## XA 16-bit microcontroller 32K/1K OTP/ROM/ROMless, 8-channel 8-bit A/D, low voltage (2.7V–5.5V), I<sup>2</sup>C, 2 UARTs, 16MB address range

## **GENERAL DESCRIPTION**

The XA-S3 device is a member of Philips Semiconductors' XA (eXtended Architecture) family of high performance 16-bit single-chip microcontrollers.

The XA-S3 device combines many powerful peripherals on one chip. With its high performance A/D converter, timers/counters, watchdog, Programmable Counter Array (PCA), I<sup>2</sup>C interface, dual UARTs, and multiple general purpose I/O ports, it is suited for general multipurpose high performance embedded control functions.

# Specific features of the XA-S3

- 2.7 V to 5.5 V operation.
- 32K bytes of on-chip EPROM/ROM program memory.
- 1024 bytes of on-chip data RAM.
- Supports off-chip addressing up to 16 megabytes (24 address lines). A clock output reference is added to simplify external bus interfacing.
- High performance 8-channel 8-bit A/D converter with automatic channel scan and repeated read functions. Completes a conversion in 4.46 microseconds at 30 MHz.

- Three standard counter/timers with enhanced features. All timers have a toggle output capability.
- Watchdog timer.
- 5-channel 16-bit Programmable Counter Array (PCA).
- I<sup>2</sup>C-bus serial I/O port with byte-oriented master and slave functions.
- Two enhanced UARTs with independent baud rates.
- Seven software interrupts.
- Active low reset output pin indicates all reset occurrences (external reset, watchdog reset and the RESET instruction). A reset source register allows program determination of the cause of the most recent reset.
- 50 I/O pins, each with 4 programmable output configurations.
- 30 MHz operating frequency at 2.7–5.5V V<sub>DD</sub> over commercial operating conditions.
- Power saving operating modes: Idle and Power-down. Wake-up from power-down via an external interrupt is supported.
- 68-pin PLCC and 80-pin PQFP packages.

# **ORDERING INFORMATION**

| ROMIess      | ROM          | EPROM        |     | TEMPERATURE RANGE (°C)<br>AND PACKAGE           | FREQ.<br>(MHz) | DRAWING<br>NUMBER |
|--------------|--------------|--------------|-----|-------------------------------------------------|----------------|-------------------|
| P51XAS30KBBA | P51XAS33KBBA | P51XAS37KBBA | OTP | 0 to +70,<br>68-pin Plastic Leaded Chip Carrier | 30             | SOT188-3          |
| P51XAS30KBBD | P51XAS33KBBD | P51XAS37KBBD | OTP | 0 to +70,<br>80-pin Plastic Quad Flat Pack      | 30             | SOT315-1          |

# XA 16-bit microcontroller 32K/1K OTP/ROM/ROMless, 8-channel 8-bit A/D, low voltage (2.7V–5.5V), I<sup>2</sup>C, 2 UARTs, 16MB address range

# **PIN CONFIGURATIONS**



## 80-pin LQFP package



# LOGIC SYMBOL



# **BLOCK DIAGRAM**



## **PIN DESCRIPTIONS**

|                         | PIN NU                     | IMBER                        | TYPE |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------------|----------------------------|------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MNEMONIC                | PLCC                       | LQFP                         | TYPE | NAME AND FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| V <sub>SS</sub>         | 1, 20, 55                  | 12, 13,<br>53, 54,<br>69, 70 | —    | Ground: 0V reference.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| V <sub>DD</sub>         | 2, 21, 54                  | 14, 15,<br>51, 52,<br>71, 72 | -    | <b>Power Supply:</b> This is the power supply voltage for normal, idle, and power down operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| RST                     | 50                         | 47                           | -    | <b>Reset:</b> A low on this pin resets the microcontroller, causing I/O ports and peripherals to take on their default states, and the processor to begin execution at the address contained in the reset vector.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| RSTOUT                  | 19                         | 11                           | 0    | <b>Reset Output:</b> This pin outputs a low whenever the XA-S3 processor is reset for any reason. This includes an external reset via the RST pin, watchdog reset, and the RESET instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| ALE/PROG                | 47                         | 44                           | I/O  | Address Latch Enable/Program Pulse: A high output on the ALE pin signals external<br>circuitry to latch the address portion of the multiplexed address/data bus. A pulse on ALE<br>occurs only when it is needed in order to process a bus cycle. During EPROM<br>programming, this pin is used as the program pulse input.                                                                                                                                                                                                                                                                                                                                                 |
| PSEN                    | 48                         | 45                           | 0    | <b>Program Store Enable:</b> The read strobe for external program memory. When the microcontroller accesses external program memory, PSEN is driven low in order to enable memory devices. PSEN is only active when external code accesses are performed.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| EA/WAIT/V <sub>PP</sub> | 22                         | 16                           | -    | <b>External Access/Bus Wait/Programming Supply Voltage</b> : The EA input determines whether the internal program memory of the microcontroller is used for code execution. The value on the EA pin is latched as the external reset input is released and applies during later execution. When latched as a 0, external program memory is used exclusively. When latched as a 1, internal program memory will be used up to its limit, and external program memory used above that point. After reset is released, this pin takes on the function of bus WAIT input. If WAIT is released. During EPROM programming, this pin is also the programming supply voltage input. |
| XTAL1                   | 68                         | 68                           | Ι    | Crystal 1: Input to the inverting amplifier used in the oscillator circuit and input to the internal clock generator circuits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| XTAL2                   | 67                         | 67                           | I    | Crystal 2: Output from the oscillator amplifier.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| CLKOUT                  | 49                         | 46                           | 0    | <b>Clock Output:</b> This pin outputs a buffered version of the internal CPU clock. The clock output may be used in conjunction with the external bus to synchronize WAIT state generators, etc. The clock output may be disabled by software.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| AV <sub>DD</sub>        | 33                         | 28, 29                       | Ι    | Analog Power Supply: Positive power supply input for the A/D converter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| AV <sub>SS</sub>        | 34                         | 30, 31                       | Ι    | Analog Ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| AV <sub>REF+</sub>      | 32                         | 27                           | Ι    | A/D Positive Reference Voltage: High end reference for the A/D converter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| AV <sub>REF-</sub>      | 31                         | 26                           | -    | A/D Negative Reference Voltage: Low end reference for the A/D converter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| P0.0 – P0.7             | 45, 46,<br>51–53,<br>56–58 | 42, 43,<br>48–50,<br>55–57   | I/O  | <b>Port 0:</b> Port 0 is an 8-bit I/O port with a user-configurable output type. Port 0 latches have 1s written to them and are configured in the quasi-bidirectional mode during reset. The operation of port 0 pins as inputs and outputs depends upon the port configuration selected. Each port pin is configured independently. Refer to the section on I/O port configuration and the DC Electrical Characteristics for details.                                                                                                                                                                                                                                      |
|                         |                            |                              |      | When the external program/data bus is used, Port 0 becomes the multiplexed low data/instruction byte and address lines 4 through 11.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

XA-S3

# XA 16-bit microcontroller 32K/1K OTP/ROM/ROMless, 8-channel 8-bit A/D, low voltage (2.7V-5.5V), I<sup>2</sup>C, 2 UARTs, 16MB address range

|             | PIN NL | IMBER            |      |                                                                                         |                                                                                                                                                                                                                                                                                                          |
|-------------|--------|------------------|------|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MNEMONIC    | PLCC   | LQFP             | TYPE |                                                                                         | NAME AND FUNCTION                                                                                                                                                                                                                                                                                        |
| P1.0 – P1.7 | 35–42  | 32–39            | I/O  | 1s written to them and are<br>operation of port 1 pins as<br>selected. Each port pin is | /O port with a user-configurable output type. Port 1 latches have<br>e configured in the quasi-bidirectional mode during reset. The<br>s inputs and outputs depends upon the port configuration<br>configured independently. Refer to the section on I/O port<br>Electrical Characteristics for details. |
|             |        |                  |      | Port 1 also provides vario                                                              | ous special functions as described below:                                                                                                                                                                                                                                                                |
|             | 35     | 32               | 0    | A0/WRH (P1.0)                                                                           | Address bit 0 of the external address bus when the eternal data<br>bus is configured for an 8-bit width. When the external data bus<br>is configured for a 16-bit width, this pin becomes the high byte<br>write strobe.                                                                                 |
|             | 36     | 33               | 0    | A1 (P1.1):                                                                              | Address bit 1 of the external address bus.                                                                                                                                                                                                                                                               |
|             | 37     | 34               | 0    | A2 (P1.2):                                                                              | Address bit 2 of the external address bus.                                                                                                                                                                                                                                                               |
|             | 38     | 35               | 0    | A3 (P1.3):                                                                              | Address bit 3 of the external address bus.                                                                                                                                                                                                                                                               |
|             | 39     | 36               | 1    | RxD1 (P1.4):                                                                            | Serial port 1 receiver input.                                                                                                                                                                                                                                                                            |
|             | 40     | 37               | 0    | TxD1 (P1.5):                                                                            | Serial port 1 transmitter output.                                                                                                                                                                                                                                                                        |
|             | 41     | 38               | I/O  | T2 (P1.6):                                                                              | Timer/counter 2 external count input or overflow output.                                                                                                                                                                                                                                                 |
|             | 42     | 39               | 0    | T2EX (P1.7):                                                                            | Timer/counter 2 reload/capture/direction control.                                                                                                                                                                                                                                                        |
| P2.0 – P2.7 | 59–66  | 58, 59,<br>61–66 | I/O  | 1s written to them and are<br>operation of port 2 pins as<br>selected. Each port pin is | /O port with a user-configurable output type. Port 2 latches have<br>e configured in the quasi-bidirectional mode during reset. The<br>s inputs and outputs depends upon the port configuration<br>configured independently. Refer to the section on I/O port<br>Electrical Characteristics for details. |
|             |        |                  |      | multiplexed high data/inst                                                              | un/data bus is used in 16-bit mode, Port 2 becomes the<br>truction byte and address lines 12 through 19. When the external<br>in 8-bit mode, the number of address lines that appear on Port 2<br>groups of 4 bits.                                                                                      |
| P3.0 – P3.7 | 11–18  | 3–10             | I/O  | 1s written to them and are<br>operation of port 3 pins as<br>selected. Each port pin is | /O port with a user-configurable output type. Port 3 latches have<br>e configured in the quasi-bidirectional mode during reset. The<br>s inputs and outputs depends upon the port configuration<br>configured independently. Refer to the section on I/O port<br>Electrical Characteristics for details. |
|             |        |                  |      | Port 3 also provides the v                                                              | various special functions as described below:                                                                                                                                                                                                                                                            |
|             | 11     | 3                | 1    | RxD0 (P3.0):                                                                            | Receiver input for serial port 0.                                                                                                                                                                                                                                                                        |
|             | 12     | 4                | 0    | TxD0 (P3.1):                                                                            | Transmitter output for serial port 0.                                                                                                                                                                                                                                                                    |
|             | 13     | 5                | 1    | INTO (P3.2):                                                                            | External interrupt 0 input.                                                                                                                                                                                                                                                                              |
|             | 14     | 6                | 1    | INT1 (P3.3):                                                                            | External interrupt 1 input.                                                                                                                                                                                                                                                                              |
|             | 15     | 7                | I/O  | T0 (P3.4):                                                                              | Timer/counter 0 external count input or overflow output.                                                                                                                                                                                                                                                 |
|             | 16     | 8                | 1/0  | T1 / BUSW (P3.5):                                                                       | Timer/counter 1 external count input or overflow output. The value on this pin is latched as an external chip reset is completed and defines the default external data bus width.                                                                                                                        |
|             | 17     | 9                | 0    | WRL (P3.6):                                                                             | External data memory low byte write strobe.                                                                                                                                                                                                                                                              |
|             | 18     | 10               | 0    | RD (P3.7):                                                                              | External data memory read strobe.                                                                                                                                                                                                                                                                        |
| P4.0 – P4.7 | 3–10   | 73–79, 2         | I/O  | 1s written to them and are<br>operation of Port 4 pins a<br>selected. Each port pin is  | /O port with a user-configurable output type. Port 4 latches have<br>e configured in the quasi-bidirectional mode during reset. The<br>s inputs and outputs depends upon the port configuration<br>configured independently. Refer to the section on I/O port<br>Electrical Characteristics for details. |
|             |        |                  |      | Port 4 also provides vario                                                              | ous special functions as described below:                                                                                                                                                                                                                                                                |
|             | 3      | 73               | I    | ECI (P4.0):                                                                             | PCA External clock input.                                                                                                                                                                                                                                                                                |
|             | 4      | 74               | 1/0  | CEX0 (P4.1):                                                                            | Capture/compare external I/O for PCA module 0.                                                                                                                                                                                                                                                           |
|             | 5      | 75               | 1/0  | CEX1 (P4.2):                                                                            | Capture/compare external I/O for PCA module 1.                                                                                                                                                                                                                                                           |
|             | 6      | 76               | 1/0  | CEX2 (P4.3):                                                                            | Capture/compare external I/O for PCA module 2.                                                                                                                                                                                                                                                           |
|             | 7      | 77               | 1/0  | CEX3 (P4.4):                                                                            | Capture/compare external I/O for PCA module 3.                                                                                                                                                                                                                                                           |
|             | 8      | 78               | 1/0  | CEX4 (P4.5):                                                                            | Capture/compare external I/O for PCA module 4.                                                                                                                                                                                                                                                           |
|             | 9      | 79               | 0    | A20 (P4.6):                                                                             | Address bit 20 of the external address bus.                                                                                                                                                                                                                                                              |
|             | 10     | 2                | 0    | A21 (P4.7):                                                                             | Address bit 21 of the external address bus.                                                                                                                                                                                                                                                              |

# XA 16-bit microcontroller 32K/1K OTP/ROM/ROMless, 8-channel 8-bit A/D, low voltage (2.7V–5.5V), I<sup>2</sup>C, 2 UARTs, 16MB address range

