# **SIEMENS** # Microcomputer Components 8-Bit CMOS Microcontroller C517A | C517A Data | Sheet | | |----------------------------------|---------------------------------|----------------------------------------------| | Revision His | story: | Current Version: 10.97 | | Previous Ver | sion: | none | | Page<br>(in previous<br>Version) | Page<br>(in current<br>Version) | Subjects (major changes since last revision) | | | | | | | | | Edition 10.97 Published by Siemens AG, Bereich Halbleiter, MarketingKommunikation, Balanstraße 73, 81541 München © Siemens AG 1997. All Rights Reserved. #### Attention please! As far as patents or other rights of third parties are concerned, liability is only assumed for components, not for applications, processes and circuits implemented within components or assemblies. The information describes the type of component and shall not be considered as assured characteristics. Terms of delivery and rights to change design reserved. For questions on technology, delivery and prices please contact the Semiconductor Group Offices in Germany or the Siemens Companies and Representatives worldwide (see address list). Due to technical requirements components may contain dangerous substances. For information on the types in question please contact your nearest Siemens Office, Semiconductor Group. Siemens AG is an approved CECC manufacturer. #### **Packing** Please use the recycling operators known to you. We can also help you – get in touch with your nearest sales office. By agreement we will take packing material back, if it is sorted. You must bear the costs of transport. For packing material that is returned to us unsorted or which we are not obliged to accept, we shall have to invoice you for any costs incurred. #### Components used in life-support devices or systems must be expressly authorized for such purpose! Critical components<sup>1</sup> of the Semiconductor Group of Siemens AG, may only be used in life-support devices or systems<sup>2</sup> with the express written approval of the Semiconductor Group of Siemens AG. - 1 A critical component is a component used in a life-support device or system whose failure can reasonably be expected to cause the failure of that life-support device or system, or to affect its safety or effectiveness of that device or system. - 2 Life support devices or systems are intended (a) to be implanted in the human body, or (b) to support and/or maintain and sustain human life. If they fail, it is reasonable to assume that the health of the user may be endangered. ## **8-Bit CMOS Microcontroller** C517A #### **Advance Information** - Full upward compatibility with SAB 80C517A/83C517A-5 - Up to 24 MHz external operating frequency - 500 ns instruction cycle at 24 MHz operation - Superset of the 8051 architecture with 8 datapointers - On-chip emulation support logic (Enhanced Hooks Technology TM) - 32K byte on-chip ROM (with optional ROM protection) - alternatively up to 64K byte external program memory - Up to 64K byte external data memory - 256 byte on-chip RAM - Additional 2K byte on-chip RAM (XRAM) - Seven 8-bit parallel I/O ports - Two input ports for analog/digital input (further features are on next page) Figure 1 C517A Functional Units ## Features (cont'd): - Two full duplex serial interfaces (USART) - 4 operating modes, fixed or variable baud rates - programmable baud rate generators - Four 16-bit timer/counters - Timer 0 / 1 (C501 compatible) - Timer 2 for 16-bit reload, compare, or capture functions - Compare timer for compare/capture functions - Powerful 16-bit compare/capture unit (CCU) with up to 21 high-speed or PWM output channels and 5 capture inputs - 10-bit A/D converter - 12 multiplexed analog inputs - Built-in self calibration - Extended watchdog facilities - 15-bit programmable watchdog timer - Oscillator watchdog - Power saving modes - Slow down mode - Idle mode (can be combined with slow down mode) - Software power-down mode - Hardware power-down mode - 17 interrupt sources (7 external, 10 internal) selectable at 4 priority levels - P-MQFP-100 packages - Temperature Ranges: SAB-C517A $T_A = 0$ to 70 °C SAF-C517A $T_A$ = -40 to 85 °C SAH-C517A $T_A$ = -40 to 110 °C # Table 1 Ordering Information | Туре | Ordering Code | Package | Description (8-Bit CMOS microcontroller) | |-----------------|---------------|--------------|-----------------------------------------------------------------| | SAB-C517A-4RM | Q67120-DXXXX | P-MQFP-100-2 | with mask programmable ROM (18 MHz) | | SAF-C517A-4RM | Q67120-DXXXX | P-MQFP-100-2 | with mask programmable ROM (18 MHz) ext. temp. – 40 °C to 85 °C | | SAB-C517A-4R24M | Q67120-DXXXX | P-MQFP-100-2 | with mask programmable ROM (24 MHz) | | SAF-C517A-4R24M | Q67120-DXXXX | P-MQFP-100-2 | with mask programmable ROM (24 MHz) ext. temp. – 40 °C to 85 °C | | SAB-C517A-LM | Q67127-C1071 | P-MQFP-100-2 | for external memory (18 MHz) | | SAF-C517A-LM | Q67127-C1063 | P-MQFP-100-2 | for external memory (18 MHz) ext. temp. – 40 °C to 85 °C | | SAB-C517A-L24M | Q67127-C1072 | P-MQFP-100-2 | for external memory (24 MHz) | **Note:** Versions for extended temperature ranges – 40 °C to 110 °C (SAH-C517A) are available on request. The ordering number of ROM types (DXXXX extensions) is defined after program release (verification) of the customer. Figure 2 Logic Symbol ## **Additional Literature** For further information about the C517A the following literature is available: | Title | Ordering Number | |----------------------------------------------------------------------------|---------------------| | C517A 8-Bit CMOS Microcontroller User's Manual | B158-H7053-X-X-7600 | | C500 Microcontroller Family Architecture and Instruction Set User's Manual | B158-H6987-X-X-7600 | | C500 Microcontroller Family - Pocket Guide | B158-H6986-X-X-7600 | Figure 3 Pin Configuration P-MQFP-100 Package (Top View) Table 2 Pin Definitions and Functions | Symbol | Pin Number | I/O*) | Function | | | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|--| | | P-MQFP-100 | | | | | | P1.0 - P1.7 | 9 - 6, 1,<br>100 - 98 | I/O | Port 1 is an 8-bit quasi-bidirectional I/O port with internal pullup resistors. Port 1 pins that have 1's written to them are pulled high by the internal pullup resistors, and in that state can be used as inputs. As inputs, port 1 pins being externally pulled low will source current ( <i>I</i> <sub>IL</sub> , in the DC characteristics) because of the internal pullup resistors. The port is used for the low-order address byte during program verification. Port 1 also contains the interrupt, timer, clock, capture and compare 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 (except when used for the compare functions). The secondary functions are assigned to the | | | | | 9 | | port 1 pins as followed P1.0 INT3 CC0 | Interrupt 3 input / compare 0 output / | | | | 8 | | P1.1 INT4 CC1 | capture 0 input<br>Interrupt 4 input / compare 1 output /<br>capture 1 input | | | | 7 | | P1.2 INT5 CC2 | Interrupt 5 input / compare 2 output / capture 2 input | | | | 6 | | P1.3 INT6 CC3 | Interrupt 6 input / compare 3 output / capture 3 input | | | | 1 P1.4 INT2 Interrupt 2 input 100 P1.5 T2EX Timer 2 external reload 99 P1.6 CLKOUT System clock output 98 P1.7 T2 Counter 2 input | | | | | | V <sub>SS</sub> | 10, 62 | _ | Ground (0V)<br>during normal, idle | , and power down operation. | | | V <sub>CC</sub> | 11, 63 | - | Supply voltage during normal, idle | , and power down mode. | | <sup>\*)</sup> I = Input O = Output Table 2 Pin Definitions and Functions (cont'd) | Symbol | Pin Number | I/O*) | Function | | | |-------------|------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | P-MQFP-100 | | | | | | XTAL2 | 12 | - | is the input to the inverting oscillator amplifier and input to the internal clock generator circuits. To drive the device from an external clock source, XTAL2 should be driven, while XTAL1 is left unconnected. Minimum and maximum high and low times as well as rise/fall times specified in the AC characteristics must be observed. | | | | XTAL1 | 13 | _ | <b>XTAL1</b> is the output of the inverting oscillator amplifier. This pin is used for the oscillator operation with crystal or ceramic resonator. | | | | P2.0 - P2.7 | 14 - 21 | I/O | is an 8-bit quasi-bidirectional I/O port with internal pullup resistors. Port 2 pins that have 1's written to them are pulled high by the internal pullup resistors, and in that state can be used as inputs. As inputs, port 2 pins being externally pulled low will source current ( <i>I</i> <sub>IL</sub> , in the DC characteristics) because of the internal pullup 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 pullup resistors when issuing 1's. 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 | 22 | 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. The signal remains high during internal program execution. | | | | ALE | 23 | 0 | The Address Latch enable output is 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. | | | <sup>\*)</sup> I = Input O = Output Table 2 Pin Definitions and Functions (cont'd) | Symbol | Pin Number | I/O*) | Function | | | |-------------|--------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | P-MQFP-100 | | | | | | ĒΑ | 24 | I | External Access Enable When held high, the C517A executes instructions from the internal ROM as long as the PC is less than 8000 <sub>H</sub> . When held low, the C517A fetches all instructions from external program memory. For the C517A-L this pin must be tied low. | | | | P0.0 - P0.7 | 26, 27,<br>30 - 35 | I/O | Port 0 is an 8-bit open-drain bidirectional I/O port. Port 0 pins that have 1's written to them float, and in that state can be used as high-impedance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external program and data memory. In this application it uses strong internal pullup resistors when issuing 1's. Port 0 also outputs the code bytes during program verification in the C517A. External pullup resistors are required during program verification. | | | | HWPD | 36 | I | Hardware Power Down A low level on this pin for the duration of one machine cycle while the oscillator is running resets the C517A. A low level for a longer period will force the part into hardware power down mode with the pins floating. There is no internal pullup resistor connected to this pin. | | | | P5.0 - P5.7 | 44 - 37 | I/O | is a quasi-bidirectional I/O port with internal pull-up resistors. Port 5 pins that have 1 s written to them are pulled high by the internal pull-up resistors, and in that state can be used as inputs. As inputs, port 5 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. This port also serves the alternate function "Concurrent Compare" and "Set/Reset Compare". The secondary functions are assigned to the port 5 pins as follows: CCM0 to CCM7 P5.0 to P5.7: concurrent compare or Set/Reset lines | | | <sup>\*)</sup> I = Input O = Output Table 2 Pin Definitions and Functions (cont'd) | Symbol | Pin Number | I/O*) | Function | | | |-------------|---------------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | P-MQFP-100 | | | | | | OWE | 45 | I | Oscillator Watchdog Enable A high level on this pin enables the oscillator watchdog. When left unconnected this pin is pulled high by a weak internal pull-up resistor. The logic level at OWE should not be changed during normal operation. When held at low level the oscillator watchdog function is turned off. During hardware power down the pullup resistor is switched off. | | | | P6.0 - P6.7 | 46 - 50,<br>54 - 56<br>46<br>47<br>48 | I/O | is a quasi-bidirectional I/O port with internal pull-up resistors. Port 6 pins that have 1 s written to them are pulled high by the internal pull-up resistors, and in that state can be used as inputs. As inputs, port 6 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 6 also contains the external A/D converter control pin and the transmit and receive pins for the serial interface 1. The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate. The secondary functions are assigned to the pins of port 6, as follows: P6.0 ADST external A/D converter start pin P6.1 RxD1 receiver data input of serial interface 1 P6.2 TxD1 transmitter data input of serial interface 1 | | | | P8.0 - P8.3 | 57 - 60 | I | Port 8 is a 4-bit unidirectional input port. Port pins can be used for digital input, if voltage levels meet the specified input high/low voltages, and for the higher 4-bit of the multiplexed analog inputs of the A/D converter, simultaneously. P8.0 - P8.3 AIN8 - AIN11 analog input 8 - 14 | | | | RO | 61 | 0 | Reset Output This pin outputs the internally synchronized reset request signal. This signal may be generated by an external hardware reset, a watchdog timer reset or an oscillator watchdog reset. The RO is active low. | | | <sup>\*)</sup> I = Input O = Output Table 2 Pin Definitions and Functions (cont'd) | Symbol | Pin Number | I/O*) | Function | |-------------------|---------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | P-MQFP-100 | | | | P4.0 - P4.7 | 64 - 66,<br>68 - 72 | I/O | Port 4 is an 8-bit quasi-bidirectional I/O port with internal pull-up resistors. Port 4 pins that have 1's written to them are pulled high by the internal pull-up resistors, and in that state can be used as inputs. As inputs, port 4 pins being externally pulled low will source current ( <i>I</i> <sub>IL</sub> , in the DC characteristics) because of the internal pull-up resistors. | | PE/SWD | 67 | I | Power saving mode enable / Start watchdog timer A low level at this pin allows the software to enter the power saving modes (idle mode, slow down mode, and power down mode). In case the low level is also seen during reset, the watchdog timer function is off on default. Usage of the software controlled power saving modes is blocked, when this pin is held at high level. A high level during reset performs an automatic start of the watchdog timer immediately after reset. When left unconnected this pin is pulled high by a weak internal pull-up resistor. During hardware power down the pullup resistor is switched off. | | RESET | 73 | I | RESET A low level on this pin for the duration of two machine cycles while the oscillator is running resets the C517A. A small internal pullup resistor permits power-on reset using only a capacitor connected to V <sub>SS</sub> . | | V <sub>AREF</sub> | 78 | _ | Reference voltage for the A/D converter | | V <sub>AGND</sub> | 79 | _ | Reference ground for the A/D converter | | P7.0 - P7.7 | 87 - 80 | | Port 7 is an 8-bit unidirectional input port. Port pins can be used for digital input, if voltage levels meet the specified input high/low voltages, and for the lower 8-bit of the multiplexed analog inputs of the A/D converter, simultaneously. P7.0 - P7.7 AINO - AIN7 analog input 8 - 14 | <sup>\*)</sup> I = Input O = Output Table 2 Pin Definitions and Functions (cont'd) | Symbol | Pin Number | I/O*) | Functi | on | | | | | |-------------|-----------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------------------------------------------------------------------------------|--|--|--| | | P-MQFP-100 | | | | | | | | | P3.0 - P3.7 | 90 - 97 | I/O | Port 3 is an 8-bit quasi-bidirectional I/O port with internal pullup resistors. Port 3 pins that have 1's written to them are pulled high by the internal pullup resistors, and in that state can be used as inputs. As inputs, port 3 pins being externally pulled low will source current ( <i>I</i> <sub>IL</sub> , in the DC characteristics) because of the internal pullup resistors. Port 3 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 | | | | | | | | | | to oper | rate. The | e programmed to a one (1) for that function secondary functions are assigned to the | | | | | | | | pins of port 3, as follows: | | | | | | | | 90 | | P3.0 | RxD0 | Receiver data input (asynch.) or data input/output (synch.) of serial interface 0 | | | | | | 91 | | P3.1 | TxD0 | Transmitter data output (asynch.) or clock output (synch.) of serial interface 0 | | | | | | 92 | | P3.2 | ĪNT0 | External interrupt 0 input / timer 0 gate control input | | | | | | 93 | | P3.3 | ĪNT1 | External interrupt 1 input / timer 1 gate control input | | | | | | 94 | | P3.4 | T0 | Timer 0 counter input | | | | | | 95 | | P3.5 | T1 | Timer 1 counter input | | | | | | 96 | | P3.6 | WR | WR control output; latches the data byte from port 0 into the external data memory | | | | | | 97 | | P3.7 | RD | RD control output; enables the external data memory | | | | | N.C. | 2 - 5, 25,<br>28, 29, 32,<br>43, 44,<br>51 - 53,<br>74 - 77<br>88, 89 | _ | | • | e P-MQFP-100 package need not be | | | | <sup>\*)</sup> I = Input O = Output Figure 4 Block Diagram of the C517A Reset Value: 00H # **CPU** The C517A 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 are executed in $1\mu s$ (24 MHz: 500 ns). # Special Function Register PSW (Address D0<sub>H</sub>) | Bit No. | MSB | | | | | | | LSB | | |-----------------|-----|-----------------|----|-----|-----|----|----|-------|-----| | | | D6 <sub>H</sub> | | | | | | • • • | _ | | D0 <sub>H</sub> | CY | AC | F0 | RS1 | RS0 | OV | F1 | Р | PSW | | Bit | Function | Function | | | | | | |------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|----------------------------------------------------------------|--|--|--|--| | CY | Carry Flag<br>Used by a | )<br>rithmetic in | estruction. | | | | | | AC | Auxiliary (<br>Used by ir | | which execute BCD operations. | | | | | | F0 | General P | urpose Fla | g | | | | | | RS1<br>RS0 | | | control bits<br>to select one of the four register banks. | | | | | | | RS1 | RS0 | Function | | | | | | | 0 | 0 | Bank 0 selected, data address 00 <sub>H</sub> -07 <sub>H</sub> | | | | | | | 0 | Bank 1 selected, data address 08 <sub>H</sub> -0F <sub>H</sub> | | | | | | | | 1 | 0 | Bank 2 selected, data address 10 <sub>H</sub> -17 <sub>H</sub> | | | | | | | 1 | 1 1 Bank 3 selected, data address 18 <sub>H</sub> -1F <sub>H</sub> | | | | | | | OV | | Overflow Flag Used by arithmetic instruction. | | | | | | | F1 | General P | General Purpose Flag | | | | | | | P | Parity Flag Set/cleared by hardware after each instruction to indicate an odd/even number of "one" bits in the accumulator, i.e. even parity. | | | | | | | # **Memory Organization** The C517A CPU manipulates operands in the following five address spaces: - up to 64 Kbyte of program memory (32K on-chip program memory for C517A-4R) - up to 64 Kbyte of external data memory - 256 bytes of internal data memory - 2K bytes of internal XRAM data memory - a 128 byte special function register area **Figure 5** illustrates the memory address spaces of the C517A. Figure 5 C517A Memory Map # **Reset and System Clock** The reset input is an active low input at pin $\overline{\text{RESET}}$ . Since the reset is synchronized internally, the $\overline{\text{RESET}}$ pin must be held low for at least two machine cycles (24 oscillator periods) while the oscillator is running. A pullup resistor is internally connected to $V_{\text{CC}}$ to allow a power-up reset with an external capacitor only. An automatic reset can be obtained when $V_{\text{CC}}$ is applied by connecting the $\overline{\text{RESET}}$ pin to $V_{\text{SS}}$ via a capacitor. **Figure 6** shows the possible reset circuitries. Figure 6 Reset Circuitries Figure 7 shows the recommended oscillator circuitries for crystal and external clock operation. Figure 7 Recommended Oscillator Circuitries # **Enhanced Hooks Emulation Concept** The Enhanced Hooks Emulation Concept of the C500 microcontroller family is a new, innovative way to control the execution of C500 MCUs and to gain extensive information on the internal operation of the controllers. Emulation of on-chip ROM based programs is possible, too. Each production chip has built-in logic for the support of the Enhanced Hooks Emulation Concept. Therefore, no costly bond-out chips are necessary for emulation. This also ensure that emulation and production chips are identical. The Enhanced Hooks Technology<sup>TM 1)</sup>, which requires embedded logic in the C500 allows the C500 together with an EH-IC to function similar to a bond-out chip. This simplifies the design and reduces costs of an ICE-system. ICE-systems using an EH-IC and a compatible C500 are able to emulate all operating modes of the different versions of the C500 microcontrollers. This includes emulation of ROM, ROM with code rollover and ROMless modes of operation. It is also able to operate in single step mode and to read the SFRs after a break. Figure 8 Basic C500 MCU Enhanced Hooks Concept Configuration Port 0, port 2 and some of the control lines of the C500 based MCU are used by Enhanced Hooks Emulation Concept to control the operation of the device during emulation and to transfer informations about the program execution and data transfer between the external emulation hardware (ICE-system) and the C500 MCU. <sup>1 &</sup>quot;Enhanced Hooks Technology" is a trademark and patent of Metalink Corporation licensed to Siemens. # **Special Function Registers** The registers, except the program counter and the four general purpose register banks, reside in the special function register area. The 94 special function registers (SFRs) in the standard and mapped SFR area include pointers and registers that provide an interface between the CPU and the other on-chip peripherals. All SFRs with addresses where address bits 0-2 are 0 (e.g. 80<sub>H</sub>, 88<sub>H</sub>, 90<sub>H</sub>, 98<sub>H</sub>, ..., F8<sub>H</sub>, FF<sub>H</sub>) are bitaddressable. The SFRs of the C517A are listed in **table 3** and **table 4**. In **table 3** they are organized in groups which refer to the functional blocks of the C517A. **Table 4** illustrates the contents of the SFRs in numeric order of their addresses. Table 3 **Special Function Registers - Functional Blocks** | Block | Symbol | Name | Address | Contents after<br>Reset | |----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CPU | ACC<br>B<br>DPH<br>DPL<br>DPSEL<br>PSW<br>SP | Accumulator B-Register Data Pointer, High Byte Data Pointer, Low Byte Data Pointer Select Register Program Status Word Register Stack Pointer | E0 <sub>H</sub> 1)<br>F0 <sub>H</sub> 1)<br>83 <sub>H</sub><br>82 <sub>H</sub><br>92 <sub>H</sub><br>D0 <sub>H</sub> 1)<br>81 <sub>H</sub> | 00H<br>00H<br>00H<br>00H<br>XXXX X000B <sup>3)</sup><br>00H<br>07H | | A/D-<br>Converter | ADCON0 <sup>2)</sup><br>ADCON1<br>ADDATH<br>ADDATL | A/D Converter Control Register 0 A/D Converter Control Register 1 A/D Converter Data Register, High Byte A/D Converter Data Register, Low Byte | D8 <sub>H</sub> 1)<br>DC <sub>H</sub><br>D9 <sub>H</sub><br>DA <sub>H</sub> | 00 <sub>H</sub><br>0XXX 0000 <sub>B</sub> <sup>3)</sup><br>00 <sub>H</sub><br>00XX XXXX <sub>B</sub> <sup>3</sup> | | Interrupt<br>System | IEN0 <sup>2)</sup> IEN1 <sup>2)</sup> IEN2 IP0 <sup>2)</sup> IP1 IRCON0 <sup>2)</sup> IRCON1 TCON <sup>2)</sup> T2CON <sup>2)</sup> S0CON <sup>2)</sup> CTCON <sup>2)</sup> | Interrupt Enable Register 0 Interrupt Enable Register 1 Interrupt Enable Register 2 Interrupt Priority Register 0 Interrupt Priority Register 1 Interrupt Request Control Register 0 Interrupt Request Control Register 1 Timer 0/1 Control Register Timer 2 Control Register Serial Channel 0 Control Register Compare Timer Control Register | A8H <sup>1)</sup> B8H <sup>1)</sup> 9AH A9H B9H C0H <sup>1)</sup> D1H 88H <sup>1)</sup> C8H <sup>1)</sup> 98H <sup>1)</sup> | 00 <sub>H</sub><br>00 <sub>H</sub><br>XX00 00X0 <sub>B</sub> <sup>3)</sup><br>00 <sub>H</sub><br>XX00 0000 <sub>B</sub> <sup>3)</sup><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub> | | MUL/DIV<br>Unit | ARCON<br>MD0<br>MD1<br>MD2<br>MD3<br>MD4<br>MD5 | Arithmetic Control Register Multiplication/Division Register 0 Multiplication/Division Register 1 Multiplication/Division Register 2 Multiplication/Division Register 3 Multiplication/Division Register 4 Multiplication/Division Register 5 | EFH<br>E9H<br>EAH<br>EBH<br>ECH<br>EDH<br>EEH | 0XXXXXXX <sub>B</sub> 3)<br>XX <sub>H</sub> 3)<br>XX <sub>H</sub> 3)<br>XX <sub>H</sub> 3)<br>XX <sub>H</sub> 3)<br>XX <sub>H</sub> 3)<br>XX <sub>H</sub> 3) | | Timer 0 /<br>Timer 1 | TCON <sup>2)</sup> TH0 TH1 TL0 TL1 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 | 00H<br>00H<br>00H<br>00H<br>00H<br>00H | <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. 3) 'X' means that the value is undefined and the location is reserved Table 3 Special Function Registers - Functional Blocks (cont'd) | Block | Symbol | Name | Address | Contents after Reset | |----------|----------------------|------------------------------------------------------------------------|------------------------------------|---------------------------------------| | Compare/ | CCEN | Compare/Capture Enable Register | C1 <sub>H</sub> | 00 <sub>H</sub> | | Capture | CC4EN | Compare/Capture 4 Enable Register | C9H | 00H | | Unit . | CCH1 | Compare/Capture Register 1, High Byte | C3H | 00H | | (CCU) | CCH2 | Compare/Capture Register 2, High Byte | C5H | 00H | | Timer 2 | CCH3 | Compare/Capture Register 3, High Byte | C7H | 00H | | | CCH4 | Compare/Capture Register 4, High Byte | CFH | 00H | | | CCL1 | Compare/Capture Register 1, Low Byte | C2H | 00H | | | CCL2 | Compare/Capture Register 2, Low Byte | C4H | 00H | | | CCL3 | Compare/Capture Register 3, Low Byte | C6H | 00H | | | CCL4 | Compare/Capture Register 4, Low Byte | CEH | 00H | | | CMEN | Compare Enable Register | F6H | 00H | | | CMH0 | Compare Register 0, High Byte | D3 <sub>H</sub> | 00H | | | CMH1 | Compare Register 1, High Byte | D5 <sub>H</sub> | 00H | | | CMH2 | Compare Register 2, High Byte | D7 <sub>H</sub> | 00H | | | CMH3 | Compare Register 3, High Byte | E3H | 00H | | | CMH4 | Compare Register 4, High Byte | E5 <sub>H</sub> | 00H | | | CMH5 | Compare Register 5, High Byte | E7 <sub>H</sub> | 00H | | | CMH6 | Compare Register 6, High Byte | F3 <sub>H</sub> | 00H | | | CMH7 | Compare Register 7, High Byte | F5 <sub>H</sub> | 00H | | | CML0 | Compare Register 0, Low Byte | D2 <sub>H</sub> | 00H | | | CML1 | Compare Register 1, Low Byte | D4 <sub>H</sub> | 00H | | | CML2 | Compare Register 2, Low Byte | D <sub>4</sub> H | 00H | | | CML3 | Compare Register 3, Low Byte | E2 <sub>H</sub> | 00H | | | CML4 | Compare Register 4, Low Byte | E4 <sub>H</sub> | 00H | | | CML5 | Compare Register 5, Low Byte | E6H | 00H | | | CML6 | Compare Register 6, Low Byte | | 00H | | | CML7 | Compare Register 7, Low Byte | F2 <sub>H</sub><br>F4 <sub>H</sub> | 00H | | | CMSEL | Compare Input Select | F7 <sub>H</sub> | 00H | | | CRCH | Comp./Rel./Capt. Register High Byte | CB. | 00H<br>00H | | | CRCL | Comp./Rel./Capt. Register Low Byte | CB <sub>H</sub><br>CA <sub>H</sub> | 00H | | | COMSETL | Compare Set Register Low Byte | A1 <sub>H</sub> | 00H | | | COMSETH | Compare Set Register, High Byte | ^!H<br>^2 | 00H | | | COMCLRL | Compare Clear Register, Low Byte | A2 <sub>H</sub><br>A3 <sub>H</sub> | 00H | | | COMCLRH | Compare Clear Register, High Byte | ^3H | 00H | | | SETMSK | Compare Set Mask Register | A4H | 00H<br>00H | | | CLRMSK | Compare Clear Mask Register | A5 <sub>H</sub> | 00H | | | | Compare Timer Control Register | A6H | 00H | | | CTCON 2)<br>CTRELH | Compare Timer Control Register Compare Timer Rel. Register, High Byte | E1H | 0X00 0000 <sub>B</sub> <sup>3</sup> ) | | | | , , | DFH | 00H | | | CTRELL | Compare Timer Rel. Register, Low Byte | DEH | 00H | | | TH2 | Timer 2, High Byte | CDH | 00H | | | TL2 | Timer 2, Low Byte | CCH | 00H | | | T2CON 2) | Timer 2 Control Register | C8H 1) | 00H | | | IRCON0 <sup>2)</sup> | Interrupt Request Control Register 0 | C0H 1) | 00H | <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>x27;X' means that the value is undefined and the location is reserved Table 3 Special Function Registers - Functional Blocks (cont'd) | Block | Symbol | Name | Address | Contents after<br>Reset | |--------------------|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Ports | P0<br>P1<br>P2<br>P3<br>P4<br>P5<br>P6<br>P7 | Port 0 Port 1 Port 2 Port 3 Port 4 Port 5 Port 6 Port 7, Analog/Digital Input Port 8, Analog/Digital Input, 4-bit | 80H <sup>1)</sup> 90H <sup>1)</sup> A0H <sup>1)</sup> B0H <sup>1)</sup> E8H <sup>1)</sup> F8H <sup>1)</sup> FAH DBH DDH | FFH<br>FFH<br>FFH<br>FFH<br>FFH<br>FFH<br>- | | XRAM | XPAGE<br>SYSCON 2) | Page Address Register for Extended<br>On-Chip RAM<br>System/XRAM Control Register | 91 <sub>H</sub><br>B1 <sub>H</sub> | OO <sub>H</sub> | | Serial<br>Channels | ADCONO <sup>2)</sup> PCON <sup>2)</sup> S0BUF S0CON S0RELL S0RELH S1BUF S1CON S1RELL S1RELL | A/D Converter Control Register Power Control Register Serial Channel 0 Buffer Register Serial Channel 0 Control Register Serial Channel 0 Reload Reg., Low Byte Serial Channel 0 Reload Reg., High Byte Serial Channel 1 Buffer Register Serial Channel 1 Control Register Serial Channel 1 Reload Reg., Low Byte Serial Channel 1 Reload Reg., High Byte | <b>D8H</b> 1)<br>87H<br>99H<br><b>98H</b> 1)<br>AAH<br>BAH<br>9CH<br>9BH<br>9DH<br>BBH | 00 <sub>H</sub><br>00 <sub>H</sub><br>XX <sub>H</sub> <sup>3</sup> )<br>00 <sub>H</sub><br>D9 <sub>H</sub><br>XXXX XX11 <sub>B</sub> <sup>3</sup> )<br>XX <sub>H</sub> <sup>3</sup> )<br>0X00 0000 <sub>B</sub> <sup>3</sup> )<br>00 <sub>H</sub><br>XXXX XX11 <sub>B</sub> <sup>3</sup> ) | | Watchdog | IEN0 <sup>2)</sup> IEN1 <sup>2)</sup> IP0 <sup>2)</sup> WDTREL | Interrupt Enable Register 0 Interrupt Enable Register 1 Interrupt Priority Register 0 Watchdog Timer Reload Register | <b>A8<sub>H</sub></b> <sup>1)</sup><br><b>B8<sub>H</sub></b> <sup>1)</sup><br>A9 <sub>H</sub><br>86 <sub>H</sub> | 00H<br>00H<br>00H<br>00H | | Pow. Sav.<br>Modes | PCON 2) | Power Control Register | 87 <sub>H</sub> | 00 <sub>H</sub> | 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 undefined and the location is reserved. Table 4 Contents of the SFRs, SFRs in numeric order of their addresses | Addr | Register | Content<br>after<br>Reset <sup>1)</sup> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |-------------------------------|----------|-----------------------------------------|--------------|-------------|-------|-------|-------|-------|-------|-------| | 80 <sub>H</sub> <sup>2)</sup> | P0 | FFH | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 81 <sub>H</sub> | SP | 07 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 82 <sub>H</sub> | DPL | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 83 <sub>H</sub> | DPH | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 83 <sub>H</sub> | WDTREL | 00 <sub>H</sub> | WDT-<br>PSEL | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 87 <sub>H</sub> | PCON | 00 <sub>H</sub> | SMOD | PDS | IDLS | SD | GF1 | GF0 | PDE | IDLE | | 88H <sup>2)</sup> | TCON | 00 <sub>H</sub> | TF1 | TR1 | TF0 | TR0 | IE1 | IT1 | IE0 | IT0 | | 89 <sub>H</sub> | TMOD | 00 <sub>H</sub> | GATE | C/T | M1 | MO | GATE | C/T | M1 | MO | | 8A <sub>H</sub> | TL0 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 8B <sub>H</sub> | TL1 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 8C <sub>H</sub> | TH0 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 8D <sub>H</sub> | TH1 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 90H <sup>2)</sup> | P1 | FFH | T2 | CLK-<br>OUT | T2EX | ĪNT2 | INT6 | INT5 | INT4 | ĪNT3 | | 91 <sub>H</sub> | XPAGE | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 92 <sub>H</sub> | DPSEL | XXXX-<br>X000B | _ | _ | _ | _ | _ | .2 | .1 | .0 | | 98H <sup>2)</sup> | S0CON | 00 <sub>H</sub> | SM0 | SM1 | SM20 | REN0 | TB80 | RB80 | TIO | RI0 | | 99 <sub>H</sub> | S0BUF | хх <sub>Н</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 9A <sub>H</sub> | IEN2 | XX00-<br>00X0 <sub>B</sub> | _ | _ | ECR | ECS | ECT | ECMP | _ | ES1 | | 9B <sub>H</sub> | S1CON | 0X00-<br>0000 <sub>B</sub> | SM | _ | SM21 | REN1 | TB81 | RB81 | TI1 | RI1 | | 9C <sub>H</sub> | S1BUF | ХХН | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 9D <sub>H</sub> | S1RELL | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | A0H <sup>2)</sup> | P2 | FFH | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | A <sub>1</sub> H | COMSETL | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | A2 <sub>H</sub> | COMSETH | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | A3 <sub>H</sub> | COMCLRL | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | <sup>1) &#</sup>x27;X' means that the value is undefined and the location is reserved <sup>2)</sup> Shaded registers are bit-addressable special function registers Table 4 Contents of the SFRs, SFRs in numeric order of their addresses (cont'd) | Addr | Register | Content<br>after<br>Reset <sup>1)</sup> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |-------------------|----------|-----------------------------------------|-------------|------------|------------|------------|-------------|------------|------------|------------| | A4 <sub>H</sub> | COMCLRH | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | A5 <sub>H</sub> | SETMSK | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | A6 <sub>H</sub> | CLRMSK | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | A8H <sup>2)</sup> | IEN0 | 00 <sub>H</sub> | EAL | WDT | ET2 | ES0 | ET1 | EX1 | ET0 | EX0 | | A9 <sub>H</sub> | IP0 | 00 <sub>H</sub> | OWDS | WDTS | .5 | .4 | .3 | .2 | .1 | .0 | | $AA_H$ | S0RELL | D9 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | B0H <sup>2)</sup> | P3 | FFH | RD | WR | T1 | ТО | INT1 | INT0 | TxD0 | RxD0 | | B1 <sub>H</sub> | SYSCON | XXXX-<br>XX01 <sub>B</sub> | _ | _ | _ | _ | _ | _ | XMAP1 | XMAP0 | | B8H <sup>2)</sup> | IEN1 | 00 <sub>H</sub> | EXEN2 | SWDT | EX6 | EX5 | EX4 | EX3 | EX2 | EADC | | B9 <sub>H</sub> | IP1 | 0000 <sub>B</sub> | _ | _ | .5 | .4 | .3 | .2 | .1 | .0 | | BA <sub>H</sub> | S0RELH | XXXX-<br>XX11 <sub>B</sub> | _ | _ | _ | _ | _ | _ | .1 | .0 | | BB <sub>H</sub> | S1RELH | XXXX-<br>XX11 <sub>B</sub> | _ | _ | _ | _ | _ | _ | .1 | .0 | | C0H <sup>2)</sup> | IRCON0 | 00 <sub>H</sub> | EXF2 | TF2 | IEX6 | IEX5 | IEX4 | IEX3 | IEX2 | IADC | | C1 <sub>H</sub> | CCEN | 00 <sub>H</sub> | COCA<br>H3 | COCAL<br>3 | COCA<br>H2 | COCAL<br>2 | COCA<br>H1 | COCAL<br>1 | COCA<br>H0 | COCA<br>L0 | | C2 <sub>H</sub> | CCL1 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | C3 <sub>H</sub> | CCH1 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | C4 <sub>H</sub> | CCL2 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | C5 <sub>H</sub> | CCH2 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | C6 <sub>H</sub> | CCL3 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | C7 <sub>H</sub> | ССН3 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | C8H <sup>2)</sup> | T2CON | 00 <sub>H</sub> | T2PS | I3FR | I2FR | T2R1 | T2R0 | T2CM | T2I1 | T2I0 | | C9 <sub>H</sub> | CC4EN | 00 <sub>H</sub> | COCO<br>EN1 | COCO<br>N2 | COCO<br>N1 | COCO<br>N0 | COCO<br>EN0 | COCA<br>H4 | COCA<br>L4 | СОМО | <sup>1) &#</sup>x27;X' means that the value is undefined and the location is reserved <sup>2)</sup> Shaded registers are bit-addressable special function registers Table 4 Contents of the SFRs, SFRs in numeric order of their addresses (cont'd) | Addr | Register | Content<br>after<br>Reset <sup>1)</sup> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |------------------------------|----------|-----------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------| | CAH | CRCL | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | СВН | CRCH | 00H | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | CCH | TL2 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | CDH | TH2 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | CEH | CCL4 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | CF <sub>H</sub> | CCH4 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | D0H <sup>2)</sup> | PSW | 00 <sub>H</sub> | CY | AC | F0 | RS1 | RS0 | OV | F1 | Р | | D1 <sub>H</sub> | IRCON1 | 00 <sub>H</sub> | ICMP7 | ICMP6 | ICMP5 | ICMP4 | ICMP3 | ICMP2 | ICMP1 | ICMP0 | | D2 <sub>H</sub> | CML0 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | D3 <sub>H</sub> | СМН0 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | D4 <sub>H</sub> | CML1 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | D5 <sub>H</sub> | CMH1 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | D6 <sub>H</sub> | CML2 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | D7 <sub>H</sub> | CMH2 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | D8 <sub>H<sup>2)</sup></sub> | ADCON0 | 00 <sub>H</sub> | BD | CLK | ADEX | BSY | ADM | MX2 | MX1 | MX0 | | D9 <sub>H</sub> | ADDATH | 00 <sub>H</sub> | .9 | .8 | .7 | .6 | .5 | .4 | .3 | .2 | | DA <sub>H</sub> | ADDATL | 00XX-<br>XXXX <sub>B</sub> | .1 | .0 | _ | _ | _ | _ | _ | _ | | DBH | P7 | _ | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | DCH | ADCON1 | 0000 <sub>B</sub> | ADCL | _ | _ | _ | MX3 | MX2 | MX1 | MX0 | | DDH | P8 | _ | _ | _ | _ | _ | .3 | .2 | .1 | .0 | | DEH | CTRELL | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | DFH | CTRELH | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | E0 <sub>H<sup>2)</sup></sub> | ACC | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | E1 <sub>H</sub> | CTCON | 0X00.<br>0000 <sub>B</sub> | T2PS1 | _ | ICR | ICS | CTF | CLK2 | CLK1 | CLK0 | | E2 <sub>H</sub> | CML3 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | <sup>&#</sup>x27;X' means that the value is undefined and the location is reserved Shaded registers are bit-addressable special function registers Table 4 Contents of the SFRs, SFRs in numeric order of their addresses (cont'd) | Addr | Register | Content<br>after<br>Reset <sup>1)</sup> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |-------------------|----------|-----------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------| | E3 <sub>H</sub> | СМНЗ | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | E4 <sub>H</sub> | CML4 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | E5 <sub>H</sub> | CMH4 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | E6 <sub>H</sub> | CML5 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | E7 <sub>H</sub> | CMH5 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | E8H <sup>2)</sup> | P4 | FFH | CM7 | СМ6 | CM5 | CM4 | СМЗ | CM2 | CM1 | СМО | | E9 <sub>H</sub> | MD0 | хх <sub>Н</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | EAH | MD1 | хх <sub>Н</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | EBH | MD2 | $xx_H$ | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | ECH | MD3 | хх <sub>Н</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | EDH | MD4 | хх <sub>Н</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | EEH | MD5 | хх <sub>Н</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | EFH | ARCON | 0XXX.<br>XXXX <sub>B</sub> | MDEF | MDOV | SLR | SC.4 | SC.3 | SC.2 | SC.1 | SC.0 | | F0H <sup>2)</sup> | В | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F2 <sub>H</sub> | CML6 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3 <sub>H</sub> | СМН6 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F4 <sub>H</sub> | CML7 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F5 <sub>H</sub> | CMH7 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F6 <sub>H</sub> | CMEN | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F7 <sub>H</sub> | CMSEL | 00H | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F8H <sup>2)</sup> | P5 | FFH | CCM7 | CCM6 | CCM5 | CCM4 | ССМЗ | CCM2 | CCM1 | ССМО | | FA <sub>H</sub> | P6 | FFH | .7 | .6 | .5 | .4 | .3 | TxD1 | RxD1 | ADST | <sup>1) &#</sup>x27;X' means that the value is undefined and the location is reserved <sup>2)</sup> Shaded registers are bit-addressable special function registers # **Digital I/O Ports** The C517A allows for digital I/O on 56 lines grouped into 7 bidirectional 8-bit ports. Each port bit consists of a latch, an output driver and an input buffer. Read and write accesses to the I/O ports P0 through P6 are performed via their corresponding special function registers P0 to P6. The output drivers of port 0 and 2 and the input buffers of port 0 are also used for accessing external memory. In this application, port 0 outputs the low byte of the external memory address, time-multiplexed with the byte being written or read. Port 2 outputs the high byte of the external memory address when the address is 16 bits wide. Otherwise, the port 2 pins continue emitting the P2 SFR contents. # **Analog Input Ports** Ports 7 (8-bit) an 8 (4-bit) are input ports only and provide two functions. When used as digital inputs, the corresponding SFR P7 and P8 contains the digital value applied to the port 7/8 lines. When used for analog inputs the desired analog channel is selected by a four-bit field in SFR ADCON1. Of course, it makes no sense to output a value to these input-only ports by writing to the SFR P7 or P8. This will have no effect. If a digital value is to be read, the voltage levels are to be held within the input voltage specifications $(V_{\rm IL}/V_{\rm IH})$ . Since P7 and P8 are not bit-addressable, all input lines of P7 and P8 are read at the same time by byte instructions. Nevertheless, it is possible to use port 7 and 8 simultaneously for analog and digital input. However, care must be taken that all bits of P7 and P8 that have an undetermined value caused by their analog function are masked. #### Timer / Counter 0 and 1 Timer/Counter 0 and 1 can be used in four operating modes as listed in table 5: Table 5 Timer/Counter 0 and 1 Operating Modes | Mode | Description | TMOD | | Input Clock | | | |------|--------------------------------------------------------------------------------------------|------|----|-------------------------|-------------------------|--| | | | M1 | МО | internal | external (max) | | | 0 | 8-bit timer/counter with a divide-by-32 prescaler | 0 | 0 | f <sub>OSC</sub> /12x32 | f <sub>OSC</sub> /24x32 | | | 1 | 16-bit timer/counter | 1 | 1 | | | | | 2 | 8-bit timer/counter with 8-bit autoreload | 1 | 0 | f /12 | £ /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 | f <sub>osc</sub> /12 | $f_{ m osc}$ /24 | | In the "timer" function (C/T = '0') the register is incremented every machine cycle. Therefore the count rate is $f_{\rm OSC}/12$ . In the "counter" function the register is incremented in response to a 1-to-0 transition at its corresponding external input pin (P3.4/T0, P3.5/T1). Since it takes two machine cycles to detect a falling edge the max. count rate is $f_{\rm OSC}/24$ . External inputs INT0 and INT1 (P3.2, P3.3) can be programmed to function as a gate to facilitate pulse width measurements. **Figure 9** illustrates the input clock logic. Figure 9 Timer/Counter 0 and 1 Input Clock Logic # **Compare / Capture Unit (CCU)** The compare/capture unit is one of the C517A's most powerful peripheral units for use in all kinds of digital signal generation and event capturing like pulse generation, pulse width modulation, pulse width measuring etc. The CCU consists of two 16-bit timer/counters with automatic reload feature and an array of 13 compare or compare/capture registers. A set of six control registers is used for flexible adapting of the CCU to a wide variety of user's applications. The block diagram in **figure 10** shows the general configuration of the CCU. All CC1 to CC4 registers and the CRC register are exclusively assigned to timer 2. Each of the eight compare registers CM0 through CM7 can either be assigned to timer 2 or to the faster compare timer, e.g. to provide up to 8 PWM output channels. The assignment of the CMx registers - which can be done individually for every single register - is combined with an automatic selection of one of the two possible compare modes. Figure 10 Timer 2 Block Diagram The main functional blocks of the CCU are: - Timer 2 with $f_{\rm OSC}/12$ input clock, 2-bit prescaler, 16-bit reload, counter/gated timer mode and overflow interrupt request. - Compare timer with $f_{\rm OSC}/2$ input clock, 3-bit prescaler, 16-bit reload and overflow interrupt request. - Compare/(reload/) capture register array consisting of four different kinds of registers: one 16-bit compare/reload/capture register, three 16-bit compare/capture registers, one 16-bit compare/capture register with additional "concurrent compare" feature, eight 16-bit compare registers with timer-overflow controlled loading. **Table 6** shows the possible configurations of the CCU and the corresponding compare modes which can be selected. The following sections describe the function of these configurations. Table 6 CCU Configurations | Assigned<br>Timer | Compare<br>Register | Compare Output at | Possible Modes | |-------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Timer 2 | CRCH/CRCL<br>CCH1/CCL1<br>CCH2/CCL2<br>CCH3/CCL3<br>CCH4/CCL4 | P1.0/INT3/CC0<br>P1.1/INT4/CC1<br>P1.2/INT5/CC2<br>P1.3/INT6/CC3<br>P1.4/INT2/CC4<br>P1.4/INT2/CC4<br>P5.0/CCM0 | Compare mode 0, 1 + Reload Compare mode 0, 1 / capture Compare mode 0, 1 / capture Compare mode 0, 1 / capture Compare mode 0, 1 / capture Compare mode 1 "Concurrent compare" | | | CMH0/CML0 | to<br>P5.7/CCM7<br>P4.0/CM0 | Compare mode 0 | | | to<br>CMH7/CML7 | to<br>P4.7/CM7 | | | | COMSET<br>COMCLR | P5.0/CCM0<br>to<br>P5.7/CCM7 | Compare mode 2 | | Compare<br>Timer | CMH0/CML0<br>to<br>CMH7/CML7 | P4.0/CM0<br>to<br>P4.7/CM7 | Compare mode 1 | ## **Timer 2 Operation** <u>Timer Mode:</u> In timer function, the count rate is derived from the oscillator frequency. A prescaler offers the possibility of selecting a count rate of 1/12 or 1/24 of the oscillator frequency. <u>Gated Timer Mode:</u> In gated timer function, the external input pin P1.7/T2 operates as a gate to the input of timer 2. If T2 is high, the internal clock input is gated to the timer. T2 = 0 stops the counting procedure. The external gate signal is sampled once every machine cycle. <u>Event Counter Mode:</u> In the event counter function, the timer 2 is incremented in response to a 1-to-0 transition at its corresponding external input pin P1.7/T2. In this function, the external input is sampled every machine cycle. The maximum count rate is 1/24 of the oscillator frequency. Reload of Timer 2: Two reload modes are selectable: In mode 0, when timer 2 rolls over from all 1's to all 0's, it not only sets TF2 but also causes the timer 2 registers to be loaded with the 16-bit value in the CRC register, which is preset by software. In mode 1, a 16-bit reload from the CRC register is caused by a negative transition at the corresponding input pin P1.5/T2EX. Figure 11 Block Diagram of Timer 2 ## **Compare Timer Operation** The compare timer receives its input clock from a programmable prescaler which provides input frequencies, ranging from $f_{\rm OSC}/2$ up to $f_{\rm OSC}/256$ . The compare timer is, once started, a free-running 16-bit timer, which on overflow is automatically reloaded by the contents of a 16-bit reload register. The compare timer has - as any other timer in the C517A - their own interrupt request flags CTF. These flags are set when the timer count rolls over from all ones to the reload value. **Figure 12** shows the block diagram of compare timer and compare timer 1. Figure 12 Compare Timer Block Diagram # **Compare Modes** The compare function of a timer/register combination operates as follows: the 16-bit value stored in a compare or compare/capture register is compared with the contents of the timer register; if the count value in the timer register matches the stored value, an appropriate output signal is generated at a corresponding port pin and an interrupt can be generated. #### Compare Mode 0 In compare mode 0, upon matching the timer and compare register contents, the output signal changes from low to high. It goes back to a low level on timer overflow. As long as compare mode 0 is enabled, the appropriate output pin is controlled by the timer circuit only and writing to the port will have no effect. **Figure 13** shows a functional diagram of a port circuit when used in compare mode 0. The port latch is directly controlled by the timer overflow and compare match signals. The input line from the internal bus and the write-to-latch line of the port latch are disconnected when compare mode 0 is enabled. Figure 13 Port Latch in Compare Mode 0 #### Compare Mode 1 If compare mode 1 is enabled and the software writes to the appropriate output latch at the port, the new value will not appear at the output pin until the next compare match occurs. Thus, it can be choosen whether the output signal has to make a new transition (1-to-0 or 0-to-1, depending on the actual pin-level) or should keep its old value at the time when the timer value matches the stored compare value. In compare mode 1 (see **figure 14**) the port circuit consists of two separate latches. One latch (which acts as a "shadow latch") can be written under software control, but its value will only be transferred to the port latch (and thus to the port pin) when a compare match occurs. Figure 14 Compare Function in Compare Mode 1 ## Compare Mode 2 In the compare mode 2 the port 5 pins are under control of compare/capture register CC4, but under control of the compare registers COMSET and COMCLR. When a compare match occurs with register COMSET, a high level appears at the pins of port 5 when the corresponding bits in the mask register SETMSK are set. When a compare match occurs with register COMCLR, a low level appears at the pins of port 5 when the corresponding bits in the mask register CLRMSK are set. Figure 15 Compare Function of Compare Mode 2 # **Multiplication / Division Unit (MDU)** This on-chip arithmetic unit of the C517A provides fast 32-bit division, 16-bit multiplication as well as shift and normalize features. All operations are unsigned integer operations. **Table 7** describes the five general operations the MDU is able to perform. **Table 7 MDU Operation Characteristics** | Operation | Result | Remainder | Execution Time | |------------------|--------|-----------|---------------------------------| | 32bit/16bit | 32bit | 16bit | 6 t <sub>CY</sub> 1) | | 16bit/16bit | 16bit | 16bit | 4 t <sub>CY</sub> 1) | | 16bit x 16bit | 32bit | _ | 4 t <sub>CY</sub> 1) | | 32-bit normalize | _ | _ | 6 t <sub>CY</sub> <sup>2)</sup> | | 32-bit shift L/R | _ | _ | 6 t <sub>CY</sub> 2) | <sup>1) 1</sup> $t_{\rm CY}$ = 12 $t_{\rm CLCL}$ = 1 machine cycle = 500 ns at 24 MHz oscillator frequency The MDU consists of seven special function registers (MD0-MD5, ARCON) which are used as operand, result, and control registers. The three operation phases are shown in **figure 16**. Figure 16 Operating Phases of the MDU <sup>2)</sup> The maximal shift speed is 6 shifts per machine cycle For starting an operation, registers MD0 to MD5 and ARCON must be written to in a certain sequence according **table 8** and **9**. The order the registers are accessed determines the type of the operation. A shift operation is started by a final write operation to SFR ARCON. Table 8 Programming the MDU for Multiplication and Division | Operation | 32Bit/ | 16Bit | 16Bit/ | 16Bit | 16Bit | x 16Bit | |-------------|--------|--------|--------|--------|-------|---------| | First Write | MD0 | D'endL | MD0 | D'endL | MD0 | M'andL | | | MD1 | D'end | MD1 | D'endH | MD4 | M'orL | | | MD2 | D'end | | | | | | | MD3 | D'endH | MD4 | D'orL | MD1 | M'andH | | | MD4 | D'orL | | | | | | Last Write | MD5 | D'orH | MD5 | D'orH | MD5 | M'orH | | First Read | MD0 | QuoL | MD0 | QuoL | MD0 | PrL | | | MD1 | Quo | MD1 | QuoH | MD1 | | | | MD2 | Quo | | | | | | | MD3 | QuoH | MD4 | RemL | MD2 | | | | MD4 | RemL | | | | | | Last Read | MD5 | RemH | MD5 | RemH | MD3 | PrH | #### Abbreviations: D'end : Dividend, 1st operand of division D'or : Divisor, 2nd operand of division M'and : Multiplicand, 1st operand of multiplication M'or : Multiplicator, 2nd operand of multiplication Pr : Product, result of multiplication Rem : Remainder Quo : Quotient, result of division ...L : means, that this byte is the least significant of the 16-bit or 32-bit operand ...H : means, that this byte is the most significant of the 16-bit or 32-bit operand Table 9 Programming of the MDU for a Shift or Normalize Operation | Operation | Normalize, Sh | ift Left, Shift Right | | |-------------|---------------|------------------------|--| | First write | MD0 | least significant byte | | | | MD1 | | | | | MD2 | | | | | MD3 | most significant byte | | | Last write | ARCON | start of conversion | | | First read | MD0 | least significant byte | | | | MD1 | | | | | MD2 | | | | Last read | MD3 | most significant byte | | #### Serial Interfaces 0 and 1 The C517A has two serial interfaces which are functionally nearly identical concerning the asynchronous modes of operation. The two channels are full-duplex, meaning they can transmit and receive simultaneously. The serial channel 0 is completely compatible with the serial channel of the C501 (one synchronous mode, three asynchronous modes). Serial channel 1 has the same functionality in its asynchronous modes, but the synchronous mode and the fixed baud rate UART mode is missing. The operating modes of the serial interfaces is illustrated in **table 10**. The possible baudrates can be calculated using the formulas given in **table 11**. Table 10 Operating Modes of Serial Interface 0 and 1 | Serial | Mode | S00 | CON | S1CON | Description | |-----------|------|-----|-----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | Interface | | SM0 | SM1 | SM | | | 0 | 0 | 0 | 0 | _ | Shift register mode Serial data enters and exits through R×D0; T×D0 outputs the shift clock; 8-bit are transmitted/received (LSB first); fixed baud rate | | | 1 | 0 | 1 | _ | 8-bit UART, variable baud rate 10 bits are transmitted (through T×D0) or received (at R×D0) | | | 2 | 1 | 0 | _ | 9-bit UART, fixed baud rate 11 bits are transmitted (through T×D0) or received (at R×D0) | | | 3 | 1 | 1 | _ | 9-bit UART, variable baud rate<br>Like mode 2 | | 1 | A | - | _ | 0 | 9-bit UART; variable baud rate 11 bits are transmitted (through T×D1) or received (at R×D1) | | | В | - | _ | 1 | 8-bit UART; variable baud rate 10 bits are transmitted (through T×D1) or received (at R×D1) | For clarification some terms regarding the difference between "baud rate clock" and "baud rate" should be mentioned. In the <u>asynchronous modes</u> the serial interfaces require a clock rate which is 16 times the baud rate for internal synchronization. Therefore, the baud rate generators/timers have to provide a "baud rate clock" (output signal in **figure 17** and **figure 18**) to the serial interface which there divided by 16 - results in the actual "baud rate". Further, the abbreviation f<sub>OSC</sub> refers to the oscillator frequency (crystal or external clock operation). The variable baud rates for modes 1 and 3 of the serial interface 0 can be derived from either timer 1 or a dedicated baud rate generator (see **figure 17**). The variable baud rates for modes A and B of the serial interface 1 are derived from a dedicated baud rate generator as shown in **figure 18**. Figure 17 Serial Interface 0 : Baud Rate Generation Configuration Figure 18 Serial Interface 1 : Baud Rate Generator Configuration The baud rate generator block in **figure 17** has the same structure (10-bit auto-reload timer) as the baud rate generator block which is shown in detail in **figure 18**. **Table 11** below lists the values/formulas for the baud rate calculation of serial interface 0 and 1 with its dependencies of the control bits BD and SMOD. Table 11 Serial Interfaces - Baud Rate Dependencies | Serial Interface<br>Operating Modes | Active ( | Control | Baud Rates | | | |--------------------------------------------|--------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | SMOD | BD | | | | | Mode 0 (Shift Register) | _ | _ | Fixed baud rate clock fosc/12 | | | | Mode 1 (8-bit UART)<br>Mode 3 (9-bit UART) | 1 (8-bit UART) X 0 | | Timer 1 overflow is used for baud rate generation; SMOD controls a divide-by-2 option Baud rate = 2 <sup>SMOD</sup> x timer 1 overflow rate / 32 | | | | | | 1 | Baud rate generator is used for baud rate generation; SMOD controls a divide-by-2 option Baud rate = 2 <sup>SMOD</sup> x oscillator frequency / 64 x (baud rate gen. overflow rate) | | | | Mode 2 (9-bit UART) | Х | _ | Fixed baud rate clock fosc/32 (SMOD=1) or fosc/<br>64 (SMOD=0) | | | | Mode A (9-bit UART)<br>Mode B (8-bit UART) | _ | _ | Baud rate generator is used for baud rate generation; SMOD controls a divide-by-2 option Baud rate = oscillator frequency / 32 x (baud rate gen. overflow rate) | | | #### 10-Bit A/D Converter The C517A provides an A/D converter with the following features: - 12 multiplexed input channels (port 7, 8), which can also be used as digital inputs - 10-bit resolution - Single or continuous conversion mode - Internal or external start-of-conversion trigger capability - Interrupt request generation after each conversion - Using successive approximation conversion technique via a capacitor array - Built-in hidden calibration of offset and linearity errors The A/D converter operates with a successive approximation technique and uses self calibration mechanisms for reduction and compensation of offset and linearity errors. The externally applied reference voltage range has to be held on a fixed value within the specifications. The main functional blocks of the A/D converter are shown in **figure 19**. Figure 19 A/D Converter Block Diagram # **Interrupt System** The C517A provides 17 interrupt sources with four priority levels. Ten interrupts can be generated by the on-chip peripherals (timer 0, timer 1, timer 2, compare timer, compare match/set/clear, A/D converter, and serial interface 0 and 1) and seven interrupts may be triggered externally (P3.2/INT0, P3.3/INT1, P1.4/INT2, P1.0/INT3, P1.1/INT4, P1.2/INT5, P1.3/INT6). This chapter shows the interrupt structure, the interrupt vectors and the interrupt related special function registers. **Figure 20** to **22** give a general overview of the interrupt sources and illustrate the request and the control flags which are described in the next sections. Figure 20 Interrupt Structure, Overview (Part 1) Figure 21 Interrupt Structure, Overview (Part 2) Figure 22 Interrupt Structure, Overview (Part 3) Table 12 Interrupt Source and Vectors | Interrupt Source | Interrupt Vector Address | Interrupt Request Flags | |--------------------------------------------------------------------------------|--------------------------|-------------------------| | External Interrupt 0 | 0003 <sub>H</sub> | IE0 | | Timer 0 Overflow | 000B <sub>H</sub> | TF0 | | External Interrupt 1 | 0013 <sub>H</sub> | IE1 | | Timer 1 Overflow | 001B <sub>H</sub> | TF1 | | Serial Channel 0 | 0023 <sub>H</sub> | RI0 / TI0 | | Timer 2 Overflow / Ext. Reload | 002B <sub>H</sub> | TF2 / EXF2 | | A/D Converter | 0043 <sub>H</sub> | IADC | | External Interrupt 2 | 004B <sub>H</sub> | IEX2 | | External Interrupt 3 | 0053 <sub>H</sub> | IEX3 | | External Interrupt 4 | 005B <sub>H</sub> | IEX4 | | External Interrupt 5 | 0063 <sub>H</sub> | IEX5 | | External Interrupt 6 | 006B <sub>H</sub> | IEX6 | | Serial Channel 1 | 0083 <sub>H</sub> | RI1 / TI1 | | Compare Match Interrupt of<br>Compare Registers CM0-CM7<br>assigned to Timer 2 | 0093 <sub>H</sub> | ICMP0 - ICMP7 | | Compare Timer Overflow | 009B <sub>H</sub> | CTF | | Compare Match Interrupt of Compare Register COMSET | 00A3 <sub>H</sub> | ICS | | Compare Match Interrupt of Compare Register COMCLR | 00AB <sub>H</sub> | ICR | #### **Fail Save Mechanisms** The C517A offers enhanced fail safe mechanisms, which allow an automatic recovery from software upset or hardware failure: - a programmable watchdog timer (WDT), with variable time-out period from 512 $\mu$ s up to approx. 1.1 s at 12 MHz. (256 $\mu$ s up to approx. 0.65 s at 24 MHz) - an oscillator watchdog (OWD) which monitors the on-chip oscillator and forces the microcontroller into reset state in case the on-chip oscillator fails; it also provides the clock for a fast internal reset after power-on. The watchdog timer in the C517A is a 15-bit timer, which is incremented by a count rate of $f_{\rm OSC}/24$ up to $f_{\rm OSC}/384$ . The system clock of the C517A is divided by two prescalers, a divide-by-two and a divide-by-16 prescaler. For programming of the watchdog timer overflow rate, the upper 7 bit of the watchdog timer can be written. **Figure 23** shows the block diagram of the watchdog timer unit. Figure 23 Block Diagram of the Watchdog Timer The watchdog timer can be started by software (bit SWDT) or by hardware through pin $\overline{PE}/SWD$ , but it cannot be stopped during active mode of the C517A. If the software fails to refresh the running watchdog timer an internal reset will be initiated on watchdog timer overflow. For refreshing of the watchdog timer the content of the SFR WDTREL is transferred to the upper 7-bit of the watchdog timer. The refresh sequence consists of two consecutive instructions which set the bits WDT and SWDT each. The reset cause (external reset or reset caused by the watchdog) can be examined by software (flag WDTS). It must be noted, however, that the watchdog timer is halted during the idle mode and power down mode of the processor. #### **Oscillator Watchdog** The oscillator watchdog unit serves for four functions: ### Monitoring of the on-chip oscillator's function The watchdog supervises the on-chip oscillator's frequency; if it is lower than the frequency of the auxiliary RC oscillator in the watchdog unit, the internal clock is supplied by the RC oscillator and the device is brought into reset; if the failure condition disappears (i.e. the on-chip oscillator has a higher frequency than the RC oscillator), the part executes a final reset phase of typ. 1 ms in order to allow the oscillator to stabilize; then the oscillator watchdog reset is released and the part starts program execution again. ### - Fast internal reset after power-on The oscillator watchdog unit provides a clock supply for the reset before the on-chip oscillator has started. The oscillator watchdog unit also works identically to the monitoring function. ## Restart from the hardware power down mode. If the hardware power down mode is terminated the oscillator watchdog has to control the correct start-up of the on-chip oscillator and to restart the program. The oscillator watchdog function is only part of the complete hardware power down sequence; however, the watchdog works identically to the monitoring function. Figure 24 Block Diagram of the Oscillator Watchdog #### **Power Saving Modes** The C517A provides two basic power saving modes, the idle mode and the power down mode. Additionally, a slow down mode is available. This power saving mode reduces the internal clock rate in normal operating mode and it can be also used for further power reduction in idle mode. #### - Idle mode The CPU is gated off from the oscillator. All peripherals are still provided with the clock and are able to work. Idle mode is entered by software and can be left by an interrupt or reset. #### Slow down mode The controller keeps up the full operating functionality, but its normal clock frequency is internally divided by 8. This slows down all parts of the controller, the CPU and all peripherals, to 1/8th of their normal operating frequency and also reduces power consumption. ### Software power down mode The operation of the C517A is completely stopped and the oscillator is turned off. This mode is used to save the contents of the internal RAM with a very low standby current. This power down mode is entered by software and can be left by reset or by a short low pulse at pin P3.2/ $\overline{\text{INT0}}$ . #### Hardware Power down mode If pin HWPD gets active (low level) the part enters the hardware power down mode and starts a complete internal reset sequence. Thereafter, both oscillators of the chip are stopped and the port pins and several control lines enter a floating state. 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. **Table 13** gives a general overview of the entry and exit procedures of the power saving modes. Table 13 Power Saving Modes Overview | Mode | Entering<br>2-Instruction<br>Example | Leaving by | Remarks | |-----------------------------|----------------------------------------------------|---------------------------------------------------|---------------------------------------------------------------------------------------| | Idle mode | ORL PCON, #01H<br>ORL PCON, #20H | Occurrence of an interrupt from a peripheral unit | CPU clock is stopped;<br>CPU maintains their data;<br>peripheral units are active (if | | | | Hardware Reset | enabled) and provided with clock | | Slow Down Mode | In normal mode:<br>ORL PCON,#10H | ANL PCON,#0EFH or Hardware Reset | Internal clock rate is reduced to 1/8 of its nominal frequency | | | With idle mode:<br>ORL PCON,#01H<br>ORL PCON, #30H | Occurrence of an interrupt from a peripheral unit | CPU clock is stopped;<br>CPU maintains their data;<br>peripheral units are active (if | | | | Hardware reset | enabled) and provided with 1/8 of its nominal frequency | | Software | ORL PCON, #02H | Hardware Reset | Oscillator is stopped; | | Power Down Mode | ORL PCON, #40H | Short low pulse at pin P3.2/INT0 | contents of on-chip RAM and SFR's are maintained; | | Hardware<br>Power Down Mode | HWPD = 0 | HWPD = 1 | Oscillator is stopped; internal reset is executed; | # **Absolute Maximum Ratings** | Ambient temperature under bias $(T_A)$ | – 40 to 125 °C | |----------------------------------------------------------------------|--------------------------------| | Storage temperature $(T_{stg})$ | - 65 °C to 150 °C | | Voltage on $V_{\rm CC}$ pins with respect to ground ( $V_{\rm SS}$ ) | -0.5~V to $6.5~V$ | | Voltage on any pin with respect to ground $(V_{SS})$ | – 0.5 V to $V_{\rm CC}$ +0.5 V | | Input current on any pin during overload condition | - 10 mA to 10 mA | | Absolute sum of all input currents during overload condition | I 100 mA I | | 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_{IN} > V_{CC} \text{ or } V_{IN} < V_{SS})$ the Voltage on $V_{CC}$ pins with respect to ground $(V_{SS})$ must not exceed the values defined by the absolute maximum ratings. # **DC Characteristics** $V_{\mathrm{CC}}$ = 5 V + 10%, - 15%; $V_{\mathrm{SS}}$ = 0 V $T_{\rm A} = 0 \text{ to } 70 \,^{\circ}{\rm C}$ for the SAB-C517A for the SAF-C517A for the SAH-C517A $T_{A} = -40 \text{ to } 85 \,^{\circ}\text{C}$ $T_{A} = -40 \text{ to } 110 \,^{\circ}\text{C}$ | Parameter | Symbol | Limit | Values | Unit | Test Condition | | |----------------------------------------------------------------------------------------|----------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------|----------------|-------------------------------------------------------------------------------------------------|--| | | | min. | max. | | | | | Input low voltage Pins except EA,RESET,HWPD EA pin HWPD and RESET pins | $V_{IL} \ V_{IL1} \ V_{IL2}$ | - 0.5<br>- 0.5<br>- 0.5 | $0.2 V_{CC} - 0.1$ $0.2 V_{CC} - 0.3$ $0.2 V_{CC} + 0.1$ | V<br>V | -<br>-<br>- | | | Input high voltage pins except RESET, XTAL2 and HWPD XTAL2 pin RESET and HWPD pin | $V_{ m lH}$ $V_{ m lH1}$ $V_{ m lH2}$ | $0.2 V_{\rm CC} + 0.9$<br>$0.7 V_{\rm CC}$<br>$0.6 V_{\rm CC}$ | $V_{\rm cc}$ + 0.5<br>$V_{\rm cc}$ + 0.5<br>$V_{\rm cc}$ + 0.5 | V<br>V<br>V | -<br>-<br>- | | | Output low voltage Ports 1, 2, 3, 4, 5, 6 Port 0, ALE, PSEN, RO | $V_{OL} \ V_{OL1}$ | _<br>_ | 0.45<br>0.45 | V | $I_{OL} = 1.6 \text{ mA}^{-1}$<br>$I_{OL} = 3.2 \text{ mA}^{-1}$ | | | Output high voltage Ports 1, 2, 3, 4, 5, 6 Port 0 in external bus mode, ALE, PSEN, RO | $V_{OH}$ $V_{OH1}$ | 2.4<br>0.9 V <sub>CC</sub><br>2.4 | _<br>_<br>_ | V<br>V<br>V | $I_{OH} = -80 \mu A$ $I_{OH} = -10 \mu A$ $I_{OH} = -800 \mu A$ | | | Logic 0 input current Ports 1, 2, 3, 4, 5, 6 | $I_{LI}$ | 0.9 V <sub>CC</sub> | -<br>- 70 | μΑ | $I_{OH} = -80 \mu\text{A}^{2}$ $V_{IN} = 0.45 \text{V}$ | | | Logical 0-to-1 transition current,<br>Ports 1, 2, 3, 4, 5, 6 | $I_{TL}$ | <b>–</b> 65 | - 650 | μΑ | <i>V</i> <sub>IN</sub> = 2 V | | | Input leakage current Port 0, 7 and 8, EA, HWPD | $I_{LI}$ | _ | ± 1 | μΑ | $0.45 < V_{IN} < V_{CC}$ | | | Input low current to RESET for reset XTAL2 PE/SWD, OWE | $I_{\text{IL2}}$ $I_{\text{IL3}}$ $I_{\text{IL4}}$ | - 10<br>-<br>- | - 100<br>- 15<br>- 20 | μΑ<br>μΑ<br>μΑ | $V_{\rm IN} = 0.45 \text{ V}$<br>$V_{\rm IN} = 0.45 \text{ V}$<br>$V_{\rm IN} = 0.45 \text{ V}$ | | | Pin capacitance | $C_{IO}$ | _ | 10 | pF | $f_{\rm C}$ = 1 MHz,<br>$T_{\rm A}$ = 25 °C | | | Overload current | $I_{OV}$ | _ | ± 5 | mA | 7) 8) | | Notes see next page | i owei ouppiy ourieri | <b>Power</b> | Sup | ply | Current | |-----------------------|--------------|-----|-----|---------| |-----------------------|--------------|-----|-----|---------| | Parameter | Symbol | Limi | t Values | Unit | Test Condition | | |------------------------------------|------------------|---------------------------|--------------------|--------------|----------------|-----------------------------| | | | | typ. <sup>9)</sup> | max. 10) | | | | Active mode | 18 MHz<br>24 MHz | $I_{\rm CC}$ $I_{\rm CC}$ | 21.3<br>27.3 | 29.2<br>37.6 | mA<br>mA | 4) | | Idle mode | 18 MHz<br>24 MHz | $I_{\rm CC}$ $I_{\rm CC}$ | 11.6<br>14.6 | 16.2<br>20.4 | mA<br>mA | 5) | | Active mode with slow-down enabled | 18 MHz<br>24 MHz | $I_{\rm CC}$ $I_{\rm CC}$ | 9.5<br>10.7 | 13.1<br>14.9 | mA<br>mA | 6) | | Power-down mode | | $I_{PD}$ | 15 | 50 | μΑ | $V_{\rm CC} = 25.5 V^{3)}$ | #### Notes: - 1) Capacitive loading on ports 0 and 2 may cause spurious noise pulses to be superimposed on the $V_{\rm OL}$ 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. - 2) Capacitive loading on ports 0 and 2 may cause the $V_{\rm OH}$ on ALE and PSEN to momentarily fall below the 0.9 $V_{\rm CC}$ specification when the address lines are stabilizing. - 3) $I_{PD}$ (power-down mode) is measured under following conditions: $EA = \overline{RESET} = Port \ 0 = Port \ 7 = Port \ 8 = V_{CC}$ ; XTAL1 = N.C.; XTAL2 = $V_{SS}$ ; $\overline{PE}/SWD = OWE = V_{SS}$ ; $\overline{HWPD} = V_{CC}$ for software power-down mode; $V_{AGND} = V_{SS}$ ; $V_{AREF} = V_{CC}$ ; all other pins are disconnected. $I_{PD}$ (hardware power-down mode) is independent of any particular pin connection. - 4) $I_{\rm CC}$ (active mode) is measured with: XTAL2 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; XTAL1 = N.C.; EA = $\overline{\rm PE}/{\rm SWD} == V_{\rm SS}$ ; Port 0 = Port 7 = Port 8 = $V_{\rm CC}$ ; HWPD = $V_{\rm CC}$ ; $\overline{\rm RESET} = V_{\rm CC}$ ; all other pins are disconnected - 5) $I_{\rm CC}$ (idle mode) is measured with all output pins disconnected and with all peripherals disabled; XTAL2 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; XTAL1 = N.C.; RESET = $V_{\rm CC}$ ; HWPD = Port 0 = Port 7 = Port 8 = $V_{\rm CC}$ ; EA = PE/SWD = $V_{\rm SS}$ ; all other pins are disconnected; - 6) $I_{\text{CC}}$ (active mode with slow-down mode) is measured with all output pins disconnected and with all peripherals disabled; XTAL2 driven with $t_{\text{CLCH}}$ , $t_{\text{CHCL}} = 5$ ns , $V_{\text{IL}} = V_{\text{SS}} + 0.5$ V, $V_{\text{IH}} = V_{\text{CC}} 0.5$ V; XTAL1 = N.C.; $\overline{\text{HWPD}} = V_{\text{CC}}$ ; $\overline{\text{RESET}} = V_{\text{CC}}$ ; Port 7 = Port 8 = $V_{\text{CC}}$ ; $\overline{\text{EA}} = \overline{\text{PE}}/\text{SWD} == V_{\text{SS}}$ ; all other pins are disconnected. - 7) Overload conditions occur if the standard operating conditions are exceeded, i.e. the voltage on any pin exceeds the specified range (i.e. $V_{\rm OV} > V_{\rm CC} + 0.5$ V or $V_{\rm OV} < V_{\rm SS}$ 0.5 V). The supply voltage $V_{\rm CC}$ and $V_{\rm SS}$ must remain within the specified limits. The absolute sum of input currents on all port pins may not exceed 50 mA. - 8) Not 100% tested, guaranteed by design characterization - 9) The typical $I_{\rm CC}$ values are periodically measured at $T_{\rm A}$ = +25 °C and $V_{\rm CC}$ = 5 V but not 100% tested. - 10)The maximum $I_{\rm CC}$ values are measured under worst case conditions ( $T_{\rm A}$ = 0 °C or -40 °C and $V_{\rm CC}$ = 5.5 V) Figure 25 ICC Diagram Table 14 Power Supply Current Calculation Formulas | Parameter | Symbol | Formula | |------------------------------------|-----------------------------------|--------------------------------------------------| | Active mode | $I_{ m CC\ typ}$ $I_{ m CC\ max}$ | $1 * f_{OSC} + 3.3$<br>$1.4 * f_{OSC} + 4.0$ | | Idle mode | $I_{ m CC\ typ}$ $I_{ m CC\ max}$ | $0.5 * f_{OSC} + 2.6$<br>$0.7 * f_{OSC} + 3.6$ | | Active mode with slow-down enabled | $I_{ m CC\ typ}$ $I_{ m CC\ max}$ | $0.25 * f_{OSC} + 4.95$<br>$0.3 * f_{OSC} + 7.7$ | **Note**: $f_{\rm osc}$ is the oscillator frequency in MHz. $I_{\rm CC}$ values are given in mA. #### A/D Converter Characteristics $V_{\rm CC}$ = 5 V + 10%, - 15%; $V_{\rm SS}$ = 0 V $T_{\rm A}$ = 0 to 70 °C for the SAB-C517A $T_{\rm A}$ = - 40 to 85 °C for the SAF-C517A $T_{\rm A}$ = - 40 to 110 °C for the SAH-C517A 4 V $\leq$ $V_{\text{AREF}}$ $\leq$ $V_{\text{CC}}$ +0.1 V; $V_{\text{SS}}$ -0.1 V $\leq$ $V_{\text{AGND}}$ $\leq$ $V_{\text{SS}}$ +0.2 V | Parameter | Symbol | Limi | t Values | Unit | Test Condition | | |-------------------------------------------------|--------------|------------|----------------------------------------------|------|--------------------------------------------------|--| | | | min. | max. | | | | | Analog input voltage | $V_{AIN}$ | $V_{AGND}$ | $V_{AREF}$ | V | 1) | | | Sample time | $t_{\rm S}$ | - | 16 x t <sub>IN</sub><br>8 x t <sub>IN</sub> | ns | Prescaler ÷ 8 Prescaler ÷ 4 <sup>2)</sup> | | | Conversion cycle time | $t_{ADCC}$ | _ | 96 x t <sub>IN</sub><br>48 x t <sub>IN</sub> | ns | Prescaler ÷ 8 Prescaler ÷ 4 <sup>3)</sup> | | | Total unadjusted error | $T_{\sf UE}$ | _ | ± 2 | LSB | $V_{SS} + 0.5V \le V_{IN} \le V_{CC} - 0.5V^{4}$ | | | Internal resistance of reference voltage source | $R_{AREF}$ | _ | t <sub>ADC</sub> / 250 - 0.25 | kΩ | t <sub>ADC</sub> in [ns] <sup>5) 6)</sup> | | | Internal resistance of analog source | $R_{ASRC}$ | _ | t <sub>S</sub> / 500<br>- 0.25 | kΩ | $t_{\rm S}$ in [ns] <sup>2) 6)</sup> | | | ADC input capacitance | $C_{AIN}$ | _ | 50 | pF | 6) | | Notes see next page. # **Clock calculation table:** | Clock Prescaler<br>Ratio | ADCL | tADC | t <sub>S</sub> | tADCC | |--------------------------|------|---------------------|----------------------|----------------------| | ÷ 8 | 1 | 8 x t <sub>IN</sub> | 16 x t <sub>IN</sub> | 96 x t <sub>IN</sub> | | ÷ 4 | 0 | 4 x t <sub>IN</sub> | 8 x t <sub>IN</sub> | 48 x t <sub>IN</sub> | Further timing conditions: $t_{ADC} min = 500 ns$ $t_{IN} = 2 / f_{OSC} = 2 t_{CLCL}$ #### Notes: - 1) $V_{AIN}$ may exceed $V_{AGND}$ or $V_{AREF}$ up to the absolute maximum ratings. However, the conversion result in these cases will be $X000_H$ or $X3FF_H$ , respectively. - 2) During the sample time the input capacitance C<sub>AIN</sub> can be charged/discharged by the external source. The internal resistance of the analog source must allow the capacitance to reach their final voltage level within t<sub>S</sub>. After the end of the sample time t<sub>S</sub>, changes of the analog input voltage have no effect on the conversion result. - 3) This parameter includes the sample time t<sub>S</sub>, the time for determining the digital result and the time for the calibration. Values for the conversion clock t<sub>ADC</sub> depend on programming and can be taken from the table on the previous page. - 4) T<sub>UE</sub> is tested at V<sub>AREF</sub> = 5.0 V, V<sub>AGND</sub> = 0 V, V<sub>CC</sub> = 4.9 V. It is guaranteed by design characterization for all other voltages within the defined voltage range. If an overload condition occurs on maximum 2 not selected analog input pins and the absolute sum of input overload currents on all analog input pins does not exceed 10 mA, an additional conversion error of 1/2 LSB is permissible. - 5) During the conversion the ADC's capacitance must be repeatedly charged or discharged. The internal resistance of the reference source must allow the capacitance to reach their final voltage level within the indicated time. The maximum internal resistance results from the programmed conversion timing. - 6) Not 100% tested, but guaranteed by design characterization. # **AC Characteristics (18 MHz)** $V_{\rm CC} = 5 \text{ V} + 10\%, -15\%; V_{\rm SS} = 0 \text{ V}$ for the SAB-C517A $T_{\rm A}$ = 0 to 70 °C $T_{\rm A}$ = - 40 to 85 °C $T_{\rm A}$ = - 40 to 110 °C for the SAF-C517A for the SAH-C517A ( $C_{L}$ for port 0, ALE and PSEN outputs = 100 pF; $C_{L}$ for all other outputs = 80 pF) # **Program Memory Characteristics** | Parameter | Symbol | Limit Values | | | | | |------------------------------------|-----------------|-----------------|------|---------------------------------------|---------------------------|----| | | | 18 MHz<br>Clock | | Variab<br>1/t <sub>CLCL</sub> = 3.5 l | | | | | | min. | max. | min. | max. | | | ALE pulse width | $t_{LHLL}$ | 71 | _ | 2 t <sub>CLCL</sub> - 40 | _ | ns | | Address setup to ALE | $t_{AVLL}$ | 26 | _ | $t_{\rm CLCL} - 30$ | _ | ns | | Address hold after ALE | $t_{LLAX}$ | 26 | _ | $t_{\text{CLCL}} - 30$ | _ | ns | | ALE low to valid instruction in | $t_{LLIV}$ | - | 122 | _ | 4 t <sub>CLCL</sub> - 100 | ns | | ALE to PSEN | $t_{LLPL}$ | 31 | _ | t <sub>CLCL</sub> - 25 | _ | ns | | PSEN pulse width | $t_{PLPH}$ | 132 | _ | 3 t <sub>CLCL</sub> - 35 | _ | ns | | PSEN to valid instruction in | $t_{PLIV}$ | _ | 92 | _ | 3 t <sub>CLCL</sub> - 75 | ns | | Input instruction hold after PSEN | $t_{PXIX}$ | 0 | _ | 0 | _ | ns | | Input instruction float after PSEN | $t_{PXIZ}^{*)}$ | _ | 46 | _ | t <sub>CLCL</sub> - 10 | ns | | Address valid after PSEN | $t_{PXAV}^{*)}$ | 48 | _ | <i>t</i> <sub>CLCL</sub> – 8 | _ | ns | | Address to valid instr in | $t_{AVIV}$ | _ | 180 | _ | 5 t <sub>CLCL</sub> – 98 | ns | | Address float to PSEN | $t_{AZPL}$ | 0 | _ | 0 | _ | ns | <sup>\*)</sup> Interfacing the C517A 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 (18 MHz, cont'd) # **External Data Memory Characteristics** | Parameter | Symbol | Limit Values | | | | Unit | |-----------------------------|--------------------|-----------------|------|------------------------------------------------------------------|---------------------------|------| | | | 18 MHz<br>Clock | | Variable Clock $1/t_{CLCL} = 3.5 \text{ MHz to } 18 \text{ MHz}$ | | | | | | min. | max. | min. | max. | | | RD pulse width | $t_{RLRH}$ | 233 | - | 6 t <sub>CLCL</sub> - 100 | _ | ns | | WR pulse width | $t_{WLWH}$ | 233 | - | 6 t <sub>CLCL</sub> - 100 | _ | ns | | Address hold after ALE | t <sub>LLAX2</sub> | 81 | - | 2 t <sub>CLCL</sub> - 30 | _ | ns | | RD to valid data in | $t_{RLDV}$ | _ | 128 | _ | 5 t <sub>CLCL</sub> - 150 | ns | | Data hold after RD | $t_{RHDX}$ | 0 | _ | 0 | _ | ns | | Data float after RD | $t_{RHDZ}$ | _ | 51 | _ | 2 t <sub>CLCL</sub> - 60 | ns | | ALE to valid data in | $t_{LLDV}$ | _ | 294 | _ | 8 t <sub>CLCL</sub> - 150 | ns | | Address to valid data in | $t_{AVDV}$ | _ | 335 | _ | 9 t <sub>CLCL</sub> - 165 | ns | | ALE to WR or RD | $t_{LLWL}$ | 117 | 217 | $3 t_{CLCL} - 50$ | $3 t_{CLCL} + 50$ | ns | | Address valid to WR or RD | t <sub>AVWL</sub> | 92 | _ | 4 t <sub>CLCL</sub> - 130 | _ | ns | | WR or RD high to ALE high | t <sub>WHLH</sub> | 16 | 96 | $t_{\rm CLCL} - 40$ | t <sub>CLCL</sub> + 40 | ns | | Data valid to WR transition | $t_{QVWX}$ | 11 | - | $t_{\rm CLCL} - 45$ | _ | ns | | Data setup before WR | $t_{\sf QVWH}$ | 239 | - | 7 t <sub>CLCL</sub> – 150 | _ | ns | | Data hold after WR | $t_{WHQX}$ | 16 | - | t <sub>CLCL</sub> - 40 | _ | ns | | Address float after RD | $t_{RLAZ}$ | _ | 0 | _ | 0 | ns | # **External Clock Drive Characteristics** | Symbol | | Unit | | |------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------|----| | | Freq | | | | | min. | max. | | | $t_{CLCL}$ | 55.6 | 285.7 | ns | | $t_{CHCX}$ | 15 | $t_{\rm CLCL} - t_{\rm CLCX}$ | ns | | $t_{CLCX}$ | 15 | $t_{\rm CLCL} - t_{\rm CHCX}$ | ns | | $t_{CLCH}$ | _ | 15 | ns | | $t_{CHCL}$ | _ | 15 | ns | | | $t_{ m CLCL}$ $t_{ m CHCX}$ $t_{ m CLCX}$ | Freq min. $t_{\rm CLCL} \qquad 55.6$ $t_{\rm CHCX} \qquad 15$ $t_{\rm CLCX} \qquad 15$ $t_{\rm CLCH} \qquad -$ | | # **AC Characteristics (24 MHz)** $V_{\rm CC} = 5 \text{ V} + 10\%, -15\%; V_{\rm SS} = 0 \text{ V}$ for the SAB-C517A $T_{\rm A}$ = 0 to 70 °C $T_{\rm A}$ = - 40 to 85 °C $T_{\rm A}$ = - 40 to 110 °C for the SAF-C517A for the SAH-C517A ( $C_{L}$ for port 0, ALE and PSEN outputs = 100 pF; $C_{L}$ for all other outputs = 80 pF) # **Program Memory Characteristics** | Parameter | Symbol | Limit Values | | | | Unit | |------------------------------------|---------------------|-----------------|------|--------------------------------------------------------|-------------------------------|------| | | | 24 MHz<br>Clock | | Variable Clock 1/t <sub>CLCL</sub> = 3.5 MHz to 24 MHz | | | | | | min. | max. | min. | max. | | | ALE pulse width | t <sub>LHLL</sub> | 43 | _ | 2 t <sub>CLCL</sub> - 40 | _ | ns | | Address setup to ALE | t <sub>AVLL</sub> | 17 | - | t <sub>CLCL</sub> - 25 | _ | ns | | Address hold after ALE | $t_{LLAX}$ | 17 | _ | t <sub>CLCL</sub> - 25 | _ | ns | | ALE low to valid instruction in | t <sub>LLIV</sub> | _ | 80 | _ | 4 t <sub>CLCL</sub> - 87 | ns | | ALE to PSEN | $t_{LLPL}$ | 22 | - | t <sub>CLCL</sub> - 20 | _ | ns | | PSEN pulse width | $t_{PLPH}$ | 95 | - | $3t_{\text{CLCL}} - 30$ | _ | ns | | PSEN to valid instruction in | $t_{\sf PLIV}$ | _ | 60 | _ | 3 t <sub>CLCL</sub> - 65 | ns | | Input instruction hold after PSEN | $t_{PXIX}$ | 0 | _ | 0 | _ | ns | | Input instruction float after PSEN | $t_{PXIZ}^{*)}$ | _ | 32 | _ | <i>t</i> <sub>CLCL</sub> – 10 | ns | | Address valid after PSEN | $t_{PXAV}^{\star)}$ | 37 | _ | $t_{\rm CLCL} - 5$ | _ | ns | | Address to valid instr in | t <sub>AVIV</sub> | _ | 148 | _ | 5 t <sub>CLCL</sub> - 60 | ns | | Address float to PSEN | $t_{AZPL}$ | 0 | _ | 0 | _ | ns | <sup>\*)</sup> Interfacing the C517A to devices with float times up to 37 ns is permissible. This limited bus contention will not cause any damage to port 0 drivers. # AC Characteristics (24 MHz, cont'd) # **External Data Memory Characteristics** | Parameter | Symbol | Limit Values | | | | Unit | |-----------------------------|--------------------|-----------------|------|--------------------------------------------------------|---------------------------|------| | | | 24 MHz<br>Clock | | Variable Clock 1/t <sub>CLCL</sub> = 3.5 MHz to 24 MHz | | | | | | min. | max. | min. | max. | | | RD pulse width | $t_{RLRH}$ | 180 | - | 6 t <sub>CLCL</sub> – 70 | _ | ns | | WR pulse width | $t_{WLWH}$ | 180 | - | 6 t <sub>CLCL</sub> – 70 | _ | ns | | Address hold after ALE | t <sub>LLAX2</sub> | 53 | _ | 2 t <sub>CLCL</sub> - 30 | _ | ns | | RD to valid data in | $t_{RLDV}$ | _ | 118 | _ | 5 t <sub>CLCL</sub> - 90 | ns | | Data hold after RD | $t_{RHDX}$ | 0 | - | 0 | _ | ns | | Data float after RD | $t_{RHDZ}$ | _ | 63 | _ | 2 t <sub>CLCL</sub> – 20 | ns | | ALE to valid data in | $t_{LLDV}$ | _ | 200 | _ | 8 t <sub>CLCL</sub> - 133 | ns | | Address to valid data in | $t_{AVDV}$ | _ | 220 | _ | 9 t <sub>CLCL</sub> - 155 | ns | | ALE to WR or RD | $t_{LLWL}$ | 75 | 175 | 3 t <sub>CLCL</sub> - 50 | 3 t <sub>CLCL</sub> + 50 | ns | | Address valid to WR or RD | $t_{AVWL}$ | 67 | - | 4 t <sub>CLCL</sub> - 97 | _ | ns | | WR or RD high to ALE high | $t_{WHLH}$ | 17 | 67 | $t_{\rm CLCL} - 25$ | t <sub>CLCL</sub> + 25 | ns | | Data valid to WR transition | $t_{QVWX}$ | 5 | - | $t_{\text{CLCL}} - 37$ | _ | ns | | Data setup before WR | $t_{\sf QVWH}$ | 170 | _ | 7 t <sub>CLCL</sub> – 122 | _ | ns | | Data hold after WR | $t_{WHQX}$ | 15 | _ | t <sub>CLCL</sub> - 27 | _ | ns | | Address float after RD | $t_{RLAZ}$ | _ | 0 | _ | 0 | ns | # **External Clock Drive Characteristics** | Parameter | Symbol | | Unit | | |-------------------|------------|------|-------------------------------|----| | | | Freq | | | | | | min. | max. | | | Oscillator period | $t_{CLCL}$ | 41.7 | 285.7 | ns | | High time | $t_{CHCX}$ | 12 | $t_{\rm CLCL} - t_{\rm CLCX}$ | ns | | Low time | $t_{CLCX}$ | 12 | $t_{\rm CLCL} - t_{\rm CHCX}$ | ns | | Rise time | $t_{CLCH}$ | _ | 12 | ns | | Fall time | $t_{CHCL}$ | _ | 12 | ns | Figure 26 Program Memory Read Cycle Figure 27 Data Memory Read Cycle Figure 28 Data Memory Write Cycle Figure 29 External Clock Drive on XTAL2 # ROM Verification Characteristics for the C517A-1RM ## **ROM Verification Mode 1** | Parameter | Symbol | Limit ' | Values | Unit | |-----------------------|------------|---------|----------------------|------| | | | min. | max. | | | Address to valid data | $t_{AVQV}$ | _ | 10 t <sub>CLCL</sub> | ns | Figure 30 ROM Verification Mode 1 # **ROM Verification Mode 2** | Parameter | Symbol | | Unit | | | |-----------------------|----------------------|---------------------|----------------------|---------------------|-----| | | | min. | typ | max. | | | ALE pulse width | $t_{AWD}$ | _ | 2 t <sub>CLCL</sub> | _ | ns | | ALE period | $t_{ACY}$ | _ | 12 t <sub>CLCL</sub> | _ | ns | | Data valid after ALE | $t_{DVA}$ | _ | _ | 4 t <sub>CLCL</sub> | ns | | Data stable after ALE | $t_{DSA}$ | 8 t <sub>CLCL</sub> | _ | _ | ns | | P3.5 setup to ALE low | t <sub>AS</sub> | _ | $t_{CLCL}$ | _ | ns | | Oscillator frequency | 1/ t <sub>CLCL</sub> | 3.5 | _ | 24 | MHz | Figure 31 ROM Verification Mode 2 AC Inputs during testing are driven at $V_{\rm CC}$ - 0.5 V for a logic '1' and 0.45 V for a logic '0'. Timing measurements are made at $V_{\rm IHmin}$ for a logic '1' and $V_{\rm ILmax}$ for a logic '0'. Figure 32 AC Testing: Input, Output Waveforms Figure 33 AC Testing: Float Waveforms Figure 34 Recommended Oscillator Circuits for Crystal Oscillator Figure 35 P-MQFP-100-2 Package Outlines # **Sorts of Packing** Package outlines for tubes, trays etc. are contained in our Data Book "Package Information" SMD = Surface Mounted Device Dimensions in mm