## SIEMENS

## Microcomputer Components

8-Bit CM OS M icrocontroller

## C509-L

## SIEMENS

## 8-Bit CMOS Microcontroller

C509-L

## Advance Information

- Full upward compatibility with SAB 80C517/80C517A and 8051/C501 microcontrollers
- 256 byte on-chip RAM
- 3K byte of on-chip XRAM
- 256 directly addressable bits
- 375 ns instruction cycle at $16-\mathrm{MHz}$ oscillator frequency
- On-chip emulation support logic (Enhanced Hooks Technology ${ }^{\text {TM }}$ )
- External program and data memory expandable up to 64 Kbyte each
- 8-bit A/D converter with 15 multiplexed inputs and built-in self calibration
- Two 16 -bit timers/counters (8051 compatible)
- Three 16-bit timers/counters (can be used in combination with the compare/capture unit)
- Powerful compare/capture unit (CCU) with up to 29 high-speed or PWM output channels or 13 capture inputs
- Arithmetic unit for division, multiplication, shift and normalize operations
- Eight datapointers instead of one for indirect addressing of program and external data memory (further features are on next page)


Figure 1

## C509-L Functional Units

Features (continued) :

- Extended watchdog facilities
- 15-bit programmable watchdog timer
- Oscillator watchdog
- Ten I/O ports
- Eight bidirectional 8-bit I/O ports with selectable port structure
quasi-bidirectional port structure (8051 compatible)
bidirectional port structure with CMOS voltage levels
- One 8-bit and one 7-bit input port for analog and digital input signals
- Two full-duplex serial interfaces with own baud rate generators
- Four priority level interrupt systems, 19 interrupt vectors
- Three power saving modes
- Slow-down mode
- Idle mode
- Power-down mode
- Siemens high-performance ACMOS technology
- M-QFP-100-2 rectangular quad flat package
- Temperature Ranges: SAB-C509-L $\quad T_{\mathrm{A}}=0$ to $70^{\circ} \mathrm{C}$

SAF-C509-L $\quad T_{\text {A }}=-40$ to $85^{\circ} \mathrm{C}$

The C509-L is a high-end microcontroller in the Siemens C500 8-bit microcontroller family. It is based on the well-known industry standard 8051 architecture; a great number of enhancements and new peripheral features extend its capabilities to meet the extensive requirements of new applications. Further, the C509-L is a superset of the Siemens SAB 80C517/80C517A 8-bit microcontroller thus offering an easy upgrade path for SAB 80C517/80C517A users.
The high performance of the C509-L microcontroller is achieved by the C500-Core with a maximum operating frequency of 16 MHz internal (and external) CPU clock. While maintaining all the features of the SAB 80C517A, the C509-L is expanded by one I/O port, in its compare/capture capabilities, by A/D converter functions, by additional 1 KByte of on-chip RAM (now 3 KByte XRAM) and by an additional user-selectable CMOS port structure. The C509-L is mounted in a P-MQFP-100-2 package.

## Ordering Information

| Type | Ordering Code | Package | Description <br> (8-Bit CMOS microcontroller) |
| :--- | :--- | :--- | :--- |
| SAB-C509-LM | Q67120-C1045 | P-MQFP-100-2 | for external memory $(16 \mathrm{MHz})$ |
| SAF-C509-LM | Q67120-C0983 | P-MQFP-100-2 | for external memory $(16 \mathrm{MHz})$ <br> ext. temp. $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ |

Note: Versions for extended temperature ranges $-40^{\circ} \mathrm{C}$ to $110^{\circ} \mathrm{C}$ (SAH-C509-L) and $-40^{\circ} \mathrm{C}$ to $125{ }^{\circ} \mathrm{C}$ (SAK-C509-L) are available on request.
$\qquad$


Figure 2
Logic Symbol


Figure 3

## C509-L Pin Configuration (P-MQFP-100-2, Top View)

## Table 1

Pin Definitions and Functions


[^0]Table 1
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | I/O*) | Function |
| :--- | :--- | :--- | :--- |
| P9.0-P9.7 | $74-77$, <br> $5-2$ | I/O | Port 9 <br> is an 8-bit quasi-bidirectional I/O port with internal pullup <br> resistors. Port 9 pins that have 1's written to them are <br> pulled high by the internal pullup resistors, and in that <br> state can be used as inputs. As inputs, port 9 pins being <br> externally pulled low will source current ( $I_{\text {IL }}$ in the DC <br> characteristics) because of the internal pullup resistors. <br> Port 9 can also be switched into a bidirectional mode, in <br> which CMOS levels are provided. In this bidirectional <br> mode, each port 1 pin can be programmed individually <br> as input or output. <br> Port 9 also serves alternate compare functions. The out- <br> put latch corresponding to a secondary function must be <br> programmed to a one (1) for that function to operate. <br> The secondary functions are assigned to the pins of <br> port 9 as follows : <br> P9.0-P9.7 CC10-CC17 Compare/capture channel 0-7 |
| XTAL2 | 12 | - | XTAL2 <br> is the input to the inverting oscillator amplifier and input <br> to the internal clock generator circuits. <br> When supplying the C509-L with an external clock <br> source, XTAL2 should be driven, while XTAL1 is left <br> unconnected. A duty cycle of 0.4 to 0.6 of the clock <br> signal is required. Minimum and maximum high and low <br> times as well as rise/fall times specified in the AC <br> characteristics must be observed. |
| XTAL1 | 13 | - | XTAL1 <br> Output of the inverting oscillator amplifier. This pin is <br> used for the oscillator operation with crystal or ceramic <br> resonartor |

*) I = Input
$\mathrm{O}=$ Output

Table 1
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | 1/0*) | Function |
| :---: | :---: | :---: | :---: |
| P2.0-P2.7 | 14-21 | I/O | Port 2 <br> is a 8-bit I/O port. Port 2 emits the high-order address byte during fetches from external program memory and during accesses to external data memory that use 16-bit addresses (MOVX @DPTR). In this application it uses strong internal pullup resistors when issuing 1s. During accesses to external data memory that use 8-bit addresses (MOVX @Ri), port 2 issues the contents of the P2 special function register. <br> P2.0-P2.7 <br> A8-A15 <br> Address lines 8-15 |
| $\overline{\text { PSEN } / \overline{R D F}}$ | 22 | 0 | $\overline{\text { Program Store Enable / Read FLASH }}$ <br> The PSEN output is a control signal that enables the external program memory to the bus during external code fetch operations. It is activated every third oscillator period. $\overline{\text { PSEN }}$ is not activated during external data memory accesses caused by MOVX instructions. PSEN is not activated when instructions are executed from the internal Boot ROM or from the XRAM. In external programming mode $\overline{\text { RDF becomes active }}$ when executing external data memory read (MOVX) instructions. |
| ALE | 23 | 0 | Address Latch Enable <br> This output is used for latching the low byte of the address into external memory during normal operation. It is activated every third oscillator period except during an external data memory access caused by MOVX instructions. |
| $\overline{\mathrm{EA}}$ | 24 | I | External Access Enable <br> The status of this pin is latched at the end of a reset. When held at low level, the C509-L fetches all instructions from the external program memory. For the C509-L this pin must be tied low. |
| PRGEN | 25 | I | External Flash-EPROM Program Enable <br> A low level at this pin disables the programming of an external Flash-EPROM. To enable the programming of an external Flash-EPROM, the pin PRGEN must be held at high level and bit PRGEN1 in SFR SYSCON1 has to be set. There is no internal pullup resistor connected to this pin. |

[^1]Table 1
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | 1/0*) | Function |
| :---: | :---: | :---: | :---: |
| P0.0-P0.7 | $\begin{aligned} & 26,27, \\ & 30-35 \end{aligned}$ | I/O | Port 0 <br> is an 8 -bit open-drain bidirectional I/O port. Port 0 pins that have 1 s written to them float, and in that state can be used as high-impendance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external program or data memory. In this operating mode it uses strong internal pullup resistors when issuing 1 s . <br> P0.0-P0.7 AD0-AD7 Address/data lines 0-7 |
| $\overline{\text { HWPD }}$ | 36 | I | Hardware Power Down <br> A low level on this pin for the duration of one machine cycle while the oscillator is running resets the C509-L. A low level for a longer period will force the part to power down mode with the pins floating. There is no internal pullup resistor connected to this pin. |
| P5.0-P5.7 | 44-37 | I/O | Port 5 <br> is an 8-bit quasi-bidirectional I/O port with internal pullup resistors. Port 5 pins that have 1's written to them are pulled high by the internal pullup resistors, and in that state can be used as inputs. As inputs, port 5 pins being externally pulled low will source current ( $I_{\mathrm{IL}}$, in the DC characteristics) because of the internal pullup resistors. Port 5 can also be switched into a bidirectional mode, in which CMOS levels are provided. In this bidirectional mode, each port 5 pin can be programmed individually as input or output. <br> Port 5 also serves as alternate function for "Concurrent Compare" and "Set/Reset compare" functions. The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate. The secondary functions are assigned to the pins of port 5 as follows: <br> P5.0-P5.7 CCM0-CCM7 Concurrent Compare or Set/Reset lines 0-7 |

[^2]Table 1
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | I/O*) | Function |
| :---: | :---: | :---: | :---: |
| OWE | 45 | I | Oscillator Watchdog Enable <br> A high level on this pin enables the oscillator watchdog. When left unconnected, this pin is pulled high by a weak internal pullup resistor. The logic level at OWE should not be changed during normal operation. When held at low level the oscillator watchdog function is turned off. During hardware power down the pullup resistor is switched off. |
| P6.0-P6.7 | $\begin{aligned} & 46-50, \\ & 5-56 \end{aligned}$ | I/O | Port 6 <br> is an 8-bit quasi-bidirectional I/O port with internal pullup resistors. Port 6 pins that have 1's written to them are pulled high by the internal pullup resistors, and in that state can be used as inputs. As inputs, port 6 pins being externally pulled low will source current ( $I_{\mathrm{LL}}$, in the DC characteristics) because of the internal pullup resistors. Port 6 can also be switched into a bidirectional mode, in which CMOS levels are provided. In this bidirectional mode, each port 6 pin can be programmed individually as input or output. <br> Port 6 also contains the external A/D converter control pin, the receive and transmission lines for the serial port 1, and the write-FLASH control signal. The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate. The secondary functions are assigned to the pins of port 6 as follows : |
|  | 46 47 48 |  | P6.0 ADST External A/D converter start pin <br> P6.1 R×D1 Receiver data input of serial interface 1 <br> P6.2 T×D1 Transmitter data output of serial interface 1 |
|  | 49 |  | P6.3 $\overline{W R F}$ The $\overline{W R F}$ (write Flash) signal is active when the programming mode is selected. In this mode WRF becomes active when executing external data memory write (MOVX) instructions. |

[^3]Table 1
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | 1/0*) | Function |
| :---: | :---: | :---: | :---: |
| P8.0-P8.6 | $\begin{aligned} & \text { 57-60, } \\ & 51-53 \end{aligned}$ | 1 | Port 8 <br> is a 7-bit unidirectional input port. Port pins can be used for digital input if voltage levels meet the specified input high/low voltages, and for the higher 7-bit of the multiplexed analog inputs of the A/D converter simultaneously. <br> P8.0-P8.6 AIN8-AIN14 Analog input 8-14 |
| $\overline{\mathrm{RO}}$ | 61 | 0 | Reset Output <br> This pin outputs the internally synchronized reset request signal. This signal may be generated by an external hardware reset, a watchdog timer reset or an oscillator watchdog reset. The $\overline{\mathrm{RO}}$ output is active low. |
| P4.0-P4.7 | $\begin{aligned} & 64-66, \\ & 68-72 \end{aligned}$ | I/O | Port 4 <br> is an 8-bit quasi-bidirectional I/O port with internal pull-up resistors. Port 4 pins that have 1's written to them are pulled high by the internal pull-up resistors, and in that state can be used as inputs. As inputs, port 4 pins being externally pulled low will source current ( $I_{\mathrm{IL}}$, in the DC characteristics) because of the internal pull-up resistors. Port 4 also erves as alternate compare functions. The output latch corresponding to a secondary functionmust be programmed to a one (1) for that function to operate. The secondary functions are assigned to the pins of port 4 as follows: <br> P4.0-P4.7 CM0-CM7 Compare channel 0-7 |
| $\overline{\text { PE / SWD }}$ | 67 | 1 | Power Saving Modes Enable / Start Watchdog Timer A low level on this pin allows the software to enter the power down mode, idle and slow down mode. If the low level is also seen during reset, the watchdog timer function is off on default. <br> Usage of the software controlled power saving modes is blocked, when this pin is held on high level. A high level during reset performs an automatic start of the watchdog timer immediately after reset. <br> When left unconnected this pin is pulled high by a weak internal pullup resistor. During hardware power down the pullup resistor is switched off. |

[^4]Table 1
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | I/O*) | Function |
| :--- | :--- | :--- | :--- |
| $\overline{\text { RESET }}$ | 73 | I | $\overline{\text { RESET }}$ <br> A low level on this pin for the duration of one machine <br> cycle while the oscillator is running resets the C509-L. A <br> small internal pullup resistor permits power-on reset <br> using only a capacitor connected to $V_{\text {Ss. }}$ |
| $V_{\text {AREF }}$ | 78 | - | Reference voltage for the A/D converter |
| $V_{\text {AGND }}$ | 79 | - | Reference ground for the A/D converter |
| P7.0-P7.7 | $87-80$ | I | Port 7 <br> Port 7is an 8-bit unidirectional input port. Port pins can <br> be used for digital input if voltage levels meet the <br> specified input high/low voltages, and for the lower 8-bit <br> of the multiplexed analog inputs of the A/D converter <br> simultaneously. <br> P7.0-P7.7 AIN0 - AIN7 Analog input 0-7 |

*) $I=$ Input
$\mathrm{O}=$ Output

Table 1
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | I/O*) | Function |
| :---: | :---: | :---: | :---: |
| P3.0-P3.7 | 90-97 | I/O | Port 3 <br> is an 8-bit quasi-bidirectional I/O port with internal pullup resistors. Port 3 pins that have 1's written to them are pulled high by the internal pullup resistors, and in that state can be used as inputs. As inputs, port 3 pins being externally pulled low will source current ( $I_{\mathrm{LL}}$, in the DC characteristics) because of the internal pullup resistors. Port 3 also contains two external interrupt inputs, the timer 0/1 inputs, the serial port 0 receive/transmit line and the external memory strobe pins. The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate. The secondary functions are assigned to the port pins of port 3 as follows <br> P3.0 R×D0 Receiver data input (asynchronous) or data input/output (synchronous) of serial interface 0 <br> P3.1 T×D0 Transmitter data output (asynchronous) or clock output (synchronous) of the serial interface 0 <br> P3.2 $\overline{\mathrm{INTO}}$ <br> P3.3 INT1 <br> P3.4 T0 <br> P3.5 T1 <br> P3.6 $\overline{\mathrm{WR}}$ The write control signal latches the data byte from port 0 into the external data memory <br> P3.7 $\overline{\mathrm{RD}} / \mathrm{The}$ read control signal enables the external data memory to port 0 <br> PSENX PSENX (external program store enable) enables the external code memory when the external / internal XRAM mode or external / internal programming mode is selected. |
|  | 90 |  |  |
|  | 91 |  |  |
|  | 92 |  |  |
|  | 93 |  |  |
|  | 94 |  |  |
|  | 95 |  |  |
|  | 96 |  |  |
|  | 97 |  |  |
| $V_{\text {SS }}$ | 10, 28, 62, 88 | - | Circuit ground potential |
| $V_{\text {CC }}$ | 11, 29, 63, 89 | - | Supply terminal for all operating modes |
| ${ }^{*}$ ) $\mathrm{I}=$ Input |  |  |  |



Figure 4

## Block Diagram of the C509-L

## CPU

The C509-L is efficient both as a controller and as an arithmetic processor. It has extensive facilities for binary and BCD arithmetic and excels in its bit-handling capabilities. Efficient use of program memory results from an instruction set consisting of $44 \%$ one-byte, $41 \%$ two-byte, and $15 \%$ threebyte instructions. With a 6 MHz crystal, $58 \%$ of the instructions are executed in $1.0 \mu \mathrm{~s}(12 \mathrm{MHz}: 500$ $\mathrm{ns}, 16 \mathrm{MHz}$ : 375 ns ).

Special Function Register PSW (Address $\mathrm{DO}_{\mathbf{H}}$ )
Reset Value : $\mathbf{0 0}_{\mathrm{H}}$

Bit No. MSB LSB


