## PRELIMINARY

# HPC16400E/HPC36400E/HPC46400E

# National Semiconductor

# HPC16400E/HPC36400E/HPC46400E High-Performance Communications microController

## **General Description**

The HPC16400E is an upgraded HPC16400. Features have been added to support V.120, the 8-bit mode has been enhanced to support all instructions, and the UART has been changed to provide more flexibility and power. The HPC16400E is fully upward compatible with the HPC16400.

The HPC16400E has 4 functional blocks to support a wide range of communication application-2 HDLC channels, 4 channel DMA controller to facilitate data flow for the HDLC channels, programmable serial interface and UART.

The serial interface decoder allows the 2 HDLC channels to be used with devices using interchip serial link for point-topoint and multipoint data exchanges. The decoder generates enable signals for the HDLC channels allowing multiplexed D and B channel data to be accessed.

The HDLC channels manage the link by providing sequencing using the HDLC framing along with error control based upon a cyclic redundancy check (CRC). Multiple address recognition modes, and both bit and byte modes of operation are supported.

The HPC16400E is available in 68-pin PLCC, LDCC, PGA and 84-Pin TapePak® packages.

## **Features**

- HPC<sup>TM</sup> family—core features:
  - 16-bit data bus, ALU, and registers
  - 64 kbytes of external memory addressing
  - FAST!-20.0 MHz system clock
  - Four 16-bit timer/counters with WATCHDOG logic
  - MICROWIRE/PLUS™ serial I/O interface
  - CMOS-low power with two power save modes

- Two full duplex HDLC channels
  - Optimized for ISDN, X.25, V.120, and LAPD applications
  - Programmable frame address recognition
  - Up to 4.65 Mbps serial data rate
  - Built in diagnostics
  - Synchronous bypass mode
  - Optional CRC generation
  - Received CRC bytes can be read by the CPU
- Four channel DMA controller
- 8- or 16-bit external data bus
- UART
- Full duplex
- 7, 8, or 9 data bits
- Even, odd, mark, space or no parity
- 7/8, 1 or 2 stop bit generation
- Accurate internal baud rate generation up to 625k baud without penalty of using expensive crystal
- Synchronous and asynchronous modes of operation
- Serial Decoder
  - Supports 6 popular time division multiplexing protocols for inter-chip communications
  - Optional rate adaptation of 64 kbit/s data rate to 56 kbit/s
- Over 1/2 Mbyte of extended addressing
- Easy interface to National's DASL, 'U' and 'S' transceivers—TP3400, TP3410 and TP3420
- Commercial (0°C to +70°C), industrial (-40°C to +85°C) and military (-55°C to +125°C) temperature ranges



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

ESD Rating is to be determined

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

-0.5V to 7.0V

All Other Pins  $(V_{CC} + 0.5)V$  to (GND - 0.5)VNote: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

# **DC Electrical Characteristics** $V_{CC} = 5.0V \pm 10\%$ unless otherwise specified, $T_A = 0^{\circ}C$ to $+70^{\circ}C$ for HPC46400E, $-40^{\circ}C$ to $+85^{\circ}C$ for HPC36400E, $-55^{\circ}C$ to $+125^{\circ}C$ for HPC16400E

| Symbol           | Parameter                                                                                                                                | Test Conditions                                             | Min                   | Max                 | Units |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|-----------------------|---------------------|-------|
| ICC1             | Supply Current                                                                                                                           | V <sub>CC</sub> = 5.5V, f <sub>in</sub> = 20.0 MHz (Note 1) |                       | 70                  | mA    |
|                  |                                                                                                                                          | V <sub>CC</sub> = 5.5V, f <sub>in</sub> = 2.0 MHz (Note 1)  |                       | 10                  | mA    |
| ICC2             | IDLE Mode Current                                                                                                                        | V <sub>CC</sub> = 5.5V, f <sub>in</sub> = 20.0 MHz (Note 1) |                       | 10                  | mA    |
| -                |                                                                                                                                          | V <sub>CC</sub> = 5.5V, f <sub>in</sub> = 2.0 MHz (Note 1)  |                       | 2                   | mA    |
| ICC3             | HALT Mode Current                                                                                                                        | V <sub>CC</sub> = 5.5V, f <sub>in</sub> = 0 kHz (Note 1)    |                       | 500                 | μA    |
| -                |                                                                                                                                          | V <sub>CC</sub> = 2.5V, f <sub>in</sub> = 0 kHz (Note 1)    |                       | 150                 | μA    |
| INPUT VC         | LTAGE LEVELS-SCHMITT TRIGGERE                                                                                                            |                                                             |                       |                     |       |
| VIH1             | Logic High                                                                                                                               |                                                             | 0.9 V <sub>CC</sub>   |                     | v     |
| VIL1             | Logic Low                                                                                                                                |                                                             |                       | 0.1 V <sub>CC</sub> | v     |
| INPUT VO         | DLTAGE LEVELS—PORT A                                                                                                                     |                                                             |                       |                     |       |
| VIH2             | Logic High                                                                                                                               |                                                             | 2.0                   |                     | v     |
| V <sub>IL2</sub> | Logic Low                                                                                                                                |                                                             |                       | 0.8                 | v     |
| INPUT VO         | ULTAGE LEVELS—ALL OTHERS                                                                                                                 |                                                             |                       |                     |       |
| V <sub>IH3</sub> | Logic High                                                                                                                               |                                                             | 0.7 V <sub>CC</sub>   |                     | v     |
| VIL3             | Logic Low                                                                                                                                |                                                             |                       | 0.2 V <sub>CC</sub> | v     |
| l <sub>LI</sub>  | Input Leakage Current                                                                                                                    | (Note 2)                                                    |                       | ±1                  | μΑ    |
| CI               | Input Capacitance                                                                                                                        | (Note 3)                                                    |                       | 10                  | pF    |
| CIO              | I/O Capacitance                                                                                                                          | (Note 3)                                                    |                       | 20                  | pF    |
| OUTPUT           | VOLTAGE LEVELS                                                                                                                           |                                                             |                       |                     |       |
| VOH1             | Logic High (CMOS)                                                                                                                        | l <sub>OH</sub> = -10 μA (Note 3)                           | V <sub>CC</sub> - 0.1 |                     | v     |
| VOL1             | Logic Low (CMOS)                                                                                                                         | I <sub>OH</sub> = 10 μA (Note 3)                            |                       | 0.1                 | v     |
| V <sub>OH2</sub> | Port A/B Drive, CK2                                                                                                                      | $I_{OH} = -7 \text{ mA}$                                    | 2.4                   |                     | v     |
| V <sub>OL2</sub> | (A <sub>0</sub> -A <sub>15</sub> , B <sub>10</sub> , B <sub>11</sub> , B <sub>12</sub> , B <sub>15</sub> )                               | $I_{OL} = 3 \text{ mA}$                                     |                       | 0.4                 | v     |
| V <sub>OH3</sub> | Other Port Pin Drive, WO (open drain)                                                                                                    | $I_{OH} = -1.6 \text{ mA} \text{ (except WO)}$              | 2.4                   |                     | v     |
| V <sub>OL3</sub> | (B <sub>0</sub> -B <sub>9</sub> , B <sub>13</sub> , B <sub>14</sub> , R <sub>0</sub> -R <sub>7</sub> , D <sub>5</sub> , D <sub>7</sub> ) | I <sub>OL</sub> = 0.5 mA                                    |                       | 0.4                 | v     |
| V <sub>OH4</sub> | ST1 and ST2 Drive                                                                                                                        | I <sub>OH</sub> = -6 mA                                     | 2.4                   |                     | v     |
| V <sub>OL4</sub> |                                                                                                                                          | I <sub>OL</sub> = 1.6 mA (Note 4)                           |                       | 0.4                 | v     |
| VRAM             | RAM Keep-Alive Voltage                                                                                                                   | (Note 5)                                                    | 2.5                   |                     | v     |
| loz              | TRI-STATE Leakage Current                                                                                                                |                                                             |                       | ±5                  | μA    |

Note 1:  $I_{CC_1}$ ,  $I_{CC_2}$ ,  $I_{CC_2}$  measured with no external drive ( $I_{OH}$  and  $I_{OL} = 0$ ,  $I_{H}$  and  $I_{IL} = 0$ ).  $I_{CC_1}$  is measured with RESET =  $V_{SS}$ .  $I_{CC_2}$  is measured with NMI =  $V_{CC}$ . CKI driven to  $V_{IH_1}$  and  $V_{IL_1}$  with rise and fall times less than 10 ns.

Note 2:  $\overline{\text{RDY}}/\overline{\text{HLD}}$  and  $\overline{\text{RDY}}/14$  pins have internal pullups and meet this spec only at V<sub>IN</sub> = V<sub>CC</sub>.

Note 3: These parameters are guaranteed by design and are not tested.

Note 4: ST2 drive will not meet this spec under condition of RESET pin = low.