| MNEMONIC    | PIN NL | IMBER           | ТҮРЕ |                                                                                 | NAME AND FUNCTION                                                                                                                                                                                                                                                                                               |
|-------------|--------|-----------------|------|---------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MINEMONIC   | PLCC   | LQFP            | ITPE |                                                                                 | NAME AND FUNCTION                                                                                                                                                                                                                                                                                               |
| P5.0 – P5.7 | 23–30  | 17–20,<br>22–25 | I/O  | 1s written to them and a<br>operation of Port 5 pins<br>selected. Each port pin | I/O port with a user-configurable output type. Port 5 latches have<br>re configured in the quasi-bidirectional mode during reset. The<br>as inputs and outputs depends upon the port configuration<br>s configured independently. Refer to the section on I/O port<br>C Electrical Characteristics for details. |
|             |        |                 |      |                                                                                 | ious special functions as described below. Port 5 pins used as A/D add by the user to the high impedance mode.                                                                                                                                                                                                  |
|             | 23     | 17              | I    | AD0 (P5.0):                                                                     | A/D channel 0 input.                                                                                                                                                                                                                                                                                            |
|             | 24     | 18              | I    | AD1 (P5.1):                                                                     | A/D channel 1 input.                                                                                                                                                                                                                                                                                            |
|             | 25     | 19              | I    | AD2 (P5.2):                                                                     | A/D channel 2 input.                                                                                                                                                                                                                                                                                            |
|             | 26     | 20              | I    | AD3 (P5.3):                                                                     | A/D channel 3 input.                                                                                                                                                                                                                                                                                            |
|             | 27     | 22              | I    | AD4 (P5.4):                                                                     | A/D channel 4 input.                                                                                                                                                                                                                                                                                            |
|             | 28     | 23              | I    | AD5 (P5.5):                                                                     | A/D channel 5 input.                                                                                                                                                                                                                                                                                            |
|             | 29     | 24              | I/O  | AD6/SCL (P5.6):                                                                 | A/D channel 6 input. I <sup>2</sup> C serial clock input/output.                                                                                                                                                                                                                                                |
|             | 30     | 25              | I/O  | AD7/SDA (P5.7):                                                                 | A/D channel 7 input. I <sup>2</sup> C serial data input/output.                                                                                                                                                                                                                                                 |
| P6.0 – P6.7 | 43, 44 | 40, 41          | I/O  | 1s written to them and a<br>operation of Port 6 pins<br>selected. Each port pin | /O port with a user-configurable output type. Port 6 latches have<br>re configured in the quasi-bidirectional mode during reset. The<br>as inputs and outputs depends upon the port configuration<br>s configured independently. Refer to the section on I/O port<br>C Electrical Characteristics for details.  |
|             |        |                 |      | Port 6 also provides spe                                                        | cial functions as described below:                                                                                                                                                                                                                                                                              |
|             | 43     | 40              | 0    | A22 (P6.0):                                                                     | Address bit 22 of the external address bus.                                                                                                                                                                                                                                                                     |
|             | 44     | 41              | 0    | A23 (P6.1):                                                                     | Address bit 23 of the external address bus.                                                                                                                                                                                                                                                                     |

# Table 1. Special Function Registers

|         |                                    | SFR     |       |       | BIT FUNC | CTIONS A | ND ADDF | RESSES     |             |       | Reset  |
|---------|------------------------------------|---------|-------|-------|----------|----------|---------|------------|-------------|-------|--------|
| NAME    | DESCRIPTION                        | Address | MSB   |       |          |          |         |            |             | LSB   | Value  |
|         |                                    |         | 3F7   | 3F6   | 3F5      | 3F4      | 3F3     | 3F2        | 3F1         | 3F0   |        |
| ADCON#* | A/D control register               | 43E     | -     | _     | -        | -        | -       | ADMOD      | ADSST       | ADINT | 00h    |
|         |                                    |         | 3FF   | 3FE   | 3FD      | 3FC      | 3FB     | ЗFA        | 3F9         | 3F8   | 1      |
| ADCS#*  | A/D channel select register        | 43F     | ADCS7 | ADCS6 | ADCS5    | ADCS4    | ADCS3   | ADCS2      | ADCS1       | ADCS0 | 00h    |
| ADCFG#  | A/D timing configuration           | 4B9     | -     | -     | -        | -        | A/      | D Timing ( | Configurati | on    | 0Fh    |
| ADRSH0# | A/D high byte result,<br>channel 0 | 4B0     |       | -     |          | -        |         |            |             |       | xx     |
| ADRSH1# | A/D high byte result,<br>channel 1 | 4B1     |       |       |          |          |         |            |             |       | хх     |
| ADRSH2# | A/D high byte result,<br>channel 2 | 4B2     |       |       |          |          |         |            |             |       | хх     |
| ADRSH3# | A/D high byte result,<br>channel 3 | 4B3     |       |       |          |          |         |            |             |       | хх     |
| ADRSH4# | A/D high byte result,<br>channel 4 | 4B4     |       |       |          |          |         |            |             |       | хх     |
| ADRSH5# | A/D high byte result,<br>channel 5 | 4B5     |       |       |          |          |         |            |             |       | хх     |
| ADRSH6# | A/D high byte result,<br>channel 6 | 4B6     |       |       |          |          |         |            |             |       | хх     |
| ADRSH7# | A/D high byte result,<br>channel 7 | 4B7     |       |       |          |          |         |            |             |       | хх     |
| BCR#    | Bus configuration register         | 46A     | -     | -     | CLKD     | WAITD    | BUSD    | BC2        | BC1         | BC0   | Note 1 |
| BTRH    | Bus timing register high<br>byte   | 469     | DW1   | DW0   | DWA1     | DWA0     | DR1     | DR0        | DRA1        | DRA0  | FFh    |
| BTRL    | Bus timing register low byte       | 468     | WM1   | WM0   | ALEW     | -        | CR1     | CR0        | CRA1        | CRA0  | EFh    |

# XA 16-bit microcontroller 32K/1K OTP/ROM/ROMless, 8-channel 8-bit A/D, low voltage (2.7V–5.5V), I<sup>2</sup>C, 2 UARTs, 16MB address range

