feat: lru eviction policy on page caches
[lunaix-os.git] / lunaix-os / includes / arch / x86 / interrupts.h
index 9d3d0857ddff155ad290d2ed095f071b9dacfaff..3643a9ef668a92f2ae4b8f1b81d4a15ba431f67b 100644 (file)
@@ -5,8 +5,24 @@
 
 #ifndef __ASM__
 #include <hal/cpu.h>
 
 #ifndef __ASM__
 #include <hal/cpu.h>
-typedef struct {
-    gp_regs registers;
+typedef struct
+{
+    struct
+    {
+        reg32 eax;
+        reg32 ebx;
+        reg32 ecx;
+        reg32 edx;
+        reg32 edi;
+        reg32 ebp;
+        reg32 esi;
+        reg32 ds;
+        reg32 es;
+        reg32 fs;
+        reg32 gs;
+        reg32 esp;
+    } registers;
+
     unsigned int vector;
     unsigned int err_code;
     unsigned int eip;
     unsigned int vector;
     unsigned int err_code;
     unsigned int eip;
@@ -16,7 +32,7 @@ typedef struct {
     unsigned int ss;
 } __attribute__((packed)) isr_param;
 
     unsigned int ss;
 } __attribute__((packed)) isr_param;
 
-typedef void (*int_subscriber)(isr_param*);
+typedef void (*int_subscriber)(const isr_param*);
 
 #pragma region ISR_DECLARATION
 
 
 #pragma region ISR_DECLARATION
 
@@ -47,8 +63,10 @@ ISR(21)
 
 ISR(32)
 ISR(33)
 
 ISR(32)
 ISR(33)
+ISR(34)
 
 ISR(201)
 
 ISR(201)
+ISR(202)
 
 ISR(210)
 
 
 ISR(210)
 
@@ -66,8 +84,7 @@ intr_subscribe(const uint8_t vector, int_subscriber);
 void
 intr_unsubscribe(const uint8_t vector, int_subscriber);
 
 void
 intr_unsubscribe(const uint8_t vector, int_subscriber);
 
-void
-intr_set_fallback_handler(int_subscriber);
+void intr_set_fallback_handler(int_subscriber);
 
 void
 intr_handler(isr_param* param);
 
 void
 intr_handler(isr_param* param);