Note 5: Test duration is 100 ms.

## **AC Electrical Characteristics**

(see Notes 1 and 4 and Figures 1 thru 5),  $V_{CC} = 5V \pm 10\%$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$  for HPC46400E,  $-40^{\circ}C$  to  $+85^{\circ}C$  for HPC36400E,  $-55^{\circ}C$  to  $+125^{\circ}C$  for HPC16400E

HPC16400E/HPC36400E/HPC46400E

|                | Symbol and Formula                    | Parameter and Notes                                 | Min | Max  | Units | Note     |
|----------------|---------------------------------------|-----------------------------------------------------|-----|------|-------|----------|
|                | fc                                    | CKI Operating Frequency                             | 2   | 20   | MHz   |          |
|                | $t_{C1} = 1/f_{C}$                    | CKI Period                                          | 50  | 500  | ns    |          |
|                | t <sub>C1R</sub>                      | CKI Rise Time                                       |     | 7    | ns    | (Note 1) |
|                | <sup>t</sup> C1F                      | CKI Fall Time                                       |     | 7    | ns    | (Note 1) |
|                | 100 t <sub>C1H</sub> /t <sub>C1</sub> | CKI Duty Cycle                                      | 45  | 55   | %     | (Note 1) |
|                | $t_{\rm C} = 2/f_{\rm C}$             | CPU or DMA Timing Cycle                             | 100 |      | ns    |          |
| ŝ              | twait = tc                            | CPU or DMA Wait State Period                        | 100 |      | ns    |          |
| Clocks         | <sup>t</sup> DC1C2R                   | Delay of CK2 Rising Edge after<br>CKI Falling Edge  | 0   | 55   | ns    | (Note 2) |
|                | tDC1C2F                               | Delay of CK2 Falling Edge after<br>CKI Falling Edge | 0   | 55   | ns    | (Note 2) |
|                | $f_{\rm U} = f_{\rm C}/8$             | External UART Clock Input Frequency                 |     | 2.5  | MHz   |          |
|                | $f_{MW} = f_C/19$                     | External MICROWIRE/PLUS<br>Clock Input Frequency    |     | 1.25 | MHz   |          |
|                | $t_{\rm HCK} = 4t_{\rm C1} + 14$      | HDLC Clock Input Period                             | 214 |      | ns    |          |
| ŝ              | $f_{XIN} = f_C/19$                    | External Timer Input Frequency                      |     | 1052 | kHz   |          |
| Je l           | $t_{XIN} = t_C$                       | Pulse Width for Timer Inputs                        | 100 |      | ns    |          |
| Timers         | $f_{XOUT} = f_C/16$                   | Timer Output Frequency                              |     | 1.25 | MHz   |          |
| ø              | tuws                                  | MICROWIRE Setup Time — Master                       | 100 | 0.   | ns    |          |
|                |                                       | — Slave                                             | 20  |      | ns    |          |
| e/             | tuwh                                  | MICROWIRE Hold Time Master                          | 20  |      | ns    |          |
| Microwire/Plus |                                       | — Slave                                             | 50  |      | ns    |          |
| cro            | tuwv                                  | MICROWIRE Output Valid Time — Master                |     | 50   | ns    |          |
| Σ              |                                       | — Slave                                             |     | 150  | ns    |          |
| Ð              | $t_{SALE} = \frac{3}{4} t_{C} + 40$   | HLD Falling Edge before ALE Rising Edge             | 115 |      | ns    |          |
| P              | $t_{HWP} = \frac{3}{4} t_{C} + 85$    | HLD Pulse Width                                     | 110 |      | ns    |          |
| - IB           | $t_{HAE} = \frac{3}{4} t_{C} + 100$   | HLDA Falling Edge after HLD Falling Edge            |     | 175  | ns    | (Note 3) |
| Ë              | $t_{HAD} = \frac{5}{4} t_{C} + 85$    | HLDA Rising Edge after HLD Rising Edge              |     | 210  | ns    |          |
| External Hold  | t <sub>BF</sub>                       | Bus Float after HLDA Falling Edge                   |     | 66   | ns    |          |
| ш              | $t_{BE} = t_{C} - 66$                 | Bus Enable after HLDA Rising Edge                   | 34  | 1.0  | ns    |          |

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. Spec'd t<sub>C1R</sub>, t<sub>C1F</sub>, and CKI duty cycle limits are not tested but are guaranteed functional by design.

Note 2: Do not design with this parameter unless CKI is driven with an active signal meeting T<sub>C1R</sub> and T<sub>C1F</sub> specs. 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<sub>HAE</sub> is spec'd for case with HLD falling edge occurring at the latest time it can be accepted during the present CPU or DMA cycle being executed. If HLD falling edge occurs later, t<sub>HAE</sub> as long as (3 t<sub>C</sub> + 4 WS + 72 t<sub>C</sub> + 100) may occur depending on the following CPU instruction or DMA cycle, its wait states and ready input.

Note 4: WS ( $I_{WAIT}$ ) × (number of preprogrammed wait states). Minimum and maximum values are calculated at maximum operating frequency,  $f_c = 20$  MHz, with one wait state preprogrammed. These values are guaranteed with AC loading of 100 pF on Port A, 50 pF on CK2, 80 pF on other outputs, and DC loading of the pin's DC spec non CMOS  $I_{OL}$  or  $I_{OH}$ .

## AC Electrical Characteristics (Continued)

CPU and DMA Timing (see Notes 1 and 4 and Figures 2, 4, 6, 7, 8, and 9),  $V_{CC} = 5V \pm 10\%$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$  for HPC46400E,  $-40^{\circ}C$  to  $+85^{\circ}C$  for HPC36400E,  $-55^{\circ}C$  to  $+125^{\circ}C$  for HPC16400E