| NAME    | DESCRIPTION                       | SFR     |     |                      | BIT FUN   | CTIONS A   |      | RESSES |      |      | Rese        |
|---------|-----------------------------------|---------|-----|----------------------|-----------|------------|------|--------|------|------|-------------|
|         | DESCRIPTION                       | Address | MSB |                      |           |            |      |        |      | LSB  | Valu        |
|         |                                   |         | 2D7 | 2D6                  | 2D5       | 2D4        | 2D3  | 2D2    | 2D1  | 2D0  |             |
| CCON#*  | PCA counter control               | 41A     | CF  | CR                   | -         | CCF4       | CCF3 | CCF2   | CCF1 | CCF0 | 00h         |
| CMOD#   | PCA mode control                  | 490     | -   | WDTE                 | -         | -          | -    | CPS1   | CPS0 | ECF  | 00h         |
| CH#     | PCA counter high byte             | 48B     |     |                      |           |            |      |        |      |      | 00h         |
| CL#     | PCA counter low byte              | 48A     |     |                      |           |            |      |        |      |      | 00h         |
| CCAPM0# | PCA module 0 mode                 | 491     | -   | ECOM                 | CAPP      | CAPN       | MAT  | TOG    | PWM  | ECCF | 00h         |
| CCAPM1# | PCA module 1 mode                 | 492     | _   | ECOM                 | CAPP      | CAPN       | MAT  | TOG    | PWM  | ECCF | 00h         |
| CCAPM2# | PCA module 2 mode                 | 493     | -   | ECOM                 | CAPP      | CAPN       | MAT  | TOG    | PWM  | ECCF | 00h         |
| CCAPM3# | PCA module 3 mode                 | 494     | -   | ECOM                 | CAPP      | CAPN       | MAT  | TOG    | PWM  | ECCF | 00h         |
| CCAPM4# | PCA module 4 mode                 | 495     | _   | ECOM                 | CAPP      | CAPN       | МАТ  | TOG    | PWM  | ECCF | 00h         |
| CCAP0H# | PCA module 0 capture<br>high byte | 497     |     |                      |           |            |      |        |      |      | XX          |
| CCAP1H# | PCA module 1 capture<br>high byte | 499     |     |                      |           |            |      |        |      |      | XX          |
| CCAP2H# | PCA module 2 capture<br>high byte | 49B     |     |                      |           |            |      |        |      |      | xx          |
| CCAP3H# | PCA module 3 capture<br>high byte | 49D     |     |                      |           |            |      |        |      |      | xx          |
| CCAP4H# | PCA module 4 capture<br>high byte | 49F     |     |                      |           |            |      |        |      |      | xx          |
| CCAP0L# | PCA module 0 capture<br>low byte  | 496     |     |                      |           |            |      |        |      |      | xx          |
| CAP1L#  | PCA module 1 capture<br>low byte  | 498     |     |                      |           |            |      |        |      |      | xx          |
| CCAP2L# | PCA module 2 capture<br>low byte  | 49A     |     |                      |           |            |      |        |      |      | xx          |
| CCAP3L# | PCA module 3 capture<br>low byte  | 49C     |     |                      |           |            |      |        |      |      | xx          |
| CCAP4L# | PCA module 4 capture<br>low byte  | 49E     |     |                      |           |            |      |        |      |      | xx          |
| cs      | Code segment                      | 443     |     |                      |           |            |      |        |      |      | 00h         |
| DS      | Data segment                      | 441     |     |                      |           |            |      |        |      |      | 00h         |
| ES      | Extra segment                     | 442     |     |                      |           |            |      |        |      |      | 00h         |
|         |                                   |         | 367 | 366                  | 365       | 364        | 363  | 362    | 361  | 360  | 4           |
| 2CON#*  | I <sup>2</sup> C control register | 42C     | CR2 | ENA                  | STA       | STO        | SI   | AA     | CR1  | CR0  | 00h         |
| 2STAT#  | I <sup>2</sup> C status register  | 46C     |     | I <sup>2</sup> C Sta | tus Code/ | Vector     |      | 0      | 0    | 0    | F8h         |
| 2DAT#   | I <sup>2</sup> C data register    | 46D     |     |                      |           |            |      |        |      | T    | XX          |
| 2ADDR#  | I <sup>2</sup> C address register | 46E     |     |                      |           | Slave Addr |      |        |      | GC   | 00h         |
|         |                                   |         | 33F | 33E                  | 33D       | 33C        | 33B  | 33A    | 339  | 338  | 4           |
| EH*     | Interrupt enable high byte        | 427     | -   | -                    | -         | -          | ETI1 | ERI1   | ETIO | ERI0 | 00h         |
|         |                                   |         | 337 | 336                  | 335       | 334        | 333  | 332    | 331  | 330  |             |
| EL#*    | Interrupt enable low byte         | 426     | EA  | EAD                  | EPC       | ET2        | ET1  | EX1    | ETO  | EX0  | 00h         |
|         |                                   | [       | 377 | 376                  | 375       | 374        | 373  | 372    | 371  | 370  |             |
| ELB#*   | Interrupt enable B low byte       | 42E     | _   | -                    | El2       | EC4        | EC3  | EC2    | EC1  | EC0  | 00h         |
| PAO     | Interrupt priority A0             | 4A0     |     | PT                   | 0         |            |      | P      | xo   |      | 00h         |
| PA1     | Interrupt priority A1             | 4A1     |     | PT                   | 1         |            |      | P      | X1   |      | <b>0</b> 0h |
| PA2#    | Interrupt priority A2             | 4A2     |     | PP                   | С         |            |      | P.     | T2   |      | 00h         |
| PA3#    | Interrupt priority A3             | 4A3     |     | _                    |           |            |      | PA     | ٩D   |      | 00h         |
| PA4     | Interrupt priority A4             | 4A4     |     | PT                   | 10        |            |      | PF     | 310  |      | 00h         |

NAME

LSB

XA-S3

Reset

Value

# XA 16-bit microcontroller 32K/1K OTP/ROM/ROMless, 8-channel 8-bit A/D, low voltage (2.7V-5.5V), I<sup>2</sup>C, 2 UARTs, 16MB address range

SFR

Address

MSB

DESCRIPTION

| IPA5    | Interrupt priority A5  | 4A5 |         | PT      | 11     |        |        | PF     | RI1   |        | 00h    |
|---------|------------------------|-----|---------|---------|--------|--------|--------|--------|-------|--------|--------|
| IPB0#   | Interrupt priority B0  | 4A8 |         | PC      | 21     |        |        | P      | C0    |        | 00h    |
| IPB1#   | Interrupt priority B1  | 4A9 |         | PC      | 3      |        |        | P      | C2    |        | 00h    |
| IPB2#   | Interrupt priority B2  | 4AA |         | PI      | 2      |        |        | PC     | 24    |        | 00h    |
|         |                        |     | 387     | 386     | 385    | 384    | 383    | 382    | 381   | 380    |        |
| P0*     | Port 0                 | 430 | A11D7   | A10D6   | A9D5   | A8D4   | A7D3   | A6D2   | A5D1  | A4D0   | FFh    |
|         |                        |     | 38F     | 38E     | 38D    | 38C    | 38B    | 38A    | 389   | 388    |        |
| P1*     | Port 1                 | 431 | T2EX    | T2      | TxD1   | RxD1   | A3     | A2     | A1    | A0/WRH | FFh    |
|         |                        |     | 397     | 396     | 395    | 394    | 393    | 392    | 391   | 390    |        |
| P2*     | Port 2                 | 432 | A19D15  | A18D14  | A17D13 | A16D12 | A15D11 | A14D10 | A13D9 | A12D8  | FFh    |
|         |                        |     | 39F     | 39E     | 39D    | 39C    | 39B    | 39A    | 399   | 398    |        |
| P3*     | Port 3                 | 433 | RD      | WRL     | T1     | ТО     | INT1   | INTO   | TxD0  | RxD0   | FFh    |
|         |                        |     | 3A7     | 3A6     | 3A5    | 3A4    | 3A3    | 3A2    | 3A1   | 3A0    |        |
| P4#*    | Port 4                 | 434 | A21     | A20     | CEX4   | CEX3   | CEX2   | CEX1   | CEX0  | ECI    | FFh    |
|         |                        |     | ЗАF     | 3AE     | 3AD    | 3AC    | 3AB    | 3AA    | 3A9   | 3A8    |        |
| P5#*    | Port 5                 | 435 | AD7/SDA | AD6/SCL | AD5    | AD4    | AD3    | AD2    | AD1   | AD0    | FFh    |
|         |                        |     |         |         |        |        |        | •      | 3B1   | 3B0    |        |
| P6#*    | Port 6                 | 436 | -       | -       | -      | -      | -      | -      | A23   | A22    | FFh    |
|         |                        |     |         |         | •      | •      | •      |        |       | •      |        |
| P0CFGA  | Port 0 configuration A | 470 |         |         |        |        |        |        |       |        | Note 5 |
| P1CFGA  | Port 1 configuration A | 471 |         |         |        |        |        |        |       |        | Note 5 |
| P2CFGA  | Port 2 configuration A | 472 |         |         |        |        |        |        |       |        | Note 5 |
| P3CFGA  | Port 3 configuration A | 473 |         |         |        |        |        |        |       |        | Note 5 |
| P4CFGA# | Port 4 configuration A | 474 |         |         |        |        |        |        |       |        | Note 5 |
| P5CFGA# | Port 5 configuration A | 475 |         |         |        |        |        |        |       |        | Note 5 |
| P6CFGA# | Port 6 configuration A | 476 | -       | -       | -      | -      | -      | -      |       |        | Note 5 |
| POCFGB  | Port 0 configuration B | 4F0 |         |         |        |        |        |        |       |        | Note 5 |
| P1CFGB  | Port 1 configuration B | 4F1 |         |         |        |        |        |        |       |        | Note 5 |
| P2CFGB  | Port 2 configuration B | 4F2 |         |         |        |        |        |        |       |        | Note 5 |
| P3CFGB  | Port 3 configuration B | 4F3 |         |         |        |        |        |        |       |        | Note 5 |
| P4CFGB# | Port 4 configuration B | 4F4 |         |         |        |        |        |        |       |        | Note 5 |
| P5CFGB# | Port 5 configuration B | 4F5 |         |         |        |        |        |        |       |        | Note 5 |
| P6CFGB# | Port 6 configuration B | 4F6 | -       | _       | -      | -      | -      | -      |       |        | Note 5 |
|         |                        |     | 227     | 226     | 225    | 224    | 223    | 222    | 221   | 220    |        |
| PCON*   | Power control register | 404 | -       | -       | -      | -      | -      | -      | PD    | IDL    | 00h    |
|         |                        |     | L       |         |        |        | -      |        |       |        |        |

**BIT FUNCTIONS AND ADDRESSES** 

1998 Jun 05

PSWH\*

PSWL\*

PSW51\*

ΤМ

206

AC

216

AC

RS1

205

\_

215

F0

RS0

204

\_

214

RS1

IМЗ

203

\_

213

RS0

IM2

202

٧

212

۷

IM1

201

Ν

211

F1

IMO

200

Ζ

210

Ρ

Note 2

Note 2

Note 3

401

400

402

SM

207

С

217

С

Program status word (high byte)

Program status word

80C51 compatible PSW

(low byte)

# XA 16-bit microcontroller 32K/1K OTP/ROM/ROMless, 8-channel 8-bit A/D, low voltage (2.7V–5.5V), I<sup>2</sup>C, 2 UARTs, 16MB address range

| NAME             | DESCRIPTION                                             | SFR<br>Address | MSB        |            | BIT FUN    | CTIONS A   | ND ADDF | RESSES |       | LSB    | Reset<br>Value |
|------------------|---------------------------------------------------------|----------------|------------|------------|------------|------------|---------|--------|-------|--------|----------------|
| RSTSRC#          | Reset source register                                   | 463            | -          | -          | _          | -          | —       | R_WD   | R_CMD | R_EXT  | Note 7         |
| RTH0             | Timer 0 reload register,<br>high byte                   | 455            |            |            |            |            |         |        |       |        | 00h            |
| RTH1             | Timer 1 reload register,<br>high byte                   | 457            |            |            |            |            |         |        |       |        | 00h            |
| RTL0             | Timer 0 reload register,<br>low byte                    | 454            |            |            |            |            |         |        |       |        | 00h            |
| RTL1             | Timer 1 reload register,<br>low byte                    | 456            |            |            |            |            |         |        |       |        | 00h            |
|                  |                                                         |                | 307        | 306        | 305        | 304        | 303     | 302    | 301   | 300    |                |
| S0CON*           | Serial port 0 control register                          | 420            | SM0_0      | SM1_0      | SM2_0      | REN_0      | TB8_0   | RB8_0  | TI_0  | RI_0   | 00h            |
|                  |                                                         |                | 30F        | 30E        | 30D        | 30C        | 30B     | 30A    | 309   | 308    |                |
| S0STAT#*         | Serial port 0 extended status                           | 421            | -          | -          | _          | ERR0       | FE0     | BR0    | OE0   | STINTO | 00h            |
| SOBUF            | Serial port 0 data buffer<br>register                   | 460            |            | -          |            |            |         |        |       | -      | xx             |
| SOADDR           | Serial port 0 address<br>register                       | 461            |            |            |            |            |         |        |       |        | 00h            |
| S0ADEN           | Serial port 0 address<br>enable                         | 462            |            |            |            |            |         |        |       |        | 00h            |
|                  | enable                                                  |                | 327        | 326        | 325        | 324        | 323     | 322    | 321   | 320    |                |
| S1CON*           | Serial port 1 control<br>register                       | 424            | SM0_1      | SM1_1      | SM2_1      | REN_1      | TB8_1   | RB8_1  | TI_1  | RI_1   | оон            |
|                  |                                                         |                | 32F        | 32E        | 32D        | 32C        | 32B     | 32A    | 329   | 328    | 1              |
| S1STAT#*         | Serial port 1 extended status                           | 425            | -          | -          | -          | ERR1       | FE1     | BR1    | OE1   | STINT1 | 00h            |
| S1BUF            | Serial port 1 data buffer<br>register                   | 464            |            |            | •          | •          |         | •      |       | •      | хх             |
| S1ADDR           | Serial port 1 address<br>register                       | 465            |            |            |            |            |         |        |       |        | 00h            |
| S1ADEN           | Serial port 1 address<br>enable                         | 466            |            |            |            |            |         |        |       |        | 00h            |
| SCR              | System configuration register                           | 440            | -          | -          | -          | -          | PT1     | PT0    | СМ    | ΡZ     | 00h            |
|                  |                                                         |                | 21F        | 21E        | 21D        | 21C        | 21B     | 21A    | 219   | 218    | ]              |
| SSEL*            | Segment selection register                              | 403            | ESWEN      | R6SEG      | R5SEG      | R4SEG      | R3SEG   | R2SEG  | R1SEG | R0SEG  | 00h            |
| SWE              | Software interrupt enable                               | 47A            | _          | SWE7       | SWE6       | SWE5       | SWE4    | SWE3   | SWE2  | SWE1   | 00h            |
|                  |                                                         |                | 357        | 356        | 355        | 354        | 353     | 352    | 351   | 350    | 1              |
| SWR*             | Software interrupt request                              | 42A            | -          | SWR7       | SWR6       | SWR5       | SWR4    | SWR3   | SWR2  | SWR1   | 00h            |
|                  |                                                         |                | 2C7        | 2C6        | 2C5        | 2C4        | 2C3     | 2C2    | 2C1   | 2C0    | 1              |
| T2CON*           | Timer 2 control register                                | 418            | TF2        | EXF2       | RCLK0      | TCLK0      | EXEN2   | TR2    | C/T2  | CP/RL2 | 00h            |
|                  |                                                         |                | 2CF        | 2CE        | 2CD        | 2CC        | 2CB     | 2CA    | 2C9   | 2C8    |                |
| T2MOD*           | Timer 2 mode control                                    | 419            | _          | -          | RCLK1      | TCLK1      | _       | -      | T2OE  | DCEN   | 00h            |
| TH2              | Timer 2 high byte                                       | 459            |            |            |            |            |         |        |       |        | 00h            |
| TL2              | Timer 2 low byte                                        | 458            |            |            |            |            |         |        |       |        | 00h            |
| T2CAPH<br>T2CAPL | Timer 2 capture, high byte<br>Timer 2 capture, low byte | 45B<br>45A     |            |            |            |            |         |        |       |        | 00h<br>00h     |
| IZUAFL           | Timer 2 capture, low byte                               | 404            | 287        | 286        | 285        | 284        | 283     | 282    | 281   | 280    |                |
| TCON*            | Timer 0 and 1 control                                   | 410            | 287<br>TF1 | 200<br>TR1 | 285<br>TF0 | 284<br>TR0 | 203     | 202    | IE0   | Z80    | 00h            |
|                  | register                                                | 410            |            |            |            |            |         |        |       | 110    |                |

# XA 16-bit microcontroller 32K/1K OTP/ROM/ROMless, 8-channel 8-bit A/D, low voltage (2.7V–5.5V), I<sup>2</sup>C, 2 UARTs, 16MB address range

| NAME   | DESCRIPTION                   | SFR     |      |      | BIT FUN | CTIONS A |      | RESSES |       |      | Reset  |
|--------|-------------------------------|---------|------|------|---------|----------|------|--------|-------|------|--------|
| NAME   | DESCRIPTION                   | Address | MSB  |      |         |          |      |        |       | LSB  | Value  |
| TH0    | Timer 0 high byte             | 451     |      |      |         |          |      |        |       |      | 00h    |
| TH1    | Timer 1 high byte             | 453     |      |      |         |          |      |        |       |      | 00h    |
| TL0    | Timer 0 low byte              | 450     |      |      |         |          |      |        |       |      | 00h    |
| TL1    | Timer 1 low byte              | 452     |      |      |         |          |      |        |       |      | 00h    |
| TMOD   | Timer 0 and 1 mode control    | 45C     | GATE | С/Т  | M1      | MO       | GATE | С/Т    | M1    | MO   | 00h    |
|        |                               |         | 28F  | 28E  | 28D     | 28C      | 28B  | 28A    | 289   | 288  |        |
| TSTAT* | Timer 0 and 1 extended status | 411     | -    | -    | -       | -        | -    | T10E   | -     | T0OE | 00h    |
|        |                               |         | 2FF  | 2FE  | 2FD     | 2FC      | 2FB  | 2FA    | 2F9   | 2F8  | 1      |
| WDCON* | Watchdog control register     | 41F     | PEW2 | PRE1 | PRE0    | -        | -    | WDRUN  | WDTOF | -    | Note 6 |
| WDL    | Watchdog timer reload         | 45F     |      |      |         |          |      |        |       |      | 00h    |
| WFEED1 | Watchdog feed 1               | 45D     |      |      |         |          |      |        |       |      | xx     |
| WFEED2 | Watchdog feed 2               | 45E     |      |      |         |          |      |        |       |      | xx     |

#### NOTES:

\* SFRs are bit addressable.

# SFRs are modified from or added to XA-G3 SFRs.

1. At reset, the BCR is loaded with the binary value 00000a11, where "a' is the value on the BUSW pin. This defaults the address bus size to 24 bits.

2. SFR is loaded from the reset vector.

3. All bits except F1, F0, and P are loaded from the reset vector. Those bits are all 0.

4. Unimplemented bits in SFRs are X (unknown) at all times. Ones should not be written to these bits since they may be used for other purposes in future XA derivatives. The reset value shown for these bits is 0.

5. Port configurations default to quasi-bidirectional when the XA begins execution from internal code memory after reset, based on the condition found on the EA pin. Thus, all PnCFGA registers will contain FF, and PnCFGB register will contain 00 when the XA begins execution using internal code memory. When the XA begins execution using external code memory, the default configuration for pins that are associated with the external bus will be push-pull. The PnCFGA and PnCFGB register contents will reflect this difference.

6. The WDCON reset value is E6 for a Watchdog reset, E4 for all other reset causes.

7. The RSTSRC register reflects the cause of the last XA-S3 reset. One bit will be set to 1, the others will be cleared to 0.

| con,# |
|-------|
| )     |
| 0     |
| Ĩ     |

XA-S3 SFR bits that are guarded in this manner are: ADINT (in ADCON); CF, CCF4, CCF3, CCF2, CCF1, and CCF0 (in CCON); SI (in I2CON); TI\_0 and RI\_0 (in S0CON); TI\_1 and RI\_1 (in S1CON); FE0, BR0, and OE0 (in S0STAT); FE1, BR1, and OE1 (in S1STAT); TF2 (in T2CON); TF1, TF0, IE1, and IE0 (in TCON); and WDTOF (in WDCON).

9. The XA-S3 implements an 8-bit SFR bus, as stated in *Chapter 8* of the XA User Guide. All SFR accesses must be 8-bit operations. Attempts to write 16 bits to an SFR will actually write only the lower 8 bits. Sixteen bit SFR reads will return undefined data in the upper byte.

## FUNCTIONAL DESCRIPTION

Details of XA-S3 functions will be described in the following sections.

#### Analog to Digital converter

The XA-S3 has an 8-channel, 8-bit A/D converter with 8 sets of result registers, single scan and multiple scan operating modes. The A/D input range is limited to 0 to  $AV_{DD}$  (3.3V max.). The A/D inputs are on Port 5. Analog Power and Ground as well as  $AV_{REF+}$  and  $AV_{REF-}$  must be supplied in order for the A/D converter to be used. Prior to enabling the A/D converter or driving analog signals into the A/D inputs, the port configurations for the pins being used as A/D inputs must be set to the "off" (high impedance, input only) mode.

A/D timing can be adapted to the application clock frequency in order to provide the fastest possible conversion.

A/D converter operation is controlled through the ADCON (A/D Control) register, see Figure 1. Bits in ADCON start and stop the A/D, flag conversion completion, and select the converter operating modes.

#### A/D Conversion Modes

