## INTEGRATED CIRCUITS



Preliminary data

2002 Mar 21





| GENERAL DESCRIPTION                      | 1  |
|------------------------------------------|----|
| ORDERING INFORMATION                     | 1  |
| PINNING INFORMATION                      | 1  |
| LOGIC SYMBOL                             | 2  |
| BLOCK DIAGRAM                            | 3  |
| PIN DESCRIPTION                          | 5  |
| SPECIAL FUNCTION REGISTERS               | 6  |
| FUNCTIONAL DESCRIPTION                   | 8  |
| Enhanced CPU                             | 8  |
| Interrupts                               | 8  |
| External Interrupt Inputs                | 9  |
| I/O Ports                                | 10 |
| Quasi-Bidirectional Output Configuration | 10 |
| Open Drain Output Configuration          | 11 |
| Push-Pull Output Configuration           | 11 |
| Keyboard Interrupt (KBI)                 | 12 |
| Oscillator                               | 14 |
| Low Frequency Oscillator Option          | 14 |
| Medium Frequency Oscillator Option       | 14 |
| High Frequency Oscillator Option         | 14 |
| On-Chip RC Oscillator Option             | 14 |
| External Clock Input Option              | 14 |
| Clock Output                             | 14 |
| CPU Clock Modification: CLKR and DIVM    | 16 |
| Power Monitoring Functions               | 16 |
| Brownout Detection                       | 16 |
| Power On Detection                       | 17 |
| Power Reduction Modes                    | 17 |
| Idle Mode                                | 17 |
| Power Down Mode                          | 17 |
| Low Voltage EPROM Operation              | 19 |
| Reset                                    | 19 |
| Timer/Counters                           | 20 |
| Mode 0                                   | 20 |
| Mode 1                                   | 21 |
| Mode 2                                   | 22 |
|                                          |    |
| Mode 3                                   | 22 |
| Timer Overflow Toggle Output             | 24 |
| Watchdog Timer                           | 24 |
| Watchdog Feed Sequence                   | 24 |
| Watchdog Reset                           | 24 |
| Additional Features                      | 26 |
| Software Reset                           | 26 |
| Dual Data Pointers                       | 26 |
| EPROM Characteristics                    | 27 |
| System Configuration Bytes               | 27 |
| Security Bits                            | 28 |
|                                          | 29 |
|                                          | 30 |
|                                          | 31 |
| REVISION HISTORY                         | 35 |

## P87LPC759

### **GENERAL DESCRIPTION**

The P87LPC759 is a 14-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 P87LPC759 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 P87LPC759 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–600 ns 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
- 1 kbyte EPROM code memory
- 64 byte RAM data memory
- Two 16-bit counter/timers. One timer may be configured to toggle a port output upon timer overflow
- Four keypad interrupt inputs, plus one additional external interrupt input
- 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
- Nine I/O pins minimum. Up to 12 I/O pins using on-chip oscillator and reset options
- Only power and ground connections are required to operate the P87LPC759 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
- 14-pin DIP package

### **ORDERING INFORMATION**

| Part Number | Temperature Range $^\circ$ C and Package                   | Frequency                     | Drawing Number |
|-------------|------------------------------------------------------------|-------------------------------|----------------|
| P87LPC759BN | 0 to +70, plastic dual in-line package; 14 leads (300 mil) | 20 MHz (5 V),<br>10 MHz (3 V) | SOT27-1        |

### PINNING INFORMATION



## P87LPC759

### LOGIC SYMBOL



### **BLOCK DIAGRAM**





 The P87LPC759 does not support access to external data memory. However, the User Configuration Bytes are accessed via the MOV instruction as if they were in external data memory.

Figure 1. P87LPC759 Program and Data Memory Map

### P87LPC759

### **PIN DESCRIPTION**