|                | Symbol            | Formula                                                                                   | Cycle      | Parameter                                                                                           | Min        | Max        | Units    | Note                 |
|----------------|-------------------|-------------------------------------------------------------------------------------------|------------|-----------------------------------------------------------------------------------------------------|------------|------------|----------|----------------------|
|                | t <sub>1ALR</sub> |                                                                                           | CPU<br>DMA | Delay of ALE Rising Edge after CKI Rising Edge<br>Delay of ALE Rising Edge after CKI Falling Edge   | 0          | 35<br>35   | ns<br>ns | (Note 2)<br>(Note 2) |
| Address Cycles | t <sub>1ALF</sub> |                                                                                           | CPU<br>DMA | Delay of ALE Falling Edge after CKI Rising Edge<br>Delay of ALE Falling Edge after CKI Falling Edge | 0<br>0     | 35<br>35   | ns<br>ns | (Note 2)<br>(Note 2) |
| ŝ              | t <sub>2ALR</sub> | 1/4 t <sub>C</sub> + 20                                                                   | CPU        | ALE Rising Edge after CK2 Rising Edge                                                               |            | 45         | ns       |                      |
| res.           | t <sub>2ALF</sub> | 1/4 t <sub>C</sub> + 20                                                                   | CPU        | ALE Falling Edge after CK2 Falling Edge                                                             |            | 45         | ns       |                      |
| <b>V</b> dd    | tLL               | 1⁄₂ t <sub>C</sub> − 9                                                                    |            | ALE Pulse Width                                                                                     | 41         |            | ns       |                      |
|                | t <sub>ST</sub>   | 1/4 t <sub>C</sub> - 16                                                                   |            | Setup of Address Valid before ALE Falling Edge                                                      | 9          |            | ns       |                      |
|                | t <sub>VP</sub>   | $\frac{1}{4}$ t <sub>C</sub> - 10<br>$\frac{1}{2}$ t <sub>C</sub> - 10                    | CPU<br>DMA | Hold of Address Valid after ALE Falling Edge                                                        | 15<br>40   |            | ns<br>ns |                      |
|                | tARR              | ½ t <sub>C</sub> − 20                                                                     |            | ALE Falling Edge to RD Falling Edge                                                                 | 30         |            | ns       |                      |
|                | tACC              | $t_{C} + WS - 55$<br>5/4 $t_{C} + WS - 75$                                                | CPU<br>DMA | Data Input Valid after Address Output Valid                                                         |            | 145<br>150 | ns<br>ns |                      |
| /cles          | t <sub>RD</sub>   | ¼ t <sub>C</sub> + WS − 35<br>½ t <sub>C</sub> + WS                                       | CPU<br>DMA | Data Input Valid after RD Falling Edge                                                              |            | 90<br>115  | ns<br>ns |                      |
| Read Cycles    | t <sub>RW</sub>   | $\frac{1_4 t_{\rm C} + WS - 10}{\frac{1_2 t_{\rm C} + WS - 15}{1_2 t_{\rm C} + WS - 15}}$ | CPU<br>DMA | RD Pulse Width                                                                                      | 115<br>135 |            | ns<br>ns |                      |
| Č.             | <sup>t</sup> DR   | t <sub>C</sub> − 15<br>¾ t <sub>C</sub> − 15                                              | CPU<br>DMA | Hold of Data Input Valid after RD Rising Edge                                                       | 0          | 85<br>60   | ns<br>ns | (Note 5<br>(Note 5   |
|                | <sup>t</sup> RDA  | $t_{\rm C} - 5$<br>$\frac{3}{4} t_{\rm C} - 5$                                            | CPU<br>DMA | Bus Enable after RD Rising Edge                                                                     | 95<br>70   |            | ns<br>ns | (Note 5<br>(Note 5   |
| 60             | tARW              | 1⁄₂ t <sub>C</sub> − 20                                                                   |            | ALE Falling Edge to WR Falling Edge                                                                 | 30         |            | ns       |                      |
| Write Cycles   | tww               | ¾ t <sub>C</sub> +WS − 15<br>½ t <sub>C</sub> +WS − 15                                    | CPU<br>DMA | WR Pulse Width                                                                                      | 160<br>135 |            | ns<br>ns |                      |
| Write          | ty                | $\frac{1/2}{1/2} t_{\rm C} + WS - 40$<br>$\frac{1}{2} t_{\rm C} + WS - 50$                | CPU<br>DMA | Data Output Valid before $\overline{WR}$ Rising Edge                                                | 110<br>100 |            | ns<br>ns |                      |
|                | t <sub>HW</sub>   | 1/4 t <sub>C</sub> - 10                                                                   |            | Hold of Data Output Valid after WR Rising Edge                                                      | 15         |            | ns       |                      |
|                | tRDYS             |                                                                                           |            | RDY Falling Edge before CK2 Rising Edge                                                             | 45         |            | ns       |                      |
| Input          | TRDYH             |                                                                                           |            | RDY Rising Edge after CK2 Rising Edge                                                               | 0          |            | ns       |                      |
| 5              | tRDYV             | $WS - \frac{1}{4}t_{C} - 47$<br>$t_{C} - 47$                                              | CPU<br>DMA | RDY Falling Edge after RD or WR Falling Edge                                                        |            | 28<br>53   | ns<br>ns | (Note 6              |

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. Spec'd t<sub>C1R</sub>, t<sub>C1F</sub>, and CKI duty cycle limits are not tested but are guaranteed functional by design.

Note 2: Do not design with this parameter unless CKI is driven with an active signal meeting T<sub>C1R</sub> and T<sub>C1F</sub> specs. 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<sub>HAE</sub> is spec'd for case with HLD falling edge occurring at the latest time it can be accepted during the present CPU or DMA cycle being executed. If HLD falling edge occurs later, t<sub>HAE</sub> as long as (3 t<sub>C</sub> + 4 WS + 72 t<sub>C</sub> + 100) may occur depending on the following CPU instruction or DMA cycle, its wait states and ready input.

Note 4: WS ( $I_{WA17}$ ) × (number of preprogrammed wait states). Minimum and maximum values are calculated at maximum operating frequency,  $f_C = 20$  MHz, with one wait state preprogrammed. These values are guaranteed with AC loading of 100 pF on Port A, 50 pF on CK2, 80 pF on other outputs, and DC loading of the pin's DC spec non CMOS  $I_{OL}$  or  $I_{OH}$ .

Note 5: Formula has  $\frac{7}{4}$  t<sub>C</sub> for CPU read followed by DMA  $\frac{4}{4}$  t<sub>C</sub> for DMA read followed by CPU.

Note 6: In HPC in-circuit emulators the  $t_{RDYV}$  formulas are WS -  $\frac{1}{4}$  t<sub>C</sub> - 57 and t<sub>C</sub> - 57 yielding minimums of 18 ns and 43 ns for CPU and DMA cycles, respectively.







## Timing Waveforms (Continued)





TL/DD/10422-14

| Symbol | Parameter                                           | Min | Max | Comments          | Units |
|--------|-----------------------------------------------------|-----|-----|-------------------|-------|
| TPFS   | Number of HCK1 Periods between FS Falling Edges     | 34  |     |                   |       |
| TAFS   | Number of HCK1 Rising Edges during FS Low           | 1   | 32  |                   |       |
| TEFS   | Hold of FS High after HCK1 Rising Edge              | 10  |     | Early FS          | ns    |
| TLFS   | Setup of FS Falling Edge before HCK1 Rising Edge    | 20  |     | Late FS, (Note 8) | ns    |
| TVFC   | Delay of TX Output Valid after HCK1 Rising Edge     |     | 50  | (Note 7)          | ns    |
| THFS   | Hold of FS Low after HCK1 Rising Edge               | 20  |     |                   | ns    |
| TSFS   | Setup of FS Rising Edge before HCK1 Rising Edge     | 20  |     |                   | ns    |
| TTTC   | Delay of TX output TRI-STATE after HCK1 Rising Edge |     | 40  |                   | ns    |

Note 7: This spec is for 1st bit only. Remaining bits are spec'd by transmitter TVTC spec.

Note 8: Receiver specs TVRS and TVRH are required along with TLFS for receiver operation using serial decoder.



TL/DD/10422-15

| Symbol | Parameter                                               | Min | Max | Comments          | Units |
|--------|---------------------------------------------------------|-----|-----|-------------------|-------|
| TPFS   | Number of HCK1 Periods between FS Rising Edges          | 64  |     | SD Mode 3         |       |
| TPFS   | Number of HCK1 Periods between FS Rising Edges          | 32  |     | SD Mode 4         |       |
| TAFS   | Number of HCK1 Falling Edges during FS High             | 2   | 62  | SD Mode 3         |       |
| TAFS   | Number of HCK1 Falling Edges during FS High             | 2   | 30  | SD Mode 4         |       |
| TEFS   | Hold of FS Low after HCK1 Falling Edge                  | 10  |     | Early FS          | ns    |
| TLFS   | Setup of FS Rising Edge before HCK1 Falling Edge        | 45  |     | Late FS, (Note 8) | ns    |
| TVFS   | Delay of TX Output Valid after HCK1 and FS Rising Edges |     | 50  | (Note 9)          | ns    |
| THFS   | Hold of FS High after HCK1 Falling Edge                 | 20  |     |                   | ns    |
| TSFS   | Setup of FS Falling Edge before HCK1 Rising Edge        | 20  |     |                   | ns    |
| TTTC   | Delay of TX output TRI-STATE after HCK1 Rising Edge     |     | 40  |                   | ns    |

Note 8: Receiver specs TVRS and TVRH are required along with TLFS for receiver operation using serial decoder. Note 9: This spec is for 1st bit only and is measured from the later of either FS or HCK1 rising edge. Remaining bits are spec'd from HCK1 rising edges by transmitter TVTC spec.



50

20

(Note 7)

ns

ns ns

ns

| TSFS           | Setup of FS Falling Edge before HCK1 Rising Edge                          | 20 |    |
|----------------|---------------------------------------------------------------------------|----|----|
| TTTC           | Delay of TX output TRI-STATE after HCK1 Rising Edge                       |    | 40 |
| Note 7. This s | is (as 1at hit ash. Demoising hits are consided to the periods TO(TO as a |    |    |

Note 7: This spec is for 1st bit only. Remaining bits are spec'd by transmitter TVTC spec.

Hold of FS High after HCK1 Falling Edge

Delay of TX Output Valid after HCK1 Rising Edge

TVFC

THFS

Note 8: Receiver specs TVRS and TVRH are required along with TLFS for receiver operation using serial decoder.

## **Pin Descriptions**

#### I/O PORTS

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 signalied by RD and WR respectively. External memory can be addressed as either bytes or words with the decoding controlled by two lines, Bus High Byte enable (HBE) and Address/Data Line 0 (A0).

Port B is a 16-bit port, with 12 bits of bidirectional I/O. Pins 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.

| no pin | to nave an a |                                                                                            |
|--------|--------------|--------------------------------------------------------------------------------------------|
| B0:    | TDX          | UART Data Output                                                                           |
| B1:    | CFLG1        | Closing Flag Output for HDLC #1<br>Transmitter                                             |
| B2:    | СКХ          | UART Clock (Input or Output)                                                               |
| B3:    | T2IO         | Timer2 I/O Pin                                                                             |
| B4:    | T3IO         | Timer3 I/O Pin                                                                             |
| B5:    | SO           | MICROWIRE/PLUS Output                                                                      |
| B6:    | SK           | MICROWIRE/PLUS Clock (Input or<br>Output)                                                  |
| B7:    | HLDA         | Hold Acknowledge Output                                                                    |
| B8:    | TS0          | Timer Synchronous Output                                                                   |
| B9:    | TS1          | Timer Synchronous Output                                                                   |
| B10:   | ALE          | Address Latch Enable Output for<br>Address/Data Bus                                        |
| B11:   | WR           | Address/Data Bus Write Output                                                              |
| B12:   | HBE          | High Byte Enable Output for Address/<br>Data Bus; also 8-Bit Mode Strap Input<br>on Reset. |
| B13:   | TS2          | Timer Synchronous Output                                                                   |
| B14:   | TS3          | Timer Synchronous Output                                                                   |
| B15:   | RD           | Address/Data Bus Read Output                                                               |
|        |              | ne extended memory addressing mode,<br>an be used as follows—                              |
| B8:    | BS0          | Memory bank switch output 0 (LSB)                                                          |
| B9:    | BS1          | Memory bank switch output 1                                                                |
|        |              |                                                                                            |

| B13: | BS2 | Memory bank switch output 2       |
|------|-----|-----------------------------------|
| B14: | BS3 | Memory bank switch output 3 (MSB) |

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:

| 10: | HCK2     | HLDC #2 Clock Input                              |
|-----|----------|--------------------------------------------------|
| 11: | NMI      | Nonmaskable Interrupt Input                      |
| 12: | INT2     | Maskable Interrupt/Input Capture                 |
| 13: | INT3     | Maskable Interrupt/Input Capture                 |
| 14: | INT4/RDY | Maskable Interrupt/Input Capture/<br>Ready Input |
| 15: | SI       | MICROWIRE/PLUS Data Input                        |
| 16: | RDX      | UART Data Input                                  |
| 17: | HCK1     | HDLC #1 Clock and Serial Decoder<br>Clock Input  |

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

| D0: | REN1/FS/<br>RHCK1 | Receiver #1 Enable/Serial Decoder<br>Frame Sync Input/Receiver #1 Clock<br>Input |
|-----|-------------------|----------------------------------------------------------------------------------|
| D1: | TEN1              | Transmitter #1 Enable Input                                                      |
| D2: | REN2/<br>RHCK2    | Receiver #2 Enable Input/Receiver<br>#2 Clock Input                              |
| D3: | TEN2              | Transmitter #2 Enable Input                                                      |
| D4: | RX1               | Receiver #1 Data Input                                                           |
| D5: | TX1               | Transmitter #1 Data Output                                                       |
| D6: | RX2               | Receiver #2 Data Input                                                           |
| D7: | TX2               | Transmitter #2 Data Output                                                       |

Note: Any of these pins can be read by software. Therefore, unused functions can be used as general purpose inputs, notably external enable lines when the internal serial decoder is used.

Port R is an 8-bit bidirectional I/O port available for general purpose I/O operations. Port R has a direction register to enable each separate pin to be individually defined as an input or output. It has a data register which contains the value to be output. In addition, the Port R pins can be read directly using the Port R pins address.

## Pin Descriptions (Continued)

#### POWER SUPPLIES

| Vcc   | I, V <sub>CC2</sub> Positive Power Supply (two pins)                                                                                                          |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GND   | Ground for On-Chip Logic                                                                                                                                      |
| DGN   | ID Ground for Output Buffers                                                                                                                                  |
| Note: | There are two electrically connected $V_{CC}$ pins on the chip, GND and DGND are electrically isolated. Both $V_{CC}$ pins and both ground pins must be used. |
| CLO   | CK PINS                                                                                                                                                       |
| СКІ   | The System Clock Input                                                                                                                                        |

CKO The System Clock Output (Inversion of CKI) Pins CKI and CKO are usually connected across an external crystal.

CK2 Clock Output (CKI divided by 2)

## **Connection Diagrams**



**Top View** 

See NS Package Number U68A

## Wait States

The HPC16400E provides software selectable Wait States for access to slower memories and for shared bus applications. The number of Wait States for the CPU are selected by two bits in the PSW register. The number of Wait States for DMA are selected by a bit in the Message System Configuration register. Additionally, the RDY input may be used to extend the RD or WR cycle, allowing the HPC to be used in shared memory applications and allowing the user to interface with slow memories and peripherals.

## **Power Save Modes**

Two power saving modes are available on the HPC16400E: HALT and IDLE. In the HALT mode, all processor activities are stopped. In the IDLE mode, the on-board oscillator and timer T0 are active but all other processor activities are stopped. In either mode, on-board RAM, registers and I/O are unaffected (except the HDLC and UART which are reset).

#### OTHER PINS

| UTHEN PINS | )                                                                                                                          |
|------------|----------------------------------------------------------------------------------------------------------------------------|
| WO         | This is an active low open drain output which<br>signals an illegal situation has been detected<br>by the Watch Dog logic. |
| ST1        | Bus Cycle Status Output indicates first op-<br>code fetch.                                                                 |
| ST2        | Bus Cycle Status Output indicates machine states (skip and interrupt).                                                     |
| RESET      | Active low input that forces the chip to restart<br>and sets the ports in a TRI-STATE mode.                                |
| RDY/HLD    | Has two uses, selected by a software bit.                                                                                  |

This pin is either a READY input to extend the bus cycle for slower memories or a HOLD-REQUEST input to put the bus in a high impedance state for external DMA purposes. In the second case the I4 pin can become the READY input.





See NS Package Number EL68A or V68A

#### HALT MODE

The HPC16400E is placed in the HALT mode under software control by setting bits in the PSW. All processor activities, including the clock and timers, are stopped. In the HALT mode, power requirements for the HPC16400E 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 reinitializes 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.

#### IDLE MODE

The HPC16400E is placed in the IDLE mode through the PSW. In this mode, all processor activity, except the onboard oscillator and Timer T0, is stopped. The HPC16400E resumes normal operation upon timer T0 overflow. As with the HALT mode, the processor is also returned to full operation by the RESET or NMI inputs, but without waiting for oscillator stabilization.

## **HPC16400E Interrupts**

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

| Vector/<br>Address | Interrupt Source      | Arbitration<br>Ranking |
|--------------------|-----------------------|------------------------|
| FFFF               | Reset                 | 0                      |
| FFFD FFFC          | Nonmaskable Ext (NMI) | 1                      |
| FFFB               | External on 12        | 2                      |
| FFF9 FFF8          | External on 13        | 3                      |
| FFF7 FFF6          | External on 14        | 4                      |
| FFF5 FFF4          | Internal on Timers    | 5                      |
| FFF3 FFF2          | Internal on UART      | 6                      |
| FFF1 FFF0          | End of Message (EOM)  | 7                      |

TABLE I. Interrupts

The 16400E contains arbitration logic to determine which interrupt will be serviced first if two or more interrupts occur simultaneously. Interrupts are serviced after the current instruction is completed except for the RESET which is serviced immediately.

The NMI interrupt will immediately stop DMA activity. Byte transfers in progress will finish thereby allowing an orderly transition to the interrupt service vector (see DMA description). The HDLC channels continue to operate, and the user must service data errors that might have occurred during the NMI service routine.

## **Interrupt Processing**

Interrupts are serviced after the current instruction is completed except for the RESET, which is serviced immediately.

RESET holds on-chip logic in a reset state while low, and triggers the RESET interrupt on its rising edge. All other 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 sensitive.

## Interrupt Control Registers

The HPC16400E 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 11 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. The occurrence 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 external interrupts are normally cleared by the HPC16400E upon entering the interrupt servicing routine

For the interrupts from the on-board peripherals, the user has the responsibility of acknowledging the interrupt through software.

#### INTERRUPT CONDITION REGISTER (IRCD)

Three bits of the register select the input polarity of the external interrupt on 12, 13, and 14.

## Servicing the Interrupts

The Interrupt, once acknowledged, pushes the program counter (PC) onto the stack thus incrementing the stack pointer (SP) twice. The Global Interrupt Enable (GIE) bit is 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, set the GIE bit and return to the main program. The GIE bit can be set in the interrupt service routine to nest interrupts if desired. *Figure 10* shows the Interrupt Enable Logic.

#### Reset

The RESET input initializes the processor and sets all pins at TRI-STATE except CK0, CK2, and WO. HBE and ST2 have pull-downs designed to withstand override. RESET is an active-low Schmitt trigger input. The processor vectors to FFFF:FFFE and resumes operation at the address contained at that memory location.

The RESET pin must be asserted low for at least 16 cycles of the CK2 clock. In applications using the Watchdog feature, RESET should be asserted for at least 64 cycles of the CK2 clock.

On application of power, RESET must be held low for at least five times the power supply rise time to ensure that the on-chip oscillator circuit has time to stabilize.

## **Timer Overview**

The HPC16400E contains a powerful set of flexible timers enabling the HPC16400E to perform extensive timer functions; not usually associated with microcontrollers.

The HPC16400E contains four 16-bit timers. Three of the timers have an associated 16-bit register. Timer T0 is a freerunning timer, counting up at a fixed CKI/16 (Clock Input/ 16) rate. It is used for Watch Dog 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. A control bit in the register TOCON configures timer T1 and its associated register R1 as capture registers I3CR and I2CR. The capture registers I2CR, I3CR, and I4CR respectively, record the value of timer T0 when specific events occur on the interrupt pins 12, 13, and 14. 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 (see Figure 11).

The timers T2 and T3 have selectable clock rates. 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 control register DIVBY programs the clock input to timers T2 and T3 (see *Figure 12*).



### Timer Overview (Continued)

The timers T1 through T3 in conjunction with their registers form Timer-Register pairs. The registers hold the pulse duration values. 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

The flexible timer structure of the HPC16400E simplifies pulse generation and measurement. 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 underflows (see *Figure 12*). Maximum output frequency for any timer output can be obtained by setting timer/register pair to zero. This then will produce an output frequency equal to 1/2 the frequency of the source used for clocking the timer.

## **Timer Registers**

There are four control registers that program the timers. The divide by (DIVBY) register programs the clock input to timers T2 and T3. The timer mode register (TMMODE) contains control bits to start and stop timers T1 through T3. It also contains bits to latch, acknowledge and enable interrupts from timers T0 through T3.

## **Timer Applications**

The use of Pulse Width Timers for the generation of various waveforms is easily accomplished by the HPC16400E.

Frequencies can be generated by using the timer/register pairs. A square wave is generated when the register value is a constant. The duty cycle can be controlled simply by changing the register value.



TL/DD/10422-22

FIGURE 13. Square Wave Frequency Generation

Synchronous outputs based on Timer T2 can be generated on the 4 outputs TS0-TS3. Each output can be individually programmed to toggle on T2 underflow. Register R2 contains the time delay between events. *Figure 14* is an example of synchronous pulse train generation.



## Watch Dog Logic

The Watch Dog Logic monitors the operations taking place and signals upon the occurrence of any illegal activity. The illegal conditions that trigger the Watch Dog logic are potentially infinite loops. Should the Watch Dog register not be written to before Timer T0 overflows twice, or more often than once every 4096 counts, an infinite loop condition is assumed to have occurred. The illegal condition forces the Watch Out (WO) pin low. The 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 (see *Figure 15*). MICROWIRE/PLUS 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., ISDN Transceivers, A/D converters, display drivers, EEPROMs).



## **MICROWIRE/PLUS Operation**

The HPC16400E can enter the MICROWIRE/PLUS mode as the master or a slave. A control bit in the IRCD register determines whether the HPC16400E is the master or slave. The shift clock is generated when the HPC16400E is configured as a master. An externally generated shift clock on the SK pin is used when the HPC16400E is configured as a slave. When the HPC16400E 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 14 selectable steps from 122 Hz to 1 MHz with CKI at 16 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 shifted out on the falling edge of the SK clock. Serial data on the SI pin is latched in on the rising edge of the SK clock.

## HPC16400E UART

The HPC16400E contains a software programmable UART. The UART (see *Figure 16*) 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 (ENU). 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 Wake-up 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_{h}$ , 1, 1 $7_{h}$ , 2), 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 three on-chip sources. Presently, two of the on-chip sources, the Divide-By (DIVBY) Register and the Precision UART Timer (PUT), are primarily for reasons of upward compatibility from earlier HPC family members. The most flexible and accurate on-chip clocking is provided by the third source: the Baud Rate Generator (BRG).

The Baud Rate Generator is controlled by the register pair PSR and BAUD, shown below.

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 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/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 HPC16400E UART features an Attention Mode of operation. This mode of operation enables the HPC16400E 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 HPC16400E 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.

## Programmable Serial Decoder Interface

The programmable serial decoder interface allows the two HDLC channels to be used with devices employing several popular Time Division Multiplexing (TDM) serial protocols for point-to-point and multipoint data exchanges. These protocols combine the 'B' and 'D' channels onto common pins—received data, transmit data, clock and Sync, which normally occurs at an 8 KHz rate and provides framing for the particular protocol.

The decoder uses the serial link clock and Sync signals to generate internal enables for the 'D' and 'B' channels, thereby allowing the HDLC channels to access the appropriate channel data from the multiplexed link.

Additionally, 64 kbit/s to 56 kbits/s rate adaptation can be done using the Serial Decoder generated enable signals B1 or B2. The rate adaption to 56 kbits/s is accomplished by using only the first 7 bits of each B channel time slot for each TDM frame. The transmitter will insert a "1" in the eighth bit of each frame. The receiver will only receive the first seven data bits and skip the eighth bit. See *Figure 17* 65 kbit/56 kbit Rate Adaption Timing Diagram.

## **HDLC Channel Description**

#### HDLC/DMA Structure

| HDLC 1           |                   | HDLC 2           |                   |
|------------------|-------------------|------------------|-------------------|
| HDLC1<br>Receive | HDLC1<br>Transmit | HDLC2<br>Receive | HDLC2<br>Transmit |
| DMAR1            | DMAT1             | DMAR2            | DMAT2             |

#### **GENERAL INFORMATION**

Both HDLC channels on the HPC16400E are identical and operate up to 4.65 Mbps. When used in an ISDN Basic Rate access application, HDLC channel #1 has been designated for use with the 16 kbps D-channel or either B channel and HDLC #2 can be used with either of the 64 kbps B-channels. If the 'D' and 'B' channels are present on a common serial link, the programmable serial decoder interface generates the necessary enable signals needed to access the D and B channel data.

There are two sources for the receive and transmit channel enable signals. They can be internally generated from the serial decoder interface or they can be externally enabled.

LAPD, the Link Access Protocol for the D channel is derived from the X.25 packet switching LAPB protocol. LAPD specifies the procedure for a terminal to use the D channel for the transfer of call control or user-data information. The procedure is used in both point-to-point and point-to-multipoint configurations. On the 16400E, the HDLC controller contains user programmable features that allow for the efficient processing of LAPD Information.

## **HDLC Channel Pin Description**

Each HDLC channel has the following pins associated with it.

- HCK HDLC Channel Clock Input Signal.
- RX Receive Serial Data Input. Data latched on the negative HCK edge.
- REN/RHCK HDLC Channel Receiver Enable Input/Receiver Clock Input.
- TEN HDLC Channel Transmitter Enable Input.
- TX Transmit Serial Data Output. Data clocked out on the positive HCK edge. Data (not including CRC) is sent LSB first. TRI-STATE when transmitter not enabled.
- CFLG1 Closing Flag output for Channel 1.

## **HDLC Functional Description**

#### TRANSMITTER DESCRIPTION

Data is transferred from external memory through the DMA controller into the transmit buffer register, from which it is loaded into a 8-bit serial shift register. The CRC is computed and appended to the frame prior to the closing flag being transmitted. Data is output at the TX output pin. If no further transmit commands are given the transmitter sends out continuous flags, aborts, or the idle pattern as selected by the control register.

An interrupt is generated when the DMA has transferred the last byte from RAM to the HDLC channel for a particular message or on a transmit error condition. An associated transmit status register will contain the status information indicating the specific interrupt source.

To support transmitting data packets at an "R" interface for V.120 in synchronous UI mode, to support the use of the HPC in test equipment, or to support proprietary CRC algorithms the transmitter has the option of preventing the transmitting of the hardware generated CRC bytes.

#### **TRANSMITTER FEATURES**

Interframe fill: the transmitter can send either continuous '1's or repeated flags or aborts between the closing flag of one packet and the opening flag of the next. When the CPU commands the transmitter to open a new frame, the interframe fill is terminated immediately.

Abort: the abort sequence, a zero followed by seven ones, will be immediately sent on command from the CPU or on an underrun condition in the DMA.

Bit/Byte boundaries: The message length between packet headers may have any number of bits and is not confined to an integral number of bytes. Three bits in the control register are used to indicate the number of valid bits in the last byte. These bits are loaded by the users software.

#### **RECEIVER DESCRIPTION**

Data is input to the receiver on the RX pin. The receive clock can be externally input at either the HCK pin or the REN/RHCK pin.

Incoming data is routed through one of several paths depending on whether it is the flag, data, or CRC.

Once the receiver is enabled it waits for the opening flag of the incoming frame, then starts the zero bit deletion, ad-



FIGURE 17. 64 kbit/56 kbit Rate Adaption Timing Diagram

dressing handling and CRC checking. All data between the flags is shifted through two 8-bit serial shift registers before being loaded into the buffer register. The user programmable address register values are compared to the incoming data while it resides in the shift registers. If an address match occurs or if operating in the transparent address recognition mode, the DMA channel is signaled that attention is required and the data is transferred by it to external memory. Appropriate interrupts are generated to the CPU on the reception of a complete frame, or on the occurance of a frame error.

The receive interrupt, in conjunction with status data in the control registers allows interrupts to be generated on the following conditions—frame length error, CRC error, receive error, abort and receive complete.

To support V.120 UI data packets at the "R" interface, proprietary CRC algorithms, and test equipment the two bytes preceding the closing flag (usually the CRC bytes) will be loaded into registers. The two bytes can then be read by the CPU and placed into memory. The DMA address pointers used for that particular message will already contain the address that the first byte should be placed into.

#### **RECEIVER FEATURES**

Flag sharing: the closing flag of one packet may be shared as the opening flag of the next. Receiver will also be able to share a zero between flags—011111101111110 is a valid two flag sequence for receive (not transmit).

Interframe fill: the receiver automatically accepts either repeated flags, repeated aborts, or all '1's as the interframe fill.

Idle: Reception of successive flags as the interframe fill sequence to be signaled to the user by setting the Flag bit in the Receiver Status register.

Short Frame Rejection: Reception of greater than 2 bytes but less than 4 bytes between flags will generate a frame error, terminating reception of the current frame and setting the Frame Error (FER) status bit in the Receive Control and Status register. Reception of less than 2 bytes will be ignored.

Abort: the 7 '1's abort sequence will be immediately recognized and will cause the receiver to reinitialize and return to searching the incoming data for an opening flag. Reception of the abort will cause the abort status bit in the Interrupt Error Status register to be set and will signal an End of Message (EOMR). Bit/Byte boundaries: The message length between packet headers may have any number of bits and it is not confined to an integral number of bytes. Three bits in the status register are used to indicate the number of valid bits in the last byte.

Address Recognition: Two user programmable bytes are available to allow frame address recognition on the two bytes immediately following the opening flag. When the received address matches the programmed value(s), the frame is passed through to the DMA channel. If no match occurs, the received frame address information is disregarded and the receiver returns to searching for the next opening flag and the address recognition process starts anew.

Support is provided to allow recognition of the Broadcast address. Additionally, a transparent mode of operation is available where no address decoding is done.

#### HDLC INTERRUPT CONDITIONS

The end of message interrupt (EOM) indicates that a complete frame has been received or transmitted by the HDLC controller. Thus, there are four separate sources for this interrupt, two each from each HDLC channel. The Message Control Register contains the pending bits for each source.

#### HDLC ERROR DETECTION

The HDLC/DMA detects several error conditions and reports them in the two Error Status Registers. These conditions are a DMA transmitter underrun, a DMA receiver overrun, a CRC error, a frame too long, a frame too short, and an aborted message.

#### HDLC CHANNEL CLOCK

Each HDLC channel uses the falling edge of the clock to sample the receive data. Outgoing transmit data is shifted out on the rising edge of the external clock. The maximum data rate when using the externally provided clocks is 4.65 Mb/s.

The receiver/transmitter pair can share a single clock input to save I/O pins, or the inputs can be separated to allow different receive and transmit clocks. This feature allows the receiver and transmitter to operate at different frequencies or enables them to each be synchronized to different parts of the user's system.

#### CYCLIC REDUNDACY CHECK

There are two standard CRC codes used in generating the 16-bit Frame Check Sequence (FCS) that is appended to the end of the data frame. Both codes are supported and

## HDLC Functional Description (Continued)

the user selects the error checking code to be used through software control (HDLC control reg). The two error checking polynomials available are:

(1) CRC-16 ( $x^{16} + x^{15} + x^2 + 1$ )

(2) CCITT CRC ( $x^{16} + x^{12} + x^5 + 1$ )

#### SYNCHRONOUS BYPASS MODE

When the BYPAS bit is set in the HDLC control register, all HDLC framing/formatting functions for the specified HDLC channel are disabled.

This allows byte-oriented data to be transmitted and received synchronously thus "bypassing" the HDLC functions.

#### LOOP BACK OPERATIONAL MODE

The user has the ability, by setting the appropriate bit in the register to internally route the transmitter output to the receiver input, and to internally route the RX pin to the TX pin.

## **DMA Controller**

#### **GENERAL INFORMATION**

The HPC16400E uses Direct Memory Access (DMA) logic to facilitate data transfer between the 2 full Duplex HDLC channels and external packet RAM. There are four DMA channels to support the four individual HDLC channels. Control of the DMA channels is accomplished through registers which are configured by the CPU. These control registers define specific operation of each channel and changes are immediately reflected in DMA operation. In addition to individual control registers, global control bits (MSS and MSSC in Message Control Register) are available so that the HDLC channels may be globally controlled.

The DMA issues a bus request to the CPU when one or more of the individual HDLC channels request service. Upon receiving a bus acknowledge from the CPU, the DMA completes all requests pending and any requests that may have occurred during DMA operation before returning control to the CPU. If no further DMA transfers are pending, the DMA relinquishes the bus and the CPU can again initiate a bus cycle.

Four memory expansion bits have been added for each of the four channels to support data transfers into the expanded memory bank areas.

The DMA has priority logic for servicing DMA requests. The priorities are:

| 1st priority | Receiver channel 1 |
|--------------|--------------------|
| 2nd priority | Transmit channel 1 |
| Srd priority | Receive channel 2  |
| 4th priority | Transmit channel 2 |

#### **RECEIVER DMA OPERATION**

The receiver DMA consists of a shift register and two buffers. A receiver DMA operation is initiated by the buffer registers. Once a byte has been placed in a buffer register from the HDLC, it generates a request and upon obtaining control of the bus, the DMA places the byte in external memory.

#### **RECEIVER REGISTERS**

All the following registers are Read/Write

A. Frame Length Register

This user programmable 16-bit register contains the maximum number of bytes to be placed in a data "block". If this number is exceeded, a Frame Too Long error is generated. DMA is stopped to prevent memory from being overwritten, however the receiver continues until the closing flag is received in order to check the CRC.

B. CNTRL ADDR 1 DATA ADDR 1 CNTRL ADDR 2 DATA ADDR 2 For split frame operation, the CNTRL ADDR register contains the external memory address where the Frame Header (Control & Address fields) are to be stored and the DATA ADDR register contains an equivalent address for the Information field.

For non-split frame operation, the CNTRL and DATA ADDR registers each contain the external memory address for entire frames.

#### TRANSMITTER DMA OPERATION

The transmitter DMA consists of a shift register and two buffers. A transmitter DMA cycle is initiated by the TX data buffers. The TX data buffers generate a request when either one is empty and the DMA responds by placing a byte in the buffer. The HDLC transmitter can then accept the byte to send when needed, upon which the DMA will issue another request, resulting in a subsequent DMA cycle.

#### TRANSMITTER REGISTERS

The following registers are Read/Write:

## **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. The HPC16400E 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 on the RDY/HLD pin by the state of a control bit. The HLDA output must be selected as the HLDA output on pin B7 by software.

The host uses DMA to interface with the HPC16400E. The host initiates a data transfer by activating the HLD input of the HPC16400E. In response, the HPC16400E places its system bus in a TRI-STATE Mode, freeing it for use by the host. The host waits for the acknowledge signal (HLDA) from the HPC16400E indicating that the sytem 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 HPC16400E resumes normal operations. See *Figure 18* (HPC16400E shared Memory Using HOLD).

An alternate approach is to use the Ready function available on either the RDY/HLD pin or the INT4/RDY pin. See *Figure 19* (HPC16400E Shared Memory Using READY). This technique is often required when the HPC is sharing memory over a system backplane bus.



HPC16400E/HPC36400E/HPC46400E

## Memory

The HPC16400E has been designed to offer flexibility in memory usage. A total address space of 64 kbytes can be addressed with 256 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 the B, X and SP registers. Memory can be addressed as words or bytes. Words are always accessed on even-byte boundaries. The HPC16400E uses memory-mapped organization to support registers, I/O and on-chip peripheral functions.

The HPC16400E memory address space extends to 64 kbytes and registers and I/O are mapped as shown in Table II.

## **Extended Memory Addressing**

If more than 64k of addressing is desired in a HPC16400E system, on board bank select circuitry is available that al-

lows four I/O lines of Port B (B8, B9, B13, B14) to be used in extending the address range. This gives the user a main routine area of 32k and 16 banks of 32k each for subroutine and data, thus getting a total of 536.5k of memory.

Note: If all four lines are not needed for memory expansion, the unused lines can be used as general purpose inputs.

The Extended Memory Addressing mode is entered by setting the EMA control bit in the Message Control Register. If this bit is not set, the port B lines (B8, B9, B13, B14) are available as general purpose I/O or synchronous outputs as selected by the BFUN register.

The main memory area contains the interrupt vectors & service routines, stack memory, and common memory for the bank subroutines to use. The 16 banks of memory can contain program or data memory (note: since the on chip resources are mapped into addresses 0000-01FF, the first 512 bytes of each bank are not usable, actual available memory is 536.5k).

|                                                                                                                                |                                                                                                                                                                        | TABLE             |
|--------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| FFFF-FFF0<br>FFEF-FFD0                                                                                                         | Interrupt Vectors<br>JSRP Vectors                                                                                                                                      |                   |
| FFCF-FFCE<br>0201-0200                                                                                                         | External Expansion                                                                                                                                                     | USER MEMORY       |
| 01FF-01FE<br>01C1-01C0                                                                                                         | On Chip RAM                                                                                                                                                            | USER RAM          |
| 01BC<br>01BA<br>01B8<br>01B6<br>01B4<br>01B2<br>01B0                                                                           | CRC Byte 2<br>CRC Byte 1<br>Error Status<br>Receiver Status<br>Cntrl<br>Recr Addr Comp Reg 2<br>Recr Addr Comp Reg 1                                                   | HDLC # 2          |
| 01AC<br>01AA<br>01A8<br>01A6<br>01A4<br>01A2<br>01A0                                                                           | CRC Byte 2<br>CRC Byte 1<br>Error Status<br>Receiver Status<br>Cntrl<br>Recr Addr Comp Reg 2<br>Recr Addr Comp Reg 1                                                   | HDLC # 1          |
| 0195-0194                                                                                                                      | Watch Dog Register                                                                                                                                                     | Watch Dog Logic   |
| 0193-0192<br>0191-0190<br>018F-018E<br>018D-018C<br>018B-018A<br>0189-0188<br>0187-0186<br>0185-0184<br>0183-0182<br>0181-0180 | T0CON Register<br>TMMODE Register<br>DIVBY Register<br>T3 Timer<br>R3 Register<br>T2 Timer<br>R2 Register/R1<br>I3CR Register/ R1<br>I3CR Register/T1<br>I4CR Register | Timer Block T0-T3 |
| 017F-017E<br>017D-017C                                                                                                         | Baud Counter<br>Baud Register                                                                                                                                          | UART Timer        |
| 0179-0178<br>0177-0176<br>0175-0174<br>0173-0172<br>0171-0170                                                                  | Byte Count 2<br>Field Addr 2<br>Byte Count 1<br>Field Addr 1<br>Xmit Cntrl & Status                                                                                    | DMAT # 2 (Xmit)   |
| 016B-016A<br>0169-0168<br>0167-0166<br>0165-0164<br>0163-0162<br>0161-0160                                                     | Frame Length<br>Data Addr 2<br>Cntrl Addr 2<br>Data Addr 1<br>Cntrl Addr 1<br>Recv Cntrl & Status                                                                      | DMAR # 2 (Recv)   |

#### TABLE II. Memory Map

| nory map                                                                                        |                                                                                                                                                                                                  |                                                     |
|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|
| 0159-0158<br>0157-0156<br>0155-0154<br>0153-0152<br>0151-0150                                   | # Bytes 2<br>Field Addr 2<br># Bytes 1<br>Field Addr 1<br>Xmit Cntrl & Status                                                                                                                    | DMAT # 1 (Xmit)                                     |
| 014B-014A<br>0149-0148<br>0147-0146<br>0145-0144<br>0143-0142<br>0141-0140                      | Frame Length<br>Data Addr 2<br>Cntrl Addr 2<br>Data Addr 1<br>Cntrl Addr 1<br>Recv Cntrl & Status                                                                                                | DMAR # 1 (Recv)                                     |
| 012C<br>012A<br>0128<br>0126<br>0124<br>0122<br>0120                                            | Baud<br>PSR - Prescaler<br>ENUR Register<br>TBUF Register<br>RBUF Register<br>ENUI Register<br>ENU Register                                                                                      | UART                                                |
| 010E<br>010C<br>010A<br>0108<br>0106<br>0104<br>0102<br>0100                                    | Port R Pins<br>DIR R Register<br>Port R Data Register<br>Message System Configuration<br>Serial Decoder/Enable<br>Configuration Reg<br>Message Pending<br>Message System Control<br>Port D Input | PORTS R & D                                         |
| 00F5-00F4<br>00F3-00F2<br>00E6<br>00E3-00E2                                                     | BFUN Register<br>DIR B Register<br>Chip Revision Register<br>Port B                                                                                                                              | PORT B                                              |
| 00DD-00DC<br>00D8<br>00D6<br>00D4<br>00D2<br>00D0                                               | Halt Enable Register<br>Port I Input Register<br>SIO Register<br>IRCD Register<br>IRPD Register<br>ENIR Register                                                                                 | PORT CONTROL<br>& INTERRUPT<br>CONTROL<br>REGISTERS |
| 00CF-00CE<br>00CD-00CC<br>00CB-00CA<br>00C9-00C8<br>00C7-00C6<br>00C5-00C4<br>00C3-00C2<br>00C0 | X Register<br>B Register<br>K Register<br>PC Register<br>SP Register<br>(Reserved)<br>PSW Register                                                                                               | HPC CORE<br>REGISTERS                               |
| 00BF-00BE                                                                                       | On Chip<br>RAM                                                                                                                                                                                   | USER RAM                                            |

Note: All unused addresses are reserved by National Semiconductor

## **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 possibly causing internal devices to go into active mode and draw DC current. 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.
- When using 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.



TL/DD/10422-29

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

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 should contain 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<sub>CC</sub> 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 dipped mica or ceramic cap mounted as close to the HPC as is physically possible on the board, using the shortest 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.

**HPC Oscillator Table** 

| f <sub>C</sub> (MHz) | <b>R<sub>CC</sub></b> (Ω) | C1 (pF) | C2 (pF) |
|----------------------|---------------------------|---------|---------|
| 2                    | 50                        | 82      | 100     |
| 4                    | 50                        | 62      | 75      |
| 6                    | 50                        | 50      | 56      |
| 8                    | 50                        | 47      | 50      |
| 10                   | 50                        | 39      | 50      |
| 12                   | 0                         | 39      | 39      |
| 14                   | 0                         | 33      | 39      |
| 16                   | 0                         | 33      | 39      |
| 18                   | 0                         | 33      | 33      |
| 20                   | 0                         | 33      | 33      |

Crystal Specifications:

"AT" cut, parallel resonant crystals tuned to the desired frequency with the following specifications are recommended:

Series Resistance <  $65\Omega$ Loading Capacitance: C<sub>L</sub> = 20 pF

## HPC16400E CPU

The HPC16400E 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 can also output the carry bit to a 1-bit C register.

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

#### Stack Pointer (SP) Register

The 16-bit SP register is the stack 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.

#### Program (PC) Register

The 16-bit PC register addresses program memory.

## **Addressing Modes**

# ADDRESSING MODES—ACCUMULATOR AS DESTINATION

#### **Register Indirect**

This is the "normal" mode of addressing for the HPC16400E (instructions are single-byte). The operand is the memory addressed by the B register (or X register for some instructions).

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

#### Double Register Indirect using the B and X Registers

Used only with Reset, Set and IF 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.

| Mnemonic     | Description                   | Action                                                                                         |                       |
|--------------|-------------------------------|------------------------------------------------------------------------------------------------|-----------------------|
| ARITHMETIC   | NSTRUCTIONS                   |                                                                                                |                       |
| ADD          | Add                           | MA+Memi → MA                                                                                   | carry $\rightarrow$ C |
| ADDS         | Add short imm8                | MA+imm8 → MA                                                                                   | carry $\rightarrow C$ |
| ADC          | Add with carry                | MA+MemI+C → MA                                                                                 | carry -+ C            |
| DADC         | Decimal add with carry        | $MA + Meml + C \rightarrow MA$ (Decimal)                                                       | carry $\rightarrow$ C |
| SUBC         | Subtract with carry           | MA-MemI+C → MA                                                                                 | carry → C             |
| DSUBC        | Decimal subtract w/carry      | MA-MemI+C → MA (Decimal)                                                                       | carry → C             |
| MULT         | Multiply (unsigned)           | $MA^*Mem \to MA \And X, 0 \to K, 0 \to C$                                                      |                       |
| DIV          | Divide (unsigned)             | $MA/Mem \to MA, rem \to X, 0 \to K, 0 \to C$                                                   |                       |
| DIVD         | Divide Double Word (unsigned) | $(x8 \text{ MA})/\text{Mem} \rightarrow \text{MA}, \text{ rem} \rightarrow X, 0 \rightarrow K$ | carry $\rightarrow$ C |
| IFEQ         | lf equal                      | Compare MA & Mem!, Do next if equal                                                            |                       |
| IFGT         | If greater than               | Compare MA & Meml, Do next if MA $\rightarrow$ Meml                                            |                       |
| AND          | Logical and                   | MA and MemI $\rightarrow$ MA                                                                   |                       |
| OR           | Logical or                    | MA or MemI $\rightarrow$ MA                                                                    |                       |
| XOR          | Logical exclusive-or          | MA xor MemI $\rightarrow$ MA                                                                   |                       |
| MEMORY MOD   | IFY INSTRUCTIONS              |                                                                                                |                       |
| INC          | Increment                     | Mem + 1 $\rightarrow$ Mem                                                                      | ·····                 |
| DECSZ        | Decrement, skip if 0          | Mem $-1 \rightarrow$ Mem, Skip next if Mem $= 0$                                               |                       |
| BIT INSTRUCT | IONS                          |                                                                                                |                       |
| SBIT         | Set bit                       | $1 \rightarrow$ Mem.bit (bit is 0 to 7 immediate)                                              |                       |
| RBIT         | Reset bit                     | $0 \rightarrow \text{Mem.bit}$                                                                 |                       |
| IFBIT        | lf bit                        | If Mem.bit is true, do next instr.                                                             |                       |
| MEMORY TRA   | NSFER INSTRUCTIONS            |                                                                                                |                       |
| LD           | Load                          | Meml → MA                                                                                      |                       |
|              | Load, incr/decr X             | $Mem(X) \rightarrow A, X \pm 1 \text{ (or 2)} \rightarrow X$                                   |                       |
| ST           | Store to Memory               | MA Mem                                                                                         |                       |
| х            | Exchange                      | $A \longleftrightarrow Mem; Mem \longleftrightarrow Mem$                                       |                       |
|              | Exchange, incr/decr X         | $A \longleftrightarrow Mem(X), X \pm 1 \text{ (or 2)} \rightarrow X$                           |                       |
| PUSH         | Push Memory to Stack          | $W \rightarrow W(SP), SP + 2 \rightarrow SP$                                                   |                       |
| 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 (or 2) \longrightarrow B,$                              |                       |
|              | Skip on condition             | Skip next if B greater/less than K                                                             |                       |
| REGISTER LO  | AD IMMEDIATE INSTRUCTIONS     |                                                                                                |                       |
| LDA          | Load A immediate              | $\operatorname{imm} \to A$                                                                     |                       |
| LDB          | Load B immediate              | $imm \rightarrow B$                                                                            |                       |
| LDK          | Load K immediate              | $imm \rightarrow K$                                                                            |                       |
| LDX          | Load X immediate              | $imm \rightarrow X$                                                                            |                       |
| LDBK         | Load B and K immediate        | $imm \rightarrow B, imm \rightarrow K$                                                         |                       |
| ACCUMULATO   | R AND 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 of $A \rightarrow A$                                                            |                       |
| SWAP A       | Swap nibbles of A             | A15:12 ← A11:8 ← A7:4 ← A3:0                                                                   |                       |
| RRCA         | Rotate A right thru C         | $C \rightarrow A15 \rightarrow \ldots \rightarrow A0 \rightarrow C$                            |                       |
| RLC A        | Rotate A left thru C          | $C \leftarrow A15 \leftarrow \ldots \leftarrow A0 \leftarrow C$                                |                       |
| SHR A        | Shift A right                 | $0 \rightarrow A15 \rightarrow \ldots \rightarrow A0 \rightarrow C$                            |                       |
| SHL A        | Shift A left                  | $C \leftarrow A15 \leftarrow \dots \leftarrow A0 \leftarrow 0$                                 |                       |
| SC           | Set C                         | $1 \rightarrow C$                                                                              |                       |
| RC           | Reset C                       | $0 \rightarrow C$                                                                              |                       |
| IFC          | IFC                           | Do next if $C = 1$                                                                             |                       |
| IFNC         | IF not C                      | Do next if C = 0                                                                               |                       |

HPC16400E/HPC36400E/HPC46400E

~

## HPC Instruction Set Description (Continued)

| Mnemonic       | Description                      | Action                                                                                                                |  |  |  |
|----------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------|--|--|--|
| TRANSFER OF CO | TRANSFER OF CONTROL INSTRUCTIONS |                                                                                                                       |  |  |  |
| JSRP           | Jump subroutine from table       | $\begin{array}{c} PC \longrightarrow W(SP), SP + 2 \longrightarrow SP \\ W(table^{*}) \longrightarrow PC \end{array}$ |  |  |  |
| JSR            | Jump subroutine relative         | PC → W(SP),SP+2 → SP,PC+ # → PC<br>(#is + 1024 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 + 256 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 \leftarrow PC + 1$                                                                                                |  |  |  |
| RET            | Return                           | $SP-2 \rightarrow SP,W(SP) \rightarrow PC$                                                                            |  |  |  |
| RETS           | 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                                                     |  |  |  |

Note: W is 16-bit word of memory

MA is Accumulator A or direct memory (8 or 16-bit) Mem is 8-bit byte or 16-bit word of memory Meml is 8- or 16-bit memory or 8 or 16-bit immediate data imm is 8-bit or 16-bit immediate data

## **Memory Usage**

For information on memory usage and instruction timing please refer to the HPC16400E User's Manual (see page 25 for ordering information).

## **Code Efficiency**

The HPC16400E has been designed to be extremely codeefficient. The HPC16400E 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 HPC16400E, 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 HPC16400E 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. Most other micros need 2-byte instructions for any short jumps.

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 INSTRUCTIONS FOR DATA MOVE-MENT AND PROGRAM LOOPING

The HPC16400E 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.

#### DECIMAL ADD AND SUBTRACT

This instruction is needed to interface with the decimal user world.

It can handle both 16-bit words and 8-bit bytes.

The 16-bit capability saves code since many variables can be stored as one piece of data and the programmer does not have to break his data into two bytes. Many applications store most data in 4-digit variables. The HPC16400E supplies 8-bit byte capability for 2-digit variables and literal variables.

#### MULTIPLY AND DIVIDE INSTRUCTIONS

The HPC16400E 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.

## **Part Selection**

The HPC family includes devices with many different options and configurations to meet various application needs. The number HPC16400E has been generally used throughout this datasheet to represent the whole family of parts. The following chart explains how to order various options available when ordering HPC family members.

Note: All options may not currently be available.



#### EXAMPLES

HPC46400EV20—Commercial temp (0° to +70°C), PLCC HPC36400EV20—Industrial temp (-40°C to +85°C), PLCC

## **Development Support**

#### HPC DEVELOPMENT SYSTEM

The HPC Development System is an in-system emulator (ISE) designed to support National Semiconductor's entire family of HPC microcontrollers. The complete package of hardware and software tools, when combined with an IBM or compatible PC, provides a powerful tool for the development of High Performance microcontroller based products.

The stand alone unit comes complete with vertically mounted circuit boards, a power supply, and an external emulation pod. It is packaged in a UL approved, fan cooled steel case. The unit can be connected to a PC host via an RS-232 link. The software package includes a C compiler, linker, cross assembler, librarian, operating manuals and a source level debugger program.

The ISE provides fully transparent in-circuit emulation at speeds up to 20 MHz 1 waitstate. A 2K word (48-bit wide) real-time trace assists in the non-instrusive monitoring of the system. EPROM programming can be done through the use of the externally mounted EPROM socket. On-line help functions and a diagnostics option allow the user to reduce his programming and debugging time. 8 hardware breakpoints (address/range located), 64 kbytes of user memory, and 8 external trace lines are some of the other features designed into the kit.

| Developmen  | t Tools Selection Table | 6 |
|-------------|-------------------------|---|
| Developinen |                         | • |

| Microcontroller | Order<br>Part Number | Description                                                  | Includes                                                                              |
|-----------------|----------------------|--------------------------------------------------------------|---------------------------------------------------------------------------------------|
|                 | HPC-DEV-ISE2         | HPC In-System Emulator<br>with PLCC Pod Cable                | HPC Microcontroller Development<br>System Manual<br>HPC16400E/HPC46400E User's Manual |
| HPC16400E       | HPC-DEV-IBMC         | C-Compiler for IBM PC<br>and Compatibles                     | C-Compiler Manual<br>Assembler Manual                                                 |
| HFC 10400E      | HPC-DEV-IBMA         | Relocatable Assembler Software<br>for IBM PC and Compatibles | Assembler Manual                                                                      |
|                 | HPC-DEV-WDBC         | C Source/Symbolic Debugger<br>with MS-Windows                | Debugger User's Manual                                                                |

#### Support Documents

| Description             | Order Number  |
|-------------------------|---------------|
| HPC16400E User's Manual | 420420213-001 |

## **Development Support** (Continued)

#### DIAL-A-HELPER

Dial-A-Helper is a service provided by the Microcontroller Applications Group. Dial-A-Helper is an electronic bulletin board information system and additionally, provides the capability of remotely accessing the development system at a customer site.

#### **INFORMATION SYSTEM**

The Dial-A-Helper system provides access to an automated information storage and retrieval system that may be accessed over standard dial-up telephone lines 24 hours a day. The system capabilities include a MESSAGE SECTION (electronic mail) for communications to and from the Microcontroller Applications Group and a FILE SECTION which consists of several file areas where valuable application software and utilities can be found. The minimum requirement for accessing Dial-A-Helper is a Hayes compatible modem. If the user has a PC with a communications package then files from the FILE SECTION can be down loaded to disk for later use.

#### Order P/N: MOLE-DIAL-A-HLP

Information System Package Contains: Dial-A-Helper Users Manual Public Domain Communications Software

#### FACTORY APPLICATIONS SUPPORT

Dial-A-Helper also provides immediate factory applications support. If a user is having difficulty in operating a development system, he can leave messages on our electronic bulletin board, which we will respond to.

Voice: (408) 721-5582 Modem: (408) 739-1162 Baud: 300 or 1200 baud Set-Up: Length: 8-Bit Parity: None Stop Bit: 1 Operation: 24 Hrs, 7 Days