The A/D converter supports a single scan mode and a continuous scan mode. In either mode, one or more A/D channels may be converted. The ADCS register determines which channels are converted. If the corresponding bit in the ADCS register is set, that channel is selected for conversions, otherwise that channel is skipped. The ADCS register is detailed in Figure 2.

For any A/D conversion, the results are stored in ADRSHn, corresponding to the A/D channel just converted.

A/D conversions are begun by setting the A/D Start and STatus bit in ADCON. In the single scan mode, all of the channels selected by

bits in the ADCS register will be converted once. The ADINT flag is set when the last channel is converted. In the continuous scan mode, the A/D converter continuously converts all A/D channels selected by bits in the ADCS register. The ADINT flag is set when all channels have been converted once.

The A/D converter can generate an interrupt when the ADINT flag is set. This will occur if the A/D interrupt is enabled (via the EAD bit in IEL), the interrupt system is enabled (via the EA bit in IEL), and the A/D interrupt priority (specified in IPA3 bits 3 to 0) is higher than the currently running code (PSW bits IM3 through IM0) and any other pending interrupt. ADINT must be cleared by software.

#### **A/D Timing Configuration**

The A/D sampling and conversion timing may be optimized for the particular oscillator frequency and input drive characteristics of the application. Because A/D operation is mostly dependent on real-time effects (charging time of sampling capacitors, settling time of the comparator, etc.), A/D conversion times are not necessarily much longer at slower clock frequencies. The A/D timing is controlled by the ADCFG register, as shown in Figure 3 and Table 2.

The primary effect of ADCFG settings is to adjust the A/D sample and hold time to be relatively constant over various clock frequencies. Two settings (value 6 and B) are provided to allow fast conversions with a lower external source driving the A/D inputs. These settings provide double the sample time at the same frequency. Of course, settings intended for lower frequencies may also be used at higher frequencies in order to increase the A/D sampling time, but this method has the side effect of significantly increasing A/D conversion times.

| ADCON Addres<br>Bit Addressable | ss:43Eh | MSB LSB                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reset Value: 00h                |         |                                                                                                                                                                                                                                                                                                                                                                                                     |
| BIT                             | SYMBOL  | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                            |
| ADCON.7                         |         | Reserved for future use. Should not be set to 1 by user programs.                                                                                                                                                                                                                                                                                                                                   |
| ADCON.6                         |         | Reserved for future use. Should not be set to 1 by user programs.                                                                                                                                                                                                                                                                                                                                   |
| ADCON.5                         |         | Reserved for future use. Should not be set to 1 by user programs.                                                                                                                                                                                                                                                                                                                                   |
| ADCON.4                         | _       | Reserved for future use. Should not be set to 1 by user programs.                                                                                                                                                                                                                                                                                                                                   |
| ADCON.3                         |         | Reserved for future use. Should not be set to 1 by user programs.                                                                                                                                                                                                                                                                                                                                   |
| ADCON.2                         | ADMOD   | A/D mode select.<br>1 = continuous scan of selected inputs after a start of the A/D.<br>0 = single scan of selected inputs after a start of the A/D.                                                                                                                                                                                                                                                |
| ADCON.1                         | ADSST   | A/D start and status. Setting this bit by software starts the A/D conversion of the selected A/D<br>inputs. ADSST remains set as long as the A/D is in operation. In continuous conversion mode,<br>ADSST will remain set unless the A/D is stopped by software. While ADSST is set, new start<br>commands are ignored. An A/D conversion is progress may be aborted by software clearing<br>ADSST. |
| ADCON.0                         | ADINT   | A/D conversion complete/interrupt flag. This flag is set when all selected A/D channels are<br>converted in either the single scan or continuous scan modes. Must be cleared by software.                                                                                                                                                                                                           |
|                                 |         | SU00938A                                                                                                                                                                                                                                                                                                                                                                                            |

Figure 1. A/D Control Register (ADCON)

XA-S3

|                                     | ss:43Fh | MSB                       |               |           | LSB    |
|-------------------------------------|---------|---------------------------|---------------|-----------|--------|
| Bit Addressable<br>Reset Value: 00h | 1       | ADCS7 ADCS6 ADCS5 ADC     | CS4 ADCS3 AD0 | CS2 ADCS1 | ADCS0  |
| BIT                                 | SYMBOL  | FUNCTION                  |               |           |        |
| ADCS.7                              | ADCS7   | A/D channel 7 select bit. |               |           |        |
| ADCS.6                              | ADCS6   | A/D channel 6 select bit. |               |           |        |
| ADCS.5                              | ADCS5   | A/D channel 5 select bit. |               |           |        |
| ADCS.4                              | ADCS4   | A/D channel 4 select bit. |               |           |        |
| ADCS.3                              | ADCS3   | A/D channel 3 select bit. |               |           |        |
| ADCS.2                              | ADCS2   | A/D channel 2 select bit. |               |           |        |
| ADCS.1                              | ADCS1   | A/D channel 1 select bit. |               |           |        |
| ADCS.0                              | ADCS0   | A/D channel 0 select bit. |               |           | SU0093 |

## Figure 2. A/D Channel Select Register (ADCS)

| ADCFG Address:4B9h                      |        | MSB LSB                                                           |
|-----------------------------------------|--------|-------------------------------------------------------------------|
| Not bit Addressable<br>Reset Value: 00h |        | — — — A/D Timing Configuration                                    |
| BIT                                     | SYMBOL | FUNCTION                                                          |
| ADCFG.7                                 | _      | Reserved for future use. Should not be set to 1 by user programs. |
| ADCFG.6                                 | _      | Reserved for future use. Should not be set to 1 by user programs. |
| ADCFG.5                                 | _      | Reserved for future use. Should not be set to 1 by user programs. |
| ADCFG.4                                 | _      | Reserved for future use. Should not be set to 1 by user programs. |
| ADCFG.3-0                               | ADCFG  | A/D timing configuration (see text and table).                    |
|                                         |        | SU00940                                                           |

Figure 3. A/D Timing Configuration Register (ADCFG)

## Table 2. A/D Timing Configuration

|                        | Max. Oscillator | Conv        | ersion Time       | Sampling Time |  |
|------------------------|-----------------|-------------|-------------------|---------------|--|
| ADCFG.3-0              | Frequency (MHz) | Osc. Clocks | μsec at max. Osc. | (Osc. Clocks) |  |
| 0h (0000)              | 6.66            | 70          | 11.11             | 4             |  |
| 1h (0001)              | 10              | 78          | 7.8               | 6             |  |
| 2h (0010)              | 11.11           | 82          | 7.38              | 8             |  |
| 3h (0011)              | 13.33           | 98          | 7.35              | 8             |  |
| 4h (0100)              | 16.66           | 102         | 6.12              | 10            |  |
| 5h (0101)              | 20              | 106         | 5.3               | 12            |  |
| 6h (0110) <sup>1</sup> | 20              | 118         | 5.9               | 24            |  |
| 7h (0111)              | 22.2            | 102         | 4.95              | 14            |  |
| 8h (1000)              | 23.3            | 126         | 5.4               | 14            |  |
| 9h (1001)              | 26.6            | 130         | 4.88              | 16            |  |
| Ah (1010)              | 30              | 134         | 4.46              | 18            |  |
| Bh (1011) <sup>1</sup> | 30              | 148         | 4.93              | 32            |  |
| Ch (1100)              | 32              | 138         | 4.31              | 20            |  |
| Dh (1101)              | 33.3            | 152         | 4.56              | 20            |  |
| Eh (1110)              | 36.6            | 172         | 4.69              | 22            |  |
| Fh (1111)              | 40              | 176         | 4.4               | 24            |  |

## NOTE:

1. These settings provide additional A/D input sampling time, in order to allow accurate readings with a higher external source impedance.

#### A/D Inputs

In order to obtain accurate measurements with the A/D Converter, the source drive must be sufficient to adequately charge the sampling capacitor during the sampling time. Figure 4 shows the equivalent resistance and capacitance related to the A/D inputs. A/D timing configurations indicated in Table 1 allow for full A/D accuracy (according to the A/D specifications) assuming a source resistance of less than or equal to  $20k\Omega$ . Larger source resistances may be accommodated by increasing the sampling time with a different A/D timing configuration.





XA-S3

|                                     |        |                                          |                                                                                                                                              |                           |                          |            |            | LSB                     |                   |
|-------------------------------------|--------|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--------------------------|------------|------------|-------------------------|-------------------|
| Bit Addressable<br>Reset Value: 00h |        | CR2 ENA                                  | STA                                                                                                                                          | STO                       | SI                       | АА         | CR1        | CR0                     |                   |
| ВІТ                                 | SYMBOL | FUNCTION                                 |                                                                                                                                              |                           |                          |            |            |                         |                   |
| 12CON.7                             | CR2    | I <sup>2</sup> C Rate Control, w         | I <sup>2</sup> C Rate Control, with CR1 and CR0. See text and table.                                                                         |                           |                          |            |            |                         |                   |
| I2CON.6                             | ENA    | Enable I <sup>2</sup> C port. W          | hen ENA =                                                                                                                                    | = 1, the l <sup>2</sup> 0 | C port is ei             | nabled.    |            |                         |                   |
| 12CON.5                             | STA    |                                          | Start flag. Setting STA to 1 causes the I <sup>2</sup> C interface to attempt to gain mastership of the bus by generating a Start condition. |                           |                          |            |            |                         | hip of the bus by |
| I2CON.4                             | STO    | Stop flag. Setting S                     | TO to 1 ca                                                                                                                                   | uses the l                | l <sup>2</sup> C interfa | ce to atte | mpt to ger | nerate a S <sup>.</sup> | top condition.    |
| 12CON.3                             | SI     | Serial Interrupt. SI software needs to r |                                                                                                                                              |                           |                          |            |            |                         |                   |
| 12CON.2                             | AA     | Assert Acknowledg<br>acknowledge pulse   |                                                                                                                                              |                           |                          |            | are to aut | omatically              | generate          |
| I2CON.1                             | CR1    | I <sup>2</sup> C Rate Control, w         | vith CR2 ar                                                                                                                                  | nd CR0. S                 | ee text an               | id table.  |            |                         |                   |
| 12CON.0                             | CR0    | I <sup>2</sup> C Rate Control, w         | rith CR2 ar                                                                                                                                  | nd CR1. S                 | ee text an               | id table.  |            |                         |                   |
|                                     |        |                                          |                                                                                                                                              |                           |                          |            |            |                         | SU00941           |

Figure 5. I<sup>2</sup>C Control Register (I2CON)

## I<sup>2</sup>C Interface

The  $l^2C$  interface on the XA-S3 is identical to the standard byte-style  $l^2C$  interface found on devices such as the 8xC552 except for the rate selection. The  $l^2C$  interface conforms to the 100 kHz  $l^2C$  specification, but may be used at rates up to 400 kHz (non-conforming).

**Important:** Before the  $I^2C$  interface may be used, the port pins P5.6 and 5.7, which correspond to the  $I^2C$  functions SCL and SDA respectively, must be set to the open drain mode.

The processor interfaces to the I<sup>2</sup>C logic via the following four special function registers: I2CON (I<sup>2</sup>C control register), I2STA (I<sup>2</sup>C status register), I2DAT (I<sup>2</sup>C data register), and I2ADR (I<sup>2</sup>C slave address register). The I<sup>2</sup>C control logic interfaces to the external I<sup>2</sup>C bus via two port 5 pins: P5.6/SCL (serial clock line) and P5.7/SDA (serial data line).

#### The Control Register, I2CON

This register is shown in Figure 5. Two bits are affected by the  $I^2C$  hardware: the SI bit is set when a serial interrupt is requested, and the STO bit is cleared when a STOP condition is present on the  $I^2C$  bus. The STO bit is also cleared when ENA = "0".

#### ENA, the I<sup>2</sup>C Enable Bit

**ENA = 0:** When ENA is "0", the SDA and SCL outputs are not driven. SDA and SCL input signals are ignored, SIO1 is in the "not addressed" slave state, and the STO bit in I2CON is forced to "0". No other bits are affected. P5.6 and P5.7 may be used as open drain I/O ports.

**ENA = 1:** When ENA is "1", SIO1 is enabled. The P5.6 and P5.7 port latches must be set to logic 1.

ENA should not be used to temporarily release the l<sup>2</sup>C-bus since, when ENA is reset, the l<sup>2</sup>C-bus status is lost. The AA flag should be used instead (see description of the AA flag in the following text).

In the following text, it is assumed the ENA = "1".

#### STA, the START flag

**STA = 1:** When the STA bit is set to enter a master mode, the  $l^2C$  hardware checks the status of the  $l^2C$  bus and generates a START condition if the bus is free. If the bus is not free, the  $l^2C$  interface waits for a STOP condition (which will free the bus) and generates a START condition after a delay of a half clock period of the internal serial clock generator.

If STA is set while the  $l^2C$  interface is already in a master mode and one or more bytes are transmitted or received, the hardware transmits a repeated START condition. STA may be set at any time. STA may also be set when the  $l^2C$  interface is an addressed slave.

**STA = 0:** When the STA bit is reset, no START condition or repeated START condition will be generated.

#### STO, the STOP flag

**STO = 1:** When the STO bit is set while the  $l^2C$  interface is in a master mode, a STOP condition is transmitted to the  $l^2C$  bus. When the STOP condition is detected on the bus, the hardware clears the STO flag. In a slave mode, the STO flag may be set to recover from an error condition. In this case, no STOP condition is transmitted to the  $l^2C$  bus. However, the hardware behaves as if a STOP condition has been received and switches to the defined "not addressed" slave receiver mode. The STO flag is automatically cleared by hardware.

If the STA and STO bits are both set, then a STOP condition is transmitted to the  $l^2C$  bus if the interface is in a master mode (in a slave mode, the hardware generates an internal STOP condition which is not transmitted). The  $l^2C$  interface then transmits a START condition.

**STO = 0:** When the STO bit is reset, no STOP condition will be generated.

#### SI, the Serial Interrupt flag

