Not recommended for new designs. Contact Microchip Sales for microcontroller design options.



### FlashFlex MCU SST89E54C / SST89E58C / SST89E516C

#### Advance Information

The SST89E54C, SST89E58C, and SST89E516C are members of the FlashFlex family of 8-bit micro controller products designed and manufactured with SST patented and proprietary SuperFlash CMOS semiconductor process technology. The split-gate cell design and thick-oxide tunneling injector offer significant cost and reliability benefits for customers. The devices use the 8051 instruction set and are pin-for-pin compatible with standard 8051 micro-controller devices.

### **Features**

- 8-bit 8051-Compatible Microcontroller (MCU) with **Embedded SuperFlash Memory** 
  - Fully Software Compatible
  - Development Toolset Compatible
  - Pin-for-Pin Package Compatible
- SST89E5xC Operation
  - 0 to 40 MHz at 5V
- Total 512 Byte = 54C / 1KByte = 58C / 2KByte = 516C Internal RAM (256 Byte by default + 256/768/1792 Byte enabled by software)

#### Single Block SuperFlash EEPROM

- SST89E/V54C: - SST89E/V58C:
- 16 KByte primary partition + 2 KByte secondary partition 32 KByte primary partition +
- SST89E/V516C:
- 2 KByte secondary partition 64 KByte primary partition + 2 KByte secondary partition – Primary Partition is divided into Four Pages
- Secondary Partition has One Page
- In-System Programming (ISP)
   In-Application Programming (IAP)
   Small-Sector Architecture: 128-Byte Sector Size
- Support External Address Range up to 64 KByte of Program and Data Memory
- Three 16-bit Timers/Counters
- I<sup>2</sup>C Interface (1st and 2nd)

- Full-Duplex, Enhanced UART
  - Framing error detection Automatic address recognition
- Eight Interrupt Sources at 4 Priority Levels
- Programmable Watchdog Timer (WDT)
- Programmable Counter Array (PCA)
- Four 8-bit I/O Ports (32 I/O pins) and one 4-bit port
- Second DPTR register
- Low EMI Mode (Inhibit ALE)
- SPI Serial Interface
- Standard 6 Clocks per cycle, the device has an option to halve the speed to 12 clocks per cycle
- TTL- and CMOS-Compatible Logic Levels
- Low Power Modes
  - Power-down Mode with External Interrupt Wake-up - Idle Mode
- Temperature Ranges:
  - Commercial (0°C to +70°C) Industrial (-40°C to +85°C)
- Packages Available
  - 44-lead PLCC
  - 44-lead TQFP
- All non-Pb (lead-free) devices are RoHS compliant



Advance Information

# **Product Description**

The SST89E54C, SST89E58C, and SST89E516C are members of the FlashFlex family of 8-bit micro controller products designed and manufactured with SST patented and proprietary SuperFlash CMOS semiconductor process technology. The split-gate cell design and thick-oxide tunneling injector offer significant cost and reliability benefits for customers. The devices use the 8051 instruction set and are pin-for-pin compatible with standard 8051 micro-controller devices.

The SST89E54C/SST89E58C/SST89E516C comes with 18/34/66 KByte of on-chip flash EEPROM program memory which is divided into 2 independent program memory partitions. The primary partition occupies 16/8/4 KByte of internal program memory space and the secondary partition occupies 2 KByte of internal program memory space.

The flash memory can be programmed via a standard 87C5x OTP EPROM programmer fitted with a special adapter and firmware for SST devices. During power-on reset, the devices can be configured as either a slave to an external host for source code storage or a master to an external host for an insystem programming (ISP) operation. The devices are designed to be programmed in-system on the printed circuit board for maximum flexibility. The device is pre-programmed with an example of the bootstrap loader (BSL) in memory, demonstrating initial user program code loading or subsequent user code updating via an ISP operation. The sample BSL is for the user's reference only; SST does not guarantee the sample BSL functionality. Chip-Erase operations will erase the pre-programmed sample code.

In addition to 18/34/66 KByte of SuperFlash EEPROM on-chip program memory and 512/1K/2K x8 bits of on-chip RAM, the devices can address up to 66 KByte and of external program memory and up to 64 KByte of external RAM.

SuperFlash, a highly-reliable patented SST technology, and memory cell architecture offer important advantages for designing and manufacturing flash EEPROMs. These advantages translate into significant cost and reliability benefits for customers.



Advance Information

# **Functional Blocks**







Advance Information

# **Pin Assignments**



Figure 2: Pin Assignments for 44-lead TQFP





Figure 3: Pin Assignments for 44-lead PLCC

### **Pin Descriptions**

| Table 1: | Pin Descriptions | (1 of 3) |
|----------|------------------|----------|
|----------|------------------|----------|

| Symbol  | Type <sup>1</sup>                    | Name and Functions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P0[7:0] | I/O                                  | <b>Port 0:</b> Port 0 is an 8-bit open drain bi-directional I/O port. As an output port each pin can sink several LS TTL inputs. Port 0 pins that have '1's written to them float, and in this state can be used as high-impedance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external code and data memory. In this application, it uses strong internal pull-ups when transitioning to '1's. Port 0 also receives the code bytes during the external host mode programming, and outputs the code bytes during the external host mode verification. External pull-ups are required during program verification or as a general purpose I/O port. |
| P1[7:0] | l/O<br>with inter-<br>nal<br>pull-up | <b>Port 1:</b> Port 1 is an 8-bit bi-directional I/O port with internal pull-ups. The Port 1 output buffers can drive LS TTL inputs. Port 1 pins are pulled high by the internal pull-ups when '1's are written to them and can be used as inputs in this state. As inputs, Port 1 pins that are externally pulled low will source current ( $I_{IL}$ , see Table 32) because of the internal pull-ups. P1[5, 6, 7] have high current drive of 16 mA. Port 1 also receives the low-order address byte during the external host mode programming and verification.                                                                                                                               |
| P1[0]   | I/O                                  | T2: External count input to Timer/Counter 2 or Clock-out from Timer/Counter 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| P1[1]   | I                                    | T2EX: Timer/Counter 2 capture/reload trigger and direction control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| P1[2]   | I                                    | <b>ECI:</b> External Clock Input<br>This signal is the external clock input for the PCA.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |



Advance Information

### Table 1: Pin Descriptions (Continued) (2 of 3)

| Symbol               | Type <sup>1</sup>                     | Name and Functions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P1[3]                | I/O                                   | <b>CEX0:</b> Capture/Compare External I/O for PCA Module 0<br>Each capture/compare module connects to a Port 1 pin for external I/O.<br>When not used by the PCA, this pin can handle standard I/O.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| P1[4]                | I/O                                   | CEX1: Capture/Compare External I/O for PCA Module 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| P1[5]                | I/O                                   | CEX2: Capture/Compare External I/O for PCA Module 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| P1[6]                | I/O                                   | SCL1: Clock for I <sup>2</sup> C - Primary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| P1[7]                | I/O                                   | SDA1 Data line for I <sup>2</sup> C - Primary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| P2[7:0]              | I/O<br>with inter-<br>nal<br>pull-up  | <b>Port 2:</b> Port 2 is an 8-bit bi-directional I/O port with internal pull-ups. Port 2 pins are pulled high by the internal pull-ups when '1's are written to them and can be used as inputs in this state. As inputs, Port 2 pins that are externally pulled low will source current (I <sub>IL</sub> , see Table 32) because of the internal pull-ups. Port 2 sends the high-order address byte during fetches from external program memory and during accesses to external Data Memory that use 16-bit address (MOVX@DPTR). In this application, it uses strong internal pull-ups when transitioning to '1's. Port 2 also receives the high-order address byte during the external host mode programming and verification. |
| P3[7:0]              | I/O<br>with inter-<br>nal<br>pull-up  | <b>Port 3:</b> Port 3 is an 8-bit bi-directional I/O port with internal pull-ups. The Port 3 output buffers can drive LS TTL inputs. Port 3 pins are pulled high by the internal pull-ups when '1's are written to them and can be used as inputs in this state. As inputs, Port 3 pins that are externally pulled low will source current (I <sub>IL</sub> , see Table 32) because of the internal pull-ups. Port 3 also receives the high-order address byte during the external host mode programming and verification.                                                                                                                                                                                                      |
| P3[0]                | I                                     | RXD: Universal Asynchronous Receiver/Transmitter (UART) - Receive input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| P3[1]                | 0                                     | TXD: UART - Transmit output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| P3[2]                | I                                     | INT0#: External Interrupt 0 Input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| P3[3]                | I                                     | INT1#: External Interrupt 1 Input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| P3[4]                | I                                     | <b>T0:</b> External count input to Timer/Counter 0<br><b>OR</b><br><b>CEX3:</b> Capture/Compare External I/O for PCA module 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| P3[5]                | I                                     | <b>T1:</b> External count input to Timer/Counter 1<br><b>OR</b><br><b>CEX4:</b> Capture/Compare External I/O for PCA module 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| P3[6]                | 0                                     | WR#: External Data Memory Write strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| P3[7]                | 0                                     | RD#: External Data Memory Read strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P4[3:0] <sup>2</sup> | I/O<br>with inter-<br>nal<br>pull-ups | <b>Port 4:</b> Port 4 is a 4-bit bi-directional I/O port with internal pull-ups. The port 4 output buffers can drive LS TTL inputs. Port 4 pins are pulled high by the internal pull-ups when '1's are written to them and can be used as inputs in this state. As inputs, port 4 pins that are externally pulled low will source current because of internal pull-ups. P4 is not bit-addressable.                                                                                                                                                                                                                                                                                                                              |
| P4[0]                | I/O                                   | <b>Port 4.0 SCK:</b> Master Clock output, slave clock input line for SPI. Bit 0 of port 4 <b>OR SCL2:</b> Clock for I <sup>2</sup> C - secondary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| P4[1]                | I/O                                   | Port 4.1 M1SO: Master input line, slave output line for SPI. Bit 1 of port 4<br>OR<br>SDA2: Data line for I <sup>2</sup> C - secondary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| P4[2]                | I/O                                   | Port 4.2 MOSI: Master output line, slave input line for SPI. Bit 2 of port 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| P4[3]                | I/O                                   | Port 4.3 SS#: Slave port select input line for SPI. Bit 3 of port 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |



Advance Information

#### Table 1: Pin Descriptions (Continued) (3 of 3)

| Symbol          | Type <sup>1</sup> | Name and Functions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PSEN#           | I/O               | <b>Program Store Enable:</b> PSEN# is the Read strobe to external program. When the device is executing from internal program memory, PSEN# is inactive (High). When the device is executing code from external program memory, PSEN# is activated twice each machine cycle, except that two PSEN# activations are skipped during each access to external data memory. A forced high-to-low input transition on the PSEN# pin while the RST input is continually held high for more than 10 machine cycles will cause the device to enter external host mode programming. |
| RST             | I                 | <b>Reset:</b> While the oscillator is running, a "high" logic state on this pin for two machine cycles will reset the device. If the PSEN# pin is driven by a high-to-low input transition while the RST input pin is held "high," the device will enter the external host mode, otherwise the device will enter the normal operation mode.                                                                                                                                                                                                                               |
| EA#             | Ι                 | <b>External Access Enable:</b> EA# must be connected to $V_{SS}$ in order to enable the device to fetch code from the external program memory. EA# must be strapped to $V_{DD}$ for internal program execution. However, Disable-Extern-Boot (See Section, "Security Lock") will disable EA#, and program execution is only possible from internal program memory. The EA# pin can tolerate a high voltage <sup>3</sup> of 12V. (See Section, "Electrical Specification")                                                                                                 |
| ALE/<br>PROG#   | I/O               | Address Latch Enable:ALE is the output signal for latching the low byte of the<br>address during an access to external memory. This pin is also the programming pulse<br>input (PROG#) for flash programming. Normally the ALE4 is emitted at a constant rate<br>of 1/6 the crystal frequency5 and can be used for external timing and clocking. One<br>                                                                                                                                                                                                                  |
| NC              | I/O               | No Connect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| XTAL1           | I                 | <b>Crystal 1:</b> Input to the inverting oscillator amplifier and input to the internal clock generator circuits.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| XTAL2           | 0                 | Crystal 2: Output from the inverting oscillator amplifier.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| V <sub>DD</sub> | I                 | Power Supply                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| V <sub>SS</sub> | 1                 | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

1. I = Input; O = Output

2. Port 4 is not present on the PDIP and WQFN packages

3. It is not necessary to receive a 12V programming supply voltage during flash programming

4.ALE loading issue: When ALE pin experiences higher loading (>30pf) during the reset, the MCU may accidentally enter into modes other than normal working mode. The solution is to add a pull-up resistor of 3-50 KΩ to V<sub>DD</sub>, e.g. for ALE pin.

5. For 6 clock mode, ALE is emitted at 1/3 of crystal frequency.



## **Memory Organization**

The device has separate address spaces for program and data memory.

### **Program Flash Memory**

There are two internal flash memory partitions in the device. The primary flash memory partition (Partition 0) has 66/34/18 KByte. The secondary flash memory partition (Partition 1) has 1 KByte. The total flash memory space of both partitions can be used as a contiguous code storage.

The 66/34/18 KByte primary flash partition is organized as 128/64/32 sectors, each sector consists of 128 Bytes. The primary partition is divided into four logical pages as shown in Figure 4, Figure 5 and Figure 6.

The 2K x8 secondary flash partition is organized as 8 sectors, each sector consists also of 128 Bytes.

For both partitions, the 7 least significant program address bits select the byte within the sector. The remainder of the program address bits select the sector within the partition.









**Figure 5:** Program Memory Organization for SST89E58C







### Data RAM Memory

The data RAM has 512 Bytes/1 KByte/2 KBytes of internal memory. The first 256 Bytes are available by default. The second 256/768/1792 Bytes are enabled by clearing the EXTRAM bit in the AUXR register. The RAM can be addressed up to 64 KByte for external data memory.

### Expanded Data RAM Addressing

The SST89E/V5xC have the capability of 512 Bytes of RAM. See Figure 7.

The device has four sections of internal data memory:

- 1. The lower 128 Bytes of RAM (00H to 7FH) are directly and indirectly addressable.
- 2. The higher 128 Bytes of RAM (80H to FFH) are indirectly addressable.
- 3. The special function registers (80H to FFH) are directly addressable only.
- 4. The expanded RAM of 256/768/1792 Bytes (00H to FFH/00H to 2FFH/00H to 6FFH) is indirectly addressable by the move external instruction (MOVX) and clearing the EXTRAM bit. (See "Auxiliary Register (AUXR)" in Section , "Special Function Registers")

Since the upper 128 bytes occupy the same addresses as the SFRs, the RAM must be accessed indirectly. The RAM and SFRs space are physically separate even though they have the same addresses.

When instructions access addresses in the upper 128 bytes (above 7FH), the MCU determines whether to access the SFRs or RAM by the type of instruction given. If it is indirect, then RAM is accessed. If it is direct, then an SFR is accessed. See the examples below.

#### **Indirect Access:**

MOV@R0, #data; R0 contains 90H

Register R0 points to 90H which is located in the upper address range. Data in "#data" is written to RAM location 90H rather than port 1.

#### **Direct Access:**

MOV90H, #data; write data to P1

Data in "#data" is written to port 1. Instructions that write directly to the address write to the SFRs.

To access the expanded RAM, the EXTRAM bit must be cleared and MOVX instructions must be used. The extra 256/768/1792 Bytes of memory is physically located on the chip and logically occupies the first 256/768/1792 bytes of external memory.

