## INTEGRATED CIRCUITS



Preliminary specification

2000 May 02



87LPC768

| GENERAL DESCRIPTION                           | 1       |
|-----------------------------------------------|---------|
| FEATURES                                      | 1       |
| ORDERING INFORMATION                          | 2       |
| PIN CONFIGURATION, 20-PIN DIP AND SO PACKAGES | 2       |
| LOGIC SYMBOL                                  | 2       |
| BLOCK DIAGRAM                                 | 3       |
| PIN DESCRIPTIONS                              | 5       |
| FUNCTIONAL DESCRIPTION                        | 9       |
| Enhanced CPU                                  | 9       |
| Analog Functions                              | 9       |
| Analog to Digital Converter                   | 9       |
|                                               | 9<br>10 |
| A/D Timing                                    |         |
| The A/D in Power Down and Idle Modes          | 11      |
| Code Examples for the A/D                     | 12      |
| Analog Comparators                            | 13      |
| I2C Serial Interface                          | 20      |
| Interrupts                                    | 24      |
| I/O Ports                                     | 26      |
| Keyboard Interrupt (KBI)                      | 28      |
| Oscillator                                    | 30      |
| Power Monitoring Functions                    | 32      |
| Power Reduction Modes                         | 33      |
| Reset                                         | 35      |
| Timer/Counters                                | 36      |
| UART                                          | 39      |
| Watchdog Timer                                | 49      |
| Additional Features                           | 51      |
| EPROM Characteristics                         | 52      |
| ABSOLUTE MAXIMUM RATINGS                      | 53      |
| DC ELECTRICAL CHARACTERISTICS                 | 54      |
| COMPARATOR ELECTRICAL CHARACTERISTICS         | 55      |
| A/D CONVERTER DC ELECTRICAL CHARACTERISTICS   | 55      |
| AC ELECTRICAL CHARACTERISTICS                 | 57      |
|                                               | 57      |

## 87LPC768

### **GENERAL DESCRIPTION**

The 87LPC768 is a 20-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 87LPC768 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 87LPC768 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.
- Four-channel 10-bit Pulse Width Modulator
- Four-channel multiplexed 8-bit A/D converter. Conversion time of  $9.3\mu S$  at  $f_{osc} = 20$  MHz.
- 2.7 V to 6.0 V operating range for digital functions.
- 4 K bytes EPROM code memory.
- 128 byte RAM data memory.
- 32-byte customer code EPROM allows serialization of devices, storage of setup parameters, etc.
- Two 16-bit counter/timers. Each timer may be configured to toggle a port output upon timer overflow.
- Two analog comparators.
- Full duplex UART.
- I<sup>2</sup>C communication port.
- Eight keypad interrupt inputs, plus two additional external interrupt inputs.
- Four interrupt priority levels.

- Watchdog timer with separate on-chip oscillator, requiring no external components. The watchdog timeout time is selectable from 8 values.
- Active low reset. On-chip power-on reset allows operation with no external reset components.
- Low voltage reset. One of two preset low voltage levels may be selected to allow a graceful system shutdown when power fails. May optionally be configured as an interrupt.
- Oscillator Fail Detect. The watchdog timer has a separate fully on-chip oscillator, allowing it to perform an oscillator fail detect function.
- Configurable on-chip oscillator with frequency range and RC oscillator options (selected by user programmed EPROM bits). The RC oscillator option allows operation with no external oscillator components.
- Programmable port output configuration options: quasi-bidirectional, open drain, push-pull, input-only.
- Selectable Schmitt trigger port inputs.
- LED drive capability (20 mA) on all port pins.
- Controlled slew rate port outputs to reduce EMI. Outputs have approximately 10 ns minimum ramp times.
- 15 I/O pins minimum. Up to 18 I/O pins using on-chip oscillator and reset options.
- Only power and ground connections are required to operate the 87LPC768 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.
- 20-pin DIP and SO packages.

87LPC768

### **ORDERING INFORMATION**

| Part Number  | Temperature Range °C and Package          | Frequency                  | Drawing Number |
|--------------|-------------------------------------------|----------------------------|----------------|
| P87LPC768B N | 0 to +70, Plastic Dual In-Line Package    | 20 MHz (5 V), 10 MHz (3 V) | SOT146-1       |
| P87LPC768B D | 0 to +70, Plastic Small Outline Package   | 20 MHz (5 V), 10 MHz (3 V) | SOT163-1       |
| P87LPC768F N | -45 to +85, Plastic Dual In-Line Package  | 20 MHz (5 V), 10 MHz (3 V) | SOT146-1       |
| P87LPC768F D | -45 to +85, Plastic Small Outline Package | 20 MHz (5 V), 10 MHz (3 V) | SOT163-1       |

### **PIN CONFIGURATION, 20-PIN DIP AND SO PACKAGES**



### LOGIC SYMBOL



87LPC768

### **BLOCK DIAGRAM**



87LPC768



Figure 1. 87LPC768 Program and Data Memory Map

87LPC768

### **PIN DESCRIPTIONS**

| MNEMONIC  | PIN NO.             | TYPE |                                                                                      |                                                                                 | NAME AND FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|---------------------|------|--------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P0.0-P0.7 | 1, 13, 14,<br>16–20 | I/O  | the quasi-bid<br>by the PRHI<br>depends upo                                          | irectional mo<br>bit in the UC<br>n the port co                                 | /O port with a user-configurable output type. Port 0 latches are configured in<br>de and have either ones or zeros written to them during reset, as determined<br>FG1 configuration byte. The operation of port 0 pins as inputs and outputs<br>nfiguration selected. Each port pin is configured independently. Refer to the<br>uration and the DC Electrical Characteristics for details.                                     |
|           |                     |      | The Keyboar                                                                          | d Interrupt fe                                                                  | ature operates with port 0 pins.                                                                                                                                                                                                                                                                                                                                                                                                |
|           |                     |      | Port 0 also p                                                                        | rovides vario                                                                   | us special functions as described below.                                                                                                                                                                                                                                                                                                                                                                                        |
|           | 1                   | 0    | P0.0                                                                                 | CMP2                                                                            | Comparator 2 output.                                                                                                                                                                                                                                                                                                                                                                                                            |
|           |                     |      |                                                                                      | PWM3                                                                            | Pulse Width Modulator 3 output.                                                                                                                                                                                                                                                                                                                                                                                                 |
|           | 20                  | I    | P0.1                                                                                 | CIN2B                                                                           | Comparator 2 positive input B.                                                                                                                                                                                                                                                                                                                                                                                                  |
|           |                     |      |                                                                                      | PWM0                                                                            | Pulse Width Modulator 0 output.                                                                                                                                                                                                                                                                                                                                                                                                 |
|           | 19                  | Ι    | P0.2                                                                                 | CIN2A                                                                           | Comparator 2 positive input A.                                                                                                                                                                                                                                                                                                                                                                                                  |
|           |                     |      |                                                                                      | BRAKE                                                                           | PWM brake input.                                                                                                                                                                                                                                                                                                                                                                                                                |
|           | 18                  | I    | P0.3                                                                                 | CIN1B                                                                           | Comparator 1 positive input B.                                                                                                                                                                                                                                                                                                                                                                                                  |
|           |                     |      |                                                                                      | AD0                                                                             | A/D channel 0 input.                                                                                                                                                                                                                                                                                                                                                                                                            |
|           | 17                  | Ι    | P0.4                                                                                 | CIN1A                                                                           | Comparator 1 positive input A.                                                                                                                                                                                                                                                                                                                                                                                                  |
|           |                     |      |                                                                                      | AD1                                                                             | A/D channel 1 input.                                                                                                                                                                                                                                                                                                                                                                                                            |
|           | 16                  | I    | P0.5                                                                                 | CMPREF                                                                          | Comparator reference (negative) input.                                                                                                                                                                                                                                                                                                                                                                                          |
|           |                     |      |                                                                                      | AD2                                                                             | A/D channel 2 input.                                                                                                                                                                                                                                                                                                                                                                                                            |
|           | 14                  | 0    | P0.6                                                                                 | CMP1                                                                            | Comparator 1 output.                                                                                                                                                                                                                                                                                                                                                                                                            |
|           |                     |      |                                                                                      | AD3                                                                             | A/D channel 3 input.                                                                                                                                                                                                                                                                                                                                                                                                            |
|           | 13                  | I/O  | P0.7                                                                                 | T1                                                                              | Timer/counter 1 external count input or overflow output.                                                                                                                                                                                                                                                                                                                                                                        |
| P1.0–P1.7 | 2–4, 8–12           | I/O  | below. Port 1<br>written to the<br>operation of t<br>selected. Eac<br>port configura | latches are<br>m during res<br>the configura<br>ch of the con-<br>ation and the | /O port with a user-configurable output type, except for three pins as noted configured in the quasi-bidirectional mode and have either ones or zeros et, as determined by the PRHI bit in the UCFG1 configuration byte. The ble port 1 pins as inputs and outputs depends upon the port configuration figurable port pins are programmed independently. Refer to the section on I/O DC Electrical Characteristics for details. |
|           |                     |      |                                                                                      |                                                                                 | us special functions as described below.                                                                                                                                                                                                                                                                                                                                                                                        |
|           | 12                  | 0    | P1.0                                                                                 | TxD                                                                             | Transmitter output for the serial port.                                                                                                                                                                                                                                                                                                                                                                                         |
|           | 11                  | I    | P1.1                                                                                 | RxD                                                                             | Receiver input for the serial port.                                                                                                                                                                                                                                                                                                                                                                                             |
|           | 10                  | I/O  | P1.2                                                                                 | Т0                                                                              | Timer/counter 0 external count input or overflow output.                                                                                                                                                                                                                                                                                                                                                                        |
|           |                     | I/O  |                                                                                      | SCL                                                                             | I <sup>2</sup> C serial clock input/output. When configured as an output, P1.2 is open drain, in order to conform to I <sup>2</sup> C specifications.                                                                                                                                                                                                                                                                           |
|           | 9                   | Ι    | P1.3                                                                                 | INT0                                                                            | External interrupt 0 input.                                                                                                                                                                                                                                                                                                                                                                                                     |
|           |                     | I/O  |                                                                                      | SDA                                                                             | $\rm I^2C$ serial data input/output. When configured as an output, P1.3 is open drain, in order to conform to $\rm I^2C$ specifications.                                                                                                                                                                                                                                                                                        |
|           | 8                   | I    | P1.4                                                                                 | INT1                                                                            | External interrupt 1 input.                                                                                                                                                                                                                                                                                                                                                                                                     |
|           | 4                   | I    | P1.5                                                                                 | RST                                                                             | External Reset input (if selected via EPROM configuration). A low on this pin resets the microcontroller, causing I/O ports and peripherals to take on their default states, and the processor begins execution at address 0. When used as a port pin, P1.5 is a Schmitt trigger input only.                                                                                                                                    |
|           | 3                   | 0    | P1.6                                                                                 | PWM1                                                                            | Pulse Width Modulator 1 output                                                                                                                                                                                                                                                                                                                                                                                                  |
|           | 2                   | 0    | P1.7                                                                                 | PWM2                                                                            | Pulse Width Modulator 2 output                                                                                                                                                                                                                                                                                                                                                                                                  |

## 87LPC768

| MNEMONIC        | PIN NO. | TYPE |                                                             |                                                                                                                 | NAME AND FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|-----------------|---------|------|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| P2.0-P2.1       | 6, 7    | I/O  | quasi-bidire<br>the PRHI bit<br>depends up<br>section on I, | ctional mode a<br>t in the UCFG<br>on the port co<br>/O port configu                                            | D port with a user-configurable output type. Port 2 latches are configured in the<br>and have either ones or zeros written to them during reset, as determined by<br>1 configuration byte. The operation of port 2 pins as inputs and outputs<br>nfiguration selected. Each port pin is configured independently. Refer to the<br>uration and the DC Electrical Characteristics for details.<br>us special functions as described below. |  |  |  |  |  |  |
|                 | 7       | 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 and in<br>conjunction with internal RC oscillator or external clock input.                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|                 | 6       | 1    | P2.1                                                        | X1                                                                                                              | Input to the oscillator circuit and internal clock generator circuits (when selected via the EPROM configuration).                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| V <sub>SS</sub> | 5       | 1    | Ground: 0V                                                  | Ground: 0V reference.                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| V <sub>DD</sub> | 15      | I    |                                                             | <b>ower Supply</b> : This is the power supply voltage for normal operation as well as Idle and ower Down modes. |                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |

## 87LPC768

Preliminary specification

## Table 1. Special Function Registers

| Name    | Description                             | SFR<br>Address | MSB    |        | Bit F  | unctions a | and Addre | esses  |        | LSB    | Res<br>Valu |
|---------|-----------------------------------------|----------------|--------|--------|--------|------------|-----------|--------|--------|--------|-------------|
|         |                                         |                | E7     | E6     | E5     | E4         | E3        | E2     | E1     | E0     | ┼──         |
| ACC*    | Accumulator                             | E0h            |        |        |        |            |           |        |        |        | 00h         |
|         |                                         |                | C7     | C6     | C5     | C4         | C3        | C2     | C1     | C0     | 1           |
| ADCON#* | A/D Control                             | C0h            | ENADC  | -      | -      | ADCI       | ADCS      | RCCLK  | AADR1  | AADR0  | 00h         |
| AUXR1#  | Auxiliary Function Register             | A2h            | KBF    | BOD    | BOI    | LPEP       | SRST      | 0      | -      | DPS    | 02h         |
|         |                                         |                | F7     | F6     | F5     | F4         | F3        | F2     | F1     | F0     | 1           |
| B*      | B register                              | F0h            |        |        |        |            |           |        |        |        | 00h         |
| CMP1#   | Comparator 1 control register           | ACh            | -      | -      | CE1    | CP1        | CN1       | OE1    | CO1    | CMF1   | 00h         |
| CMP2#   | Comparator 2 control register           | ADh            | -      | -      | CE2    | CP2        | CN2       | OE2    | CO2    | CMF2   | 00h         |
| CNSW0   | PWM Counter Shadow<br>Register 0        | D1h            | CNSW7  | CNSW6  | CNSW5  | CNSW4      | CNSW3     | CNSW2  | CNSW1  | CNSW0  | FFh         |
| CNSW1   | PWM Counter Shadow<br>Register 1        | D2h            | -      | -      | -      | -          | -         | -      | CNSW9  | CNSW8  | FFh         |
| CPSW0   | PWM Compare Shadow<br>Register 0        | D3h            | CPSW07 | CPSW06 | CPSW05 | CPSW04     | CPSW03    | CPSW02 | CPSW01 | CPSW00 | 00h         |
| CPSW1   | PWM Compare Shadow<br>Register 1        | D4h            | CPSW17 | CPSW16 | CPSW15 | CPSW14     | CPSW13    | CPSW12 | CPSW11 | CPSW10 | 00h         |
| CPSW2   | PWM Compare Shadow<br>Register 2        | D5h            | CPSW27 | CPSW26 | CPSW25 | CPSW24     | CPSW23    | CPSW22 | CPSW21 | CPSW20 | 00h         |
| CPSW3   | PWM Compare Shadow<br>Register 3        | D6h            | CPSW37 | CPSW36 | CPSW35 | CPSW34     | CPSW33    | CPSW32 | CPSW31 | CPSW30 | 00h         |
| CPSW4   | PWM Compare Shadow<br>Register 4        | D7h            | CPSW39 | CPSW38 | CPSW29 | CPSW28     | CPSW19    | CPSW18 | CPSW09 | CPSW08 | 00h         |
| DAC0#   | A/D Result                              | C5h            |        |        |        | 1          |           |        |        |        | 00h         |
| DIVM#   | CPU clock divide-by-M control           | 95h            |        |        |        |            |           |        |        |        | 00h         |
| DPTR:   | Data pointer (2 bytes)                  |                |        |        |        |            |           |        |        |        |             |
| DPH     | Data pointer high byte                  | 83h            |        |        |        |            |           |        |        |        | 00h         |
| DPL     | Data pointer low byte                   | 82h            |        |        |        |            |           |        |        |        | 00h         |
|         |                                         |                | CF     | CE     | CD     | CC         | СВ        | CA     | C9     | C8     |             |
| I2CFG#* | I <sup>2</sup> C configuration register | C8h/RD         | SLAVEN | MASTRQ | 0      | TIRUN      | -         | -      | CT1    | CT0    | 00r         |
|         |                                         | C8h/WR         | SLAVEN | MASTRQ | CLRTI  | TIRUN      | -         | -      | CT1    | CT0    | ]           |
|         |                                         |                | DF     | DE     | DD     | DC         | DB        | DA     | D9     | D8     | ]           |
| I2CON#* | I <sup>2</sup> C control register       | D8h/RD         | RDAT   | ATN    | DRDY   | ARL        | STR       | STP    | MASTER | -      | 80h         |
|         |                                         | D8h/WR         | СХА    | IDLE   | CDR    | CARL       | CSTR      | CSTP   | XSTR   | XSTP   | ]           |
| I2DAT#  | I <sup>2</sup> C data register          | D9h/RD         | RDAT   | 0      | 0      | 0          | 0         | 0      | 0      | 0      | 80h         |
|         |                                         | D9h/WR         | XDAT   | х      | х      | х          | х         | х      | х      | х      | ]           |
|         |                                         |                | AF     | AE     | AD     | AC         | AB        | AA     | A9     | A8     | ]           |
| IEN0*   | Interrupt enable 0                      | A8h            | EA     | EWD    | EBO    | ES         | ET1       | EX1    | ET0    | EX0    | 00r         |
|         |                                         |                | EF     | EE     | ED     | EC         | EB        | EA     | E9     | E8     |             |
| IEN1#*  | Interrupt enable 1                      | E8h            | ETI    | -      | EC1    | EAD        | -         | EC2    | EKB    | El2    | 00r         |
|         |                                         |                | BF     | BE     | BD     | BC         | BB        | BA     | B9     | B8     |             |
| IP0*    | Interrupt priority 0                    | B8h            | _      | PWD    | PBO    | PS         | PT1       | PX1    | PT0    | PX0    | 00r         |
| IP0H#   | Interrupt priority 0 high byte          | B7h            | -      | PWDH   | PBOH   | PSH        | PT1H      | PX1H   | PT0H   | PX0H   | 00h         |
|         |                                         |                | FF     | FE     | FD     | FC         | FB        | FA     | F9     | F8     |             |
| IP1*    | Interrupt priority 1                    | F8h            | PTI    | -      | PC1    | PAD        | -         | PC2    | PKB    | Pl2    | 00h         |
| IP1H#   | Interrupt priority 1 high byte          | F7h            | PTIH   | -      | PC1H   | PADH       | -         | PC2H   | PKBH   | PI2H   | 00h         |

