### 查询HPC46100供应商

## 捷多邦,专业PCB打样工厂,24小时加急出货

National Semiconductor

### PRELIMINARY June 1994

HPC46100 High-Performance microController with DSP Capability

# HPC46100 High-Performance microController with DSP Capability

### **General Description**

The HPC46100 is a member of the HPC™ family of High Performance microControllers. Each member of the family has a similar core CPU with unique memory, resources, and I/O configuration to suit specific applications. The HPC46100 is fabricated in National's advanced microCMOS technology. This process combined with an advanced architecture provides fast, flexible I/O control, efficient data manipulation, high speed computation, and low power consumption.

Throughput is enhanced by operating the HPC46100 at frequencies up to 40 MHz, by integrating a Multiply/Accumulate Unit (MAU) onto the chip, and by optimizing instructions to increase efficiency. These features increase performance in closed loop digital servo and filter applications.

The HPC devices are complete microcomputers on a single chip. All system timing, internal logic, RAM, and I/O are provided on the chip to produce a cost effective solution for high performance applications. On-chip functions such as an MAU unit, PWM outputs, Chip Select Signals, UART, up to seven 16-bit timers with input capture capability, WATCHDOGTM logic, vectored interrupts, and MICROWIRE/PLUSTM provide a high level of system integration. The ability to directly address up to 64 kbytes of memory enables the HPC to be used in powerful applications typically performed by microprocessors and peripheral chips. (Continued)

### Features

- Multiply/Accumulate Unit for fast signed multiply or multiply-accumulate
- High speed 16 bit timers with PWM outputs or input capture logic
- 4 Chip select output logic with programmable control
- 8-channel, 8-bit A/D Converter
- 1024 bytes of on-chip 0 wait state RAM
- FAST 100 ns for fastest instruction when using 40.0 MHz clock
- Very low power with two power save modes: IDLE and HALT
- UART full duplex, with a programmable baud rate generator and parity checking/detection
- MICROWIRE/PLUS serial I/O interface
- 8 vectored interrupt sources
- Signed overflow flag for add and subtract instructions
- 16 x 16 multiply and 32 x 16 divide
- 16-bit architecture with byte and word operations
- 64 kbytes of direct memory addressing
- 8- or 16-bit wide external memory
- Program instructions can be executed from RAM
   Up to 31 general purpose I/O lines that are memory mapped

### WATCHDOG logic



©1995 National Semiconductor Corporation TL/DD11289



RRD-B30M105/Printed in U. S. A.

### General Description (Continued)

The HPC46100 has, as an on-chip peripheral, an 8-channel 8-bit Analog-to-Digital Converter. This A/D converter can operate in a single-ended mode where the analog input voltage is applied across one of the eight input channels (D0–D7) and AGND. The A/D converter can also operate in a differential mode where the analog input voltage is applied across two adjacent input channels. The A/D converter will convert up to eight channels in the single-ended mode and up to four channel pairs in the differential mode.

A group of three high speed timers provide processor independent PWM signal generation. These timers and their support logic provide independent control of PWM frequency and PWM duty cycle with a minimum resolution of 50 ns when running at 40 MHz.

The HPC46100 is upwards source code compatible with the HPC family except for Decimal Add and Subtract. The HPC46100 is available in an 80-pin QFP package.

### 40 MHz

### **Absolute Maximum Ratings**

 

 If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.

 Total Allowable Source or Sink Current
 100 mA

 Storage Temperature Range
 -65°C to +150°C

 Lead Temperature (Soldering, 10 sec.)
 300°C

 V<sub>CC</sub> with Respect to GND
 -0.5V to +6.5V

 V<sub>REF</sub> with Respect to GND
 V<sub>CC</sub>

 All Other Pins
 (V<sub>CC</sub> +0.5V) to (GND - 0.5V)

### **DC Characteristics**

 $V_{CC}$  = 5.0V ±10% unless otherwise specified. T<sub>A</sub> = 0°C to +70°C unless otherwise specified.

| Symbol           | Parameter                                                  | Test Conditions                                                                                                                                                                       | Min                   | Max                 | Unit     |
|------------------|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|---------------------|----------|
| SUPPLIES         |                                                            |                                                                                                                                                                                       |                       |                     |          |
| I <sub>CC1</sub> | Supply Current                                             | $\begin{array}{l} V_{CC}=5.5 \text{V}, \text{f}_{\text{IN}}=40 \text{ MHz} \text{ (Note 1)} \\ V_{CC}=5.5 \text{V}, \text{f}_{\text{IN}}=20 \text{ MHz} \text{ (Note 1)} \end{array}$ |                       | 65<br>40            | mA<br>mA |
| I <sub>CC2</sub> | IDLE Mode Supply Current                                   | $\begin{array}{l} V_{CC}=5.5 \text{V}, \text{f}_{\text{IN}}=40 \text{ MHz} \text{ (Note 1)} \\ V_{CC}=5.5 \text{V}, \text{f}_{\text{IN}}=20 \text{ MHz} \text{ (Note 1)} \end{array}$ |                       | 25<br>20            | m/<br>m/ |
| I <sub>CC3</sub> | HALT Mode Supply Current with $\overline{\text{NMI}}$ High | $V_{CC} = 5.5V, f_{IN} = 0$ (Note 1)<br>$V_{CC} = 2.5V, f_{IN} = 0$ (Note 1)                                                                                                          |                       | 300<br>100          | μΑ<br>μΑ |
| I <sub>CC4</sub> | HALT Mode Supply Current with NMI Low                      | $V_{CC} = 5.5V$ , $f_{IN} = 40$ MHz (Note 1)                                                                                                                                          |                       | 25                  | m/       |
| V <sub>RAM</sub> | RAM Keep-Alive Voltage                                     | (Note 2)                                                                                                                                                                              | 2.5                   |                     | V        |
| NPUT VOI         | TAGE LEVELS FOR SCHMITT TRIGGERED II                       | NPUTS RESET, NMI AND WO; AND AL                                                                                                                                                       | SO CKI                |                     |          |
| V <sub>IH1</sub> | Logic High                                                 |                                                                                                                                                                                       | 0.9 V <sub>CC</sub>   |                     | V        |
| V <sub>IL1</sub> | Logic Low                                                  |                                                                                                                                                                                       |                       | 0.1 V <sub>CC</sub> | V        |
| INPUT VOI        | TAGE LEVELS FOR PORT A                                     |                                                                                                                                                                                       |                       |                     |          |
| V <sub>IH2</sub> | Logic High                                                 |                                                                                                                                                                                       | 2.0                   |                     | V        |
| V <sub>IL2</sub> | Logic Low                                                  |                                                                                                                                                                                       |                       | 0.8                 | V        |
| INPUT VOI        | TAGE LEVELS FOR ALL OTHER INPUTS                           |                                                                                                                                                                                       |                       |                     |          |
| V <sub>IH3</sub> | Logic High (except Port D)                                 |                                                                                                                                                                                       | 0.7 V <sub>CC</sub>   |                     | V        |
| V <sub>IL3</sub> | Logic Low (except Port D)                                  |                                                                                                                                                                                       |                       | 0.2 V <sub>CC</sub> | V        |
| $V_{\text{IH4}}$ | Logic High (Port D only)                                   | (Note 6 in AC Characteristics)                                                                                                                                                        | 0.7 V <sub>CC</sub>   |                     | V        |
| $V_{IL4}$        | Logic Low (Port D only)                                    | (Note 6 in AC Characteristics)                                                                                                                                                        |                       | 0.2 V <sub>CC</sub> | V        |
| I <sub>LI1</sub> | Input Leakage Current; all pins except below               |                                                                                                                                                                                       |                       | 10                  | μA       |
| I <sub>LI2</sub> | Input Leakage Current; pin RDY/HLD only                    |                                                                                                                                                                                       | -3                    | -50                 | μA       |
| I <sub>LI3</sub> | Input Leakage Current; pin B12 (HBE) only                  | $RESET = GND, V_{IN} = V_{CC}$                                                                                                                                                        | 0.5                   | 7.0                 | m/       |
| Cl               | Input Pin Capacitance                                      | (Note 3)                                                                                                                                                                              |                       | 10                  | pF       |
| CIO              | Input/Output Pin Capacitance                               | (Note 3)                                                                                                                                                                              |                       | 20                  | pF       |
| ουτρυτ ν         | OLTAGE LEVELS                                              |                                                                                                                                                                                       |                       |                     |          |
| CMOS USA         | AGE: ALL OUTPUTS AND I/O PINS                              |                                                                                                                                                                                       |                       |                     |          |
| V <sub>OH1</sub> | Logic High                                                 | $I_{OH} = -10 \ \mu A$ (Note 3)                                                                                                                                                       | $V_{\text{CC}} - 0.1$ |                     | V        |
| V <sub>OL1</sub> | Logic Low                                                  | I <sub>OL</sub> = 10 μA (Note 3)                                                                                                                                                      |                       | 0.1                 | l v      |