| Bit | Function |  |  |
| :---: | :---: | :---: | :---: |
| CY | Carry Flag Used by arithmetic instruction. |  |  |
| AC | Auxiliary Carry Flag <br> Used by instructions which execute BCD operations. |  |  |
| F0 | General Purpose Flag |  |  |
| $\begin{aligned} & \text { RS1 } \\ & \text { RS0 } \end{aligned}$ | Register Bank select control bits These bits are used to select one of the four register banks. |  |  |
|  | RS1 | RSO | Function |
|  | 0 | 0 | Bank 0 selected, data address $00{ }_{H}{ }^{-07} \mathrm{H}$ |
|  | 0 | 1 | Bank 1 selected, data address $08{ }_{H}-0 \mathrm{~F}_{\mathrm{H}}$ |
|  | 1 | 0 | Bank 2 selected, data address $10{ }^{-17} \mathrm{H}$ |
|  | 1 | 1 | Bank 3 selected, data address $18 \mathrm{H}^{-1 \mathrm{~F}_{\mathrm{H}}}$ |
| OV | Overflow Flag <br> Used by arithmetic instruction. |  |  |
| F1 | General Purpose Flag |  |  |
| P | Parity Flag <br> Set/cleared by hardware after each instruction to indicate an odd/even number of "one" bits in the accumulator, i.e. even parity. |  |  |

## Memory Organization

The C509-L CPU manipulates data and operands in the following five address spaces:

- up to 64 Kbyte of external program memory
- up to 64 Kbyte of external data memory
- 512 byte of internal Boot ROM (program memory)
- 256 bytes of internal data memory
- 3 Kbyte of external XRAM data memory
- a 128 byte special function register area

Figure 5 illustrates the memory address spaces of the C509-L.


Figure 5

## C509-L Memory Map

The C509-L can operate in four different operating modes (chipmodes) with different program and data memory organizations :

- Normal Mode
- XRAM Mode
- Bootstrap Mode
- Programming Mode

Table 2 describes the program and data memory areas which are available in the different chipmodes of the C509-L. It also shows the control bits of SFR SYSCON1, which are used for the software selection of the chipmodes. Figures 6 to 9 shows the four chipmode configurations with the code and data memory partitioning.

Table 2
Overview of Program and Data Memory Organization

| Operating Mode (Chipmode) | Program Memory |  | Data Memory |  | SYSCON1 Bits |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Ext. | Int. | Ext. | Int. | $\begin{aligned} & \text { PRGEN } \\ & 1 \end{aligned}$ | SWAP |
| Normal Mode | $\begin{aligned} & \mathrm{OOOO}_{\mathrm{H}}- \\ & \mathrm{FFFF}_{\mathrm{H}} \end{aligned}$ | - | $\begin{aligned} & 0000_{\mathrm{H}} \\ & \mathrm{~F}_{3} \mathrm{FF}_{\mathrm{H}} \end{aligned}$ | $\begin{aligned} & \mathrm{F}^{200_{\mathrm{H}}-} \\ & \mathrm{FFFF}_{\mathrm{H}} \\ & (\text { XRAM } \end{aligned}$ | 0 | 0 |
| XRAM Mode | $\begin{aligned} & 0200_{\mathrm{H}} \\ & \mathrm{~F}_{\mathrm{F} \mathrm{FF}_{\mathrm{H}}} \end{aligned}$ | $\begin{aligned} & \text { 0000 }_{\mathrm{H}}{ }^{-} \\ & \text {01FF }_{\mathrm{H}}= \\ & \text { Boot ROM; }^{2} \\ & \text { F400 }_{\mathrm{H}}{ }^{-} \\ & \text {FFFF }_{\mathrm{H}}= \\ & (\text { (RAM }) \end{aligned}$ | $\begin{aligned} & 0000_{\mathrm{H}}- \\ & \mathrm{FFFF}_{\mathrm{H}} \\ & \text { (read only) } \end{aligned}$ | - | 0 | 1 |
| Bootstrap Mode | $\begin{aligned} & 0^{0200_{H}}- \\ & {\mathrm{F} 3 \mathrm{FF}_{\mathrm{H}}}^{-} \end{aligned}$ | $\begin{aligned} & 0000_{\mathrm{H}}- \\ & 01 \mathrm{FF} \mathrm{H}_{\mathrm{H}}= \\ & \text { Boot ROM } \end{aligned}$ | $\begin{aligned} & 0000_{\mathrm{H}} \\ & \mathrm{~F}_{3} \mathrm{FF}_{\mathrm{H}} \end{aligned}$ | $\begin{aligned} & \mathrm{F}^{200} \mathrm{H}^{-} \\ & \text {FFFFH }_{\mathrm{H}} \\ & (\text { XRAM } \end{aligned}$ | 1 | 0 |
| Programming Mode | $\begin{aligned} & 0200_{\mathrm{H}}- \\ & \mathrm{FFFF}_{\mathrm{H}} \end{aligned}$ | $\begin{aligned} & \text { 0000 }{ }^{-} \\ & 01 \mathrm{FF}_{\mathrm{H}}= \\ & \text { Boot ROM; }^{\text {ROM }} \\ & \text { F400 }_{\mathrm{H}}{ }^{-} \\ & \text {FFFF }_{\mathrm{H}}= \\ & \text { XRAM } \end{aligned}$ | $0000_{\mathrm{H}}-$ <br> $\mathrm{FFFF}_{\mathrm{H}}$ <br> (read and write) | - | 1 | 1 |

## Normal Mode Configuration

The Normal Mode is the standard 8051 compatible operating mode of the C509-L. In this mode 64 K byte external code memory and 61 K byte external SRAM as well as 3 K byte internal data memory (XRAM) are provided. If the is disabled (default after reset), totally 64K byte external data memory are available. The Boot ROM is disabled. The external program memory is controlled by the PSEN/ $\overline{R D F}$ signal. Read and write accesses to the external data memory are controlled by the $\overline{R D}$ and $\overline{W R}$ pins of port 3.


Figure 6
Locations of Code- and Data Memory in Normal Mode

## XRAM Mode Configuration

The XRAM Mode is implemented in the C509-L for executing e.g. up to 3K byte diagnostic software which has been loaded into the XRAM in the Bootstrap Mode via the serial interface. In this operating mode the Boot ROM, the XRAM, and the external data memory are mapped into the code memory area, while the external ROM/EPROM is mapped into the external data memory area. External program memory fetches from the SRAM are controlled by the P3.7//RD/ $\overline{\mathrm{PSENX}}$ pin. External data memory read accesses from the ROM/EPROM are controlled by the $\overline{P S E N} / \overline{R D F}$ pin. In XRAM mode, the external data memory can only be read but not written.


Figure 7
Locations of Code- and Data Memory in XRAM Mode

## Bootstrap Mode Configuration

In the Bootstrap Mode the Boot ROM and the external FLASH/ROM/EPROM are mapped into the code memory area. 61K byte external SRAM as well as 3 K byte internal data memory (XRAM) are provided in the external data memory area. The external program memory is controlled by the $\overline{\mathrm{PSEN}} / \overline{\mathrm{RDF}}$ signal. Read and write accesses to the external data memory are controlled by the $\overline{\mathrm{RD}}$ and $\overline{W R}$ pins of port 3 .


Figure 8
Locations of Code- and Data Memory in Bootstrap Mode

## Programming Mode Configuration

The External Programming Mode is implemented for the in-circuit programming of external 5V-only FLASH EPROMs. Similar as in the XRAM mode, the Boot ROM, the XRAM, and the external data memory (SRAM) are mapped into the code memory area, while the external FLASH memory is mapped into the external data memory area. Additionally to the XRAM mode, the FLASH memory can also be written through external data memory accesses (MOVX instructions). External program memory fetches from the SRAM are controlled by the P3.7/信/ $\overline{\text { PSENX pin. External data memory }}$ read/write accesses from/to the ROM/EPROM are controlled by the $\overline{P S E N} / \overline{R D F}$ and P6.3/ $\overline{W R F}$ pin.


Figure 9

## Locations of Code- and Data Memory in Programming Mode

## The Bootstrap Loader

The C509-L includes a bootstrap mode, which is activated by setting the PRGEN pin at logic high level at the rising edge of the RESET or the HWPD signal (bit PRGEN1=1). In this mode software routines of the bootstrap loader, located at the addresses $0000_{H}$ to $01 \mathrm{FF}_{\mathrm{H}}$ in the boot ROM will be executed. Its purpose is to allow the easy and quick programming of the internal XRAM ( $\mathrm{F} 400_{\mathrm{H}}$ to FFFFFH $_{H}$ ) via serial interface while the MCU is in-circuit. This allows to transfer custom routines to the XRAM, which will program an external 64 KByte FLASH memory. The serial routines of the bootstrap loader may be replaced by own custom software or even can be blocked to prevent unauthorized persons from reading out or writing to the external FLASH memory. Therefore the bootstrap loader checks an external FLASH memory for existing custom software and executes it.

The bootstrap loader consists of three functional parts which represent the three phases as described below.

Phase I : Check for existing custom software in the external FLASH memory and execute it.
Phase II : Establish a serial connection and automatically synchronize to the transfer speed (baud rate) of the serial communication partner (host).
Phase III: Perform the serial communication to the host. The host controls the bootstrap loader by sending header informations, which select one of four operating modes. These modes are :
 This mode returns to the beginning of phase III.
Mode 1: Execute a custom program in the XRAM at any start address from $\mathrm{F} 400_{\mathrm{H}}$ to $\mathrm{FFFF}_{\mathrm{H}}$.
Mode 2: Check the contents of any area of the external FLASH memory by calculating a checksum. This mode returns to the beginning of phase III.
Mode 3: Execute a custom program in the FLASH memory at any start address beyond $0200_{\mathrm{H}}$ (at addresses $0000_{\mathrm{H}}$ to $01 \mathrm{FF}_{\mathrm{H}}$ the boot-ROM is active).
The three phases of the bootstrap loader program and their connections are illustrated in figure 10.


Figure 10

## The Three Phases of the Bootstrap Loader

The serial communication, which is activated in phase II is performed with the integrated serial interface 0 of the C509-L. Using a full- or half-duplex serial cable (RS232) the MCU must be connected to the serial port of the host computer as shown in figure .


Figure 11
Bootstrap Loader Interface to the PC

## Control of XRAM Access

The XRAM in the C509-L is a memory area that is logically located at the upper end of the external memory space, but is integrated on the chip. Because the XRAM is used in the same way as external data memory the same instruction types (MOVX) must be used for accessing the XRAM. Two bits in SFR SYSCON, XMAPO and XMAP1, control the accesses to the XRAM.

Special Function Register SYSCON (Address B1H) Reset Value : 1010XX01B


The functions of the shaded bits are not used for XRAM control.

| Bit | Function |
| :---: | :---: |
| XMAP1 | XRAM visible access control <br> Control bit for $\overline{R D} / \overline{W R}$ signals during XRAMaccesses. If addresses are outside the XRAM address range or if XRAM is disabled, this bit has no effect. <br> XMAP1 $=0$ : The signals $\overline{R D}$ and $\overline{W R}$ are not activated during accesses to the XRAM <br> XMAP1 $=1$ : Ports 0,2 and the signals $\overline{R D}$ and $\overline{W R}$ are activated during accesses to XRAM. In this mode, address and data information during XRAM/CAN Controller accesses are visible externally. |
| XMAPO | Global XRAM access enable/disable control <br> XMAPO $=0$ : The access to XRAM is enabled. <br> XMAPO $=1:$ The access to XRAM is disabled (default after reset!). All MOVX accesses are performed via the external bus. Further, this bit is hardware protected. |

Bit XMAP0 is hardware protected. If it is reset once (XRAM access enabled) it cannot be set by software. Only a reset operation will set the XMAP0 bit again.

The XRAM can be accessed by read/write instructions (MOVX A,DPTR, MOVX @DPTR,A), which use the 16 -bit DPTR for indirect addressing. For accessing the XRAM, the effective address stored in DPTR must be in the range of $\mathrm{F} 700_{\mathrm{H}}$ to $\mathrm{FFFF}_{\mathrm{H}} \cdot 38$
The XRAM can be also accessed by read/write instructions (MOVX A,@Ri, MOVX @Ri,A), which use only an 8 -bit address (indirect addressing with registers R0 or R1). Therefore, a special page register XPAGE which provides the upper address information (A8-A15) during 8-bit XRAM accesses.

The behaviour of Port 0 and P2 during a MOVX access depends on the control bits XMAP0 and XMAP1 in register SYSCON and on the state of pin EA. Table 3 lists the various operating conditions.

|  |  | $\overline{E A}=0$ |  |  | $\overline{E A}=1$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | XMAP1, XMAP0 |  |  | XMAP1, XMAP0 |  |  |
|  |  | 00 | 10 | X1 | 00 | 10 | X1 |
| MOVX <br> @DPTR | DPTR < XRAM address range | a) $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow$ Bus <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory is used | a) $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow \mathrm{Bus}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory is used | a) $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow$ Bus <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory is used | a) $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow$ Bus <br> b) $\overline{R D} / \overline{W R}$ active <br> c)ext.memory is used | a) $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow$ Bus <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory is used | a) $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow$ Bus <br> b) $\overline{R D} / \overline{W R}$ active <br> c)ext.memory is used |
|  | DPTR $\geq$ <br> XRAM <br> address range | a) $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow$ Bus ( $\overline{\mathrm{WR}} / \overline{\mathrm{RD}}$ Data) b) $\overline{R D} / \overline{W R}$ inactive c) XRAM is used | a) $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow$ Bus ( $\overline{\mathrm{WR}} / \overline{\mathrm{RD}}$ Data) b) $\overline{R D} / \overline{W R}$ active c) XRAM is used | a) $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow$ Bus <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory is used | a) $\mathrm{PO} / \mathrm{P} 2 \rightarrow \mathrm{I} / 0$ <br> b) $\overline{R D} / \overline{W R}$ <br> inactive <br> c)XRAM is used | a)P0/P2 $\rightarrow$ Bus ( $\overline{W R} / \overline{R D}$ Data) b) $\overline{R D} / \overline{W R}$ active <br> c) XRAM is used | a) $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow$ Bus <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory is used |
| MOVX <br> @ Ri | XPAGE <br> < <br> XRAM <br> addr.page range | a) $\mathrm{PO} \rightarrow$ Bus $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory is used | a) $\mathrm{P} 0 \rightarrow$ Bus <br> P2 $\rightarrow$ I/O <br> b) $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ active <br> c) ext.memory <br> is used | a)P0 $\rightarrow$ Bus <br> $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory <br> is used | a) P0 $\rightarrow$ Bus $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory is used | a) $\mathrm{P} 0 \rightarrow$ Bus <br> P2 $\rightarrow$ I/O <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory <br> is used | a) P0 $\rightarrow$ Bus <br> P2 $\rightarrow$ I/O <br> b) $\overline{R D} / \overline{W R}$ active <br> c)ext.memory <br> is used |
|  | XPAGE $\geq$ <br> XRAM <br> addr.page range | a) P0 $\rightarrow$ Bus <br> ( $\overline{\mathrm{WR}} / \overline{\mathrm{RD}}$ Data) $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{R D} / \overline{W R}$ <br> inactive <br> c) XRAM is used | a)P0 $\rightarrow$ Bus <br> ( $\mathrm{WR} / \overline{R D}$ Data) $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c)XRAM is used | a)P0 $\rightarrow$ Bus $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c)ext.memory is used | a) $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{R D} / \overline{W R}$ <br> inactive <br> c)XRAM is used | a)P0 $\rightarrow$ Bus <br> ( $\mathrm{WR} / \overline{R D}$ Data) $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c) XRAM is used | a) PO $\rightarrow$ Bus $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c)ext.memory is used |

## Reset and System Clock

The reset input is an active low input at pin RESET. Since the reset is synchronized internally, the RESET pin must be held low for at least two machine cycles (12 oscillator periods) while the oscillator is running. A pullup resistor is internally connected to $V_{\mathrm{CC}}$ to allow a power-up reset with an external capacitor only. An automatic reset can be obtained when $V_{\mathrm{CC}}$ is applied by connecting the reset pin to $V_{\mathrm{Ss}}$ via a capacitor. Figure 12 shows the possible reset circuitries.


Figure 12

## Reset Circuitries

Figure 13 shows the recommended oscillator circiutries for crystal and external clock operation.


Figure 13
Recommended Oscillator Circuitries

## Multiple Datapointers

As a functional enhancement to the standard 8051 architecture, the C509-L contains eight 16-bit datapointers instead of only one datapointer. The instruction set uses just one of these datapointers at a time. The selection of the actual datapointer is done in the special function regsiter DPSEL. Figure 14 illustrates the datapointer addressing mechanism.


Figure 14

## External Data Memory Addressing using Multiple Datapointers

## Enhanced Hooks Emulation Concept

The Enhanced Hooks Emulation Concept of the C500 microcontroller family is a new, innovative way to control the execution of C500 MCUs and to gain extensive information on the internal operation of the controllers. Emulation of on-chip ROM based programs is possible, too (not true for the C509-L, because it lacks internal program memory).
Each production chip has built-in logic for the supprt of the Enhanced Hooks Emulation Concept. Therefore, no costly bond-out chips are necessary for emulation. This also ensure that emulation and production chips are identical.
The Enhanced Hooks Technology ${ }^{\top}$, which requires embedded logic in the C500 allows the C500 together with an EH-IC to function similar to a bond-out chip. This simplifies the design and reduces costs of an ICE-system. ICE-systems using an EH-IC and a compatible C500 are able to emulate all operating modes of the different versions of the C500 microcontrollers. This includes emulation of ROM, ROM with code rollover and ROMless modes of operation. It is also able to operate in single step mode and to read the SFRs after a break.


