serenity/Kernel/Arch/x86_64/Interrupts.h

44 lines
1.6 KiB
C
Raw Normal View History

2020-06-27 23:06:33 +00:00
/*
* Copyright (c) 2018-2021, Andreas Kling <kling@serenityos.org>
* Copyright (c) 2021, Leon Albrecht <leon2002.la@gmail.com>
2020-06-27 23:06:33 +00:00
*
* SPDX-License-Identifier: BSD-2-Clause
2020-06-27 23:06:33 +00:00
*/
#pragma once
#include <AK/Types.h>
#include <Kernel/Interrupts/GenericInterruptHandler.h>
2020-06-27 23:06:33 +00:00
#include <AK/Platform.h>
VALIDATE_IS_X86()
2020-06-27 23:06:33 +00:00
namespace Kernel {
2022-01-07 12:04:05 +00:00
class GenericInterruptHandler;
extern "C" void interrupt_common_asm_entry();
2022-10-04 00:05:54 +00:00
#define INTERRUPT_HANDLER_PUSH_PADDING "pushw $0\npushw $0\n"
// clang-format off
#define GENERATE_GENERIC_INTERRUPT_HANDLER_ASM_ENTRY(isr_number) \
extern "C" void interrupt_##isr_number##_asm_entry(); \
static void interrupt_##isr_number##_asm_entry_dummy() __attribute__((used)); \
NEVER_INLINE void interrupt_##isr_number##_asm_entry_dummy() \
{ \
asm(".globl interrupt_" #isr_number "_asm_entry\n" \
"interrupt_" #isr_number "_asm_entry:\n" \
INTERRUPT_HANDLER_PUSH_PADDING \
" pushw $" #isr_number "\n" \
" pushw $0\n" \
" jmp interrupt_common_asm_entry\n"); \
}
// clang-format on
void register_interrupt_handler(u8 number, void (*handler)());
void register_user_callable_interrupt_handler(u8 number, void (*handler)());
void register_disabled_interrupt_handler(u8 number, GenericInterruptHandler& handler);
2020-06-27 23:06:33 +00:00
}