**SI = 1:** When the SI flag is set, and the EA (interrupt system enable) and EI2 (I<sup>2</sup>C interrupt enable) bits are also set, an I<sup>2</sup>C interrupt is requested. SI is set by hardware when one of 25 of the 26 possible I<sup>2</sup>C interface states is entered. The only state that does not cause SI to be set is state F8H, which indicates that no relevant state information is available.

While SI is set, the low period of the serial clock on the SCL line is stretched, and the serial transfer is suspended. A high level on the SCL line is unaffected by the serial interrupt flag. SI must be reset by software.

**SI = 0:** When the SI flag is reset, no serial interrupt is requested, and there is no stretching of the serial clock on the SCL line.

#### AA, the Assert Acknowledge flag

**AA = 1:** If the AA flag is set, an acknowledge (low level to SDA) will be returned during the acknowledge clock pulse on the SCL line when:

- The "own slave address" has been received.
- The general call address has been received while the general call bit (GC) in I2ADR is set.
- A data byte has been received while the I<sup>2</sup>C interface is in the master receiver mode.
- A data byte has been received while the I<sup>2</sup>C interface is in the addressed slave receiver mode.

**AA = 0:** If the AA flag is reset, a not acknowledge (high level to SDA) will be returned during the acknowledge clock pulse on the SCL line when:

- A data byte has been received while the I<sup>2</sup>C interface is in the master receiver mode.
- A data byte has been received while the I<sup>2</sup>C interface is in the addressed slave receiver mode.

When the  $l^2C$  interface is in the addressed slave transmitter mode, state C8H will be entered after the last serial data byte is transmitted. When SI is cleared, the  $l^2C$  interface leaves state C8H, enters the not addressed slave receiver mode, and the SDA line remains at a high level. In state C8H, the AA flag can be set again for future address recognition.

When the I<sup>2</sup>C interface is in the not addressed slave mode, its own slave address and the general call address are ignored. Consequently, no acknowledge is returned, and a serial interrupt is

not requested. Thus, the hardware can be temporarily released from the  $l^2C$  bus while the bus status is monitored. While the hardware is released from the bus, START and STOP conditions are detected, and serial data is shifted in. Address recognition can be resumed at any time by setting the AA flag. If the AA flag is set when the part's own slave address or the general call address has been partly received, the address will be recognized at the end of the byte transmission.

#### CR0, CR1, and CR2, the Clock Rate Bits

These three bits determine the serial clock frequency when the  $l^2C$  interface is in a master mode. An  $l^2C$  rate of 100kHz or lower is typical and can be derived from many oscillator frequencies. The various serial rates are shown in Table 3. A variable bit rate may also be used if Timer 1 is not required for any other purpose while the  $l^2C$  hardware is in a master mode. The frequencies shown in Table 3 are unimportant when the  $l^2C$  hardware is in a slave mode. In the slave modes, the hardware will automatically synchronize with the incoming clock frequency.

## The I<sup>2</sup>C Status Register, I2STA

I2STA is an 8-bit read-only special function register. The three least significant bits are always zero. The five most significant bits contain the status code. There are 26 possible status codes. When I2STA contains F8H, no relevant state information is available and no serial interrupt is requested. All other I2STA values correspond to defined hardware interface states. When each of these states is entered, a serial interrupt is requested (SI = "1").

# NOTE: A detailed I<sup>2</sup>C interface description and usage information, including example driver code, will be provided in a separate document.

| Frequency Select | Oleek Divisor          | Example I <sup>2</sup> C Rates at Specific Oscillator Frequencies |                        |                        |                        |                        |                        |
|------------------|------------------------|-------------------------------------------------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|
| (CR2, CR1, CR0)  | Clock Divisor          | 8 MHz                                                             | 12 MHz                 | 16 MHz                 | 20 MHz                 | 24 MHz                 | 30 MHz                 |
| 0h (0000)        | 20                     | (400) <sup>1</sup>                                                | -                      | _                      | -                      | -                      | _                      |
| 1h (0001)        | 40                     | (200) <sup>1</sup>                                                | (300) <sup>1</sup>     | (400) <sup>1</sup>     | -                      | -                      | _                      |
| 2h (0010)        | 68                     | (116.65) <sup>1</sup>                                             | (176.46) <sup>1</sup>  | (235.29) <sup>1</sup>  | (294.12) <sup>1</sup>  | (352.94) <sup>1</sup>  | _                      |
| 3h (0011)        | 88                     | 90.91                                                             | (136.36) <sup>1</sup>  | (181.82) <sup>1</sup>  | (227.27) <sup>1</sup>  | (272.73) <sup>1</sup>  | (340.91) <sup>1</sup>  |
| 4h (0100)        | 160                    | 50                                                                | 75                     | 100                    | (125) <sup>1</sup>     | (150) <sup>1</sup>     | (187.5) <sup>1</sup>   |
| 5h (0101)        | 272                    | 29.41                                                             | 44.12                  | 58.82                  | 73.53                  | 88.24                  | (110.29) <sup>1</sup>  |
| 6h (0110)        | 352                    | 22.73                                                             | 34.09                  | 45.45                  | 56.82                  | 68.18                  | 85.23                  |
| 7h (0111)        | (Timer 1) <sup>2</sup> | (Timer 1) <sup>2</sup>                                            | (Timer 1) <sup>2</sup> | (Timer 1) <sup>2</sup> | (Timer 1) <sup>2</sup> | (Timer 1) <sup>2</sup> | (Timer 1) <sup>2</sup> |

# Table 3. I<sup>2</sup>C Rate Control

#### NOTES:

1. The XA-S3 I<sup>2</sup>C interface does not conform to the 400kHz I<sup>2</sup>C specification (which applies to rates greater than 100kHz) in all details, but may be used with care where higher rates are required by the application.

2. The timer 1 overflow is used to clock the I<sup>2</sup>C interface. The resulting bit rate is 1/2 of the timer overflow rate.

## XA-S3 Timer/Counters

The XA-S3 has three general purpose counter/timers, two of which may also be used as baud rate generators for either or both of the UARTs.

#### Timer 0 and 1

These are identical to the standard XA-G3 timer 0 and 1.

#### Timer 2

This is identical to the standard XA-G3 timer 2.

## PCA

This is a standard 80C51FC-style PCA counter/timer. The XA uses TCLK (the global peripheral clock which is Osc/4, Osc/16, or Osc/64), Timer 0 overflow, and External (ECI pin). When the ECI input is used, the falling edge clocks the PCA counter. The maximum rate for the counter in this mode on the XA is Osc/4. Each PCA module has its own interrupt (in addition to the standard global PCA interrupt).

## Watchdog Timer

This is a standard XA-G3 watchdog timer. This watchdog timer always comes up running at reset. The watchdog acts the same on EPROM, ROM, and ROMless parts, as in the XA-G3.

## UARTs

Standard XA-G3 UART0 and UART1 with double buffered transmit register. A flag has been added to SnSTAT that is set if any of the status flags (BRn, FEn, or OEn) is set for the corresponding UART channel. This allows polling for UART errors quickly at the interrupt service routine. Baud rate sources may be timer 1 or timer 2.

#### Clocking / Baud Rate Generation

Same as for the XA-G3.

#### I/O Port Output Configuration

Port output configurations are the same as for the XA-G3: open drain, quasi-bidirectional, push-pull, and off.

## **External Bus**

The external bus operates in the same manner as the XA-G3, but all 24 address lines are brought out to the outside world. This allows for a maximum of 16 Mbytes of code memory and 16 Mbytes of data memory.

## Clock Output

The CLKOUT pin allows easier external bus interfacing in some situations. This output reflects the X1 clock input to the XA, but is delayed to match the external bus outputs and strobes. The default is for CLKOUT to be on at reset, but it may be turned off via the CLKD bit that has been added to the BCR register.

#### Reset

Active low reset input, the same as the XA-G3.

The associated RSTOUT pin provides an external indication via an active low open drain output when an internal reset occurs. The RSTOUT pin will be driven low when the RST pin is driven low, when a Watchdog reset occurs or the RESET instruction is executed. This signal may be used to inform other devices in a system that the XA-S3 has been reset.

The latched values of EA and BUSW are NOT automatically updated when an internal reset occurs. RSTOUT may be used to apply an external reset to the XA-S3 in order to update the previously latched EA and BUSW values. However, since RSTOUT reflects ALL reset sources, it cannot simply be fed back into the RST pin without other logic.

The reset source identification register (RSTSRC) indicates the cause of the most recent XA reset. The cause may have been an externally applied reset signal, execution of the RESET instruction, or a Watchdog reset. Figure 6 shows the fields in the RSTSRC register.

## **Power Reduction Modes**

The XA-S3 supports Idle and Power Down modes of power reduction. The idle mode leaves some peripherals running in order to allow them to activate the processor when an interrupt is generated. The power down mode stops the oscillator in order to absolutely minimize power. The processor can be made to exit power down mode via a reset or one of the external interrupt inputs (INT0 or INT1). This will occur if the interrupt is enabled and its priority is higher than that defined by IM3 through IM0. In power down mode, the power supply voltage may be reduced to the RAM keep-alive voltage  $V_{\rm RAM}$ . This retains the RAM, register, and SFR contents at the point where power down mode was entered.  $V_{\rm DD}$  must be raised to within the operating range before power down mode is exited.

| RSTSRC Address                                | :463h  | MSB                     |                                                                   |            |             |                   |             | LSB        |
|-----------------------------------------------|--------|-------------------------|-------------------------------------------------------------------|------------|-------------|-------------------|-------------|------------|
| Not bit Addressable<br>Reset Value: see belov | w      |                         |                                                                   | _          | _           | R_WD              | R_CMD       | R_EXT      |
| BIT                                           | SYMBOL | FUNCTION                |                                                                   |            |             |                   |             |            |
| RSTSRC.7                                      |        | Reserved for future u   | se. Shou                                                          | uld not be | set to 1 b  | y user pro        | grams.      |            |
| RSTSRC.6                                      |        | Reserved for future u   | se. Shou                                                          | uld not be | set to 1 by | by user programs. |             |            |
| RSTSRC.5                                      |        | Reserved for future u   | Reserved for future use. Should not be set to 1 by user programs. |            |             |                   |             |            |
| RSTSRC.4                                      |        | Reserved for future u   | se. Shou                                                          | uld not be | set to 1 by | y user pro        | grams.      |            |
| RSTSRC.3                                      | _      | Reserved for future u   | se. Shou                                                          | uld not be | set to 1 b  | y user pro        | grams.      |            |
| RSTSRC.2                                      | R_WD   | Indicates that the last | reset wa                                                          | as caused  | l by a wate | chdog tim         | er overflov | v.         |
| RSTSRC.1                                      | R_CMD  | Indicates that the last | reset wa                                                          | as caused  | l by execu  | ition of the      | RESET i     | nstruction |
| RSTSRC.0                                      | R_EXT  | Indicates that the last | reset wa                                                          | as caused  | l by the ex | ternal RS         | ⊤ input.    |            |
|                                               |        |                         |                                                                   |            |             |                   |             | SU009      |

Figure 6. Reset source register (RSTSRC)

## **INTERRUPTS**

XA-S3 interrupt sources include the following:

- External interrupts 0 and 1 (2)
- Timer 0, 1, and 2 interrupts (3)
- PCA: 1 global and 5 channel interrupts (6)
- A/D interrupt (1)

## **EXCEPTION/TRAPS PRECEDENCE**

- UART 0 transmitter and receiver interrupts (2)
- UART 1 transmitter and receiver interrupts (2)
- I<sup>2</sup>C interrupt (1)
- Software interrupts (7)

There are a total of 17 **hardware** interrupt sources, enable bits, priority bit sets, etc.

| DESCRIPTION                | VECTOR ADDRESS | ARBITRATION RANKING |
|----------------------------|----------------|---------------------|
| Reset (h/w, watchdog, s/w) | 0000–0003      | 0 (High)            |
| Breakpoint                 | 0004–0007      | 1                   |
| Trace                      | 0008–000B      | 1                   |
| Stack Overflow             | 000C-000F      | 1                   |
| Divide by 0                | 0010–0013      | 1                   |
| User RETI                  | 0014–0017      | 1                   |
| TRAP 0–15 (software)       | 0040–007F      | 1                   |

# **EVENT INTERRUPTS**

| DESCRIPTION                | FLAG BIT      | VECTOR ADDRESS | ENABLE BIT | INTERRUPT<br>PRIORITY | ARBITRATION<br>RANKING |
|----------------------------|---------------|----------------|------------|-----------------------|------------------------|
| External Interrupt 0       | IE0           | 0080–0083      | EX0        | IPA0.3–0 (PX0)        | 2                      |
| Timer 0 Interrupt          | TF0           | 0084–0087      | ET0        | IPA0.7–4 (PT0)        | 3                      |
| External Interrupt 1       | IE1           | 0088–008B      | EX1        | IPA1.3–0 (PX1)        | 4                      |
| Timer 1 Interrupt          | TF1           | 008C-008F      | ET1        | IPA1.7–4 (PT1)        | 5                      |
| Timer 2 Interrupt          | TF2 (EXF2)    | 0090–0093      | ET2        | IPA2.3–0 (PT2)        | 6                      |
| PCA Interrupt              | CCF0-CCF4, CF | 0094–0097      | EPC        | IPA2.7–4 (PPC)        | 7                      |
| A/D Interrupt              | ADINT         | 0098–009B      | EAD        | IPA3.3–0 (PAD)        | 8                      |
| Serial Port 0 Rx           | RI_0          | 00A0-00A3      | ERI0       | IPA4.3–0 (PRI0)       | 9                      |
| Serial Port 0 Tx           | TI_0          | 00A400A7       | ETI0       | IPA4.7–4 (PTI0)       | 10                     |
| Serial Port 1 Rx           | RI_1          | 00A800AB       | ERI1       | IPA5.3–0 (PRI1)       | 11                     |
| Serial Port 1 Tx           | TI_1          | 00AC-00AF      | ETI1       | IPA5.7–4 (PTI1)       | 12                     |
| PCA channel 0              | CCF0          | 00C0-00C3      | EC0        | IPB0.3–0 (PC0)        | 17                     |
| PCA channel 1              | CCF1          | 00C4-00C7      | EC1        | IPB0.7–4 (PC1)        | 18                     |
| PCA channel 2              | CCF2          | 00C8-00CB      | EC2        | IPB1.3-0 (PC2)        | 19                     |
| PCA channel 3              | CCF3          | 00CC-00CF      | EC3        | IPB1.7–4 (PC3)        | 20                     |
| PCA channel 4              | CCF4          | 00D0-00D3      | EC4        | IPB2.3–0 (PC4)        | 21                     |
| I <sup>2</sup> C Interrupt | SI            | 00D400D7       | El2        | IPB2.7–4 (PI2)        | 22                     |