Figure 15

## Basic C500 MCU Enhanced Hooks Concept Configuration

Port 0, port 2 and some of the control lines of the C500 based MCU are used by Enhanced Hooks Emulation Concept to control the operation of the device during emulation and to transfer informations about the programm execution and data transfer between the external emulation hardware (ICE-system) and the C500 MCU.

## Special Function Registers

All registers, except the program counter and the four general purpose register banks, reside in the special function register area. Several special function registers of the C509-L (CC10-17, CT1REL, CC1EN, CAFR) are located in the mapped special function register area. For accessing the mapped special function register area, bit RMAP in special function register SYSCON must be set. All other special function registers are located in the standard special function register area. As long as bit RMAP is set, mapped special function registers can be accessed. This bit is not cleared by hardware automatically.

Special Function Register SYSCON (Address B1H)
Reset Value : 1010XX01B


| Bit | Function |
| :--- | :--- |
| RMAP | Special function register map bit <br> RMAP $=0:$The access to the non-mapped (standard) special function <br> register area is enabled (reset value). <br> RMAP $=1:$The access to the mapped special function register area is <br> enabled. |

The 103 special function register (SFR) include pointers and registers that provide an interface between the CPU and the other on-chip peripherals. The SFRs of the C509-L are listed in table 4 and table 5. In table 4 they are organized in groups which refer to the functional blocks of the C509L. Table 5 illustrates the contents of the SFRs in numeric order of their addresses. The most right column of table 5 indicates if an SFR is accessed with a mapped procedure controlled by either RMAP or PDIR.

Table 4
Special Function Registers - Functional Blocks

| Block | Symbol | Name | Address | Contents after Reset |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CPU}}$ | ACC <br> B <br> DPH <br> DPL <br> DPSEL <br> PSW <br> SP <br> SYSCON1 | Accumulator <br> B-Register <br> Data Pointer, High Byte <br> Data Pointer, Low Byte <br> Data Pointer Select Register <br> Program Status Word <br> Stack Pointer <br> System Control Register 1 |  |  |
| SFR <br> Mapping | SYSCON ${ }^{2}$ | System Control Register | H | 10XX01 ${ }^{3)}$ |
| Interrupt System | IENO <br> CTCON ${ }^{2)}$ CT1CON ${ }^{2)}$ IEN1 ${ }^{2)}$ <br> IEN2 ${ }^{2)}$ <br> IEN3 <br> IP0 ${ }^{2)}$ <br> IP1 ${ }^{\text {2) }}$ <br> IRCONO <br> IRCON1 <br> IRCON2 ${ }^{4)}$ <br> EICC1 ${ }^{4)}$ <br> TCON ${ }^{2)}$ <br> T2CON ${ }^{2)}$ | Interrupt Enable Register 0 Compare Timer Control Register Compare Timer 1 Control Register Interrupt Enable Register 1 Interrupt Enable Register 2 Interrupt Enable Register 3 Interrupt Priority Register 0 Interrupt Priority Register 1 Interrupt Request Control Register 0 Interrupt Request Control Register 1 Interrupt Request Control Register 2 Interrupt Request Enable Register for CT1 Timer Control Register Timer 2 Control Register |  |  |
| XRAM | XPAGE <br> SYSCON ${ }^{2)}$ | Page Address Register for XRAM System Control Register | $\begin{array}{\|l\|} \hline 91_{\mathrm{H}} \\ \mathrm{~B} 1_{\mathrm{H}} \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline 00 \mathrm{H} \\ 1010 \mathrm{XX01} \mathrm{~B}^{3)} \\ \hline \end{array}$ |
| A/D Converter | ADCONO <br> ADCON1 <br> ADDATH <br> ADDATL | A/D Converter Control Register 0 <br> A/D Converter Control Register 1 <br> A/D Converter Data Register, High Byte <br> A/D Converter Data Register, Low Byte | $\begin{aligned} & \mathbf{D 8}_{\mathbf{H}}{ }^{1)} \\ & \text { DC }_{\mathrm{H}} \\ & \text { D9 }{ }_{H} \\ & \text { DA }_{H} \end{aligned}$ | $\begin{aligned} & \mathbf{0 0} \mathbf{H}_{\mathbf{H}} \\ & 01000000_{\mathrm{B}}{ }^{3)} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \end{aligned}$ |

1) Bit-addressable special function registers
2) This special function register is listed repeatedly since some bits of it also belong to other functional blocks.
3) $X$ means that the value is indeterminate or the location is reserved
4) Register is mapped by bit PDIR.
5) Register is mapped by bit RMAP.
6) "E" means that the value of the bit is defined by the logic level at pin PRGEN at the rising edge of the $\overline{\text { RESET }}$ or HWPD signals.

Table 4
Special Function Registers - Functional Blocks (cont'd)

| Block | Symbol | Name | Address | Contents after Reset |
| :---: | :---: | :---: | :---: | :---: |
| Compare / | CCEN | Compare/Capture Enable Register | $\mathrm{C1}_{\mathrm{H}}$ | ${ }^{00} \mathrm{H}$ |
| Capture | CC4EN | Compare/Capture 4 Enable Register | $\mathrm{C}^{\mathrm{H}}$ | $0^{00} \mathrm{H}$ |
| Unit (CCU) | CCH 1 | Compare/Capture Register 1, High Byte | $\mathrm{C3}_{\mathrm{H}}$ | $0^{00} \mathrm{H}$ |
| Timer 2 | CCH 2 | Compare/Capture Register 2, High Byte | $\mathrm{C}_{5} \mathrm{H}$ | ${ }^{00} \mathrm{H}$ |
|  | CCH3 | Compare/Capture Register 3, High Byte | $\mathrm{C7}_{\mathrm{H}}$ | $0^{00} \mathrm{H}$ |
|  | CCH4 | Compare/Capture Register 4, High Byte | $\mathrm{CFH}_{\mathrm{H}}$ | ${ }^{00} \mathrm{H}$ |
|  | CCL1 | Compare/Capture Register 1, Low Byte | $\mathrm{C} 2^{2} \mathrm{H}$ | ${ }^{00} \mathrm{H}$ |
|  | CCL2 | Compare/Capture Register 2, Low Byte | $\mathrm{C}_{4} \mathrm{H}$ | $0^{00} \mathrm{H}$ |
|  | CCL3 | Compare/Capture Register 3, Low Byte | $\mathrm{C}^{\mathrm{H}} \mathrm{H}$ | ${ }^{00} \mathrm{H}$ |
|  | CCL4 | Compare/Capture Register 4, Low Byte | $\mathrm{CE}_{\mathrm{H}}$ | $0^{00} \mathrm{H}$ |
|  | CMEN ${ }^{5}$ | Compare Enable Register | ${ }^{\mathrm{F} 6} \mathrm{H}$ | ${ }^{00} \mathrm{H}$ |
|  | CMHO ${ }^{5}$ | Compare Register 0, High Byte | D3 ${ }^{\text {H }}$ | $0^{00} \mathrm{H}$ |
|  | CMH1 ${ }^{5}$ | Compare Register 1, High Byte | D5 ${ }^{\text {H }}$ | ${ }^{00} \mathrm{H}$ |
|  | CMH2 ${ }^{5}$ | Compare Register 2, High Byte | D7H | $0^{00} \mathrm{H}$ |
|  | CMH3 ${ }^{5}$ | Compare Register 3, High Byte | $\mathrm{E3}_{\mathrm{H}}$ | $0^{00} \mathrm{H}$ |
|  | CMH4 ${ }^{\text {5 }}$ | Compare Register 4, High Byte | $\mathrm{E5}_{\mathrm{H}}$ | ${ }^{00} \mathrm{H}$ |
|  | CMH5 5) | Compare Register 5, High Byte | $\mathrm{E7}_{\mathrm{H}}$ | ${ }^{00} \mathrm{H}$ |
|  | CMH6 ${ }^{5}$ | Compare Register 6, High Byte | $\mathrm{F}_{3} \mathrm{H}$ | $0^{00} \mathrm{H}$ |
|  | CMH7 ${ }^{5}$ | Compare Register 7, High Byte | $\mathrm{F}^{\mathrm{H}} \mathrm{H}$ | $0^{00} \mathrm{H}$ |
|  | CMLO ${ }^{5}$ | Compare Register 0, Low Byte | D2H | $0^{00} \mathrm{H}$ |
|  | CML1 ${ }^{5}$ | Compare Register 1, Low Byte | D4 H | ${ }^{00} \mathrm{H}$ |
|  | CML2 ${ }^{5}$ | Compare Register 2, Low Byte | $\mathrm{D}^{6} \mathrm{H}$ | ${ }^{00} \mathrm{H}$ |
|  | CML3 ${ }^{5}$ | Compare Register 3, Low Byte | E2H | $0^{00} \mathrm{H}$ |
|  | CML4 ${ }^{5}$ | Compare Register 4, Low Byte | $\mathrm{E4}^{4} \mathrm{H}$ | $0^{00} \mathrm{H}$ |
|  | CML5 ${ }^{5}$ | Compare Register 5, Low Byte | $\mathrm{E}^{\text {H }}$ | $0^{00} \mathrm{H}$ |
|  | CML6 ${ }^{5}$ | Compare Register 6, Low Byte | $\mathrm{F}^{2} \mathrm{H}$ | ${ }^{00} \mathrm{H}$ |
|  | CML7 ${ }^{\text {5 }}$ | Compare Register 7, Low Byte | $\mathrm{F}^{4} \mathrm{H}$ | $0^{00} \mathrm{H}$ |
|  | CC1EN ${ }^{5}$ | Compare/Capture Enable Register | $\mathrm{F}^{\mathrm{H}} \mathrm{H}$ | ${ }^{00} \mathrm{H}$ |
|  | CC1H0 ${ }^{5}$ | Compare/Capture 1 Register 0, High Byte | $\mathrm{D}_{\mathrm{H}}$ | $0^{00} \mathrm{H}$ |
|  | $\mathrm{CC1H1}{ }^{5}$ | Compare/Capture 1 Register 1, High Byte | $\mathrm{D}^{\text {H }}$ | $0^{00} \mathrm{H}$ |
|  | $\mathrm{CC} 1 \mathrm{H}^{5}{ }^{5}$ | Compare/Capture 1 Register 2, High Byte | ${ }^{\text {D7 }} \mathrm{H}$ | ${ }^{00} \mathrm{H}$ |
|  | CC1H3 ${ }^{5}$ | Compare/Capture 1 Register 3, High Byte | $\mathrm{E3}_{\mathrm{H}}$ | $0^{00} \mathrm{H}$ |
|  | CC1H4 ${ }^{5}$ | Compare/Capture 1 Register 4, High Byte | E5 H | ${ }^{00} \mathrm{H}$ |
|  | CC1H5 ${ }^{5}$ | Compare/Capture 1 Register 5, High Byte | ${ }^{\text {E7 }} \mathrm{H}$ | $0^{00} \mathrm{H}$ |
|  | CC1H6 ${ }^{5}$ | Compare/Capture 1 Register 6, High Byte | $\mathrm{F}^{\mathrm{H}} \mathrm{H}$ | $0^{00} \mathrm{H}$ |
|  | CC1H7 ${ }^{5}$ | Compare/Capture 1 Register 7, High Byte | $\mathrm{F}^{5} \mathrm{H}$ | ${ }^{00} \mathrm{H}$ |
|  | CC1L0 ${ }^{5}$ | Compare/Capture 1 Register 0, Low Byte | ${ }^{\text {D2 }} \mathrm{H}$ | $0^{00} \mathrm{H}$ |
|  | CC1L1 ${ }^{5}$ | Compare/Capture 1 Register 1, Low Byte | D4H | ${ }^{00} \mathrm{H}$ |
|  | CC1L2 ${ }^{5}$ | Compare/Capture 1 Register 2, Low Byte | D6H | $0^{00} \mathrm{H}$ |
|  | CC1L3 ${ }^{5}$ | Compare/Capture 1 Register 3, Low Byte | E2H | $0^{00} \mathrm{H}$ |
|  | CC1L4 ${ }^{5}$ | Compare/Capture 1 Register 4, Low Byte | ${ }^{\text {E4 }} \mathrm{H}$ | $0^{00} \mathrm{H}$ |
|  | CC1L5 ${ }^{5}$ | Compare/Capture 1 Register 5, Low Byte | $\mathrm{E}^{\mathrm{H}} \mathrm{H}$ | $0^{00} \mathrm{H}$ |
|  | CC1L6 ${ }^{5}$ | Compare/Capture 1 Register 6, Low Byte | $\mathrm{F}^{2} \mathrm{H}$ | $0^{00} \mathrm{H}$ |
|  | CC1L7 ${ }^{5}$ | Compare/Capture 1 Register 7, Low Byte | ${ }^{\mathrm{F}} \mathrm{H}_{\mathrm{H}}$ | ${ }^{00} \mathrm{H}$ |
|  | CMSEL ${ }^{\text {) }}$ | Compare Input Select | ${ }^{\mathrm{F}} \mathrm{H}_{\mathrm{H}}$ | ${ }^{00} \mathrm{H}$ |

[^5]Table 4
Special Function Registers - Functional Blocks (cont'd)

| Block | Symbol | Name | Address | Contents after Reset |
| :---: | :---: | :---: | :---: | :---: |
| Compare / <br> Capture <br> Unit (CCU) <br> Timer 2 cont'd | CAFR ${ }^{5}$ <br> CRCH <br> CRCL <br> COMSETL <br> COMSETH <br> COMCLRL <br> COMCLRH <br> SETMSK <br> CLRMSK <br> CTCON ${ }^{2)}$ <br> CTRELH ${ }^{5)}$ <br> CTRELL ${ }^{5)}$ <br> CT1RELH ${ }^{5}$ <br> CT1RELL ${ }^{5)}$ <br> TH2 <br> TL2 <br> T2CON ${ }^{2)}$ <br> CT1CON ${ }^{2)}$ <br> PRSC ${ }^{2)}$ | Capture 1, Falling/Rising Edge Register Comp./Rel./Capt. Reg. High Byte Comp./Rel./Capt. Reg. Low Byte Compare Set Register, Low Byte Compare Set Register, High Byte Compare Clear Register, Low Byte Compare Clear Register, High Byte Compare Set Mask Register Compare Clear Mask Register Compare Timer Control Register Compare Timer Rel. Reg., High Byte Compare Timer Rel. Reg., Low Byte Compare Timer 1 Rel. Reg., High Byte Compare Timer 1 Rel. Reg., Low Byte Timer 2, High Byte <br> Timer 2, Low Byte <br> Timer 2 Control Register <br> Compare Timer 1 Control Register Prescaler Control Register | ${ }^{F 7}{ }_{H}$ <br> $\mathrm{CB}_{\mathrm{H}}$ <br> $\mathrm{CA}_{\mathrm{H}}$ <br> ${ }^{\mathrm{A} 1} \mathrm{H}$ <br> $\mathrm{A}^{2} \mathrm{H}$ <br> $\mathrm{A}^{\mathrm{A}} \mathrm{H}$ <br> ${ }^{A 4} \mathrm{H}$ <br> ${ }^{A 5} \mathrm{H}$ <br> ${ }^{A 6} \mathrm{H}$ <br> ${ }^{\mathrm{E} 1} \mathrm{H}$ <br> $\mathrm{DF}_{\mathrm{H}}$ <br> $\mathrm{DE}_{\mathrm{H}}$ <br> $\mathrm{DF}_{\mathrm{H}}$ <br> $\mathrm{DE}_{\mathrm{H}}$ <br> $\mathrm{CD}_{\mathrm{H}}$ <br> $\mathrm{CC}_{\mathrm{H}}$ <br> $\mathrm{CB}_{\mathrm{H}}{ }^{1)}$ <br> $\mathrm{BC}_{\mathrm{H}}$ <br> ${ }^{B 4} 4$ | ${ }^{00} \mathrm{H}$ <br> $0^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> $0^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> $01000000{ }^{\text {B }}{ }^{3}$ ) <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> X1XX0000 $B^{3)}$ <br> $11010101_{B}{ }^{3)}$ |
| Serial Channels | $\begin{aligned} & \text { ADCONO }{ }^{2)} \\ & \text { PCON }{ }^{2)} \\ & \text { SOBUF } \\ & \text { SOCON } \\ & \text { SORELL } \\ & \text { SORELH } \\ & \text { S1BUF } \\ & \text { S1CON } \\ & \text { S1RELL } \\ & \text { S1RELH } \end{aligned}$ | A/D Converter Control Register <br> Power Control Register <br> Serial Channel 0 Buffer Register <br> Serial Channel 0 Control Register <br> Serial Channel 0 Reload Reg., Low Byte <br> Serial Channel 0 Reload Reg., High Byte <br> Serial Channel 1 Buffer Register <br> Serial Channel 1 Control Register <br> Serial Channel 1 Reload Reg., Low Byte <br> Serial Channel 1 Reload Reg., High Byte | D8 $H_{H}{ }^{1)}$ $87_{H}$ $99_{H}{ }^{1}$ $98_{H}{ }^{1)}$ $A A_{H}$ $B A_{H}$ $9 C_{H}$ $9 B_{H}$ $9 D_{H}$ $B B_{H}$ |  |
| Watchdog | IENO ${ }^{2)}$ <br> IEN1 ${ }^{2)}$ <br> IPO ${ }^{2)}$ <br> IP1 ${ }^{\text {2) }}$ <br> WDTREL <br> WDTL ${ }^{6)}$ <br> WDTH ${ }^{6}$ | Interrupt Enable Register 0 Interrupt Enable Register 1 Interrupt Priority Register 0 Interrupt Priority Register 1 Watchdog Timer Reload Register Watchdog Timer Register, Low Byte Watchdog Timer Register, High Byte |  | $\begin{aligned} & 00_{\mathrm{H}} \\ & \mathbf{0 0}_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & \left.0 \mathrm{XO}^{2} 0000_{\mathrm{B}}{ }^{3}\right) \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & \hline \end{aligned}$ |