| MNEMONIC                | PIN NO.    | TYPE |                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | NAME AND FUNCTION                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|-------------------------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| P0.3-P0.6               | 10, 12–14  | I/O  | figured in the<br>reset, as det<br>0 pins as inp<br>configured in                                                                                                                                                                                                                     | <b>Port 0:</b> Port 0 is a 4-bit I/O port with a user-configurable output type. Port 0 latches are con-<br>figured in the quasi-bidirectional mode and have either ones or zeros written to them during<br>reset, as determined by the PRHI bit in the UCFG1 configuration byte. The operation of port<br>0 pins as inputs and outputs depends upon the port configuration selected. Each port pin is<br>configured independently. Refer to the section on I/O port configuration and the DC Electri-<br>cal Characteristics for details.                                                            |                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|                         |            |      | The Keyboa                                                                                                                                                                                                                                                                            | The Keyboard Interrupt feature operates with port 0 pins.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| P1.0–P1.3<br>P1.5, P1.7 | 1–2<br>6–9 | I/O  | as noted bel<br>ther ones or<br>configuration<br>pends upon<br>grammed in                                                                                                                                                                                                             | <b>Port 1:</b> Port 1 is an 6-bit I/O port with a user-configurable output type, except for three pins as noted below. Port 1 latches are configured in the quasi-bidirectional mode and have either ones or zeros written to them during reset, as determined by the PRHI bit in the UCFG1 configuration byte. The operation of the configurable port 1 pins as inputs and outputs depends upon the port configuration selected. Each of the configurable port pins are programmed independently. Refer to the section on I/O port configuration and the DC Electrical Characteristics for details. |                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|                         |            |      | Port 1 also provides various special functions as described below.                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|                         | 7          | I/O  | P1.2 T0 Timer/counter 0 external count input or overflow output.                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|                         |            | 0    |                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | When configured as an output, P1.2 is open drain.                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|                         | 6          | I    | P1.3                                                                                                                                                                                                                                                                                  | INT0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | External interrupt 0 input.                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|                         |            | 0    |                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | When configured as an output, P1.3 is open drain.                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|                         | 2          | Ι    | P1.5 RST External Reset input (if selected via EPROM configuration low on this pin resets the microcontroller, causing I/O ports peripherals to take on their default states, and the process begins execution at address 0. When used as a port pin, F a Schmitt trigger input only. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| P2.0-P2.1               | 4, 5       | I/O  | figured in the<br>reset, as det<br>2 pins as inp<br>configured in                                                                                                                                                                                                                     | e quasi-bidired<br>termined by th<br>outs and outpu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | D port with a user-configurable output type. Port 2 latches are con-<br>ctional mode and have either ones or zeros written to them during<br>the PRHI bit in the UCFG1 configuration byte. The operation of port<br>uts depends upon the port configuration selected. Each port pin is<br>Refer to the section on I/O port configuration and the DC Electri-<br>ails. |  |  |  |  |  |  |
|                         |            |      | Port 2 also p                                                                                                                                                                                                                                                                         | provides vario                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | us special functions as described below.                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
|                         | 5          | 0    | P2.0                                                                                                                                                                                                                                                                                  | X2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Output from the oscillator amplifier (when a crystal oscillator option is selected via the EPROM configuration).                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|                         |            |      |                                                                                                                                                                                                                                                                                       | CLKOUT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | CPU clock divided by 6 clock output when enabled via SFR bit<br>and in conjunction with internal RC oscillator or external clock<br>input.                                                                                                                                                                                                                            |  |  |  |  |  |  |
|                         | 4          | Ι    | P2.1                                                                                                                                                                                                                                                                                  | X1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Input to the oscillator circuit and internal clock generator circuits (when selected via the EPROM configuration).                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| V <sub>SS</sub>         | 3          | I    | Ground: 0                                                                                                                                                                                                                                                                             | V reference.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| V <sub>DD</sub>         | 11         | I    | Power Sup<br>Power Dowr                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | e power supply voltage for normal operation as well as Idle and                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |

### SPECIAL FUNCTION REGISTERS

| Name                                                                                                                                             | Description                       | SFR<br>Address | M        | SB        | Bit Fu    | inctions a | nd Addre  | esses   | L         | SB        | Rese<br>Valu     |
|--------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|----------------|----------|-----------|-----------|------------|-----------|---------|-----------|-----------|------------------|
|                                                                                                                                                  |                                   |                | E7       | E6        | E5        | E4         | E3        | E2      | E1        | E0        |                  |
| ACC*                                                                                                                                             | Accumulator                       | E0h            |          |           |           |            |           |         |           |           | 00h              |
| AUXR1#                                                                                                                                           | Auxiliary Function Register       | A2h            | KBF      | BOD       | BOI       | LPEP       | SRST      | 0       | -         | DPS       | 02h <sup>1</sup> |
|                                                                                                                                                  |                                   |                | F7       | F6        | F5        | F4         | F3        | F2      | F1        | F0        |                  |
| B*                                                                                                                                               | B register                        | F0h            |          |           |           |            |           |         |           |           | 00h              |
| DIVM#                                                                                                                                            | CPU clock divide-by-M<br>control  | 95h            |          |           |           |            |           |         |           |           | 00h              |
| DPTR:                                                                                                                                            | Data pointer (2 bytes)            |                |          |           |           |            |           |         |           |           |                  |
| DPH                                                                                                                                              | Data pointer high byte            | 83h            |          |           |           |            |           |         |           |           | 00h              |
| DPL                                                                                                                                              | Data pointer low byte             | 82h            |          |           |           |            |           |         |           |           | 00h              |
|                                                                                                                                                  |                                   |                | DF       | DE        | DD        | DC         | DB        | DA      | D9        | D8        |                  |
|                                                                                                                                                  |                                   |                | AF       | AE        | AD        | AC         | AB        | AA      | A9        | A8        |                  |
| EN0*                                                                                                                                             | Interrupt enable 0                | A8h            | EA       | EWD       | EBO       | -          | ET1       | _       | ET0       | EX0       | 00h              |
|                                                                                                                                                  |                                   | 501            | EF       | EE        | ED        | EC         | EB        | EA      | E9        | E8        |                  |
| IEN1#*                                                                                                                                           | Interrupt enable 1                | E8h            | -        | -         | -         | -          | -         | _       | EKB       | -         | 00h <sup>1</sup> |
| IP0*                                                                                                                                             | Interrupt priority 0              | B8h            | BF<br>–  | BE<br>PWD | BD<br>PBO | BC         | BB<br>PT1 | BA<br>_ | B9<br>PT0 | B8<br>PX0 | 00h <sup>1</sup> |
| IP0H#                                                                                                                                            | Interrupt priority 0 high         | B7h            | _        | PWDH      | РВОН      | -          | PT1H      |         | PTOH      | PX0H      | 00h <sup>1</sup> |
| г0п#                                                                                                                                             | byte                              | ВЛП            | _        |           |           |            | FIIN      |         |           | FAUN      | 001              |
|                                                                                                                                                  |                                   |                | FF       | FE        | FD        | FC         | FB        | FA      | F9        | F8        |                  |
| P1*                                                                                                                                              | Interrupt priority 1              | F8h            | _        | -         | -         | -          | -         | -       | PKB       | -         | 00h              |
| P1H#                                                                                                                                             | Interrupt priority 1 high<br>byte | F7h            | -        | -         | -         | -          | -         | -       | PKBH      | -         | 00h              |
| <bi#< td=""><td>Keyboard Interrupt</td><td>86h</td><td></td><td></td><td></td><td></td><td></td><td>L</td><td>,</td><td></td><td>00h</td></bi#<> | Keyboard Interrupt                | 86h            |          |           |           |            |           | L       | ,         |           | 00h              |
|                                                                                                                                                  |                                   |                | 87       | 86        | 85        | 84         | 83        | 82      | 81        | 80        |                  |
| P0*                                                                                                                                              | Port 0                            | 80h            | -        | -         | -         | -          | -         | -       | -         | -         | Note             |
|                                                                                                                                                  |                                   |                | 97       | 96        | 95        | 94         | 93        | 92      | 91        | 90        | ]                |
| P1*                                                                                                                                              | Port 1                            | 90h            | (P1.7)   | -         | RST       | -          | INT0      | T0      | _         | -         | Note             |
|                                                                                                                                                  |                                   |                | A7       | A6        | A5        | A4         | A3        | A2      | A1        | A0        |                  |
| P2*                                                                                                                                              | Port 2                            | A0h            | -        | -         | -         | -          | -         | -       | X1        | X2        | Note             |
| P0M1#                                                                                                                                            | Port 0 output mode 1              | 84h            | -        | (P0M1.6)  | (P0M1.5)  | (P0M1.4)   | (P0M1.3)  | _       | -         | -         | 001              |
| P0M2#                                                                                                                                            | Port 0 output mode 2              | 85h            | -        | (P0M2.6)  | (P0M2.5)  | (P0M2.4)   | (P0M2.3)  | -       | -         | -         | 00ł              |
| P1M1#                                                                                                                                            | Port 1 output mode 1              | 91h            | (P1M1.7) | -         | -         | -          | -         | -       | (P1M1.1)  | (P1M1.0)  | 00h              |
| P1M2#                                                                                                                                            | Port 1 output mode 2              | 92h            | (P1M2.7) | -         | -         | -          | -         | -       | (P1M2.1)  | (P1M2.0)  | 00h              |
| P2M1#                                                                                                                                            | Port 2 output mode 1              | A4h            | P2S      | P1S       | P0S       | ENCLK      | -         | T0OE    | (P2M1.1)  | (P2M1.0)  | 00ł              |
| P2M2#                                                                                                                                            | Port 2 output mode 2              | A5h            | -        | -         | -         | -          | -         | _       | (P2M2.1)  | (P2M2.0)  | 00h              |
| PCON                                                                                                                                             | Power control register            | 87h            | SMOD1    | SMOD0     | BOF       | POF        | GF1       | GF0     | PD        | IDL       | Note             |
|                                                                                                                                                  |                                   |                | D7       | D6        | D5        | D4         | D3        | D2      | D1        | D0        | 1                |
| PSW*                                                                                                                                             | Program status word               | D0h            | CY       | AC        | F0        | RS1        | RS0       | OV      | F1        | Р         | 00h              |
| SP                                                                                                                                               | Stack pointer                     | 81h            |          |           |           |            |           |         |           |           | 07h              |
|                                                                                                                                                  |                                   |                | 8F       | 8E        | 8D        | 8C         | 8B        | 8A      | 89        | 88        |                  |
| TCON*                                                                                                                                            | Timer 0 and 1 control             | 88h            | TF1      | TR1       | TF0       | TR0        | _         | _       | IE0       | IT0       | 00h              |
| ГНО                                                                                                                                              | Timer 0 high byte                 | 8Ch            |          |           |           |            |           |         |           |           | 00h              |

## Low power, low price, low pin count (14 pin) microcontroller with 1 kbyte OTP

| Name   | Description               | SFR<br>Address | M | SB | Bit Fu | nctions a | nd Addre | esses | L    | SB   | Reset<br>Value |
|--------|---------------------------|----------------|---|----|--------|-----------|----------|-------|------|------|----------------|
| TH1    | Timer 1 high byte         | 8Dh            |   |    |        |           |          |       |      | -    | 00h            |
| TL0    | Timer 0 low byte          | 8Ah            |   |    |        |           |          |       |      |      | 00h            |
| TL1    | Timer 1 low byte          | 8Bh            |   |    |        |           |          |       |      |      | 00h            |
| TMOD   | Timer 0 and 1 mode        | 89h            | - | -  | M1     | MO        | GATE     | C/T   | M1   | M0   | 00h            |
|        |                           |                |   |    |        |           |          |       |      |      |                |
| WDCON# | Watchdog control register | A7h            | - | -  | WDOVF  | WDRUN     | WDCLK    | WDS2  | WDS1 | WDS0 | Note 4         |
| WDRST# | Watchdog reset register   | A6h            |   |    |        |           | •        |       |      | 1    | 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. 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 3. 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.