# SOFTWARE INTERRUPTS

| DESCRIPTION          | FLAG BIT | VECTOR ADDRESS | ENABLE BIT | INTERRUPT PRIORITY |
|----------------------|----------|----------------|------------|--------------------|
| Software Interrupt 1 | SWR1     | 0100–0103      | SWE1       | (fixed at 1)       |
| Software Interrupt 2 | SWR2     | 0104–0107      | SWE2       | (fixed at 2)       |
| Software Interrupt 3 | SWR3     | 0108–010B      | SWE3       | (fixed at 3)       |
| Software Interrupt 4 | SWR4     | 010C-010F      | SWE4       | (fixed at 4)       |
| Software Interrupt 5 | SWR5     | 0110–0113      | SWE5       | (fixed at 5)       |
| Software Interrupt 6 | SWR6     | 0114–0117      | SWE6       | (fixed at 6)       |
| Software Interrupt 7 | SWR7     | 0118–011B      | SWE7       | (fixed at 7)       |

## **ABSOLUTE MAXIMUM RATINGS**

| PARAMETER                                                                        | RATING                        | UNIT |
|----------------------------------------------------------------------------------|-------------------------------|------|
| Operating temperature under bias                                                 | –55 to +125                   | °C   |
| Storage temperature range                                                        | −65 to +150                   | °C   |
| Voltage on EA/V <sub>PP</sub> pin to V <sub>SS</sub>                             | 0 to +13.0                    | V    |
| Voltage on any other pin to $V_{\rm SS}$                                         | –0.5 to V <sub>DD</sub> +0.5V | V    |
| Maximum I <sub>OL</sub> per I/O pin                                              | 15                            | mA   |
| Power dissipation (based on package heat transfer, not device power consumption) | 1.5                           | W    |

# **DC ELECTRICAL CHARACTERISTICS**

 $V_{DD}$  = 2.7V to 5.5V, unless otherwise specified.

 $T_{amb} = 0$  to +70°C for commercial unless otherwise specified.

|                  |                                                           | TEAT CONDITIONS                                      |                     | LIMITS |                      |      |
|------------------|-----------------------------------------------------------|------------------------------------------------------|---------------------|--------|----------------------|------|
| SYMBOL           | PARAMETER                                                 | TEST CONDITIONS                                      | MIN                 | ТҮР    | MAX                  | UNIT |
| I <sub>DD</sub>  | Power supply current, operating                           | 5.0V, 30MHz                                          |                     |        | 100                  | mA   |
| l <sub>ID</sub>  | Power supply current, Idle mode                           | 5.0V, 30MHz                                          |                     |        | 25                   | mA   |
| I <sub>PD</sub>  | Power supply current, Power Down mode                     | 5.0V, 3.0V                                           |                     | 5      | 50                   | μA   |
| V <sub>RAM</sub> | RAM keep-alive voltage                                    |                                                      | 1.5                 |        |                      | V    |
| V <sub>IL</sub>  | Input low voltage                                         |                                                      | -0.5                |        | 0.22 V <sub>DD</sub> | V    |
| V <sub>IH</sub>  | Input high voltage, except XTAL1, RST                     | V <sub>DD</sub> = 5.0V                               | 2.2                 |        |                      | V    |
|                  |                                                           | V <sub>DD</sub> = 3.0V                               | 2.0                 |        |                      | V    |
| V <sub>IH1</sub> | Input high voltage to XTAL1, RST                          | For both 3.0V and 5.0V                               | 0.7 V <sub>DD</sub> |        |                      | V    |
| V <sub>OL</sub>  | Output low voltage, all ports, ALE, PSEN <sup>4</sup>     | l <sub>OL</sub> = 3.2mA, V <sub>DD</sub> = 5.0V      |                     |        | 0.5                  | V    |
|                  |                                                           | I <sub>OL</sub> = 1.0mA, V <sub>DD</sub> = 3.0V      |                     |        | 0.4                  | V    |
| V <sub>OH1</sub> | Output high voltage, all ports, ALE, PSEN <sup>2</sup>    | l <sub>OH</sub> = −100μA, V <sub>DD</sub> = 4.5V     | 2.4                 |        |                      | V    |
|                  |                                                           | l <sub>OH</sub> = –30μΑ, V <sub>DD</sub> = 2.7V      | 2.0                 |        |                      | V    |
| V <sub>OH2</sub> | Output high voltage, all ports ALE, PSEN <sup>3</sup>     | I <sub>OH</sub> = –3.2mA, V <sub>DD</sub> = 4.5V     | 2.4                 |        |                      | V    |
|                  |                                                           | I <sub>OH</sub> = -1.0mA, V <sub>DD</sub> = 2.7V     | 2.2                 |        |                      | V    |
| C <sub>IO</sub>  | Input/Output pin capacitance <sup>1</sup>                 |                                                      |                     |        | 15                   | pF   |
| կլ               | Logical 0 input current, all ports <sup>7</sup>           | V <sub>IN</sub> = 0.45V                              |                     |        | -50                  | μA   |
| Iц               | Input leakage current, all ports <sup>6</sup>             | V <sub>IN</sub> = V <sub>IL</sub> or V <sub>IH</sub> |                     |        | ±10                  | μA   |
| I <sub>TL</sub>  | Logical 1 to 0 transition current, all ports <sup>b</sup> | At V <sub>DD</sub> = 5.5V                            |                     |        | -650                 | μA   |
|                  |                                                           | At V <sub>DD</sub> = 2.7V                            |                     |        | -250                 | μA   |

NOTES:

1. Maximum 15pF for EA/V<sub>PP</sub>.

2. Ports in quasi-bidirectional mode with weak pullup (applies to ALE, PSEN only during RESET).

3. Ports in PUSH-PULL mode, both pullup and pulldown assumed to be the same strength.

4. In all output modes.

5. Port pins source a transition current when used in quasi-bidirectional mode and externally driven from 1 to 0. This current is highest when V<sub>IN</sub> is approximately 2V.

6. Measured with port in high impedance mode.

7. Measured with port in quasi-bidirectional mode.

8. Under steady state (non-transient) conditions, I<sub>OL</sub> must be externally limited as follows:

Maximum I<sub>OL</sub> per port pin: 15mA

Maximum I<sub>OL</sub> per 8-bit port: 26mA

Maximum total I<sub>OL</sub> for all outputs: 71mA

If  $I_{OL}$  exceeds the test condition,  $V_{OL}$  may exceed the related specification. Pins are not guaranteed to sink current greater than the listed test conditions.

# A/D CONVERTER DC ELECTRICAL CHARACTERISTICS

T<sub>amb</sub> = 0 to +70°C for commercial unless otherwise specified.

|                  | DADAMETER                                     | TEST CONDITIONS                              | LIN                   | LIMITS                |       |  |  |
|------------------|-----------------------------------------------|----------------------------------------------|-----------------------|-----------------------|-------|--|--|
| SYMBOL           | PARAMETER                                     | TEST CONDITIONS                              | MIN                   | МАХ                   | UNIT  |  |  |
| AV <sub>DD</sub> | Analog supply voltage                         |                                              | 2.7                   | 3.3                   | V     |  |  |
| Al <sub>DD</sub> | Analog supply current (operating)             | Port 5 = 0 to $AV_{DD}$                      |                       | tbd                   | mA    |  |  |
| Al <sub>ID</sub> | Analog supply current (Idle mode)             |                                              |                       | tbd                   | μA    |  |  |
| Al <sub>PD</sub> | Analog supply current (Power-Down mode)       | 2V < AV <sub>PD</sub> < AV <sub>DD</sub> max |                       | tbd                   | μA    |  |  |
| AV <sub>IN</sub> | Analog input voltage                          |                                              | AV <sub>SS</sub> –0.2 | AV <sub>DD</sub> +0.2 | V     |  |  |
| R <sub>REF</sub> | Resistance between $V_{REF+}$ and $V_{REF-}$  |                                              | tbd                   | tbd                   | kΩ    |  |  |
| C <sub>IA</sub>  | Analog input capacitance                      |                                              |                       | 15                    | pF    |  |  |
| -                | A/D input slew rate                           |                                              |                       | tbd                   | mV/μs |  |  |
| DLe              | Differential non-linearity <sup>1, 2, 3</sup> |                                              |                       | tbd                   | LSB   |  |  |
| ILe              | Integral non-linearity <sup>1, 4</sup>        |                                              |                       | tbd                   | LSB   |  |  |
| OS <sub>e</sub>  | Offset error <sup>1, 5</sup>                  |                                              |                       | tbd                   | LSB   |  |  |
| G <sub>e</sub>   | Gain error <sup>1, 6</sup>                    |                                              |                       | tbd                   | LSB   |  |  |
| A <sub>e</sub>   | Absolute voltage error <sup>1, 7</sup>        |                                              |                       | tbd                   | LSB   |  |  |
| M <sub>CTC</sub> | Channel-to-channel matching                   |                                              |                       | tbd                   | LSB   |  |  |
| Ct               | Crosstalk between inputs of port <sup>8</sup> | 0 – 100kHz                                   |                       | tbd                   | dB    |  |  |

NOTES:

Conditions:  $AV_{REF-} = 0V$ ;  $AV_{REF+} = 3.0V$ . 1.

The differential non-linearity (DLe) is the difference between the actual step width and the ideal step width. See Figure 7. 2.

З. The ADC is monotonic, there are no missing codes.

The integral non-linearity (ILe) is the peak difference between the center of the steps of the actual and the ideal transfer curve after 4.

appropriate adjustment of gain and offset errors. See Figure 7. The offset error (OS<sub>e</sub>) is the absolute difference between the straight line which fits the actual transfer curve (after removing gain error), and 5. the straight line which fits the ideal transfer curve. See Figure 7.

6. The gain error (Ge) is the relative difference in percent between the straight line fitting the actual transfer curve (after removing offset error), and the straight line which fits the ideal transfer curve. Gain error is constant at every point on the transfer curve. See Figure 7.

7. The absolute voltage error (Ae) is the maximum difference between the center of the steps of the actual transfer curve of the non-calibrated ADC and the ideal transfer curve.

8. This should be considered when both analog and digital signals are input simultaneously to Port 5. Parameter is guaranteed by design.



Figure 7. ADC Conversion Characteristic

# AC ELECTRICAL CHARACTERISTICS (5V)

 $V_{DD}$  = 4.5V to 5.5V;  $T_{amb}$  = 0 to +70°C for commercial.