When EXTRAM = 0, the expanded RAM is indirectly addressed using the MOVX instruction in combination with any of the registers R0, R1 of the selected bank or DPTR. Accessing the expanded RAM does not affect ports P0, P3.6 (WR#), P3.7 (RD#), or P2. With EXTRAM = 0, the expanded RAM can be accessed as in the following example.



#### Expanded RAM Access (Indirect Addressing only):

#### MOVX@DPTR, A; DPTR contains 0A0H

DPTR points to 0A0H and data in "A" is written to address 0A0H of the expanded RAM rather than external memory. Access to external memory higher than FFH using the MOVX instruction will access external memory (0100H to FFFFH) and will perform in the same way as the standard 8051, with P0 and P2 as data/address bus, and P3.6 and P3.7 as write and read timing signals.

When EXTRAM = 1, MOVX @Ri and MOVX @DPTR will be similar to the standard 8051. Using MOVX @Ri provides an 8-bit address with multiplexed data on Port 0. Other output port pins can be used to output higher order address bits. This provides external paging capabilities. Using MOVX @DPTR generates a 16-bit address. This allows external addressing up the 64K. Port 2 provides the high-order eight address bits (DPH), and Port 0 multiplexes the low order eight address bits (DPL) with data. Both MOVX @Ri and MOVX @DPTR generates the necessary read and write signals (P3.6 - WR# and P3.7 - RD#) for external memory use. Table 2 shows external data memory RD#, WR# operation with EXTRAM bit.

The stack pointer (SP) can be located anywhere within the 256 bytes of internal RAM (lower 128 bytes and upper 128 bytes). The stack pointer may not be located in any part of the expanded RAM.

|            | MOVX @DPTR, A or       | MOVX A, @DPTR      | MOVX @Ri, A or MOVX A, @Ri          |
|------------|------------------------|--------------------|-------------------------------------|
| AUXR       | ADDR < 0100H           | ADDR = Any         |                                     |
| EXTRAM = 0 | RD# / WR# not asserted | RD# / WR# asserted | RD# / WR# not asserted <sup>2</sup> |
| EXTRAM = 1 | RD# / WR# asserted     | RD# / WR# asserted |                                     |

 Table 2: External Data Memory RD#, WR# with EXTRAM bit (Typical Example<sup>1</sup>)

1. The table addresses will differ for each part—SST89E54C, SST89E58C, and SST89E516C.

2. Access limited to ERAM address within 0 to 0FFH.

T2.0 25096





Figure 7: Internal and External Data Memory Structure

### **Dual Data Pointers**

The device has two 16-bit data pointers. The DPTR Select (DPS) bit in AUXR1 determines which of the two data pointers is accessed. When DPS=0, DPTR0 is selected; when DPS=1, DPTR1 is selected. Quickly switching between the two data pointers can be accomplished by a single INC instruction on AUXR1. (See Figure 8)



### **Special Function Registers**

Most of the unique features of the FlashFlex micro controller family are controlled by bits in special function registers (SFRs) located in the SFR memory map shown in Table 3. Individual descriptions of each SFR are provided and reset values indicated in Tables 4 to 8.



Figure 8: Dual Data Pointer Organization



Advance Information

|     |       |       | •      | •      |        |        |        |      |
|-----|-------|-------|--------|--------|--------|--------|--------|------|
|     |       |       |        | 8 BY   | TES    |        |        |      |
| F8H | S2CON | СН    | CCAP0H | CCAP1H | CCAP2H | ССАРЗН | CCAP4H |      |
| F0H | В     |       |        |        |        |        |        |      |
| E8H | IEN1  | CL    | CCAP0L | CCAP1L | CCAP2L | CCAP3L | CCAP4L |      |
| E0H | ACC   | S2STA | S2DAT  | S2ADR  |        |        |        |      |
| D8H | S1CON | S1STA | S1DAT  | S1ADR  |        |        |        |      |
| D0H | PSW   |       |        |        |        | SPCR   |        |      |
| C8H | T2CON | T2MOD | RCAP2L | RCAP2H | TL2    | TH2    |        |      |
| C0H | CCON  | CMOD  | CCAPM0 | CCAPM1 | CCAPM2 | CCAPM3 | CCAPM4 |      |
| B8H | IP    | SADEN |        |        |        |        |        |      |
| B0H | P3    | SFCF  | SFCM   | SFAL   | SFAH   |        | SFST   | IPH  |
| A8H | IEN0  | SADDR | SPSR   |        |        |        |        |      |
| A0H | P2    | P4    | AUXR1  |        |        |        | WDTRST |      |
| 98H | SOCON | S0BUF |        |        |        |        |        |      |
| 90H | P1    | IP1   | IP1H   |        |        |        |        |      |
| 88H | TCON  | TMOD  | TL0    | TL1    | TH0    | TH1    | AUXR   |      |
| 80H | P0    | SP    | DPL    | DPH    |        |        | SPDR   | PCON |

### Table 3: FlashFlex SFR Memory Map

T3.0 25096

#### Table 4: CPU related SFRs

|                   |                                  | Direct  |       | Bit Addr | ess, Symb | ol, or A | Iternativ | e Port F | unction |      | Reset        |
|-------------------|----------------------------------|---------|-------|----------|-----------|----------|-----------|----------|---------|------|--------------|
| Symbol            | Description                      | Address | MSB   |          |           |          |           |          |         | LSB  | Value<br>00H |
| ACC <sup>1</sup>  | Accumulator                      | E0H     |       | ACC[7:0] |           |          |           |          |         |      |              |
| B <sup>1</sup>    | B Register                       | F0H     |       | B[7:0]   |           |          |           |          |         |      |              |
| PSW <sup>1</sup>  | Program Status<br>Word           | D0H     | CY    | AC       | F0        | RS1      | RS0       | OV       | F1      | Р    | 00H          |
| SP                | Stack Pointer                    | 81H     |       |          |           | SP[7     | :0]       |          |         |      | 07H          |
| DPL               | Data Pointer<br>Low              | 82H     |       |          |           | DPL[7    | 7:0]      |          |         |      | 00H          |
| DPH               | Data Pointer<br>High             | 83H     |       | DPH[7:0] |           |          |           |          |         |      |              |
| IEN0 <sup>1</sup> | Interrupt Enable                 | A8H     | EA    | EC       | ES1       | ES0      | ET1       | EX1      | ET0     | EX0  | 00H          |
| IEN1 <sup>1</sup> | Interrupt Enable A               | E8H     | -     | -        | -         | -        | -         | ES3      | ES2     | ET2  | xxxxx000b    |
| IP                | Interrupt Priority<br>Reg        | B8H     | PT2   | PPC      | PS1       | PS0      | PT1       | PX1      | PT0     | PX0  | 0000000b     |
| IPH               | Interrupt Priority<br>Reg High   | B7H     | PT2H  | PPCH     | PS1H      | PS0H     | PT1H      | PX1H     | PT0H    | PX0H | 0000000b     |
| IPI               | Interrupt Priority<br>Reg A      | 91H     | -     |          | -         | -        | -         | -        | PS3     | PS2  | xxxxxx00b    |
| IPIH              | Interrupt Priority<br>Reg A High | 92H     | -     |          | -         | -        | -         | -        | PS3H    | PS2H | xxxxxx00b    |
| PCON              | Power Control                    | 87H     | SMOD1 | SMOD0    | -         | POF      | GF1       | GF0      | PD      | IDL  | 00x10000b    |
| AUXR              | Auxiliary Reg                    | 8EH     | -     | -        | -         | -        | -         | -        | EXTRAM  | AO   | xxxxxx10b    |
| AUXR1             | Auxiliary Reg 1                  | A2H     | -     | -        | ENBOOT    | -        | GF2       | 0        | -       | DPS  | xxxx00x0b    |
|                   | , ,                              |         |       |          | I         |          |           |          |         |      | T4.0 25096   |

1. Bit Addressable SFRs

T4.0 25096



Advance Information

| Table 5: | Flash | Memory | Programming | SFRs |
|----------|-------|--------|-------------|------|
|----------|-------|--------|-------------|------|

|        |                               |                        |                          |                                                                                            |         |                     |                       |            |         |          | ,              |
|--------|-------------------------------|------------------------|--------------------------|--------------------------------------------------------------------------------------------|---------|---------------------|-----------------------|------------|---------|----------|----------------|
| Symbol | Description                   | Direct<br>Address      | Bit<br>MSB               | Addre                                                                                      | ess, Sy | mbol, or            | Alternat              | ive Port   | Functio | n<br>LSB | Reset<br>Value |
| SFCF   | SuperFlash<br>Configuration   | B1H                    | IAP<br>Command<br>Status | Command ISP 1 1                                                                            |         |                     |                       |            |         |          |                |
| SFCM   | SuperFlash<br>Command         | B2H                    | -                        | - FCM[6:0]                                                                                 |         |                     |                       |            |         |          |                |
| SFAL   | SuperFlash<br>Address<br>Low  | ВЗН                    |                          | SuperFlash<br>Low Order Byte Address Register<br>$A_7$ to $A_0$ (SFAL)                     |         |                     |                       |            |         |          |                |
| SFAH   | SuperFlash<br>Address<br>High | B4H                    |                          | SuperFlash<br>High Order Byte Address Register<br>A <sub>15</sub> to A <sub>8</sub> (SFAH) |         |                     |                       |            |         |          |                |
| SFDT   | SuperFlash<br>Data            | B5H                    |                          |                                                                                            |         |                     | rFlash<br>legister    |            |         |          | 00H            |
|        |                               | B6H<br>SFST_SEL=<br>0H |                          |                                                                                            |         | Manufac             | turer's ID            |            |         |          | 15H            |
|        |                               | SFST_SEL=<br>1H        |                          |                                                                                            | (F7H in | Devio<br>dicates De | ce ID0<br>vice ID1 is | s real ID) |         |          |                |
| SFST   | SuperFlash<br>Status          | SFST_SEL=<br>2H        |                          | Device ID1                                                                                 |         |                     |                       |            |         |          |                |
|        |                               | SFST_SEL=<br>3H        |                          | Boot Vector                                                                                |         |                     |                       |            |         |          |                |
|        |                               | SFST_SEL=<br>4H        | Status<br>Byte_N         | -                                                                                          | -       | -                   | 12 Cycle<br>Mode_N    | LB3_N      | LB2_N   | LB1_N    | 1xxx1111b      |
|        |                               |                        |                          |                                                                                            |         |                     |                       |            |         |          | TE 0 25006     |

T5.0 25096

### Table 6: Watchdog Timer SFRs

| Symbol | Description | Direct<br>Address | Bit Address, Symbol, or Alternative Port Function<br>MSB LSB | Reset<br>Value |
|--------|-------------|-------------------|--------------------------------------------------------------|----------------|
| WDTRST |             | A6H               |                                                              | 00H            |

T6.0 25096



Advance Information

### Table 7: TIMER/COUNTER SFR

|                    |                            | Direct  | Bit Address, Symbol, or Alternative Port Function |             |       |      |           |      |        |         | Reset      |
|--------------------|----------------------------|---------|---------------------------------------------------|-------------|-------|------|-----------|------|--------|---------|------------|
| Symbol             | Description                | Address | MSB                                               |             |       |      |           |      |        | LSB     | Value      |
| TMOD               | Timer/Counter              | 89H     |                                                   | Tim         | ier 1 |      |           | Ti   | imer 0 |         | 00H        |
|                    | Mode Control               |         | GATE                                              | C/T#        | M1    | MO   | GATE      | C/T# | M1     | MO      |            |
| TCON <sup>1</sup>  | Timer/Counter<br>Control   | 88H     | TF1                                               | TR1         | TF0   | TR0  | IE1       | IT1  | IE0    | ITO     | 00H        |
| TH0                | Timer 0 MSB                | 8CH     |                                                   | TH0[7:0]    |       |      |           |      |        |         |            |
| TL0                | Timer 0 LSB                | 8AH     |                                                   | TL0[7:0]    |       |      |           |      |        |         |            |
| TH1                | Timer 1 MSB                | 8DH     |                                                   | TH1[7:0]    |       |      |           |      |        |         |            |
| TL1                | Timer 1 LSB                | 8BH     |                                                   |             |       | TI   | _1[7:0]   |      |        |         | 00H        |
| T2CON <sup>1</sup> | Timer/Counter 2<br>Control | C8H     | TF2                                               | EXF2        | RCLK  | TCLK | EXEN2     | TR2  | C/T2#  | CP/RL2# | 00H        |
| T2MOD#             | Timer 2<br>Mode Control    | C9H     | -                                                 | -           | -     | -    | -         | -    | T2OE   | DCEN    | xxxxxx00b  |
| TH2                | Timer 2 MSB                | CDH     |                                                   |             |       | Tł   | H2[7:0]   | •    |        |         | 00H        |
| TL2                | Timer 2 LSB                | ССН     |                                                   |             |       | TI   | _2[7:0]   |      |        |         | 00H        |
| RCAP2H             | Timer 2<br>Capture MSB     | СВН     |                                                   | RCAP2H[7:0] |       |      |           |      |        | 00H     |            |
| RCAP2L             | Timer 2<br>Capture LSB     | CAH     |                                                   |             |       | RCA  | AP2L[7:0] |      |        |         | 00H        |
|                    |                            |         |                                                   |             |       |      |           |      |        |         | T7 0 25096 |

1. Bit Addressable SFRs

T7.0 25096



Advance Information

|                 |                            | Direct  |                                  | Bit Addr   | ess, Sym | bol, or Al | ternative | Port Fun | ction |       | Reset             |
|-----------------|----------------------------|---------|----------------------------------|------------|----------|------------|-----------|----------|-------|-------|-------------------|
| Symbol          | Description                | Address | MSB                              |            |          |            |           |          |       | LSB   | Value             |
| SOBUF           | Serial Data Buffer         | 99H     |                                  |            |          | SBUF[7     | 7:0]      |          |       |       | Indeter<br>minate |
| S0CON1          | Serial Port Control        | 98H     | SM0/FE SM1 SM2 REN TB8 RB8 TI RI |            |          |            |           |          |       | 00H   |                   |
| SADDR           | Slave Address              | A9H     |                                  | SADDR[7:0] |          |            |           |          |       |       |                   |
| SADEN           | Slave Address<br>Mask      | B9H     |                                  |            |          | SADEN      | [7:0]     |          |       |       | 00H               |
| SPCR            | SPI Control<br>Register    | D5H     | SPIE                             | SPE        | DORD     | MSTR       | CPOL      | CPHA     | SPR1  | SPR0  | 04H               |
| SPSR            | SPI Status<br>Register     | AAH     | SPIF                             | WCOL       |          |            |           |          |       |       | 00H               |
| SPDR            | SPI Data Register          | 86H     |                                  |            |          | SPDR[      | 7:0]      |          |       |       | 00H               |
| S1CON           | I <sup>2</sup> C 1 Control | D8H     | CR2_1                            | ENS1_1     | STA_1    | ST0_1      | S1_1      | AA_1     | CR1_1 | CR0_1 | 00H               |
| S1STA           | I <sup>2</sup> C 1 Status  | D9H     | SC4_1                            | SC3_1      | SC2_1    | SC1_1      | SC0_1     | 0        | 0     | 0     | F8H               |
| S1DAT           | I <sup>2</sup> C 1 Data    | DAH     |                                  |            |          | S1DAT[     | 7:0]      |          |       |       | 00H               |
| S1ADR           | I <sup>2</sup> C 1 Address | DBH     |                                  |            | Slav     | e Address  | 3         |          |       | GC_1  | 00H               |
| S2CON           | I <sup>2</sup> C 1 Control | F8H     | CR2_2                            | ENS1_2     | STA_2    | ST0_2      | S1_2      | AA_2     | CR1_2 | CR0_2 | 00H               |
| S2STA           | I <sup>2</sup> C 1 Status  | E1H     | SC4_2                            | SC3_2      | SC2_2    | SC1_2      | SC0_2     | 0        | 0     | 0     | F8H               |
| S2DAT           | I <sup>2</sup> C 1 Data    | E2H     |                                  |            |          | S2DAT[     | 7:0]      |          |       |       | 00H               |
| S2ADR           | I2C 1 Address              | E3H     |                                  |            | Slav     | e Address  | 3         |          |       | GC_2  | 00H               |
| P0 <sup>1</sup> | Port 0                     | 80H     |                                  |            |          | P0[7       | :]        |          |       |       | FFH               |
| P1 <sup>1</sup> | Port 1                     | 90H     | -                                | -          | -        | -          | -         | -        | T2EX  | T2    | FFH               |
| P2 <sup>1</sup> | Port 2                     | AOH     |                                  |            |          | P0[7:      | :]        |          |       |       | FFH               |
| P3 <sup>1</sup> | Port 3                     | BOH     | RD#                              | WR#        | T1       | T0         | INT1#     | INT0#    | TXD   | RXD   | FFH               |

1. Bit Addressable SFRs

©2011 Silicon Storage Technology, Inc.

DS25096A 11/11



Advance Information

| Table 9:PCA SFRs |
|------------------|
|------------------|

|                   |                                         | Direct  |      | Bit Ade     | dress, Syı | nbol, or A | Alternativ | ve Port F | unction |       | Reset     |
|-------------------|-----------------------------------------|---------|------|-------------|------------|------------|------------|-----------|---------|-------|-----------|
| Symbol            | Description                             | Address | MSB  |             |            |            |            |           |         | LSB   | Value     |
| CH                | PCA Timer/Coun-                         | F9H     |      |             |            | CH[7       | -          |           |         |       | 00H       |
| CL                | ter                                     | E9H     |      |             |            | CL[7       | 7:0]       |           |         |       | 00H       |
| CCON <sup>1</sup> | PCA Timer/Coun-<br>ter Control Register | COH     | CF   | CR          | -          | CCF4       | CCF3       | CCF2      | CCF1    | CCF0  | 00x00000b |
| CMOD              | PCA Timer/Coun-<br>ter Mode Register    | C1H     | CIDL | WDTE        | -          | -          | -          | CPS1      | CPS0    | ECF   | 00xxx000b |
| CCAP0H            | PCA Module 0                            | FAH     |      | CCAP0H[7:0] |            |            |            |           |         |       |           |
| CCAP0L            | Compare/Capture<br>Registers            | EAH     |      |             |            | CCAPO      | )L[7:0]    |           |         |       | 00H       |
| CCAP1H            | PCA Module 1                            | FBH     |      |             |            | CCAP1      | H[7:0]     |           |         |       | 00H       |
| CCAP1L            | Compare/Capture<br>Registers            | EBH     |      |             |            | CCAP1      | L[7:0]     |           |         |       | 00H       |
| CCAP2H            | PCA Module 2                            | FCH     |      |             |            | CCAP2      | :H[7:0]    |           |         |       | 00H       |
| CCAP2L            | Compare/Capture<br>Registers            | ECH     |      |             |            | CCAP2      | 2L[7:0]    |           |         |       | 00H       |
| ССАРЗН            | PCA Module 3                            | FDH     |      |             |            | CCAP3      | H[7:0]     |           |         |       | 00H       |
| CCAP3L            | Compare/Capture<br>Registers            | EDH     |      |             |            | CCAPS      | BL[7:0]    |           |         |       | 00H       |
| CCAP4H            | PCA Module 4                            | FEH     |      |             |            | CCAP4      | H[7:0]     |           |         |       | 00H       |
| CCAP4L            | Compare/Capture<br>Registers            | EEH     |      |             |            | CCAP4      | IL[7:0]    |           |         |       | 00H       |
| CCAPM0            |                                         | C2H     | -    | ECOM0       | CAPP0      | CAPN0      | MAT0       | TOG0      | PWM0    | ECCF0 | x000000b  |
| CCAPM1            | Capture Module                          | СЗН     | -    | ECOM1       | CAPP1      | CAPN1      | MAT1       | TOG1      | PWM1    | ECCF1 | x0000000b |
| CCAPM2            | Mode Registers                          | C4H     | -    | ECOM2       | CAPP2      | CAPN2      | MAT2       | TOG2      | PWM2    | ECCF2 | x000000b  |
| CCAPM3            |                                         | C5H     | -    | ECOM3       | CAPP3      | CAPN3      | MAT3       | TOG3      | PWM3    | ECCF3 | x000000b  |
| CCAPM4            |                                         | C6H     | -    | ECOM4       | CAPP4      | CAPN4      | MAT4       | TOG4      | PWM4    | ECCF4 | x000000b  |

1. Bit Addressable SFRs

T9.0 25096



| - F    |                            | (= = )                                                                                                                                                                                                                          |   |                               |   |   |          |     |                             |
|--------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-------------------------------|---|---|----------|-----|-----------------------------|
| Loca   | ition 7                    | 6                                                                                                                                                                                                                               | 5 | 4                             | 3 | 2 | 1        | 0   | <b>Reset Value</b>          |
| B      | H IAP<br>Command<br>Status | IAP/ISP<br>Enable                                                                                                                                                                                                               | - | ENBOOT<br>1                   | - |   | SFST_SEL |     | 10x00000b                   |
| Syml   | ool                        | Functior                                                                                                                                                                                                                        | ı |                               |   |   |          |     |                             |
| IAP C  | command Status             |                                                                                                                                                                                                                                 |   | d is execut<br>et by the ha   |   |   |          |     |                             |
| IAP/IS | SP Enable                  | 0: Disabl                                                                                                                                                                                                                       |   | t<br>' command<br>SP (default | • |   | •        | ed) |                             |
| ENBO   | DOT1                       | 0: Any instruction code fetch from address 62K to 63K will read from Partitio<br>for 516C and from external memory for 54C and 58C<br>1: Any instruction code fetch from address 62K-63K will read from Lower 1k<br>Partition 1 |   |                               |   |   |          |     |                             |
| SFST   | _SEL                       | (See , "S                                                                                                                                                                                                                       |   | n Status Re                   |   |   |          | •   | r is executed<br>on page 20 |

#### SuperFlash Command Register (SFCM)

SuperFlash Configuration Register (SFCF)

| Location | 7 | 6       | 5           | 4            | 3              | 2           | 1          | 0            | Reset Value  |
|----------|---|---------|-------------|--------------|----------------|-------------|------------|--------------|--------------|
| B2H      |   | FCM6    | FCM5        | FCM4         | FCM3           | FCM2        | FCM1       | FCM0         | 00H          |
| DZIT     | - |         | I ONIJ      | 1 01014      |                |             |            |              |              |
| Symbol   |   | Functi  | on          |              |                |             |            |              |              |
| -        |   | Reserv  | /ed         |              |                |             |            |              |              |
| FCM[6:0] |   | Flash   | operation   | command      |                |             |            |              |              |
|          |   | 000 0   | 001b (      | Chip-Erase   | Э              |             |            |              |              |
|          |   | 000_1   | 011b S      | Sector-Era   | se             |             |            |              |              |
|          |   | 000_1   | 101b F      | Partition0-I | Erase          |             |            |              |              |
|          |   | 000_1   | 100b E      | Byte-Verify  | / <sup>1</sup> |             |            |              |              |
|          |   | 000_1   | 110b E      | Byte-Progr   | am             |             |            |              |              |
|          |   | 000_0   | 011b F      | Prog Lock    | Bit 1/2/3      |             |            |              |              |
|          |   | 000_1   | 000b F      | prog-12-C    | ycles mod      | e/status by | yte        |              |              |
|          |   | 000_1   | 001b p      | rog Boot     | Vector/Era     | se Boot V   | ector and  | Status By    | te           |
|          |   | All oth | er combin   | ations are   | not impler     | mented, a   | nd reserve | ed for futur | e use.       |
|          |   | Before  | writing th  | e commar     | nd to the re   | gisters, th | e applicat | ion code r   | needs to put |
|          |   | the co  | rrect value | on SFAL      | , SFAH, ar     | nd SFDT i   | f necessai | ry.          | -            |
|          |   |         |             |              |                |             |            | -            |              |

#### SuperFlash Address Registers (SFAL)

| Location       | 7                                          | 6                                   | 5          | 4           | 3           | 2        | 1          | 0         | Reset Value |
|----------------|--------------------------------------------|-------------------------------------|------------|-------------|-------------|----------|------------|-----------|-------------|
| B3H            | SuperFlash Low Order Byte Address Register |                                     |            |             |             |          |            |           |             |
| Symbol<br>SFAL |                                            | <b>Funct</b> i<br>Mailbo<br>registe | x register | for interfa | cing with f | lash mem | ory block. | (Low orde | er address  |



| Location                                                         | 7                                                                                                                   | 6                                                                                                                  | 5                                                                                                                            | 4                                                                                                                                                                | 3                                                                                                      | 2                                                 | 1                             | 0                      | Reset Value                             |  |  |  |
|------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|---------------------------------------------------|-------------------------------|------------------------|-----------------------------------------|--|--|--|
| B4H                                                              |                                                                                                                     | Ś                                                                                                                  | SuperFlash                                                                                                                   | High Orde                                                                                                                                                        | r Byte Addr                                                                                            | ess Registe                                       | er                            |                        | 00H                                     |  |  |  |
| Symbol                                                           |                                                                                                                     | Funct                                                                                                              | ion                                                                                                                          |                                                                                                                                                                  |                                                                                                        |                                                   |                               |                        |                                         |  |  |  |
| SFAH                                                             |                                                                                                                     | Mailbo<br>registe                                                                                                  | -                                                                                                                            | for interfa                                                                                                                                                      | cing with f                                                                                            | lash mem                                          | ory block.                    | (High or               | der address                             |  |  |  |
| SuperFlash Data Register                                         | · (SFDT)                                                                                                            |                                                                                                                    |                                                                                                                              |                                                                                                                                                                  |                                                                                                        |                                                   |                               |                        |                                         |  |  |  |
| Location                                                         | 7                                                                                                                   |                                                                                                                    |                                                                                                                              |                                                                                                                                                                  |                                                                                                        |                                                   |                               |                        |                                         |  |  |  |
| B5H                                                              |                                                                                                                     |                                                                                                                    | S                                                                                                                            | uperFlash I                                                                                                                                                      | Data Regist                                                                                            | er                                                |                               |                        | 00H                                     |  |  |  |
| Symbol                                                           |                                                                                                                     | Funct                                                                                                              | ion                                                                                                                          |                                                                                                                                                                  |                                                                                                        |                                                   |                               |                        |                                         |  |  |  |
| SFDT                                                             |                                                                                                                     | Mailbo                                                                                                             | ox register                                                                                                                  | for interfa                                                                                                                                                      | cing with f                                                                                            | lash mem                                          | ory block.                    | (Data re               | gister)                                 |  |  |  |
|                                                                  | <i>(</i> <b>-</b>                                                                                                   |                                                                                                                    | •                                                                                                                            |                                                                                                                                                                  | 0                                                                                                      |                                                   |                               | · ·                    | <b>o</b> ,                              |  |  |  |
| SuperFlash Status Regist                                         |                                                                                                                     |                                                                                                                    |                                                                                                                              |                                                                                                                                                                  |                                                                                                        |                                                   |                               | 1                      |                                         |  |  |  |
| Location                                                         | 7                                                                                                                   | 6                                                                                                                  | 5                                                                                                                            | 4                                                                                                                                                                | 3                                                                                                      | 2                                                 | 1                             | 0                      | Reset Value                             |  |  |  |
| B6H                                                              |                                                                                                                     | SuperFlash Status Register                                                                                         |                                                                                                                              |                                                                                                                                                                  |                                                                                                        |                                                   |                               |                        |                                         |  |  |  |
| Symbol                                                           |                                                                                                                     | Function                                                                                                           |                                                                                                                              |                                                                                                                                                                  |                                                                                                        |                                                   |                               |                        |                                         |  |  |  |
| SFST                                                             | ST This is a read-only register. The read-back value is indexed by SFS the SuperFlash Configuration Register (SFCF) |                                                                                                                    |                                                                                                                              |                                                                                                                                                                  |                                                                                                        |                                                   |                               |                        |                                         |  |  |  |
|                                                                  |                                                                                                                     |                                                                                                                    |                                                                                                                              |                                                                                                                                                                  |                                                                                                        |                                                   |                               |                        |                                         |  |  |  |
|                                                                  |                                                                                                                     | the St                                                                                                             | lper⊢lash                                                                                                                    | Configura                                                                                                                                                        |                                                                                                        | ter (SFCF                                         |                               |                        |                                         |  |  |  |
|                                                                  |                                                                                                                     |                                                                                                                    | _SEL= (                                                                                                                      | DH: Manuf                                                                                                                                                        | tion Regist<br>acturer's I                                                                             | D                                                 |                               | lice by c              |                                         |  |  |  |
|                                                                  |                                                                                                                     |                                                                                                                    | _SEL= (                                                                                                                      | 0H: Manuf<br>1H: Device                                                                                                                                          | tion Regist<br>acturer's I<br>e ID0 = F7                                                               | D<br>H                                            | )                             |                        |                                         |  |  |  |
|                                                                  |                                                                                                                     |                                                                                                                    | _SEL= (                                                                                                                      | 0H: Manuf<br>1H: Device<br>2H: Device                                                                                                                            | tion Regist<br>acturer's I<br>e ID0 = F7<br>e ID1 = De                                                 | D<br>H                                            | )                             |                        | n page 31)                              |  |  |  |
|                                                                  |                                                                                                                     |                                                                                                                    | _SEL= (                                                                                                                      | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V                                                                                                              | tion Regisi<br>acturer's I<br>e ID0 = F7<br>e ID1 = De<br>Vector                                       | D<br>H<br>vice ID (R                              | )                             |                        |                                         |  |  |  |
|                                                                  |                                                                                                                     |                                                                                                                    | _SEL= (                                                                                                                      | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-3                                                                                                | tion Regist<br>acturer's I<br>e ID0 = F7<br>e ID1 = De                                                 | D<br>H<br>vice ID (R<br>t setting                 | )<br>efer to Ta               | ble 10 or              | n page 31)                              |  |  |  |
|                                                                  |                                                                                                                     |                                                                                                                    | _SEL= (                                                                                                                      | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-3                                                                                                | tion Regist<br>acturer's I<br>e ID0 = F7<br>e ID1 = De<br>/ector<br>Security bi                        | D<br>H<br>vice ID (R<br>t setting                 | )<br>efer to Ta               | ble 10 or              | n page 31)                              |  |  |  |
| - · · /                                                          |                                                                                                                     | SFST                                                                                                               | _SEL= ()                                                                                                                     | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-<br>5H: Chip-L                                                                                   | tion Regist<br>acturer's I<br>e ID0 = F7<br>e ID1 = De<br>/ector<br>Security bi<br>.evel Secu          | D<br>H<br>vice ID (R<br>t setting<br>rity bit set | )<br>efer to Ta<br>ting and B | ble 10 or<br>oot Optic | n page 31)<br>ons                       |  |  |  |
| Location                                                         | 7                                                                                                                   | SFST                                                                                                               | _SEL= (                                                                                                                      | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-3<br>5H: Chip-L                                                                                  | tion Regist<br>acturer's I<br>e ID0 = F7<br>e ID1 = De<br>'ector<br>Security bi<br>.evel Secu          | D<br>H<br>vice ID (R<br>t setting<br>rity bit set | )<br>efer to Ta<br>ting and B | ble 10 or<br>oot Optic | n page 31)<br>ons<br><b>Reset Value</b> |  |  |  |
| - · · /                                                          | <b>7</b><br>EA                                                                                                      | SFST                                                                                                               | _SEL= ()                                                                                                                     | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-<br>5H: Chip-L                                                                                   | tion Regist<br>acturer's I<br>e ID0 = F7<br>e ID1 = De<br>/ector<br>Security bi<br>.evel Secu          | D<br>H<br>vice ID (R<br>t setting<br>rity bit set | )<br>efer to Ta<br>ting and B | ble 10 or<br>oot Optic | n page 31)<br>ons                       |  |  |  |
| Location                                                         |                                                                                                                     | SFST                                                                                                               | _SEL= ()<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2                      | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-3<br>5H: Chip-L                                                                                  | tion Regist<br>acturer's I<br>e ID0 = F7<br>e ID1 = De<br>'ector<br>Security bi<br>.evel Secu          | D<br>H<br>vice ID (R<br>t setting<br>rity bit set | )<br>efer to Ta<br>ting and B | ble 10 or<br>oot Optic | n page 31)<br>ons<br><b>Reset Value</b> |  |  |  |
| Location<br>A8H                                                  |                                                                                                                     | 6<br>EC<br>Funct<br>Globa                                                                                          | SEL= 0                                                                                                                       | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-<br>5H: Chip-L<br>4<br>ES                                                                        | tion Regist<br>acturer's I<br>e ID0 = F7<br>e ID1 = De<br>'ector<br>Security bi<br>.evel Secu          | D<br>H<br>vice ID (R<br>t setting<br>rity bit set | )<br>efer to Ta<br>ting and B | ble 10 or<br>oot Optic | n page 31)<br>ons<br><b>Reset Value</b> |  |  |  |
| Location<br>A8H<br>Symbol                                        |                                                                                                                     | 6<br>EC<br>Funct<br>Globa<br>0 = Di                                                                                | _SEL= ()<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2                      | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-<br>5H: Chip-L<br>4<br>ES                                                                        | tion Regist<br>acturer's I<br>e ID0 = F7<br>e ID1 = De<br>'ector<br>Security bi<br>.evel Secu          | D<br>H<br>vice ID (R<br>t setting<br>rity bit set | )<br>efer to Ta<br>ting and B | ble 10 or<br>oot Optic | n page 31)<br>ons<br><b>Reset Value</b> |  |  |  |
| Location<br>A8H<br>Symbol<br>EA                                  |                                                                                                                     | 6<br>EC<br>Funct<br>Globa<br>0 = Di<br>1 = Er                                                                      | _SEL= 0                                                                                                                      | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-3<br>5H: Chip-L<br>4<br>ES<br>Enable                                                             | tion Regist<br>acturer's I<br>e ID0 = F7<br>e ID1 = De<br>'ector<br>Security bi<br>.evel Secu          | D<br>H<br>vice ID (R<br>t setting<br>rity bit set | )<br>efer to Ta<br>ting and B | ble 10 or<br>oot Optic | n page 31)<br>ons<br><b>Reset Value</b> |  |  |  |
| Location<br>A8H<br>Symbol<br>EA<br>EC                            |                                                                                                                     | 6<br>EC<br>Funct<br>Globa<br>0 = Di<br>1 = Er<br>PCA I                                                             | SEL= 0<br>5<br>ES1<br>tion<br>I Interrupt<br>sable<br>nable<br>nterrupt E                                                    | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-3<br>5H: Chip-L<br><b>4</b><br>ES<br>Enable                                                      | tion Regist<br>acturer's I<br>e ID0 = F7<br>e ID1 = De<br>'ector<br>Security bi<br>.evel Secu          | D<br>H<br>vice ID (R<br>t setting<br>rity bit set | )<br>efer to Ta<br>ting and B | ble 10 or<br>oot Optic | n page 31)<br>ons<br><b>Reset Value</b> |  |  |  |
| Location<br>A8H<br>Symbol<br>EA<br>EC<br>ES1                     |                                                                                                                     | 6<br>EC<br>Funct<br>Globa<br>0 = Di<br>1 = Er<br>PCA I<br>I <sup>2</sup> C 1                                       | SEL= 0<br>5<br>ES1<br>tion<br>I Interrupt<br>sable<br>nable<br>nterrupt El<br>Interrupt E                                    | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-3<br>5H: Chip-L<br>4<br>Enable<br>nable                                                          | tion Regist<br>acturer's I<br>e ID0 = F7<br>e ID1 = De<br>'ector<br>Security bi<br>.evel Secu          | D<br>H<br>vice ID (R<br>t setting<br>rity bit set | )<br>efer to Ta<br>ting and B | ble 10 or<br>oot Optic | n page 31)<br>ons<br><b>Reset Value</b> |  |  |  |
| Location<br>A8H<br>Symbol<br>EA<br>EC<br>ES1<br>ES               |                                                                                                                     | 6<br>EC<br>Funct<br>Globa<br>0 = Di<br>1 = Er<br>PCA I<br>I <sup>2</sup> C 1<br>Serial                             | SEL= 0<br>5<br>ES1<br>tion<br>I Interrupt<br>sable<br>nable<br>nterrupt E<br>Interrupt E<br>Interrupt E                      | DH: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-3<br>5H: Chip-L<br>4<br>Enable<br>Enable<br>Enable<br>Enable                                     | tion Regist<br>acturer's I<br>e ID0 = F7<br>e ID1 = De<br>'ector<br>Security bi<br>.evel Secu          | D<br>H<br>vice ID (R<br>t setting<br>rity bit set | )<br>efer to Ta<br>ting and B | ble 10 or<br>oot Optic | n page 31)<br>ons<br><b>Reset Value</b> |  |  |  |
| Location<br>A8H<br>Symbol<br>EA<br>EC<br>ES1<br>ES<br>ET1        |                                                                                                                     | 6<br>EC<br>Funct<br>Globa<br>0 = Di<br>1 = Er<br>PCA I<br>I <sup>2</sup> C 1<br>Serial<br>Timer                    | SEL= 0<br>5<br>ES1<br>tion<br>I Interrupt<br>sable<br>nable<br>nterrupt E<br>Interrupt E<br>Interrupt E<br>Interrupt E       | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-3<br>5H: Chip-L<br>4<br>Enable<br>Enable<br>Enable<br>Enable<br>Enable<br>t Enable               | tion Regist<br>acturer's I<br>P ID0 = F7<br>ID1 = De<br>Vector<br>Security bi<br>evel Secu             | D<br>H<br>vice ID (R<br>t setting<br>rity bit set | )<br>efer to Ta<br>ting and B | ble 10 or<br>oot Optic | n page 31)<br>ons<br><b>Reset Value</b> |  |  |  |
| Location<br>A8H<br>Symbol<br>EA<br>EC<br>ES1<br>ES<br>ET1<br>EX1 |                                                                                                                     | 6<br>EC<br>Funct<br>Globa<br>0 = Di<br>1 = Er<br>PCA I<br>I <sup>2</sup> C 1<br>Serial<br>Timer<br>Exterr          | SEL= 0<br>5<br>ES1<br>tion<br>I Interrupt<br>sable<br>nterrupt E<br>Interrupt E<br>Interrupt E<br>Interrupt E<br>1 Interrupt | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-3<br>5H: Chip-L<br>4<br>Enable<br>Enable<br>Enable<br>Enable<br>Enable<br>t Enable<br>t Enable   | tion Regist<br>acturer's I<br>P ID0 = F7<br>ID1 = De<br>Vector<br>Security bi<br>evel Secu             | D<br>H<br>vice ID (R<br>t setting<br>rity bit set | )<br>efer to Ta<br>ting and B | ble 10 or<br>oot Optic | n page 31)<br>ons<br><b>Reset Value</b> |  |  |  |
| A8H<br>Symbol<br>EA<br>EC<br>ES1<br>ES<br>ET1                    |                                                                                                                     | 6<br>EC<br>Funct<br>Globa<br>0 = Di<br>1 = Er<br>PCA I<br>I <sup>2</sup> C 1<br>Serial<br>Timer<br>Extern<br>Timer | SEL= 0<br>5<br>ES1<br>tion<br>I Interrupt<br>sable<br>nable<br>nterrupt E<br>Interrupt E<br>Interrupt E<br>Interrupt E       | 0H: Manuf<br>1H: Device<br>2H: Device<br>3H: Boot V<br>4H: Page-3<br>5H: Chip-L<br>4<br>Enable<br>Enable<br>Enable<br>Enable<br>t Enable<br>t Enable<br>t Enable | tion Regist<br>acturer's I<br>P ID0 = F7<br>ID1 = De<br>Vector<br>Security bi<br>evel Secu<br>3<br>ET1 | D<br>H<br>vice ID (R<br>t setting<br>rity bit set | )<br>efer to Ta<br>ting and B | ble 10 or<br>oot Optic | n page 31)<br>ons<br><b>Reset Value</b> |  |  |  |

EX0 External 0 Interrupt Enable



Advance Information

| Le                  | ocation   | 7    | 6                    | 5           | 4                              | 3            | 2    | 1    | 0    | Reset Value |
|---------------------|-----------|------|----------------------|-------------|--------------------------------|--------------|------|------|------|-------------|
|                     | E8H       | -    | -                    | -           | -                              | -            | ES3  | ES2  | ET2  | xxxxx000b   |
| Sy                  | mbol      |      | Funct                | ion         |                                |              |      |      |      |             |
| ET                  | 2         |      | Timer                | 2 Interrup  | t Enable                       |              |      |      |      |             |
| ES                  | 2         |      | I <sup>2</sup> C 2 I | Interrupt E | nable                          |              |      |      |      |             |
| ES                  | 3         |      | SPI Er               | nable       |                                |              |      |      |      |             |
| nterrupt Priority ( | IP)       |      |                      |             |                                |              |      |      |      |             |
| Lo                  | ocation   | 7    | 6                    | 5           | 4                              | 3            | 2    | 1    | 0    | Reset Value |
|                     | B8H       | PT2  | PPC                  | PSI         | PS                             | PT1          | PX1  | PT0  | PX0  | 0000000b    |
| Sy                  | mbol      |      | Funct                | ion         |                                |              |      |      |      |             |
| PT                  | 2         |      | Timer                | 2 Interrup  | t priority bi                  | it           |      |      |      |             |
| PP                  | C         |      | PCA Ir               | nterrupt pr | iority bit                     |              |      |      |      |             |
| PS                  | 51        |      | I <sup>2</sup> C 1 I | Interrupt p | riority bit                    |              |      |      |      |             |
| PS                  | ;         |      | Serial               | Port Interr | upt priority                   | y bit        |      |      |      |             |
| PT                  | 1         |      | Timer                | 1 Interrup  | t priority bi                  | it           |      |      |      |             |
| PX                  | (1        |      | Extern               | al Interrup | ot 1 priority                  | / bit        |      |      |      |             |
| PT                  | 0         |      | Timer                | 0 Interrup  | t priority b                   | it           |      |      |      |             |
| PX                  | 0         |      | Extern               | al Interrup | ot 0 priority                  | <i>i</i> bit |      |      |      |             |
| nterrupt Priority H | High (IP  | H)   |                      |             |                                |              |      |      |      |             |
| Le                  | ocation   | 7    | 6                    | 5           | 4                              | 3            | 2    | 1    | 0    | Reset Value |
|                     | B7H       | PT2H | PPCH                 | PS1H        | PSH                            | PT1H         | PX1H | PT0H | PX0H | 0000000b    |
| Sy                  | mbol      |      | Funct                | ion         |                                |              |      |      |      |             |
| PT                  | 2H        |      | Timer                | 2 Interrup  | t priority b                   | it high      |      |      |      |             |
| PP                  | СН        |      | PCA Ir               | nterrupt pr | iority bit h                   | igh          |      |      |      |             |
| PS                  | 51H       |      | I <sup>2</sup> C 1 I | Interrupt p | riority bit h                  | nigh         |      |      |      |             |
|                     | Η         |      | Serial               | Port Interr | upt priority                   | y bit high   |      |      |      |             |
| PS                  |           |      | Timer                | 1 Interrup  | t priority b                   | it high      |      |      |      |             |
|                     | 1H        |      |                      |             |                                |              |      |      |      |             |
| PT                  | 1H<br>(1H |      |                      | al Interrup | ot 1 priority                  | ı bit high   |      |      |      |             |
| PT<br>PX            |           |      | Extern               |             | ot 1 priority<br>t priority bi | -            |      |      |      |             |

#### 1 **Reset Value** Location 7 6 5 4 3 2 0 PS3 PS2 91H ---xxxxxx00b mbol ination -

| Symbol | Function                                  |
|--------|-------------------------------------------|
| PS2    | I <sup>2</sup> C 2 Interrupt priority bit |
| PS3    | SPI Interrupt priority bit                |



| Location                                                  | 7 | 6                                                                                                                 | 5                                                                                                                                       | 4                                                                                                                           | 3                                                                                                              | 2                                                                       | 1                                                                               | 0                                              | Reset Value                                                            |
|-----------------------------------------------------------|---|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|---------------------------------------------------------------------------------|------------------------------------------------|------------------------------------------------------------------------|
| 92H                                                       | - | -                                                                                                                 | -                                                                                                                                       | -                                                                                                                           | -                                                                                                              | -                                                                       | PS3H                                                                            | PS2H                                           | xxxxxx00b                                                              |
| Symbol                                                    |   | Funct                                                                                                             | ion                                                                                                                                     |                                                                                                                             |                                                                                                                |                                                                         |                                                                                 |                                                |                                                                        |
| PS2H                                                      |   | I <sup>2</sup> C 2 I                                                                                              | nterrupt p                                                                                                                              | riority bit h                                                                                                               | nigh                                                                                                           |                                                                         |                                                                                 |                                                |                                                                        |
| PS3H                                                      |   | SPI In                                                                                                            | terrupt pri                                                                                                                             | ority bit hig                                                                                                               | gh                                                                                                             |                                                                         |                                                                                 |                                                |                                                                        |
| Auxiliary Register (AUXR)                                 |   |                                                                                                                   |                                                                                                                                         |                                                                                                                             |                                                                                                                |                                                                         |                                                                                 |                                                |                                                                        |
| Location                                                  | 7 | 6                                                                                                                 | 5                                                                                                                                       | 4                                                                                                                           | 3                                                                                                              | 2                                                                       | 1                                                                               | 0                                              | Reset Value                                                            |
| 8EH                                                       | - | -                                                                                                                 | -                                                                                                                                       | -                                                                                                                           | -                                                                                                              | -                                                                       | EXTRAM                                                                          | AO                                             | xxxxxx10b                                                              |
| Symbol                                                    |   | Funct                                                                                                             | ion                                                                                                                                     |                                                                                                                             |                                                                                                                |                                                                         |                                                                                 |                                                |                                                                        |
| EXTRAM                                                    |   | Interna                                                                                                           | al/Externa                                                                                                                              | RAM acc                                                                                                                     | ess                                                                                                            |                                                                         |                                                                                 |                                                |                                                                        |
|                                                           |   | memo                                                                                                              | ry For det                                                                                                                              | ails, refer                                                                                                                 | to Section                                                                                                     |                                                                         | /s accesse<br>led Data R                                                        |                                                |                                                                        |
| AO                                                        |   | memo<br>1: Exte<br>Disabl<br>0: ALE<br>mode,                                                                      | ry For det<br>ernal data<br>e/Enable<br>is emittee<br>1/6 f <sub>OSC</sub> i                                                            | ails, refer<br>memory a<br>ALE<br>d at a con<br>n 12 clock                                                                  | to Section<br>access<br>stant rate of<br>mode                                                                  | , "Expand<br>of 1/3 the                                                 |                                                                                 | AM Addr<br>requency                            | essing"                                                                |
|                                                           |   | memo<br>1: Exte<br>Disabl<br>0: ALE<br>mode,                                                                      | ry For det<br>ernal data<br>e/Enable<br>is emittee<br>1/6 f <sub>OSC</sub> i                                                            | ails, refer<br>memory a<br>ALE<br>d at a con<br>n 12 clock                                                                  | to Section<br>access<br>stant rate of<br>mode                                                                  | , "Expand<br>of 1/3 the                                                 | ded Data R<br>oscillator fi                                                     | AM Addr<br>requency                            | essing"                                                                |
|                                                           | 7 | memo<br>1: Exte<br>Disabl<br>0: ALE<br>mode,                                                                      | ry For det<br>ernal data<br>e/Enable<br>is emittee<br>1/6 f <sub>OSC</sub> i                                                            | ails, refer<br>memory a<br>ALE<br>d at a con<br>n 12 clock                                                                  | to Section<br>access<br>stant rate of<br>mode                                                                  | , "Expand<br>of 1/3 the                                                 | ded Data R<br>oscillator fi                                                     | AM Addr<br>requency                            | essing"                                                                |
| Auxiliary Register 1 (AUXR1)                              |   | memo<br>1: Exte<br>Disabl<br>0: ALE<br>mode,<br>1: ALE                                                            | ry For det<br>ernal data<br>e/Enable<br>is emitte<br>1/6 f <sub>OSC</sub> i<br>is active                                                | ails, refer<br>memory a<br>ALE<br>d at a con<br>n 12 clock<br>only durin                                                    | to Section<br>access<br>stant rate of<br>mode<br>g a MOVX                                                      | , "Expand<br>of 1/3 the<br>Cor MOVC                                     | ded Data R<br>oscillator fi<br>C instruction                                    | AM Addr<br>requency<br>n                       | essing"<br>in 6 clock                                                  |
| Auxiliary Register 1 (AUXR1)                              | 7 | memo<br>1: Exte<br>Disabl<br>0: ALE<br>mode,<br>1: ALE                                                            | ry For deta<br>ernal data<br>e/Enable a<br>is emitted<br>1/6 f <sub>OSC</sub> i<br>is active<br>5<br>ENBOOT                             | ails, refer<br>memory a<br>ALE<br>d at a con<br>n 12 clock<br>only durin                                                    | to Section<br>access<br>stant rate of<br>mode<br>g a MOVX                                                      | , "Expand<br>of 1/3 the<br>Cor MOVC                                     | ded Data R<br>oscillator fr<br>C instruction                                    | AM Addr<br>requency<br>n<br>0                  | essing"<br>in 6 clock                                                  |
| Auxiliary Register 1 (AUXR1)<br>Location<br>A2H           | 7 | memo<br>1: Exte<br>Disabl<br>0: ALE<br>mode,<br>1: ALE<br>6<br>-<br>Funct<br>0: Any                               | ry For deta<br>ernal data<br>e/Enable a<br>is emitted<br>1/6 f <sub>OSC</sub> i<br>is active<br><b>5</b><br>ENBOOT<br>ion               | ails, refer<br>memory a<br>ALE<br>d at a con<br>n 12 clock<br>only durin<br>4<br>-<br>n code fet                            | to Section<br>access<br>stant rate of<br>mode<br>g a MOVX<br>3<br>GF2<br>ch from ac                            | , "Expand<br>of 1/3 the<br>C or MOVC<br>2<br>0<br>ddress 62             | ded Data R<br>oscillator fi<br>C instruction                                    | AM Addr<br>requency<br>n<br>DPS                | essing"<br>in 6 clock                                                  |
| Auxiliary Register 1 (AUXR1)<br>Location<br>A2H<br>Symbol | 7 | memo<br>1: Exte<br>Disabl<br>0: ALE<br>mode,<br>1: ALE<br>6<br>-<br>Funct<br>0: Any<br>for 516                    | ry For deta<br>ernal data<br>e/Enable a<br>is emitted<br>1/6 f <sub>OSC</sub> i<br>is active<br><b>5</b><br>ENBOOT<br>ion<br>instructio | ails, refer<br>memory a<br>ALE<br>d at a con<br>n 12 clock<br>only durin<br>4<br>-<br>n code fet                            | to Section<br>access<br>stant rate of<br>mode<br>g a MOVX<br>3<br>GF2<br>ch from ac<br>al memory               | , "Expand<br>of 1/3 the<br>Cor MOVC<br>2<br>0<br>ddress 62<br>for 54C a | ded Data R<br>oscillator fi<br>C instruction<br>1<br>-<br>K to 63K wi<br>nd 58C | AM Addr<br>requency<br>n<br>DPS<br>ill read fr | essing"<br>in 6 clock                                                  |
| Auxiliary Register 1 (AUXR1)<br>Location<br>A2H<br>Symbol | 7 | memo<br>1: Exte<br>Disabl<br>0: ALE<br>mode,<br>1: ALE<br>6<br>-<br>Funct<br>0: Any<br>for 516<br>1: Any<br>Block | ry For deta<br>ernal data<br>e/Enable a<br>is emitted<br>1/6 f <sub>OSC</sub> i<br>is active<br><b>5</b><br>ENBOOT<br>ion<br>instructio | ails, refer<br>memory a<br>ALE<br>d at a con<br>n 12 clock<br>only durin<br>4<br>-<br>n code fet<br>m externa<br>n code fet | to Section<br>access<br>stant rate of<br>mode<br>g a MOVX<br>3<br>GF2<br>ch from ac<br>al memory<br>ch from ad | , "Expand<br>of 1/3 the<br>Cor MOVC<br>2<br>0<br>ddress 62<br>for 54C a | ded Data R<br>oscillator fi<br>C instruction<br>1<br>-<br>K to 63K wi<br>nd 58C | AM Addr<br>requency<br>n<br>DPS<br>ill read fr | essing"<br>in 6 clock<br><b>Reset Value</b><br>xx0x00x0b<br>om Block 0 |

#### Watchdog Timer Control Register (WDTRST)

| Location | 7 | 6      | 5   | 4 | 3 | 2 | 1 | 0 | Reset Value |
|----------|---|--------|-----|---|---|---|---|---|-------------|
| A6H      | - | -      | -   | - | - | - | - | - | 0000000b    |
| Symbol   |   | Functi | ion |   |   |   |   |   |             |

Reserved



Advance Information

### I<sup>2</sup>C 1 Control Register (S1CON)

|          | ,     |                      |             |           |      |      |       |       |             |  |  |  |
|----------|-------|----------------------|-------------|-----------|------|------|-------|-------|-------------|--|--|--|
| Location | 7     | 6                    | 5           | 4         | 3    | 2    | 1     | 0     | Reset Value |  |  |  |
| D8H      | CR2_1 | ENS1_1               | STA_1       | ST0_1     | S1_1 | AA_1 | CR1_1 | CR0_1 | 00H         |  |  |  |
| Symbol   |       | Function             |             |           |      |      |       |       |             |  |  |  |
| CR2_1    |       | Clock                | rate Bit    |           |      |      |       |       |             |  |  |  |
| ENS1_1   |       | I <sup>2</sup> C 1 E | Enable Bit  |           |      |      |       |       |             |  |  |  |
| STA_1    |       | Start F              | lag         |           |      |      |       |       |             |  |  |  |
| ST0_1    |       | Stop F               | lag         |           |      |      |       |       |             |  |  |  |
| S1_1     |       | Serial               | Interrupt F | lag       |      |      |       |       |             |  |  |  |
| AA_1     |       | Assert               | Acknowle    | edge Flag |      |      |       |       |             |  |  |  |
| CR1_1    |       | Clock                | rate Bit    |           |      |      |       |       |             |  |  |  |
| CR0_1    |       | Clock                | Rate Bit    |           |      |      |       |       |             |  |  |  |
|          |       |                      |             |           |      |      |       |       |             |  |  |  |

#### I<sup>2</sup>C 2 Control Register (S2CON)

| Location | 7              | 6                    | 5           | 4        | 3    | 2    | 1     | 0     | Reset Value |  |  |
|----------|----------------|----------------------|-------------|----------|------|------|-------|-------|-------------|--|--|
| F8H      | CR2_2          | ENS1_2               | STA_2       | ST0_2    | S1_2 | AA_2 | CR1_2 | CR0_2 | ] 00H       |  |  |
| Symbol   | Function       |                      |             |          |      |      |       |       |             |  |  |
| CR2_2    |                | Clock                | rate Bit    |          |      |      |       |       |             |  |  |
| ENS1_2   |                | I <sup>2</sup> C 1 E | Enable Bit  |          |      |      |       |       |             |  |  |
| STA_2    |                | Start F              | lag         |          |      |      |       |       |             |  |  |
| ST0_2    |                | Stop F               | lag         |          |      |      |       |       |             |  |  |
| S1_2     |                | Serial               | Interrupt F | lag      |      |      |       |       |             |  |  |
| AA_2     |                | Assert               | Acknowle    | dge Flag |      |      |       |       |             |  |  |
| CR1_2    |                | Clock Rate Bit       |             |          |      |      |       |       |             |  |  |
| CR0_2    | Clock Rate Bit |                      |             |          |      |      |       |       |             |  |  |
|          |                |                      |             |          |      |      |       |       |             |  |  |

#### I<sup>2</sup>C 1 Status Register (S1STA)

| Location | 7     | 6     | 5     | 4     | 3     | 2 | 1 | 0 | Reset Value |
|----------|-------|-------|-------|-------|-------|---|---|---|-------------|
| D9H      | SC4_1 | SC3_1 | SC2_1 | SC1_1 | SC0_1 | 0 | 0 | 0 | F8H         |

#### Function

Symbol S1STA

This is a read-only SFR. The five most significant bits contain the status code. The three least significant bits are always 0.

#### I<sup>2</sup>C 2 Status Register (S2STA)

| Location | 7     | 6     | 5     | 4     | 3     | 2 | 1 | 0 | <b>Reset Value</b> |
|----------|-------|-------|-------|-------|-------|---|---|---|--------------------|
| E1H      | SC4_2 | SC3_2 | SC2_2 | SC1_2 | SC0_2 | 0 | 0 | 0 | F8H                |

#### Symbol S2STA

#### Function

This is a read-only SFR. The five most significant bits contain the status code. The three least significant bits are always 0.



Advance Information I<sup>2</sup>C 1 Data Register (S1DAT) Location 6 5 4 3 2 1 0 **Reset Value** 7 DAH S1DAT[7:0] 00H I<sup>2</sup>C 2 Data Register (S2DAT) Location 7 6 5 4 3 2 1 0 **Reset Value** E2H S2DAT[7:0] 00H I<sup>2</sup>C 1 Address Register 1 (S1ADR) 7 6 4 3 2 1 **Reset Value** Location 5 0 D8H Slave Address GC 1 00H I<sup>2</sup>C 2 Data Register (S2ADR) Location 7 6 5 4 2 1 **Reset Value** 3 0 E3H Slave Address GC 2 00H PCA Timer/Counter Control Register<sup>1</sup> (CCON) Location 4 **Reset Value** 7 6 5 3 2 1 0 CF CCF4 CCF2 CCF0 C0H CR CCF3 CCF1 00x00000b 1. Bit addressable Symbol Function CF PCA Counter Overflow Flag Set by hardware when the counter rolls over. CF flags an interrupt if bit ECF in CMOD is set. CF may be set by either hardware or software, but can only cleared by software. CR PCA Counter Run control bit Set by software to turn the PCA counter on. Must be cleared by software to turn the PCA counter off. Not implemented, reserved for future use. Note: User should not write '1's to reserved bits. The value read from a reserved bit is indeterminate. CCF4 PCA Module 4 interrupt flag. Set by hardware when a match or capture occurs. Must be cleared by software. CCF3 PCA Module 3 interrupt flag. Set by hardware when a match or capture occurs. Must be cleared by software. CCF2 PCA Module 2 interrupt flag. Set by hardware when a match or capture occurs. Must be cleared by software. CCF1 PCA Module 1 interrupt flag. Set by hardware when a match or capture occurs. Must be cleared by software.

> CCF0 PCA Module 0 interrupt flag. Set by hardware when a match or capture occurs. Must be cleared by software.



PCA Timer/Counter Mode Register<sup>1</sup> (CMOD)

Advance Information

|          | <b>U</b>     | · · ·                                               |          |                        |              |                               |               |                             |             |  |  |  |  |
|----------|--------------|-----------------------------------------------------|----------|------------------------|--------------|-------------------------------|---------------|-----------------------------|-------------|--|--|--|--|
| Location | 7            | 6                                                   | 5        | 4                      | 3            | 2                             | 1             | 0                           | Reset Value |  |  |  |  |
| C1H      | CIDL         | WDTE                                                | -        | -                      | -            | CPS1                          | CPS0          | ECF                         | 00xxx000b   |  |  |  |  |
|          | 1. Not bit a | addressable                                         |          |                        |              |                               |               |                             | _           |  |  |  |  |
| Symbol   |              | Functi                                              | on       |                        |              |                               |               |                             |             |  |  |  |  |
| CIDL     |              |                                                     | r Idle C |                        |              |                               |               |                             |             |  |  |  |  |
|          |              |                                                     |          | e PCA Coun             |              |                               | •             | •                           | mode        |  |  |  |  |
|          |              | -                                                   |          | e PCA Coun             | ler lo be    | galed off o                   | auring late   |                             |             |  |  |  |  |
| WDTE     |              | Watchdog Timer Enable:                              |          |                        |              |                               |               |                             |             |  |  |  |  |
|          |              | 0: Disables Watchdog timer function on PCA module 4 |          |                        |              |                               |               |                             |             |  |  |  |  |
|          |              | 1: Enables Watchdog timer function on PCA module 4  |          |                        |              |                               |               |                             |             |  |  |  |  |
| -        |              |                                                     |          | ed, reserved           |              |                               |               |                             |             |  |  |  |  |
|          |              | Note: Us<br>indeterm                                |          | not write '1's to      | reserved b   | oits. The valu                | e read from a | a reserved l                | oit is      |  |  |  |  |
| CPS1     |              | PCA C                                               | ount Pu  | lse Select bit         | :1           |                               |               |                             |             |  |  |  |  |
| CPS0     |              | PCA C                                               | ount Pu  | lse Select bit         | 2            |                               |               |                             |             |  |  |  |  |
|          |              |                                                     |          |                        |              |                               |               |                             |             |  |  |  |  |
|          |              |                                                     |          | Selected               |              |                               |               |                             |             |  |  |  |  |
|          |              | CPS1                                                | CPS0     | PCA Input <sup>1</sup> |              |                               |               |                             |             |  |  |  |  |
|          |              | 0                                                   | 0        | 0                      | Internal clo | ock, f <sub>OSC</sub> /6 in 6 | clock mode (1 | f <sub>OSC</sub> /12 in 12  | clock mode) |  |  |  |  |
|          |              | 0                                                   | 1        | 1                      | Internal clo | ock, f <sub>OSC</sub> /2 in 6 | clock mode (1 | f <sub>OSC</sub> /4 in 12 c | clock mode) |  |  |  |  |
|          |              | 1                                                   | 0        | 2                      | Timer 0 ov   | verflow                       |               |                             |             |  |  |  |  |
|          |              | 1                                                   | 1        | 3                      | External c   | ock at ECI/P1                 | .2 pin        |                             |             |  |  |  |  |

### $(max. rate = f_{OSC}/4 in 6 clock mode, f_{OSC}/8 in 12 clock mode)$

1. f<sub>OSC</sub> = oscillator frequency

ECF

PCA Enable Counter Overflow interrupt:

0: Disables the CF bit in CCON

1: Enables CF bit in CCON to generate an interrupt



### PCA Compare/Capture Module Mode Register<sup>1</sup> (CCAPMn)

| Location | 7                                                                                        | 6                                                                      | 5           | 4                        | 3           | 2            | 1          | 0           | Reset Value |  |  |  |
|----------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------|-------------|--------------------------|-------------|--------------|------------|-------------|-------------|--|--|--|
| C2H      | -                                                                                        | ECOM0                                                                  | CAPP0       | CAPN0                    | MAT0        | TOG0         | PWM0       | ECCF0       | x0000000b   |  |  |  |
| СЗН      | -                                                                                        | ECOM1                                                                  | CAPP1       | CAPN1                    | MAT1        | TOG1         | PWM1       | ECCF1       | x0000000b   |  |  |  |
| C4H      | -                                                                                        | ECOM2                                                                  | CAPP2       | CAPN2                    | MAT2        | TOG2         | PWM2       | ECCF2       | x0000000b   |  |  |  |
| C5H      | -                                                                                        | ECOM3                                                                  | CAPP3       | CAPN3                    | MAT3        | TOG3         | PWM3       | ECCF3       | x0000000b   |  |  |  |
| C6H      | -                                                                                        | ECOM4                                                                  | CAPP4       | CAPN4                    | MAT4        | TOG4         | PWM4       | ECCF4       | x0000000b   |  |  |  |
|          | 1. Not bit                                                                               | addressable                                                            |             |                          |             |              |            |             | -           |  |  |  |
| Symbol   |                                                                                          | Functi                                                                 | on          |                          |             |              |            |             |             |  |  |  |
| -        | - Not implemented, reserved for future use.                                              |                                                                        |             |                          |             |              |            |             |             |  |  |  |
|          | Note: User should not write '1's to reserved bits. The value read from a reserved bit is |                                                                        |             |                          |             |              |            |             |             |  |  |  |
|          | indeterminate.                                                                           |                                                                        |             |                          |             |              |            |             |             |  |  |  |
| ECOMn    |                                                                                          | Enable Comparator                                                      |             |                          |             |              |            |             |             |  |  |  |
|          |                                                                                          | 0: Disables the comparator function 1: Enables the comparator function |             |                          |             |              |            |             |             |  |  |  |
| 0455     |                                                                                          | ·                                                                      |             |                          |             |              |            |             |             |  |  |  |
| CAPPn    |                                                                                          | Capture Positive<br>0: Disables positive edge capture on CEX[4:0]      |             |                          |             |              |            |             |             |  |  |  |
|          |                                                                                          | 1: Enables positive edge capture on CEX[4:0]                           |             |                          |             |              |            |             |             |  |  |  |
| CAPNn    |                                                                                          |                                                                        | e Negativ   | •                        |             |              |            |             |             |  |  |  |
| OAI NII  |                                                                                          | •                                                                      | •           | ative edge               | capture o   | n CEX[4:0    | 01         |             |             |  |  |  |
|          |                                                                                          |                                                                        | •           | tive edge                | •           | -            | -          |             |             |  |  |  |
| MATn     |                                                                                          | Match:                                                                 | Set ECO     | M[4:0] and               | MAT[4:0     | ] to impler  | nent the s | oftware tir | ner mode    |  |  |  |
|          |                                                                                          | 0: Disa                                                                | ubles softv | vare timer               | mode        |              |            |             |             |  |  |  |
|          |                                                                                          |                                                                        |             | e PCA cou                |             |              |            |             | e register  |  |  |  |
|          |                                                                                          |                                                                        |             | n bit in CC              | ON to be    | set, flaggi  | ng an inte | rrupt.      |             |  |  |  |
| TOGn     |                                                                                          | Toggle                                                                 |             | 1 . <b>f k</b> '         |             |              |            |             |             |  |  |  |
|          |                                                                                          |                                                                        |             | le function<br>e PCA cou |             | bic modul    | o'e oomoo  | vro/ooptur  | rogistor    |  |  |  |
|          |                                                                                          |                                                                        |             | EXn pin t                |             |              | e s compa  | ile/capture | e register  |  |  |  |
| PWMn     |                                                                                          |                                                                        |             | dulation m               |             |              |            |             |             |  |  |  |
|          |                                                                                          |                                                                        | bles PWN    |                          | 040         |              |            |             |             |  |  |  |
|          |                                                                                          | 1: Ena                                                                 | bles CEX    | n pin to be              | used as a   | a pulse wie  | dth modula | ated outpu  | ıt          |  |  |  |
| ECCFn    |                                                                                          | Enable                                                                 | CCF Inte    | errupt                   |             |              |            |             |             |  |  |  |
|          |                                                                                          |                                                                        |             |                          | ire flag CC | CF[4:0] in t | the CCON   | register to | o generate  |  |  |  |
|          |                                                                                          |                                                                        | rrupt requ  |                          |             |              |            |             |             |  |  |  |
|          |                                                                                          |                                                                        |             |                          | re flag CC  | ⊱[4:0] in tl | he CCON    | register to | generate    |  |  |  |
|          |                                                                                          | aninte                                                                 | rrupt requ  | iest.                    |             |              |            |             |             |  |  |  |



| Control Register (SP | CR)  |         |                                                                                                      |                                            |              |             |             |            | _           |  |  |
|----------------------|------|---------|------------------------------------------------------------------------------------------------------|--------------------------------------------|--------------|-------------|-------------|------------|-------------|--|--|
| Location             | 7    | 6       | 5                                                                                                    | 4                                          | 3            | 2           | 1           | 0          | Reset Value |  |  |
| D5H                  | SPIE | SPE     | DORD                                                                                                 | MSTR                                       | CPOL         | CPHA        | SPR1        | SPR0       | ] оон       |  |  |
| Symbol               |      | Funct   | ion                                                                                                  |                                            |              |             |             |            |             |  |  |
| SPIE                 |      | If both | SPIE and                                                                                             | I ES are se                                | et to one, S | SPI interru | ipts are er | nabled.    |             |  |  |
| SPE                  |      | 0: Disa |                                                                                                      |                                            | cts SS#, N   | IOSI, MIS   | O, and SC   | CK to pins | P1.4, P1.5, |  |  |
| DORD                 |      | 0: MS   | Data Transmission Order.<br>0: MSB first in data transmission.<br>1: LSB first in data transmission. |                                            |              |             |             |            |             |  |  |
| MSTR                 |      | 0: Sele | Master/Slave select.<br>0: Selects Slave mode.<br>1: Selects Master mode.                            |                                            |              |             |             |            |             |  |  |
| CPOL                 |      | 0: SCł  |                                                                                                      | hen idle (A<br>/hen idle (/                | •            | ,           |             |            |             |  |  |
| CPHA                 |      | 0: Shif |                                                                                                      | ntrol bit.<br>I on the lea<br>I on the tra |              |             |             |            |             |  |  |
| SPR1, SP             | R0   | config  | ured as m                                                                                            | Select bits<br>aster. SPF<br>veen SCK      | R1 and SP    | R0 have r   | no effect o | n the slav |             |  |  |
|                      |      |         | 001                                                                                                  | CD                                         |              |             |             |            | .,          |  |  |

| SPR1 | SPR0 | SCK = f <sub>OSC</sub> divided by |
|------|------|-----------------------------------|
| 0    | 0    | 4                                 |
| 0    | 1    | 16                                |
| 1    | 0    | 64                                |
| 1    | 1    | 128                               |

#### **SPI Status Register (SPSR)**

| Location | 7    | 6                 | 5           | 4            | 3                                    | 2         | 1          | 0    | Reset Value |
|----------|------|-------------------|-------------|--------------|--------------------------------------|-----------|------------|------|-------------|
| AAH      | SPIF | WCOL              | -           | -            | -                                    | -         | -          | -    | 00xxxxxb    |
| Symbol   |      | Functi            | on          |              |                                      |           |            |      |             |
| SPIF     |      | Upon o<br>If SPIE | E = 1 and E | n of data tr | ransfer, thi<br>nterrupt is<br>vare. |           |            |      |             |
| WCOL     |      | Set if t          |             | 0            |                                      | to during | data trans | fer. |             |



| SPI Data Register (SPDR  | ł)     |                                                               |                       |              |                       |             |              |             |              |  |
|--------------------------|--------|---------------------------------------------------------------|-----------------------|--------------|-----------------------|-------------|--------------|-------------|--------------|--|
| Location                 | 7      | 6                                                             | 5                     | 4            | 3                     | 2           | 1            | 0           | Reset Value  |  |
| 86H                      |        |                                                               |                       | SPD          | R[7:0]                |             |              |             | 00H          |  |
| Power Control Register ( | (PCON) | 1                                                             |                       | 1            | 1                     |             | 1            | 1           | _            |  |
| Location                 | 7      | 6                                                             | 5                     | 4            | 3                     | 2           | 1            | 0           | Reset Value  |  |
| 87H                      | SMOD1  | SMOD0                                                         | -                     | POF          | GF1                   | GF0         | PD           | IDL         | 00x10000b    |  |
| Symbol                   |        | Funct                                                         | on                    |              |                       |             |              |             |              |  |
| SMOD1                    |        |                                                               |                       |              | IOD1 = 1,<br>in modes |             | •            | enerate th  | e baud rate, |  |
| SMOD0                    |        | FE/SM0 Selection bit.<br>0: SCON[7] = SM0<br>1: SCON[7] = FE, |                       |              |                       |             |              |             |              |  |
| POF                      |        | should<br>0: No l                                             | be cleare<br>Power-on | ed by softv  | vare.                 | l not be af | fected by a  | any other   | reset. POF   |  |
| GF1                      |        | Gener                                                         | al-purpose            | e flag bit.  |                       |             |              |             |              |  |
| GF0                      |        | Gener                                                         | al-purpose            | e flag bit.  |                       |             |              |             |              |  |
| PD                       |        | mode.<br>0: Pow                                               | ver-down i            |              | ot activated          |             | e after exit | ing from p  | oower-down   |  |
| IDL                      |        | 0: Idle                                                       | -                     | not activate | eared by h<br>ed.     | ardware a   | fter exiting | ı from idle | e mode.      |  |



| Location | 7      | 6                                                                                                                                                                                                                                                            | 5                                                | 4                                      | 3                            | 3                | 2                      | 1                         | 0                       | Reset Value                                                        |
|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|----------------------------------------|------------------------------|------------------|------------------------|---------------------------|-------------------------|--------------------------------------------------------------------|
| 98H      | SM0/FE | SM1                                                                                                                                                                                                                                                          | SM2                                              | REN                                    | TE                           | 38               | RB8                    | TI                        | RI                      | 00000000<br>b                                                      |
| Symbol   |        | Functi                                                                                                                                                                                                                                                       | ion                                              |                                        |                              |                  |                        |                           |                         |                                                                    |
| FE       |        | 0: No f<br>1: Frar                                                                                                                                                                                                                                           | IOD0 = 1<br>raming er<br>ning Erro<br>to be clea | rror<br>r. Set by                      | receive                      | er wh            | en an inv              | alid stop b               | oit is dete             | cted. This bit                                                     |
| SM0      |        |                                                                                                                                                                                                                                                              | 0 = 0 to a<br>Port Mode                          |                                        | /10 bit.                     |                  |                        |                           |                         |                                                                    |
| SM1      |        | Serial                                                                                                                                                                                                                                                       | Port Mod                                         | e Bit 1                                |                              |                  |                        |                           |                         |                                                                    |
|          |        | SM                                                                                                                                                                                                                                                           | 0 SN                                             | /11 N                                  | ode                          | Des              | cription               | Baud Ra                   | te <sup>1</sup>         |                                                                    |
|          |        | 0                                                                                                                                                                                                                                                            | (                                                | )                                      | 0                            |                  | t Register             |                           | clock mod<br>12 clock m |                                                                    |
|          |        | 0                                                                                                                                                                                                                                                            | 1                                                |                                        | 1                            |                  | UART                   | Variable                  |                         |                                                                    |
|          |        | 1                                                                                                                                                                                                                                                            | 0                                                | )                                      | 2                            | 9-bit            | UART                   | or                        |                         | 6 clock mode)                                                      |
|          |        | 1                                                                                                                                                                                                                                                            |                                                  |                                        | 3                            | 9-hit            | UART                   | Variable                  | 1 10SC/32 (             | 12 clock mode                                                      |
|          |        | 1. fc                                                                                                                                                                                                                                                        | osc = oscilla                                    |                                        | -                            | 3-01             |                        | Valiable                  |                         |                                                                    |
| SM2      |        | 1 then<br>an ado<br>if SM2                                                                                                                                                                                                                                   | RI will no<br>Iress, and                         | t be set ι<br>I the rece<br>RI will no | inless<br>ived by<br>t be ac | the re<br>/te is | eceived 9<br>a given o | th data bit<br>or broadca | (RB8) is<br>st addres   | or 3. If SM2 =<br>1, indicating<br>s. In Mode 1,<br>s received. In |
| REN      |        | 0: to d                                                                                                                                                                                                                                                      | es serial re<br>isable rec<br>nable rec          | eption.                                |                              |                  |                        |                           |                         |                                                                    |
| TB8      |        |                                                                                                                                                                                                                                                              | h data bit<br>re as des                          |                                        | be tran                      | smitt            | ed in Moo              | des 2 and                 | 3. Set or               | clear by                                                           |
| RB8      |        |                                                                                                                                                                                                                                                              |                                                  |                                        |                              |                  |                        | ceived. In<br>e 0, RB8 is |                         | if SM2 = 0,<br>I.                                                  |
| ТІ       |        | or at th                                                                                                                                                                                                                                                     | ne beginni                                       | ing of the                             | stop b                       | oit in t         | the other              | end of the<br>modes, in   |                         | ne in Mode 0,<br>al                                                |
| RI       |        | transmission, Must be cleared by software.<br>Receive interrupt flag. Set by hardware at the end of the8th bit time in Mod<br>or halfway through the stop bit time in the other modes, in any serial recep<br>(except see SM2). Must be cleared by software. |                                                  |                                        |                              |                  |                        |                           |                         |                                                                    |



| Location | 7   | 6                                                                                                                                                                                                                                                                                                                                      | 5                                                                                                                                                                                                                                                                                                                                       | 4           | 3                                      | 2            | 1            | 0           | Reset Value                       |  |  |  |
|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------------------------|--------------|--------------|-------------|-----------------------------------|--|--|--|
|          | -   | -                                                                                                                                                                                                                                                                                                                                      | -                                                                                                                                                                                                                                                                                                                                       | -           | -                                      | _            | -            | -           |                                   |  |  |  |
| C8H      | TF2 | EXF2                                                                                                                                                                                                                                                                                                                                   | RCLK                                                                                                                                                                                                                                                                                                                                    | TCLK        | EXEN2                                  | TR2          | C/T2#        | CP/<br>RL2# | 00H                               |  |  |  |
| Symbol   |     | Funct                                                                                                                                                                                                                                                                                                                                  | ion                                                                                                                                                                                                                                                                                                                                     |             |                                        |              |              |             |                                   |  |  |  |
| TF2      |     |                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                         | •           | oy a Timer<br>et when ei               |              |              |             | ed by                             |  |  |  |
| EXF2     |     | negati<br>enable<br>routine                                                                                                                                                                                                                                                                                                            | Timer 2 external flag set when either a capture or reload is caused by a negative transition on T2EX and EXEN2 = 1. When Timer 2 interrupt is enabled, $EXF2 = 1$ will cause the CPU to vector to the Timer 2 interrupt routine. EXF2 must be cleared by software. EXF2 does not cause an interrupt in up/down counter mode (DCEN = 1). |             |                                        |              |              |             |                                   |  |  |  |
| RCLK     |     | pulses                                                                                                                                                                                                                                                                                                                                 | Receive clock flag. When set, causes the serial port to use Timer 2 overflow pulses for its receive clock in modes 1 and 3. RCLK = 0 causes Timer 1 overflow to be used for the receive clock.                                                                                                                                          |             |                                        |              |              |             |                                   |  |  |  |
| TCLK     |     | pulses                                                                                                                                                                                                                                                                                                                                 | for its trai                                                                                                                                                                                                                                                                                                                            | nsmit cloc  | set, cause<br>k in modes<br>transmit o | s 1 and 3.   | •            |             | 2 overflow<br>imer 1              |  |  |  |
| EXEN2    |     | a resu                                                                                                                                                                                                                                                                                                                                 | lt of a neg                                                                                                                                                                                                                                                                                                                             | ative trans |                                        | 2EX if Tim   | ier 2 is not | being us    | to occur as<br>ed to clock<br>EX. |  |  |  |
| TR2      |     | Start/s                                                                                                                                                                                                                                                                                                                                | top contro                                                                                                                                                                                                                                                                                                                              | l for Time  | r 2. A logic                           | : 1 starts t | he timer.    |             |                                   |  |  |  |
| C/T2#    |     | Timer or counter select (Timer 2)<br>0: Internal timer (OSC/6 in 6 clock mode, OSC/12 in 12 clock mode)<br>1: External event counter (falling edge triggered)                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                         |             |                                        |              |              |             |                                   |  |  |  |
| CP/RL2#  |     | Capture/Reload flag. When set, captures will occur on negative transitions at T2EX if EXEN2 = 1. When cleared, auto-reloads will occur either with Timer 2 overflows or negative transitions at T2EX when EXEN2 = 1. When either RCLM = 1 or TCLK = 1, this bit is ignored and the timer is forced to auto-reload on Timer 2 overflow. |                                                                                                                                                                                                                                                                                                                                         |             |                                        |              |              |             |                                   |  |  |  |

### Timer/Counter 2 Control Register (T2CON)

#### Timer/Counter 2 Mode Control (T2MOD)

| Location | 7 | 6                   | 5                      | 4               | 3             | 2             | 1             | 0            | Reset Value |
|----------|---|---------------------|------------------------|-----------------|---------------|---------------|---------------|--------------|-------------|
| С9Н      | - | -                   | -                      | -               | -             | -             | T2OE          | DCEN         | xxxxxx00b   |
| Symbol   |   | Funct               | ion                    |                 |               |               |               |              |             |
| -        |   | Not im              | plemente               | d, reserve      | d for future  | e use.        |               |              |             |
|          |   | Note: U<br>indetern |                        | ot write '1's t | to reserved b | its. The valu | e read from a | a reserved b | it is       |
| T2OE     |   | Timer               | 2 Output I             | Enable bit.     |               |               |               |              |             |
| DCEN     |   |                     | Count Ena<br>vn counte |                 | /hen set, tl  | nis allows    | Timer 2 to    | be config    | jured as an |



# Flash Memory Programming

The device internal flash memory can be programmed or erased using In-Application Programming (IAP).

### **Product Identification**

The Read-ID command accesses the Signature Bytes that identify the device and the manufacturer as SST. External programmers primarily use these Signature Bytes in the selection of programming algorithms.

#### Table 10: Product Identification

|                      | Address | Data |
|----------------------|---------|------|
| Manufacturer's ID    | 30H     | 15H  |
| Device ID            | 31H     | C2H  |
| Device ID (extended) |         |      |
| SST89E54C            | 32H     | 90H  |
| SST89E58C            | 32H     | 91H  |
| SST89E516C           | 32H     | 92H  |

T10.0 25096

### **In-Application Programming**

The IAP/ISP functions are issued via the SST mail box scheme. Detailed flash block operations are performed by the flash control unit. While the flash control executes IAP commands, the CPU is on hold since there is only one physical flash block in the SST89x5xC devices. When IAP commands finish, the CPU can resume execution of the application code. So the application code needs to turn off the interrupt or turn off the peripheral modules before it issues IAP commands since the CPU cannot respond to the interrupt or poll the SFR status.

The IAP supports the following commands:

- 1. Chip-Erase
- 2. Partition0-Erase
- 3. Sector-Erase
- 4. Byte-Program
- 5. Byte-Verify
- 6. PROG-Status Byte
- 7. PROG-Boot Vector
- 8. PROG-LB-1/-2/-3 (LB = Lock Bit)
- 9. PROG-12-Cycles-Mode
- 10. Erase-Status-Byte-and-Boot-Vector



#### Advance Information

#### Table 11: IAP Commands

| Operation                             | SFCM<br>[6:0] | SFAH | SFAL | SFDT |
|---------------------------------------|---------------|------|------|------|
| Chip-Erase                            | 01H           | Х    | Х    | 55H  |
| Partition0-Erase                      | 0DH           | X    | Х    | AAH  |
| Sector-Erase                          | 0BH           | AH   | AL   | A5H  |
| Byte-Program                          | 0EH           | AH   | AL   | DI   |
| Byte-Verify (Read)                    | 0CH           | AH   | AL   | DO   |
| PROG-Boot-Vector                      | 09H           | F0H  | Х    | DI   |
| PROG-Status-Byte                      | 08H           | E0H  | Х    | X    |
| PROG-LB1                              | 03H           | 90H  | Х    | X    |
| PROG-LB2                              | 03H           | 91H  | Х    | X    |
| PROG-LB3                              | 03H           | 92H  | Х    | X    |
| PROG-12-Cycles-Mode                   | 03H           | 93H  | Х    | X    |
| Erase-Status-Byte-<br>and-Boot-Vector | 03H           | СОН  | Х    | Х    |

T11.0 1294

#### **Chip-Erase**

Chip-Erase IAP command will erase Partition 0 and Partition 1, code flash memory, erase the non-volatile RAM (NVR) sector 1, and set the LB status bit to 0.

#### **Partition0-Erase**

Partition0-Erase IAP command will erase Partition 0 code flash memory, erase the NVR sector 1, and set the LB status bit to 0.

#### **Erase Status Byte and Boot Vector**

This command sets the Status Byte and Boot Vector to 1.

#### **IAP Command Sequence**

In order to protect the flash during the power-off condition, the application needs to write a special, sequential command sequence to the SFCM SFR address before issuing a valid IAP command.

First, the application needs to write 0FH, second, A6H or 59H (depending on the targeted block), then the IAP command.

| IAP Commands                                | Valid 2 <sup>nd</sup> Sequence | Target Memory                                 | Address Range                                                |
|---------------------------------------------|--------------------------------|-----------------------------------------------|--------------------------------------------------------------|
| Sector France                               | 59H                            | Partition 1                                   | 0-2K                                                         |
| Sector-Erase<br>Byte-Program<br>Byte-Verify | A6H                            | Partition 0                                   | 0-64K (SST89E516C)<br>0-32K (SST89E58C)<br>0-16K (SST89E54C) |
| Other IAP Commands                          | A6H/59H                        | NVR or<br>Partition 0 or<br>Whole Flash Space | N/A                                                          |

#### Table 12:Command Sequence Table

T12.0 1294



### In-System Programming

The bootstrap loader (BSL) is located in Partition 1 and cannot be accessed unless the SFR AUXR1 (Address = A2H), Bit 5 is enabled. The default value of this bit after reset is 0 unless the Status byte is programmed or the PSEN# is pulled low, ALE is high and EA# is high at the falling edge of the reset.

### **Normal Mode**

After power-on, the hardware checks the Status byte. If the Status byte is set to 0, the value of the boot vector is used as the high byte of the program counter (PC) starting address, the lower byte of PC will be 00H. If the Status byte is set to 1, the PC will start from address 0. The boot vector factory setting is FCH and the Status byte factory default setting is 0.

### Hardware Enter Mode

The user can hold PSEN# low, ALE and EA# is high at the falling edge of reset. This is the same effect as having a programmed NVR Status Byte.



Figure 9: Hardware Active Mode/ISP Entry Mode



## **Timers/Counters**

### Timers

The device has three 16-bit registers that can be used as either timers or event counters. The three timers/counters are denoted Timer 0 (T0), Timer 1 (T1), and Timer 2 (T2). Each is designated a pair of 8-bit registers in the SFRs. The pair consists of a most significant (high) byte and least significant (low) byte. The respective registers are TL0, TH0, TL1, TH1, TL2, and TH2.

### **Timer Set-up**

Refer to Table 7 for TMOD, TCON, and T2CON registers regarding timers T0, T1, and T2. The following tables provide TMOD values to be used to set up Timers T0, T1, and T2.

Except for the baud rate generator mode, the values given for T2CON do not include the setting of the TR2 bit. Therefore, bit TR2 must be set separately to turn the timer on.

|                    |      |                   | ТМОД                             |                                  |  |
|--------------------|------|-------------------|----------------------------------|----------------------------------|--|
|                    | Mode | Function          | Internal<br>Control <sup>1</sup> | External<br>Control <sup>2</sup> |  |
| Used as Timer      | 0    | 13-bit Timer      | 00H                              | 08H                              |  |
|                    | 1    | 16-bit Timer      | 01H                              | 09H                              |  |
|                    | 2    | 8-bit Auto-Reload | 02H                              | 0AH                              |  |
|                    | 3    | Two 8-bit Timers  | 03H                              | 0BH                              |  |
| Used as<br>Counter | 0    | 13-bit Timer      | 04H                              | 0CH                              |  |
|                    | 1    | 16-bit Timer      | 05H                              | 0DH                              |  |
|                    | 2    | 8-bit Auto-Reload | 06H                              | 0EH                              |  |
|                    | 3    | Two 8-bit Timers  | 07H                              | 0FH                              |  |

#### Table 13:Timer/Counter 0

1. The Timer is turned ON/OFF by setting/clearing bit TR0 in the software.

2. The Timer is turned ON/OFF by the 1 to 0 transition on INT0# (P3.2) when TR0 = 1 (hardware control).

T13.0 25096



#### Advance Information

T14.0 25096

#### Table 14:Timer/Counter 1

|                    |      |                   | ТМОД                             |                                  |  |
|--------------------|------|-------------------|----------------------------------|----------------------------------|--|
|                    | Mode | Function          | Internal<br>Control <sup>1</sup> | External<br>Control <sup>2</sup> |  |
| Used as Timer      | 0    | 13-bit Timer      | 00H                              | 80H                              |  |
|                    | 1    | 16-bit Timer      | 10H                              | 90H                              |  |
|                    | 2    | 8-bit Auto-Reload | 20H                              | A0H                              |  |
|                    | 3    | Does not run      | 30H                              | B0H                              |  |
| Used as<br>Counter | 0    | 13-bit Timer      | 40H                              | СОН                              |  |
|                    | 1    | 16-bit Timer      | 50H                              | D0H                              |  |
|                    | 2    | 8-bit Auto-Reload | 60H                              | E0H                              |  |
|                    | 3    | Not available     | -                                | -                                |  |

1. The Timer is turned ON/OFF by setting/clearing bit TR1 in the software.

2. The Timer is turned ON/OFF by the 1 to 0 transition on INT1# (P3.3) when TR1 = 1 (hardware control).

|                 |                                                               | T20                              | CON                              |
|-----------------|---------------------------------------------------------------|----------------------------------|----------------------------------|
|                 | Mode                                                          | Internal<br>Control <sup>1</sup> | External<br>Control <sup>2</sup> |
|                 | 16-bit Auto-Reload                                            | 00H                              | 08H                              |
|                 | 16-bit Capture                                                | 01H                              | 09H                              |
| Used as Timer   | Baud rate generator<br>receive and transmit<br>same baud rate | 34H                              | 36H                              |
|                 | Receive only                                                  | 24H                              | 26H                              |
|                 | Transmit only                                                 | 14H                              | 16H                              |
| Used as Counter | 16-bit Auto-Reload                                            | 02H                              | 0AH                              |
|                 | 16-bit Capture                                                | 03H                              | 0BH                              |

#### Table 15: Timer/Counter 2

1. Capture/Reload occurs only on timer/counter overflow.

2. Capture/Reload occurs on timer/counter overflow and a 1 to 0 transition on T2EX (P1.1) pin except when Timer 2 is used in the baud rate generating mode.



### Programmable Clock-Out

A 50% duty cycle clock can be programmed to come out on P1.0. This pin, besides being a regular I/O pin, has two alternate functions. It can be programmed:

- 1. to input the external clock for Timer/Counter 2, or
- 2. to output a 50% duty cycle clock ranging from 122 Hz to 8 MHz at a 16 MHz operating frequency (61 Hz to 4 MHz in 12 clock mode).

To configure Timer/Counter 2 as a clock generator, bit C/#T2 (in T2CON) must be cleared and bit T20E in T2MOD must be set. Bit TR2 (T2CON.2) also must be set to start the timer.

The Clock-Out frequency depends on the oscillator frequency and the reload value of Timer 2 capture registers (RCAP2H, RCAP2L) as shown in this equation:

Oscillator Frequency n x (65536 - RCAP2H, RCAP2L)

n =2 (in 6 clock mode) 4 (in 12 clock mode)

Where (RCAP2H, RCAP2L) = the contents of RCAP2H and RCAP2L taken as a 16-bit unsigned integer.

In the Clock-Out mode, Timer 2 roll-overs will not generate an interrupt. This is similar to when it is used as a baud-rate generator. It is possible to use Timer 2 as a baud-rate generator and a clock generator simultaneously. Note, however, that the baud-rate and the Clock-Out frequency will not be the same.



## Serial I/O

## Full-Duplex, Enhanced UART

The device serial I/O port is a full-duplex port that allows data to be transmitted and received simultaneously in hardware by the transmit and receive registers, respectively, while the software is performing other tasks. The transmit and receive registers are both located in the Serial Data Buffer (SBUF) special function register. Writing to the SBUF register loads the transmit register, and reading from the SBUF register obtains the contents of the receive register.

The UART has four modes of operation which are selected by the Serial Port Mode Specifier (SM0 and SM1) bits of the Serial Port Control (SCON) special function register. In all four modes, transmission is initiated by any instruction that uses the SBUF register as a destination register. Reception is initiated in mode 0 when the Receive Interrupt (RI) flag bit of the Serial Port Control (SCON) SFR is cleared and the Reception Enable/ Disable (REN) bit of the SCON register is set. Reception is initiated in the other modes by the incoming start bit if the REN bit of the SCON register is set.

## **Framing Error Detection**

Framing Error Detection is a feature, which allows the receiving controller to check for valid stop bits in modes 1, 2, or 3. Missing stops bits can be caused by noise in serial lines or from simultaneous transmission by two CPUs.

Framing Error Detection is selected by going to the PCON register and changing SMOD0 = 1 (see Figure 10). If a stop bit is missing, the Framing Error bit (FE) will be set. Software may examine the FE bit after each reception to check for data errors. After the FE bit has been set, it can only be cleared by software. Valid stop bits do not clear FE. When FE is enabled, RI rises on the stop bit, instead of the last data bit (see Figure 11 and Figure 12).



Figure 10: Framing Error Block Diagram



#### Advance Information



#### Figure 11:UART Timings in Mode 1



Figure 12: UART Timings in Modes 2 and 3

#### **Automatic Address Recognition**

Automatic Address Recognition (AAR) helps to reduce the time and power required to communicate with multiple serial devices. Each device shares the same serial link, but has its own address. In this configuration, a device is only interrupted when it receives its own address, thus eliminating the software overhead to compare addresses.

This same feature helps to save power because it can be used in conjunction with idle mode to reduce the system's overall power consumption. AAR allows the other slaves to remain in idle mode while only one is interrupted. By limiting the number of interruptions, the total current draw on the system is reduced.

There are two ways to communicate with slaves: a group of them at once, or all of them at once. To communicate with a group of slaves, the master sends out an address called the given address. To communicate with all the slaves, the master sends out an address called the "broadcast" address.

AAR can be configured as mode 2 or 3 (9-bit modes) and setting the SM2 bit in SCON. Each slave has its own SM2 bit set waiting for an address byte (9th bit = 1). The Receive Interrupt (RI) flag will only be set when the received byte matches either the given address or the broadcast address. Next, the slave then clears its SM2 bit to enable reception of the data bytes (9th bit = 0) from the master. When the 9th bit = 1, the master is sending an address. When the 9th bit = 0, the master is sending actual data.



If mode 1 is used, the stop bit takes the place of the 9th bit. Bit RI is set only when the received command frame address matches the device's address and is terminated by a valid stop bit. Note that mode 0 cannot be used. Setting SM2 bit in the SCON register in mode 0 will have no effect.

Each slave's individual address is specified by SFR SADDR. SFR SADEN is a mask byte that defines "don't care" bits to form the given address when combined with SADDR. See the example below:

#### Slave 1

| SADDR | = | 1111 0001 |
|-------|---|-----------|
| SADEN | = | 1111 1010 |
| GIVEN | = | 1111 0X0X |

#### Slave 2

| SADDR | = | 1111 0011 |
|-------|---|-----------|
| SADEN | = | 1111 1001 |
| GIVEN | = | 1111 0XX1 |

#### Using the Given Address to Select Slaves

Any bits masked off by a 0 from SADEN become a "don't care" bit for the given address. Any bit masked off by a 1, becomes ANDED with SADDR. The "don't cares" provide flexibility in the user-defined addresses to address more slaves when using the given address.

Shown in the example above, Slave 1 has been given an address of 1111 0001 (SADDR). The SADEN byte has been used to mask off bits to a given address to allow more combinations of selecting Slave 1 and Slave 2. In this case for the given addresses, the last bit (LSB) of Slave 1 is a "don't care" and the last bit of Slave 2 is a 1. To communicate with Slave 1 and Slave 2, the master would need to send an address with the last bit equal to 1 (e.g. 1111 0001) since Slave 1's last bit is a don't care and Slave 2's last bit has to be a 1. To communicate with Slave 1 alone, the master would send an address with the last bit equal to 0 (e.g. 1111 0000), since Slave 2's last bit is a 1. See the table below for other possible combinations.

| Select Slave 1 Only                      |           |           |
|------------------------------------------|-----------|-----------|
| Slave 1 Given Address Possible Addresses |           |           |
|                                          | 1111 0X0X | 1111 0000 |
|                                          |           | 1111 0100 |

| Select Slave 2 Only                      |           |                    |
|------------------------------------------|-----------|--------------------|
| Slave 2 Given Address Possible Addresses |           | Possible Addresses |
|                                          | 1111 0XX1 | 1111 0111          |
|                                          |           | 1111 0011          |

| Select Slaves 1 and 2             |           |  |
|-----------------------------------|-----------|--|
| Slaves 1 and 2 Possible Addresses |           |  |
|                                   | 1111 0001 |  |
|                                   | 1111 0101 |  |



If the user added a third slave such as the example below:

 Slave 3

 SADDR
 =
 1111
 1001

 SADEN
 =
 1111
 0101

 GIVEN
 =
 1111
 X0X1

| Select Slave 3 Only                      |           |                    |
|------------------------------------------|-----------|--------------------|
| Slave 2 Given Address Possible Addresses |           | Possible Addresses |
|                                          | 1111 X0X1 | 1111 1011          |
|                                          |           | 1111 1001          |

The user could use the possible addresses above to select slave 3 only. Another combination could be to select slave 2 and 3 only as shown below.

| Select Slaves 2 and 3 Only        |  |  |
|-----------------------------------|--|--|
| Slaves 2 and 3 Possible Addresses |  |  |
| 1111 0011                         |  |  |

More than one slave may have the same SADDR address as well, and a given address could be used to modify the address so that it is unique.

#### Using the Broadcast Address to Select Slaves

Using the broadcast address, the master can communicate with all the slaves at once. It is formed by performing a logical OR of SADDR and SADEN with 0s in the result treated as "don't cares".

#### Slave 1

1111 0001 = SADDR +1111 1010 = SADEN 1111 1X11 = Broadcast

"Don't cares" allow for a wider range in defining the broadcast address, but in most cases, the broadcast address will be FFH.

On reset, SADDR and SADEN are "0". This produces an given address of all "don't cares" as well as a broadcast address of all "don't cares." This effectively disables Automatic Addressing mode and allows the micro controller to function as a standard 8051, which does not make use of this feature.



## Serial Peripheral Interface

#### **SPI Features**

- Master or slave operation
- 10 MHz bit frequency (max)
- LSB first or MSB first data transfer
- Four programmable bit rates
- End of transmission (SPIF)
- Write collision flag protection (WCOL)
- Wake up from idle mode (slave mode only)

#### **SPI Description**

The serial peripheral interface (SPI) allows high-speed synchronous data transfer between the SST89E/V5xC and peripheral devices or between several SST89E/V5xC devices.

Figure 13 shows the correspondence between master and slave SPI devices. The SCK pin is the clock output and input for the master and slave modes, respectively. The SPI clock generator will start following a write to the master devices SPI data register. The written data is then shifted out of the MOSI pin on the master device into the MOSI pin of the slave device. Following a complete transmission of one byte of data, the SPI clock generator is stopped and the SPIF flag is set. An SPI interrupt request will be generated if the SPI Interrupt Enable bit (SPIE) and the Serial Port Interrupt Enable bit (ES) are both set.

An external master drives the Slave Select input pin, SS#/P1[4], low to select the SPI module as a slave. If SS#/P1[4] has not been driven low, then the slave SPI unit is not active and the MOSI/P1[5] port can also be used as an input port pin.

CPHA and CPOL control the phase and polarity of the SPI clock. Figures 14 and 15 show the four possible combinations of these two bits.



#### Figure 13:SPI Master-slave Interconnection



Advance Information

## **SPI Transfer Formats**



Figure 14:SPI Transfer Format with CPHA = 0



Figure 15:SPI Transfer Format with CPHA = 1



## I<sup>2</sup>C Serial Communication (SIO1)

#### Introduction

The I<sup>2</sup>C bus uses two wires (SDA and SCL) to transfer information between devices connected to the bus. The main features of the bus are:

- Multi master bus (no central master)
- Arbitration between simultaneously transmitting masters without corruption of serial data on the bus
- Bi-directional data transfer between masters and slaves
- Serial clock synchronization allows devices with different bit rates to communicate via one serial bus
- Serial clock synchronization can be used as a handshake mechanism to suspend and resume serial transfer
- The I<sup>2</sup>C bus may be used for test and diagnostic purposes

A typical  $I^2C$  bus configuration is shown in Figure 6.7 and Figure 6.8 shows how data transfer is accomplished on the bus.



Figure 16: Typical I<sup>2</sup>C Bus Configuration



Figure 17: Data Transfer on the I<sup>2</sup>C Bus



## Modes of Operation

The on-chip I<sup>2</sup>C logic provides a serial interface that meets the I<sup>2</sup>C bus specs and supports all transfer modes, except low speed mode, from and to the I<sup>2</sup>C bus. The SIO1 logic may operate in the follow for modes.

#### **Master Transmitter Mode**

The serial data output through P1.7/SDA1 while P1.6/SCL1 supplies the serial clock. The first transmitted byte contains the slave address of the receiving device (7 bits) and the data direction bit. In this mode, the data direction bit (R/W) will be logic 0, and we say that a 'W' is transmitted. Thus, the first byte transmitted is SLA+W. Send data is transmitted 8 bits at a time. After each byte is transmitted, an acknowledge bit is received. START and STOP conditions are output to indicate the beginning and the end of a serial transfer.

#### **Master Receiver Mode**

The first transmitted byte contains the slave address of the transmitting device (7 bits) and the data direction bit. In this mode, the data direction bit (R/W) will be logic 1, and we say that an "R" is transmitted. Thus, the first byte transmitted is SLA+R. Serial data is received via P1.7/SDA1 while P1.6/SCL1 outputs the serial clock. Serial data is received 8 bits at a time. After each byte is received, an acknowledge bit is transmitted. START and STOP conditions are output to indicate the beginning and end of a serial transfer.

#### **Slave Receiver Mode**

Serial data and the serial clock are received through P1.7/SDA1 and P1.6/SCL1. After each byte is received, and acknowledge bit is transmitted. START and STOP conditions are recognized as the beginning and end of a serial transfer. Address recognition is performed by hardware after reception of the slave address and direction bit.

#### **Slave Transmitter Mode**

The first byte is received and handled as in the Slave Receiver mode. However, in this mode, the direction bit will indicate that the transfer direction is reversed. Serial data is transmitted via P1.7/SDA1 while the serial clock is input through P1.6/SCL1. START and STOP conditions are recognized as the beginning and end of a serial transfer.

In a given application, SIO1 may operate as a master and as a slave. In the Slave mode, the SIO1 hardware looks for its own slave address and the general call address. If one of these addresses is detected, an interrupt is requested. When the microcontroller wishes to become the bus master, the hardware waits until the bus is free before the Master mode is entered so that a possible slave action is not interrupted. If bus arbitration is lost in the Master mode, SIO1 switches to the Slave mode immediately and can detect its own slave address in the same serial transfer.

## SIO1 Implementation and Operation

Figure 6.9 shows how the on-chip I<sup>2</sup>C bus interface is implemented. Details can be seen in Appendix A.



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

This device will include two I<sup>2</sup>C interfaces. Both interfaces will be identical except for the SFR addresses and I/O pins associated with each interface.

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

The primary I<sup>2</sup>C interface will use the S1 register sets (S1CON). These register addresses are identical to that used in Philips byte-wide two wire devices including the P89C66x series. The primary I<sup>2</sup>C interface will use open drain port pins P1.6 and P1.7 for SCL1 and SDA1, respectively.

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

The secondary I<sup>2</sup>C interface will use the S2 register sets (S2CON). The secondary I<sup>2</sup>C interface will use standard quasi bi-directional port pins P4.0 and P4.1 for SCL2 and SDA2, respectively. The secondary I<sup>2</sup>C interface will have its enable bit, ES2, located in IEN1.1. Its priority will be controlled by bits PS2 and PS2H in locations IP1.0 and IP1H.0, respectively.



Advance Information



Figure 18:I<sup>2</sup>C Bus Serial Interface Block Diagram



## Watchdog timer

## Hardware Watchdog Timer

The WDT is intended as a recovery method in situations when the CPU encounters software errors. The WDT consists of a 14-bit counter and the write-only WatchDog Timer reset (WDTRST) SFR.

After hardware reset, the WDT is disabled. To enable it, commands must be written to the WDTRST SFR. When the WDT is enabled, it will increment every machine cycle while the oscillator is running. There is no way to disable the WDT except though hardware reset.

## Using the WDT

The WDT is enabled or serviced by writing 01EH and 0E1H, in sequence, to the WDTRST (SFR location 0A6H). Once enabled, the WDT counter will increment every machine cycle while the oscillator is running. The 14-bit counter value cannot be read or written. The counter overflows when it reaches 16383 (3FFFH) and then it drives an output reset HIGH pulse at the RST pin. The RESET pulse duration is 98 x T<sub>OSC</sub> (6 clock mode; 196 in 12 clock mode), where T<sub>OSC</sub> =  $1/f_{OSC}$ .

To make the best use of the WDT, it should be serviced in those sections of code that will be periodically executed within the time required to prevent a WDT overflow.

Note: The WDT counter will be on hold while IAP commands are executed.



## Programmable Counter Array

The Programmable Counter Array (PCA) is a special 16-bit timer that has five 16-bit capture/compare modules. Each of the modules can be programmed to operate in one of four modes: rising and/or falling edge capture, software timer, high-speed output, or pulse width modulator. The 5th module can be programmed as a Watchdog timer in addition to the other four modes. Each module has a pin associated with it in port 1. Module 0 is connected to P1.3 (CEX0), module 1 to P1[4] (CEX1), module 2 to P1[5] (CEX2), module 3 to P3[4] (CEX3), and module 4 to P3[5] (CEX4). PCA configuration is shown in Figure 19.

## **PCA** Overview

PCA provides more timing capabilities with less CPU intervention than the standard timer/counter. Its advantages include reduced software overhead and improved accuracy.

The PCA consists of a dedicated timer/counter which serves as the time base for an array of five compare/capture modules. Figure 19 shows a block diagram of the PCA. External events associated with modules are shared with corresponding Port 1 pins. Modules not using the port pins can still be used for standard I/O.

Each of the five modules can be programmed in any of the following modes:

- Rising and/or falling edge capture
- Software timer
- High speed output
- Watchdog timer (Module 4 only)
- Pulse Width Modulator (PWM)

## PCA Timer/Counter

The PCA timer is a free-running 16-bit timer consisting of registers CH and CL (the high and low bytes of the count values). The PCA timer is common time base for all five modules and can be programmed to run at: 1/6 the oscillator frequency, 1/2 the oscillator frequency, Timer 0 overflow, or the input on the ECI pin (P1.2). The timer/counter source is determined from the CPS1 and CPS0 bits in the CMOD SFR as shown in Table 16. See also "PCA Timer/Counter Mode Register (CMOD)" on page 25.

| CPS1 | CPS0 | 12 Clock Mode                                                     | 6 Clock Mode                                                      |
|------|------|-------------------------------------------------------------------|-------------------------------------------------------------------|
| 0    | 0    | f <sub>OSC</sub> /12                                              | f <sub>OSC</sub> /6                                               |
| 0    | 1    | f <sub>OSC</sub> /4                                               | f <sub>OSC</sub> /2                                               |
| 1    | 0    | Timer 0 overflow                                                  | Timer 0 overflow                                                  |
| 1    | 1    | External clock at ECI pin<br>(maximum rate = f <sub>OSC</sub> /8) | External clock at ECI pin<br>(maximum rate = f <sub>OSC</sub> /4) |

#### Table 16: PCA Timer/Counter Source

T16.0 25096



#### Advance Information



The table below summarizes various clock inputs at two common frequencies.

|                                        | Clock Increments |                  |  |
|----------------------------------------|------------------|------------------|--|
| PCA Timer/Counter Mode                 | 12 MHz           | 16 MHz           |  |
| Mode 0: f <sub>OSC</sub> /12           | 1 µsec           | 0.75 µsec        |  |
| Mode 1:                                | 330 nsec         | 250 nsec         |  |
| Mode 2: Timer 0 Overflows <sup>1</sup> |                  |                  |  |
| Timer 0 programmed in:                 |                  |                  |  |
| 8-bit mode                             | 256 µsec         | 192 µsec         |  |
| 16-bit mode                            | 65 msec          | 49 µsec          |  |
| 8-bit auto-reload                      | 1 to 255 µsec    | 0.75 to 191 µsec |  |
| Mode 3: External Input MAX             | 0.66 µsec        | 0.50 µsec        |  |
|                                        | •                | T17.             |  |

1. In Mode 2, the overflow interrupt for Timer 0 does not need to be enabled.

the overflow interrupt enabled are shown below

CMOD's four possible timer modes with and without the overflow interrupt enabled are shown below. This list assumes that PCA will be left running during idle mode.

#### Table 18:CMOD Values

|                                      | CMOD Value                |                        |  |
|--------------------------------------|---------------------------|------------------------|--|
| PCA Count Pulse Selected             | Without Interrupt Enabled | With Interrupt Enabled |  |
| Internal clock, f <sub>OSC</sub> /12 | 00H                       | 01H                    |  |
| Internal clock, f <sub>OSC</sub> /4  | 02H                       | 03H                    |  |
| Timer 0 overflow                     | 04H                       | 05H                    |  |
| External clock at P1.2               | 06H                       | 07H                    |  |

T18.0 25096



The CCON register is associated with all PCA timer functions. It contains run control bits and flags for the PCA timer (CF) and all modules. To run the PCA the CR bit (CCON.6) must be set by software. Clearing the bit, will turn off PCA. When the PCA counter overflows, the CF (CCON.7) will be set, and an interrupt will be generated if the ECF bit in the CMOD register is set. The CF bit can only be cleared by software. Each module has its own timer interrupt or capture interrupt flag (CCF0 for module 0, CCF4 for module 4, etc.). They are set when either a match or capture occurs. These flags can only be cleared by software. See "PCA Timer/Counter Control Register (CCON)" on page 24.

## **Compare/Capture Modules**

Each PCA module has an associated SFR with it. These registers are: CCAPM0 for module 0, CCAPM1 for module 1, etc. Refer to "PCA Compare/Capture Module Mode Register (CCAPMn)" on page 26 for details. The registers each contain 7 bits which are used to control the mode each module will operate in. The ECCF bit (CCAPMn.0 where n = 0, 1, 2, 3, or 4 depending on module) will enable the CCF flag in the CCON SFR to generate an interrupt when a match or compare occurs. PWM (CCAPMn.1) enables the pulse width modulation mode. The TOG bit (CCAPMn.2) when set, causes the CEX output associated with the module to toggle when there is a match between the PCA counter and the module's capture/compare register. When there is a match between the PCA counter and the module's capture/compare register, the MATn (CCAPMn.3) and the CCFn bit in the CCON register to be set.

Bits CAPN (CCAPMn.4) and CAPP (CCAPMn.5) determine whether the capture input will be active on a positive edge or negative edge. The CAPN bit enables the negative edge that a capture input will be active on, and the CAPP bit enables the positive edge. When both bits are set, both edges will be enabled and a capture will occur for either transition. The last bit in the register ECOM (CCAPMn.6) when set, enables the comparator function. Table 20 shows the CCAPMn settings for the various PCA functions.

There are two additional register associated with each of the PCA modules: CCAPnH and CCAPnL. They are registers that hold the 16-bit count value when a capture occurs or a compare occurs. When a module is used in PWM mode, these registers are used to control the duty cycle of the output. See Figure 19.



#### Table 19: PCA High and Low Register Compare/Capture Modules

|            |                              |                   | Bit Address, Symbol, or Alternative Port Function |                |
|------------|------------------------------|-------------------|---------------------------------------------------|----------------|
| Symbol     | Description                  | Direct<br>Address | MS<br>B LSB                                       | RESET<br>Value |
| CCAP0<br>H | PCA Module 0<br>Compare/Cap- | FAH               | CCAP0H[7:0]                                       | 00H            |
| CCAP0<br>L | ture<br>Registers            | EAH               | CCAP0L[7:0]                                       | 00H            |
| CCAP1<br>H | PCA Module 1<br>Compare/Cap- | FBH               | CCAP1H[7:0]                                       | 00H            |
| CCAP1<br>L | ture<br>Registers            | EBH               | CCAP1L[7:0]                                       | 00H            |
| CCAP2<br>H | PCA Module 2<br>Compare/Cap- | FCH               | CCAP2H[7:0]                                       | 00H            |
| CCAP2<br>L | ture<br>Registers            | ECH               | CCAP2L[7:0]                                       | 00H            |
| CCAP3<br>H | PCA Module 3<br>Compare/Cap- | FDH               | CCAP3H[7:0]                                       | 00H            |
| CCAP3<br>L | ture<br>Registers            | EDH               | CCAP3L[7:0]                                       | 00H            |
| CCAP4<br>H | PCA Module 4<br>Compare/Cap- | FEH               | CCAP4H[7:0]                                       | 00H            |
| CCAP4<br>L | ture<br>Registers            | EEH               | CCAP4L[7:0]                                       | 00H            |

T19.0 25096

#### Table 20: PCA Module Modes

| Wi | Without Interrupt enabled |                    |                    |                   |                     |                   |                    |                                                                     |
|----|---------------------------|--------------------|--------------------|-------------------|---------------------|-------------------|--------------------|---------------------------------------------------------------------|
| _1 | ECOMy <sup>2</sup>        | CAPPy <sup>2</sup> | CAPNy <sup>2</sup> | MATy <sup>2</sup> | TOGy <sup>2</sup>   | PWMy <sup>2</sup> | ECCFy <sup>2</sup> | Module Code                                                         |
| -  | 0                         | 0                  | 0                  | 0                 | 0                   | 0                 | 0                  | No Operation                                                        |
| -  | 0                         | 1                  | 0                  | 0                 | 0                   | 0                 | 0                  | 16-bit capture on positive-edge trig-<br>ger at CEX[4:0]            |
| -  | 0                         | 0                  | 1                  | 0                 | 0                   | 0                 | 0                  | 16-bit capture on negative-edge trig-<br>ger at CEX[4:0]            |
| -  | 0                         | 1                  | 1                  | 0                 | 0                   | 0                 | 0                  | 16-bit capture on positive/negative-<br>edge<br>trigger at CEX[4:0] |
| -  | 1                         | 0                  | 0                  | 1                 | 0                   | 0                 | 0                  | Compare: software timer                                             |
| -  | 1                         | 0                  | 0                  | 1                 | 1                   | 0                 | 0                  | Compare: high-speed output                                          |
| -  | 1                         | 0                  | 0                  | 0                 | 0                   | 1                 | 0                  | Compare: 8-bit PWM                                                  |
| -  | 1                         | 0                  | 0                  | 1                 | 0 or 1 <sup>3</sup> | 0                 | 0                  | Compare: PCA WDT (CCAPM4 only) <sup>4</sup>                         |
|    |                           |                    |                    |                   |                     |                   |                    | T20.0 2509                                                          |

1. User should not write '1's to reserved bits. The value read from a reserved bit is indeterminate.

2. y = 0, 1, 2, 3, 4

3. A 0 disables toggle function. A 1 enables toggle function on CEX[4:0] pin.

4. For PCA WDT mode, also set the WDTE bit in the CMOD register to enable the reset output signal.



Advance Information

## Table 21:PCA Module Modes

| Wi | th Interrup        | t enabled          |                    |                   |                     |                   |                    |                                                                     |
|----|--------------------|--------------------|--------------------|-------------------|---------------------|-------------------|--------------------|---------------------------------------------------------------------|
| _1 | ECOMy <sup>2</sup> | CAPPy <sup>2</sup> | CAPNy <sup>2</sup> | MATy <sup>2</sup> | TOGy <sup>2</sup>   | PWMy <sup>2</sup> | ECCFy <sup>2</sup> | Module Code                                                         |
| -  | 0                  | 1                  | 0                  | 0                 | 0                   | 0                 | 1                  | 16-bit capture on positive-edge trig-<br>ger at CEX[4:0]            |
| -  | 0                  | 0                  | 1                  | 0                 | 0                   | 0                 | 1                  | 16-bit capture on negative-edge trig-<br>ger at CEX[4:0]            |
| -  | 0                  | 1                  | 1                  | 0                 | 0                   | 0                 | 1                  | 16-bit capture on positive/negative-<br>edge<br>trigger at CEX[4:0] |
| -  | 1                  | 0                  | 0                  | 1                 | 0                   | 0                 | 1                  | Compare: software timer                                             |
| -  | 1                  | 0                  | 0                  | 1                 | 1                   | 0                 | 1                  | Compare: high-speed output                                          |
| -  | 1                  | 0                  | 0                  | 0                 | 0                   | 1                 | X <sup>3</sup>     | Compare: 8-bit PWM                                                  |
| -  | 1                  | 0                  | 0                  | 1                 | 0 or 1 <sup>4</sup> | 0                 | X <sup>5</sup>     | Compare: PCA WDT (CCAPM4 only) <sup>6</sup>                         |
|    |                    |                    |                    | •                 |                     |                   |                    | T21.0 25096                                                         |

1. User should not write '1's to reserved bits. The value read from a reserved bit is indeterminate.

2. y = 0, 1, 2, 3, 4

3. No PCA interrupt is needed to generate the PWM.

4. A 0 disables toggle function. A 1 enables toggle function on CEX[4:0] pin.

5. Enabling an interrupt for the Watchdog timer would defeat the purpose of the Watchdog timer.

6. For PCA WDT mode, also set the WDTE bit in the CMOD register to enable the reset output signal.



Advance Information

## **Capture Mode**

Capture mode is used to capture the PCA timer/counter value into a module's capture registers (CCAPnH and CCAPnL). The capture will occur on a positive edge, negative edge, or both on the corresponding module's pin. To use one of the PCA modules in the capture mode, either one or both the CCAPM bits CAPN and CAPP for that module must be set. When a valid transition occurs on the CEX pin corresponding to the module used, the PCA hardware loads the 16-bit value of the PCA counter register (CH and CL) into the module's capture registers (CCAPnL and CCAPnH). If the CCFn bit for the module in the CCON SFR and the ECCFn bit in the CCAPMn SFR are set, then an interrupt will be generated. In the interrupt service routine, the 16-bit capture value must be saved in RAM before the next event capture occurs. If a subsequent capture occurred, the original capture values would be lost. After flag event flag has been set by hardware, the user must clear the flag in software. See Figure 20.



Figure 20: PCA Capture Mode



## 16-Bit Software Timer Mode

The 16-bit software timer mode is used to trigger interrupt routines, which must occur at periodic intervals. It is setup by setting both the ECOM and MAT bits in the module's CCAPMn register. The PCA timer will be compared to the module's capture registers (CCAPnL and CCAPnH) and when a match occurs, an interrupt will occur, if the CCFn (CCON SFR) and the ECCFn (CCAPMn SFR) bits for the module are both set.

If necessary, a new 16-bit compare value can be loaded into CCAPnH and CCAPnL during the interrupt routine. The user should be aware that the hardware temporarily disables the comparator function while these registers are being updated so that an invalid match will not occur. Thus, it is recommended that the user write to the low byte first (CCAPnL) to disable the comparator, then write to the high byte (CCAPnH) to re-enable it. If any updates to the registers are done, the user may want to hold off any interrupts from occurring by clearing the EA# bit. See Figure 21.



Figure 21: PCA Compare Mode (Software Timer)



## High Speed Output Mode

The high speed output mode is used to toggle a port pin when a match occurs between the PCA timer and the preloaded value in the compare registers. In this mode, the CEX output pin (on port 1) associated with the PCA module will toggle every time there is a match between the PCA counter (CH and CL) and the capture registers (CCAPnH and CCAPnL). To activate this mode, the user must set TOG, MAT, and ECOM bits in the module's CCAPMn SFR.

High speed output mode is much more accurate than toggling pins since the toggle occurs before branching to an interrupt. In this case, interrupt latency will not affect the accuracy of the output. When using high speed output, using an interrupt is optional. Only if the user wishes to change the time for the next toggle is it necessary to update the compare registers. Otherwise, the next toggle will occur when the PCA timer rolls over and matches the last compare value. See Figure 22.



Figure 22: PCA High Speed Output Mode



## Pulse Width Modulator

The Pulse Width Modulator (PWM) mode is used to generate 8-bit PWMs by comparing the low byte of the PCA timer (CL) with the low byte of the compare register (CCAPnL). When CL < CCAPnL the output is low. When  $CL \ge CCAPnL$  the output is high. To activate this mode, the user must set the PWM and ECOM bits in the module's CCAPMn SFR. See Figure 23 and Table 22.

In PWM mode, the frequency of the output depends on the source for the PCA timer. Since there is only one set of CH and CL registers, all modules share the PCA timer and frequency. Duty cycle of the output is controlled by the value loaded into the high byte (CCAPnH). Since writes to the CCAPnH register are asynchronous, a new value written to the high byte will not be shifted into CCAPnL for comparison until the next period of the output (when CL rolls over from 255 to 00).

To calculate values for CCAPnH for any duty cycle, use the following equation:

CCAPnH = 256(1 - Duty Cycle)

where CCAPnH is an 8-bit integer and Duty Cycle is a fraction.



Figure 23: PCA Pulse Width Modulator Mode

#### Table 22: Pulse Width Modulator Frequencies

|                           | PWM Frequency      |                    |  |  |
|---------------------------|--------------------|--------------------|--|--|
| PCA Timer Mode            | 12 MHz             | 16 MHz             |  |  |
| 1/12 Oscillator Frequency | 3.9 KHz            | 5.2 KHz            |  |  |
| 1/4 Oscillator Frequency  | 11.8 KHz           | 15.6 KHz           |  |  |
| Timer 0 Overflow:         |                    |                    |  |  |
| 8-bit                     | 15.5 Hz            | 20.3 Hz            |  |  |
| 16-bit                    | 0.06 Hz            | 0.08 Hz            |  |  |
| 8-bit Auto-Reload         | 3.9 KHz to 15.3 Hz | 5.2 KHz to 20.3 Hz |  |  |
| External Input (Max)      | 5.9 KHz            | 7.8 KHz            |  |  |

T22.0 25096



## Watchdog Timer

The Watchdog Timer mode is used to improve reliability in the system without increasing chip count (See Figure 24). Watchdog timers are useful for systems that are susceptible to noise, power glitches, or electrostatic discharge. It can also be used to prevent a software deadlock. If during the execution of the user's code, there is a deadlock, the Watchdog timer will time out and an internal reset will occur. Only module 4 can be programmed as a Watchdog timer (but still can be programmed to other modes if the Watchdog timer is not used).

To use the Watchdog timer, the user pre-loads a 16-bit value in the compare register. Just like the other compare modes, this 16-bit value is compared to the PCA timer value. If a match is allowed to occur, an internal reset will be generated. This will not cause the RST pin to be driven high.

In order to hold off the reset, the user has three options:

- 1. periodically change the compare value so it will never match the PCA timer,
- 2. periodically change the PCA timer value so it will never match the compare values, or
- 3. disable the Watchdog timer by clearing the WDTE bit before a match occurs and then reenable it.

The first two options are more reliable because the Watchdog timer is never disabled as in option #3. If the program counter ever goes astray, a match will eventually occur and cause an internal reset. The second option is also not recommended if other PCA modules are being used. Remember, the PCA timer is the time base for all modules; changing the time base for other modules would not be a good idea. Thus, in most application the first solution is the best option.

Use the code below to initialize the Watchdog timer. Module 4 can be configured in either compare mode, and the WDTE bit in CMOD must also be set. The user's software then must periodically change (CCAP4H, CCAP4L) to keep a match from occurring with the PCA timer (CH, CL). This code is given in the Watchdog routine below.

| ;======================================                                                                             |
|---------------------------------------------------------------------------------------------------------------------|
| Init_Watchdog:                                                                                                      |
| MOVCCAPM4, #4CH; Module 4 in compare mode                                                                           |
| MOVCCAP4L, #0FFH; Write to low byte first                                                                           |
| MOVCCAP4H, #0FFH; Before PCA timer counts up<br>; to FFFF Hex, these compare<br>; values must be changed.           |
| ORLCMOD, #40H; Set the WDTE bit to enable the<br>; watchdog timer without<br>; changing the other bits in<br>; CMOD |
| ;=====================================                                                                              |
| WATCHDOG:                                                                                                           |
|                                                                                                                     |
| CLR EA; Hold off interrupts                                                                                         |
| CLR EA; Hold off interrupts<br>MOVCCAP4L, #00; Next compare value is within                                         |
| , ,                                                                                                                 |
| MOVCCAP4L, #00; Next compare value is within MOVCCAP4H, CH; 65,535 counts of the                                    |
| MOVCCAP4L, #00; Next compare value is within<br>MOVCCAP4H, CH; 65,535 counts of the<br>; current PCA                |



#### Advance Information

This routine should not be part of an interrupt service routine. If the program counter goes astray and gets stuck in an infinite loop, interrupts will still be serviced and the watchdog will keep getting reset. Thus, the purpose of the watchdog would be defeated. Instead, call this subroutine from the main program of the PCA timer.



Figure 24: PCA Watchdog Timer (Module 4 only)



# Security Lock

## **Chip-Level Security Lock**

The SSTE/V895xC use three flash bits for security setting and each bit actually acts independently.

| Security Bit | Protection Scheme                                                                                                                                                            |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LB1          | All the External Host mode commands are<br>disabled except Read-ID, Byte-Verify,<br>Partition0-Erase, Chip-Erase, Partition Selection, and security bit programming commands |
| LB2          | Verify memory is disabled in External Host mode                                                                                                                              |
| LB3          | External execution is disabled                                                                                                                                               |

T22.1294

### **Default Security**

MOVC command is always disabled if it is executed from External Code Memory and Targeting Internal Code Memory without any LB programmed. If one byte of the MOVC instruction resides in external memory, this command will also be disabled. The READ BACK value is 00H if this command is blocked.

## Security Bit 1 (LB1)

If the NVR bit LB1 has been programmed, only Read-ID, Verify, Partition Selection, Partition0-Erase, Chip-Erase and security bit programming commands are allowed in the External Host mode (parallel programming mode). For the IAP/ISP mode, the hardware only needs to provide the LB bits status and let the firmware control it.

## Security Bit 2 (LB2)

If the NVR bit LB2 has been programmed, the flash code memory verify command will be disabled in the External Host mode (parallel programming mode). Any attempt to read the user code in the External Host mode will return a value of 55H. For the IAP/ISP mode, the hardware will only need to provide the LB bits status and let the firmware control it. Once this bit is set, the E-Hook will be disabled.

## Security Bit 3 (LB3)

If the NVR bit LB3 has been programmed, the MCU will ignore the EA# pin and fetch the code from internal flash memory. All code fetched from external code memory (SST89E54C/58C/516C) will become 00H (NOP command).

## EA# Pin Security

The EA# pin value is latched at the falling edge of the external reset. See Figure 25.



Figure 25:Latching the EA# Pin



Advance Information

## **Reset Mode**

## Reset

A system reset initializes the MCU and begins program execution at program memory location 0000H or the boot vector address. The reset input for the device is the RST pin. In order to reset the device (See Figure 26), a logic level high must be applied to the RST pin for at least two machine cycles (24 clocks), after the oscillator becomes stable. ALE and PSEN# are weakly pulled high during reset. During reset, ALE and PSEN# output a high level in order to perform a proper reset. This level must not be affected by external element. A system reset will not affect the on-chip RAM while the device is running, however, the contents of the on-chip RAM during power up are indeterminate. Following reset, all Special Function Registers (SFR) return to their reset values outlined in Tables 4 to 9.



Figure 26: Power-on Reset Circuit



## Boot Sequence

#### **Normal Mode**

After Power-on, the hardware checks the Status byte. (See Figure 27) If the Status byte is programmed, the value of the boot vector is used as the high byte of the program counter (PC) starting address, the lower byte of PC will be 00H. if the Status Byte is un-programmed, the PC will start from address 0. The boot vector factory default setting is FCH and the status byte factory default setting is programmed.

#### Hardware Enter Mode

The user can hold PSEN# low, ALE and EA# high at the falling edge of reset. This is the same effect as having a programmed NVR Status byte.



Figure 27:Boot Sequence Flow Chart



## **Interrupt Priority and Polling Sequence**

The device supports eight interrupt sources under four-level priority scheme. Table 23 summarizes the polling sequence of the supported interrupts. Note that the SPI serial interface and the UART share the same interrupt vector. See Figure 28.





#### Advance Information

## Table 23: Interrupt Table

| Description               | Interrupt<br>Flag | Vector<br>Address | Interrupt<br>Enable | Interrupt<br>Priority | Service<br>Priority | Wake-Up<br>Power-down |
|---------------------------|-------------------|-------------------|---------------------|-----------------------|---------------------|-----------------------|
| Ext. Int0                 | IE0               | 0003H             | EX0                 | PX0/H                 | 1(highest)          | yes                   |
| I <sup>2</sup> C 1 Vector | S1_1              | 002BH             | ES1                 | PS1/H                 | 2                   | no                    |
| Т0                        | TF0               | 000BH             | ET0                 | PT0/H                 | 3                   | no                    |
| Ext. Int1                 | IE1               | 0013H             | EX1                 | PX1/H                 | 4                   | yes                   |
| T1                        | TF1               | 001BH             | ET1                 | PT1/H                 | 5                   | no                    |
| UART                      | TI/RI             | 0023H             | ES                  | PS/H                  | 6                   | no                    |
| T2                        | TF2, EXF2         | 003BH             | ET2                 | PT2/H                 | 7                   | no                    |
| PCA                       | CF/CCFn           | 0033H             | EC                  | PPC/H                 | 8                   | no                    |
| SPI Interrupt Vec-<br>tor | SPIF              | 004BH             | ES3                 | PS3/H                 | 9                   | no                    |
| I <sup>2</sup> C 2 Vector | S1_2              | 0043H             | ES2                 | PS2/H                 | 10                  | no                    |

T23.0 25096



## **Power-Saving Modes**

The device provides two power saving modes of operation for applications where power consumption is critical. The two modes are idle and power-down, see Table 24.

## **Idle Mode**

Idle mode is entered setting the IDL bit in the PCON register. In idle mode, the program counter (PC) is stopped. The system clock continues to run and all interrupts and peripherals remain active. The on-chip RAM and the special function registers hold their data during this mode.

The device exits idle mode through either a system interrupt or a hardware reset. Exiting idle mode via system interrupt, the start of the interrupt clears the IDL bit and exits idle mode. After exit the Interrupt Service Routine, the interrupted program resumes execution beginning at the instruction immediately following the instruction which invoked the idle mode. A hardware reset starts the device similar to a power-on reset.

## Power-down Mode

The power-down mode is entered by setting the PD bit in the PCON register. In the power-down mode, the clock is stopped and external interrupts are active for level sensitive interrupts only. SRAM contents are retained during power-down, the minimum  $V_{DD}$  level is 4.5V.

The device exits power-down mode through either an enabled external level sensitive interrupt or a hardware reset. The start of the interrupt clears the PD bit and exits power-down. Holding the external interrupt pin low restarts the oscillator, the signal must hold low at least 1024 clock cycles before bringing back high to complete the exit. Upon interrupt signal restored to logic  $V_{IH}$ , the interrupt service routine program execution resumes beginning at the instruction immediately following the instruction which invoked power-down mode. A hardware reset starts the device similar to power-on reset.

To exit properly out of power-down, the reset or external interrupt should not be executed before the  $V_{DD}$  line is restored to its normal operating voltage. Be sure to hold  $V_{DD}$  voltage long enough at its normal operating level for the oscillator to restart and stabilize (normally less than 10 ms).



Advance Information

## Table 24: Power Saving Modes

| Mode           | Initiated by                                               | State of MCU                                                                                                                                                                                                                                      | Exited by                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Idle           | Software<br>(Set IDL bit in<br>PCON)<br>MOV PCON,<br>#01H; | <ul> <li>CLK is running.</li> <li>Interrupts, serial port and timers/counters are active.</li> <li>Program Counter is stopped.</li> <li>ALE and PSEN# signals at a HIGH level during Idle.</li> <li>All registers remain unchanged.</li> </ul>    | Enabled interrupt or hardware reset.<br>Start of interrupt clears IDL bit and exits<br>idle mode, after the ISR RETI instruc-<br>tion, program resumes execution<br>beginning at the instruction following<br>the one that invoked idle mode. A user<br>could consider placing two or three<br>NOP instructions after the instruction<br>that invokes idle mode to eliminate any<br>problems. A hardware reset restarts the<br>device similar to a power-on reset.                                                          |
| Power-<br>down | Software<br>(Set PD bit in<br>PCON)<br>MOV PCON,<br>#02H;  | <ul> <li>CLK is stopped.</li> <li>On-chip SRAM and SFR data is maintained.</li> <li>ALE and PSEN# signals at a LOW level during power - down.</li> <li>External Interrupts are only active for level sensitive interrupts, if enabled.</li> </ul> | Enabled external level sensitive inter-<br>rupt or hardware reset. Start of inter-<br>rupt clears PD bit and exits power-<br>down mode, after the ISR RETI instruc-<br>tion program resumes execution begin-<br>ning at the instruction following the one<br>that invoked power-down mode. A user<br>could consider placing two or three<br>NOP instructions after the instruction<br>that invokes power-down mode to elimi-<br>nate any problems. A hardware reset<br>restarts the device similar to a power-<br>on reset. |

T24.0 25096



## System Clock and Clock Options

## **Clock Input Options and Recommended Capacitor Values for Oscillator**

Shown in Figure 29 are the input and output of an internal inverting amplifier (XTAL1, XTAL2), which can be configured for use as an on-chip oscillator.

When driving the device from an external clock source, XTAL2 should be left disconnected and XTAL1 should be driven.

At start-up, the external oscillator may encounter a higher capacitive load at XTAL1 due to interaction between the amplifier and its feedback capacitance. However, the capacitance will not exceed 15 pF once the external signal meets the  $V_{IL}$  and  $V_{IH}$  specifications.

Crystal manufacturer, supply voltage, and other factors may cause circuit performance to differ from one application to another. C1 and C2 should be adjusted appropriately for each design. Table 25, shows the typical values for C1 and C2 vs. crystal type for various frequencies

#### Table 25: Recommended Values for C1 and C2 by Crystal Type

| Crystal | C1 = C2 |
|---------|---------|
| Quartz  | 20-30pF |
| Ceramic | 40-50pF |

T25.1 25096

More specific information about on-chip oscillator design can be found in the **FlashFlex Oscillator Circuit Design Considerations** application note.

## **Clock Halving Option**

By default, the device runs at 6 clocks per machine cycle (x1 mode). The device has a clock halving option to reduce speed to 12 clocks per machine cycle. Please refer to Table 26 for detail.

Clock double mode can be enabled either via the external host mode or the IAP mode. Please refer to Table 11 for the IAP mode enabling command (When set, the Enable-Clock-Double\_i bit in the SFST register will indicate 6-clock mode.).

The clock double mode is only for doubling the internal system clock and the internal flash memory, i.e. EA#=1. To access the external memory and the peripheral devices, careful consideration must be taken. Also note that the crystal output (XTAL2) will not be doubled.



Advance Information



## Figure 29: Oscillator Characteristics

### Table 26: Clock Halving Features

| Device    | Standard Mode (x1)             |                                           | Clock Half Mode (x2)           |                                           |  |
|-----------|--------------------------------|-------------------------------------------|--------------------------------|-------------------------------------------|--|
|           | Clocks per<br>Machine<br>Cycle | Max. External Clock<br>Frequency<br>(MHz) | Clocks per<br>Machine<br>Cycle | Max. External Clock<br>Frequency<br>(MHz) |  |
| SST89E5xC | 6                              | 20                                        | 12                             | 40                                        |  |

T26.0 25096



## **Electrical Specification**

**Absolute Maximum Stress Ratings** (Applied conditions greater than those listed under "Absolute Maximum Stress Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these conditions or conditions greater than those defined in the operational sections of this data sheet is not implied. Exposure to absolute maximum stress rating conditions may affect device reliability.)

| Ambient Temperature Under Bias                               | 55°C to +125°C                |
|--------------------------------------------------------------|-------------------------------|
| Storage Temperature                                          | 65°C to +150°C                |
| Voltage on EA# Pin to V <sub>SS</sub>                        | 0.5V to +14.0V                |
| D.C. Voltage on Any Pin to Ground Potential                  | 0.5V to V <sub>DD</sub> +0.5V |
| Transient Voltage (<20ns) on Any Other Pin to $V_{SS}$       | 1.0V to V <sub>DD</sub> +1.0V |
| Maximum I <sub>OL</sub> per I/O for All Other Pins           | 15mA                          |
| Package Power Dissipation Capability (T <sub>A</sub> = 25°C) | 1.5W                          |
| Through Hole Lead Soldering Temperature (10 Seconds)         | 300°C                         |
| Surface Mount Solder Reflow Temperature <sup>1</sup>         | 260°C for 10 seconds          |
| Output Short Circuit Current <sup>2</sup>                    | 50 mA                         |

1. Excluding certain with-Pb 32-PLCC units, all packages are 260°C capable in both non-Pb and with-Pb solder versions. Certain with-Pb 32-PLCC package types are capable of 240°C for 10 seconds; please consult the factory for the latest information.

**Note:** This specification contains preliminary information on new products in production. The specifications are subject to change without notice.

| Symbol           | Description                                         | Min. | Max | Unit |
|------------------|-----------------------------------------------------|------|-----|------|
| T <sub>A</sub>   | Ambient Temperature Under Bias                      |      |     |      |
|                  | Standard                                            | 0    | +70 | °C   |
|                  | Industrial                                          | -40  | +85 | °C   |
| V <sub>DD</sub>  | Supply Voltage                                      |      |     |      |
|                  | SST89E5xC                                           | 4.5  | 5.5 | V    |
| f <sub>OSC</sub> | Oscillator Frequency                                |      |     |      |
|                  | SST89E5xC                                           | 0    | 40  | MHz  |
|                  | Oscillator Frequency for In-Application programming |      |     |      |
|                  | SST89E5xC                                           | .25  | 40  | MHz  |

## Table 27: Operating Range

T27.1 25096

#### Table 28: Reliability Characteristics

| Symbol                        | Parameter      | Minimum Specification | Units  | Test Method         |
|-------------------------------|----------------|-----------------------|--------|---------------------|
| N <sub>END</sub> <sup>1</sup> | Endurance      | 10,000                | Cycles | JEDEC Standard A117 |
| T <sub>DR</sub> <sup>1</sup>  | Data Retention | 100                   | Years  | JEDEC Standard A103 |
| ILTH <sup>1</sup>             | Latch Up       | 100 + I <sub>DD</sub> | mA     | JEDEC Standard 78   |
|                               |                |                       |        | T28.0 25096         |

1. This parameter is measured only for initial qualification and after a design or process change that could affect this parameter.

<sup>2.</sup> Outputs shorted for no more than one second. No more than one output shorted at a time. (Based on package heat transfer limitations, not device power consumption.



#### Table 29: AC Conditions of Test<sup>1</sup>

| Input Rise/Fall Time | Output Load             |
|----------------------|-------------------------|
| 10 ns                | C <sub>L</sub> = 100 pF |

1. See Figures 36 and 38

T29.1 25096

#### Table 30: Recommended System Power-up Timings

| Symbol                             | Parameter                   | Minimum | Units |
|------------------------------------|-----------------------------|---------|-------|
| T <sub>PU-READ</sub> <sup>1</sup>  | Power-up to Read Operation  | 100     | μs    |
| T <sub>PU-WRITE</sub> <sup>1</sup> | Power-up to Write Operation | 100     | μs    |

T30.2 25096 1. This parameter is measured only for initial qualification and after a design or process change that could affect this parameter

#### Table 31: Pin Impedance (VDD=3.3V, TA=25 °C, f=1 Mhz, other pins open)

| Parameter                     | Description         | Test Condition | Maximum     |
|-------------------------------|---------------------|----------------|-------------|
| C <sub>I/O</sub> <sup>1</sup> | I/O Pin Capacitance | $V_{I/O} = 0V$ | 15 pF       |
| C <sub>IN</sub> <sup>1</sup>  | Input Capacitance   | $V_{IN} = 0V$  | 12 pF       |
| L <sub>PIN</sub> <sup>2</sup> | Pin Inductance      |                | 20 nH       |
|                               |                     |                | T31.4 25096 |

1. This parameter is measured only for initial qualification and after a design or process change that could affect this parameter.

2. Refer to PCI spec.



## **DC Electrical Characteristics**

| Table 3 | 2:DC Characteristics f<br>0V | or SST89E5xC: | $T_A = -40^{\circ}C \text{ to } +85$ | °C; V <sub>DD</sub> = 4 | 4.5-5.5V; V | / <sub>SS</sub> = |
|---------|------------------------------|---------------|--------------------------------------|-------------------------|-------------|-------------------|
|         |                              |               |                                      |                         | 1           |                   |

| Symbo<br>I       | Parameter                                                      | Test Conditions                                   | Min                      | Мах                      | Unit<br>s |
|------------------|----------------------------------------------------------------|---------------------------------------------------|--------------------------|--------------------------|-----------|
| V <sub>IL</sub>  | Input Low Voltage                                              | 4.5 < V <sub>DD</sub> < 5.5                       | -0.5                     | 0.2V <sub>DD</sub> - 0.1 | v         |
| VIH              | Input High Voltage                                             | $4.5 < V_{DD} < 5.5$                              | 0.2V <sub>DD</sub> + 0.9 | V <sub>DD</sub> + 0.5    | V         |
| V <sub>IH1</sub> | Input High Voltage (XTAL1, RST)                                | 4.5 < V <sub>DD</sub> < 5.5                       | 0.7V <sub>DD</sub>       | V <sub>DD</sub> + 0.5    | V         |
| V <sub>OL</sub>  | Output Low Voltage (Ports 1, 2, 3) <sup>1</sup>                | $V_{DD} = 4.5V$                                   |                          |                          |           |
| 01               |                                                                | $I_{OL} = 100 \mu A^2$                            |                          | 0.3                      | V         |
|                  |                                                                | $I_{OL} = 1.6 mA^2$                               |                          | 0.45                     | V         |
|                  |                                                                | $I_{OL} = 3.5 mA^2$                               |                          | 1.0                      | V         |
| V <sub>OL1</sub> | Output Low Voltage (Port 0, ALE, PSEN#) <sup>1,3</sup>         | V <sub>DD</sub> = 4.5V                            |                          |                          |           |
|                  |                                                                | $I_{OL} = 200 \mu A^2$                            |                          | 0.3                      | V         |
|                  |                                                                | $I_{OL} = 3.2 m A^2$                              |                          | 0.45                     | V         |
| V <sub>OH</sub>  | Output High Voltage (Ports 1, 2, 3, ALE,                       | $V_{DD} = 4.5V$                                   |                          |                          |           |
|                  | PSEN#) <sup>4</sup>                                            | I <sub>OH</sub> = -10μA                           | V <sub>DD</sub> - 0.3    |                          | V         |
|                  |                                                                | Ι <sub>ΟΗ</sub> = -30μΑ                           | V <sub>DD</sub> - 0.7    |                          | V         |
|                  |                                                                | I <sub>OH</sub> = -60µА                           | V <sub>DD</sub> - 1.5    |                          | V         |
| V <sub>OH1</sub> | Output High Voltage (Port 0 in External Bus                    | $V_{DD} = 4.5V$                                   |                          |                          |           |
|                  | Mode) <sup>4</sup>                                             | I <sub>OH</sub> = -200μA                          | V <sub>DD</sub> - 0.3    |                          | V         |
|                  |                                                                | I <sub>OH</sub> = -3.2mA                          | V <sub>DD</sub> - 0.7    |                          | V         |
| IIL              | Logical 0 Input Current (Ports 1, 2, 3)                        | $V_{IN} = 0.4V$                                   |                          | -75                      | μA        |
| I <sub>TL</sub>  | Logical 1-to-0 Transition Current (Ports 1, 2, 3) <sup>5</sup> | $V_{IN} = 2V$                                     |                          | -650                     | μA        |
| l <sub>Li</sub>  | Input Leakage Current (Port 0)                                 | 0.45 < V <sub>IN</sub> < V <sub>DD</sub> -<br>0.3 |                          | ±10                      | μA        |
| I <sub>L2</sub>  | Input leakage current, P1.6/SCL1, P41.7SDA1                    | 0V < VI < 6V                                      |                          | 10                       | μA        |
|                  |                                                                | $0V < V_{DD} < 5.5v$                              |                          |                          |           |
| R <sub>RST</sub> | RST Pull-down Resistor                                         |                                                   | 40                       | 225                      | KΩ        |
| C <sub>IO</sub>  | Pin Capacitance <sup>6</sup>                                   | @ 1 MHz, 25°C                                     |                          | 15                       | pF        |
| I <sub>DD</sub>  | Power Supply Current                                           |                                                   |                          |                          |           |
|                  | IAP Mode @ 40 MHz                                              |                                                   |                          | 88                       | mA        |
|                  | Active Mode @ 40 MHz                                           |                                                   |                          | 50                       | mA        |
|                  | Idle Mode@ 40 MHz                                              |                                                   |                          | 42                       | mA        |
|                  | Power-down Mode (min. $V_{DD} = 4.5V$ )                        | $T_A = 0^{\circ}C \text{ to } +70^{\circ}C$       |                          | 80                       | μA        |
|                  |                                                                | $T_{A} = -40^{\circ}C \text{ to } +85^{\circ}C$   |                          | 90                       | μA        |

T32.0 25096

1. Under steady state (non-transient) conditions,  $I_{OL}$  must be externally limited as follows: Maximum  $I_{OL}$  per port pin: 15mA Maximum  $I_{OL}$  per 8-bit port:26mA

Maximum IOL total for all outputs:71mA

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



- 2. Capacitive loading on Ports 0 and 2 may cause spurious noise to be superimposed on the V<sub>OL</sub>s of ALE and Ports 1 and 3. The noise due to external bus capacitance discharging into the Port 0 and 2 pins when the pins make 1-to-0 transitions during bus operations. In the worst cases (capacitive loading > 100pF), the noise pulse on the ALE pin may exceed 0.8V. 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.
- 3. Load capacitance for Port 0, ALE and PSEN#= 100pF, load capacitance for all other outputs = 80 pF.
- 4. Capacitive loading on Ports 0 and 2 may cause the V<sub>OH</sub> on ALE and PSEN# to momentarily fall below the V<sub>DD</sub> 0.7 specification when the address bits are stabilizing.
- 5. Pins of Ports 1, 2, and 3 source a transition current when they are being externally driven from 1 to 0. The transition current reaches its maximum value when V<sub>IN</sub> is approximately 2V.
- 6. Pin capacitance is characterized but not tested. EA# is 25pF (max).



Figure 30:I<sub>DD</sub> vs. Frequency (SST89E5xC)



## **AC Electrical Characteristics**

#### **AC Characteristics:**

(Over Operating Conditions: Load Capacitance for Port 0, ALE, and PSEN# = 100pF; Load Capacitance for All Other Outputs = 80pF)

|                      |                                          | Oscillator                                              |     |                              |                              |     |
|----------------------|------------------------------------------|---------------------------------------------------------|-----|------------------------------|------------------------------|-----|
|                      |                                          | 40 MHz (x1<br>Mode)<br>20 MHz (x2<br>Mode) <sup>1</sup> |     | Vari                         | Unit                         |     |
| Symbol               | Parameter                                | Min                                                     | Max | Min                          | Max                          | s   |
| 1/T <sub>CLCL</sub>  | x1 Mode Oscillator Frequency             | 0                                                       | 40  | 0                            | 40                           | MHz |
| 1/2T <sub>CLCL</sub> | x2 Mode Oscillator Frequency             | 0                                                       | 20  | 0                            | 20                           | MHz |
| T <sub>LHLL</sub>    | ALE Pulse Width                          | 35                                                      |     | 2T <sub>CLCL</sub> - 15      |                              | ns  |
| T <sub>AVLL</sub>    | Address Valid to ALE Low                 | 10                                                      |     | T <sub>CLCL</sub> - 15 (5V)  |                              | ns  |
| T <sub>LLAX</sub>    | Address Hold After ALE Low               | 10                                                      |     | T <sub>CLCL</sub> - 15 (5V)  |                              | ns  |
| T <sub>LLIV</sub>    | ALE Low to Valid Instr In                |                                                         | 55  |                              | 4T <sub>CLCL</sub> - 45 (5V) | ns  |
| T <sub>LLPL</sub>    | ALE Low to PSEN# Low                     | 10                                                      |     | T <sub>CLCL</sub> - 15 (5V)  |                              | ns  |
| T <sub>PLPH</sub>    | PSEN# Pulse Width                        | 60                                                      |     | 3T <sub>CLCL</sub> - 15 (5V) |                              | ns  |
| T <sub>PLIV</sub>    | PSEN# Low to Valid Instr In              |                                                         | 25  |                              | 3T <sub>CLCL</sub> - 50 (5V) | ns  |
| T <sub>PXIX</sub>    | Input Instr Hold After PSEN#             |                                                         |     | 0                            |                              | ns  |
| T <sub>PXIZ</sub>    | Input Instr Float After PSEN#            |                                                         | 10  |                              | T <sub>CLCL</sub> - 15 (5V)  | ns  |
| T <sub>PXAV</sub>    | PSEN# to Address valid                   | 17                                                      |     | T <sub>CLCL</sub> - 8        |                              | ns  |
| T <sub>AVIV</sub>    | Address to Valid Instr In                |                                                         | 65  |                              | 5T <sub>CLCL</sub> - 60 (5V) | ns  |
| T <sub>PLAZ</sub>    | PSEN# Low to Address Float               |                                                         | 10  |                              | 10                           | ns  |
| T <sub>RLRH</sub>    | RD# Pulse Width                          | 120                                                     |     | 6T <sub>CLCL</sub> - 30 (5V) |                              | ns  |
| T <sub>WLWH</sub>    | Write Pulse Width (WE#)                  | 120                                                     |     | 6T <sub>CLCL</sub> - 30 (5V) |                              | ns  |
| T <sub>RLDV</sub>    | RD# Low to Valid Data In                 |                                                         | 75  |                              | 5T <sub>CLCL</sub> - 50 (5V) | ns  |
| T <sub>RHDX</sub>    | Data Hold After RD#                      | 0                                                       |     | 0                            |                              | ns  |
| T <sub>RHDZ</sub>    | Data Float After RD#                     |                                                         | 38  |                              | 2T <sub>CLCL</sub> - 12 (5V) | ns  |
| T <sub>LLDV</sub>    | ALE Low to Valid Data In                 |                                                         | 150 |                              | 8T <sub>CLCL</sub> - 50 (5V) | ns  |
| T <sub>AVDV</sub>    | Address to Valid Data In                 |                                                         | 150 |                              | 9T <sub>CLCL</sub> - 75 (5V) | ns  |
| T <sub>LLWL</sub>    | ALE Low to RD# or WR# Low                | 60                                                      | 90  | 3T <sub>CLCL</sub> - 15 (5V) | 3T <sub>CLCL</sub> + 15 (5V) | ns  |
| TAVWL                | Address to RD# or WR# Low                | 70                                                      |     | 4T <sub>CLCL</sub> - 30 (5V) |                              | ns  |
| T <sub>QVWX</sub>    | Data Valid to WR# High to Low Transition |                                                         | 5   | T <sub>CLCL</sub> - 20       |                              | ns  |
| T <sub>WHQX</sub>    | Data Hold After WR#                      | 5                                                       |     | T <sub>CLCL</sub> - 20 (5V)  |                              | ns  |
| T <sub>QVWH</sub>    | Data Valid to WR# High                   | 125                                                     |     | 7T <sub>CLCL</sub> - 50 (5V) |                              | ns  |
| T <sub>RLAZ</sub>    | RD# Low to Address Float                 |                                                         | 0   |                              | 0                            | ns  |
| T <sub>WHLH</sub>    | RD# to WR# High to ALE High              | 10                                                      | 40  | T <sub>CLCL</sub> - 15 (5V)  | T <sub>CLCL</sub> + 15 (5V)  | ns  |

1. Calculated values are for x1 Mode only

©2011 Silicon Storage Technology, Inc.



Q: Output data

R: RD# signal

W: WR# signal

X: No longer a valid logic level

Z: High Impedance (Float)

T: Time

V: Valid

Advance Information

#### **Explanation of Symbols**

Each timing symbol has 5 characters. The first character is always a 'T' (stands for time). The other characters, depending on their positions, stand for the name of a signal or the logical status of that signal. The following is a list of all the characters and what they stand for.

- A: Address
- C: Clock
- D: Input data
- H: Logic level HIGH
- I: Instruction (program memory contents)
- L: Logic level LOW or ALE
- P: PSEN#
- For example:
  - T<sub>AVLL</sub> = Time from Address Valid to ALE Low
  - T<sub>LLPL</sub> = Time from ALE Low to PSEN# Low

#### ©2011 Silicon Storage Technology, Inc.



#### Advance Information



#### Figure 31: External Program Memory Read Cycle



## Figure 32: External Data Memory Read Cycle



Advance Information



Figure 33: External Data Memory Write Cycle

| Table 34:Exte | ernal Clock Drive |
|---------------|-------------------|
|---------------|-------------------|

|                     |                      |      |                | Oscillator            |                       |             |
|---------------------|----------------------|------|----------------|-----------------------|-----------------------|-------------|
|                     |                      | 401  | 40MHz Variable |                       | able                  |             |
| Symbol              | Parameter            | Min  | Max            | Min                   | Max                   | Units       |
| 1/T <sub>CLCL</sub> | Oscillator Frequency |      |                | 0                     | 40                    | MHz         |
| T <sub>CLCL</sub>   |                      | 25   |                |                       |                       | ns          |
| T <sub>CHCX</sub>   | High Time            | 8.75 |                | 0.35T <sub>CLCL</sub> | 0.65T <sub>CLCL</sub> | ns          |
| T <sub>CLCX</sub>   | Low Time             | 8.75 |                | 0.35T <sub>CLCL</sub> | 0.65T <sub>CLCL</sub> | ns          |
| T <sub>CLCH</sub>   | Rise Time            |      | 10             |                       |                       | ns          |
| T <sub>CHCL</sub>   | Fall Time            |      | 10             |                       |                       | ns          |
|                     | •                    | •    |                |                       | •                     | T34.2 25096 |



### Figure 34: External Clock Drive Waveform



Advance Information

### Table 35: Serial Port Timing

|                   |                                          |     | Oscillator |                           |                           |       |
|-------------------|------------------------------------------|-----|------------|---------------------------|---------------------------|-------|
|                   |                                          | 40  | ЛНz        | Variable                  |                           |       |
| Symbol            | Parameter                                | Min | Max        | Min                       | Max                       | Units |
| T <sub>XLXL</sub> | Serial Port Clock Cycle Time             | 0.3 |            | 12T <sub>CLCL</sub>       |                           | μs    |
| T <sub>QVXH</sub> | Output Data Setup to Clock Rising Edge   | 117 |            | 10T <sub>CLCL</sub> - 133 |                           | ns    |
| т                 | Output Data Hold After Clock Pieing Edge |     |            | 2T <sub>CLCL</sub> - 117  |                           | ns    |
| T <sub>XHQX</sub> | Output Data Hold After Clock Rising Edge | 0   |            | 2T <sub>CLCL</sub> - 50   |                           | ns    |
| T <sub>XHDX</sub> | Input Data Hold After Clock Rising Edge  | 0   |            | 0                         |                           | ns    |
| T <sub>XHDV</sub> | Clock Rising Edge to Input Data Valid    |     | 117        |                           | 10T <sub>CLCL</sub> - 133 | ns    |

T35.2 25096



#### Figure 35: Shift Register Mode Timing Waveforms



#### Figure 36: AC Testing Input/Output Test Waveform



Advance Information



#### Figure 37: Float Waveform



#### Figure 38: A Test Load Example



Figure 39:I<sub>DD</sub> Test Condition, Active Mode



Advance Information



## Figure 40:I<sub>DD</sub> Test Condition, Idle Mode



## Figure 41:I<sub>DD</sub> Test Condition, Power-down Mode

#### Table 36:Flash Memory Programming/Verification Parameters<sup>1</sup>

| Parameter <sup>2</sup>              | Мах | Units |
|-------------------------------------|-----|-------|
| Chip-Erase Time                     | 350 | ms    |
| Block-Erase Time                    | 300 | ms    |
| Sector-Erase Time                   | 30  | ms    |
| Byte-Program Time <sup>3</sup>      | 100 | μs    |
| Re-map or Security bit Program Time | 100 | μs    |

T36.0 25096

1. For IAP operations, the program execution overhead must be added to the above timing parameters.

2. Program and Erase times will scale inversely proportional to programming clock frequency.

3. Each byte must be erased before programming.



Advance Information

## **Product ordering information**



1. Environmental suffix "E" denotes non-Pb solder. SST non-Pb solder devices are "RoHS Compliant".

## Valid Combinations

#### Valid combinations for SST89E54C

| SST89E54C-40-C-NJE                | SST89E54C- |
|-----------------------------------|------------|
| SST89E54C-40-I-NJE                | SST89E54C- |
| Valid combinations for SST89E58C  |            |
| SST89E58C-40-C-NJE                | SST89E58C- |
| SST89E58C-40-I-NJE                | SST89E58C- |
| Valid combinations for SST89E516C |            |
|                                   | 0070055400 |

SST89E516C-40-C-NJE SST89E516C-40-I-NJE

-40-C-TQJE -40-I-TQJE

-40-C-TQJE -40-I-TQJE

SST89E516C-40-C-TQJE SST89E516C-40-I-TQJE

Note: Valid combinations are those products in mass production or will be in mass production. Consult your SST sales representative to confirm availability of valid combinations and to determine availability of new combinations.



#### Advance Information

# **Packaging Diagrams**



Figure 42:44-Lead Plastic Lead Chip Carrier (PLCC) SST Package Code: NJ



#### Advance Information



Figure 43:44-Lead Thin Quad Flat Pack (TQFP) SST Package Code: TQJ



## Table 37: Revision History

| Revision |   | Description                                                                                                                               | Date     |
|----------|---|-------------------------------------------------------------------------------------------------------------------------------------------|----------|
| 00       | • | Initial Release of data sheet                                                                                                             | Jan 2006 |
|          | • | Removed 3V version and Pb packages                                                                                                        |          |
|          | • | Changed B798H, B797H, B3B0H, and B3AFH to FC00H, FBFFH, FB00H, and F7FFH in Figure 4, Figure 5, and Figure 6                              | Apr 2007 |
|          | • | Edited SFCF Register page 19                                                                                                              |          |
|          | • | Edited SFCM Register page 19                                                                                                              |          |
|          | • | Changed Clock Doubling Option to "Clock Halving Option" on page 66                                                                        |          |
|          | • | Edited Table 26 on page 67                                                                                                                |          |
|          | • | Removed "Individual Page Security Lock" from Features on page 1                                                                           |          |
|          | • | Edited SFST last row in Table 5 on page 15                                                                                                |          |
|          | • | Removed 12MHz Min/Max from Table 34 on page 75 and Table 35 on page 76                                                                    |          |
|          | • | Changed Block to Partition globally.                                                                                                      |          |
|          | • | Changed FlashFlex51 to FlashFlex globally.                                                                                                |          |
|          | • | In Features under Single Block SuperFlash EEPROM, changed 18 KByte to 16 KByte, 34 KByte to 32 KByte, and 66 KByte to 64 KByte on page 1. |          |
|          | • | In Features, deleted "Three High Current Port 1 Pins" page 1.                                                                             |          |
|          | • | Changed 512 x8 bits to 512/1K/2K x8 bits on page 2.                                                                                       |          |
|          | • | Changes 256 Bytes to 1792/768/256 Bytes in four places on page 10.                                                                        |          |
|          | • | In Table 2, added footnote.                                                                                                               |          |
|          | • | Edited Table 4, CPU related SFRs                                                                                                          |          |
|          | • | Edited Table 5, changed reset value of SFCF and SFST.                                                                                     |          |
|          | • | Edited Table 6, changed reset value of WDTRST.                                                                                            |          |
|          | • | Edited "SuperFlash Configuration Register (SFCF)", changed reset value.                                                                   |          |
|          | • | Edited "SuperFlash Command Register (SFCM)", removed note.                                                                                |          |
|          | • | Edited "SuperFlash Status Register (SFST) (Read Only Register)", changed reset value.                                                     |          |
|          | • | Edited "Interrupt Priority (IP)", changed reset value                                                                                     |          |
|          | • | Edited "Interrupt Priority High (IPH)", changed reset value                                                                               |          |
|          | • | Edited "Interrupt Priority (IPI)", changed reset value                                                                                    |          |
|          | • | Edited "Interrupt Priority High (IPIH)", changed reset value                                                                              |          |
|          | • | Edited "Auxiliary Register 1 (AUXR1)", added ENBOOT symbol and function.                                                                  |          |
|          | • | Edited "PCA Compare/Capture Module Mode Register (CCAPMn)", changed all reset values.                                                     |          |
|          | • | Added Partition Selection Command and changed the External Host mode value from FFH to 55H on page 59.                                    |          |
|          | • | Edited table Table 23                                                                                                                     |          |
|          | • | Removed Maximum I <sub>OL</sub> per I/O Pins P1.5, P1.6, P1.7 on page 68                                                                  |          |
|          | • | Edited Table 32, removed V <sub>OL</sub> .                                                                                                |          |
|          | • | Changed SRAM power-down voltage from 2.0V to 4.5V in "Power-down Mode" on page 64, in Table 32, and in Figure 41.                         |          |
| A        | • | Applied new document format                                                                                                               | Nov 2011 |
|          | • | Release document under letter revision system                                                                                             |          |
|          | • | Updated spec number from S71294 to DS25096                                                                                                |          |



A Microchip Technology Company

SST, Silicon Storage Technology, the SST logo, SuperFlash, MTP, and FlashFlex are registered trademarks of Silicon Storage Technology, Inc. MPF, SQI, Serial Quad I/O, and Z-Scale are trademarks of Silicon Storage Technology, Inc. All other trademarks and registered trademarks mentioned herein are the property of their respective owners.

Specifications are subject to change without notice. Refer to www.microchip.com for the most recent documentation. For the most current package drawings, please see the Packaging Specification located at http://www.microchip.com/packaging.

Memory sizes denote raw storage capacity; actual usable capacity may be less.

SST makes no warranty for the use of its products other than those expressly contained in the Standard Terms and Conditions of Sale.

For sales office locations and information, please see www.microchip.com.

#### Silicon Storage Technology, Inc. A Microchip Technology Company www.microchip.com