summaryrefslogtreecommitdiff
path: root/kernel/cpu/idt.h
blob: 46ef4a39d165c5704806f62f0f99dd68a9e12964 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
/**
 * @file idt.h
 *
 * @author Freya Murphy <freya@freyacat.org>
 *
 * IDT functions
 */

#ifndef IDT_H_
#define IDT_H_

#include <stdint.h>

struct isr_regs {
	uint64_t r15;
	uint64_t r14;
	uint64_t r13;
	uint64_t r12;
	uint64_t r11;
	uint64_t r10;
	uint64_t r9;
	uint64_t r8;
	uint64_t rbp;
	uint64_t rdi;
	uint64_t rsi;
	uint64_t rdx;
	uint64_t rcx;
	uint64_t rbx;
	uint64_t rax;

	uint64_t rip;
	uint64_t cs;
	uint64_t rflags;
	uint64_t rsp;
	uint64_t ss;
};

struct rflags {
	uint64_t cf : 1,
	         : 1,
	         pf : 1,
	         : 1,
	         af : 1,
	         : 1,
	         zf : 1,
	         sf : 1,

	         tf : 1,
	         if_ : 1,
	         df : 1,
	         of : 1,
	         iopl : 2,
	         nt : 1,
	         md : 1,

	         rf : 1,
	         vm : 1,
	         ac : 1,
	         vif : 1,
	         vip : 1,
	         id : 1,
	         : 42;
};

void idt_init(void);

#endif /* idt.h */