| SYMBOL             | FIGURE    |                                                                             | LIMITS                       |                              | UNIT |  |
|--------------------|-----------|-----------------------------------------------------------------------------|------------------------------|------------------------------|------|--|
| STMBOL             | FIGURE    | PARAMETER                                                                   | MIN                          | MAX                          |      |  |
| External C         | lock      |                                                                             |                              |                              |      |  |
| f <sub>C</sub>     | 14        | Oscillator frequency                                                        | 0                            | 30                           | MHz  |  |
| t <sub>C</sub>     | 14        | Clock period and CPU timing cycle                                           | 1/f <sub>C</sub>             |                              | ns   |  |
| t <sub>CHCX</sub>  | 14        | Clock high-time                                                             | t <sub>C</sub> * 0.5         |                              | ns   |  |
| t <sub>CLCX</sub>  | 14        | Clock low time                                                              | t <sub>C</sub> * 0.4         |                              | ns   |  |
| t <sub>CLCH</sub>  | 14        | Clock rise time                                                             |                              | 5                            | ns   |  |
| t <sub>CHCL</sub>  | 14        | Clock fall time                                                             |                              | 5                            | ns   |  |
| Address C          | ycle      |                                                                             |                              |                              |      |  |
| t <sub>LHLL</sub>  | 8, 10, 12 | ALE pulse width (programmable)                                              | (V1 * t <sub>C</sub> ) – 6   |                              | ns   |  |
| t <sub>AVLL</sub>  | 8, 10, 12 | Address valid to ALE de-asserted (set-up)                                   | (V1 * t <sub>C</sub> ) – 12  |                              | ns   |  |
| t <sub>LLAX</sub>  | 8, 10, 12 | Address hold after ALE de-asserted                                          | (t <sub>C</sub> /2) – 10     |                              | ns   |  |
| Code Read          | l Cycle   |                                                                             |                              |                              |      |  |
| t <sub>PLPH</sub>  | 8         | PSEN pulse width                                                            | (V2 * t <sub>C</sub> ) – 10  |                              | ns   |  |
| t <sub>LLPL</sub>  | 8         | ALE de-asserted to PSEN asserted                                            | $(t_{\rm C}/2) - 7$          |                              | ns   |  |
| t <sub>AVIVA</sub> | 8         | Address valid to instruction valid, ALE cycle (access time)                 |                              | (V3 * t <sub>C</sub> ) – 36  | ns   |  |
| t <sub>AVIVB</sub> | 9         | Address valid to instruction valid, non-ALE cycle (access time)             |                              | (V4 * t <sub>C</sub> ) – 29  | ns   |  |
| t <sub>PLIV</sub>  | 8         | PSEN asserted to instruction valid (enable time)                            |                              | (V2 * t <sub>C</sub> ) – 29  | ns   |  |
| t <sub>PHIX</sub>  | 8         | Instruction hold after PSEN de-asserted                                     | 0                            |                              | ns   |  |
| t <sub>PHIZ</sub>  | 8         | Bus 3-State after PSEN de-asserted                                          |                              | t <sub>C</sub> – 8           | ns   |  |
| tixua              | 8         | Hold time of unlatched part of address after instruction latched            | 0                            |                              | ns   |  |
| Data Read          | Cycle     | ·                                                                           |                              |                              |      |  |
| t <sub>RLRH</sub>  | 10        | RD pulse width                                                              | (V7 * t <sub>C</sub> ) – 10  |                              | ns   |  |
| t <sub>LLRL</sub>  | 10        | ALE de-asserted to RD asserted                                              | $(t_{\rm C}/2) - 7$          |                              | ns   |  |
| t <sub>avdva</sub> | 10        | Address valid to data input valid, ALE cycle (access time)                  |                              | (V6 * t <sub>C</sub> ) – 36  | ns   |  |
| t <sub>AVDVB</sub> | 11        | Address valid to data input valid, non-ALE cycle (access time)              |                              | (V5 * t <sub>C</sub> ) – 29  | ns   |  |
| t <sub>RLDV</sub>  | 10        | RD low to valid data in (enable time)                                       |                              | (V7 * t <sub>C</sub> ) – 29  | ns   |  |
| t <sub>RHDX</sub>  | 10        | Data hold time after RD de-asserted                                         | 0                            |                              | ns   |  |
| t <sub>RHDZ</sub>  | 10        | Bus 3-State after RD de-asserted (disable time)                             |                              | t <sub>C</sub> – 8           | ns   |  |
| t <sub>DXUA</sub>  | 10        | Hold time of unlatched part of address after data latched                   | 0                            |                              | ns   |  |
| Data Write         | Cycle     | •                                                                           | •                            |                              |      |  |
| twlwH              | 12        | WR pulse width                                                              | (V8 * t <sub>C</sub> ) – 10  |                              | ns   |  |
| tLLWL              | 12        | ALE falling edge to WR asserted                                             | (V12 * t <sub>C</sub> ) – 10 |                              | ns   |  |
| t <sub>QVWX</sub>  | 12        | Data valid before WR asserted (data set-up time)                            | (V13 * t <sub>C</sub> ) – 22 |                              | ns   |  |
| tWHQX              | 12        | Data hold time after WR de-asserted (Note 6)                                | (V11 * t <sub>C</sub> ) – 5  |                              | ns   |  |
| tavwL              | 12        | Address valid to $\overline{WR}$ asserted (address set-up time) (Note 5)    | (V9 * t <sub>C</sub> ) – 22  |                              | ns   |  |
| tUAWH              | 12        | Hold time of unlatched part of address after $\overline{WR}$ is de-asserted | (V11 * t <sub>C</sub> ) – 7  |                              | ns   |  |
| Wait Input         |           |                                                                             |                              |                              |      |  |
| twth               | 13        | WAIT stable after bus strobe (RD, WR, or PSEN) asserted                     |                              | (V10 * t <sub>C</sub> ) – 30 | ns   |  |
| t <sub>WTL</sub>   | 13        | WAIT hold after bus strobe (RD, WR, or PSEN) asserted                       | (V10 * t <sub>C</sub> ) – 5  |                              | ns   |  |

NOTES ON PAGE 27.

# AC ELECTRICAL CHARACTERISTICS (5V) (continued)

This set of parameters is referenced to the XA-S3 clock output.

| SYMBOL             | FIGURE | DADAMETED                                          | LIN | LIMITS |    |  |
|--------------------|--------|----------------------------------------------------|-----|--------|----|--|
| SYMBOL             | FIGURE | PARAMETER                                          | MIN | MAX    |    |  |
| Address Cy         | /cle   | •                                                  |     |        |    |  |
| t <sub>CHLH</sub>  | 8      | Delay from CLKOUT rising edge to ALE rising edge   | 10  | 40     | ns |  |
| tCLLL              | 8      | Delay from CLKOUT falling edge to ALE falling edge |     |        | ns |  |
| t <sub>CHAV</sub>  | 8      | Delay from CLKOUT rising edge to address valid     |     |        | ns |  |
| t <sub>CHAX</sub>  | 8      | Address hold after CLKOUT rising edge              |     |        | ns |  |
| Code Read          | Cycle  | •                                                  | •   | -      |    |  |
| t <sub>CHPL</sub>  | 8      | Delay from CLKOUT rising edge to PSEN asserted     |     |        | ns |  |
| t <sub>CHPH</sub>  | 8      | Delay from CLKOUT rising edge to PSEN de-asserted  |     |        | ns |  |
| tıvcн              | 8      | Instruction valid to CLKOUT rising edge            |     |        | ns |  |
| t <sub>CHIX</sub>  | 8      | Instruction hold from CLKOUT rising edge           |     |        | ns |  |
| <sup>t</sup> сніz  | 8      | Bus 3-State after CLKOUT rising edge (code read)   |     |        | ns |  |
| Data Read          | Cycle  | •                                                  | •   | •      |    |  |
| t <sub>CHRL</sub>  | 10     | Delay from CLKOUT rising edge to RD asserted       |     |        | ns |  |
| t <sub>CHRH</sub>  | 10     | Delay from CLKOUT rising edge to RD de-asserted    |     |        | ns |  |
| t <sub>DVCH</sub>  | 10     | Data valid to CLKOUT rising edge                   |     |        | ns |  |
| t <sub>CHDX</sub>  | 10     | 10 Data hold after CLKOUT rising edge              |     |        | ns |  |
| t <sub>CHDZ</sub>  | 10     | Bus 3-State after CLKOUT rising edge (data read)   |     |        | ns |  |
| Data Write         | Cycle  | ·                                                  |     | -      |    |  |
| t <sub>CHWL</sub>  | 12     | Delay from CLKOUT rising edge to WR asserted       |     |        | ns |  |
| t <sub>CHWH</sub>  | 12     | Delay from CLKOUT rising edge to WR de-asserted    |     |        | ns |  |
| tqvcн              | 12     | Data valid to CLKOUT rising edge                   |     |        | ns |  |
| t <sub>CHQX</sub>  | 12     | Data hold after CLKOUT rising edge                 |     |        | ns |  |
| t <sub>CHQZ</sub>  | 12     | Bus 3-State after CLKOUT rising edge (data write)  |     |        | ns |  |
| Wait Input         |        |                                                    |     |        |    |  |
| t <sub>CHWTH</sub> | 13     | 13 WAIT stable before CLKOUT rising edge           |     |        | ns |  |
| t <sub>CHWTL</sub> | 13     | WAIT hold after CLKOUT rising edge                 |     |        | ns |  |

NOTES ON PAGE 27.

# AC ELECTRICAL CHARACTERISTICS (3V) $V_{DD} = 2.7V$ to 4.5V; $T_{amb} = 0$ to +70°C for commercial.

| SYMBOL             | FIGURE    | PARAMETER                                                        | LIMITS                       |                              |      |  |
|--------------------|-----------|------------------------------------------------------------------|------------------------------|------------------------------|------|--|
| STMBOL             | FIGURE    |                                                                  | MIN                          | MAX                          | UNIT |  |
| Address C          | ycle      | ·                                                                |                              |                              |      |  |
| tLHLL              | 8, 10, 12 | ALE pulse width (programmable)                                   | (V1 * t <sub>C</sub> ) – 10  |                              | ns   |  |
| t <sub>AVLL</sub>  | 8, 10, 12 | Address valid to ALE de-asserted (set-up)                        | (V1 * t <sub>C</sub> ) – 18  |                              | ns   |  |
| t <sub>LLAX</sub>  | 8, 10, 12 | Address hold after ALE de-asserted                               | (t <sub>C</sub> /2) – 12     |                              | ns   |  |
| Code Read          | Cycle     | •                                                                | •                            |                              |      |  |
| t <sub>PLPH</sub>  | 8         | PSEN pulse width                                                 | (V2 * t <sub>C</sub> ) – 12  |                              | ns   |  |
| t <sub>LLPL</sub>  | 8         | ALE de-asserted to PSEN asserted                                 | (t <sub>C</sub> /2) – 9      |                              | ns   |  |
| t <sub>AVIVA</sub> | 8         | Address valid to instruction valid, ALE cycle (access time)      |                              | (V3 * t <sub>C</sub> ) – 58  | ns   |  |
| t <sub>AVIVB</sub> | 9         | Address valid to instruction valid, non-ALE cycle (access time)  |                              | (V4 * t <sub>C</sub> ) – 52  | ns   |  |
| t <sub>PLIV</sub>  | 8         | PSEN asserted to instruction valid (enable time)                 |                              | (V2 * t <sub>C</sub> ) – 52  | ns   |  |
| t <sub>PHIX</sub>  | 8         | Instruction hold after PSEN de-asserted                          | 0                            |                              | ns   |  |
| t <sub>PHIZ</sub>  | 8         | Bus 3-State after PSEN de-asserted                               |                              | t <sub>C</sub> – 8           | ns   |  |
| t <sub>IXUA</sub>  | 8         | Hold time of unlatched part of address after instruction latched | 0                            |                              | ns   |  |
| Data Read          | Cycle     |                                                                  |                              |                              |      |  |
| t <sub>RLRH</sub>  | 10        | RD pulse width                                                   | (V7 * t <sub>C</sub> ) – 12  |                              | ns   |  |
| t <sub>LLRL</sub>  | 10        | ALE de-asserted to RD asserted                                   | $(t_{\rm C}/2) - 9$          |                              | ns   |  |
| tavdva             | 10        | Address valid to data input valid, ALE cycle (access time)       |                              | (V6 * t <sub>C</sub> ) – 58  | ns   |  |
| t <sub>AVDVB</sub> | 11        | Address valid to data input valid, non-ALE cycle (access time)   |                              | (V5 * t <sub>C</sub> ) – 52  | ns   |  |
| t <sub>RLDV</sub>  | 10        | RD low to valid data in (enable time)                            |                              | (V7 * t <sub>C</sub> ) – 52  | ns   |  |
| t <sub>RHDX</sub>  | 10        | Data hold time after RD de-asserted                              | 0                            |                              | ns   |  |
| t <sub>RHDZ</sub>  | 10        | Bus 3-State after RD de-asserted (disable time)                  |                              | t <sub>C</sub> – 8           | ns   |  |
| t <sub>DXUA</sub>  | 10        | Hold time of unlatched part of address after data latched        | 0                            |                              | ns   |  |
| Data Write         | Cycle     |                                                                  | •                            |                              |      |  |
| t <sub>WLWH</sub>  | 12        | WR pulse width                                                   | (V8 * t <sub>C</sub> ) – 12  |                              | ns   |  |
| tLLWL              | 12        | ALE falling edge to WR asserted                                  | (V12 * t <sub>C</sub> ) – 10 |                              | ns   |  |
| t <sub>QVWX</sub>  | 12        | Data valid before WR asserted (data set-up time)                 | (V13 * t <sub>C</sub> ) – 28 |                              | ns   |  |
| t <sub>WHQX</sub>  | 12        | Data hold time after WR de-asserted (Note 6)                     | (V11 * t <sub>C</sub> ) – 8  |                              | ns   |  |
| tAVWL              | 12        | Address valid to WR asserted (address set-up time) (Note 5)      | (V9 * t <sub>C</sub> ) – 28  |                              | ns   |  |
| tUAWH              | 12        | Hold time of unlatched part of address after WR is de-asserted   | (V11 * t <sub>C</sub> ) – 10 |                              | ns   |  |
| Wait Input         |           |                                                                  | •                            | •                            |      |  |
| t <sub>WTH</sub>   | 13        | WAIT stable after bus strobe (RD, WR, or PSEN) asserted          |                              | (V10 * t <sub>C</sub> ) – 40 | ns   |  |
| twrL               | 13        | WAIT hold after bus strobe (RD, WR, or PSEN) asserted            | (V10 * t <sub>C</sub> ) – 5  |                              | ns   |  |

NOTES ON PAGE 27.

# AC ELECTRICAL CHARACTERISTICS (3V) (continued)

This set of parameters is referenced to the XA-S3 clock output.

| SYMBOL             | FIGURE                                             | PARAMETER                                          | LIN | LIMITS |          |  |
|--------------------|----------------------------------------------------|----------------------------------------------------|-----|--------|----------|--|
| STMBOL             | FIGURE                                             |                                                    | MIN | MAX    |          |  |
| Address C          | /cle                                               | •                                                  |     | •      |          |  |
| <sup>t</sup> CHLH  | 8 Delay from CLKOUT rising edge to ALE rising edge |                                                    | 15  | 60     | ns       |  |
| tCLLL              | 8                                                  | Delay from CLKOUT falling edge to ALE falling edge |     |        | ns       |  |
| t <sub>CHAV</sub>  | 8                                                  | Delay from CLKOUT rising edge to address valid     |     |        | ns       |  |
| t <sub>CHAX</sub>  | 8                                                  | Address hold after CLKOUT rising edge              |     |        | ns       |  |
| Code Read          | Cycle                                              | •                                                  |     |        |          |  |
| t <sub>CHPL</sub>  | 8                                                  | Delay from CLKOUT rising edge to PSEN asserted     |     |        | ns       |  |
| t <sub>CHPH</sub>  | 8                                                  | Delay from CLKOUT rising edge to PSEN de-asserted  |     |        | ns       |  |
| t <sub>IVCH</sub>  | 8                                                  | Instruction valid to CLKOUT rising edge            |     |        | ns       |  |
| <sup>t</sup> сніх  | 8                                                  | Instruction hold from CLKOUT rising edge           |     |        | ns       |  |
| t <sub>CHIZ</sub>  | 8                                                  | Bus 3-State after CLKOUT rising edge (code read)   |     |        | ns       |  |
| Data Read          | Cycle                                              | •                                                  | -   | •      |          |  |
| t <sub>CHRL</sub>  | 10                                                 | Delay from CLKOUT rising edge to RD asserted       |     |        | ns       |  |
| t <sub>CHRH</sub>  | 10                                                 | Delay from CLKOUT rising edge to RD de-asserted    |     |        | ns       |  |
| t <sub>DVCH</sub>  | 10                                                 | Data valid to CLKOUT rising edge                   |     |        | ns       |  |
| t <sub>CHDX</sub>  | 10                                                 | Data hold after CLKOUT rising edge                 |     |        | ns       |  |
| t <sub>CHDZ</sub>  | 10                                                 | Bus 3-State after CLKOUT rising edge (data read)   |     |        | ns       |  |
| Data Write         | Cycle                                              | •                                                  | •   | •      | -        |  |
| t <sub>CHWL</sub>  | 12                                                 | Delay from CLKOUT rising edge to WR asserted       |     |        | ns       |  |
| <sup>t</sup> снwн  | 12                                                 | Delay from CLKOUT rising edge to WR de-asserted    |     |        | ns       |  |
| t <sub>QVCH</sub>  | 12                                                 | Data valid to CLKOUT rising edge                   |     |        | ns       |  |
| t <sub>CHQX</sub>  | 12                                                 | Data hold after CLKOUT rising edge                 |     |        | ns       |  |
| t <sub>CHQZ</sub>  | 12                                                 | Bus 3-State after CLKOUT rising edge (data write)  |     |        | ns       |  |
| Wait Input         |                                                    | •                                                  | •   | •      | <u>.</u> |  |
| t <sub>CHWTH</sub> | 13                                                 | WAIT stable before CLKOUT rising edge              |     |        | ns       |  |
| t <sub>CHWTL</sub> | 13                                                 | WAIT hold after CLKOUT rising edge                 |     |        | ns       |  |