[^6]Table 4
Special Function Registers - Functional Blocks (cont'd)

| Block | Symbol | Name | Address | Contents after Reset |
| :---: | :---: | :---: | :---: | :---: |
| MUL/DIV Unit | ARCON <br> MDO <br> MD1 <br> MD2 <br> MD3 <br> MD4 <br> MD5 | Arithmetic Control Register Multiplication/Division Register 0 Multiplication/Division Register 1 Multiplication/Division Register 2 Multiplication/Division Register 3 Multiplication/Division Register 4 Multiplication/Division Register 5 | $E F_{H}$ <br> $\mathrm{E9}_{\mathrm{H}}$ <br> $E A_{H}$ <br> $\mathrm{EBH}_{\mathrm{H}}$ <br> $\mathrm{EC}_{\mathrm{H}}$ <br> $E D_{H}$ <br> $\mathrm{EE}_{\mathrm{H}}$ |  |
| Timer 0 / <br> Timer 1 | $\begin{aligned} & \text { TCON } \\ & \text { TH0 } \\ & \text { TH1 } \\ & \text { TL0 } \\ & \text { TL1 } \\ & \text { TMOD } \\ & \text { PRSC }{ }^{2)} \end{aligned}$ | Timer Control Register Timer 0, High Byte <br> Timer 1, High Byte <br> Timer 0, Low Byte <br> Timer 1, Low Byte <br> Timer Mode Register Prescaler Control Register | $\begin{aligned} & 88_{H}{ }^{1)} \\ & 8 \mathrm{C}_{\mathrm{H}} \\ & 8 \mathrm{D}_{\mathrm{H}} \\ & 8 \mathrm{~A}_{\mathrm{H}} \\ & 8 \mathrm{~B}_{\mathrm{H}} \\ & 89_{\mathrm{H}} \\ & \mathrm{~B} 4_{\mathrm{H}} \end{aligned}$ | $\begin{aligned} & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 11010101_{\mathrm{B}}{ }^{3)} \end{aligned}$ |
| Ports | PO ${ }^{4}$ <br> DIRO ${ }^{4)}$ <br> P1 ${ }^{4)}$ <br> DIR1 ${ }^{4)}$ <br> P2 ${ }^{4)}$ <br> DIR2 ${ }^{4)}$ <br> P3 ${ }^{4}$ <br> DIR3 ${ }^{4)}$ <br> P4 ${ }^{4}$ <br> DIR4 ${ }^{4)}$ <br> P5 ${ }^{4)}$ <br> DIR5 ${ }^{4)}$ <br> P6 ${ }^{4}$ <br> DIR6 ${ }^{4)}$ <br> P7 <br> P8 <br> P9 4) <br> DIR9 ${ }^{4)}$ | Port 0 <br> Direction Register Port 0 <br> Port 1 <br> Direction Register Port 1 <br> Port 2 <br> Direction Register Port 2 <br> Port 3 <br> Direction Register Port 3 <br> Port 4 <br> Direction Register Port 4 <br> Port 5 <br> Direction Register Port 5 <br> Port 6 <br> Direction Register Port 6 <br> Port 7, Analog/Digital Input <br> Port 8, Analog/Digital Input <br> Port 9 <br> Direction Register Port 9 | ${ }^{80} \mathrm{H}$ <br> ${ }^{80} \mathrm{H}$ <br> ${ }^{90} \mathrm{H}$ <br> ${ }^{90} \mathrm{H}$ <br> $\mathrm{AO}_{\mathrm{H}}$ <br> ${ }^{A 0} \mathbf{H}$ <br> $\mathrm{BO}_{\mathrm{H}}$ <br> $\mathrm{BO}_{\mathrm{H}}$ <br> ${ }^{E} 8_{H}{ }^{1}$ <br> E8H <br> ${ }^{\text {F8H }}$ <br> ${ }^{\mathrm{F}} \mathrm{B}_{\mathrm{H}}$ <br> $\mathrm{FA}_{\mathrm{H}}$ <br> $\mathrm{FA}_{\mathrm{H}}$ <br> $\mathrm{DB}_{\mathrm{H}}$ <br> $\mathrm{DD}_{\mathrm{H}}$ <br> ${ }^{\mathrm{F} 9} \mathrm{H}$ <br> ${ }^{\mathrm{F} 9} \mathrm{H}$ | $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> ${ }^{\mathrm{FF}} \mathrm{H}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> -- <br> -- <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ |
| Power Saving Modes | PCON | Power Control Register | ${ }^{87} \mathrm{H}$ | ${ }^{00} \mathrm{H}$ |

[^7]Table 5
Contents of the SFRs, SFRs in numeric order of their addresses

| Addr | Register | Content after Reset ${ }^{1)}$ | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Mapped by ${ }^{2)}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{80} \mathrm{H}$ | P0 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | PDIR=0 |
| $88^{80}$ | DIR0 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | PDIR=1 |
| ${ }^{81} \mathrm{H}$ | SP | ${ }^{07} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{82} \mathrm{H}$ | DPL | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{83} \mathrm{H}$ | DPH | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{84} \mathrm{H}$ | WDTL | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{85} \mathrm{H}$ | WDTH | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{86} \mathrm{H}$ | WDTREL | ${ }^{00} \mathrm{H}$ | WPSEL | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{87} \mathrm{H}$ | PCON | ${ }^{00} \mathrm{H}$ | SMOD | PDS | IDLS | SD | GF1 | GF0 | PDE | IDLE | - |
| ${ }^{88} \mathrm{H}$ | TCON | $0^{00} \mathrm{H}$ | TF1 | TR1 | TFO | TR0 | IE1 | IT1 | IE0 | ITO | - |
| ${ }^{89} \mathrm{H}$ | TMOD | $0^{00} \mathrm{H}$ | GATE | C/T | M1 | M0 | GATE | C/T | M1 | M0 | - |
| $8 \mathrm{~A}_{\mathrm{H}}$ | TLO | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $8_{8 \mathrm{~B}}$ | TL1 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $8 \mathrm{CH}_{\mathrm{H}}$ | TH0 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $8 \mathrm{D}_{\mathrm{H}}$ | TH1 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $90^{\text {H }}$ | P1 | $\mathrm{FF}_{\mathrm{H}}$ | T2 | $\begin{aligned} & \text { CLK- } \\ & \text { OUT } \end{aligned}$ | T2EX | $\overline{\text { INT2 }}$ | INT6 | INT5 | INT4 | INT3 | $\mathrm{PDIR}=0$ |
| $90^{\text {H }}$ | DIR1 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | PDIR=1 |
| ${ }^{91} \mathrm{H}$ | XPAGE | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| 92 H | DPSEL | $\begin{aligned} & \mathrm{XXXX} . \\ & \mathrm{X000} \mathrm{~B} \end{aligned}$ | - | - | - | - | - | . 2 | . 1 | . 0 | - |
| 98H | SOCON | $0^{0} \mathrm{H}$ | SM0 | SM1 | SM20 | REN0 | TB80 | RB80 | TIO | RIO | - |
| ${ }^{99} \mathrm{H}$ | SOBUF | XX ${ }_{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $9 A_{H}$ | IEN2 | $\begin{aligned} & \mathrm{XX00} . \\ & 00 \mathrm{X} 0_{\mathrm{B}} \end{aligned}$ | - | - | ECR | ECS | ECT | ECMP | - | ES1 | - |
| ${ }^{9 B} \mathrm{H}$ | S1CON | $\begin{aligned} & 0100 . \\ & 0000_{\mathrm{B}} \end{aligned}$ | SM | S1P | SM21 | REN1 | TB81 | RB81 | TI1 | RI1 | - |
| $9 \mathrm{C}_{\mathrm{H}}$ | S1BUF | XX ${ }_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\underline{9 D_{H}}$ | S1RELL | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\xrightarrow{\text { A0 }} \mathrm{H}$ | P2 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | PDIR=0 |
| ${ }^{\mathrm{A} 0_{\mathrm{H}}}$ | DIR2 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | PDIR=1 |
| ${ }^{\text {A1 }} \mathrm{H}$ | COMSETL | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |

1) $X$ means that the value is indeterminate or the location is reserved.
2) SFRs with a comment in this column are mapped registers.

Shaded registers are bit-addressable special function registers.

Table 5
Contents of the SFRs, SFRs in numeric order of their addresses (cont'd)

| Addr | Register | Content after Reset ${ }^{1)}$ | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Mapped by ${ }^{2)}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {A2 }} \mathrm{H}$ | COMSETH | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{\text {A3 }} \mathrm{H}$ | COMCLRL | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{\text {A }}{ }^{\text {H }}$ | COMCLRH | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{\text {A5 }} \mathrm{H}$ | SETMSK | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{\text {A6 }} \mathrm{H}$ | CLRMSK | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{A8H}_{\mathrm{H}}$ | IEN0 | ${ }^{00} \mathrm{H}$ | EAL | WDT | ET2 | ES0 | ET1 | EX1 | ETO | EXO | - |
| $\mathrm{A9H}_{\mathrm{H}}$ | IP0 | ${ }^{00} \mathrm{H}$ | OWDS | WDTS | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{AA}_{\mathrm{H}}$ | SORELL | D9 ${ }_{\text {H }}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{\text {B0H }}$ | P3 | $\mathrm{FF}_{\mathrm{H}}$ | RD | WR | T1 | T0 | INT1 | INT0 | TxD0 | RxD0 | PDIR=0 |
| $\mathrm{B0}_{\mathrm{H}}$ | DIR3 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | PDIR=1 |
| ${ }^{\mathrm{B} 1} \mathrm{H}$ | SYSCON | $\begin{aligned} & 1010 . \\ & \mathrm{XX01} \end{aligned}$ | CLKP | PMOD | 1 | RMAP | - | - | XMAP1 | XMAPO | - |
| $\mathrm{B}^{2} \mathrm{H}$ | SYSCON1 <br> 3) | $\begin{aligned} & \text { OOXX. } \\ & \text { XEEOB }^{2} \end{aligned}$ | ESWC | SWC | - | EA1 | EAO | PRGEN1 | PRGEN0 | SWAP | - |
| ${ }^{B 4} \mathrm{H}$ | PRSC | $\begin{aligned} & 1101 . \\ & 0101_{\mathrm{B}} \\ & \hline \end{aligned}$ | WDTP | SOP | T2P1 | T2P0 | T1P1 | T1P0 | T0P1 | TOPO | - |
| $\mathrm{B8}_{\mathrm{H}}$ | IEN1 | $0^{00} \mathrm{H}$ | EXEN2 | SWDT | EX6 | EX5 | EX4 | EX3 | EX2 | EADC | - |
| B9H | IP1 | $\begin{aligned} & 0 \times 00 . \\ & 0000_{\mathrm{B}} \end{aligned}$ | PDIR | - | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{BA}_{\mathrm{H}}$ | SORELH | $\begin{aligned} & \mathrm{XXXX} \\ & \mathrm{XX11} \\ & \hline \end{aligned}$ | - | - | - | - | - | - | . 1 | . 0 | - |
| $\mathrm{BB}_{\mathrm{H}}$ | S1RELH | $\begin{aligned} & \mathrm{XXXX} \\ & \mathrm{XX11} \end{aligned}$ | - | - | - | - | - | - | . 1 | . 0 | - |
| $\overline{B C}_{H}$ | CT1CON | $\begin{aligned} & \mathrm{X} 1 \mathrm{XX} \\ & 0000_{\mathrm{B}} \end{aligned}$ | - | CT1P | - | - | CT1F | CLK12 | CLK11 | CLK10 | - |
| $\mathrm{BE}_{\mathrm{H}}$ | IEN3 | $\begin{aligned} & \mathrm{XXXX} \\ & 00 X X_{B} \end{aligned}$ | - | - | - | - | ECT1 | ECC1 | - | - | - |
| $\mathrm{BF}_{\mathrm{H}}$ | IRCON2 | $0^{00} \mathrm{H}$ | ICC17 | ICC16 | ICC15 | ICC14 | ICC13 | ICC12 | ICC11 | ICC10 | PDIR=0 |
| $\mathrm{BF}_{\mathrm{H}}$ | EICC1 | $\mathrm{FF}_{\mathrm{H}}$ | EICC17 | EICC16 | EICC15 | EICC14 | EICC13 | EICC12 | EICC11 | EICC10 | PDIR=1 |
| ${ }^{\mathrm{C} 0} \mathrm{H}$ | IRCON0 | ${ }^{00} \mathrm{H}$ | EXF2 | TF2 | IEX6 | IEX5 | IEX4 | IEX3 | IEX2 | IADC | - |
| $\mathrm{C} 1_{\mathrm{H}}$ | CCEN | $0^{00} \mathrm{H}$ | COCAH3 | COCAL3 | COCAH2 | COCAL2 | COCAH1 | COCAL1 | COCAH0 | COCALO | - |

1) $X$ means that the value is indeterminate or the location is reserved.
2) SFRs with a comment in this column are mapped registers.
3) "E" means that the value of the bit is defined by the logic level at pin PRGEN at the rising edge of the RESET or HWPD signals.
Shaded registers are bit-addressable special function registers.

Table 5
Contents of the SFRs, SFRs in numeric order of their addresses (cont'd)

| Addr | Register | Content after Reset ${ }^{1)}$ | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Mapped by ${ }^{2)}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\mathrm{C} 2 \mathrm{H}}$ | CCL1 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{\mathrm{C} 3 \mathrm{H}}$ | CCH1 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{\mathrm{C} 4} \mathrm{H}^{\text {H}}$ | CCL2 | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{\mathrm{C} 5 \mathrm{H}}$ | CCH 2 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{C6}_{\mathrm{H}}$ | CCL3 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{C}^{\mathrm{C}} \mathrm{H}$ | CCH3 | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{C8}_{\mathrm{H}}$ | T2CON | $0^{00} \mathrm{H}$ | T2PS | I3FR | I2FR | T2R1 | T2R0 | T2CM | T2l1 | T210 | - |
| $\mathrm{C9}_{\mathrm{H}}$ | CC4EN | ${ }^{00} \mathrm{H}$ | $\begin{gathered} \text { COCO } \\ \text { EN1 } \end{gathered}$ | $\begin{gathered} \text { COCO } \\ \text { N2 } \\ \hline \end{gathered}$ | $\begin{gathered} \mathrm{COCO} \\ \mathrm{~N} 1 \\ \hline \end{gathered}$ | $\begin{gathered} \text { COCO } \\ \text { NO } \\ \hline \end{gathered}$ | $\begin{gathered} \text { COCO } \\ \text { ENO } \end{gathered}$ | $\begin{aligned} & \text { COCAH } \\ & 4 \end{aligned}$ | $\begin{array}{\|l} \text { COCAL } \\ 4 \end{array}$ | COM0 | - |
| $\mathrm{CA}_{\mathrm{H}}$ | CRCL | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{CB}_{\mathrm{H}}$ | CRCH | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{CCH}_{\mathrm{H}}$ | TL2 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{CD}_{\mathrm{H}}$ | TH2 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{CE}_{\mathrm{H}}$ | CCL4 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{CF}_{\mathrm{H}}$ | CCH 4 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{\text {D0 }} \mathrm{H}$ | PSW | ${ }^{00} \mathrm{H}$ | CY | AC | F0 | RS1 | RS0 | OV | F1 | P | - |
| ${ }^{\text {D1 }} \mathrm{H}$ | IRCON1 | ${ }^{00} \mathrm{H}$ | ICMP7 | ICMP6 | ICMP5 | ICMP4 | ICMP3 | ICMP2 | ICMP1 | ICMP0 | - |
| ${ }^{\mathrm{D} 2 \mathrm{H}}$ | CMLO | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| ${ }^{\mathrm{D} 2 \mathrm{H}}$ | CC1L0 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| ${ }^{\text {D3 }} \mathrm{H}$ | CMHO | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| ${ }^{\text {D3 }} \mathrm{H}$ | CC1H0 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| ${ }^{\text {D4 }} \mathrm{H}$ | CML1 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| ${ }^{\text {D4 }} \mathrm{H}$ | CC1L1 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| ${ }^{\text {D5 H }}$ | CMH1 | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| ${ }^{\text {D5 }} \mathrm{H}$ | CC1H1 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| $\mathrm{D6H}_{\mathrm{H}}$ | CML2 | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| ${ }^{\text {D6 }} \mathrm{H}$ | CC1L2 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| $\mathrm{D7H}^{\text {¢ }}$ | CMH2 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| ${ }^{\text {D7 H }}$ | CC1H2 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| $\mathrm{D8H}_{\mathrm{H}}$ | ADCONO | ${ }^{00} \mathrm{H}$ | BD | CLK | ADEX | BSY | ADM | MX2 | MX1 | MX0 | - |
| $\mathrm{D}^{\mathrm{H}}$ | ADDATH | ${ }^{00} \mathrm{H}$ | $\begin{aligned} & .7 \\ & \text { (MSB) } \end{aligned}$ | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |

1) $X$ means that the value is indeterminate or the location is reserved.
2) SFRs with a comment in this column are mapped registers.

Shaded registers are bit-addressable special function registers.

Table 5
Contents of the SFRs, SFRs in numeric order of their addresses (cont'd)

| Addr | Register | Content after Reset ${ }^{1)}$ | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Mapped by ${ }^{2)}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{DA}_{\mathrm{H}}$ | ADDATL | ${ }^{00} \mathrm{H}$ | . 7 | $\begin{aligned} & .6 \\ & (\mathrm{LSB}) \end{aligned}$ | - | - | - | - | - | - | - |
| $\mathrm{DB}_{\mathrm{H}}$ | P7 | - | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{DCH}_{\mathrm{H}}$ | ADCON1 | $\begin{aligned} & 0100 . \\ & 0000_{\mathrm{B}} \end{aligned}$ | ADCL1 | ADCL0 | ADST1 | ADST0 | MX3 | MX2 | MX1 | MXO | - |
| $\mathrm{DD}_{\mathrm{H}}$ | P8 | - | - | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{DE}_{\mathrm{H}}$ | CTRELL | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| $\mathrm{DE}_{\mathrm{H}}$ | CT1RELL | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| $\mathrm{DF}_{\mathrm{H}}$ | CTRELH | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| $\mathrm{DF}_{\mathrm{H}}$ | CT1RELH | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| $\mathrm{EOH}_{\mathrm{H}}$ | ACC | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{\text {E1 }} \mathrm{H}$ | CTCON | $\begin{aligned} & 0100 . \\ & 0000_{\mathrm{B}} \end{aligned}$ | T2PS1 | CTP | ICR | ICS | CTF | CLK2 | CLK1 | CLK0 | - |
| E2H | CML3 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| E2H | CC1L3 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| $\mathrm{E}^{\text {3H }}$ | CMH3 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| ${ }^{\text {E3H }}$ | CC1H3 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| ${ }^{\text {E4 }} \mathrm{H}$ | CML4 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| ${ }^{\text {E4 }} \mathrm{H}$ | CC1L4 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| ${ }^{\text {E5 H }}$ | CMH4 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| ${ }^{\text {E5 H }}$ | CC1H4 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| E6H | CML5 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| E6H | CC1L5 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| ${ }^{\text {E7 }} \mathrm{H}$ | CMH5 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| ${ }^{\text {E7 }} \mathrm{H}$ | CC1H5 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| E8H | P4 | $\mathrm{FF}_{\mathrm{H}}$ | CM7 | CM6 | CM5 | CM4 | CM3 | CM2 | CM1 | CMO | PDIR=0 |
| E8H | DIR4 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | PDIR=1 |
| E9H | MD0 | XX ${ }_{\text {H }}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{EA}_{\mathrm{H}}$ | MD1 | $X X_{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{EB}_{\mathrm{H}}$ | MD2 | $X^{\prime}{ }_{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{ECH}_{\mathrm{H}}$ | MD3 | $\mathrm{XX}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{ED}_{\mathrm{H}}$ | MD4 | XX ${ }_{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |

1) $X$ means that the value is indeterminate or the location is reserved.
2) SFRs with a comment in this column are mapped registers.

Shaded registers are bit-addressable special function registers.

Table 5
Contents of the SFRs, SFRs in numeric order of their addresses (cont'd)

| Addr | Register | Content after Reset ${ }^{1)}$ | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Mapped by ${ }^{2)}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{EE}_{\mathrm{H}}$ | MD5 | $\mathrm{XX}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| $\mathrm{EF}_{\mathrm{H}}$ | ARCON | $\begin{aligned} & 0 X X X . \\ & X X X X_{B} \end{aligned}$ | MDEF | MDOV | SLR | SC. 4 | SC. 3 | SC. 2 | SC. 1 | SC. 0 | - |
| ${ }^{\mathrm{F} 0} \mathrm{H}$ | B | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | - |
| ${ }^{\mathrm{F} 2 \mathrm{H}}$ | CML6 | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| ${ }^{\mathrm{F} 2 \mathrm{H}}$ | CC1L6 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| $\mathrm{F}^{\text {H }} \mathrm{H}$ | CMH6 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP=0 |
| ${ }^{\mathrm{F} 3} \mathrm{H}$ | CC1H6 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| ${ }^{\mathrm{F} 4} \mathrm{H}$ | CML7 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP=0 |
| ${ }^{\mathrm{F} 4} \mathrm{H}$ | CC1L7 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| ${ }^{\text {F5 }} \mathrm{H}$ | CMH7 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| ${ }^{\text {F5 H }}$ | CC1H7 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| ${ }^{\text {F6 }} \mathrm{H}$ | CMEN | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| ${ }^{\text {F6 }} \mathrm{H}$ | CC1EN | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=1$ |
| ${ }^{\mathrm{F}} \mathrm{H}_{\mathrm{H}}$ | CMSEL | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP $=0$ |
| ${ }^{\mathrm{F}} \mathrm{H}_{\mathrm{H}}$ | CAFR | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | RMAP=1 |
| ${ }^{\mathrm{F} 8_{\mathrm{H}}}$ | P5 | $\mathrm{FF}_{\mathrm{H}}$ | CCM7 | CCM6 | CCM5 | CCM4 | CCM3 | CCM2 | CCM1 | CCM0 | PDIR=0 |
| ${ }^{\mathrm{F} 8_{\mathrm{H}}}$ | DIR5 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | PDIR=1 |
| $\mathrm{F9}_{\mathrm{H}}$ | P9 | $\mathrm{FF}_{\mathrm{H}}$ | CC17 | CC16 | CC15 | CC14 | CC13 | CC12 | CC11 | CC10 | PDIR=0 |
| $\mathrm{F9}_{\mathrm{H}}$ | DIR9 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | PDIR=1 |
| $\mathrm{FA}_{\mathrm{H}}$ | P6 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6. | . 5 | . 4 | . 3 | TxD1 | RxD1 | $\overline{\text { ADST }}$ | PDIR=0 |
| $\mathrm{FA}_{\mathrm{H}}$ | DIR6 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 | PDIR=1 |

1) $X$ means that the value is indeterminate or the location is reserved.
2) SFRs with a comment in this column are mapped registers. Shaded registers are bit-addressable special function registers.

## Digital I/O Ports

The C509-L allows for digital I/O on 64 lines grouped into 8 bidirectional 8 -bit ports. Each port bit consists of a latch, an output driver and an input buffer. Read and write accesses to the I/O ports P0 through P6 and P9 are performed via their corresponding special function registers P0 to P6 and P9. The port structure of the C509-L is designed to operate either as a quasi-bidirectional port structure, compatible to the standard 8051-Family, or as a genuine bidirectional port structure. This port operating mode can be selected by software (setting or clearing the bit PMOD in the SFR SYSCON).
The output drivers of port 0 and 2 and the input buffers of port 0 are also used for accessing external memory. In this application, port 0 outputs the low byte of the external memory address, timemultiplexed with the byte being written or read. Port 2 outputs the high byte of the external memory address when the address is 16 bits wide. Otherwise, the port 2 pins continue emitting the P2 SFR contents.

## Analog Input Ports

Ports 7 and 8 are available as input ports only and provide for two functions. When used as digital inputs, the corresponding SFR's P7 and P8 contain the digital value applied to port 7 and port 8 lines. When used for analog inputs the desired analog channel is selected by a three-bit field in SFR ADCON0 or a four-bit field in SFR ADCON1. Of course, it makes no sense to output a value to these input-only ports by writing to the SFR's P7 or P8; this will have no effect.
If a digital value is to be read, the voltage levels are to be held within the input voltage specifications ( $V_{\mathrm{IL}} / V_{\mathrm{IH}}$ ). Since P 7 and P 8 are not bit-addressable registers, all input lines of P 7 or P 8 are read at the same time by byte instructions.
Nevertheless, it is possible to use ports 7 and 8 simultaneously for analog and digital input. However, care must be taken that all bits of P7 or P8 that have an undetermined value caused by their analog function are masked.

## Port Structure Selection

After a reset operation of the C509-L, the quasi-bidirectional 8051-compatible port structure is selected. For selection of the bidirectional port structure (CMOS) the bit PMOD of SFR SYSCON must be set. Because each port pin can be programmed as an input or an output, additionally, after the selection of the bidirectional mode the direction register of the ports must be written (except the analog/digital input ports 7,8 ). This direction registers are mapped to the port registers. This means, the port register address is equal to its direction register address. Figure 16 illustrates the port- and direction register configuration.


Figure 16

## Port Register, Direction Register

For the access the direction registers a double instruction sequence must be executed. The first instruction has to set bit PDIR in SFR IP1. Thereafter, a second instruction can read or write the direction registers. PDIR will automatically be cleared after the second machine cycle (S2P2) after having been set. For this time, the access to the direction register is enabled and the register can be read or written. Further, the double instruction sequence as shown in figure 16, cannot be interrupted by an interrupt,
When the bidirectional port structure is activated (bit PMOD in SFR SYSCON =1) after a reset, the ports are defined as inputs (direction registers default values after reset are set to $\mathrm{FF}_{\mathrm{H}}$ ).
With PMOD = 0 (quasi-bidirectional port structure selected), any access to the direction registers has no effect on the port driver circuitries.

## Timer / Counter 0 and 1

Timer/Counter 0 and 1 can be used in four operating modes as listed in table 6 :

## Table 6

Timer/Counter 0 and 1 Operating Modes

| Mode | Description | TMOD |  | Input Clock |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | M1 | M0 | internal | external (max) |
| 0 | 8-bit timer/counter with a divide-by-32 prescaler | 0 | 0 | $\begin{gathered} f_{\text {osd }} / 6 \times 32 \text { up to } \\ f_{\text {osd }} / 48 \times 32 \end{gathered}$ | $f_{\text {osd }} / 12 \times 32$ |
| 1 | 16-bit timer/counter | 0 | 1 | $\begin{gathered} f_{\text {osc }} / 6 \text { up to } f_{\text {osc }} / \\ 48 \end{gathered}$ | $f_{\text {osc }} / 12$ |
| 2 | 8-bit timer/counter with 8-bit autoreload | 1 | 0 |  |  |
| 3 | Timer/counter 0 used as one 8 -bit timer/counter and one 8-bit timer Timer 1 stops | 1 | 1 |  |  |

In the "timer" function ( $\mathrm{C} / \overline{\mathrm{T}}=$ ' 0 ') the register is incremented by a count rate of $f_{\text {osc }} / 6$ up to $f_{\text {osc }} / 32$.
In the "counter" function the register is incremented in response to a 1-to-0 transition at its corresponding external input pin (P3.4/T0, P3.5/T1). Since it takes two machine cycles to detect a falling edge the max. count rate is $f_{\text {osd }} / 12$. External inputs INT0 and INT1 (P3.2, P3.3) can be programmed to function as a gate to facilitate pulse width measurements. Figure 17 illustrates the input clock logic of timer 0/1.


Figure 17

## Timer/Counter 0 and 1 Input Clock Logic

## Compare / Capture Unit (CCU)

The compare/capture unit can be used in all kinds of digital signal generation and event capturing like pulse generation, pulse width modulation, pulse width measuring etc. The CCU consists of three 16 -bit timer/counters and an array of several compare or compare/capture registers. A set of control registers is used for flexible adapting of the CCU to a wide variety of applications.


Figure 18
Block Diagram of the CCU

The block diagram in figure 18 shows the general configuration of the CCU. All CC1 to CC4 registers and the CRC register are exclusively assigned to timer 2. Each of the eight compare registers CM0 through CM7 can either be assigned to timer 2 or to the faster compare timer, e.g. to provide up to 8 PWM output channels. The assignment of the CMx registers - which can be done individually for every single register - is combined with an automatic selection of one of the two possible compare modes. The compare/capture registers CC10 to CC17 and the reload register CT1REL are assigned to compare timer 1 and are mapped to the corresponding registers of the compare timer.

The compare function and the reaction of the corresponding outputs depend on the timer/compare register combination. Table 7 shows the possible configurations of the CCU and the corresponding compare modes which can be selected. The following sections describe the function of these configurations.

Table 7
CCU Configurations

| Assigned Timer | Compare Register | Compare Output at | Possible Modes |
| :---: | :---: | :---: | :---: |
| Timer 2 | CRCH/CRCL <br> CCH1/CCL1 <br> CCH2/CCL2 <br> CCH3/CCL3 <br> CCH4/CCL4 | P1.0/INT3/CC0 <br> P1.1/INT4/CC1 <br> P1.2/INT5/CC2 <br> P1.3/INT6/CC3 <br> P1.4/INT2/CC4 | Compare mode 0, 1 + Reload Compare mode 0, 1 / capture Compare mode 0, 1 / capture Compare mode 0, 1 / capture Compare mode 0, 1 / capture) |
|  | CCH4/CCL4 | $\begin{aligned} & \text { P1.4//INT2/CC4 } \\ & \text { P5.0/CCM0 } \\ & \text { to } \\ & \text { P5.7/CCM7 } \end{aligned}$ | Compare mode 1 "Concurrent compare" |
|  | $\begin{gathered} \text { CMHO/CMLO } \\ \text { to } \\ \text { CMH7/CML7 } \end{gathered}$ | $\begin{gathered} \text { P4.0/CM0 } \\ \text { to } \\ \text { P4.7/CM7 } \end{gathered}$ | Compare mode 0 |
|  | COMSET COMCLR | $\begin{gathered} \text { P5.0/CCM0 } \\ \text { to } \\ \text { P5.7/CCM7 } \end{gathered}$ | Compare mode 2 |
| Compare Timer | $\begin{aligned} & \text { CMHO/CMLO } \\ & \text { to } \\ & \text { CMH7/CML7 } \end{aligned}$ | $\begin{aligned} & \text { P4.0/CM0 } \\ & \text { to } \\ & \text { P4.7/CM7 } \end{aligned}$ | Compare mode 1 |
| Compare Timer 1 | $\begin{aligned} & \mathrm{CC} 1 \mathrm{H} 0 / \mathrm{CC} 1 \mathrm{LO} \\ & \text { to } \\ & \text { CC1H7/CC1L7 } \end{aligned}$ | $\begin{gathered} \text { P5.0/CCM0 } \\ \text { to } \\ \text { P5.7/CCM7 } \end{gathered}$ | Compare mode 0 / capture |

## Timer 2 Operation

Gated Timer Mode : In gated timer function, the external input pin P1.7/T2 operates as a gate to the input of timer 2. If T 2 is high, the internal clock input is gated to the timer. $\mathrm{T} 2=0$ stops the counting procedure. The external gate signal is sampled once every machine cycle.
Event Counter Mode : In the event counter function, the timer 2 is incremented in response to a 1 -to-0 transition at its corresponding external input pin P1.7/T2. In this function, the external input is sampled every machine cycle. The maximum count rate is $1 / 12$ of the oscillator frequency.

## Reload of Timer 2: Two reload modes are selectable:

In mode 0, when timer 2 rolls over from all 1's to all 0's, it not only sets TF2 but also causes the timer 2 registers to be loaded with the 16-bit value in the CRC register, which is preset by software.
In mode 1, a 16-bit reload from the CRC register is caused by a negative transition at the corresponding input pin P1.5/T2EX.


Figure 19

## Block Diagram of Timer 2

## Compare Timer Operation

The compare timers receive its input clock from a programmable prescaler which provides input frequencies, ranging from $f_{\text {osc }}$ up to $f_{\text {osd }} / 256$. The compare timers are, once started, free-running 16-bit timers, which on overflow are automatically reloaded by the contents of the 16 -bit reload registers. The compare timers have - as any other timer in the C509-L - their own interrupt request flags CTF and CT1F. These flags are set when the timer count rolls over from all ones to the reload value. Figure 20 shows the block diagram of compare timer and compare timer 1.

Compare Timer Configuration


Compare Timer 1 Configuration


Figure 20
Compare Timer and Compare Timer 1 Block Diagram

## Compare Modes

The compare function of a timer/register combination operates as follows. the 16-bit value stored in a compare or compare/capture register is compared with the contents of the timer register. If the count value in the timer register matches the stored value, an appropriate output signal is generated at a corresponding port pin. Several timer/compare register combinations are selectable (see table 7). In these configurations three cdifferent ompare modes are selectable.

## Compare Mode 0

In compare mode 0 , upon matching the timer and compare register contents, the output signal changes from low to high. It goes back to a low level on timer overflow. As long as compare mode 0 is enabled, the appropriate output pin is controlled by the timer circuit only and writing to the port will have no effect. Figure 21 shows a functional diagram of a port circuit when used in compare mode 0 . The port latch is directly controlled by the timer overflow and compare match signals. The input line from the internal bus and the write-to-latch line of the port latch are disconnected when compare mode 0 is enabled.


Figure 21

## Port Latch in Compare Mode 0

## Compare Mode 1

Ilf compare mode 1 is enabled (can only be selected for compare registers assigned to timer 2) and the software writes to the appropriate output latch at the port, the new value will not appear at the output pin until the next compare match occurs. Thus, it can be choosen whether the output signal has to make a new transition (1-to-0 or 0-to-1, depending on the actual pin-level) or should keep its old value at the time when the timer value matches the stored compare value.

In compare mode 1 (see figure 22) the port circuit consists of two separate latches. One latch (which acts as a "shadow latch") can be written under software control, but its value will only be transferred to the port latch (and thus to the port pin) when a compare match occurs.


Figure 22

## Compare Function in Compare Mode 1

## Compare Mode 2

In the compare mode 2 the port 5 pins are under control of compare/capture register CC 4 , but under control of the compare registers COMSET and COMCLR. When a compare match occurs with register COMSET, a high level appears at the pins of port 5 when the corresponding bits in the mask register SETMSK are set. When a compare match occurs with register COMCLR, a low level appears at the pins of port 5 when the corresponding bits in the mask register CLRMSK are set.


Figure 23

## Compare Function of Compare Mode 2

## Multiplication / Division Unit (MDU)

This on-chip arithmetic unit of the C509-L provides fast 32-bit division, 16 -bit multiplication as well as shift and normalize features. All operations are unsigned integer operations. Table 8 describes the five general operations the MDU is able to perform.

## Table 8 <br> MDU Operation Characteristics

| Operation | Result | Remainder | Execution Time |
| :--- | :--- | :--- | :--- |
| 32bit/16bit | 32 bit | 16 bit | $6 t_{\mathrm{CY}}{ }^{1)}$ |
| 16bit/16bit | 16 bit | 16 bit | $4 t_{\mathrm{CY}}{ }^{1)}$ |
| 16bit x 16bit | 32 bit | - | $4 t_{\mathrm{CY}}{ }^{1)}$ |
| 32-bit normalize | - | - | $6 t_{\mathrm{tY}}{ }^{2)}$ |
| 32-bit shift L/R | - | - | $6 t_{\mathrm{CY}}{ }^{2)}$ |