| Preliminary | specification |
|-------------|---------------|
|-------------|---------------|

## 87LPC768

| Name    | Description                      | SFR<br>Address | MSB      |          | Bit F    | unctions a | and Addre | esses    |          | LSB      | Rese<br>Value    |
|---------|----------------------------------|----------------|----------|----------|----------|------------|-----------|----------|----------|----------|------------------|
| KBI#    | Keyboard Interrupt               | 86h            |          |          |          |            |           |          |          |          | 00h              |
|         |                                  |                | 87       | 86       | 85       | 84         | 83        | 82       | 81       | 80       |                  |
| P0*     | Port 0                           | 80h            | T1       | CMP1     | CMPREF   | CIN1A      | CIN1B     | CIN2A    | CIN2B    | CMP2     | Note 2           |
|         |                                  |                | 97       | 96       | 95       | 94         | 93        | 92       | 91       | 90       | ]                |
| P1*     | Port 1                           | 90h            | (P1.7)   | (P1.6)   | RST      | INT1       | INT0      | Т0       | RxD      | TxD      | Note             |
|         |                                  |                | A7       | A6       | A5       | A4         | A3        | A2       | A1       | A0       | ]                |
| P2*     | Port 2                           | A0h            | -        | -        | -        | -          | -         | -        | X1       | X2       | Note             |
| P0M1#   | Port 0 output mode 1             | 84h            | (P0M1.7) | (P0M1.6) | (P0M1.5) | (P0M1.4)   | (P0M1.3)  | (P0M1.2) | (P0M1.1) | (P0M1.0) | 00h              |
| P0M2#   | Port 0 output mode 2             | 85h            | (P0M2.7) | (P0M2.6) | (P0M2.5) | (P0M2.4)   | (P0M2.3)  | (P0M2.2) | (P0M2.1) | (P0M2.0) | 00H              |
| P1M1#   | Port 1 output mode 1             | 91h            | (P1M1.7) | (P1M1.6) | -        | (P1M1.4)   | -         | -        | (P1M1.1) | (P1M1.0) | 00h <sup>1</sup> |
| P1M2#   | Port 1 output mode 2             | 92h            | (P1M2.7) | (P1M2.6) | -        | (P1M2.4)   | -         | -        | (P1M2.1) | (P1M2.0) | 00h <sup>1</sup> |
| P2M1#   | Port 2 output mode 1             | A4h            | P2S      | P1S      | P0S      | ENCLK      | T1OE      | T0OE     | (P2M1.1) | (P2M1.0) | 00h              |
| P2M2#   | Port 2 output mode 2             | A5h            | -        | -        | -        | -          | -         | -        | (P2M2.1) | (P2M2.0) | 00h <sup>1</sup> |
| 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              |
| PT0AD#  | Port 0 digital input disable     | F6h            |          |          |          |            |           |          |          |          | 00h              |
|         |                                  |                |          |          |          |            |           |          |          |          |                  |
|         |                                  |                | 9F       | 9E       | 9D       | 9C         | 9B        | 9A       | 99       | 98       |                  |
| PWMCON0 | PWM Control Register 0           | DAh            | RUN      | XFER     | PWM3I    | PWM2I      | -         | PWM1I    | PWM0I    | -        | 00h              |
| PWMCON1 | PWM Control Register 1           | DBh            | ВКСН     | BKPS     | BPEN     | BKEN       | PWM3B     | PWM2B    | PWM1B    | PWM0B    | 00h              |
| SCON*   | Serial port control              | 98h            | SM0      | SM1      | SM2      | REN        | TB8       | RB8      | TI       | RI       | 00h              |
| SBUF    | Serial port data buffer register | 99h            |          | 1        | 1        |            | 1         |          |          | <b></b>  | xxh              |
| SADDR#  | Serial port address register     | A9h            |          |          |          |            |           |          |          |          | 00h              |
| SADEN#  | Serial port address enable       | B9h            |          |          |          |            |           |          |          |          | 00h              |
| SP      | Stack pointer                    | 81h            |          |          |          |            |           |          |          |          | 07h              |
|         |                                  |                |          |          |          |            |           |          |          |          |                  |
|         |                                  |                | 8F       | 8E       | 8D       | 8C         | 8B        | 8A       | 89       | 88       |                  |
| CON*    | Timer 0 and 1 control            | 88h            | TF1      | TR1      | TF0      | TR0        | IE1       | IT1      | IE0      | IT0      | 00h              |
| ГНО     | Timer 0 high byte                | 8Ch            |          |          |          |            |           |          |          |          | 00h              |
| ГН1     | Timer 1 high byte                | 8Dh            |          |          |          |            |           |          |          |          | 00h              |
| ΓL0     | Timer 0 low byte                 | 8Ah            |          |          |          |            |           |          |          |          | 00h              |
| ۲L1     | Timer 1 low byte                 | 8Bh            |          |          |          |            |           |          |          |          | 00h              |
| TMOD    | Timer 0 and 1 mode               | 89h            | GATE     | C/T      | M1       | MO         | GATE      | C/T      | M1       | MO       | 00h              |
|         |                                  |                |          |          |          |            |           |          |          |          | 1                |
| NDCON#  | Watchdog control register        | A7h            | -        | -        | WDOVF    | WDRUN      | WDCLK     | WDS2     | WDS1     | WDS0     | Note             |
| NDRST#  | Watchdog reset register          | A6h            | I        |          |          |            |           |          |          |          | xxh              |

\* SFRs are bit addressable.

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

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

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

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

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

### 87LPC768

## Low power, low price, low pin count (20 pin) microcontroller with 4 kB OTP 8-bit A/D, Pulse Width Modulator

### FUNCTIONAL DESCRIPTION

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

### Enhanced CPU

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

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

### Analog Functions

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

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

Digital inputs on port 0 may be disabled through the use of the PT0AD register. Each bit in this register corresponds to one pin of Port 0. Setting the corresponding bit in PT0AD disables that pin's digital input. Port bits that have their digital inputs disabled will be read as 0 by any instruction that accesses the port.

### Analog to Digital Converter

The 87LPC768 incorporates a four channel, 8-bit A/D converter. The A/D inputs are alternate functions on four port 0 pins. Because the

device has a very limited number of pins, the A/D power supply and references are shared with the processor power pins, V<sub>DD</sub> and V<sub>SS</sub>. The A/D converter operates down to a V<sub>DD</sub> supply of 3.0V.

The A/D converter circuitry consists of a 4-input analog multiplexer and an 8-bit successive approximation ADC. The A/D employs a ratiometric potentiometer which guarantees DAC monotonicity.

The A/D converter is controlled by the special function register ADCON. Details of ADCON are shown in Figure 2. The A/D must be enabled by setting the ENADC bit at least 10 microseconds before a conversion is started, to allow time for the A/D to stabilize. Prior to the beginning of an A/D conversion, one analog input pin must be selected for conversion via the AADR1 and AADR0 bits. These bits cannot be changed while the A/D is performing a conversion.

An A/D conversion is started by setting the ADCS bit, which remains set while the conversion is in progress. When the conversion is complete, the ADCS bit is cleared and the ADCI bit is set. When ADCI is set, it will generate an interrupt if the interrupt system is enabled, the A/D interrupt is enabled (via the EAD bit in the IE1 register), and the A/D interrupt is the highest priority pending interrupt.

When a conversion is complete, the result is contained in the register DAC0. This value will not change until another conversion is started. Before another A/D conversion may be started, the ADCI bit must be cleared by software. The A/D channel selection may be changed by the same instruction that sets ADCS to start a new conversion, but not by the same instruction that clears ADCI.

The connections of the A/D converter are shown in Figure 3.

The ideal A/D result may be calculated as follows:

Result = (V\_{IN} - V\_{SS}) x 
$$\frac{256}{V_{DD} - V_{SS}}$$
 (round result to the nearest integer)

| ADCON Ad                                                                                                                                                                                                                                                              | ldress: C0h  | 7                                                                                                                                                                                         | 6                                                                                                                                                                              | 5          | 4           | 3           | 2            | 1             | 0                  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------|-------------|--------------|---------------|--------------------|--|--|--|
| Bit addressable                                                                                                                                                                                                                                                       | ;            | ENADC                                                                                                                                                                                     | -                                                                                                                                                                              | -          | ADCI        | ADCS        | RCCLK        | AADR1         | AADR0              |  |  |  |
| Reset Value: 00                                                                                                                                                                                                                                                       | Oh           |                                                                                                                                                                                           |                                                                                                                                                                                |            |             |             |              |               |                    |  |  |  |
| BIT                                                                                                                                                                                                                                                                   | SYMBOL       | FUNCTION                                                                                                                                                                                  | FUNCTION                                                                                                                                                                       |            |             |             |              |               |                    |  |  |  |
| ADCON.7                                                                                                                                                                                                                                                               | ENADC        |                                                                                                                                                                                           | When $ENADC = 1$ , the A/D is enabled and conversions may take place. Must be set 10 microseconds before a conversion is started. ENADC cannot be cleared while ADCS or are 1. |            |             |             |              |               |                    |  |  |  |
| ADCON.6                                                                                                                                                                                                                                                               | -            | Reserved for f                                                                                                                                                                            | Reserved for future use. Should not be set to 1 by user programs.                                                                                                              |            |             |             |              |               |                    |  |  |  |
| ADCON.5                                                                                                                                                                                                                                                               | -            | Reserved for f                                                                                                                                                                            | uture use.                                                                                                                                                                     | Should not | be set to 1 | by user pro | grams.       |               |                    |  |  |  |
| ADCON.4                                                                                                                                                                                                                                                               | ADCI         | A/D conversion complete/interrupt flag. This flag is set when an A/D conversion is<br>This bit will cause a hardware interrupt if enabled and of sufficient priority. Must b<br>software. |                                                                                                                                                                                |            |             |             |              |               |                    |  |  |  |
| ADCON.3 ADCS A/D start. Setting this bit by software starts the conversion of the selected A/D input. A remains set while the A/D conversion is in progress and is cleared automatically upon completion. While ADCS or ADCI are one, new start commands are ignored. |              |                                                                                                                                                                                           |                                                                                                                                                                                |            |             |             |              |               |                    |  |  |  |
|                                                                                                                                                                                                                                                                       | ADCI, ADCS   | <u>A/D Status</u>                                                                                                                                                                         |                                                                                                                                                                                |            |             |             |              |               |                    |  |  |  |
|                                                                                                                                                                                                                                                                       | 0 0          | A/D not busy, a conversion can be started.                                                                                                                                                |                                                                                                                                                                                |            |             |             |              |               |                    |  |  |  |
|                                                                                                                                                                                                                                                                       | 0 1          | A/D busy, the start of a new conversion is blocked.                                                                                                                                       |                                                                                                                                                                                |            |             |             |              |               |                    |  |  |  |
|                                                                                                                                                                                                                                                                       | 10           | An A/D conversion is complete. ADCI must be cleared prior to starting a new conversion.                                                                                                   |                                                                                                                                                                                |            |             |             |              |               |                    |  |  |  |
|                                                                                                                                                                                                                                                                       | 11           | An A/D conve<br>state exists for                                                                                                                                                          |                                                                                                                                                                                |            |             |             |              |               | v conversion. This |  |  |  |
| ADCON.2                                                                                                                                                                                                                                                               | RCCLK        | When RCCLk oscillator is us                                                                                                                                                               |                                                                                                                                                                                |            |             |             |              |               |                    |  |  |  |
| ADCON.1, 0                                                                                                                                                                                                                                                            | AADR1,0      | Along with A<br>while ADCS a                                                                                                                                                              |                                                                                                                                                                                |            | channel to  | be conver   | ted. These b | oits can only | y be written       |  |  |  |
|                                                                                                                                                                                                                                                                       | AADR1, AADR0 | A/D Input Sel                                                                                                                                                                             | ected                                                                                                                                                                          |            |             |             |              |               |                    |  |  |  |
|                                                                                                                                                                                                                                                                       | 0 0          | AD0 (P0.3).                                                                                                                                                                               |                                                                                                                                                                                |            |             |             |              |               |                    |  |  |  |
|                                                                                                                                                                                                                                                                       | 0 1          | AD1 (P0.4).                                                                                                                                                                               |                                                                                                                                                                                |            |             |             |              |               |                    |  |  |  |
|                                                                                                                                                                                                                                                                       | 1 0          | AD2 (P0.5).                                                                                                                                                                               |                                                                                                                                                                                |            |             |             |              |               |                    |  |  |  |
|                                                                                                                                                                                                                                                                       | 11           | AD3 (P0.6).                                                                                                                                                                               |                                                                                                                                                                                |            |             |             |              |               |                    |  |  |  |
|                                                                                                                                                                                                                                                                       |              |                                                                                                                                                                                           |                                                                                                                                                                                |            |             |             |              |               | SU01354            |  |  |  |

Figure 2. A/D Control Register (ADCON)

### A/D Timing

The A/D may be clocked in one of two ways. The default is to use the CPU clock as the A/D clock source. When used in this manner, the A/D completes a conversion in 31 machine cycles. The A/D may be operated up to the maximum CPU clock rate of 20 MHz, giving a conversion time of 9.3  $\mu$ s. The formula for calculating A/D conversion time when the CPU clock runs the A/D is: 186  $\mu$ s / CPU clock rate (in MHZ). To obtain accurate A/D conversion results, the CPU clock must be at least 1 MHz.

The A/D may also be clocked by the on-chip RC oscillator, even if the RC oscillator is not used as the CPU clock. This is accomplished by setting the RCCLK bit in ADCON. This arrangement has several advantages. First, the A/D conversion time is faster at lower CPU clock rates. Also, the CPU may be run at speeds below 1 MHz without affecting A/D accuracy. Finally, the Power Down mode may be used to completely shut down the CPU and its oscillator, along with other peripheral functions, in order to obtain the best possible A/D accuracy. This should not be used if the MCU uses an external clock source greater than 4 MHz.

When the A/D is operated from the RCCLK while the CPU is running from another clock source, 3 or 4 machine cycles are used to synchronize A/D operation. The time can range from a minimum of 3 machine cycles (at the CPU clock rate) + 108 RC clocks to a maximum of 4 machine cycles (at the CPU clock rate) + 112 RC clocks.