NOTES:

Load capacitance for all outputs = 80pF.

Variables V1 through V13 reflect programmable bus timing, which is programmed via the Bus Timing registers (BTRH and BTRL). Refer to the XA User Guide for details of the bus timing settings.

This variable represents the programmed width of the ALE pulse as determined by the ALEW bit in the BTRL register. V1 = 0.5 if the V1) ALEW bit = 0, and 1.5 if the ALEW bit = 1.

V2) This variable represents the programmed width of the PSEN pulse as determined by the CR1 and CR0 bits or the CRA1, CRA0, and ALEW bits in the BTRL register.

For a bus cycle with  $\mathbf{no}$  ALE, V2 = 1 if CR1/0 = 00, 2 if CR1/0 = 01, 3 if CR1/0 = 10, and 4 if CR1/0 = 11. Note that during burst mode code fetches. PSEN does not exhibit transitions at the boundaries of bus cycles. V2 still applies for the purpose of determining peripheral timing requirements.

For a bus cycle with an ALE, V2 = the total bus cycle duration (2 if CRA1/0 = 00, 3 if CRA1/0 = 01, 4 if CRA1/0 = 10, and 5 if CRA1/0 = 11) minus the number of clocks used by ALE (V1 + 0.5) = 2. Example: if CRA1/0 = 10 and ALEW = 1, the V2 = 4 - (1.5 + 0.5) = 2.

V3) This variable represents the programmed length of an entire code read cycle with ALE. This time is determined by the CRA1 and CRA0 bits in the BTRL register. V3 = the total bus cycle duration (2 if CRA1/0 = 00, 3 if CRA1/0 = 01, 4 if CRA1/0 = 10, and 5 if CRA1/0 = 11).

This variable represents the programmed length of an entire code read cycle with no ALE. This time is determined by the CR1 and V4)

CR0 bits in the BTRL register. V4 = 1 if CR1/0 = 00, 2 if CR1/0 = 01, 3 if CR1/0 = 10, and 4 if CR1/0 = 11. This variable represents the programmed length of an entire data read cycle with **no** ALE. This time is determined by the DR1 and V5) DR0 bits in the BTRH register. V5 = 1 if DR1/0 = 00, 2 if DR1/0 = 01, 3 if DR1/0 = 10, and 4 if DR1/0 = 11.

V6) This variable represents the programmed length of an entire data read cycle with ALE. The time is determined by the DRA1 and DRA0 bits in the BTRH register. V6 = the total bus cycle duration (2 if DRA1/0 = 00, 3 if DRA1/0 = 01, 4 if DRA1/0 = 10, and 5 if DRA1/0 = 11).

# XA 16-bit microcontroller 32K/1K OTP/ROM/ROMless, 8-channel 8-bit A/D, low voltage (2.7V-5.5V), I<sup>2</sup>C, 2 UARTs, 16MB address range

- This variable represents the programmed width of the RD pulse as determined by the DR1 and DR0 bits or the DRA1, DRA0 in the V7) BTRH register, and the SLEW bit in the BTRL register. Note that during a 16-bit operation on an 8-bit external bus, RD remains low and does not exhibit a transition between the first and second byte bus cycles. V7 still applies for the purpose of determining peripheral timing requirements. The timing for the first byte is for a bus cycle with ALE, the timing for the second byte is for a bus cycle with no ALE.

  - For a bus cycle with **no** ALE, V7 = 1 if DR1/0 = 00, 2 if DR1/0 = 01, 3 if DR1/0 = 10, and 4 if DR1/0 = 11. For a bus cycle **with** an ALE, V7 = the total bus cycle duration (2 if DRA1/0 = 00, 3 if DRA1/0 = 01, 4 if DRA1/0 = 10, and 5 if DRA1/0 = 11) minus the number of clocks used by ALE (V1 + 0.5).
    - Example: if DRA1/0 = 00 and ALEW = 0, then V7 = 2 (0.5 + 0.5) = 1
- This variable represents the programmed width of the WRL and/or WRH pulse as determined by the WM1 bit in the BTRL register. V8) V8 = 1 if WM1 = 0, and 2 if WM1 = 1.
- V9) This variable represents the programmed address setup time for a write as determined by the data write cycle duration (defined by DW1 and DW0 or the DWA1 and DWA0 bits in the BTRH register), the WM0 bit in the BTRL register, and the value of V8.
  - For a bus cycle with an ALE, V9 = the total bus write cycle duration (2 if DWA1/0 = 00, 3 if DWA1/0 = 01, 4 if DWA1/0 = 10, and 5 if DWA1/0 = 11) minus the number of clocks used by the WRL and/or WRH pulse (V8) minus the number of clocks used by data hold time (0 if WM0 = 0 and 1 if WM0 = 1)
  - Example: If DWA1/0 = 10, WM0 = 1, and WM1 = 1, then V9 = 4 1 2 = 1.
  - For a bus cycle with **no** ALE, V9 = the total bus cycle duration (2 if DW1/0 = 00, 3 if DW1/0 = 01, 4 if DW1/0 = 10, and 5 if DW1/0 = 11) minus the number of clocks used by the WRL and/or WRH pulse (V8), minus the number of clocks used by data hold time (0 if WMo = 0 and 1 if WM0 = 1). Example: If DW1/0 = 11, WM0 = 1, and WM1 = 0, then V9 = 5 - 1 - 1 = 3.
- V10) This variable represents the length of a bus strobe for calculation of WAIT set-up and hold times. The strobe may be RD (for data read cycles), WRL and/or WRH (for data write cycles), or PSEN (for code read cycles), depending on the type of bus cycle being widened by WAIT. V10 = 2 for WAIT associated with a code read cycle using PSEN. V10 = V8 for a data write cycle using WRL and/or WRH. V10 = V7 - 1 for a data read cycle using RD. This means that a single clock data read cycle cannot be stretched using WAIT. If WAIT is used to vary the duration of data read cycles, the RD strobe width must be set to be at least two clocks in duration. Also see Note 4.
- V11) This variable represents the programmed write hold time as determined by the WM0 bit in the BTRL register. V11 0 if the WM0 bit = 0, and 1 if the WM0 bit = 1.
- V12) this variable represents the programmed period between the end of the ALE pulse and the beginning of the WRL and/or WRH pulse as determined by the data write cycle duration (defined by the DWA1 and DWA0 bits in the BTRH register), the WM0 bit in the BTRL register, and the values of V1 and V8. V12 = the total bus cycle duration (2 if DWA1/0 = 00, 3 if DWA1/0 = 01, 4 if DWA1/0 = 10, and 5 if DWA1/0 = 11) minus the number of clocks used by the WRL and/or WRH pulse (V8), minus the number of clocks used by data hold time (0 if WM0 = 0 and 1 if WM0 = 1), minus the width of the ALE pulse (V1). Example: If SWA1/0 = 11, WM0 = 1, WM1 = 0, and ALEW = 1, then V12 = 5 - 1 - 1 - 1.5 = 1.5.
- V13) This variable represents the programmed data setup time for a write as determined by the data write cycle duration (defined by DW1 and DW0 or the DWA1 and DWA0 bits in the BTRH register), the WM0 bit in the BTRL register, and the values of V1 and V8.
  - For a bus cycle with an ALE, V13 = the total bus cycle duration (2 if DWA1/0 = 00, 3 if DWA1/0 = 01, 4 if DWA1/0 = 10, and 5 if DWA1/0 = 11) minus the number of clocks used by the WRL and/or WRH pulse (V8), minus the number of clocks used by data hold time (0 if WM0 = 0 and 1 if WM0 = 1), minus the number of clocks used by ALE (V1 + 0.5). Example: If DWA1/0 = 11, WM0 = 1, WM1 = 1, and ALEW = 0, then V13 = 5 - 1 - 2 - 1 = 1.
  - For a bus cycle with no ALE, V13 = the total bus cycle duration (2 if DW1/0 = 00, 3 if DW1/0 = 01, 4 if DW1/0 = 10, and 5 if DW1/0 = 11) minus the number of clocks used by the WRL and/or WRH pulse (V8), minus the number of clocks used by data hold time (0 if WM0 = 0 and 1 if WM0 = 1).
  - Example: If DW1/0 = 01, WM0 = 1, and WM1 = 0, then V13 = 3 1 1 = 1.
- 3. Not all combinations of bus timing configuration values result in valid bus cycles. Please refer to the XA User Guide section on the External Bus for details
- When code is being fetched for execution on the external bus, a burst mode fetch is used that dows not have PSEN edges in every fetch cycle. This would be A3-A0 for an 8-bit bus, and A3-A1 for a 16-bit bus. Also, a 16-bit read operation conducted on an 8-bit wide bus similarly does not include two separate RD strobes. So, a rising edge on the low order address line (A0) must be used to trigger a WAIT in the second half of such a cycle.
- This parameter is provided for peripherals that have the data clocked in on the falling edge of the WR strobe. This is not usually the case and in most applications this parameter is not used.
- Please note that the XA-S3 requires that extended data bus hold time (WM0 = 1) to be used with external bus write cycles.

XA 16-bit microcontroller 32K/1K OTP/ROM/ROMless, 8-channel 8-bit A/D, low voltage (2.7V–5.5V), I<sup>2</sup>C, 2 UARTs, 16MB address range

## **AC WAVEFORMS**



### Figure 8. External Program Memory Read Cycle (ALE Cycle)



Figure 9. External Program Memory Read Cycle (Non-ALE Cycle)





Figure 11. External Data Memory Read Cycle (Non-ALE Cycle)













Figure 15. AC Testing Input/Output











Figure 18. I<sub>DD</sub> Test Condition, Idle Mode All other pins are disconnected

# XA 16-bit microcontroller 32K/1K OTP/ROM/ROMless, 8-channel 8-bit A/D, low voltage (2.7V–5.5V), I<sup>2</sup>C, 2 UARTs, 16MB address range



Figure 19. I<sub>DD</sub> vs. Frequency Valid only within frequency specification of the device under test.







Figure 21. I\_DD Test Condition, Power Down Mode All other pins are disconnected. V\_DD=2V to 5.5V

## **EPROM CHARACTERISTICS**

The XA-S3 is programmed by using a modified Improved Quick-Pulse Programming<sup>™</sup> algorithm. This algorithm is essentially the same as that used by 80C51 family EPROM parts. However different pins are used for many programming functions.

Detailed EPROM programming information may be obtained from the Internet at www.philipsmcu.com/ftp.html.

The XA-S3 contains three signature bytes that can be read and used by an EPROM programming system to identify the device. The signature bytes identify the device as an XA-S3 manufactured by Philips.

## **Security Bits**

With none of the security bits programmed the code in the program memory can be verified. When only security bit 1 is programmed, MOVC instructions executed from external program memory are disabled from fetching code bytes from the internal memory. All further programming of the EPROM is disabled. When security bits 1 and 2 are programmed, in addition to the above, verify mode is disabled. When all three security bits are programmed, all of the conditions above apply and all external program memory execution is disabled. (See Table 4.)

## Table 4. Program Security Bits

| PROGRAM LOCK BITS |     | rs  |     |                                                                                                                                                                      |
|-------------------|-----|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | SB1 | SB2 | SB3 | PROTECTION DESCRIPTION                                                                                                                                               |
| 1                 | U   | U   | U   | No Program Security features enabled.                                                                                                                                |
| 2                 | Р   | U   | U   | MOVC instructions executed from external program memory are disabled from fetching code bytes from internal memory and further programming of the EPROM is disabled. |
| 3                 | Р   | Р   | U   | Same as 2, also verify is disabled.                                                                                                                                  |
| 4                 | Р   | Р   | Р   | Same as 3, external execution is disabled. Internal data RAM is not accessible.                                                                                      |
| NOTES             |     |     |     |                                                                                                                                                                      |

NOTES:

1. P – programmed. U – unprogrammed.

2. Any other combination of the security bits is not defined.

## **ROM CODE SUBMISSION**

When submitting ROM code for the XA-S3, the following must be specified:

1. 32k byte user ROM data

2. ROM security bits.

| ADDRESS        | CONTENT | BIT(S) | COMMENT                                                           |
|----------------|---------|--------|-------------------------------------------------------------------|
| 0000H to 7FFFH | DATA    | 7:0    | User ROM Data                                                     |
| 8020H          | SEC     | 0      | ROM Security Bit 1                                                |
| 8020H          | SEC     | 1      | ROM Security Bit 2<br>0 = enable security<br>1 = disable security |
| 8020H          | SEC     | 3      | ROM Security Bit 3<br>0 = enable security<br>1 = disable security |

<sup>™</sup>Trademark phrase of Intel Corporation.

XA-S3



