]>
Commit | Line | Data |
---|---|---|
b7da2494 SG |
1 | typedef long Long; |
2 | ||
3 | /* The following enum is used to access the special registers in | |
4 | the saved machine state. */ | |
5 | ||
6 | typedef enum | |
7 | { | |
8 | kDc_SavedPC = 0, /* really SRR0 */ | |
9 | kDc_SavedMSR = 1, /* really SRR1 */ | |
10 | kDc_SavedCR = 2, | |
11 | kDc_SavedLR = 3, | |
12 | kDc_SavedDSISR = 4, | |
13 | kDc_SavedDAR = 5, | |
14 | kDc_SavedXER = 6, | |
15 | kDc_SavedCTR = 7, | |
16 | kDc_SavedSDR1 = 8, | |
17 | kDc_SavedRTCU = 9, | |
18 | kDc_SavedRTCL = 10, | |
19 | kDc_SavedDEC = 11, | |
20 | kDc_SavedSR00 = 12, /* The Segement Registers are consecutive */ | |
21 | kDc_SavedSR01 = 13, /* kDc_SavedSR00 + n is supported */ | |
22 | kDc_SavedSR02 = 14, | |
23 | kDc_SavedSR03 = 15, | |
24 | kDc_SavedSR04 = 16, | |
25 | kDc_SavedSR05 = 17, | |
26 | kDc_SavedSR06 = 18, | |
27 | kDc_SavedSR07 = 19, | |
28 | kDc_SavedSR08 = 20, | |
29 | kDc_SavedSR09 = 21, | |
30 | kDc_SavedSR10 = 22, | |
31 | kDc_SavedSR11 = 23, | |
32 | kDc_SavedSR12 = 24, | |
33 | kDc_SavedSR13 = 25, | |
34 | kDc_SavedSR14 = 26, | |
35 | kDc_SavedSR15 = 27, | |
36 | kDc_SavedFPSCR = 29, | |
37 | kDc_SavedMQ = 30, | |
38 | kDc_SavedBAT0U = 31, | |
39 | kDc_SavedBAT0L = 32, | |
40 | kDc_SavedBAT1U = 33, | |
41 | kDc_SavedBAT1L = 34, | |
42 | kDc_SavedBAT2U = 35, | |
43 | kDc_SavedBAT2L = 36, | |
44 | kDc_SavedBAT3U = 37, | |
45 | kDc_SavedBAT3L = 38, | |
46 | ||
47 | kNumberSpecialRegisters = 39 | |
48 | } Dc_SavedRegisterName; | |
49 | ||
50 | /* Access to floating points is not very easy. This allows the number to be | |
51 | accessed both as a floating number and as a pair of Longs. */ | |
52 | ||
53 | typedef union | |
54 | { | |
55 | double asfloat; /* access the variable as a floating number */ | |
56 | struct | |
57 | { | |
58 | Long high; | |
59 | Long low; | |
60 | } | |
61 | asLONG; /* access the variable as two Longs */ | |
62 | } FloatingPoints; | |
63 | ||
64 | /* The following is the standard record for Saving a machine state */ | |
65 | ||
66 | struct SavedMachineState | |
67 | { | |
68 | FloatingPoints CSavedFPRegs[32]; /* The floating point registers [0->31] */ | |
69 | /* ***32bit assumption*** */ | |
70 | Long CsavedRegs[32]; /* space to save the General Registers */ | |
71 | /* These are saved 0->31 */ | |
72 | Long CexReason; | |
73 | Long SavedDomainID; | |
74 | union | |
75 | { /* must be 8-byte aligned, so doubleFPSCR is 8-byte aligned */ | |
76 | struct | |
77 | { | |
78 | Long CsavedSRR0; /* Index 0 - The saved PC */ | |
79 | Long CsavedSRR1; /* 1 saved MSR */ | |
80 | Long CsavedCR; /* 2 */ | |
81 | Long CsavedLR; /* 3 */ | |
82 | Long CsavedDSISR; /* 4 */ | |
83 | Long CsavedDAR; /* 5 */ | |
84 | ||
85 | Long CsavedXER; /* 6 */ | |
86 | Long CsavedCTR; /* 7 */ | |
87 | Long CsavedSDR1; /* 8 */ | |
88 | Long CsavedRTCU; /* 9 */ | |
89 | Long CsavedRTCL; /* 10 */ | |
90 | Long CsavedDEC; /* 11 */ | |
91 | Long CsavedSR0; /* 12 */ | |
92 | Long CsavedSR1; /* 13 */ | |
93 | Long CsavedSR2; /* 14 */ | |
94 | Long CsavedSR3; /* 15 */ | |
95 | Long CsavedSR4; /* 16 */ | |
96 | Long CsavedSR5; /* 17 */ | |
97 | Long CsavedSR6; /* 18 */ | |
98 | Long CsavedSR7; /* 19 */ | |
99 | Long CsavedSR8; /* 20 */ | |
100 | Long CsavedSR9; /* 21 */ | |
101 | Long CsavedSR10; /* 22 */ | |
102 | Long CsavedSR11; /* 23 */ | |
103 | Long CsavedSR12; /* 24 */ | |
104 | Long CsavedSR13; /* 25 */ | |
105 | Long CsavedSR14; /* 26 */ | |
106 | Long CsavedSR15; /* 27 */ | |
107 | /* CdoubleFPSCR must be double word aligned */ | |
108 | Long CdoubleFPSCR; /* 28 this is the upper part of the store and has | |
109 | no meaning */ | |
110 | Long CsavedFPSCR; /* 29 */ | |
111 | Long CsavedMQ; /* 30 */ | |
112 | Long CsavedBAT0U; /* 31 */ | |
113 | Long CsavedBAT0L; /* 32 */ | |
114 | Long CsavedBAT1U; /* 33 */ | |
115 | Long CsavedBAT1L; /* 34 */ | |
116 | Long CsavedBAT2U; /* 35 */ | |
117 | Long CsavedBAT2L; /* 36 */ | |
118 | Long CsavedBAT3U; /* 37 */ | |
119 | Long CsavedBAT3L; /* 38 */ | |
120 | } | |
121 | SpecialRegistersEnumerated; | |
122 | ||
123 | Long SpecialRegistersIndexed[kNumberSpecialRegisters]; | |
124 | } u; | |
125 | ||
126 | Long Padding[3]; /* Needed for quad-word alignment */ | |
127 | }; | |
128 | ||
129 | struct StackFrame | |
130 | { | |
131 | LONG *ExceptionDomainID; | |
132 | /*ProcessorStructure*/ int *ExceptionProcessorID; | |
133 | BYTE *ExceptionDescription; | |
134 | LONG ExceptionFlags; | |
135 | LONG ExceptionErrorCode; | |
136 | LONG ExceptionNumber; | |
137 | struct SavedMachineState ExceptionState; | |
138 | }; | |
139 | ||
140 | /* Register values. All of these values *MUST* agree with tm.h */ | |
141 | #define GP0_REGNUM 0 /* GPR register 0 */ | |
142 | #define SP_REGNUM 1 /* Contains address of top of stack */ | |
143 | #define FP0_REGNUM 32 /* FPR (Floating point) register 0 */ | |
144 | #define PC_REGNUM 64 /* Contains program counter */ | |
145 | #define PS_REGNUM 65 /* Processor (or machine) status (%msr) */ | |
146 | #define CR_REGNUM 66 /* Condition register */ | |
147 | #define LR_REGNUM 67 /* Link register */ | |
148 | #define CTR_REGNUM 68 /* Count register */ | |
149 | #define XER_REGNUM 69 /* Fixed point exception registers */ | |
150 | #define MQ_REGNUM 70 /* Multiply/quotient register */ | |
151 | #define NUM_REGS 71 /* Number of machine registers */ | |
152 | #define REGISTER_BYTES (420) /* Total size of registers array */ | |
153 | ||
154 | #define ExceptionPC ExceptionState.u.SpecialRegistersEnumerated.CsavedSRR0 | |
155 | #define DECR_PC_AFTER_BREAK 0 /* PPCs get this right! */ | |
156 | #define BREAKPOINT {0x7d, 0x82, 0x10, 0x08} | |
157 | extern unsigned char breakpoint_insn[]; | |
158 | #define BREAKPOINT_SIZE 4 | |
159 | ||
67b12682 | 160 | #if 0 |
b7da2494 | 161 | #define ALTERNATE_MEM_FUNCS /* We need our own get_char/set_char */ |
67b12682 | 162 | #endif |
b7da2494 SG |
163 | |
164 | extern int get_char (char *addr); | |
165 | extern void set_char (char *addr, int val); |