Example A/D conversion times at various CPU clock rates are shown in Table 2. In Table 2, maximum times for RCCLK = 1 use an RC clock frequency of 4.5 MHz (6 MHz - 25%). Minimum times for RCCLK = 1 use an RC clock frequency of 7.5 MHz (6 MHz + 25%). Nominal time assume an ideal RC clock frequency of 6 MHz and an average of 3.5 machine cycles at the CPU clock rate.

| Table 2. | Example A/D | <b>Conversion Times</b> |  |
|----------|-------------|-------------------------|--|
|----------|-------------|-------------------------|--|

| CPU Clock Rate | RCCLK = 0 | RCCLK = 1 |         |         |  |  |  |  |  |  |
|----------------|-----------|-----------|---------|---------|--|--|--|--|--|--|
| CFU CIOCK Rate | RCCLR = 0 | minimum   | nominal | maximum |  |  |  |  |  |  |
| 32 kHz         | NA        | 563.4 μs  | 659 μs  | 757 μs  |  |  |  |  |  |  |
| 1 MHz          | 186 µs    | 32.4 µs   | 39.3 μs | 48.9 µs |  |  |  |  |  |  |
| 4 MHz          | 46.5 μs   | 18.9 μs   | 23.6 μs | 30.1 μs |  |  |  |  |  |  |
| 11.0592 MHz    | 16.8 μs   | 16 μs     | 20.2 μs | 27.1 μs |  |  |  |  |  |  |
| 12 MHz         | 15.5 μs   |           |         |         |  |  |  |  |  |  |
| 16 MHz         | 11.6 μs   |           |         |         |  |  |  |  |  |  |
| 20 MHz         | 9.3 µs    |           |         |         |  |  |  |  |  |  |

Note: Do not clock ADC from the RC oscillator when MCU clock is greater than 4 MHz.





### The A/D in Power Down and Idle Modes

While using the CPU clock as the A/D clock source, the Idle mode may be used to conserve power and/or to minimize system noise during the conversion. CPU operation will resume and Idle mode terminate automatically when a conversion is complete if the A/D interrupt is active. In Idle mode, noise from the CPU itself is eliminated, but noise from the oscillator and any other on-chip peripherals that are running will remain.

The CPU may be put into Power Down mode when the A/D is clocked by the on-chip RC oscillator (RCCLK=1). This mode gives the best possible A/D accuracy by eliminating most on-chip noise sources.

If the Power Down mode is entered while the A/D is running from the CPU clock (RCCLK=0), the A/D will abort operation and will not wake up the CPU. The contents of DAC0 will be invalid when operation does resume.

When an A/D conversion is started, Power Down or Idle mode must be activated within two machine cycles in order to have the most accurate A/D result. These two machine cycles are counted at the CPU clock rate. When using the A/D with either Power Down or Idle mode, care must be taken to insure that the CPU is not restarted by another interrupt until the A/D conversion is complete. The possible causes of wakeup are different in Power Down and Idle modes.

A/D accuracy is also affected by noise generated elsewhere in the application, power supply noise, and power supply regulation. Since the 87LPC768 power pins are also used as the A/D reference and supply, the power supply has a very direct affect on the accuracy of A/D readings. Using the A/D without Power Down mode while the clock is divided through the use of CLKR or DIVM has an adverse effect on A/D accuracy.

;

## Low power, low price, low pin count (20 pin) microcontroller with 4 kB OTP 8-bit A/D, Pulse Width Modulator

87LPC768

### Code Examples for the A/D

The first piece of sample code shows an example of port configuration for use with the A/D. This example sets up the pins so that all four A/D channels may be used. Port configuration for analog functions is described in the section Analog Functions.

| ; | Set | up | port | pins   | for | A/D | conve | er | sion,  | wit | hout   | af | fecting  | oth  | ler | pins.   |      |     |
|---|-----|----|------|--------|-----|-----|-------|----|--------|-----|--------|----|----------|------|-----|---------|------|-----|
|   | mov |    | PT0  | AD,#7  | 8h  |     | ;     | ;  | Disabl | e d | ligita | al | inputs o | on A | A/D | input   | pins | 5.  |
|   | anl |    | POM  | 12,#87 | h   |     | ;     | ;  | Disabl | e d | ligita | al | outputs  | on   | A/D | ) input | pir  | ns. |
|   | orl |    | POM  | 1,#78  | h   |     | ;     | ;  | Disabl | e d | ligita | al | outputs  | on   | A/D | ) input | pir  | ıs. |

Following is an example of using the A/D with interrupts. The routine ADStart begins an A/D conversion using the A/D channel number supplied in the accumulator. The channel number is not checked for validity. The A/D must previously have been enabled with sufficient time to allow for stabilization.

The interrupt handler routine reads the conversion value and returns it in memory address ADResult. The interrupt should be enabled prior to starting the conversion.

| ; Start A<br>ADStart: | A/D conversion. |                                                                |
|-----------------------|-----------------|----------------------------------------------------------------|
| orl                   | ADCON, A        | ; Add in the new channel number.                               |
| setb                  | ADCS            | ; Start an A/D conversion.                                     |
| ; orl                 | PCON,#01h       | ; The CPU could be put into Idle mode here.                    |
| ; orl<br>ret          | PCON,#02h       | ; The CPU could be put into Power Down mode here if RCCLK = 1. |
| ; A/D int<br>ADInt:   | errupt handler. |                                                                |
| push                  | ACC             | ; Save accumulator.                                            |

| push | ACC         | ; | Save accumulator.              |
|------|-------------|---|--------------------------------|
| mov  | A,DACO      | ; | Get A/D result,                |
| mov  | ADResult,A  | ; | and save it in memory.         |
| clr  | ADCI        | ; | Clear the A/D completion flag. |
| anl  | ADCON,#0fch | ; | Clear the A/D channel number.  |
| рор  | ACC         | ; | Restore accumulator.           |
| reti |             |   |                                |

Following is an example of using the A/D with polling. An A/D conversion is started using the channel number supplied in the accumulator. The channel number is not checked for validity. The A/D must previously have been enabled with sufficient time to allow for stabilization. The conversion result is returned in the accumulator.

| ADRead: |             |                            |        |
|---------|-------------|----------------------------|--------|
| orl     | ADCON, A    | ; Add in the new channel n | umber. |
| setb    | ADCS        | ; Start A/D conversion.    |        |
| ADChk:  |             |                            |        |
| jnb     | ADCI, ADChk | ; Wait for ADCI to be set. |        |
| mov     | A,DACO      | ; Get A/D result.          |        |
| clr     | ADCI        | ; Clear the A/D completion | flag.  |
| anl     | ADCON,#0fch | ; Clear the A/D channel nu | mber.  |
| ret     |             |                            |        |

87LPC768

### **Analog Comparators**

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

#### **Comparator Configuration**

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

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

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



Figure 4. Comparator Control Registers (CMP1 and CMP2)

87LPC768



Figure 5. Comparator Input and Output Connections



Figure 6. Comparator Configurations

87LPC768

#### Internal Reference Voltage

An internal reference voltage generator may supply a default reference when a single comparator input pin is used. The value of the internal reference voltage, referred to as  $V_{ref}$ , is 1.28 V ±10%.

#### **Comparator Interrupt**

Each comparator has an interrupt flag CMFn contained in its configuration register. This flag is set whenever the comparator output changes state. The flag may be polled by software or may be used to generate an interrupt. The interrupt will be generated when the corresponding enable bit ECn in the IEN1 register is set and the interrupt system is enabled via the EA bit in the IEN0 register.

#### **Comparators and Power Reduction Modes**

Either or both comparators may remain enabled when Power Down or Idle mode is activated. The comparators will continue to function in the power reduction mode. If a comparator interrupt is enabled, a change of the comparator output state will generate an interrupt and wake up the processor. If the comparator output to a pin is enabled, the pin should be configured in the push-pull mode in order to obtain fast switching times while in power down mode. The reason is that with the oscillator stopped, the temporary strong pull-up that normally occurs during switching on a quasi-bidirectional port pin does not take place.

Comparators consume power in Power Down and Idle modes, as well as in the normal operating mode. This fact should be taken into account when system power consumption is an issue.

#### **Comparator Configuration Example**

The code shown in Figure 7 is an example of initializing one comparator. Comparator 1 is configured to use the CIN1A and CMPREF inputs, outputs the comparator result to the CMP1 pin, and generates an interrupt when the comparator output changes.

The interrupt routine used for the comparator must clear the interrupt flag (CMF1 in this case) before returning.

| CmpInit: | 55035 4203 |                                                 |
|----------|------------|-------------------------------------------------|
| mov      | PTOAD,#30h | ; Disable digital inputs on pins that are used  |
|          |            | ; for analog functions: CIN1A, CMPREF.          |
| anl      | POM2,#0cfh | ; Disable digital outputs on pins that are used |
| orl      | P0M1,#30h  | ; for analog functions: CIN1A, CMPREF.          |
| mov      | CMP1,#24h  | ; Turn on comparator 1 and set up for:          |
|          |            | ; - Positive input on CIN1A.                    |
|          |            | ; - Negative input from CMPREF pin.             |
|          |            | ; - Output to CMP1 pin enabled.                 |
| call     | delay10us  | ; The comparator has to start up for at         |
|          |            | ; least 10 microseconds before use.             |
| anl      | CMP1,#0feh | ; Clear comparator 1 interrupt flag.            |
| setb     | EC1        | ; Enable the comparator 1 interrupt. The        |
|          |            | ; priority is left at the current value.        |
| setb     | EA         | ; Enable the interrupt system (if needed).      |
| ret      |            | ; Return to caller.                             |

#### Figure 7.

#### Pulse Width Modulator

The 87LPC768 contains four Pulse Width Modulated (PWM) channels which generate pulses of programmable length and interval. The output for PWM0 is on P0.1, PWM1 on P1.6, PWM2 on P1.7 and PWM3 on P0.1. After chip reset the internal output of the each PWM channel is a "1." Note that the state of the pin will not reflect this if UCFG1.5, PRHI, is set to a zero. In this case before the pin will reflect the state of the internal PWM output a "1" must be written to each port bit that serves as a PWM output. A block diagram is shown in Figure 8.

The interval between successive outputs is controlled by a 10-bit down counter which uses the internal microcontroller clock as its input. When bit 3 in the UCFG1 register is a "1" the microcontroller clock, and therefore the PWM counter clock, has the same frequency as the clock source defined by the FOSC bits in UCFG1. When bit 3 in the UCFG1 register is a "0" the microcontroller and PWM counter clocks operate at half the frequency of clock source defined by the FOSC bits in UCFG1. When the counter reaches underflow it is reloaded with a user selectable value. This mechanism allows the user to set the PWM frequency at any integer sub–multiple of the microcontroller clock frequency. The repetition frequency of the PWM is given by:

### $f_{PWM} = F_C / (CNSW+1)$

where CNSW is contained in CNSW0 and CNSW1 as described in the following tables.

## 87LPC768



The word "Shadow" in the above refers to the fact that writes are not into the register that controls the counter; rather they are into a holding register. As described below the transfer of data from this

holding register, into the register which contains the actual reload value, is controlled by the user's program.



Figure 8. PWM Block Diagram

87LPC768

The width of each PWM output pulse is determined by the value in the appropriate compare shadow registers, CPSW0 through CPSW4, CPSW0–3 for bits 0–7 and CPSW4 for bits 7 and 8. When the counter described above reaches underflow the PWM output is forced high. It remains high until the compare value is reached at which point it goes low until the next underflow. The number of microcontroller clock pulses that the PWM<sub>n</sub> output is high is given by:

#### $t_{HI} = (CNSW - CPSW_n + 1)$

A compare value greater than the counter reload value results in the PWM output being permanently high. In addition there are two

special cases. A compare value of all zeroes, 000, causes the output to remain permanently high. A compare value of all ones, 3FF, results in the PWM output remaining permanently low. Again the compare value is loaded into a shadow register. The transfer from this holding register to the actual compare register is under program control.

The register assignments are shown below where the number immediately following "CPSW" identifies the PWM output. Thus CPSW0 controls the width of PWM0, CPSW1 the width of PWM1 etc. In the case of two digits following "CPSW," e.g. CPSW00, the second digit refers to the bit of the compare value. Thus CPSW00 represents the value loaded into bit 0 of the PWM0 compare register



The overall functioning of the PWM module is controlled by the contents of the PWMCON0 register. The operation of most of the control bits is straightforward. For example there is an invert bit for each output which causes results in the output to have the opposite value compared to its non-inverted output. The transfer of the data from the shadow registers to the control registers is controlled by the PWMCON0.6 while PWMCON0.7 allows the PWM to be either in the run or idle state. The user can monitor when underflow causes the transfer to occur by monitoring the Transfer bit, PWCON0.6. When the transfer takes place the PWM logic automatically resets this bit.

The fact that the transfer from the shadow to the working registers only occurs when there is an underflow in the counter results in the need for the user's program to observe the following precautions. If PWMCON1 is written with Transfer set without Run being enabled the transfer will never take place. Thus if a subsequent write sets Run without Transfer the compare and counter values will not be those expected. If Transfer and Run are set, and prior to underflow there is a subsequent load of PWMCON0 which sets Run but not Transfer, the transfer will never take place. Again the compare and counter values that existed prior to the update attempt will be used. As outlined above the Transfer bit can be polled to determine when the transfer occurs. Unless there is a compelling reason to do otherwise, it is recommended that both Run, PWMCON0.7, and Transfer, PWMCON0.7, be set when PWMCON0 is written.

When the Run bit, PWMCON0.7, is cleared the PWM outputs take on the state they had just prior to the bit being cleared. In general this state is not known. In order to place the outputs in a known

### 87LPC768

## Low power, low price, low pin count (20 pin) microcontroller with 4 kB OTP 8-bit A/D, Pulse Width Modulator

state when Run is cleared the Compare registers can be written to either the "always 1" or "always 0" so the output will have the output desired when the counter is halted. After this PWMCON0 should be written with the Transfer and Run bits are enabled. After this is done PWMCON0 to is polled to find that the Transfer has taken place. Once the transfer has occurred the Run bit in PWMCON0 can be cleared. The outputs will retain the state they had just prior to the Run being cleared. If the Brake pin (see discussion below in section concerning the operation of PWMCON1) is not used to control the brake function, the "Brake when not running" function can be used to cause the outputs to have a given state when the PWM is halted. This approach should be used only in time critical situations when there is not sufficient time to use the approach outlined above since going from the Brake state to run without causing an undefined state on the outputs is not straightforward. A discussion on this topic is included in the section on PWMCON1.

