2 * XA G3 SFR definitions
3 * Extracted directly from Philips documentation
9 sfr at 0x400 /*unsigned short*/ PSW; /* Program status word */
10 sfr at 0x400 PSWL; /* Program status word (low byte) */
11 sfr at 0x401 PSWH; /* Program status word (high byte) */
12 sfr at 0x402 PSW51; /* 80C51 compatible PSW */
13 sfr at 0x403 SSEL; /* Segment selection register */
14 sfr at 0x404 PCON; /* Power control register */
15 sfr at 0x410 TCON; /* Timer 0 and 1 control register */
16 sfr at 0x411 TSTAT; /* Timer 0 and 1 extended status */
17 sfr at 0x418 T2CON; /* Timer 2 control register */
18 sfr at 0x419 T2MOD; /* Timer 2 mode control */
19 sfr at 0x41F WDCON; /* Watchdog control register */
20 sfr at 0x420 S0CON; /* Serial port 0 control register */
21 sfr at 0x421 S0STAT; /* Serial port 0 extended status */
22 sfr at 0x424 S1CON; /* Serial port 1 control register */
23 sfr at 0x425 S1STAT; /* Serial port 1 extended status */
24 sfr at 0x426 IEL; /* Interrupt enable low byte */
25 sfr at 0x427 IEH; /* Interrupt enable high byte */
26 sfr at 0x42A SWR; /* Software Interrupt Request */
27 sfr at 0x430 P0; /* Port 0 */
28 sfr at 0x431 P1; /* Port 1 */
29 sfr at 0x432 P2; /* Port 2 */
30 sfr at 0x433 P3; /* Port3 */
31 sfr at 0x440 SCR; /* System configuration register */
32 sfr at 0x441 DS; /* Data segment */
33 sfr at 0x442 ES; /* Extra segment */
34 sfr at 0x443 CS; /* Code segment */
35 sfr at 0x450 TL0; /* Timer 0 low byte */
36 sfr at 0x451 TH0; /* Timer 0 high byte */
37 sfr at 0x452 TL1; /* Timer 1 low byte */
38 sfr at 0x453 TH1; /* Timer 1 high byte */
39 sfr at 0x454 RTL0; /* Timer 0 extended reload, low byte */
40 sfr at 0x455 RTH0; /* Timer 0 extended reload, high byte */
41 sfr at 0x456 RTL1; /* Timer 1 extended reload, low byte */
42 sfr at 0x457 RTH1; /* Timer 1 extended reload, high byte */
43 sfr at 0x458 TL2; /* Timer 2 low byte */
44 sfr at 0x459 TH2; /* Timer 2 high byte */
45 sfr at 0x45A T2CAPL; /* Timer 2 capture register, low byte */
46 sfr at 0x45B T2CAPH; /* Timer 2 capture register, high byte */
47 sfr at 0x45C TMOD; /* Timer 0 and 1 mode register */
48 sfr at 0x45D WFEED1; /* Watchdog feed 1 */
49 sfr at 0x45E WFEED2; /* Watchdog feed 2 */
50 sfr at 0x45F WDL; /* Watchdog timer reload */
51 sfr at 0x460 S0BUF; /* Serial port 0 buffer register */
52 sfr at 0x461 S0ADDR; /* Serial port 0 address register */
53 sfr at 0x462 S0ADEN; /* Serial port 0 address enable register */
54 sfr at 0x464 S1BUF; /* Serial port 1 buffer register */
55 sfr at 0x465 S1ADDR; /* Serial port 1 address register */
56 sfr at 0x466 S1ADEN; /* Serial port 1 address enable register */
57 sfr at 0x468 BTRL; /* Bus timing register high byte */
58 sfr at 0x469 BTRH; /* Bus timing register low byte */
59 sfr at 0x46A BCR; /* Bus configuration register */
60 sfr at 0x470 P0CFGA; /* Port 0 configuration A */
61 sfr at 0x471 P1CFGA; /* Port 1 configuration A */
62 sfr at 0x472 P2CFGA; /* Port 2 configuration A */
63 sfr at 0x473 P3CFGA; /* Port 3 configuration A */
64 sfr at 0x47A SWE; /* Software Interrupt Enable */
65 sfr at 0x4A0 IPA0; /* Interrupt priority 0 */
66 sfr at 0x4A1 IPA1; /* Interrupt priority 1 */
67 sfr at 0x4A2 IPA2; /* Interrupt priority 2 */
68 sfr at 0x4A4 IPA4; /* Interrupt priority 4 */
69 sfr at 0x4A5 IPA5; /* Interrupt priority 5 */
70 sfr at 0x4F0 P0CFGB; /* Port 0 configuration B */
71 sfr at 0x4F1 P1CFGB; /* Port 1 configuration B */
72 sfr at 0x4F2 P2CFGB; /* Port 2 configuration B */
73 sfr at 0x4F3 P3CFGB; /* Port 3 configuration B */
75 sbit at 0x33B ETI1; /* TX interrupt enable 1 */
76 sbit at 0x33A ERI1; /* RX interrupt enable 1 */
77 sbit at 0x339 ETI0; /* TX interrupt enable 0 */
78 sbit at 0x338 ERI0; /* RX interrupt enable 0 */
79 sbit at 0x337 EA; /* global int. enable */
80 sbit at 0x334 ET2; /* timer 2 interrupt */
81 sbit at 0x333 ET1; /* timer 1 interrupt */
82 sbit at 0x332 EX1; /* external interrupt 1 */
83 sbit at 0x331 ET0; /* timer 0 interrupt */
84 sbit at 0x330 EX0; /* external interrupt 0 */
85 sbit at 0x221 PD; /* power down */
101 sbit at 0x301 TI0; /* serial port 0 tx ready */
102 sbit at 0x300 RI0; /* serial port 0 rx ready */
106 sbit at 0x308 STINT0;
113 sbit at 0x321 TI1; /* serial port 0 tx ready */
114 sbit at 0x320 RI1; /* serial port 0 rx ready */
118 sbit at 0x328 STINT1;
174 #define IV_BRKPT 0x04 /* breakpoint vector */
175 #define IV_TRACE 0x08 /* Trace mode bit set */
176 #define IV_STKOVER 0x0C /* stack overflow */
177 #define IV_DIVZERO 0x10 /* divide by zero */
178 #define IV_IRET 0x14 /* user mode IRET */
189 #define IV_SWI1 0x100 /* software interrupts */
190 #define IV_SWI2 0x104
191 #define IV_SWI3 0x108
192 #define IV_SWI4 0x10C
193 #define IV_SWI5 0x110
194 #define IV_SWI6 0x114
195 #define IV_SWI7 0x118
197 /* PSW Values for interrupt vectors */
199 #define IV_PSW 0x8F00 /* System mode, high priority, bank 0 */
201 #define IV_SYSTEM 0x8000
203 #define IV_PRI00 0x0000 /* priorities 0 - 15 */
204 #define IV_PRI01 0x0100
205 #define IV_PRI02 0x0200
206 #define IV_PRI03 0x0300
207 #define IV_PRI04 0x0400
208 #define IV_PRI05 0x0500
209 #define IV_PRI06 0x0600
210 #define IV_PRI07 0x0700
211 #define IV_PRI08 0x0800
212 #define IV_PRI09 0x0900
213 #define IV_PRI10 0x0A00
214 #define IV_PRI11 0x0B00
215 #define IV_PRI12 0x0C00
216 #define IV_PRI13 0x0D00
217 #define IV_PRI14 0x0E00
218 #define IV_PRI15 0x0F00
220 #define IV_BANK0 0x0000
221 #define IV_BANK1 0x1000
222 #define IV_BANK2 0x2000
223 #define IV_BANK3 0x3000