#### High-Performance 8-Bit Single Chip Microcontroller SAB 80515/80535 #### **Preliminary** SAB 80515 Microcontroller with factory mask-programmable ROM SAB 80535 Microcontroller for external ROM - 8 K × 8 ROM (SAB 80C515 only) - 256 × 8 RAM - Six 8-bit I/O ports, one 8-bit input port for analog signals - Three 16-bit timer/counters - Highly flexible reload, capture, compare capabilities - Full-duplex serial channel - Twelve interrupt vectors, four priority levels - 8-bit A/D converter with 8 multiplexed inputs and programmable internal reference voltages - 16-bit watchdog timer - V<sub>PD</sub> provides standby current for 40 bytes of RAM - Boolean processor - 256-bit-addressable locations - Most instructions execute in 1 μs (750 ns) - 4 μs (3 μs) multiply and divide - External memory expandable up to 128 Kbytes - Backwardly compatible with SAB 8051 - Three temperature ranges available: 0 to 70 °C - -40 to 85 °C (T40/85) - -40 to 110 °C (T40/110) The SAB 80515/80535 is a powerful member of the Siemens SAB 8051 family of 8-bit microcontrollers. It is fabricated in $\pm$ 5 V N-channel, silicon-gate Siemens MYMOS technology. The SAB 80515/80535 is a stand-alone, high-performance single-chip microcontroller based on the SAB 8051 architecture. While maintaining all the SAB 8051 operating characteristics, the SAB 80515/80535 incorporates several enhancements which significantly increase design flexibility and overall system performance. The SAB 80535 is identical with the SAB 80515 except that it lacks the on-chip program memory. The SAB 80515/80535 is supplied in a 68-pin plastic leaded chip carrier package (P-LCC-68). ## **Ordering Information** | Туре | Ordering code | Package | Description<br>8-bit CMOS microcontroller | |--------------------|---------------|----------|-------------------------------------------| | SAB 80515-N | Q 67120-C211 | P-LCC-68 | with mask-programmable ROM | | SAB 80535-N | Q 67120-C241 | P-LCC-68 | for external memory | | SAB 80515-N-T40/85 | Q 67120-C210 | P-LCC-68 | with mask-programmable ROM | | SAB 80535-N-40/85 | Q 67120-C240 | P-LCC-68 | for external memory | Logic Symbol Pin Configuration (P-LCC-68) Semiconductor Group ## Pin Definitions and Functions | Symbol | Pin | Input (I)<br>Output (O) | Function | |-------------------|----------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P4.0-P4.7 | 1-3, 5-9 | 1/0 | Port 4 is an 8-bit quasi-bidirectional I/O port. Port 4 can sink/source 4 LS-TTL loads. | | $V_{PD}$ | 4 | | Power down supply. If $V_{\rm PD}$ is held within its specs while $V_{\rm CC}$ drops below specs, $V_{\rm PD}$ will provide standby power to 40 byte of the internal RAM. When $V_{\rm PD}$ is low, the RAM's current is drawn from $V_{\rm CC}$ . | | RESET | 10 | | A low level on this pin for the duration of two machine cycles while the oscillator is running resets the SAB 80C515. A small internal pullup resistor permits power-on reset using only a capacitor connected to $V_{\rm SS}$ | | VAREF | 11 | | Reference voltage for the A/D converter | | V <sub>AGND</sub> | 12 | | Reference ground for the A/D converter | | AN7-AN0 | 13-20 | l l | Multiplexed analog inputs | ## Pin Definitions and Functions (cont'd) | Symbol | Pin | Input (I)<br>Output (O) | Function | |-----------|-------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P3.0-P3.7 | 21-28 | 1/0 | Port 3 is an 8-bit bidirectional I/O. It also contains the interrupt, timer, serial port 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. Port 3 can sink/source 4 LS-TTL loads. The secondary functions are assigned to the pins of port 3, as follows: | | | | | <ul> <li>R x D (P3.0): serial port's receiver data<br/>input (asynchronous) or data<br/>input/output (synchronous)</li> </ul> | | | | | T × D (P3.1): serial port's transmitter data output (asynchronous) or clock output (synchronous) | | | | - ĪNT0(P3.2): | NT0(P3.2): interrupt 0 input/timer 0 gate control input | | | | | NT1(P3.3): interrupt 1 input/timer 1 gate control input | | | | | - T0 (P3.4): counter 0 input | | | | | - T1 (P3.5): counter 1 input | | | | | WR(P3.6): the write control signal latches<br>the data byte from port 0 into<br>the external data memory | | | | | RD (P3.7): the read control signal enables the external data memory to port 0 | ## Pin Definitions and Functions (cont'd) | Symbol | Pin | Input (I)<br>Output (O) | Function | |-------------|---------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P1.7 - P1.0 | 29 - 36 | I/O | Port 1 is an 8-bit bidirectional I/O port. It is used for the low-order address byte during program verification. It also contains the interrupt, timer, clock, capture and compare pins that are used by various options. The output latch must be programmed to a one (1) for that function to operate (except when used for the compare functions). The secondary functions are assigned to the port 1 pins as follows: — INT3/CC0 (P1.0): interrupt 3 input / compare 0 output / capture 0 input | | , | | | INT4/CC1 (P1.1): interrupt 4 input / compare 1 output / capture 1 input | | | | | INT5/CC2 (P1.2): interrupt 5 input / compare 2 output / capture 2 input | | | | | INT6/CC3 (P1.3): interrupt 6 input / compare 3 output / capture 3 input | | | | | - INT2(P1.4): interrupt 2 input | | | | | T2EX (P1.5): timer 2 external reload trigger input | | | | | CLKOUT (P1.6): system clock output | | | | | - T2 (P1.7): counter 2 input | | $V_{BB}$ | 37 | | Substrate pin. Must be connected to $V_{\rm SS}$ through a capacitor (47 to 100 nF) for proper operation of the A/D converter. | | XTAL2 | 39 | _ | XTAL2 is the output from the oscillator's amplifier.Input to the internal timing circuitry. A crystal, ceramic resonator, or external source can be used. | | XTAL1 | 40 | - | XTAL1 is the input to the oscillator's high gain amplifier. Required when a crystal or ceramic resonator is used. Connect to $V_{\rm SS}$ when external source is used on XTAL2. | ## Pin Definitions and Functions (cont'd) | Symbol | Pin | Input (I)<br>Output (O) | Function | |-----------------|--------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P2.0-P2.7 | 41- 48 | I/O | Port 2 is an 8-bit quasi-bidirectional I/O port. It also emits the high-order address byte when accessing external memory. It is used for the high-order address and the control signals during program verification. Port 2 can sink/source 4 LS-TTL loads. | | PSEN | 49 | 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. | | ALE | 50 | 0 | Provides address latch enable output used for latching the address into external memory during normal operation. It is activated every six oscillator periods except during an external data memory access. | | ĒĀ | 51 | I | When held at a TTL high level, the SAB 80515 executes instructions from the internal ROM when the PC is less than 8192. When held at a TTL low level, the SAB 80515 fetches all instructions from external program memory. For the SAB 80535 this pin must be tied low. | | P0.0-P0.7 | 52-59 | I/O | Port 0 is an 8-bit open-drain bidirectional I/O port. It is also the multiplexed low-order address and data bus when using external memory. It is used for data output during program verification. Port 0 can sink/source 8 LS-TTL loads. | | P5.7-P5.0 | 60-67 | I/O | Port 5 is an 8-bit quasi-bidirectional I/O port.<br>Port 5 can sink/source 4 LS-TTL loads. | | V <sub>CC</sub> | 68 | | POWER SUPPLY (+ 5 V power supply during normal operation and program verification) | | $V_{\rm SS}$ | 38 | | GROUND (0 V) | Figure 1 Block Diagram #### **Functional Description** The architecture of the SAB 80515 is based on the SAB 8051 microcontroller family. The following features of the SAB 80515 are fully compatible with the SAB 8051 features: - Instruction set - External memory expansion interface (port 0 and port 2) - Full-duplex serial port - Timer/counter 0 and 1 - Alternate functions on port 3 - The lower 128 bytes of internal RAM and the lower 4 Kbytes of internal ROM The SAB 80515 additionally contains 128 bytes of internal RAM and 4 Kbytes of internal ROM, which results in a total of 256 bytes of RAM and 8 Kbytes of ROM on chip. The SAB 80515 has a new 16-bit timer/counter with a 2:1 prescaler, reload mode, compare and capture capability. It also contains a 16-bit watchdog timer, an 8-bit A/D converter with programmable reference voltages, two additional quasi-bidirectional 8-bit ports, one 8-bit input port for analog signals, and a programmable clock output (fosc/12). Furthermore, the SAB 80515 has a powerful interrupt structure with 12 vectors and 4 program- Furthermore, the SAB 80515 has a powerful interrupt structure with 12 vectors and 4 program mable priority levels. Figure 1 shows a block diagram of the SAB 80515. #### CPU The SAB 80515 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. #### **Memory Organization** The SAB 80515 manipulates operands in the four memory address spaces described in the following. (Figure 2 illustrates the memory address spaces of the SAB 80515). Figure 2 Memory Address Spaces #### **Program memory** The SAB 80515 has 8 Kbyte of on-chip ROM, while the SAB 80535 has no internal ROM. The program memory can be externally expanded up to 64 Kbytes. If the $\overline{EA}$ pin is held high, the SAB 80515 executes out of internal ROM unless the address exceeds 1FFFH. Locations 2000H through 0FFFFH are then fetched from the external program memory. If the $\overline{EA}$ pin is held low, the SAB 80515 fetches all instructions from the external program memory. Since the SAB 80535 has no internal ROM, pin $\overline{EA}$ must be tied low when using this component. #### **Data Memory** The data memory address space consists of an internal and an external memory space. The internal data memory is divided into three physically separate and distinct blocks: the lower 128 bytes of RAM, the upper 128 bytes of RAM, and the 128-byte special function register (SFR) area. While the upper 128 bytes of data memory and the SFR area share the same address locations, they are accessed through different addressing modes. The lower 128 bytes of data memory can be accessed through direct or register indirect addressing; the upper 128 bytes of RAM can be accessed through register indirect addressing; the special function registers are accessible through direct addressing. Four 8-register banks, each bank consisting of eight 8-bit multi-purpose registers, occupy locations 0 through 1FH in the lower RAM area. The next 16 bytes, locations 20H through 2FH, contain 128 directly addressable bit locations. The stack can be located anywhere in the internal data memory address space, and the stack depth can be expanded up to 256 bytes. The external data memory can be expanded up to 64 Kbytes and can be accessed by instructions that use a 16-bit or an 8-bit address. #### **Special Function Registers** All registers, except the program counter and the four 8-register banks, reside in the special function register area. The 41 special function registers (SFR's) include arithmetic registers, pointers, and registers that provide an interface between the CPU and the on-chip peripheral functions. There are also 128 directly addressable bits within the SFR area. The special function registers are listed in the following table: 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 80515/80535. Table 1 Special Function Register | Address | Register | Contents after Reset | Address | Register | Contents<br>after Reset | |------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | 80H<br>81H<br>82H<br>83H<br>84H<br>85H<br>86H<br>87H | P0 1) SP DPL DPH reserved reserved reserved PCON | 0FFH<br>07H<br>00H<br>00H<br>XXH <sup>2)</sup><br>XXH <sup>2)</sup><br>XXH <sup>2)</sup><br>000X 0000B <sup>2)</sup> | 98H<br>99H<br>9AH<br>9BH<br>9CH<br>9DH<br>9EH<br>9FH | SCON 1) SBUF reserved reserved reserved reserved reserved reserved | 00H<br>XXXX XXXX B<br>XXH 2)<br>XXH 2)<br>XXH 2)<br>XXH 2)<br>XXH 2)<br>XXH 2) | | 88H<br>89H<br>8AH<br>8BH<br>8CH<br>8DH<br>8EH<br>8FH | TCON 1) TMOD TL0 TL1 TH0 TH1 reserved reserved | 00H<br>00H<br>00H<br>00H<br>00H<br>00H<br>XXH <sup>2)</sup><br>XXH <sup>2)</sup> | A0H<br>A1H<br>A2H<br>A3H<br>A4H<br>A5H<br>A6H<br>A7H | P2 1) reserved reserved reserved reserved reserved reserved reserved reserved | OFFH XXH 21 | | 90H<br>91H<br>92H<br>93H<br>94H<br>95H<br>96H<br>97H | P1 1) reserved reserved reserved reserved reserved reserved reserved | OFFH XXH 2) | A8H<br>A9H<br>AAH<br>ABH<br>ACH<br>ADH<br>AEH<br>AFH | IENO 1) IPO reserved reserved reserved reserved reserved reserved | 00H<br>X000 0000B <sup>2)</sup><br>XXH <sup>2)</sup><br>XXH <sup>2)</sup><br>XXH <sup>2)</sup><br>XXH <sup>2)</sup><br>XXH <sup>2)</sup><br>XXH <sup>2)</sup> | <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 (cont'd) | Address | Register | Contents<br>after Reset | Address | Register | Contents<br>after Reset | |------------------------------------------------------|---------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | B0H<br>B1H<br>B2H<br>B3H<br>B4H<br>B5H<br>B6H<br>B7H | p31) reserved reserved reserved reserved reserved reserved reserved | 0FFH<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> ) | DOH<br>D1H<br>D2H<br>D3H<br>D4H<br>D5H<br>D6H<br>D7H | PSW 1) reserved reserved reserved reserved reserved reserved | 00H<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> ) | | B8H<br>B9H<br>BAH<br>BBH<br>BCH<br>BDH<br>BEH<br>BFH | IEN1 1) IP1 reserved reserved reserved reserved reserved | OOH<br>XX00 00000B 2)<br>XXH 2)<br>XXH 2)<br>XXH 2)<br>XXH 2)<br>XXH 2)<br>XXH 2)<br>XXH 2 | D8H D9H DAH DBH DCH DDH DEH DFH | ADCON<br>ADDAT<br>DAPR<br>P6<br>reserved<br>reserved<br>reserved | 00X0 0000 B <sup>2)</sup><br>00H<br>00H<br>XXH <sup>2)</sup><br>XXH <sup>2)</sup><br>XXH <sup>2)</sup><br>XXH <sup>2)</sup> | | C0H<br>C1H<br>C2H<br>C3H<br>C4H<br>C5H<br>C6H<br>C7H | IRCON 1) CCEN CCL1 CCH1 CCL2 CCH2 CCL3 CCH3 | 00H<br>00H<br>00H<br>00H<br>00H<br>00H<br>00H | E0H<br>E1H<br>E2H<br>E3H<br>E4H<br>E5H<br>E6H<br>E7H | ACC 1) reserved reserved reserved reserved reserved reserved reserved | 00H<br>XXH <sup>2)</sup><br>XXH <sup>2)</sup><br>XXH <sup>2)</sup><br>XXH <sup>2)</sup><br>XXH <sup>2)</sup><br>XXH <sup>2)</sup><br>XXH <sup>2)</sup> | | C8H<br>C9H<br>CAH<br>CBH<br>CCH<br>CDH<br>CEH<br>CFH | T2CON 1) reserved CRCL CRCH TL2 TH2 reserved reserved | 00H<br>XXH <sup>2)</sup><br>00H<br>00H<br>00H<br>00H<br>XXH <sup>2)</sup><br>XXH <sup>2)</sup> | E8H<br>E9H<br>EAH<br>EBH<br>ECH<br>EDH<br>EEH | P4 1) reserved reserved reserved reserved reserved reserved reserved | OFFH<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> )<br>XXH <sup>2</sup> ) | Bit-addressable Special Function Register X means that the value is indeterminate and the location is reserved Table 1 Special Function Register (cont'd) | Address | Register | Contents after Reset | Address | Register | Contents after Reset | |---------|-----------------|----------------------|---------|----------|----------------------| | F0H | B <sup>1)</sup> | 00H | F8H | P5 1) | OFFH | | F1H | reserved | XXH <sup>2)</sup> | F9H | reserved | XXH <sup>2)</sup> | | F2H | reserved | XXH <sup>2)</sup> | FAH | reserved | XXH <sup>2)</sup> | | F3H | reserved | XXH <sup>2)</sup> | FBH | reserved | XXH <sup>2)</sup> | | F4H | reserved | XXH <sup>2)</sup> | FCH | reserved | XXH <sup>2)</sup> | | F5H | reserved | XXH <sup>2)</sup> | FDH | reserved | XXH <sup>2)</sup> | | F6H | reserved | XXH <sup>2)</sup> | FEH | reserved | XXH <sup>2)</sup> | | F7H | reserved | XXH <sup>2)</sup> | FFH | reserved | XXH 2) | Bit-addressable Special Function Register X means that the value is indeterminate and the location is reserved Table 2 **Special Function Registers - Functional Blocks** | Block | Symbol | Name | Address | Contents<br>after Reset | |--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------| | CPU | ACC<br>B<br>DPH<br>DPL<br>PSW<br>SP | Accumulator B-Register Data Pointer, High Byte Data Pointer, Low Byte Program Status Word Register Stack Pointer | 0E0H 1)<br>0F0H 1)<br>083H<br>082H<br>0D0H 1)<br>081H | 00H<br>00H<br>00H<br>00H<br>00H<br>07H | | A/D-<br>Converter | ADCON <sup>2)</sup><br>ADDAT<br>DAPR | A/D Converter Control Register<br>A/D Converter Data Register<br>A/D Converter Program Register | <b>0D8H</b> <sup>1)</sup><br>09DH<br>0DAH | 00X0 0000 B <sup>3)</sup><br>00H<br>00H) | | Interrupt<br>System | IEN0 <sup>2)</sup> IEN1 <sup>2)</sup> IP0 <sup>2)</sup> IP1 IRCON TCON <sup>2)</sup> T2CON <sup>2)</sup> | Interrupt Enable Register 0 Interrupt Enable Register 1 Interrupt Priority Register 0 Interrupt Priority Register 1 Interrupt Request Control Register Timer Control Register Timer 2 Control Register | 0A8H 1)<br>0B8H 1)<br>0A9H<br>0B9H<br>0C0H 1)<br>88H 1)<br>0C8H 1 | 00H<br>00H<br>X000 0000 B <sup>3)</sup><br>XX00 0000 B <sup>3)</sup><br>00H<br>00H<br>00H | | Compare/<br>Capture-<br>Unit<br>Compare/<br>Capture-<br>Unit<br>(CCU)<br>(cont'd)<br>(CCU) | CCEN<br>CCH1<br>CCH2<br>CCH3<br>CCL1<br>CCL2<br>CCL3<br>CRCH<br>CRCL<br>TH2<br>TL2<br>T2CON <sup>2)</sup> | Comp./Capture Enable Reg. Comp./Capture Reg. 1, High Byte Comp./Capture Reg. 2, High Byte Comp./Capture Reg. 3, High Byte Comp./Capture Reg. 1, Low Byte Comp./Capture Reg. 2. Low Byte Comp./Capture Reg. 3, Low Byte Comp./Capture Reg. 3, Low Byte Com./Rel./Capt. Reg. High Byte Com./Rel./Capt. Reg. Low Byte Timer 2, High Byte Timer 2, Low Byte Timer 2 Control Register 1) | 0C1H<br>0C3H<br>0C5H<br>0C7H<br>0C2H<br>0C4H<br>0C6H<br>0CBH<br>0CAH<br>0CDH<br>0CCH " | 00H<br>00H<br>00H<br>00H<br>00H<br>00H<br>00H<br>00H<br>00H<br>00H | Bit-addressable special function registers This special function register is listed repeatedly since some bits of it also belong to other functional blocks X means that the value is indeterminate Table 2 Special Function Registers- Functional Blocks (cont'd) | Block | Symbol | Name | Address | Contents<br>after Reset | |---------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|---------------------------------------------------------------| | Ports | P0<br>P1<br>P2<br>P3<br>P4<br>P5<br>P6 | Port 0 Port 1 Port 2 Port 3 Port 4 Port 5 Port 6, Analog/Digital Input | 80H 1)<br>90H 1)<br>0A0H 1)<br>0B0H 1)<br>0E8H 1)<br>0F8H 1)<br>0DBH | OFFH OFFH OFFH OFFH OFFH | | Pow. Sav.<br>Modes | PCON 2) | Power Control Register | 087H | 000X 0000 B <sup>2)</sup> | | Serial<br>Channels | ADCON 2)<br>PCON 2)<br>SBUF<br>SCON | A/D Converter Control Reg.<br>Power Control Register<br>Serial Channel Buffer Reg.<br>Serial Channel Control Reg. | <b>0D8H</b> <sup>1)</sup><br>087H<br>099H<br><b>098H</b> <sup>1)</sup> | 00X0 0000 B <sup>3)</sup><br>000X 0000 B <sup>3)</sup><br>00H | | Timer 0/<br>Timer 1 | TCON 2)<br>TH0<br>TH1<br>TL0<br>TL1<br>TMOD | THO Timer 0. High Byte TH1 Timer 1, High Byte TL0 Timer 0, Low Byte TL1 Timer 1, Low Byte | | 00H<br>00H<br>00H<br>00H<br>00H<br>00H | | Watchdog | IEN0 <sup>2)</sup><br>IEN1 <sup>2)</sup><br>IP0 <sup>2)</sup> | Interrupt Enable Register 0<br>Interrupt Enable Register 1<br>Interrupt Priority Register 0 | 0A8H 1)<br>0B8H 1)<br>0A9H | 00H<br>00H<br>X000 0000 B <sup>3)</sup> | <sup>1)</sup> 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 #### **Serial Port** The serial port of the SAB 80515 enables full duplex communication between microcontrollers or between microcontroller and peripheral devices. The serial port can operate in 4 modes: - Mode 0: Shift register mode. Serial data enters and exits through RxD. TxD outputs the shift clock. 8 bits are transmitted/received: 8 data bits (LSB first). The baud rate is fixed at 1/12 of the oscillator frequency. - Mode 1: 10 bits are transmitted (through R×D) or received (through T×D): a start bit (0), 8 data bits (LSB first), and a stop bit (1). The baud rate is variable. - Mode 2: 11 bits are transmitted (through R×D) or received (through T×D): a start bit (0), 8 data bits (LSB first), a programmable 9th data bit, and a stop bit (1). The baud rate is programmable to either 1/32 or 1/64 of the oscillator frequency. - Mode 3: 11 bits are transmitted (through TxD) or received (through RxD): a start bit (0), 8 data bits (LSB first), a programmable 9th data bit, and a stop bit (1). Mode 3 is identical to mode 2 except for the baud rate. The baud rate in mode 3 is variable. The variable baud rates in modes 1 and 3 can be generated by timer 1 or an internal baud rate generator. #### A/D Converter The 8-bit A/D converter of the SAB 80515 has eight multiplexed analog inputs (Port 6) and uses the successive approximation method. It takes 5 machine cycles to sample an analog signal (during this sample time the input signal should be held constant); the total conversion time (including sample time) is 15 machine cycles (15 $\mu$ s at 12 MHz oscillator frequency). Conversion can be programmed to be single or continuous; at the end of a conversion an interrupt can be generated. A unique feature is the capability of internal reference voltage programming. The internal reference voltages $V_{\rm IntAREF}$ and $V_{\rm IntAGND}$ for the A/D converter both are programmable to one of 16 steps with respect to the external reference voltages. This feature permits a conversion with a smaller internal reference voltage range to gain a higher resolution. In addition, the internal reference voltages can easily be adapted by software to the desired analog input voltage range. Figure 3 shows a block diagram of the A/D converter. Figure 3 Block Diagram of the A/D Converter #### **Timer/Counters** The SAB 80515 contains three 16-bit timer/counters which are useful in many applications for timing and counting. The input clock for each timer/counter is 1/12 of the oscillator frequency in the timer operation or can be taken from an external clock source for the counter operation (maximum count rate is 1/24 of the oscillator frequency). #### - Timer/counter 0 and 1 These timer/counters can operate in four modes: Mode 0: 8-bit timer/counter with 32:1 prescaler Mode 1: 16-bit timer/counter Mode 2: 8-bit timer/counter with 8-bit auto-reload Mode 3: Timer/counter 0 is configured as one 8-bit timer/counter and one 8-bit timer; timer/counter 1 in this mode holds its count. External inputs INTO and INT1 can be programmed to function as a gate for timer/counters 0 and 1 to facilitate pulse width measurements. #### - Timer/counter 2 Timer/counter 2 of the SAB 80515 is a 16-bit timer/counter with several additional features. It offers a 2:1 prescaler, a selectable gate function, and compare, capture and reload functions. Corresponding to the 16-bit timer register there are four 16-bit capture/compare registers, one of them can be used to perform a 16-bit reload on a timer overflow or external event. Each of these registers corresponds to a pin of port 1 for capture input/compare output. Figure 4 shows a block diagram of the timer/counter 2. #### Reload A 16-bit reload can be performed with the 16-bit CRC register, which is a concatenation of the 8-bit registers CRCL and CRCH. There are two modes from which to select: Mode 0: Reload is caused by a timer 2 overflow (auto-reload). Mode 1: Reload is caused in response to a negative transition at pin T2EX (P1.5), which can also request an interrupt. #### Capture This feature permits saving the actual timer/counter contents into a selected register upon an external event or a software write operation. Two modes are provided to latch the current 16-bit value in timer 2 registers into a dedicated capture register: Mode 0: Capture is performed in response to a transition at the corresponding port 1 pins CC0 to CC3. Mode 1: Write operation into the low-order byte of the dedicated capture register causes the timer 2 contents to be latched into this register. SAB 80515/80535 ## **SIEMENS** #### Compare In the compare mode, the 16-bit values stored in the dedicated compare registers are compared to the contents of the timer 2 registers. If the count value in the timer 2 registers matches one of the stored values, an appropriate output signal is generated and an interrupt is requested. Two compare modes are provided: - Mode 0: Upon a match the output signal changes from low to high. It goes back to a low level when timer 2 overflows. - Mode 1: The transition of the output signal can be determined by software. A timer 2 overflow causes no output change. Figure 4 Block Diagram of Timer/Counter 2 #### **Interrupt Structure** The SAB 80515 has 12 interrupt vectors with the following vector addresses and request flags: Table 3 Interrupt Sources and Vectors | Source (Request Flags) | Vector Address | Vector | |------------------------|----------------|-------------------------| | IE0 | 0003H | External interrupt 0 | | TF0 | 000BH | Timer 0 interrupt | | IE1 | 0013H | External interrupt 1 | | TF1 | 001BH | Timer 1 interrupt | | RI + TI | 0023H | Serial port interrupt | | TF2 + EXF2 | 002BH | Timer 2 interrupt | | IADC | 0043H | A/D converter interrupt | | IEX2 | 004BH | External interrupt 2 | | IEX3 | 0053H | External interrupt 3 | | IEX4 | 005BH | External interrupt 4 | | IEX5 | 0063H | External interrupt 5 | | IEX6 | 006BH | External interrupt 6 | Each interrupt vector can be individually enabled/disabled. The minimum response time to an interrupt request is more than 3 machine cycles and less than 9 machine cycles. Figure 5 shows the interrupt request sources. External interrupts 0 and 1 can be activated by a low-level or a negative transition (selectable) at their corresponding input pin, external interrupts 2 and 3 can be programmed for triggering on a negative or a positive transition. The external interrupts 3 to 6 are combined with the corresponding alternate functions compare (output) and capture (input) on port 1. For programming of the priority levels the interrupt vectors are combined to pairs. Each pair can be programmed individually to one of four priority levels by setting or clearing one bit in the special function register IPO and one in IP1. Figure 6 shows the priority level structure. Figure 5 Interrupt Request Sources Figure 6 Priority Level Structure #### I/O Ports The SAB 80515 has six 8-bit I/O ports and one 8-bit input port. Port 0 is an open-drain bidirectional I/O port, while ports 1 to 5 are quasi-bidirectional I/O ports with internal pull-up resistors. That means, when configured as inputs, ports 1 to 5 will be pulled high and will source current when externally pulled low. Port 0 will float when configured as input. Port 0 and port 2 can be used to expand the program and data memory externally. During an access to external memory, port 0 emits the low-order address byte and reads/writes the data byte, while port 2 emits the high-order address byte. In this function, port 0 is not an open-drain port, but uses a strong internal pullup FET. Ports 1 and 3 are provided for several alternate functions, as listed below: | Port | Symbol | Function | |------|----------|-------------------------------------------------------------------------------------| | P1.0 | INT3/CC0 | External interrupt 3 input, compare 0 output, capture 0 input | | P1.1 | INT4/CC1 | External interrupt 4 input, compare 1 output, capture 1 input | | P1.2 | INT5/CC2 | External interrupt 5 input, compare 2 output, capture 2 input | | P1.3 | INT6/CC3 | External interrupt 6 input, compare 3 output, capture 3 input | | P1.4 | INT2 | External interrupt 2 input | | P1.5 | T2EX | Timer 2 external reload trigger input | | P1.6 | CLKOUT | System clock output | | P1.7 | T2 | Timer 2 external counter input | | P3.0 | RXD | Serial port's receiver data input (asynchronous) or data input/output (synchronous) | | P3.1 | TXD | Serial port's transmitter data output (asynchronous) or clock output (synchronous) | | P3.2 | ĪNT0 | External interrupt 0 input, timer 0 gate control | | P3.3 | ĪNT1 | External interrupt 1 input, timer 1 gate control | | P3.4 | T0 | Timer 0 external counter input | | P3.5 | T1 | Timer 1 external counter input | | P3.6 | WR | External data memory write strobe | | P3.7 | RD | External data memory read strobe | The input port AN0-AN7 is used for analog input signals to the A/D converter. ### 21EMENA #### **Watchdog Timer** This feature is provided as a means of graceful recovery from a software upset. After an external reset, the watchdog timer is cleared and stopped. It can be started and cleared by software, but it cannot be stopped. If the software fails to clear the watchdog timer at least every 65532 machine cycles (about 65 ms if a 12 MHz oscillator frequency is used), an internal hardware reset will be initiated. The reset cause (external reset or reset caused by the watchdog) can be examined by software. To clear the watchdog, two bits in two different special function registers must be set by two consecutive instructions (bits IEN0.6 and IEN1.6). This is done to prevent the watchdog from being cleared by unexpected opcodes. #### **Instruction Set Summary** The SAB 80515/80535 has the same instruction set as the industry standard 8051 microcontroller. A pocket guide is available which contains the complete instruction set in functional and hexadecimal order. Furtheron it provides helpful information about Special Function Registers, Interrupt Vectors and Assembler Directives. #### Literature Information | Title | Ordering No. | |----------------------------------------------|---------------------------| | Microcontroller Family SAB 8051 Pocket Guide | B158-B6599 - X - X - 7600 | #### **Absolute Maximum Ratings** | Ambient temperature under bias | | |-------------------------------------------------------|----------------| | SAB 80515/80535 | 0 to 70 °C | | SAB 80515/80535-T40/85 | – 40 to 85 °C | | SAB 80515/80535-T40/110 | 40 to 110 °C | | Storage temperature | 65 to 150 °C | | Voltage on any pins with respect to ground $(V_{SS})$ | – 0.5 V to 7 V | | Power dissipation | 2 W | **Note** Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage of the device. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. ## DC Characteristics $V_{CC} = 5 \text{ V} \pm 10 \text{ %}; V_{SS} = 0 \text{ V}$ $T_{\rm A} = 0$ to 70 °C for the SAB 80515/80535 $T_{\rm A} = -40$ to 85 °C for the SAB 80515/80535-T40/85 $T_{\rm A} = -40$ to110 °C for the SAB 80515/80535-T40/110 | Parameter | Symbol | Limit | values | Unit | Test condition | | |---------------------------------------------|------------------|-------|--------------------------|------|-------------------------------------|--| | | | min. | max. | | | | | Input low voltage | VIL | - 0.5 | 0.8 | V | _ | | | Input high voltage)<br>(except RESET, XTAL2 | $V_{IH}$ | 2.0 | V <sub>CC</sub> – 0.5 | V | _ | | | Input high voltage to XTAL2 | V <sub>IH1</sub> | 2.5 | V <sub>CC</sub> +<br>0.5 | V | XTAL1 to V <sub>SS</sub> | | | Input high voltage to RESET | V <sub>IH2</sub> | 3.0 | - | V | - | | | Power down voltage | $V_{PD}$ | 3 | 5.5 | ٧ | V <sub>CC</sub> = 0 V | | | Output low voltage ports 1, 2, 3, 4, 5 | V <sub>OL</sub> | _ | 0.45 | ٧ | $I_{\rm OL}$ = 1.6 mA <sup>1)</sup> | | | Output low voltage port 0, ALE, PSEN | V <sub>OL1</sub> | _ | 0.45 | V | $I_{\rm OL}$ = 3.2 mA <sup>1)</sup> | | | Output high voltage ports 1, 2, 3, 4, 5 | V <sub>OH</sub> | 2.4 | _ | V | <i>I</i> <sub>OH</sub> = - 80 μA | | | Output high voltage port 0, ALE, PSEN | V <sub>OH1</sub> | 2.4 | _ | V | I <sub>OH</sub> = - 400 μA | | Capacitive loading on ports 0 and 2 may cause spurious noise pulses to be superimposed on the $V_{\rm OL}$ of ALE and ports 1,3,4,5. The noise is due to external bus capacitance discharging into the port 0 and port 2 pins when these pins make 1-0 transitions during bus operation. ### DC Characteristics (cont'd) | Parameter | Symbol | Limi | it values | Unit | Test condition | |------------------------------------------------------------------------------------------------------------|---------------------------------|------|-------------------|----------------|--------------------------------------------| | | | min. | max. | | | | Logic 0 input current<br>ports 1, 2, 3, 4, 5 | I <sub>IL</sub> | - | - 800 | μА | V <sub>IL</sub> = 0.45 V | | Logic 0 input current<br>XTAL2 | I <sub>IL2</sub> | - | - 2.5 | mA | $XTAL1 = V_{SS}$ $V_{IL} = 0.45 \text{ V}$ | | Input low current to RESET for reset | $I_{IL3}$ | - | - 500 | μА | V <sub>IL</sub> = 0.45 V | | Input leakage current to<br>port 0, EA AN0 - AN7 | $I_{LI}$ | - | ± 10 | μА | 0 V< V <sub>IN</sub> < V <sub>CC</sub> | | Power supply current: <sup>)</sup><br>SAB 80515/80535<br>SAB 80515/80535-T40/85<br>SAB 80515/80535-T40/110 | I <sub>CC</sub> I <sub>CC</sub> | | 210<br>230<br>230 | mA<br>mA<br>mA | all outputs<br>disconnected | | Power-down current | $I_{PD}$ | - | 3 | mA | V <sub>CC</sub> = 0 V | | Capacitance of I/O buffer | C <sub>IO</sub> | - | 10 | pF | f <sub>C</sub> =1 MHz | Capacitive loading on ports 0 and 2 may cause spurious noise pulses to be superimposed on the $V_{\rm OL}$ of ALE and ports 1,3,4,5. The noise is due to external bus capacitance discharging into the port 0 and port 2 pins when these pins make 1-0 transitions during bus operation. #### A/D Converter Characteristics $$\begin{split} V_{\text{CC}} = 5 \text{ V} \pm 10\%; \ V_{\text{SS}} = 0 \text{ V}; \ V_{\text{AREF}} = V_{\text{CC}} \pm 5\%; \ V_{\text{AGND}} = V_{\text{SS}} \pm 0.2 \text{ V}; \\ V_{\text{IntAREF}} - V_{\text{IntAGND}} \ge 1 \text{ V}; \qquad T_{\text{A}} = 0 \text{ to } +70 \text{ °C for SAB } 80515/80535 \\ T_{\text{A}} = -40 \text{ to } +85 \text{ °C for SAB } 80515/80535 \text{ - T40/85} \\ T_{\text{A}} = -40 \text{ to } +110 \text{ °C for SAB } 80515/80535 \text{ - T40/110} \end{split}$$ | Parameter | Symbol | Li | nit valu | ies | Unit | Test condition | |--------------------------------------------------------------------------------------------------------------|-----------------------|----------------------------|-------------------------------------------|----------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------| | | | min. | typ. | max. | | | | Analog input voltage | VAINPUT | V <sub>AGND</sub> -<br>0.2 | - | V <sub>AREF</sub> + 0.2 | V | _ | | Analog input capacitance | $C_{I}$ | - | 25 | - | pF | 1) | | Load time | tL | _ | _ | 2 t <sub>CY</sub> | μs | _ | | Sample time<br>(incl. load time) | ts | _ | _ | 5 t <sub>CY</sub> | μs | _ | | Conversion time (including sample time) | t <sub>C</sub> | _ | _ | 15 t <sub>CY</sub> | μs | _ | | Differential non-linearity<br>Integral non-linearity<br>Offset error<br>Gain error<br>Total unadjusted error | DNLE<br>INLE<br>TUE | _ | ± 1/2<br>± 1/2<br>± 1/2<br>± 1/2<br>± 1/2 | ±1<br>±1<br>±1<br>±1<br>±2 | LSB<br>LSB<br>LSB<br>LSB<br>LSB | $V_{\text{IntAREF}} = V_{\text{AREF}} = V_{\text{CC}}$ $V_{\text{IntAGND}} = V_{\text{AGND}} = V_{\text{SS}}$ 2) | | V <sub>AREF</sub> supply current | I <sub>REF</sub> | - | - | 5 | mA | 2) | | Internal reference error | V <sub>IntREFER</sub> | _ | ±5 | ± 15 | mV | 2) | <sup>1)</sup> The internal resistance of the analog source must be low enough to assure full loading of the sample capacitance $(C_1)$ during load time $(r_1)$ . After charging of the internal capacitance $(C_1)$ in the load time $(r_1)$ the analog input must be held constant for the rest of the sample time $(r_3)$ . <sup>&</sup>lt;sup>2)</sup> The differential impedance $r_{\rm D}$ of the analog reference voltage source must be less than 1 k $\Omega$ at reference supply voltage. ## A/D Characteristics $V_{\rm CC}$ = 5 V ± 10%; $V_{\rm SS}$ = 0 V; ( $C_{\rm L}$ for port 0, ALE and PSEN outputs = 100 pF; $C_{\rm L}$ for all other outputs = 80 pF) $T_{\rm A}$ = 0 to + 70 °C; for SAB 80515/80535 $T_{\rm A}$ = -40 to + 85 °C; for SAB 80515/80535 - 40/85 $T_{\rm A}$ = -40 to + 110 °C; for SAB 80515/80535 - 40/110 | Parameter | Symbol | Limit values | | | | | |-----------|--------|--------------|------|-----------------------------------------------------------|------|--| | | | 12 MHz clock | | Variable clock<br>1/t <sub>CLCL</sub> = 1.2 MHz to 12 MHz | | | | | | min | max. | min. | max. | | ### **Program Memory Characteristics** | Cycle Time | tCY | 1000 | _ | 12 t <sub>C LCL</sub> | - | ns | |------------------------------------|----------------------|------|-----|---------------------------|----------------------------|----| | ALE pulse width | t <sub>LHLL</sub> | 127 | - | 2 t <sub>CLCL</sub> - 40 | _ | ns | | Address setup to ALE | t <sub>AVLL</sub> | 53 | - | t <sub>CLCL</sub> - 30 | _ | ns | | Address hold after ALE | tLLAX1 | 48 | - | t <sub>C LCL</sub> - 35 | _ | ns | | ALE to valid instruction in | t <sub>ILIV</sub> | - | 233 | _ | 4 t <sub>C LCL</sub> - 100 | ns | | ALE to PSEN | t <sub>LLPL</sub> | 58 | _ | t <sub>C LCL</sub> - 25 | _ | ns | | PSEN pulse width | t <sub>PLPH</sub> | 215 | | 3 t <sub>C LCL</sub> - 35 | _ | ns | | PSEN to valid instruction in | t <sub>PLIV</sub> | - | 150 | _ | 3 t <sub>C LCL</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>C LCL</sub> - 20 | ns | | Address valid after<br>PSEN | t <sub>PXAV</sub> *) | 75 | - | t <sub>CLCL</sub> -8 | - | ns | | Address to valid instruction in | t <sub>A VIV</sub> | _ | 302 | _ | 5 t <sub>C LCL</sub> – 115 | ns | | Address float to PSEN | tAZPL | 0 | - | 0 | _ | ns | ¹) Interfacing the SAB 805156 to devices with float times up to 75 ns is permissible. This limited bus contention will not cause any damage to port 0 drivers. ## SAB 80515/80535 | Parameter | Symbol | Limit values | | | | | |-----------|--------|--------------|------|-----------------------------------------------------------|------|--| | | | 12 MHz clock | | Variable clock<br>1/t <sub>CLCL</sub> = 1.2 MHz to 12 MHz | | | | | | min | max. | min. | max. | | ## **External Data Memory Characteristics** | RD pulse width | t <sub>RLRH</sub> | 400 | - | 6 t <sub>CLCL</sub> – 100 | _ | ns | |-----------------------------|--------------------|-----|-----|---------------------------|----------------------------|----| | WR pulse width | <sup>‡</sup> WLWH | 400 | - | 6 t <sub>CLCL</sub> – 100 | _ | ns | | Address hold after ALE | t <sub>LLAX2</sub> | 132 | - | 2 t <sub>CLCL</sub> - 35 | _ | ns | | RD to valid data in | <sup>t</sup> RLDV | - | 252 | _ | 5 t <sub>CLCL</sub> - 165 | ns | | DATA hold after RD | <sup>‡</sup> RHDX | 0 | _ | 0 | | ns | | Data float after RD | <sup>t</sup> RHDZ | - | 97 | - | 2 t <sub>CLCL</sub> - 70 | ns | | ALE to valid data in | t <sub>LLDV</sub> | - | 517 | _ | 8 t <sub>CLCL</sub> — 150 | ns | | Address to valid data in | t <sub>AVDV</sub> | - | 585 | - | 9 t <sub>nCLCL</sub> - 165 | ns | | ALE to WR or RD | t <sub>LLWL</sub> | 200 | 300 | 3 t <sub>CLCL</sub> - 50 | 3 t <sub>CLCL</sub> + 50 | ns | | Address to WR or RD | t AVWL | 203 | - | 4 <sub>CLCL</sub> – 130 | _ | ns | | WR or RD high to ALE high | t <sub>WHLH</sub> | 43 | 123 | t <sub>CLCL</sub> - 40 | t <sub>CLCL</sub> + 40 | ns | | Data valid to WR transition | <sup>t</sup> Qvwx | 33 | _ | t <sub>CLCL</sub> - 50 | _ | ns | | Data setup before WR | t <sub>QVWH</sub> | 433 | _ | 7 t <sub>CLCL</sub> – 150 | _ | ns | | Data hold after WR | <sup>t</sup> WHQX | 33 | _ | t <sub>CLCL</sub> - 50 | _ | ns | | Address float after RD | <sup>t</sup> RLAZ | - | 0 | - | 0 | ns | #### **Waveforms** ## **Program Memory Read Cycle** ## **Data Memory Read Cycle** ## **Recommended Oscillator Circuits** ## AC Characteristics (cont'd) | Parameter | Symbol | Limit | Unit | |-----------|--------|---------------------------|------| | | | Variabl<br>Frequ. = 1.2 N | | | | | min. | max. | ## **External Clock Drive XTAL2** | Oscillator period | period $t_{\text{CLCL}}$ 83.3 833.3 | | 833.3 | ns | |-------------------|-------------------------------------|-----------------------------------------|-------------|----| | High time | t <sub>CHCX</sub> | 20 t <sub>CLCL</sub> -t <sub>CLCX</sub> | | ns | | Low time | t <sub>CLCX</sub> | 20 | tCLCL-tCHCX | ns | | Rise time | t <sub>CLCH</sub> | - | 20 | ns | | Fall time | t <sub>CHCL</sub> | _ | 20 | ns | | Oscillator period | t <sub>CLCL</sub> | 83.3 | 833.3 | ns | **External Clock Cycle** A.C. Testing Input, Output, Float Waveforms ## AC Characteristics (cont'd) | Parameter | Symbol | | Limit values | | | | | |-----------|--------|--------------|--------------|-----------------------------------------------------------|------|--|--| | | | 16 MHz clock | | Variable clock<br>1/t <sub>CLCL</sub> = 1.2 MHz to 12 MHz | | | | | | | min. | max. | min. | max. | | | ## **System Clock Timing** | ALE to CLKOUT | t <sub>LLSH</sub> | 543 | - | 7t <sub>CLCL</sub> - 40 | _ | ns | |------------------------|-------------------|-----|-----|--------------------------|-----------------------|----| | CLKOUT high time | t <sub>SHSL</sub> | 127 | | 2t <sub>CLCL</sub> - 40 | - | ns | | CLKOUT low time | t <sub>SLSH</sub> | 793 | _ | 10t <sub>CLCL</sub> - 40 | - | ns | | CLKOUT low to ALE high | t <sub>SLLH</sub> | 43 | 123 | t <sub>CLCL</sub> - 40 | t <sub>CLCL</sub> +40 | ns | **System Clock Timing** #### **ROM Verification Characteristics** $T_{\mathsf{A}} = 25^{\circ}\mathsf{C} \pm 5^{\circ}\mathsf{C}; \ V_{\mathsf{CC}} = 5 \ \mathsf{V} \pm 10\%; \ V_{\mathsf{SS}} = 0 \ \mathsf{V}$ | Parameter | Symbol | Limit values | | Unit | |-----------|--------|--------------|------|------| | | | min | max. | | #### **ROM Verification** | Address to valid data | <i>t</i> AVQV | _ | 48 t <sub>CLCL1</sub> | ns | |-------------------------|---------------------|---|-------------------------|-----| | ENABLE to valid data | <sup>t</sup> ELQV | - | 48 t <sub>CLCL1</sub> | ns | | Data float after ENABLE | t <sub>EHOZ</sub> | 0 | 48 t <sub>CLCL1</sub> · | ns | | Oscillator frequency | 1/t <sub>CLCL</sub> | 4 | 6 | MHz | #### **ROM Verification**