## NXP USA Inc. - P87LPC762BN,112 Datasheet





Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

### Details

| Product Status             | Obsolete                                                                |
|----------------------------|-------------------------------------------------------------------------|
| Core Processor             | 8051                                                                    |
| Core Size                  | 8-Bit                                                                   |
| Speed                      | 20MHz                                                                   |
| Connectivity               | I <sup>2</sup> C, UART/USART                                            |
| Peripherals                | Brown-out Detect/Reset, LED, POR, WDT                                   |
| Number of I/O              | 18                                                                      |
| Program Memory Size        | 2KB (2K x 8)                                                            |
| Program Memory Type        | OTP                                                                     |
| EEPROM Size                | -                                                                       |
| RAM Size                   | 128 x 8                                                                 |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 6V                                                               |
| Data Converters            |                                                                         |
| Oscillator Type            | Internal                                                                |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                         |
| Mounting Type              | Through Hole                                                            |
| Package / Case             | 20-DIP (0.300", 7.62mm)                                                 |
| Supplier Device Package    | 20-DIP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/p87lpc762bn-112 |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

#### i. ι. 1 . $( \cap \cap$ ' y

| 2001 Oct 26 |  |
|-------------|--|

| Low power,   | low price, | low pin co | ount (20 pin) |
|--------------|------------|------------|---------------|
| microcontrol | ler with 2 | kbyte OTI  | 2             |

|                                                       | 1        |
|-------------------------------------------------------|----------|
| FEATURES                                              | 1        |
|                                                       | 1        |
| PIN CONFIGURATION, 20-PIN DIP, SO, AND TSSOP PACKAGES | 2        |
|                                                       | 2        |
| BLOCK DIAGRAM                                         | 3        |
| PIN DESCRIPTIONS                                      | 5        |
| SPECIAL FUNCTION REGISTERS                            | 6        |
| FUNCTIONAL DESCRIPTION                                | 9        |
| Enhanced CPU                                          | 9        |
| Analog Functions                                      | 9        |
| Analog Comparators                                    | 9        |
| Comparator Configuration                              | 9        |
| Internal Reference Voltage                            | 11       |
| Comparator Interrupt                                  | 11       |
| Comparators and Power Reduction Modes                 | 11       |
| Comparator Configuration Example                      | 11       |
| I <sup>2</sup> C Serial Interface                     | 12       |
| I <sup>2</sup> C Interrupts                           | 12       |
| Reading I2CON                                         | 12       |
| Checking ATN and DRDY                                 | 13       |
| Writing I2CON                                         | 14       |
| Regarding Transmit Active                             | 14       |
| Regarding Software Response Time                      | 15       |
| Interrupts                                            | 16       |
| External Interrupt Inputs                             | 17       |
| I/O Ports                                             | 18       |
| Quasi-Bidirectional Output Configuration              | 18       |
| Open Drain Output Configuration                       | 19       |
| Push-Pull Output Configuration                        | 19       |
| Keyboard Interrupt (KBI)                              | 20       |
| Oscillator                                            | 22       |
| Low Frequency Oscillator Option                       | 22       |
| Medium Frequency Oscillator Option                    | 22       |
| High Frequency Oscillator Option                      | 22       |
| On-Chip RC Oscillator Option                          | 22       |
| External Clock Input Option                           | 22       |
|                                                       | 22       |
| Clock Output                                          | 24       |
| Power Monitoring Functions                            | 24<br>24 |
| 5                                                     | 24       |
| Brownout Detection                                    | 24<br>25 |
| Power On Detection                                    |          |
| Power Reduction Modes                                 | 25       |
|                                                       | 25       |
| Power Down Mode                                       | 25       |
| Low Voltage EPROM Operation                           | 27       |
| Reset                                                 | 27       |
| Timer/Counters                                        | 28       |
| Mode 0                                                | 29       |
| Mode 1                                                | 30       |
| Mode 2                                                | 30       |
| Mode 3                                                | 30       |
| Timer Overflow Toggle Output                          | 31       |

## **BLOCK DIAGRAM**



87LPC762

# Low power, low price, low pin count (20 pin) microcontroller with 2 kbyte OTP



Figure 1. 87LPC762 Program and Data Memory Map

# Low power, low price, low pin count (20 pin) microcontroller with 2 kbyte OTP

| Name   | Description               | SFR<br>Address | Bit Functions and Addresses<br>MSB |     |       |       |       | LS   | ЗB   | Reset<br>Value |        |
|--------|---------------------------|----------------|------------------------------------|-----|-------|-------|-------|------|------|----------------|--------|
| TL1    | Timer 1 low byte          | 8Bh            |                                    |     |       |       |       |      |      |                | 00h    |
| TMOD   | Timer 0 and 1 mode        | 89h            | GATE                               | C/T | M1    | MO    | GATE  | C/T  | M1   | MO             | 00h    |
|        |                           |                |                                    |     |       |       |       |      |      |                | ]      |
| WDCON# | Watchdog control register | A7h            | -                                  | -   | WDOVF | WDRUN | WDCLK | WDS2 | WDS1 | WDS0           | Note 4 |
| WDRST# | Watchdog reset register   | A6h            |                                    |     |       |       |       |      |      |                | xxh    |

NOTES:

\* SFRs are bit addressable.

# SFRs are modified from or added to the 80C51 SFRs.

1. Unimplemented bits in SFRs are X (unknown) at all times. Ones should not be written to these bits since they may be used for other purposes in future derivatives. The reset value shown in the table for these bits is 0.

2. I/O port values at reset are determined by the PRHI bit in the UCFG1 configuration byte.

3. The PCON reset value is x x BOF POF–0 0 0 0b. The BOF and POF flags are not affected by reset. The POF flag is set by hardware upon power up. The BOF flag is set by the occurrence of a brownout reset/interrupt and upon power up.

4. The WDCON reset value is xx11 0000b for a Watchdog reset, xx01 0000b for all other reset causes if the watchdog is enabled, and xx00 0000b for all other reset causes if the watchdog is disabled.

### FUNCTIONAL DESCRIPTION

Details of 87LPC762 functions will be described in the following sections.

### Enhanced CPU

The 87LPC762 uses an enhanced 80C51 CPU which runs at twice the speed of standard 80C51 devices. This means that the performance of the 87LPC762 running at 5 MHz is exactly the same as that of a standard 80C51 running at 10 MHz. A machine cycle consists of 6 oscillator cycles, and most instructions execute in 6 or 12 clocks. A user configurable option allows restoring standard 80C51 execution timing. In that case, a machine cycle becomes 12 oscillator cycles.

In the following sections, the term "CPU clock" is used to refer to the clock that controls internal instruction execution. This may sometimes be different from the externally applied clock, as in the case where the part is configured for standard 80C51 timing by means of the CLKR configuration bit or in the case where the clock is divided down via the setting of the DIVM register. These features are described in the Oscillator section.

## **Analog Functions**

The 87LPC762 incorporates two Analog Comparators. In order to give the best analog function performance and to minimize power consumption, pins that are actually being used for analog functions must have the digital outputs and the digital inputs disabled.

Digital outputs are disabled by putting the port output into the Input Only (high impedance) mode as described in the I/O Ports section.

Digital inputs on port 0 may be disabled through the use of the PT0AD register. Each bit in this register corresponds to one pin of

Port 0. Setting the corresponding bit in PTOAD disables that pin's digital input. Port bits that have their digital inputs disabled will be read as 0 by any instruction that accesses the port.

### **Analog Comparators**

Two analog comparators are provided on the 87LPC762. Input and output options allow use of the comparators in a number of different configurations. Comparator operation is such that the output is a logical one (which may be read in a register and/or routed to a pin) when the positive input (one of two selectable pins) is greater than the negative input (selectable from a pin or an internal reference voltage). Otherwise the output is a zero. Each comparator may be configured to cause an interrupt when the output value changes.

#### **Comparator Configuration**

