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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
#ifndef _Cpu_c_h
#define _Cpu_c_h
#define NANO_STATE_HIGH_BIT (14)
#define LAZY_FT (1)
enum cv
{
SAFE_SEGMENT,
PUSH_SAFE,
POP_SAFE,
BP_RELATED_SAFE,
PROTECTED,
VIRTUAL_8086,
FLAT_SEGMENT,
DF_BACKWARDS,
NO_FLAGS,
ALIGN_2,
ALIGN_4,
ADDRESS_SIZE_32,
ACCESS_IS_READ,
EXPAND_UP,
COMPILE_TIME_FT,
COMPILE_TIME_FT_PAD1,
COMPILE_TIME_FT_PAD2,
COMPILE_TIME_FT_PAD3,
COMPILE_TIME_FT_PAD4,
COMPILE_TIME_FT_PAD5,
BEFORE_SINGLE,
AFTER_SINGLE,
COPIER_CHECK_OK,
SF_UNCHECKED,
SF_IOACCESS,
INVERT_JCOND,
LAST_CV
};
enum Constraints
{
ConstraintPROTECTED = 0,
ConstraintVIRTUAL_8086 = 1,
ConstraintBIG_CODE = 2,
ConstraintDF = 3,
ConstraintRAX_LS16 = 4,
ConstraintRAL_LS8 = 5,
ConstraintRBX_LS16 = 6,
ConstraintRBL_LS8 = 7,
ConstraintRCX_LS16 = 8,
ConstraintRCL_LS8 = 9,
ConstraintRDX_LS16 = 10,
ConstraintRDL_LS8 = 11,
ConstraintRBP_LS16 = 12,
ConstraintRSI_LS16 = 13,
ConstraintRDI_LS16 = 14,
ConstraintSfUnchecked = 15,
ConstraintSfIOAccess = 16,
ConstraintDS_SAFE = 17,
ConstraintES_SAFE = 18,
ConstraintFS_SAFE = 19,
ConstraintGS_SAFE = 20,
ConstraintPUSH_SAFE = 21,
ConstraintPOP_SAFE = 22,
ConstraintBP_RELATED_SAFE = 23,
ConstraintBEFORE_SINGLE = 24,
ConstraintAFTER_SINGLE = 25,
ConstraintCS_FLAT = 26,
ConstraintDS_FLAT = 27,
ConstraintES_FLAT = 28,
ConstraintFS_FLAT = 29,
ConstraintGS_FLAT = 30,
ConstraintSS_FLAT = 31,
ConstraintODD_SEGMENT = 32,
ConstraintNPX_DOES_INT7 = 33,
ConstraintDEBUGGING = 34,
ConstraintContext0 = 35,
ConstraintContext1 = 36,
ConstraintContext2 = 37,
ConstraintContext3 = 38,
ConstraintContext4 = 39,
ConstraintContext5 = 40
};
enum Targets
{
TargetUNKNOWN = 0,
TargetALPHA64 = 1,
TargetALPHA32 = 2,
TargetHPP = 3,
TargetPPC = 4,
TargetSPARC = 5
};
#define Prod (0)
#define SwappedM (0)
#define Bigendian (1)
#define Asserts (1)
#define Pig (1)
#define Tracing (1)
#define Sad (1)
#define SyncTimer (0)
#define TargetArch (3)
#define Ic (0)
#define MustAlign (1)
#define BWOP (0)
/* #defines generated by tremit.c for maniplulating pointers
* to Intel memory (that the caller knows will remain within a 4k page
*/
#ifndef SWAPPED_M /* This will be visible to mk -V checking*/
#define ConvertHostToCpuPtrLS0(base, size, offset) ((IHP)(((IU8 *)(base))+(size)-(offset)-1))
#define ConvertCpuPtrLS0toCpuPtrLS8(ls0ptr) ((IU8 *)(ls0ptr))
#define AddCpuPtrLS8(ptr, amount) ((ptr) - (amount))
#define IncCpuPtrLS8(ptr) (ptr)--
#define DecCpuPtrLS8(ptr) (ptr)++
#define DiffCpuPtrsLS8(lo, hi) ((lo) - (hi))
#define BelowCpuPtrsLS8(p1, p2) ((p1) > (p2))
#define BelowOrEqualCpuPtrsLS8(p1, p2) ((p1) >= (p2))
#define FloorIntelPageLS8(ptr) ((IU8 *) (((IHPE)(ptr)) | 0xFFF))
#define CeilingIntelPageLS8(ptr) ((IU8 *) (((IHPE)(ptr)) & ~((IHPE)0xFFF)))
#endif /* SWAPPED_M */
#define GDP_OFFSET (0)
#endif /* ! _Cpu_c_h */
|