summaryrefslogtreecommitdiff
path: root/kernel/include/registers.h
blob: 373e5570b53abcdb14f11d9dbddba904c32d128c (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
#ifndef REGISTERS_H
#define REGISTERS_H

#include <types.h>

#define RAX	0x0
#define RBX	0x8
#define RCX	0x10
#define RDX	0x18
#define RSI	0x20
#define RDI	0x28
#define RSP	0x30
#define RBP	0x38
#define R8	0x40
#define R9	0x48
#define R10	0x50
#define R11	0x58
#define R12	0x60
#define R13	0x68
#define R14	0x70
#define R15	0x78
#define RIP	0x80
#define RFLAGS	0x88
#define CR3	0x90
#define CS	0x98
#define DS	0x9c
#define SS	0x100
#define ES	0x104
#define FS	0x108
#define GS	0x10c

struct registers_t {
	uint64_t rax;
	uint64_t rbx;
	uint64_t rcx;
	uint64_t rdx;
	uint64_t rsi;
	uint64_t rdi;
	uint64_t rsp;
	uint64_t rbp;
	uint64_t r8;
	uint64_t r9;
	uint64_t r10;
	uint64_t r11;
	uint64_t r12;
	uint64_t r13;
	uint64_t r14;
	uint64_t r15;
	uint64_t rip;
	uint64_t rflags;
	uint64_t cr3;
	uint16_t cs;
	uint16_t ds;
	uint16_t ss;
	uint16_t es;
	uint16_t fs;
	uint16_t gs;
} __attribute__((packed, aligned(8)));
typedef struct registers_t registers_t;

#endif