| Addr: 0DAH       |        | 7                                                                                                              | 6              | 5                                           | 4              | 3            | 2             | 1              | 0              |         |
|------------------|--------|----------------------------------------------------------------------------------------------------------------|----------------|---------------------------------------------|----------------|--------------|---------------|----------------|----------------|---------|
| Reset Value: 00H |        | RUN                                                                                                            | XFER           | PWM3I                                       | PWM2I          | -            | PWM1I         | PWM0I          | -              |         |
| BIT              | SYMBOL | FUNCTION                                                                                                       | l              |                                             |                |              |               |                |                |         |
| PWMCON0.7        | RUN    | value o                                                                                                        | f the corresp  | reset Value<br>bonding PW<br>I to the Value | MxB bit (PV    | VMCON1[3:    | ,             |                |                |         |
|                  |        | 1= Counter                                                                                                     | run            |                                             |                |              |               |                |                |         |
| PWMCON0.6        | XFER   | 0= Counter                                                                                                     | & Compare      | shadow reg                                  | jisters are n  | ot connecte  | ed to the act | tive register: | 5              |         |
|                  |        |                                                                                                                | 0              | ntents transf<br>hardware af                |                | 0            |               |                |                | nis bit |
| PWMCON0.5        | PWM3I  | NM3I 0= PWM3 output is non-inverted. Output is a '1' from the start of the cycle until compare;<br>thereafter. |                |                                             |                |              |               | ompare; '0'    |                |         |
|                  |        | 1= PWM3 output is inverted. Output is a '0' from the start of the cycle until con                              |                |                                             |                |              |               |                |                | after.  |
| PWMCON0.4        | PWM2I  | 0= PWM2 of thereaf                                                                                             |                | –inverted.                                  | Output is a '  | 1' from the  | start of the  | cycle until c  | ompare; '0'    |         |
|                  |        | 1= PWM2 0                                                                                                      | output is inve | erted. Output                               | ut is '0' from | the start of | the cycle u   | ntil compare   | e; '1' thereaf | ter.    |
| PWMCON0.2        | PWM1I  | 0= PWM1 o<br>thereaf                                                                                           |                | –inverted.                                  | Output is a '  | 1' from the  | start of the  | cycle until c  | ompare; '0'    |         |
|                  |        | 1= PWM1 o                                                                                                      | output is inve | erted. Output                               | ut is '0' from | the start of | the cycle u   | ntil compare   | e; '1' thereaf | ter.    |
| PWMCON0.1        | PWM0I  | 0= PWM0 o<br>thereaf                                                                                           |                | -inverted.                                  | Output is a '  | 1' from the  | start of the  | cycle until c  | ompare; '0'    |         |
|                  |        | 1= PWM0 0                                                                                                      | output is inve | erted. Outp                                 | ut is '0' from | the start of | the cycle u   | ntil compare   | e; '1' thereaf | ter.    |
|                  |        |                                                                                                                |                |                                             |                |              |               |                | SU01387        |         |

The Brake function, which is controlled by the contents of the PWMCON1 register, is somewhat unique. In general when Brake is asserted the four PWM outputs are forced to a user selected state, namely the state selected by PWMCON1 bits 0 to 3.

As shown in the description of the operation of the PWMCON1 register if PWMCON1.4 is a "1" brake is asserted under the control PWMCON1.7, BKCH, and PWMCON1.5, BPEN. As shown if both are a "0" Brake is asserted. If PWMCON1.7 is a "1" brake is asserted when the run bit, PWMCON0.7, is a "0." If PWMCON1.6 is a "1" brake is asserted when the Brake Pin, P0.2, has the same polarity as PWMCON1.6. When brake is asserted in response to this pin the RUN bit, PWMCON0.7, is automatically cleared. The combination of both PWMCON1.7 and PWMCON1.5 being a "1" is not allowed.

Since the Brake Pin being asserted will automatically clear the Run bit, PWMCON0.7, the user program can poll this bit to determine when the Brake Pin causes a brake to occur. The other method for detecting a brake caused by the Brake Pin would be to tie the Brake Pin to one of the external interrupt pins. This latter approach is needed if the Brake signal can be of insufficient length to ensure that it can be captured by a polling routine.

When, after being asserted, the condition causing the brake is removed, the PWM outputs go to whatever state that had immediately prior to the brake. This means that in order to go from brake being asserted to having the PWM run without going through an indeterminate state care must be taken. If the Brake Pin causes brake to be asserted the following prototype code will allow the PWM to go from brake to run smoothly.

- Rewrite PWMCON1 to change from Brake Pin enabled to S/W Brake
- Write CPSW.(0:4) to always "1", 11 h, or always "0" 00 h, to give brake pattern
- Set PWMCON0 to enable Run and Transfer.
- Poll Brake Pin until it is no longer active. When no longer active:

87LPC768

- Poll PWMCON0 to find that Transfer Bit PWMCON0.6 is "0". When "0":
- Write CNSW.(0:1) and CPSW.(0:4) for desired pulse widths and counter reload values
- Set PWMCON0 to Run and Transfer

Note that if a narrow pulse on the Brake Pin causes brake to be asserted, it may not be possible to go through the above code before the end of the pulse. In this case, in addition to the code shown, an external latch on the Brake Pin may be required to ensure that there is a smooth transition in going from brake to run.

The details for PWMCON1 are shown in the following table.

| PWMCON1.7                     | SYMBOL<br>BKCH<br>BKPS                                  | BKCH<br>FUNCTION<br>See table be | BKPS                                    | BPEN          | BKEN          | PWM3B   | PWM2B    |       |         |  |  |
|-------------------------------|---------------------------------------------------------|----------------------------------|-----------------------------------------|---------------|---------------|---------|----------|-------|---------|--|--|
| BIT<br>PWMCON1.7<br>PWMCON1.6 | BKCH                                                    |                                  |                                         |               |               | 1 THROE | PVVIVIZD | PWM1B | PWM0B   |  |  |
|                               | -                                                       | See table be                     |                                         |               |               |         |          | 1     | J       |  |  |
| PWMCON1.6                     | BKPS                                                    | 000 (00.00                       | elow                                    |               |               |         |          |       |         |  |  |
|                               | BIGO                                                    | 0= "Brake" i                     | s asserted i                            | f P0.2(Brak   | e Pin) is low |         |          |       |         |  |  |
|                               |                                                         | 1= "Brake" i                     | s asserted i                            | f P0.2(Brake  | e Pin) is hig | h.      |          |       |         |  |  |
| PWMCON1.5                     | BPEN                                                    | See table be                     | elow.                                   |               |               |         |          |       |         |  |  |
| PWMCON1.4                     | BKEN                                                    | 0= "Brake" i                     | s never ass                             | erted.        |               |         |          |       |         |  |  |
|                               |                                                         | 1= "Brake" i                     | s enabled p                             | er table bel  | SW.           |         |          |       |         |  |  |
| PWMCON1.3                     | PWM3B                                                   | 0= PWM3 is                       | 0= PWM3 is low, when Brake is asserted. |               |               |         |          |       |         |  |  |
|                               |                                                         | 1= PWM3 is                       | high, wher                              | Brake is as   | sserted.      |         |          |       |         |  |  |
| PWMCON1.2                     | PWMCON1.2 PWM2B 0= PWM2 is low, when Brake is asserted. |                                  |                                         |               |               |         |          |       |         |  |  |
|                               |                                                         | 1= PWM2 is                       | high, wher                              | Brake is as   | sserted.      |         |          |       |         |  |  |
| PWMCON1.1                     | PWM1B                                                   | 0= PWM1 is                       | low, when                               | Brake is as   | serted.       |         |          |       |         |  |  |
|                               |                                                         | 1= PWM1 is                       | high, wher                              | Brake is as   | sserted.      |         |          |       |         |  |  |
| PWMCON1.0                     | PWM0B                                                   | 0= PWM0 is                       | low, when                               | Brake is as   | serted.       |         |          |       |         |  |  |
|                               |                                                         | 1= PWM0 is                       | high, wher                              | n Brake is as | sserted.      |         |          |       |         |  |  |
| BPEN                          | вксн                                                    |                                  |                                         |               | ITION         |         |          |       |         |  |  |
| 0                             | 0<br>1                                                  | Always On,<br>On when PV         |                                         | ,             | Pin has no e  | effect) |          |       |         |  |  |
| 1                             | 0                                                       | On when Bra                      |                                         | 0 (           |               | ,       |          |       |         |  |  |
| 1                             | 1                                                       | Not Allowed                      |                                         |               |               |         |          |       | SU01388 |  |  |

87LPC768

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

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

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

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

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

The 87LPC768 I2C implementation duplicates that of the 87C751 and 87C752 except for the following details:

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

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

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

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

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

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

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

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

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

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

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

#### **Reading I2CON**

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

87LPC768

|         |            | 7      | 6                                                    | 5           | 4                     | 3            | 2           | 1                         | 0           |                                                         |  |
|---------|------------|--------|------------------------------------------------------|-------------|-----------------------|--------------|-------------|---------------------------|-------------|---------------------------------------------------------|--|
|         | READ       | RDAT   | ATN                                                  | DRDY        | ARL                   | STR          | STP         | MASTER                    | _           |                                                         |  |
|         | WRITE      | CXA    | IDLE                                                 | CDR         | CARL                  | CSTR         | CSTP        | XSTR                      | XSTP        |                                                         |  |
|         | L          |        |                                                      | 1           |                       |              |             |                           |             | 1                                                       |  |
| BIT     | SYMBOL     | _      | CTION                                                |             |                       |              |             |                           |             |                                                         |  |
| 12CON.7 | RDAT       |        |                                                      |             | received of           |              |             |                           |             |                                                         |  |
| "       | CXA        |        |                                                      |             | t active fla          | 0            |             |                           |             |                                                         |  |
| 12CON.6 | ATN        |        |                                                      |             | 0                     |              |             | • STP = 1.                |             |                                                         |  |
| "       | IDLE       |        | : in the I <sup>2</sup><br>eded agai                 |             | ode, writir           | ng a 1 to th | nis bit cau | ises the I <sup>2</sup> C | hardware    | to ignore the bus until it                              |  |
| 12CON.5 | DRDY       |        | -                                                    |             | set when t            | there is a   | rising edg  | e on SCL.                 |             |                                                         |  |
| "       | CDR        | Write  | Write: writing a 1 to this bit clears the DRDY flag. |             |                       |              |             |                           |             |                                                         |  |
| I2CON.4 | ARL        | Read   | l: Arbitrati                                         | on Loss fl  | ag, set wh            | en arbitra   | tion is los | t while in the            | e transmit  | mode.                                                   |  |
| "       | CARL       | Write  | Write: writing a 1 to this bit clears the CARL flag. |             |                       |              |             |                           |             |                                                         |  |
| I2CON.3 | STR        | Read   | l: Start fla                                         | g, set whe  | n a start o           | condition is | s detected  | d at a maste              | r or non-i  | dle slave.                                              |  |
| "       | CSTR       | Write  | : writing a                                          | 1 to this   | oit clears t          | he STR fl    | ag.         |                           |             |                                                         |  |
| I2CON.2 | STP        | Read   | l: Stop flag                                         | g, set whe  | n a stop c            | ondition is  | s detected  | d at a maste              | r or non-io | dle slave.                                              |  |
| "       | CSTP       | Write  | : writing a                                          | 1 to this   | oit clears t          | he STP fla   | ag.         |                           |             |                                                         |  |
| I2CON.1 | MASTER     | Read   | l: indicate                                          | s whether   | this devic            | e is curre   | ntly as bu  | s master.                 |             |                                                         |  |
| **      | XSTR       | Write  | : writing a                                          | 1 to this l | oit causes            | a repeate    | ed start co | ndition to b              | e generate  | ed.                                                     |  |
| 12CON.0 | —          | Read   | l: undefine                                          | ed.         |                       |              |             |                           |             |                                                         |  |
| "       | XSTP       | Write  | : writing a                                          | 1 to this   | oit causes            | a stop co    | ndition to  | be generate               | əd.         |                                                         |  |
|         | SETB, CLR, | CPL, M | OV (bit), o                                          | or JBC inst | ructions.             | This is due  | e to the fa | ct that read              |             | hould never be altered by<br>functions of this register |  |
|         |            |        |                                                      |             |                       |              |             |                           |             | SU01155                                                 |  |
|         |            |        |                                                      | Figure 9.   | I <sup>2</sup> C Cont | rol Regis    | ter (I2CC   | N)                        |             |                                                         |  |
| Addres  | s: D9h     |        |                                                      |             |                       |              |             |                           |             | Reset Value: xxh                                        |  |

|                                                                                                                                                                | READ   | RDAT | —     | — | — | _ | _ | —                       | — |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------|-------|---|---|---|---|-------------------------|---|--|
|                                                                                                                                                                | WRITE  | XDAT |       | — | — | — |   | —                       | — |  |
|                                                                                                                                                                |        |      |       |   |   |   |   |                         |   |  |
| BIT                                                                                                                                                            | SYMBOL | FUN  | CTION |   |   |   |   |                         |   |  |
| I2DAT.7 RDAT Read: the most recently received data bit, captured from SDA at every rising edge of SCL. I I2DAT also clears DRDY and the Transmit Active state. |        |      |       |   |   |   |   | ig edge of SCL. Reading |   |  |

XDAT Write: sets the data for the next transmitted bit. Writing I2DAT also clears DRDY and sets the Transmit Active state.

SU01156

#### Figure 10. I<sup>2</sup>C Data Register (<sup>I</sup>2DAT)

"

I2DAT.6-0

Unused.

\_

## 87LPC768

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

When a program detects ATN = 1, it should next check DRDY. If DRDY = 1, then if it receives the last bit, it should capture the data from RDAT (in I2DAT or I2CON). Next, if the next bit is to be sent, it should be written to I2DAT. One way or another, it should clear DRDY and then return to monitoring ATN. Note that if any of ARL, STR, or STP is set, clearing DRDY will not release SCL to high, so that the I<sup>2</sup>C will not go on to the next bit. If a program detects ATN = 1, and DRDY = 0, it should go on to examine ARL, STR, and STP.

ARL "Arbitration Loss" is 1 when transmit Active was set, but this device lost arbitration to another transmitter. Transmit Active is cleared when ARL is 1. There are four separate cases in which ARL is set.

1. If the program sent a 1 or repeated start, but another device sent a 0, or a stop, so that SDA is 0 at the rising edge of SCL. (If the other device sent a stop, the setting of ARL will be followed shortly by STP being set.)

2. If the program sent a 1, but another device sent a repeated start, and it drove SDA low before SCL could be driven low. (This type of ARL is always accompanied by STR = 1.)

3. In master mode, if the program sent a repeated start, but another device sent a 1, and it drove SCL low before this device could drive SDA low.

4. In master mode, if the program sent stop, but it could not be sent because another device sent a 0.

- STR "STaRt" is set to a 1 when an I<sup>2</sup>C start condition is detected at a non-idle slave or at a master. (STR is not set when an idle slave becomes active due to a start bit; the slave has nothing useful to do until the rising edge of SCL sets DRDY.)
- STP "SToP" is set to 1 when an I<sup>2</sup>C stop condition is detected at a non-idle slave or at a master. (STP is not set for a stop condition at an idle slave.)
- MASTER "MASTER" is 1 if this device is currently a master on the I<sup>2</sup>C. MASTER is set when MASTRQ is 1 and the bus is not busy (i.e., if a start bit hasn't been received since reset or a "Timer I" time-out, or if a stop has been received since the last start). MASTER is cleared when ARL is set, or after the software writes MASTRQ = 0 and then XSTP = 1.

#### Writing I2CON

Typically, for each bit in an  $I^2C$  message, a service routine waits for ATN = 1. Based on DRDY, ARL, STR, and STP, and on the current

bit position in the message, it may then write I2CON with one or more of the following bits, or it may read or write the I2DAT register.

CXA Writing a 1 to "Clear Xmit Active" clears the Transmit Active state. (Reading the I2DAT register also does this.)

#### **Regarding Transmit Active**

Transmit Active is set by writing the I2DAT register, or by writing I2CON with XSTR = 1 or XSTP = 1. The I<sup>2</sup>C interface will only drive the SDA line low when Transmit Active is set, and the ARL bit will only be set to 1 when Transmit Active is set. Transmit Active is cleared by reading the I2DAT register, or by writing I2CON with CXA = 1. Transmit Active is automatically cleared when ARL is 1.

- IDLE Writing 1 to "IDLE" causes a slave's I<sup>2</sup>C hardware to ignore the I<sup>2</sup>C until the next start condition (but if MASTRQ is 1, then a stop condition will cause this device to become a master).
- CDR Writing a 1 to "Clear Data Ready" clears DRDY. (Reading or writing the I2DAT register also does this.)
- CARL Writing a 1 to "Clear Arbitration Loss" clears the ARL bit.
- CSTR Writing a 1 to "Clear STaRt" clears the STR bit.
- CSTP Writing a 1 to "Clear SToP" clears the STP bit. Note that if one or more of DRDY, ARL, STR, or STP is 1, the low time of SCL is stretched until the service routine responds by clearing them.
- XSTR Writing 1s to "Xmit repeated STaRt" and CDR tells the I<sup>2</sup>C hardware to send a repeated start condition. This should only be at a master. Note that XSTR need not and should not be used to send an "initial" (non-repeated) start; it is sent automatically by the I<sup>2</sup>C hardware. Writing XSTR = 1 includes the effect of writing I2DAT with XDAT = 1; it sets Transmit Active and releases SDA to high during the SCL low time. After SCL goes high, the I<sup>2</sup>C hardware waits for the suitable minimum time and then drives SDA low to make the start condition.
- XSTP Writing 1s to "Xmit SToP" and CDR tells the I<sup>2</sup>C hardware to send a stop condition. This should only be done at a master. If there are no more messages to initiate, the service routine should clear the MASTRQ bit in I2CFG to 0 before writing XSTP with 1. Writing XSTP = 1 includes the effect of writing I2DAT with XDAT = 0; it sets Transmit Active and drives SDA low during the SCL low time. After SCL goes high, the I<sup>2</sup>C hardware waits for the suitable minimum time and then releases SDA to high to make the stop condition.

87LPC768

| FG Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | s: C8h<br>Addressable                                                                                                                                                                                                                                        |                               |              |             |             |                                                               |              |             | Reset Value: 00h     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|--------------|-------------|-------------|---------------------------------------------------------------|--------------|-------------|----------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 7                                                                                                                                                                                                                                                            | 6                             | 5            | 4           | 3           | 2                                                             | 1            | 0           |                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | SLAV                                                                                                                                                                                                                                                         |                               | CLRTI        | TIRUN       | _           |                                                               | CT1          | СТО         | ]                    |
| BIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | SYMBOL                                                                                                                                                                                                                                                       | FUNCTION                      |              |             |             |                                                               |              |             |                      |
| I2CFG.7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | CFG.7 SLAVEN Slave Enable. Writing a 1 this bit enables the slave functions of the I <sup>2</sup> C subsystem. If SLAVEN and MASTRQ are 0, the I <sup>2</sup> C hardware is disabled. This bit is cleared to 0 by reset and by an I <sup>2</sup> C time-out. |                               |              |             |             |                                                               |              |             |                      |
| I2CFG.6 MASTRQ Master Request. Writing a 1 to this bit requests mastership of the I <sup>2</sup> C bus. If a transmission progress when this bit is changed from 0 to 1, action is delayed until a stop condition is det start condition is sent and DRDY is set (thus making ATN = 1 and generating an I <sup>2</sup> C interru When a master wishes to release mastership status of the I <sup>2</sup> C, it writes a 1 to XSTP in I2C MASTRQ is cleared by an I <sup>2</sup> C time-out. |                                                                                                                                                                                                                                                              |                               |              |             |             | o condition is detected. A ng an I <sup>2</sup> C interrupt). |              |             |                      |
| I2CFG.5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | CLRTI                                                                                                                                                                                                                                                        | Writing a 1 to th             | nis bit clea | ars the Tin | ner I overf | low flag.                                                     | This bit pos | ition alway | ys reads as a 0.     |
| I2CFG.4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | TIRUN                                                                                                                                                                                                                                                        | Writing a 1 to th and MASTER, |              |             |             |                                                               |              |             | vith SLAVEN, MASTRQ, |
| I2CFG.2, 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | _                                                                                                                                                                                                                                                            | Reserved for fu               | iture use.   | Should no   | ot be set t | o 1 by use                                                    | er programs  | 3.          |                      |
| <ul> <li>I2CFG.2, 3 — Reserved for future use. Should not be set to 1 by user programs.</li> <li>I2CFG.1, 0 CT1, CT0 These two bits are programmed as a function of the CPU clock rate, to optimize the MIN time of SCL when this device is a master on the I<sup>2</sup>C. The time value determined by these controls both of these parameters, and also the timing for stop and start conditions.</li> </ul>                                                                             |                                                                                                                                                                                                                                                              |                               |              |             |             | nined by these bits                                           |              |             |                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                              |                               |              |             |             |                                                               |              |             | SU01157              |

#### Figure 11. I<sup>2</sup>C Configuration Register (I2CFG)

### **Regarding Software Response Time**

Because the 87LPC768 can run at 20 MHz, and because the  $I^2C$  interface is optimized for high-speed operation, it is quite likely that an  $I^2C$  service routine will sometimes respond to DRDY (which is set at a rising edge of SCL) and write I2DAT before SCL has gone low again. If XDAT were applied directly to SDA, this situation would produce an  $I^2C$  protocol violation. The programmer need not worry about this possibility because XDAT is applied to SDA only when SCL is low.

Conversely, a program that includes an I<sup>2</sup>C service routine may take a long time to respond to DRDY. Typically, an I<sup>2</sup>C routine operates on a flag-polling basis during a message, with interrupts from other peripheral functions enabled. If an interrupt occurs, it will delay the response of the I<sup>2</sup>C service routine. The programmer need not worry about this very much either, because the I<sup>2</sup>C hardware stretches the SCL low time until the service routine responds. The only constraint on the response is that it must not exceed the Timer I time-out.

Values to be used in the CT1 and CT0 bits are shown in Table 2. To allow the  $I^2C$  bus to run at the maximum rate for a particular oscillator frequency, compare the actual oscillator rate to the f OSC max column in the table. The value for CT1 and CT0 is found in the

first line of the table where CPU clock max is greater than or equal to the actual frequency.

Table 2 also shows the machine cycle count for various settings of CT1/CT0. This allows calculation of the actual minimum high and low times for SCL as follows:

SCL min high/low time (in microseconds) =  $\frac{6 * Min Time Count}{CPU clock (in MHz)}$ 

For instance, at an 8 MHz frequency, with CT1/CT0 set to 1 0, the minimum SCL high and low times will be 5.25  $\mu s.$ 

Table 2 also shows the Timer I timeout period (given in machine cycles) for each CT1/CT0 combination. The timeout period varies because of the way in which minimum SCL high and low times are measured. When the  $I^2C$  interface is operating, Timer I is pre-loaded at every SCL transition with a value dependent upon CT1/CT0. The pre-load value is chosen such that a minimum SCL high or low time has elapsed when Timer I reaches a count of 008 (the actual value pre-loaded into Timer I is 8 minus the machine cycle count).

87LPC768

### Table 3. Interaction of TIRUN with SLAVEN, MASTRQ, and MASTER

| SLAVEN,<br>MASTRQ,<br>MASTER | TIRUN | OPERATING MODE                                                                                                                                                                                                                                                                 |
|------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All 0                        | 0     | The I <sup>2</sup> C interface is disabled. Timer I is cleared and does not run. This is the state assumed after a reset. If an I <sup>2</sup> C application wants to ignore the I <sup>2</sup> C at certain times, it should write SLAVEN, MASTRQ, and TIRUN all to zero.     |
| All 0                        | 1     | The I <sup>2</sup> C interface is disabled.                                                                                                                                                                                                                                    |
| Any or all 1                 | 0     | The I <sup>2</sup> C interface is enabled. The 3 low-order bits of Timer I run for min-time generation, but the hi-order bits do not, so that there is no checking for I <sup>2</sup> C being "hung." This configuration can be used for very slow I <sup>2</sup> C operation. |
| Any or all 1                 | 1     | The I <sup>2</sup> C interface is enabled. Timer I runs during frames on the I <sup>2</sup> C, and is cleared by transitions on SCL, and by Start and Stop conditions. This is the normal state for I <sup>2</sup> C operation.                                                |

### Table 4. CT1, CT0 Values

| СТ1, СТ0 | Min Time Count<br>(Machine Cycles) | CPU Clock Max<br>(for 100 kHz I <sup>2</sup> C) | Timeout Period<br>(Machine Cycles) |  |
|----------|------------------------------------|-------------------------------------------------|------------------------------------|--|
| 1 0      | 7                                  | 8.4 MHz                                         | 1023                               |  |
| 0 1      | 6                                  | 7.2 MHz                                         | 1022                               |  |
| 0 0      | 5                                  | 6.0 MHz                                         | 1021                               |  |
| 1 1      | 4                                  | 4.8 MHz                                         | 1020                               |  |

### Interrupts

The 87LPC768 uses a four priority level interrupt structure. This allows great flexibility in controlling the handling of the 87LPC768's many interrupt sources. The 87LPC768 supports up to 13 interrupt sources.

Each interrupt source can be individually enabled or disabled by setting or clearing a bit in registers IEN0 or IEN1. The IEN0 register also contains a global disable bit, EA, which disables all interrupts at once.

Each interrupt source can be individually programmed to one of four priority levels by setting or clearing bits in the IPO, IPOH, IP1, and IP1H registers. An interrupt service routine in progress can be interrupted by a higher priority interrupt, but not by another interrupt

of the same or lower priority. The highest priority interrupt service cannot be interrupted by any other interrupt source. So, if two requests of different priority levels are received simultaneously, the request of higher priority level is serviced.

If requests of the same priority level are received simultaneously, an internal polling sequence determines which request is serviced. This is called the arbitration ranking. Note that the arbitration ranking is only used to resolve simultaneous requests of the same priority level.

Table 3 summarizes the interrupt sources, flag bits, vector addresses, enable bits, priority bits, arbitration ranking, and whether each interrupt may wake up the CPU from Power Down mode.

### Table 5. Summary of Interrupts

| Description                | Interrupt<br>Flag Bit(s) | Vector<br>Address | Interrupt<br>Enable Bit(s) | Interrupt<br>Priority | Arbitration<br>Ranking | Power Down<br>Wakeup |
|----------------------------|--------------------------|-------------------|----------------------------|-----------------------|------------------------|----------------------|
| External Interrupt 0       | IE0                      | 0003h             | EX0 (IEN0.0)               | IP0H.0, IP0.0         | 1 (highest)            | Yes                  |
| Timer 0 Interrupt          | TF0                      | 000Bh             | ET0 (IEN0.1)               | IP0H.1, IP0.1         | 4                      | No                   |
| External Interrupt 1       | IE1                      | 0013h             | EX1 (IEN0.2)               | IP0H.2, IP0.2         | 7                      | Yes                  |
| Timer 1 Interrupt          | TF1                      | 001Bh             | ET1 (IEN0.3)               | IP0H.3, IP0.3         | 10                     | No                   |
| Serial Port Tx and Rx      | TI & RI                  | 0023h             | ES (IEN0.4)                | IP0H.4, IP0.4         | 12                     | No                   |
| Brownout Detect            | BOD                      | 002Bh             | EBO (IEN0.5)               | IP0H.5, IP0.5         | 2                      | Yes                  |
| I <sup>2</sup> C Interrupt | ATN                      | 0033h             | EI2 (IEN1.0)               | IP1H.0, IP1.0         | 5                      | No                   |
| KBI Interrupt              | KBF                      | 003Bh             | EKB (IEN1.1)               | IP1H.1, IP1.1         | 8                      | Yes                  |
| Comparator 2 interrupt     | CMF2                     | 0043h             | EC2 (IEN1.2)               | IP1H.2, IP1.2         | 11                     | Yes                  |
| Watchdog Timer             | WDOVF                    | 0053h             | EWD (IEN0.6)               | IP0H.6, IP0.6         | 3                      | Yes                  |
| A/D Converter              | ADCI                     | 005Bh             | EAD (IEN1.4)               | IP1H.4, IP1.4         | 6                      | Yes                  |
| Comparator 1 interrupt     | CMF1                     | 0063h             | EC1 (IEN1.5)               | IP1H.5, IP1.5         | 9                      | Yes                  |
| Timer 1 interrupt          | -                        | 0073h             | ETI (IEN 1.7)              | lp1H.7, IP1.7         | 13 (lowest)            | No                   |

87LPC768

#### **External Interrupt Inputs**

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

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

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

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

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

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

## 87LPC768

### I/O Ports

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

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

### Table 6. Port Output Configuration Settings

| PxM1.y | PxM2.y | Port Output Mode            |  |  |  |  |
|--------|--------|-----------------------------|--|--|--|--|
| 0      | 0      | <b>Quasi-bidirectional</b>  |  |  |  |  |
| 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 87LPC768 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 13.



Figure 13. Quasi-Bidirectional Output

87LPC768

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

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

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 87LPC768 has been configured for an internal reset and is not using the external reset input function 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 87LPC768 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 87LPC768 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 16.

Each I/O port of the 87LPC768 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 14. Open Drain Output



Figure 15. Push-Pull Output

87LPC768

| 2M1 | Address:                                                                                                                                                                                           | A4h                                                                                                                                                                                      |                                                                     |            |             |             |            |               |              | Reset Value: 00h                |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|------------|-------------|-------------|------------|---------------|--------------|---------------------------------|
|     | Not Bit A                                                                                                                                                                                          | ddressable                                                                                                                                                                               |                                                                     |            |             |             |            |               |              |                                 |
|     |                                                                                                                                                                                                    | 7                                                                                                                                                                                        | 6                                                                   | 5          | 4           | 3           | 2          | 1             | 0            |                                 |
|     |                                                                                                                                                                                                    | P2S                                                                                                                                                                                      | P1S                                                                 | P0S        | ENCLK       | ENT1        | ENT0       | (P2M1.1)      | (P2M1.0)     |                                 |
| В   | ят                                                                                                                                                                                                 | SYMBOL                                                                                                                                                                                   | FUNCTION                                                            |            |             |             |            |               |              |                                 |
| Р   | 2M1.7                                                                                                                                                                                              | P2S                                                                                                                                                                                      | When P2S =                                                          | 1, this bi | t enables S | chmitt trig | ger inputs | s on Port 2.  |              |                                 |
| Р   | 2M1.6                                                                                                                                                                                              | P1S                                                                                                                                                                                      | When P1S =                                                          | 1, this bi | t enables S | chmitt trig | ger inputs | s on Port 1.  |              |                                 |
| Р   | 2M1.5                                                                                                                                                                                              | P0S                                                                                                                                                                                      | When $POS = 1$ , this bit enables Schmitt trigger inputs on Port 0. |            |             |             |            |               |              |                                 |
| Ρ   | 2M1.4                                                                                                                                                                                              | 4 ENCLK When ENCLK is set and the 87LPC764 is configured to use the on-chip RC oscillator, a clo<br>output is enabled on the X2 pin (P2.0). Refer to the Oscillator section for details. |                                                                     |            |             |             |            |               |              |                                 |
| Ρ   | 2M1.3                                                                                                                                                                                              | ENT1                                                                                                                                                                                     | When set, th one half of the                                        |            |             |             |            |               |              | quency is therefore<br>details. |
| Ρ   | P2M1.2 ENT0 When set, the P1.2 pin is toggled whenever Timer 0 overflows. The output frequency is therefore one half of the Timer 0 overflow rate. Refer to the Timer/Counterssection for details. |                                                                                                                                                                                          |                                                                     |            |             |             |            |               |              |                                 |
| Ρ   | 2M1.1, P2M                                                                                                                                                                                         | 1.0 —                                                                                                                                                                                    | These bits, a P2.1 and P2                                           |            |             |             |            | register, con | trol the out | out configuration of            |
|     |                                                                                                                                                                                                    |                                                                                                                                                                                          |                                                                     |            |             |             |            |               |              | SU01162                         |

Figure 16. 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 87LPC768, as shown in Figure 17. 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 87LPC768 allows any or all pins of port 0 to be enabled to cause this interrupt. Port pins are enabled by the setting of bits in

the KBI register, as shown in Figure 18. 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.

87LPC768



Figure 17. Keyboard Interrupt

|       | ress: 86h                         |               |                                                            |             |            |             |             |             | Reset Value: 00h      |
|-------|-----------------------------------|---------------|------------------------------------------------------------|-------------|------------|-------------|-------------|-------------|-----------------------|
| Not   | Not Bit Addressable               |               |                                                            |             |            |             |             |             |                       |
|       | 7                                 | 6             | 5                                                          | 4           | 3          | 2           | 1           | 0           |                       |
|       | KBI                               | .7 KBI.6      | KBI.5                                                      | KBI.4       | KBI.3      | KBI.2       | KBI.1       | KBI.0       |                       |
| віт   | SYMBOL                            | FUNCTION      |                                                            |             |            |             |             |             |                       |
| KBI.7 | _                                 | When set, ena | bles P0.7                                                  | as a caus   | e of a Kev | board Inte  | errupt.     |             |                       |
| KBI.6 | _                                 | When set, ena |                                                            |             |            |             | •           |             |                       |
| KBI.5 | _                                 | When set, ena | When set, enables P0.5 as a cause of a Keyboard Interrupt. |             |            |             |             |             |                       |
| KBI.4 | _                                 | When set, ena | When set, enables P0.4 as a cause of a Keyboard Interrupt. |             |            |             |             |             |                       |
| KBI.3 | _                                 | When set, ena | When set, enables P0.3 as a cause of a Keyboard Interrupt. |             |            |             |             |             |                       |
| KBI.2 | _                                 | When set, ena | bles P0.2                                                  | as a caus   | e of a Key | /board Inte | errupt.     |             |                       |
| KBI.1 | _                                 | When set, ena | bles P0.1                                                  | as a caus   | e of a Key | board Inte  | errupt.     |             |                       |
| KBI.0 | —                                 | When set, ena | bles P0.0                                                  | as a caus   | e of a Key | /board Inte | errupt.     |             |                       |
|       | Keyboard Inte<br>located at bit 7 |               | abled in or                                                | der for the | e settings | of the KBI  | register to | be effectiv | e. The interrupt flag |
|       |                                   |               |                                                            |             |            |             |             |             | SU01164               |

Figure 18. Keyboard Interrupt Register (KBI)

87LPC768

### Oscillator

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

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

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

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

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

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

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

| Oscillator Frequency | V <sub>DD</sub> = 2.7 to 4.5 V |               |             |  |  |  |  |  |
|----------------------|--------------------------------|---------------|-------------|--|--|--|--|--|
| Usernator 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 9 shows capacitor values that may be used with a quartz crystal in this mode.

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

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

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

The on-chip RC oscillator option has a typical frequency of 6 MHz and can be divided down for slower operation through the use of the DIVM register. Note that the on-chip oscillator has a  $\pm 25\%$  frequency tolerance and for that reason may not be suitable for use in some applications. A clock output on the X2/P2.0 pin may be enabled when the on-chip RC oscillator is used.

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

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

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

#### **Clock Output**

The 87LPC768 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 87LPC768. 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.

87LPC768



Figure 19. Using the Crystal Oscillator



Figure 20. Using an External Clock Input

87LPC768

SU01167

# Low power, low price, low pin count (20 pin) microcontroller with 4 kB OTP 8-bit A/D, Pulse Width Modulator



Figure 21. Block Diagram of Oscillator Control

### CPU Clock Modification: CLKR and DIVM

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

(UCFG1.3)

The 87LPC768 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 87LPC768 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.

### 87LPC768

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 87LPC768 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 22).

#### 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 22).

The processor can be made to exit Power Down mode via Reset or one of the interrupt sources shown in Table 5. 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<sub>RAM</sub>. This retains the RAM contents at the point where Power Down mode was entered. SFR contents are not guaranteed after V<sub>DD</sub> has been lowered to V<sub>RAM</sub>, therefore it is recommended to wake up the processor via Reset in this case. V<sub>DD</sub> 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, Watchdog Timer, Comparators, and A/D converter.

| PCON | Addres<br>Not Bit | s: 87h<br>Addressable |                                                                                                                                                                                                            |                                                                                                                                                                       |              |              |            | Reset Value    | • 20    | h for a Power On reset<br>h for a Brownout reset<br>h for other reset sources |  |
|------|-------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|------------|----------------|---------|-------------------------------------------------------------------------------|--|
|      |                   | 7                     | 6                                                                                                                                                                                                          | 5                                                                                                                                                                     | 4            | 3            | 2          | 1              | 0       |                                                                               |  |
|      |                   | SMO                   | D1 SMOD0                                                                                                                                                                                                   | BOF                                                                                                                                                                   | POF          | GF1          | GF0        | PD             | IDL     |                                                                               |  |
| BI   | т                 | SYMBOL                | FUNCTION                                                                                                                                                                                                   |                                                                                                                                                                       |              |              |            |                |         |                                                                               |  |
| PC   | CON.7             | SMOD1                 | When set, this                                                                                                                                                                                             | bit double                                                                                                                                                            | es the UAR   | RT baud ra   | ate for mo | odes 1, 2, and | 13.     |                                                                               |  |
| PC   | CON.6             | SMOD0                 | This bit selects the function of bit 7 of the SCON SFR. When 0, SCON.7 is the SM0 bit. When SCON.7 is the FE (Framing Error) flag. See Figure 26 for additional information.                               |                                                                                                                                                                       |              |              |            |                |         |                                                                               |  |
| PC   | CON.5             | BOF                   | Brown Out Flag. Set automatically when a brownout reset or interrupt has occurred. Also set<br>power on. Cleared by software. Refer to the Power Monitoring Functions section for addition<br>information. |                                                                                                                                                                       |              |              |            |                |         |                                                                               |  |
| PC   | CON.4             | POF                   |                                                                                                                                                                                                            | Power On Flag. Set automatically when a power-on reset has occurred. Cleared by software. Refer to the Power Monitoring Functions section for additional information. |              |              |            |                |         |                                                                               |  |
| PC   | CON.3             | GF1                   | General purpo                                                                                                                                                                                              | General purpose flag 1. May be read or written by user software, but has no effect on operation.                                                                      |              |              |            |                |         |                                                                               |  |
| PC   | CON.2             | GF0                   | General purpose flag 0. May be read or written by user software, but has no effect on operation                                                                                                            |                                                                                                                                                                       |              |              |            |                |         | o effect on operation.                                                        |  |
| PC   | CON.1             | PD                    |                                                                                                                                                                                                            | Power Down control bit. Setting this bit activates Power Down mode operation. Cleared when the Power Down mode is terminated (see text).                              |              |              |            |                |         |                                                                               |  |
| PC   | CON.0             | IDL                   |                                                                                                                                                                                                            |                                                                                                                                                                       | tting this b | oit activate | s Idle mo  | de operation.  | Cleared | d when the Idle mode is                                                       |  |
|      |                   |                       | terminated (se                                                                                                                                                                                             | e text).                                                                                                                                                              |              |              |            |                |         | SU01168                                                                       |  |

Figure 22. Power Control Register (PCON)

87LPC768

| Wakeup Source             | Conditions                                                                                                                                                                       |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| External Interrupt 0 or 1 | The corresponding interrupt must be enabled.                                                                                                                                     |
| Keyboard Interrupt        | The keyboard interrupt feature must be enabled and properly set up. The corresponding interrupt must be enabled.                                                                 |
| Comparator 1 or 2         | The comparator(s) 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.                                                                                                                                        |
| A/D converter             | Must use internal RC clock (RCCLK = 1) for A/D converter to work in Power Down mode. The A/D must be enabled and properly set up. The corresponding interrupt must be enabled.   |

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

87LPC768

### 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 87LPC768 has an active low reset input when configured for an external reset. A fully internal reset may also be configured which provides a reset when power is initially applied to the device. The watchdog timer can act as an oscillator fail detect because it uses an independent, fully on-chip oscillator.

The external reset input is disabled, and fully internal reset generation enabled, by programming the RPD bit in the EPROM configuration register UCFG1 to 0. EPROM configuration is described in the section EPROM Characteristics



Figure 23. Typical External Reset Circuits



Figure 24. Block Diagram Showing Reset Sources

### Timer/Counters

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

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

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

The "Timer" or "Counter" function is selected by control bits C/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.

| OD Addres | ss: 89h<br>Addressable | 9                               |            |             |              |            |              |              | Reset Value: (                                       |
|-----------|------------------------|---------------------------------|------------|-------------|--------------|------------|--------------|--------------|------------------------------------------------------|
|           | 7                      | 6                               | 5          | 4           | 3            | 2          | 1            | 0            |                                                      |
|           | GAT                    | E C/T                           | M1         | MO          | GATE         | C/T        | M1           | MO           | ]                                                    |
| BIT       | SYMBOL                 | FUNCTION                        |            |             |              |            |              |              |                                                      |
| TMOD.7    | GATE                   |                                 |            |             |              |            |              |              | the INT1 pin is high and control bit is set.         |
| TMOD.6    | C/T                    | Timer or Coun<br>Set for Counte |            |             |              |            | ner operatio | on (input fr | om internal system clock.)                           |
| TMOD.5, 4 | M1, M0                 | Mode Select for                 | or Timer 1 | (see table  | e below).    |            |              |              |                                                      |
| TMOD.3    | GATE                   |                                 |            |             |              |            |              |              | the INTO pin is high and control bit is set.         |
| TMOD.2    | C/T                    | Timer or Coun<br>Set for Counte |            |             |              |            | ner operatio | on (input fr | om internal system clock.)                           |
| TMOD.1, 0 | M1, M0                 | Mode Select for                 | or Timer 0 | (see table  | e below).    |            |              |              |                                                      |
|           | <u>M1, M0</u>          | Timer Mode                      |            |             |              |            |              |              |                                                      |
|           | 0 0                    | 8048 Timer "T                   | _n" serves | s as 5-bit  | prescaler.   |            |              |              |                                                      |
|           | 0 1                    | 16-bit Timer/C                  | ounter "Th | n" and "ا   | TLn" are ca  | ascaded; t | here is no   | prescaler.   |                                                      |
|           | 10                     | 8-bit auto-reloa                | 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<br>imer 1 control bits (see |
|           |                        |                                 |            |             |              |            |              |              | SU01171                                              |

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

### 87LPC768

#### Mode 0

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

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

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

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

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

|        | ess: 88h<br>ddressable |                                     |                                                                                                                                                            |              |            |             |              |             | Reset Value: 00      |  |  |
|--------|------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------|-------------|--------------|-------------|----------------------|--|--|
| 2      |                        |                                     |                                                                                                                                                            |              |            |             |              |             |                      |  |  |
|        | 7                      | 6                                   | 5                                                                                                                                                          | 4            | 3          | 2           | 1            | 0           |                      |  |  |
|        | TF1                    | I TR1                               | TF0                                                                                                                                                        | TR0          | IE1        | IT1         | IE0          | IT0         | ]                    |  |  |
| BIT    | SYMBOL                 | FUNCTION                            |                                                                                                                                                            |              |            |             |              |             |                      |  |  |
| TCON.7 | TF1                    | Timer 1 overflo                     |                                                                                                                                                            |              |            | imer/Cour   | nter overflo | w. Cleared  | by hardware when the |  |  |
| TCON.6 | TR1                    | Timer 1 Run co                      | ontrol bit.                                                                                                                                                | Set/cleare   | d by softw | vare to tur | n Timer/Co   | unter 1 on  | /off.                |  |  |
| TCON.5 | TF0                    |                                     | Timer 0 overflow flag. Set by hardware on Timer/Counter overflow. Cleared by hardware when the processor vectors to the interrupt routine, or by software. |              |            |             |              |             |                      |  |  |
| TCON.4 | TR0                    | Timer 0 Run co                      | ontrol bit.                                                                                                                                                | Set/cleare   | d by softw | vare to tur | n Timer/Co   | unter 0 on  | /off.                |  |  |
| TCON.3 | IE1                    | Interrupt 1 Edg<br>hardware whe     |                                                                                                                                                            |              |            |             |              | edge is de  | tected. Cleared by   |  |  |
| TCON.2 | IT1                    | Interrupt 1 Typ<br>external interru |                                                                                                                                                            | oit. Set/cle | ared by s  | oftware to  | specify fal  | ling edge/l | ow level triggered   |  |  |
| TCON.1 | IE0                    |                                     | nterrupt 0 Edge flag. Set by hardware when external interrupt 0 edge is detected. Cleared by nardware when the interrupt is processed, or by software.     |              |            |             |              |             |                      |  |  |
| TCON.0 | IT0                    | Interrupt 0 Typ<br>external interru |                                                                                                                                                            | oit. Set/cle | ared by s  | oftware to  | specify fal  | ling edge/l | ow level triggered   |  |  |
|        |                        |                                     |                                                                                                                                                            |              |            |             |              |             | SU01172              |  |  |

Figure 26. Timer/Counter Control Register (TCON)



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

87LPC768

#### 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 Figure 28

#### Mode 2

Mode 2 configures the Timer register as an 8-bit Counter (TL1) with automatic reload, as shown in Figure 29. 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 the same for Timer 0 and Timer 1.

#### 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 30. TL0 uses the Timer 0 control bits: C/T, GATE, TR0,  $\overline{INT0}$ , and TF0. 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 87LPC768 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 28. Timer/Counter 0 or 1 in Mode 1 (16-Bit Counter)



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

87LPC768



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

### Timer Overflow Toggle Output

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

### UART

The 87LPC768 includes an enhanced 80C51 UART. The baud rate source for the UART is timer 1 for modes 1 and 3, while the rate is fixed in modes 0 and 2. Because CPU clocking is different on the 87LPC768 than on the standard 80C51, baud rate calculation is somewhat different. Enhancements over the standard 80C51 UART include Framing Error detection and automatic address recognition.

The serial port is full duplex, meaning it can transmit and receive simultaneously. It is also receive-buffered, meaning it can commence reception of a second byte before a previously received byte has been read from the SBUF register. However, if the first byte still hasn't been read by the time reception of the second byte is complete, the first byte will be lost. The serial port receive and transmit registers are both accessed through Special Function Register SBUF. Writing to SBUF loads the transmit register, and reading SBUF accesses a physically separate receive register.

The serial port can be operated in 4 modes:

### Mode 0

Serial data enters and exits through RxD. TxD outputs the shift clock. 8 bits are transmitted or received, LSB first. The baud rate is fixed at 1/6 of the CPU clock frequency.

#### Mode 1

10 bits are transmitted (through TxD) or received (through RxD): a start bit (logical 0), 8 data bits (LSB first), and a stop bit (logical 1). When data is received, the stop bit is stored in RB8 in Special Function Register SCON. The baud rate is variable and is determined by the Timer 1 overflow rate.

#### Mode 2

11 bits are transmitted (through TxD) or received (through RxD): start bit (logical 0), 8 data bits (LSB first), a programmable 9th data bit, and a stop bit (logical 1). When data is transmitted, the 9th data bit (TB8 in SCON) can be assigned the value of 0 or 1. Or, for example, the parity bit (P, in the PSW) could be moved into TB8. When data is received, the 9th data bit goes into RB8 in Special Function Register SCON, while the stop bit is ignored. The baud rate is programmable to either 1/16 or 1/32 of the CPU clock frequency, as determined by the SMOD1 bit in PCON.

#### Mode 3

11 bits are transmitted (through TxD) or received (through RxD): a start bit (logical 0), 8 data bits (LSB first), a programmable 9th data bit, and a stop bit (logical 1). In fact, Mode 3 is the same as Mode 2 in all respects except baud rate. The baud rate in Mode 3 is variable and is determined by the Timer 1 overflow rate.

In all four modes, transmission is initiated by any instruction that uses SBUF as a destination register. Reception is initiated in Mode 0 by the condition RI = 0 and REN = 1. Reception is initiated in the other modes by the incoming start bit if REN = 1.

### 87LPC768

### Serial Port Control Register (SCON)

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

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

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

|         | ss: 98h<br>dressable |                                |              |              |             |            |              |               | Reset Value: 00h                                                     |
|---------|----------------------|--------------------------------|--------------|--------------|-------------|------------|--------------|---------------|----------------------------------------------------------------------|
| Dit Au  |                      |                                |              |              |             |            |              |               |                                                                      |
|         | 7                    | 6                              | 5            | 4            | 3           | 2          | 1            | 0             | _                                                                    |
|         | SM0/                 | FE SM1                         | SM2          | REN          | TB8         | RB8        | ТІ           | RI            |                                                                      |
| BIT     | SYMBOL               | FUNCTION                       |              |              |             |            |              |               |                                                                      |
| SCON.7  | FE                   |                                | tware. The   |              |             |            |              |               | is detected. Must be is bit to be accessible.                        |
| SCON.7  | SM0                  | With SM1, det to be accessib   |              |              |             | SMOD0 I    | bit in the P | CON regis     | ter must be 0 for this bit                                           |
| SCON. 6 | SM1                  | With SM0, det                  | ines the s   | erial port n | node (see   | table belo | ow).         |               |                                                                      |
|         | <u>SM0, SM1</u>      | UART Mode                      |              | Baud         | Rate        |            |              |               |                                                                      |
|         | 0 0                  | 0: shift registe               | r            | CPU          | clock/6     |            |              |               |                                                                      |
|         | 0 1                  | 1: 8-bit UART                  |              | Varial       | ole (see te | ∋xt)       |              |               |                                                                      |
|         | 10                   | 2: 9-bit UART                  |              | CPU          | clock/32 d  | or CPU clo | ock/16       |               |                                                                      |
|         | 1 1                  | 3: 9-bit UART                  |              | Varial       | ole (see te | ext)       |              |               |                                                                      |
| SCON.5  | SM2                  |                                | ill not be a | activated if | the recei   | ved 9th da | ta bit (RB8  | 3) is 0. In N | ode 2 or 3, if SM2 is set<br>/lode 1, if SM2=1 then RI<br>ould be 0. |
| SCON.4  | REN                  | Enables seria                  | reception    | . Set by so  | oftware to  | enable re  | ception. Cl  | ear by sof    | tware to disable reception                                           |
| SCON.3  | TB8                  | The 9th data b                 | it that will | be transm    | itted in M  | odes 2 an  | d 3. Set or  | clear by s    | oftware as desired.                                                  |
| SCON.2  | RB8                  | In Modes 2 ar<br>was received. |              |              |             | s receivec | I. In Mode   | 1, it SM2=    | 0, RB8 is the stop bit tha                                           |
| SCON.1  | ТІ                   |                                |              |              |             |            |              |               | de 0, or at the beginning ed by software.                            |
| SCON.0  | RI                   |                                |              |              |             |            |              |               | de 0, or halfway through<br>l2). Must be cleared by                  |

Figure 31. Serial Port Control Register (SCON)

### 87LPC768

#### **Baud Rates**

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

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

#### Using Timer 1 to Generate Baud Rates

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

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

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

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

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

87LPC768

| Timer Count |          |          |           | Baud Rate |           |           |           |
|-------------|----------|----------|-----------|-----------|-----------|-----------|-----------|
| Timer Count | 2400     | 4800     | 9600      | 19.2k     | 38.4k     | 57.6k     | 115.2k    |
| -1          | 0.2304   | 0.4608   | 0.9216    | * 1.8432  | * 3.6864  | 5.5296    | * 11.0592 |
| -2          | 0.4608   | 0.9216   | * 1.8432  | * 3.6864  | * 7.3728  | * 11.0592 | -         |
| -3          | 0.6912   | 1.3824   | 2.7648    | 5.5296    | * 11.0592 | 16.5888   | -         |
| -4          | 0.9216   | * 1.8432 | * 3.6864  | * 7.3728  | * 14.7456 | -         | -         |
| -5          | 1.1520   | 2.3040   | 4.6080    | 9.2160    | * 18.4320 | -         | -         |
| -6          | 1.3824   | 2.7648   | 5.5296    | * 11.0592 | -         | -         | -         |
| -7          | 1.6128   | 3.2256   | 6.4512    | 12.9024   | -         | -         | -         |
| -8          | * 1.8432 | * 3.6864 | * 7.3728  | * 14.7456 | -         | -         | -         |
| -9          | 2.0736   | 4.1472   | 8.2944    | 16.5888   | -         | -         | -         |
| -10         | 2.3040   | 4.6080   | 9.2160    | * 18.4320 | -         | -         | -         |
| -11         | 2.5344   | 5.0688   | 10.1376   | -         | -         | -         | -         |
| -12         | 2.7648   | 5.5296   | * 11.0592 | -         | -         | -         | -         |
| -13         | 2.9952   | 5.9904   | 11.9808   | -         | -         | -         | -         |
| -14         | 3.2256   | 6.4512   | 12.9024   | -         | -         | -         | -         |
| -15         | 3.4560   | 6.9120   | 13.8240   | -         | -         | -         | -         |
| -16         | * 3.6864 | * 7.3728 | * 14.7456 | -         | -         | -         | -         |
| -17         | 3.9168   | 7.8336   | 15.6672   | -         | -         | -         | -         |
| -18         | 4.1472   | 8.2944   | 16.5888   | -         | -         | -         | -         |
| -19         | 4.3776   | 8.7552   | 17.5104   | -         | -         | -         | -         |
| -20         | 4.6080   | 9.2160   | * 18.4320 | -         | -         | -         | -         |
| -21         | 4.8384   | 9.6768   | 19.3536   | -         | -         | -         | -         |

### Table 12. Baud Rates, Timer Values, and CPU Clock Frequencies for SMOD1 = 1

### NOTES TO TABLES 11 AND 12:

1. Tables 6 and 7 apply to UART modes 1 and 3 (variable rate modes), and show CPU clock rates in MHz for standard baud rates from 2400 to 115.2k baud.

Table 6 shows timer settings and CPU clock rates with the SMOD1 bit in the PCON register = 0 (the default after reset), while Table 7 reflects the SMOD1 bit = 1.

3. The tables show all potential CPU clock frequencies up to 20 MHz that may be used for baud rates from 9600 baud to 115.2k baud. Other CPU clock frequencies that would give only lower baud rates are not shown.

4. Table entries marked with an asterisk (\*) indicate standard crystal and ceramic resonator frequencies that may be obtained from many sources without special ordering.

### 87LPC768

#### More About UART Mode 0

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

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

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

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

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

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

#### More About UART Mode 1

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

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

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

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

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

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

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

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



Figure 32. Serial Port Mode 0



Figure 33. Serial Port Mode 1

#### More About UART Modes 2 and 3

Eleven bits are transmitted (through TxD), or received (through RxD): a start bit (0), 8 data bits (LSB first), a programmable 9th data bit, and a stop bit (1). On transmit, the 9th data bit (TB8) can be assigned the value of 0 or 1. On receive, the 9the data bit goes into RB8 in SCON. The baud rate is programmable to either 1/16 or 1/32 of the CPU clock frequency in Mode 2. Mode 3 may have a variable baud rate generated from Timer 1.

Figures 34 and 35 show a functional diagram of the serial port in Modes 2 and 3. The receive portion is exactly the same as in Mode 1. The transmit portion differs from Mode 1 only in the 9th bit of the transmit shift register.

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

The transmission begins with activation of SEND, which puts the start bit at TxD. One bit time later, DATA is activated, which enables the output bit of the transmit shift register to TxD. The first shift pulse occurs one bit time after that. The first shift clocks a 1 (the stop bit) into the 9th bit position of the shift register. Thereafter, only zeros are clocked in. Thus, as data bits shift out to the right, zeros are clocked in from the left. When TB8 is at the output position of the shift register, then the stop bit is just to the left of TB8, and all positions to the left of that contain zeros. This condition flags the TX Control unit to do one last shift and then deactivate SEND and set TI. This occurs at the 11th divide-by-16 rollover after "write to SBUF."

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

At the 7th, 8th, and 9th counter states of each bit time, the bit detector samples the value of R–D. The value accepted is the value that was seen in at least 2 of the 3 samples. If the value accepted during the first bit time is not 0, the receive circuits are reset and the unit goes back to looking for another 1-to-0 transition. If the start bit

proves valid, it is shifted into the input shift register, and reception of the rest of the frame will proceed.

As data bits come in from the right, 1s shift out to the left. When the start bit arrives at the leftmost position in the shift register (which in Modes 2 and 3 is a 9-bit register), it flags the RX Control block to do one last shift, load SBUF and RB8, and set RI.

The signal to load SBUF and RB8, and to set RI, will be generated if, and only if, the following conditions are met at the time the final shift pulse is generated. 1. RI = 0, and 2. Either SM2 = 0, or the received 9th data bit = 1.

If either of these conditions is not met, the received frame is irretrievably lost, and RI is not set. If both conditions are met, the received 9th data bit goes into RB8, and the first 8 data bits go into SBUF. One bit time later, whether the above conditions were met or not, the unit goes back to looking for a 1-to-0 transition at the RxD input.

#### **Multiprocessor Communications**

UART modes 2 and 3 have a special provision for multiprocessor communications. In these modes, 9 data bits are received or transmitted. When data is received, the 9th bit is stored in RB8. The UART can be programmed such that when the stop bit is received, the serial port interrupt will be activated only if RB8 = 1. This feature is enabled by setting bit SM2 in SCON. One way to use this feature in multiprocessor systems is as follows:

When the master processor wants to transmit a block of data to one of several slaves, it first sends out an address byte which identifies the target slave. An address byte differs from a data byte in that the 9th bit is 1 in an address byte and 0 in a data byte. With SM2 = 1, no slave will be interrupted by a data byte. An address byte, however, will interrupt all slaves, so that each slave can examine the received byte and see if it is being addressed. The addressed slave will clear its SM2 bit and prepare to receive the data bytes that follow. The slaves that weren't being addressed leave their SM2 bits set and go on about their business, ignoring the subsequent data bytes.

SM2 has no effect in Mode 0, and in Mode 1 can be used to check the validity of the stop bit, although this is better done with the Framing Error flag. In a Mode 1 reception, if SM2 = 1, the receive interrupt will not be activated unless a valid stop bit is received.



Figure 34. Serial Port Mode 2



Figure 35. Serial Port Mode 3

### 87LPC768

### Low power, low price, low pin count (20 pin) microcontroller with 4 kB OTP 8-bit A/D, Pulse Width Modulator

#### Automatic Address Recognition

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

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

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

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

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

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

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

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

#### Watchdog Timer

When enabled via the WDTE configuration bit, the watchdog timer is operated from an independent, fully on-chip oscillator in order to provide the greatest possible dependability. When the watchdog feature is enabled, the timer must be fed regularly by software in order to prevent it from resetting the CPU, and it <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 36.

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

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

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

### Watchdog Feed Sequence

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

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

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

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

#### Watchdog Reset

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

87LPC768



Figure 36. Block Diagram of the Watchdog Timer

| DCON Address: A |           | Reset Va              |                                                                                                                                                                              | )h for a wat | 0            |             |              |            |                                     |                 |  |  |
|-----------------|-----------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|-------------|--------------|------------|-------------------------------------|-----------------|--|--|
| Not Bit Ad      | dressable |                       | • 10                                                                                                                                                                         | h for other  | rest sourc   | es if the v | vatchdog is  | enabled v  | ia the WDTE conf                    | iguration bit.  |  |  |
|                 |           |                       | • 00                                                                                                                                                                         | )h for other | reset sour   | ces if the  | watchdog i   | s disabled | via the WDTE co                     | nfiguration bit |  |  |
|                 |           |                       |                                                                                                                                                                              |              |              |             |              |            |                                     |                 |  |  |
|                 | 7         | 6                     | 5                                                                                                                                                                            | 4            | 3            | 2           | 1            | 0          |                                     |                 |  |  |
|                 | _         | — V                   | VDOVF                                                                                                                                                                        | WDRUN        | WDCLK        | WDS2        | WDS1         | WDS0       |                                     |                 |  |  |
|                 |           |                       |                                                                                                                                                                              |              |              |             |              |            |                                     |                 |  |  |
| BIT             | SYMBOL    | FUNCTIO               | <b>N</b>                                                                                                                                                                     |              |              |             |              |            |                                     |                 |  |  |
| WDCON.7, 6      | —         | Reserved              | for futur                                                                                                                                                                    | e use. Shou  | uld not be s | set to 1 by | / user prog  | rams.      |                                     |                 |  |  |
| WDCON.5         | WDOVF     | Watchdog<br>the watch |                                                                                                                                                                              |              | Set when     | a watchd    | log reset or | timer ove  | flow occurs. Clea                   | red when        |  |  |
| WDCON.4         | WDRUN     |                       | Watchdog run control. The watchdog timer is started when WDRUN = 1 and stopped when WDRUN = 0. This bit is forced to 1 (watchdog running) if the WDTE configuration bit = 1. |              |              |             |              |            |                                     |                 |  |  |
| WDCON.3         | WDCLK     | the watch             | dog RC                                                                                                                                                                       |              | hen WDCL     | K = 0. Th   |              |            | when WDCLK = 1<br>sing the watchdog |                 |  |  |
| WDCON.2-0       | WDS2-0    | Watchdog              | g rate sel                                                                                                                                                                   | ect.         |              |             |              |            |                                     |                 |  |  |
|                 | WDS2-0    | Timeout (             | <u>Clocks</u>                                                                                                                                                                | Minimur      | n Time       | N           | ominal Time  | <u>e</u>   | <u>Maximum Time</u>                 |                 |  |  |
|                 | 000       | 8,19                  | 92                                                                                                                                                                           | 10 r         | ns           |             | 16 ms        |            | 23 ms                               |                 |  |  |
|                 | 001       | 16,3                  | 84                                                                                                                                                                           | 20 r         | ns           |             | 32 ms        |            | 45 ms                               |                 |  |  |
|                 | 010       | 32,7                  | 68                                                                                                                                                                           | 41 r         | ns           |             | 65 ms        |            | 90 ms                               |                 |  |  |
|                 | 011       | 65,5                  | 36                                                                                                                                                                           | 82 r         | ns           |             | 131 ms       |            | 180 ms                              |                 |  |  |
|                 | 100       | 131,0                 | )72                                                                                                                                                                          | 165          | ms           |             | 262 ms       |            | 360 ms                              |                 |  |  |
|                 | 101       | 262,1                 | 44                                                                                                                                                                           | 330          | ms           |             | 524 ms       |            | 719 ms                              |                 |  |  |
|                 | 110       | 524,2                 | 288                                                                                                                                                                          | 660          | ms           |             | 1.05 sec     |            | 1.44 sec                            |                 |  |  |
|                 | 111       | 1,048,                | 576                                                                                                                                                                          | 1.3 s        | sec          |             | 2.1 sec      |            | 2.9 sec                             |                 |  |  |
|                 |           | . ,                   |                                                                                                                                                                              |              |              |             |              |            |                                     | SU01183         |  |  |