Each comparator has a control register, CMP1 for comparator 1 and CMP2 for comparator 2. The control registers are identical and are shown in Figure 2.

The overall connections to both comparators are shown in Figure 3. There are eight possible configurations for each comparator, as determined by the control bits in the corresponding CMPn register: CPn, CNn, and OEn. These configurations are shown in Figure 4. The comparators function down to a  $V_{DD}$  of 3.0V.

When each comparator is first enabled, the comparator output and interrupt flag are not guaranteed to be stable for 10 microseconds. The corresponding comparator interrupt should not be enabled during that time, and the comparator interrupt flag must be cleared before the interrupt is enabled in order to prevent an immediate interrupt service.

| Pn Addres<br>Not Bit |        | Reset Value: 00h |                                                                                                                                                                   |                           |           |                         |             |             |              |                                                              |
|----------------------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-----------|-------------------------|-------------|-------------|--------------|--------------------------------------------------------------|
|                      |        | 7                | 6                                                                                                                                                                 | 5                         | 4         | 3                       | 2           | 1           | 0            |                                                              |
|                      |        | _                |                                                                                                                                                                   | CEn                       | CPn       | CNn                     | OEn         | COn         | CMFn         | ]                                                            |
| BIT                  | SYMBOL | FUN              | CTION                                                                                                                                                             |                           |           |                         |             |             |              |                                                              |
| CMPn.7, 6            | —      | Rese             | rved for fu                                                                                                                                                       | uture use.                | Should n  | ot be set t             | o 1 by use  | er progran  | ns.          |                                                              |
| CMPn.5               | CEn    |                  | Comparator enable. When set by software, the corresponding comparator function is enabled.<br>Comparator output is stable 10 microseconds after CEn is first set. |                           |           |                         |             |             |              |                                                              |
| CMPn.4               | CPn    |                  |                                                                                                                                                                   |                           |           | When 0, C<br>e compar   |             |             | s the positi | ive comparator input. Whe                                    |
| CMPn.3               | CNn    | the n            | egative co                                                                                                                                                        |                           | input. Wh |                         |             |             |              | CMPREF is selected as<br>V <sub>ref</sub> is selected as the |
| CMPn.2               | OEn    |                  |                                                                                                                                                                   |                           |           | arator out<br>asynchror |             |             |              | pin if the comparator is                                     |
| CMPn.1               | COn    |                  |                                                                                                                                                                   | itput, synd<br>disabled ( |           |                         | J clock to  | allow rea   | ding by sc   | oftware. Cleared when the                                    |
| CMPn.0               | CMFn   | state            | . This bit v                                                                                                                                                      | vill cause                | a hardwa  |                         | t if enable | ed and of s |              | arator output COn change<br>priority. Cleared by             |
|                      |        |                  |                                                                                                                                                                   |                           |           |                         |             |             |              | SU011:                                                       |

#### Figure 2. Comparator Control Registers (CMP1 and CMP2)

## 87LPC762

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

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

- Bidirectional data transfer between masters and slaves.
- Serial addressing of slaves (no added wiring).
- Acknowledgment after each transferred byte.
- Multimaster bus.
- Arbitration between simultaneously transmitting masters without corruption of serial data on bus.

The  $l^2C$  subsystem includes hardware to simplify the software required to drive the  $l^2C$  bus. The hardware is a single bit interface which in addition to including the necessary arbitration and framing error checks, includes clock stretching and a bus timeout timer. The interface is synchronized to software either through polled loops or interrupts.

Refer to the application note AN422, entitled "Using the 8XC751 Microcontroller as an I<sup>2</sup>C Bus Master" for additional discussion of the 8xC76x I<sup>2</sup>C interface and sample driver routines.

The 87LPC762 I<sup>2</sup>C implementation duplicates that of the 87C751 and 87C752 except for the following details:

- The interrupt vector addresses for both the I<sup>2</sup>C interrupt and the Timer I interrupt.
- The I<sup>2</sup>C SFR addresses (I2CON, I2CFG, I2DAT).
- The location of the I<sup>2</sup>C interrupt enable bit and the name of the SFR it is located within (EI2 is Bit 0 in IEN1).
- The location of the Timer I interrupt enable bit and the name of the SFR it is located within (ETI is Bit 7 in IEN1).
- The I<sup>2</sup>C and Timer I interrupts have a settable priority.

Timer I is used to both control the timing of the  $l^2C$  bus and also to detect a "bus locked" condition, by causing an interrupt when nothing happens on the  $l^2C$  bus for an inordinately long period of time while a transmission is in progress. If this interrupt occurs, the program has the opportunity to attempt to correct the fault and resume  $l^2C$  operation.

Six time spans are important in I<sup>2</sup>C operation and are insured by timer I:

- The MINIMUM HIGH time for SCL when this device is the master.
- The MINIMUM LOW time for SCL when this device is a master. This is not very important for a single-bit hardware interface like this one, because the SCL low time is stretched until the software responds to the I<sup>2</sup>C flags. The software response time normally meets or exceeds the MIN LO time. In cases where the software responds within MIN HI + MIN LO) time, timer I will ensure that the minimum time is met.
- The MINIMUM SCL HIGH TO SDA HIGH time in a stop condition.
- The MINIMUM SDA HIGH TO SDA LOW time between I<sup>2</sup>C stop and start conditions (4.7ms, see I<sup>2</sup>C specification).
- The MINIMUM SDA LOW TO SCL LOW time in a start condition.
- The MAXIMUM SCL CHANGE time while an I<sup>2</sup>C frame is in progress. A frame is in progress between a start condition and the following stop condition. This time span serves to detect a lack of software response on this device as well as external I<sup>2</sup>C

problems. SCL "stuck low" indicates a faulty master or slave. SCL "stuck high" may mean a faulty device, or that noise induced onto the I<sup>2</sup>C bus caused all masters to withdraw from I<sup>2</sup>C arbitration.

The first five of these times are 4.7ms (see I<sup>2</sup>C specification) and are covered by the low order three bits of timer I. Timer I is clocked by the 87LPC762 CPU clock. Timer I can be pre-loaded with one of four values to optimize timing for different oscillator frequencies. At lower frequencies, software response time is increased and will degrade maximum performance of the I<sup>2</sup>C bus. See special function register I2CFG description for prescale values (CT0, CT1).

The MAXIMUM SCL CHANGE time is important, but its exact span is not critical. The complete 10 bits of timer I are used to count out the maximum time. When I<sup>2</sup>C operation is enabled, this counter is cleared by transitions on the SCL pin. The timer does not run between I<sup>2</sup>C frames (i.e., whenever reset or stop occurred more recently than the last start). When this counter is running, it will carry out after 1020 to 1023 machine cycles have elapsed since a change on SCL. A carry out causes a hardware reset of the I<sup>2</sup>C interface and generates an interrupt if the Timer I interrupt is enabled. In cases where the bus hang-up is due to a lack of software response by this device, the reset releases SCL and allows I<sup>2</sup>C operation among other devices to continue.

Timer I is enabled to run, and will reset the I<sup>2</sup>C interface upon overflow, if the TIRUN bit in the I2CFG register is set. The Timer I interrupt may be enabled via the ETI bit in IEN1, and its priority set by the PTIH and PTI bits in the IP1H and IP1 registers respectively.

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

If I<sup>2</sup>C interrupts are enabled (EA and EI2 are both set to 1), an I<sup>2</sup>C interrupt will occur whenever the ATN flag is set by a start, stop, arbitration loss, or data ready condition (refer to the description of ATN following). In practice, it is not efficient to operate the I<sup>2</sup>C interface in this fashion because the I<sup>2</sup>C interrupt service routine would somehow have to distinguish between hundreds of possible conditions. Also, since I<sup>2</sup>C can operate at a fairly high rate, the software may execute faster if the code simply waits for the I<sup>2</sup>C interface.

Typically, the  $l^2C$  interrupt should only be used to indicate a start condition at an idle slave device, or a stop condition at an idle master device (if it is waiting to use the  $l^2C$  bus). This is accomplished by enabling the  $l^2C$  interrupt only during the aforementioned conditions.

#### Reading I2CON

- RDAT The data from SDA is captured into "Receive DATa" whenever a rising edge occurs on SCL. RDAT is also available (with seven low-order zeros) in the I2DAT register. The difference between reading it here and there is that reading I2DAT clears DRDY, allowing the I<sup>2</sup>C to proceed on to another bit. Typically, the first seven bits of a received byte are read from I2DAT, while the 8th is read here. Then I2DAT can be written to send the Acknowledge bit and clear DRDY.
- ATN "ATteNtion" is 1 when one or more of DRDY, ARL, STR, or STP is 1. Thus, ATN comprises a single bit that can be tested to release the I<sup>2</sup>C service routine from a "wait loop."
- DRDY "Data ReaDY" (and thus ATN) is set when a rising edge occurs on SCL, except at idle slave. DRDY is cleared by writing CDR = 1, or by writing or reading the I2DAT register. The following low period on SCL is stretched until the program responds by clearing DRDY.

# Low power, low price, low pin count (20 pin) microcontroller with 2 kbyte OTP

| ON Add  | ress: D8h                |       |                                                                                                                                                     |             |              |             |             |                |             | Reset Value: 81h |
|---------|--------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|-------------|-------------|----------------|-------------|------------------|
| Bit A   | Addressable <sup>1</sup> | 7     | 6                                                                                                                                                   | 5           | 4            | 3           | 2           | 1              | 0           |                  |
|         | READ                     | RDAT  | ATN                                                                                                                                                 | DRDY        | ARL          | STR         | STP         | MASTER         | _           |                  |
|         | WRITE                    | CXA   | IDLE                                                                                                                                                | CDR         | CARL         | CSTR        | CSTP        | XSTR           | XSTP        |                  |
| BIT     | SYMBOL                   | . FUN | CTION                                                                                                                                               |             |              |             |             |                |             |                  |
| I2CON.7 | RDAT                     | Read  | I: the mos                                                                                                                                          | t recently  | received of  | data bit.   |             |                |             |                  |
| "       | CXA                      | Write | : clears th                                                                                                                                         | e transmi   | t active fla | g.          |             |                |             |                  |
| I2CON.6 | ATN                      | Read  | I: ATN = 1                                                                                                                                          | if any of t | he flags E   | RDY, AR     | L, STR, o   | r STP = 1.     |             |                  |
| "       | IDLE                     |       | Write: in the I <sup>2</sup> C slave mode, writing a 1 to this bit causes the I <sup>2</sup> C hardware to ignore the bus until it is needed again. |             |              |             |             |                |             |                  |
| I2CON.5 | DRDY                     | Read  | l: Data Re                                                                                                                                          | ady flag,   | set when     | here is a   | rising edg  | e on SCL.      |             |                  |
| "       | CDR                      | Write | : writing a                                                                                                                                         | 1 to this I | oit clears t | he DRDY     | flag.       |                |             |                  |
| I2CON.4 | ARL                      | Read  | l: Arbitrati                                                                                                                                        | on Loss fl  | ag, set wh   | en arbitra  | tion is los | t while in the | e transmit  | mode.            |
| "       | CARL                     | Write | : writing a                                                                                                                                         | 1 to this I | bit clears t | he CARL     | flag.       |                |             |                  |
| I2CON.3 | STR                      | Read  | l: Start fla                                                                                                                                        | g, set whe  | en a start o | ondition is | s detected  | d at a maste   | r or non-io | dle slave.       |
| "       | CSTR                     | Write | : writing a                                                                                                                                         | 1 to this I | bit clears t | he STR fl   | ag.         |                |             |                  |
| I2CON.2 | STP                      | Read  | l: Stop flag                                                                                                                                        | g, set whe  | n a stop c   | ondition is | s detected  | l at a maste   | r or non-ic | lle slave.       |
| "       | CSTP                     | Write | : writing a                                                                                                                                         | 1 to this I | bit clears t | he STP fla  | ag.         |                |             |                  |
| I2CON.1 | MASTER                   | Read  | l: indicate                                                                                                                                         | s whether   | this devic   | e is curre  | ntly as bu  | s master.      |             |                  |
| "       | XSTR                     | Write | : writing a                                                                                                                                         | 1 to this I | oit causes   | a repeate   | d start co  | ndition to be  | e generate  | ed.              |
| I2CON.C | _                        | Read  | l: undefine                                                                                                                                         | ed.         |              |             |             |                |             |                  |
| **      | XSTP                     | Write | : writing a                                                                                                                                         | 1 to this I | oit causes   | a stop co   | ndition to  | be generate    | ed.         | SU01155          |

### Figure 6. I<sup>2</sup>C Control Register (I2CON)

| I2DAT | Address | s: D9h     |      |                     |   |             |           |              |             |             | Reset Value: xxh        |
|-------|---------|------------|------|---------------------|---|-------------|-----------|--------------|-------------|-------------|-------------------------|
|       | Not Bit | Addressabl | le   |                     |   |             |           |              |             |             |                         |
|       |         |            | 7    | 6                   | 5 | 4           | 3         | 2            | 1           | 0           |                         |
|       |         | READ       | RDAT |                     | _ | _           | _         | _            | _           | _           |                         |
|       |         | WRITE      | XDAT | _                   | _ | _           | _         | _            |             | _           | -                       |
| BI    | т       | SYMBOL     | FUNG | TION                |   |             |           |              |             |             |                         |
| 121   | DAT.7   | RDAT       |      |                     |   |             |           | aptured fro  |             | every risin | ng edge of SCL. Reading |
|       | 66      | XDAT       |      | sets the mit Active |   | ne next tra | Insmitted | bit. Writing | g I2DAT als | o clears D  | RDY and sets the        |
| 121   | DAT.6–0 | -          | Unus | ed.                 |   |             |           |              |             |             | SU0115                  |

Figure 7. I<sup>2</sup>C Data Register (I2DAT)

#### **Checking ATN and DRDY**

When a program detects ATN = 1, it should next check DRDY. If DRDY = 1, then if it receives the last bit, it should capture the data from RDAT (in I2DAT or I2CON). Next, if the next bit is to be sent, it should be written to I2DAT. One way or another, it should clear DRDY and then return to monitoring ATN. Note that if any of ARL,

STR, or STP is set, clearing DRDY will not release SCL to high, so that the  $I^2C$  will not go on to the next bit. If a program detects ATN = 1, and DRDY = 0, it should go on to examine ARL, STR, and STP.

## 87LPC762

#### **External Interrupt Inputs**

The 87LPC762 has two individual interrupt inputs as well as the Keyboard Interrupt function. The latter is described separately elsewhere in this section. The two interrupt inputs are identical to those present on the standard 80C51 microcontroller.

The external sources can be programmed to be level-activated or transition-activated by setting or clearing bit IT1 or IT0 in Register TCON. If ITn = 0, external interrupt n is triggered by a detected low at the  $\overline{\rm INTn}$  pin. If ITn = 1, external interrupt n is edge triggered. In this mode if successive samples of the  $\overline{\rm INTn}$  pin show a high in one cycle and a low in the next cycle, interrupt request flag IEn in TCON is set, causing an interrupt request.

Since the external interrupt pins are sampled once each machine cycle, an input high or low should hold for at least 6 CPU Clocks to ensure proper sampling. If the external interrupt is

transition-activated, the external source has to hold the request pin high for at least one machine cycle, and then hold it low for at least one machine cycle. This is to ensure that the transition is seen and that interrupt request flag IEn is set. IEn is automatically cleared by the CPU when the service routine is called.

If the external interrupt is level-activated, the external source must hold the request active until the requested interrupt is actually generated. If the external interrupt is still asserted when the interrupt service routine is completed another interrupt will be generated. It is not necessary to clear the interrupt flag IEn when the interrupt is level sensitive, it simply tracks the input pin level.

If an external interrupt is enabled when the 87LPC762 is put into Power Down or Idle mode, the interrupt will cause the processor to wake up and resume operation. Refer to the section on Power Reduction Modes for details.



Figure 9. Interrupt Sources, Interrupt Enables, and Power Down Wakeup Sources

# 87LPC762

## I/O Ports

The 87LPC762 has 3 I/O ports, port 0, port 1, and port 2. The exact number of I/O pins available depend upon the oscillator and reset options chosen. At least 15 pins of the 87LPC762 may be used as I/Os when a two-pin external oscillator and an external reset circuit are used. Up to 18 pins may be available if fully on-chip oscillator and reset configurations are chosen.

All but three I/O port pins on the 87LPC762 may be software configured to one of four types on a bit-by-bit basis, as shown in Table 4. These are: quasi-bidirectional (standard 80C51 port outputs), push-pull, open drain, and input only. Two configuration registers for each port choose the output type for each port pin.

## Table 4. Port Output Configuration Settings

| PxM1.y | PxM2.y | Port Output Mode            |
|--------|--------|-----------------------------|
| 0      | 0      | Quasi-bidirectional         |
| 0      | 1      | Push-Pull                   |
| 1      | 0      | Input Only (High Impedance) |
| 1      | 1      | Open Drain                  |

#### **Quasi-Bidirectional Output Configuration**

The default port output configuration for standard 87LPC762 I/O ports is the quasi-bidirectional output that is common on the 80C51 and most of its derivatives. This output type can be used as both an

input and output without the need to reconfigure the port. This is possible because when the port outputs a logic high, it is weakly driven, allowing an external device to pull the pin low. When the pin is pulled low, it is driven strongly and able to sink a fairly large current. These features are somewhat similar to an open drain output except that there are three pull-up transistors in the quasi-bidirectional output that serve different purposes.

One of these pull-ups, called the "very weak" pull-up, is turned on whenever the port latch for the pin contains a logic 1. The very weak pull-up sources a very small current that will pull the pin high if it is left floating.

A second pull-up, called the "weak" pull-up, is turned on when the port latch for the pin contains a logic 1 and the pin itself is also at a logic 1 level. This pull-up provides the primary source current for a quasi-bidirectional pin that is outputting a 1. If a pin that has a logic 1 on it is pulled low by an external device, the weak pull-up turns off, and only the very weak pull-up remains on. In order to pull the pin low under these conditions, the external device has to sink enough current to overpower the weak pull-up and take the voltage on the port pin below its input threshold.

The third pull-up is referred to as the "strong" pull-up. This pull-up is used to speed up low-to-high transitions on a quasi-bidirectional port pin when the port latch changes from a logic 0 to a logic 1. When this occurs, the strong pull-up turns on for a brief time, two CPU clocks, in order to pull the port pin high quickly. Then it turns off again.

The quasi-bidirectional port configuration is shown in Figure 10.



Figure 10. Quasi-Bidirectional Output

### Oscillator

The 87LPC762 provides several user selectable oscillator options, allowing optimization for a range of needs from high precision to lowest possible cost. These are configured when the EPROM is

programmed. Basic oscillator types that are supported include: low, medium, and high speed crystals, covering a range from 20 kHz to 20 MHz; ceramic resonators; and on-chip RC oscillator.

#### Low Frequency Oscillator Option

This option supports an external crystal in the range of 20 kHz to 100 kHz.

Table 5 shows capacitor values that may be used with a quartz crystal in this mode.

### Table 5. Recommended oscillator capacitors for use with the low frequency oscillator option

| Oscillator |             | $V_{DD}$ = 2.7 to 4.5 V |             | V <sub>DD</sub> = 4.5 to 6.0 V |               |             |  |
|------------|-------------|-------------------------|-------------|--------------------------------|---------------|-------------|--|
| Frequency  | Lower Limit | Optimal Value           | Upper Limit | Lower Limit                    | Optimal Value | Upper Limit |  |
| 20 kHz     | 15 pF       | 15 pF                   | 33 pF       | 33 pF                          | 33 pF         | 47 pF       |  |
| 32 kHz     | 15 pF       | 15 pF                   | 33 pF       | 33 pF                          | 33 pF         | 47 pF       |  |
| 100 kHz    | 15 pF       | 15 pF                   | 33 pF       | 15 pF                          | 15 pF         | 33 pF       |  |

#### **Medium Frequency Oscillator Option**

This option supports an external crystal in the range of 100 kHz to 4 MHz. Ceramic resonators are also supported in this configuration.

Table 6 shows capacitor values that may be used with a quartz crystal in this mode.

### Table 6. Recommended oscillator capacitors for use with the medium frequency oscillator option

| Oscillator Frequency | V <sub>DD</sub> = 2.7 to 4.5 V |               |             |  |  |  |  |
|----------------------|--------------------------------|---------------|-------------|--|--|--|--|
| Oscillator Frequency | Lower Limit                    | Optimal Value | Upper Limit |  |  |  |  |
| 100 kHz              | 33 pF                          | 33 pF         | 47 pF       |  |  |  |  |
| 1 MHz                | 15 pF                          | 15 pF         | 33 pF       |  |  |  |  |
| 4 MHz                | 15 pF                          | 15 pF         | 33 pF       |  |  |  |  |

#### High Frequency Oscillator Option

This option supports an external crystal in the range of 4 to 20 MHz. Ceramic resonators are also supported in this configuration.

Table 7 shows capacitor values that may be used with a quartz crystal in this mode.

### Table 7. Recommended oscillator capacitors for use with the high frequency oscillator option

| Oscillator |             | $V_{DD}$ = 2.7 to 4.5 V   |       | V <sub>DD</sub> = 4.5 to 6.0 V |               |             |  |
|------------|-------------|---------------------------|-------|--------------------------------|---------------|-------------|--|
| Frequency  | Lower Limit | Optimal Value Upper Limit |       | Lower Limit                    | Optimal Value | Upper Limit |  |
| 4 MHz      | 15 pF       | 33 pF                     | 47 pF | 15 pF                          | 33 pF         | 68 pF       |  |
| 8 MHz      | 15 pF       | 15 pF                     | 33 pF | 15 pF                          | 33 pF         | 47 pF       |  |
| 16 MHz     | -           | -                         | -     | 15 pF                          | 15 pF         | 33 pF       |  |
| 20 MHz     | -           | -                         | -     | 15 pF                          | 15 pF         | 33 pF       |  |

#### **On-Chip RC Oscillator Option**

The on-chip RC oscillator option has a typical frequency of 6 MHz and can be divided down for slower operation through the use of the DIVM register. Note that some devices have 10% tolerance and others 25% tolerance at this time. For on-chip oscillator tolerance see Electrical Characteristics table. A clock output on the X2/P2.0 pin may be enabled when the on-chip RC oscillator is used.

#### **External Clock Input Option**

In this configuration, the processor clock is input from an external source driving the X1/P2.1 pin. The rate may be from 0 Hz up to 20 MHz when  $V_{DD}$  is above 4.5 V and up to 10 MHz when  $V_{DD}$  is below 4.5 V. When the external clock input mode is used, the X2/P2.0

pin may be used as a standard port pin. A clock output on the X2/P2.0 pin may be enabled when the external clock input is used.

#### **Clock Output**

The 87LPC762 supports a clock output function when either the on-chip RC oscillator or external clock input options are selected. This allows external devices to synchronize to the 87LPC762. When enabled, via the ENCLK bit in the P2M1 register, the clock output appears on the X2/CLKOUT pin whenever the on-chip oscillator is running, including in Idle mode. The frequency of the clock output is 1/6 of the CPU clock rate. If the clock output is not needed in Idle mode, it may be turned off prior to entering Idle, saving additional power. The clock output may also be enabled when the external clock input option is selected.

# Low power, low price, low pin count (20 pin) microcontroller with 2 kbyte OTP



Figure 18. Block Diagram of Oscillator Control

### CPU Clock Modification: CLKR and DIVM

For backward compatibility, the CLKR configuration bit allows setting the 87LPC762 instruction and peripheral timing to match standard 80C51 timing by dividing the CPU clock by two. Default timing for the 87LPC762 is 6 CPU clocks per machine cycle while standard 80C51 timing is 12 clocks per machine cycle. This division also applies to peripheral timing, allowing 80C51 code that is oscillator frequency and/or timer rate dependent. The CLKR bit is located in the EPROM configuration register UCFG1, described under EPROM Characteristics

In addition to this, the CPU clock may be divided down from the oscillator rate by a programmable divider, under program control. This function is controlled by the DIVM register. If the DIVM register is set to zero (the default value), the CPU will be clocked by either the unmodified oscillator rate, or that rate divided by two, as determined by the previously described CLKR function.

When the DIVM register is set to some value N (between 1 and 255), the CPU clock is divided by 2 \* (N + 1). Clock division values from 4 through 512 are thus possible. This feature makes it possible to temporarily run the CPU at a lower rate, reducing power consumption, in a manner similar to Idle mode. By dividing the clock, the CPU can retain the ability to respond to events other than those that can cause interrupts (i.e. events that allow exiting the Idle mode) by executing its normal program at a lower rate. This can allow bypassing the oscillator startup time in cases where Power Down mode would otherwise be used. The value of DIVM may be changed by the program at any time without interrupting code execution.

## **Power Monitoring Functions**

The 87LPC762 incorporates power monitoring functions designed to prevent incorrect operation during initial power up and power loss or reduction during operation. This is accomplished with two hardware functions: Power-On Detect and Brownout Detect.

#### **Brownout Detection**

The Brownout Detect function allows preventing the processor from failing in an unpredictable manner if the power supply voltage drops below a certain level. The default operation is for a brownout detection to cause a processor reset, however it may alternatively be configured to generate an interrupt by setting the BOI bit in the AUXR1 register (AUXR1.5).

The 87LPC762 allows selection of two Brownout levels: 2.5 V or 3.8 V. When  $V_{DD}$  drops below the selected voltage, the brownout detector triggers and remains active until  $V_{DD}$  is returns to a level above the Brownout Detect voltage. When Brownout Detect causes a processor reset, that reset remains active as long as  $V_{DD}$  remains below the Brownout Detect voltage. When Brownout Detect generates an interrupt, that interrupt occurs once as  $V_{DD}$  crosses from above to below the Brownout Detect voltage. For the interrupt to be processed, the interrupt system and the BOI interrupt must both be enabled (via the EA and EBO bits in IEN0).

When Brownout Detect is activated, the BOF flag in the PCON register is set so that the cause of processor reset may be determined by software. This flag will remain set until cleared by software.

## 87LPC762

### **Timer/Counters**

The 87LPC762 has two general purpose counter/timers which are upward compatible with the standard 80C51 Timer 0 and Timer 1. Both can be configured to operate either as timers or event counters (see Figure 22). An option to automatically toggle the T0 and/or T1 pins upon timer overflow has been added.

In the "Timer" function, the register is incremented every machine cycle. Thus, one can think of it as counting machine cycles. Since a machine cycle consists of 6 CPU clock periods, the count rate is 1/6 of the CPU clock frequency. Refer to the section Enhanced CPU for a description of the CPU clock.

In the "Counter" function, the register is incremented in response to a 1-to-0 transition at its corresponding external input pin, T0 or T1. In this function, the external input is sampled once during every machine cycle. When the samples of the pin state show a high in one cycle and a low in the next cycle, the count is incremented. The new count value appears in the register during the cycle following the one in which the transition was detected. Since it takes 2 machine cycles (12 CPU clocks) to recognize a 1-to-0 transition, the maximum count rate is 1/6 of the CPU clock frequency. There are no restrictions on the duty cycle of the external input signal, but to ensure that a given level is sampled at least once before it changes, it should be held for at least one full machine cycle.

The "Timer" or "Counter" function is selected by control bits  $C/\overline{T}$  in the Special Function Register TMOD. In addition to the "Timer" or "Counter" selection, Timer 0 and Timer 1 have four operating modes, which are selected by bit-pairs (M1, M0) in TMOD. Modes 0, 1, and 2 are the same for both Timers/Counters. Mode 3 is different. The four operating modes are described in the following text.



Figure 22. Timer/Counter Mode Control Register (TMOD)

## 87LPC762

#### Mode 0

Putting either Timer into Mode 0 makes it look like an 8048 Timer, which is an 8-bit Counter with a divide-by-32 prescaler. Figure 24 shows Mode 0 operation.

In this mode, the Timer register is configured as a 13-bit register. As the count rolls over from all 1s to all 0s, it sets the Timer interrupt flag TFn. The count input is enabled to the Timer when TRn = 1 and either GATE = 0 or INTn = 1. (Setting GATE = 1 allows the Timer to be controlled by external input INTn, to facilitate pulse width

measurements). TRn is a control bit in the Special Function Register TCON (Figure 23). The GATE bit is in the TMOD register.

The 13-bit register consists of all 8 bits of THn and the lower 5 bits of TLn. The upper 3 bits of TLn are indeterminate and should be ignored. Setting the run flag (TRn) does not clear the registers.

Mode 0 operation is the same for Timer 0 and Timer 1. See Figure 24. There are two different GATE bits, one for Timer 1 (TMOD.7) and one for Timer 0 (TMOD.3).

| ON | Addres  | s: 88h    |                                                                                  |             |              |            |             |              |             | Reset Value: 00      |
|----|---------|-----------|----------------------------------------------------------------------------------|-------------|--------------|------------|-------------|--------------|-------------|----------------------|
|    | Bit Add | Iressable |                                                                                  |             |              |            |             |              |             |                      |
|    |         | 7         | 6                                                                                | 5           | 4            | 3          | 2           | 1            | 0           |                      |
|    |         | TF1       | TR1                                                                              | TF0         | TR0          | IE1        | IT1         | IE0          | IT0         | ]                    |
| Bľ | т       | SYMBOL    | FUNCTION                                                                         |             |              |            |             |              |             |                      |
| тс | ON.7    | TF1       | Timer 1 overflo                                                                  |             |              |            | imer/Cour   | nter overflo | w. Cleared  | by hardware when the |
| тс | ON.6    | TR1       | Timer 1 Run control bit. Set/cleared by software to turn Timer/Counter 1 on/off. |             |              |            |             |              |             | /off.                |
| тс | ON.5    | TF0       | Timer 0 overflo<br>processor vect                                                |             |              |            |             |              | w. Cleared  | by hardware when the |
| ТС | ON.4    | TR0       | Timer 0 Run co                                                                   | ontrol bit. | Set/cleare   | d by softw | vare to tur | n Timer/Co   | unter 0 on  | /off.                |
| тс | ON.3    | IE1       | Interrupt 1 Edg<br>hardware wher                                                 |             |              |            |             |              | edge is de  | tected. Cleared by   |
| тс | ON.2    | IT1       | Interrupt 1 Type<br>external interru                                             |             | oit. Set/cle | ared by s  | oftware to  | specify fal  | ling edge/l | ow level triggered   |
| тс | ON.1    | IE0       | Interrupt 0 Edg<br>hardware wher                                                 |             |              |            |             |              | edge is de  | tected. Cleared by   |
| тс | ON.0    | IT0       | 1 21                                                                             |             | oit. Set/cle | ared by s  | oftware to  | specify fal  | ling edge/  | ow level triggered   |
|    |         |           | external interru                                                                 | pts.        |              |            |             |              |             | SU01172              |

Figure 23. Timer/Counter Control Register (TCON)



Figure 24. Timer/Counter 0 or 1 in Mode 0 (13-Bit Counter)

#### Philips Semiconductors

# Low power, low price, low pin count (20 pin) microcontroller with 2 kbyte OTP

### Serial Port Control Register (SCON)

The serial port control and status register is the Special Function Register SCON, shown in Figure 28. This register contains not only the mode selection bits, but also the 9th data bit for transmit and receive (TB8 and RB8), and the serial port interrupt bits (TI and RI).

The Framing Error bit (FE) allows detection of missing stop bits in the received data stream. The FE bit shares the bit position SCON.7

with the SM0 bit. Which bit appears in SCON at any particular time is determined by the SMOD0 bit in the PCON register. If SMOD0 = 0, SCON.7 is the SM0 bit. If SMOD0 = 1, SCON.7 is the FE bit. Once set, the FE bit remains set until it is cleared by software. This allows detection of framing errors for a group of characters without the need for monitoring it for every character individually.

|         | ss: 98h         |                                                                                                                                             |               |              |             |            |              |               | Reset Value: 00h                                                    |
|---------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------|-------------|------------|--------------|---------------|---------------------------------------------------------------------|
| Bit Ad  | dressable       |                                                                                                                                             |               |              |             |            |              |               |                                                                     |
|         | 7               | 6                                                                                                                                           | 5             | 4            | 3           | 2          | 1            | 0             |                                                                     |
|         | SM0/            | FE SM1                                                                                                                                      | SM2           | REN          | TB8         | RB8        | TI           | RI            |                                                                     |
| BIT     | SYMBOL          | FUNCTION                                                                                                                                    |               |              |             |            |              |               |                                                                     |
| SCON.7  | FE              |                                                                                                                                             | tware. The    |              |             |            |              |               | t is detected. Must be is bit to be accessible.                     |
| SCON.7  | SM0             | With SM1, de<br>to be accessib                                                                                                              |               |              |             | SMOD0 I    | bit in the P | CON regis     | ster must be 0 for this bit                                         |
| SCON. 6 | SM1             | With SM0, de                                                                                                                                | ines the se   | erial port r | node (see   | table belo | ow).         |               |                                                                     |
|         | <u>SM0, SM1</u> | UART Mode                                                                                                                                   |               | Baud         | Rate        |            |              |               |                                                                     |
|         | 0 0             | 0: shift registe                                                                                                                            | r             | CPU          | clock/6     |            |              |               |                                                                     |
|         | 0 1             | 1: 8-bit UART                                                                                                                               |               | Varia        | ble (see te | ext)       |              |               |                                                                     |
|         | 10              | 2: 9-bit UART                                                                                                                               |               | CPU          | clock/32 d  | or CPU clo | ock/16       |               |                                                                     |
|         | 11              | 3: 9-bit UART                                                                                                                               |               | Varia        | ble (see te | ext)       |              |               |                                                                     |
| SCON.5  | SM2             |                                                                                                                                             | vill not be a | ctivated if  | the recei   | ved 9th da | ta bit (RB8  | 3) is 0. In N | ode 2 or 3, if SM2 is set<br>Mode 1, if SM2=1 then RI<br>ould be 0. |
| SCON.4  | REN             | Enables seria                                                                                                                               | reception     | . Set by so  | oftware to  | enable ree | ception. Cl  | ear by sof    | tware to disable reception                                          |
| SCON.3  | TB8             | The 9th data bit that will be transmitted in Modes 2 and 3. Set or clear by software as desired.                                            |               |              |             |            |              |               |                                                                     |
| SCON.2  | RB8             | In Modes 2 and 3, is the 9th data bit that was received. In Mode 1, it SM2=0, RB8 is the stop bit was received. In Mode 0, RB8 is not used. |               |              |             |            |              |               |                                                                     |
| SCON.1  | ТІ              |                                                                                                                                             |               |              |             |            |              |               | de 0, or at the beginning red by software.                          |
| SCON.0  | RI              | the stop bit tin                                                                                                                            |               |              |             |            |              |               | de 0, or halfway through<br>12). Must be cleared by                 |
|         |                 | software.                                                                                                                                   |               |              |             |            |              |               | SU0115                                                              |

Figure 28. Serial Port Control Register (SCON)

# 87LPC762

#### More About UART Mode 0

Serial data enters and exits through RxD. TxD outputs the shift clock. 8 bits are transmitted/received: 8 data bits (LSB first). The baud rate is fixed at 1/6 the CPU clock frequency. Figure 29 shows a simplified functional diagram of the serial port in Mode 0, and associated timing.

Transmission is initiated by any instruction that uses SBUF as a destination register. The "write to SBUF" signal at S6P2 also loads a 1 into the 9th position of the transmit shift register and tells the TX Control block to commence a transmission. The internal timing is such that one full machine cycle will elapse between "write to SBUF" and activation of SEND.

SEND enables the output of the shift register to the alternate output function line of P1.1 and also enable SHIFT CLOCK to the alternate output function line of P1.0. SHIFT CLOCK is low during S3, S4, and S5 of every machine cycle, and high during S6, S1, and S2. At S6P2 of every machine cycle in which SEND is active, the contents of the transmit shift are shifted to the right one position.

As data bits shift out to the right, zeros come in from the left. When the MSB of the data byte is at the output position of the shift register, then the 1 that was initially loaded into the 9th position, is just to the left of the MSB, and all positions to the left of that contain zeros. This condition flags the TX Control block to do one last shift and then deactivate SEND and set T1. Both of these actions occur at S1P1 of the 10th machine cycle after "write to SBUF." Reception is initiated by the condition REN = 1 and R1 = 0. At S6P2 of the next machine cycle, the RX Control unit writes the bits 1111110 t o the receive shift register, and in the next clock phase activates RECEIVE.

RECEIVE enable SHIFT CLOCK to the alternate output function line of P1.0. SHIFT CLOCK makes transitions at S3P1 and S6P1 of every machine cycle. At S6P2 of every machine cycle in which RECEIVE is active, the contents of the receive shift register are shifted to the left one position. The value that comes in from the right is the value that was sampled at the P1.1 pin at S5P2 of the same machine cycle.

As data bits come in from the right, 1s shift out to the left. When the 0 that was initially loaded into the rightmost position arrives at the leftmost position in the shift register, it flags the RX Control block to do one last shift and load SBUF. At S1P1 of the 10th machine cycle after the write to SCON that cleared RI, RECEIVE is cleared as RI is set.

#### More About UART Mode 1

Ten bits are transmitted (through TxD), or received (through RxD): a start bit (0), 8 data bits (LSB first), and a stop bit (1). On receive, the stop bit goes into RB8 in SCON. In the 87LPC762 the baud rate is determined by the Timer 1 overflow rate. Figure 30 shows a simplified functional diagram of the serial port in Mode 1, and associated timings for transmit receive.

Transmission is initiated by any instruction that uses SBUF as a destination register. The "write to SBUF" signal also loads a 1 into the 9th bit position of the transmit shift register and flags the TX Control unit that a transmission is requested. Transmission actually commences at S1P1 of the machine cycle following the next rollover in the divide-by-16 counter. (Thus, the bit times are synchronized to the divide-by-16 counter, not to the "write to SBUF" signal.)

The transmission begins with activation of SEND which puts the start bit at TxD. One bit time later, DATA is activated, which enables the output bit of the transmit shift register to TxD. The first shift pulse occurs one bit time after that.

As data bits shift out to the right, zeros are clocked in from the left. When the MSB of the data byte is at the output position of the shift register, then the 1 that was initially loaded into the 9th position is just to the left of the MSB, and all positions to the left of that contain zeros. This condition flags the TX Control unit to do one last shift and then deactivate SEND and set TI. This occurs at the 10th divide-by-16 rollover after "write to SBUF."

Reception is initiated by a detected 1-to-0 transition at RxD. For this purpose RxD is sampled at a rate of 16 times whatever baud rate has been established. When a transition is detected, the divide-by-16 counter is immediately reset, and 1FFH is written into the input shift register. Resetting the divide-by-16 counter aligns its rollovers with the boundaries of the incoming bit times.

The 16 states of the counter divide each bit time into 16ths. At the 7th, 8th, and 9th counter states of each bit time, the bit detector samples the value of RxD. The value accepted is the value that was seen in at least 2 of the 3 samples. This is done for noise rejection. If the value accepted during the first bit time is not 0, the receive circuits are reset and the unit goes back to looking for another 1-to-0 transition. This is to provide rejection of false start bits. If the start bit proves valid, it is shifted into the input shift register, and reception of the rest of the frame will proceed.

As data bits come in from the right, 1s shift out to the left. When the start bit arrives at the leftmost position in the shift register (which in mode 1 is a 9-bit register), it flags the RX Control block to do one last shift, load SBUF and RB8, and set RI. The signal to load SBUF and RB8, and to set RI, will be generated if, and only if, the following conditions are met at the time the final shift pulse is generated.: 1. R1 = 0, and 2. Either SM2 = 0, or the received stop bit = 1.

If either of these two conditions is not met, the received frame is irretrievably lost. If both conditions are met, the stop bit goes into RB8, the 8 data bits go into SBUF, and RI is activated. At this time, whether the above conditions are met or not, the unit goes back to looking for a 1-to-0 transition in RxD.

87LPC762



Figure 31. Serial Port Mode 2

# 87LPC762

### Additional Features

The AUXR1 register contains several special purpose control bits that relate to several chip features. AUXR1 is described in Figure 35.

#### Software Reset

The SRST bit in AUXR1 allows software the opportunity to reset the processor completely, as if an external reset or watchdog reset had occurred. If a value is written to AUXR1 that contains a 1 at bit position 3, all SFRs will be initialized and execution will resume at program address 0000. Care should be taken when writing to AUXR1 to avoid accidental software resets.

#### **Dual Data Pointers**

The dual Data Pointer (DPTR) adds to the ways in which the processor can specify the address used with certain instructions. The DPS bit in the AUXR1 register selects one of the two Data Pointers. The DPTR that is not currently selected is not accessible to software unless the DPS bit is toggled.

Specific instructions affected by the Data Pointer selection are:

- INC DPTR Increments the Data Pointer by 1.
- JMP @A+DPTR Jump indirect relative to DPTR value.

- MOV DPTR, #data16 Load the Data Pointer with a 16-bit constant.
   MOVC A, @A+DPTR Move code byte relative to DPTR to the accumulator.
- MOVX A, @DPTR Move data byte the accumulator to data memory relative to DPTR.
- MOVX @DPTR, A Move data byte from data memory relative to DPTR to the accumulator.

Also, any instruction that reads or manipulates the DPH and DPL registers (the upper and lower bytes of the current DPTR) will be affected by the setting of DPS. The MOVX instructions have limited application for the 87LPC762 since the part does not have an external data bus. However, they may be used to access EPROM configuration information (see EPROM Characteristics section).

Bit 2 of AUXR1 is permanently wired as a logic 0. This is so that the DPS bit may be toggled (thereby switching Data Pointers) simply by incrementing the AUXR1 register, without the possibility of inadvertently altering other bits in the register.

| JXR1 Addres | Addressable |      |                                                                                                                                   |            |                               |               |             |              |             | Reset Value: 0                               |
|-------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------|------------|-------------------------------|---------------|-------------|--------------|-------------|----------------------------------------------|
| NOL DIL     | Addressable |      |                                                                                                                                   |            |                               |               |             |              |             |                                              |
|             | _           | 7    | 6                                                                                                                                 | 5          | 4                             | 3             | 2           | 1            | 0           |                                              |
|             |             | KBF  | BOD                                                                                                                               | BOI        | LPEP                          | SRST          | 0           | —            | DPS         |                                              |
|             | _           |      |                                                                                                                                   |            |                               |               |             |              |             |                                              |
| BIT         | SYMBOL      | FUN  | ICTION                                                                                                                            |            |                               |               |             |              |             |                                              |
| AUXR1.7     | KBF         |      |                                                                                                                                   |            | . Set when a be cleared       |               |             | is enabled   | for the Key | yboard Interrupt                             |
| AUXR1.6     | BOD         |      | Brown Out Disable. When set, turns off brownout detection and saves power. See Power<br>Monitoring Functions section for details. |            |                               |               |             |              |             |                                              |
| AUXR1.5     | BOI         | the  |                                                                                                                                   | detect fun |                               |               |             |              |             | hip reset and allows<br>pring Functions      |
| AUXR1.4     | LPEP        |      |                                                                                                                                   |            |                               |               |             |              |             | Set by software. Can es section for details. |
| AUXR1.3     | SRST        | Soft | ware Res                                                                                                                          | et. When s | set by softw                  | are, resets   | the 87LP    | C762 as if   | a hardware  | e reset occurred.                            |
| AUXR1.2     | —           |      |                                                                                                                                   |            | wired 0. All<br>s in the regi |               | ig of the [ | DPS bit by i | ncrementin  | g AUXR1, without                             |
| AUXR1.1     | _           | Res  | erved for                                                                                                                         | future use | . Should no                   | t be set to ? | l by user   | programs.    |             |                                              |
| AUXR1.0     | DPS         | Data | a Pointer                                                                                                                         | Select. Ch | ooses one o                   | of two Data   | Pointers    | for use by   | the prograr | n. See text for details.                     |
|             |             |      |                                                                                                                                   |            |                               |               |             |              |             | SU01223                                      |

Figure 35. AUXR1 Register



Figure 37. EPROM System Configuration Byte 2 (UCFG2)

#### Security Bits

When neither of the security bits are programmed, the code in the EPROM can be verified. When only security bit 1 is programmed, all further programming of the EPROM is disabled. At that point, only security bit 2 may still be programmed. When both security bits are programmed, EPROM verify is also disabled.

## Table 11. EPROM Security Bits

| SB2 | SB1 | Protection Description                                                                                         |
|-----|-----|----------------------------------------------------------------------------------------------------------------|
| 1   | 1   | Both security bits unprogrammed. No program security features enabled. EPROM is programmable and verifiable.   |
| 1   | 0   | Only security bit 1 programmed. Further EPROM programming is disabled. Security bit 2 may still be programmed. |
| 0   | 1   | Only security bit 2 programmed. This combination is not supported.                                             |
| 0   | 0   | Both security bits programmed. All EPROM verification and programming are disabled.                            |

## **ABSOLUTE MAXIMUM RATINGS**

| PARAMETER                                                                        | RATING                        | UNIT |
|----------------------------------------------------------------------------------|-------------------------------|------|
| Operating temperature under bias                                                 | -55 to +125                   | °C   |
| Storage temperature range                                                        | -65 to +150                   | °C   |
| Voltage on RST/V <sub>PP</sub> pin to V <sub>SS</sub>                            | 0 to +11.0                    | V    |
| Voltage on any other pin to $V_{SS}$                                             | –0.5 to V <sub>DD</sub> +0.5V | V    |
| Maximum I <sub>OL</sub> per I/O pin                                              | 20                            | mA   |
| Power dissipation (based on package heat transfer, not device power consumption) | 1.5                           | W    |

NOTES:

 Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any conditions other than those described in the AC and DC Electrical Characteristics section of this specification are not implied.

2. This product includes circuitry specifically designed for the protection of its internal devices from the damaging effects of excessive static charge. Nonetheless, it is suggested that conventional precautions be taken to avoid applying greater than the rated maximum.

3. Parameters are valid over operating temperature range unless otherwise specified. All voltages are with respect to VSS unless otherwise noted.

## DC ELECTRICAL CHARACTERISTICS

 $V_{DD}$  = 2.7 V to 6.0 V unless otherwise specified;  $T_{amb}$  = 0°C to +70°C or -40°C to +85°C, unless otherwise specified.

| SYMBOL                             | DADAMETED                                                    | TEST CONDITIONS                                    |                          | UNIT                |                          |        |  |
|------------------------------------|--------------------------------------------------------------|----------------------------------------------------|--------------------------|---------------------|--------------------------|--------|--|
| STMBUL                             | PARAMETER                                                    | TEST CONDITIONS                                    | MIN                      | TYP <sup>1</sup>    | MAX                      |        |  |
|                                    | Device events an existing                                    | 5.0 V, 20 MHz <sup>11</sup>                        |                          | 15                  | 25                       | mA     |  |
| IDD                                | Power supply current, operating                              | 3.0 V, 10 MHz <sup>11</sup>                        |                          | 4                   | 7                        | mA     |  |
| I <sub>ID</sub>                    | Devenue and the second state                                 | 5.0 V, 20 MHz <sup>11</sup>                        |                          | 6                   | 10                       | mA     |  |
|                                    | Power supply current, Idle mode                              | 3.0 V, 10 MHz <sup>11</sup>                        |                          | 2                   | 4                        | mA     |  |
|                                    | Device events average Device Device mode                     | 5.0 V <sup>11</sup>                                |                          | 1                   | 10                       | μΑ     |  |
| PD                                 | Power supply current, Power Down mode                        | 3.0 V <sup>11</sup>                                |                          | 1                   | 5                        | μΑ     |  |
| V <sub>RAM</sub>                   | RAM keep-alive voltage                                       |                                                    | 1.5                      |                     |                          | V      |  |
| N                                  |                                                              | 4.0 V < V <sub>DD</sub> < 6.0 V                    | -0.5                     |                     | 0.2 V <sub>DD</sub> -0.1 | V      |  |
| VIL                                | Input low voltage (TTL input)                                | 2.7 V < V <sub>DD</sub> < 4.0 V                    | -0.5                     |                     | 0.7                      | V      |  |
| V <sub>IL1</sub>                   | Negative going threshold (Schmitt input)                     |                                                    | -0.5                     |                     | 0.3 V <sub>DD</sub>      | V      |  |
| VIH                                | Input high voltage (TTL input)                               |                                                    | 0.2 V <sub>DD</sub> +0.9 |                     | V <sub>DD</sub> +0.5     | V      |  |
| V <sub>IH1</sub>                   | Positive going threshold (Schmitt input)                     |                                                    | 0.7V <sub>DD</sub>       |                     | V <sub>DD</sub> +0.5     | V      |  |
| HYS                                | Hysteresis voltage                                           |                                                    |                          | 0.2 V <sub>DD</sub> |                          | V      |  |
| V <sub>OL</sub>                    | Output low voltage all ports <sup>5, 9</sup>                 | I <sub>OL</sub> = 3.2 mA, V <sub>DD</sub> = 2.7 V  |                          |                     | 0.4                      | V      |  |
| V <sub>OL1</sub>                   | Output low voltage all ports <sup>5, 9</sup>                 | I <sub>OL</sub> = 20 mA, V <sub>DD</sub> = 2.7 V   |                          |                     | 1.0                      | V      |  |
|                                    |                                                              | I <sub>OH</sub> = -20 μA, V <sub>DD</sub> = 2.7 V  | V <sub>DD</sub> -0.7     |                     |                          | V      |  |
| V <sub>OH</sub>                    | Output high voltage, all ports <sup>3</sup>                  | I <sub>OH</sub> = -30 μA, V <sub>DD</sub> = 4.5 V  | V <sub>DD</sub> -0.7     |                     |                          | V      |  |
| V <sub>OH1</sub>                   | Output high voltage, all ports <sup>4</sup>                  | I <sub>OH</sub> = -1.0 mA, V <sub>DD</sub> = 2.7 V | V <sub>DD</sub> -0.7     |                     |                          | V      |  |
| CIO                                | Input/Output pin capacitance <sup>10</sup>                   |                                                    |                          |                     | 15                       | pF     |  |
| IIL                                | Logical 0 input current, all ports <sup>8</sup>              | V <sub>IN</sub> = 0.4 V                            |                          |                     | -50                      | μA     |  |
| ILI                                | Input leakage current, all ports <sup>7</sup>                | $V_{IN} = V_{IL}$ or $V_{IH}$                      |                          |                     | ±2                       | μΑ     |  |
|                                    |                                                              | $V_{IN}$ = 1.5 V at $V_{DD}$ = 3.0 V               | -30                      |                     | -250                     | μA     |  |
| ITL                                | Logical 1 to 0 transition current, all ports <sup>3, 6</sup> | $V_{IN}$ = 2.0 V at $V_{DD}$ = 5.5 V               | -150                     |                     | -650                     | μΑ     |  |
| R <sub>RST</sub>                   | Internal reset pull-up resistor                              |                                                    | 40                       |                     | 225                      | kΩ     |  |
| VBOLOW                             | Brownout trip voltage with BOV = $1^{12}$                    |                                                    | 2.35                     |                     | 2.69                     | V      |  |
| V <sub>BOHI</sub>                  | Brownout trip voltage with BOV = 0                           |                                                    | 3.45                     |                     | 3.99                     | V      |  |
| V <sub>REF</sub>                   | Reference voltage                                            |                                                    | 1.11                     | 1.26                | 1.41                     | V      |  |
| t <sub>C</sub> (V <sub>REF</sub> ) | Temperature coefficient                                      |                                                    |                          | tbd                 |                          | ppm/°0 |  |
| SS                                 | Supply sensitivity                                           |                                                    |                          | tbd                 |                          | %/V    |  |

NOTES:

9.

Typical ratings are not guaranteed. The values listed are at room temperature, 5 V.

2. See other Figures for details. Active mode: I<sub>CC(MAX)</sub> = tbd; Idle mode: I<sub>CC(MAX)</sub> = tbd

Ports in quasi-bidirectional mode with weak pull-up (applies to all port pins with pull-ups). Does not apply to open drain pins. 3.

4. Ports in PUSH-PULL mode. Does not apply to open drain pins.

5. In all output modes except high impedance mode.

Port pins source a transition current when used in quasi-bidirectional mode and externally driven from 1 to 0. This current is highest when VIN is approximately 2 V.

7. Measured with port in high impedance mode.

Measured with port in quasi-bidirectional mode. 8.

Under steady state (non-transient) conditions, I<sub>OL</sub> must be externally limited as follows:

Maximum IOL per port pin:

20 mA Maximum total IOL for all outputs: 80 mA

Maximum total IOH for all outputs: 5 mA

If I<sub>OL</sub> exceeds the test condition, V<sub>OL</sub> may exceed the related specification. Pins are not guaranteed to sink current greater than the listed test conditions.

10. Pin capacitance is characterized but not tested.

11. The IDD, IDD, and IPD specifications are measured using an external clock with the following functions disabled: comparators, brownout detect, and watchdog timer. For V<sub>DD</sub> = 3 V, LPEP = 1. Refer to the appropriate figures on the following pages for additional current drawn by each of these functions and detailed graphs for other frequency and voltage combinations.

12. Devices initially operating at V<sub>DD</sub> = 2.7 V or above, and at f<sub>OSC</sub> = 10 MHz or less, are guaranteed to continue to execute instructions correctly at the brownout trip point. Initial power-on operation below V<sub>DD</sub> = 2.7 V is not guaranteed.

13. Devices initially operating at  $V_{DD} = 4.0$  V or above and at  $f_{OSC} = 20$  MHz or less are guaranteed to continue to execute instructions correctly at the brownout trip point. Initial power-on operation below  $V_{DD} = 4.0$  V and  $f_{OSC} > 10$  MHz is not guaranteed.

## 87LPC762

# 87LPC762



Figure 38. Shift Register Mode Timing



Figure 39. External Clock Timing



Figure 40. Typical ldd versus frequency (low frequency oscillator, 25°C)



Figure 41. Typical Idd versus frequency (medium frequency oscillator, 25°C)