1) $1 t_{\mathrm{CY}}=6 \cdot \mathrm{CLP}=1$ machine cycle $=375 \mathrm{~ns}$ at $16-\mathrm{MHz}$ oscillator frequency
2) The maximal shift speed is 6 shifts per machine cycle

The MDU consists of seven special function registers (MDO-MD5, ARCON) which are used as operand, result, and control registers. The three operation phases are shown in figure 24.


Figure 24

## Operating Phases of the MDU

For starting an operation, registers MDO to MD5 and ARCON must be written to in a certain sequence according table 8 and 9 . The order the registers are accessed determines the type of the operation. A shift operation is started by a final write operation to SFR ARCON.

## Table 9

Programming the MDU for Multiplication and Division

| Operation | 32Bit/16Bit |  | 16Bit/16Bit |  | 16Bit x 16Bit |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| First Write | MDO | D'endL | MD0 | D'endL | MD0 | M'andL |
|  | MD1 | D'end | MD1 | D'endH | MD4 | M'orL |
|  | MD2 | D'end |  |  |  |  |
|  | MD3 | D'endH | MD4 | D'orL | MD1 | M'andH |
|  | MD4 | D'orL |  |  |  |  |
| Last Write | MD5 | D'orH | MD5 | D'orH | MD5 | M'orH |
| First Read | MD0 | QuoL | MD0 | QuoL | MD0 | PrL |
|  | MD1 | Quo | MD1 | QuoH | MD1 |  |
|  | MD2 | Quo |  |  |  |  |
|  | MD3 | Quoh | MD4 | RemL | MD2 |  |
|  | MD4 | RemL |  |  |  |  |
| Last Read | MD5 | RemH | MD5 | RemH | MD3 | PrH |

## Abbrevations :

D'end : Dividend, 1st operand of division
D'or : Divisor, 2nd operand of division
M'and : Multiplicand, 1st operand of multiplication
M'or : Multiplicator, 2nd operand of multiplication
$\operatorname{Pr} \quad$ : Product, result of multiplication
Rem : Remainder
Quo : Quotient, result of division
...L : means, that this byte is the least significant of the 16 -bit or 32 -bit operand
... H : means, that this byte is the most significant of the 16 -bit or 32 -bit operand

Table 10
Programming athe MDU for a Shift or Normalize Operation

| Operation | Normalize, Shift Left, Shift Right |  |
| :--- | :--- | :---: |
| First write | MD0 | least significant byte |
|  | MD1 | $\cdot$ |
|  | MD2 | $\cdot$ |
|  | MD3 | most significant byte |
|  | ARCON | start of conversion |
| Last write | MD0 | least significant byte |
|  | MD1 | $\cdot$ |
|  | MD2 | $\cdot$ |
|  | MD3 | most significant byte |

## Serial Interfaces 0 and 1

The C509-L has two serial interfaces which are functionally nearly identical concerning the asynchronous modes of operation. The two channels are full-duplex, meaning they can transmit and receive simultaneously. The serial channel 0 is completely compatible with the serial channel of the C501 (one synchronous mode, three asynchronous modes). Serial channel 1 has the same functionality in its asynchronous modes, but the synchronous mode and the fixed baud rate UART mode is missing.
The operating modes of the serial interfaces is illustrated in table 11. The possible baudrates can be calculated using the formulas given in table 12.
Table 11
Operating Modes of Serial Interface 0 and 1

| Serial Interface | Mode | SOCON |  | $\begin{array}{\|c\|} \hline \text { S1CON } \\ \hline \text { SM } \\ \hline \end{array}$ | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | SM0 | SM1 |  |  |
| 0 | 0 | 0 | 0 | - | Shift register mode <br> Serial data enters and exits through $\mathrm{R} \times \mathrm{DO}$; <br> T×D0 outputs the shift clock; 8-bit are transmitted/received (LSB first); fixed baud rate |
|  | 1 | 0 | 1 | - | 8-bit UART, variable baud rate 10 bits are transmitted (through $\mathrm{T} \times \mathrm{D} 0$ ) or received (at $\mathrm{R} \times \mathrm{D} 0$ ) |
|  | 2 | 1 | 0 | - | 9-bit UART, fixed baud rate 11 bits are transmitted (through T×DO) or received (at $\mathrm{R} \times \mathrm{D} 0$ ) |
|  | 3 | 1 | 1 | - | 9-bit UART, variable baud rate Like mode 2 |
| 1 | A | - | - | 0 | 9-bit UART; variable baud rate <br> 11 bits are transmitted (through $\mathrm{T} \times \mathrm{D} 1$ ) or received (at $\mathrm{R} \times \mathrm{D} 1$ ) |
|  | B | - | - | 1 | 8-bit UART; variable baud rate 10 bits are transmitted (through T×D1) or received (at $\mathrm{R} \times \mathrm{D} 1$ ) |

For clarification some terms regarding the difference between "baud rate clock" and "baud rate" should be mentioned. In the asynchronous modes the serial interfaces require a clock rate which is 16 times the baud rate for internal synchronization. Therefore, the baud rate generators/timers have to provide a "baud rate clock" (output signal in figure 25 and figure 26) to the serial interface which - there divided by 16 - results in the actual "baud rate". Further, the abrevation fosc refers to the oscillator frequency (crystal or external clock operation).
The variable baud rates for modes 1 and 3 of the serial interface 0 can be derived from either timer 1 or a decdicated baud rate generator (see figure 25). The variable baud rates for modes A and B of the serial interface 1 are derived from a decdicated baud rate generator as shown in figure 26.


Figure 25
Serial Interface 0 : Baud Rate Generation Configuration


Figure 26

## Serial Interface 1 : Baud Rate Generator Configuration

Table 12 below lists the values/formulas for the baud rate calculation of serial interface 0 and 1 with its dependencies of the control bits BD, SMOD, S0P, and S1P.

Table 12
Serial Interface 0-Baud Rate Dependencies

| Serial Interface 0 Operating Modes | Active Control Bits |  |  |  | Baud Rate Calculation |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | BD | SOP | SMOD | S1P |  |
| Mode 0 (Shift Register) | - | - | - | - | $f_{\text {osc }} / 6$ |
| Mode 1 (8-bit UART) Mode 3 (9-bit UART) | 0 | - | 0 or 1 | - | Controlled by timer 1 overflow : ( $2^{\text {SMOD }} \times$ timer 1 overflow rate) / 32 |
|  | 1 | 0 or 1 | 0 or 1 | - | Controlled by baud rate generator : $\left(2^{\text {SOP }} \times 2^{\text {SMOD }} \times f_{\text {OSC }}\right) /$ <br> ( $64 \times$ baud rate generator overflow rate) |
| Mode 2 (9-bit UART) | - | - | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | - | $\begin{aligned} & f_{\mathrm{OSc}} / 32 \\ & f_{\mathrm{osc}} / 16 \end{aligned}$ |
| Mode A (9-bit UART) <br> Mode B (8-bit UART) | - | - | - | 0 or 1 | $\begin{aligned} & \left(2^{\mathrm{SIP}} \times f_{\text {OSC) }}\right) / \\ & (32 \times \text { baud rate generator overflow rate }) \end{aligned}$ |

## 10-Bit A/D Converter

The C509-L has a high perfomance 10-bit A/D converter (figure 27) with 15 inputs included which uses successive approximation technique for the conversion and uses self calibration mechanisms for reduction and compensation of offset and linearity errors


Figure 27

## A/D Converter Block Diagram

The A/D converter provides the following features:

- 15 multiplexed input channels, which can also be used as digital inputs (port 7, port 8)
- 10-bit resolution
- Single or continuous conversion mode
- Internal or external start-of-conversion trigger capability
- Programmable conversion and sample clock
- Interrupt request generation after each conversion
- Using successive approximation conversion technique via a capacitor array
- Built-in hidden calibration of offset and linearity errors

The $A / D$ converter uses basically three clock signals for operation : the input clock $f_{I N}\left(=1 /{ }_{f_{\mathrm{N}}}\right)$, the conversion clock $\mathrm{f}_{\mathrm{ADC}}\left(=1 / \mathrm{t}_{\mathrm{ADC}}\right)$ and the sample clock $\mathrm{f}_{\mathrm{SC}}\left(=1 / \mathrm{t}_{\mathrm{SC}}\right)$. All clock signals are derived from the C509-L system clock $f_{\text {OSC }}$ which is applied at the XTAL pins. The input clock $f_{I N}$ is equal to fosc while the conversion clock and the sample clock must be adapted. The conversion clock is limited to a maximum frequency of 2 MHz . The table in figure $\mathbf{2 8}$ defines the divider ratio for the conversion and sample clock of each combination of the prescaler bits.


Figure 28
A/D Converter Clock Selection

## A/D Conversion Timing

An A/D conversion is internally started by writing into the SFR ADDATL with dummy data. A write to SFR ADDATL will start a new conversion even if a conversion is currently in progress. Basically, the $A / D$ conversion procedure is divided into three parts :

- Sample phase ( $\mathrm{t}_{\mathrm{S}}$ ), used for sampling the analog input voltage.
- Conversion phase ( $t_{\mathrm{c}}$ ), used for the real A/D conversion.(includes calibration)
- Write result phase ( $t_{W R}$ ), used for writing the conversion result into the ADDAT registers.

The total A/D conversion time is defined by $t_{\text {ADCC }}$ which is the sum of the two phase times $\mathrm{t}_{\mathrm{s}}$ and ${ }^{t}$ co. The duration of the two phases of an A/D conversion is specified by its specific timing parameter as shown in figure 29.


Figure 29
A/D Conversion Timing

## Interrupt System

The C509-L provides 19 interrupt sources with four priority levels. 12 interrupts can be generated by the on-chip peripherals and 7 interrupts may be triggered externally. In the C509-L the 19 interrupt sources are combined to six groups of three or four interrupt sources. Each interrupt group can be programmed to one of the four interrupt priority levels. Figure $\mathbf{3 0}$ to $\mathbf{3 3}$ give a general overview of the interrupt sources and illustrate the interrupt request and control flags.


Figure 30 Interrupt Request Sources (Part 1)


Figure 31
Interrupt Request Sources (Part 2)


Figure 32
Interrupt Request Sources (Part 3)


Figure 33

## Interrupt Request Sources (Part 4)

Table 13
Interrupt Sources and their Corresponding Interrupt Vectors

| Interrupt Source | Interrupt Vector Address | Interrupt Request Flags |
| :---: | :---: | :---: |
| External Interrupt 0 | $0^{0003} \mathrm{H}$ | IE0 |
| Timer 0 Overflow | $0^{000 B_{H}}$ | TF0 |
| External Interrupt 1 | $0^{0013} \mathrm{H}$ | IE1 |
| Timer 1 Overflow | $001 \mathrm{~B}_{\mathrm{H}}$ | TF1 |
| Serial Channel 0 | ${ }^{0023} \mathrm{H}$ | RIO / TIO |
| Timer 2 Overflow / Ext. Reload | $0^{002 B_{H}}$ | TF2 / EXF2 |
| A/D Converter | ${ }^{0043} \mathrm{H}$ | IADC |
| External Interrupt 2 | $0^{004 B}{ }_{\text {H }}$ | IEX2 |
| External Interrupt 3 | $0^{0053} \mathrm{H}$ | IEX3 |
| External Interrupt 4 | ${ }^{005 B_{H}}$ | IEX4 |
| External Interrupt 5 | ${ }^{0063} \mathrm{H}$ | IEX5 |
| External Interrupt 6 | $0^{006 B}{ }_{H}$ | IEX6 |
| Serial Channel 1 | 0083 H | RI1 / TI1 |
| Compare Match Interupt of Compare Registers CM0-CM7 assigned to Timer 2 | ${ }^{0093} \mathrm{H}$ | ICMP0 - ICMP7 |
| Compare Timer Overflow | $0^{009 B}{ }_{H}$ | CTF |
| Compare Match Interupt of Compare Register COMSET | ${ }^{00} \mathrm{~A}^{\mathrm{H}} \mathrm{H}$ | ICS |
| Compare Match Interupt of Compare Register COMCLR | $0^{00 A B H}$ | ICR |
| Compare / Capture Event interrupt | 00D3 H | ICC10-ICC17 |
| Compare Timer 1 Overflow | $0^{00 D B_{H}}$ | CT1F |

## Fail Save Mechanisms

The C509-L offers two on-chip peripherals which monitor the program flow and ensure an automatic "fail-safe" reaction for cases where the controller's hardware fails or the software hangs up:

- A programmable watchdog timer (WDT) with variable time-out period from 189 microseconds up to approx. 0.79 seconds at 16 MHz .
- An oscillator watchdog (OWD) which monitors the on-chip oscillator and forces the microcontroller into the reset state if the on-chip oscillator fails.


## Programmable Watchdog Timer

The watchdog timer in the C509-L is a 15 -bit timer, which is incremented by a count rate of $f_{\text {osc }} / 12$ up to $f_{\text {osc }} / 384$. For programming of the watchdog timer overflow rate, the upper 7 bit of the watchdog timer can be written. Figure 34 shows the block diagram of the watchdog timer unit.


Figure 34

## Block Diagram of the Programmable Watchdog Timer

The watchdog timer can be started by software (bit SWDT) or by hardware through pin $\overline{\mathrm{PE}} / \mathrm{SWD}$, but it cannot be stopped during active mode of the C509-L. If the software fails to refresh the running watchdog timer an internal reset will be initiated on watchdog timer overflow. For refreshing of the watchdog timer the content of the SFR WDTREL is transferred to the upper 7-bit of the watchdog timer. The refresh sequence consists of two consecutive instructions which set the bits WDT and SWDT each. The reset cause (external reset or reset caused by the watchdog) can be examined by software (flag WDTS). It must be noted, however, that the watchdog timer is halted during the idle mode and power down mode of the processor.

## Oscillator Watchdog

The oscillator watchdog of the C509-L serves for three functions:

- Monitoring of the on-chip oscillator's function.

The watchdog supervises the on-chip oscillator's frequency; if it is lower than the frequency of the auxiliary RC oscillator in the watchdog unit, the internal clock is supplied by the RC oscillator and the device is brought into reset; if the failure condition disappears (i.e. the onchip oscillator has a higher frequency than the RC oscillator), the part executes a final reset phase of appr. 0.5 ms in order to allow the oscillatior to stabilize; then the oscillator watchdog reset is released and the part starts program execution again.