| Symbol                                                                                                                                                                  | 10% unless otherwise specified. $T_A = 0$<br>Parameter             | Test Conditions               | Min               | Max                             | Units                |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------------|-------------------|---------------------------------|----------------------|
|                                                                                                                                                                         | ORT A AND PINS B8-B15, PALE, CK2, S                                | ST1 AND ST2                   |                   |                                 |                      |
| V <sub>OH2</sub>                                                                                                                                                        | Logic High                                                         | $I_{OH} = -1 \text{ mA}$      | 2.4               |                                 | V                    |
| V <sub>OL2</sub>                                                                                                                                                        | Logic Low                                                          | $I_{OL} = 3 \text{ mA}$       |                   | 0.4                             | V                    |
|                                                                                                                                                                         | DRIVERS: B0-B7, WO, P0-P2                                          |                               |                   | 0.4                             | v                    |
|                                                                                                                                                                         |                                                                    | L _ 10mA                      | 0.4               |                                 | V                    |
| V <sub>OH3</sub>                                                                                                                                                        | Logic High                                                         | $I_{OH} = -1.6 \text{ mA}$    | 2.4               |                                 |                      |
| V <sub>OL3</sub>                                                                                                                                                        | Logic Low                                                          | $I_{OL} = 0.5 \text{ mA}$     |                   | 0.4                             | V                    |
| I <sub>OZ</sub>                                                                                                                                                         | TRI-STATE <sup>®</sup> Leakage Current                             |                               |                   | 10                              | μΑ                   |
|                                                                                                                                                                         | d 4 and <i>Figure 1</i> thru <i>Figure 5</i> . V <sub>CC</sub> = 5 |                               | rise specified, T | <sub>A</sub> = 25°C, one<br>Max | wait state.<br>Units |
|                                                                                                                                                                         |                                                                    | I                             |                   | I                               |                      |
| fC                                                                                                                                                                      | CKI Operating Frequency                                            |                               | 2                 | 40                              | MHz                  |
| $t_{C1} = 1/f_{C1}$                                                                                                                                                     | CKI Period                                                         |                               | 25                | 500                             | ns                   |
| t <sub>C1H</sub>                                                                                                                                                        | CKI High Time                                                      |                               | 11.25             |                                 | ns                   |
| <sup>t</sup> C1L                                                                                                                                                        | CKI Low Time                                                       |                               | 11.25             |                                 | ns                   |
| $t_{\rm C} = 2/f_{\rm C}$                                                                                                                                               | Bus Timing Cycle                                                   |                               | 50                | 1000                            | ns                   |
| tWAIT                                                                                                                                                                   | Wait State Period                                                  |                               | 50                |                                 | ns                   |
| tDC1C2R                                                                                                                                                                 | CK2 Rising Edge after CKI F                                        | alling Edge (Note 2)          | 0                 | 55                              | ns                   |
| t <sub>DC1C2F</sub>                                                                                                                                                     | CK2 Falling Edge after CKI F                                       | ,                             | 0                 | 55                              | ns                   |
| fu                                                                                                                                                                      | External UART Clock Input F                                        |                               |                   | 5                               | MHz                  |
| f <sub>MW</sub>                                                                                                                                                         |                                                                    | External MICROWIRE/PLUS Clock |                   | 2.5                             | MHz                  |
|                                                                                                                                                                         | Input Frequency                                                    |                               |                   |                                 |                      |
| IMER T0-T3                                                                                                                                                              |                                                                    |                               |                   |                                 | • • • •              |
| $f_{XIN} = f_C/22$                                                                                                                                                      | External Timer Input Frequer<br>Pulse Width for Timer Input        | ncy                           | 50                | 1.82                            | MHz                  |
| $t_{XIN} = t_C$                                                                                                                                                         |                                                                    |                               | 50                |                                 | ns                   |
|                                                                                                                                                                         |                                                                    |                               |                   |                                 | • • • •              |
|                                                                                                                                                                         |                                                                    | ncy                           | 75                | 8                               | MHz                  |
| $f_{HSXIN} = f_C/5$                                                                                                                                                     |                                                                    |                               | 75                |                                 | ns                   |
| $f_{HSXIN} = f_C/\xi$<br>$t_{HSXIN} = 1.5$                                                                                                                              | <b>c</b>                                                           |                               |                   |                                 |                      |
| t <sub>HSXIN</sub> = 1.5                                                                                                                                                |                                                                    |                               |                   |                                 |                      |
| $f_{HSXIN} = f_C/5$ $t_{HSXIN} = 1.5$ $MICROWIRE/PLU$ $t_{UWS}$                                                                                                         | S MICROWIRE Setup Time                                             |                               | 100               |                                 | ns                   |
| $f_{HSXIN} = f_C/5$<br>$t_{HSXIN} = 1.5$<br><b>MICROWIRE/PLU</b><br>$t_{UWS}$<br>Master                                                                                 |                                                                    |                               | 100<br>20         |                                 |                      |
| $f_{HSXIN} = f_C/5$ $t_{HSXIN} = 1.5$ <b>MICROWIRE/PLU</b> $t_{UWS}$ Master Slave                                                                                       | MICROWIRE Setup Time                                               |                               | 100<br>20         |                                 |                      |
| $f_{HSXIN} = f_C/t$ $t_{HSXIN} = 1.5$ <b>IICROWIRE/PLU</b> $t_{UWS}$ Master Slave $t_{UWH}$                                                                             |                                                                    |                               | 20                |                                 | ne                   |
| $f_{HSXIN} = f_C/5$ $t_{HSXIN} = 1.5$ <b>IICROWIRE/PLU</b> $t_{UWS}$ Master Slave                                                                                       | MICROWIRE Setup Time                                               |                               |                   |                                 | ns                   |
| f <sub>HSXIN</sub> = f <sub>C</sub> /s<br>t <sub>HSXIN</sub> = 1.5<br><b>MCROWIRE/PLU</b><br>t <sub>UWS</sub><br>Master<br>Slave<br>t <sub>UWH</sub><br>Master<br>Slave | MICROWIRE Setup Time<br>MICROWIRE Hold Time                        | ime                           | 20<br>20          |                                 | ns                   |
| $f_{HSXIN} = f_C/t$ $t_{HSXIN} = 1.5$ <b>MICROWIRE/PLU</b> $t_{UWS}$ Master Slave $t_{UWH}$ Master                                                                      | MICROWIRE Setup Time                                               | ime                           | 20<br>20          | 50                              | ns                   |

| Symbol                                                                                    | Parameter                                                                                                             | Min        | Max        | Units    |  |
|-------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|------------|------------|----------|--|
| EXTERNAL HOLD                                                                             |                                                                                                                       |            |            | 1        |  |
| $t_{SALE} = 0.75 t_{C} + 40$                                                              | HLD Falling Edge before ALE Rising Edge                                                                               | 77.5       |            | ns       |  |
| $t_{HWP} = 0.75 t_{C} + 35$                                                               | HLD Pulse Width                                                                                                       | 72.5       |            | ns       |  |
| $t_{HAE} = 0.75 t_{C} + 100$                                                              | HLDA Falling Edge after HLD Falling Edge (Note 3)                                                                     |            | 137.5      | ns       |  |
| $t_{HAD} = 0.75 t_{C} + 85$                                                               | HLDA Rising Edge after HLD Rising Edge                                                                                |            | 122.5      | ns       |  |
| t <sub>BF</sub>                                                                           | Bus TRI-Stated after HLDA Falling Edge (Note 5)                                                                       |            | 70         | ns       |  |
| $t_{BE} = 0.75 t_{C} + 30$                                                                | Bus Enable after HLDA Rising Edge                                                                                     | 67.5       |            | ns       |  |
| ATIVE BUS TIMING: ADDRESS C                                                               | CLE                                                                                                                   |            |            |          |  |
| $t_{LL} = 0.5 t_{C} - 10$                                                                 | ALE Pulse Width                                                                                                       | 15         |            | ns       |  |
| t <sub>1ALR</sub>                                                                         | ALE Rising Edge after CK1 Rising Edge (Note 2)                                                                        | 0          | 35         | ns       |  |
| t <sub>1ALF</sub>                                                                         | ALE Falling Edge after CK1 Falling Edge (Note 2)                                                                      | 0          | 35         | ns       |  |
| $t_{2ALR} = 0.25 t_{C} + 20$                                                              | ALE Rising Edge after CK2 Rising Edge                                                                                 |            | 32.5       | ns       |  |
| $t_{2ALF} = 0.25 t_{C} + 20$                                                              | ALE Falling Edge after CK2 Falling Edge                                                                               |            | 32.5       | ns       |  |
| $t_{ST} = 0.25 t_{C} - 9$                                                                 | Address Valid to ALE Falling Edge                                                                                     | 3.5        |            | ns       |  |
| $t_{VP} = 0.5 t_{C} - 10$                                                                 | Address Hold after ALE Falling Edge                                                                                   | 15         |            | ns       |  |
| EAD CYCLE                                                                                 |                                                                                                                       | 1          |            | 1        |  |
| $t_{RW} = 0.25 t_{C} + WS - 15$                                                           | RD Pulse Width                                                                                                        | 47.5       |            | ns       |  |
| $t_{ARD} = 0.75 t_{C} - 20$                                                               | Address Valid to RD Falling Edge                                                                                      | 17.5       |            | ns       |  |
| $t_{ARR} = 0.5 t_{C} - 20$                                                                | ALE Falling Edge to RD Falling Edge                                                                                   | 5          |            | ns       |  |
| $t_{RD} = 0.25 t_{C} + WS - 20$                                                           | RD Falling Edge to Input Data Valid                                                                                   | 0          | 42.5<br>50 | ns<br>ns |  |
|                                                                                           | $t_{DR}$ Data Hold after $\overline{RD}$ Rising Edge<br>$t_{ACC} = t_{C} + WS - 20$ Address Valid to Input Data Valid |            |            |          |  |
| $t_{ACC} = t_{C} + WS - 20$                                                               | Address valid to input Data valid                                                                                     |            | 80         | ns       |  |
| VRITE CYCLE                                                                               |                                                                                                                       |            |            | 1        |  |
| $t_{WW} = 0.75 t_{C} + WS - 15$                                                           | WR Pulse Width                                                                                                        | 72.5       |            | ns       |  |
| $t_V = 0.5 t_C + WS - 20$                                                                 | Data Valid before WR Rising Edge                                                                                      | 55         |            | ns       |  |
| $t_{HW} = 0.5 t_{C} - 10$                                                                 | Data Hold after WR Rising Edge                                                                                        | 15<br>17.5 |            | ns       |  |
| $t_{AWR} = 0.75 t_{C} - 20$                                                               | Address Valid to WR Falling Edge                                                                                      | 17.5       |            | ns       |  |
| EADY INPUT                                                                                | I                                                                                                                     |            |            |          |  |
| t <sub>RDYS</sub>                                                                         | RDY Falling Edge before CK2 Falling Edge                                                                              | 45         |            | ns       |  |
| t <sub>RDYH</sub>                                                                         | RDY Rising Edge after CK2 Falling Edge                                                                                | 0          |            | ns       |  |
| $t_{RDYV} = WS + 0.25 t_{C} - 30$                                                         | RDY Falling Edge after RD or WR Falling Edge                                                                          |            | 32.5       | ns       |  |
| HIP SELECT NATIVE BUS TIMIN                                                               | G                                                                                                                     | 1          |            |          |  |
| $t_{CS30RD} = 0.75 t_{C} - 30$                                                            | CS3, CS0 Valid to RD Falling Edge                                                                                     | 7.5        |            | ns       |  |
| $t_{ACCS30} = t_{C} + WS - 30$                                                            | CS3, CS0 Valid to Input Data Valid                                                                                    |            | 70         | ns       |  |
| $t_{CS21RD} = 0.75 t_{C} - 35$                                                            | CS2, CS1 Valid to RD Falling Edge                                                                                     | 2.5        | C.F.       | ns       |  |
| $t_{ACCS21} = t_{C} + WS - 35$                                                            | CS2, CS1 Valid to Input Data Valid<br>Chip Select Hold after RD Rising Edge                                           | 35         | 65         | ns       |  |
| t <sub>CSHR</sub> = t <sub>C</sub> - 15<br>t <sub>CS30WR</sub> = 0.75 t <sub>C</sub> - 30 | CS3, CS0 Valid to $\overline{WR}$ Falling Edge                                                                        | 7.5        |            | ns<br>ns |  |
|                                                                                           | $CS2, CS1$ Valid to $\overline{WR}$ Falling Edge                                                                      | 2.5        |            | ns       |  |
| t <sub>CS21WR</sub> = 0.75 t <sub>C</sub> - 35                                            | Chip Select Hold after WR Rising Edge                                                                                 | 10         |            | ns       |  |

