#### 8-Bit CMOS Microcontroller **SAB-C502** ### **Preliminary** - Fully compatible to standard 8051 microcontroller - Versions for 12 / 20 MHz operating frequency - 16 K × 8 ROM (SAB-C502-2R only) - 256 × 8 RAM - 256 × 8 XRAM (additional on-chip RAM) - Eight datapointers for indirect addressing of program and external data memory (including XRAM) - Four 8-bit ports - Three 16 -bit Timers / Counters (Timer 2 with Up/Down Counter feature) - USART with programmable 10-bit Baudrate-Generator - Six interrupt sources, two priority levels - Programmable 15-bit Watchdog Timer - Oscillator Watchdog - Fast Power On Reset - Power Saving Modes - P-DiP-40 package and P-LCC-44 package Temperature ranges: SAB-C502 SAB-C502 $T_A$ : 0 °C to 70 °C SAF-C502 $T_A$ : -40 °C to 85 °C **SAB-C502** RAM Oscillator Watchdog 256 x 8 ΤO Port CPU XRAM 8-bit T2 256 x 8 USART Port 2 T1 8 Datapointer ROM 16k x 8 Watchdog Timer (SAB-C502-2R only) MCA01763 The SAB-C502-L/C502-2R described in this document is compatible with the SAB 80C52 and can be used for all present SAB 80C52 applications. The SAB-C502-2R contains a non-volatile 16 K $\times$ 8 read-only program memory, a volatile 256 $\times$ 8 read/write data memory, four ports, three 16-bit timers/counters, a six source, two priority level interrupt structure, a serial port and versatile fail save mechanisms. The SAB-C502-L/C502-2R incorporates 256 $\times$ 8 additional on-chip RAM called XRAM. For higher performance eight datapointers are implemented. The SAB-C502-L is identical, except that it lacks the program memory on chip. Therefore the term SAB-C502 refers to both versions within this specification unless otherwise noted. # **Ordering Information** | Туре | Ordering<br>Code | Package | Description (8-Bit CMOS microcontroller) | |----------------|------------------|----------|-----------------------------------------------------------------| | SAB-C502-LN | Q67120-C838 | P-LCC-44 | for external memory 12 MHz | | SAB-C502-LP | Q67120-C889 | P-DIP-40 | | | SAB-C502-2RN | Q67120-C839 | P-LCC-44 | with mask-programmable ROM, 12 MHz | | SAB-C502-2RP | Q67120-C890 | P-DIP-40 | | | SAB-C502-L20N | Q67120-C885 | P-LCC-44 | for external memory 20 MHz | | SAB-C502-L20P | Q67120-C891 | P-DIP-40 | | | SAB-C502-2R20N | Q67120-C884 | P-LCC-44 | with mask-programmable ROM, 20 MHz | | SAB-C502-2R20P | Q67120-C892 | P-DIP-40 | | | SAF-C502-LN | Q67120-C883 | P-LCC-44 | for external ROM, 12 MHz, | | SAF-C502-LP | Q67120-C893 | P-DIP-40 | ext. temp 40 °C to 85 °C | | SAF-C502-2RN | Q67120-C886 | P-LCC-44 | with mask-programmable ROM, | | SAF-C502-2RP | Q67120-C894 | P-DIP-40 | 12 MHz, ext. temp. – 40 °C to 85 °C | | SAF-C502-L20N | Q67120-C887 | P-LCC-44 | for external memory, 20 MHz, ext. temp. – 40 °C to 85 °C | | SAF-C502-L20P | Q67120-C895 | P-DIP-40 | | | SAF-C502-2R20N | Q67120-C888 | P-LCC-44 | with mask-programmable ROM, 20 MHz, ext. temp. – 40 °C to 85 °C | | SAF-C502-2R20P | Q67120-C896 | P-DIP-40 | | Note: Extended temperature range − 40 °C to 110 °C (SAH-C502) on request. # Pin Configuration **Logic Symbol** ## Pin Definitions and Functions | Symbol | Pin N | umber | I/O*) | Function | | | |-------------|----------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | P-LCC-44 | P-DIP-40 | 7 | | | | | P1.7 – P1.0 | 9-2 | 8–1 | | Port 1 is a bidirectional I/O port with internal pull-up resistors. Port 1 pins that have 1s written to them are pulled high by the internal pull-up resistors, and in that state can be used as inputs. As inputs, port 1 pins being externally pulled low will source current (I <sub>IL</sub> , in the DC characteristics) because of the internal pull-up resistors. Port 1 also contains the timer 2 pins as secondary function. 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 1, as follows: | | | | | 2 3 | 1 2 | | P1.0 T2 Input to counter 2 P1.1 T2EX Capture - Reload trigger of timer 2 / Up-Down count | | | <sup>\*)</sup> I = Input O = Output # Pin Definitions and Functions (cont'd) | Symbol | Pin N | umber | I/O*) | Function | | | | |-------------|-----------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | | P-LCC-44 | P-DIP-40 | 1 | | | | | | P3.0 – P3.7 | 11, 13–19 | 10–17 | VO | Port 3 is a bidirectional I/O port with internal pull-up resistors. Port 3 pins that have 1s written to them are pulled high by the internal pull-up resistors, and in that state can be used as inputs. As inputs, port 3 pins being externally pulled low will source current ( $I_{\rm iL}$ , in the DC characteristics) because of the internal pull-up resistors. Port 3 also contains the interrupt, timer, serial port 0 and external memory strobe pins that are used by various options. 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 3, as follows: | | | | | | 11 | 10 | | P3.0 R×D receiver data input (asynchronous) or data input/ output (synchronous) of serial interface 0 | | | | | | 13 | 11 | | P3.1 T×D transmitter data output (asynchronous) or clock output (synchronous) of the serial interface 0 | | | | | | 14 | 12 | | P3.2 INTO interrupt 0 input/timer 0 gate control | | | | | | 15 | 13 | | P3.3 INT1 interrupt 1 input/timer 1 gate control | | | | | | 16 | 14 | | P3.4 T0 counter 0 input | | | | | | 17 | 15 | | | | | | | | 1 | - | | | | | | | | 18 | 16 | | P3.6 WR the write control signal latches the data byte from port 0 into the external data memory | | | | | | 19 | 17 | | P3.7 RD the read control signal enables the external data memory to port 0 | | | | | XTAL2 | 20 | 18 | _ | XTAL2 | | | | | | | | | Output of the inverting oscillator amplifier | | | | <sup>\*)</sup>I = Input O = Output ## Pin Definitions and Functions (cont'd) | Symbol | Pin N | umber | I/O*) | Function | | | |-------------|----------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | P-LCC-44 | P-DIP-40 | | | | | | XTAL1 | 21 | 19 | - | Input to the inverting oscillator amplifier and input to the internal clock generator circuits. To drive the device from an external clock source, XTAL1 should be driven, while XTAL2 is left unconnected. There are no requirements on the duty cycle of the external clock signal, since the input to the internal clocking circuitry is divided down by a divide-by-two flip-flop. Minimum and maximum high and low times as well as rise fall times specified in the AC characteristics must be observed. | | | | P2.0 – P2.7 | 24–31 | 21–28 | VO | is a bidirectional I/O port with internal pull-up resistors. Port 2 pins that have 1s written to them are pulled high by the internal pull-up resistors, and in that state can be used as inputs. As inputs, port 2 pins being externally pulled low will source current ( <i>I</i> <sub>IL</sub> , in the DC characteristics) because of the internal pull-up resistors. 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 pull-up 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. | | | | PSEN | 32 | 29 | 0 | The Program Store Enable output is a control signal that enables the external program memory to the bus during external fetch operations. It is activated every six oscillator periods except during external data memory accesses. Remains high during internal program execution. | | | <sup>\*)</sup> I = Input O = Output # Pin Definitions and Functions (cont'd) | Symbol | Pin N | umber | I/O*) | Function | | | |------------------------------|------------------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | P-LCC-44 | P-DIP-40 | | | | | | RESET | 10 | 9 | 1 | <b>RESET</b> A high level on this pin for two machine cycles while the oscillator is running resets the device. An internal diffused resistor to $V_{\rm SS}$ permits power-on reset using only an external capacitor to $V_{\rm CC}$ . | | | | ALE | 33 | 30 | 0 | The Address Latch Enable output is used for latching the low-byte of the address into external memory during normal operation. It is activated every six oscillator periods except during an external data memory access. | | | | ĒĀ | 35 | 31 | I | External Access Enable When held at high level, instructions are fetched from the internal ROM (SAB-C502-2R only) when the PC is less than 4000 <sub>H</sub> . When held at low level, the SAB-C502 fetches all instructions from external program memory. For the SAB-C502-L this pin must be tied low. | | | | P0.0 – P0.7 | 43–36 | 39–32 | I/O | Port 0 is an 8-bit open-drain bidirectional I/O port. Port 0 pins that have 1s written to them float, and in that state can be used as high-impedance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external program or data memory. In this application it uses strong internal pull-up resistors when issuing 1s. Port 0 also outputs the code bytes during program verification in the SAB-C502-2R. External pull-up resistors are required during program verification. | | | | $\overline{V_{\mathtt{SS}}}$ | 22 | 20 | - | Circuit ground potential | | | | $\overline{V_{\text{CC}}}$ | 44 | 40 | - | Supply terminal for all operating modes | | | | N.C. | 1, 12,<br>23, 34 | _ | _ | No connection | | | <sup>\*)</sup> I = Input O = Output #### **Functional Description** The SAB-C502 is fully compatible to the standard 8051 microcontroller family. It is compatible with the SAB 80C52. While maintaining all architectural and operational characteristics of the SAB 80C52 the SAB-C502 incorporates some enhancements in the Timer2 and Fail Save Mechanism Unit. Figure 1 shows a block diagram of the SAB-C502. Figure 1 Block Diagram of the SAB-C502 #### CPU The SAB-C502 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 % three-byte instructions. With a 12 MHz crystal, 58 % of the instructions execute in 1.0 $\mu$ s (18 MHz : 667 ns). #### **Special Function Register PSW** | | MSB | | | | | | | LSB | | |-----------------------|-----|----|----|-----|-----|----|----|-----|--| | Bit No | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Addr. D0 <sub>H</sub> | CY | AC | F0 | RS1 | RS0 | OV | F1 | Р | | | Bit | | Function | | | | | |-----|------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | CY | Carry Flag | | | | | | | AC | | Auxiliary Carry Flag (for BCD operations) | | | | | | F0 | | General Purpose Flag | | | | | | RS1 | RS0 | Register Bank select control bits | | | | | | 0 | 0 | Bank 0 selected, data address 00 <sub>H</sub> - 07 <sub>H</sub> | | | | | | 0 | 1 | Bank 1 selected, data address 08H - 0FH | | | | | | 1 | 0 | Bank 2 selected, data address 10 <sub>H</sub> - 17 <sub>H</sub> | | | | | | 1 | 1 | Bank 3 selected, data address 18 <sub>H</sub> - 1F <sub>H</sub> | | | | | | ov | | Overflow Flag | | | | | | F1 | | General Purpose Flag | | | | | | P | | Parity Flag. Set/cleared by hardware each instruction cycle to indicate an odd/even number of "one" bits in the accumulator, i.e. even parity. | | | | | Reset value of PSW is 00H. #### **Special Function Registers** All registers, except the program counter and the four general purpose register banks, reside in the special function register area. The 36 special function register (SFR) include pointers and registers that provide an interface between the CPU and the other on-chip peripherals. There are also 128 directly addressable bits within the SFR area All SFRs are listed in **table 1**, **table 2** and **table 3**. In **table 1** they are organized in numeric order of their addresses. In **table 2** they are organized in groups which refer to the functional blocks of the SAB-C502. **Table 3** illustrates the contents of the SFRs. Table 1 Special Function Register in Numeric Order of their Addresses | Address | Register | Contents after Reset | Address | Register | Contents after Reset | |-----------------|------------------|-------------------------------------|-----------------|----------|-------------------------| | 80 <sub>H</sub> | P0 <sup>1)</sup> | FF <sub>H</sub> | 98 <sub>H</sub> | SCON 1) | 00H | | 81 <sub>H</sub> | SP | 07H | 99H | SBUF | XXH <sup>2)</sup> | | 82 <sub>H</sub> | DPL | 00H | 9A <sub>H</sub> | reserved | XXH 2) | | 83H | DPH | 00H | 9B <sub>H</sub> | reserved | XXH <sup>2)</sup> | | 84 <sub>H</sub> | reserved | '' | 9CH | reserved | XXH 2) | | 85H | reserved | | 9DH | reserved | XXH 2) | | 86H | WDTREL | 00 <sub>H</sub> | 9EH | reserved | XXH 2) | | 87 <sub>H</sub> | PCON | 000X0000B <sup>2)</sup> | 9FH | reserved | XXH <sup>2)</sup> | | 88 <sub>H</sub> | TCON 1) | 00 <sub>H</sub> | A0 <sub>H</sub> | P2 1) | FFH | | 89 <sub>H</sub> | TMOD | 00H | A1H | reserved | XXH <sup>2)</sup> | | 8AH | TLO | 00H | A2H | reserved | XXH 2) | | 8BH | TL1 | 00H | A3H | reserved | XXH <sup>2)</sup> | | 8CH | TH0 | 00H | A4H | reserved | XXH <sup>2)</sup> | | 8DH | TH1 | 00H | A5H | reserved | XXH 2) | | 8EH | reserved | XXH <sup>2)</sup> | A6H | reserved | XXH 2) | | 8FH | reserved | XXH <sup>2)</sup> | A7H | reserved | XXH <sup>2)</sup> | | 90H | P1 1) | FFH | A8 <sub>H</sub> | IE 1) | 0X000000B <sup>2)</sup> | | 91 <sub>H</sub> | XPAGE | 00H | A9H | reserved | XXH <sup>2)</sup> | | 92 <sub>H</sub> | DPSEL | XXXXX000 <sub>B</sub> <sup>2)</sup> | AAH | SRELL | 0D9 <sub>H</sub> | | 93H | reserved | XXH <sup>2)</sup> | AB <sub>H</sub> | reserved | XXH <sup>2)</sup> | | 94 <sub>H</sub> | XCON | 0F8 <sub>H</sub> | ACH | reserved | XXH <sup>2)</sup> | | 95 <sub>H</sub> | reserved | XXH <sup>2)</sup> | $AD_{H}^{\cap}$ | reserved | XXH 2) | | 96 <sub>H</sub> | reserved | XXH <sup>2)</sup> | AEH | reserved | XXH 2) | | 97 <sub>H</sub> | reserved | XXH <sup>2)</sup> | AFH | reserved | XXH 2) | <sup>1):</sup> Bit-addressable Special Function Register <sup>2):</sup> X means that the value is indeterminate and the location is reserved Table 1 Special Function Register in Numeric Order of their Addresses (cont'd) | Address | Register | Contents after Reset | Address | Register | Contents after Reset | |-----------------|-------------------|--------------------------------------|-----------------|-------------|-------------------------------| | B0 <sub>H</sub> | P3 1) | FFH | D8 <sub>H</sub> | BAUD | 0XXXXXXX <sub>B</sub> 2) | | B1H | SYSCON | XXXXXXX01 <sub>B</sub> <sup>2)</sup> | D9 <sub>H</sub> | reserved | XXH <sup>2)</sup> | | B2H | reserved | XXH <sup>2)</sup> | DA <sub>H</sub> | reserved | XXH 2) | | В3 <sub>Н</sub> | reserved | XXH 2) | DB <sub>H</sub> | reserved | XXH 2) | | B4H | reserved | XXH 2) | DCH | reserved | XXH 2) | | B5H | reserved | XXH 2) | DDH | reserved | XXH <sup>2)</sup> | | N6H | reserved | XXH 2) | DEH | reserved | XXH 2) | | B7H | reserved | XXH 2) | DFH | reserved | XXH <sup>2)</sup> | | B8 <sub>H</sub> | IP 1) | XX000000 <sub>B</sub> 2) | E0 <sub>H</sub> | ACC 1) | 00H | | в9 <sub>Н</sub> | reserved | XX <sub>H</sub> <sup>2)</sup> | E1H | reserved | XX <sub>H</sub> <sup>2)</sup> | | BAH | SRELH | XXXXXX11 <sub>B<sup>2)</sup></sub> | E2 <sub>H</sub> | reserved | XXH <sup>2)</sup> | | ввн | reserved | XXH <sup>2)</sup> | E3 <sub>H</sub> | reserved | XXH <sup>2)</sup> | | всн | reserved | XXH 2) | E4 <sub>H</sub> | reserved | XXH <sup>2)</sup> | | $BD_H$ | reserved | XXH <sup>2)</sup> | E5 <sub>H</sub> | reserved | XXH <sup>2)</sup> | | BEH | reserved | XXH 2) | E6 <sub>H</sub> | reserved | XXH <sup>2)</sup> | | BFH | reserved | XXH <sup>2)</sup> | E7 <sub>H</sub> | reserved | XXH <sup>2)</sup> | | C0H | WDCON 1) | XXXX0000 <sub>B</sub> 2) | E8 <sub>H</sub> | reserved | XXH <sup>2)</sup> | | C1 <sub>H</sub> | reserved | XX <sub>H</sub> <sup>2)</sup> | E9H | reserved | XXH <sup>2)</sup> | | C2 <sub>H</sub> | reserved | XXH 2) | EAH | reserved | XXH <sup>2)</sup> | | СЗН | reserved | XXH <sup>2)</sup> | EBH | reserved | XXH <sup>2)</sup> | | C4 <sub>H</sub> | reserved | XXH <sup>2)</sup> | ECH | reserved | XXH 2) | | C5 <sub>H</sub> | reserved | XXH <sup>2)</sup> | $ED_H$ | reserved | XXH <sup>2)</sup> | | C6 <sub>H</sub> | reserved | XXH <sup>2)</sup> | EEH | reserved | XXH <sup>2)</sup> | | C7 <sub>H</sub> | reserved | XXH <sup>2)</sup> | EFH | reserved | XXH <sup>2)</sup> | | C8 <sub>H</sub> | T2CON 1) | 00 <sub>H</sub> | F0 <sub>H</sub> | <b>B</b> 1) | 00H | | C9H | T2MOD | XXXXXXX0B 2) | F1H | reserved | XXH <sup>2)</sup> | | CAH | RC2L | 00 <sub>H</sub> | F2 <sub>H</sub> | reserved | XXH <sup>2)</sup> | | СВН | RC2H | 00H | F3 <sub>H</sub> | reserved | XXH <sup>2)</sup> | | CCH | TL2 | 00 <sub>H</sub> | F4 <sub>H</sub> | reserved | XXH <sup>2)</sup> | | CDH | TH2 | 00 <sub>H</sub> | F5 <sub>H</sub> | reserved | XXH <sup>2)</sup> | | CEH | reserved | XXH <sup>2)</sup> | F6H | reserved | XXH <sup>2)</sup> | | CFH | reserved | XXH <sup>2)</sup> | F7H | reserved | XXH <sup>2)</sup> | | D0 <sub>H</sub> | PSW <sup>1)</sup> | 00H | F8 <sub>H</sub> | reserved | XX <sub>H</sub> <sup>2)</sup> | | D1 <sub>H</sub> | reserved | XXH <sup>2)</sup> | F9H | reserved | XXH <sup>2)</sup> | | D2H | reserved | XXH <sup>2)</sup> | FAH | reserved | XXH <sup>2)</sup> | | D3 <sub>H</sub> | reserved | XXH <sup>2)</sup> | FB⊣ | reserved | XXH <sup>2)</sup> | | D4 <sub>H</sub> | reserved | XXH <sup>2)</sup> | FC <sub>H</sub> | reserved | XXH <sup>2)</sup> | | D5 <sub>H</sub> | reserved | XXH <sup>2)</sup> | $FD_H$ | reserved | XXH <sup>2)</sup> | | D6 <sub>H</sub> | reserved | XXH <sup>2)</sup> | FEH | reserved | XXH <sup>2)</sup> | | D7H | reserved | XXH 2) | FFH | reserved | XXH <sup>2)</sup> | <sup>1):</sup> Bit-addressable Special Function Register Semiconductor Group <sup>2):</sup> X means that the value is indeterminate and the location is reserved # **SIEMENS** Table 2 Special Function Registers - Functional Blocks | Block | Symbol | Name | Address | Contents after Reset | |---------------------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------| | CPU | ACC<br>B<br>DPH<br>DPL<br>DPSEL<br>PSW<br>SP | E0H <sup>1)</sup> F0H <sup>1)</sup> 83H 82H 92H D0H <sup>1)</sup> | 00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>XXXX X000 B <sup>3)</sup><br>00 <sub>H</sub><br>07 <sub>H</sub> | | | Interrupt<br>System | IE<br>IP | Interrupt Enable Register Interrupt Priority Register | A8H <sup>1)</sup><br>B8H <sup>1)</sup> | XX00 0000 B <sub>3)</sub> | | Ports | P0<br>P1<br>P2<br>P3 | Port 0 Port 1 Port 2 Port 3 | 80 <sub>H</sub> <sup>1)</sup><br>90 <sub>H</sub> <sup>1)</sup><br>A0 <sub>H</sub> <sup>1)</sup><br>B0 <sub>H</sub> <sup>1)</sup> | FF <sub>H</sub><br>FF <sub>H</sub><br>FF <sub>H</sub> | | XRAM | XPAGE<br>XCON<br>SYSCON | Page addr. reg. for XRAM<br>XRAM startaddress (highbyte)<br>XRAM control register | 91 <sub>H</sub><br>94 <sub>H</sub><br>B1 <sub>H</sub> | 00 <sub>H</sub><br>F8 <sub>H</sub><br>XXXX XX01 <sub>B</sub> <sup>3)</sup> | | Serial<br>Channels | PCON <sup>2)</sup> SBUF SCON SRELL SRELH BAUD | Power Control Register Serial Channel Buffer Reg. Serial Channel Control Reg. Baudrate Generator Reloadvalue, Lowbyte Baudrate Generator Reloadvalue, Highbyte Baudrate Generator Enable Bit | 87 <sub>H</sub><br>99 <sub>H</sub><br>98 <sub>H</sub> <sup>1)</sup><br>AA <sub>H</sub><br>BA <sub>H</sub><br>D8 <sub>H</sub> <sup>1)</sup> | 00 <sub>H</sub><br>XX <sub>H<sup>3</sup></sub> )<br>00 <sub>H</sub><br>D9 <sub>H</sub><br>XXXX XX11 <sub>B<sup>3</sup></sub> ) | | Timer 0/<br>Timer 1 | TCON<br>TH0<br>TH1<br>TL0<br>TL1<br>TMOD | Timer 0/1 Control Register Timer 0, High Byte Timer 1, High Byte Timer 0, Low Byte Timer 1, Low Byte Timer Mode Register | 88H <sup>1)</sup><br>8CH<br>8DH<br>8AH<br>8BH<br>89H | 00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub> | | Timer 2 | T2CON<br>T2MOD<br>RC2L<br>RC2H<br>TH2<br>TL2 | Timer 2 Control Register Timer 2 Mode Register Timer 2, Reload Capture Register, Low Byte Timer 2, Reload Capture Register, High Byte Timer 2, High Byte Timer 2, Low Byte | C8 <sub>H</sub> <sup>1)</sup><br>C9 <sub>H</sub><br>CA <sub>H</sub><br>CB <sub>H</sub><br>CD <sub>H</sub><br>CC <sub>H</sub> | 00H<br>00H<br>00H<br>00H<br>XXXX XXX0 B <sub>37</sub> | | Watchdog | WDCON<br>WDTREL | Watchdog Timer Control Register<br>Watchdog Timer Reload Reg. | <b>C0H</b> <sup>1)</sup><br>86H | XXXX 0000B <sup>3)</sup> | | Pow. Sav.<br>Modes | PCON <sup>2</sup> ) | Power Control Register | 87 <sub>H</sub> | 000X 0000B <sub>3</sub> ) | <sup>1):</sup> Bit-addressable special function registers <sup>2):</sup> This special function register is listed repeatedly since some bits of it also belong to other functional blocks. <sup>3):</sup> X means that the value is indeterminate and the location is reserved Table 3 Contents of SFR's, SFR's in Numeric Order | Address | Register | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|----------|-------|-----|-----------------------------------------|--------|----------|--------|----------|-----------------------------------------| | 80 <sub>H</sub> | P0 | | | | | | | | | | 81 <sub>H</sub> | SP | | 1 | T I | l I | 1 | l<br>L | 1 | 1 | | 82 <sub>H</sub> | DPL | | | 1 | I<br>I | 1 | I | T | 1 | | 83H | DPH | | | 1 | l<br>L | I<br>I | 1 | I | I<br>1 | | 86 <sub>H</sub> | WDTREL | | | 1 | I | 1<br> | | <u> </u> | r · · · · · · · · · · · · · · · · · · · | | 87 <sub>H</sub> | PCON | SMOD | PDS | IDLS | | GF1 | GF0 | PDE | IDLE | | 88 <sub>H</sub> | TCON | TF1 | TR1 | TF0 | TR0 | IE1 | IT1 | IE0 | IT0 | | 89 <sub>H</sub> | TMOD | GATE | C/T | M1 | МО | GATE | C/T | M1 | MO | | 8A <sub>H</sub> | TLO | | | | | 1 1 | | <br> | <br> | | 8B <sub>H</sub> | TL1 | | · | 1 | 1 | 1 | | 1 | [ | | 8C <sub>H</sub> | TH0 | | | [<br>[ | 1 | I<br>I | | | 1 | | 8D <sub>H</sub> | TH1 | | | l | | 1 | | <u> </u> | l | | 90H | P1 | | | | | | | | | | 91 <sub>H</sub> | XPAGE | | | r · · · · · · · · · · · · · · · · · · · | | i<br>I | | 1 | I<br>L | | 92 <sub>H</sub> | DPSEL | - | - | <u> </u> | - | <u> </u> | .2 | .1 | .0 | | 94 <sub>H</sub> | XCON | | | | 1 | 1 | | 1 | I | | 98 <sub>H</sub> | SCON | SM0 | SM1 | SM2 | REN | TB8 | RB8 | TI | RI | | 99 <sub>H</sub> | SBUF | | | I | | | | | Y | | A0 <sub>H</sub> | P2 | | | | | | | | | | A8 <sub>H</sub> | ΙE | EA | | ET2 | ES | ET1 | EX1 | ET0 | EX0 | | AAH | SRELL | | | l | | | | | L | | | | | | | bit and byte addressable | |--------|---|--|---|---|--------------------------| | l<br>L | l | | 1 | 1 | not bit addressable | - = reserved Table 3 Contents of SFRs, SFRs in Numeric Order (cont'd) | Address | Register | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|----------|-------|----------|--------|----------|----------|------|--------|--------| | B0 <sub>H</sub> | P3 | | | | | | | | | | B1 <sub>H</sub> | SYSCON | _ | <u> </u> | - | <u> </u> | _ | - | XMAP1 | XMAP0 | | B8 <sub>H</sub> | ΙP | _ | PADC | PT2 | PS | PT1 | PX1 | PT0 | PX0 | | BAH | SRELH | | l L | l<br>I | l<br>t | i | | I<br>L | | | C0H | WDCON | - | - | _ | _ | OWDS | WDTS | WDT | SWDT | | C8 <sub>H</sub> | T2CON | TF2 | EXF2 | RCLK | TCLK | EXEN2 | TR2 | C/T2 | CP/RL2 | | C9 <sub>H</sub> | T2MOD | - | | _ | _ | <u> </u> | _ | _ | DCEN | | CAH | RC2L | | I | 1 | 1 | T T | | ı | 1 | | CBH | RC2H | | 1 | T I | 1 | I | 1 | i<br>I | l | | CCH | TL2 | | 1 | I I | 1 | 1 | 1 | I. | I | | CDH | TH2 | | I . | l | 1 | I I | | 1 | 1 | | D0 <sub>H</sub> | PSW | CY | AC | F0 | RS1 | RS0 | OV | F1 | Р | | D8 <sub>H</sub> | BAUD | BD | - | - | <u> </u> | _ | _ | _ | _ | | EOH | ACC | | | | | | | | | | F0 <sub>H</sub> | В | | | | | | | | | | | | | | | | | bit and byte addressable | |---|-----|--|---|---|---|---|--------------------------| | I | - [ | | + | 1 | 1 | 1 | not bit addressable | – ≃ reserved #### Timer/Counter 0 and 1 Timer/Counter 0 and 1 can be used in four operating modes as listed in table 4: Table 4 Timer/Counter 0 and 1 Operating Modes | Mode | Description | | TM | OD | | Inpu | it Clock | |------|--------------------------------------------------------------------------------------------|------|-----|----|----|----------------------------------|---------------------------------| | | | Gate | C/T | M1 | МО | internal | external<br>(max) | | 0 | 8-bit timer/counter with a divide-by-32 prescaler | Х | Х | 0 | 0 | $f_{\rm OSC}/_{12\times32}$ | $f_{\rm OSC}/_{\rm 24\times32}$ | | 1 | 16-bit timer/counter | Х | Х | 0 | 1 | $f_{\rm OSC}/_{12}$ | $f_{\rm OSC}/_{24}$ | | 2 | 8-bit timer/counter with<br>8-bit auto-reload | X | Х | 1 | 0 | f <sub>OSC</sub> / <sub>12</sub> | fosc/24 | | 3 | Timer/counter 0 used as one<br>8-bit timer/counter and one<br>8-bit timer<br>Timer 1 stops | Х | Х | 1 | 1 | fosc/12 | fosc/24 | In "timer" function ( $C/\overline{T} = '0'$ ) the register is incremented every machine cycle. Therefore the count rate is $f_{OSC}/12$ . In "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_{\rm OSC}/24$ . External inputs $\overline{\rm INT0}$ and $\overline{\rm INT1}$ (P3.2, P3.3) can be programmed to function as a gate to facilitate pulse width measurements. **Figure 2** illustrates the input clock logic. Figure 2 Timer/Counter 0 and 1 Input Clock Logic # **SIEMENS** #### Timer 2 Timer 2 is a 16-bit Timer/Counter with up/down count feature. It can operate either as timer or as an event counter which is selected by bit $C/\overline{12}$ (T2CON.1). It has three operating modes as shown in table 5. Table 5 Timer/Counter 2 Operating Modes | | T: | 2CON | | T2MOD | T2CON | | | Input | Clock | |--------------------------------|----------------------|------------|-----|-------|-------|---------------|-----------------------------------------------------------------------------------------|----------------------|-----------------------------| | Mode | R×CLK<br>or<br>T×CLK | CP/<br>RL2 | TR2 | DCEN | EXEN | P1.1/<br>T2EX | Remarks | internal | external<br>(P1.0/T2) | | 16-bit<br>Auto- | С | 0 | 1 | 0 | 0 | Х | reload upon<br>overflow | | | | reload | 0 | 0 | 1 | 0 | 1 | ↓ ↓ | reload trigger<br>(falling edge) | $f_{\rm OSC}/12$ | max $f_{\rm OSC}/24$ | | | 0 | 0 | 1 | 1 | X | 0 | Down counting | | | | | 0 | 0 | 1 | 1 | X | 1 | Up counting | | | | 16-bit<br>Cap-<br>ture | 0 | 1 | 1 | x | 0 | <b>x</b> | 16-bit Timer/<br>Counter (only<br>up-counting)<br>capture TH2,<br>TL2 → RC2H,<br>RC2L | f <sub>osc</sub> /12 | max<br>f <sub>osc</sub> /24 | | Baud<br>Rate<br>Gene-<br>rator | 1 | X | 1 | x | 0 | <b>X</b> | no overflow<br>interrupt<br>request (TF2)<br>extra external<br>interrupt<br>("Timer 2") | fosc/2 | max fosc/24 | | off | Х | Х | 0 | X | Х | Х | Timer 2 stops | _ | _ | Note: ↓ = → falling edge #### Serial Interface (USART) The serial port is full duplex and can operate in four modes (one synchronous mode, three asynchronous modes) as illustrated in **table 6**. **Figure 3** illustrates the block diagram of Baudrate generation for the serial interface. Table 6 USART Operating Modes | 11-4- | SC | ON | Baudrate | Description | |-------|-----|-----|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------| | Mode | SMO | SM1 | | | | 0 | 0 | 0 | f <sub>osc</sub> /12 | Serial data enters and exits through R×D. T×D outputs the shift clock. 8-bit are transmitted/received (LSB first) | | 1 | 0 | 1 | Timer 1/2 overflow rate or Baudrate Generator | 8-bit UART<br>10 bits are transmitted (through T×D) or<br>received (R×D) | | 2 | 1 | 0 | f <sub>osc</sub> /32 or f <sub>osc</sub> /64 | 9-bit UART<br>11 bits are transmitted (T×D) or<br>received (R×D) | | 3 | 1 | 1 | Timer 1/2 overflow rate<br>or<br>Baudrate Generator | 9-bit UART<br>Like mode 2 except the variable<br>baud rate | Figure 3 Block Diagram of Baud Rate Generation for Serial Interface ■ 8235605 0061289 OT1 **■** The possible baudrate can be calculated using the formulas given in table 7. Table 7 **Baudrates** | Baud Rate<br>derived from | Interface Mode | Baudrate | |------------------------------------------------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------| | Oscillator | 0<br>2 | $f_{\rm OSC}/12$ (2 <sup>SMOD</sup> × $f_{\rm OSC}$ )/64 | | Timer 1 (16-bit timer)<br>(8-bit timer with<br>8-bit autoreload) | 1,3<br>1,3 | $(2^{\text{SMOD}} \times \text{timer 1 overflow rate})/32$<br>$(2^{\text{SMOD}} \times f_{\text{OSC}})/(32 \times 12 \times (256\text{-TH1}))$ | | Timer 2 | 1,3 | $f_{\rm OSC}/(32 \times (65536-(RC2H, RC2L))$ | | Baudrate<br>Generator | 1,3 | $(2^{\text{SMOD}} \times f_{\text{OSC}})/(64 \times (2^{10}\text{-SREL}))$ | The internal baudrate generator consists of a free running 10-bit timer with $f_{\rm OSC}/2$ input frequency. The internal baudrate generator is selected by setting bit BD in SFR BAUD. #### Additional On-Chip RAM - XRAM The SAB-C502 contains another 256byte of On-Chip RAM additional to the 256bytes internal RAM. This RAM is called XRAM ('eXtended RAM') in this document. The additional ON-Chip RAM is logically located in the external data memory range. The highbyte of the XRAM address range startaddress is programmable by SFR XCON (94 $_{\rm H}$ ). The reset value of XCON is 0F8 $_{\rm H}$ (that is, XRAM address range F800H $_{\rm H}$ ... F8FF $_{\rm H}$ ). The contents of the XRAM is not affected by a reset. After power up the contents is undefined, while it remains unchanged during and after reset as long as the power supply is not turned off. The XRAM is controlled by SFR SYSCON as shown in **table 8**. Table 8 Control of the XRAM | SFR S | YSCON | Description | |-------|-------|-----------------------------------------------------------------------------------------------------| | XMAP1 | XMAP0 | | | 0 | 1 | Resetvalue. Access to XRAM is disabled. When cleared it car be set again only by a reset | | 0 | 0 | XRAM enabled | | 1 | 0 | XRAM enabled. The signals $\overline{RD}$ and $\overline{WR}$ are activated during accesses to XRAM | Because of the XRAM is used in the same way as external data memory the same instruction types must be used for accessing the XRAM. A general overview gives **table 9**. Table 9 Accessing the XRAM | Instruction using | Instruction | Remarks | |----------------------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DPTR | MOVX A @DPTR<br>MOVX @ DPTR,A | Normally the use of these instructions would use a physically external memory. However, in the SAB-C502 the XRAM is accessed if it is enabled. | | R0/R1<br>(page mode) | MOVX A, @Ri<br>MOVX@Ri,A | Normally Port 2 serves as page register. However, the distinction, whether Port 2 is as general purpose I/O or as "page address" is made by the external design. Hence a special SFR XPAGE is implemented the serve the same function for the XRAM as Port 2 for external data memory. | **Note:** When writing the page address (in page mode) at Port2 the value is also written in XPAGE. However when writing XPAGE the value at PORT2 is not changed! The behaviour of Port0/Port2 and RD/WR during MOVX accesses is shown in table 10. ■ 8235605 0061291 75T **■** Table 10 Behaviour of P0/P2 and RD/WR during MOVX Accesses | Beh | avi | our | of P0/P2 and | RD/WR duri | ng MOVX Acces | sses | |---------------|--------------|-----|-------------------------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------| | | | × | a) P0/P2 → Bus<br>b) RD/WR<br>active<br>c) ext. memory<br>is used | a) P0/P2 → Bus<br>b) RD/WR<br>active<br>c) ext. memory<br>is used | a) P0 → Bus P2 → I/O b) RD/WR active c) ext. memory is used | a) P0 → Bus P2 → I/O b) RD/WR active c) ext. memory is used | | <u>EA</u> = 1 | XMAP1, XMAP0 | 10 | a) P0/P2 → Bus<br>b) RD/WR<br>active<br>c) ext. memory<br>is used | a) P0/P2 → Bus<br>(WR-Data only)<br>b) RD/WR<br>active<br>c) XRAM is used | a) P0 → Bus P2 → I/O b) RD/WR active c) ext. memory is used | a) P0 → Bus<br>(WR-Data only)<br>P2 → I/O<br>b) RD/WR<br>active<br>c) XRAM is used | | | | 00 | a) P0/P2 → Bus<br>b) RD/WR<br>active<br>c) ext. memory<br>is used | a) P0/P2 → I/O b) RD/WR inactive c) XRAM is used | a) P0 → Bus P2 → I/O b) RD/WR active c) ext. memory is used | a) P0/P2 → I/O<br>b) RD/WR<br>inactive<br>c) XRAM is used | | | | 1X | a) PO/P2 → Bus<br>b) RD/WR<br>active<br>c) ext. memory<br>is used | a) P0/P2 → Bus b) RD/WR active c) ext. memory is used | a) P0 → Bus<br>P2 → I/O<br>b) RD/WR<br>active<br>c) ext. memory<br>is used | a) P0 → Bus<br>P2 → I/O<br>b) RD/WR<br>active<br>c) ext. memory<br>is used | | <u>EA</u> = 0 | XMAP1, XMAP0 | 10 | a) PO/P2 → Bus b) RD/WR active c) ext. memory is used | a) P0/P2 → Bus (WR-Data only) b) RD/WR active c) XRAM is used | a) P0 → Bus P2 → I/O b) RD/WR active c) ext. memory is used | a) P0 → Bus (WR-Data only) P2 → I/O D) RD/WR Inactive c) XRAM is used (WR-Data only) P2 → I/O D) RD/WR active c) XRAM is used | | | | 00 | a) PO/P2 → Bus b) RD/WR active c) ext. memory is used | a) PO/P2 → Bus (WR-Data only) b) RD/WR inactive c) XRAM is used | a) P0 → Bus P2 → I/O b) RD/WR active c) ext. memory is used | a) P0 → Bus (WR-Data only) P2 → I/O b) RD/WR inactive c) XRAM is used | | | | | DPTR outside<br>XRAM address<br>range<br>(DPH ≠ XCON) | DPTR within XRAM address range (DPH = XCON) | XPAGE outside<br>XRAM addr. page<br>range<br>(XPAGE ≠ XCON) | XPAGE within XHAM addr. page range (XPAGE = XCON) | | | | | XAOW | @DPTR | MOVX | @<br>B. | modes compatible to the standard 8051-family #### Eight Datapointers for Faster External Bus Access The SAB-C502 contains a set of eight 16-bit-Datapointer (DPTR) from which the actual DPTR can be selected. This means that the user's program may keep up to eight 16-bit addresses resident in these registers, but only one register at the time is selected to be the datapointer. Thus the DPTR in turn is accessed (or selected) via indirect addressing. This indirect addressing is done through a special function register (SFR) called DPSEL (data pointer select register, Bits 0 to 2). All instructions of the SAB-C502 which handle the DPTR therefore affect only one of the eight pointers which is addressed by DPSEL at that very moment. A 3-bit field in SFR DPSEL points to the currently used DPTRx: | DPS | EL | | selected<br>DPTR | |-----|----|----|------------------| | .2 | .1 | .0 | | | 0 | 0 | 0 | DPTR 0 | | 0 | 0 | 1 | DPTR 1 | | 0 | 1 | 0 | DPTR 2 | | 0 | 1 | 1 | DPTR 3 | | 1 | 0 | 0 | DPTR 4 | | 1 | 0 | 1 | DPTR 5 | | 1 | 1 | 0 | DPTR 6 | | 1 | 1 | 1 | DPTR 7 | #### Interrupt System The SAB-C502 provides 6 interrupt sources with two priority levels. **Figure 4** gives a general overview of the interrupt sources and illustrates the request and control flags. Figure 4 Interrupt Request Sources Table 11 Interrupt Sources and their Corresponding Interrupt Vectors | Source (Request Flags) | Vector | Vector Address | |------------------------|-----------------------|-------------------| | IE0 | External interrupt 0 | 0003 <sub>H</sub> | | TF0 | Timer 0 interrupt | 000BH | | IE1 | External interrupt 1 | 0013 <sub>H</sub> | | TF1 | Timer 1 interrupt | 001B <sub>H</sub> | | RI + TI | Serial port interrupt | 0023 <sub>H</sub> | | TF2 + EXF2 | Timer 2 interrupt | 002B <sub>H</sub> | A low-priority interrupt can itself be interrupted by a high-priority interrupt, but not by another lowpriority interrupt. A high-priority interrupt cannot be interrupted by any other interrupt source. If two requests of different priority level are received simultaneously, the request of higher priority is serviced. If requests of the same priority are received simultaneously, an internal polling sequence determines which request is serviced. Thus within each priority level there is a second priority structure determined by the polling sequence as shown in table 12. Table 12 Interrupt Priority-within-Level | Interrupt So | Priority | | |-----------------------|-------------|------| | External Interrupt 0, | 1E0 | High | | Timer 0 Interrupt, | TF0 | | | External Interrupt 1, | IE1 | ↓ | | Timer 1 Interrupt, | TF1 | | | Serial Channel, | RI or TI | | | Timer 2 Interrupt, | TF2 or EXF2 | Low | #### Fail Safe Mechanisms The SAB-C502 offers enhanced fail safe mechanisms, which allow an automatic recovery from software upset or hardware failure. - 1) Watchdog Timer (15 bit, WDT) - 2) Oscillator Watchdog (OWD) #### 1) Watchdog Timer (WDT) The Watchdog Timer in the SAB-C502 is a 15-bit timer, which is incremented by a count rate of either $f_{\text{CYCLE}}/22$ or $f_{\text{CYCLE}}=f_{\text{OSC}}/12$ ). That is, the machine clock is divided by a series of arrangement of two prescalers, a divide-by-two and a divide-by-16 prescaler. The latter is enabled by setting bit WDTREL.7. Figure 5 shows the block diagram of the programmable Watchdog Timer. Figure 5 Block Diagram of the Programmable Watchdog Timer #### - Starting and refreshing the WDT **Table 13** gives an overview how to start and refresh the WDT. The mentioned bits are located in SER WDCON Table 13 Starting and Refreshing the WDT | Function | E | xample | Remarks | | | |---------------|--------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Starting WD | SETB | SWDT | Cannot be stopped during active mode of the device. WDT is halted during idle mode, power down mode or the oscillator watchdog reset is active. | | | | Refreshing WD | SETB<br>SETB | WDT<br>SWDT | Double instruction sequence (setting bit WDT and SWDT consecutively) to increase system security. | | | #### Watchdog reset and watchdog status flag (WDTS) If the software fails to clear the watchdog in time, an internally generated watchdog reset is entered at the counter state $7FFC_H$ . The duration of the reset signal then depends on the prescaler selection (either 8 or 128 cycles). This internal reset differs from an external one in so far as the Watchdog Timer is not disabled and bit WDTS (SFR WDCON) is set. The WDTS is a flip-flop, which is set by a Watchdog Timer reset and can be cleared by an external hardware reset. Bit WDTS allows the software to examine from which source the reset was activated. The bit WDTS can also be cleared by software. #### 2) Oscillator Watchdog (OWD) The OWD consists of an internal RC oscillator which provides the reference frequency for the comparison with the frequency of the on-chip oscillator. Figure 6 shows the block diagram of the oscillator watchdog unit while table 14 shows the effect when the OWD becomes active/inactive. Note: The OWD is always enabled! Figure 6 Functional Block Diagram of the Oscillator Watchdog Table 14 Effects of the OWD | Conditions | Effect | |------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | $f_{\rm OSC} < f_{\rm RC}/5$ | Switch input of internal clock system to RC oscillator output Activating internal reset at the same time (reset sequence is clocked by RC-oscillator). Exception from effects of a Hardware Reset: Watchdog Timer Status Flag, WDTS is not reset Oscillator Watchdog Status Flag, OWDS is set | | $f_{\rm OSC} > f_{\rm RC}/5$ | Input of internal clock system is $f_{\rm OSC}/2$ . When failure condition ( $f_{\rm OSC} < f_{\rm RC}/5$ ) disappears the part executes a final reset phase of typ. 1 ms in order to allow the external oscillator to stabilize. | # 8235605 0061298 004 #### Fast Internal Reset after Power-On The SAB-C502 can use the oscillator watchdog unit for a fast internal reset procedure after poweron. Normally members of the 8051 family enter their default reset state not before the on-chip oscillator starts. The reason is that the external reset signal must be internally synchronized and processed in order to bring the device into the correct reset state. Especially if a crystal is used the start up timed of the oscillator is relatively long (typ. 1 ms). During this time period the pins have an undefined state which could have severe effects e.g. to actuators connected to port pins. In the SAB-C502 the oscillator watchdog unit avoids this situation. After power-on the oscillator watchdog's RC oscillator starts working within a very short start-up time (typ. less than 2 $\mu$ s). In the following the watchdog circuitry detects a failure condition for the on-chip oscillator this has not yet started (a failure is always recognized if the watchdog's RC oscillator runs faster than the on-chip oscillator). As long as this condition is valid the watchdog uses the RC oscillator output as a clock source for the chip rather than the on-chip oscillator's 16 output. This allows correct resetting of the part and brings also all ports to the defined state. Delay between power-on and correct reset state: Typ: 18 μs Max: 34 μs #### **Power Saving Modes** Two power down modes are available, the Idle Mode and the Power Down Mode. The bits PDE, PDS and IDLE, IDLS select the Power Down mode or the idle mode, respectively. If the Power Down mode and the idle mode are set at the same time, Power Down takes precedence. Table 15 gives a general overview of the power saving modes. Table 15 **Entering and Leaving the Power Saving Modes** | Mode | Entering<br>Example | Leaving by | Remarks | |--------------------|----------------------------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Idle mode | ORL PCON, #01H<br>ORL PCON, #20H | <ul><li>enabled interrupt</li><li>Hardware Reset</li></ul> | CPU is gated off CPU status registers maintain their data. Peripherals are active Double instruction sequence | | Power Down<br>Mode | ORL PCON, #02H<br>ORL PCON, #40H | Hardware Reset | Oscillators are stopped. Contents of on-chip RAM and SFR's are maintained (leaving Power Down Mode means redefinition of SFR's contents.) Double instruction sequence | In the Power Down mode of operation, $V_{\rm CC}$ can be reduced to minimize power consumption. It must be ensured, however, that $V_{\rm CC}$ is not reduced before the Power Down mode is invoked, and that $V_{\rm CC}$ is restored to its normal operating level, before the Power Down mode is terminated. The reset signal that terminates the Power Down mode also restarts the oscillator. The reset should not be activated before $V_{ m CC}$ is restored to its normal operating level and must be held active long enough to allow the oscillator to restart and stabilize (similar to power-on reset). ### **Absolute Maximum Ratings** | Ambient temperature under bias (T <sub>A</sub> ) | 40 °C to + 85 °C | |------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------| | Storage temperature $(T_{ST})$ | 65 °C to + 150 °C | | Voltage on $V_{\rm CC}$ pins with respect to ground ( $V_{\rm SS}$ )<br>Voltage on any pin with respect to ground ( $V_{\rm SS}$ ) | 0.5 V to 6.5 V<br>0.5 V to V <sub>CC</sub> + 0.5 V | | Input current on any pin during overload condition Absolute sum of all input currents during overload condition | 10 mA to + 10 mA<br>100 mA | | Power dissipation | TBD | **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_{\rm IN} > V_{\rm CC} \text{ or } V_{\rm IN} < V_{\rm SS})$ the Voltage on $V_{\rm CC}$ pins with respect to ground $(V_{\rm SS})$ must not exceed the values defined by the absolute maximum ratings. ### **DC Characteristics** $V_{\rm CC} = 5 \text{ V} + 10 \%, -15 \%; V_{\rm SS} = 0 \text{ V};$ $T_{\rm A}$ = 0 to + 70 °C for the SAB-C502 $T_{\rm A}$ = - 40 to + 85 °C for the SAF-C502 | Parameter | Symbol | Lim | t Values | Unit | Test Condition | | |--------------------------------------------------------------|-------------------|------------------------------|------------------------------|------|------------------------------------------------------------------------------------|--| | | | min. | max. | | | | | Input low voltage (except EA, RESET) | $V_{IL}$ | - 0.5 | 0.2 V <sub>CC</sub><br>- 0.1 | V | _ | | | Input low voltage (EA) | $V_{IL1}$ | - 0.5 | 0.2 V <sub>CC</sub><br>- 0.3 | ٧ | _ | | | Input low voltage (RESET) | $V_{\rm IL2}$ | -0.5 | 0.2 V <sub>CC</sub><br>+ 0.1 | ٧ | _ | | | Input high voltage<br>(except EA, RESET, XTAL1) | $V_{IH}$ | 0.2 V <sub>CC</sub><br>+ 0.9 | $V_{\rm CC} + 0.5$ | V | _ | | | Input high voltage to XTAL1 | V <sub>IH1</sub> | 0.7 V <sub>cc</sub> | $V_{\rm CC} + 0.5$ | V | | | | Input high voltage to RESET, EA | $V_{\rm iH2}$ | 0.6 V <sub>CC</sub> | $V_{\rm CC} + 0.5$ | ٧ | _ | | | Output low voltage (ports 2, 3) | $V_{OL}$ | _ | 0.45 | V | $I_{\rm Ol} = 1.6 \rm mA^{1)}$ | | | Output low voltage<br>(port 0, ALE, PSEN) | $V_{OL1}$ | _ | 0.45 | V | $I_{\rm OL} = 3.2 {\rm mA}^{1)}$ | | | Output high voltage (ports 2, 3) | $V_{OH}$ | 2.4<br>0.9 V <sub>CC</sub> | - | ٧ | $I_{\rm OH} = -80~\mu{\rm A}$<br>$I_{\rm OH} = -10~\mu{\rm A}$ | | | Output high voltage (port 0 in external bus mode, ALE, PSEN) | $V_{OH1}$ | 2.4<br>0.9 V <sub>cc</sub> | - | V | $I_{\text{OH}} = -800 \mu\text{A}^{2)},$<br>$I_{\text{OH}} = -80 \mu\text{A}^{2)}$ | | | Logic 0 input current (ports 1, 2, 3) | $I_{IL}$ | - 10 | - 50 | μΑ | $V_{\rm IN} = 0.45 \ { m V}$ | | | Logical 1-to-0 transition current (ports 1, 2, 3) | $I_{TL}$ | - 65 | - 650 | μА | V <sub>IN</sub> = 2 V | | | Input leakage current<br>(port 0, EA, P1) | $I_{LI}$ | _ | ± 1 | μА | $0.45 < V_{\rm IN} < V_{\rm CC}$ | | | Pin capacitance | $C_{IO}$ | _ | 10 | pF | $f_{\rm C}$ = 1 MHz,<br>$T_{\rm A}$ = 25 °C | | | Power supply current: | | | | | | | | Active mode, 12 MHz <sup>7)</sup> | $I_{\rm CC}$ | _ | 23.3 | mA | $V_{\rm CC} = 5 \text{ V},^{4)}$ | | | ldle mode, 12 MHz <sup>7)</sup> | $I_{\mathtt{CC}}$ | _ | 7.4 | mA | $V_{\rm CC} = 5 \text{ V}^{(5)}$ | | | Active mode, 20 MHz <sup>7)</sup> | $I_{\text{CC}}$ | _ | 33.9 | mA | $V_{\rm CC} = 5 \rm V^{(4)}$ | | | ldle mode, 20 MHz <sup>7)</sup> | $I_{CC}$ | - | 10.6 | mA | $V_{\rm CC} = 5 \text{ V},^{5)}$ | | | Power Down Mode | $I_{PD}$ | _ | 50 | μA | $V_{\rm CC}$ = 2 5.5 V,3) | | - Capacitive loading on ports 0 and 2 may cause spurious noise pulses to be superimposed on the V<sub>CL</sub> of ALE and port 3. 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 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. - <sup>2)</sup> Capacitive loading on ports 0 and 2 may cause the $V_{\rm OH}$ on ALE and $\overline{\rm PSEN}$ to momentarily fall bellow the 0.9 $V_{\rm CC}$ specification when the address lines are stabilizing. - $^{3)}$ $I_{\rm PD}$ (Power Down Mode) is measured under following conditions: EA = Port0 = $V_{\rm CC}$ ; RESET = $V_{\rm SS}$ ; XTAL2 = N.C.; XTAL1 = $V_{\rm SS}$ ; all other pins are disconnected. - $f_{\rm ICC}$ (active mode) is measured with: XTAL1 driven with $t_{\rm CLCH}$ , $t_{\rm CHCL}=5$ ns, $V_{\rm IL}=V_{\rm SS}+0.5$ V, $V_{\rm IH}=V_{\rm CC}-0.5$ V; XTAL2= N.C.; $\overline{\rm EA}=$ Port0 = RESET = $V_{\rm CC}$ ; all other pins are disconnected. $I_{\rm CC}$ would be slightly higher if a crystal oscillator is used (appr. 1 mA). - 55 $I_{\rm CC}$ (Idle mode) is measured with all output pins disconnected and with all peripherals disabled; XTAL1 driven with $t_{\rm CLCH}$ , $t_{\rm CHCL}$ = 5 ns, $V_{\rm IL}$ = $V_{\rm SS}$ + 0.5 V, $V_{\rm IH}$ = $V_{\rm CC}$ 0.5 V; XTAL2 = N.C.; RESET = $\overline{\rm EA}$ = $V_{\rm SS}$ ; Port0 = $V_{\rm CC}$ ; all other pins are disconnected; - $I_{\rm CC\ max}$ at other frequencies is given by: active mode: $I_{\rm CC\ max} = 1.32\ x\ f_{\rm OSC} + 7.48$ idle mode: $I_{\rm CC\ max} = 0.40\ x\ f_{\rm OSC} + 2.62$ where $f_{\rm OSC}$ is the oscillator frequency in MHz. $I_{\rm CC}$ values are given in mA and measured at $V_{\rm CC} = 5\ {\rm V}$ . #### AC Characteristics for SAB-C502-L / C502-2R $V_{\rm CC}$ = 5 V + 10 %, - 15 %; $V_{\rm SS}$ = 0 V $T_{A} = 0 \,^{\circ}\text{C to} + 70 \,^{\circ}\text{C}$ $T_{A} = -40 \,^{\circ}\text{C to} + 85 \,^{\circ}\text{C}$ for the SAB-C502 for the SAF-C502 ( $C_L$ for port 0, ALE and $\overline{PSEN}$ outputs = 100 pF; $C_L$ for all other outputs = 80 pF) #### **Program Memory Characteristics** | Parameter | Symbol | | | Limit Value | <b>S</b> | Unit | |------------------------------------|----------------------|-----------------|------|--------------------------------------------------------|--------------------------|------| | | | 12 MHz<br>Clock | | Variable Clock 1/t <sub>CLCL</sub> = 3.5 MHz to 12 MHz | | 1 | | | | min. | max. | min. | max. | 1 | | ALE pulse width | t <sub>LHLL</sub> | 127 | - | 2t <sub>CLCL</sub> - 40 | _ | ns | | Address setup to ALE | t <sub>AVLL</sub> | 43 | _ | $t_{\text{CLCL}} - 40$ | - | ns | | Address hold after ALE | t <sub>LLAX</sub> | 30 | - | $t_{\rm CLCL} - 53$ | - | ns | | ALE low to valid instr in | t <sub>LLIV</sub> | _ | 233 | _ | 4t <sub>CLCL</sub> - 100 | ns | | ALE to PSEN | t <sub>LLPL</sub> | 58 | - | t <sub>CLCL</sub> - 25 | _ | ns | | PSEN pulse width | t <sub>PLPH</sub> | 215 | _ | $3t_{\text{CLCL}} - 35$ | _ | ns | | PSEN to valid instr in | $t_{PLIV}$ | - | 150 | - | 3t <sub>CLCL</sub> - 100 | ns | | Input instruction hold after PSEN | t <sub>PXIX</sub> | 0 | - | 0 | _ | ns | | Input instruction float after PSEN | t <sub>PXIZ</sub> *) | - | 63 | _ | t <sub>CLCL</sub> - 20 | ns | | Address valid after PSEN | t <sub>PXAV</sub> *) | 75 | - | t <sub>CLCL</sub> - 8 | _ | ns | | Address to valid instr in | t <sub>AVIV</sub> | _ | 302 | _ | 5t <sub>CLCL</sub> - 115 | ns | | Address float to PSEN | t <sub>AZPL</sub> | 0 | - | 0 | _ | ns | <sup>\*)</sup> Interfacing the SAB-C502-L/C502-2R to devices with float times up to 75 ns is permissible. This limited bus contention will not cause any damage to port 0 Drivers. ## AC Characteristics for SAB-C502-L / C502-2R # **External Data Memory Characteristics** | Parameter | Symbol | Limit Values | | | | Unit | |-----------------------------|--------------------|-----------------|------------|-----------------------------------------------------------|--------------------------|------| | | | 12 MHz<br>Clock | | Variable Clock<br>1/t <sub>CLCL</sub> = 3.5 MHz to 12 MHz | | | | | | min. | max. | min. | max. | 1 | | RD pulse width | t <sub>RLRH</sub> | 400 | <b> </b> - | 6t <sub>CLCL</sub> - 100 | _ | ns | | WR pulse width | t <sub>WLWH</sub> | 400 | - | 6t <sub>CLCL</sub> - 100 | _ | ns | | Address hold after ALE | t <sub>LLAX2</sub> | 30 | - | t <sub>CLCL</sub> - 53 | - | ns | | RD to valid data in | t <sub>RLDV</sub> | _ | 252 | _ | 5t <sub>CLCL</sub> - 165 | ns | | Data hold after RD | $t_{RHDX}$ | 0 | _ | 0 | _ | ns | | Data float after RD | t <sub>RHDZ</sub> | _ | 97 | - | 2t <sub>CLCL</sub> - 70 | ns | | ALE to valid data in | t <sub>LLDV</sub> | _ | 517 | - | 8t <sub>CLCL</sub> - 150 | ns | | Address to valid data in | t <sub>AVDV</sub> | _ | 585 | - | 9t <sub>CLCL</sub> - 165 | ns | | ALE to WR or RD | t <sub>LLWL</sub> | 200 | 300 | 3t <sub>CLCL</sub> - 50 | $3t_{CLCL} + 50$ | ns | | Address valid to WR or RD | t <sub>AVWL</sub> | 203 | - | 4t <sub>CLCL</sub> - 130 | <b>-</b> | ns | | WR or RD high to ALE high | t <sub>WHLH</sub> | 43 | 123 | t <sub>CLCL</sub> - 40 | $t_{\text{CLCL}} + 40$ | ns | | Data valid to WR transition | t <sub>QVWX</sub> | 33 | _ | t <sub>CLCL</sub> - 50 | _ | ns | | Data setup before WR | $t_{\sf QVWH}$ | 433 | - | 7t <sub>CLCL</sub> - 150 | - | ns | | Data hold after WR | t <sub>WHQX</sub> | 33 | _ | t <sub>CLCL</sub> - 50 | - | ns | | Address float after RD | t <sub>RLAZ</sub> | - | 0 | _ | 0 | ns | # **External Clock Drive** | Parameter | Symbol | | Limit Values | | | | |-------------------|-------------------|------|-------------------------------------|----|--|--| | | | Freq | | | | | | | | min. | max. | _ | | | | Oscillator period | $t_{CLCL}$ | 83.3 | 285.7 | ns | | | | High time | $t_{CHCX}$ | 20 | $t_{\text{CLCL}} - t_{\text{CLCX}}$ | ns | | | | Low time | $t_{\sf CLCX}$ | 20 | $t_{\text{CLCL}} - t_{\text{CHCX}}$ | ns | | | | Rise time | t <sub>CLCH</sub> | _ | 20 | ns | | | | Fall time | $t_{CHCL}$ | | 20 | ns | | | # AC Characteristics for SAB-C502-L20 / C502-2R20 $V_{\rm CC}$ = 5 V + 10 %, -15 %; $V_{\rm SS}$ = 0 V for the SAB-C502 $T_{A} = 0 \,^{\circ}\text{C to} + 70 \,^{\circ}\text{C}$ $T_{A} = -40 \,^{\circ}\text{C to} + 85 \,^{\circ}\text{C}$ for the SAF-C502 ( $C_L$ for port 0, ALE and $\overline{\text{PSEN}}$ outputs = 100 pF; $C_L$ for all other outputs = 80 pF) # **Program Memory Characteristics** | Parameter | Symbol | Limit Values | | | | | |------------------------------------|----------------------|-----------------|-------------|-----------------------------------------------------------|--------------------------|----| | | | 20 MHz<br>Clock | | Variable Clock<br>1/t <sub>CLCL</sub> = 3.5 MHz to 20 MHz | | | | | | min. | max. | min. | max. | | | ALE pulse width | t <sub>LHLL</sub> | 60 | Ī- <u> </u> | $2t_{CLCL}-40$ | | ns | | Address setup to ALE | t <sub>AVLL</sub> | 20 | T | $t_{\rm CLCL}-30$ | | ns | | Address hold after ALE | t <sub>LLAX</sub> | 20 | - | $t_{\text{CLCL}} - 30$ | | ns | | ALE low to valid instr in | t <sub>LLIV</sub> | _ | 100 | - | $4t_{\text{CLCL}} - 100$ | ns | | ALE to PSEN | $t_{LLPL}$ | 25 | - | $t_{\rm CLCL}-25$ | - | ns | | PSEN pulse width | $t_{PLPH}$ | 115 | Ī- | $3t_{CLCL} - 35$ | _ | ns | | PSEN to valid instr in | $t_{PLIV}$ | - | 75 | - | $3t_{CLCL} - 75$ | ns | | Input instruction hold after PSEN | $t_{PXIX}$ | 0 | _ | 0 | | ns | | Input instruction float after PSEN | $t_{PXIZ}$ | _ | 40 | - | $t_{\rm CLCL}-10$ | ns | | Address valid after PSEN | t <sub>PXAV</sub> *) | 47 | - | t <sub>CLCL</sub> - 3 | _ | ns | | Address to valid instr in | t <sub>AVIV</sub> | - | 190 | _ | 5t <sub>CLCL</sub> - 60 | ns | | Address float to PSEN | t <sub>AZPL</sub> | 0 | - | 0 | _ | ns | <sup>\*)</sup> Interfacing the SAB-C502-L20/C502-2R20 to devices with float times up to 45 ns is permissible. This limited bus contention will not cause any damage to port 0 Drivers. ## AC Characteristics for SAB-C502-L20 / C502-2R20 # **External Data Memory Characteristics** | Parameter | Symbol | Limit Values | | | | | |-----------------------------|--------------------|-----------------|------|-----------------------------------------------------------|--------------------------|----| | | | 18 MHz<br>Clock | | Variable Clock<br>1/t <sub>CLCL</sub> = 3.5 MHz to 20 MHz | | | | | | min. | max. | min. | max. | 1 | | RD pulse width | t <sub>RLRH</sub> | 200 | _ | 6t <sub>CLCL</sub> - 100 | - | ns | | WR pulse width | t <sub>WLWH</sub> | 200 | - | 6t <sub>CLCL</sub> - 100 | - | ns | | Address hold after ALE | t <sub>LLAX2</sub> | 20 | - | t <sub>CLCL</sub> - 30 | _ | ns | | RD to valid data in | t <sub>RLDV</sub> | - | 155 | - | 5t <sub>CLCL</sub> - 95 | ns | | Data hold after RD | t <sub>RHDX</sub> | 0 | - | 0 | _ | ns | | Data float after RD | $t_{RHDZ}$ | _ | 76 | _ | 2t <sub>CLCL</sub> - 24 | ns | | ALE to valid data in | t <sub>LLDV</sub> | _ | 250 | _ | 8t <sub>CLCL</sub> - 150 | ns | | Address to valid data in | t <sub>AVDV</sub> | | 285 | - | 9t <sub>CLCL</sub> - 165 | ns | | ALE to WR or RD | t <sub>LLWL</sub> | 100 | 200 | $3t_{\text{CLCL}} - 50$ | 3t <sub>CLCL</sub> + 50 | ns | | Address valid to WR or RD | t <sub>AVWL</sub> | 70 | - | 4t <sub>CLCL</sub> - 130 | _ | ns | | WR or RD high to ALE high | t <sub>WHLH</sub> | 20 | 80 | t <sub>CLCL</sub> - 30 | t <sub>CLCL</sub> + 30 | ns | | Data valid to WR transition | t <sub>QVWX</sub> | 5 | - | t <sub>CLCL</sub> - 45 | _ | ns | | Data setup before WR | t <sub>QVWH</sub> | 200 | - | 7t <sub>CLCL</sub> - 150 | - | ns | | Data hold after WR | t <sub>whax</sub> | 10 | - | t <sub>CLCL</sub> - 40 | | ns | | Address float after RD | t <sub>RLAZ</sub> | _ | 0 | _ | 0 | ns | #### **External Clock Drive** | Parameter | Symbol | | Limit Values | Unit | |-------------------|-------------------|-------------------------|-------------------------------------|------| | | | Variab<br>Freq. = 3.5 N | | | | | | min. | max. | | | Oscillator period | t <sub>CLCL</sub> | 50 | 285.7 | ns | | High time | t <sub>CHCX</sub> | 12 | $t_{\text{CLCL}} - t_{\text{CLCX}}$ | ns | | Low time | t <sub>CLCX</sub> | 12 | $t_{\text{CLCL}} - t_{\text{CHCX}}$ | ns | | Rise time | t <sub>CLCH</sub> | _ | 12 | ns | | Fall time | t <sub>CHCL</sub> | _ | 12 | ns | Figure 7 Program Memory Read Cycle **■** 8235605 0061309 71T **■** Figure 8 Data Memory Read Cycle Figure 9 Data Memory Write Cycle #### **ROM Verification Characteristics for SAB-C502-2R** #### **ROM Verification Mode 1** | Parameter | Symbol | | Unit | | |-------------------------|---------------------|------|---------------------|-----| | | | min. | max. | | | Address to valid data | $t_{AVQV}$ | _ | 48t <sub>CLCL</sub> | ns | | ENABLE to valid data | $t_{\sf ELQV}$ | _ | 48t <sub>CLCL</sub> | ns | | Data float after ENABLE | $t_{EHQZ}$ | 0 | 48t <sub>CLCL</sub> | ns | | Oscillator frequency | 1/t <sub>CLCL</sub> | 4 | 6 | MHz | Figure 10 ROM Verification Mode 1 Figure 11 AC Testing: Input, Output Waveforms 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_{\rm OH}$ / $V_{\rm OL}$ level occurs. $I_{\rm OL}$ / $I_{\rm OH} \ge \pm 20$ mA. Figure 12 AC Testing: Float Waveforms Figure 13 External Clock Cycle **■** 8235605 0061313 140 **■** Figure 14 Recommended Oscillator Circuits