- Restart from the hardware power down mode.

If the hardware power down mode is terminated the oscillator watchdog has to control the correct start-up of the on-chip oscillator and to restart the program. The oscillator watchdog function is only part of the complete hardware power down sequence; however, the watchdog works identically to the monitoring function.

- Fast internal reset after power-on.

In this function the oscillator watchdog unit provides a clock supply for the reset before the onchip oscillator has started. In this case the oscillator watchdog unit also works identically to the monitoring function.


Figure 35

## Block Diagram of the Oscillator Watchdog

## Power Saving Modes

The C509-L provides three power saving modes in which power consumption can be significantly reduced.

- Idle mode

The CPU is gated off from the oscillator. All peripherals are still provided with the clock and are able to work.

- Power down mode

The operation of the C509-L is completely stopped and the oscillator is turned off. This mode is used to save the contents of the internal RAM with a very low standby current. Power down mode can be entered by software or by hardware (pin HWPD).

- Slow-down mode

The controller keeps up the full operating functionality, but its normal clock frequency is internally divided by eight. This slows down all parts of the controller, the CPU and all peripherals, to $1 / 8$ th of their normal operating frequency. Slowing down the frequency greatly reduces power consumption.

Table 14 gives a general overview of the entry and exit procedures of the power saving modes.
Table 14
Power Saving Modes Overview

| Mode | Entering <br> 2-Instruction <br> Example | Leaving by | Remarks |
| :--- | :--- | :--- | :--- |
| Idle mode | ORL PCON, \#01H <br> ORL PCON, \#20H | Ocurrence of an <br> interrupt from a <br> peripheral unit | CPU clock is stopped; <br> CPU maintains their data; <br> peripheral units are active (if <br> enabled) and provided with <br> clock |
|  | Hardware Reset |  |  |

In the power down mode of operation, $V_{\mathrm{CC}}$ can be reduced to minimize power consumption. It must be ensured, however, that $V_{\mathrm{CC}}$ is not reduced before the power down mode is invoked, and that $V_{\mathrm{CC}}$ is restored to its normal operating level, before the power down mode is terminated.

If e.g. the idle mode is left through an interrupt, the microcontroller state (CPU, ports, peripherals) remains preserved. If a power saving mode is left by a hardware reset, the microcontroller state is disturbed and replaced by the reset state of the C509-L.
Absolute Maximum Ratings
Ambient temperature under bias $\left(T_{\mathrm{A}}\right)$ ..... -40 to $110^{\circ} \mathrm{C}$
Storage temperature ( $T_{\text {stg }}$ ) $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
Voltage on $V_{\mathrm{CC}}$ pins with respect to ground ( $V_{\mathrm{SS}}$ ) ..... -0.5 V to 6.5 V
Voltage on any pin with respect to ground ( $V_{\mathrm{SS}}$ ) -0.5 V to $V_{\mathrm{CC}}+0.5 \mathrm{~V}$
Input current on any pin during overload condition -10 mA to 10 mA
Absolute sum of all input currents during overload condition ..... 1100 mA I
Power dissipation ..... 1 W

## Note:

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage of the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for longer periods may affect device reliability. During overload conditions ( $V_{I N}>V_{C C}$ or $V_{I N}<V_{S S}$ ) the Voltage on $V_{C C}$ pins with respect to ground ( $V_{S S}$ ) must not exceed the values defined by the absolute maximum ratings.

## DC Characteristics

$\begin{array}{ll}V_{\mathrm{CC}}=5 \mathrm{~V}+10 \%,-15 \% ; V_{\mathrm{SS}}=0 \mathrm{~V} \quad & T_{\mathrm{A}}=0 \text { to } 70^{\circ} \mathrm{C} \quad \text { for the SAB-C509 } \\ T_{\mathrm{A}}=-40 \text { to } 85^{\circ} \mathrm{C} \quad \text { for the SAF-C509 }\end{array}$

| Parameter | Symbol | Limit Values |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |  |
| Input low voltage (except $\overline{E A}, \overline{R E S E T}, \overline{H W P D})$ | $V_{\text {IL }}$ | -0.5 | $\begin{aligned} & 0.2 V_{\mathrm{CC}}- \\ & 0.1 \end{aligned}$ | V | - |
| Input low voltage ( $\overline{\mathrm{EA}}$ ) | $V_{\text {IL1 }}$ | -0.5 | $\begin{aligned} & 0.2 V_{\mathrm{CC}}- \\ & 0.3 \end{aligned}$ | V | - |
| Input low voltage ( $\overline{\mathrm{HWPD}}$, RESET) | $V_{\text {IL2 }}$ | -0.5 | $\begin{aligned} & 0.2 V_{\mathrm{CC}}+ \\ & 0.1 \end{aligned}$ | V | - |
| Input low voltage (CMOS) (ports 0-9) | $V_{\text {ILC }}$ | -0.5 | $0.3 V_{\text {CC }}$ | V | - |
| Input high voltage (except RESET, XTAL2 and HWPD | $V_{\text {IH }}$ | $\begin{aligned} & 0.2 V_{\mathrm{CC}}+ \\ & 0.9 \end{aligned}$ | $V_{\mathrm{CC}}+0.5$ | V | - |
| Input high voltage to XTAL2 | $V_{1 H 1}$ | $0.7 V_{\text {CC }}$ | $V_{\mathrm{CC}}+0.5$ | V | - |
| Input high voltage to RESET and HWPD | $V_{1+2}$ | $0.6 V_{\text {cc }}$ | $V_{\text {CC }}+0.5$ | V | - |
| Input high voltage (CMOS) (ports 0-9) | $V_{\text {IHC }}$ | $0.7 V_{\text {CC }}$ | $V_{\mathrm{CC}}+0.5$ | V | - |
| CMOS input hysteresis (ports 1, 3 to 9 ) | $V_{\text {IHYS }}$ | 0.1 | - | V | - |


| Parameter | Symbol | Limit Values |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |  |
| Output low voltage (ports 1, 2, 3, 4, 5, 6, 9) | $V_{\text {OL }}$ | - | 0.45 | V | $I_{\text {OL }}=1.6 \mathrm{~mA}^{1)}$ |
| Output low voltage (port 0, ALE, $\overline{\text { PSEN }} / \overline{R D F}, \overline{R O}$ ) | $V_{\text {OL1 }}$ | - | 0.45 | V | $I_{\mathrm{OL}}=3.2 \mathrm{~mA}^{1)}$ |
| Output high voltage (ports 1, 2, 3, 4, 5, 6, 9) | $V_{\text {OH }}$ | $\begin{array}{\|l\|} 2.4 \\ 0.9 V_{\mathrm{CC}} \end{array}$ | - | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & I_{\mathrm{OH}}=-80 \mu \mathrm{~A} \\ & I_{\mathrm{OH}}=-10 \mu \mathrm{~A} \end{aligned}$ |
| Output high voltage (port 0 in external bus mode, ALE, PSEN/RDF, $\overline{\text { RO })}$ | $V_{\mathrm{OH} 1}$ | $\begin{array}{\|l\|} 2.4 \\ 0.9 V_{\mathrm{CC}} \end{array}$ | - | $\begin{aligned} & \hline \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & I_{\mathrm{OH}}=-800 \mu \mathrm{~A}^{2)} \\ & I_{\mathrm{OH}}=-80 \mu \mathrm{~A}^{2)} \end{aligned}$ |
| Output high voltage (CMOS) (ports 1, 2, 3, 4, 5, 6, 9) | $V_{\text {онс }}$ | $0.9 V_{\text {CC }}$ | - | V | $I_{\text {OH }}=-800 \mu \mathrm{~A}$ |
| Logic input low current (ports 1, 2, 3, 4, 5, 6, 9) | $I_{\text {IL }}$ | - 10 | -70 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0.45 \mathrm{~V}$ |
| Logical 1-to-0 transition current (ports 1, 2, 3, 4, 5, 6, 9) | $I_{\mathrm{TL}}$ | -65 | -650 | $\mu \mathrm{A}$ | $V_{\text {IN }}=2 \mathrm{~V}$ |
| Input leakage current ${ }^{7)}$ (port 0, 7, 8, HWPD) | $I_{\text {LI }}$ | - | $\pm 100$ | nA | $0.45<V_{\text {IN }}<V_{\text {CC }}$ |
| (port 0 in CMOS) |  |  | $\pm 150$ | nA | $\begin{aligned} & 0.45<V_{\text {IN }}<V_{\mathrm{CC}} \\ & T_{\mathrm{A}}>100^{\circ} \mathrm{C} \end{aligned}$ |
| Input leakage current (EA, PRGEN) (ports 1, 2, 3, 4, 5, 6, 9 in CMOS) | $I_{\text {LIC }}$ | - | $\pm 1$ | $\mu \mathrm{A}$ | $0.45<V_{\text {IN }}<V_{\text {CC }}$ |
| Input low current to RESET for reset | $I_{\text {LI2 }}$ | - 10 | -100 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0.45 \mathrm{~V}$ |
| Input low current (XTAL2) | $I_{\text {Lı }}$ | - | -15 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0.45 \mathrm{~V}$ |
| Input low current (PE/SWD, OWE) | $I_{\text {LI4 }}$ | - | -20 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0.45 \mathrm{~V}$ |
| Pin capacitance | $C_{10}$ | - | 10 | pF | $\begin{aligned} & f_{\mathrm{C}}=1 \mathrm{MHz} \\ & T_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Overload current | $I_{\text {OV }}$ | - | $\pm 5$ | mA | 10) 11) |


| Parameter | Symbol | Limit Values |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | typ. ${ }^{12}$ | max. |  |  |
| Power supply current: |  |  |  |  |  |
| C509-L, Active mode, $12 \mathrm{MHz}{ }^{8}{ }^{8}$ | $I_{\text {CC }}$ | 9) | TBD | mA | $V_{\mathrm{CC}}=5 \mathrm{~V},{ }^{4)}$ |
| C509-L, Active mode, $16 \mathrm{MHz}^{8}{ }^{8}$ | $I_{\text {CC }}$ | 9) | TBD | mA | $V_{\mathrm{CC}}=5 \mathrm{~V},{ }^{4)}$ |
| C509-L, Idle mode, $12 \mathrm{MHz}{ }^{8}{ }^{8}$ | $I_{\text {CC }}$ | 9) | TBD | mA | $V_{\mathrm{CC}}=5 \mathrm{~V},{ }^{5}$ ) |
| C509-L, Idle mode, $16 \mathrm{MHz}{ }^{8}$ | $I_{\text {CC }}$ | 9) | TBD | mA | $\left.V_{\mathrm{CC}}=5 \mathrm{~V},{ }^{5}\right)$ |
| C509-L, Slow down mode, 12 MHz | $I_{\text {CC }}$ | - | TBD | mA | $V_{\mathrm{CC}}=5 \mathrm{~V},{ }^{6}$ |
| C509-L, Slow down mode, 16 MHz | $I_{\text {CC }}$ | - | TBD | mA | $V_{\text {CC }}=5 \mathrm{~V},{ }^{6}$ |
| C509-L, Power Down Mode | $I_{\text {PD }}$ | 5 | 50 | $\mu \mathrm{A}$ | $V_{\mathrm{CC}}=2 \ldots . .5 .5$ |

## Notes :

1) Capacitive loading on ports 0 and 2 may cause spurious noise pulses to be superimposed on the $V_{\mathrm{OL}}$ of ALE and port $1,3,4,5,6$, and 9 . The noise is due to external bus capacitance discharging into the port 0 and port 2 pins when these pins make 1-to- 0 transitions during bus operation. In the worst case (capacitive loading $>100 \mathrm{pF}$ ), the noise pulse on ALE line may exceed 0.8 V . In such cases it may be desirable to qualify ALE with a schmitt-trigger, or use an address latch with a schmitt-trigger strobe input.
2) Capacitive loading on ports 0 and 2 may cause the $V_{\text {OH }}$ on ALE and PSEN/ $\overline{\mathrm{RDF}}$ to momentarily fall below the $0.9 V_{\mathrm{CC}}$ specification when the address lines are stabilizing.
3) $I_{\mathrm{PD}}$ (power down mode) is measured under following conditions:
$\mathrm{EA}=\mathrm{RESET}=V_{\mathrm{CC}} ;$ Port0 $=$ Port7 $=$ Port8 $=V_{\mathrm{CC}} ; \mathrm{XTAL1}=$ N.C. $; \mathrm{XTAL2}=V_{\mathrm{SS}} ; \mathrm{PE} / \mathrm{SWD}=\mathrm{OWE}=V_{\mathrm{SS}} ;$ $\mathrm{HWDP}=V_{\mathrm{CC}} ; V_{\text {AREF }}=V_{\mathrm{CC}} ; V_{\text {AGND }}=V_{\mathrm{SS}} ;$ all other pins are disconnected.
Hardware power down mode current ( $I_{\mathrm{PD}}$ ) is measured with $\mathrm{OWE}=V_{\mathrm{CC}}$ or $V_{\mathrm{SS}}$.
4) $I_{\mathrm{CC}}$ (active mode) is measured with:

XTAL2 driven with $t_{\mathrm{R}} / t_{\mathrm{F}}=5 \mathrm{~ns}, V_{\mathrm{IL}}=V_{\mathrm{SS}}+0.5 \mathrm{~V}, V_{\mathrm{HH}}=V_{\mathrm{CC}}-0.5 \mathrm{~V} ; \mathrm{XTAL1}=\mathrm{N} . \mathrm{C} . ; \mathrm{EA}=\overline{\mathrm{PE}} / \mathrm{SWD}=V_{\mathrm{CC}}$;
Port0 $=$ Port7 $=$ Port $=V_{\mathrm{CC}} ; \mathrm{HWPD}=V_{\mathrm{CC}} ; \mathrm{RESET}=V_{\mathrm{SS}} ;$ all other pins are disconnected. $I_{\mathrm{CC}}$ would be slightly higher if a crystal oscillator is used.
5) $I_{\mathrm{CC}}$ (idle mode) is measured with all output pins disconnected and with all peripherals disabled;

XTAL2 driven with $t_{\mathrm{R}} / t_{\mathrm{F}}=5 \mathrm{~ns}, V_{\mathrm{IL}}=V_{\mathrm{SS}}+0.5 \mathrm{~V}, V_{\mathrm{HH}}=V_{\mathrm{CC}}-0.5 \mathrm{~V} ; \mathrm{XTAL} 1=\mathrm{N} . \mathrm{C} . ; \operatorname{RESET}=V_{\mathrm{CC}} ;$ HWPD $=V_{\mathrm{CC}} ;$ Port0 $=$ Port7 $=$ Port8 $=V_{\mathrm{CC}} ; \mathrm{EA}=\mathrm{PE} / \mathrm{SWD}=V_{\mathrm{SS}} ;$ all other pins are disconnected;
6) $I_{\mathrm{CC}}$ (slow down mode) is measured with all output pins disconnected and with all peripherals disabled;

XTAL2 driven with $t_{\mathrm{R}} / t_{\mathrm{F}}=5 \mathrm{~ns}, V_{\mathrm{IL}}=V_{\mathrm{SS}}+0.5 \mathrm{~V}, V_{\mathrm{IH}}=V_{\mathrm{CC}}-0.5 \mathrm{~V} ; \mathrm{XTAL1}=\mathrm{N} . \mathrm{C} . ;$ RESET $=V_{\mathrm{CC}} ;$ HWPD $=V_{\mathrm{CC}} ;$ Port7 $=$ Port8 $=V_{\mathrm{CC}} ; \mathrm{EA}=\mathrm{PE} / \mathrm{SWD}=V_{\mathrm{SS}} ;$ all other pins are disconnected;
7) Input leakage current for port 0 is measured with $\overline{\text { RESET }}=V_{\mathrm{CC}}$.
8) $I_{\mathrm{CC} \text { max }}$ at other frequencies is given by:
active mode:TBD
idle mode:TBD
where $f_{\text {osc }}$ is the oscillator frequency in MHz . $I_{\mathrm{CC}}$ values are given in mA and measured at $V_{\mathrm{CC}}=5 \mathrm{~V}$.
9) Typical power supply current ( $I_{\text {CC typ }}$ ) with test conditiones as defined in note 4 and 5 is given by:
active mode, $12 \mathrm{MHz}: 45 \mathrm{~mA}$
active mode, $16 \mathrm{MHz}: 72 \mathrm{~mA}$
idle mode, $16 \mathrm{MHz}: 29 \mathrm{~mA}$
10)Overload conditions occur if the standard operating conditions are exeeded, ie. the voltage on any pin exceeds the specified range (i.e. $V_{\mathrm{OV}}>V_{\mathrm{CC}}+0.5 \mathrm{~V}$ or $V_{\mathrm{OV}}<V_{\mathrm{SS}}-0.5 \mathrm{~V}$ ). The supply voltage $V_{\mathrm{CC}}$ and $V_{\mathrm{SS}}$ must remain within the specified limits. The absolute sum of input currents on all port pins may not exceed 50 mA .
11) Not $100 \%$ tested, guaranteed by design characterization.
12)The typical $I_{\mathrm{CC}}$ values are periodically measured at $T_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ but not $100 \%$ tested.

