diff options
author | Andreas Baumann <mail@andreasbaumann.cc> | 2017-07-08 15:01:50 +0200 |
---|---|---|
committer | Andreas Baumann <mail@andreasbaumann.cc> | 2017-07-08 15:01:50 +0200 |
commit | ce832186460563db9cdfb59bd438f242600c0edf (patch) | |
tree | fa0b716951b089a367446a5e9b6735f42f0ebd2f /src/hardware/interrupts.c | |
parent | 3b01fe6cbe94a4f0edaca0e07456bd0589d648d9 (diff) | |
download | abaos-ce832186460563db9cdfb59bd438f242600c0edf.tar.gz abaos-ce832186460563db9cdfb59bd438f242600c0edf.tar.bz2 |
forgot to set the backpointer to the interrupt manager (interrupts_t) in the
interrupt_handler_init_void (clang and O1 crashed it while initializing
the empty interrupt vectors)
Diffstat (limited to 'src/hardware/interrupts.c')
-rw-r--r-- | src/hardware/interrupts.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/src/hardware/interrupts.c b/src/hardware/interrupts.c index 4ca0f14..bec0896 100644 --- a/src/hardware/interrupts.c +++ b/src/hardware/interrupts.c @@ -53,9 +53,11 @@ // OCW2 #define OCW2_EOI 0x20 // non-specific End Of Interrupt -void interrupt_handler_init_void( interrupt_handler_t *handler ) +void interrupt_handler_init_void( interrupt_handler_t *handler, struct interrupt_t *interrupt ) { memset( handler, 0, sizeof( interrupt_handler_t ) ); + + handler->interrupt = interrupt; } void interrupt_handler_init( interrupt_handler_t *handler, uint8_t interrupt_no, struct interrupt_t *interrupt, interrupt_handler_func_t handle, void *driver ) @@ -77,7 +79,7 @@ void interrupts_init( interrupt_t *interrupt, uint16_t gdt_code_segment_selector memset( interrupt, 0, sizeof( interrupt_t ) ); interrupt_handler_t empty_interrupt_handler; - interrupt_handler_init_void( &empty_interrupt_handler ); + interrupt_handler_init_void( &empty_interrupt_handler, interrupt ); interrupt->task_manager = task_manager; |