# Low power, low price, low pin count (14 pin) microcontroller with 1 kbyte OTP

### FUNCTIONAL DESCRIPTION

### P87LPC759

#### External Interrupt Inputs

The P87LPC759 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 source 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 pin is 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 detected 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 IEO when the interrupt is level sensitive, it simply tracks the input pin level.

If the external interrupt is enabled when the P87LPC759 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 2. Interrupt Sources, Interrupt Enables, and Power Down Wakeup Sources

## P87LPC759

### I/O Ports

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

All but three I/O port pins on the P87LPC759 may be software configured to one of four types on a bit-by-bit basis, as shown in Table 2. 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 2. Port Output Configuration Settings |
|---------------------------------------------|
|---------------------------------------------|

| PxM1.y | PxM2.y        | Port Output Mode            |  |  |
|--------|---------------|-----------------------------|--|--|
| 0      | 0             | Quasi-bidirectional         |  |  |
| 0      | 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 P87LPC759 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 3.



Figure 3. Quasi-Bidirectional Output

## Low power, low price, low pin count (14 pin) microcontroller with 1 kbyte OTP

#### **Open Drain Output Configuration**

The open drain output configuration turns off all pull-ups and only drives the pull-down transistor of the port driver when the port latch contains a logic 0. To be used as a logic output, a port configured in this manner must have an external pull-up, typically a resistor tied to  $V_{DD}$ . The pull-down for this mode is the same as for the quasi-bidirectional mode.

The open drain port configuration is shown in Figure 4.

#### **Push-Pull Output Configuration**

The push-pull output configuration has the same pull-down structure as both the open drain and the quasi-bidirectional output modes, but provides a continuous strong pull-up when the port latch contains a logic 1. The push-pull mode may be used when more source current is needed from a port output.

The push-pull port configuration is shown in Figure 5.

The three port pins that cannot be configured are P1.2, P1.3, and P1.5. The port pins P1.2 and P1.3 are permanently configured as open drain outputs. They may be used as inputs by writing ones to their respective port latches. P1.5 may be used as a Schmitt trigger input if the P87LPC759 has been configured for an internal reset and is not using the external reset input function  $\overline{\text{RST}}$ .

Additionally, port pins P2.0 and P2.1 are disabled for both input and output if one of the crystal oscillator options is chosen. Those options are described in the Oscillator section.

The value of port pins at reset is determined by the PRHI bit in the UCFG1 register. Ports may be configured to reset high or low as needed for the application. When port pins are driven high at reset, they are in quasi-bidirectional mode and therefore do not source large amounts of current.

Every output on the P87LPC759 may potentially be used as a 20 mA sink LED drive output. However, there is a maximum total output current for all ports which must not be exceeded.

All ports pins of the P87LPC759 have slew rate controlled outputs. This is to limit noise generated by quickly switching output signals. The slew rate is factory set to approximately 10 ns rise and fall times.

The bits in the P2M1 register that are not used to control configuration of P2.1 and P2.0 are used for other purposes. These bits can enable Schmitt trigger inputs on each I/O port, enable toggle outputs from Timer 0 and Timer 1, and enable a clock output if either the internal RC oscillator or external clock input is being used. The last two functions are described in the Timer/Counters and Oscillator sections respectively. The enable bits for all of these functions are shown in Figure 6.

Each I/O port of the P87LPC759 may be selected to use TTL level inputs or Schmitt inputs with hysteresis. A single configuration bit determines this selection for the entire port. Port pins P1.2, P1.3, and P1.5 always have a Schmitt trigger input.



Figure 4. Open Drain Output



Figure 5. Push-Pull Output

## Low power, low price, low pin count (14 pin) microcontroller with 1 kbyte OTP

| 2M1                                                                                               | Address:  | : A4h      |                              |                                                                  |              |             |            |               | F             | Reset Value: 00h              |
|---------------------------------------------------------------------------------------------------|-----------|------------|------------------------------|------------------------------------------------------------------|--------------|-------------|------------|---------------|---------------|-------------------------------|
|                                                                                                   | Not Bit A | ddressable |                              |                                                                  |              |             |            |               |               |                               |
|                                                                                                   |           | 7          | 6                            | 5                                                                | 4            | 3           | 2          | 1             | 0             |                               |
|                                                                                                   |           | P2S        | P1S                          | P0S                                                              | ENCLK        | -           | T0OE       | (P2M1.1)      | (P2M1.0)      |                               |
| В                                                                                                 | ІТ        | SYMBOL     | FUNCTION                     |                                                                  |              |             |            |               |               |                               |
| Р                                                                                                 | 2M1.7     | P2S        | When P2S =                   | When P2S = 1, this bit enables Schmitt trigger inputs on Port 2. |              |             |            |               |               |                               |
| Р                                                                                                 | 2M1.6     | P1S        | When P1S =                   | When P1S = 1, this bit enables Schmitt trigger inputs on Port 1. |              |             |            |               |               |                               |
| Р                                                                                                 | 2M1.5     | P0S        | When P0S =                   | 1, this bi                                                       | t enables So | chmitt trig | ger inputs | s on Port 0.  |               |                               |
| Ρ                                                                                                 | 2M1.4     | ENCLK      | When ENCL output is ena      |                                                                  |              |             |            |               |               | oscillator, a clock<br>ils.   |
| Ρ                                                                                                 | 2M1.2     | TOOE       | When set, th one half of the |                                                                  |              |             |            |               |               | equency is therefore details. |
| P2M1.1, P2M1.0 — These bits, along with the matching bi P2.1 and P2.0 respectively <sup>1</sup> . |           |            |                              |                                                                  |              | ng bits in  | the P2M2   | register, con | trol the outp | ut configuration of           |
|                                                                                                   |           |            |                              |                                                                  |              |             |            |               |               | SU01535                       |

1. See Table 2, Port Output Configuration Settings.

Figure 6. 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 P87LPC759, as shown in Figure 7. 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 P87LPC759 allows any pin 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 8. 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 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.

### 2002 Mar 21

## P87LPC759



### Figure 7. Keyboard Interrupt