| 40 MHz (Continued)                   |                                                                                                 |                             |               |             |
|--------------------------------------|-------------------------------------------------------------------------------------------------|-----------------------------|---------------|-------------|
|                                      | <b>Pacteristics</b> (Continued)<br>a 1 thru Figure 5. $V_{CC} = 5.0V \pm 10\%$ unless otherwise | e specified, T <sub>A</sub> | = 25°C, one v | vait state. |
| Symbol                               | Parameter                                                                                       | Min                         | Max           | Units       |
| GNAL TIMING PARAMETER                | IS                                                                                              |                             |               |             |
| $t_{RWSE} = 0.25 t_{C} - 7$          | WR Falling Edge to E Rising Edge                                                                | 5.5                         |               | ns          |
| $t_{RWHE} = 0.5  t_{C} - 7$          | E Falling Edge to WR Rising Edge                                                                | 18                          |               | ns          |
| $t_{ASE} = t_{C} - 20$               | Address Valid to E Rising Edge                                                                  | 30                          |               | ns          |
| $t_{RDE} = WS - 20$                  | E Falling Edge to Data Input Valid                                                              | 30                          |               | ns          |
| OW PERIPHERAL TIMING PA              | ARAMETERS                                                                                       |                             |               |             |
| $t_{PLL} = t_C - 5$                  | PALE Pulse Width                                                                                | 45                          |               | ns          |
| $t_{PST} = 0.75 t_{C} - 10$          | Address Valid to PALE Falling Edge                                                              | 27.5                        |               | ns          |
| $t_{PVL} = 0.75 t_{C} - 15$          | Address Hold from PALE Falling Edge                                                             | 22.5                        |               | ns          |
| $t_{PVP} = 0.75 t_{C} - 10$          | PALE Falling Edge to RD or WR Falling Edge                                                      | 27.5                        |               | ns          |
| $t_{PCSA} = 0.25 t_{C} - 12.5$       | Chip Select Setup to PALE Falling Edge                                                          | 0                           |               | ns          |
| $t_{PAS} = 1.5 t_{C} - 20$           | Address Setup to RD or WR Falling Edge                                                          | 55                          |               | ns          |
| $t_{PCSS} = t_C - 15$                | Chip Select Setup to RD or WR Falling Edge                                                      | 35                          |               | ns          |
| $t_{PCSH} = 0.5 t_{C} - 15$          | Chip Select Hold from RD or WR Rising Edge                                                      | 10                          |               | ns          |
| $t_{PACC} = 5 t_C - 25$              | Address Valid to Input Data Valid                                                               |                             | 225           | ns          |
| $t_{PRD} = 3.5 t_{C} - 25$           | RD Falling Edge to Data In Valid                                                                |                             | 150           | ns          |
| $t_{PDR} = t_C (max)$                | Data Hold after RD Rising Edge                                                                  | 0                           | 50            | ns          |
| $t_{PRW} = 3.5 t_{C} - 15$           | RD Strobe Width                                                                                 | 160                         |               | ns          |
| $t_{\sf PSW} = 3.0 \ t_{\sf C} - 20$ | Data Setup before WR Rising Edge                                                                | 130                         |               | ns          |
| $t_{PHW} = t_{C} - 20$               | Data Hold after WR Rising Edge                                                                  | 30                          |               | ns          |
| $t_{PWW} = 3.5 t_{C} - 15$           | WR Strobe Width                                                                                 | 160                         |               | ns          |

Note:  $C_L = 40 \text{ pF}.$ 

Note 1: These AC characteristics are guaranteed with external clock drive on CKI having 50% duty cycle and with less than 15 pF load on CKO with rise and fall times (t<sub>CKIR</sub> and t<sub>CKIL</sub>) on CKI input less than 2.5 ns.

Note 2: Do not design with these parameters unless CKI is driven with an active signal. When using a passive crystal circuit, its stability is not guaranteed if either CKI or CKO is connected to any external logic other than the passive components of the crystal circuit.

Note 3:  $t_{HAE}$  is spec'd for case with HLD falling edge occurring at the latest time it can be accepted during the present CPU cycle begin executed. If HLD falling edge occurs later,  $t_{HAE}$  as long as (3  $t_{C}$  + 4 WS + 72  $t_{C}$  + 100) may occur depending on the following CPU instruction cycles, its wait states and ready input. Note 4: WS ( $t_{WAIT}$ ) x (number of preprogrammed wait states). Minimum and maximum values are calculated at maximum operating frequency,  $t_{C}$  = 40 MHz, with one wait state programmed.

Note 5: Due to testing limitations—actual limits will be better.













# I/O Ports

### PORT A

Port A is a 16-bit multiplexed address/data bus used for accessing external program and data memory. Four associated bus control signals are available on port B. The Address Latch Enable (ALE) signal is used to provide timing to demultiplex the bus. Reading from and writing to external memory are signalled by  $\overline{RD}$  and  $\overline{WR}$  respectively. External memory can be addressed as either bytes or words with the decoding controlled by two lines. Bus High Bus Enable ( $\overline{HBE}$ ) and Address/Data line 0 (A0).

### PORT B

Port B is a 16-bit port with 12 bits of bidirectional I/O. B10, B11, B12 and B15 are the control bus signals for the address/data bus. Port B may also be configured via a function register BFUN to individually allow each bidirectional I/O pin to have an alternate function. The direction of port B is determined by the direction register (DIRB). This register is used to set up each pin to be individually defined as an input or output. A specific I/O bit is selected as a high impedance input by clearing the corresponding bit in the direction register. It is selected as an output by setting this bit. The data register (PORTB) is used to hold data to be output on the B port. A write operation to a port pin configured as an input causes the value to be written into the data register, a read operation returns the value of the pin. Writing to port pins configured as outputs causes the pins to have the same value, reading the pins returns the value of the data register. *Figure 12* through *Figure 14* show the structure of Port B.

Port B may also be configured via a 16-bit alternate function register BFUN, to individually allow each pin to have an alternate function. The alternate functions are enabled by setting the corresponding bits in the BFUN register. The alternate B port functions are as follows:

| Pin | Alternate | Function                                |  |
|-----|-----------|-----------------------------------------|--|
| B0  | TDX       | UART Data Output                        |  |
| B1  | E         | E signal output                         |  |
| B2  | СКХ       | UART Clock                              |  |
| B3  | T2IO      | Timer2 I/O Pin                          |  |
| B4  | T3IO      | Timer3 I/O Pin                          |  |
| B5  | SO        | MICROWIRE/PLUS Output (data)            |  |
| B6  | SK        | MICROWIRE/PLUS Clock                    |  |
| B7  | HLDA      | Hold Acknowledge Output                 |  |
| B8  | TS0/CS0   | Timer Synchronous or Chip Select Output |  |
| B9  | TS1/CS1   | Timer Synchronous or Chip Select Output |  |
| B10 | ALE       | Address/data bus Address Latch Enable   |  |
| B11 | WR        | Address/data bus Write Output           |  |
| B12 | HBE       | Address/data bus High Byte Enable       |  |
| B13 | TS2/CS2   | Timer Synchronous or Chip Select Output |  |
| B14 | TS3/CS3   | Timer Synchronous or Chip Select Output |  |
| B15 | RD        | Address/data bus Read Output            |  |





# I/O Ports (Continued)

### PORT I

Port I is an 8-bit input port that can be read as general purpose inputs and can also be used for the following functions:

| Pin | Alternate | Function                                 |  |
|-----|-----------|------------------------------------------|--|
| 10  | R5B       | Timer T5 R5B Input                       |  |
| 11  | NMI       | Nonmaskable Interrupt Input              |  |
| 12  | INT2      | Maskable Interrupt/Input Capture         |  |
| 13  | INT3      | Maskable Interrupt/Input Capture         |  |
| 14  | INT4      | Maskable Interrupt/Input Capture         |  |
| 15  | SI        | MICROWIRE/PLUS Data Input                |  |
| 16  | RDX       | UART Data Input                          |  |
| 17  | R6B       | Timer T6 R6B Input and A/D Trigger Input |  |

### PORT D

Port D is an 8-bit input port that can be used as general purpose digital inputs and as analog inputs for the A/D converter.

### PORT P

Port P is a 3-bit input/output port that is used as general purpose outputs, or I/O that is controlled by timers T4, T5 and T6. These pins can be configured as Pulse Width Modu-lated Outputs (PWM), capture inputs or event counter inputs.

### POWER SUPPLY PINS

Four pairs of power supply pins are provided to minimize cross talk between the analog, digital, and output driver sections of the chip.

| Pin              | Function                              |  |
|------------------|---------------------------------------|--|
| V <sub>CC</sub>  | Power for Digital Logic               |  |
| GND              | Ground for Digital Logic              |  |
| DV <sub>CC</sub> | Power for Output Drivers              |  |
| DGND             | Ground for Output Drivers             |  |
| AV <sub>CC</sub> | Power for Analog Logic                |  |
| AV <sub>SS</sub> | Ground for Analog Logic               |  |
| V <sub>REF</sub> | A/D Converter Reference Voltage Input |  |
| AGND             | Ground Reference for Analog Logic     |  |

| CLOCK PINS<br>Pin<br>CKI<br>CKO<br>CK2 | Function<br>System Oscillator Input/External Clock Input<br>System Oscillator Output (Inversion of CKI)<br>Clock Output (CKI divided by 2) |
|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| OTHER PINS                             |                                                                                                                                            |
| Pin                                    | Function                                                                                                                                   |
| RESET                                  | System reset input, active low.                                                                                                            |
| PALE                                   | Slow peripheral address latch enable.                                                                                                      |
| RDY/HLD                                | Has two uses, selected by a software bit.                                                                                                  |
|                                        | It's either a READY input to extend the                                                                                                    |
|                                        | bus cycle for slower memories, or HOLD request input to put the bus in a high                                                              |
|                                        | impedance state for DMA purposes.                                                                                                          |
| $\overline{WO}$                        | This is an active low open drain output                                                                                                    |
|                                        | that signals an illegal situation has been                                                                                                 |
|                                        | detected by the WATCHDOG logic.                                                                                                            |
| ST1                                    | Bus Cycle Status Output: indicates first                                                                                                   |
|                                        | opcode fetch.                                                                                                                              |
| ST2                                    | Bus Cycle Status Output: indicates                                                                                                         |
|                                        | machine states (skip, interrupt and first                                                                                                  |
| EXM                                    | instruction cycle).<br>External memory enable (active high)                                                                                |
|                                        | disables internal ROM and maps it to                                                                                                       |
|                                        | external memory.                                                                                                                           |
| ĒĪ                                     | Has two uses, it's either an active low                                                                                                    |
|                                        | level external interrupt with vector                                                                                                       |
|                                        | address FFF3:FFF2 which is shared with                                                                                                     |
|                                        | the UART, or Timer T4 R4B input.                                                                                                           |



### **Operating Modes**

The HPC46100 does not have any internal ROM, and has only one mode of operation, the Expanded ROMless Mode. The EXM pin must be pulled high (logic "1"). The EA bit in the PSW register of the HPC46100 is hard wired to a logic "1". The use of this bit is reserved. Currently, the HPC46100 is intended for use with external memory. The external memory may be any combination of ROM, RAM, or peripherals and may be configured with an 8-bit or 16-bit external address/data bus (see Figure 16 and Figure 17). Up to 62k bytes of external memory may be accessed.

### Wait States

The HPC46100 provides four selectable Wait States that allow access to slower memories. The Wait States are selectable by the state of two bits in the PSW register or by two bits in the Chip Select Control registers. Additionally, the RDY input may be used to extend the instruction or memory access cycle, allowing the user to interface with slow memories and peripherals. There also is a slow peripheral bus mode when using the Chip Select logic.

### **Power Save Modes**

Two power saving modes are available on the HPC46100: HALT and IDLE. In the HALT mode, all processor activities are stopped. In the IDLE mode, the internal oscillator and timer T0 are active but all other processor activities are stopped. In either mode, all internal RAM, registers and I/O are unaffected.

### HALT MODE

The HPC46100 is placed in the HALT mode under software control by setting bits in the PSW. All processor activities,

### Power Save Modes (Continued)

