mirror of
https://github.com/EnderIce2/Fennix.git
synced 2025-07-02 02:49:15 +00:00
Merge remote-tracking branch 'Drivers/master'
This commit is contained in:
83
Drivers/library/Makefile
Normal file
83
Drivers/library/Makefile
Normal file
@ -0,0 +1,83 @@
|
||||
# Config file
|
||||
include ../../Makefile.conf
|
||||
|
||||
FILENAME = libkernel.so
|
||||
|
||||
CC = ../../$(COMPILER_PATH)/$(COMPILER_ARCH)gcc
|
||||
CPP = ../../$(COMPILER_PATH)/$(COMPILER_ARCH)g++
|
||||
LD = ../../$(COMPILER_PATH)/$(COMPILER_ARCH)ld
|
||||
AS = ../../$(COMPILER_PATH)/$(COMPILER_ARCH)as
|
||||
AR = ../../$(COMPILER_PATH)/$(COMPILER_ARCH)ar
|
||||
|
||||
S_SOURCES = $(shell find ./ -type f -name '*.S' -not -path "./crt/*")
|
||||
C_SOURCES = $(shell find ./ -type f -name '*.c' -not -path "./crt/*")
|
||||
CPP_SOURCES = $(shell find ./ -type f -name '*.cpp' -not -path "./crt/*")
|
||||
HEADERS = $(sort $(dir $(wildcard ../include/*)))
|
||||
OBJ = $(C_SOURCES:.c=.o) $(CPP_SOURCES:.cpp=.o) $(ASM_SOURCES:.asm=.o) $(S_SOURCES:.S=.o) $(PSF_SOURCES:.psf=.o) $(BMP_SOURCES:.bmp=.o)
|
||||
STACK_USAGE_OBJ = $(C_SOURCES:.c=.su) $(CPP_SOURCES:.cpp=.su)
|
||||
INCLUDE_DIR = ../include
|
||||
|
||||
LDFLAGS := -fPIC -fPIE -pie -nostdlib -nodefaultlibs -nolibc \
|
||||
-zmax-page-size=0x1000 -Wl,-Map libkernel.map -shared
|
||||
|
||||
WARNCFLAG = -Wall -Wextra
|
||||
|
||||
CFLAGS := -I$(INCLUDE_DIR) -shared
|
||||
|
||||
ifeq ($(OSARCH), amd64)
|
||||
|
||||
CFLAGS += -fPIC -fPIE -pie -mno-80387 -mno-mmx -mno-3dnow \
|
||||
-mno-red-zone -mno-sse -mno-sse2 \
|
||||
-march=x86-64 -pipe -ffunction-sections \
|
||||
-msoft-float -fno-builtin
|
||||
|
||||
else ifeq ($(OSARCH), i386)
|
||||
|
||||
CFLAGS += -fPIC -fPIE -pie -mno-80387 -mno-mmx -mno-3dnow \
|
||||
-mno-red-zone -mno-sse -mno-sse2 -ffunction-sections \
|
||||
-march=i386 -pipe -msoft-float -fno-builtin
|
||||
|
||||
else ifeq ($(OSARCH), aarch64)
|
||||
|
||||
CFLAGS += -pipe -fno-builtin -fPIC
|
||||
|
||||
endif
|
||||
|
||||
CRT_CFLAGS := -fPIC -fPIE -pie -mno-red-zone -std=c++20 -I../include
|
||||
|
||||
ifeq ($(DEBUG), 1)
|
||||
CFLAGS += -DDEBUG -ggdb3 -O0 -fdiagnostics-color=always -fstack-usage
|
||||
CRT_CFLAGS += -DDEBUG -ggdb3 -O0 -fdiagnostics-color=always -fstack-usage
|
||||
ifeq ($(OSARCH), amd64)
|
||||
CFLAGS += -fverbose-asm
|
||||
CRT_CFLAGS += -fverbose-asm
|
||||
endif
|
||||
ifneq ($(OSARCH), aarch64)
|
||||
CFLAGS += -fstack-check
|
||||
CRT_CFLAGS += -fstack-check
|
||||
endif
|
||||
LDFLAGS += -ggdb3 -O0
|
||||
endif
|
||||
|
||||
build: $(FILENAME)
|
||||
$(CPP) $(CRT_CFLAGS) -c crt/crt0.cpp -o dcrt0.o
|
||||
mv dcrt0.o ../out/dcrt0.o
|
||||
|
||||
$(FILENAME): $(OBJ)
|
||||
$(info Linking $@)
|
||||
$(CC) $(LDFLAGS) $(OBJ) -o ../out/$(FILENAME)
|
||||
|
||||
%.o: %.c $(HEADERS)
|
||||
$(info Compiling $<)
|
||||
$(CC) $(CFLAGS) $(WARNCFLAG) -std=c17 -c $< -o $@
|
||||
|
||||
%.o: %.cpp $(HEADERS)
|
||||
$(info Compiling $<)
|
||||
$(CPP) $(CFLAGS) $(WARNCFLAG) -std=c++20 -fexceptions -c $< -o $@
|
||||
|
||||
%.o: %.S
|
||||
$(info Compiling $<)
|
||||
$(AS) -o $@ $<
|
||||
|
||||
clean:
|
||||
rm -f libkernel.map $(OBJ) $(FILENAME) $(STACK_USAGE_OBJ) dcrt0.su
|
94
Drivers/library/base.cpp
Normal file
94
Drivers/library/base.cpp
Normal file
@ -0,0 +1,94 @@
|
||||
/*
|
||||
This file is part of Fennix Drivers.
|
||||
|
||||
Fennix Drivers is free software: you can redistribute it and/or
|
||||
modify it under the terms of the GNU General Public License as
|
||||
published by the Free Software Foundation, either version 3 of
|
||||
the License, or (at your option) any later version.
|
||||
|
||||
Fennix Drivers is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with Fennix Drivers. If not, see <https://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include <base.h>
|
||||
|
||||
#include <driver.h>
|
||||
#include <errno.h>
|
||||
#include <fs.h>
|
||||
|
||||
extern "C" dev_t DriverID;
|
||||
|
||||
#define KernelFunction(Name) \
|
||||
extern "C" __attribute__((naked, used)) long \
|
||||
__##Name(dev_t, long, long, long, \
|
||||
long, long, long) { return 0; }
|
||||
|
||||
void *operator new(__SIZE_TYPE__) { return (void *)1; }
|
||||
void *operator new[](__SIZE_TYPE__) { return (void *)1; }
|
||||
void operator delete(void *) {}
|
||||
void operator delete[](void *) {}
|
||||
void operator delete(void *, __SIZE_TYPE__) {}
|
||||
void operator delete[](void *, __SIZE_TYPE__) {}
|
||||
|
||||
KernelFunction(KernelPrint);
|
||||
KernelFunction(KernelLog);
|
||||
|
||||
KernelFunction(RegisterInterruptHandler);
|
||||
KernelFunction(OverrideInterruptHandler);
|
||||
KernelFunction(UnregisterInterruptHandler);
|
||||
KernelFunction(UnregisterAllInterruptHandlers);
|
||||
|
||||
KernelFunction(AllocateMemory);
|
||||
KernelFunction(FreeMemory);
|
||||
KernelFunction(AppendMapFlag);
|
||||
KernelFunction(RemoveMapFlag);
|
||||
KernelFunction(MapPages);
|
||||
KernelFunction(UnmapPages);
|
||||
|
||||
KernelFunction(MemoryCopy);
|
||||
KernelFunction(MemorySet);
|
||||
KernelFunction(MemoryMove);
|
||||
KernelFunction(StringLength);
|
||||
KernelFunction(strstr);
|
||||
|
||||
KernelFunction(EnterCriticalSection);
|
||||
KernelFunction(LeaveCriticalSection);
|
||||
|
||||
KernelFunction(CreateKernelProcess);
|
||||
KernelFunction(CreateKernelThread);
|
||||
KernelFunction(GetCurrentProcess);
|
||||
KernelFunction(KillProcess);
|
||||
KernelFunction(KillThread);
|
||||
KernelFunction(Yield);
|
||||
KernelFunction(Sleep);
|
||||
|
||||
KernelFunction(RegisterFileSystem);
|
||||
KernelFunction(UnregisterFileSystem);
|
||||
|
||||
KernelFunction(PIC_EOI);
|
||||
KernelFunction(IRQ_MASK);
|
||||
KernelFunction(IRQ_UNMASK);
|
||||
KernelFunction(PS2Wait);
|
||||
KernelFunction(PS2WriteCommand);
|
||||
KernelFunction(PS2WriteData);
|
||||
KernelFunction(PS2ReadData);
|
||||
KernelFunction(PS2ReadStatus);
|
||||
KernelFunction(PS2ReadAfterACK);
|
||||
KernelFunction(PS2ClearOutputBuffer);
|
||||
KernelFunction(PS2ACKTimeout);
|
||||
|
||||
KernelFunction(RegisterDevice);
|
||||
KernelFunction(UnregisterDevice);
|
||||
|
||||
KernelFunction(ReportInputEvent);
|
||||
|
||||
KernelFunction(InitializePCI);
|
||||
KernelFunction(GetPCIDevices);
|
||||
KernelFunction(GetBAR);
|
||||
KernelFunction(iLine);
|
||||
KernelFunction(iPin);
|
144
Drivers/library/crt/crt0.cpp
Normal file
144
Drivers/library/crt/crt0.cpp
Normal file
@ -0,0 +1,144 @@
|
||||
/*
|
||||
This file is part of Fennix Drivers.
|
||||
|
||||
Fennix Drivers is free software: you can redistribute it and/or
|
||||
modify it under the terms of the GNU General Public License as
|
||||
published by the Free Software Foundation, either version 3 of
|
||||
the License, or (at your option) any later version.
|
||||
|
||||
Fennix Drivers is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with Fennix Drivers. If not, see <https://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include <driver.h>
|
||||
#include <errno.h>
|
||||
|
||||
dev_t DriverID = -1;
|
||||
|
||||
extern "C" int DriverEntry();
|
||||
extern "C" int DriverFinal();
|
||||
extern "C" int DriverPanic();
|
||||
extern "C" int DriverProbe();
|
||||
|
||||
typedef void (*CallPtr)(void);
|
||||
extern "C" CallPtr __init_array_start[0], __init_array_end[0];
|
||||
extern "C" CallPtr __fini_array_start[0], __fini_array_end[0];
|
||||
|
||||
extern "C" int _start(dev_t id)
|
||||
{
|
||||
DriverID = id;
|
||||
|
||||
for (CallPtr *func = __init_array_start; func != __init_array_end; func++)
|
||||
(*func)();
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
extern "C" int _final()
|
||||
{
|
||||
int err = DriverFinal();
|
||||
|
||||
for (CallPtr *func = __fini_array_start; func != __fini_array_end; func++)
|
||||
(*func)();
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
/* ---------------------------------------------------------- */
|
||||
|
||||
#define KCALL extern "C" __attribute__((used))
|
||||
|
||||
#define KernelFunction(Name) \
|
||||
KCALL long __##Name(dev_t id, \
|
||||
long arg0 = 0, long arg1 = 0, long arg2 = 0, \
|
||||
long arg3 = 0, long arg4 = 0, long arg5 = 0);
|
||||
|
||||
#define DefineFunction(ReturnType, Name, ...) \
|
||||
KernelFunction(Name); \
|
||||
KCALL ReturnType Name(__VA_ARGS__)
|
||||
|
||||
#define DefineWrapper(Name) \
|
||||
KernelFunction(Name); \
|
||||
KCALL long Name(long arg0, long arg1, long arg2, long arg3, long arg4, long arg5) \
|
||||
{ \
|
||||
return __##Name(DriverID, arg0, arg1, arg2, arg3, arg4, arg5); \
|
||||
}
|
||||
|
||||
DefineFunction(void, KernelPrint, const char *format, ...)
|
||||
{
|
||||
__builtin_va_list args;
|
||||
__builtin_va_start(args, format);
|
||||
__KernelPrint(DriverID, (long)format, (long)args);
|
||||
__builtin_va_end(args);
|
||||
}
|
||||
|
||||
DefineFunction(void, KernelLog, const char *format, ...)
|
||||
{
|
||||
__builtin_va_list args;
|
||||
__builtin_va_start(args, format);
|
||||
__KernelLog(DriverID, (long)format, (long)args);
|
||||
__builtin_va_end(args);
|
||||
}
|
||||
|
||||
DefineWrapper(RegisterInterruptHandler);
|
||||
DefineWrapper(OverrideInterruptHandler);
|
||||
DefineWrapper(UnregisterInterruptHandler);
|
||||
DefineWrapper(UnregisterAllInterruptHandlers);
|
||||
|
||||
DefineWrapper(AllocateMemory);
|
||||
DefineWrapper(FreeMemory);
|
||||
DefineWrapper(AppendMapFlag);
|
||||
DefineWrapper(RemoveMapFlag);
|
||||
DefineWrapper(MapPages);
|
||||
DefineWrapper(UnmapPages);
|
||||
|
||||
DefineWrapper(MemoryCopy);
|
||||
DefineWrapper(MemorySet);
|
||||
DefineWrapper(MemoryMove);
|
||||
DefineWrapper(StringLength);
|
||||
#pragma GCC diagnostic push
|
||||
#pragma GCC diagnostic ignored "-Wbuiltin-declaration-mismatch"
|
||||
DefineWrapper(strstr);
|
||||
#pragma GCC diagnostic pop
|
||||
|
||||
DefineWrapper(EnterCriticalSection);
|
||||
DefineWrapper(LeaveCriticalSection);
|
||||
|
||||
DefineWrapper(CreateKernelProcess);
|
||||
DefineWrapper(CreateKernelThread);
|
||||
DefineWrapper(GetCurrentProcess);
|
||||
DefineWrapper(KillProcess);
|
||||
DefineWrapper(KillThread);
|
||||
DefineWrapper(Yield);
|
||||
DefineWrapper(Sleep);
|
||||
|
||||
DefineWrapper(RegisterFileSystem);
|
||||
DefineWrapper(UnregisterFileSystem);
|
||||
|
||||
DefineWrapper(PIC_EOI);
|
||||
DefineWrapper(IRQ_MASK);
|
||||
DefineWrapper(IRQ_UNMASK);
|
||||
DefineWrapper(PS2Wait);
|
||||
DefineWrapper(PS2WriteCommand);
|
||||
DefineWrapper(PS2WriteData);
|
||||
DefineWrapper(PS2ReadData);
|
||||
DefineWrapper(PS2ReadStatus);
|
||||
DefineWrapper(PS2ReadAfterACK);
|
||||
DefineWrapper(PS2ClearOutputBuffer);
|
||||
DefineWrapper(PS2ACKTimeout);
|
||||
|
||||
DefineWrapper(RegisterDevice);
|
||||
DefineWrapper(UnregisterDevice);
|
||||
|
||||
DefineWrapper(ReportInputEvent);
|
||||
|
||||
DefineWrapper(InitializePCI);
|
||||
DefineWrapper(GetPCIDevices);
|
||||
DefineWrapper(GetBAR);
|
||||
DefineWrapper(iLine);
|
||||
DefineWrapper(iPin);
|
Reference in New Issue
Block a user