kern

annotate src/intr.h @ 49:50730d42d2d3

fuck yeah, now do priviledge levels and TSS
author John Tsiombikas <nuclear@member.fsf.org>
date Sat, 30 Jul 2011 07:21:54 +0300
parents f65b348780e3
children b1e8c8251884
rev   line source
nuclear@11 1 #ifndef INTR_H_
nuclear@11 2 #define INTR_H_
nuclear@11 3
nuclear@11 4 #include <inttypes.h>
nuclear@25 5 #include "asmops.h"
nuclear@11 6
nuclear@35 7 /* offset used to remap IRQ numbers (+32) */
nuclear@35 8 #define IRQ_OFFSET 32
nuclear@35 9 /* conversion macros between IRQ and interrupt numbers */
nuclear@35 10 #define IRQ_TO_INTR(x) ((x) + IRQ_OFFSET)
nuclear@35 11 #define INTR_TO_IRQ(x) ((x) - IRQ_OFFSET)
nuclear@35 12 /* checks whether a particular interrupt is an remapped IRQ */
nuclear@35 13 #define IS_IRQ(n) ((n) >= IRQ_OFFSET && (n) < IRQ_OFFSET + 16)
nuclear@35 14
nuclear@47 15 /* structure used to pass the interrupt stack frame from the
nuclear@47 16 * entry points to the C dispatch function.
nuclear@47 17 */
nuclear@47 18 struct intr_frame {
nuclear@47 19 /* registers pushed by pusha in intr_entry_* */
nuclear@47 20 struct registers regs;
nuclear@47 21 /* interrupt number and error code pushed in intr_entry_* */
nuclear@47 22 uint32_t inum, err;
nuclear@47 23 /* pushed by CPU during interrupt entry */
nuclear@47 24 uint32_t eip, cs, eflags;
nuclear@47 25 /* pushed by CPU during interrupt entry from user space */
nuclear@47 26 uint32_t esp, ss;
nuclear@49 27 } __attribute__ ((packed));
nuclear@47 28
nuclear@47 29
nuclear@35 30
nuclear@11 31 typedef void (*intr_func_t)(int, uint32_t);
nuclear@11 32
nuclear@11 33
nuclear@11 34 void init_intr(void);
nuclear@11 35
nuclear@11 36 void interrupt(int intr_num, intr_func_t func);
nuclear@11 37
nuclear@25 38 /* defined in intr-asm.S */
nuclear@25 39 int get_intr_state(void);
nuclear@25 40 void set_intr_state(int s);
nuclear@25 41
nuclear@47 42 void intr_ret(struct intr_frame ifrm);
nuclear@47 43
nuclear@11 44 #endif /* INTR_H_ */