mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 07:07:34 +00:00
Kernel: Allow building the kernel with -O0
Unfortunately the kernel doesn't run with -O0 but at least it can be successfully built with this change.
This commit is contained in:
parent
b06d01f040
commit
4fca9ee060
2 changed files with 48 additions and 40 deletions
|
@ -15,13 +15,17 @@ class GenericInterruptHandeler;
|
||||||
|
|
||||||
extern "C" void interrupt_common_asm_entry();
|
extern "C" void interrupt_common_asm_entry();
|
||||||
|
|
||||||
#define GENERATE_GENERIC_INTERRUPT_HANDLER_ASM_ENTRY(isr_number) \
|
#define GENERATE_GENERIC_INTERRUPT_HANDLER_ASM_ENTRY(isr_number) \
|
||||||
extern "C" void interrupt_##isr_number##_asm_entry(); \
|
extern "C" void interrupt_##isr_number##_asm_entry(); \
|
||||||
asm(".globl interrupt_" #isr_number "_asm_entry\n" \
|
static void interrupt_##isr_number##_asm_entry_dummy() __attribute__((used)); \
|
||||||
"interrupt_" #isr_number "_asm_entry:\n" \
|
NEVER_INLINE void interrupt_##isr_number##_asm_entry_dummy() \
|
||||||
" pushw $" #isr_number "\n" \
|
{ \
|
||||||
" pushw $0\n" \
|
asm(".globl interrupt_" #isr_number "_asm_entry\n" \
|
||||||
" jmp interrupt_common_asm_entry\n");
|
"interrupt_" #isr_number "_asm_entry:\n" \
|
||||||
|
" pushw $" #isr_number "\n" \
|
||||||
|
" pushw $0\n" \
|
||||||
|
" jmp interrupt_common_asm_entry\n"); \
|
||||||
|
}
|
||||||
|
|
||||||
void register_interrupt_handler(u8 number, void (*handler)());
|
void register_interrupt_handler(u8 number, void (*handler)());
|
||||||
void register_user_callable_interrupt_handler(u8 number, void (*handler)());
|
void register_user_callable_interrupt_handler(u8 number, void (*handler)());
|
||||||
|
|
|
@ -16,43 +16,47 @@ namespace Kernel {
|
||||||
extern "C" void syscall_handler(TrapFrame*) __attribute__((used));
|
extern "C" void syscall_handler(TrapFrame*) __attribute__((used));
|
||||||
extern "C" void syscall_asm_entry();
|
extern "C" void syscall_asm_entry();
|
||||||
|
|
||||||
// clang-format off
|
static void syscall_asm_entry_dummy() __attribute__((used));
|
||||||
|
NEVER_INLINE void syscall_asm_entry_dummy()
|
||||||
|
{
|
||||||
|
// clang-format off
|
||||||
#if ARCH(I386)
|
#if ARCH(I386)
|
||||||
asm(
|
asm(
|
||||||
".globl syscall_asm_entry\n"
|
".globl syscall_asm_entry\n"
|
||||||
"syscall_asm_entry:\n"
|
"syscall_asm_entry:\n"
|
||||||
" pushl $0x0\n"
|
" pushl $0x0\n"
|
||||||
" pusha\n"
|
" pusha\n"
|
||||||
" pushl %ds\n"
|
" pushl %ds\n"
|
||||||
" pushl %es\n"
|
" pushl %es\n"
|
||||||
" pushl %fs\n"
|
" pushl %fs\n"
|
||||||
" pushl %gs\n"
|
" pushl %gs\n"
|
||||||
" pushl %ss\n"
|
" pushl %ss\n"
|
||||||
" mov $" __STRINGIFY(GDT_SELECTOR_DATA0) ", %ax\n"
|
" mov $" __STRINGIFY(GDT_SELECTOR_DATA0) ", %ax\n"
|
||||||
" mov %ax, %ds\n"
|
" mov %ax, %ds\n"
|
||||||
" mov %ax, %es\n"
|
" mov %ax, %es\n"
|
||||||
" mov $" __STRINGIFY(GDT_SELECTOR_PROC) ", %ax\n"
|
" mov $" __STRINGIFY(GDT_SELECTOR_PROC) ", %ax\n"
|
||||||
" mov %ax, %fs\n"
|
" mov %ax, %fs\n"
|
||||||
" cld\n"
|
" cld\n"
|
||||||
" xor %esi, %esi\n"
|
" xor %esi, %esi\n"
|
||||||
" xor %edi, %edi\n"
|
" xor %edi, %edi\n"
|
||||||
" pushl %esp \n" // set TrapFrame::regs
|
" pushl %esp \n" // set TrapFrame::regs
|
||||||
" subl $" __STRINGIFY(TRAP_FRAME_SIZE - 4) ", %esp \n"
|
" subl $" __STRINGIFY(TRAP_FRAME_SIZE - 4) ", %esp \n"
|
||||||
" movl %esp, %ebx \n"
|
" movl %esp, %ebx \n"
|
||||||
" pushl %ebx \n" // push pointer to TrapFrame
|
" pushl %ebx \n" // push pointer to TrapFrame
|
||||||
" call enter_trap_no_irq \n"
|
" call enter_trap_no_irq \n"
|
||||||
" movl %ebx, 0(%esp) \n" // push pointer to TrapFrame
|
" movl %ebx, 0(%esp) \n" // push pointer to TrapFrame
|
||||||
" call syscall_handler \n"
|
" call syscall_handler \n"
|
||||||
" movl %ebx, 0(%esp) \n" // push pointer to TrapFrame
|
" movl %ebx, 0(%esp) \n" // push pointer to TrapFrame
|
||||||
" jmp common_trap_exit \n");
|
" jmp common_trap_exit \n");
|
||||||
#elif ARCH(X86_64)
|
#elif ARCH(X86_64)
|
||||||
asm(
|
asm(
|
||||||
".globl syscall_asm_entry\n"
|
".globl syscall_asm_entry\n"
|
||||||
"syscall_asm_entry:\n"
|
"syscall_asm_entry:\n"
|
||||||
" cli\n"
|
" cli\n"
|
||||||
" hlt\n");
|
" hlt\n");
|
||||||
#endif
|
#endif
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
}
|
||||||
|
|
||||||
namespace Syscall {
|
namespace Syscall {
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue