



#### 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²C, UART/USART                                                         |
| Peripherals                | Brown-out Detect/Reset, LED, POR, WDT                                   |
| Number of I/O              | 14                                                                      |
| 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             | 16-DIP (0.300", 7.62mm)                                                 |
| Supplier Device Package    | 16-DIP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/p87lpc761bn-112 |

Email: info@E-XFL.COM

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

### P87LPC761



### **GENERAL DESCRIPTION**

The P87LPC761 is a 16-pin single-chip microcontroller designed for low pin count applications demanding high-integration, low cost solutions over a wide range of performance requirements. A member of the Philips low pin count family, the P87LPC761 offers programmable oscillator configurations for high and low speed crystals or RC operation, wide operating voltage range, programmable port output configurations, selectable Schmitt trigger inputs, LED drive outputs, and a built-in watchdog timer. The P87LPC761 is based on an accelerated 80C51 processor architecture that executes instructions at twice the rate of standard 80C51 devices.

### FEATURES

- An accelerated 80C51 CPU provides instruction cycle times of 300–600ns for all instructions except multiply and divide when executing at 20 MHz. Execution at up to 20 MHz when V<sub>DD</sub> = 4.5 V to 6.0 V, 10 MHz when V<sub>DD</sub> = 2.7 V to 6.0 V
- 2.7 V to 6.0 V operating range for digital functions
- 2 kbytes EPROM code memory
- 128 byte RAM data memory
- 32-byte customer code EPROM allows serialization of devices, storage of setup parameters, etc
- Two 16-bit counter/timers. One timer may be configured to toggle a port output upon timer overflow
- Two analog comparators
- Full duplex UART
- I<sup>2</sup>C communication port

- Six keypad interrupt inputs, plus two additional external interrupt inputs
- Four interrupt priority levels
- Watchdog timer with separate on-chip oscillator, requiring no external components. The watchdog timeout time is selectable from 8 values
- Active low reset. On-chip power-on reset allows operation with no external reset components
- Low voltage reset. One of two preset low voltage levels may be selected to allow a graceful system shutdown when power fails. May optionally be configured as an interrupt
- Oscillator Fail Detect. The watchdog timer has a separate fully on-chip oscillator, allowing it to perform an oscillator fail detect function
- Configurable on-chip oscillator with frequency range and RC oscillator options (selected by user programmed EPROM bits). The RC oscillator option allows operation with no external oscillator components
- Programmable port output configuration options: quasi-bidirectional, open drain, push-pull, input-only
- Selectable Schmitt trigger port inputs
- LED drive capability (20 mA) on all port pins
- Controlled slew rate port outputs to reduce EMI. Outputs have approximately 10 ns minimum ramp times
- 11 I/O pins minimum. Up to 14 I/O pins using on-chip oscillator and reset options
- Only power and ground connections are required to operate the P87LPC761 when fully on-chip oscillator and reset options are selected
- Serial EPROM programming allows simple in-circuit production coding. Two EPROM security bits prevent reading of sensitive application programs
- Idle and Power Down reduced power modes. Improved wakeup from Power Down mode (a low interrupt input starts execution). Typical Power Down current is 1 μA
- 16-pin DIP and TSSOP packages

|              | Package | Package                                                                |                               |                           |          |  |  |  |  |  |  |  |
|--------------|---------|------------------------------------------------------------------------|-------------------------------|---------------------------|----------|--|--|--|--|--|--|--|
| Type number  | Name    | Description                                                            | Frequency                     | Temperature<br>Range (°C) | Version  |  |  |  |  |  |  |  |
| P87LPC761BDH | TSSOP16 | Plastic thin shrink small outline package; 16 leads; body width 4.4 mm | 20 MHz (5 V),<br>10 MHz (3 V) | 0 to +70                  | SOT403-1 |  |  |  |  |  |  |  |
| P87LPC761BN  | DIP16   | Plastic dual in-line package; 16 leads (300 mil); long body            | 20 MHz (5 V),<br>10 MHz (3 V) | 0 to +70                  | SOT38-1  |  |  |  |  |  |  |  |

### ORDERING INFORMATION

### **BLOCK DIAGRAM**



P87LPC761

### FUNCTIONAL DESCRIPTION

Details of P87LPC761 functions will be described in the following sections.

### Enhanced CPU

The P87LPC761 uses an enhanced 80C51 CPU which runs at twice the speed of standard 80C51 devices. This means that the performance of the P87LPC761 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 P87LPC761 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 PT0AD 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 P87LPC761. 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 comparator 1 and four for comparator 2, 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<sub>DD</sub> 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.

|           | s: ACh for C<br>Addressable | ,     |                                                                                                                                                                | 11 2                      |           |                          |             |            |            | 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. Comparator output is stable 10 microseconds after CEn is first set. |                           |           |                          |             |            |            |                                                              |
| CMPn.4    | CPn                         |       |                                                                                                                                                                |                           |           |                          |             |            |            | ive comparator input. Whe<br>at to 1 in CMP2!                |
| CMPn.3    | CNn                         | the n | egative co                                                                                                                                                     |                           | input. Wł |                          |             |            |            | CMPREF is selected as<br>V <sub>ref</sub> is selected as the |
| CMPn.2    | OEn                         |       |                                                                                                                                                                |                           |           | arator outp<br>asynchron |             |            |            | pin if the comparator is                                     |
| CMPn.1    | COn                         |       |                                                                                                                                                                | itput, synd<br>disabled ( |           |                          | J clock to  | allow rea  | ding by sc | ftware. Cleared when the                                     |
| CMPn.0    | CMFn                        | state | This bit v                                                                                                                                                     | will cause                | a hardwa  |                          | t if enable | d and of s |            | arator output COn change<br>priority. Cleared by             |

Figure 2. Comparator Control Registers (CMP1 and CMP2)

P87LPC761

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



1. Bit CP2 must be set to 1 to enable CIN2B.

Figure 3. Comparator Input and Output Connections



Figure 4. Comparator Configurations

### P87LPC761

### 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 I<sup>2</sup>C subsystem includes hardware to simplify the software required to drive the I<sup>2</sup>C 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 P87LPC761  $I^2C$  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^2C$  specification) and are covered by the low order three bits of timer I. Timer I is clocked by the P87LPC761 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^2C$  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 I<sup>2</sup>C 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 I<sup>2</sup>C bus). This is accomplished by enabling the I<sup>2</sup>C 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.

| D07 |     | 761 |
|-----|-----|-----|
| P0/ | LPC | 101 |

| 2CON                         | Address: | D8h    |       |                                                                                                                                                     |             |              |              |             |                |             | Reset Value: 81h |
|------------------------------|----------|--------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|--------------|-------------|----------------|-------------|------------------|
| Bit 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                          | s        | SYMBOL | FUN   | CTION                                                                                                                                               |             |              |              |             |                |             |                  |
| I2CO                         | DN.7     | RDAT   | Read  | : the mos                                                                                                                                           | t recently  | received of  | data bit.    |             |                |             |                  |
| **                           |          | CXA    | Write | Nrite: clears the transmit active flag.                                                                                                             |             |              |              |             |                |             |                  |
| I2CO                         | DN.6     | ATN    | Read  | Read: ATN = 1 if any of the flags DRDY, ARL, STR, or 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. |             |              |              |             |                |             |                  |
| 12CO                         | DN.5     | DRDY   | Read  | Read: Data Ready flag, set when there is a rising edge on SCL.                                                                                      |             |              |              |             |                |             |                  |
| **                           |          | CDR    | Write | : writing a                                                                                                                                         | 1 to this b | oit clears t | he DRDY      | flag.       |                |             |                  |
| I2CO                         | DN.4     | ARL    | Read  | : Arbitrati                                                                                                                                         | on Loss fla | ag, set wh   | en arbitra   | tion is los | t while in the | e transmit  | mode.            |
| "                            |          | CARL   | Write | : writing a                                                                                                                                         | 1 to this I | oit clears t | he CARL      | flag.       |                |             |                  |
| 12CO                         | DN.3     | STR    | Read  | : Start flag                                                                                                                                        | g, set whe  | n a start o  | condition is | s detected  | d at a maste   | r or non-i  | dle slave.       |
| "                            |          | CSTR   | Write | : writing a                                                                                                                                         | 1 to this I | oit clears t | he STR fl    | ag.         |                |             |                  |
| 12CO                         | DN.2     | STP    | Read  | : Stop flag                                                                                                                                         | g, set whe  | n a stop c   | ondition is  | detected    | l at a maste   | r or non-io | dle slave.       |
| "                            |          | CSTP   | Write | : writing a                                                                                                                                         | 1 to this I | oit clears t | he STP fla   | ag.         |                |             |                  |
| I2CO                         | DN.1 M   | MASTER | Read  | : indicate                                                                                                                                          | s whether   | this devic   | e is curre   | ntly as bu  | s master.      |             |                  |
| "                            |          | XSTR   | Write | Write: writing a 1 to this bit causes a repeated start condition to be generated.                                                                   |             |              |              |             |                |             |                  |
| I2CO                         | DN.0     | _      | Read  | : 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 A | Addressab | le   |                                                                                                                       |   |   |   |                             |   |             |                      |
|       |           |           | 7    | 6                                                                                                                     | 5 | 4 | 3 | 2                           | 1 | 0           |                      |
|       |           | READ      | RDAT | _                                                                                                                     | _ | _ | _ | —                           | _ | _           |                      |
|       |           | WRITE     | XDAT | _                                                                                                                     | _ | _ | _ | _                           | _ | _           |                      |
| Bľ    | т         | SYMBOL    | FUN  | CTION                                                                                                                 |   |   |   |                             |   |             |                      |
| 120   | DAT.7     | RDAT      |      |                                                                                                                       |   |   |   | aptured fro<br>octive state |   | every risir | ng edge of SCL. Read |
|       | "         | XDAT      |      | Write: sets the data for the next transmitted bit. Writing I2DAT also clears DRDY and sets the Transmit Active state. |   |   |   |                             |   |             |                      |
| 120   | DAT.6-0   | -         | Unus | ed.                                                                                                                   |   |   |   |                             |   |             | SU                   |

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

### P87LPC761

### **External Interrupt Inputs**

The P87LPC761 has one individual interrupt input as well as the Keyboard Interrupt function. The latter is described separately in this section. The interrupt input is 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 IT0 in Register TCON. If IT0 = 0, external interrupt 0 is triggered by a detected low at the INT0 pin. If IT0 = 1, external interrupt 0 is edge-triggered. In this mode if successive samples of the INT0 pin show a high in one cycle and a low in the next cycle, interrupt request flag IE0 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 IE0 is set. IE0 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 IE0 when the interrupt is level sensitive, it simply tracks the input pin level.

If an external interrupt is enabled when the P87LPC761 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

### P87LPC761

### I/O Ports

The P87LPC761 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 11 pins of the P87LPC761 may be used as I/Os when a two-pin external oscillator and an external reset circuit are used. Up to 14 pins may be available if fully on-chip oscillator and reset configurations are chosen.

All but three I/O port pins on the P87LPC761 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 P87LPC761 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

P87LPC761

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

| Addre     | ss: A4h       |                                                                                                                                                     |            |             |             |            |            | F        | Reset Value: 00h              |
|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------|-------------|------------|------------|----------|-------------------------------|
| Not Bi    | t Addressable |                                                                                                                                                     |            |             |             |            |            |          |                               |
|           | 7             | 6                                                                                                                                                   | 5          | 4           | 3           | 2          | 1          | 0        |                               |
|           | P2S           | P1S                                                                                                                                                 | P0S        | ENCLK       | _           | ENT0       | (P2M1.1)   | (P2M1.0) |                               |
| BIT       | SYMBOL        | FUNCTION                                                                                                                                            |            |             |             |            |            |          |                               |
| P2M1.7    | P2S           | When P2S =                                                                                                                                          | 1, this bi | t enables S | chmitt trig | ger inputs | on Port 2. |          |                               |
| P2M1.6    | P1S           | When P1S =                                                                                                                                          | 1, this bi | t enables S | chmitt trig | ger inputs | on Port 1. |          |                               |
| P2M1.5    | P0S           | When P0S =                                                                                                                                          | 1, this bi | t enables S | chmitt trig | ger inputs | on Port 0. |          |                               |
| P2M1.4    | ENCLK         | When ENCL output is ena                                                                                                                             |            |             |             |            |            |          | oscillator, a clock<br>ails.  |
| P2M1.3    | —             | Reserved. M                                                                                                                                         | lust be 0. |             |             |            |            |          |                               |
| P2M1.2    | ENT0          | When set, th<br>one half of th                                                                                                                      |            |             |             |            |            |          | equency is therefore details. |
| P2M1.1, P | 2M1.0 —       | These bits, along with the matching bits in the P2M2 register, control the output configuration of P2.1 and P2.0 respectively, as shown in Table 4. |            |             |             |            |            |          |                               |
|           |               |                                                                                                                                                     |            |             |             |            |            |          | SU01571                       |

Figure 13. Port 2 Mode Register 1 (P2M1)

### Keyboard Interrupt (KBI)

The Keyboard Interrupt function is intended primarily to allow a single interrupt to be generated when any key is pressed on a keyboard or keypad connected to specific pins of the P87LPC761, as shown in Figure 14. This interrupt may be used to wake up the CPU from Idle or Power Down modes. This feature is particularly useful in handheld, battery powered systems that need to carefully manage power consumption yet also need to be convenient to use.

The P87LPC761 allows any or all pins of port 0 to be enabled to cause this interrupt. Port pins are enabled by the setting of bits in

the KBI register, as shown in Figure 15. The Keyboard Interrupt Flag (KBF) in the AUXR1 register is set when any enabled pin is pulled low while the KBI interrupt function is active. An interrupt will be generated if it has been enabled. Note that the KBF bit must be cleared by software.

Due to human time scales and the mechanical delay associated with keyswitch closures, the KBI feature will typically allow the interrupt service routine to poll port 0 in order to determine which key was pressed, even if the processor has to wake up from Power Down mode. Refer to the section on Power Reduction Modes for details.

### P87LPC761

### Oscillator

The P87LPC761 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

#### Low Frequency Oscillator Option

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

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.

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  | Frequency Lower Limit |                         | 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. 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 VDD is above 4.5 V and up to 10 MHz when VDD 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 P87LPC761 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 P87LPC761. 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.

### P87LPC761

#### Low Voltage EPROM Operation

The EPROM array contains some analog circuits that are not required when  $V_{DD}$  is less than 4 V, but are required for a  $V_{DD}$  greater than 4 V. The LPEP bit (AUXR.4), when set by software, will power down these analog circuits resulting in a reduced supply current. LPEP is cleared only by power-on reset, so it may be set ONLY for applications that always operate with  $V_{DD}$  less than 4 V.

### Reset

The P87LPC761 has an integrated power-on reset circuit which always provides a reset when power is initially applied to the device. It is recommended to use the internal reset whenever possible to save external components and to be able to use pin P1.5 as a general-purpose input pin.

The P87LPC761 can additionally be configured to use P1.5 as an external active-low reset pin  $\overline{\text{RST}}$  by programming the RPD bit in the User Configuration Register UCFG1 to 0. The internal reset is still active on power-up of the device. While the signal on the  $\overline{\text{RST}}$  pin is low, the P87LPC761 is held in reset until the signal goes high.

The watchdog timer on the P87LPC761 can act as an oscillator fail detect because it uses an independent, fully on-chip oscillator.

UCFG1 is described in the System Configuration Bytes section of this datasheet.



Figure 20. Using pin P1.5 as general purpose input pin or as low-active reset pin



Figure 21. Block Diagram Showing Reset Sources

### P87LPC761

#### **Baud Rates**

The baud rate in Mode 0 is fixed: Mode 0 Baud Rate = CPU clock/6. The baud rate in Mode 2 depends on the value of bit SMOD1 in Special Function Register PCON. If SMOD1 = 0 (which is the value on reset), the baud rate is 1/32 of the CPU clock frequency. If SMOD1 = 1, the baud rate is 1/16 of the CPU clock frequency.

Mode 2 Baud Rate = 
$$\frac{1 + \text{SMOD1}}{32}$$
 x CPU clock frequency

#### Using Timer 1 to Generate Baud Rates

When Timer 1 is used as the baud rate generator, the baud rates in Modes 1 and 3 are determined by the Timer 1 overflow rate and the value of SMOD1. The Timer 1 interrupt should be disabled in this application. The Timer itself can be configured for either "timer" or "counter" operation, and in any of its 3 running modes. In the most typical applications, it is configured for "timer" operation, in the auto-reload mode (high nibble of TMOD = 0010b). In that case the baud rate is given by the formula:

Mode 1, 3 Baud Rate = 
$$\frac{\begin{array}{c} \text{CPU clock frequency/} \\ 192 \text{ (or 96 if SMOD1 = 1)} \\ \hline 256 - \text{ (TH1)} \end{array}$$

Tables 9 and 10 list various commonly used baud rates and how they can be obtained using Timer 1 as the baud rate generator.

### Table 9. Baud Rates, Timer Values, and CPU Clock Frequencies for SMOD1 = 0

| Timer Count |          |          | Baud      | Rate      |           |           |
|-------------|----------|----------|-----------|-----------|-----------|-----------|
| Timer Count | 2400     | 4800     | 9600      | 19.2k     | 38.4k     | 57.6k     |
| -1          | 0.4608   | 0.9216   | * 1.8432  | * 3.6864  | * 7.3728  | * 11.0592 |
| -2          | 0.9216   | 1.8432   | * 3.6864  | * 7.3728  | * 14.7456 |           |
| -3          | 1.3824   | 2.7648   | 5.5296    | * 11.0592 | -         | -         |
| -4          | * 1.8432 | * 3.6864 | * 7.3728  | * 14.7456 | -         | -         |
| -5          | 2.3040   | 4.6080   | 9.2160    | * 18.4320 | -         | -         |
| -6          | 2.7648   | 5.5296   | * 11.0592 | -         | -         | -         |
| -7          | 3.2256   | 6.4512   | 12.9024   | -         | -         | -         |
| -8          | * 3.6864 | * 7.3728 | * 14.7456 | -         | -         | -         |
| -9          | 4.1472   | 8.2944   | 16.5888   | -         | -         | _         |
| -10         | 4.6080   | 9.2160   | * 18.4320 | -         | -         | _         |

### P87LPC761

#### 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 32 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 P87LPC761 the baud rate is determined by the Timer 1 overflow rate. Figure 33 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.

### P87LPC761



Figure 35. Serial Port Mode 3

#### Automatic Address Recognition

Automatic Address Recognition is a feature which allows the UART to recognize certain addresses in the serial bit stream by using hardware to make the comparisons. This feature saves a great deal of software overhead by eliminating the need for the software to examine every serial address which passes by the serial port. This feature is enabled by setting the SM2 bit in SCON. In the 9 bit UART modes, mode 2 and mode 3, the Receive Interrupt flag (RI) will be automatically set when the received byte contains either the "Given" address or the "Broadcast" address. The 9 bit mode requires that the 9th information bit is a 1 to indicate that the received information is an address and not data.

Using the Automatic Address Recognition feature allows a master to selectively communicate with one or more slaves by invoking the Given slave address or addresses. All of the slaves may be contacted by using the Broadcast address. Two special Function Registers are used to define the slave's address, SADDR, and the address mask, SADEN. SADEN is used to define which bits in the SADDR are to be used and which bits are "don't care". The SADEN mask can be logically ANDed with the SADDR to create the "Given" address which the master will use for addressing each of the slaves. Use of the Given address allows multiple slaves to be recognized while excluding others. The following examples will help to show the versatility of this scheme:

| Slave 0 | SADDR<br>SADEN<br>Given | = 1100 0000<br>= <u>1111 1101</u><br>= 1100 00X0 |
|---------|-------------------------|--------------------------------------------------|
| Slave 1 | SADDR<br>SADEN<br>Given | = 1100 0000<br>= <u>1111 1110</u><br>= 1100 000X |

In the above example SADDR is the same and the SADEN data is used to differentiate between the two slaves. Slave 0 requires a 0 in bit 0 and it ignores bit 1. Slave 1 requires a 0 in bit 1 and bit 0 is ignored. A unique address for Slave 0 would be 1100 0010 since slave 1 requires a 0 in bit 1. A unique address for slave 1 would be 1100 0001 since a 1 in bit 0 will exclude slave 0. Both slaves can be selected at the same time by an address which has bit 0 = 0 (for slave 0) and bit 1 = 0 (for slave 1). Thus, both could be addressed with 1100 0000.

In a more complex system the following could be used to select slaves 1 and 2 while excluding slave 0:

| Slave 0 | SADDR<br>SADEN<br>Given | = 1100 0000<br>= <u>1111 1001</u><br>= 1100 0XX0 |
|---------|-------------------------|--------------------------------------------------|
| Slave 1 | SADDR<br>SADEN<br>Given | = 1110 0000<br>= <u>1111 1010</u><br>= 1110 0X0X |
| Slave 2 | SADDR<br>SADEN<br>Given | = 1110 0000<br>= <u>1111 1100</u><br>= 1110 00XX |

In the above example the differentiation among the 3 slaves is in the lower 3 address bits. Slave 0 requires that bit 0 = 0 and it can be uniquely addressed by 1110 0110. Slave 1 requires that bit 1 = 0 and it can be uniquely addressed by 1110 and 0101. Slave 2 requires that bit 2 = 0 and its unique address is 1110 0011. To select Slaves 0 and 1 and exclude Slave 2 use address 1110 0100, since it is necessary to make bit 2 = 1 to exclude slave 2. The Broadcast Address for each slave is created by taking the logical OR of SADDR and SADEN. Zeros in this result are treated as don't-cares. In most cases, interpreting the don't-cares as ones, the broadcast address

### P87LPC761

will be FF hexadecimal. Upon reset SADDR and SADEN are loaded with 0s. This produces a given address of all "don't cares" as well as a Broadcast address of all "don't cares". This effectively disables the Automatic Addressing mode and allows the microcontroller to use standard UART drivers which do not make use of this feature.

### Watchdog Timer

When enabled via the WDTE configuration bit, the watchdog timer is operated from an independent, fully on-chip oscillator in order to provide the greatest possible dependability. When the watchdog feature is enabled, the timer must be fed regularly by software in order to prevent it from resetting the CPU, and it **cannot** be turned off. When disabled as a watchdog timer (via the WDTE bit in the UCFG1 configuration register), it may be used as an interval timer and may generate an interrupt. The watchdog timer is shown in Figure 36.

The watchdog timeout time is selectable from one of eight values, nominal times range from 25 milliseconds to 3.2 seconds. The frequency tolerance of the independent watchdog RC oscillator is  $\pm$ 37%. The timeout selections and other control bits are shown in Figure 37. When the watchdog function is enabled, the WDCON register may be written <u>once</u> during chip initialization in order to set the watchdog timeout time. The recommended method of initializing the WDCON register is to first feed the watchdog, then write to WDCON to configure the WDS2–0 bits. Using this method, the watchdog initialization may be done any time within 10 milliseconds after startup without a watchdog overflow occurring before the initialization can be completed.

Since the watchdog timer oscillator is fully on-chip and independent of any external oscillator circuit used by the CPU, it intrinsically serves as an oscillator fail detection function. If the watchdog feature is enabled and the CPU oscillator fails for any reason, the watchdog timer will time out and reset the CPU.

When the watchdog function is enabled, the timer is deactivated temporarily when a chip reset occurs from another source, such as a power on reset, brownout reset, or external reset.

### Watchdog Feed Sequence

If the watchdog timer is running, it must be fed before it times out in order to prevent a chip reset from occurring. The watchdog feed sequence consists of first writing the value 1Eh, then the value E1h to the WDRST register. An example of a watchdog feed sequence is shown below.

```
WDFeed:
  mov WDRST,#leh ; First part of watchdog feed sequence.
  mov WDRST,#0elh ; Second part of watchdog feed sequence.
```

The two writes to WDRST do not have to occur in consecutive instructions. An incorrect watchdog feed sequence does not cause any immediate response from the watchdog timer, which will still time out at the originally scheduled time if a correct feed sequence does not occur prior to that time.

After a chip reset, the user program has a limited time in which to either feed the watchdog timer or change the timeout period. When a low CPU clock frequency is used in the application, the number of instructions that can be executed before the watchdog overflows may be quite small.

#### Watchdog Reset

If a watchdog reset occurs, the internal reset is active for approximately one microsecond. If the CPU clock was still running, code execution will begin immediately after that. If the processor was in Power Down mode, the watchdog reset will start the oscillator and code execution will resume after the oscillator is stable.

### P87LPC761



Figure 36. Block Diagram of the Watchdog Timer

| WDCON Address: A7h | Reset Value: • 30                                      | )h for a watchdog res                                                                                                                                                                                                              | et.                    |                            |                    |  |
|--------------------|--------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----------------------------|--------------------|--|
| Not Bit Addressa   | ble • 10                                               | )h for other rest sour                                                                                                                                                                                                             | ces if the watchdog is | enabled via the WDTE co    | onfiguration bit.  |  |
|                    | • 00                                                   | )h for other reset sou                                                                                                                                                                                                             | rces if the watchdog   | is disabled via the WDTE   | configuration bit. |  |
| -                  | 765                                                    | 4 3                                                                                                                                                                                                                                | 2 1                    | 0                          |                    |  |
| -                  | – – WDOVF                                              | WDRUN WDCLK                                                                                                                                                                                                                        | WDS2 WDS1              | WDS0                       |                    |  |
|                    |                                                        |                                                                                                                                                                                                                                    |                        |                            |                    |  |
| BIT SYMBO          |                                                        |                                                                                                                                                                                                                                    |                        |                            |                    |  |
| WDCON.7, 6 —       | Reserved for futur                                     | e use. Should not be                                                                                                                                                                                                               | set to 1 by user prog  | rams.                      |                    |  |
| WDCON.5 WDOV       | <pre>/F Watchdog timer ov<br/>the watchdog is fe</pre> |                                                                                                                                                                                                                                    | a watchdog reset or    | timer overflow occurs. Clo | eared when         |  |
| WDCON.4 WDRU       |                                                        | Watchdog run control. The watchdog timer is started when WDRUN = 1 and stopped when WDRUN = 0. This bit is forced to 1 (watchdog running) if the WDTE configuration bit = 1.                                                       |                        |                            |                    |  |
| WDCON.3 WDCL       | the watchdog RC                                        | Watchdog clock select. The watchdog timer is clocked by CPU clock/6 when WDCLK = 1 and by the watchdog RC oscillator when WDCLK = 0. This bit is forced to 0 (using the watchdog RC oscillator) if the WDTE configuration bit = 1. |                        |                            |                    |  |
| WDCON.2-0 WDS2-    | -0 Watchdog rate sel                                   | ect.                                                                                                                                                                                                                               |                        |                            |                    |  |
| WDS2-              | -0 Timeout Clocks                                      | Minimum Time                                                                                                                                                                                                                       | Nominal Time           | e <u>Maximum Time</u>      |                    |  |
| 0 0 0              | 8,192                                                  | 10 ms                                                                                                                                                                                                                              | 16 ms                  | 23 ms                      |                    |  |
| 0 0 1              | 16,384                                                 | 20 ms                                                                                                                                                                                                                              | 32 ms                  | 45 ms                      |                    |  |
| 010                | 32,768                                                 | 41 ms                                                                                                                                                                                                                              | 65 ms                  | 90 ms                      |                    |  |
| 011                | 65,536                                                 | 82 ms                                                                                                                                                                                                                              | 131 ms                 | 180 ms                     |                    |  |
| 100                | 131,072                                                | 165 ms                                                                                                                                                                                                                             | 262 ms                 | 360 ms                     |                    |  |
| 101                | 262,144                                                | 330 ms                                                                                                                                                                                                                             | 524 ms                 | 719 ms                     |                    |  |
| 110                | 524,288                                                | 660 ms                                                                                                                                                                                                                             | 1.05 sec               | 1.44 sec                   |                    |  |
| 111                | ,                                                      | 1.3 sec                                                                                                                                                                                                                            | 2.1 sec                | 2.9 sec                    |                    |  |
|                    | .,                                                     |                                                                                                                                                                                                                                    |                        |                            | SU01634            |  |

Figure 37. Watchdog Timer Control Register (WDCON)

### P87LPC761

### Additional Features

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

#### 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 P87LPC761 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.

| XR1 Addres | s: A2h<br>Addressable |      |                                                                                                                                                                                                                  |            |                         |             |          |              |             | Reset Value: (          |
|------------|-----------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------------------|-------------|----------|--------------|-------------|-------------------------|
| NUL DI     | Audressable           | ;    |                                                                                                                                                                                                                  |            |                         |             |          |              |             |                         |
|            | _                     | 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 |             |          | t is enabled | for the Key | board 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  | Brown Out Interrupt. When set, prevents brownout detection from causing a chip reset and allows the brownout detect function to be used as an interrupt. See the Power Monitoring Functions section for details. |            |                         |             |          |              |             |                         |
| AUXR1.4    | LPEP                  |      | Low Power EPROM control bit. Allows power savings in low voltage systems. Set by software. Can only be cleared by power-on or brownout reset. See the Power Reduction Modes section for details.                 |            |                         |             |          |              |             |                         |
| AUXR1.3    | SRST                  | Soft | Software Reset. When set by software, resets the 87LPC761 as if a hardware reset occurred.                                                                                                                       |            |                         |             |          |              |             |                         |
| AUXR1.2    | —                     |      | This bit contains a hard-wired 0. Allows toggling of the DPS bit by incrementing AUXR1, without interfering with other bits in the register.                                                                     |            |                         |             |          |              |             |                         |
| AUXR1.1    | —                     | Res  | Reserved for future use. Should not be set to 1 by user programs.                                                                                                                                                |            |                         |             |          |              |             |                         |
| AUXR1.0    | DPS                   | Data | a Pointer                                                                                                                                                                                                        | Select. Ch | ooses one o             | of two Data | Pointers | for use by   | the program | . See text for details. |
|            |                       |      |                                                                                                                                                                                                                  |            |                         |             |          |              |             | SU01576                 |

### Figure 38. AUXR1 Register

### P87LPC761

### COMPARATOR ELECTRICAL CHARACTERISTICS

 $V_{DD}$  = 3.0 V to 6.0 V unless otherwise specified;  $T_{amb}$  = 0 °C to +70 °C, unless otherwise specified.

| SYMBOL          | PARAMETER                                     | TEST CONDITIONS       |     | UNIT |                     |      |
|-----------------|-----------------------------------------------|-----------------------|-----|------|---------------------|------|
| STMBOL          | PARAMETER                                     | TEST CONDITIONS       | MIN | TYP  | MAX                 | UNIT |
| V <sub>IO</sub> | Offset voltage comparator inputs <sup>1</sup> |                       | -   | -    | ±10                 | mV   |
| V <sub>CR</sub> | Common mode range comparator inputs           |                       | 0   | -    | V <sub>DD</sub> 0.3 | V    |
| CMRR            | Common mode rejection ratio <sup>1</sup>      |                       | -   | -    | -50                 | dB   |
|                 | Response time                                 |                       | -   | 250  | 500                 | ns   |
|                 | Comparator enable to output valid             |                       | -   | -    | 10                  | μs   |
| ١ <sub>١L</sub> | Input leakage current, comparator             | $0 < V_{IN} < V_{DD}$ | -   | -    | ±10                 | μΑ   |

NOTE:

1. This parameter is guaranteed by characterization, but not tested in production.

### **AC ELECTRICAL CHARACTERISTICS**

 $T_{amb}$  = 0 °C to +70 °C,  $V_{DD}$  = 2.7 V to 6.0 V unless otherwise specified;  $V_{SS}$  = 0 V<sup>1, 2, 3</sup>

|                   | FIGURE     |                                                                                     |                            |                       |      |     |
|-------------------|------------|-------------------------------------------------------------------------------------|----------------------------|-----------------------|------|-----|
| SYMBOL            | FIGURE     | PARAMETER                                                                           | MIN                        | MAX                   | UNIT |     |
| External Cl       | ock        | •                                                                                   |                            |                       | -    |     |
| f <sub>C</sub>    | 42         | Oscillator frequency ( $V_{DD} = 4.0 \text{ V}$ to 6.0 V)                           |                            | 0                     | 20   | MHz |
| f <sub>C</sub>    | 42         | Oscillator frequency ( $V_{DD} = 2.7 \text{ V to } 6.0 \text{ V}$ )                 |                            | 0                     | 10   | MHz |
| t <sub>C</sub>    | 42         | Clock period and CPU timing cycle                                                   |                            | 1/f <sub>C</sub>      | -    | ns  |
| f <sub>CLCX</sub> | 42         | Clock low-time <sup>1</sup>                                                         | f <sub>OSC</sub> = 20 MHz  | 20                    | -    | ns  |
| f <sub>CLCX</sub> | 42         | 1                                                                                   | f <sub>OSC</sub> = 10 MHz  | 40                    | -    | ns  |
| f <sub>CHCX</sub> | 42         | Clock high-time <sup>1</sup>                                                        | f <sub>OSC</sub> = 20 MHz  | 20                    | -    | ns  |
| f <sub>CHCX</sub> | 42         | 1                                                                                   | 40                         | -                     | ns   |     |
| Internal RC       | Oscillator | •                                                                                   |                            |                       | -    |     |
| f <sub>CCAL</sub> |            | On-chip RC oscillator calibration <sup>2</sup>                                      | f <sub>RCOSC</sub> = 6 MHz | -1                    | +1   | %   |
| fctol             |            | On-chip RC oscillator, 0 °C to +50 °C <sup>3,4</sup> tol.                           | f <sub>RCOSC</sub> = 6 MHz | -2.5                  | +2.5 | %   |
| f <sub>CTOL</sub> |            | On-chip RC oscillator, 0 °C to +70 °C <sup>3</sup> tol. $f_{RCOSC} = 6 \text{ MHz}$ |                            | -5 <sup>5</sup>       | +2.5 | %   |
| Shift Regist      | er         | •                                                                                   |                            |                       | -    |     |
| t <sub>XLXL</sub> | 41         | Serial port clock cycle time                                                        |                            | 6t <sub>C</sub>       | -    | ns  |
| t <sub>QVXH</sub> | 41         | Output data setup to clock rising edge                                              |                            | 5t <sub>C</sub> – 133 | -    | ns  |
| t <sub>XHQX</sub> | 41         | Output data hold after clock rising edge                                            | 1t <sub>C</sub> - 80       | -                     | ns   |     |
| t <sub>XHDV</sub> | 41         | Input data setup to clock rising edge                                               | -                          | 5t <sub>C</sub> – 133 | ns   |     |
| t <sub>XHDX</sub> | 41         | Input data hold after clock rising edge                                             | 0                          | -                     | ns   |     |

#### NOTES:

1. Applies only to an external clock source, not when a crystal is connected to the X1 and X2 pins.

2. Tested at  $V_{DD} = 5.0$  V and room temperature.

3. These parameters are characterized but not tested.

4. +/- 2.5% accuracy enables serial communication over the UART with the internal Oscillator.

5. Min frequency at hot temperature.



Figure 45. Typical ldd versus frequency (high frequency oscillator, 25°C)



Figure 46. Typical Active Idd versus frequency (external clock, 25°C, LPEP=0)



Figure 47. Typical Active Idd versus frequency (external clock, 25°C, LPEP=1)



Figure 48. Typical Idle Idd versus frequency (external clock, 25°C, LPEP=1)



Figure 49. Typical Idle Idd versus frequency (external clock,  $25^{\circ}\text{C}, \text{LPEP=0})$ 

## P87LPC761

### **REVISION HISTORY**

| Date        | CPCN           | Description     |
|-------------|----------------|-----------------|
| 2002 Mar 07 | 9397 750 09533 | Initial release |

### P87LPC761