Figure 37. Watchdog Timer Control Register (WDCON)

### 87LPC768

### Additional Features

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

#### Software Reset

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

#### **Dual Data Pointers**

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

Specific instructions affected by the Data Pointer selection are:

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

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

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

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

| JXR1 | Address   | s: A2h      |      |           |            |                                |               |             |              |               | Reset Value: 0                         |
|------|-----------|-------------|------|-----------|------------|--------------------------------|---------------|-------------|--------------|---------------|----------------------------------------|
|      | Not Bit / | Addressable |      |           |            |                                |               |             |              |               |                                        |
|      |           | _           | 7    | 6         | 5          | 4                              | 3             | 2           | 1            | 0             |                                        |
|      |           |             | KBF  | BOD       | BOI        | LPEP                           | SRST          | 0           | _            | DPS           |                                        |
| BI   | т         | SYMBOL      | FUN  |           |            |                                |               |             |              |               |                                        |
| AL   | JXR1.7    | KBF         |      |           |            | . Set when be cleared          |               |             | t is enabled | d for the Key | board Interrupt                        |
| AL   | JXR1.6    | BOD         |      |           |            | en set, turn<br>ection for de  |               | out detec   | tion and sa  | aves power. S | See Power                              |
| AL   | JXR1.5    | BOI         | the  |           | detect fun |                                |               |             |              |               | nip reset and allows<br>ring Functions |
| AL   | JXR1.4    | LPEP        |      | be clear  |            |                                |               |             |              |               | Set by software. Can les section for   |
| AL   | JXR1.3    | SRST        | Soft | ware Res  | et. When s | set by softw                   | are, resets   | the 87LF    | PC764 as if  | a hardware    | reset occurred.                        |
| AL   | JXR1.2    | —           |      |           |            | -wired 0. All<br>s in the regi |               | ng of the l | DPS bit by   | incrementing  | g AUXR1, without                       |
| AL   | JXR1.1    | _           | Res  | erved for | future use | . Should no                    | t be set to 7 | 1 by user   | programs.    |               |                                        |
| AL   | JXR1.0    | DPS         | Data | a Pointer | Select. Ch | ooses one                      | of two Data   | Pointers    | for use by   | the program   | . See text for details.                |
|      |           |             |      |           |            |                                |               |             |              |               | SU01184                                |