| Address                                                                | s: 86h                           |                                                              |                                                                                                                           |                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                      | Reset Value: 00h                                                                                                                                                                                                                                                                                                                                                    |  |
|------------------------------------------------------------------------|----------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Not Bit                                                                | Addressable                      |                                                              |                                                                                                                           |                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                     |  |
|                                                                        | 7                                | 6                                                            | 5                                                                                                                         | 4                                                                                                                                                                                                                                          | 3                                                                                                                                                                                                                                                                                          | 2                                                                                                                                                                                                  | 1                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                     |  |
|                                                                        | -                                | KBI.6                                                        | KBI.5                                                                                                                     | KBI.4                                                                                                                                                                                                                                      | KBI.3                                                                                                                                                                                                                                                                                      | _                                                                                                                                                                                                  | _                                                                                                                                                                                                                                                                                                                                                       | _                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                     |  |
| т                                                                      | SYMBOL                           | FUNCTION                                                     |                                                                                                                           |                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                     |  |
| KBI.6 KBI.6 When set, enables P0.6 as a cause of a Keyboard Interrupt. |                                  |                                                              |                                                                                                                           |                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                     |  |
| KBI.5 KBI.5 When set, enables P0.5 as a cause of a Keyboard Interrupt. |                                  |                                                              |                                                                                                                           |                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                     |  |
| 31.4                                                                   | KBI.4                            | When set, ena                                                | bles P0.4                                                                                                                 | as a caus                                                                                                                                                                                                                                  | e of a Key                                                                                                                                                                                                                                                                                 | board Inte                                                                                                                                                                                         | errupt.                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                     |  |
| 31.3                                                                   | KBI.3                            | When set, ena                                                | When set, enables P0.3 as a cause of a Keyboard Interrupt.                                                                |                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                     |  |
|                                                                        | <b>T</b><br>81.6<br>81.5<br>81.4 | 7<br>–<br>T SYMBOL<br>81.6 KB1.6<br>81.5 KB1.5<br>81.4 KB1.4 | -  KBI.6    T  SYMBOL  FUNCTION    81.6  KBI.6  When set, ena    81.5  KBI.5  When set, ena    81.4  KBI.4  When set, ena | 7      6      5        -      KBI.6      KBI.5        T      SYMBOL      FUNCTION        81.6      KBI.6      When set, enables P0.6        81.5      KBI.5      When set, enables P0.5        81.4      KBI.4      When set, enables P0.4 | 7      6      5      4        –      KBI.6      KBI.5      KBI.4        T      SYMBOL      FUNCTION        81.6      KBI.6      When set, enables P0.6 as a caus        81.5      KBI.5      When set, enables P0.5 as a caus        81.4      KBI.4      When set, enables P0.4 as a caus | 76543-KBI.6KBI.5KBI.4KBI.3TSYMBOLFUNCTION81.6KBI.6When set, enables P0.6 as a cause of a Key81.5KBI.5When set, enables P0.5 as a cause of a Key81.4KBI.4When set, enables P0.4 as a cause of a Key | 7    6    5    4    3    2      -    KBI.6    KBI.5    KBI.4    KBI.3    -      T    SYMBOL    FUNCTION      81.6    KBI.6    When set, enables P0.6 as a cause of a Keyboard Interview      81.5    KBI.5    When set, enables P0.5 as a cause of a Keyboard Interview      81.4    KBI.4    When set, enables P0.4 as a cause of a Keyboard Interview | 7    6    5    4    3    2    1      -    KBI.6    KBI.5    KBI.4    KBI.3    -    -      T    SYMBOL    FUNCTION      81.6    KBI.6    When set, enables P0.6 as a cause of a Keyboard Interrupt.      81.5    KBI.5    When set, enables P0.5 as a cause of a Keyboard Interrupt.      81.4    KBI.4    When set, enables P0.4 as a cause of a Keyboard Interrupt. | 7    6    5    4    3    2    1    0      -    KBI.6    KBI.5    KBI.4    KBI.3    -    -    -      T    SYMBOL    FUNCTION    KBI.6    When set, enables P0.6 as a cause of a Keyboard Interrupt.      81.6    KBI.5    When set, enables P0.5 as a cause of a Keyboard Interrupt.    KBI.4    KBI.4    When set, enables P0.4 as a cause of a Keyboard Interrupt. |  |

Figure 8. Keyboard Interrupt Register (KBI)

## P87LPC759

### Oscillator

The P87LPC759 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 3 shows capacitor values that may be used with a quartz crystal in this mode.

| Table 3. Recommended oscillator capacitors for use with the low frequency oscillator option | Table 3. | Recommended | oscillator cap | pacitors 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 4 shows capacitor values that may be used with a quartz crystal in this mode.

### Table 4. 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 5 shows capacitor values that may be used with a quartz crystal in this mode.

### Table 5. 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 AC 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<sub>DD</sub> is above 4.5 V and up to 10 MHz when V<sub>DD</sub> 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 P87LPC759 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 P87LPC759. 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.



Figure 9. Using the Crystal Oscillator



Figure 10. Using an External Clock Input

## Low power, low price, low pin count (14 pin) microcontroller with 1 kbyte OTP



Figure 11. Block Diagram of Oscillator Control

### **CPU Clock Modification: CLKR and DIVM**

For backward compatibility, the CLKR configuration bit allows setting the P87LPC759 instruction and peripheral timing to match standard 80C51 timing by dividing the CPU clock by two. Default timing for the P87LPC759 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 P87LPC759 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 P87LPC759 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.

### P87LPC759

For correct activation of Brownout Detect, the V<sub>DD</sub> fall time must be no faster than 50 mV/ $\mu$ s. When V<sub>DD</sub> is restored, is should not rise faster than 2 mV/ $\mu$ s in order to insure a proper reset.

The brownout voltage (2.5 V or 3.8 V) is selected via the BOV bit in the EPROM configuration register UCFG1. When unprogrammed (BOV = 1), the brownout detect voltage is 2.5 V. When programmed (BOV = 0), the brownout detect voltage is 3.8 V.

If the Brownout Detect function is not required in an application, it may be disabled, thus saving power. Brownout Detect is disabled by setting the control bit BOD in the AUXR1 register (AUXR1.6).

### **Power On Detection**

The Power On Detect has a function similar to the Brownout Detect, but is designed to work as power comes up initially, before the power supply voltage reaches a level where Brownout Detect can work. When this feature is activated, the POF flag in the PCON register is set to indicate an initial power up condition. The POF flag will remain set until cleared by software.

### **Power Reduction Modes**

The P87LPC759 supports Idle and Power Down modes of power reduction.

### Idle Mode

The Idle mode leaves peripherals running in order to allow them to activate the processor when an interrupt is generated. Any enabled interrupt source or Reset may terminate Idle mode. Idle mode is entered by setting the IDL bit in the PCON register (see Figure 12).

#### Power Down Mode

The Power Down mode stops the oscillator in order to absolutely minimize power consumption. Power Down mode is entered by setting the PD bit in the PCON register (see Figure 12).

The processor can be made to exit Power Down mode via Reset or one of the interrupt sources shown in Table 3. This will occur if the interrupt is enabled and its priority is higher than any interrupt currently in progress.

In Power Down mode, the power supply voltage may be reduced to the RAM keep-alive voltage  $V_{RAM}$ . This retains the RAM contents at the point where Power Down mode was entered. SFR contents are not guaranteed after  $V_{DD}$  has been lowered to  $V_{RAM}$ , therefore it is recommended to wake up the processor via Reset in this case.  $V_{DD}$  must be raised to within the operating range before the Power Down mode is exited. Since the watchdog timer has a separate oscillator, it may reset the processor upon overflow if it is running during Power Down.

Note that if the Brownout Detect reset is enabled, the processor will be put into reset as soon as  $V_{DD}$  drops below the brownout voltage. If Brownout Detect is configured as an interrupt and is enabled, it will wake up the processor from Power Down mode when  $V_{DD}$  drops below the brownout voltage.

When the processor wakes up from Power Down mode, it will start the oscillator immediately and begin execution when the oscillator is stable. Oscillator stability is determined by counting 1024 CPU clocks after start-up when one of the crystal oscillator configurations is used, or 256 clocks after start-up for the internal RC or external clock input configurations.

Some chip functions continue to operate and draw power during Power Down mode, increasing the total power used during Power Down. These include the Brownout Detect and Watchdog Timer.