including the clock and timers, are stopped when the HALT mode is entered with the NMI input high. When the HALT mode is entered with the NMI input low, the high speed timers (T4, T5 and T6), remain active. In the HALT mode, power requirements for the HPC46100 are minimal and the applied voltage ( $V_{CC}$ ) may be decreased without altering the state of the machine. There are two ways of exiting the HALT mode: via the RESET or the NMI. The RESET input re-initializes the processor. Use of the NMI input will generate a vectored interrupt and resume operation from that point with no initialization. The HALT mode can be enabled or disabled by means of a control register HALT enable. To prevent accidental use of the HALT mode the HALT enable register can be modified only once.

#### IDLE MODE

THE HPC46100 is placed in the IDLE mode through the PSW. In this mode, all processor activity, except the internal oscillator, the high speed timers (T4, T5, and T6), and Timer T0, is stopped. As with the HALT mode, the processor is returned to full operation by the RESET or NMI inputs, but without waiting for oscillator stabilization. A timer T0 overflow will also cause the HPC46100 to resume normal operation.

### **HPC46100 Interrupts**

Complex interrupt handling is easily accomplished by the HPC46100's vectored interrupt scheme. There are eight possible interrupt sources as shown in Table I.

| Vector<br>Address | Interrupt Source                                  | Arbitration<br>Ranking |
|-------------------|---------------------------------------------------|------------------------|
| FFFF:FFFE         | RESET                                             | 0                      |
| FFFD:FFFC         | Non-maskable external on<br>rising edge of I1 pin | 1                      |
| FFFB:FFFA         | External interrupt on I2 pin                      | 2                      |
| FFF9:FFF8         | External interrupt on I3 pin                      | 3                      |
| FFF7:FFF6         | External interrupt on I4 pin                      | 4                      |
| FFF5:FFF4         | Overflow on internal timers                       | 5                      |
| FFF3:FFF2         | Internal by UART or external on EI pin            | 6                      |
| FFFF1:FFF0        | A/D converter                                     | 7                      |

#### INTERRUPT ARBITRATION

The HPC46100 contains arbitration logic to determine which interrupt will be serviced first if two or more interrupts occur simultaneously. The arbitration ranking is given in Table I. The interrupt on  $\overline{\text{RESET}}$  has the highest rank and is serviced first.

#### INTERRUPT PROCESSING

Interrupts are serviced after the current instruction is completed and except for the  $\overline{\text{RESET}}$ , which is serviced immediately.  $\overline{\text{RESET}}$  and  $\overline{\text{El}}$  are level-LOW-sensitive interrupts. All other external interrupts are edge-sensitive. NMI is positive-edge sensitive. The external interrupts on I2, I3 and I4 can be software selected to be rising or falling edge.

#### INTERRUPT CONTROL REGISTERS

The HPC46100 allows the various interrupt sources and conditions to be programmed. This is done through the various control registers. A brief description of the different control registers is given below.

### INTERRUPT ENABLE REGISTER (ENIR)

RESET and the External Interrupt on I1 are non-maskable interrupts. The other interrupts can be individually enabled or disabled. Additionally, a Global Interrupt Enable Bit in the ENIR Register allows the Maskable interrupts to be collectively enabled or disabled. Thus, in order for a particular interrupt to request service, both the individual enable bit and the Global Interrupt bit (GIE) have to be set.

### **INTERRUPT PENDING REGISTER (IRPD)**

The IRPD register contains a bit allocated for each interrupt vector excluding the EI interrupt which has a dedicated register containing an interrupt enable and pending bit. The occurance of specified interrupt trigger conditions causes the appropriate bit to be set. There is no indication of the order in which the interrupts have been received. The bits are set independently of the fact that the interrupts may be disabled. IRPD is a Read/Write register. The bits corresponding to the maskable, external interrupts are normally cleared by the HPC46100 after servicing the interrupts. For the interrupts from the on-board peripherals, the user has the responsibility of resetting the interrupt pending flags through software. The NMI bit is read only and I2, I3, and I4 are designed as to only allow a zero to be written to the pending bit (writing a one has no effect). A LOAD IMMEDI-ATE instruction is to be the only instruction used to clear a bit or bits in the IRPD register. This allows a mask to be used, thus ensuring that the other pending bits are not affected.

#### INTERRUPT CONDITION REGISTER (IRCD)

Three bits of the register select the input polarity of the external interrupt on I2, I3 and I4.

#### **EI INTERRUPT CONFIGURATION REGISTER (EICON)**

The  $\overline{EI}$  pin is an active low level sensitive interrupt. Interrupts from the  $\overline{EI}$  pin are enabled by using the EICON register.

#### SERVICING THE INTERRUPTS

The Interrupt, once acknowledged, pushes the program counter (PC) onto the stack then incrementing the stack pointer (SP) by two. The Global Interrupt Enable bit (GIE) is copied into the CGIE bit of the PSW register; it is then reset, thus disabling further interrupts. The program counter is loaded with the contents of the memory at the vector address and the processor resumes operation at this point. At the end of the interrupt service routine, the user does a RETI instruction to pop the stack and re-enable interrupts if the CGIE bit is set, or RET to just pop the stack if the CGIE bit is clear, and then returns to the main program. The GIE bit can be set in the interrupt service routine to nest interrupts if desired. *Figure 15* shows the interrupt enable logic.

### RESET

RESET is an active-low Schmitt trigger input that initializes the processor and sets all pins in a TRI-STATE condition except for CK0, CKI, ST1, ST2, HBE and WO when held low. When rising edge is detected on RESET, the processor vectors to FFFF:FFFE and resumes operation at the address contained at that memory location.



### Multiply/Accumulate Unit (MAU)

This is dedicated hardware that is supported by instructions which perform basic multiply-accumulate DSP steps for FIR and IIR filter calculations, an arithmetic right shift of the Math unit Result Register (MRR), and a signed multiply of two 16-bit values producing a 32-bit result.

The MACZ and MAC instructions support the MAU by fetching data and performing circular buffer management in parallel with the multiplication. The MACZ instruction is used initially, and it is followed by a string of additional MAC instructions, one instruction per filter tap (including the MACZ). The source values are taken as 16-bit values; there is not a form that operates on byte-wide inputs. The MACZ instruction clears the result register before completing the first multiply operation.

The MAC instruction is opcode 38 hex. The MACZ instruction is opcode 39 hex. Both instructions are one byte in length, and neither allows use of an Addressing Directive prefix.

The specific function performed is as follows:

- Clear MRR to zero (MACZ instruction only).
- Fetch 16-bit data pointed to by B, and issue it to the MAU as the first operand.
- Increment B by two (bytes), compare B with K: if B > K then load B from A.
- Fetch 16-bit data pointed to by X, increment X by two (bytes).
- Issue data to the MAU to start multiply-accumulate operation. The MAU multiplies the two operands issued to it, and adds the 32-bit result to the current 32-bit contents of the MRR register.