Figure 38. AUXR1 Register

### 87LPC768

### **EPROM Characteristics**

Programming of the EPROM on the 87LPC768 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 in-circuit programming of the 87LPC768 in an application board. Details of the programming algorithm may be found in a separate document that is available on the Philips web site at: http://www.semiconductors.philips.com/mcu/support/progspecs/

The 87LPC768 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 87LPC768 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.

A special user data area is also available for access via the MOVC instruction at addresses FCE0h through FCFFh. This "customer code" space is programmed in the same manner as the main code EPROM and may be used to store a serial number, manufacturing date, or other application information.

#### 32-Byte Customer Code Space

A small supplemental EPROM space is reserved for use by the customer in order to identify code revisions, store checksums, add a serial number to each device, or any other desired use. This area exists in the code memory space from addresses FCE0h through FCFFh. Code execution from this space is not supported, but it may be read as data through the use of the MOVC instruction with the appropriate addresses. The memory may be programmed at the same time as the rest of the code memory and UCFG bytes are programmed.

#### System Configuration Bytes

A number of user configurable features of the 87LPC768 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 39 and 40. 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.

| G1 Address | s: FD00h |        |                                                                                           |                             |                            |              |             |             | Unj         | programmed Value: F                             |  |
|------------|----------|--------|-------------------------------------------------------------------------------------------|-----------------------------|----------------------------|--------------|-------------|-------------|-------------|-------------------------------------------------|--|
|            |          | 7      | 6                                                                                         | 5                           | 4                          | 3            | 2           | 1           | 0           |                                                 |  |
|            |          | WDTE   | RPD                                                                                       | PRHI                        | BOV                        | CLKR         | FOSC2       | FOSC1       | FOSC0       |                                                 |  |
| BIT        | SYM      | BOL    | FUNC                                                                                      | ION                         |                            |              |             |             |             |                                                 |  |
| UCFG1.7    | WD       | TE     |                                                                                           |                             | nable. Whe<br>nerate an ir |              | med (0), d  | isables the | watchdog    | timer. The timer may                            |  |
| UCFG1.6    | RF       | PD     |                                                                                           | oin disable<br>nly port pin |                            | sables the   | reset func  | tion of pin | P1.5, allow | ving it to be used as a                         |  |
| UCFG1.5    | PR       | HI     | Port reset high. When 1, ports reset to a high state. When 0, ports reset to a low state. |                             |                            |              |             |             |             |                                                 |  |
| UCFG1.4    | BC       | DV     |                                                                                           |                             |                            |              |             |             |             | When 0, the brownou<br>ions section.            |  |
| UCFG1.3    | CLI      | KR     | taking                                                                                    | 12 CPU clo                  |                            | plete as in  | the standa  |             |             | ults in machine cycles<br>ackward compatibility |  |
| UCFG1.2-0  | FOSC2-   | -FSOC0 |                                                                                           |                             |                            |              |             |             |             | tion. Combinations or future use.               |  |
|            | FOSC2-   | -FOSC0 | <u>Oscilla</u>                                                                            | tor Configu                 | ration                     |              |             |             |             |                                                 |  |
|            | 1 1      | 1      | Externa                                                                                   | al clock inp                | ut on X1 (de               | efault setti | ng for an u | Inprogramr  | ned part).  |                                                 |  |
|            | 0 1      | 1      | Interna                                                                                   | I RC oscilla                | ator, 6 MHz                | ±25%.        |             |             |             |                                                 |  |
|            | 0 1      | 0      | Low fre                                                                                   | quency cr                   | ystal, 20 kH               | z to 100 kł  | Ηz.         |             |             |                                                 |  |
|            | 0 0      | ) 1    | Mediur                                                                                    | n frequenc                  | y crystal or               | resonator,   | 100 kHz t   | o 4 MHz.    |             |                                                 |  |
|            | 0 0      | 0 0    | High fr                                                                                   | equency cr                  | ystal or res               | onator, 4 N  | /Hz to 20   | MHz.        |             |                                                 |  |