## A/D Converter Characteristics

$T_{\mathrm{A}}=0$ to $70^{\circ} \mathrm{C}$ for the SAB-C509
$T_{\mathrm{A}}=-40$ to $85^{\circ} \mathrm{C}$ for the SAF-C509
$V_{\mathrm{CC}}=5 \mathrm{~V}+10 \%,-15 \% ; V_{\mathrm{SS}}=0 \mathrm{~V}$
$4 \mathrm{~V} \leq V_{\text {AREF }} \leq V_{\mathrm{CC}}+0.1 \mathrm{~V} ; V_{\mathrm{SS}}-0.1 \mathrm{~V} \leq V_{\mathrm{AGND}} \leq V_{\mathrm{SS}}+0.2 \mathrm{~V}$

| Parameter | Symbol | Limit Values |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |  |
| Analog input voltage | $V_{\text {AIN }}$ | $V_{\text {AGND }}$ | $V_{\text {AREF }}$ | V | 1) |
| Sample time | $t_{\text {s }}$ | $8 t_{\text {IN }}$ | $512 t_{\text {IN }}$ |  | ${ }^{\text {2) }}$ see table below |
| Conversion time | $t_{\text {ADCC }}$ | $48 t_{\text {IN }}$ | $832 t_{\text {IN }}$ |  | ${ }^{3)}$ see table below |
| Total unadjusted error | TUE | - | $\pm 2$ | LSB | 4) |
| Internal resistance of reference voltage source | $R_{\text {AREF }}$ | - | $\begin{aligned} & t_{\mathrm{ADC}} / 250 \\ & -0.25 \end{aligned}$ | $\mathrm{k} \Omega$ | $t_{\text {ADC }}$ in [ns] ${ }^{5) 6}$ |
| Internal resistance of analog source | $R_{\text {ASRC }}$ | - | $\begin{aligned} & t_{\mathrm{s}} / 500 \\ & -0.25 \end{aligned}$ | $\mathrm{k} \Omega$ | $t_{\mathrm{S}} \mathrm{in}[\mathrm{ns}]^{3) 6}$ |
| ADC input capacitance | $C_{\text {AIN }}$ | - | 50 | pF | 6) |

Notes see next page.

## Clock calculation table

| Conversion Clock Selection |  |  | Sample Clock Selection |  |  | Sample Time ts | Conversion Time t ADCC |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADCL1 | ADCLO | Prescaler CCP | ADST1 | ADSTO | Prescaler SCP |  |  |
| 0 | 0 | 4 | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | 2 | $\begin{aligned} & 8 \times t_{\mathrm{IN}} \\ & 16 \times \mathrm{t}_{\mathrm{IN}} \\ & 32 \times \mathrm{IIN}_{\mathrm{IN}} \\ & 64 \times \mathrm{t}^{2} \end{aligned}$ | $\begin{gathered} 48 \times t_{I N} \\ 56 \times t_{I N} \\ 72 \times t_{I N} \\ 104 \times t_{\mathrm{IN}} \end{gathered}$ |
| 0 | 1 | 8 | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | 4 | $\begin{aligned} & 16 \times t_{\mathrm{IN}} \\ & 32 \times \mathrm{t}_{\mathrm{IN}} \\ & 64 \times \mathrm{t}_{\mathrm{IN}} \\ & 128 \times \mathrm{t}_{\mathrm{IN}} \end{aligned}$ | $\begin{aligned} & 96 \times t_{I N} \\ & 112 \times t_{\mathrm{IN}} \\ & 144 \times t_{\mathrm{IN}} \\ & 208 \times t_{\mathrm{IN}} \end{aligned}$ |
| 1 | 0 | 16 | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | 8 | $\begin{gathered} 32 \times \mathrm{t}_{\mathrm{IN}} \\ 64 \times \mathrm{t}_{\mathrm{IN}} \\ 128 \times \mathrm{t}_{\mathrm{IN}} \\ 256 \times \mathrm{t}_{\mathrm{IN}} \end{gathered}$ | $\begin{aligned} & 192 \times t_{I N} \\ & 224 \times t_{I N} \\ & 288 \times t_{I N} \\ & 416 \times t_{I N} \end{aligned}$ |
| 1 | 1 | 32 | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | 16 | $\begin{gathered} 64 \times t_{I N} \\ 128 \times t_{I N} \\ 256 \times t_{I N} \\ 512 \times t_{I N} \end{gathered}$ | $\begin{aligned} & 384 \times t_{I N} \\ & 448 \times t_{I N} \\ & 576 \times t_{I N} \\ & 832 \times t_{I N} \end{aligned}$ |

Further timing conditions : ${ }^{\mathrm{t}} \mathrm{ADC}$ min $=500 \mathrm{~ns}=\mathrm{CCP} \times$ CLP
$\mathrm{t}_{\mathrm{IN}}=1 / \mathrm{f}_{\mathrm{OSC}}=\mathrm{CLP}$
$\mathrm{t}_{\mathrm{SC}}=\mathrm{t}$ ADC $\times \mathrm{SCP}$

## Notes:

1) $V_{\text {AIN }}$ may exeed $V_{\text {AGND }}$ or $V_{\text {AREF }}$ up to the absolute maximum ratings. However, the conversion result in these cases will be $\mathrm{X} 000_{\mathrm{H}}$ or $\mathrm{X}^{2} \mathrm{FF}_{\mathrm{H}}$, respectively.
2) During the sample time the input capacitance $\mathrm{C}_{\text {AIN }}$ can be charged/discharged by the external source. The internal resistance of the analog source must allow the capacitance to reach their final voltage level within ts. After the end of the sample time $\mathrm{t}_{\mathrm{S}}$, changes of the analog input voltage have no effect on the conversion result.
3) This parameter includes the sample time $t_{s}$, the time for determining the digital result and the time for the calibration. Values for the conversion clock $\mathrm{f}_{\text {ADC }}$ depend on programming and can be taken from the table below.
4) $\mathrm{T}_{\mathrm{UE}}$ is tested at $\mathrm{V}_{\mathrm{AREF}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{AGND}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=4.9 \mathrm{~V}$. It is guaranteed by design characterization for all other voltages within the defined voltage range.
If an overload condition occurs on maximum 2 not selected analog input pins and the absolute sum of input overload currents on all analog input pins does not exceed 10 mA , an additional conversion error of $1 / 2$ LSB is permissible.
5) During the conversion the ADC's capacitance must be repeatedly charged or discharged. The internal resistance of the reference source must allow the capacitance to reach their final voltage level within the indicated time. The maximum internal resistance results from the programmed conversion timing.
6) Not $100 \%$ tested, but guaranteed by design characterization.

## AC Characteristics

$$
\begin{array}{lll}
V_{\mathrm{CC}}=5 \mathrm{~V}+10 \%,-15 \% ; V_{\mathrm{SS}}=0 \mathrm{~V} & T_{\mathrm{A}}=0 \text { to } 70^{\circ} \mathrm{C} \quad \text { for the SAB-C509 } \\
& T_{\mathrm{A}}=-40 \text { to } 85^{\circ} \mathrm{C} & \text { for the SAF-C509 }
\end{array}
$$

( $C_{\mathrm{L}}$ for port 0, ALE and $\overline{\text { PSEN }}$ outputs $=100 \mathrm{pF} ; C_{\mathrm{L}}$ for all other outputs $=80 \mathrm{pF}$ )
Program Memory Characteristics

| Parameter | Symbol | Limit Values |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 16-MHz clock Duty Cycle 0.4 to 0.6 |  | Variable Clock $1 / \mathrm{CLP}=3.5 \mathrm{MHz}$ to 16 MHz |  |  |
|  |  | min. | max. | min. | max. |  |
| ALE pulse width | $t_{\text {LHLL }}$ | 48 | - | CLP-15 | - | ns |
| Address setup to ALE | $t_{\text {AVLL }}$ | 10 | - | $\mathrm{TCL}_{\text {Hmin }}-15$ | - | ns |
| Address hold after ALE | $t_{\text {LLAX }}$ | 10 | - | $\mathrm{TCL}_{\text {Hmin }}-15$ | - | ns |
| Address to valid instruction in | $t_{\text {LuIV }}$ | - | 75 | - | 2 CLP-50 | ns |
|  | $t_{\text {LLPL }}$ | 10 | - | TCL ${ }_{\text {Lmin }}$-15 | - | ns |
| $\overline{\text { PSEN } / \mathrm{RDF}}$ pulse width | $t_{\text {PLPH }}$ | 73 | - | $\begin{aligned} & \text { CLP+ } \\ & \text { TCL }_{\text {Hinin }}-15 \\ & \hline \end{aligned}$ | - | ns |
| $\overline{\overline{\text { PSEN }} / \overline{\text { RDF }} \text { to valid instruction in }}$ | $t_{\text {PLIV }}$ | - | 38 | - | $\begin{aligned} & \mathrm{CLP}_{+} \\ & \mathrm{TCL}_{\mathrm{H} \text { min }}-50 \end{aligned}$ | ns |
| Input instruction hold after PSEN/ $\overline{R D F}$ | $t_{\text {PXIX }}$ | 0 | - | 0 | - | ns |
| Input instruction float after $\overline{\text { PSEN/ }}$ RDF | $t_{\text {PXIZ }}{ }^{\text {* }}$ | - | 15 | - | $\mathrm{TCL}_{\text {Lmin }}-10$ | ns |
| Address valid after $\overline{\text { PSEN }} / \overline{\text { RDF }}$ | $t_{\text {PXAV }}{ }^{*}$ | 20 | - | TCL ${ }_{\text {Lmin }}$-5 | - | ns |
| Address to valid instruction in | $t_{\text {AVIV }}$ | - | 95 | - | $\begin{aligned} & 2 \text { CLP }_{+} \\ & \text {TCL }_{\text {H } \min }-55 \end{aligned}$ | ns |
| Address float to $\overline{\text { PSEN }} / \overline{\text { RDF }}$ | $t_{\text {AZPL }}$ | - 5 |  | - 5 | - | ns |

*) Interfacing the C509-L to devices with float times up to 20 ns is permissible. This limited bus contention will not cause any damage to port 0 drivers.

## External Data Memory Characteristics

| Parameter | Symbol | Limit Values |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 16-MHz clock Duty Cycle 0.4 to 0.6 |  | $\begin{gathered} \text { Variable Clock } \\ \text { 1/CLP }=3.5 \mathrm{MHz} \text { to } \\ 16 \mathrm{MHz} \end{gathered}$ |  |  |
|  |  | min. | max. | min. | max. |  |
| $\overline{\mathrm{RD}}$ pulse width | $t_{\text {RLRH }}$ | 158 | - | 3 CLP-30 | - | ns |
| WR pulse width | $t_{\text {WLWH }}$ | 158 | - | 3 CLP-30 | - | ns |
| Address hold after ALE | $t_{\text {LLAX2 }}$ | 48 | - | CLP -15 | - | ns |
| $\overline{\mathrm{RD}}$ to valid data in | $t_{\text {RLDV }}$ | - | 100 | - | $\begin{aligned} & 2 \mathrm{CLP}_{+} \\ & \text {TCL }_{\mathrm{Hmin}}-50 \end{aligned}$ | ns |
| Data hold after $\overline{\mathrm{RD}}$ | $t_{\text {RHDX }}$ | 0 |  | 0 | - | ns |
| Data float after $\overline{\mathrm{RD}}$ | $t_{\text {RHDZ }}$ | - | 51 | - | CLP-12 | ns |
| ALE to valid data in | $t_{\text {LLDV }}$ | - | 200 | - | 4 CLP-50 | ns |
| Address to valid data in | $t_{\text {AVDV }}$ | - | 200 | - | $\begin{array}{\|l\|} \hline 4 \text { CLP }_{+} \\ \text {TCL }_{\text {Hinin}}-75 \\ \hline \end{array}$ | ns |
| ALE to $\overline{\mathrm{WR}}$ or $\overline{\mathrm{RD}}$ | $t_{\text {LLWL }}$ | 73 | 103 | $\begin{aligned} & \mathrm{CLP}_{+} \\ & \mathrm{TCL}_{\mathrm{Lmin}}-15 \end{aligned}$ | $\begin{aligned} & \text { CLP+ } \\ & \text { TCL }_{\text {Lmin }}+15 \end{aligned}$ | ns |
| Address valid to WR | $t_{\text {AVWL }}$ | 95 | - | 2 CLP-30 | - | ns |
| $\overline{\text { WR }}$ or $\overline{\mathrm{RD}}$ high to ALE high | $t_{\text {WHLL }}$ | 10 | 40 | $\mathrm{TCL}_{\text {Hmin }}-15$ | TCL ${ }_{\text {Hmin }}+15$ | ns |
| Data valid to $\overline{W R}$ transition | $t_{\text {Qvwx }}$ | 5 | - | TCL ${ }_{\text {Lmin }}-20$ | - | ns |
| Data setup before WR | $t_{\text {Quwh }}$ | 163 | - | $\begin{aligned} & 3 \text { CLP }_{+} \\ & \text {TCL }_{\text {Lmin }}-50 \end{aligned}$ | - | ns |
| Data hold after WR | $t_{\text {Whax }}$ | 5 | - | $\mathrm{TCL}_{\text {Hmin }}-20$ | - | ns |
| Address float after $\overline{\mathrm{RD}}$ | $t_{\text {RLAZ }}$ | - | 0 | - | 0 | ns |

## External Clock Drive XTAL2

| Parameter | Symbol | $\begin{aligned} & \text { CPU Clock }=16 \mathrm{MHz} \\ & \text { Duty cycle } 0.4 \text { to } 0.6 \end{aligned}$ |  | Variable CPU Clock $1 / C L P=3.5$ to 16 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. | min. | max. |  |
| Oscillator period | CLP | 62.5 | 62.5 | 62.5 | 285 | ns |
| High time | TCL ${ }_{\text {H }}$ | 25 | - | 25 | CLP-TCL | ns |
| Low time | TCL ${ }_{\text {L }}$ | 25 | - | 25 | CLP-TCL ${ }_{\text {H }}$ | ns |
| Rise time | $t_{\text {R }}$ | - | 10 | - | 10 | ns |
| Fall time | $t_{\mathrm{F}}$ | - | 10 | - | 10 | ns |
| Oscillator duty cycle | DC | 0.4 | 0.6 | 25 / CLP | 1-25 / CLP | - |
| Clock cycle | TCL | 25 | 37.5 | CLP * DC ${ }_{\text {min }}$ | CLP * DC ${ }_{\text {max }}$ | ns |

Note: The 16 MHz values in the tables are given as an example for a typical duty cycle variation of the oscillator clock from 0.4 to 0.6 .


Figure 36

## Program Memory Read Cycle



Figure 37


Figure 38
Data Memory Write Cycle


Figure 39
External Clock Drive Drive XTAL2


AC Inputs during testing are driven at $V_{\mathrm{CC}}-0.5 \mathrm{~V}$ for a logic ' 1 ' and 0.45 V for a logic ' 0 '. Timing measurements are made at $V_{\mathrm{IH} \min }$ for a logic '1' and $V_{\mathrm{IL} \max }$ for a logic '0'.

Figure 40
AC Testing: Input, Output Waveforms


MCT00038
For timing purposes a port pin is no longer floating when a 100 mV change from load voltage occurs and begins to float when a 100 mV change from the loaded $V_{\mathrm{OH}} / V_{\text {OL }}$ level occurs.
$I_{\mathrm{OL}} / I_{\mathrm{OH}} \geq \pm 20 \mathrm{~mA}$
Figure 41

## AC Testing: Float Waveforms



Figure 42
Recommended Oscillator Circuits for Crystal Oscillators up to 16 MHz


[^0]:    *) I = Input
    $\mathrm{O}=$ Output

[^1]:    *) I = Input
    $\mathrm{O}=$ Output

[^2]:    *) I = Input
    $\mathrm{O}=$ Output

[^3]:    *) 1 = Input
    $\mathrm{O}=$ Output

[^4]:    *) I = Input
    $\mathrm{O}=$ Output

[^5]:    5) Register is mapped by bit RMAP.
[^6]:    ${ }^{1)}$ Bit-addressable special function registers
    ${ }^{2)}$ This special function register is listed repeatedly since some bits of it also belong to other functional blocks.
    3) $X$ means that the value is indeterminate or the location is reserved
    4) Register is mapped by bit PDIR.
    ${ }^{5)}$ Register is mapped by bit RMAP.
    ${ }^{6)}$ Registers are only readable and cannot be written.

[^7]:    1) Bit-addressable special function registers
    2) This special function register is listed repeatedly since some bits of it also belong to other functional blocks.
    3) X means that the value is indeterminate and the location is reserved
    4) Register is mapped by bit PDIR.
    5) Register is mapped by bit RMAP.