| PCON | Address | s: 87h      |                                  |                                                                                                                                                                                                                |              |              |           | Reset Val    |            | h for a Power On reset                              |  |  |  |
|------|---------|-------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|-----------|--------------|------------|-----------------------------------------------------|--|--|--|
|      | Not Bit | Addressable |                                  |                                                                                                                                                                                                                |              |              |           |              |            | h for a Brownout reset<br>h for other reset sources |  |  |  |
|      |         | 7           | 6                                | 5                                                                                                                                                                                                              | 4            | 3            | 2         | 1            | 0          | _                                                   |  |  |  |
|      |         | -           | -                                | BOF                                                                                                                                                                                                            | POF          | GF1          | GF0       | PD           | IDL        |                                                     |  |  |  |
| BI   | т       | SYMBOL      | FUNCTION                         |                                                                                                                                                                                                                |              |              |           |              |            | -                                                   |  |  |  |
| PC   | CON.7   | -           | Reserved                         | erved                                                                                                                                                                                                          |              |              |           |              |            |                                                     |  |  |  |
| PC   | CON.6   | -           | Reserved                         | erved                                                                                                                                                                                                          |              |              |           |              |            |                                                     |  |  |  |
| PC   | CON.5   | BOF         |                                  | Brown Out Flag. Set automatically when a brownout reset or interrupt has occurred. Also set at<br>sower on. Cleared by software. Refer to the Power Monitoring Functions section for additional<br>nformation. |              |              |           |              |            |                                                     |  |  |  |
| PC   | CON.4   | POF         | Power On Flag<br>to the Power M  |                                                                                                                                                                                                                |              |              |           |              |            | eared by software. Refer                            |  |  |  |
| PC   | CON.3   | GF1         | General purpo                    | se flag 1.                                                                                                                                                                                                     | May be re    | ad or write  | en by use | er software, | but has n  | o effect on operation.                              |  |  |  |
| PC   | CON.2   | GF0         | General purpo                    | se flag 0.                                                                                                                                                                                                     | May be re    | ad or writ   | en by use | er software, | but has n  | o effect on operation.                              |  |  |  |
| PC   | CON.1   | PD          | Power Down c<br>Power Down n     |                                                                                                                                                                                                                |              |              | ates Powe | er Down mo   | ode opera  | tion. Cleared when the                              |  |  |  |
| PC   | CON.0   | IDL         | Idle mode cont<br>terminated (se |                                                                                                                                                                                                                | tting this t | oit activate | s Idle mo | de operatio  | n. Cleared | d when the Idle mode is                             |  |  |  |
|      |         |             |                                  |                                                                                                                                                                                                                |              |              |           |              |            | SU01647                                             |  |  |  |

Figure 12. Power Control Register (PCON)

### Table 6. Sources of Wakeup from Power Down Mode

| Wakeup Source             | Conditions                                                                                                                                                                       |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| External Interrupt 0      | The interrupt must be enabled.                                                                                                                                                   |
| Keyboard Interrupt        | The keyboard interrupt feature must be enabled and properly set up. The corresponding interrupt must be enabled.                                                                 |
| Watchdog Timer Reset      | The watchdog timer must be enabled via the WDTE bit in the UCFG1 EPROM configuration byte.                                                                                       |
| Watchdog Timer Interrupt  | The WDTE bit in the UCFG1 EPROM configuration byte must not be set. The corresponding interrupt must be enabled.                                                                 |
| Brownout Detect Reset     | The BOD bit in AUXR1 must not be set (brownout detect not disabled). The BOI bit in AUXR1 must not be set (brownout interrupt disabled).                                         |
| Brownout Detect Interrupt | The BOD bit in AUXR1 must not be set (brownout detect not disabled). The BOI bit in AUXR1 must be set (brownout interrupt enabled). The corresponding interrupt must be enabled. |
| Reset Input               | The external reset input must be enabled.                                                                                                                                        |

### P87LPC759

#### 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 P87LPC759 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 P87LPC759 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 P87LPC759 is held in reset until the signal goes high.

The watchdog timer on the P87LPC759 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 13. Using pin P1.5 as general purpose input pin or as low-active reset pin



Figure 14. Block Diagram Showing Reset Sources

### P87LPC759

### **Timer/Counters**

The P87LPC759 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 as timers or can be configured to be an event counter (see Figure 15). An option to automatically toggle the T0 pin 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 of Timer 0, the register is incremented in response to a 1-to-0 transition at its corresponding external input pin, T0. 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 of Timer 0 is selected by control bit C/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.

| TMOD Addres | ss: 89h       |                                 |              |              |            |            |              |              | Reset Value: 00h                                                 |
|-------------|---------------|---------------------------------|--------------|--------------|------------|------------|--------------|--------------|------------------------------------------------------------------|
| Not Bi      | t Addressable |                                 |              |              |            |            |              |              |                                                                  |
|             | 7             | 6                               | 5            | 4            | 3          | 2          | 1            | 0            |                                                                  |
|             | -             | -                               | M1           | MO           | GATE       | C/T        | M1           | MO           |                                                                  |
|             |               |                                 |              |              |            |            |              |              |                                                                  |
|             |               |                                 | Т            | 1            |            | Т          | 0            |              |                                                                  |
| BIT         | SYMBOL        | FUNCTION                        |              |              |            |            |              |              |                                                                  |
| TMOD.7, 6   | -             | Reserved. Mu                    | st be writte | en with ze   | ros only.  |            |              |              |                                                                  |
| TMOD.5, 4   | M1, M0        | Mode Select f                   | or Timer 1   | (see table   | e below).  |            |              |              |                                                                  |
| TMOD.3      | GATE          |                                 |              |              |            |            |              |              | he INTO pin is high and control bit is set.                      |
| TMOD.2      | C/T           | Timer or Cour<br>Set for Counte |              |              |            |            | er operatio  | on (input fr | om internal system clock.)                                       |
| TMOD.1, 0   | M1, M0        | Mode Select f                   | or Timer 0   | (see table   | e below).  |            |              |              |                                                                  |
|             | <u>M1, M0</u> | Timer Mode                      |              |              |            |            |              |              |                                                                  |
|             | 0 0           | 8048 Timer "T                   | Ln" serves   | s as 5-bit j | orescaler. |            |              |              |                                                                  |
|             | 0 1           | 16-bit Timer/C                  | ounter "Th   | In" and "T   | Ln" are ca | iscaded; t | here is no   | prescaler.   |                                                                  |
|             | 10            | 8-bit auto-relo                 | ad Timer/0   | Counter. T   | Hn holds a | a value wł | nich is load | led into TL  | n when it overflows.                                             |
|             | 11            |                                 | r 0 contro   | l bits. THC  | is an 8-bi |            |              |              | ounter controlled by the imer 1 control bits (see <i>SU01542</i> |

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

### P87LPC759

#### 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. Figures 17 and 18 show 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 Timer 0 when TR0 = 1 and either GATE = 0 or INT0 = 1. (Setting GATE = 1 allows the Timer to be controlled by external input INT0, to facilitate pulse width

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

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 slightly different for Timer 0 and Timer 1. See Figures 17 and 18.

| CON | Address  | s: 88h   |                                     |                                                                                                                                                       |              |            |             |              |            | Reset Value: 00        |  |  |
|-----|----------|----------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------|-------------|--------------|------------|------------------------|--|--|
|     | Bit Add  | ressable |                                     |                                                                                                                                                       |              |            |             |              |            |                        |  |  |
|     |          | 7        | 6                                   | 5                                                                                                                                                     | 4            | 3          | 2           | 1            | 0          |                        |  |  |
|     |          | TF1      | TR1                                 | TF0                                                                                                                                                   | TR0          | _          | _           | IE0          | ІТО        |                        |  |  |
| в   | п        | SYMBOL   | FUNCTION                            |                                                                                                                                                       |              |            |             |              |            | -                      |  |  |
| _   | CON.7    | TF1      | Timer 1 overflo                     | mer 1 overflow flag. Set by hardware on Timer/Counter overflow. Cleared by hardware when the terrupt is processed, or by software.                    |              |            |             |              |            |                        |  |  |
| Т   | CON.6    | TR1      | Timer 1 Run c                       | ontrol bit.                                                                                                                                           | Set/cleare   | d by softw | are to turi | n Timer/Cou  | unter 1 on | /off.                  |  |  |
| T   | CON.5    | TF0      | Timer 0 overflo<br>processor vec    |                                                                                                                                                       |              |            |             |              | v. Cleared | l by hardware when the |  |  |
| Т   | CON.4    | TR0      | Timer 0 Run c                       | ontrol bit.                                                                                                                                           | Set/cleare   | d by softw | are to turi | n Timer/Cou  | unter 0 on | /off.                  |  |  |
| Т   | CON.3, 2 | _        | Reserved (mu                        | st be 0).                                                                                                                                             |              |            |             |              |            |                        |  |  |
| T   | CON.1    | IE0      |                                     | nterrupt 0 Edge flag. Set by hardware when external interrupt 0 edge is detected. Cleared by ardware when the interrupt is processed, or by software. |              |            |             |              |            |                        |  |  |
| T   | CON.0    | IT0      | Interrupt 0 Typ<br>external interro |                                                                                                                                                       | oit. Set/cle | ared by s  | oftware to  | specify fall | ing edge/l | ow level triggered     |  |  |

Figure 16. Timer/Counter Control Register (TCON)



Figure 17. Timer/Counter 0 in Mode 0 (13-Bit Timer/Counter)

## P87LPC759





### Mode 1

Mode 1 is the same as Mode 0, except that all 16 bits of the timer register (THn and TLn) are used. (See Figures 19 and 20)

### Mode 2

Mode 2 configures the Timer register as an 8-bit Counter (TLn) with automatic reload, as shown in Figures 21 and 22. Overflow from TLn not only sets TFn, but also reloads TLn with the contents of THn, which must be preset by software. The reload leaves THn unchanged. Mode 2 operation is slightly different for Timer 0 and Timer 1 (see Figures 21 and 22).

### Mode 3

When Timer 1 is in Mode 3 it is stopped. The effect is the same as setting TR1 = 0.

Timer 0 in Mode 3 establishes TL0 and TH0 as two separate 8-bit counters. The logic for Mode 3 on Timer 0 is shown in Figure 23. TL0 uses the Timer 0 control bits: C/T, GATE, TR0, and TF0 as well as the INT0 pin. TH0 is locked into a timer function (counting machine cycles) and takes over the use of TR1 and TF1 from Timer 1. Thus, TH0 now controls the "Timer 1" interrupt.

Mode 3 is provided for applications that require an extra 8-bit timer. With Timer 0 in Mode 3, an P87LPC759 can look like it has three Timer/Counters. When Timer 0 is in Mode 3, Timer 1 can be turned on and off by switching it into and out of its own Mode 3. It can still be used by the serial port as a baud rate generator, or in any application not requiring an interrupt.







Figure 20. Timer 1 in Mode 1 (16-Bit Timer)

OSC/6

OSC/12

OR

P87LPC759

# Low power, low price, low pin count (14 pin) microcontroller with 1 kbyte OTP

#### C/T = 0 C/T = 1 C/T = 1 C/T = 1 C/T = 1 C/T = 0 C/T



Figure 21. Timer/Counter 0 in Mode 2 (8-Bit Auto-Reload)



Figure 22. Timer 1 in Mode 2 (8-Bit Auto-Reload)



Figure 23. Timer/Counter 0 Mode 3 (Two 8-Bit Timer/Counters)

## P87LPC759

#### Timer Overflow Toggle Output

Timer 0 can be configured to automatically toggle a port output whenever a timer overflow occurs. The same device pins that is used for the T0 count inputs are also used for the timer toggle outputs. This function is enabled by control bit T0OE in the P2M1 register. The port outputs will be a logic 1 prior to the first timer overflow when this mode is turned on.

### 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 <u>cannot</u> 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 24.

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%. 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.



Figure 24. Block Diagram of the Watchdog Timer

## P87LPC759

| Net Dit A  | dalara a salah | Reset Value:                  |                         | 0            |             | otob do a !- | anabla d i | is the MDTE configuration bi                  |  |  |
|------------|----------------|-------------------------------|-------------------------|--------------|-------------|--------------|------------|-----------------------------------------------|--|--|
| Not Bit A  | ddressable     |                               |                         |              |             | 0            |            | ia the WDTE configuration bi                  |  |  |
|            |                |                               | • 00h for other         | reset sour   | ces if the  | watchdog is  | s disabled | via the WDTE configuration                    |  |  |
|            |                |                               |                         |              |             |              |            |                                               |  |  |
|            | 7              | 6 5                           | 4                       | 3            | 2           | 1            | 0          |                                               |  |  |
|            |                | — WDOV                        | F WDRUN                 | WDCLK        | WDS2        | WDS1         | WDS0       |                                               |  |  |
|            |                |                               |                         | 11           |             |              |            |                                               |  |  |
| BIT        | SYMBOL         | FUNCTION                      |                         |              |             |              |            |                                               |  |  |
| WDCON.7, 6 | _              | Reserved for fu               | ture use. Sho           | uld not be s | set to 1 by | v user progr | rams.      |                                               |  |  |
| WDCON.5    | WDOVF          | Watchdog time the watchdog is |                         | . Set when   | a watchd    | og reset or  | timer over | flow occurs. Cleared when                     |  |  |
| WDCON.4    | WDRUN          |                               |                         |              |             |              |            | 1 and stopped when<br>nfiguration bit = 1.    |  |  |
| WDCON.3    | WDCLK          |                               | C oscillator w          | hen WDCL     | K = 0. Th   |              |            | when WDCLK = 1 and by<br>sing the watchdog RC |  |  |
| WDCON.2-0  | WDS2-0         | Watchdog rate                 | select.                 |              |             |              |            |                                               |  |  |
|            | WDS2-0         | Timeout Clock                 | <u>s</u> <u>Minimur</u> | m Time       | No          | ominal Time  | 2          | Maximum Time                                  |  |  |
|            | 000            | 8,192                         | 10                      | ms           |             | 16 ms        |            | 23 ms                                         |  |  |
|            | 001            | 16,384                        | 20 1                    | ms           |             | 32 ms        |            | 45 ms                                         |  |  |
|            | 010            | 32,768                        | 41 (                    | ms           |             | 65 ms        |            | 90 ms                                         |  |  |
|            |                |                               |                         | ~~~          |             | 131 ms       |            | 180 ms                                        |  |  |
|            | 011            | 65,536                        | 82 ו                    | 115          |             | 1011113      |            | 100 1115                                      |  |  |
|            | 0 1 1<br>1 0 0 | 65,536<br>131,072             | 82 i<br>165             |              |             | 262 ms       |            | 360 ms                                        |  |  |
|            |                |                               |                         | ms           |             |              |            |                                               |  |  |
|            | 100            | 131,072                       | 165                     | ms<br>ms     |             | 262 ms       |            | 360 ms                                        |  |  |

Figure 25. Watchdog Timer Control Register (WDCON)

## P87LPC759

### Additional Features

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

### 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<br>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 P87LPC759 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.

|     | Address<br>Not Bit A | : A2h<br>Addressable |      |                                                                                                                                                 |            |                               |               |             |              |             | Reset Value: 00                              |  |
|-----|----------------------|----------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------------------------|---------------|-------------|--------------|-------------|----------------------------------------------|--|
|     |                      |                      | 7    | 6                                                                                                                                               | 5          | 4                             | 3             | 2           | 1            | 0           |                                              |  |
|     |                      |                      | KBF  | BOD                                                                                                                                             | BOI        | LPEP                          | SRST          | 0           | _            | DPS         |                                              |  |
| BIT |                      | SYMBOL               | FUN  |                                                                                                                                                 |            |                               |               |             |              |             |                                              |  |
| AUX | (R1.7                | KBF                  |      | eyboard Interrupt Flag. Set when any pin of port 0 that is enabled for the Keyboard Interrupt<br>unction goes low. Must be cleared by software. |            |                               |               |             |              |             |                                              |  |
| AUX | (R1.6                | BOD                  |      | Brown Out Disable. When set, turns off brownout detection and saves power. See Power<br>Monitoring Functions section for details.               |            |                               |               |             |              |             |                                              |  |
| AUX | (R1.5                | BOI                  | the  |                                                                                                                                                 | detect fun |                               |               |             |              |             | hip reset and allows<br>pring Functions      |  |
| AUX | (R1.4                | LPEP                 |      |                                                                                                                                                 |            |                               |               |             |              |             | Set by software. Can es section for details. |  |
| AUX | (R1.3                | SRST                 | Soft | ware Res                                                                                                                                        | et. When s | set by softw                  | are, resets   | the 87LP    | C760 as if   | a hardware  | e reset occurred.                            |  |
| AUX | (R1.2                | —                    |      |                                                                                                                                                 |            | wired 0. All<br>s in the regi |               | ig of the [ | OPS bit by i | ncrementin  | ng AUXR1, without                            |  |
| AUX | (R1.1                | _                    | Res  | erved for                                                                                                                                       | future use | . Should no                   | t be set to 1 | l by user   | programs.    |             |                                              |  |
| AUX | (R1.0                | DPS                  | Data | a Pointer                                                                                                                                       | Select. Ch | ooses one o                   | of two Data   | Pointers    | for use by   | the prograr | n. See text for details.                     |  |
|     |                      |                      |      |                                                                                                                                                 |            |                               |               |             |              |             |                                              |  |

Figure 26. AUXR1 Register

## P87LPC759

### **EPROM Characteristics**

Programming of the EPROM on the P87LPC759 is accomplished with a serial programming method. Commands, addresses, and data are transmitted to and from the device on two pins after programming mode is entered. Serial programming allows easy implementation of On-Board Programming of the P87LPC759 in an application board. Details of On-Board Programming can be found in application note AN466.

The P87LPC759 contains three signature bytes that can be read and used by an EPROM programming system to identify the device. The signature bytes designate the device as an P87LPC759 manufactured by Philips. The signature bytes may be read by the user program at addresses FC30h, FC31h and FC60h with the MOVC instruction, using the DPTR register for addressing.

### System Configuration Bytes

A number of user configurable features of the P87LPC759 must be defined at power up and therefore cannot be set by the program after start of execution. Those features are configured through the use of two EPROM bytes that are programmed in the same manner as the EPROM program space. The contents of the two configuration bytes, UCFG1 and UCFG2, are shown in Figures 27 and 28. The values of these bytes may be read by the program through the use of the MOVX instruction at the addresses shown in the figure.

| UCFG1 | Address   | : FD00h |        |          |                              |                            |              |             |               | Un          | programmed Value: FFh                            |
|-------|-----------|---------|--------|----------|------------------------------|----------------------------|--------------|-------------|---------------|-------------|--------------------------------------------------|
|       |           |         | 7      | 6        | 5                            | 4                          | 3            | 2           | 1             | 0           |                                                  |
|       |           |         | WDTE   | RPD      | PRHI                         | BOV                        | CLKR         | FOSC2       | FOSC1         | FOSC0       |                                                  |
|       |           |         |        |          |                              |                            |              |             |               |             |                                                  |
| B     | ыт        | SYM     | BOL    | FUNCT    | ION                          |                            |              |             |               |             |                                                  |
| L     | JCFG1.7   | WE      | DTE    |          |                              | nable. Whe<br>nerate an ir |              | med (0), d  | lisables the  | watchdog    | timer. The timer may                             |
| U     | JCFG1.6   | RF      | PD     |          | oin disable.<br>nly port pin |                            | sables the   | reset func  | tion of pin l | P1.5, allov | ving it to be used as an                         |
| L     | JCFG1.5   | PR      | RHI    | Port rea | set high. W                  | /hen 1, port               | s reset to a | a high stat | e. When 0,    | ports rese  | et to a low state.                               |
| L     | JCFG1.4   | BC      | OV.    |          |                              |                            |              |             |               |             | When 0, the brownout ions section.               |
| L     | JCFG1.3   | CL      | KR     | taking ' | 12 CPU clo                   |                            | plete as in  | the stand   |               |             | ults in machine cycles<br>ackward compatibility, |
| L     | JCFG1.2-0 | FOSC2-  | -FSOC0 |          |                              |                            |              |             |               |             | tion. Combinations for future use.               |
|       |           | FOSC2-  | -FOSC0 | Oscillat | or Configu                   | ration                     |              |             |               |             |                                                  |
|       |           | 1 1     | 11     | Externa  | al clock inp                 | ut on X1 (de               | efault setti | ng for an u | Inprogramn    | ned part).  |                                                  |
|       |           | 0 1     | 11     | Interna  | I RC oscilla                 | ator, 6 MHz.               | For tolera   | nce, see A  | AC Electrica  | al Charact  | eristics table.                                  |
|       |           | 0 1     | 10     | Low fre  | quency cry                   | /stal, 20 kH               | z to 100 kl  | Ηz.         |               |             |                                                  |
|       |           | 0 0     | 0 1    | Mediur   | n frequenc                   | y crystal or               | resonator,   | 100 kHz t   | o 4 MHz.      |             |                                                  |
|       |           | 0 0     | 0 0    | High fre | equency cr                   | ystal or res               | onator, 4 N  | IHz to 20   | MHz.          |             |                                                  |
|       |           |         |        |          |                              |                            |              |             |               |             | SU01477                                          |

Figure 27. EPROM System Configuration Byte 1 (UCFG1)



Figure 28. EPROM System Configuration Byte 2 (UCFG2)

### P87LPC759

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

### P87LPC759

### **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:

1. 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<sub>DD</sub> = 2.7 V to 6.0 V unless otherwise specified; T<sub>amb</sub> = 0 °C to +70 °C, unless otherwise specified.

| SYMBOL             | DADAMETED                                                    | TEST CONDITIONS                                             |                          | LIMITS              |                          | UNIT |
|--------------------|--------------------------------------------------------------|-------------------------------------------------------------|--------------------------|---------------------|--------------------------|------|
| STWDUL             | PARAMETER                                                    | TEST CONDITIONS                                             | MIN                      | TYP <sup>1,2</sup>  | MAX                      | UNIT |
| 1                  | Power supply current, operating                              | 5.0 V, 20 MHz <sup>11</sup>                                 | -                        | 15                  | 25                       | mA   |
| DD                 | Power supply current, operating                              | 3.0 V, 10 MHz <sup>11</sup>                                 | -                        | 4                   | 7                        | mA   |
| 1                  | Power supply current, operating RC Osc.                      | 5.0 V, 6 MHz <sup>11</sup>                                  | -                        | 4                   | -                        | mA   |
| IRC                | Power supply current, operating RC Osc.                      | 3.0 V, 6 MHz <sup>11</sup>                                  | -                        | 2                   | -                        | mA   |
| L                  | Power supply current, Idle mode                              | 5.0 V, 20 MHz <sup>11</sup>                                 | -                        | 6                   | 10                       | mA   |
| ID                 | Fower supply current, fulle mode                             | 3.0 V, 10 MHz <sup>11</sup>                                 | -                        | 2                   | 4                        | mA   |
| l                  | Power supply current, Power Down mode                        | 5.0 V <sup>11</sup>                                         | -                        | 1                   | 10                       | μΑ   |
| IPD                | 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    |
|                    | Innut lour voltogo (TTL innut)                               | 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    |
| V <sub>IH</sub>    | 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    |
|                    | Output high voltage, all ports <sup>3</sup>                  | 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*                              | $I_{OH} = -30 \ \mu A, \ V_{DD} = 4.5 \ V$                  | V <sub>DD</sub> -0.7     | -                   | -                        | V    |
| V <sub>OH1</sub>   | Output high voltage, all ports <sup>4</sup>                  | $I_{OH} = -1.0 \text{ mA}, \text{ V}_{DD} = 2.7 \text{ 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} \text{ or } V_{IH}$                        | -                        | -                   | ±2                       | μA   |
|                    |                                                              | V <sub>IN</sub> = 1.5 V at V <sub>DD</sub> = 3.0 V          | -30                      | -                   | -250                     | μA   |
| ITL                | Logical 1 to 0 transition current, all ports <sup>3, 6</sup> | $V_{IN} = 2.0 \text{ V} \text{ at } V_{DD} = 5.5 \text{ V}$ | -150                     | -                   | -650                     | μΑ   |
| R <sub>RST</sub>   | Internal reset pull-up resistor                              |                                                             | 40                       | -                   | 225                      | kΩ   |
| V <sub>BOLOW</sub> | Brownout trip voltage with BOV = 1 <sup>12</sup>             |                                                             | 2.35                     | -                   | 2.69                     | V    |
| V <sub>BOHI</sub>  | Brownout trip voltage with BOV = 0                           | 1                                                           | 3.45                     | -                   | 3.99                     | V    |

NOTES:

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

See other Figures for details. 2.

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

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 6. V<sub>IN</sub> is approximately 2 V.

Measured with port in high impedance mode. Parameter is guaranteed but not tested at cold temperature. 7.

8. Measured with port in quasi-bidirectional mode.

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

Maximum I<sub>OL</sub> per port pin: Maximum total I<sub>OL</sub> for all outputs: 20 mA 80 mA

| maximam | IOIUI IOL             | ior un  | ouipuis. | 00 111/ |
|---------|-----------------------|---------|----------|---------|
| Maximum | total I <sub>OH</sub> | for all | outputs: | 5 mA    |

If IQL exceeds the test condition, VQL 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.
- 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.
  Devices initially operating at V<sub>DD</sub> = 4.0 V or above and at f<sub>OSC</sub> = 20 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> = 4.0 V and f<sub>OSC</sub> > 10 MHz or less are guaranteed.

## **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  $^{1,\ 2,\ 3}$ 

|                   | DADAMETED  | LIMITS                                                              |                            |                       |                       |     |
|-------------------|------------|---------------------------------------------------------------------|----------------------------|-----------------------|-----------------------|-----|
| SYMBOL            | FIGURE     | PARAMETER                                                           | MIN                        | MAX                   | UNIT                  |     |
| External Cl       | ock        | -                                                                   |                            |                       |                       |     |
| f <sub>C</sub>    | 29         | Oscillator frequency ( $V_{DD}$ = 4.0 V to 6.0 V)                   |                            | 0                     | 20                    | MHz |
| f <sub>C</sub>    | 29         | Oscillator frequency ( $V_{DD} = 2.7 \text{ V to } 6.0 \text{ V}$ ) |                            | 0                     | 10                    | MHz |
| t <sub>C</sub>    | 29         | Clock period and CPU timing cycle                                   |                            | 1/f <sub>C</sub>      | -                     | ns  |
| f <sub>CLCX</sub> | 29         | Clock low-time <sup>1</sup>                                         | f <sub>OSC</sub> = 20 MHz  | 20                    | -                     | ns  |
| f <sub>CLCX</sub> | 29         | 1                                                                   | f <sub>OSC</sub> = 10 MHz  | 40                    | -                     | ns  |
| f <sub>CHCX</sub> | 29         | Clock high-time <sup>1</sup>                                        | f <sub>OSC</sub> = 20 MHz  | 20                    | -                     | ns  |
| fснсх             | 29         | ]                                                                   | f <sub>OSC</sub> = 10 MHz  | 40                    | -                     | ns  |
| Internal RC       | Oscillator | -<br>-                                                              | -                          | •                     |                       |     |
| f <sub>CTOL</sub> |            | On-chip RC oscillator tolerance                                     | f <sub>RCoSC</sub> = 6 MHz | -10                   | +10                   | %   |
| Shift Regis       | ter        |                                                                     |                            |                       |                       |     |
| t <sub>XLXL</sub> |            | Serial port clock cycle time                                        |                            | 6t <sub>C</sub>       | -                     | ns  |
| t <sub>QVXH</sub> |            | Output data setup to clock rising edge                              |                            | 5t <sub>C</sub> – 133 | -                     | ns  |
| t <sub>XHQX</sub> |            | Output data hold after clock rising edge                            |                            | 1t <sub>C</sub> – 80  | -                     | ns  |
| t <sub>XHDV</sub> |            | Input data setup to clock rising edge                               |                            | -                     | 5t <sub>C</sub> – 133 | ns  |
| t <sub>XHDX</sub> |            | 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.

## Low power, low price, low pin count (14 pin) microcontroller with 1 kbyte OTP







Figure 30. Typical Idd versus frequency (low frequency oscillator, 25 °C)



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



Figure 32. Typical Idd versus frequency (high frequency oscillator, 25 °C)



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

# Low power, low price, low pin count (14 pin) microcontroller with 1 kbyte OTP

#### 10,000 1,000 (y) pp 10 10 10 10 10 100 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,000 1,0

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



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

#### 10,000 4.0 1,000 331 (Au) bbl 27V 100 11111 10 100 1,000 10,000 100,000 10 Frequency (kHz) SU01208

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

### 2002 Mar 21

### P87LPC759



#### Note

1. Plastic or metal protrusions of 0.25 mm maximum per side are not included.

| OUTLINE | REFERENCES |        |           | EUROPEAN | ISSUE DATE |                                  |
|---------|------------|--------|-----------|----------|------------|----------------------------------|
| VERSION | IEC        | JEDEC  | EIAJ      |          | PROJECTION | 1550E DATE                       |
| SOT27-1 | 050G04     | MO-001 | SC-501-14 |          |            | <del>-95-03-11</del><br>99-12-27 |

## P87LPC759

### **REVISION HISTORY**

| Date        | CPCN     | Description     |
|-------------|----------|-----------------|
| 2002 Mar xx | 9397 750 | Initial release |

### Data sheet status

| Data sheet status <sup>[1]</sup> | Product<br>status <sup>[2]</sup> | Definitions                                                                                                                                                                                                                                                                                                            |
|----------------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Objective data                   | Development                      | This data sheet contains data from the objective specification for product development.<br>Philips Semiconductors reserves the right to change the specification in any manner without notice.                                                                                                                         |
| Preliminary data                 | Qualification                    | This data sheet contains data from the preliminary specification. Supplementary data will be published at a later date. Philips Semiconductors reserves the right to change the specification without notice, in order to improve the design and supply the best possible product.                                     |
| Product data                     | Production                       | This data sheet contains data from the product specification. Philips Semiconductors reserves the right to make changes at any time in order to improve the design, manufacturing and supply. Changes will be communicated according to the Customer Product/Process Change Notification (CPCN) procedure SNW-SQ-650A. |

[1] Please consult the most recently issued data sheet before initiating or completing a design.

[2] The product status of the device(s) described in this data sheet may have changed since this data sheet was published. The latest information is available on the Internet at URL http://www.semiconductors.philips.com.

### Definitions

**Short-form specification** — The data in a short-form specification is extracted from a full data sheet with the same type number and title. For detailed information see the relevant data sheet or data handbook.

Limiting values definition — Limiting values given are in accordance with the Absolute Maximum Rating System (IEC 60134). Stress above one or more of the limiting values may cause permanent damage to the device. These are stress ratings only and operation of the device at these or at any other conditions above those given in the Characteristics sections of the specification is not implied. Exposure to limiting values for extended periods may affect device reliability.

Application information — Applications that are described herein for any of these products are for illustrative purposes only. Philips Semiconductors make no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

### Disclaimers

Life support — These products are not designed for use in life support appliances, devices or systems where malfunction of these products can reasonably be expected to result in personal injury. Philips Semiconductors customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Philips Semiconductors for any damages resulting from such application.

**Right to make changes** — Philips Semiconductors reserves the right to make changes, without notice, in the products, including circuits, standard cells, and/or software, described or contained herein in order to improve design and/or performance. Philips Semiconductors assumes no responsibility or liability for the use of any of these products, conveys no license or title under any patent, copyright, or mask work right to these products, and makes no representations or warranties that these products are free from patent, copyright, or mask work right infringement, unless otherwise specified.

### Contact information

For additional information please visit http://www.semiconductors.philips.com. Fax: +31

Fax: +31 40 27 24825

© Koninklijke Philips Electronics N.V. 2002 All rights reserved. Printed in U.S.A.

Date of release: 03-02

For sales offices addresses send e-mail to: sales.addresses@www.semiconductors.philips.com

Document order number:

9397 750

Let's make things better.