Figure 39. EPROM System Configuration Byte 1 (UCFG1)

87LPC768



Figure 40. EPROM System Configuration Byte 2 (UCFG2)

### Security Bits

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

### Table 13. EPROM Security Bits

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

### **ABSOLUTE MAXIMUM RATINGS**

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

NOTES:

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

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

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

### 87LPC768

### DC ELECTRICAL CHARACTERISTICS

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

| SYMBOL                             | DADAMETED                                                    | TEAT CONDITIONS                                    |                          |                     |                          |         |  |
|------------------------------------|--------------------------------------------------------------|----------------------------------------------------|--------------------------|---------------------|--------------------------|---------|--|
| SYMBOL                             | PARAMETER                                                    | TEST CONDITIONS                                    | MIN                      | TYP <sup>1</sup>    | MAX                      | MA UNIT |  |
|                                    | Device events an existing                                    | 5.0 V, 20 MHz <sup>11</sup>                        |                          | 15                  | 25                       |         |  |
| DD                                 | Power supply current, operating                              | 3.0 V, 10 MHz <sup>11</sup>                        |                          | 4                   | 7                        | mA      |  |
|                                    | Devenue and the second state                                 | 5.0 V, 20 MHz <sup>11</sup>                        |                          | 6                   | 10                       | mA      |  |
| I <sub>ID</sub>                    | Power supply current, Idle mode                              | 3.0 V, 10 MHz <sup>11</sup>                        |                          | 2                   | 4                        | mA      |  |
|                                    | Power eventy everent Dewer Dewe mode                         | 5.0 V <sup>11</sup>                                |                          | 1                   | 10                       | μA      |  |
| 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       |  |
| N.                                 | Input low voltage (TTL input)                                | 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 V <sub>DD</sub>     | 0.4 V <sub>DD</sub> | 0.3 V <sub>DD</sub>      | V       |  |
| VIH                                | Input high voltage (TTL input)                               |                                                    | 0.2 V <sub>DD</sub> +0.9 |                     | V <sub>DD</sub> +0.5     | V       |  |
| V <sub>IH1</sub>                   | Positive going threshold (Schmitt input)                     |                                                    | 0.7 V <sub>DD</sub>      | 0.6 V <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 and to use all a set s <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 <sup>3</sup>                  | $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}, 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}$ or $V_{IH}$                      |                          |                     | ±2                       | μΑ      |  |
|                                    |                                                              | V <sub>IN</sub> = 1.5 V at V <sub>DD</sub> = 3.0 V | -30                      |                     | -250                     | μΑ      |  |
| ITL                                | Logical 1 to 0 transition current, all ports <sup>3, 6</sup> | $V_{IN}$ = 2.0 V at $V_{DD}$ = 5.5 V               | -150                     |                     | -650                     | μA      |  |
| R <sub>RST</sub>                   | Internal reset pull-up resistor                              |                                                    | 40                       |                     | 225                      | kΩ      |  |
| V <sub>BO2.5</sub>                 | Brownout trip voltage with BOV = 1 <sup>12</sup>             | T <sub>amb</sub> = 0°C to +70°C                    | 2.45                     | 2.5                 | 2.65                     | V       |  |
| V <sub>BO3.8</sub>                 | Brownout trip voltage with BOV = 0                           |                                                    | 3.45                     | 3.8                 | 3.90                     | V       |  |
| V <sub>REF</sub>                   | Bandgap reference voltage                                    |                                                    | 1.11                     | 1.26                | 1.41                     | V       |  |
| t <sub>C</sub> (V <sub>REF</sub> ) | Bandgap temperature coefficient                              |                                                    |                          | tbd                 |                          | ppm/°0  |  |
| SS                                 | Bandgap supply sensitivity                                   |                                                    |                          | tbd                 |                          | %/V     |  |