On completion, the result goes to the MRR register. The MVP bit in the PSW is set to a "1" if a signed (2's complement) overflow occurred in the positive direction as a result of the accumulation substep (overflow from the multiplication substep is impossible). If the overflow occurred in the negative direction, the MVN bit is set instead. Neither of these bits is affected by the MAU if the other is already set. By stringing together a sequence of MAC instructions, the HPC46100 can do a multiply-accumulate every 9 cycles (assuming a 1 wait state instruction fetch). At 40 MHz, this gives a 450 ns multiply-accumulate (including data fetching and circular buffer management). This can be reduced to 400 ns if executed from internal RAM.

### Chip Select Signals CHIP SELECT LOGIC

The chip select logic can produce up to four chip select signals without any off-chip logic. The chip select logic supports two bus timing modes. The first bus timing mode is native bus mode, which is the standard bus mode of all HPC family members. The second bus mode is the slow peripheral bus mode, which allows the HPC46100 to interface with slow peripherals without external chip select logic. There is an additional data strobe provided for auxiliary bus timing. This auxiliary strobe is called the E signal.

Each of chip select signals is controlled by a dedicated chip select control register (CSC0–CSC3). The control registers contain one bit to enable/disable the chip select signals, one bit to select the polarity of the chip select signal, two bits program the wait states of the data accesses, four bits that select the address range which the chip select signals are active in and one bit to enable or disable the E signal.



### Chip Select Signals (Continued)

The Chip Select Address Range Selection (SEL) defines the address range the chip select is valid over. For Chip Select 0 (CSC0), the address range starts at location 0800 hex and extends to  $S_0$ FFF hex, where  $S_0$  is the 4-bit contents of the SEL field. For both Chip Select 1 (CSC1) and Chip Select 2 (CSC2) the SEL field defines a single 4 kbyte range: S<sub>1</sub>000 through S<sub>1</sub>FFF for CSC1, and S<sub>2</sub>000 through S<sub>2</sub>FFF for CSC2, where S<sub>1</sub> and S<sub>2</sub> are their respective SEL field contents. These ranges can be used to control peripherals by using the "Slow Peripheral" bus timing mode. Chip Select 3 (CSC3) defines a range beginning at S<sub>3</sub>000 hex, and continuing through FFFF hex. This range will typically define the off-chip ROM space. See *Figure 18*.



are Selected



Chip Select 0 and Chip Select 3 can be programmed independently to operate with 1, 2 or 4 wait states. Chip Select 1 and 2 can be programmed independently to operate in native bus mode with 1, 2 or 4 wait states or slow peripheral bus mode.

### **Timer Overview**

The HPC46100 contains seven 16-bit timers, four core timers and three high speed timers. Timers T0-T3 are the standard core timers and are fully compatible with the core timers on other HPC family members. See *Figure 19* and *Figure 20*.



### Timer Overview (Continued) CORE TIMERS

Timer T0 is a free-running timer, counting up at a fixed CKI/16 (Clock Input/16) rate. It is used for Watchdog logic, high speed event capture, and to exit from the IDLE mode. Consequently, it cannot be stopped or written to under software control. Timer T0 permits precise measurements by means of the capture registers I2CR, I3CR, and I4CR. Registers I2CR and I3CR have the alternate function of being R1 and T1 respectively. The function of these registers (I2CR/R1 and I3CR/T1) are mutually exclusive and under the control of software. The capture registers I2CR, I3CR, and I4CR respectively, record the value of timer T0 when specific events occur on the interrupt pins I2, I3, and I4. The control register IRCD programs the capture registers to trigger on either a rising edge or a falling edge of its respective input. The specified edge can also be programmed to generate an interrupt.

The timers T2 and T3 have a clock rate which is selectable. The clock input to these two timers may be selected from the following two sources: an external pin, or derived internally by dividing the clock input. Timer T2 has additional capability of being clocked by the timer T3 underflow. This allows the user to cascade timers T3 and T2 into a 32-bit timer/counter.

The timers T1 through T3 in conjunction with their registers form Timer-Register pairs. All the Timer-Register pairs can be read from or written to. Each timer can be started or stopped under software control. Once enabled, the timers count down, and upon underflow, the contents of its associated register are automatically loaded into the timer.

#### Synchronous Outputs

There are four synchronous timer outputs (TS0 through TS3) that work in conjunction with the timer T2. The synchronous timer outputs can be used either as regular outputs or individually programmed to toggle on timer T2 underflow.

Note: These outputs are shared with the chip select outputs. The use of these two functions are mutually exclusive.

### TIMERS T4, T5 AND T6

The HPC46100 has a set of three powerful timers/counters, T4, T5 and T6. Since the three timers, T4, T5 and T6 are identical, all comments are equally applicable to any of the three timer blocks.

These timers are designed to allow the device to easily perform all timer functions with minimal software overhead. All timers are synchronized on the first overflow of timer T0. Each timer has four 16-bit registers dedicated to it, a control register (TnCON), timer register (Tn), and two auto-load/ capture registers (RnA, RnB). *Figure 21* shows a block diagram of the three high speed timers.



#### TIMER CONTROL REGISTERS

There are three timer control registers (T4CON, T5CON and T6CON). These control registers have bits which set the clock input rate, mode of operation and interrupt control structure. Each timer control register has interrupt pending and interrupt acknowledge bits for Tn, RnA and RnB, and a global interrupt pending bit for that specific timer. There are bits to enable/disable the interrupts from Tn, RnA and RnB. The clock input rate can be selected to be CKI/2, CKI/4, CKI/8 or CKI/16. The Four modes of operation are: External Event Counter mode, Input Capture mode, Processor Independent PWM mode and externally triggered PWM mode.

#### MODE 0. EXTERNAL EVENT COUNTER MODE

This mode is the default after <u>RESET</u>. In this mode the timer register Tn is decremented each time there is an active edge on the A input. The active edge is determined by the value of a bit in the control register. Upon every underflow of the timer register (Tn), the timer (Tn) is aternately reloaded with the contents of the supporting registers RnA and RnB. The first underflow of the timer after entry into this mode will cause the timer to reload from register RnA. All following underflows will alternate which reload is used beginning with RnB. Every underflow from the timer will set a Tn global interrupt pending bit in the control register. The selected edge on Input A and Input B will also set corresponding pending bits in the control register. *Figure 22* shows a block diagram of the high speed timers in Mode 0.



#### MODE 1. DUAL INPUT CAPTURE MODE

The device can precisely measure external frequencies or time external events by placing the timer in the input capture mode. In this mode, the timer Tn is constantly running at a fixed rate as selected in the timer control register. The two registers, RnA and RnB, act as capture registers. Each register is loaded with the contents of the timer register Tn when an active edge on it's associated pin is detected. The active edge is determined by the value of two bits in the control register. The active edge for each input pin can be specified independently, and can be programmed to generate an interrupt. The interrupt can be generated on an input from the A or B input along with an underflow of the timer register (Tn). *Figure 23* shows a block diagram of the timer in Input Capture mode.



#### MODE 2. PROCESSOR INDEPENDENT PWM MODE

As the name suggests, this mode allows the device to generate a PWM signal with very minimal user intervention. The user only has to define the parameters of the PWM signal (ON time and OFF time). Once begun, the timer block will continuously generate the PWM signal completely independent of the microcontroller. The user software services the timer block only when the PWM parameters require updating. In this mode the timer Tn counts down at a fixed rate as programmed in the control register. Upon every underflow the timer is alternately reloaded with the contents of its supporting registers, RnA and RnB. The very first underflow of the timer after entry into this mode causes the timer to reload from the register RnA. Subsequent underflows cause the timer to be reloaded from the registers alternately beginning with the register RnB. Figure 24 shows a block diagram of the timer in PWM mode.



#### FIGURE 24. PWM

The underflow can be programmed to toggle the A output pin (Port P). The underflow can also be programmed to generate interrupts. These interrupts can occur on a reload from RnA or RnB. This gives the user the flexibility of interrupting once per PWM period on either the rising or falling edge of the PWM output. Alternatively, the user may choose to interrupt on both edges of the PWM output.

#### MODE 3. EXTERNALLY TRIGGERED PWM/PORT OUTPUT

In this mode the timer is stopped and the corresponding port P pin can be programmed as a general purpose output pin. The timer block can be programmed to remain halted using its A pin for use as a general purpose output, or it can be programmed to exit mode 3 and enter mode 2 (Processor Independent PWM) when a rising edge is detected on the B input.

The external triggering of this feature provides the capability of generating a delayed pulse triggered by an external event as follows: From the rising edge of the B input the timer enters PWM mode. When the timer register underflows the output toggles and the value of RnA is loaded to the timer. The next underflow will cause the RnB register to load into

### Timer Overview (Continued)

the timer and operation will continue as in the PWM mode. Alternately, an interrupt from the RnB load can be used to branch to a routine that would set the timer into mode 3 waiting for the trigger for another pulse. *Figure 25* shows a block diagram of the timer in this mode.



FIGURE 25. Port Output/Externally Triggered PWM

#### WATCHDOG LOGIC

The WATCHDOG Logic monitors the operations taking place and signals upon the occurrence of any illegal activity. The illegal conditions that trigger the WATCHDOG logic are potentially infinite loops. Should the WATCHDOG register not be written to before Timer TO overflows twice, or more often than once every 4096 counts, an infinite loop condition is assumed to have occurred. Any illegal condition forces the WATCHDOG Output ( $\overline{WO}$ ) pin low. The  $\overline{WO}$  pin is an open drain output and can be connected to the RESET or NMI inputs or to the users external logic.

### **MICROWIRE/PLUS**

MICROWIRE/PLUS is used for synchronous serial data communications and has an 8-bit parallel-loaded, serial shift register using SI as the input and SO as the output. SK is the clock for the serial shift register (SIO). The SK clock signal can be provided by an internal or external source. The internal clock rate is programmable by the DIVBY register. A DONE flag indicates when the data shift is completed. The MICROWIRE/PLUS capability enables it to interface with any of National Semiconductor's MICROWIRE peripherals (i.e., A/D converters, display drivers, EEPROMs).

#### **MICROWIRE/PLUS OPERATION**

The HPC46100 can enter the MICROWIRE/PLUS mode as the master or a slave. A control bit in the IRCD register determines whether the HPC46100 is the master or slave. The shift clock is generated when the HPC46100 is configured as a master. An externally generated shift clock on the SK pin is used when the HPC46100 is configured as a slave. When the HPC46100 is a master, the DIVBY register programs the frequency of the SK clock. The DIVBY register allows the SK clock frequency to be programmed in 15 selectable steps from 64 Hz to 1 MHz with CKI at 16.0 MHz. The contents of the SIO register may be accessed through any of the memory access instructions. Data waiting to be transmitted in the SIO register is clocked out on the falling edge of the SK clock. Serial data on the SI pin is clocked in on the rising edge of the SK clock.



FIGURE 26. MICROWIRE/PLUS

### **HPC46100 UART**

The HPC46100 contains a software programmable UART. The UART (see Figure 27) consists of a transmit shift register, a receiver shift register and five addressable registers, as follows: a transmit buffer register (TBUF), a receiver buffer register (RBUF), a UART control and status register (ENU), a UART receive control and status register (ENUR) and a UART interrupt and clock source register (ENUI). The ENU register contains flags for transmit and receive functions; this register also determines the length of the data frame (7, 8 or 9 bits) and the value of the ninth bit in transmission. The ENUR register flags framing, parity, and data overrun errors while the UART is receiving. Other functions of the ENUR register include saving the ninth bit received in the data frame, reporting receiving and transmitting status, and enabling or disabling the UART's Attention Mode of operation.

The determination of an internal or external clock source is done by the ENUI register, as well as selecting the number of stop bits ( $7_{\rm /6}$ , 1, 1 $7_{\rm /6}$  or 2 stop bits), selecting between the synchronous or asynchronous mode and enabling or disabling transmit and receive interrupts. The clock inputs to the Transmitter and Receiver sections of the UART can be individually selected to come from either an off-chip source on the CKX pin or one of the two on-chip sources. The Divide-By (DIVBY) Register provides upward compatibility from earlier HPC family members, and the most flexible and accurate on-chip clocking is provided by the Baud Rate Generator (BRG).



FIGURE 27. UART Block Diagram

The Baud Rate Generator is controlled by the register pair PSR and BAUD. The Prescaler factor is selected by the upper 5 bits of the PSR register (the PRESCALE field), in units of the CK2 clock from 1 to 16 in  $\frac{1}{2}$  step increments. The lower 3 bits of the PSR register, in conjunction with the 8 bits of the baud register, form the 11-bit BAUDRATE field, which defines a baud rate divisor ranging from 1 to 2048, in units of the prescaled clock selected by the PRESCALE field.

In Asynchronous Mode, the resulting baud rate is  $1_{\rm 16}$  of the clocking rate selected through the BRG circuit. The maximum baud rate generated using the BRG is 625 kbaud.

In the Synchronous Mode data is transmitted on the rising edge and received on the falling edge of the external clock. Although the data is transmitted and received synchronously, it is still contained within an asynchronous frame; i.e., a start bit, parity bit (if selected) and stop bit(s) are still present.

### UART ATTENTION MODE

The HPC46100 UART features an Attention Mode of operation. This mode of operation enables the HPC46100 to be networked with other processors. Typically in such environments, the messages consist of addresses and actual data. Addresses are specified by having the ninth bit in the data frame set to 1. Data in the message is specified by having the ninth bit in the data frame reset to 0. The UART monitors the communication stream looking for addresses. When the data word with the ninth bit set is received, the UART signals the HPC46100 with an interrupt. The processor then examines the content of the receiver buffer to decide whether it has been addressed and whether to accept subsequent data.

### A/D Converter

The HPC46100 has an on-board eight-channel 8-bit Analog to Digital converter. Conversion is performed using a successive approximation technique. The A/D converter cell can operate in single-ended mode where the input voltage is applied across one of the eight input channels (D0–D7) and AGND or in differential mode where the input voltage is applied across two adjacent input channels. The A/D converter will convert up to eight channels in single-ended mode and up to four channel-pairs in differential mode.

### OPERATING MODES

The operating modes of the converter are selected by 4 bits called ADMODE (ADCR2.4–7) see Table II. Associated with the eight input channels in single-ended mode are eight result registers, one for each channel. The A/D converter can be programmed by software to convert on any specific channel storing the result in the result register associated with that channel. It can also be programmed to stop after one conversion or to convert continuously. If a brief history of the signal on any specific input channel is required, the converter can be programmed to convert on that channel and store the consecutive results in each of the result register stepping. As a final configuration in single-ended mode, the converter can be programmed to convert the signal on each input channel and store the result in its associated step is the signal on each input channel and store the result in its associated be programmed to convert the signal on each input channel and store the result in its associated be programmed to convert the signal on each input channel and store the result in its associated be programmed to convert the signal on each input channel and store the result in its associated be result register continuously.

Associated with each even-odd pair of input channels in differential mode of operation are four result register-pairs. The A/D converter performs two conversions on the selected pair of input channels. One conversion is performed assuming the positive connection is made to the even channel and the negative connection is made to the following odd channel. This result is stored in the result register associated with the even channel. Another conversion is performed assuming the positive connection is made to the odd channel and the negative connection is made to the preceding even channel. This result is stored in the result register associated with the odd channel. This technique does not require that the programmer know the polarity of the input signal. If the even channel result register is non-zero (meaning the odd channel result register is zero), then the input signal is positive with respect to the odd channel. If the odd channel result register is non-zero (meaning the even channel result register is zero), then the input signal is positive with respect to the even channel.

### A/D Converter (Continued)

|        | TABLE II. Operating Modes                                                                                                 |  |  |  |  |
|--------|---------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Mode 0 | single-ended, single channel, single result<br>register, one-shot (default value on power-<br>up)                         |  |  |  |  |
| Mode 1 | single-ended, single channel, single result register, continuous                                                          |  |  |  |  |
| Mode 2 | single-ended, single channel, multiple result registers, stop after 8                                                     |  |  |  |  |
| Mode 3 | single-ended, multiple channel, multiple result register, continuous                                                      |  |  |  |  |
| Mode 4 | differential, single channel-pair, single result register-pair, one-shot                                                  |  |  |  |  |
| Mode 5 | differential, single channel-pair, single result register-pair, continuous                                                |  |  |  |  |
| Mode 6 | differential, single channel-pair, multiple<br>result register-pairs, stop after 4 pairs                                  |  |  |  |  |
| Mode 7 | differential, multiple channel-pair, multiple result register-pairs, continuous                                           |  |  |  |  |
| Mode 8 | single-ended, single channel, single result<br>register, one-shot (default value on power-<br>up), quiet address/data bus |  |  |  |  |
| Mode C | differential, single channel-pair, single result<br>register-pair, one-shot, quiet address/data<br>bus                    |  |  |  |  |

The same operating modes for single-ended operation also apply when the inputs are taken from channel-pairs in differential mode. The programmer can configure the A/D to convert on any selected channel-pair and store the result in its associated result register-pair then stop. The A/D can also be programmed to do this continuously. Conversion can also be done on any channel-pair storing the result into four result register-pairs for a history of the differential input. Finally, all input channel-pairs can be converted continuously. The final mode of operation suppresses the external address/data bus activity during the single conversion modes. These quiet modes of operation utilize the RDY function of the HPC Core to insert wait states in the instruction being executed in order to limit digital noise in the environment due to external bus activity when addressing external memory.

### CONTROL

The conversion clock supplied to the A/D converter can be selected by three bits in ADCR1. These bits are used as a prescaler on CKI, and can provide a clock rate from CKI/4 to CKI/32. These bits can be used to ensure that the A/D is clocked as fast as possible when different external crystal frequencies are used. Controlling the starting of conversion cycles in each of the operating modes can be done by four different methods. The method is selected by two bits called SC (ADCR3.0–1). Conversion cycles can be initiated through software by resetting a bit in a control register, through hardware by an underflow of Timer T2, or externally by a rising or falling edge of a signal input on I7.

#### INTERRUPTS

The A/D converter can interrupt the HPC when it completes a conversion cycle if one of the non-continuous modes has been selected. If one of the cycle modes was selected, then the converter will request an interrupt after eight conversions. If one of the one-shot modes was selected, then the converter will request an interrupt after every conversion. When this interrupt is generated, the HPC vectors to the A/D converter interrupt vector location at address FFF0.

#### Analog Input and Source Resistance Considerations

Figure 28 shows the A/D pin model for the HPC46100 in single ended mode. The differential mode has similiar A/D pin model. The leads to the analog inputs should be kept as short as possible. Both noise and digital clock coupling to an A/D input can cause conversion errors. The clock lead should be kept away from the analog input line to reduce coupling. The A/D channel input pins do not have any internal output driver circuitry connected to them because this circuitry would load the analog input signals due to output buffer leakage current.



### A/D Converter (Continued)

Source impedances greater than 1 k $\Omega$  on the analog input lines will adversely affect internal RC charging time during input sampling. As shown in *Figure 28*, the analog switch to the DAC array is closed only during the 2 A/D cycle sample time. Large source impedances on the analog inputs may result in the DAC array not being charged to the correct voltage levels, causing scale errors.

If large source resistance is necessary, the recommended solution is to slow down the A/D clock speed in proportion to the source resistance. The A/D converter may be operated at the maximum speed for R<sub>S</sub> less than 1 kΩ. For R<sub>S</sub> greater than 1 kΩ, A/D clock speed needs to be reduced. For example, with R<sub>S</sub> = 2 kΩ, the A/D converter may be operated at half the maximum speed. A/D converter clock speed may be slowed down by either increasing the A/D prescaler divide-by or decreasing the CKI clock frequency. The A/D clock speed may be reduced to its minimum frequency of 100 kHz.

### **Shared Memory Support**

Shared memory access provides a rapid technique to exchange data. It is effective when data is moved from a peripheral to memory or when data is moved between blocks of memory. A related area where shared memory access proves effective is in multiprocessing applications where two CPUs share a common memory block (see *Figure 29*). The HPC46100 supports shared memory access with two pins. The pins are the RDY/HLD input pin and the HLDA output pin. The user can software select either the Hold or Ready function by the state of a control bit. The HLDA output is multiplexed onto port B.

The host uses DMA to interface with the HPC46100. The host initiates a data transfer by activating the HLD input of the HPC46100. In response, the HPC46100 places its system bus in a TRI-STATE Mode, freeing it for use by the host.



### Shared Memory Support (Continued)

The host waits for the acknowledge signal (HLDA) from the HPC46100 indicating that the system bus is free. On receiving the acknowledge, the host can rapidly transfer data into, or out of, the shared memory by using a conventional DMA controller. Upon completion of the message transfer, the host removes the HOLD request and the HPC46100 resumes normal operations.

### Memory

FFFF:FFF0

FFEF:FFD0

FFCF:0800

07FF:04C0

04BF:0196

0195:0194

0191:0190

018F:018E

018D:018C

018B:018A

0189:0188

0187:0186

0185:0184

0183:0182

0181:0180

017F:0168

0167:0166

0165:0164 0163:0162

0161:0160

015F:0158

0157:0156

0155:0154

0153:0152

0151:0150

014F:012D

012C

012A

0128

0126

0124

0122

0120

011E

011C

011A

0118

0116

0114

0112

0110

010F:0109

0192

The HPC46100 has been designed to offer flexibility in memory usage. A total address space of 64 kbytes can be

directly addressed including 1024 bytes of RAM available on the chip itself.

Program memory addressing is accomplished by the 16-bit program counter on a byte basis. Memory can be addressed directly by instructions or indirectly through registers or any memory word in the first 256 bytes of memory (On-Chip Basepage RAM). Memory can be addressed as words or bytes. Words are always addressed on even-byte boundaries. The HPC46100 uses memory-mapped organization to support registers, I/O and on-chip peripheral functions. The HPC46100 memory address space extends to 64 kbytes and registers and I/O are mapped as shown in Table III.

El Pin

Control

A/D

Control

Timer 5

Ports

A&B

Control

Timer 4

Ports A&B

Math Unit

Interrupt

Control

Registers

HPC Core

Registers

Basepage

RAM

| TABLE III. HPC46100 Memory Map                                                                                            |                         |   |                                                               |                                                                             |  |
|---------------------------------------------------------------------------------------------------------------------------|-------------------------|---|---------------------------------------------------------------|-----------------------------------------------------------------------------|--|
| Interrupt Vectors<br>JSRP Vectors                                                                                         | User<br>Memory          |   | 0108                                                          | EICON Register                                                              |  |
| External Memory<br>On-Chip RAM                                                                                            | Chip RAM User<br>RAM    |   | 0106<br>0104<br>0102<br>0100                                  | ADCR3 Register<br>PORTD Register<br>ADCR2 Register<br>ADCR1 Register        |  |
| RESERVED<br>Watchdog Register                                                                                             | Watchdog<br>Logic       |   | 00FF:00FE<br>00FD:00FC<br>00FB:00FA                           | T5 TIMER<br>T5CON Register<br>R5A Register                                  |  |
| TOCON Register<br>TMMODE Register                                                                                         |                         |   | 00F9:00F8<br>00F7:00F6                                        | R5B Register<br>RESERVED                                                    |  |
| DIVBY Register<br>T3 Timer<br>R3 Register<br>T2 Timer<br>R2 Register                                                      | Timer<br>Block<br>T0:T3 |   | 00F5:00F4<br>00F3:00F2<br>00F1:00F0                           | BFUN Register<br>DIR B Register<br>RESERVED<br>FOR DIRA                     |  |
| I2CR Register/R1<br>I3CR Register/T1<br>I4CR Register                                                                     |                         |   |                                                               | T4 TIMER<br>T4CON Register<br>R4A Register                                  |  |
| RESERVED<br>CSC3 Register<br>CSC2 Register                                                                                | Chip                    |   | 00E9:00E8<br>00E7:00E6                                        | R4B Register<br>RESERVED<br>FOR UPIC                                        |  |
| CSC1 Register                                                                                                             | Select<br>Control       |   | 00E5:00E6                                                     | RESERVED                                                                    |  |
| CSC0 Register<br>RESERVED                                                                                                 |                         |   | 00E3:00E2<br>00E1:00E0                                        | PORTB Register<br>RESERVED                                                  |  |
| T6 Timer<br>T6CON Register<br>R6A Register<br>R6B Register                                                                | Timer T6                |   | 00DF:00DE<br>00DD:00DC<br>00DA                                | FOR PORTA<br>MRU (MRR upper)<br>MRL (MRR lower)<br>MIR                      |  |
| RESERVED                                                                                                                  |                         |   | 00D8                                                          | PORTI Register                                                              |  |
| Baud Register<br>PSR Register<br>ENUR Register<br>TBUF Register                                                           | UART                    |   | 00D6<br>00D4<br>00D2<br>00D0                                  | SIO Register<br>IRCD Register<br>IRPD Register<br>ENIR Register             |  |
| RBUF Register<br>ENUI Register<br>ENU Register                                                                            |                         |   | 00CF:00CE<br>00CD:00CC<br>00CB:00CA                           | X Register<br>B Register<br>K Register                                      |  |
| A/D Result Register 7<br>A/D Result Register 6<br>A/D Result Register 5<br>A/D Result Register 4<br>A/D Result Register 3 | A/D                     |   | 00C9:00C8<br>00C7:00C6<br>00C5:00C4<br>00C3:00C2<br>00C1:00C0 | A Register<br>PC Register<br>SP Register<br>HALTEN Register<br>PSW Register |  |
| A/D Result Register 2<br>A/D Result Register 1<br>A/D Result Register 0                                                   | Converter               |   | 00BF:0000                                                     | On-Chip RAM                                                                 |  |
| RESERVED                                                                                                                  |                         | J |                                                               |                                                                             |  |

#### TABLE III. HPC46100 Memory Map

### **Design Considerations**

Designs using the HPC family of 16-bit high speed CMOS microcontrollers need to follow some general guidelines on usage and board layout.

Floating inputs are a frequently overlooked problem. CMOS inputs have extremely high impedance and, if left open, can float to any voltage. You should thus tie unused inputs to  $V_{CC}$  or ground, either through a resistor or directly. Unlike the inputs, unused outputs should be left floating to allow the output to switch without drawing any DC current.

To reduce voltage transients, keep the supply line's parasitic inductances as low as possible by reducing trace lengths, using wide traces, ground planes, and by decoupling the supply with bypass capacitors. In order to prevent additional voltage spiking, this local bypass capacitor must exhibit low inductive reactance. You should therefore use high frequency ceramic capacitors and place them very near the IC to minimize wiring inductance.

- Keep V<sub>CC</sub> bus routing short. When using double sided or multilayer circuit boards, use ground plane techniques.
- Keep ground lines short, and on PC boards make them as wide as possible, even if trace width varies. Use separate ground traces to supply high current devices such as relay and transmission line drivers.
- In systems mixing linear and logic functions and where supply noise is critical to the analog components' performance, provide separate supply buses or even separate supplies.
- If you use local regulators, bypass their inputs with a tantalum capacitor of at least 1  $\mu$ F and bypass their outputs with a 10  $\mu$ F to 50  $\mu$ F tantalum or aluminum electrolytic capacitor.
- If the system uses a centralized regulated power supply, use a 10  $\mu$ F to 20  $\mu$ F tantalum electrolytic capacitor or a 50  $\mu$ F to 100  $\mu$ F aluminum electrolytic capacitor to decouple the V<sub>CC</sub> bus connected to the circuit board.
- Provide localized decoupling. For random logic, a rule of thumb dictates approximately 10 nF (spaced within 12 cm) per every two to five packages, and 100 nF for every 10 packages. You can group these capacitances, but it's more effective to distribute them among the ICs. If the design has a fair amount of synchronous logic with outputs that tend to switch simultaneously, additional decoupling might be advisable. Octal flip-flop and buffers in bus-oriented circuits might also require more decoupling. Note that wire-wrapped circuits can require more decoupling than ground plane or multilayer PC boards.



A recommended crystal oscillator circuit to be used with the HPC is shown in *Figure 30*. See table for recommended component values. The recommended values given in the table have yielded consistent results and are made to match a crystal with a 18 pF load capacitance, with some small allowance for layout capacitance.

For frequencies between 26 MHz and 40 MHz a third overtone frequency "AT" cut crystal or fundamental frequency "BT" cut crystal may be used. Tite "AT" crystal has a tighter frequency tolerance over temperature than the "BT" cut. The "BT" crystal network is easier to design due to its fundamental nature. For the "BT" crystal:

$$R_{\rm F} = 1-2 \,\mathrm{M}\Omega$$
,  $R_1 = 0\Omega - 100\Omega$ 

 $C_1 = 22 \text{ pF}-27 \text{ pF}, C_2 = 27 \text{ pF}-53 \text{ pF}.$ 

The "AT" crystal can be configured in one of two ways. One circuit is shown in *Figure 31*.

where:

$$R_{F} = 1 M\Omega - 2 M\Omega, R_{1} = 0\Omega - 100\Omega,$$

 $C_{l}\,=\,22\;pF{-}27\;pF,\,C_{2}\,=\,27\;pF{-}33\;pF$ 

 $C_3 = 15 \text{ pF}-30 \text{ pF}$ , and  $L_1$  is determined by the equation:

$$f = \frac{1}{2\pi\sqrt{L_1 C_3}}$$

f is the frequency which is  $1/_2$  the crystal frequency, from this, the value of  $L_1$  can be calculated. The second circuit is similar to *Figure 30* where  $R_F=2~k\Omega,~R_1=0\Omega,~C_1=12~pF-15~pF,~C_2=15~pF-22~pF$ . The lower  $C_1$  and  $C_2$  values allow a greater influence to stray capacitance and EMI. The lower  $R_F$  resistance decreases gain while increasing bandwidth. The oscillator networks and component values are supplied for reference only. Actual networks and component values should be obtained from the crystal manufacturer.

| XTAL<br>Frequency<br>(MHz) | <b>R1 (</b> Ω) |
|----------------------------|----------------|
| ≤2                         | 1500           |
| 4                          | 1200           |
| 6                          | 910            |
| 8                          | 750            |
| 10                         | 600            |
| 12                         | 470            |
| 14                         | 390            |
| 16                         | 300            |
| 18                         | 220            |
| 20                         | 180            |
| 22                         | 150            |
| 24                         | 120            |

 $\mathsf{R}_\mathsf{F}$  = 3.3 M $\Omega,\,\mathsf{C1}$  = 27 pF, C2 = 33 pF

XTAL Specifications: The crystal used was an M-TRON Industries MP-1 Series crystal. Fundamental frequency "AT" cut parallel resonant with a loading capacitance C<sub>L</sub> = 18 pF, and a series resistance of 25 $\Omega$  @ 25 MHz, 40 $\Omega$  @ 10 MHz, or 600 $\Omega$  @ 2 MHz.





A recommended layout for the oscillator network should be as close to the processor as physically possible, entirely within "1" distance. This is to reduce lead inductance from long PC traces, as well as interference from other components, and reduce trace capacitance. The layout contains a large ground plane either on the top or bottom surface of the board to provide signal shielding, and a convenient location to ground both the HPC, and the case of the crystal. It is very critical to have an extremely clean power supply for the HPC crystal oscillator. Ideally one would like a  $V_{\mbox{CC}}$  and ground plane that provide low inductance power lines to the chip. The power planes in the PC board should be decoupled with three decoupling capacitors as close to the chip as possible. A 1.0  $\mu$ F, a 0.1  $\mu$ F, and a 0.001  $\mu$ F capacitor dipped mica or ceramic cap mounted as close to the HPC as physically possible on the board using short leads, or surface mount components. This should provide a stable power supply, and noiseless ground plane which will vastly improve the performance of the crystal oscillator network.

### **HPC46100 CPU**

The HPC46100 CPU has a 16-bit ALU and six 16-bit registers.

#### ARITHMETIC LOGIC UNIT (ALU)

The ALU is 16 bits wide and can do 16-bit add, subtract and shift or logic AND, OR and exclusive OR in one timing cycle. The ALU has two carry bits; one for signed overflow (V bit) and one for unsigned overflow (C bit).

#### **ACCUMULATOR (A) REGISTER**

The 16-bit A register is the source and destination register for most I/O, arithmetic, logic and data memory access operations.

#### ADDRESS (B AND X) REGISTERS

The 16-bit B and X registers can be used for indirect addressing. They can automatically count up or down to sequence through data memory.

#### **BOUNDARY (K) REGISTER**

The 16-bit K register is used to set limits in repetitive loops of code as register B sequences through data memory. The K register can also be used as a pointer register.

#### STACK POINTER (SP) REGISTER

The 16-bit SP register is the pointer that addresses the stack. The SP register is incremented by two for each push or call and decremented by two for each pop or return. The stack can be placed anywhere in user memory and be as

deep as the available memory permits. The SP register can also be used as a pointer register.

#### **PROGRAM (PC) REGISTER**

The 16-bit PC register addresses program memory.

### MAU RESULT REGISTER (MRR)

The 32-bit MAU Result Register holds the results from MAC (Multiply/Accumulate) instructions. In addition, it receives the result of the MULS (Multiply Signed) instruction, and can be shifted in place by the ASHR (Arithmetic Shift Right) operation.

### **Addressing Modes**

ADDRESSING MODES WITH THE ACCUMULATOR AS DESTINATION

#### **Register Indirect**

The operand is the memory addressed by the A, B, X or K register. This mode of addressing for the HPC46100 produces single byte instructions when using the B or X register (depending on the instruction).

#### Direct

The instruction contains an 8-bit or 16-bit address field that directly points to the memory for the operand.

#### Indirect

The instruction contains an 8-bit address field. The contents of the WORD addressed points to the memory for the operand.

### Indexed

The instruction contains an 8-bit address field and an 8- or 16-bit displacement field. The contents of the WORD addressed is added to the displacement to get the address of the operand.

#### Immediate

The instruction contains an 8-bit or 16-bit immediate field that is used as the operand.

#### **Register Indirect (Auto Increment and Decrement)**

The operand is the memory addressed by the X register. This mode automatically increments or decrements the X register (by 1 for bytes and by 2 for words).

# Register Indirect Auto Increment and Decrement) with Conditional Skip

The operand is the memory addressed by the B register. This mode automatically increments or decrements the B register (by 1 for bytes and by 2 for words). The B register is then compared with the K register. A skip condition is generated if B goes past K.

# ADDRESSING MODES WITH DIRECT MEMORY AS DESTINATION

### **Direct Memory to Direct Memory**

The instruction contains two 8- or 16-bit address fields. One field directly points to the source operand and the other field directly points to the destination operand.

#### **Immediate to Direct Memory**

The instruction contains an 8- or 16-bit address field and an 8- or 16-bit immediate field. The immediate field is the operand and the direct field is the destination.

### Addressing Modes (Continued)

#### **Double Register Indirect Using the B and X Registers**

Used only with Reset, Set, IF and IF NOT bit instructions; a specific bit within the 64 kbyte address range is addressed using the B and X registers. The address of a byte of memory is formed by adding the contents of the B register to the most significant 13 bits of the X register. The specific bit to be modified or tested within the byte of memory is selected using the least significant 3 bits of register X.

### **Code Efficiency**

One of the most important criteria of a single chip microcontroller is code efficiency. The more efficient the code, the more features that can be put on a chip. The memory size on a chip is fixed so if code is not efficient, features may have to be sacrificed or the programmer may have to buy a larger, more expensive version of the chip.

The HPC46100 has been designed to be extremely code-efficient. The HPC46100 looks very good in all the standard coding benchmarks; however, it is not realistic to rely only on benchmarks. Many large jobs have been programmed onto the HPC46100, and the code savings over other popular microcontrollers has been considerable. Reasons for this saving of code include the following:

#### SINGLE BYTE INSTRUCTIONS

The majority of instructions on the HPC46100 are singlebyte. There are two especially code-saving instructions: JP is a 1-byte jump. True, it can only jump within a range of plus or minus 32, but many loops and decisions are often within a small range of program memory.

JSRP is a 1-byte call subroutine. The user makes a table of his 16 most frequently called subroutines and these calls will only take one byte. Most other micros require two and even three bytes to call a subroutine. The user does not have to decide which subroutine addresses to put into his table; the assembler can give him this information.

#### EFFICIENT SUBROUTINE CALLS

The 2-byte JSR instructions can call any subroutine within plus or minus 1k of program memory.

#### MULTIFUNCTION INSTRUCTION FOR DATA MOVEMENT AND PROGRAM LOOPING

The HPC46100 has single-byte instructions that perform multiple tasks. For example, the XS instruction will do the following.

- 1. Exchange A and memory pointed to by the B register
- 2. Increment or decrement the B register
- 3. Compare the B register to the K register
- 4. Generate a conditional skip if B has passed K

The value of this multipurpose instruction becomes evident when looping through sequential areas of memory and exiting when the loop is finished.

#### **BIT MANIPULATION INSTRUCTIONS**

Any bit of memory, I/O or registers can be set, reset or tested by the single byte bit instructions. The bits can be addressed directly or indirectly. Since all registers and I/O are mapped into the memory, it is very easy to manipulate specific bits to do efficient control.

### MULTIPLY AND DIVIDE INSTRUCTIONS

The HPC46100 has 16-bit multiply, 16-bit by 16-bit divide, and 32-bit by 16-bit divide instructions. This saves both code and time. Multiply and divide can use immediate data or data from memory. The ability to multiply and divide by immediate data saves code since this function is often needed for scaling, base conversion, computing indexes of arrays, etc.

| Mnemonic      | Description                                                                      | Action                                                                                                                          |
|---------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| ARITHMETIC    | INSTRUCTIONS                                                                     |                                                                                                                                 |
| ADD           | Add                                                                              | $MA + MemI \rightarrow MA$ , carry $\rightarrow C$                                                                              |
| ADC           | Add with carry                                                                   | $MA + MemI + C \rightarrow MA$ , carry $\rightarrow C$                                                                          |
| SUB           | Subtract without carry                                                           | $MA-MemI \rightarrow MA$                                                                                                        |
| SUBC          | Subtract with carry                                                              | $MA-Meml+C \rightarrow MA$ , carry $\rightarrow C$                                                                              |
| MULT          | Multiply (unsigned)                                                              | $MA^*MemI \rightarrow MA \& X, 0 \rightarrow K, 0 \rightarrow C$                                                                |
| DIV           | Divide (unsigned)                                                                | MA/MemIMA, rem. $\rightarrow$ X, 0 $\rightarrow$ K, 0 $\rightarrow$ C                                                           |
| DIVD          | Divide Double Word (unsigned)                                                    | X & MA/MemIMA, rem. $\rightarrow$ X, 0K, Carry $\rightarrow$ C                                                                  |
| IFEQ          | If equal                                                                         | Compare MA & Meml, Do next if equal                                                                                             |
| IFGT          | If greater than                                                                  | Compare MA & Meml, Do next if MA > Meml                                                                                         |
| IFGE          | If greater than or equal                                                         | Compare MA & Meml, Do next if $MA = or > Meml$                                                                                  |
| IFGES         | If greater than or equal signed                                                  | Signed compare MA & Meml, Do next if MA = or > Meml                                                                             |
| IFGTS         | If greater than signed                                                           | Signed compare MA & Meml, Do next if MA > Meml                                                                                  |
| AND           | Logical and                                                                      | MA and MemI $\rightarrow$ MA                                                                                                    |
| OR            | Logical or                                                                       | MA or Meml $\rightarrow$ MA                                                                                                     |
| XOR           | Logical exclusive-or                                                             | MA or Memi $\rightarrow$ MA                                                                                                     |
| MACZ          | ·                                                                                | $0 \rightarrow MRR, [B+]^*[X+] + MRR \rightarrow MRR$                                                                           |
| WACZ          | Multiply-accumulate From<br>Zero signed word                                     | $O \rightarrow Minn, [B + ] [X + ] + Minn \rightarrow Minn$<br>OVERFLOW $\rightarrow$ MVP or MVN, IF B>K THEN A $\rightarrow$ B |
| MAC           | 0                                                                                | $[B+]^*[X+]+MRR \rightarrow MRR, OVERFLOW \rightarrow MVP or MVN, IF B>K then A \rightarrow E$                                  |
|               | Multiple-accumulate signed word                                                  |                                                                                                                                 |
| MULS<br>ASHR  | Multiply, signed                                                                 | $MA^*MemI \rightarrow MRR$                                                                                                      |
|               | Arithmetic right                                                                 | $MRR/2^{A}MM \rightarrow MRR, \text{ or } MRR/2^{A} \rightarrow MRR$                                                            |
| MEMORY MC     | DIFY INSTRUCTIONS                                                                |                                                                                                                                 |
| INC           | Increment                                                                        | $Mem + 1 \rightarrow Mem$                                                                                                       |
| DECSZ         | Decrement, skip if 0                                                             | $Mem - 1 \rightarrow Mem, Skip next if Mem = 0$                                                                                 |
| BIT INSTRUC   | TIONS                                                                            |                                                                                                                                 |
| SBIT          | Set bit                                                                          | 1 → Mem.bit                                                                                                                     |
| RBIT          | Reset bit                                                                        | $0 \rightarrow Mem.bit$                                                                                                         |
| IFBIT         | If bit                                                                           | If Mem.bit is $=$ 1, do next instruction                                                                                        |
| IFNBIT        | If not bit                                                                       | If Mem.bit is $=$ 0, do next instruction                                                                                        |
| MEMORY TR     | ANSFER INSTRUCTIONS                                                              |                                                                                                                                 |
| LD            | Load                                                                             | $Meml \rightarrow MA$                                                                                                           |
| LD            | Load, incr/decr X                                                                | $Mem(X) \rightarrow A, X \pm 1 \text{ (or 2)} \rightarrow X$                                                                    |
| LD B,         | Load, incl/decl X                                                                | $\operatorname{Men}(X) \to A, X \pm 1 (012) \to X$                                                                              |
| mode          | Load B                                                                           | $Meml \to B$                                                                                                                    |
|               | LOAU D                                                                           |                                                                                                                                 |
| LD X,<br>mode | Load X                                                                           | Moml -> V                                                                                                                       |
|               | Load A                                                                           | MemI $\rightarrow$ X                                                                                                            |
| LD K,         | Lood K                                                                           | $MemI \to K$                                                                                                                    |
| mode          | Load K                                                                           |                                                                                                                                 |
| ST            | Store to Memory                                                                  | $A \rightarrow Mem$                                                                                                             |
| Х             |                                                                                  | $A \rightarrow Mem$                                                                                                             |
|               | Exchange, incr/decr X                                                            | $A \rightarrow Mem(X), X \pm 1 \text{ (or } 2) \rightarrow X$                                                                   |
| PUSH          | Push Memory to Stack                                                             | $W \rightarrow W(SP), SP + 2 \rightarrow SP$                                                                                    |
| FETCH         | Dummy read                                                                       | Gen. addressed byte is read and discarded                                                                                       |
| POP           | Pop Stack to Memory                                                              | $SP-2 \rightarrow SP, W(SP) \rightarrow W$                                                                                      |
| LDS           | Load A, incr/decr B,                                                             | $Mem(B) \rightarrow A, B \pm 1 \text{ (or 2)} \rightarrow B,$                                                                   |
| 200           | Skip on condition                                                                | Skip next if B greater/less than K                                                                                              |
| XS            | Exchange, incr/decr B,                                                           | $MEM(B) \longleftrightarrow A, B \pm 1 \text{ (or } 2) \longrightarrow B,$                                                      |
|               | Skip on condition                                                                | Skip next if B greater/less than K                                                                                              |
|               | 6-bit word of memory                                                             | 24                                                                                                                              |
|               | Accumulator A or direct memory (8- or 16-bit word of memory                      | ny                                                                                                                              |
|               | is 8-bit byte or 16-bit word of memory                                           | liato data                                                                                                                      |
|               | is 8- or 16-bit memory or 8- or 16-bit immed<br>s 8-bit or 16-bit immediate data | ilaie Uala                                                                                                                      |
|               |                                                                                  |                                                                                                                                 |

| Mnemonic                                        | Description                                                                                                                                                                  | Action                                                                                       |
|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| EGISTER LOAD I                                  | MMEDIATE INSTRUCTIONS                                                                                                                                                        |                                                                                              |
| LD B                                            | Load B                                                                                                                                                                       | $MemI \rightarrow B$                                                                         |
| LD K                                            | Load B                                                                                                                                                                       | $Meml \rightarrow K$                                                                         |
| LD X                                            | Load X                                                                                                                                                                       | $Meml \rightarrow X$                                                                         |
| LD BK                                           | Load B and K immediate                                                                                                                                                       | $\operatorname{imm} \rightarrow B, \operatorname{imm} \rightarrow K$                         |
| CCUMULATOR A                                    | ND C INSTRUCTIONS                                                                                                                                                            |                                                                                              |
| CLR A                                           | Clear A                                                                                                                                                                      | $0 \rightarrow A$                                                                            |
| INC A                                           | Increment A                                                                                                                                                                  | $A + 1 \rightarrow A$                                                                        |
| DEC A                                           | Decrement A                                                                                                                                                                  | $A + 1 \rightarrow A$                                                                        |
| COMP A                                          | Complement A                                                                                                                                                                 | 1's complement A $\rightarrow$ A                                                             |
| SWAP A                                          | Swap nibbles of A                                                                                                                                                            | $A15:12 \leftarrow A11:8 \leftarrow A7:4 \leftarrow \rightarrow A3:0$                        |
| RRC A                                           | Rotate A right thru C                                                                                                                                                        | $C \rightarrow A15 \rightarrow \rightarrow A0 \rightarrow C$                                 |
| RLC A                                           | Rotate A left thru C                                                                                                                                                         | $C \leftarrow A15 \leftarrow \leftarrow A0 \leftarrow C$                                     |
| SHR A                                           | Shift A right                                                                                                                                                                | $0 \rightarrow A15 \rightarrow \rightarrow A0 \rightarrow C$                                 |
| SHL A                                           | Shift A left                                                                                                                                                                 | $C \leftarrow A15 \leftarrow C$                                                              |
| SC                                              | Set C                                                                                                                                                                        | $1 \rightarrow C$                                                                            |
|                                                 | Reset C                                                                                                                                                                      | $0 \rightarrow C$                                                                            |
| RC                                              |                                                                                                                                                                              | $D \rightarrow C$<br>Do next if $C = 1$                                                      |
| IFC                                             | IF C                                                                                                                                                                         |                                                                                              |
| IFNC                                            | IF not C                                                                                                                                                                     | Do next if C = 0                                                                             |
|                                                 | NTROL INSTRUCTIONS                                                                                                                                                           |                                                                                              |
| JSRP                                            | Jump Subroutine from table                                                                                                                                                   | $PC \rightarrow W(SP), SP + 2 \rightarrow SP, W(table\#) \rightarrow PC$                     |
| JSR                                             | Jump Subroutine relative                                                                                                                                                     | $PC \rightarrow W(SP), SP+2 \rightarrow SP, PC + \# \rightarrow PC (\# is + 1025 to - 1023)$ |
| JSRL                                            | Jump Subroutine long                                                                                                                                                         | $PC \rightarrow W(SP), SP+2 \rightarrow SP, PC+ \# \rightarrow PC$                           |
| JP                                              | Jump relative short                                                                                                                                                          | $PC + # \rightarrow PC(# is + 32 to - 31)$                                                   |
| JMP                                             | Jump relative                                                                                                                                                                | $PC + # \rightarrow PC(# is + 257 to - 255)$                                                 |
| JMPL                                            | Jump relative long                                                                                                                                                           | $PC + # \rightarrow PC$                                                                      |
| JID                                             | Jump indirect at PC+A                                                                                                                                                        | $PC + A + 1 \rightarrow PC$                                                                  |
| JIDW                                            |                                                                                                                                                                              | then Mem(PC) + PC $\rightarrow$ PC                                                           |
| NOP                                             | No Operation                                                                                                                                                                 | $PC+1 \rightarrow PC$                                                                        |
| RET                                             | Return                                                                                                                                                                       | $SP-2 \rightarrow SP,W(SP) \rightarrow PC$                                                   |
| RETSK                                           | Return then skip next                                                                                                                                                        | $SP-2 \rightarrow SP,W(SP) \rightarrow PC, \& skip$                                          |
| RETI                                            | Return from interrupt                                                                                                                                                        | $SP-2 \rightarrow SP,W(SP) \rightarrow PC$ , interrupt re-enabled                            |
| Mem is 8-bit<br>Meml is 8- or<br>imm is 8-bit c | ulator A or direct memory (8- or 16-bit)<br>byte or 16-bit word of memory<br>16-bit memory or 8- or 16-bit immediate data<br>or 16-bit immediate data<br>immediate data only |                                                                                              |





National does not assume any responsibility for use of any circuitry described, no circuit patent licenses are implied and National reserves the right at any time without notice to change said circuitry and specifications.