1
0
mirror of https://gitlab.os-k.eu/os-k-team/kvisc.git synced 2023-08-25 14:05:46 +02:00
kvisc/pc/regs.h

79 lines
1.4 KiB
C
Raw Normal View History

2019-05-29 16:57:22 +02:00
// The OS/K Team licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.
enum
{
INV,
2019-06-02 16:33:28 +02:00
RIP, FLG, RBP, RSP,
#define rip R(RIP)
#define flg R(FLG)
#define rbp R(RBP)
#define rsp R(RSP)
2019-05-29 16:57:22 +02:00
2019-06-02 16:33:28 +02:00
RAX, RBX, RCX, RDX,
RSX, RBI, RDI, RSI,
#define rax R(RAX)
#define rbx R(RBX)
#define rcx R(RCX)
#define rdx R(RDX)
#define rsx R(RSX)
#define rbi R(RBI)
#define rdi R(RDI)
#define rsi R(RSI)
2019-05-29 16:57:22 +02:00
2019-06-02 16:33:28 +02:00
NX0, NX1, NX2, NX3,
NX4, NX5, NX6, NX7,
2019-05-29 16:57:22 +02:00
2019-06-02 16:33:28 +02:00
AX0, AX1, AX2, AX3,
AX4, AX5, AX6, AX7,
2019-05-30 12:44:56 +02:00
2019-06-02 16:33:28 +02:00
CR0, CR1, CR2, CR3,
CR4, CR5, CR6, CR7,
#define cr0 R(CR0)
#define cr1 R(CR1)
#define cr2 R(CR2)
#define cr3 R(CR3)
2019-05-30 12:44:56 +02:00
2019-06-02 16:33:28 +02:00
SA0, SA1,
SA2, SA3,
SA4, SA5,
SA6, SA7,
2019-05-29 16:57:22 +02:00
NREGS
};
2019-05-30 12:44:56 +02:00
enum
2019-05-29 16:57:22 +02:00
{
GPR = 1 << 0, // General
CTL = 1 << 1, // Control
SEG = 1 << 2, // Segment
RES = 1 << 8, // Reserved for insternal use
SYS = 1 << 9, // Reserved for supervisor mode
};
// FLG register
enum
{
CF = 1 << 0, // Carry flag
PF = 1 << 1, // Parity flag
AC = 1 << 2, // Auxiliary flag
ZF = 1 << 3, // Zero flag
OV = 1 << 4, // Overflow flag
DF = 1 << 5, // Direction flag
SF = 1 << 6, // Sign flag
2019-05-30 12:44:56 +02:00
2019-05-29 16:57:22 +02:00
UF = 1 << 16, // User-mode flag
IF = 1 << 17, // Interrupts enable flag
};
struct reg_t
{
char *name;
char *desc;
char *conv;
ulong val;
ulong flags;
};