NOTES:

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

2. See other Figures for details.

Active mode:  $I_{CC(MAX)} = tbd$ 

Idle mode: I<sub>CC(MAX)</sub> = tbd 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.

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

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

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: 20 mA

80 mA Maximum total I<sub>OL</sub> for all outputs:

Maximum total I<sub>OH</sub> for all outputs: 5 mA

If IOL exceeds the test condition, VOL may exceed the related specification. Pins are not guaranteed to sink current greater than the listed test conditions.

10. Pin capacitance is characterized but not tested.

11. The IDD, IDD, and IPD specifications are measured using an external clock with the following functions disabled: comparators, brownout

detect, and watchdog timer. For V<sub>DD</sub> = 3 V, LPEP = 1. Refer to the appropriate figures on the following pages for additional current drawn by each of these functions and detailed graphs for other frequency and voltage combinations.

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

87LPC768

### COMPARATOR ELECTRICAL CHARACTERISTICS

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

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

NOTE:

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

### A/D CONVERTER DC ELECTRICAL CHARACTERISTICS

Vdd = 3.0V to 6.0V unless otherwise specified;

Tamb = 0 to +70°C for commercial, -40°C to +85°C for industrial, unless otherwise specified.

| SYMBOL           | PARAMETER                                     | TEST CONDITIONS | LIN                   | LIMITS                |      |  |
|------------------|-----------------------------------------------|-----------------|-----------------------|-----------------------|------|--|
| STMBOL           | FARAMETER                                     | TEST CONDITIONS | MIN                   | MAX                   | UNIT |  |
| AV <sub>IN</sub> | Analog input voltage                          |                 | V <sub>SS</sub> - 0.2 | V <sub>DD</sub> + 0.2 | V    |  |
| R <sub>REF</sub> | Resistance between $V_{DD}$ and $V_{SS}$      | A/D enabled     | tbd                   | tbd                   | kΩ   |  |
| CIA              | Analog input capacitance                      |                 |                       | 15                    | pF   |  |
| DL <sub>e</sub>  | Differential non-linearity <sup>1,2,3</sup>   |                 |                       | ±1                    | LSB  |  |
| ILe              | Integral non-linearity <sup>1,4</sup>         |                 |                       | ±1                    | LSB  |  |
| OS <sub>e</sub>  | Offset error <sup>1,5</sup>                   |                 |                       | ±2                    | LSB  |  |
| G <sub>e</sub>   | Gain error <sup>1,6</sup>                     |                 |                       | ±1                    | %    |  |
| A <sub>e</sub>   | Absolute voltage error <sup>1,7</sup>         |                 |                       | ±1                    | LSB  |  |
| M <sub>CTC</sub> | Channel-to-channel matching                   |                 |                       | ±1                    | LSB  |  |
| Ct               | Crosstalk between inputs of port <sup>8</sup> | 0 - 100kHz      |                       | -60                   | dB   |  |
| -                | Input slew rate                               |                 |                       | 100                   | V/ms |  |
| -                | Input source impedance                        |                 |                       | 10                    | kΩ   |  |

NOTES:

1. Conditions:  $V_{SS} = 0V$ ;  $V_{DD} = 5.12V$ . 2. The A/D is monotonic, there are no missing codes

3. The differential non-linearity ( $DL_e$ ) is the difference between the actual step width and the ideal step width. See Figure 41.

4. The integral non-linearity (ILe) is the peak difference between the center of the steps of the actual and the ideal transfer curve after appropriate adjustment of gain and offset errors. See Figure 41.

5. The offset error (OSe) is the absolute difference between the straight line which fits the actual transfer curve (after removing gain error), and the straight line which fits the ideal transfer curve. See Figure 41.

The gain error (Ge) is the relative difference in percent between the straight line fitting the actual transfer curve (after removing offset error), 6. and the straight line which fits the ideal transfer curve. Gain error is constant at every point on the transfer curve. See Figure 41.

7. The absolute voltage error (Ae) is the maximum difference between the center of the steps of the actual transfer curve of the non-calibrated ADC and the ideal transfer curve.

This should be considered when both analog and digital signals are input simultaneously to A/D pins. 8.

9. Changing the input voltage faster than this may cause erroneous readings.

10. A source impedance higher than this driving an A/D input may result in loss of precision and erroneous readings.



Figure 41. A/D Conversion Characteristics

### 87LPC768

### AC ELECTRICAL CHARACTERISTICS

 $T_{amb} = 0^{\circ}C \text{ to } +70^{\circ}C \text{ or } -40^{\circ}C \text{ to } +85^{\circ}C, V_{DD} = 2.7 \text{ V to } 6.0 \text{ V unless otherwise specified}, V_{SS} = 0 \text{ V}^{1, 2, 3}$ 

|                   | FIGURE | DADAMETER                                                 | LIN                   | IITS                  | UNUT |  |
|-------------------|--------|-----------------------------------------------------------|-----------------------|-----------------------|------|--|
| SYMBOL FIGURE     |        | PARAMETER                                                 | MIN                   | MAX                   |      |  |
| External Cl       | ock    | •                                                         | -                     | -                     |      |  |
| f <sub>C</sub>    | 43     | Oscillator frequency ( $V_{DD} = 4.5 \text{ V}$ to 6.0 V) | 0                     | 20                    | MHz  |  |
| f <sub>C</sub>    | 43     | Oscillator frequency ( $V_{DD} = 2.7 \text{ V}$ to 6.0 V) | 0                     | 10                    | MHz  |  |
| t <sub>C</sub>    | 43     | Clock period and CPU timing cycle                         | 1/f <sub>C</sub>      |                       | ns   |  |
| t <sub>CHCX</sub> | 43     | Clock high-time <sup>4</sup>                              | 20                    |                       | ns   |  |
| t <sub>CLCX</sub> | 43     | Clock low time <sup>4</sup>                               | 20                    |                       | ns   |  |
| Shift Regis       | ter    |                                                           |                       |                       |      |  |
| t <sub>XLXL</sub> | 42     | Serial port clock cycle time                              | 6t <sub>C</sub>       |                       | ns   |  |
| t <sub>QVXH</sub> | 42     | Output data setup to clock rising edge                    | 5t <sub>C</sub> - 133 |                       | ns   |  |
| t <sub>XHQX</sub> | 42     | Output data hold after clock rising edge                  | 1t <sub>C</sub> - 80  |                       | ns   |  |
| t <sub>XHDV</sub> | 42     | Input data setup to clock rising edge                     |                       | 5t <sub>C</sub> – 133 | ns   |  |
| t <sub>XHDX</sub> | 42     | Input data hold after clock rising edge                   | 0                     |                       | ns   |  |

NOTES:

1. Parameters are valid over operating temperature range unless otherwise specified.

2. Load capacitance for all outputs = 80 pF.

3. Parts are guaranteed to operate down to 0 Hz.

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



Figure 42. Shift Register Mode Timing



Figure 43. External Clock Timing



Figure 44. Typical low frequency oscillator Idd at 25°C (See Note 1)



Figure 45. Typical medium frequency oscillator Idd at 25°C (See Note 1)

### 87LPC768



Figure 46. Typical high frequency oscillator ldd versus frequency at 25°C (See Note 1)



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



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



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



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

NOTE:

1. Total Idd at sum of oscillator current and active or idle current shown in Figures 47, 48, 49 or 50 as appropriate

### 87LPC768



### DIMENSIONS (inch dimensions are derived from the original mm dimensions)

| UNIT   | A<br>max. | A <sub>1</sub><br>min. | A <sub>2</sub><br>max. | b              | b <sub>1</sub> | c              | D <sup>(1)</sup> | E <sup>(1)</sup> | e    | e <sub>1</sub> | L            | M <sub>E</sub> | M <sub>H</sub> | w     | Z <sup>(1)</sup><br>max. |
|--------|-----------|------------------------|------------------------|----------------|----------------|----------------|------------------|------------------|------|----------------|--------------|----------------|----------------|-------|--------------------------|
| mm     | 4.2       | 0.51                   | 3.2                    | 1.73<br>1.30   | 0.53<br>0.38   | 0.36<br>0.23   | 26.92<br>26.54   | 6.40<br>6.22     | 2.54 | 7.62           | 3.60<br>3.05 | 8.25<br>7.80   | 10.0<br>8.3    | 0.254 | 2.0                      |
| inches | 0.17      | 0.020                  | 0.13                   | 0.068<br>0.051 | 0.021<br>0.015 | 0.014<br>0.009 | 1.060<br>1.045   | 0.25<br>0.24     | 0.10 | 0.30           | 0.14<br>0.12 | 0.32<br>0.31   | 0.39<br>0.33   | 0.01  | 0.078                    |

#### Note

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

| OUTLINE  |     | REFERENCES |       |  |            | ISSUE DATE                       |
|----------|-----|------------|-------|--|------------|----------------------------------|
| VERSION  | IEC | JEDEC      | EIAJ  |  | PROJECTION | ISSUE DATE                       |
| SOT146-1 |     |            | SC603 |  |            | <del>-92-11-17</del><br>95-05-24 |

Low power, low price, low pin count (20 pin) microcontroller with

4 kB OTP 8-bit A/D, Pulse Width Modulator

### 87LPC768

#### plastic small outline package; 20 leads; body width 7.5 mm SOT163-1 SO20: А D Х - 🛛 у = v 🕅 A HE Q (A<sub>3</sub> pin 1 index L 10 detail X е $\Phi \otimes \mathbb{M}$ b<sub>p</sub> 10 mm 0 5 scale DIMENSIONS (inch dimensions are derived from the original mm dimensions) А D<sup>(1)</sup> z <sup>(1)</sup> E<sup>(1)</sup> A<sub>1</sub> A<sub>2</sub> **b**p UNIT $A_3$ с ${\sf H}_{\sf E}$ L Lp Q v θ е w У max. 0.9 0.30 2.45 0.49 0.32 13.0 7.6 10.65 1.1 1.1 2.65 mm 0.25 1.27 0.25 1.4 0.25 0.1 8<sup>0</sup> 0.10 2.25 0.36 0.23 12.6 7.4 10.00 0.4 1.0 0.4 $0^{\mathrm{o}}$ 0.035 0.012 0.096 0.019 0.013 0.51 0.30 0.419 0.043 0.043 0.10 0.055 inches 0.050 0.004 0.01 0.01 0.01 0.004 0.089 0.014 0.009 0.49 0.29 0.394 0.016 0.039 0.016 Note 1. Plastic or metal protrusions of 0.15 mm maximum per side are not included. REFERENCES OUTLINE EUROPEAN **ISSUE DATE** PROJECTION VERSION IEC JEDEC EIAJ <del>-95-01-24</del> SOT163-1 075E04 MS-013AC $\odot$ Ŧ 97-05-22

2000 May 02

### 87LPC768

NOTES

### Data sheet status

| Data sheet<br>status      | Product<br>status | Definition [1]                                                                                                                                                                                                                                                   |
|---------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Objective specification   | Development       | This data sheet contains the design target or goal specifications for product development.<br>Specification may change in any manner without notice.                                                                                                             |
| Preliminary specification | Qualification     | This data sheet contains preliminary data, and supplementary data will be published at a later date.<br>Philips Semiconductors reserves the right to make changes at any time without notice in order to<br>improve design and supply the best possible product. |
| Product specification     | Production        | This data sheet contains final specifications. Philips Semiconductors reserves the right to make changes at any time without notice in order to improve design and supply the best possible product.                                                             |

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

### 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 134). 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.

Philips Semiconductors 811 East Arques Avenue P.O. Box 3409 Sunnyvale, California 94088–3409 Telephone 800-234-7381 © Copyright Philips Electronics North America Corporation 2000 All rights reserved. Printed in U.S.A.

> Date of release: 5-00 9397 750 07112

Let's make things better.



Document order number:

