### Section 1 Overview T-49-19-16 #### 1.1 Features The H8/520 is an original Hitachi CMOS microcomputer unit (MCU) comprising a high-performance CPU core plus a full range of supporting functions—an entire system integrated onto a single chip. The CPU features a highly orthogonal instruction set that permits addressing modes and data sizes to be specified independently in each instruction. An internal 16-bit architecture and 16-bit access to on-chip memory enhance the CPU's data-processing capability and provide the speed needed for realtime control applications. The address space can be expanded to perform high-volume data processing. The on-chip supporting functions include RAM, ROM, timers, a serial communication interface (SCI), A/D converter, and I/O ports. An on-chip data transfer controller (DTC) provides an efficient way to transfer data in either direction between memory and I/O. For the on-chip ROM, a choice is offered between masked ROM and programmable ROM (PROM). The PROM version can be programmed by the user with a general-purpose PROM writer. Table 1-1 lists the main features of the H8/520 chip. DataSheet4U.com DataShe #### Table 1-1 Features | Feature | Description | | | | | |--------------|--------------------------------------------------------------------------------------------------------|--|--|--|--| | CPU | General-register machine | | | | | | | Eight 16-bit general registers | | | | | | | Five 8-bit and two 16-bit control registers | | | | | | | High speed | | | | | | | Maximum clock rate: 10 MHz (oscillator frequency: 20 MHz) | | | | | | | Expanded operating modes supporting external memory | | | | | | | Minimum mode: up to 64-kbyte address space | | | | | | | Maximum mode: up to 1-Mbyte address space | | | | | | | Highly orthogonal instruction set | | | | | | | <ul> <li>Addressing modes and data size can be specified independently for each instruction</li> </ul> | | | | | | | Instructions can address registers or memory | | | | | | | Register-register operations | | | | | | | Register-memory operations | | | | | | | Instruction set optimized for C language | | | | | | | Special short formats for frequently-used instructions and addressing modes | | | | | | Memory | 512-Byte high-speed RAM on-chip | | | | | | | 16-kbyte programmable or masked ROM on-chip | | | | | | 16-Bit free- | Each channel provides: | | | | | | running | 1 free-running counter (which can count external events) | | | | | | timer | 2 output-compare registers | | | | | | (2 channels) | 1 input capture register | | | | | | 8-Bit timer | One 8-bit up-counter (which can count external events) | | | | | | (1 channel) | 2 time constant registers | | | | | | Watchdog | An overflow generates a reset | | | | | | timer | Can output an external reset signal | | | | | | (1 channel) | Can also be used as an interval timer | | | | | et4U.com DataShe **HITACHI** 2 T-49-19-16 | Table 1-1 | Features ( | (cont) | |-----------|------------|--------| |-----------|------------|--------| | Feature | Description | | | <del></del> - | | |------------------|--------------------------------------------------------------------|-------------------------------------------------|---------------------|---------------|--| | Serial com- | <ul> <li>Asynchronous</li> </ul> | s or synchronous mode (selectable) | | _ | | | munication | Full duplex: ca | an send and receive simultaneously | | | | | interface (SCI) | Built-in baud ra | ate generator | | | | | (2 channels) | | | | | | | A/D converter | 10-Bit resolution | on | | | | | | • 4 (or 8*) chan | nels, controllable in single mode or scan mo | ode (selectable) | | | | | Sample-and-h | old function | | | | | | Can be extern | ally triggered | | | | | I/O ports | 46 input/outpu | ut pins (five 8-bit ports, one 6-bit port) | | _ | | | | <ul> <li>4 (or 8*) input-</li> </ul> | only pins (one 4- or 8*-bit port) | | | | | Interrupt | 9 external inte | errupt pins (NMI, IRQo to IRQ7) | | _ | | | controller | • 18 internal inte | errupts | | | | | (INTC) | 8 priority levels | | | | | | Data transfer | Performs efficient | t, rapid, bidirectional data transfer between r | memory and I/O with | | | | controller (DTC) | minimal CPU prog | gramming. | | _ | | | Wait-state | Can insert wait st | ates in access to external memory or I/O | | | | | controller (WSC) | | · | | _ | | | Operating | 5 MCU operating modes | | | | | | modes | Expanded minimum modes, supporting up to 64 kbytes external memory | | | | | | | with or without | t using on-chip ROM (Modes 1 and 2) | | | | | | Expanded maximum modes, supporting up to 1 Mbyte external memory | | | | | | | with or without using on-chip ROM (Modes 3 and 4) | | | | | | | Single-chip mode (Mode 7) | | | | | | | 3 power-down modes | | | | | | | Sleep mode | | | | | | | Software stand | dby mode | | | | | | Hardware standby mode | | | | | | Other features | Clock generate | or on-chip | | <u> </u> | | | Product line-up | Model Name | Package Options | ROM | _ | | | | HD6475208C | 64-Pin windowed shrink DIP (DC-64S) | PROM | | | | | HD6475208P | 64-Pin shrink DIP (DP-64S) | | | | | | HD6475208CP | 68-Pin PLCC (CP-68) | | | | | | HD6475208F | 64-Pin QFP (FP-64A) | | | | | | HD6435208P | 64-Pin shrink DIP (DP-64S) | Masked | | | | | HD6435208CP | 68-Pin PLCC (CP-68) | ROM | | | | | HD6435208F | 64-Pin QFP (FP-64A) | _ | | | Note: \* CP- 68 package only. 3 HITACHI www.DataSheet4U.com 4U.com Figure 1-1 shows a block diagram of the H8/520 chip. Figure 1-1 Block Diagram DataSheet4U.com ### 1.3 Pin Arrangements and Functions T-49-19-16 #### 1.3.1 Pin Arrangement Figure 1-2 shows the pin arrangement of the DC-64S and DP-64S packages. Figure 1-3 shows the pin arrangement of the FP-64A package. Figure 1-4 shows the pin arrangement of the CP-68 package. Figure 1-2 Pin Arrangement (DC-64S, DP-64S, Top View) 5 HITACHI DataSheet4U.com 4U.com www.DataSheet4U.com Figure 1-3 Pin Arrangement (FP-64A, Top View) **HITACHI** 6 DataSheet4U.com et4U.com www.DataSheet4U.com DataShe Figure 1-4 Pin Arrangement (CP-68, Top View) Pin Arrangements in Each Operating Mode: Table 1-2 lists the arrangements of the pins of the DC-64S and DP-64S packages in each operating mode. Table 1-3 lists the arrangements for the FP-64A package. Table 1-4 lists the arrangements for the CP-68 package. Table 1-2 Pin Arrangements in Each Operating Mode (DC-64S, DP-64S) | Din | Name | |-----|--------| | | 144111 | | Pin<br>No. | Modes Mode 1 EXTAL XTAL | Mode 2<br>EXTAL | Modes Mode 3 | Mode 4 | Mode | PROM | |------------|----------------------------|-----------------|-----------------|--------------------|------------------------|------------| | | EXTAL<br>XTAL | EXTAL | | Mode 4 | | _ | | 1 | XTAL | | CVTAI | | Mode 7 | Mode | | | | | EXTAL | EXTAL | EXTAL | NC | | 2 | | XTAL | XTAL | XTAL | XTAL | NC | | 3 | P1o / WAIT | P1o/WAIT | P1o / WAIT | P1o / WAIT | P10 | NC | | 4 | P11 / ĪRQ0 | P11 / ÎRQ0 | P11/IRQo | P11 / ÎRQo | P11/IRQ0 | NC | | 5 | P12 / ÎRQ1 / | P12 / ĪRQ1 / | A18 | P12 / A18 / IRQ1 / | P12/ <del>IRQ1</del> / | NC | | | ADTRG | ADTRG | | ADTRG | ADTRG | | | 6 | P13 / ÎRQ2 | P13 / IRQ2 | A17 | P13 / A17 / ÎRQ2 | P13 / IRQ2 | NC | | 7 | P14 / ÎRQ3 | P14 / ĪRQ3 | A <sub>16</sub> | P14 / A16 / IRQ3 | P14 / ÎRQ3 | NC | | 8 | ĀS | ĀS | ĀS | ĀS | P15 | NC | | 9 | RD | RD | RD | RD | P16 | NC | | 10 | WR | WR ` | WR | WR | P17 | NC | | 11 | Vcc | Vcc | VccataSheet4U | Vcc | Vcc | Vcc | | 12 | MD <sub>0</sub> | MDo | MD <sub>0</sub> | MD <sub>0</sub> | MD <sub>0</sub> | Vcc | | 13 | MD <sub>1</sub> | MD <sub>1</sub> | MD <sub>1</sub> | MDı | MD <sub>1</sub> | Vss | | 14 | MD2 | MD2 | MD2 | MD2 | MD2 | Vcc | | 15 | RES | RES | RES | RES | RES | VPP | | 16 | NMI | NMI | NMI | NMI | NMI | <b>A</b> 9 | | 17 | Vss | Vss | Vss | Vss | Vss | Vss | | 18 | D <sub>0</sub> | D <sub>0</sub> | Do . | D <sub>0</sub> | P2 <sub>0</sub> | <b>0</b> o | | 19 | D <sub>1</sub> | D <sub>1</sub> | D <sub>1</sub> | D1 | P21 | <b>0</b> 1 | | 20 | D <sub>2</sub> | D2 | D <sub>2</sub> | D <sub>2</sub> | P22 | 02 | | 21 | D3 | D <sub>3</sub> | D <sub>3</sub> | Dз | P23 | 0з | | 22 | D4 | D4 | D4 | D4 | P24 | 04 | Notes: 1. For the PROM mode, see section 16, "ROM." 2. Pins marked NC should be left unconnected. HITACHI 8 www.DataSheet4U.com DataShe et4U.com w.DataSheet4U.com **Table 1-2 Pin Arrangements in Each Operating Mode (DC-64S, DP-64S) (cont)** | | | | Pin Name | | T-49-19- | 16 | | |-----|-----------------------|------------------|-------------------|-------------------|-------------------|------------|--------| | | Expanded Minim | num | Expanded Max | imum | Single-Chip | | | | Pin | Modes | | Modes | | Mode | PROM | | | No. | Mode 1 | Mode 2 | Mode 3 | Mode 4 | Mode 7 | Mode | | | 23 | D5 | D <sub>5</sub> | D5 | Ds . | P25 | 05 | | | 24 | D <sub>6</sub> | D <sub>6</sub> | D <sub>6</sub> | D <sub>6</sub> | P26 | 06 | | | 25 | D <sub>7</sub> | D7 | D7 | D7 | P27 | 07 | | | 26 | Ao | Ao | Ao | Ao | P30 | Ao | | | 27 | A <sub>1</sub> | A1 | <b>A</b> 1 | A1 | P31 | A1 | | | 28 | A2 | A2 | A2 | A2 | P32 | A2 | | | 29 | Аз | Аз | Аз | <b>A</b> 3 | P33 | Аз | | | 30 | A4 | A4 | A4 | <b>A</b> 4 | P34 | A4 | | | 31 | A5 | As | <b>A</b> 5 | <b>A</b> 5 | P3s | <b>A</b> 5 | | | 32 | <b>A</b> 6 | <b>A</b> 6 | As | A6 | P36 | Ae | | | 33 | A7 | A7 | A7 | <b>A</b> 7 | P37 | <b>A</b> 7 | | | 34 | A <sub>8</sub> | P40 / A8 | A8 | P4o / A8 | P40 | A8 | | | 35 | <b>A</b> 9 | P41 / A9 | A9 | P41 / A9 | P41 | ŌĒ | | | 36 | A10 | P42 / A10 | A10 | P42 / A10 | P42 | A10 | | | 37 | Att | P43 / A11 | A11 | P43 / A11 | P43 | A11 | | | 38 | A12 | P44 / A12 / IRQ4 | A12 | P44 / A12 / IRQ4 | P44 / ĪRQ4 | A12 | - | | 39 | A13 | P45 / A13 / TRQ5 | A13 | P45 / A13 / IRQ5 | P45 / IRQ5 | A13 | - | | 40 | A14 | P46 / A14 / IRQ6 | A14 | P46 / A14 / IRQ6 | P46 / TRQ6 | A14 | | | 41 | A15 | P47 / A15 / IRQ7 | DataSheet4U.c | P47 / A15 / IRQ7 | P47 / IRQ7 | CE [ | DataSh | | 42 | Vcc | Vcc | Vcc | Vcc | Vcc | Vcc | _ | | 43 | P5o / TMCI | P5o / TMCI | P5o / TMCI | P5o / TMCI | P5o / TMCI | Vcc | _ | | 44 | P51 / FTI1 | P51 / FTI1 | P51 / FTI1 | P51 / FTI1 | P51 / FTI1 | Vcc | _ | | 45 | P52 / FTI2 / | P52 / FTI2 / | P52 / FTI2 / | P52 / FTI2 / | P52 / FTI2 / | NC | | | | TMRI | TMRI | TMRI | TMRI | TMRI | | | | 46 | P5 <sub>3</sub> / TMO | P53 / TMO | P53 / TMO | P53 / TMO | P53 / TMO | NC | | | 47 | P54 / FTOB1 / | P54 / FTOB1 / | P54 / FTOB1 / | P54 / FTOB1 / | P54 / FTOB1 / | NC | | | • - | FTCh | FTCh | FTCI <sub>1</sub> | FTCI <sub>1</sub> | FTCI <sub>1</sub> | | | Notes: 1. For the PROM mode, see section 16, "ROM." 2. Pins marked NC should be left unconnected. 9 HITACHI DataSheet4U.com 4U.com Table 1-2 Pin Arrangements in Each Operating Mode (DC-64S, DP-64S) (cont) | | | T-49-19-16 | | | | | |-----|-------------------|-------------------|-----------------|-------------------|-----------------|------| | | Expanded Minin | num | Expanded Maxi | Expanded Maximum | | | | Pin | Modes | | Modes | | Mode | PROM | | No. | Mode 1 | Mode 2 | Mode 3 | Mode 4 | Mode 7 | Mode | | 48 | P55 / FTOB2 / | P55 / FTOB2 / | P55 / FTOB2 / | P55 / FTOB2 / | P5s / FTOB2 / | NC | | | FTCl <sub>2</sub> | FTCl <sub>2</sub> | FTCl2 | FTCl <sub>2</sub> | FTCl2 | | | 49 | P56 / FTOA1 | P56 / FTOA1 | P56 / FTOA1 | P56 / FTOA1 | P56 / FTOA1 | NC | | 50 | P57 / FTOA2 / Ø | P57 / FTOA2 / ø | P57 / FTOA2 / ø | P57 / FTOA2 / ø | P57 / FTOA2 / ø | NC | | 51 | Vss | Vss | Vss | Vss | Vss | Vss | | 52 | AVss | AVss | AVss | AVss | AVss | Vss | | 53 | P6o / ANo | P60 / AN0 | P60 / AN0 | P60 / AN0 | P60 / AN0 | NC | | 54 | P61 / AN1 | P61 / AN1 | P61 / AN1 | P61 / AN1 | P61 / AN1 | NC | | 55 | P62 / AN2 | P62 / AN2 | P62 / AN2 | P62 / AN2 | P62 / AN2 | NC | | 56 | P63 / AN3 | P63 / AN3 | P63 / AN3 | P63 / AN3 | P63 / AN3 | NC | | 57 | AVcc | AVcc | AVcc | AVcc | AVcc | Vcc | | 58 | P70 / TXD2 | P7o / TXD2 | P70 / TXD2 | P7o / TXD2 | P70 / TXD2 | NC | | 59 | P71 / RXD2 | P71 / RXD2 | P71 / RXD2 | P71 / RXD2 | P71 / RXD2 | NC | | 60 | P72 / SCK2 | P72 / SCK2 | A19 | P72 / SCK2 / A19 | P72 / SCK2 | NC | | 61 | P73 / TXD1 | P73 / TXD1 | P73 / TXD1 | P73 / TXD1 | P73 / TXD1 | NC | | 62 | P74 / RXD1 | P74 / RXD1 | P74 / RXD1 | P74 / RXD1 | P74 / RXD1 | NC | | 63 | P75 / SCK1 | P75 / SCK1 | P75 / SCK1 | P75 / SCK1 | P75 / SCK1 | NC | | 64 | Vss | Vss | Vss | Vss | Vss | Vss | et4U.com DataShe **HITACHI** 10 Notes: 1. For the PROM mode, see section 16, "ROM." 2. Pins marked NC should be left unconnected. www.DataSheet4U.com Pin Arrangements in Each Operating Mode (FP-64A) T-49-19-16 #### Pin Name | | | | Pin Nam | 10 | <u></u> | | | |-----|-----------------|-----------------|-----------------|----------------|-----------------|----------------|----------| | | Expanded Mi | inimum | Expanded N | Maximum | Single-Chip | | | | Pin | Modes | | Modes | | Mode | PROM | | | No. | Mode 1 | Mode 2 | Mode 3 | Mode 4 | Mode 7 | Mode | | | 1 | RD | RD | RD | RD | P16 | NC | | | 2 | WR | WR | WR | WR | P17 | NC | | | 3 | Vcc | Vcc | Vcc | Vcc | Vcc | Vcc | | | 4 | MDo | MD₀ | MDo | MDo | MD <sub>0</sub> | Vcc | | | 5 | MD <sub>1</sub> | MD <sub>1</sub> | MD <sub>1</sub> | MD1 | MD <sub>1</sub> | Vss | | | 6 | MD2 | MD <sub>2</sub> | MD2 | MD2 | MD2 | Vcc | | | 7 | RES | RES | RES | RES | RES | VPP | | | 8 | NMI | NMI | NMI | NMI | NMI | A9 | | | 9 | Vss | Vss | Vss | Vss | Vss | Vss | | | 10 | D <sub>0</sub> | D <sub>0</sub> | Do | Do | P2o | O <sub>0</sub> | | | 11 | D1 | D <sub>1</sub> | D <sub>1</sub> | D <sub>1</sub> | P21 | O <sub>1</sub> | | | 12 | D2 | D2 | D2 | D2 | P2 <sub>2</sub> | O2 | | | 13 | Dз | D3 | Dз | D3 | P23 | Оз | | | 14 | D4 | D <sub>4</sub> | D4 | D4 | P24 | O4 | | | 15 | D <sub>5</sub> | Ds | Ds | Ds | P25 | O <sub>5</sub> | | | 16 | D <sub>6</sub> | D <sub>6</sub> | D <sub>6</sub> | D <sub>6</sub> | P26 | O <sub>6</sub> | | | 17 | D <sub>7</sub> | D7 | D7 | D <sub>7</sub> | P27 | O <sub>7</sub> | | | 18 | Ao | P3o/Ao | Ao | P3o/Ao | P3o | Ao | Ohan | | 19 | A <sub>1</sub> | P31/A1 | A1 | P31/A1 | P3 <sub>1</sub> | A <sub>1</sub> | DataShee | | 20 | A2 | P32/A2 | A2 | P32/A2 | P32 | A2 | | | 21 | Аз | P33/A3 | Аз | P33/A3 | P33 | Аз | | | 22 | A4 | P34/A4 | A4 | P34/A4 | P34 | A4 | | | 23 | <b>A</b> 5 | P35/A5 | <b>A</b> 5 | P3s/As | P3s | <b>A</b> 5 | | | 24 | A6 | P36/A6 | <b>A</b> 6 | P36/A6 | P36 | <b>A</b> 6 | | | 25 | A <sub>7</sub> | P37/A7 | A7 | P37/A7 | P37 | A7 | _ | | 26 | As | P4o / A8 | Aa | P4o / As | P40 | A8 | - | | 27 | A9 | P41 / A9 | A9 | P41 / A9 | P41 | ŌĒ | | | 28 | A10 | P42 / A10 | <b>A</b> 10 | P42 / A10 | P42 | A10 | _ | | 29 | | P43 / A11 | A11 | P43 / A11 | P43 | <b>A</b> 11 | | | | | | | | | | | Notes: 1. For the PROM mode, see section 16, "ROM." 2. Pins marked NC should be left unconnected. 11 **HITACHI** DataSheet4U.com et4U.com Table 1-3 Pin Arrangements in Each Operating Mode (FP-64A) (cont) T-49-19-16 | Pin | Name | |-----|------| | | | | | Pili Name | | | | | | | | |-----|-----------------------|-------------------|----------------|-----------------------|-------------------|------|--|--| | | Expanded Minir | num | Expanded Max | kimum | Single-Chip | | | | | Pin | Modes | | Modes | Modes | | PROM | | | | No. | Mode 1 | Mode 2 | Mode 3 | Mode 4 | Mode 7 | Mode | | | | 30 | A12 | P44 / A12 / IRQ4 | A12 | P44 / A12 / IRQ4 | P44 / IRQ4 | A12 | | | | 31 | A13 | P45 / A13 / IRQ5 | А13 | P45 / A13 / IRQ5 | P4s / IRQs | A13 | | | | 32 | A14 | P46 / A14 / IRQ6 | A14 | P46 / A14 / IRQ6 | P46 / IRQ6 | A14 | | | | 33 | A15 | P47 / A15 / IRQ7 | A15 | P47 / A15 / IRQ7 | P47 / IRQ7 | CE | | | | 34 | Vcc | Vcc | Vcc | Vcc | Vcc | Vcc | | | | 35 | P5 <sub>0</sub> /TMCI | P5o /TMCI | P5o /TMCI | P5 <sub>0</sub> /TMCI | P50 /TMCI | Vcc | | | | 36 | P51 /FTI1 | P51 /FTI1 | P51 /FTI1 | P51 FTI1 | P51 /FTI1 | Vcc | | | | 37 | P52 /FTI2 / | P52 /FTI2 / | P52 /FT12 / | P52 /FTI2 / | P52 /FTI2 / | NC | | | | | TMRI | TMRI | TMRI | TMRI | TMRI | | | | | 38 | P53/TMO | P53/TMO | P53/TMO | P53/TMO | P53/TMO | NC | | | | 39 | P54 /FTOB1 / | P54 /FTOB1 / | P54 /FTOB1 / | P54 /FTOB1 / | P54 /FTOB1 / | NC | | | | | FTCh | FTCl <sub>1</sub> | FTCI | FTCI1 | FTCI <sub>1</sub> | | | | | 40 | P55 /FTOB2 / | P5s /FTOB2 / | P55 /FTOB2 / | P55 /FTOB2 / | P5s /FTOB2 / | NC | | | | | FTCl2 | FTCl2 | FTCl2 | FTCI2 | FTCl2 | | | | | 41 | P56 /FTOA1 | P56 /FTOA1 | P56 /FTOA1 | P56 /FTOA1 | P56 /FTOA1 | NC | | | | 42 | P57 /FTOA2 / ø | P57 /FTOA2 / Ø | P57 /FTOA2 / Ø | P57 /FTOA2 / ø | P57 /FTOA2 / Ø | NC | | | | 43 | Vss | Vss | Vss | Vss | Vss | Vss | | | | 44 | AVss | AVss | AVssataSheet4L | AVss | AVss | Vss | | | | 45 | P6o / ANo | P6o / ANo | P6o / ANo | P6o / ANo | P60 / AN0 | NC | | | | 46 | P61 / AN1 | P61 / AN1 | P61 / AN1 | P61 / AN1 | P61 / AN1 | NC | | | | 47 | P62 / AN2 | P62 / AN2 | P62 / AN2 | P62 / AN2 | P62 / AN2 | NC | | | | 48 | P63 / AN3 | P63 / AN3 | P63 / AN3 | P63 / AN3 | P63 / AN3 | NC | | | | 49 | AVcc | AVcc | AVcc | AVcc | AVcc | Vcc | | | | 50 | P70 / TXD2 | P70 / TXD2 | P70 / TXD2 | P70 / TXD2 | P70 / TXD2 | NC | | | | | | | | | | | | | et4U.com Notes: 1. For the PROM mode, see section 16, "ROM." 2. Pins marked NC should be left unconnected. HITACHI 12 www.DataSheet4U.com DataShe ## ww.DataSheat4U13<sup>m</sup>Pin Arrangements in Each Operating Mode (FP-64A) (cont) | T | J-2 | | |--------|-----|-----| | T-49-1 | 9-1 | 16 | | | - 1 | ··· | | | Pin Name | | | | | | |--------|------------------------|--------------|------------------|------------------|-------------|---------| | | Expanded Minimum Modes | | Expanded Maximum | | Single-Chip | | | Pin | | | Modes | | Mode | _ PROM | | No. | Mode 1 | Mode 2 | Mode 3 | Mode 4 | Mode 7 | Mode | | 51 | P71 / RXD2 | P71 / RXD2 | P71 / RXD2 | P71 / RXD2 | P71 / RXD2 | NC | | <br>52 | P72 / SCK2 | P72 / SCK2 | A19 | P72 / SCK2 / A19 | P72 / SCK2 | NC | | 53 | P73 / TXD1 | P73 / TXD1 | P73 / TXD1 | P73 / TXD1 | P73 / TXD1 | NC | | 54 | P74 / RXD1 | P74 / RXD1 | P74 / RXD1 | P74 / RXD1 | P74 / RXD1 | NC | | 55 | P7s / SCK1 | P75 / SCK1 | P75 / SCK1 | P75 / SCK1 | P75 / SCK1 | NC | | 56 | Vss | Vss | Vss | Vss | Vss | Vss | | 57 | EXTAL | EXTAL | EXTAL | EXTAL | EXTAL | NC | | 58 | XTAL | XTAL | XTAL | XTAL | XTAL | NC | | 59 | P1o / WAIT | P1o / WAIT | P1o/WAIT | P1o / WAIT | P10 | NC | | 60 | P11/ĪRQo | P11/IRQo | P11/IRQ0 | P11 / ÎRQo | P11/IRQo | NC | | 61 | P12/IRQ1/ | P12 / IRQ1 / | A18 | P12 / A18 / | P12/IRQ1/ | NC | | - | ADTRG | ADTRG | | IRQ1/ ADTRG | ADTRG | <u></u> | | 62 | P13 / IRQ2 | P13 / IRQ2 | A17 | P13 / A17 / IRQ2 | P13 / IRQ2 | NC | | 63 | P14 / IRQ3 | P14/IRQ3 | A16 | P14 / A16 / IRQ3 | P14/IRQ3 | NC | | 64 | ĀS | ĀS | ĀS | ĀS | P15 | NC | Notes: 1. For the PROM mode, see section 16, "ROM." 2. Pins marked NC should be left unconnected. et4U.com DataSheet4U.com DataShe 13 HITACHI DataSheet4U.com ## www.DataSheet4U.com Table 1-4 Pin Arrangements in Each Operating Mode (CP-68) T-49-19-16 | P | in | Name | |---|----|--------| | | | Hallie | | | | | Fillitalii | <b>5</b> | | | |-----|-----------------|-----------------|-----------------|------------------|-----------------|------------| | | Expanded Mir | nimum | Expanded M | aximum | Single-Chip | | | Pin | Modes | | Modes | | Mode | PROM | | No. | Mode 1 | Mode 2 | Mode 3 | Mode 4 | Mode 7 | <br>Mode | | 1 | P75 / SCK1 | P75 / SCK1 | P75 / SCK1 | P75 / SCK1 | P75 / SCK1 | NC | | 2 | Vss | Vss | Vss | Vss | Vss | Vss | | 3 | EXTAL | EXTAL | EXTAL | EXTAL | EXTAL | NC | | 4 | XTAL | XTAL | XTAL | XTAL | XTAL | NC | | 5 | P1o / WAIT | P1o/WAIT | P1o/WAIT | P1o / WAIT | P10 | NC | | 6 | P11/IRQo | P11 / IRQ0 | P11 / ÎRQ0 | P11/ĪRQo | P11/IRQo | NC | | 7 | P12 / ĪRQ1 / | P12 / ÎRQ1 / | A18 | P12 / A18 / | P12 / IRQ1 / | NC | | | ADTRG | ADTRG | | IRQ1 / ADTRG | ADTRG | | | 8 | P13 / ÎRQ2 | P13 / ÎRQ2 | A17 | P13 / A17 / IRQ2 | P13 / ÎRQ2 | NC | | 9 | P14 / ÎRQ3 | P14 / IRQ3 | A16 | P14 / A16 / IRQ3 | P14 / ĪRQ3 | NC | | 10 | ĀS | ĀS | ĀS | ĀS | P15 | NC | | 11 | RD | RD | RD | RD | P16 | NÇ | | 12 | WR | WR | WR | WR | P17 | NC | | 13 | Vcc | Vcc | Vcc | Vcc | Vcc | Vcc | | 14 | MD <sub>0</sub> | MD <sub>0</sub> | MD <sub>0</sub> | MD <sub>0</sub> | MD <sub>0</sub> | Vcc | | 15 | MD <sub>1</sub> | MD <sub>1</sub> | MD <sub>1</sub> | MD <sub>1</sub> | MD <sub>1</sub> | Vss | | 16 | MD2 | MD <sub>2</sub> | MD2 | MD2 | MD <sub>2</sub> | Vcc | | 17 | RES | RES | RES ata Sheet | 4URES | RES | VPP | | 18 | NMI | NMI | NMI | NMI | NMI | <b>A</b> 9 | | 19 | Vss | Vss | Vss | Vss | Vss | Vss | | 20 | Do | Do | Do | Do | P2 <sub>0</sub> | Oo | | 21 | D1 | D1 | D <sub>1</sub> | D <sub>1</sub> | P21 | 01 | | 22 | D <sub>2</sub> | D2 | D2 | D <sub>2</sub> | P2 <sub>2</sub> | 02 | | 23 | D3 | Dз | Dз | D <sub>3</sub> | P2 <sub>3</sub> | 0з | | 24 | D4 | D <sub>4</sub> | D4 | D4 | P24 | 04 | | | | | | | <del> </del> | | Notes: 1. For the PROM mode, see section 16, "ROM." 2. Pins marked NC should be left unconnected. HITACHI 14 www.DataSheet4U.com DataShe et4U.com www.DataSheet4U.comPin Arrangements in Each Operating Mode (CP-68) (cont) T-49-19-16 #### **Pin Name** | | | Pili Name | | | | | |----------------|--------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Expanded Mini | mum | Expanded Ma | ximum | Single-Chip | | | | Modes | | Modes | | Mode | PROM | | | Mode 1 | Mode 2 | Mode 3 | Mode 4 | Mode 7 | Mode | | | D5 | D5 | Ds | Ds . | P25 | 05 | | | D <sub>6</sub> | D <sub>6</sub> | D <sub>6</sub> | D <sub>6</sub> | P26 | 06 | | | D7 | D <sub>7</sub> | D7 | D7 | P27 | 07 | | | Ao | Ao | Ao | Ao | P30 | Ao | | | A1 | <b>A</b> 1 | <b>A</b> 1 | <b>A</b> 1 | P3 <sub>1</sub> | <b>A</b> 1 | | | A2 | A2 | A2 | A2 | P32 | <b>A</b> 2 | | | Аз | Аз | Аз | Аз | P33 | A3 | | | A4 | A4 | A4 | A4 | P34 | A4 | , | | <b>A</b> 5 | As | A <sub>5</sub> | A5 | P35 | <b>A</b> 5 | | | A6 | A6 | As | A6 | P36 | Ав | | | | A <sub>7</sub> | A7 | A7 | P37 | A7 | | | As | P40 / A8 | A8 | P4o / A8 | P40 | A8 | | | Ag | P41 / A9 | <b>A</b> 9 | P41 / A9 | P41 | ŌĒ | | | A10 | P42 / A10 | <b>A</b> 10 | P42 / A10 | P42 | A10 | • | | A11 | P43 / A11 | A11 | P43 / A11 | P43 | A11 | • | | A12 | P44 / A12 / TRQ4 | A12 | P44 / A12 / IRQ4 | P44 / ÎRQ4 | A12 | • | | A13 | P4s / A13 / IRQ5 | A13 | P45 / A13 / IRQ5 | P4s / IRQs | A13 | _ | | A14 | P46 / A14 / IRQ6 | A14 | P46 / A14 / IRQ6 | P46 / IRQ6 | A14 . | _ | | A15 | P47 / A15 / IRQ7 | DataSheet4U<br><b>A</b> 15 | P47 / A15 / IRQ7 | P47 / IRQ7 | CE | DataShe | | Vcc | Vcc | Vcc | Vcc | Vcc | Vcc | _ | | P5o / TMCI | P5o / TMCI | P50 / TMCI | P5o / TMCI | P5 <sub>0</sub> / TMCl | Vcc | _ | | P51 / FTI1 | P51 / FTI1 | P51 / FTI1 | P51 / FTI1 | P51 / FTl1 | Vcc | _ | | P52 / FTl2 / | P52 / FTI2 / | P52 / FTI2 / | P52 / FTl2 / | P52 / FTI2 / | NC | | | TMRI | TMRI | TMRI | TMRI | TMRI | | | | | Modes Mode 1 Ds D6 D7 A0 A1 A2 A3 A4 A5 A6 A7 A8 A9 A10 A11 A12 A13 A14 A15 Vcc P50 / TMCI P51 / FTl1 P52 / FTl2 / | Mode 1 Mode 2 Ds Ds De De Dr Dr Ao Ao A1 A1 A2 A2 A3 A3 A4 A4 A5 A5 A6 A6 A7 A7 A8 P40 / A8 A9 P41 / A9 A10 P42 / A10 A11 P43 / A11 A12 P44 / A12 / IRQ4 A13 P45 / A13 / IRQ5 A14 P46 / A14 / IRQ6 A15 P47 / A15 / IRQ7 Vcc Vcc P50 / TMCI P50 / TMCI P51 / FTI1 P51 / FTI1 P52 / FTI2 / P52 / FTI2 / | Expanded Minimum Expanded Management Modes Modes Mode 1 Mode 2 Mode 3 Ds Ds Ds De De De Dr Dr Dr Ao Ao Ao A1 A1 A1 A2 A2 A2 A3 A3 A3 A4 A4 A4 A5 A5 A5 A6 A6 A6 A7 A7 A7 A8 P40 / A8 A8 A9 P41 / A9 A9 A10 P42 / A10 A10 A11 P43 / A11 A11 A12 P44 / A12 / IRQ4 A12 A13 P45 / A13 / IRQ5 A13 A14 P46 / A14 / IRQ6 A14 A15 P47 / A15 / IRQ7 A15 Vcc Vcc Vcc P50 / TMCI P50 / TMCI P50 / TMCI < | Expanded Maximum Modes Modes Mode 1 Mode 2 Mode 3 Mode 4 Ds Ds Ds Ds De De De De Dr Dr Dr Dr Ao Ao Ao Ao Ai Ai Ai Ai Ai Ai Ai Ai Aa | Expanded Maximum Single-Chip Modes Modes Mode Mode 1 Mode 2 Mode 3 Mode 4 Mode 7 Ds Ds Ds Ds P2s De De De De P2s D7 D7 D7 D7 P2r A0 A0 A0 A0 P30 A1 A1 A1 A1 P31 A2 A2 A2 A2 P32 A3 A3 A3 A3 P33 A4 A4 A4 A4 P34 A5 A5 A5 A5 P35 A6 A6 A6 A6 P36 A7 A7 A7 A7 P37 A8 P40 / A8 A8 P40 / A8 P40 A9 P41 / A9 A9 P41 / A9 P41 A10 P42 / A10 A10 P42 / A10 P42 | Expanded Maximum Single-Chip Modes Modes Mode Mode 7 Mode Mode 1 Mode 2 Mode 3 Mode 4 Mode 7 Mode Ds Ds Ds Ds P2s 0s De De De P2e 0e D7 D7 D7 P27 07 A0 A0 A0 A0 P30 A0 A1 A1 A1 A1 P31 A1 A2 A2 A2 P32 A2 A3 A3 A3 A3 P33 A3 A4 A4 A4 A4 P34 A4 A5 A5 A5 A5 A5 A5 A6 A6 A6 A6 A6 P36 A6 A7 A7 A7 A7 P37 A7 A8 P40 / A6 A8 P40 / A6 P40 / A6 A1 | et4U.com Notes: 1. For the PROM mode, see section 16, "ROM." 2. Pins marked NC should be left unconnected. 15 **HITACHI** www.DataSheet4U.com Table 1-4 Pin Arrangements in Each Operating Mode (CP-68) (cont) T-49-19-16 | riii naille | P | in | Name | |-------------|---|----|------| |-------------|---|----|------| | | | | riii Naine | | | | |-----|-------------------------------------|-----------------|-----------------|-------------------------------------|-------------------|--------------| | | Expanded Minis | num | Expanded Max | imum | Single-Chip | <del> </del> | | Pin | Modes | | Modes | | Mode | PROM | | No. | o. Mode 1 Mode 2 | | Mode 3 | Mode 4 | 4 Mode 7 | | | 48 | P53 / TMO | P53 / TMO | P53 / TMO | P53 / TMO | P53 / TMO | NC | | 49 | P54 / FTOB1 / | P54 / FTOB1 / | P54 / FTOB1 / | P54 / FTOB1 / | P54 / FTOB1 / | NC | | | FTCI <sub>1</sub> | FTCl1 | FTCI | FTCI <sub>1</sub> | FTCh | | | 50 | P55 / FTOB2 / | P55 / FTOB2 / | P55 / FTOB2 / | P55 / FTOB2 / | P55 / FTOB2 / | NC | | | FTCl2 | FTCl2 | FTCl2 | FTCl <sub>2</sub> | FTCl <sub>2</sub> | | | 51 | P5 <sub>6</sub> / FTOA <sub>1</sub> | P56 / FTOA1 | P56 / FTOA1 | P5 <sub>6</sub> / FTOA <sub>1</sub> | P56 / FTOA1 | NC | | 52 | P57 / FTOA2 / ø | P57 / FTOA2 / ø | P57 / FTOA2 / ø | P57 / FTOA2 / Ø | P57 / FTOA2 / Ø | NC | | 53 | Vss | Vss | Vss | Vss | Vss | Vss | | 54 | AVss | AVss | AVss | AVss | AVss | Vss | | 55 | P6o / ANo | P6o / ANo | P60 / AN0 | P6o / ANo | P6o / ANo | NC | | 56 | P61 / AN1 | P61 / AN1 | P61 / AN1 | P61 / AN1 | P61 / AN1 | NC | | 57 | P62 / AN2 | P62 / AN2 | P62 / AN2 | P62 / AN2 | P62 / AN2 | NC | | 58 | P63 / AN3 | P63 / AN3 | P63 / AN3 | P63 / AN3 | P63 / AN3 | NC | | 59 | P64 / AN4 | P64 / AN4 | P64 / AN4 | P64 / AN4 | P64 / AN4 | NC | | 60 | P65 / AN5 | P65 / AN5 | P65 / AN5 | P65 / AN5 | P65 / AN5 | NC | | 61 | P66 / AN6 | P66 / AN6 | P66 / AN6 | P66 / AN6 | P66 / AN6 | NC | | 62 | P67 / AN7 | P67 / AN7 | P67 / AN7 | P67 / AN7 | P67 / AN7 | NC | | 63 | AVcc | AVcc | AVecataSheet4U | _AVcc | AVcc | Vcc | | 64 | P70 / TXD2 | P70 / TXD2 | P70 / TXD2 | P70 / TXD2 | P70 / TXD2 | NC | | 65 | P71 / RXD2 | P71 / RXD2 | P71 / RXD2 | P71 / RXD2 | P71 / RXD2 | NC | | 66 | P72 / SCK2 | P72 / SCK2 | A19 | P72 / SCK2 / A19 | P72 / SCK2 | NC | | 67 | P73 / TXD1 | P73 / TXD1 | P73 / TXD1 | P73 / TXD1 | P73 / TXD1 | NC | | 68 | P74 / RXD1 | P74 / RXD1 | P74 / RXD1 | P74 / RXD1 | P74 / RXD1 | NC | et4U.com - Notes: 1. For the PROM mode, see section 16, "ROM." - 2. Pins marked NC should be left unconnected. HITACHI 16 www.DataSheet4U.com DataShe Www.DataSheet4U.com Pin Functions: Table 1-5 gives a concise description of the function of each pin. **Table 1-5** Pin Functions T-49-19-16 | | | | Pin No. | | | | |-------|--------|---------|---------|---------------|-------------------|-----------------------------------------------------------| | | | DC-64S | FP-64A | CP-68 | | | | Туре | Symbol | DP-64S | | | 1/0 | Name and Function | | Power | Vcc | 42, 11 | 34, 3 | 44, 13 | ı | Power: Connected to the power supply (+5 V). | | | | | | | | Connect both Vcc pins to the system power supply | | | | | | | | (+5 V). The chip will not operate if either pin is left | | | | | | | | unconnected. | | | Vss | 51, 17, | 43, 9, | 53, 19, | 1 | Ground: Connected to ground (0 V). Connect all Vss | | | | 64 | 56 | 2 | | pins to the system power supply (0 V). The chip will | | | | | | | | not operate if either pin is left unconnected. | | Clock | XTAL | 2 | 58 | 4 | 0 | Crystal: Connected to a crystal oscillator. The crystal | | | | | | | | frequency should be double the desired ø clock | | | | | | | | frequency. If an external clock is input at the EXTAL | | | | | | | | pin, input an inverted clock signal at the XTAL pin. | | | EXTAL | 1 | 57 | 3 | - | External Crystal: Connected to a crystal oscillator or | | | | | | | | external clock. The frequency of the external clock | | | | | | | | should be double the desired ø clock frequency. | | | | | | | | See section 8.2, "Oscillator Circuit", for examples of | | | | | | | | connections to a crystal and external clock. | | | Ø | 50 | 42 | <b>52</b> Dat | <b>O</b><br>aShee | System Clock: Supplies the ø clock to peripheral devices. | et4U.com DataShe **17** HITACHI T-49-19-16 | | | | Pin No. | | | 1 49-15-10 | |---------|---------------------------------------|---------------------------------------|---------|---------|-----|----------------------------------------------------------------------------------------| | | | DC-64S | FP-64A | CP-68 | | | | Туре | Symbol | DP-64S | | | I/O | Name and Function | | System | RES | 15 | 7 | 17 | 1/0 | Reset: A low input causes the H8/520 chip to reset. | | control | | | | | | If the reset output enable bit (RSTOE) is set to 1, | | | | | | | | when the watchdog timer overflows, a low signal is | | | | | | | | output for 132 system clock cycles. | | Address | A19 - A0 | 60, | 52, | 66, | 0 | Address Bus: Address output pins. | | bus | | 5-7 | 61 – 63 | 7-9 | | | | | | 41 – 26 | 33 – 18 | 43 – 28 | | | | Data | D7 – D0 | 25 – 18 | 17 – 10 | 27 – 20 | 1/0 | Data Bus: 8-Bit bidirectional data bus. | | bus | | | | | | | | Bus | WAIT | 3 | 59 | 5 | I | Wait: Requests the CPU to insert one | | control | | | | | | or more Tw states when accessing an off-chip | | | | | | | | address. | | | AS | 8 | 64 | 10 | 0 | Address Strobe: Goes low to indicate that there is a valid address on the address bus. | | | RD | 9 | 1 | 11 | 0 | Read: Goes low to indicate that the CPU is reading | | | | | | | | an external address. | | | WR | 10 | 2 | 12 | 0 | Write: Goes low to indicate that the CPU is writing to | | | | | | | | an external address. | | | · · · · · · · · · · · · · · · · · · · | · · · · · · · · · · · · · · · · · · · | ···· | | | | et4U.com DataSheet4U.com DataShe HITACHI 18 www.DataSheet4U.com **Table 1-5 Pin Functions (cont)** | | | | Pin No. | | | | | | | T-49-19-16 | |------------------------------|-------------------------|----------------|--------------|----------------|-----|--------------------------------|--------------------|-------------|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | DC-64S | FP-64A | CP-68 | | | | | | | | Гуре | Symbol | DP-64S | | | 1/0 | | | unctio | | · · · · · · · · · · · · · · · · · · · | | nterrupt | NMI | 16 | 8 | 18 | ı | | | | | ghest-priority interrupt | | | | | | | | • | _ | | | skable interrupt control | | | | | | | | • | | | | whether the interrupt is | | | | | | | | - | sted or | 1 the ris | sing or fal | ling edge of the NMI | | | | | | | | input. | | | | | | | IRQ <sub>0</sub> | 4 | 60 | 6 | l | | | quest | 0 to 7: M | laskable interrupt request | | | <b>IRQ</b> <sub>1</sub> | 5 | 61 | 7 | | signals | S | | | | | | IRQ <sub>2</sub> | 6 | 62 | 8 | | | | | | | | | IRQ <sub>3</sub> | 7 | 63 | 9 | | | | | | | | | IRQ4 | 38 | 30 | 40 | | | | | | | | | IRQ5 | 39 | 31 | 41 | | | | | | | | | | | | 40 | | | | | | | | | IRQ6 | 40 | 32 | 42 | | | | | | | | | IRQ6<br>IRQ7 | 40<br>41 | 32<br>33 | 42<br>43 | | | <u>-</u> | <del></del> | | | | | | | | | ı | Mode | : Inpu | t pins f | or setting | the MCU operating mode | | - | IRQ7 | 41 | 33 | 43 | ì | | | | or setting | | | node | IRQ7<br>MD2 | 14 | 33<br>6 | 43<br>16 | I | accore | ding to | the tal | ble below | | | node | IRQ7<br>MD2<br>MD1 | 41<br>14<br>13 | 33<br>6<br>5 | 43<br>16<br>15 | I | MD2 | ding to | the tal | ble below<br>Mode | | | node | IRQ7<br>MD2<br>MD1 | 41<br>14<br>13 | 33<br>6<br>5 | 43<br>16<br>15 | ì | MD2 | MD1 | the tal | Mode 0 | Description<br>— | | node | IRQ7<br>MD2<br>MD1 | 41<br>14<br>13 | 33<br>6<br>5 | 16<br>15<br>14 | | MD2 | MD1<br>0 | the tal | ble below<br>Mode | Description — Expanded minimum mode | | mode | IRQ7<br>MD2<br>MD1 | 41<br>14<br>13 | 33<br>6<br>5 | 16<br>15<br>14 | | MD2<br>0<br>0 | MD1<br>0<br>0 | MDO<br>0 | Mode 0 | Description<br>— | | Operating<br>mode<br>control | IRQ7<br>MD2<br>MD1 | 41<br>14<br>13 | 33<br>6<br>5 | 16<br>15<br>14 | | MD2 | MD1<br>0 | the tal | Mode<br>Mode 0 | Description Expanded minimum mode (ROM disabled) | | node | IRQ7<br>MD2<br>MD1 | 41<br>14<br>13 | 33<br>6<br>5 | 16<br>15<br>14 | | MD2<br>0<br>0 | MD1<br>0<br>0 | MDO<br>0 | Mode<br>Mode 0 | Description — Expanded minimum mode (ROM disabled) Expanded minimum mode | | mode | IRQ7<br>MD2<br>MD1 | 41<br>14<br>13 | 33<br>6<br>5 | 16<br>15<br>14 | | MD2<br>0<br>0<br>0<br>et4U.cor | MD1<br>0<br>0 | MDO 0 1 | Mode 0 Mode 1 Mode 2 | Description Expanded minimum mode (ROM disabled) Expanded minimum mode (ROM enabled) Expanded maximum mode (ROM disabled) | | mode | IRQ7<br>MD2<br>MD1 | 41<br>14<br>13 | 33<br>6<br>5 | 16<br>15<br>14 | | MD2<br>0<br>0<br>0<br>et4U.cor | MD1<br>0<br>0 | MDO 0 1 | Mode 0 Mode 1 Mode 2 | Description Expanded minimum mode (ROM disabled) Expanded minimum mode (ROM enabled) Expanded maximum mode (ROM disabled) Expanded maximum mode (ROM disabled) | | mode | IRQ7<br>MD2<br>MD1 | 41<br>14<br>13 | 33<br>6<br>5 | 16<br>15<br>14 | | MD2<br>0<br>0<br>et4U.cor | MD1<br>0<br>0<br>1 | MDO 0 1 0 | Mode 0<br>Mode 1<br>Mode 2<br>Mode 3<br>Mode 4 | Description Expanded minimum mode (ROM disabled) Expanded minimum mode (ROM enabled) Expanded maximum mode (ROM disabled) | | mode | IRQ7<br>MD2<br>MD1 | 41<br>14<br>13 | 33<br>6<br>5 | 16<br>15<br>14 | | MD2<br>0<br>0<br>et4U.cor | MD1<br>0<br>0<br>1 | MDO 0 1 | Mode 0 Mode 1 Mode 2 Mode 3 | Description Expanded minimum mode (ROM disabled) Expanded minimum mode (ROM enabled) Expanded maximum mode (ROM disabled) Expanded maximum mode (ROM disabled) | 19 **HITACHI** DataSheet4U.com 4U.com **Table 1-5 Pin Functions (cont)** | | | Pin No. | | | | |-------------------|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | DC-64S | FP-64A | CP-68 | | | | Symbol | DP-64S | | | 1/0 | Name and Function | | FTOA <sub>1</sub> | 49 | 41 | 51 | 0 | FRT Output Compare A (channels 1 and 2): | | FTOA <sub>2</sub> | 50 | 42 | 52 | | Output pins for the output compare A function of | | | | | | | free-running timer channels 1 and 2. | | FTOB <sub>1</sub> | 47 | 39 | 49 | 0 | FRT Output Compare B (channels 1 and 2): | | FTOB <sub>2</sub> | 48 | 40 | 50 | | Output pins for the output compare B function of | | | | | | | free-running timer channels 1 and 2. | | FTCI <sub>1</sub> | 47 | 39 | 49 | 1 | FRT Counter Clock Input (channels 1 and 2): | | FTCI2 | 48 | 40 | 50 | | External clock input pins for the free-running counters | | | | | | | (FRCs) of free-running timer channels 1 and 2. | | FTI <sub>1</sub> | 44 | 36 | 46 | ı | FRT Input Capture (channels 1 and 2): Input | | FTI2 | 45 | 37 | 47 | | capture pins for free-running timer channels 1 and 2. | | TMO | 46 | 38 | 48 | O | 8-bit Timer Output: Compare-match output pin for | | | | | | | the 8-bit timer. | | TMCI | 43 | 35 | 45 | ı | 8-bit Timer Clock Input: External clock input pin for | | | | | | | the 8-bit timer counter. | | TMRI | 45 | 37 | 47 | 1 | 8-bit Timer Counter Reset Input: A high input at this | | | | | | | pin resets the 8-bit timer counter. | | | FTOA1 FTOA2 FTOB1 FTOB2 FTCI1 FTCI2 FTI1 FTI2 TMO | Symbol DP-64S FTOA1 49 FTOA2 50 FTOB1 47 FTOB2 48 FTCI1 47 FTCI2 48 FTI1 44 FTI2 45 TMO 46 TMCI 43 | DC-64S FP-64A Symbol DP-64S FTOA1 49 41 FTOA2 50 42 FTOB1 47 39 FTOB2 48 40 FTCl1 47 39 FTCl2 48 40 FTI1 44 36 FTI2 45 37 TMO 46 38 TMCI 43 35 | DC-64S FP-64A CP-68 Symbol DP-64S FP-64A CP-68 FTOA1 49 41 51 FTOA2 50 42 52 FTOB1 47 39 49 FTCI1 47 39 49 FTCI2 48 40 50 FTI1 44 36 46 FTI2 45 37 47 TMO 46 38 48 TMCI 43 35 45 | DC-64S FP-64A CP-68 Symbol DP-64S I/O FTOA1 49 41 51 O FTOA2 50 42 52 O FTOB1 47 39 49 O FTCI1 47 39 49 I FTCI2 48 40 50 FTI1 44 36 46 I FTI2 45 37 47 TMO 46 38 48 O TMCI 43 35 45 I | et4U.com DataSheet4U.com DataShe HITACHI 20 **Table 1-5** Pin Functions (cont) | | | ` . | | | | T-49-19-16 | | |-------------|------------------|----------|---------|----------|-------|---------------------------------------------------|----------| | | | | Pin No. | | _ | 1-43-1- | | | | | DC-64S | FP-64A | CP-68 | | | | | Туре | Symbol | DP-64S | | | I/O | Name and Function | | | Serial com- | TXD <sub>1</sub> | 61 | 53 | 67 | 0 | Transmit Data (channels 1 and 2): Data output | | | munication | TXD2 | 58 | 50 | 64 | | pins for serial communication interface channels | | | interface | | <u> </u> | | | | 1 and 2. | - | | signals | RXD <sub>1</sub> | 62 | 54 | 68 | ŧ | Receive Data (channels 1 and 2): Data input | | | | RXD2 | 59 | 51 | 65 | | pins for serial communication interface channels | | | | | | | <u>.</u> | | 1 and 2. | _ | | | SCK <sub>1</sub> | 63 | 55 | 1 | 1/0 | Serial Clock (channels 1 and 2): Input/output | | | | SCK <sub>2</sub> | 60 | 52 | 66 | | pins for the serial interface clock. | | | A/D | AN3 – ANo | 56 – 53 | 48 – 45 | 58 – 55 | ı | Analog Input: Analog signal input pins. | | | converter | AN7 - AN4* | | | 62 – 59 | | | _ | | | AVcc | 57 | 49 | 63 | ı | Analog Reference Voltage: Reference | | | | | | | | | voltage pin for the A/D converter. | _ | | | AVss | 52 | 44 | 54 | 1 | Analog Ground: Ground pin for the A/D | | | | | | | | | converter. | _ | | | ADTRG | 5 | 61 | 7 | 1 | A/D External Trigger: External trigger input pin | | | | | | | | | for the A/D converter. | _ | | Parallel | P17 P10 | 10-3 | 2-1, | 12-5 | 1/0 | Port 1: An 8-bit input/output port. The direction | | | 1/0 | | | 64 - 59 | | | of each bit is determined by the port 1 data | | | | | | | DataShee | et4[] | direction register (P1DDR). | - 1-Ch | | | P27 - P20 | 25 – 18 | 17 – 10 | | 1/0 | Port 2: An 8-bit input/output port. The direction | - DataSh | | | | | | | | of each bit is determined by the port 2 data | | | | | | | | | direction register (P2DDR). | | | | P37 - P30 | 33 – 26 | 25 – 18 | 35 – 28 | 1/0 | | • | | | | | | | | of each bit is determined by the port 3 data | | | | | | | | | direction register (P3DDR). These pins have | | | | | | | | | built-in MOS input pull-ups. They can drive LED | | | | | | | | | indicators. | | | | P47 - P40 | 41 – 34 | 33 – 26 | 43 – 36 | 1/0 | | - | | | 177-170 | 71 0. | 00 =0 | 10 00 | " + | of each bit is determined by the port 4 data | | | | | | | | | direction register (P4DDR). These pins have | | | | | | | | | built-in MOS input pull-ups. | | | | | | | | | Built-III WOO Input puirups. | _ | Note: \* CP-68 only 21 **HITACHI** www.DataSheet4U.com et4U.com ## wwwTable 1254 Pin Functions (cont) | | | | Pin No. | | | T-49-19-16 | | |------------------------|-------------------------|---------|---------|--------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | | | DC-64S | FP-64A | CP-68 | | | | | Туре | Symbol | DP-64S | _ | | I/O | Name and Function | | | Parallel<br>I/O (cont) | P57 P50 | 50 – 43 | 42 – 35 | 52 – 45 | I/O | Port 5: An 8-bit input/output port. The direction of each bit is determined by the port 5 data direction register (P5DDR). These pins have Schmitt inputs. | | | | P63 - P60<br>P67 - P64* | 56 – 53 | 48 – 45 | 58 - 55<br>62 - 59 | 1 | Port 6: A 4-bit (or 8-bit*) input port. | | | | P75 – P70 | 63 – 58 | 55 – 50 | 2 - 1,<br>68 - 64, | 1/0 | Port 7: A 6-bit input/output port. The direction of each bit is determined by the port 7 data direction register (P7DDR). | | Note: \* CP-68 package only et4U.com DataSheet4U.com www.DataSheet4U.com DataShe ## Section 2 MCU Operating Modes and Address Space 2.1 Overview T-49-19-16 The H8/520 microcomputer unit (MCU) operates in five modes numbered 1, 2, 3, 4, and 7. The mode is selected by the inputs at the mode pins (MD2 to MD0) at the instant when the chip comes out of a reset. As indicated in table 2-1, the MCU mode determines the size of the address space, the usage of on-chip ROM, and the operating mode of the CPU. The MCU mode also affects the functions of I/O pins. **Table 2-1 Operating Modes** | MD2 | MD1 | MD0 | MCU Mode | Address Space | On-Chip RAM | On-Chip ROM | CPU Mode | | |-----|-----|-----|----------|-----------------------|-------------|-------------|--------------|--| | 0 | 0 | 0 | Mode 0 | _ | <u> </u> | | | | | 0 | 0 | 1 | Mode 1 | Expanded minimum | Enabled* | Disabled | Minimum mode | | | 0 | 1 | 0 | Mode 2 | Expanded minimum | Enabled* | Enabled | Minimum mode | | | 0 | 1 | 1 | Mode 3 | Expanded maximum | Enabled* | Disabled | Maximum mode | | | 1 | 0 | 0 | Mode 4 | Expanded maximum | Enabled* | Enabled | Maximum mode | | | 1 | 0 | 1 | Mode 5 | - | | | | | | 1 | 1 | 0 | Mode 6 | Hardware standby mode | | | | | | 1 | 1. | 1 | Mode 7 | Single-chip only | Enabled* | Enabled | Minimum mode | | Notation: 0: Low level 1: High level -: Cannot be used et4U.com Note: \* On-chip RAM can be disabled by RAME bit to 0 in RAM control register (RAMCR). DataShe Modes 1 to 4 are referred to as "expanded" because they permit access to off-chip memory and peripheral addresses. The expanded minimum modes (modes 1 and 2) support a maximum address space of 64 kbytes. The expanded maximum modes (modes 3 and 4) support a maximum address space of 1 Mbyte. Interrupt service is slightly slower in the expanded maximum modes than in the other modes because the CPU has to save its code page register. The H8/520 cannot be set to modes 0 and 5. The mode pins should never be set to these values. The hardware standby mode (mode 6) is a power-down mode, not an operating mode. See section 17.4, "Hardware Standby Mode" for details. HITACHI 23 ### 2.2 Mode Descriptions T-49-19-16 The five MCU modes are described below. For further information on the I/O pin functions in each mode, see section 9, "I/O ports." Mode 1 (Expanded Minimum Mode): Mode 1 supports a maximum 64-kbyte address space which does not include any on-chip ROM. Ports 1 to 4 are used for bus lines and bus control signals as follows: Control signals: Port 1 (partly) Data bus: Port 2 Address bus: Ports 3 and 4 Mode 2 (Expanded Minimum Mode): Mode 2 supports a maximum 64-kbyte address space of which the first 16 kbytes are in on-chip ROM. Ports 1 to 4 are used for bus lines and bus control signals as follows: Control signals: Port 1 (partly) Data bus: Port 2 Address bus: Ports 3 and 4 Note: In mode 2, port 4 is initially a general-purpose input port. Software must change the desired pins to output before using them for the address bus. See section 9.5, "Port 4" for details. The following instruction makes all pins of port 4 into output pins: DataSheet4U.com MOV.B #H'FF, @H'FF85 DataShe Mode 3 (Expanded Maximum Mode): Mode 3 supports a maximum 1-Mbyte address space which does not include any on-chip ROM. Ports 1 to 4 and one pin in port 7 are used for bus lines and bus control signals as follows: Control signals: Port 1 (partly) Data bus: et4U.com Port 2 Address bus: Ports 1 (partly), 3, 4, and 7 (partly) HITACHI 24 PataSheet4U.com www.DataSheet4U.com ww.DataSheet4U.com Mode 4 (Expanded Maximum Mode): Mode 4 supports a maximum 1-Mbyte address space of which the first 16 kbytes are in on-chip ROM. Ports 1 to 4 and one pin in port 7 are used for bus lines and bus control signals as follows: Control signals: Port 1 (partly) Data bus: Port 2 Address bus: Ports 1 (page 1) Ports 1 (partly), 3, 4, and 7 (partly) Note: In mode 4, port 4, pins 2 to 4 of port 1, and pin 2 of port 7 are initially used for general-purpose input. Software must change the desired pins to output before using them for the address bus. See section 9, "I/O Ports" for details. Mode 7 (Single-Chip Mode): In this mode all memory is on-chip, in 16 kbytes of ROM and 512 bytes of RAM. It is not possible to access off-chip addresses. The single-chip mode provides the maximum number of ports. All the pins associated with the address and data buses in the expanded modes are available as general-purpose input/output ports in the single-chip mode. ### 2.3 Address Space Map #### 2.3.1 Page Segmentation The H8/520's address space is segmented into 64-kbyte pages. In the single-chip mode and expanded minimum modes there is just one page: page 0. In the expanded maximum modes there can be up to 16 pages. Figure 2-1 shows the address space in each mode and indicates which parts are on- and off-chip. DataShe T-49-19-16 **HITACHI** 25 et4U.com Figure 2-1 Address Space in Each Mode et4U.com DataSheet4U.com DataShe **HITACHI** 26 DataSheet4U.com www.DataSheet4U.com DataSheet4U.com #### 2.3.2 Page 0 Address Allocations T-49-19-16 The high and low address areas in page 0 are reserved for registers and vector tables. **Vector Tables:** The low address contains the exception vector table and DTC vector table. The CPU accesses the exception vector table to obtain the addresses of user-coded exception-handling routines. The DTC vector table contains pointers to tables of register information used by the on-chip chip data transfer controller. The size of these tables depends on the CPU operating mode. Details are given in section 4.1.2, "Exception Sources and Vector Table," section 5.2.3, "Interrupt Vector Table," and section 6.3.2, "DTC Vector Table." In modes 2, 4, and 7 the vector tables are located in on-chip ROM. In modes 1 and 3 the vector tables are in external memory. Register Field: The highest 128 addresses in page 0 (addresses H'FF80 to H'FFFF) belong to control, status, and data registers used by the I/O ports and on-chip supporting modules. Program code cannot be located at these addresses. The CPU accesses addresses in this register field like other addresses in the address space. By reading and writing at these addresses the CPU controls the on-chip supporting modules and communicates via the I/O ports. A complete map of the register field is given in appendix B. On-Chip RAM: One of the control registers in the register field is a RAM control register (RAMCR) containing a RAM enable bit (RAME) that enables or disables the 512-byte on-chip RAM. When this bit is set to 1 (its default value), addresses H'FD80 to H'FF7F are located on-chip. When this bit is cleared to 0, these addresses are located in external memory and the on-chip RAM is not used. See section 15, "RAM", for further information. The RAME bit is bit 7 at address H'FFF9. #### **Coding Example:** To enable on-chip RAM: BSET.B #7, H'FFF9 To disable on-chip RAM: BCLR.B #7, H'FFF9 Note: If on-chip RAM is disabled in the single-chip mode, access to addresses H'FD80 to H'FF7F causes an address error. HITACHI 27 www.DataSheet4U.com DataShe DataSneet4U.com et4U.com Figure 2-2 Map of Page 0 ## ww.DataSheet4U.com 2.4 Mode Control Register (MDCR) T-49-19-16 Another control register in the register field in page 0 is the mode control register (MDCR). The inputs at the mode pins are latched in this register on the rising edge of the signal. The mode control register can be read by the CPU, but not written. Table 2-2 lists the attributes of this register. Table 2-2 Mode Control Register | Name | Abbreviation | Read/Write | Address | |-----------------------|--------------|------------|---------| | Mode control register | MDCR | Read only | H'FFFA | The bit configuration of this register is shown below. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|---|---|---|------|------|------| | | | - | _ | | | MDS2 | MDS1 | MDS0 | | Initial value | 1 | 1 | 0 | 0 | 0 | * | * | * | | Read/Write | | _ | | _ | | R | R | R | Note: \* Initialized according to MD2 to MDo. Bits 7 and 6—Reserved: These bits cannot be modified and are always read as 1. Bits 5 to 3—Reserved: These bits cannot be modified and are always read as 0. et4U.com Bits 2 to 0—Mode Select 2 to 0 (MDS2 to MDS0): These bits indicate the values of the mode pins (MD2 to MD0) latched on the rising edge of the RES signal. MDS2 corresponds to MD2, MDS1 to MD1, and MDS0 to MD0. These bits can be read but not written. DataShe Coding example: To test whether the MCU is operating in mode 1: The comparison is with H'C1 instead of H'01 because bits 7 and 6 are always read as 1. HITACHI DataSheet4U.com ## Section 3 CPU #### 3.1 Overview The H8/520 chip has the H8/500 Family CPU: a high-speed central processing unit designed for real-time control of a wide range of medium-scale office and industrial equipment. It features eight 16-bit general registers, internal 16-bit data paths, and an optimized instruction set. Section 3 summarizes the CPU architecture and instruction set. #### 3.1.1 Features The main features of the H8/500 CPU are listed below. - · General-register machine - --- Eight 16-bit general registers - Seven control registers (two 16-bit registers, five 8-bit registers) - High speed: maximum 10-MHz clock - At 10 MHz a register-register add operation takes only 200 ns. - Address space managed in 64-kbyte pages, expandable to 1 Mbyte\* Page registers make four pages available simultaneously: a code page, stack page, data page, and extended page. - Two CPU operating modes: - Minimum mode: Maximum 64-kbyte address space - Maximum mode: Maximum 1-Mbyte address space\* - · Highly orthogonal instruction set - Addressing modes and data sizes can be specified independently within each instruction. - · 1.5 addressing modes - Register-register and register-memory operations are supported. - Optimized for efficient programming in C language In addition to the general registers and orthogonal instruction set, the CPU has special short formats for frequently-used instructions and addressing modes. - Note: \* The CPU Architecture supports up to 16 Mbytes of external memory, but the H8/520 chip has only enough address pins to address 1 Mbyte. **HITACH!** 31 www.DataSheet4U.com DataShe et4U.com #### 3.1.2 Address Space The address space size depends on the operating mode. T-49-19-16 The H8/520 MCU has five operating modes, which are selected by the input to the mode pins (MD2 to MD0) when the chip comes out of a reset. The CPU, however, has only two operating modes. The MCU operating mode determines the CPU operating mode, which in turn determines the maximum address space size as indicated in figure 3-1. Figure 3-1 CPU Operating Modes et4U.com DataSheet4U.com DataShe **HITACHI** 32 DataSheet4U.com Figure 3-2 shows the register structure of the CPU. There are two groups of registers: the general registers (Rn) and control registers (CR). Figure 3-2 Registers in the CPU 33 HITACHI DataSheet4U.com ## 3.2 CPU Register Descriptions ## T-49-19-16 #### 3.2.1 General Registers All eight of the 16-bit general registers are functionally alike; there is no distinction between data registers and address registers. When these registers are accessed as data registers, either byte or word size can be selected. R6 and R7, in addition to functioning as general registers, have special assignments. R7 is the stack pointer, used implicitly in exception handling and subroutine calls. It can be designated by the name SP, which is synonymous with R7. As indicated in figure 3-3, it points to the top of the stack. It is also used implicitly by the LDM and STM instructions, which load and store multiple registers from and to the stack and pre-decrement or post-increment R7 accordingly. R6 functions as a frame pointer (FP). The LINK and UNLK instructions use R6 implicitly to reserve or release a stack frame. Figure 3-3 Stack Pointer HITACHI 34 www.DataSheet4U.com DataShe # ww.DataSheet4U.com 3.2.2 Control Registers The CPU control registers include a 16-bit program counter (PC), a 16-bit status register (SR), four 8-bit page registers, and one 8-bit base register (BR). **Program Counter (PC):** This 16-bit register indicates the address of the next instruction the CPU will execute. Status Register (SR): This 16-bit register contains internal status information. The lower half of the status register is referred to as the condition code register (CCR): it can be accessed as a separate condition code byte. | | | | | | | | CCR | | | | | | | | | | |---|---|------|---|---|----|----|-----|---|---|---|--|---|---|-------------|---|---| | | | | | | | | | _ | | | | ~ | | <del></del> | _ | | | _ | | | | | | | | | | | | 3 | | | | _ | | | Т | <br> | — | _ | 12 | 11 | lo | - | - | - | | N | Z | ٧ | С | | Bit 15—Trace (T): When this bit is set to 1, the CPU operates in trace mode and generates a trace exception after every instruction. See section 4.4, "Trace", for a description of the trace exception-handling sequence. When the value of this bit is 0, instructions are executed in normal continuous sequence. This bit is cleared to 0 at a reset. et4U.com DataSheet4U.com Bits 14 to 11—Reserved: These bits cannot be modified and are always read as 0. DataShe Bits 10 to 8—Interrupt Mask (I2, I1, I0): These bits indicate the interrupt request mask level (0 to 7). As shown in table 3-1, an interrupt request is not accepted unless it has a higher level than the value of the mask. A nonmaskable interrupt (NMI), which has level 8, is accepted at any mask level. After an interrupt is accepted, I2, I1, and I0 are changed to the level of the interrupt. Table 3-2 indicates the values of the I bits after the interrupt is accepted. A reset sets all three bits (I2, I1, and I0) to 1, masking all interrupts except NMI. HITACHI 35 | | Mask | Ma | sk Bil | ts | ^; | | | | |----------|-------|----|--------|----|-----------------------|--|--|--| | Priority | Level | l2 | lı . | lo | Interrupts Accepted | | | | | High | 7 | 1 | 1 | 1 | NMI | | | | | <b>A</b> | 6 | 1 | 1 | 0 | Level 7 and NMI | | | | | | 5 | 1 | 0 | 1 | Levels 6 to 7 and NMI | | | | | | 4 | 1 | 0 | 0 | Levels 5 to 7 and NMI | | | | | | 3 | 0 | 1 | 1 | Levels 4 to 7 and NMI | | | | | | 2 | 0 | 1 | 0 | Levels 3 to 7 and NMI | | | | | | 1 | 0 | 0 | 1 | Levels 2 to 7 and NMI | | | | | Low | 0 | 0 | 0 | 0 | Levels 1 to 7 and NMI | | | | Table 3-2 Interrupt Mask Bits after an Interrupt is Accepted | Level of Interrupt Accepted | <u> 2</u> | <u>lı</u> | lo | | |-----------------------------|-------------|-----------|------------------|-------| | NMI (8) | 1 | 1 | 1 | | | 7 | 1 | 1 | 1 | | | 6 | 1 | 1 | 0 | | | 5 | 1 | 0 | 1 | | | 4 | 1 | 0 | 0 | | | 3 | 0 | 1 | 1 | | | 2 | 0 | Dat | aS <b>b</b> eet4 | U.com | | 1 | 0 | 0 | 1 | | et4U.com DataShe HITACHI 36 DataSheet4U.com Bit 3—Negative (N): This bit indicates the most significant bit (sign bit) of the result of an instruction. Bit 2—Zero (Z): This bit is set to 1 to indicate a zero result and cleared to 0 to indicate a nonzero result. Bit 1—Overflow (V): This bit is set to 1 when an arithmetic overflow occurs, and cleared to 0 at other times. Bit 0—Carry (C): This bit is set to 1 when a carry or borrow occurs at the most significant bit, and is cleared to 0 (or left unchanged) at other times. The specific changes that occur in the condition code bits when each instruction is executed are listed in appendix A.1 "Instruction Tables." See the H8/500 Series Programming Manual for further details. Page Registers: The code page register (CP), data page register (DP), extended page register (EP), and stack page register (TP) are 8-bit registers that are used only in the maximum mode. No use of their contents is made in the minimum mode. In the maximum mode, the page registers combine with the program counter and general registers to generate 24-bit effective addresses as shown in figure 3-4, thereby expanding the program area, data area, and stack area. et4U.com DataSheet4U.com 37 DataShe HITACHI Figure 3-4 Combinations of Page Registers with Other Registers Code Page Register (CP): The code page register and the program counter combine to generate at 24-bit program code address. The code page register contains the upper 8 bits of the address. In the maximum mode, the code page register is initialized at a reset to a value loaded from the vector table, and both the code page register and program counter are saved and restored in exception handling. Data Page Register (DP): The data page register combines with general registers R0 to R3 to generate a 24-bit effective address. The data page register contains the upper 8 bits of the address. It is used to calculate effective addresses in the register indirect addressing mode using R0 to R3, and in the 16-bit absolute addressing mode (@aa:16), but not in the short absolute addressing mode (@aa:8). The data page register is rewritten by the LDC instruction. **HITACHI** 38 DataSheet4U.com www.DataSheet4U.com Extended Page Register (EP): The extended page register combines with general register R4 or R5 to generate a 24-bit operand address. The extended page register contains the upper 8 bits of the address. It is used to calculate effective addresses in the register indirect addressing mode using R4 or R5. The extended page can be used as an additional data page. T-49-19-16 Stack Page Register (TP): The stack page register combines with R6 (FP) or R7 (SP) to generate a 24-bit stack address. The stack page register contains the upper 8 bits of the address. It is used to calculate effective addresses in the register indirect addressing mode using R6 or R7, in exception handling, and in subroutine calls. Base Register (BR): This 8-bit register stores the base address used in the short absolute addressing mode (@aa:8). In this addressing mode a 16-bit effective address in page 0 is generated by using the contents of the base register as the upper 8 bits and an address given in the instruction code as the lower 8 bits. See figure 3-5. In the short absolute addressing mode the address is always located in page 0. Figure 3-5 Short Absolute Addressing Mode and Base Register HITACHI 39 ### 3.2.3 Initial Register Values When the CPU is reset, its internal registers are initialized as shown in table 3-3. Note that the stack pointer (R7) and base register (BR) are not initialized to fixed values. Also, of the page registers used in maximum mode, only the code page register (CP) is initialized; the other three page registers come out of the reset state with undetermined values. Accordingly, in the minimum mode the first instruction executed after a reset should initialize the stack pointer. The base register must also be initialized before the short absolute addressing mode (@aa:8) is used. In the maximum mode, the first instruction executed after a reset should initialize the stack page register (TP) and the next instruction should initialize the stack pointer. Later instructions should initialize the base register and the other page registers as necessary. et4U.com DataSheet4U.com DataShe HITACHI 40 DataSheet4U.com | | | Initial Value | | | |-------------------|--------|--------------------------------------|--------------------------|--------------| | Register | | Minimum Mode | Maximum Mode | <del>-</del> | | General registers | | | | - | | 15 | 0 | Undetermined | Undetermined | | | R7 - R0 | | | | | | Control registers | | | | | | 15 | 0 | Loaded from vector table | Loaded from vector table | | | PC | | | | | | SR | | | · | | | | | | | | | CCR | | | | | | | | | | | | 15 8 7 | _0<br> | H'070* | H'070* | | | T l2l1l0 NZVC | | (*: undetermined) | (*: undetermined) | | | 7 | 0 | | | | | СР | | Undetermined | Loaded from vector table | | | 7 | 0 | | | | | DP | | Undetermined | Undetermined | | | 7 | 0 | | | | | EP | | Undetermined | Undetermined | | | 7 | 0 | | | | | TP | | Data Sheet 4 U. com.<br>Undetermined | Undetermined | Data | | 7 | 0 | | | | | BR | | Undetermined | Undetermined | | ### 3.3 Data Formats The H8/500 can process 1-bit data, 4-bit BCD data, 8-bit (byte) data, 16-bit (word) data, and 32-bit (longword) data. - Bit manipulation instructions operate on 1-bit data. - Decimal arithmetic instructions operate on 4-bit BCD data. - Almost all instructions operate on byte and word data. - Multiply and divide instructions operate on longword data. 41 HITACHI www.DataSheet4U.com Data of all the sizes above can be stored in general registers as shown in table 3-4. Bit data locations are specified by bit number. Bit 15 is the most significant bit. Bit 0 is the least significant bit. BCD and byte data are stored in the lower 8 bits of a general register. Word data use all 16 bits of a general register. Longword data use two general registers: the upper 16 bits are stored in Rn (n must be an even number); the lower 16 bits are stored in Rn+1. Operations performed on BCD data or byte data do not affect the upper 8 bits of the register. Table 3-4 General Register Data Formats | Data Type | Register No. | Data Structure | | |-----------|--------------|-------------------------------------------------------------|-------------| | 1-Bit | Pn | 15 0<br>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | | | Rn | 15 14 10 12 11 10 3 0 7 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 | . <u> </u> | | BCD | | 15 8 7 4 3 0 | | | | Rn | Don't-care Upper digit Lower digit | | | Byte | | 15 8 7 0 | | | • | Rn | Don't-care MSB LSB | | | Word | | 15 0 | | | | Rn | MSB DataSheet4U.com LSB | DataShe | | Longword | | 31 16 | <del></del> | | | Rn* | MSB Upper 16 bits | | | | Rn + 1* | Lower 16 bits LSB | · | | | | 15 0 | | Note: \* For longword data, n must be even (0, 2, 4, or 6). HITACHI 42 DataSheet4U.com Table 3-5 indicates the data formats in memory. Instructions that access bit data in memory have byte or word operands. The instruction specifies a bit number to indicate a specific bit in the operand. Access to word data in memory must always begin at an even address. Access to word data starting at an odd address causes an address error. The upper 8 bits of word data are stored in address n (where n is an even number); the lower 8 bits are stored in address n+1. **Table 3-5 Data Formats in Memory** When the stack is accessed in exception processing (to save or restore the program counter, code page register, or status register), word access is always performed, regardless of the actual data size. Similarly, when the stack is accessed by an instruction using the pre-decrement or post-increment register indirect addressing mode specifying R7 (@-R7 or @R7+), which is the stack pointer, word access is performed regardless of the operand size specified in the instruction. An address error will therefore occur if the stack pointer indicates an odd address. Programs should be coded so that the stack pointer always indicates an even address. Table 3-6 shows the data formats on the stack. HITACHI 43 ### 3.4 Instructions #### 3.4.1 Basic Instruction Formats There are two basic CPU instruction formats: the general format and the special format. General Format: This format consists of an effective address (EA) field, an effective address extension field, and an operation code (OP) field. The effective address is placed before the operation code because this results in faster execution of the instruction. DataSheet4U.com • Effective address field: One byte containing information used to calculate the effective address of an operand. • Effective address extension: Zero to two bytes containing a displacement value, immediate data, or an absolute address. The size of the effective address extension is specified in the effective address field. • Operation code: Defines the operation to be carried out on the operand located at the address calculated from the effective address information. Some instructions (DADD, DSUB) have an extended format in which the operand code is preceded by a one-byte prefix code. HITACHI 44 DataSheet4U.com et4U.com www.DataSheet4U.com DataShe | Effective address | Prefix code | Operation code | |-------------------|-------------|----------------| | 10100rrr | 0000000 | 10100rrr | **Special Format:** In this format the operation code comes first, followed by the effective address field and effective address extension. This format is used in branching instructions, system control instructions, and other instructions that can be executed faster if the operation is specified before the operand. | Operation code | Effective address field | Effective address extension | |----------------|-------------------------|-----------------------------| | | | <br> | - Operation code: One or two bytes defining the operation to be performed by the instruction. - Effective address field and effective address extension: Zero to three bytes containing information used to calculate an effective address. ### 3.4.2 Addressing Modes The CPU supports 7 addressing modes: (1) register direct; (2) register indirect; (3) register indirect with displacement; (4) register indirect with pre-decrement or post-increment; (5) immediate; (6) absolute; and (7) PC-relative. DataSheet4U.com Due to the highly orthogonal nature of the instruction set, most instructions having operands can use any applicable addressing mode from (1) through (6). The PC-relative mode (7) is used by branching instructions. In most instructions, the addressing mode is specified in the effective address field. The effective-address extension, if present, contains a displacement, immediate data, or an absolute address. Table 3-7 indicates how the addressing mode is specified in the effective address field. 45 HITACHI www.DataSheet4U.com DataShe Table 3-7 Addressing Modes T-49-19-16 | No. | Addressing Mode | Mnemonic | EA Field | EA Extension | | |-----|----------------------------------------------------------------|-------------------------|------------------------------------------------------------------|------------------------------------------|----------| | 1 | Register direct | Rn | 1 0 1 0 Sz r.rr<br>*1 *2 | None | | | 2 | Register indirect | @Rn | 1 1 0 1 Sz r r r | None | | | 3 | Register indirect with displacement | @(d:8,Rn) | 1110 Szrrr | Displacement (1 byte) | | | | With displacement | @(d:16,Rn) | 1111Szrrr | Displacement (2 bytes) | • | | 4 | Register indirect | @-Rn | 1011Szrrr | | _ | | | with pre-decrement<br>Register indirect<br>with post-increment | @Rn+ | 1100 Szrrr | None | | | 5 | Immediate | #xx:8 | 00000100 | Immediate data (1 byte) | | | | | #xx:16 | 00001100 | Immediate data (2 bytes) | | | 6 | Absolute*3 | @aa:8 | 0 0 0 0 Sz 1 0 1 | 1-Byte absolute address | _ | | | | DataSh<br><b>@aa:16</b> | neet4 <del>U.ssm.</del><br>0 0 0 1 Sz 1 0 1 | (offset from BR) 2-Byte absolute address | DataShee | | 7 | PC-relative | disp | No EA field. Addressing mode is specified in the operation code. | 1- or 2-byte displacement | | et4U.com Notes: 1. Sz: Specifies the operand size. When Sz = 0: byte operand When Sz = 1: word operand 2. rrr: Register number field, specifying a general register number. 0 0 0—Ro 0 0 1—R1 0 1 0—R2 1 0 0—R4 1 0 1—R5 1 1 0—R6 0 1 1 ---R3 1 1 0—R6 1 1 1—R<sub>7</sub> 3. The @aa:8 addressing mode is also referred to as the short absolute addressing mode. HITACHI 46 DataSheet4U.com ## ww.DataSheet4U.com 3.4,3 Effective Address Calculation Table 3-8 explains how the effective address is calculated in each addressing mode. **Table 3-8 Effective Address Calculation** T-49-19-16 | No. | Addressing Mode | Effective Address Calculation | Effective Address | |-----|------------------------------------------------------------|-----------------------------------------------------------------|---------------------------------| | 1 | Register direct<br>Rn | _ | Operand is contents of Rn | | | 1010Sz rrr | | | | 2 | Register indirect<br>@Rn | | 23 15 0 | | | 1101Sz rrr | | Or TP or EP | | 3 | Register indirect with displacement @(d:8, Rn) 1110Sz rrr | 8 Bits<br>15 0<br>Rn | 23 15 0 DP Result Or TP or EP | | | | Displacement with sign extension | | | | @(d:16, Rn)<br>1111Sz rrr | 16 Bits<br>15 0<br>Rn | 23 15 0 DP Result | | | | 15 0 + | Or TP or EP | | 4 | Register indirect with pre-decrement | DataSheet4U.com | 23 15 0 DataSI | | | @-Rn<br>1011Sz rrr | 1 or 2 *3 | Or TP or EP*2 | | | | Rn is decremented by -1 or -2 before instruction execution. *4 | | | | Register indirect with post-increment | | 23 15 0<br>DP*1 Result | | | @Rn + 1100Sz rrr | | Or TP or EP <sup>2</sup> | | | | Rn is incremented by +1 or +2 after instruction execution. *3.4 | | Notes: 1. The page register is ignored in minimum mode. - 2. The page register used in addressing modes 2, 3, and 4 depends on the general register: DP for R0, R1, R2, or R3; EP for R4 or R5; TP for R6 or R7. - 3. Decrement by -1 for a byte operand, and by -2 for a word operand. - 4. The pre-decrement or post-increment is always ±2 when R7 is specified, even if the operand is byte size. 47 HITACHI www.DataSheet4U.com Table 3-8 Effective Address Calculation (cont) Note: The drawing below shows what happens when the @-SP and @ SP+ addressing modes are used to save and restore the stack pointer. HITACHI 48 DataSheet4U.com ### .or . - daleend nocypal 122 mHIL3 #### 3.5.1 Overview 3.5 Instruction Set T-49-19-16 The main features of the CPU instruction set are: - A general-register architecture. - Orthogonality. Addressing modes and data sizes can be specified independently in each instruction. - · Register-register and register-memory operations are supported. - Affinity for high-level languages, particularly C, with short formats for frequently-used instructions and addressing modes. - · Standard mnemonics, common throughout the H Series. The CPU instruction set includes 61 (63)\*1 types of instructions, listed by function in table 3-9. **Table 3-9 Instruction Classification** | Function | Instructions | Types | |-----------------------|-------------------------------------------------------------------------------------------------|-----------| | Data transfer | MOV, LDM, STM, XCH, SWAP, (MOVTPE, MOVFPE)*1 | 5 (7)*1 | | Arithmetic operations | ADD, SUB, ADDS, SUBS, ADDX, SUBX, DADD, DSUB, MULXU, DIVXU, CMP, EXTS, EXTU, TST, NEG, CLR, TAS | 17 | | Logic operations | AND, OR, XOR, NOT | 4 | | Shift | SHAL, SHAR, SHLL, SHLR, ROTL, ROTR, ROTXL, ROTXR | 8 | | Bit manipulation | BSET, BCLR, BTST, BNOT | 4 | | Branch | Bcc*2, JMP, PJMP, BSR, JSR, PJSR, RTS, PRTD, PRTS, RTD, SCB (/F, /NE, /EQ) | 11 | | System control | TRAPA, TRAP/VS, RTE, SLEEP, LDC, STC, ANDC, ORC, XORC, NOP, LINK, UNLK | 12 | | , | Total | 61 (63)*1 | Notes: 1. The H8/520 chip does not have an E clock output pin, so it does not support the MOVTPE and MOVFPE instructions. H8/520 software should not use these instructions. 2. Bcc is a conditional branch instruction in which cc represents a condition code. Tables 3-10 to 3-16 give a concise summary of the instructions in each functional category. The MOV, ADD, and CMP instructions have special short formats, which are listed in table 3-17. For detailed descriptions of the instructions, refer to the H8/500 Series Programming Manual. HITACHI 49 www.DataSheet4U.com DataShe ataSheet411 com ### The notation used in tables 3-10 to 3-17 is defined below. | T-49-19 | 9–16 | |---------|------| |---------|------| | Operation | Notation | |-----------|--------------------------------| | Rd | General register (destination) | | Rs | General register (source) | | Rn | General register | | (EAd) | Destination operand | | (EAs) | Source operand | | CCR | Condition code register | | N | N (negative) bit of CCR | | Z | Z (zero) bit of CCR | | V | V (overflow) bit of CCR | | C | C (carry) bit of CCR | | CR | Control register | | PC | Program counter | | СР | Code page register | | SP | Stack pointer | | FP | Frame pointer | | #IMM | Immediate data | | disp | Displacement | | + | Addition | | | Subtraction | | × | Multiplication | | + | Division DataSneet+0.com | | ^ | AND logical | | <b>v</b> | OR logical | | <b>⊕</b> | Exclusive OR logical | | <b>→</b> | Move | | ↔ | Exchange | | _ | Not | et4U.com DataShe **HITACHI** 50 DataSheet4U.com #### 3.5.2 Data Transfer Instructions T-49-19-16 Table 3-10 describes the seven data transfer instructions. **Table 3-10 Data Transfer Instructions** | Instruction | | Size*2 | Function | |-------------|-------------|--------|------------------------------------------------------------| | Data | MOV | | $(EAs) \rightarrow (EAd), \#IMM \rightarrow (EAd)$ | | transfer | / MOV:G | B/W | Moves data between two general registers, or between | | | MOV:E | В | a general register and memory, or moves immediate data | | | MOV:I | W | to a general register or memory. | | | MOV:F | B/W | | | | MOV:L | B/W | | | | Mov:s | B/W | | | | LDM | M | Stack → Rn (register list) | | | | | Pops data from the stack to one or more registers. | | | STM | W | Rn (register list) → stack | | | | | Pushes data from one or more registers onto the stack. | | | ХСН | W | Rs ↔ Rd | | | | | Exchanges data between two general registers. | | | SWAP | В | Rd (upper byte) ↔ Rd (lower byte) | | | | | Exchanges the upper and lower bytes in a general register. | | | (MOVTPE) *1 | | Not supported by the H8/520 | | | (MOVFPE)*1 | | □ Not supported by the H8/520 | et4U.com Notes: 1. The H8/520 does not have an E clock output pin, so it does not support the MOVTPE and MOVFPE instructions. H8/520 software should not use these instructions. If the MOVTPE and MOVFPE instructions are used, the H8/520 executes them in the number of cycles indicated in figures A and B. From 7 to 14 wait states (Tw) are automatically inserted between the T2 state and T3 state to synchronize the bus cycle with an internal E clock obtained by dividing the system clock (Ø) by eight. Accordingly, the number of cycles taken by a MOVTPE or MOVFPE instruction varies. Note that no wait states (Tw) are inserted by the wait state controller. 2. B: Byte, W: Word HITACHI DataShe Figure A Execution Cycle Length of MOVTPE and MOVFPE Instructions in Expanded Modes (Maximum Number of Cycles) Figure B Execution Cycle Length of MOVTPE and MOVFPE Instructions in Expanded Modes (Minimum Number of Cycles) HITACHI 52 DataSheet4U.com www.DataSheet4U.com DataShe ### 3.5.3 Arithmetic Instructions Table 3-11 describes the 17 arithmetic instructions. **Table 3-11 Arithmetic Instructions** T-49-19-16 | Instruction | | Size | Function | | |-------------|-------|------|------------------------------------------------------------------------------------|-----| | Arithmetic | ADD | | $Rd \pm (EAs) \rightarrow Rd$ , (EAd) $\pm \#IMM \rightarrow (EAd)$ | | | operations | ADD:G | B/W | Performs addition or subtraction on data in a general register and | | | | Q:DDA | B/W | data in another general register or memory, or on data in a general | | | | SUB | B/W | register or memory and immediate data. | | | | ADDS | B/W | | | | | SUBS | B/W | | | | | ADDX | B/W | $Rd \pm (EAs) \pm C \rightarrow Rd$ | | | | SUBX | B/W | Performs addition or subtraction with carry or borrow on data in a | | | | | | general register and data in another general register or memory, or on | | | | | | data in a general register and immediate data. | | | | DADD | В | $(Rd)_{10} \pm (Rs)_{10} \pm C \rightarrow (Rd)_{10}$ | | | | DSUB | В | Performs decimal addition or subtraction on data in two general | | | | | | registers. | | | | MULXU | B/W | $Rn \times (EAs) \rightarrow Rd$ | | | | | | Performs 8-bit $\times$ 8-bit or 16-bit $\times$ 16-bit unsigned multiplication on | | | | • | | data in a general register and data in another general register or | | | | | | memory or on data in a general register and immediate data. | taS | | | DIAXA | в/₩ | Rd ÷ (EAs) → Rd | | | | | | Performs 16-bit + 8-bit or 32-bit + 16-bit unsigned division on data in | | | | | | a general register and data in another general register or memory, | | | | | | or on data in a general register and immediate data. | | | | CMP | | Rn – (EAs), (EAd) – #IMM | | | | CMP:G | B/W | Compares data in a general register with data in another general | | | | CMP:E | В | register or memory, or with immediate data, or compares data in | | | | CMP:I | W | memory with immediate data. | | | | | | | | et4U.com HITACHI **Table 3-11 Arithmetic Instructions (cont)** | Instruction | | Size | Function | |-------------|------|------|--------------------------------------------------------------------------------------------------------| | Arithmetic | EXTS | В | ( <bit 7=""> of <rd>) <math>\rightarrow</math> (<bits 15="" 8="" to="">of <rd>)</rd></bits></rd></bit> | | operations | | | Converts byte data in a general register to word data by extending | | | | | the sign bit. | | | EXTU | В | 0 → ( <bits 15="" 8="" to=""> of <rd>)</rd></bits> | | | | | Converts byte data in a general register to word data by padding | | | | | with zero bits. | | | TST | B/W | (EAd) – 0 | | | | | Compares general register or memory contents with 0. | | | NEG | B/W | 0 - (EAd) → (EAd) | | | | | Obtains the two's complement of general register or memory | | | | | contents. | | | CLR | B/W | 0 → (EAd) | | | | | Clears general register or memory contents to 0. | | | TAS | В | $(EAd) - 0$ , $(1)_2 \rightarrow ( of )$ | | | | | Tests general register or memory contents, then sets the most | | | | | significant bit (bit 7) to 1. | ### 3.5.4 Logic Operations Table 3-12 lists the four instructions that perform logic operations. **Table 3-12 Logic Operation Instructions** | Instruction | | Size | Function | | | |-------------|-----|------|---------------------------------------------------------------------|--|--| | Logical | AND | B/W | $Rd \wedge (EAs) \rightarrow Rd$ | | | | operations | | | Performs a logical AND operation on a general register and another | | | | | | | general register, memory, or immediate data. | | | | | OR | B/W | Rd ∨ (EAs) → Rd | | | | | | | Performs a logical OR operation on a general register and another | | | | | | | general register, memory, or immediate data. | | | | | XOR | B/W | Rd ⊕ (EAs) → Rd | | | | | | | Performs a logical exclusive OR operation on a general register and | | | | | | | another general register, memory, or immediate data. | | | | | NOT | B/W | $\neg$ (EAd) $\rightarrow$ (EAd) | | | | | | | Obtains the one's complement of general register or memory | | | | | | | contents. | | | HITACHI 54 www.DataSheet4U.com DataShe www.DataSheet4U.com Table 3-13 lists the eight shift instructions. **Table 3-13 Shift Instructions** 3.5.5 Shift Operations T-49-19-16 | Instruction | | Size | Function | |-------------|-------|------|------------------------------------------------------------------------| | Shift | SHAL | B/W | (EAd) shift → (EAd) | | operations | SHAR | B/W | Performs an arithmetic shift operation on general register or memory | | | | | contents. | | | SHLL | B/W | (EAd) shift → (EAd) | | | SHIR | B/W | Performs a logical shift operation on general register or memory | | | | | contents. | | | ROTL | B/W | (EAd) rotate → (EAd) | | | ROTR | B/W | Rotates general register or memory contents. | | | ROTXL | B/W | (EAd) rotate through carry → (EAd) | | | ROTXR | B/W | Rotates general register or memory contents through the C (carry) bit. | et4U.com DataSheet4U.com DataShe HITACHI 55 ### 3.5.6 Bit Manipulations Table 3-14 describes the four bit-manipulation instructions **Table 3-14 Bit-Manipulation Instructions** T-49-19-16 | Instruction | | Size | Function | |---------------|------|------|------------------------------------------------------------------------------------------------------------------------------------------| | Bit | BSET | B/W | $\neg$ ( <bit-no.> of <ead> <math>\rightarrow</math> Z, 1 <math>\rightarrow</math> (<bit-no.> of <ead>)</ead></bit-no.></ead></bit-no.> | | manipulations | | | Tests a specified bit in a general register or memory, then sets the | | | | | bit to 1. The bit is specified by a bit number given in immediate data | | | | | or a general register. | | | BCLR | B/W | $\neg$ ( <bit-no.> of <ead>) <math>\rightarrow</math> Z, 0 <math>\rightarrow</math> (<bit-no.> of <ead>)</ead></bit-no.></ead></bit-no.> | | | | | Tests a specified bit in a general register or memory, then clears the | | | | | bit to 0. The bit is specified by a bit number given in immediate data | | | | | or a general register. | | | BNOT | B/W | $\neg$ ( <bit-no.> of <ead>) <math>\rightarrow</math> Z, <math>\rightarrow</math> (<bit-no.> of <ead>)</ead></bit-no.></ead></bit-no.> | | | | | Tests a specified bit in a general register or memory, then inverts the | | | | | bit. The bit is specified by a bit number given in immediate data or a | | | | | general register. | | | BTST | B/W | $\neg$ ( <bit-no.> of <ead>) <math>\rightarrow</math> Z</ead></bit-no.> | | | | | Tests a specified bit in a general register or memory. The bit is | | | | | specified by a bit number given in immediate data or a general | | | | | register. | et4U.com - DataSheet4U.com DataShe **HITACHI** 56 ## www.DataSheet4U.com 3.5.7 Branching Instructions Table 3-15 describes the 11 branching instructions T-49-79-16 **Table 3-15 Branching Instructions** | Branch Bcc Branches if condition cc is true. Mnemonic Description Cond BRA (BT) Always (true) True BRN (BF) Never (false) False BHI High C ∨ Z BLS Low or Same C ∨ Z BCC (BHS) Carry Clear (High or Same) BCS (BLO) Carry Set (Low) C = 1 BNE Not Equal Z = 0 | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | BRA (BT) Always (true) True BRN (BF) Never (false) False BHI High C V Z BLS Low or Same C V Z BCC (BHS) Carry Clear C = 0 (High or Same) BCS (BLO) Carry Set (Low) C = 1 | | | BRN (BF) Never (false) False BHI High C ∨ Z BLS Low or Same C ∨ Z BCC (BHS) Carry Clear C = 0 (High or Same) BCS (BLO) Carry Set (Low) C = 1 | = 0 | | BHI High C V Z BLS Low or Same C V Z BCC (BHS) Carry Clear C = 0 (High or Same) BCS (BLO) Carry Set (Low) C = 1 | <b>=</b> 0 | | BLS Low or Same $C \vee Z$ BCC (BHS) Carry Clear $C = 0$ (High or Same) BCS (BLO) Carry Set (Low) $C = 1$ | = 0 | | BCC (BHS) Carry Clear C = 0 (High or Same) BCS (BLO) Carry Set (Low) C = 1 | | | (High or Same) BCS (BLO) Carry Set (Low) C = 1 | = 1 | | BCS (BLO) Carry Set (Low) C = 1 | | | · · · · · · · · · · · · · · · · · · · | | | PME Not Equal $7 = 0$ | | | DNE Not Educi. | | | BEQ Equal $Z = 1$ | | | BVC Overflow Clear $V = 0$ | | | BVS Overflow Set V = 1 | | | BPL Plus $N = 0$ | | | BMI Minus N = 1 | | | BGE DataSheet4 Greater or Equal N ⊕ V | /=0<br><sub>Data</sub> She | | BLT Less Than N + V | /=1 | | BGT Greater Than Z v (N | N ⊕ V) = 0 | | BLE Less or Equal Z v (N | N ⊕ V) = 1 | | | | | JMP — Branches unconditionally to a specified address | s in the same page. | | PJMP — Branches unconditionally to a specified address | s in a specified page. | | BSR — Branches to a subroutine at a specified address | s in the same page. | | JSR — Branches to a subroutine at a specified address | s in the same page. | | PJSR — Branches to a subroutine at a specified address | s in a specified page. | | RTS — Returns from a subroutine in the same page. | | HITACHI www.DataSheet4U.com ETIH**ER** 891 9482200 6029646 LP8 ### Table 3-15 Branching Instructions (cont) T-49-19-16 DataShe | Instruction | | Size | Function | |-------------|--------|------|---------------------------------------------------------------------| | Branch | PRTS | | Returns from a subroutine in a different page. | | | RTD | | Returns from a subroutine in the same page and adjusts the stack | | | | | pointer. | | | PRTD | | Returns from a subroutine in a different page and adjusts the stack | | | | | pointer. | | | SCB/F | | Controls a loop using a loop counter and/or a specified termination | | | SCB/NE | _ | condition. | | | SCB/EQ | | | et4U.com DataSheet4U.com **HITACHI** 58 DataSheet4U.com www.DataSheet4U.com # www.DataSheet4U.com 3.5.8 System Control Instructions Table 3-16 describes the 12 system control instructions. T-49-19-16 **Table 3-16 System Control Instructions** | Instruction | | Size | Function | | |-------------|---------------|-------------|--------------------------------------------------------------------------|--------| | System | TRAPA | | Generates a trap exception with a specified vector number. | | | control | TRAP/VS | | Generates a trap exception if the V bit is set to 1 when the instruction | | | | | | is executed. | | | | RTE | | Returns from an exception-handling routine. | | | | LINK | | $FP \rightarrow @-SP; SP \rightarrow FP; SP + \#IMM \rightarrow SP$ | | | | | | Creates a stack frame. | | | | UNTK | <del></del> | FP → SP; @SP + → FP | | | | • | | Deallocates a stack frame created by the LINK instruction. | | | | SLEEP | | Causes a transition to the power-down state. | | | | LDC | в/w* | (EAs) → CR | | | | | | Moves immediate data or general register or memory contents to a | | | | | | specified control register. | | | | STC | B/W* | CR → (EAd) | | | | | | Moves control register data to a specified general register or memory | | | | | | location. | _ | | | ANDC | B/W* | CR ∧ #IMM → CR | | | | <del></del> - | - | Logically ANDs a control register with immediate data. | Oh | | | ORC | B/W* | CR ∨ #IMM → CR | DataSh | | | | - | Logically ORs a control register with immediate data. | | | | XORC | B/W* | CR ⊕ #IMM → CR | | | | | - | Logically exclusive-ORs a control register with immediate data. | | | | NOP | | PC + 1 → PC | | | | | | No operation. Only increments the program counter. | | 59 Note: \* The size depends on the control register. **HITACHI** DataSheet4U.com www.DataSheet4U.com When using the LDC and STC instructions to stack and unstack the BR, CCR, TP, DP, and EP control registers in the H8/500 family, note the following point. T-49-19-16 H8/500 hardware does not permit byte access to the stack. If the LDC.B or STC.B assembler mnemonic is coded with the @R7+ (@SP+) or @-R7 (@-SP) addressing mode, the stack-pointer addressing mode takes precedence and hardware automatically performs word access. Specifically, the LDC.B and STC.B instructions are executed as follows. The following applies only to the stack-pointer addressing modes. In addressing modes that do not use the stack pointer, byte data access is performed as specified by the assembler mnemonic. #### 1. STC.B EP, 0-SP When word data access is applied to EP, both EP and DP are accessed. This instruction stores EP at address SP (old) -2, and DP at address SP (old) -1. ### 2. LDC.B @SP+, EP When word data access is applied to EP, both EP and DP are accessed. This instruction loads EP from address SP (old), and DP from address SP (old) + 1, updating the DP value as well as the EP value. DataSheet4U.com HITACHI 60 www.DataSheet4U.com DataShe vww.DataSheet4U.com 3. STC.B CCR, @-SP When word data access is applied to CCR, only CCR is accessed. This instruction stores identical CCR contents at both address SP (old) -2 and address SP (old) -1. 4. LDC.B @SP+, CCR When word data access is applied to CCR, only CCR is accessed. This instruction loads CCR from address SP(old) + 1. Note that the value in address SP(old) is not loaded. BR, DP, and TP are accessed in the same way as CCR. When EP is specified, both EP and DP are accessed, but when CCR, BR, DP, or TP is specified, only the specified register is accessed. et4U.com DataSheet4U.com HITACHI DataShe 61 www.DataSheet4U.com DataSheet4U.com #### 3.5.9 Short-Format Instructions The ADD, CMP, and MOV instructions have special short formats. Table 3-17 lists these short formats together with the equivalent general formats. The short formats are a byte shorter than the corresponding general formats, and most of them execute one state faster. **Table 3-17 Short-Format Instructions and Equivalent General Formats** | Short-Format | Execution | Equivalent General- | | | Execution | | |--------------------|-----------|---------------------|-----------|--------------|-----------|----------| | Instruction | Length | States*2 | Format Ir | struction | Length | States*2 | | ADD:Q #xx,Rd*1 | 2 | 2 | ADD:G | #xx:8,Rd | 3 | 3 | | CMP:E #xx:8,Rd | 2 | 2 | CMP:G.B | #xx:8,Rd | 3 | 3 | | CMP:I #xx:16,Rd | 3 | 3 | CMP:G.W | #xx:16,Rd | 4 | 4 | | MOV:E #xx:8,Rd | 2 | 2 | MOV:G.B | #xx:8,Rd | 3 | 3 | | MOV:I #xx:16,Rd | 3 | 3 | MOV:G.W | #xx:16,Rd | 4 | 4 | | MOV:L @aa:8,Rd | 2 | 5 | MOV:G | @aa:8,Rd | 3 | 5 | | MOV:S Rs,@aa:8 | 2 | 5 | MOV:G | Rs,@aa:8 | 3 | 5 | | MOV:F @(d:8,R6),Rd | 2 | 5 | MOV:G | @(d:8,R6),Rd | 3 | 5 | | MOV:F Rs,@(d:8,R6) | 2 | 5 | MOV:G | Rs,@(d:8,R6) | 3 | 5 | | | | | | | | | Notes: 1. The ADD: Q instruction accepts other destination operands in addition to a general register, but the immediate data value (#xx) is limited to ±1 or ±2. 2. Number of execution states for access to on-chip memory. DataSheet4U.com et4U.com ### 3.6 Operating Modes The CPU operates in one of two modes: the minimum mode or the maximum mode. These modes are selected by the mode pins (MD2 to MD0). #### 3.6.1 Minimum Mode The minimum mode supports a maximum address space of 64 kbytes. The page registers are ignored. Instructions that branch across page boundaries (PJMP, PJSR, PRTS, PRTD) are invalid. HITACHI 62 www.DataSheet4U.com DataShe In the maximum mode the page registers are valid, expanding the maximum address space to 1 Mbyte. The address space is divided into 64-kbyte pages. The pages are separate; it is not possible to move continuously across a page boundary. It is possible to move from one page to another with branching instructions (PJMP, PJSR, PRTS, PRTD). The TRAPA instruction and instructions that branch to interrupt-handling routines can also jump across page boundaries. It is not necessary for a program to be contained in a single 64-kbyte page. When data access crosses a page boundary, the program must rewrite the page register before it can access the data in the next page. For further information on the operating modes, see section 2, "MCU Operating Modes and Address Space." ### 3.7 Basic Operational Timing #### 3.7.1 Overview et4U.com The CPU operates on a system clock (ø) which is created by dividing the crystal oscillator frequency (fosc) by two. One period of the system clock is referred to as a "state." The CPU accesses memory in Data Sheet a cycle consisting of 2 or 3 states. The CPU uses different methods to access on-chip memory, the on-chip register field, and external devices. Access to On-Chip Memory (RAM, ROM): For maximum speed, access to on-chip memory (RAM, ROM) is performed in two states, using a 16-bit-wide data bus. Figure 3-6 shows the on-chip memory access cycle. Figure 3-7 indicates the pin states. The bus control signals output from the H8/520 chip go to the nonactive state during the access. Access to On-Chip Register Field (Addresses H'FF80 to H'FFFF): The access cycle consists of three states. The data bus is 8 bits wide. Figure 3-8 shows the on-chip supporting module access cycle. Figure 3-9 indicates the pin states. HITACHI 63 www.DataSheet4U.com Access to External Devices: The access cycle consists of three states. The data bus is 8 bits wide. Figure 3-10 (a) and (b) shows the external access cycle. Additional wait states (Tw) can be inserted by the wait-state controller (WSC). ### 3.7.2 On-Chip Memory Access Cycle Figure 3-6 On-Chip Memory Access Timing HITACHI 64 DataSheet4U.com www.DataSheet4U.com DataShe ### 3.7.3 Pin States during On-Chip Memory Access Figure 3-7 Pin States during Access to On-Chip Memory ### 3.7.4 Register Field Access Cycle (Addresses H'FF80 to H'FFFF) Figure 3-8 Register Field Access Timing 65 HITACHI DataSheet4U.com et4U.com ### 3.7.5 Pin States during Register Field Access (Addresses H'FF80 to H'FFFF) Figure 3-9 Pin States during Register Field Access ### 3.7.6 External Access Cycle Figure 3-10 (a) External Access Cycle (Read Access) **HITACHI** 66 DataSheet4U.com www.DataSheet4U.com DataSheet4U.com ww.DataSheet4U.com Figure 3-10 (b) External Access Cycle (Write Access) ### 3.8 CPU States et4U.com DataSheet4U.com ### 3.8.1 Overview The CPU has four states: the program execution state, exception-handling state, reset state, and power-down state. The power-down state is further divided into the sleep mode, software standby mode, and hardware standby mode. Figure 3-11 summarizes these sates, and figure 3-12 shows a map of the state transitions. HITACHI 67 www.DataSheet4U.com DataShe Figure 3-11 Operating States HITACHI 68 DataSheet4U.com www.DataSheet4U.com Figure 3-12 State Transitions DataShe ### 3.8.2 Program Execution State In this state the CPU executes program instructions in normal sequence. HITACHI 69 www.DataSheet4U.com ### 3.8.3 Exception-Handling State The exception-handling state is a transient state that occurs when the CPU alters the normal program flow due to an interrupt, trap instruction, address error, or other exception. In this state the CPU carries out a hardware-controlled sequence that prepares it to execute a user-coded exception-handling routine. In the hardware exception-handling sequence the CPU does the following: - 1. Saves the program counter and status register (in minimum mode) or program counter, code page register, and status register (in maximum mode) to the stack. - 2. Clears the T bit in the status register to 0. - 3. Fetches the start address of the exception-handling routine from the exception vector table. - 4. Branches to that address, returning to the program execution state. See section 4, "Exception Handling", for further information on the exception-handling state. #### 3.8.4 Reset State In the reset state, the CPU and all on-chip supporting modules are initialized and placed in the stopped state. The CPU enters the reset state whenever the RES pin goes low, unless the CPU is currently in the hardware standby mode. It remains in the reset state until the RES pin goes high. See section 4.2, "Reset", for further information on the reset state. ## et4U.com 3.8.5 Power-Down State DataSheet4U.com DataShe The power-down state comprises three modes: the sleep mode, software standby mode, and hardware standby mode. See section 17, "Power-Down State", for further information. HITACHI 70 ### Section 4 Exception Handling ### 4.1 Overview T-49-19-16 ### 4.1.1 Types of Exception Handling and Their Priority As indicated in table 4-1 (a) and (b), exception handling can be initiated by a reset, address error, trace, interrupt, or instruction. An instruction initiates exception handling if the instruction is an invalid instruction, a trap instruction, or a DIVXU instruction with zero divisor. Exception handling begins with a hardware exception-handling sequence which prepares for the execution of a user-coded software exception-handling routine. There is a priority order among the different types of exceptions, as shown in table 4-1 (a). If two or more exceptions occur simultaneously, they are handled in their order of priority. An instruction exception cannot occur simultaneously with other types of exceptions. Table 4-1 (a) Exceptions and Their Priority | Priority | Exception<br>Type | Source | Detection Timing | Start of Exception-<br>Handling Sequence | _ | |----------|-------------------|-----------------------|----------------------------------------------------------------------|------------------------------------------|----------| | High A | Reset | External, internal | RES Low-to-High transition | Immediately | _ | | | Address error | Internal | Instruction fetch or data read/write bus cycle | End of instruction execution | _ | | | Trace | Internal | End of instruction execution, if T = 1 in status register | End of instruction execution | DataShee | | | Interrupt | External,<br>internal | . End of instruction execution or end of exception-handling sequence | End of instruction execution | | Table 4-1 (b) Instruction Exceptions | Start of Exception-Handling Sequence Attempted execution of instruction with undefined code | | | |---------------------------------------------------------------------------------------------|--|--| | | | | | Attempted execution of DIVXU instruction with zero divisor | | | | | | | 71 HITACHI DataSheet4U.com et4U.com #### www.BataSfiee14U.com (MCU/MPU) 200 T-49-19-16 ### 4.1.2 Hardware Exception-Handling Sequence The hardware exception-handling sequence varies depending on the type of exception. When exception handling is initiated by an exception other than a reset, the CPU: - 1. Saves the program counter and status register (in minimum mode) or program counter, code page register, and status register (in maximum mode) to the stack. - 2. Clears the T bit in the status register to 0. - 3. Fetches the start address of the exception-handling routine from the exception vector table. - 4. Branches to that address. For an interrupt, the CPU also alters the interrupt mask level in bits I2 to I0 of the status register. For a reset, step 1 is omitted. See section 4.2, "Reset", for the full reset sequence. #### 4.1.3 Exception Sources and Vector Table The sources that initiate exception handling can be classified as shown in figure 4-1. The starting addresses of the exception-handling routines for each source are contained in an exception vector table located in the low addresses of page 0. The vector addresses are listed in table 4-2. Note that there are different addresses for the minimum and maximum modes. et4U.com DataSheet4U.com DataShe HITACHI 72 DataSheet4U.com Figure 4-1 Sources Causing Exception Handling 73 HITACHI DataSheet4U.com **Table 4-2 Exception Vector Table** T-49-19-16 #### **Vector Address** | Type of Exception | Minimum Mode | Maximum Mode | | | |--------------------------------------|------------------|------------------|--|--| | Reset (initialize PC) | H'0000 to H'0001 | H'0000 to H'0003 | | | | — (Reserved for system) | H'0002 to H'0003 | H'0004 to H'0007 | | | | Invalid instruction | H'0004 to H'0005 | H'0008 to H'000B | | | | DIVXU instruction (zero divide) | H'0006 to H'0007 | H'000C to H'000F | | | | TRAP/VS instruction | H'0008 to H'0009 | H'0010 to H'0013 | | | | | H'000A to H'000B | H'0014 to H'0017 | | | | (Reserved for system) | to | to | | | | • | H'000E to H'000F | H'001C to H'001F | | | | Address error | H'0010 to H'0011 | H'0020 to H'0023 | | | | Trace | H'0012 to H'0013 | H'0024 to H'0027 | | | | — (Reserved for system) | H'0014 to H'0015 | H'0028 to H'002B | | | | Nonmaskable external interrupt (NMI) | H'0016 to H'0017 | H'002C to H'002F | | | | | H'0018 to H'0019 | H'0030 to H'0033 | | | | (Reserved for system) | to | to | | | | • | H'001E to H'001F | H'003C to H'003F | | | | TRAPA instruction (16 vectors) | H'0020 to H'0021 | H'0040 to H'0043 | | | | , | to | to | | | | | H'003E to H'003F | H'007C to H'007F | | | | External interrupts IRQo to IRQ7 | H'0040 to H'0041 | H'0080 to H'0083 | | | | | DataSheet4ltocom | to | | | | | H'004E to H'004F | H'009C to H'009F | | | | Internal interrupts | H'0050 to H'0051 | H'00AO to H'00A3 | | | | | to | to | | | | | H'007E to H'007F | H'00FC to H'00FF | | | et4U.com Notes: 1. The exception vector table is located at the beginning of page 0. 2. For details of the internal interrupt vectors, see table 5-2. HITACHI 74 www.DataSheet4U.com DataShe #### 4.2.1 Overview T-49-19-16 A reset has the highest exception-handling priority. A reset can be generated by a low input at the RES pin or by a watchdog timer (WDT) overflow. When the $\overline{RES}$ pin goes low, all current processing halts and the H8/520 chip enters the reset state. The internal status of the CPU and the contents of the registers of the on-chip supporting modules are initialized. When the $\overline{RES}$ pin returns from low to high, the hardware reset sequence described in the next section begins. To ensure that the H8/520 chip is reset correctly, the $\overline{RES}$ pin should be held low for at least 20 ms at power-up. To reset the H8/520 during operation, the $\overline{RES}$ pin should be held low for at least six system clock ( $\emptyset$ ) cycles. When the RSTOE bit (see below) is set to 1, the $\overline{RES}$ input must be held low for at least 520 system clock ( $\emptyset$ ) cycles to reset the H8/520 chip. When the watchdog timer operates in watchdog mode, if the watchdog timer counter (TCNT) overflows due to a program crash, for example, the watchdog timer generates an internal reset signal that resets the H8/520 chip. If in addition the reset output enable (RSTOE) bit in the reset control/status register (RSTCSR) is set to 1, a low output signal is generated at the RES pin for 132 system clock (ø) cycles. This signal can be used to reset devices controlled by the H8/520. DataSheet4U.com DataShe See section 12, "Watchdog Timer", for further information on the reset generated by the watchdog timer. See appendix E, "Pin Status in the Reset State", for the status of pins when a reset occurs. #### 4.2.2 Reset Sequence When the RES pin returns to the high state after being held low for the necessary time, the hardware reset exception-handling sequence begins, during which: - 1. The value at the mode pins (MD2 to MD0) is latched in bits MDS2 to MDS0 of the mode control register (MDCR). - 2. In the status register (SR), the T bit is cleared to disable the trace mode, and the interrupt mask level (bits I2 to I0) is set to 7. A reset disables all interrupts. - 3. The CPU loads the reset start address from the vector table into the program counter and begins executing the program at that address. HITACHI 75 www.DataSheet4U.com et4U.com The contents of the vector table differs between minimum mode and maximum mode as indicated in figure 4-2. This affects step 3 as described below. $T_{-49}=19-16$ Minimum Mode: One word is copied from addresses H'0000 and H'0001 in the vector table to the program counter. Program execution then begins from the address in the program counter (PC). Maximum Mode: Two words are read from addresses H'0000 to H'0003 in the vector table. The byte in address H'0000 is ignored. The byte in address H'0001 is copied to the code page register (CP). The contents of addresses H'0002 and H'0003 are copied to the program counter. Program execution starts from the address indicated by the code page register and program counter. Figure 4-2 Reset Vector Figure 4-3 shows the timing of the reset sequence in minimum mode. Figure 4-4 shows the timing of the reset sequence in maximum mode. et4U.com #### 4.2.3 Stack Pointer Initialization The hardware reset sequence does not initialize the stack pointer, so this must be done by software. If an interrupt were to be accepted after a reset and before the stack pointer (SP) is initialized, the program counter and status register would not be saved correctly, causing a program crash. This danger can be avoided by coding the reset routine as explained next. When the chip comes out of the reset state all interrupts, including NMI, are disabled, so the instruction at the reset start address is always executed. In the minimum mode, this instruction should initialize the stack pointer (SP). In the maximum mode, this instruction should be an LDC instruction initializing the stack page register (TP), and the next instruction should initialize the stack pointer. Execution of the LDC instruction disables interrupts again, ensuring that the stack pointer initializing instruction is executed. HITACHI 76 www.DataSheet4U.com DataShe ataonoot ro.com Figure 4-3 Reset Sequence (Minimum Mode, On-Chip Memory) 77 HITACHI DataSheet4U.com www.DataSheet4U.com Figure 4-4 Reset Sequence (Maximum Mode, External Memory) HITACHI 78 DataSheet4U.com ## www.DataSheet4U.com 4.3 Address Error T-49-19-16 There are three causes of address errors: - · Instruction prefetch from illegal address - · Word data access at odd address - · Off-chip access in single-chip mode An address error initiates the address error exception-handling sequence. This sequence clears the T bit of the status register to 0 to disable the trace mode, but does not affect the interrupt mask level in bits I2 to Io. #### 4.3.1 Instruction Prefetch from Illegal Address An attempt to prefetch an instruction from the register field in memory addresses H'FF80 to H'FFFF causes an address error regardless of the MCU operating mode. Handling of this address error begins when the prefetch cycle that caused the error has been completed and execution of the current instruction has also been completed. The program counter value pushed on the stack is the address of the instruction immediately following the last instruction executed. See section 4.9, "Stack Status after Completion of Exception Handling", for a diagram of the stack. Program code should not be located in addresses H'FF7D to H'FF7F. If the CPU executes an instruction in these addresses, it will attempt to prefetch the next instruction from the register field, causing an address error. DataSheet4U.com 4.3.2 Word Data Access at Odd Address If an attempt is made to access word data starting at an odd address, an address error occurs regardless of the MCU operating mode. The program counter value pushed on the stack in the handling of this error is the address of the next instruction after the instruction that attempted the illegal word access. #### 4.3.3 Off-Chip Address Access in Single-Chip Mode In the single-chip mode there is no external memory, so in addition to the address errors described above, the following two types of address errors can occur. HITACHI 79 www.DataSheet4U.com DataShe ataSheet4U.com et4U.com Access to Addresses H'4000 to H'FD7F: These addresses exist neither in on-chip ROM or RAM nor in the on-chip register field, so an address error occurs if they are accessed for any purpose: for instruction prefetch, byte data access, or word data access. T-49-19-16 Program code should not be located in the last three bytes of on-chip ROM (addresses H'3FFD to H'3FFF) in single-chip mode. If an instruction is located in these three bytes, the CPU will attempt to fetch the next instruction from addresses H'4000 to H'4002, causing an address error. Access to Disabled RAM Area: The on-chip RAM area (H'FD80 to H'FF7F) can be disabled by clearing the RAME bit in the RAM control register (RAMCR). If any type of RAM access is attempted in this state in the single-chip mode, an address error occurs. #### 4.4 Trace When the T bit of the status register is set to 1, the CPU operates in trace mode. A trace exception occurs at the completion of each instruction. The trace mode can be used to monitor program execution for debugging by a debugger. In the trace exception sequence the T bit of the status register is cleared to 0 to disable the trace mode while the trace routine is executing. The interrupt mask level in bits I2 to I0 is not changed. Interrupts are accepted as usual during the trace routine. In the status-register data saved on the stack, the T bit is set to 1. When the trace routine returns with the RTE instruction, the status register is popped from the stack and the trace mode resumes. ne DataShe If an address error occurs during execution of the first instruction after the return from the trace routine, since the address error has higher priority, the address error exception-handling sequence is initiated, clearing the T bit in the status register to 0 and making it impossible to trace this instruction. ### 4.5 Interrupts et4U.com Interrupts can be requested from nine external sources (NMI and IRQ0 to IRQ7) and seven on-chip supporting modules: the 16-bit free-running timers (FRT1 and FRT2), the 8-bit timer, the serial communication interfaces (SCI1 and SCI2), the A/D converter, and the watchdog timer (WDT). The on-chip interrupt sources can request a total of eighteen different types of interrupts, each having its own interrupt vector. Figure 4-5 lists the interrupt sources and the number of different interrupts from each source. HITACHI 80 Each interrupt source has a priority. NMI interrupts have the highest priority, and are normally accepted unconditionally. The priorities of the other interrupt sources are set in interrupt priority registers A to D (IPRA to IPRD) in the register field at the high end of page 0 and can be changed by software. Priority levels range from 0 (low) to 7 (high), with NMI considered to be on level 8. IRQ1 to IRQ7 always have the same priority. The priority of IRQ0 can be set independently. T-49-19-16 The on-chip interrupt controller decides whether an interrupt can be accepted by comparing its priority with the interrupt mask level, and determines the order in which to accept competing interrupt requests. Interrupts that are not accepted immediately remain pending until they can be accepted later. When it accepts an interrupt, the interrupt controller also decides whether to have the interrupt handled by the CPU or the on-chip data transfer controller (DTC). This decision is controlled by bits set in data transfer enable registers A to D (DTEA to DTED) in the register field. The DTC is started if the corresponding DTE bit is set to 1; otherwise a CPU interrupt is generated. DTC interrupts provide an efficient way to send and receive blocks of data via the serial communication interface, or to transfer data between memory and I/O without detailed CPU programming. The CPU halts while the DTC is executing. DTC interrupts are described in section 6, "Data Transfer Controller". The hardware exception-handling sequence for a CPU interrupt clears the T bit in the status register to 0 and sets the interrupt mask level in bits I2 to I0 to the level of the interrupt it has accepted. This prevents the interrupt-handling routine from being interrupted except by a higher-level interrupt. The previous interrupt mask level is restored on the return from the interrupt-handling routine. For further information on interrupts, see section 5, "Interrupt Controller". DataShe HITACHI www.DataSheet4U.com Figure 4-5 Interrupt Sources (and Number of Interrupt Types) #### 4.6 Invalid Instruction et4U.com An invalid instruction exception occurs if an attempt is made to execute an instruction with an undefined operation code or illegal addressing mode specification. The program counter value pushed on the stack is the value of the program counter when the invalid instruction code was detected. DataShe In the invalid instruction exception-handling sequence the T bit of the status register is cleared to 0, but the interrupt mask level (I2 to I0) is not affected. If a normal interrupt is requested while a trap or zerodivide instruction is being executed, after the trap or zero-divide exception-handling sequence, the normal interrupt exception-handling sequence is carried out. HITACHI 82 www.DataSheet4U.com DataSheet4U.com T-49-19-16 A trap exception occurs when the TRAPA or TRAP/VS instruction is executed. A zero divide exception occurs if an attempt is made to execute a DIVXU instruction with a zero divisor. In the exception-handling sequences for these exceptions the T bit of the status register is cleared to 0, but the interrupt mask level (I2 to I0) is not affected. **TRAPA Instruction:** The TRAPA instruction always causes a trap exception. The TRAPA instruction includes a vector number from 0 to 15, allowing the user to provide up to sixteen different traphandling routines. TRAP/VS Instruction: When the TRAP/VS instruction is executed, a trap exception occurs if the overflow (V) bit in the condition code register is set to 1. If the V bit is cleared to 0, no exception occurs and the next instruction is executed. **DIVXU Instruction with Zero Divisor:** An exception occurs if an attempt is made to divide by zero in a DIVXU instruction. #### 4.8 Cases in Which Exception Handling is Deferred In the case described next, the address error exception, trace exception, external interrupt (NMI and IRQ0 to IRQ7) requests, and internal interrupt requests (18 types) are not accepted immediately but are deferred until after the next instruction has been executed. et4U.com DataSheet4U.com DataShe 83 HITACHI #### 4.8.1 Instructions that Disable Interrupts T-49-19-16 Interrupts are disabled immediately after the execution of five instructions: XORC, ORC, ANDC, LDC, and RTE. Suppose that an internal interrupt is requested and the interrupt controller, after checking the interrupt priority and interrupt mask level, notifies the CPU of the interrupt, but the CPU is currently executing one of the five instructions listed above. After executing this instruction the CPU always proceeds to the next instruction. (And if the next instruction is one of these five, the CPU also proceeds to the next instruction after that.) The exception-handling sequence starts after the next instruction that is not one of these five has been executed. The following is an example: et4U.com Note: When the LDC instruction alters the I bits in the status register (SR), the new I-bit values do not take effect until three states after the LDC instruction. If a program running in on-chip memory uses the LDC instruction to enable interrupts by modifying the I bits and the next instruction is a DataShe uses the LDC instruction to enable interrupts by modifying the I bits and the next instruction is a two-state instruction (NOP for example), interrupts will not be accepted after this next instruction; they will not be accepted until another instruction has been executed after that. The same applies to the ANDC, ORC, and XORC instructions. ### 4.8.2 Disabling of Exceptions Immediately after a Reset If an interrupt is accepted after a reset and before the stack pointer (SP) is initialized, the program counter and status register will not be saved correctly, leading to a program crash. To prevent this, when the chip comes out of the reset state all interrupts, including NMI, are disabled, so the first instruction of the reset routine is always executed. As noted earlier, in the minimum mode, this instruction should initialize the stack pointer (SP). In the maximum mode, the first instruction should be an LDC instruction that initializes the stack page register (TP); the next instruction should initialize the stack pointer. HITACHI 84 ataSheet4U.com www.DataSheet4U.com If an interrupt starts the data transfer controller and another interrupt is requested during the data transfer cycle, when the data transfer cycle ends, the CPU always executes the next instruction before handling the second interrupt. Even if a nonmaskable interrupt (NMI) occurs during a data transfer cycle, it is not accepted until the next instruction has been executed. An example of this is shown below. DataSheet4U.com 85 HITACHI www.DataSheet4U.com DataShe et4U.com www.DataSheet4U.com ## 4.9 Stack Status after Completion of Exception Handling T-49-19-16 The status of the stack after an exception-handling sequence is described below. Table 4-3 shows the stack after completion of the exception-handling sequence for various types of exceptions in the minimum and maximum modes. Table 4-3 Stack after Exception Handling Sequence Note: The RTE instruction returns to the next instruction after the instruction being executed when the exception occurred. et4U.com DataSheet4U.com DataShe HITACHI 86 DataSheet4U.com Note: The program counter value pushed on the stack is not necessarily the address of the first byte of the invalid instruction. Note: The program counter value pushed on the stack is the address of the next instruction after the last instruction successfully executed. 87 HITACHI www.DataSheet4U.com # 4.9.1 PC Value Pushed on Stack for Trace, Interrupts, Trap Instructions, and Zero Divide Exceptions T-49-19-16 The program counter value pushed on the stack for a trace, interrupt, trap, or zero divide exception is the address of the next instruction at the time when the interrupt or exception was accepted. The RTE instruction accordingly returns to the next instruction after the instruction executed before the exception-handling sequence. ## 4.9.2 PC Value Pushed on Stack for Address Error and Invalid Instruction Exceptions The program counter value pushed on the stack for an address error or invalid instruction exception differs depending on the conditions when the exception occurred. #### 4.10 Notes on Use of the Stack If the stack pointer is set to an odd address, an address error will occur when the stack is accessed during interrupt handling or for a subroutine call. The stack pointer should always point to an even address. To keep the stack pointer pointing to an even address, a program should use word data size when saving or restoring registers to and from the stack. In the @-SP or @SP+ addressing mode, the CPU performs word access even if the instruction specifies byte size. (This is not true in the @-Rn and @Rn+ addressing modes when Rn is a register from R0 to R6.) et4U.com DataSheet4U.com DataShe HITACH 88 DataSheet4U.com ## Section 5 Interrupt Controller T-49-19-16 #### 5.1 Overview The interrupt controller decides which interrupts to accept, and how to deal with multiple interrupts and other exceptions. It also decides whether an interrupt should be served by the CPU or by the data transfer controller (DTC). This section explains the features of the interrupt controller, describes its internal structure and control registers, and details the handling of interrupts. For detailed information on the data transfer controller, see section 6, "Data Transfer Controller". #### 5.1.1 Features The main features of the interrupt controller are as follows: - Interrupt priorities are user-programmable. User programs can set priority levels from 7 (high) to 0 (low) in four interrupt priority (IPR) registers for IRQ0, IRQ1 to IRQ7, and each of the on-chip supporting modules—for every interrupt, that is, except the nonmaskable interrupt (NMI). NMI has the highest priority level (8) and is normally always accepted. An interrupt with priority level 0 is always masked. - Multiple interrupts on the same level are served in a default priority order. Lower-priority interrupts remain pending until higher-priority interrupts have been handled. - For most interrupts, software can select whether to have the interrupt served by the CPU or the onchip data transfer controller (DTC). User programs can make this selection by setting and clearing bits in four data transfer enable (DTE) registers. The data transfer controller can be started by any interrupts except NMI, IRQ4 to IRQ7, the error interrupt (ERI) from the on-chip serial communication interface, and the overflow interrupts (FOVI and OVI) from the on-chip timers. Software can select the NMI edge and can enable or disable IRQ0 to IRQ7. The NMI control register (NMICR) determines whether a nonmaskable interrupt is triggered by the rising or falling edge of the NMI input signal. The IRQ control register (IRQCR) enables or disables IRQ0 to IRQ7. DataShe HITACHI 89 www.DataSheet4U.com et4U.com #### 5.1.2 Block Diagram T-49-19-16 Figure 5-1 shows the block configuration of the interrupt controller. Figure 5-1 Interrupt Controller Block Diagram **HITACHI** 90 DataSheet4U.com Table 5-1 lists the attributes of the registers used by the interrupt controller. **Table 5-1 Interrupt Controller Registers** | | <b>Abbreviation</b> | Read/Write | Initial Value | Address | |---|----------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------| | Α | IPRA | R/W | H'00 | H'FFF0 | | В | IPRB | R/W | H'00 | H'FFF1 | | С | IPRC | R/W | H'00 | H'FFF2 | | D | IPRD | R/W | H'00 | H'FFF3 | | Α | DTEA | R/W | H.00 | F'FFF4 | | В | DTEB | R/W | H'00 | H'FFF5 | | С | DTEC | R/W | H'00 | H'FFF6 | | D | DTED | R/W | H:00 | H'FFF7 | | • | NMICR | R/W | H'FE | H'FFFC | | | IRQCR | R/W | H'00 | H'FFFD | | | B<br>C<br>D<br>A<br>B<br>C | A IPRA B IPRB C IPRC D IPRD A DTEA B DTEB C DTEC D DTED NMICR | A IPRA R/W B IPRB R/W C IPRC R/W D IPRD R/W A DTEA R/W B DTEB R/W C DTEC R/W D DTED R/W | A IPRA R/W H'00 B IPRB R/W H'00 C IPRC R/W H'00 D IPRD R/W H'00 A DTEA R/W H'00 B DTEB R/W H'00 C DTEC R/W H'00 D DTED R/W H'00 NMICR R/W H'FE | See section 6.2.5, "Data Transfer Enable Registers A to D", for detailed information about DTEA to DTED. #### **5.2** Interrupt Types et4U.com There are 27 distinct types of interrupts: 9 external interrupts originating off-chip and 18 internal interrupts originating in the on-chip supporting modules. #### 5.2.1 External Interrupts The nine external interrupts are NMI and IRQ0 to IRQ7. NMI (Non Maskable Interrupt): This interrupt has the highest priority level (8) and cannot be masked. An NMI is generated by input to the NMI pin. The input at the NMI pin is edge-sensed. A user program can select whether to have the interrupt occur on the rising edge or falling edge of the NMI input by setting or clearing the nonmaskable interrupt edge bit (NMIEG) in the NMI control register (NMICR). HITACHI 91 www.DataSheet4U.com DataShe www.DataSheet4U.com In the NMI exception-handling sequence, the T (Trace) bit in the CPU status register (SR) is cleared to 0, and the interrupt mask level in I2 to I0 is set to 7, masking all other interrupts. The interrupt controller holds the NMI request until the NMI exception-handling sequence begins, then clears the NMI request, so if another interrupt is requested at the NMI pin during the NMI exception-handling sequence, the NMI exception-handling sequence will be carried out again. $T_{-49-19-16}$ #### **Coding Examples:** To select the rising edge of the NMI input: BSET.B #0, @H'FFFC To select the falling edge of the NMI input: BCLR.B #0, @H'FFFC IRQ0 (Interrupt Request 0): An IRQ0 interrupt can be requested by a low input to the $\overline{IRQ0}$ pin and/or a watchdog timer overflow. A low $\overline{IRQ0}$ input requests an IRQ0 interrupt if the interrupt request enable 0 bit (IRQ0 E) in the IRQ control register (IRQCR) is set to 1. The interrupt controller samples the level of the $\overline{IRQ0}$ pin directly, so this pin must be held low until the interrupt is accepted. Otherwise the request will be ignored. A watchdog timer overflow requests an IRQ0 interrupt if the TME bit is set to 1 and the WT/IT bit is cleared to 0 in the watchdog timer's control/status register. See section 12, "Watchdog Timer", for details of the watchdog timer. The IRQo interrupt can be assigned any priority level from 7 to 0 by setting the corresponding value in the upper four bits of IPRA. If bit 4 of data transfer enable register A (DTEA) is set to 1, an IRQo interrupt starts the data transfer controller. Otherwise the interrupt is served by the CPU. DataSheet4U.com In the CPU interrupt-handling sequence for IRQ0 the T bit of the status register is cleared to 0, and the interrupt mask level is set to the value in the upper four bits of IPRA. #### **Coding Examples:** et4U.com To enable IRQ0 to be requested by IRQ0 input: BSET.B #0, @H'FFFD To assign priority level 7 to IRQ0: OR.B #70, @H'FFF0 To have IRQ0 start the DTC: BSET.B #4, @H'FFF4 IRQ1 to IRQ7 (Interrupt Request 1 to 7): An IRQ1 to IRQ7 interrupt is requested by a high-to-low transition at the IRQ1 to IRQ7 pin. The IRQ1 to IRQ7 interrupt is enabled only when the interrupt request enable bit IRQ1E to IRQ7E in the IRQ control register is set to 1. The IRQ1 to IRQ7 input is latched in the interrupt controller and held until the interrupt request is accepted. HITACHI 92 www.DataSheet4U.com DataShe DataSheet4U.com vww.DataSheet4U.com The IRQ1 to IRQ7 interrupts can be assigned any priority level from 7 (high) to 0 (low) by setting the corresponding value in the lower four bits of IPRA. These seven interrupts always have the same priority. They cannot be assigned priorities separately. T-49-19-16 If bits 0 to 2 of data transfer enable register A (DTEA) are set to 1, IRQ1 to IRQ3 can start the data transfer controller. Otherwise the interrupt is served by the CPU. IRQ4 to IRQ7 cannot start the data transfer controller; they are always served by the CPU. The interrupt controller holds IRQ1 to IRQ7 requests until the corresponding exception-handling sequence begins, then clears the request. Contention among IRQ1 to IRQ7 is resolved when the CPU accepts the interrupt by taking the interrupt with the highest priority first and holding lower-priority interrupts pending. During the interrupt-handling routine, if the same external interrupt is requested again the request is held, but the exception-handling sequence is not carried out immediately because the interrupt is masked by bits I2 to I0 in the status register. On return from the interrupt-handling routine one more instruction is executed, then the pending exception-handling sequence is carried out. In the CPU interrupt-handling sequence for IRQ1 to IRQ7, the T bit of the CPU status register is cleared to 0, and the interrupt mask level is set to the value in the lower four bits of IPRA. #### **Coding Examples:** et4U.com To enable IRQ1 to be requested by $\overline{IRQ1}$ input: BSET.B #1, @H'FFFD To assign priority level 7 to IRQ0 and level 5 to IRQ1 to IRQ7: MOV.B #75, @H'FFF0 To have IRQ1 start the DTC: BSET.B #0, @H'FFF4 #### 5.2.2 Internal Interrupts Eighteen types of internal interrupts can be requested by the on-chip supporting modules. Each interrupt is separately vectored in the exception vector table, so it is not necessary for the user-coded interrupt handler routine to determine which type of interrupt has occurred. Each of the internal interrupts can be enabled or disabled by setting or clearing an enable bit in the control register of the on-chip supporting module. HITACHI 93 www.DataSheet4U.com DataShe DataSheet4U.com www.DataSheet4U.com An interrupt priority level from 7 to 0 can be assigned to each on-chip supporting module by setting interrupt priority registers B to D. Within each module, different interrupts have a fixed priority order. For most of these interrupts, values set in data transfer enable registers B to D can select whether to have the interrupt served by the CPU or the data transfer controller. T-49-19-16 In the CPU interrupt-handling sequence, the T bit of the CPU status register is cleared to 0, and the interrupt mask level in bits I2 to I0 is set to the value in the IPR. #### 5.2.3 Interrupt Vector Table Table 5-2 lists the addresses of the exception vector table entries for each interrupt, and explains how their priority is determined. For the on-chip supporting modules, the priority level set in the interrupt priority register applies to the module as a whole: all interrupts from that module have the same priority level. A separate priority order is established among interrupts from the same module. If the same priority level is assigned to two or more modules and two interrupts are requested simultaneously from these modules, they are served in the priority order indicated in the rightmost column in table 5-2. A reset clears the interrupt priority registers so that all interrupts except NMI start with priority level 0, meaning that they are unconditionally masked. et4U.com DataSheet4U.com DataShe HITACHI 94 DataSheet4U.com www.DataSheet4U.com | | | Assignable<br>Priority<br>Levels | | Priority | Vector Table E | Entry Address | Priority<br>among<br>Interrupts | |---------|------------------|----------------------------------|--------------|----------|------------------|------------------|---------------------------------| | | | (initial | IPR | within | Minimum | Maximum | on Same | | interru | pt | Level) | Bits | Module | Mode | Mode | Levei* | | NMI | | 8 | - | _ | H'0016 to H'0017 | H'002C to H'002F | High | | | | (8) | | | <u> </u> | | <b>A</b> | | IRQ | IRQ <sub>0</sub> | 7 to 0 | IPRA | _ | H'0040 to H'0041 | H'0080 to H'0083 | | | | | (0) | Upper 4 bits | | | | | | | IRQ1 | 7 to 0 | IPRA | 6 | H'0042 to H'0043 | H'0084 to H'0087 | | | | IRQ2 | | Lower 4 bits | 5 | H'0044 to H'0045 | H'0088 to H'008B | | | | IRQ3 | | | 4 | H'0046 to H'0047 | H'008C to H'008F | | | | IRQ4 | | | 3 | H'0048 to H'0049 | H'0090 to H'0093 | | | | IRQ5 | | | 2 | H'004A to H'004B | H'0094 to H'0097 | | | | IRQ6 | | | 1 | H'004C to H'004D | H'0098 to H'009B | | | | IRQ7 | (0) | | 0 | H'004E to H'004F | H'009C to H'009F | - | | FRT1 | ICI | 7 to 0 | IPRB | 3 | H'0050 to H'0051 | H'00A0 to H'00A3 | | | | OCIA | | Upper 4 bits | 2 | H'0052 to H'0053 | H'00A4 to H'00A7 | | | | OCIB | | | 1 | H'0054 to H'0055 | H'00A8 to H'00AB | | | | FOVI | (0) | | 0 | H'0056 to H'0057 | H'00AC to H'00AF | | | FRT2 | ICI | 7 to 0 | IPRB | 3 | H'0058 to H'0059 | H'00B0 to H'00B3 | | | | OCIA | | Lower 4 bits | 2 | H'005A to H'005B | H'00B4 to H'00B7 | | | | OICB | | | DataShe | H'005C to H'005D | H'00B8 to H'00BB | | | | FOVI | (0) | | 0 | H'005E to H'005F | H'00BC to H'00BF | | | 8-Bit | CMIA | 7 to 0 | IPRC | 2 | H'0060 to H'0061 | H'00C0 to H'00C3 | | | timer | CMIB | | Upper 4 bits | 1 | H'0062 to H'0063 | H'00C4 to H'00C7 | | | | OVI | (0) | | 0 | H'0064 to H'0065 | H'00C8 to H'00CB | | | SCI1 | ERI | 7 to 0 | IPRC | 2 | H'0068 to H'0069 | H'00D0 to H'00D3 | | | | RXI | | Upper 4 bits | 1 | H'006A to H'006B | H'00D4 to H'00D7 | | | | TXI | (0) | | 0 | H'006C to H'006D | H'00D8 to H'00DB | | | SCI2 | ERI | 7 to 0 | IPRD | 2 | H'0070 to H'0071 | H'00E0 to H'00E3 | | | | RXI | | Upper 4 bits | 1 . | H'0072 to H'0073 | H'00E4 to H'00E7 | | | | TXI | (0) | | 0 | H'0074 to H'0075 | H'00E8 to H'00EB | | | A/D | ADI | 7 to 0 | IPRD | _ | H'0078 to H'0079 | H'00F0 to H'00F3 | | | conver | ler | (0) | Lower 4 bits | | | | Low | Note: \* If two or more interrupts are requested simultaneously, they are handled in order of priority level, as set in registers IPRA to IPRD. If they have the same priority level because they are requested from the same on-chip supporting module, they are handled in a fixed priority order within the module. If they are requested from different modules to which the same priority level is assigned, they are handled in the order indicated in the right-hand column. 95 HITACHI www.DataSheet4U.com DataShe DataSheet4U.com et4U.com #### www.DataSheet4U.com ### **5.3 Register Descriptions** #### 5.3.1 Interrupt Priority Registers A to D (IPRA to IPRD) T-49-19-16 IRQ0, IRQ1 to IRQ7, and the on-chip supporting modules are each assigned three bits in one of the four interrupt priority registers (IPRA to IPRD). These bits specify a priority level from 7 (high) to 0 (low) for interrupts from the corresponding source. The drawing below shows the configuration of the interrupt priority registers. Table 5-3 lists their assignments to interrupt sources. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|-----|-----|-----|---|-----|-----|-----| | | _ | | | | | | | | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R | R/W | R/W | R/W | R | R/W | R/W | R/W | Note: Bits 7 and 3 are reserved. They cannot be modified and are always read as 0. Table 5-3 Assignment of Interrupt Priority Registers | | Interrupt Request Source | | | | | | |----------|--------------------------|---------------|--|--|--|--| | Register | Bits 6 to 4 | Bits 2 to 0 | | | | | | IPRA | ĪRQ <sub>0</sub> | IRQ1 to IRQ7 | | | | | | IPRB | FRT1 | FRT2 | | | | | | IPRC | 8-Bit timer | SCI1 | | | | | | IPRD | SCI2 | A/D converter | | | | | et4U.com DataSheet4U.com DataShe As table 5-3 indicates, each interrupt priority register specifies priority levels for two interrupt sources. A user program can assign desired levels to these interrupt sources by writing 000 in bits 6 to 4 or bits 2 to 0 to set priority level 0, for example, or 111 to set priority level 7. A reset clears registers IPRA to IPRD to H'00, so all interrupts except NMI are initially masked. When the interrupt controller receives one or more interrupt requests, it selects the request with the highest priority and compares its priority level with the interrupt mask level set in bits I2 to I0 in the CPU status register. If the priority level is higher than the mask level, the interrupt controller passes the interrupt request to the CPU (or starts the data transfer controller). If the priority level is lower than the mask level, the interrupt controller leaves the interrupt request pending until the interrupt mask is altered to a lower level or the interrupt priority is raised. Similarly, if it receives two interrupt requests with the same priority level, the interrupt controller determines their priority as explained in table 5-2 and leaves the interrupt request with the lower priority pending. HITACHI 96 DataSheet4U.com www.DataSheet4U.com vww.DataSheet4U.com The interrupt controller requires two system clock (ø) periods to determine the priority level of an interrupt. Accordingly, when an instruction modifies an instruction priority register, the new priority does not take effect until after the next instruction has been executed. ### 5.3.2 NMI Control Register (NMICR)—H'FFFC | | _ | _ | | | | | |---|----|-----|----|---|----|---| | ٦ | Γ- | -49 | -1 | 9 | -1 | 6 | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|---|---|---|---|---|-------| | | | | _ | | | _ | | NMIEG | | Initial value | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | | Read/Write | _ | | | | | | | R/W | The NMI control register (NMICR) is an 8-bit register that selects the edge of the NMI input signal which triggers a nonmaskable interrupt. The NMICR is initialized to HFF (falling edge) at a reset and in the hardware standby mode. It is not initialized in the software standby mode. Bit 7 to 0—Reserved: These bits cannot be modified and are always read as 1. Bit 0—Nonmaskable Interrupt Edge (NMIEG): This bit selects the valid edge of the NMI input signal. Bit 0 et4U.com | NMIEG | Description | DataSheet4U.com | | | |-------|--------------------------------------------------------------------------|--------------------------|--|--| | 0 | A nonmaskable interrupt is generated on the falling edge (Initial value) | | | | | | of the NMI input signal. | | | | | 1 | A nonmaskable interrupt is gene | rated on the rising edge | | | | | of the NMI input signal. | | | | #### 5.3.3 IRQ Control Register (IRQCR)—H'FFFD | Bit | 7 | 6 | 5 | 4 | -3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------|-------|-------|-------|-------| | | IRQ7E | IRQ6E | IRQ5E | IRQ4E | IRQ3E | IRQ2E | IRQ1E | IRQ0E | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W HITACHI 97 www.DataSheet4U.com DataShe www.DataSheet4U.com The IRQ control register (IRQCR) enables or disables external interrupts on an individual basis. When an interrupt is enabled, the corresponding pin in port 1 or 4 can be used for interrupt request input. (The pin can also be read by the CPU as a port input pin.) The data direction bit in the port 1 or 4 data direction register must be cleared to 0 to designate the input mode. The IRQCR is initialized to H'00 at a reset and in the hardware standby mode, disabling all interrupt requests. It is not initialized in the software standby mode. Bit 7—Interrupt Request 7 Enable (IRQ7E): This bit determines whether a high-to-low transition at pin P47 is recognized as an IRQ7 interrupt request. #### Bit 7 | IRQ7E | Description | | |-------|----------------------------------|-----------------| | 0 | P47 is not used for IRQ7 input. | (Initial value) | | 1 | P47 can be used for IRQ7 input.* | | Bit 6—Interrupt Request 6 Enable (IRQ6E): This bit determines whether a high-to-low transition at pin P46 is recognized as an IRQ6 interrupt request. #### Bit 6 | IRQ6E | Description | | |-------|----------------------------------|-----------------| | 0 | P4e is not used for IRQe input. | (Initial value) | | 1 | P4e can be used for IRQe input.* | | et4U.com Bit 5—Interrupt Request 5 Enable (IRQ5E): This bit determines whether a high-to-low transition at pin P45 is recognized as an IRQ5 interrupt request. #### Bit 5 | IRQ5E | Description | | |-------|----------------------------------|-----------------| | 0 | P4s is not used for IRQs input. | (Initial value) | | 1 | P4s can be used for IRQs input.* | | Note: \* In modes 1 and 3 these pins cannot be used for IRQ7 to IRQ4 input because they are occupied by bits 15 to 12 of the address bus. HITACHI 98 Sheet40.com Bit 4—Interrupt Request 4 Enable (IRQ4E): This bit determines whether a high-to-low transition at pin P44 is recognized as an IRQ4 interrupt request. T-49-19-16 Bit 4 | IRQ4E | Description | | |-------|----------------------------------|-----------------| | 0 | P44 is not used for IRQ4 input. | (Initial value) | | 1 | P44 can be used for IRQ4 input.* | | Note: \* In modes 1 and 3 these pins cannot be used for IRQ7 to IRQ4 input because they are occupied by bits 15 to 12 of the address bus. Bit 3—Interrupt Request 3 Enable (IRQ3E): This bit determines whether a high-to-low transition at pin P14 is recognized as an IRQ3 interrupt request. #### Bit 3 | IRQ3E | Description | | |-------|----------------------------------|-----------------| | 0 | P14 is not used for IRQ3 input. | (Initial value) | | 1 | P14 can be used for IRQ3 input.* | | Bit 2—Interrupt Request 2 Enable (IRQ2E): This bit determines whether a high-to-low transition at pin P13 is recognized as an IRQ2 interrupt request. #### Bit 2 et4U.com | IRQ2E | Description | | | |-------|------------------------------------------------|-----------------|--| | 0 | P1s is not used for IRQ2 input. | (Initial value) | | | 1 | P1₃ can be used for IRQ₂ input PataSheet4U.com | | | Bit 1—Interrupt Request 1 Enable (IRQ1E): This bit determines whether a high-to-low transition at pin P12 is recognized as an IRQ1 interrupt request. #### Bit 1 | IRQ1E | Description | | |-------|----------------------------------|-----------------| | 0 | P12 is not used for IRQ1 input. | (Initial value) | | 1 | P12 can be used for IRQ1 input.* | | Note: \* In modes 3 these pins cannot be used for IRQ3 to IRQ1 input because they are occupied by the page address bus. **HITACHI** 99 Bit 0—Interrupt Request 0 Enable (IRQ0E): This bit determines whether a low input at pin P11 is recognized as an IRQ0 interrupt request. | Bit 0 | | T-49-19-16 | | |-------|---------------------------------|-----------------|--| | IRQ0E | Description | | | | 0 | P11 is not used for IRQo input. | (Initial value) | | | 1 | P11 can be used for IRQo input. | | | #### 5.4 Interrupt-Handling Sequence #### 5.4.1 Interrupt-Handling Flow The interrupt-handling sequence follows the flowchart in figure 5-2, which also covers address-error and trace exceptions. Note that address error, trace exception, and NMI requests bypass the interrupt controller's priority decision logic and are routed directly to the CPU. - 1. Interrupt requests are generated by one or more on-chip supporting modules or external interrupt sources. - 2. The interrupt controller checks the interrupt priorities set in the IPRA to IPRD and selects the interrupt with the highest priority. Interrupts with lower priorities remain pending. Among interrupts with the same priority level, the interrupt controller determines priority as explained in table 5-2. DataSheet4U.com - DataShe - 3. The interrupt controller compares the priority level of the selected interrupt request with the mask level in the CPU status register (bits I2 to I0). If the priority level is equal to or less than the mask level, the interrupt request remains pending. If the priority level is higher than the mask level, the interrupt controller accepts the interrupt request and proceeds to the next step. - 4. The interrupt controller checks the corresponding bit (if any) in the data transfer enable registers (DTEA to DTEB). If this bit is set to 1, the data transfer controller is started. Otherwise, the CPU interrupt exception-handling sequence is started. When the data transfer controller is started, the interrupt request is cleared (except for interrupt requests from the serial communication interface, which are cleared by writing to the TDR or reading the RDR). If the data transfer enable bit is cleared to 0 (or is nonexistent), the sequence proceeds as follows. For the case in which the data transfer controller is started, see section 6, "Data Transfer Controller". **HITACHI** 100 www.DataSheet4U.com et4U.com - 5. After the CPU has finished executing the current instruction, the program counter and status register (in minimum mode) or program counter, code page register, and status register (in maximum mode) are saved to the stack, leaving the stack in the condition shown in figure 5-3 (a) or (b). The program counter value saved on the stack is the address of the next instruction to be executed. T-49-19-16 - 6. The T (Trace) bit of the status register is cleared to 0, and the priority level of the interrupt is copied to bits I2 to I0, thus masking further interrupts unless they have a higher priority level. When an NMI is accepted, the interrupt mask level in bits I2 to I0 is set to 7. - 7. The interrupt controller generates the vector address of the interrupt, and the entry at this address in the exception vector table is read to obtain the starting address of the user-coded interrupt handling routine. In step 7, the same difference between the minimum and maximum modes exists as in the reset handling sequence. In the minimum mode, one word is copied from the vector table to the program counter, then the interrupt-handling routine starts executing from the address indicated in the program counter. In the maximum mode, two words are read. The lower byte of the first word is copied to the code page register. The second word is copied to the program counter. The interrupt-handling routine starts executing from the address indicated in the code page register and program counter. et4U.com DataSheet4U.com DataShe 101 HITACHI DataSheet/III.com www.DataSheet4U.com T-49-19-16 Program execution state Exception present? Address error? Trace? N Level-7 interrupt Level-6 interrupt? Level-1 interrupt? Mask level in SR≤6? Mask level Mask level Interrupt remains pending Data transfer enabled? Start DTC Read DTC vector Exception-handling sequence Read transfer mode Save PC Read source address Read data Maximum mode? Source address increment mode? N Save CP Increment source address (+1 or +2) Save SR Write source address et4U.com DataSheet4U.com DataShe Read destination address Clear T bit Write data Trace Destination address increment mode Address Increment destination error? address (+1 or +2) Update mask level Write destination address Read DTCR Vectoring DTCR-1 → DTCR Write DTCR To user-coded exception-handling Figure 5-2 Interrupt Handling Flowchart DTCR = 0? routine HITACHI 102 DataSheet4U.com www.DataSheet4U.com Figure 5-3 (a) and (b) show the stack before and after the interrupt exception-handling sequence. Figure 5-3 (a) Stack before and after Interrupt Exception-Handling (Minimum Mode) Figure 5-3 (b) Stack before and after Interrupt Exception-Handling (Maximum Mode) 103 HITACHI DataSheet4U.com Figure 5-4 shows the timing in minimum mode when the program area and stack are both in on-chip memory and the user-coded interrupt-handling routine starts at an even address. Figure 5-5 shows the timing in maximum mode when the program area and stack are both in external memory. #### 5.5 Interrupts During Operation of the Data Transfer Controller If an interrupt is requested during a DTC data transfer cycle, the interrupt is not accepted until the data transfer cycle has been completed and the next instruction has been executed. This is true even if the interrupt is an NMI. An example is shown below. et4U.com HITACHI 104 www.DataSheet4U.com DataShe 105 HITACHI **HITACHI** 106 DataSheet4U.com www.DataSheet4U.com T-49-19-16 Table 5-4 indicates the number of states that may elapse between the generation of an interrupt request and the execution of the first instruction of the interrupt-handling routine, assuming that the interrupt is not masked and not preempted by a higher-priority interrupt. Since word access is performed to onchip memory areas, fastest interrupt service can be obtained by placing the program in on-chip ROM and the stack in on-chip RAM. Table 5-4 Number of States before Interrupt Service | | | | Number of States | | |-------|-----------------------------------------------------------------------------------|--------------------------------------------------------|---------------------------------------------------------------|-----------------------------| | No. | Reason for Walt | | Minimum Mode | Maximum Mode | | 1 | Interrupt priority decision and comparison with mask level in CPU status register | | 2 states | | | 2 | Maximum number of states to completion of current instruction | Instruction is in on-chip<br>memory | x<br>(x = 38 for LDM inst<br>registers) | truction specifying all | | | | Instruction is in external memory | y (y = 74 + 16m for LDM instruction specifying all registers) | | | 3 | Number of states from saving of PC and SR (or PC, SR, | Stack is in on-chip RAM | 16 | 21 | | | and CP) until first instruction of interrupt-handling routine is prefetched. | Stack is in external memory <sub>ataSheet4</sub> U.com | 28 + 6m | 41 + 10m | | Total | Stack is in on-chip RAM | Instruction is in on-chip memory | 18 + x<br>(56) | 23 + x<br>(61) | | | | Instruction is in external memory | 18 + y<br>(92 + 16m) | 23 + y<br>(97 + 16m) | | | Stack is in external RAM | Instruction is in on-chip memory | 30 + 6m + x<br>(68 + 6m) | 43 + 10m + x<br>(81 + 10m) | | | | Instruction is in external memory | 30 + 6m + y<br>(104 + 22m) | 43 + 10m + y<br>(117 + 26m) | Notes: m: Number of wait states inserted in external memory access. Values in parentheses are for the LDM instruction specifying all registers. HITACHI 107 www.DataSheet4U.com et4U.com T-49-19-16 DataShe et4U.com DataSheet4U.com HITACHI DataSheet4U.com www.DataSheet4U.com DataSheet4U.com # Section 6 Data Transfer Controller #### 6.1 Overview T-49-19-16 The H8/520 chip includes a data transfer controller (DTC) that can be started by designated interrupts to transfer data from a source address to a destination address located in page 0. These addresses include in particular the registers of the on-chip supporting modules and I/O ports. Typical uses of the DTC are to change the setting of a control register of an on-chip supporting module in response to an interrupt from that module, or to transfer data from memory to an I/O port or the serial communication interface. Once set up, the transfer is interrupt-driven, so it proceeds independently of program execution, although program execution temporarily stops while each byte or word is being transferred. The data transfer functions of the DTC could also be performed by the CPU, but the DTC offers three advantages: - · It is faster. - · It requires less program coding. - · It has its own registers and does not require CPU registers to be used as pointers, etc. #### 6.1.1 Features et4U.com The main features of the DTC are listed below: - The source address and destination address can be set anywhere in the 64-kbyte address space of page 0. DataSheet4U.com - The DTC can be programmed to transfer one byte or one word of data per interrupt. - The DTC can be programmed to increment the source address and/or destination address after each byte or word is transferred. - After transferring a designated number of bytes or words, the DTC generates a CPU interrupt with the vector of the interrupt source that started the DTC. - This designated data transfer count can be set from 1 to 65,536 bytes or words. #### 6.1.2 Block Diagram Figure 6-1 shows a block diagram of the DTC. The four DTC control registers (DTMR, DTSR, DTDR, and DTCR) are invisible to the CPU, but corresponding information is kept in a register information table in memory. A separate table is maintained for each DTC interrupt type. When an interrupt requests DTC service, the DTC loads its 109 HITACHI DataSheet4U.com www.DataSheet4U.com www.DataSheet4U.com control registers from the table in memory, transfers the byte or word of data, and writes any altered register information back to memory. Figure 6-1 Block Diagram of Data Transfer Controller et4U.com #### 6.1.3 Register Configuration The four DTC control registers are listed in table 6-1. These registers are not located in the address space and cannot be written or read by the CPU. To set information in these registers, a program must write the information in a table in memory from which it will be loaded by the DTC. Table 6-1 Internal Control Registers of the DTC | Name | Abbreviation | Read/Write | |--------------------------------------------|--------------|------------| | Data transfer mode register | DTMR | Disabled | | Data transfer source address register | DTSR | Disabled | | Data transfer destination address register | DTDR | Disabled | | Data transfer count register | DTCR | Disabled | HITACHI 110 www.DataSheet4U.com www.DataSpect4U controlled by the four data transfer enable registers, which are located in high addresses in page 0. Table 6-2 lists these registers. Table 6-2 Data Transfer Enable Registers | Name | | Abbreviation | Read/Write | Initial Value | Address | |-----------------|---|--------------|------------|---------------|---------| | Data transfer | Α | DTEA | R/W | H'00 | H'FFF4 | | enable register | В | DTEB | R/W | H'00 | H'FFF5 | | | С | DTEC | R/W | H'00 | H'FFF6 | | | D | DTED | R/W | H'00 | H'FFF7 | # **6.2 Register Descriptions** # 6.2.1 Data Transfer Mode Register (DTMR) | Bit | 15 | | | | | | 7 | | | | | |------------|----|----|----|---|------|------|---|------|-------|------|---| | | Sz | SI | DI | _ | <br> | <br> | _ | <br> | <br>_ | <br> | | | Read/Write | | | | | <br> | <br> | | <br> | <br>_ | <br> | - | The data transfer mode register is a 16-bit register, the first three bits of which designate the data size and specify whether to increment the source and destination addresses. Bit 15—Sz (Size): This bit designates the size of the data transferred. et4U.com | כו וום | DataShe | |--------|--------------------------------------| | Sz | Description | | 0 | Byte transfer | | 1 | Word transfer* (two bytes at a time) | Note: \* For word transfer, the source and designation addresses must be even addresses. Bit 14—SI (Source Increment): This bit specifies whether to increment the source address. #### **Blt 14** | SI | Description | |----|-----------------------------------------------------------------------------| | 0 | Source address is not incremented. | | 1 | 1. If Sz = 0: Source address is incremented by +1 after each data transfer. | | | 2. If Sz = 1: Source address is incremented by +2 after each data transfer. | 111 HITACHI www.DataSheet4U.com # www.DataSheet4U.com Bit 13—DI (Destination Increment): This bit specifies whether to increment the destination address. | Bit 13 | T-49-19-16 | |--------|----------------------------------------------------------------------------------| | DI | Description | | 0 | Destination address is not incremented. | | 1 | 1. If Sz = 0: Destination address is incremented by +1 after each data transfer. | | | 2. If Sz = 1: Destination address is incremented by +2 after each data transfer. | Bits 12 to 0—Reserved Bits: These bits are reserved. ## 6.2.2 Data Transfer Source Address Register (DTSR) The data transfer source register is a 16-bit register that designates the data transfer source address. For word transfer this must be an even address. In the maximum mode, this address is implicitly located in page 0. #### 6.2.3 Data Transfer Destination Register (DTDR) The data transfer destination register is a 16-bit register that designates the data transfer destination address. For word transfer this must be an even address. In the maximum mode, this address is implicitly located in page 0. #### 6.2.4 Data Transfer Count Register (DTCR) HITACHI 112 www.DataSheet4U.com The data transfer count register is a 16-bit register that counts the number of bytes or words of data remaining to be transferred. The initial count can be set from 1 to 65,536. A register value of 0 designates an initial count of 65,536. T-49-19-16 The data transfer count register is decremented automatically after each byte or word is transferred. When its value reaches 0, indicating that the designated number of bytes or words have been transferred, a CPU interrupt is generated with the vector of the interrupt that requested the data transfer. # 6.2.5 Data Transfer Enable Registers A to D (DTEA to DTED) These four registers designate whether an interrupt starts the DTC. The bits in these registers are assigned to interrupts as indicated in table 6-3. No bits are assigned to the NMI, IRQ4, IRQ5, IRQ6, IRQ7, FOVI, OVI, and ERI interrupts, which cannot request data transfers. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|-----|-----|-----|-----| | | | | | | | | | | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W Table 6-3 Assignment of Data Transfer Enable Registers | | Interrupt Source | | Interrupt Source | | | |----------|------------------|--------------------------------------|------------------|---------------------------------------------------------------------|----------| | Register | Module | Bits 7 to 4 | Module | Bits 3 to 0 | | | DTEA | ĪRQ <sub>0</sub> | 7 6 5 4<br>— — DataSheet4U<br>— IRQo | ÎRQ3 - ÎRQ1 | 3 2 1 0<br> IRQ <sub>3</sub> IRQ <sub>2</sub> IRQ <sub>1</sub> | DataShee | | DTEB | FRT1 | — OCIB OCIA ICI | FRT2 | - OCIB OCIA ICI | | | DTEC | 8-Bit timer | — — CMIB CMIA | SCI1 | _ TXI RXI _ | | | DTED | SCI2 | _ TXI RXI _ | A/D converter | ADI | _ | Note: Bits marked "-" should always be cleared to 0. If the bit for a certain interrupt is set to 1, that interrupt is regarded as a request for DTC service. If the bit is cleared to 0, the interrupt is regarded as a CPU interrupt request. Only the 16 interrupts indicated in table 6-3 can request DTC service. DTE bits not assigned to any interrupt (indicated by "---" in table 6-3) should be left cleared to 0. 113 HITACHI DataSheet4U.com et4U.com Note on Timing of DTE Modifications: The interrupt controller requires two system clock (\$\phi\$) periods to determine the priority level of an interrupt. Accordingly, when an instruction modifies a data transfer enable register, the new setting does not take effect until after the next instruction has been executed. T-49-19-16 # 6.3 Data Transfer Operation ## 6.3.1 Data Transfer Cycle When started by an interrupt, the DTC executes the following data transfer cycle: - 1. From the DTC vector table, the DTC reads the address at which the register information table for that interrupt is located in memory. - 2. The DTC loads the data transfer mode register and source address register from this table and reads the data (one byte or word) from the source address. - 3. If so specified in the mode register, the DTC increments the source address register and writes the new source address back to the table in memory. - 4. The DTC loads the data transfer destination address register and writes the byte or word of data to the destination address. - 5. If so specified in the mode register, the DTC increments the destination address register and writes the new destination address back to the table in memory. - 6. The DTC loads the data transfer count register from the table in memory, decrements the data count, and writes the new count back to memory. - 7. If the data transfer count is now 0, the DTC generates a CPU interrupt. The interrupt vector is the vector of the interrupt type that started the DTC. DataShe At an appropriate point during this procedure the DTC also clears the interrupt request by clearing the corresponding flag bit in the status register of the on-chip supporting module to 0. (For IRQ1 to IRQ3, the DTC clears an internal latch.) But the DTC does not clear the data transfer enable bit in the data transfer enable register. This action, if necessary, must be taken by the user-coded interrupt-handling routine invoked at the end of the transfer. The data transfer cycle is shown in a flowchart in figure 6-2. For the steps from the occurrence of the interrupt up to the start of the data transfer cycle, see section 5.4.1, "Interrupt-Handling Flow". HITACHI 114 Figure 6-2 Flowchart of Data Transfer Cycle 115 HITACHI DataSheet4U.com www.DataSheet4U.com T-49-19-16 The DTC vector table is located immediately following the exception vector table at the beginning of page 0 in memory. For each interrupt that can request DTC service, the DTC vector table provides a pointer to an address in memory where the table of DTC control register information for that interrupt is stored. The register information tables can be placed in any available locations in page 0. Figure 6-3 DTC Vector Table In minimum mode, each entry in the DTC vector table consists of two bytes, pointing to an address in page 0. In maximum mode, for hardware reasons, each DTC vector table entry consists of four bytes but the first two bytes are ignored; the last two bytes point to an address which is implicitly assumed to be in page 0, regardless of the current page specifications. Figure 6-4 shows one DTC vector table entry in minimum and maximum mode. HITACHI 116 Figure 6-4 DTC Vector Table Entry Table 6-4 lists the addresses of the entries in the DTC vector table for each interrupt. Table 6-4 Addresses of DTC Vectors | | | _ | | |----|-------|--------|--------| | Δd | draee | of DTC | Vector | | Interrup | ot | Minimum Mode | Maximum Mode | | | | |----------|------------------|------------------|-------------------------------------|--|--|--| | IRQ | IRQ <sub>0</sub> | H'0080 to H'0081 | H'0100 to H'0103 | | | | | | IRQ <sub>1</sub> | H'0082 to H'0083 | H'0104 to H'0107<br>DataSheet4U.com | | | | | | IRQ2 | H'0084 to H'0085 | H'0108 to H'010B | | | | | | IRQ3 | H'0086 to H'0087 | H'010C to H'010F | | | | | FRT1 | ICI | H'0090 to H'0091 | H'0120 to H'0123 | | | | | | OCIA | H'0092 to H'0093 | H'0124 to H'0127 | | | | | | OCIB | H'0094 to H'0095 | H'0128 to H'012B | | | | | FRT2 | ICI | H'0098 to H'0099 | H'0130 to H'0133 | | | | | | OCIA | H'009A to H'009B | H'0134 to H'0137 | | | | | | OCIB | H'009C to H'009D | H'0138 to H'013B | | | | et4U.com DataShe HITACHI Table 6-4 Addresses of DTC Vectors (cont) | | | Address of DTC Vector | | | | | | | |----------------------|------|-----------------------|------------------|--|--|--|--|--| | Interrupt | | Minimum Mode | Maximum Mode | | | | | | | 8-Bit timer | CMIA | H'00A0 to H'00A1 | H'0140 to H'0143 | | | | | | | | CMIB | H'00A2 to H'00A3 | H'0144 to H'0147 | | | | | | | Serial communication | RXI | H'00AA to H'00AB | H'0154 to H'0157 | | | | | | | interface 1 | TXI | H'00AC to H'00AD | H'0158 to H'015B | | | | | | | Serial communication | RXI | H'00B2 to H'00B3 | H'0164 to H'0157 | | | | | | | interface 2 | TXI | H'00B4 to H'00B5 | H'0168 to H'016B | | | | | | | A/D converter | ADI | H'00B8 to H'00B9 | H'0170 to H'0173 | | | | | | #### 6.3.3 Location of Register Information in Memory For each interrupt, the DTC control register information is stored in four consecutive words in memory in the order shown in figure 6-5. Figure 6-5 Order of Register Information #### 6.3.4 Length of Data Transfer Cycle #### 1. Register Information in On-Chip RAM Table 6-5 lists the number of states required per data transfer, assuming that the DTC control register information is stored in on-chip RAM. This is the number of states required for loading and saving the DTC control registers and transferring one byte or word of data. Two cases are considered: a transfer between on-chip RAM and a register belonging to an I/O port or on-chip supporting module (i.e., a register in the register field from addresses H'FF80 to H'FFFF); and a transfer between such a register and external RAM. HITACHI 118 Table 6-5 Number of States per Data Transfer T-49-19-16 | Increment Mode | | On-Chip RAM | /I ↔ Module or I/O Register | External RAM ↔ Module or I/O Register | | | | |----------------|------------------|---------------|-----------------------------|---------------------------------------|---------------|--|--| | Source (SI) | Destination (DI) | Byte Transfer | Word Transfer | Byte Transfer | Word Transfer | | | | 0 | 0 | 31 | 34 | 32 | 38 | | | | 0 | 1 | 33 | 36 | 34 | 40 | | | | 1 | 0 | 33 | 36 | 34 | 40 | | | | 1 | 1 | 35 | 38 | 36 | 42 | | | Note: Numbers in the table are the number of states. The values in table 6-5 are calculated from the formula: $$N = 26 + 2 \times SI + 2 \times DI + Ms + MD$$ Where Ms and MD have the following meanings: Ms: Number of states for reading source data MD: Number of states for writing destination data The values of Ms and MD depend on the data location as follows: a. Byte or word data in on-chip RAM: ⇒ 2 states c. Word data in external RAM or register field: ⇒ 6 states #### et4U.com ## 2. Register Information in External RAMtaSheet4U.com DataShe If the DTC control register information is stored in external RAM, $20 + 4 \times SI + 4 \times DI$ must be added to the values in table 6-5. #### 3. Interrupt Controller Wait The values given above do not include the time between the occurrence of the interrupt request and the starting of the DTC. This time includes two states for the interrupt controller to check priority and a variable wait until the end of the current CPU instruction. At maximum, this time equals the sum of the values indicated for items No. 1 and 2 in table 6-6. If the data transfer count is 0 at the end of a data transfer cycle, the number of states from the end of the data transfer cycle until the first instruction of the user-coded interrupt-handling routine is executed is the value given for item No. 3 in table 6-6. 119 HITACHI | | | | Numbe | er of States | |-----|------------------------------------|----------------------------|-----------------------|---------------------| | No. | Reason for Wait | | Minimum Mode | Maximum Mode | | 1 | Interrupt priority decision and co | mparison with | 2 states | | | | mask level in CPU status registe | er | | | | 2 | Maximum number of | Instruction is in on-chip | x | | | | states to completion | memory | (x = 38 for LDM ins) | truction specifying | | | of current instruction | | all registers) | | | | | Instruction is in external | У | | | | | memory | (y = 74 + 16m for L | DM instruction | | | | | specifying all regist | ers) | | 3 | Number of states from saving | Stack is in on-chip | 16 | 21 | | | of PC and SR (or PC, SR, | RAM | | | | | and CP) until first instruction | Stack is in external | 28 + 6m | 41 + 10m | | | of interrupt-handling routine | memory | | | | | is prefetched. | | | | Note: m: Number of wait states inserted in external memory access. # 6.4 Procedure for Using the DTC A program that uses the DTC to transfer data must do the following: et4U.com - 1. Set the appropriate DTMR, DTSR, DTDR, and DTCR register information in the memory location indicated in the DTC vector table. - 2. Set the data transfer enable bit of the pertinent interrupt to 1, and set the priority of the interrupt source (in the interrupt priority register) and the interrupt mask level (in the CPU status register) so that the interrupt can be accepted. - 3. Set the interrupt enable bit in the control register for the interrupt source. (For IRQ0 to IRQ3, the control register is the IRQ control register.) Following these preparations, the DTC will be started each time the interrupt occurs. When the number of bytes or words designated by the DTCR value have been transferred, after transferring the last byte or word, the DTC generates a CPU interrupt. **HITACHI** 120 www.DataSheet4U.com The user-coded interrupt-handling routine must take action to prepare for or disable further DTC data transfer: by readjusting the data transfer count, for example, or clearing the data transfer enable bit. If no action is taken, the next interrupt of the same type will start the DTC with an initial data transfer count of 65,536. T-49-19-16 ## 6.5 Example Purpose: To receive 128 bytes of serial data via serial communication interface 1. #### **Conditions:** - · Operating mode: Minimum mode - Received data are to be stored in consecutive addresses starting at H'FE00. - DTC control register information for the RXI interrupt is stored at addresses H'FD80 to H'FD87. - Accordingly, the DTC vector table contains H'FD at address H'00AA and H'80 at address H'00AB. - The desired interrupt mask level in the CPU status register is 4, and the desired SCI1 interrupt priority level is 5. #### **Procedure** 1. The user program sets DTC control register information in addresses H'FD80 to H'FD87 as shown in table 6-7. t4U.com Table 6-7 DTC Control Register Information Set in RAM DataShe | Register | Description | Value Set | |----------|--------------------------------------|-----------| | DTMR | Byte transfer | | | | Source address fixed | H'2000 | | | Increment destination address | | | DTSR | Address of SCI receive data register | H'FEDD | | DTDR | Address H'FE00 | H'FE00 | | DTCR | Number of bytes to be received: 128 | H'0080 | | | | | - 2. The program sets the RXI (SCI Receive Interrupt) bit in the data transfer enable register (bit 1 of register DTEC) to 1. - 3. The program sets the interrupt mask in the CPU status register to 4, and the SCI1 interrupt priority in bits 2 to 0 of interrupt priority register IPRC to 5. 121 HITACHI www.DataSheet4U.com 4. The program sets SCI1 to the appropriate receive mode, and sets the receive interrupt enable (RIE) bit in the serial control register (SCR) to 1 to enable receive interrupts. T-49-19-16 - 5. Thereafter, each time the SCI1 receives one byte of data, it requests an RXI interrupt, which the interrupt controller directs toward the DTC. The DTC transfers the byte from SCI1's receive data register (RDR) into RAM, and clears the interrupt request before ending. - 6. When 128 bytes have been transferred (DTCR = 0), the DTC generates a CPU interrupt. The interrupt source is SCI1. The interrupt type is RXI. - 7. The user-coded RXI interrupt-handling routine processes the received data and disables further data transfer (by clearing the RIE bit, for example). et4U.com DataSheet4U.com DataShe HITACHI 122 DataSheet4U.com www.DataSheet4U.com www.DataSheet4U.com Figure 6-6 shows the DTC vector table and data in RAM for this example. Figure 6-6 Use of DTC to Receive Data via Serial Communication Interface 123 HITACHI DataSheet4U.com www.DataSheet4U.com 205 2 -- 44 10504 0051475 2PP -- HIL3 T-49-19-16 et4U.com DataSheet4U.com DataShe HITACHI DataSheet4U.com www.DataSheet4U.com 179 # Section 7 Wait-State Controller T-49-19-16 #### 7.1 Overview To simplify interfacing to low-speed external devices, the H8/520 has an on-chip wait-state controller (WSC) that can insert wait states (Tw) to prolong bus cycles. The wait-state function can be used in CPU and DTC access cycles to external addresses. It is not used in access to on-chip memory or registers. The Tw states are inserted between the T2 state and T3 state in the bus cycle. The number of wait states can be selected by a value set in the wait-state control register (WCR), or by holding the WAIT pin low for the required interval. #### 7.1.1 Features The main features of the wait-state controller are as follows: - Selection of three operating modes Programmable wait mode, pin wait mode, or pin auto-wait mode - 0, 1, 2, or 3 wait states can be inserted. And in the pin wait mode, 4 or more states can be inserted by holding the WAIT pin low. et4U.com DataSheet4U.com DataShe 125 HITACHI DataSheet4U.com # 7.1.2 Block Diagram Figure 7-1 shows a block diagram of the wait-state controller. Figure 7-1 Block Diagram of Wait-State Controller et4U.com # 7.1.3 Register Configuration DataSheet4U.com DataShe The wait-state controller has one control register: the wait-state control register described in table 7-1. **Table 7-1 Register Configuration** | Name | Abbreviation | Read/Write | Initial Value | Address | |-----------------------------|--------------|------------|---------------|---------| | Wait-state control register | WCR | R/W | H'F3 | H'FFF8 | HITACHI 126 DataSheet4U.com The wait-state control register (WCR) is an 8-bit register that specifies the wait mode and the number of wait states to be inserted. A reset initializes the WCR to specify the programmable wait mode with three wait states. The WCR is not initialized in the software standby mode. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|---|---|------|------|-----|-----| | | | | _ | _ | WMS1 | WMS0 | WC1 | WC0 | | Initial value | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | | Read/Write | | _ | | _ | R/W | R/W | R/W | R/W | Bits 7 to 4—Reserved: These bits cannot be modified and are always read as 1. Bits 3 and 2—Wait Mode Select 1 and 0 (WMS1 and WMS0): These bits select the wait mode as shown below: | Bit 3 | Bit 2 | | | |-------|-------|------------------------------------------------------------|-----------------| | WMS1 | WMS0 | Description | | | 0 | 0 | Programmable wait mode | (Initial value) | | 0 | 1 | No wait states are inserted, regardless of the wait count. | | | 1 | 0 | Pin wait mode | | | 1 | 1 | Pin auto-wait mode | | et4U.com Bits 1 and 0—Wait Count (WC1 and WC0): These bits specify the number of wait states to be inserted. DataShe Wait states are inserted only in bus cycles in which the CPU or DTC accesses an external address. | Bit 1 | Bit 0 | | | | |-------|-------|-------------------------------------------------------|-----------------|--| | WC1 | WC0 | Description | | | | 0 | 0 | No wait states are inserted, except in pin wait mode. | | | | 0 | 1 | 1 wait state is inserted. | | | | 1 | 0 | 2 wait states are inserted. | | | | 1 | 1 | 3 wait states are inserted. | (Initial value) | | HITACHI # www.DataSheet4U.com 7.3 Operation in Each Wait Mode T-49-19-16 Table 7-2 summarizes the operation of the three wait modes. Table 7-2 Wait Modes | Mode | WAIT PIn Function | Insertion Conditions | Number of Wait States Inserted | |---------------|-------------------|------------------------|---------------------------------------| | Programmable | Disabled | Inserted on access to | 0 to 3 wait states are inserted, as | | wait mode | | an off-chip address | specified by bits WC0 and WC1. | | WMS1 = 0 | | | | | WMS0 = 0 | | | | | Pin wait mode | Enabled | Inserted on access to | 0 to 3 wait states are inserted, as | | WMS1 = 1 | | an off-chip address | specified by bits WC0 and WC1, | | WMS0 = 0 | | | plus additional wait states while the | | | | | WAIT pin is held low. | | Pin auto-wait | Enabled | Inserted on access to | 0 to 3 wait states are inserted, as | | mode | | an off-chip address if | specified by bits WC0 and WC1. | | WMS1 = 1 | | the WAIT pin is low | | | WMS0 = 1 | | | | ## 7.3.1 Programmable Wait Mode The programmable wait mode is selected when WMS1 = 0 and WMS0 = 0. DataSheet4U.com Whenever the CPU or DTC accesses an off-chip address, the number of wait states set in bits WC1 and WC0 are inserted. The $\overline{\text{WAIT}}$ pin is not used for wait control; it is available as an I/O pin (P10). HITACHI 128 www.DataSheet4U.com DataShe et4U.com Figure 7-2 shows the timing of the operation in this mode when the wait count is 1 (WC1 = 0, WC0 = 1). Figure 7-2 Programmable Wait Mode #### 7.3.2 Pin Wait Mode et4U.com The pin wait mode is selected when WMS1 = 1 and WMS0 = 0. DataSheet4U.com In this mode the WAIT function of the P10/WAIT pin is used automatically. The number of wait states indicated by bits WC1 and WC0 are inserted into any bus cycle in which the CPU or DTC accesses an off-chip address. In addition, wait states continue to be inserted as long as the WAIT pin is held low. In particular, if the wait count is 0 but the WAIT pin is low at the rising edge of the ø clock in the T2 state, wait states are inserted until the WAIT pin goes high. This mode is useful for inserting four or more wait states, or when different external devices require different numbers of wait states. HITACHI 129 www.DataSheet4U.com DataShe DataSheet4U.com www.DataSheet4U.com Figure 7-3 shows the timing of the operation in this mode when the wait count is 1 (WC1 = 0, WC0 = 1) and the $\overline{\text{WAIT}}$ pin is held low to insert one additional wait state. 7-49-19-16 Figure 7-3 Pin Wait Mode et4U.com DataShe HITACHI 130 DataSheet4U.com T-49-19-16 The pin auto-wait mode is selected when WMS1 = 1 and WMS0 = 1. In this mode the WAIT function of the P10/WAIT pin is used automatically. In this mode, the number of wait states indicated by bits WC1 and WC0 are inserted, but only if there is a low input at the WAIT pin. Figure 7-4 shows the timing of this operation when the wait count is 1. In the pin auto-wait mode, the WAIT pin is sampled only once, on the falling edge of the ø clock in the T2 state. If the WAIT pin is low at this time, the wait-state controller inserts the number of wait states indicated by bits WC1 and WC0. The WAIT pin is not sampled during the Tw and T3 states, so no additional wait states are inserted even if the WAIT pin continues to be held low. This mode offers a simple way to interface a low-speed device: the wait states can be inserted by routing the address strobe (AS) signal to the WAIT pin and gating it with an address decode signal. Figure 7-4 Pin Auto-Wait Mode 131 HITACHI DataSheet4U.com # Section 8 Clock Pulse Generator 8.1 Overview T-49-19-16 The H8/520 chip has a built-in clock pulse generator (CPG) consisting of an oscillator circuit, a system (ø) clock divider, and a prescaler. The prescaler generates clock signals for the on-chip supporting modules. ## 8.1.1 Block Diagram Figure 8-1 Block Diagram of Clock Pulse Generator et4U.com DataSheet4U.com DataShe # 8.2 Oscillator Circuit If an external crystal is connected across the EXTAL and XTAL pins, the on-chip oscillator circuit generates a clock signal for the system clock divider. Alternatively, an external clock signal can be applied directly. # 1. Connecting an External Crystal Circuit Configuration: An external crystal can be connected as in the example in figure 8-2. An AT-cut parallel resonating crystal should be used. www.DataSheet4U.com Figure 8-2 Connection of Crystal Oscillator (Example) Crystal Oscillator: The external crystal should have the characteristics listed in table 8-1. Figure 8-3 Crystal Oscillator Equivalent Circuit et4U.com DataSheet4U.com **Table 8-1 External Crystal Parameters** | Frequency (MHz) | 2 | 4 | 8 | 12 | 16 | 20 | |-----------------|-----|-----|--------|-----|----|----| | Rs max (Ω) | 500 | 120 | 60 | 40 | 30 | 20 | | Co (pF) | | | 7 pF ı | max | | | Note on Board Design: When an external crystal is connected, other signal lines should be kept away from the crystal circuit to prevent induction from interfering with correct oscillation. See figure 8-4. When the board is designed, the crystal and its load capacitors should be placed as close as possible to the XTAL and EXTAL pins. HITACHI 134 DataSheet4U.com www.DataSheet4U.com DataSheet4U.com Figure 8-4 Notes on Board Design around External Crystal #### 2. Input of External Clock Signal Circuit Configuration: An external clock signal can be input at the EXTAL pin as shown in the example in figure 8-5. Figure 8-5 External Clock Input (Example) Note: The masked ROM version can be driven by supplying an external clock signal to the EXTAL pin only, leaving the XTAL pin open. The PROM version can also be driven in this way, leaving the XTAL pin open, when the clock frequency is 16 MHz or less. 135 HITACHI www.DataSheet4U.com . et4U.com DataSheet4U.com www.DataSheet4U.com DataShe DataSheet4U.com # Section 9 I/O Ports 9.1 Overview T-49-19-16 The H8/520 has seven parallel I/O ports. Ports 1 to 5 are eight-bit input/output ports. Port 6 is a four-bit (or eight-bit\*) input-only port. Port 7 is a six-bit input/output port. Table 9-1 summarizes the functions of each port. Input and output are memory-mapped. The CPU views each port as a data register (DR) located in the register field at the high end of page 0 of the address space. Each port (except port 6) also has a data direction register (DDR) which determines which pins are used for input and which for output. To read data from an I/O port, the CPU selects input in the data direction register and reads the data register. This causes the input logic level at the pin to be placed directly on the internal data bus. There is no intervening input latch. To send data to an output port, the CPU selects output in the data direction register and writes the desired data in the data register, causing the data to be held in a latch. The latch output drives the pin through a buffer amplifier. If the CPU reads the data register of an output port, it obtains the data held in the latch rather than the actual level of the pin. As table 9-1 indicates, all of the I/O port pins have dual functions. For example, pin 0 of port 1 can be as she used either as a general-purpose I/O pin (P10), or for input of the WAIT signal. The function of a pin is determined by the MCU operating mode, or by a value set in a control register. Outputs from ports 1 to 4 can drive one TTL load and a 90-pF capacitive load. Outputs from ports 5 and 7 can drive one TTL load and a 30-pF capacitive load. Outputs from ports 1 to 5 and 7 can also drive a Darlington transistor pair. Outputs from port 3 can drive a light-emitting diode (with 10-mA current sink). Ports 3 and 4 have built-in MOS pull-ups for each input. Port 5 has Schmitt inputs. Schematic diagrams of the I/O port circuits are shown in appendix C. Note: \* CP-68 package only www.DataSheet4U.com Single-Chip Mode P17, P16, and P15 Mode 7 Mode 4 Mode 3 Mode 2 Mode 1 AS, RD, and WR output P17/WR P16/RD P15/AS Description 8-bit input/output Port 1 절 Pins **Expanded Modes** input/output IRQ3 and IRQ2 IRQs and IRQz Page address P14/A16/IRQ3 P13/A17/IRQ2 P14 and P13 address (A16, (A16, A17) output input and input, page input/output A17) output, and P14 and P13 PT4 and PT3 input/output PT4 and PT3 input/output TRO IRO Input and PT1 input/output WAIT input and PT1 input/output Data bus (D7 to Do) Low address Low address Low address bus output (A7 - A0) (A7 - A0) ADTRG input, and page address IRO1 input, input IRQ<sub>1</sub> input, Page address output (A18) P12 input/output ADTRG input, and P12 input (A18) output, P10 input/output input/output P27 to P20 T-49-19-16 input/output bus output (A7 - A0) bus output (A7 - A0) P37 to P30 Low address Low address et4U.com HITACHI Table 9-1 I/O Port Summary 138 IRQ1/ADTRG P12/A18/ www.DataSheet4U.com Can drive LEDs.) pull-up. P27 - P20/ 8-bit input/output Port 2 D7 - D0 절 P11/IRQ0 P10/WAIT P37 - P30/ 8-bit input/output Port 3 A7 - A0 (Built-in MOS input | | | | , , , , | | |--------------------|---|---|---------|-------------| | vw.DataSheet4U.com | | | | <br>. • • • | | 1 1 | i | i | | ł | Table 9-1 I/O Port Summary (cont) et4U.com | p Mode | | | | 244 | | | | | | | | | | | | | | T- | 49- | -19 | -16 | <u> </u> | 2, | | |------------------|-------------|---------------------|--------------|----------------|----------------|--------------------------------------|------------|-----------|--------------|--------------|--------------|---------------------------------|-----------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--------|------------|------|---------|-----------|----------|----------|----------| | Single-Chip Mode | Mode 7 | IRO <sub>7</sub> to | IRO4 input | and P47 to P44 | input/output | σ | | | P43 to P40 | input/output | | | | by the 16-bit | | ; (ø). | | | | | | | | | | | Mode 4 | IRQ7 to | IRQ4 input, | high address | bus output | (A15 to A12), | and P47 to | P44 input | High address | bus output | (A11 to A8), | and P4s to | P4o input | or input and output | FTСІ1, FTI2, FTI1) | of the system clock | | | | | | | | | | Modes | Mode 3 | High | address | snq | output | (A15 to A8) | | | | | | | | General-purpose input/output pins (P57 to P50) also used for input and output by the 16-bit | free-running timer module (FTOA2, FTOA1, FTOB1, FTCI2, FTCI1, FTI2, FTI1) | and 8-bit timer module (TMO, TMRI, TMCI), and for output of the system clock (ø). | | | | | | | | | | Expanded Modes | Mode 2 | IRQ7 to | IRQ4 input, | high address | bus output | (A15 to A12), | and P47 to | P44 input | High address | bus output | (A11 to A8), | and P43 to | P4o input | input/output pins (P5 | r module (FTOA2, FT | odule (TMO, TMRI, 1 | | | | | | | | | | | Mode 1 | High | address | snq | output | (A <sub>15</sub> to A <sub>8</sub> ) | | ļ | [ | Data | She | et4l | J.co | General-purpose | free-running time | and 8-bit timer m | | | | | | | | | | | Pins | P47/A15/IRQ7 | P46/A14/IROs | P45/A13/IRQ5 | A44/A12/IRQ4 | | | | P43/A11 | P42/A10 | P41/A9 | P4 <sub>0</sub> /A <sub>8</sub> | | P57/FTOA2/ø | P5e/FTOA1 | P5s/FTOB2/ | FTC12 | P54/FTOB1/ | FTCI | P5a/TMO | P52/FTI2/ | TMRI | P51/FTI1 | P5v/TMCI | | | Description | 8-bit input/output | port | (Built-in MOS | input pull-up) | | | | | | | | | 8-bit input/output | port | (Schmit trigger | input) | | | | | | | | | | Port | Port 4 | | | | | | | | | | | | Port 5 | | | | | | | | | | | 139 HITACHI www.DataSheet4U.com DataSheet4U.com | | - • | | ~ | , , , | ~ . | |--------------|--------|----|---|-------|-----| | www.DataShee | et4U.c | om | | | | T-49-19-16 Table 9-1 I/O Port Summary (cont) et4U.com | Port Bescription Rode 1 Mode 2 Mode 3 Mode 4 Mode 7 Port 6 4-bit input port (3-bit input port) ANs – ANo General-purpose input (P67 to P60) and analog input (AN* to ANa)]* ANs – ANo Port 7 6-bit input/output P7s/CK1 General-purpose input (P67 to P60) and analog input (AN* to ANa)]* ANY – ANo)* Port 7 6-bit input/output P7s/CK1 General-purpose input/output pins (P7s to P7s), also used for input and output by serial Port 7 6-bit input/output P7s/CK2 General-purpose input/output pins (P7s to P7s), also used for input and output by serial Port 8 SCK2 (serial communication interface channel 1 (SCK1, RXD1, TXD1) SCK2 input/ SCK2 input/ P7s/TXD1 SCK2 (serial communication interface channel 2 clock) output (As) output (As) input/output P7s/TXD2 SCK2 (serial communication interface channel 2 clock) output (As) output (As) input/output P7s/TXD2 SCK2 (serial communication interface channel 2 (RXD2, TXD2) output (As) output (As) | | | | | Expande | Expanded Modes | | Single-Chip Mode | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------|-----------------------------------|------------------|-----------------------|------------------------------------|---------------------|------------------| | P6s – P6v/ General-purpose input (P6s to P6o) and analog input (ANo to ANs) (P67 – P6v/ [General-purpose input (P67 to P6o) and analog input (AN7 to ANo)]* AN7 – ANo)* P7s/SCK1 General-purpose input/output pins (P7s to P7s), also used for input and output by P7s/RXD1 communication interface channel 1 (SCK1, RXD1, TXD1) P7s/A1s/ SCK2 (serial communication Page address SCK2 input/ P7s/A1s/ SCK2 input/ and P72 address input/output and P72 address input/output P7s/RXD2 General-purpose input/output pins (P71, P70), also used for input and output by se P7v/TXD2 communication interface channel 2 (RXD2, TXD2) | Port | Description | Pins | Mode 1 | Mode 2 | Mode 3 | Mode 4 | Mode 7 | | (8-bit input port) (P67 – P6s/) (P67 – P6s/) (General-purpose input (P67 to P6s) and analog input (AN7 to AN9)* 6-bit input/output P7s/SCK1 General-purpose input/output pins (P7s to P7s), also used for input and output by port P7s/TXD1 P7s/TXD1 P7s/TXD1 SCK2 interface channel 2 clock) input/output and P72 input/output P7s/TXD2 General-purpose input/output pins (P71, P76), also used for input and output by set address output (A19) | Port 6 | 4-bit input port | P63 - P60/ | General-purpose | input (P6s to P6o) | and analog input (ANd | to ANs) | | | 6-bit input/output P7s/SCK1 General-purpose input (P67 to P60) and analog input (AN7 to AN0)]* 6-bit input/output P7s/SCK1 General-purpose input/output pins (P7s to P7s), also used for input and output by port P7s/TXD1 communication interface channel 1 (SCK1, RXD1, TXD1) P7s/TXD1 SCK2 (serial communication Page address SCK2 input/SCK2 input/sCK2 input/sCK3 interface channel 2 clock) output (A19) output, page input/output and P72 address input/output P7s/RXD2 General-purpose input/output pins (P71, P70), also used for input and output by set P7s/TXD2 communication interface channel 2 (RXD2, TXD2) | | (8-bit input port) | AN3 - ANo | | | | | | | 6-bit input/output P7s/SCK1 General-purpose input/output pins (P7s to P7s), also used for input and output by port P7s/RXD1 communication interface channel 1 (SCK1, RXD1, TXD1) P7s/TXD1 P7s/TXD1 P7s/TXD1 SCK2 (serial communication Page address SCK2 input/SCK2 interface channel 2 clock) output (Ai9) output (Ai9) input/output and P72 input/output P7./RXD2 General-purpose input/output pins (P71, P70), also used for input and output by se P7o/TXD2 communication interface channel 2 (RXD2, TXD2) | | | (P67 – P6o/ | [General-purpos | e input (P67 to P60) | and analog input (AN | 7 to ANo)]* | | | 6-bit input/output P7s/SCK1 General-purpose input/output pins (P7s to P7a), also used for input and output by port P7a/RXD1 communication interface channel 1 (SCK1, RXD1, TXD1) P7a/RXD1 SCK2 (serial communication Page address SCK2 input/SCK2 interface channel 2 clock) output (A1a) output, page input/output and P72 address input/output P7a/RXD2 General-purpose input/output pins (P71, P70), also used for input and output by set P7a/RXD2 communication interface channel 2 (RXD2, TXD2) | | | AN7 - ANO)* | | | | | | | P73/RXD1 P72/A19/ SCK2 (serial communication interface channel 1 (SCK1, RXD1, TXD1) P72/A19/ SCK2 interface channel 2 clock) output (A19) output, page input/output and P72 SCK2 input/output P72/A19/ SCK2 input/output input/output General-purpose input/output pins (P71, P70), also used for input and output by se communication interface channel 2 (RXD2, TXD2) | Port 7 | 6-bit input/output | P7s/SCK1 | General-purpose | ) suid that poins (I | <sup>5</sup> 75 to P73), also usec | for input and outpu | t by serial | | SCK2 (serial communication Page address SCK2 input/ interface channel 2 clock) output (A19) output, page input/output and P72 address input/output General-purpose input/output pins (P71, P70), also used for input and output by se communication interface channel 2 (RXD2, TXD2) | | port | P74/RXD1 | communication i | nterface channel 1 | SCK1, RXD1, TXD1) | | ۵ | | SCK2 (serial communication Page address SCK2 input/interface channel 2 clock) output (A19) output, page input/output and P72 address output (A19), or P72 input/output 22 General-purpose input/output pins (P71, P70), also used for input and output by se communication interface channel 2 (RXD2, TXD2) | | | P73/TXD1 | : | | | | | | interface channel 2 clock) output (A <sub>19</sub> ) output, page input/output and P72 address output (A <sub>19</sub> ), or P72 or P72 XD2 General-purpose input/output pins (P71, P70), also used for input and output by se communication interface channel 2 (RXD2, TXD2) | | | P72/A19/ | SCK2 (serial con | nmunication | Page address | SCK2 input/ | SCK2 input/ | | input/output and P72 input/output output (A19), or P72 input/output General-purpose input/output pins (P71, P70), also used for input and output by se | | | SCK2 | interface channe | il 2 clock) | output (A19) | output, page | output or P72 | | | | | | input/output and | P72 | | address | input/output | | | | | | input/output | | | output (A19), | | | | | | | .con | | | or P72 | | | | | | | า | | | input/output | | | | | | P7 <sub>1</sub> /RXD <sub>2</sub> | General-purpos | e input/output pins ( | P71, P70), also used f | or input and output | by serial | | | | | P7 <sub>0</sub> /TXD <sub>2</sub> | communication | interface channel 2 | (RXD2, TXD2) | | | e: \* CP-68 package on HITACHI 140 www.DataSheet4U.com DataShe DataSheet4U.com # 9.2.1 Overview Port 1 is an 8-bit input/output port with the pin configuration shown in figure 9-1. The pin functions depend on the MCU operating mode. Some pins can perform two or three functions simultaneously. Outputs from port 1 can drive one TTL load and a 90-pF capacitive load. They can also drive a Darlington transistor pair. et4U.com DataSheet4U.com DataShe DataSheet4U.com www.DataSheet4U T-49-19-16 Pin ➤ P17 / WR ➤ P16 / RD ← ► P15 / AS ← P14 / ÎRQ3 / A16 Port → P13 / ÎRQ2 / A17 1 ► P12 / IRQ1 / A18 / ADTRG ▶ P1₁ / IRQ₀ P10 / WAIT Mode 3 Modes 1 and 2 WR (output) WR (output) RD (output) RD (output) AS (output) AS (output) P14 (input/output) / IRQ3 (input) A<sub>16</sub> (output) P13 (input/output) / IRQ2 (input) A<sub>17</sub> (output) P12 (input/output) / IRQ1 (input) / A<sub>18</sub> (output) P11 (input/output) / IRQo (input) **ADTRG** (input) P1o (input/output) / WAIT (input) P11 (input/output) / IRQo (input) P1o (input/output) / WAIT (input) **Single-Chip Mode** Mode 4 DataShe P17 (input/output) WR (output) P16 (input/output) RD (output) P15 (input/output) AS (output) P14 (input/output) / IRQ3 (input) P14 (input) / IRQ3 (input) / A<sub>16</sub> (output) P13 (input/output) / IRQ2 (input) P1s (input) / IRQ2 (input) / A<sub>17</sub> (output) P12 (input/output) / IRQ1 (input) / P12 (input) / IRQ1 (input) / ADTRG (input) A<sub>18</sub> (output) / ADTRG (input) P11 (input/output) / IRQo (input) P11 (input/output) / IRQ0 (input) Figure 9-1 Pin Functions of Port 1 142 HITACHI P1o (input/output) / WAIT (input) et4U.com www.DataSheet4U.com P1o (input/output) #### 9.2.2 Port 1 Registers Table 9-2 lists the registers of port 1. T-49-19-16 Table 9-2 Port 1 Registers | Name | Abbreviation | Read/Write | Initial Value | Address | | |--------------------------------|--------------|------------|---------------|---------|--| | Port 1 data direction register | P1DDR | W | H'00* | H'FF80 | | | Port 1 data register | P1DR | R/W | H'00 | H'FF82 | | Note: \* In single-chip mode. #### 1. Port 1 Data Direction Register (P1DDR)—H'FF80 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|--------|--------|--------|--------|--------|--------|--------|--------| | | P17DDR | P16DDR | P1₅DDR | P14DDR | P13DDR | P12DDR | P11DDR | P1oDDR | | Initial value* | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | W | W | W | W | Note: \* In single-chip mode P1DDR is an 8-bit register that selects the direction of each pin in port 1. Details are given for each MCU operating mode below. Modes 1 and 2 (Expanded Minimum Modes): Bits 7 to 5 of P1DDR are fixed at 1 and cannot be written. Pins P17 to P15 are used for output of bus control signals. DataShe When bits 4 to 0 of P1DDR are set to 1, the corresponding pin of port 1 functions as an output pin. When these bits are cleared to 0, the corresponding pin functions as an input pin. Mode 3 (Expanded Maximum Mode with On-Chip ROM Disabled): Bits 7 to 2 of P1DDR are fixed at 1 and cannot be written. Pins P17 to P15 are used for output of bus control signals. Pins P14 to P12 are used for page address output. When bits 1 and 0 of P1DDR are set to 1, the corresponding pin of port 1 functions as an output pin. When these bits are cleared to 0, the corresponding pin functions as an input pin. Mode 4 (Expanded Maximum Mode with On-Chip ROM Enabled): Bits 7 to 5 of P1DDR are fixed at 1 and cannot be written. Pins P17 to P15 are used for output of bus control signals. 143 HITACHI www.DataSheet4U.com et4U.com When bits 4 to 2 of P1DDR are set to 1, pins P14 to P12 are used for page address output. When these bits are cleared to 0, the corresponding pin becomes available for general-purpose input. T-49-19-16 When bits 1 and 0 of P1DDR are set to 1, pins P11 and P10 function as output pins. When these bits are cleared to 0, the corresponding pin functions as an input pin. Mode 7 (Single-Chip Mode): A pin functions as an output pin if the corresponding bit in P1DDR is set to 1, and as in input pin if the bit is cleared to 0. P1DDR can be written but not read. An attempt to read this register does not cause an error, but all bits are read as 1, regardless of their true values. P1DDR is initialized to H'00 by a reset and in the hardware standby mode. P1DDR is not initialized in the software standby mode, so if a P1DDR bit is set to 1 when the chip enters the software standby mode, the corresponding pin continues to output the value in the port 1 data register. #### 2. Port 1 Data Register (P1DR)—H'FF82 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|-----|-----|-----|-----| | | P17 | P16 | P15 | P14 | P13 | P12 | P11 | P10 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W et4U.com DataSheet4U.com P1DR is an 8-bit register containing output data for pins P17 to P10. When port 1 is read, output pins return the value in the P1DR latch, regardless of the actual level at the pin. Input pins return the level at the pin, not the value in the P1DR latch. If any of the port 1 data direction bits are cleared to 0, selecting input, use only data transfer (MOV) instructions to write data in P1DR. Do not use arithmetic, logic, or bit manipulation instructions. These instructions read the input pins and may write unintended data in P1DR. #### 9.2.3 Pin Functions in Each Mode The functions of port 1 depend on the MCU operating mode. Table 9-3 shows the pin functions in modes 1 and 2. Table 9-4 shows the pin functions in mode 3. Table 9-5 shows the pin functions in mode 4. Table 9-6 shows the pin functions in the single-chip mode. HITACHI 144 www.DataSheet4U.com DataShe DataSheet4U.com T-49-19-16 | Pin | <b>Functions</b> | | | | | |------------|------------------|-------------------|---------------------|---------------------|--------------| | WR | Output of WR sig | nal. | | | | | RD | Output of RD sig | nal. | | | | | ĀS | Output of AS sig | nal. | | | | | P14 / IRQ3 | The function dep | ends on the IRQ3I | E bit in the IRQ co | ontrol register (IR | QCR) and the | | | P14DDR bit as fo | llows: | | | | | | IRQ3E | | 0 | | 1 | | | P14DDR | 0 | 1 | 0 | 1 | | | 5: ( | D4 look | D4 | JDO- innext | IDO: input | | IRQ3E | ( | 0 | | 1 | |--------------|-----------|------------|-----------------------------|------------------------------| | P14DDR | 0 | 1 | 0 | 1 | | Pin function | P14 input | P14 output | IRQ3 input<br>and P14 input | IRQ3 input<br>and P14 output | P13/IRQ2 The function depends on the IRQ2E bit and the P13DDR bit as follows: | IRQ2E | 0 | | 0 1 | | |--------------|-----------|------------|---------------|----------------| | P13DDR | 0 | 1 | 0 | 1 | | Pin function | P1s input | P1s output | IRQ2 input | IRQ2 input | | L., | | | and P1s input | and P13 output | et4U.com DataSheet4U.com DataShe 145 HITACHI DataSheet4U.com # Table 9-3 Port 1 Pin Functions in Modes 1 and 2 (cont) T-49-19-16 Pin **Functions** P12/IRQ1/ ADTRG The function depends on the IRQ1E bit, the P12DDR bit, and the trigger enable bit (TRGE) in the A/D control register (ADCR) as follows: | TRGE | 0 | | | | | |--------------|-----------|------------|-----------------------------|------------------------------|--| | IRQ1E | | 0 | | 1 | | | P12DDR | 0 | 1 | 0 | 1 | | | Pin function | P12 input | P12 output | IRQ1 input<br>and P12 input | IRQ1 input<br>and P12 output | | | TRGE | | | 1 | | |--------------|---------------|----------------|---------------|----------------| | IRQ1E | ( | ) | | 1 | | P12DDR | 0 | 1 | 0 | 1 | | Pin function | ADTRG input | ADTRG input | ADTRG input, | ADTRG input, | | | and P12 input | and P12 output | IRQ1 input, | ÎRQ1 input, | | | | | and P12 input | and P12 output | P11/IRQo The function depends on the IRQ0E bit and the P11DDR bit as follows: | IRQ0E | 0 | | | 1 | |--------------|-----------------------|------------|---------------|----------------| | P11DDR | 0 DataSheet4U.com | | 0 | 1 | | Pin function | P1 <sub>1</sub> input | P11 output | IRQ₀ input | IRQo input | | | | | and P11 input | and P11 output | et4U.com P1o/WAIT The function depends on the wait mode select 1 bit (WMS1) of the wait-state control register (WCR) and the P1oDDR bit as follows: | WMS1 | 0 | | | 1 | |--------------|-----------|------------|------------|---| | P1oDDR | 0 | 1 | 0 | 1 | | Pin function | P1o input | P1o output | WAIT input | | **HITACHI** 146 www.DataSheet4U.com DataShe ### www.DataSheet4U.com **Table 9-4** Port 1 Pin Functions in Mode 3 | | | T-49-19-16 | |-------|----------------------|------------| | Pin | Functions | | | WR | Output of WR signal. | | | RD AS | Output of RD signal. | | | AS | Output of AS signal. | | | A16 | A16 output | | | A17 | A17 output | | | A18 | A18 output | | P11 / IRQ0 The function depends on the IRQ0E bit and the P11DDR bit as follows: | IRQ0E | 0. | | 0. 1 | | 1 | |--------------|-----------|------------|-----------------------------|------------------------------|---| | P1:DDR | 0 | 1 | 0 | 1 | | | Pin function | P11 input | P11 output | IRQ₀ input<br>and P1₁ input | IRQo input<br>and P11 output | | P1o/WAIT The function depends on the wait mode select 1 bit (WMS1) of the wait-state control register (WCR) and the P11DDR bit as follows: | WMS1 | 0 | | | · | |--------------|-----------|------------|------------|---| | P1oDDR | 0 | 1 | 0 | 1 | | Pin function | P1o input | P1o output | WAIT input | | et4U.com DataSheet4U.com DataShe 147 **HITACHI** DataSheet4U.com P14DDR bit as follows: T-49-19-16 | Pin | Functions | |--------------|-----------------------------------------------------------------------------------| | WR | Output of WR signal. | | RD | Output of RD signal. | | ĀS | Output of AS signal. | | P14 / IRQ3 / | The function depends on the IRQ3E bit in the IRQ control register (IRQCR) and the | | RQ3E | · ( | ) | 1 | | |--------------|-----------|------------------------|---------------|------------------------| | 14DDR | 0 | 1 | 0 | 1 | | Pin function | P14 input | A <sub>16</sub> output | ĪRQ₃ input | A <sub>16</sub> output | | 'in function | P14 input | A16 output | and P14 input | А | P13 / IRQ2 / The function depends on the IRQ2E bit and the P13DDR bit as follows: A17 A<sub>16</sub> | IRQ2E | ( | ) | 1 | | |--------------|-----------|------------------------|-----------------------------|------------------------| | P13DDR | 0 | 1 | 0 | 11 | | Pin function | P13 input | A <sub>17</sub> output | IRQ2 input<br>and P13 input | A <sub>17</sub> output | P12/ IRQ1/ The function depends on the IRQ1E bit, the P12DDR bit, and the trigger enable bit (TRGE) in the A/D control register (ADCR) as follows: A18 / et4U.com ADTRG DataSheet4U.com | TRGE | 0 | | | | | |--------------|-----------|------------------------|-----------------------------|------------------------|--| | IRQ1E | ( | ) | 1 | | | | P12DDR | 0 | 1 | 0 | 1 | | | Pin function | P12 input | A <sub>18</sub> output | IRQ1 input<br>and P12 input | A <sub>18</sub> output | | | TRGE | 1 | | | | | |--------------|------------------------------|------------------------|----------------------------------------|------------|--| | IRQ1E | 0 | | 1 | | | | P12DDR | 0 | 1 | 0 | 1 | | | Pin function | ADTRG input<br>and P12 input | A <sub>18</sub> output | ADTRG input, IRQ1 input, and P12 input | A18 output | | HITACHI 148 www.DataSheet4U.com DataShe ETIH HE GER JELJOOD 1000. # Table 9-5 Port 1 Pin Functions in Mode 4 (cont) | Di- | Eunations | | |-----|-----------|--| | Pin | Functions | | T-49-19-16 P11 / ÎRQo The function depends on the IRQ0E bit and the P11DDR bit as follows: | IRQ0E | 0 | | 1 | | |--------------|-----------|------------|-----------------------------|------------------------------| | P11DDR | 0 | 1 | 0 | 1 | | Pin function | P11 input | P11 output | IRQo input<br>and P11 input | IRQ₀ input<br>and P1₁ output | P10/WAIT The function depends on the wait mode select 1 bit (WMS1) of the wait-state control register (WCR) and the P1oDDR bit as follows: | WMS1 | | ) | | 1 | |--------------|-----------|------------|------------|---| | P1oDDR | 0 | 1 | 0 | 1 | | Pin function | P1o input | P1o output | WAIT input | | et4U.com DataSheet4U.com DataShe 149 **HITACHI** DataSheet4U.com www.DataSheet4U.com Table 9-6 Port 1 Pin Functions in Single-Chip Mode T-49-19-16 Pin P17 **Functions** | P17DDR | 0 | 1 | |--------------|-----------|------------| | Pin function | P17 input | P17 output | P16 | P1eDDR | 0 | 1 | |--------------|-----------|------------| | Pin function | P16 input | P16 output | P15 | P1sDDR | 0 | 1 | |--------------|-----------|------------| | Pin function | P1s input | P1s output | P14/IRQ3 The function depends on the IRQ3E bit in the IRQ control register (IRQCR) and the P14DDR bit as follows: | IRQ3E | 0 | | 1 | | |--------------|-----------|------------|-----------------------------|------------------------------| | P14DDR | 0 | 1 | 0 | 1 | | Pin function | P14 input | P14 output | IRQ₃ input<br>and P1₄ input | IRQ3 input<br>and P14 output | et4U.com P13/IRQ2 The function depends on the IRQ2E bit and the P13DDR bit as follows: | IRQ2E | | ) | | 1 | |--------------|-----------|------------|-----------------------------|------------------------------| | P13DDR | 0 | 1 | 0 | 1 | | Pin function | P1s input | P1s output | IRQ2 input<br>and P13 input | IRQ2 input<br>and P13 output | HITACHI 150 DataShe Pin Functions P12 / IRQ1 / The function depends on the IRQ1E bit, the P12DDR bit, and the trigger enable bit ADTRG (TRGE) in the A/D control register (ADCR) as follows: TRGE 0 | TRGE | 0 | | | | | | |--------------|-----------|------------|-----------------------------|------------------------------|--|--| | IRQ1E | | ) | 1 | | | | | P12DDR | 0 | 1 | 0 | 1 | | | | Pin function | P12 input | P12 output | IRQ1 input<br>and P12 input | IRQ1 input<br>and P12 output | | | | TRGE | | • | 1 | | |--------------|---------------|----------------|-------------------------|----------------| | IRQ1E | | 0 | | ( | | P12DDR | 0 | 1 | 0 | 1 | | Pin function | ADTRG input | ADTRG input | ADTRG input, | ADTRG input, | | | and P12 input | and P12 output | IRQ <sub>1</sub> input, | IRQ1 input, | | | | | and P12 input | and P12 output | P11 / $\overline{IRQ_0}$ The function depends on the IRQ<sub>0</sub>E bit and the P11DDR bit as follows: | IRQ0E | C | ) | 1 | | | |--------------|-----------|----------------------|---------------|----------------|--| | P11DDR | 0 1 | | 0 | 1 | | | Pin function | P11 input | P11 input P11 output | | IRQo input | | | | DataSh | eet4U.com | and P11 input | and P11 output | | DataShe P10 et4U.com | P1₀DDR | 0 | 1 | |--------------|-----------|------------| | Pin function | P1o input | P1o output | 151 HITACHI DataSheet4U.com ### 9.3.1 Overview Port 2 is an 8-bit input/output port with the pin configuration shown in figure 9-2. In the expanded modes it operates as the external data bus (D7 - D0). In the single-chip mode it operates as a general-purpose input/output port. Outputs from port 2 can drive one TTL load and a 90-pF capacitive load. They can also drive a Darlington transistor pair. Figure 9-2 Pin Functions of Port 2 et4U.com ## 9.3.2 Port 2 Registers DataSheet4U.com DataShe Table 9-7 lists the registers of port 2. **Table 9-7 Port 2 Registers** | Name | Abbreviation | Read/Write | Initial Value | Address | |--------------------------------|--------------|------------|---------------|---------| | Port 2 data direction register | P2DDR | W | H'00 | H'FF81 | | Port 2 data register | P2DR | R/W | H'00 | H'FF83 | ## 1. Port 2 Data Direction Register (P2DDR)—H'FF81 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|--------|--------|--------|--------|--------|--------|--------|--------| | - | P27DDR | P26DDR | P25DDR | P24DDR | P23DDR | P22DDR | P21DDR | P2₀DDR | | Initial value* | 0 | 0 | 0 | 0 | 0 - | 0 | 0 | 0 | | Read/Write | W | W | W | W | W | W | W | W | HITACHI 152 www.Data P2DDR Is an 8-bit register that selects the direction of each pin in port 2. Expanded Modes: P2DDR is not used. Single-Chip Mode: A pin functions as an output pin if the corresponding bit in P2DDR is set to 1, and as in input pin if the bit is cleared to 0. P2DDR can be written but not read. An attempt to read this register does not cause an error, but all bits are read as 1, regardless of their true values. At a reset and in the hardware standby mode, P2DDR is initialized to H'00, making all eight pins input pins. P2DDR is not initialized in the software standby mode, so if a P2DDR bit is set to 1 when the chip enters the software standby mode, the corresponding pin continues to output the value in the port 2 data register. ## 2. Port 2 Data Register (P2DR)—H'FF83 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|-----|-----|-----|-----| | | P27 | P26 | P25 | P24 | P23 | P22 | P21 | P2o | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W P2DR is an 8-bit register containing output data for pins P27 to P20. At a reset and in the hardware standby mode, P2DR is initialized to H'00. DataShe When port 2 is read, output pins return the value in the P2DR latch, regardless of the actual level at the pin. Input pins return the level at the pin, not the value in the P2DR latch. If any of the port 2 data direction bits are cleared to 0, selecting input, use only data transfer (MOV) instructions to write data in P2DR. Do not use arithmetic, logic, or bit manipulation instructions. These instructions read the input pins and may write unintended data in P2DR. 153 HITACHI www.DataSheet4U.com et4U.com Port 2 has different functions in the expanded modes (modes 1, 2, 3, 4) and the single-chip mode (mode 7). Separate descriptions are given below. Pin Functions in Expanded Modes: In the expanded modes (modes 1, 2, 3, and 4), port 2 is automatically used as the data bus and P2DDR is ignored. Figure 9-3 shows the pin functions for the expanded modes. Figure 9-3 Port 2 Pin Functions in Expanded Modes Pin Functions in Single-Chip Mode: In the single-chip mode (mode 7), each of the port 2 pins can be designated as an input pin or an output pin, as indicated in figure 9-4, by setting the corresponding bit in P2DDR to 1 for output or clearing it to 0 for input. Figure 9-4 Port 2 Pin Functions in Single-Chip Mode HITACHI 154 www.DataSheet4U.com DataShe et4U.com 9.4.1 Overview T-49-19-16 Port 3 is an 8-bit input/output port with the pin configuration shown in figure 9-5. In the expanded modes it provides the low bits (A7 - A0) of the address bus. In the single-chip mode it operates as a general-purpose input/output port. Port 3 has built-in MOS pull-ups that can be turned on or off under program control. Outputs from port 3 can drive one TTL load and a 90-pF capacitive load. They can also drive a Darlington transistor pair or LED (with 10-mA current sink). Figure 9-5 Pin Functions of Port 3 DataShe ### 9.4.2 Port 3 Registers Table 9-8 lists the registers of port 3. Table 9-8 Port 3 Registers | Name | Abbreviation | Read/Write | Initial Value | Address | |--------------------------------|--------------|------------|---------------|---------| | Port 3 data direction register | P3DDR | W | H'00* | H'FF84 | | Port 3 data register | P3DR | R/W | H'00 | H'FF86 | Note: \* Initialized to H'00 in modes 2, 4, and 7. Fixed at H'FF in modes 1 and 3. 155 HITACHI DataSheet4U.com et4U.com ### www.DataSheet4U.com 1. Port 3 Data Direction Register (P3DDR)—H'FF84 | | | | | | | | [1· | <i>J</i> , - | |----------------|--------|---------------------|--------|---------------------|--------|--------|--------|---------------------| | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | P37DDR | P3 <sub>6</sub> DDR | P3₅DDR | P3 <sub>4</sub> DDR | P3₃DDR | P32DDR | P31DDR | P3 <sub>0</sub> DDR | | Initial value* | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | W | W | W | W | + 19 - 19 - 16 Note: \* In mode 2, 4, and 7 P3DDR is an 8-bit register that selects the direction of each pin in port 3. Modes 1, 2, 3, and 4: All bits of P3DDR are fixed at 1 and cannot be modified. Port 3 is used for address bus output. Single-Chip Mode: A pin functions as an output pin if the corresponding bit in P3DDR is set to 1, and as an input pin if the bit is cleared to 0. P3DDR can be written but not read. An attempt to read this register does not cause an error, but all bits are read as 1, regardless of their true values. At a reset and in the hardware standby mode, P3DDR is initialized to H'00, making all eight pins input pins. P3DDR is not initialized in the software standby mode, so if a P3DDR bit is set to 1 when the chip enters the software standby mode, the corresponding pin continues to output the value in the port 3 data register. et4U.com DataSheet4U.com ### 2. Port 3 Data Register (P3DR)—H'FF86 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|-----|-----|-----|-----| | | P37 | P36 | P35 | P34 | P33 | P32 | P31 | P30 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W **HITACHI** 156 www.DataSheet4U.com DataShe DataSheet4U.com www.DataSp3DR is an 8-bit register containing output data for pins P37 to P30. T-49-19-16 At a reset and in the hardware standby mode, P3DR is initialized to H'00. When port 3 is read, output pins return the value in the P3DR latch, regardless of the actual level at the pin. Input pins return the level at the pin, not the value in the P3DR latch. If any of the port 3 data direction bits are cleared to 0, selecting input, use only data transfer (MOV) instructions to write data in P3DR. Do not use arithmetic, logic, or bit manipulation instructions. These instructions read the input pins and may write unintended data in P3DR. ## 9.4.3 Pin Functions in Each Mode Port 3 has different functions in the expanded modes (modes 1 to 4), and the single-chip mode (mode 7). Separate descriptions are given below. Pin Functions in Modes 1 to 4: In the expanded modes, port 3 is used for output of the low bits (A7—A0) of the address bus. P3DDR is automatically set for output. Figure 9-6 shows the pin functions for the expanded modes. Figure 9-6 Port 3 Pin Functions in Modes 1 and 3 157 HITACHI DataSheet4U.com et4U.com Pin Functions in Single-Chip Mode: In the single-chip mode (mode 7), each of the port 3 pins can be designated as an input pin or an output pin, as indicated in figure 9-7, by setting the corresponding bit in P3DDR to 1 for output or clearing it to 0 for input. T-49-19-16 Figure 9-7 Port 3 Pin Functions in Single-Chip Mode ### 9.4.4 Built-in MOS Pull-Up The MOS input pull-ups of port 3 are turned on by clearing the corresponding bit in P3DDR to 0 and writing a 1 in P3DR. These pull-ups are turned off at a reset and in the hardware standby mode. Table 9-9 indicates the status of the MOS pull-ups in various modes. Table 9-9 Status of MOS Pull-Ups for Port 3 | et4U.com | Mode | Reset | Hardware Standby Mode | S Other Operating States* | |----------|------|-------|-----------------------|---------------------------| | | 1 | OFF | OFF | OFF | | | 2 | | | | | | 3 | | | | | | 4 | | | | | | 7 | | | ON/OFF | Note: \* Including the software standby mode. Notation: OFF: The MOS pull-up is always off. ON/OFF: The MOS pull-up is on when P3DDR = 0 and P3DR = 1, and off otherwise. **HITACHI** 158 www.DataSheet4U.com DataShe DataSheet4U.com www.Data Note on Usage of MOS Pull-Ups: If a bit manipulation instruction (BSET, BCLR, or BNOT) is used to modify the port 3 data register, since the instruction rewrites the data register according to the levels of input pins, it may switch their built-in MOS pull-ups on or off unintentionally. The same precaution applies to port 4. Example (BSET Instruction): Suppose a BSET instruction is executed to set bit 0 in the port 3 data register (P3DR) under the following conditions. P37: Input pin, low, MOS pull-up transistor on P36: Input pin, high, MOS pull-up transistor off P35 - P30: Output pins, low The intended purpose of this BSET instruction is to switch the output level at P30 from low to high. # **Before Execution of BSET Instruction** | P37 | P36 | P35 | P34 | P33 | P32 | P3 <sub>1</sub> | P30 | |-------|-------------------|------------------------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | input | Input | Output | Output | Output | Output | Output | Output | | Low | High | Low | Low | Low | Low | Low | Low | | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | 1 | 0 | 0 | 0 | 0 . | 0 | 0 | 0 | | On | Off | | Input<br>Low<br>0 | Input Input Low High 0 0 1 0 | Input Input Output Low High Low 0 0 1 1 0 0 | Input Input Output Output Low High Low Low 0 0 1 1 1 0 0 0 | Input Input Output Output Output Output Low High Low Low Low 0 0 1 1 1 1 0 0 0 0 | Input Input Output <td>Input Input Output Output</td> | Input Input Output | et4U.com # **Execution of BSET Instruction** DataSheet4U.com BSET, B #0, @PORT3 ; set bit 0 in port 3 data register # **After Execution of BSET Instruction** | | P57 | P56 | P5s | P54 | P53 | P52 | P51 | P50 | |--------------|-------|-------|--------|--------|--------|--------|--------|--------| | Input/output | Input | Input | Output | Output | Output | Output | Output | Output | | Pin state | Low | High | Low | Low | Low | Low | Low | High | | DDR | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | DR | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | | Pull-up | Off | On | Off | Off | Off | Off | Off | Off | 159 HITACHI DataSheet4U.com www.DataSheet4U.com DataShe www.DataS Explanation: To execute the BSET instruction, the CPU begins by reading port 3. Since P37 and P36 are input pins, the CPU reads the level of these pins directly, not the value in the P3DR data register. It reads P37 as low (0) and P36 as high (1). T-49-19-16 Since P35 to P30 are output pins, for these pins the CPU reads the value in the data register (0). The CPU therefore reads the value of port 3 as H'40, although the actual value in P3DR is H'80. Next the CPU sets bit 0 of the read data to 1, changing the value to H'41. Finally, the CPU writes this value (H'41) back to P3DR to complete the BSET instruction. As a result, bit P30 is set to 1, switching pin P30 to high output. In addition, bits P37 and P36 are both modified, changing the on/off settings of the MOS pull-up transistors of pins P37 and P36. **Programming Solution:** The switching of the pull-ups for P37 and P36 in this example can be avoided by reserving a one-byte work area in RAM, performing bit manipulations in the work area, then transferring the work area contents to the port 3 data register. RAMO is a symbol for the user-selected address of the work area below. ### **Before Execution of BSET Instruction** | MOV.B | #80, | R0 | |-------|------|--------| | MOV.B | RO, | @RAMO | | MOV.B | RO, | @PORT3 | ; put write data (H'80) for port 3 data register in R0 ; transfer from R0 to work area (RAM0) ; transfer from R0 to port 3 data register | | P37 | P36 | P35 | P34 | P33 | P32 | P3 <sub>1</sub> | P30 | |--------------|-------|-------|--------|--------|--------|--------|-----------------|--------| | Input/output | Input | Input | Output | Output | Output | Output | Output | Output | | Pin state | Low | High | Low | Low | Low | Low | Low | Low | | DDR | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | DR | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Pull-up | On | Off | RAM0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### **Execution of BSET Instruction** | BSET, B | #0, | @RAMO | |---------|-----|-------| ; set bit 0 in work area (RAM0) **HITACHI** 160 www.DataSheet4U.com DataShe MOV.B @RAMO, RO MOV.B RO, @PORT3 ; get value in work area (RAM0) ; write value to port 3 data register T-49-19-16 | P37 | P36 | P35 | P34 | P33 | P32 | P3 <sub>1</sub> | P30 | |-------|-------------------|-------------------------------------|--------------------------------------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Input | Input | Output | Output | Output | Output | Output | Output | | Low | High | Low | Low | Low | Low | Low | High | | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | On | Off | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Input<br>Low<br>0 | Input Input Low High 0 0 1 0 On Off | Input Input Output Low High Low 0 0 1 1 0 0 On Off Off | Input Input Output Output Low High Low Low 0 0 1 1 1 0 0 0 On Off Off Off | Input Input Output Output Output Low High Low Low Low 0 0 1 1 1 1 1 0 0 0 0 0 On Off Off Off Off | Input Input Output Output Output Output Output Low High Low Low Low Low 0 0 1 1 1 1 1 0 0 0 0 0 On Off Off Off Off | Input Input Output | et4U.com DataSheet4U.com DataShe 161 **HITACHI** DataSheet4U.com ---- 44762U4 UU2795O 37T ■ HIT3 9.5.1 Overview T-49-19-16 Port 4 is an eight-bit input/output port with the pin configuration shown in figure 9-8. In the expanded modes without on-chip ROM (modes 1 and 3), port 4 is used for output of bits A15 to A8 of the address bus. In the single-chip mode (mode 7) port 4 is a general-purpose input/output port which can also receive interrupt signals $\overline{IRQ7}$ to $\overline{IRQ4}$ . In the expanded modes with on-chip ROM (modes 2 and 4), the pins of port 4 function either for output of bits A15 – A8 of the address bus, or for general-purpose input and/or output of $\overline{IRQ7}$ to $\overline{IRQ4}$ . Port 4 has built-in MOS pull-ups that can be turned on or off under program control. Outputs from port 4 can drive one TTL load and a 90-pF capacitive load. They can also drive a Darlington transistor pair. Figure 9-8 Pin Functions of Port 4 HITACHI 162 # www.DataSheet4U.com 9.5.2 Port 4 Registers Table 9-10 lists the registers of port 4. Table 9-10 Port 4 Registers | Name | Abbreviation | Read/Write | Initial Value | Address | |--------------------------------|--------------|------------|---------------|---------| | Port 4 data direction register | P4DDR | w | H'00* | H'FF85 | | Port 4 data register | P4DR | R/W | H'00 | H'FF87 | Note: \* Initialized to H'00 in modes 2, 4, and 7. Fixed at H'FF in modes 1 and 3. # 1. Port 4 Data Direction Register (P4DDR)—H'FF85 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|--------|--------|--------|--------|--------|--------|--------|--------| | + | P47DDR | P46DDR | P4₅DDR | P44DDR | P43DDR | P42DDR | P41DDR | P4₀DDR | | Initial value* | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | W | W | W | W | Note: \* In modes 2, 4, and 7 P4DDR is an 8-bit register that selects the direction of each pin in port 4. Expanded Modes Not Using On-Chip ROM (Modes 1 and 3): All bits of P4DDR are fixed at 1 and cannot be modified. Port 4 is used for address output. et4U.com DataSheet4U.com Expanded Modes Using On-Chip ROM (Modes 2 and 4): If a bit in P4DDR is set to 1, the corresponding pin is used for address output. If a bit in P4DDR is cleared to 0, the pin is used for general-purpose input. P4DDR is initialized to H'00 at a reset and in the hardware standby mode. Single-Chip Mode: A pin functions as an output pin if the corresponding bit in P4DDR is set to 1, and as an input pin if the bit is cleared to 0. P4DDR can be written but not read. An attempt to read this register does not cause an error, but all bits are read as 1, regardless of their true values. DataShe 163 HITACHI DataSheet4U.com www.DataSheet4U.com At a reset and in the hardware standby mode, P4DDR is initialized to H'00, making all eight pins input pins. P4DDR is not initialized in the software standby mode, so if a P4DDR bit is set to 1 when the chip enters the software standby mode, the corresponding pin continues to output the value in the port 4 data register. T-49-19-16 ### 2. Port 4 Data Register (P4DR)—H'FF87 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|-----|-----|-----|-----| | | P47 | P46 | P45 | P44 | P43 | P42 | P41 | P40 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W P4DR is an 8-bit register containing output data for pins P47 to P40. At a reset and in the hardware standby mode, P4DR is initialized to H'00. When port 4 is read, output pins return the value in the P4DR latch, regardless of the actual level at the pin. Input pins return the level at the pin, not the value in the P4DR latch. If any of the port 4 data direction bits are cleared to 0, selecting input, use only data transfer (MOV) instructions to write data in P4DR. Do not use arithmetic, logic, or bit manipulation instructions. These instructions read the input pins and may write unintended data in P4DR. et4U.com DataSheet4U.com DataShe HITACHI 164 T-49-19-16 Port 4 operates in one way in modes 1 and 3, in another way in modes 2 and 4, and in a third way in mode 7. Separate descriptions are given below. Pin Functions in Modes 1 and 3: In modes 1 and 3 (expanded modes in which the on-chip ROM is not used), all bits of P4DDR are automatically set to 1 for output, and the pins of port 4 carry bits A<sub>15</sub> – A<sub>8</sub> of the address bus. Figure 9-9 shows the pin functions for modes 1 and 3. Figure 9-9 Port 4 Pin Functions in Modes 1 and 3 Pin Functions in Modes 2 and 4: Table 9-11 shows the usage of port 4 in modes 2 and 4. et4U.com DataSheet4U.com DataShe 165 HITACHI DataSheet4U.com # Table 9-11 Port 4 Pin Functions in Modes 2 and 4 Pin **Functions** T-49-19-16 P47 / A15 / IRQ7 The function depends on the IRQ7E bit and P47DDR bit as follows: | IRQ7E | 0 | | 0 1 | | |--------------|-----------|------------------------|-----------------------------|------------------------| | P47DDR | 0 | 1 | 0 | 1 | | Pin function | P47 input | A <sub>15</sub> output | IRQ7 input<br>and P47 input | A <sub>15</sub> output | P46 / A14 / IRQ6 The function depends on the IRQ6E bit and P46DDR bit as follows: | IRQ6E | 0 | | 1 | | |--------------|-----------|------------|-----------------------------|------------| | P46DDR | 0 | 1 | 0 | 1 | | Pin function | P46 input | A14 output | IRQe input<br>and P4e input | A14 output | P45 / A13 / TRQ5 The function depends on the IRQ5E bit and P4sDDR bit as follows: | IRQ5E | 0 | | 1 | | | | | | |-------------------|---|---|-----------------------------|------------------------|--|--|--|--| | P4sDDR | 0 | 1 | 0 | 1 | | | | | | Pin function | | | IRQs input<br>and P4s input | A <sub>13</sub> output | | | | | | Data Shoot/I Loom | | | | | | | | | DataSheet4U.com P44 / A12 / IRQ4 et4U.com The function depends on the IRQ4E bit and P44DDR bit as follows: | IRQ4E | 0 . | | 1 | | |--------------|-----------|------------|-----------------------------|------------| | P44DDR | 0 | 1 | 0 | 1 | | Pin function | P44 input | A12 output | IRQ4 input<br>and P44 input | A12 output | HITACHI 166 # www.DataSheet4U.com **Table 9-11 Port 4 Pin Functions in Modes 2 and 4 (cont)** | • | | | | | |---|--------|-----|----------|----| | | - 40 | 7 | $\sim$ | 16 | | | 1 /1/4 | . 1 | <b>4</b> | เก | | | T-49- | , | , | | | Pin | Functions | | | |-----------|---------------------|-----------|------------| | P43 / A11 | | | | | | P43DDR | 0 | 1 | | | Pin function | P43 input | A11 output | | P42 / A10 | | <u></u> | | | | P42DDR | 0 | 1 | | | Pin function | P42 input | A10 output | | P41 / A9 | | | | | L411Va | P4 <sub>1</sub> DDR | 0 | 1 | | | Pin function | P41 input | As output | | | | | | | P40 / A8 | | | | | | P4oDDR | 0 | 1 | | | Pin function | P4o input | As output | et4U.com DataSheet4U.com DataShe 167 HITACHI DataSheet4U.com Table 9-12 Port 4 Pin Functions in Single-Chip Mode T-49-19-16 ### **Functions** P47 / IRQ7 The function depends on the IRQ7E bit and P47DDR bit as follows: | IRQ7E | 0 | | , | 1 | |--------------|-----------|------------|---------------|----------------| | P47DDR | 0 | 1 | 0 | 1 | | Pin function | P47 input | P47 output | IRQ7 input | IRQ7 input | | | | | and P47 input | and P47 output | P46 / IRQ6 The function depends on the IRQ6E bit and P46DDR bit as follows: | IRQ6E | 0 | | | 1 | |--------------|-----------|------------|---------------|----------------| | P46DDR | 0 | 1 | 0 | 1 | | Pin function | P46 input | P46 output | IRQ6 input | IRQ6 input | | | | | and P4s input | and P46 output | P45 / IRQs The function depends on the IRQ5E bit and P45DDR bit as follows: | IRQ5E | | 0 | | 1 | |--------------|-----------|------------|---------------|----------------| | P45DDR | 0 | 1 | 0 | 1 | | Pin function | P4s input | P4s output | IRQs input | IRQs input | | | | | and P4s input | and P4s output | et4U.com P44 / IRQ4 The function depends on the IRQ4E bit and P44DDR bit as follows: | IRQ4E | 0 | | | 1 | |--------------|-----------|------------|---------------|----------------| | P44DDR | 0 | 1 | 0 | 1 | | Pin function | P44 input | P44 output | IRQ4 input | ÎRQ4 input | | | | | and P44 input | and P44 output | HITACHI 168 www.DataSheet4U.com DataShe # Table 9-12 Port 4 Pin Functions in Single-Chip Mode (cont) T-49-19-16 | Pin | Functions | | | , 10 | |-----------------|--------------|-----------------------|------------|------| | P43 | | | | | | | P43DDR | 0 | 1 | | | | Pin function | P43 input | P43 output | | | P4 <sub>2</sub> | | | | | | | P42DDR | 0 | 1 | | | | Pin function | P42 input | P42 output | | | P41 | | | | | | | P41DDR | 0 | 1 | | | | Pin function | P4 <sub>1</sub> input | P41 output | | | P40 | | | | | | | P4oDDR | 0 | 1 | | | | | | | | et4U.com DataSheet4U.com DataShe 169 HITACHI DataSheet4U.com ### 9.5.4 Built-In MOS Pull-Up The MOS input pull-ups of port 4 are turned on by clearing the corresponding bit in P4DDR to 0 and writing a 1 in P4DR. These pull-ups are turned off at a reset and in the hardware standby mode. Table 9-13 indicates the status of the MOS pull-ups in various modes. Table 9-13 Status of MOS Pull-Ups for Port 4 | Mode | Reset | Hardware Standby Mode | Other Operating States* | |------|-------|-----------------------|-------------------------| | 1 | OFF | OFF | OFF | | 2 | | | ON/OFF | | 3 | | | OFF | | 4 | | | ON/OFF | | 7 · | | | ON/OFF | Notes: \* Including the software standby mode. Notation: OFF: The MOS pu The MOS pull-up is always off. ON/OFF: The MOS pull-up is on when P4DDR = 0 and P4DR = 1, and off otherwise. Note on Usage of MOS Pull-Ups: See the note in section 9.4.4, "Built-in MOS Pull-up". et4U.com DataSheet4U.com DataShe **HITACHI** 170 DataSheet4U.com ## 9.6 Port 5 ### 9.6.1 Overview T-49-19-16 Port 5 is an eight-bit input/output port with the pin configuration shown in figure 9-10. Its pins also carry input and output signals for the free-running timers (FRT1 and FRT2) and 8-bit timer, and pin 7 can output the system clock $(\emptyset)$ . Port 5 has Schmitt inputs. Outputs from port 5 can drive one TTL load and a 30-pF capacitive load. They can also drive a Darlington transistor pair. Figure 9-10 Pin Functions of Port 5 et4U.com ## 9.6.2 Port 5 Registers DataSheet4U.con DataShe Table 9-14 lists the registers of port 5. Table 9-14 Port 5 Registers | Name | Abbreviation | Read/Write | Initial Value | Address | |--------------------------------|--------------|------------|---------------|---------| | Port 5 data direction register | P5DDR | W | H'00 | H'FF88 | | Port 5 data register | P5DR | R/W | H'00 | H'FF8A | 171 HITACHI ### 1. Port 5 Data Direction Register (P5DDR)—H'FF88 | Bit | 7 | 6 5 4 3 2 1 P56DDR P55DDR P54DDR P53DDR P52DDR P51DDR 0 0 0 0 0 0 0 W W W W W | 0 | | | | | | |---------------|--------|-----------------------------------------------------------------------------------------------|--------|--------|--------|--------|---------------------|---------------------| | | P57DDR | P5eDDR | P5₅DDR | P54DDR | P53DDR | P52DDR | P5 <sub>1</sub> DDR | P5 <sub>0</sub> DDR | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | W | W | W | W | P5DDR is an 8-bit register that selects the direction of each pin in port 5. A pin functions as an output pin if the corresponding bit in P5DDR is set to 1, and as an input pin if the bit is cleared to 0. P5DDR can be written but not read. An attempt to read this register does not cause an error, but all bits are read as 1, regardless of their true values. At a reset and in the hardware standby mode, P5DDR is initialized to H'00, setting all pins for input. P5DDR is not initialized in the software standby mode, so if a P5DDR bit is set to 1 when the chip enters the software standby mode, the corresponding pin continues to output the value in the port 5 data register. A transition to the software standby mode initializes the on-chip supporting modules, so any pins of port 5 that were being used by an on-chip timer when the transition occurs revert to general-purpose input or output, controlled by P5DDR and P5DR. ## 2. Port 5 Data Register (P5DR)—H'FF8A DataSheet4U.com | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----------------|-----|-----|-----|-----|-----|-----| | | P57 | P5 <sub>6</sub> | P5s | P54 | P53 | P52 | P51 | P5o | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W P5DR is an 8-bit register containing output data for pins P57 to P50. P5DR is initialized to H'00 by a reset and in the hardware standby mode. When port 5 is read, output pins return the value in the P5DR latch, regardless of the actual level at the pin. Input pins return the level at the pin, not the value in the P5DR latch. If any of the port 5 data direction bits are cleared to 0, selecting input, use only data transfer (MOV) instructions to write data in P5DR. Do not use arithmetic, logic, or bit manipulation instructions. These instructions read the input pins and may write unintended data in P5DR. HITACHI 172 www.DataSheet4U.com DataShe et4U.com T-49-19-16 The pin functions of port 5 are the same in all MCU operating modes. As figure 9-10 indicated, these pins are used for input and output of on-chip timer signals as well as for general-purpose input and output. For some pins, two or more functions can be enabled simultaneously. Table 9-15 shows how the functions of the pins of port 5 are selected. **Table 9-15 Port 5 Pin Functions** | Pin | Functions | | | | | | | | | |---------|---------------------------------------------------------------------------------------------------------------------------------|-------------|-----|-----|-------|--------|------|----|---| | P57 / | The function depends on the output enable A bit (OEA) of the FRT1 timer control | | | | | | | | | | FTOA2/ø | register (TCR), the P57DDR bit, and the system clock output enable bit (ØOE) in the port 7 data direction register, as follows: | | | | | | | | | | | øOE | | 1 | | | 0 | | | | | | OEA | ( | ) | 1 | | 0 | | 1 | | | | P57DDR | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | | | Pin function | ø output P5 | P57 | P57 | FTOA2 | | | | | | | | | | | input | output | outp | ut | | Note: A reset initializes øOE to 0 in mode 7 and to 1 in modes 1, 2, 3, and 4. et4U.com DataSheet4U.com DataShe 173 HITACHI # **Table 9-15 Port 5 Pin Functions (cont)** | | | | | T-4 | 49-19-16 | |----------------|------------------------------------------|-----------|-----------------------------------------|-------------------|----------| | Pin | Functions | | | | | | P56 /<br>FTOA2 | The function deper<br>register (TCR) and | | enable A bit (OEA) o<br>bit as follows: | f the FRT2 timer | control | | | OEB | 0 | | 1 | | | | P5eDDR | 0 | 1 | 0 | 11 | | | Pin function | P56 input | P56 output | FTOA <sub>1</sub> | output | P55/ The function depends on the output enable B bit (OEB) of the FRT2 timer control register (TCR) and on the P55DDR bit as follows: FTOB2/ FTCl<sub>2</sub> | OEB | C | ) | 1 | | |--------------|----------------------|-------|-------|--------| | P5sDDR | 0 | 1 | 0 | 1 | | Pin function | P5s input P5s output | | FTOB2 | output | | | FTCl2 | input | | | P54/ FTOB<sub>1</sub> / The function depends on the output enable B bit (OEB) of the FRT1 timer control register (TCR) and on the P54DDR bit as follows: FTCI<sub>1</sub> | OEB | 0 | | 1 | | |--------------|-----------------------------|------|-------------------|--------| | P54DDR | 0 | 1 | 0 | 1 | | Pin function | P54 inputtaSheet P54coutput | | FTOB <sub>1</sub> | output | | | FTCl <sub>1</sub> i | nput | | | et4U.com DataShe **HITACHI** 174 DataSheet4U.com ### Pin #### **Functions** P53 / TMO The function depends on output select bits 3 to 0 (OS3 to OS0) in the timer control/status register (TCSR) of the 8-bit timer, and on the P53DDR bit as follows: | OS3 to OS0 | All three | bits are 0 | At least one bit is set to 1 | | | |--------------|-----------|------------|------------------------------|--|--| | P53DDR | 0 | 1 | 0 1 | | | | Pin function | P53 input | P53 output | TMO output | | | P52 / FTI2 / **TMRI** In addition to functioning for general-purpose input or output, this pin receives the input capture signal (FTI<sub>2</sub>) for free-running timer 2 and the reset input (TMRI) for the 8-bit timer. TMRI input is enabled when the counter clear bits (CCLR1 and CCLR0) in the timer control register (TCR) are both set to 1. | P52DDR | 0 | 1 | | | |--------------|---------------------|------------|--|--| | Pin function | P52 input | P52 output | | | | | FTI2 and TMRI input | | | | P51 / FTI1 | P51DDR | 0 | 1 | | | | | |--------------|----------------------|------------|--|--|--|--| | Pin function | P51 input | P51 output | | | | | | | Della Sinput 4 U.com | | | | | | et4U.com P5o / TMCI In addition to functioning for general-purpose input or output, this pin can simultaneously be used for external clock input for the 8-bit timer, depending on clock select bits 2 to 0 (CKS2, CKS1, and CKS0) in the timer control register (TCR). | P5 <sub>0</sub> DDR | 0 | 1 | | | | |---------------------|------------|------------------------|--|--|--| | Pin function | P5₀ input | P5 <sub>0</sub> output | | | | | | TMCI input | | | | | 175 HITACHI www.DataSheet4U.com DataShe www.DataSheet4U.com ### 9.7 Port 6 T-49-19-16 ### 9.7.1 Overview Port 6 is a 4-bit input port that also receives inputs for the on-chip A/D converter. The pin functions are the same in all MCU operating modes, as shown in figure 9-11. Figure 9-11 Pin Functions of Port 6 In the 68-pin CP-68 package, port 6 has eight pins for general-purpose input and analog input. Figure 9-12 shows the pin configuration of port 6 in the CP-68 package. Figure 9-12 Pin Functions of Port 6 (CP-68 Package) HITACHI 176 DataSheet4U.com www.DataSheet4U.com ## 9.7.2 Port 6 Registers Port 6 has only the data register described in table 9-16. Since it is exclusively an input port, there is no data direction register. T-49-19-16 Table 9-16 Port 6 Registers | Name | Abbreviation | Read/Write | Address | |----------------------|--------------|------------|---------| | Port 6 data register | P6DR | R | H'FF8B | ### 1. Port 6 Data Register (P6DR)—H'FF8B | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|-----|-----|-----|-----|-----|-----|-----|-----| | | P67 | P66 | P65 | P64 | P63 | P62 | P61 | P60 | | Read/Write | R | R | R | R | R | R | R | R | Note: Bits 7 to 4 are valid in the CP-68 package only. When the CPU reads P6DR it always reads the current status of each pin, except that during A/D conversion the pin currently being converted reads 1 regardless of the actual input voltage at that pin. In a 64-pin package, the data read from the upper four bits are indeterminate. et4U.com DataSheet4U.com DataShe 177 HITACHI ETIH**EN** 7E7 4496204 0027966 797 **EN**HITS ### 9.8 Port 7 9.8.1 Overview T-49-19-16 Port 7 is a 6-bit input/output port with the pin configuration shown in figure 9-13. In addition to general-purpose input and output, its pins are used for input and output by the on-chip serial communication interface (SCI). In the expanded maximum modes (modes 3 and 4), it also supplies bit A19 of the page address bus. Outputs from port 7 can drive one TTL load and a 30-pF capacitive load. They can also drive a Darlington transistor pair. et4U.com DataSheet4U.com DataShe HITACHI 178 DataSheet4U.com Figure 9-13 Pin Functions of Port 7 179 HITACHI Table 9-17 lists the registers of port 7. Table 9-17 Port 7 Registers | Name | Abbreviation | abbreviation Read/Write | | Address | | |--------------------------------|--------------|-------------------------|-------|---------|--| | Port 7 data direction register | P7DDR | W | H'40* | H'FF8C | | | Port 7 data register | P7DR | R/W | H'00 | H'FF8E | | Note: \* Initialized to H'40 in modes 1, 2, 3, and 4, and to H'00 in mode 7. # 1. Port 7 Data Direction Register (P7DDR)—H'FF8C | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 11 | 0 | |---------------|---|-----|--------|--------|--------|--------|--------|--------| | | | øOE | P7₅DDR | P74DDR | P7₃DDR | P72DDR | P71DDR | P7₀DDR | | Initial value | | 1/0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | | W | W | W | W | W | W | W | P7DDR is an 8-bit register that selects the direction of each pin in port 7. Bit 7 is reserved. Bit 6 selects whether the system clock (ø) is output at pin P57 in port 5. The usage of P7DDR depends on the MCU operating mode as explained below. Modes 1, 2, and 4: A pin functions as an output pin if the corresponding bit in P7DDR is set to 1, and as an input pin if the bit is cleared to 0. P7DDR can be written but not read. An attempt to read this register does not cause an error, but all bits are read as 1, regardless of their true values. At a reset and in the hardware standby mode, P7DDR is initialized to H'40, setting all pins to the input state. P7DDR is not initialized in the software standby mode, so if a P7DDR bit is set to 1 when the chip enters the software standby mode, the corresponding pin continues to output the value in the port 7 data register. A transition to the software standby mode initializes the serial communication interface module, so any pins of port 7 that were being used for serial communication when the transition occurs revert to general-purpose input or output, controlled by P7DDR and P7DR. HITACHI 180 www.DataSheet4U.com DataShe et4U.com Bits 5 to 3 and 1 to 0 can be set to 1 for output or cleared to 0 for input as in the other MCU modes. Mode 7: In single-chip mode, P7DDR is initialized to H'00 at a reset and in the hardware standby mode. ## 2. Port 7 Data Register (P7DR)—H'FF8E | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|-----|-----|-----|-----|-----------------|-----| | | | _ | P75 | P74 | P73 | P72 | P7 <sub>1</sub> | P7o | | Initial value | _ | | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | | | R/W | R/W | R/W | R/W | R/W | R/W | P7DR is an 8-bit register containing the data for pins P76 to P70. Bits 7 and 6 are reserved. When port 7 is read, output pins return the value in the P7DR latch, regardless of the actual level at the pin. Input pins return the level at the pin, not the value in the P7DR latch. If any of the port 7 data direction bits are cleared to 0, selecting input, use only data transfer (MOV) instructions to write data in P7DR. Do not use arithmetic, logic, or bit manipulation instructions. These instructions read the input pins and may write unintended data in P7DR. ### et4U.com 9.8.3 Pin Functions DataSheet4U.com DataShe The pin functions of port 7 depend on the MCU operating mode. Table 9-18 shows how the functions are selected in modes 1, 2, and 7. Table 9-19 shows how they are selected in mode 3. Table 9-20 shows how they are selected in mode 4. 181 HITACHI Pin **Functions** P75 / SCK1 The function depends on the communication mode bit $(C/\overline{A})$ and the clock enable 1 and 2 bits (CKE1 and CKE0) of the serial control register (SCR) of SCI1 as follows: | C/Ā | | 0 | | | | | 1 | | |--------------|--------------------|---------------------------|--------|---|--------------------|---|---------|---| | CKE1 | | 0 | | 1 | ( | ) | | 1 | | CKE0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | | Pin function | P7s<br>input<br>or | SCI1<br>internal<br>clock | SCI1 e | | SCI1 in<br>clock o | | SCI1 ex | | | | output* | output | | | 1 | | | | Note: \* Input or output is selected by the P7sDDR bit. P74 / RXD1 The function depends on the receive enable bit (RE) of the serial control register (SCR) of SCI1 and on the P74DDR bit as follows: | RE | | 0 | | 1 | | |--------------|-----------|------------|------------|---|--| | P74DDR | 0 1 | | 0 | 1 | | | Pin function | P74 input | P74 output | RXD1 input | | | P73 / TXD1 The function depends on the transmit enable bit (TE) of the serial control register (SCR) of SCI1 and on the P73DDR bit as follows: | TE | 0 | | • | 1 | |--------------|-----------|------------|-------------------------|----| | P7₃DDR | 0 1 | | 0 | 11 | | Pin function | P73 input | P73 output | TXD <sub>1</sub> output | | et4U.com HITACHI 182 www.DataSheet4U.com Pin **Functions** P72 / SCK2 The function depends on the communication mode bit $(C/\overline{A})$ and the clock enable 1 and 2 bits (CKE1 and CKE0) of the serial control register (SCR) of SCI2 as follows: | C/Ā | | C | ) | - | | | 1 | | |--------------|----------------------|-------------------------------------|--------------------|---|--------|---|---------|---| | CKE1 | | 0 | | 1 | ļ | 0 | | 1 | | CKE0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | | Pin function | P72 input or output* | SCI2<br>internal<br>clock<br>output | SCI2 e<br>clock in | | SCI2 i | | SCI2 ex | | Note: \* Input or output is selected by the P72DDR bit. P71 / RXD2 The function depends on the receive enable bit (RE) of the serial control register (SCR) of SCI2 and on the P71DDR bit as follows: | RE | | 0 | | 1 | | |--------------|-----------|------------------------|------------|---|--| | P71DDR | 0 1 | | 0 | 1 | | | Pin function | P71 input | P7 <sub>1</sub> output | RXD2 input | | | P70 / TXD2 The function depends on the transmit enable bit (TE) of the serial control register (SCR) of SCI2 and on the P7oDDR bit as follows: | TE | ( | 0 | | 1 | |--------------|-----------|------------|-------------|---| | P7₀DDR | 0 | 1 | 0 | 1 | | Pin function | P7o input | P7₀ output | TXD2 output | | et4U.com 183 HITACHI www.DataSheet4U.com ממר ז 🚃 אאימטעווא החכנעונ ואח 📟 שדו מ # Table 9-19 Port 7 Pin Functions in Mode 3 T-49-19-16 Pin #### **Functions** P75 / SCK1 The function depends on the communication mode bit $(C/\overline{A})$ and the clock enable 1 and 2 bits (CKE1 and CKE0) of the serial control register (SCR) of SCI1 as follows: | C/Ā | 0 | | | | | 1 | | | |--------------|----------------------|-------------------------------------|--------------------|---|---------|---|----------|---| | CKE1 | | 0 | | 1 | ( | 0 | <u> </u> | 1 | | CKE0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | | Pin function | P7s input or output* | SCI1<br>internal<br>clock<br>output | SCI1 e<br>clock in | | SCI1 in | | SCI1 ex | | Note: \* Input or output is selected by the P7sDDR bit. P74 / RXD1 The function depends on the receive enable bit (RE) of the serial control register (SCR) of SCI1 and on the P74DDR bit as follows: | RE | 0 | | 1 | · · · · · · · · · · · · · · · · · · · | |--------------|-----------|------------|------------------------|---------------------------------------| | P74DDR | 0 | 1 0 | | 1 | | Pin function | P74 input | P74 output | RXD <sub>1</sub> input | | et4U.com DataSheet4U.com DataShe HITACHI 184 DataSheet4U.com Pin **Functions** P73 / TXD1 The function depends on the transmit enable bit (TE) of the serial control register (SCR) of SCI1 and on the P73DDR bit as follows: | TE | | 0 | | 1 | | |--------------|-----------|------------|-------------|---|--| | P7₃DDR | 0 | 1 | 0 | 1 | | | Pin function | P7s input | P73 output | TXD1 output | | | A19 A19 page address output. P71 / RXD2 The function depends on the receive enable bit (RE) of the serial control register (SCR) of SCI2 and on the P71DDR bit as follows: | RE | 0 | | | 1 | |--------------|-----------|------------|------------|---| | P71DDR | 0 | 0 1 | | 1 | | Pin function | P71 input | P71 output | RXD2 input | | P70 / TXD2 The function depends on the transmit enable bit (TE) of the serial control register (SCR) of SCI2 and on the P7oDDR bit as follows: | TE | ( | ) | | 1 | |--------------|---------------------------|------------------------|-------------|---| | P7₀DDR | 0 1 | | 0 | 1 | | Pin function | P7o input <sub>taSh</sub> | eet4 <b>P7e.output</b> | TXD2 output | | et4U.com 185 HITACHI T-49-19-16 Pin **Functions** P75 / SCK1 The function depends on the communication mode bit $(C/\overline{A})$ and the clock enable 1 and 2 bits (CKE1 and CKE0) of the serial control register (SCR) of SCI1 as follows: | C/Ā | | C | ) | | 1 | | | | | | | |--------------|---------|----------|---------|---------|--------|---------|---------------------------|---|--|--|--| | CKE1 | | 0 | | 1 | | 0 | 1 | | | | | | CKE0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | | | | | Pin function | P75 | SCI1 | SCI1 e | xternal | SCI1 i | nternal | SCI1 external clock input | | | | | | | input | internal | clock i | nput | clock | output | | | | | | | | or | clock | | | | | | | | | | | | output* | output | | | | | <u></u> | | | | | Note: \* Input or output is selected by the P7sDDR bit. P74 / RXD1 The function depends on the receive enable bit (RE) of the serial control register (SCR) of SCI1 and on the P74DDR bit as follows: | RE | | ) 1 | | | | | | |--------------|-----------|------------|-----|---------|--|--|--| | P74DDR | 0 | 1 | 0 | 1 | | | | | Pin function | P74 input | P74 output | RXD | ı input | | | | et4U.com DataSheet4U.com DataShe **HITACHI** 186 DataSheet4U.com Pin **Functions** P73 / TXD1 The function depends on the transmit enable bit (TE) of the serial control register (SCR) of SCI1 and on the P7sDDR bit as follows: | TE | | 0 | 1 | | | | | |--------------|-----------|------------|-------------|---|--|--|--| | P73DDR | 0 | 1 | 0 | 1 | | | | | Pin function | P73 input | P73 output | TXD1 output | | | | | P72 / A19 / SCK2 The function depends on the C/A, CKE1, and CKE0 bits of the serial control register (SCR) of SCI2 and on P72DDR as follows: | P72DDR | | 0 | | | |--------------|-----------|----------------------------|--------------|----------------| | C/Ā | | 0 | <u></u> | | | CKE1 | | 1 | | | | CKE0 | 0 | 1 | 0 | 1 | | Pin function | P72 input | SCI2 internal clock output | SCI2 externa | al clock input | | P72DDR | | | 0 | 1 | | |--------------|--------|-------------------|------------|------------|------------------------| | C/Ā | | | 1 | Don't care | | | CKE1 | | <b>0</b> DataSh | neet4U.cor | ħ | Don't care | | CKE0 | 0 | 1 | 0 | 1 | Don't care | | Pin function | SCI2 i | nternal<br>output | SCI2 e | 1 | A <sub>19</sub> output | DataShe et4U.com 187 **HITACHI** DataSheet4U.com Table 9-20 Port 7 Pin Functions in Mode 4 (cont) T-49-19-16 Pin **Functions** P71 / RXD2 The function depends on the receive enable bit (RE) of the serial control register (SCR) of SCI2 and on the P71DDR bit as follows: | RE | | 0 | | 1 | | | |--------------|-----------|------------|------------|---|--|--| | P71DDR | 0 | 1 | 0 | 1 | | | | Pin function | P71 input | P71 output | RXD2 input | | | | P70 / TXD2 The function depends on the transmit enable bit (TE) of the serial control register (SCR) of SCI2 and on the P7oDDR bit as follows: | TE | ( | 0 | 1 | | | | |--------------|-----------|------------|-------------|--|--|--| | P7₀DDR | 0 | 11 | 0 1 | | | | | Pin function | P7o input | P7o output | TXD2 output | | | | et4U.com DataSheet4U.com DataShe HITACHI 188 DataSheet4U.com # Section 10 16-Bit Free-Running Timers #### 10.1 Overview T-49-19-16 The H8/520 has an on-chip 16-bit free-running timer (FRT) module with two independent channels (FRT1 and FRT2). Both channels are functionally identical. Each channel has a 16-bit free-running counter that it uses as a time base. Applications of the FRT module include rectangular-wave output (up to two independent waveforms per channel), input pulse width measurement, and measurement of external clock periods. #### 10.1.1 Features The features of the free-running timer module are listed below. - Selection of four clock sources The free-running counters can be driven by an internal clock source (\$\phi/4\$, \$\phi/8\$, or \$\phi/32\$), or an external clock input (enabling use as an external event counter). - Two independent comparators Each free-running timer channel can generate two independent waveforms. - Input capture function The current count can be captured on the rising or falling edge (selectable) of an input signal. - Four types of interrupts Compare-match A and B, input capture, and overflow interrupts can be requested independently. The compare-match and input capture interrupts can be served by the data transfer controller (DTC), enabling interrupt-driven data transfer with minimal CPU programming. - Counter can be cleared under program control The free-running counters can be cleared on compare-match A. DataShe 189 HITACHI DataSheet4U.com et4U.com ## 10.1.2 Block Diagram T-49-19-16 Figure 10-1 shows a block diagram of one free-running timer channel. Figure 10-1 Block Diagram of 16-Bit Free-Running Timer HITACHI 190 DataSheet4U.com et4U.com # 10.1.3 Input and Output Pins T-49-19-16 Table 10-1 lists the input and output pins of the free-running timer module. Table 10-1 Input and Output Pins of Free-Running Timer Module | Channel | Name | Abbreviation | I/O | Function | |---------|---------------------|---------------------|----------|--------------------------------------------------| | 1 | Output compare A | FTOA <sub>1</sub> | Output | Output controlled by comparator A of FRT1 | | | Output compare B or | FTOB <sub>1</sub> / | Output / | Output controlled by comparator B of | | | counter clock input | FTCI <sub>1</sub> | Input | FRT1, or input of external clock source for FRT1 | | | Input capture | FTI <sub>1</sub> | Input | Trigger for capturing current count of FRT1 | | 2 | Output compare A* | FTOA2 | Output | Output controlled by comparator A of FRT2 | | | Output compare B or | FTOB <sub>2</sub> / | Output / | Output controlled by comparator B of FRT2, or | | | counter clock input | FTCI2 | Input | input of external clock source for FRT2 | | | Input capture | FT12 | Input | Trigger for capturing current count of FRT2 | Note: \* When the ØOE bit in P7DDR is set to 1, this pin is used for system clock (Ø) output and cannot be used for FTOA2. et4U.com DataSheet4U.com DataShe 191 HITACHI T-49-19-16 Table 10-2 lists the registers of each free-running timer channel. Table 10-2 Register Configuration 10.1.4 Register Configuration | | | | | Initial | | | |---------|----------------------------------|--------------|--------|---------|---------|--------------| | Channel | Name | Abbreviation | R/W | Value | Address | | | 1 | Timer control register | TCR | R/W | H'00 | H'FF90 | | | | Timer control/status register | TCSR | R/(W)* | H'00 | H'FF91 | _ | | | Free-running counter (High) | FRC (H) | R/W | H'00 | H'FF92 | | | | Free-running counter (Low) | FRC (L) | R/W | H'00 | H'FF93 | <u>-</u> | | | Output compare register A (High) | OCRA (H) | R/W | H'FF | H'FF94 | _ | | | Output compare register A (Low) | OCRA (L) | R/W | H'FF | H'FF95 | _ | | | Output compare register B (High) | OCRB (H) | R/W | H'FF | H'FF96 | - | | | Output compare register B (Low) | OCRB (L) | R/W | H'FF | H'FF97 | _ | | | Input capture register (High) | ICR (H) | R | H'00 | H'FF98 | _ | | | Input capture register (Low) | ICR (L) | R | H'00 | H'FF99 | | | 2 | Timer control register | TCR | R/W | H'00 | H'FFA0 | <u>-</u><br> | | | Timer control/status register | TCSR | R/(W)* | H'00 | H'FFA1 | _ | | | Free-running counter (High) | FRC (H) | R/W | H'00 | H'FFA2 | <u>-</u> | | | Free-running counter (Low) | FRC (L) | R/W | H'00 | H'FFA3 | | | | Output compare register A (High) | OCRA (H) | R/W | H'FF | H'FFA4 | _ | | | | ocra (L) | R/W | H'FF | H'FFA5 | DataSh | | | Output compare register B (High) | OCRB (H) | R/W | H'FF | H'FFA6 | - | | | Output compare register B (Low) | OCRB (L) | R/W | H'FF | H'FFA7 | _ | | | Input capture register (High) | ICR (H) | R | H'00 | H'FFA8 | _ | | | Input capture register (Low) | ICR (L) | R | H'00 | H'FFA9 | _ | | | mpart suprairies years ( , , , | | | | | | Note: \* Software can write a 0 to clear bits 7 to 4, but cannot write a 1 in these bits. HITACHI 192 www.DataSheet4U.com et4U.com #### www.DataSheet4U.com 10.2 Register Descriptions T-49-19-16 # 10.2.1 Free-Running Counter (FRC)—H'FF92, H'FFA2 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | _1_ | 0 | |---------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | | | | | | | | | | | | | | | | | | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W Each FRC is a 16-bit readable/writable up-counter that increments on an internal pulse generated from a clock source. The clock source is selected by the clock select 1 and 0 bits (CKS1 and CKS0) of the timer control register (TCR). The FRC can be cleared by compare-match A. When the FRC overflows from H'FFFF to H'0000, the overflow flag (OVF) in the timer control/status register (TCSR) is set to 1. Because the FRC is a 16-bit register, a temporary register (TEMP) is used when the FRC is written or read. See section 10.3, "CPU Interface", for details. The FRCs are initialized to H'0000 at a reset and in the standby modes. # 10.2.2 Output Compare Registers A and B (OCRA and OCRB)—H'FF94 and H'FF96, H'FFA4 and H'FFA6 DataSheet4U.com 6 5 4 3 2 1 0 Bit 15 14 13 12 11 10 1 1 1 Initial value Read/Write OCRA and OCRB are 16-bit readable/writable registers, the contents of which are continually compared with the value in the FRC. When a match is detected, the corresponding output compare flag (OCFA or OCFB) is set in the timer control/status register (TCSR). In addition, if the output enable bit (OEA or OEB) in the timer control register (TCR) is set to 1, when the output compare register and FRC values match, the logic level selected by the output level bit (OLVLA or OLVLB) in the timer control status register (TCSR) is output at the output compare pin (FTOA or FTOB). 193 HITACHI www.DataSheet4U.com DataShe et4U.com www.DataSheet4U.com Because OCRA and OCRB are 16-bit registers, a temporary register (TEMP) is used when they are written. See section 10.3, "CPU Interface", for details. OCRA and OCRB are initialized to H'FFFF at a reset and in the standby modes. ## 10.2.3 Input Capture Register (ICR)—H'FF98, H'FFA8 | Bit | 15 | 14 | 13 | 12 | 11 | | 9 | | 7 | 6 | | 4 | | | 1 | 0 | |---------------|----|----|----|----|----|---|---|---|---|---|----------|---|---|---|---|---| | • | | | | : | | | | | | | <b>.</b> | l | | | | | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | The ICR is a 16-bit read-only register. When the rising or falling edge of the signal at the input capture input pin is detected, the current value of the FRC is copied to the ICR. At the same time, the input capture flag (ICF) in the timer control/status register (TCSR) is set to 1. The input capture edge is selected by the input edge select bit (IEDG) in the TCSR. Because the ICR is a 16-bit register, a temporary register (TEMP) is used when the ICR is written or read. See section 10.3, "CPU Interface", for details. To ensure input capture, the pulse width of the input capture signal should be at least 1.5 system clock periods (1.5 ø). DataSheet4U.com Minimum FTI Pulse Width The ICR is initialized to H'0000 at a reset and in the standby modes. Note: When input capture is detected, the FRC value is transferred to the ICR even if the input capture flag (ICF) is already set. HITACHI 194 www.DataSheet4U.com DataShe et4U.com | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 11 | 0 | |---------------|------|-------|-------|------|-----|-----|------|------| | | ICIE | OCIEB | OCIEA | OVIE | OEB | OEA | CKS1 | CKS0 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W The TCR is an 8-bit readable/writable register that selects the FRC clock source, enables the output compare signals, and enables interrupts. The TCR is initialized to H'00 at a reset and in the standby modes. Bit 7—Input Capture Interrupt Enable (ICIE): This bit selects whether to request an input capture interrupt (ICI) when the input capture flag (ICF) in the timer status/control register (TCSR) is set to 1. | Bit | 7 | |-----|---| |-----|---| | ICIE | Description | | · | |------|--------------------------------------------------------|-----------------|---| | 0 | The input capture interrupt request (ICI) is disabled. | (Initial value) | | | 1 | The input capture interrupt request (ICI) is enabled. | | | Bit 6—Output Compare Interrupt Enable B (OCIEB): This bit selects whether to request output compare interrupt B (OCIB) when output compare flag B (OCFB) in the timer status/control register (TCSR) is set to 1. et4U.com DataSheet4U.com DataShe | Bit 6 | | |-------|---| | | _ | | OCIEB | Description | | | |-------|--------------------------------------------------------|-----------------|--| | 0 | Output compare interrupt request B (OCIB) is disabled. | (Initial value) | | | 1 | Output compare interrupt request B (OCIB) is enabled. | | | Bit 5—Output Compare Interrupt Enable A (OCIEA): This bit selects whether to request output compare interrupt A (OCIA) when output compare flag A (OCFA) in the timer status/control register (TCSR) is set to 1. BIt 5 | OCIEA | Description | | | |-------|--------------------------------------------------------|-----------------|-----| | 0 | Output compare interrupt request A (OCIA) is disabled. | (Initial value) | ··· | | 1 | Output compare interrupt request A (OCIA) is enabled. | | | 195 HITACHI DataSheet4U.com Bit 4—Timer Overflow Interrupt Enable (OVIE): This bit selects whether to request a free-running timer overflow interrupt (FOVI) when the timer overflow flag (OVF) in the timer status/control register (TCSR) is set to 1. T-49-19-16 | В | lt | 4 | |---|----|---| | | | | | OVIE | Description | | |------|-----------------------------------------------------------------------|-----------------| | 0 | The free-running timer overflow interrupt request (FOVI) is disabled. | (Initial value) | | 1 | The free-running timer overflow interrupt request (FOVI) is enabled. | | Bit 3—Output Enable B (OEB): This bit selects whether to enable or disable output of the logic level selected by the OLVLB bit in the timer status/control register (TCSR) at the output compare B pin when the FRC and OCRB values match. Bit 3 | OEB | Description | | |-----|--------------------------------------|-----------------| | 0 | Output compare B output is disabled. | (Initial value) | | 1 | Output compare B output is enabled. | | Bit 2—Output Enable A (OEA): This bit selects whether to enable or disable output of the logic level selected by the OLVLA bit in the timer status/control register (TCSR) at the output compare A pin when the FRC and OCRA values match. Bit 2 | 0 | Output compare A output is disabled. | (Initial value) | |-----|--------------------------------------|-----------------| | OEA | Description DataSheet4U.com | | Bits 1 and 0—Clock Select (CKS1 and CKS0): These bits select external clock input or one of three internal clock sources for the FRC. External clock pulses are counted on the rising edge. | Bit 1 | Bit 0 | | | |-------|-------|-----------------------------------------------------|-----------------| | CKS1 | CKS0 | Description | | | 0 | 0 | Internal clock source (ø/4) | (Initial value) | | 0 | 1 | Internal clock source (ø/8) | | | 1 | 0 | Internal clock source (ø/32) | | | 1 | 1 | External clock source (counted on the rising edge)* | | Note: \* Output enable B (bit 3) must be cleared to 0. HITACHI 196 # www.DataSheet4U.com 10.2.5 Timer Control/Status Register (TCSR)—H'FF91, H'FFA1 T-49-19-16 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|--------|--------|--------|-------|-------|------|-------| | | ICF | OCFB | OCFA | OVF | OLVLB | OLVLA | IEDG | CCLRA | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/(W)* | R/(W)* | R/(W)* | R/(W)* | R/W | R/W | R/W | R/W | The TCSR is an 8-bit readable and partially writable\* register that selects the input capture edge and output compare levels, and specifies whether to clear the counter on compare-match A. It also contains four status flags. The TCSR is initialized to H'00 at a reset and in the standby modes. Note: \* Software can write a 0 in bits 7 to 4 to clear the flags, but cannot write a 1 in these bits. Bit 7—Input Capture Flag (ICF): This status flag is set to 1 to indicate an input capture event. It signifies that the FRC value has been copied to the ICR. #### Bit 7 et4U.com | ICF | <b>Description</b> | | | | | |------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|--------------------------------|--|--|--| | 0 | This bit is cleared from 1 to 0 when: (Initial value) | | | | | | | 1. The CPU reads the ICF bit after the ICF bit has been set to 1, then writes a 0 in this bit. | | | | | | | 2. The data transfer controller (DTC) serves an input capture interrupt . | | | | | | 1 This bit is set to 1 when an input capture signal causes the FRC value to be cop | | value to be copied to the ICR. | | | | Bit 6—Output Compare Flag B (OCFB): This status flag is set to 1 when the FRC value matches the OCRB value. #### Bit 6 | OCFB | Description | | |------|--------------------------------------------------------------------------------------------------|-----------------| | 0 | This bit is cleared from 1 to 0 when: | (Initial value) | | | 1. The CPU reads the OCFB bit after the OCFB bit has been set to 1, then writes a 0 in this bit. | | | | The data transfer controller (DTC) serves output compare interrupt B. | | | 1 | This bit is set to 1 when FRC = OCRB. | | 197 HITACHI www.DataSheet4U.com Bit 5—Output Compare Flag A (OCFA): This status flag is set to 1 when the FRC value matches the OCRA value. T-49-19-16 #### Blt 5 | OCFA | Description | | |------|--------------------------------------------------------------------------------------------------|-----------------| | 0 | This bit is cleared from 1 to 0 when: | (Initial value) | | | 1. The CPU reads the OCFA bit after the OCFA bit has been set to 1, then writes a 0 in this bit. | | | | 2. The data transfer controller (DTC) serves output compare interrupt A. | | | 1 | This bit is set to 1 when FRC = OCRA. | | Bit 4—Timer Overflow Flag (OVF): This status flag is set to 1 when the FRC overflows (changes from H'FFFF to H'0000). #### Bit 4 | OVF | Description | | | |-----|-------------------------------------------------------------------------------|-----------------|--| | 0 | This bit is cleared from 1 to 0 when the CPU reads | (Initial value) | | | | the OVF bit after the OVF bit has been set to 1, then writes a 0 in this bit. | | | | 1 | This bit is set to 1 when FRC changes from H'FFFF to H'0000. | | | Bit 3—Output Level B (OLVLB): This bit selects the logic level to be output at the FTOB pin when the FRC and OCRB values match. #### Bit 3 et4U.com | OLVLB | Description DataSheet4U.com | | |-------|-------------------------------------------------------|-----------------| | 0 | A 0 logic level (low) is output for compare-match B. | (Initial value) | | 1 | A 1 logic level (high) is output for compare-match B. | | Bit 2—Output Level A (OLVLA): This bit selects the logic level to be output at the FTOA pin when the FRC and OCRA values match. #### Blt 2 | OLVLA | Description | | | |-------|-------------------------------------------------------|-----------------|--| | 0 | A 0 logic level (low) is output for compare-match A. | (Initial value) | | | 1 | A 1 logic level (high) is output for compare-match A. | | | Bit 1-Input Edge Select (IEDG): This bit selects whether to capture the count on the rising or falling edge of the input capture signal. # HITACHI 198 www.DataSheet4U.com DataShe DataSheet4U.com | IEDG | Description | | |------|--------------------------------------------------------|-----------------| | 0 | The FRC value is copied to the ICR on the falling edge | (Initial value) | | | of the input capture signal. | | | 1 | The FRC value is copied to the ICR on the rising edge | | | | of the input capture signal. | | Bit 0—Counter Clear A (CCLRA): This bit selects whether to clear the FRC at compare-match A (when the FRC and OCRA values match). #### Bit 0 | CCLRA | Description | | |-------|----------------------------------------|-----------------| | 0 | The FRC is not cleared. | (Initial value) | | 1 | The FRC is cleared at compare-match A. | | #### 10.3 CPU Interface The FRC, OCRA, OCRB, and ICR are 16-bit registers, but they are connected to an 8-bit data bus. When the CPU accesses these four registers, to ensure that both bytes are written or read simultaneously, the access is performed using an 8-bit temporary register (TEMP). These registers are written and read as follows. et4U.com #### Register Write DataSheet4U.com DataShe When the CPU writes to the upper byte, the upper byte of write data is placed in TEMP. Next, when the CPU writes to the lower byte, this byte of data is combined with the byte in TEMP and all 16 bits are written in the register simultaneously. #### Register Read When the CPU reads the upper byte, the upper byte of data is sent to the CPU and the lower byte is placed in TEMP. When the CPU reads the lower byte, it receives the value in TEMP. Programs that access these four registers should normally use word access. Equivalently, they may access first the upper byte, then the lower byte. Data will not be transferred correctly if the bytes are accessed in reverse order, or if only one byte is accessed. The same considerations apply to access by the DTC. 199 HITACHI - 1. To write the contents of general register R0 to output compare register A in FRT1: MOV.W R0, @H'FF94 - 2. To read the FRT2 input capture register contents into general register R0: MOV.W @H'FFA8, R0 Figure 10-2 shows the data flow when the FRC is accessed. The other registers are accessed in the same way, except that when OCRA or OCRB is read, the upper and lower bytes are both transferred directly to the CPU without using the temporary register. Figure 10-2 (a) Write Access to FRC (When CPU Writes H'AA55) **HITACHI** 200 www.DataSheet4U.com Figure 10-2 (b) Read Access to FRC (When FRC Contains H'AA55) # 10.4 Operation # 10.4.1 FRC Incrementation Timing The FRC increments on a pulse generated once for each period of the selected (internal or external) clock source. 201 **HITACHI** DataSheet4U.com Www.DataSheet4U.com If external clock input is selected, the FRC increments on the rising edge of the clock signal. Figure 10-3 shows the increment timing. T-49-19-16 The pulse width of the external clock signal must be at least 1.5 ø clock periods. The counter will not increment correctly if the pulse width is shorter than 1.5 ø clock periods. Figure 10-3 Increment Timing for External Clock Input et4U.com # 10.4.2 Output Compare Timing Setting of Output Compare Flags A and B (OCFA and OCFB): The output compare flags are set to 1 by an internal compare-match signal generated when the FRC value matches the OCRA or OCRB value. This compare-match signal is generated at the last state in which the two values match, just as the FRC increments to a new value. Accordingly, when the FRC and OCR values match, the compare-match signal is not generated until the next period of the clock source. Figure 10-4 shows the timing of the setting of the output compare flags. HITACHI 202 www.DataSheet4U.com Figure 10-4 Setting of Output Compare Flags Output Timing: When a compare-match occurs, the logic level selected by the output level bit (OLVLA or OLVLB) in the TCSR is output at the output compare pin (FTOA or FTOB). Figure 10-5 shows the timing of this operation for compare-match A. Figure 10-5 Timing of Output Compare A 203 HITACHI DataSheet4U.com et4U.com FRC Clear Timing: If the CCLRA bit is set to 1, the FRC is cleared when compare-match A occurs. Figure 10-6 shows the timing of this operation. Figure 10-6 Clearing of FRC by Compare-Match A #### 10.4.3 Input Capture Timing Input Capture Timing: An internal input capture signal is generated from the rising or falling edge of the input at the input capture pin (FTI), as selected by the IEDG bit in the TCSR. Figure 10-7 shows the usual input capture timing when the rising edge is selected (IEDG = 1). Figure 10-7 Input Capture Timing (Usual Case) But if the upper byte of the ICR is being read when the input capture signal arrives, the internal input capture signal is delayed by one state. Figure 10-8 shows the timing for this case. HITACHI 204 Figure 10-8 Input Capture Timing (1-State Delay) Timing of Input Capture Flag (ICF) Setting: The input capture flag (ICF) is set to 1 by the internal input capture signal. Figure 10-9 shows the timing of this operation. Figure 10-9 Setting of Input Capture Flag 205 HITACHI DataSheet4U.com The FRC overflow flag (OVF) is set to 1 when the FRC overflows (changes from H'FFFF to H'0000). Figure 10-10 shows the timing of this operation. T-49-19-16 Figure 10-10 Setting of Overflow Flag (OVF) # 10.5 CPU Interrupts and DTC Interrupts Each free-running timer channel can request four types of interrupts: input capture (ICI), output compare A and B (OCIA and OCIB), and overflow (FOVI). Each interrupt is requested when the corresponding enable and flag bits are set. Independent signals are sent to the interrupt controller for each type of interrupt. Table 10-3 lists information about these interrupts. et4U.com Table 10-3 Free-Running Timer Interrupts | Interrupt | Description | DTC Service Available? | Priority | |-----------|----------------------------|------------------------|----------| | ICI | Requested when ICF is set | Yes | High | | OCIA | Requested when OCFA is set | Yes | <b>^</b> | | OCIB | Requested when OCFB is set | Yes | | | FOVI | Requested when OVF is set | No | Low | The ICI, OCIA, and OCIB interrupts can be directed to the data transfer controller (DTC) to have a data transfer performed in place of the usual interrupt-handling routine. When the DTC serves one of these interrupts, it automatically clears the ICF, OCFA, or OCFB flag to 0. See section 6, "Data Transfer Controller", for further information on the DTC. **HITACHI** 206 www.DataSheet4U.com # www.Data 10.64 Synchronization of Free-Running Timers 1 and 2 # 10.6.1 Synchronization after a Reset T-49-19-16 The two free-running timer channels are synchronized at a reset and remain synchronized until one of the following conditions is satisfied: - The clock source is changed. - · FRC contents are rewritten. - · An FRC is cleared. After a reset, each free-running counter operates on the ø/4 internal clock source. # 10.6.2 Synchronization by Writing to FRCs When synchronization between free-running timers 1 and 2 is lost, it can be restored by writing to the free-running counters. Synchronization on Internal Clock Source: When an internal clock is selected, free-running timers 1 and 2 can be synchronized by writing data to their free-running counters as indicated in table 10-4. Table 10-4 Synchronization by Writing to FRCs | Clock Source | Write Interval | Write Data | |--------------|----------------|-----------------| | ø/4 | 4n (states) | DataSheet4U.com | | ø/8 | 8n (states) | m + n (FRC2) | | ø/32 | 32n (states) | | m, n: Arbitrary integers After writing these data, synchronization can be checked by reading the two free-running counters at the same interval as the write interval. If the read data have the same relative difference as the write data, the free-running timers are synchronized. Examples of programs for synchronizing the free-running timers are given next. Examples a, b, and c apply when the program is stored in on-chip memory. Examples d, e, and f apply when the program is stored in external memory which is accessed with zero wait states (Tw), assuming that there is no NMI input. 207 HITACHI DataSheet4U.com et4U.com www.DataSheet4U.com ``` ; Initialize base register for short-format instruction (MOV:S) LA: LDC.B #H'FF, BR LDC.W #H'0700,SR ; Raise interrupt mask level to 7 T-49-19-16 MOV.W ; Data for free-running timer 1 #m, R1 MOV.W #m+3,R2 ; Data for free-running timer 2 (m + n = m + 3) ; Call write routine BSR SET4 .ALIGN ; Align write instructions (MOV:S) at even address SET4: MOV:S.W R1, @H'92:8 ; Write to FRC 1 (address H'FF92) 9 states ; 2-Byte dummy instruction BRN SET4:8 3 states MOV:S.W R2, @H'A2:8 ; Write to FRC2 (address H'FFA2) Total 12 states RTS Example b: \emptyset/8 clock source, 16-state write interval (n = 2), on-chip memory LB: LDC.B #H'FF, BR #H'0700,SR LDC.W MOV.W #m, R1 MOV.W #m+2,R2 BSR SET8 .ALIGN et4U.com ; 9 statesheet4 J.com SET8: MOV:S.W R1, @H'92:8 BRN SET8:8 ; 3 states - Total 16 states XCH R1,R1 ; 4 states MOV:S.W R2, @H'A2:8 RTS ``` www.DataSheet411 com **Example a:** Ø/4 clock source, 12-state write interval (n = 3), on-chip memory HITACHI 208 www.DataSheet4U.com 209 ; 2 bytes, 7 states - HITACHI DataSheet4U.com BRN LD:8 MOV:S.W R2, @H'A2:8 www.DataSheet4U.com Total 20 states www.DataS Example e: ø/8 clock source, 24-state write interval (n = 3), external memory LE: LDC.B #H'FF, BR LDC.W #H'0700, SR T-49-19-16 CLR.B @H'F8:8 W.VOM #m, R1 #m+3,R2 W.VOM R1, @H'92:8; 13 states -MOV:S.W BRN LE:8 ; 2 bytes, 7 states-Total 24 states NOP ; 1 byte, 4 states MOV:S.W R2,@H'A2;8 # Example f: $\emptyset/32$ clock source, 32-state write interval (n = 1), external memory LF: LDC.B #H'FF, BR LDC.W #H'0700, SR CLR.B @H'F8:8 W.VOM #m, R1 W.VOM #m+1,R2 MOV:S.W R1, @H'92:8; External memory, so 13 states XCH RO, RO 8 states ; 2 bytes, BRN LF:8 - Total 32 states 7 states 4 states NOP MOV:S.W R2, @H'A2:8 et4U.com DataSheet4U.com DataShe HITACHI 210 DataSheet4U.com Synchronization on External Clock Source: When the external clock source is selected, the free-running timers can be synchronized by halting their external clock inputs, then writing identical values in their free-running counters. # 10.7 Sample Application In the example below, one free-running timer channel is used to generate two square-wave outputs with a 50% duty factor and arbitrary phase relationship. The programming is as follows: - 1. The CCLRA bit in the TCSR is set to 1. - 2. Each time a compare-match interrupt occurs, software inverts the corresponding output level bit in the TCSR. Figure 10-11 Square-Wave Output (Example) # 10.8 Application Notes Application programmers should note that the following types of contention can occur in the free-running timers. Contention between FRC Write and Clear: If an internal counter clear signal is generated during the T3 state of a write cycle to the lower byte of a free-running counter, the clear signal takes priority and the write is not performed. 211 HITACHI DataSheet4U.com et4U.com Figure 10-12 shows this type of contention. Figure 10-12 FRC Write-Clear Contention Contention between FRC Write and Increment: If an FRC increment pulse is generated during the T3 state of a write cycle to the lower byte of a free-running counter, the write takes priority and the FRC is not incremented. DataSheet4U.com et4U.com DataShe HITACHI 212 www.DataSheet4U.com DataSheet4U.com Figure 10-13 FRC Write-Increment Contention et4U.com DataSheet4U.com DataShe 213 **HITACHI** DataSheet4U.com Contention between OCR Write and Compare-Match: If a compare-match occurs during the T3 state of a write cycle to the lower byte of OCRA or OCRB, the write takes precedence and the compare-match signal is inhibited. Figure 10-14 shows this type of contention. T-49-19-16 Figure 10-14 Contention between OCR Write and Compare-Match Incrementation Caused by Changing of Internal Clock Source: When an internal clock source is changed, the changeover may cause the FRC to increment. This depends on the time at which the clock select bits (CKS1 and CKS0) are rewritten, as shown in table 10-5. The pulse that increments the FRC is generated at the falling edge of the internal clock source. If clock sources are changed when the old source is high and the new source is low, as in case no. 3 in table 10-5, the changeover generates a falling edge that triggers the FRC increment pulse. Switching between an internal and external clock source can also cause the FRC to increment. HITACHI 214 DataSheet4U.com T-49-19-16 rewritten while old clock source is high and new clock source is low. Note: \* The switching of clock sources is regarded as a falling edge that increments the FRC. 215 HITACHI DataSheet4U.com et4U.com www.DataSheet4U.com Table 10-5 Effect of Changing Internal Clock Sources (cont) et4U.com DataSheet4U.com DataShe HITACHI 216 DataSheet4U.com # Section 11 8-Bit Timer T-49-19-16 #### 11.1 Overview The H8/520 chip includes a single 8-bit timer based on an 8-bit counter (TCNT). The timer has two time constant registers (TCORA and TCORB) that are constantly compared with the TCNT value to detect compare-match events. One application of the 8-bit timer is to generate a rectangular-wave output with an arbitrary duty factor. #### 11.1.1 Features The features of the 8-bit timer are listed below. - Selection of four clock sources The counter can be driven by an internal clock signal (ø/8, ø/64, or ø/1024) or an external clock input (enabling use as an external event counter). - Selection of three ways to clear the counter The counter can be cleared on compare-match A or B, or by an external reset signal. - Timer output controlled by two compare-match signals The single timer output (TMO) is controlled by two independent compare-match signals, enabling the timer to generate output waveforms with an arbitrary duty factor. DataShe 217 HITACHI DataSheet4U.com et4U.com ### 11.1.2 Block Diagram T-49-19-16 Figure 11-1 shows a block diagram of the 8-bit timer. Figure 11-1 Block Diagram of 8-Bit Timer **HITACHI** 218 DataSheet4U.com DataSheet4U.com et4U.com ### 11.1.3 Input and Output Pins T-49-19-16 Table 11-1 lists the input and output pins of the 8-bit timer. Table 11-1 Input and Output Pins of 8-Bit Timer | Name | <b>Abbreviation</b> | I/O | Function | | |-------------------|---------------------|--------|---------------------------------------|--| | Timer output | TMO | Output | Output controlled by compare-match | | | Timer clock input | TMCI | Input | External clock source for the counter | | | Timer reset input | TMRI | Input | External reset signal for the counter | | ### 11.1.4 Register Configuration Table 11-2 lists the registers of the 8-bit timer. Table 11-2 8-Bit Timer Registers | Name | Abbreviation | R/W | Initial Value | Address | | |-------------------------------|--------------|--------|---------------|---------|--| | Timer control register | TCR | R/W | H'00 | H'FFD0 | | | Timer control/status register | TCSR | R/(W)* | H'10 | H'FFD1 | | | Timer constant register A | TCORA | R/W | H'FF | H'FFD2 | | | Timer constant register B | TCORB | R/W | H'FF | H'FFD3 | | | Timer counter | TCNT | R/W | H'00 | H'FFD4 | | et4U.com Note: \* Software can write a 0 to clear bits 7 to 5, but cannot write a 1 in these bits. DataShe ## 11.2 Register Descriptions #### 11.2.1 Timer Counter (TCNT)—H'FFD4 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|-----|-----|-----|-----| | | | | | | | | | | | Initial value | 0 | 0 | 0 | 0 | 0 - | 0 | 0 | 0 | | Read/Write | R/W The timer counter (TCNT) is an 8-bit up-counter that increments on a pulse generated from one of four clock sources. The clock source is selected by clock select bits 2 to 0 (CKS2 to CKS0) of the timer control register (TCR). The CPU can always read or write the timer counter. 219 HITACHI www.DataSheet4U.com The timer counter can be cleared by an external reset input or by an internal compare-match signal generated at a compare-match event. Clock clear bits 1 and 0 (CCLR1 and CCLR0) of the timer control register select the method of clearing. T-49-19-16 When the timer counter overflows from H'FF to H'00, the overflow flag (OVF) in the timer control/status register (TCSR) is set to 1. The timer counter is initialized to H'00 at a reset and in the standby modes. # 11.2.2 Time Constant Registers A and B (TCORA and TCORB)—H'FFD2 and H'FFD3 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|-----|-----|-----|-----| | | | | | | | | | | | Initial value | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Read/Write | R/W TCORA and TCORB are 8-bit readable/writable registers. The timer count is continually compared with the constants written in these registers. When a match is detected, the corresponding comparematch flag (CMFA or CMFB) is set in the timer control/status register (TCSR). The timer output signal (TMO) is controlled by these compare-match signals as specified by output select bits 3 to 0 (OS3 to OS0) in the timer status/control register (TCSR). TCORA and TCORB are initialized to H'FF at a reset and in the standby modes. ### 11.2.3 Timer Control Register (TCR)—H'FFD0 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|-------|------|-------|-------|------|------|------| | | CMIEB | CMIEA | OVIE | CCLR1 | CCLR0 | CKS2 | CKS1 | CKS0 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W The TCR is an 8-bit readable/writable register that selects the clock source and the time at which the timer counter is cleared, and enables interrupts. The TCR is initialized to H'00 at a reset and in the standby modes. 220 HITACHI DataSheet4U.com et4U.com DataShe Bit 7—Compare-Match Interrupt Enable B (CMIEB): This bit selects whether to request comparematch interrupt B (CMIB) when compare-match flag B (CMFB) in the timer status/control register (TCSR) is set to 1. | Bit 7 | | T-49-19-16 | |-------|-------------------------------------------------------|-----------------| | CMIEB | Description | | | 0 | Compare-match interrupt request B (CMIB) is disabled. | (Initial value) | | 1 | Compare-match interrupt request B (CMIB) is enabled. | | Bit 6—Compare-Match Interrupt Enable A (CMIEA): This bit selects whether to request compare-match interrupt A (CMIA) when compare-match flag A (CMFA) in the timer status/control register (TCSR) is set to 1. #### Bit 6 | CMIEA | Description | | | |-------|-------------------------------------------------------|-----------------|-------| | 0 | Compare-match interrupt request A (CMIA) is disabled. | (Initial value) | ····· | | 1 | Compare-match interrupt request A (CMIA) is enabled. | | | Bit 5—Timer Overflow Interrupt Enable (OVIE): This bit selects whether to request a timer overflow interrupt (OVI) when the overflow flag (OVF) in the timer status/control register (TCSR) is set to 1. #### Bit 5 | et4U.com <b>oviE</b> | Description | DataSheet4U.com | | | |----------------------|-----------------------------------|------------------------|-----------------|--| | 0 | The timer overflow interrupt requ | est (OVI) is disabled. | (Initial value) | | | 1 | The timer overflow interrupt requ | est (OVI) is enabled. | | | Bits 4 and 3—Counter Clear 1 and 0 (CCLR1 and CCLR0): These bits select how the timer counter is cleared: by compare-match A or B or by an external reset input. | Bit 4 | Bit 3 | | | |-------|-------|------------------------------------------------------|-----------------| | CCLR1 | CCLR0 | Description | | | 0 | 0 | Not cleared. | (Initial value) | | 0 | 1 | Cleared on compare-match A. | <u> </u> | | 1 | 0 | Cleared on compare-match B. | | | 1 | 1 | Cleared on rising edge of external reset input signa | al. | 221 HITACHI www.DataSheet4U.com DataShe Bits 2, 1, and 0—Clock Select (CKS2, CKS1, and CKS0): These bits select the internal or external clock source for the timer counter. For the external clock source they select whether to increment the count on the rising or falling edge of the clock input, or on both edges. | Bit 2 | Bit 1 | Bit 0 | | T-49-19-16 | |-------|-------|-------|--------------------------------------------|-----------------| | CKS2 | CKS1 | CKS0 | Description | | | 0 | 0 | 0 | No clock source (timer stopped). | (Initial value) | | 0 | 0 | 1 | Internal clock source (ø/8). | | | 0 | 1 | 0 | Internal clock source (ø/64). | | | 0 | 1 | 1 | Internal clock source (ø/1024). | | | 1 | 0 | 0 | No clock source (timer stopped). | | | 1 | 0 | 1 | External clock source, counted on the ris | ing edge. | | 1 | 1 | 0 | External clock source, counted on the fal | lling edge. | | 1 | 1 | 1 | External clock source, counted on both the | he rising | | | | | and falling edges. | | ## 11.2.4 Timer Control/Status Register (TCSR) | Bit | 7 | 6 | 5 | 4 | 3 | . 2 | 1 | 0 | |---------------|--------|--------|--------|---|-----|-----|-----|-----| | | CMFB | CMFA | OVF | _ | OS3 | OS2 | OS1 | OS0 | | Initial value | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | Read/Write | R/(W)* | R/(W)* | R/(W)* | | R/W | R/W | R/W | R/W | et4U.com DataSheet4U.com The TCSR is an 8-bit readable and partially writable\* register that indicates compare-match and overflow status and selects the effect of compare-match events on the timer output signal (TMO). The TCSR is initialized to H'10 at a reset and in the standby modes. Note: \* Software can write a 0 in bits 7 to 5 to clear the flags, but cannot write a 1 in these bits. Bit 7—Compare-Match Flag B (CMFB): This status flag is set to 1 when the timer count matches the time constant set in TCORB. HITACHI 222 | Bit 7 | | 1-49-19-16 | | | | | |-------|-------------------------------------------------------------------------------|-------------------------------------------------|--|--|--|--| | CMFB | Description | | | | | | | 0 | This bit is cleared from 1 to 0 when: | (Initial value) | | | | | | | 1. The CPU reads the CMFB bit after the CMFB bit | has been set to 1, then writes a 0 in this bit. | | | | | | | 2. Compare-match interrupt B is served by the data transfer controller (DTC). | | | | | | | 1 | This bit is set to 1 when TCNT = TCORB. | | | | | | Bit 6—Compare-Match Flag A (CMFA): This status flag is set to 1 when the timer count matches the time constant set in TCORA. #### Bit 6 | CMFA | Description | | | |------|--------------------------------------------------------------------------------------------------|----------------------------|--| | 0 | This bit is cleared from 1 to 0 when: | (Initial value) | | | | 1. The CPU reads the CMFA bit after the CMFA bit has been set to 1, then writes a 0 in this bit. | | | | | 2. Compare-match interrupt A is served by the data | transfer controller (DTC). | | | 1 | This bit is set to 1 when TCNT = TCORA. | | | Bit 5—Timer Overflow Flag (OVF): This status flag is set to 1 when the timer count overflows (changes from H'FF to H'00). #### Bit 5 | OVF | Description | | | | | | |----------|----------------------------------------------------------------|-----------------|--|--|--|--| | et4U.com | This bit is cleared from 1 to 0 when the CPU reads | (Initial value) | | | | | | | the OVF bit after the OVF bit has been set to 1, then writes a | 0 in this bit. | | | | | | 1 | 1 This bit is set to 1 when TCNT changes from H'FF to H'00. | | | | | | Bit 4—Reserved: This bit cannot be modified and is always read as 1. Bits 3 to 0—Output Select 3 to 0 (OS3 to OS0): These bits specify the effect of compare-match events on the timer output signal (TMO). Bits OS3 and OS2 control the effect of compare-match B on the output level. Bits OS1 and OS0 control the effect of compare-match A on the output level. When all four output select bits are cleared to 0 the TMO signal is not output. After a reset, the TMO output is low (0) until the first compare-match event. 223 HITACHI DataShe | Blt 3 | Bit 2 | | 1-49-19-10 | |-------|-------|-------------------------------------------------------|-----------------| | OS3 | OS2 | Description | | | 0 | 0 | No change when compare-match B occurs. | (Initial value) | | 0 | 1 | Output changes to 0 when compare-match B occurs. | | | 1 | 0 | Output changes to 1 when compare-match B occurs. | | | 1 | 1 | Output inverts (toggles) when compare-match B occurs. | | | Bit 1 | Blt 0 | | | | |------------|-------|-------------------------------------------------------|-----------------|-------------| | <b>OS1</b> | OS0 | Description | | <del></del> | | 0 | 0 | No change when compare-match A occurs. | (Initial value) | | | 0 | 1 | Output changes to 0 when compare-match A occurs. | | | | 1 | 0 | Output changes to 1 when compare-match A occurs. | | | | 1 | 1 | Output inverts (toggles) when compare-match A occurs. | | | # 11.3 Operation ### 11.3.1 TCNT Incrementation Timing The timer counter increments on a pulse generated once for each period of the selected (internal or external) clock source. If external clock input (TMCI) is selected, the timer counter can increment on the rising edge, the falling edge, or both edges of the external clock signal. DataShe The external clock pulse width must be at least $1.5 \, \phi$ clock periods for incrementation on a single edge, and at least $2.5 \, \phi$ clock periods for incrementation on both edges. The counter will not increment correctly if the pulse width is shorter than these values. HITACHI 224 www.DataSheet4U.com et4U.com Figure 11-2 shows the timing of incrementation on both edges of an external clock signal. Figure 11-2 Count Timing for External Clock Input 225 HITACHI Setting of Compare-Match Flags A and B (CMFA and CMFB): The compare-match flags are set to 1 by an internal compare-match signal generated when the timer count matches the time constant in TCORA or TCORB. The compare-match signal is generated at the last state in which the match is true, just as the timer counter increments to a new value. Accordingly, when the timer count matches one of the time constants, the compare-match signal is not generated until the next period of the clock source. Figure 11-3 shows the timing of the setting of the compare-match flags. Figure 11-3 Setting of Compare-Match Flags Output Timing: When a compare-match event occurs, the timer output (TMO) changes as specified by the output select bits (OS3 to OS0) in the TCSR. Depending on these bits, the output can remain the same, change to 0, change to 1, or toggle. HITACHI 226 www.DataSheet4U.com Figure 11-4 shows the timing when the output is set to toggle on compare-match A. Figure 11-4 Timing of Timer Output ### **Timing of Compare-Match Clear** Depending on the CCLR1 and CCLR0 bits in the TCR, the timer counter can be cleared when compare-match A or B occurs. Figure 11-5 shows the timing of this operation. Figure 11-5 Timing of Compare-Match Clear #### 11.3.3 External Reset of TCNT When the CCLR1 and CCLR0 bits in the TCR are both set to 1, the timer counter is cleared on the rising edge of an external reset input (TMRI). To ensure resetting, the TMRI pulse width must be at least 1.5 ø clock periods. Figure 11-6 shows the timing of this operation. 227 HITACHI Figure 11-6 Timing of External Reset # 11.3.4 Setting of TCNT Overflow Flag The overflow flag (OVF) is set to 1 when the timer count overflows (changes from H'FF to H'00). Figure 11-7 shows the timing of this operation. Figure 11-7 Setting of Overflow Flag (OVF) HITACHI 228 DataSheet4U.com www.DataSheet4U.com et4U.com # www.Dais4 CPU Interrupts and DTC Interrupts T-49-19-16 The 8-bit timer can generate three types of interrupts: compare-match A and B (CMIA and CMIB), and overflow (OVI). Each interrupt is requested when the corresponding enable and flag bits are set in the TCR and TCSR. Independent signals are sent to the interrupt controller for each type of interrupt. Table 11-3 lists information about these interrupts. Table 11-3 8-Bit Timer Interrupts | Interrupt | Description | DTC Service Available? | Priority | |-----------|----------------------------|------------------------|----------| | CMIA | Requested when CMFA is set | Yes | High | | CMIB | Requested when CMFB is set | Yes | | | OVI | Requested when OVF is set | No | Low | The CMIA and CMIB interrupts can be served by the data transfer controller (DTC) to have a data transfer performed. When the DTC serves one of these interrupts, it automatically clears the CMFA or CMFB flag to 0. See section 6, "Data Transfer Controller", for further information on the DTC. et4U.com DataSheet4U.com DataShe 229 HITACHI www.DataSheet4U.com DataSheet4U.com In the example below, the 8-bit timer is used to generate a pulse output with a selected duty factor. The control bits are set as follows: - 1. In the TCR, CCLR1 is cleared to 0 and CCLR0 is set to 1 so that the timer counter is cleared when its value matches the constant in TCORA. - 2. In the TCSR, bits OS3 to OS0 are set to 0110, causing the output to change to 1 on compare-match A and to 0 on compare-match B. With these settings, the 8-bit timer provides output of pulses at a rate determined by TCORA with a pulse width determined by TCORB. No software intervention is required. Figure 11-8 Example of Pulse Output DataShe HITACHI 230 www.DataSheet4U.com et4U.com #### www.DataSheet4U.com 11.6 Application Notes Application programmers should note that the following types of contention can occur in the 8-bit timer. T-49-19-16 Contention between TCNT Write and Clear: If an internal counter clear signal is generated during the T3 state of a write cycle to the timer counter, the clear signal takes priority and the write is not performed. Figure 11-9 shows this type of contention. Figure 11-9 TCNT Write-Clear Contention 231 **HITACHI** www.DataSheet4U.com Contention between TCNT Write and Increment: If a timer counter increment pulse is generated during the T3 state of a write cycle to the timer counter, the write takes priority and the timer counter is not incremented. Figure 11-10 shows this type of contention. Figure 11-10 TCNT Write-Increment Contention 232 HITACHI www.DataSheet4U.com et4U.com Contention between TCOR Write and Compare-Match: If a compare-match occurs during the T3 state of a write cycle to TCORA or TCORB, the write takes precedence and the compare-match signal is inhibited. Figure 11-11 shows this type of contention. Figure 11-11 Contention between TCOR Write and Compare-Match Contention between Compare-Match A and Compare-Match B: If identical time constants are written in TCORA and TCORB, causing compare-match A and B to occur simultaneously, any conflict between the output selections for compare-match A and B is resolved by following the priority order in table 11-4. 233 HITACHI Table 11-4 Priority Order of Timer Output | T-49-19 | 916 | |---------|-----| |---------|-----| | Output Selection | Priority | |------------------|----------| | Toggle | High | | 1 Output | <b>^</b> | | 0 Output | | | No change | Low | Incrementation Caused by Changing of Internal Clock Source: When an internal clock source is changed, the changeover may cause the timer counter to increment. This depends on the time at which the clock select bits (CKS2 to CKS0) are rewritten, as shown in table 11-5. The pulse that increments the timer counter is generated at the falling edge of the internal clock source signal. If clock sources are changed when the old source is high and the new source is low, as in case no. 3 in table 11-5, the changeover generates a falling edge that triggers the TCNT clock pulse and increments the timer counter. Switching between an internal and external clock source can also cause the timer counter to increment. Table 11-5 Effect of Changing Internal Clock Sources Note: \* Including a transition from low to the stopped state (CKS1 = 0, CKS0 = 0), or a transition from the stopped state to low. HITACHI 234 DataSheet4U.com Notes: 1. Including a transition from the stopped state to high. - 2. Including a transition from high to the stopped state. - 3. The switching of clock sources is regarded as a falling edge that increments the TCNT. 235 HITACHI www.DataSheet4U.com **CKS** rewrite Table 11-5 Effect of Changing Internal Clock Sources (cont) T-49-19-16 et4U.com DataSheet4U.com DataShe HITACHI 236 DataSheet4U.com # Section 12 Watchdog Timer T-49-19-16 #### 12.1 Overview The H8/520 has an on-chip watchdog timer (WDT) module. This module can monitor system operation by generating a signal that resets the H8/520 chip if a system crash allows the timer count to overflow. When this watchdog function is not needed, the WDT module can be used as an interval timer. In the interval timer mode, an IRQ0 interrupt is requested at each counter overflow. The WDT module is also used in recovering from the software standby mode. #### 12.1.1 Features The basic features of the watchdog timer module are summarized as follows: - Selection of eight clock sources - Selection of two modes: watchdog timer mode and interval timer mode - Counter overflow generates a reset signal or interrupt request Reset signal in the watchdog timer mode; IRQ0 request in the interval timer mode. - External output of reset signal Depending on a reset output enable bit, the reset signal can be output externally to reset devices controlled by the H8/520, as well as the H8/520 itself. et4U.com DataShe 237 HITACHI # 12.1.2 Block Diagram Figure 12-1 is a block diagram of the watchdog timer. T-49-19-16 Figure 12-1 Block Diagram of Timer Counter DataShe HITACHI 238 DataSheet4U.com www.DataSheet4U.com et4U.com Table 12-1 lists information on the watchdog timer registers. **Table 12-1 Register Configuration** | | | | initial | Addresses | | |-------------------------------|--------------|--------|---------|-----------|--------| | Name | Abbreviation | R/W | value | Write | Read | | Timer control/status register | TCSR | R/(W)* | H'18 | H'FFEC | H'FFEC | | Timer counter | TCNT | R/W | H'00 | H'FFEC | H'FFED | | Reset control/status register | RSTCSR | R/(W)* | H'3F | H'FFFE | H'FFFF | Note: \* Software can write a 0 to clear bit 7, but cannot write a 1. #### 12.2 Register Descriptions ### 12.2.1 Timer Counter (TCNT)—H'FFED | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------------|-----|-----|-----|-----|-----|-----|-----|-----|--| | | | | | | | | | | | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Read/Write | R/W | The watchdog timer counter (TCNT) is a readable/writable\* 8-bit up-counter. When the timer enable bit (TME) in the timer control/status register (TCSR) is set to 1, the timer counter starts counting pulses of an internal clock source selected by clock select bits 2 to 0 (CKS2 to CKS0) in the TCSR. When the count overflows (changes from H'FF to H'00), a reset or interrupt signal is generated. DataShe The watchdog timer counter is initialized to H'00 at a reset and when the TME bit is cleared to 0. Note: \* TCNT is write-protected by a password. See section 12.2.4, "Notes on Register Access", for details. 239 HITACHI www.DataSheet4U.com et4U.com ### 12.2.2 Timer Control/Status Register (TCSR)—H'FFEC (Read), H'FFED (Write) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------------|-------|-------|-----|---|----------------|------|------|---------|---| | | OVF | WT/IT | TME | _ | | CKS2 | CKS1 | CKS0 | | | Initial value | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | | Read/Write | R/W*1 | R/W | R/W | _ | <del>-</del> . | R/W | R/W | R/W | | | | | | | | | | T- | 49-19-1 | 6 | The watchdog timer control/status register (TCSR) is an 8-bit readable/writable 2 register that selects the timer mode and clock source and performs other functions. Bits 7 to 5 are initialized to 0 at a reset and in the standby modes. Bits 2 to 0 are initialized to 0 at a reset, but retain their values in the software standby mode. - Notes: 1. Software can write a 0 in bit 7 to clear the flag, but cannot set this bit to 1. - 2. The TCSR is write-protected by a password. See section 12.2.4, "Notes on Register Access", for details. Bit 7—Overflow Flag (OVF): This bit indicates that the watchdog timer count has overflowed. | OVF | Description | | | |-----|---------------------------------------------------------------------------|-----------------|---| | 0 | To clear this bit, the CPU must read this bit after it has been set to 1, | (Initial value) | | | | then write a 0 in this bit. DataSheet4U.com | | | | 1 | This bit is set to 1 when TCNT changes from H'FF to H'00.* | | D | Note: \* The OVF bit is not set in the watchdog timer mode. Bit 6—Timer Mode Select (WT/TT): This bit selects whether to operate in the watchdog timer mode or interval timer mode. If the watchdog timer mode is selected, a watchdog timer overflow resets the chip. If the interval timer mode is selected, a watchdog timer overflow generates an IRQ0 interrupt request. #### Bit 6 et4U.com | WT/IT | Description | | |-------|------------------------------------|-----------------| | 0 | Interval timer mode (IRQo request) | (Initial value) | | 1 | Watchdog timer mode (Reset) | | HITACHI 240 www.DataSheet4U.com Bit 5—Timer Enable (TME): This bit enables or disables the timer. | Bit 5 | | T-49-19-16 | | | |-------|----------------------------------------------|---------------------------|--|--| | TME | Description | | | | | 0 | TCNT is initialized to H'00 and stopped. | (Initial value) | | | | 1 | TCNT runs. A reset or interrupt is requested | when the count overflows. | | | Bits 4 and 3—Reserved: These bits cannot be modified and are always read as 1. Bits 2, 1, and 0—Clock Select (CKS2, CKS1, and CKS0): These bits select one of eight clock sources obtained by dividing the system clock (Ø). The overflow interval listed in the table below is the time from when the watchdog timer counter begins counting from H'00 until an overflow occurs. In the interval timer mode, IRQ0 interrupts are requested at this interval. | | Bit 2<br>CKS2 | Bit 1 | Bit 0 | Description | | | | |----------|---------------|--------------|-------|--------------|--------------------------------|-----------------|--| | | | KS2 CKS1 CKS | CKS0 | Clock Source | Overflow Interval (ø = 10 MHz) | | | | | 0 | 0 | 0 | ø/2 | 51.2 μs | (Initial value) | | | | 0 | 0 | 1 | ø/32 | 819.2 μs | · | | | :t4U.com | 0 | 1 | 0 | ø/64 | 1.6 ms | | | | | n <b>0</b> | 1 | 1 | ø/128 | 3.3 ms | | | | | 1 | 0 | 0 | ø/256 | 6.6 ms | | | | | 1 | 0 | 1 | ø/512 | 13.1 ms | | | | | 1 | 1 | 0 | ø/2048 | 52.4 ms | | | | | 1 | 1 | 1 | ø/4096 | 104.9 ms | | | ## 12.2.3 Reset Control/Status Register (RSTCSR)—H'FFFF (Read), H'FFFE (Write) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | , | |---------------|---------|-------|-------------|---|---|-------|---|---|---| | | WRST | RSTOE | | | | | | _ | | | Initial value | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | | Read/Write | R/(W)*1 | R/W | <del></del> | - | | ***** | | _ | | The reset control/status register (RSTCSR) is an 8-bit readable/writable\*2 register that indicates when a reset has been caused by a watchdog timer overflow, and controls external output of the reset signal. 241 HITACHI www.DataSheet4U.com DataShe Bit 6 is not initialized by the reset caused by the watchdog timer overflow. It is initialized, however, by a reset caused by input at the $\overline{RES}$ pin. T-49-19-16 - Notes: 1. Software can write a 0 in bit 7 to clear the flag, but cannot set this bit to 1. - 2. The RSTCSR is write-protected by a password. See section 12.2.4, "Notes on Register Access", for details. Bit 7—Watchdog Timer Reset (WRST): This bit indicates that a reset signal has been generated by a watchdog timer overflow in the watchdog timer mode. The reset signal generated by the overflow resets the entire H8/520 chip. In addition, if the reset output enable (RSTOE) bit is set to 1, a reset signal (low) is output at the $\overline{RES}$ pin to reset devices connected to the H8/520. The WRST bit can be cleared by software by writing a 0. It is also cleared when a reset signal from an external device is received at the $\overline{RES}$ pin. #### Bit 7 | WRST | Description | | | |------|---------------------------------------------------------------------------------|---------------------|--------| | 0 | This bit is cleared to 0 by a reset signal input from the RES pin, (Initial sta | te) | | | | or when software writes a 0. | | | | 1 | This bit is set to 1 when the watchdog timer overflows in the watchdog timer mo | ode and an internal | | | | reset signal is generated. DataSheet411.com | | - (-Ch | | | • | | DataSh | Bit 6—Reset Output Enable (RSTOE): This bit selects whether to output a reset signal from the RST pin when the timer counter overflows in the watchdog timer mode. #### Bit 6 et4U.com | RSTOE | Description | | |-------|----------------------------------------------------------------------|-------------------| | 0 | The reset signal generated by a watchdog timer overflow is not | (Initial state) | | | output to external devices. | | | 1 | The reset signal generated by a watchdog timer overflow is output to | external devices. | Bits 5 to 0—Reserved: These bits cannot be modified and are always read as 1. #### 12.2.4 Notes on Register Access The watchdog timer's TCNT, TCSR, and RSTCSR registers differ from other registers in being more difficult to write. The procedures for writing and reading these registers are given below. #### HITACHI 242 Writing to TCNT and TCSR: These registers must be written by word access. Programs cannot write to them by byte access. The word must contain the write data and a password. T-49-19-16 The watchdog timer's TCNT and TCSR registers both have the same write address. The write data must be contained in the lower byte of the word written at this address. The upper byte must contain H'5A (password for TCNT) or H'A5 (password for TCSR). See figure 12-2. The result of the access depicted in figure 12-2 is to transfer the write data from the lower byte to the TCNT or TCSR. Figure 12-2 Writing to TCNT and TCSR #### **Coding Examples:** To clear TCNT to 00: MOV.W #H'5A00, @H'FFEC To write H'4F in TCSR: MOV.W #H'A54F, @H'FFEC not be written by byte access. nataShe The upper byte of the word must contain a password. Separate passwords are used for clearing the WRST bit and for writing a 1 or 0 to the RSTOE bit. To clear the WRST bit, the word written at address H'FFFE must contain the password H'A5 in the upper byte and the data H'00 in the lower byte. This clears the WRST bit to 0 without affecting other bits. To set or clear the RSTOE bit, the word written at address H'FFFE must contain the password H'5A in the upper byte and the write data in the lower byte. This writes the desired data in the RSTOE bit without affecting other bits. These write operations are illustrated in figure 12-3. 243 HITACHI www.DataSheet4U.com Figure 12-3 Writing to RSTCSR #### **Coding Examples:** To clear WRST to 0: MOV.W #H'A500, @H'FFFE To set RSTOE to 1: MOV.W #H'5AFF, @H'FFFE Reading TCNT, TCSR, and RSTCSR: The read addresses are H'FFEC for TCSR, H'FFED for TCNT, and H'FFFF for RSTCSR as indicated in table 12-2. These three registers are read like other registers. Byte access instructions can be used. Table 12-2 Read Addresses of TCNT and TCSR | Read Address | Register | | |--------------|----------|----| | H'FFEC | TCSR | | | H'FFED | TCNT | | | H'FFFF | RSTCSR | Da | et4U.com DataSheet4U.com ### DataShe # 12.3 Operation ### 12.3.1 Watchdog Timer Mode The watchdog timer function begins operating when software sets the WT/IT and TME bits to 1 in the TCSR. Thereafter, software should periodically rewrite the contents of the timer counter (normally by writing H'00) to prevent the count from overflowing. If a program crash allows the timer count to overflow, the watchdog timer generates a reset as shown in figure 12-4. The reset signal from the watchdog timer can also be output from the $\overline{RES}$ pin to reset external devices. This reset output signal is a low pulse with a duration of 132 $\emptyset$ clock periods. The reset signal is output only if the RSTOE bit in the TCSR is set to 1. HITACHI 244 The reset signal from the watchdog timer has the same vector as a reset generated by low input at the $\overline{RES}$ pin. Software should check the WRST bit in the RSTCSR to determine the source of the reset. If a watchdog timer overflow occurs at the same time as a low input at the RES pin, priority is given to one type of reset or the other depending on the value of the RSTOE bit in the RSTCSR. T-49-19-16 If the RSTOE bit is set to 1 when both types of reset occur simultaneously, the watchdog timer's reset signal takes precedence. The internal state of the H8/520 chip is reset, the RSTOE bit remains set to 1, the WRST bit is also set to 1, and the $\overline{RES}$ pin is held low for 132 $\emptyset$ clock periods. If at the end of 520 $\emptyset$ clock periods there is still an external low input to the $\overline{RES}$ pin, the external reset takes effect, clearing the WRST and RSTOE bits to 0. Note that if the external reset occurs before the watchdog timer overflows, it takes effect immediately and clears the RSTOE bit. If the RSTOE bit is cleared to 0 when both types of reset occur simultaneously, the reset signal input from the $\overline{RES}$ pin takes precedence and the WRST bit is cleared to 0. Figure 12-4 Operation in Watchdog Timer Mode 245 HITACHI www.DataSheet4U.com ataSheet4U.com Interval timer operation begins when the WT/IT bit is cleared to 0 and the TME bit is set to 1. In the interval timer mode, an IRQ0 request is generated each time the timer count overflows. This function can be used to generate IRQ0 requests at regular intervals. See figure 12-5. IRQo requests from the watchdog timer module have the same vector as IRQo requests from the IRQo pin, so the IRQo interrupt-handling routine must check the OVF bit in the TCSR to determine the source of the interrupt. Figure 12-5 Operation in Interval Timer Mode DataShe #### 12.3.3 Operation in Software Standby Mode The watchdog timer has a special function in the software standby mode. Specific watchdog timer settings are required when the software standby mode is used. Before Transition to the Software Standby Mode: The TME bit must be cleared to 0 to stop the watchdog timer counter before a transition to the software standby mode. The chip cannot enter the software standby mode while the TME bit is set to 1. Before entering the software standby mode, software should also set the clock select bits (CKS2 to CKS0) to a value that makes the timer overflow interval equal to or greater than the settling time of the clock oscillator. Recovery from the Software Standby Mode: Recovery from the software standby mode can be triggered by an NMI request. In this case the recovery proceeds as follows: HITACHI 246 www.DataSheet4U.com et4U.com www.Data When an NMI request signal is received, the clock oscillator starts running and the watchdog timer starts counting at the rate selected by the clock select bits before the software standby mode was entered. When the count overflows from H'FF to H'00, the ø clock is presumed to be stable and usable, clock signals are supplied to all modules on the chip, and the NMI interrupt-handling routine starts executing. T-49-19-16 # 12.3.4 Setting of Overflow Flag The OVF bit is set to 1 when the timer count overflows in the interval timer mode. Simultaneously, the WDT module requests an IRQ0 interrupt. The timing is shown in figure 12-6. Figure 12-6 Setting of OVF Bit DataShe 247 HITACHI DataSheet4U.com # www.DataSheet4U.com 12.3.5 Setting of Watchdog Timer Reset (WRST) Bit The WRST bit is valid when $WT/\overline{IT} = 1$ and TME = 1. T-49-19-16 The WRST bit is set to 1 when the timer count overflows. An internal reset signal is simultaneously generated for the entire H8/520 chip. The timing is shown in figure 12-7. Figure 12-7 Setting of WRST Bit and Internal Reset Signal et4U.com # 12.4 Application Notes Contention between TCNT Write and Increment: If a timer counter clock pulse is generated during the T3 state of a write cycle to the timer counter, the write takes priority and the timer counter is not incremented. See figure 12-8. **HITACHI** 248 www.DataSheet4U.com DataShe DataSheet4U.com Figure 12-8 TCNT Write-Increment Contention Changing the Clock Select Bits (CKS2 to CKS0): Software should stop the watchdog timer (by clearing the TME bit to 0) before changing the value of the clock select bits. If the clock select bits are modified while the watchdog timer is running, the timer count may be incremented incorrectly. et4U.com DataSheet4U.com DataShe 249 HITACHI www.bataeneet40.comMCU/MPU) 50E D •• 4496204 0028038 521 •• HIT3 T-49-19-16 DataShe et4U.com DataSheet4U.com HITACHI 256 DataSheet4U.com www.DataSheet4U.com www.DataSheet4U.com # Section 13 Serial Communication Interface ### 13.1 Overview T-49-19-16 The H8/520 chip includes a two-channel serial communication interface (SCI) for transferring serial data to and from other chips. The two channels are independent but are functionally identical. Synchronous and asynchronous data transfer are supported on both channels. #### 13.1.1 Features The features of the on-chip serial communication interface are as follows: - · Selection of asynchronous or synchronous mode - -Asynchronous mode The SCI can communicate with a UART (Universal Asynchronous Receiver/Transmitter), ACIA (Asynchronous Communication Interface Adapter), or other chip that employs standard asynchronous serial communication. Eight data formats are available. -Data length: 7 or 8 bits -Stop bit length: 1 or 2 bits -Parity: Even, odd, or none -Error detection: Parity, overrun, and framing errors -Synchronous mode et4U.com The SCI can communicate with chips able to synchronize data transfers with clock pulses. -Data length: 8 bits - Error detection: Overrun errors Full duplex communication The transmitting and receiving sections are independent, so the SCI can transmit and receive simultaneously. Both the transmit and receive sections use double buffering, so continuous data transfer is possible in either direction. · Built-in baud rate generator Any specified baud rate can be generated. Internal or external clock source The baud rate generator can operate on an internal clock source, or an external clock signal input at the SCK pin. · Three interrupts Transmit-end, receive-end, and receive-error interrupts are requested independently. The transmitend and receive-end interrupts can be served by the on-chip data transfer controller (DTC), providing a convenient way to transfer data with minimal CPU programming. 251 HITACHI DataSheet4U.com www.DataSheet4U.com DataShe DataSheet4U.com ### 13.1.2 Block Diagram T-49-19-16 Figure 13-1 shows a block diagram of one serial communication interface channel. Figure 13-1 Block Diagram of Serial Communication Interface HITACHI 252 DataSheet4U.com www.DataSheet4U.com ## 13.1.3 Input and Output Pins Table 13-1 lists the input and output pins used by the SCI module. T-49-19-16 Table 13-1 SCI Input/Output Pins | Name | Abbreviation | 1/0 | Function | |--------------|------------------|------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------| | Serial clock | SCK1 | Input/output | Serial clock input and output for channel 1 | | Receive data | RXD <sub>1</sub> | Input | Receive data input for channel 1 | | - | TXD1 | Output | Transmit data output for channel 1 | | | SCK2 | Input/output | Serial clock input and output for channel 2 | | | RXD2 | Input | Receive data input for channel 2 | | | TXD2 | Output | Transmit data output for channel 2 | | | | Serial clock SCK1 Receive data RXD1 Transmit data TXD1 Serial clock SCK2 Receive data RXD2 | Serial clock SCK1 Input/output Receive data RXD1 Input Transmit data TXD1 Output Serial clock SCK2 Input/output Receive data RXD2 Input | ## 13.1.4 Register Configuration Table 13-2 lists the SCI registers. These registers specify the communication mode (synchronous or asynchronous), data format, and bit rate, and control the transmit and receive sections. Table 13-2 SCI Registers | Channel | Name | Abbreviation | R/W | Initial Value | Address | - | |---------|-------------------------|--------------------|--------|---------------|---------|-----------| | 1 | Receive shift register | RSR | | | | _ | | • | Receive data register | RDR<br>Sheet4l Lco | n R | H'00 | H'FFDD | DataShe | | | Transmit shift register | TSR | | | | - Dataono | | | Transmit data register | TDR | R/W | H'FF | H'FFDB | _ | | | Serial mode register | SMR | R/W | H'04 | H'FFD8 | _ | | | Serial control register | SCR | R/W | H'0C | H'FFDA | _ | | | Serial status register | SSR | R/(W)* | H'87 | H'FFDC | <b>_</b> | | | Bit rate register | BRR | R/W | H'FF | H'FFD9 | | | 2 | Receive shift register | RSR | | | | _ | | - | Receive data register | RDR | R | H'00 | H'FFC5 | _ | | | Transmit shift register | TSR | | | | _ | | | Transmit data register | TDR | R/W | H'FF | H'FFC3 | _ | | | Serial mode register | SMR | R/W | H'04 | H'FFC0 | <b></b> | | | Serial control register | SCR | R/W | H'0C | H'FFC2 | _ | | | Serial status register | SSR | R/(W)* | H'87 | H'FFC4 | _ | | | Bit rate register | BRR | R/W | H'FF | H'FFC1 | | | | | | | | | | Note: \* Software can write a 0 to clear the status flag bits, but cannot write a 1. 253 **HITACHI** DataSheet4U.com et4U.com ## 13.2 Register Descriptions T-49-19-16 ### 13.2.1 Receive Shift Register (RSR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|---|---|---|---|---|---|---|----------| | | | | | | | | | | | Read/Write | _ | _ | | | | | | <b>—</b> | The RSR receives incoming data bits. When one character (one byte) has been received, it is transferred to the receive data register (RDR). The CPU cannot read or write the RSR directly. ## 13.2.2 Receive Data Register (RDR)—H'FFDD (Channel 1), H'FFC5 (Channel 2) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|---|---|---|---|---|---| | | | | | | | | | | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R | R | R | R | R | R | R | R | The RDR stores received data. As each character is received, it is transferred from the RSR to the RDR, enabling the RSR to receive the next character. This double-buffering allows the SCI to receive data continuously. et4U.com The CPU can read but not write the RDR. The RDR is initialized to H'00 at a reset and in the standby modes. ### 13.2.3 Transmit Shift Register (TSR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|---|---|---|---|---|---|---|---| | | | | | | | | | | | Read/Write | _ | _ | | • | | | | | The TSR holds the character currently being transmitted. When transmission of this character is completed, the next character is moved from the transmit data register (TDR) to the TSR and transmission of that character begins. If the TDR does not contain valid data, the SCI stops transmitting. The CPU cannot read or write the TSR directly. HITACHI 254 # 13.2.4 Transmit Data Register (TDR)—H'FFDB (Channel 1), H'FFC3 (Channel 2) The TDR is an 8-bit readable/writable register that holds the next character to be transmitted. When the TSR becomes empty, the character written in the TDR is transferred to the TSR. Continuous data transmission is possible by writing the next byte in the TDR while the current byte is being transmitted from the TSR. The TDR is initialized to H'FF at a reset and in the standby modes. # 13.2.5 Serial Mode Register (SMR)—H'FFD8 (Channel 1), H'FFC0 (Channel 2) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|------|---|------|------| | | C/Ā | CHR | PE | O/E | STOP | | CKS1 | CKS0 | | Initial value | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | Read/Write | R/W | R/W | R/W | R/W | R/W | | R/W | R/W | The SMR is an 8-bit readable/writable register that controls the communication format and selects the etau.comclock rate for the internal clock source. It is initialized to H'04 at a reset and in the standby modes. Bit 7—Communication Mode ( $C/\overline{A}$ ): This bit selects the asynchronous or synchronous communication mode. Bit 7 | C/A | Description | | <u></u> | |-----|------------------------------------------------------|-----------------|---------| | 0 | Asynchronous communication. | (Initial value) | | | 1 | Communication is synchronized with the serial clock. | | | Bit 6—Character Length (CHR): This bit selects the character length in asynchronous mode. It is ignored in synchronous mode. 255 **HITACHI** www.DataSheet4U.com DataShe 200 D 44JPCN4 NNSAN44 852 MAHILE | CHR | Description | | |-----|-----------------------|-----------------| | 0 | 8 bits per character. | (Initial value) | | 1 | 7 bits per character. | | | | | T-49-19-16 | Bit 5—Parity Enable (PE): This bit selects whether to add a parity bit in asynchronous mode. It is ignored in synchronous mode. ### Bit 5 | PE | Description | | |----|-----------------------------------|-----------------| | 0 | Transmit: No parity bit is added. | (Initial value) | | | Receive: Parity is not checked. | | | 1 | Transmit: A parity bit is added. | | | | Receive: Parity is checked. | | Bit 4—Parity Mode (O/E): In asynchronous mode, when parity is enabled (PE = 1), this bit selects even or odd parity. Even parity means that a parity bit is added to the data bits for each character to make the total number of 1s even. Odd parity means that the total number of 1s is made odd. This bit is ignored when PE = 0 and in the synchronous mode. et4U.com | 0 | Even parity. | (Initial value) | | |-------|--------------|-----------------|---| | 0/E | Description | | | | O/Ë | Description | | | | Bit 4 | | DataSheet4U.com | Г | Bit 3—Stop Bit Length (STOP): This bit selects the number of stop bits. It is ignored in the synchronous mode. #### Bit 3 | STOP | Description | | |------|--------------|-----------------| | 0 | 1 stop bit. | (Initial value) | | 1 | 2 stop bits. | | Bit 2—Reserved: This bit cannot be modified and is always read as 1. ### HITACHI 256 ta Sheet 4 U. com Bits 1 and 0—Clock Select 1 and 0 (CKS1 and CKS0): These bits select the internal clock source when the baud rate generator is clocked from within the H8/520 chip. | Bit 1 | Bit 0 | | | |-------|-------|-------------|-----------------| | CKS1 | CKS0 | Description | | | 0 | 0 | ø clock | (Initial value) | | 0 | 1 | ø/4 clock | | | 1 | 0 | ø/16 clock | | | 1 | 1 | ø/64 clock | | # 13.2.6 Serial Control Register (SCR)—H'FFDA (Channel 1), H'FFC2 (Channel 2) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|---|-------------|------|------| | | TIE | RIE | TE | RE | | | CKE1 | CKE0 | | Initial value | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | Read/Write | R/W | R/W | R/W | R/W | _ | <del></del> | R/W | R/W | The SCR is an 8-bit readable/writable register that enables or disables various SCI functions. It is initialized to H'0C at a reset and in the standby modes. Bit 7—Transmit Interrupt Enable (RIE): This bit enables or disables the transmit-end interrupt (TXI) request when the transmit data register empty (TDRE) bit in the serial status register (SSR) is set to 1. et4U.com DataSheet4U.com DataShe | Bit 7 | | | |-------|-------------------------------------------------------|-----------------| | TIE | Description | | | 0 | The transmit-end interrupt request (TXI) is disabled. | (Initial value) | The transmit-end interrupt request (TXI) is enabled. Bit 6—Receive Interrupt Enable (RIE): This bit enables or disables the receive-end interrupt (RXI) request when the receive data register full (RDRF) bit in the serial status register (SSR) is set to 1. It also enables and disables the receive-error interrupt (ERI) request. #### Bit 6 | RIE | Description | | |-----|-------------------------------------------------------------------------|-------------------| | 0 | The receive-end interrupt (RXI) and receive-error interrupt (ERI) | (Initial value) | | | requests are disabled. | | | 1 | The receive-end interrupt (RXI) and receive-error interrupt (ERI) reque | ests are enabled. | 257 HITACHI DataSheet4U.com Bit 5—Transmit Enable (TE): This bit enables or disables the transmit function. When the transmit function is enabled, the TXD pin is automatically used for output. When the transmit function is disabled, the TXD pin can be used as a general-purpose I/O port. | Bit 5 | | T-49-19-16 | |-------|-------------------------------------------------------------------|-----------------| | TE | Description | | | 0 | The transmit function is disabled. The TXD pin can be | (Initial value) | | _ | used as a general-purpose I/O port. | | | 1 | The transmit function is enabled. The TXD pin is used for output. | | Bit 4—Receive Enable (RE): This bit enables or disables the receive function. When the receive function is enabled, the RXD pin is automatically used for input. When the receive function is disabled, the RXD pin is available as a general-purpose I/O port. Blt 4 | RE | Description | | |----|-----------------------------------------------------------------|-----------------| | 0 | The receive function is disabled. The RXD pin can be | (Initial value) | | | used as a general-purpose I/O port. | | | 1 | The receive function is enabled. The RXD pin is used for input. | | Bits 3 and 2—Reserved: These bits cannot be modified and are always read as 1. Bit 1—Clock Enable 1 (CKE1): This bit selects the SCI clock source: either the internal baud rate generator or an external clock signal input at the SCK pin. When the external clock source is selected, the SCK pin is automatically used for input of the external clock signal. DataShe Bit 1 | CKE1 | Description | | | |------|---------------------------------------------------------|-----------------|--| | 0 | Internal clock source. | (Initial value) | | | 1 | External clock source. (The SCK pin is used for input.) | | | Bit 0—Clock Enable 0 (CKE0): When an internal clock source is used in synchronous mode, this bit enables or disables serial clock output at the SCK pin. This bit is ignored when the external clock is selected, or when the asynchronous mode is selected. For further information on the communication format and clock source selection, see tables 13-5 and 13-6 in section 13.3, "Operation". HITACHI 258 | DataSheet4U.com | <br> | 1116677 | 0020071 | J J 7 | | |-----------------|------|---------|---------|-------|--| | Bit O | | | | | | | CKE0 | Description | | |------|---------------------------------------------------------|-----------------| | 0 | The SCK pin is not used by the SCI (and is available as | (Initial value) | | | a general-purpose I/O port). | | | 1 | The SCK pin is used for serial clock output. | | # 13.2.7 Serial Status Register (SSR)—H'FFDC (Channel 1), H'FFC4 (Channel 2) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 | |---------------|--------|--------|--------|--------|-----------------|---|---|---|---| | | TDRE | RDRF | ORER | FER | PER | | | | | | Initial value | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | | Read/Write | R/(W)* | R/(W)* | R/(W)* | R/(W)* | R/( <b>W</b> )* | R | R | R | | Note: \* Software can write a 0 to clear the flags, but cannot write a 1 in these bits. The SSR is an 8-bit register that indicates transmit and receive status. It is initialized to H'87 at a reset and in the standby modes. Bit 7—Transmit Data Register Empty (TDRE): This bit indicates when the TDR contents have been transferred to the TSR and the next character can safely be written in the TDR. #### Bit 7 t4U.com | TDRE | Des | cription | | - | |------|------|---------------------------------------------------------|---------------------------------------------|----------| | 0 | This | bit is cleared from 1 to 0 when: | | | | | 1. | The CPU reads the TDRE bit lafter the TDRE bit has t | been set to 1, then writes a 0 in this bit. | DataShe | | | 2. | The data transfer controller (DTC) writes data in the T | DR. | - | | 1 | This | bit is set to 1 at the following times: | (Initial value) | | | | 1. | The chip is reset or enters a standby mode. | | | | | 2. | When TDR contents are transferred to the TSR. | | | | | 3. | When TDRE = 0 and the TE bit is cleared to 0. | | <b>-</b> | Bit 6—Receive Data Register Full (RDRF): This bit indicates when one character has been received and transferred to the RDR. 259 HITACHI DataSheet4U.com | Bit 6 | | | T-49-19-16 | |-------|-----|-------------------------------------------------------|---------------------------------------------------| | RDRF | De | scription | 1-45 | | 0 | Thi | s bit is cleared from 1 to 0 when: | (Initial value) | | | 1. | The CPU reads the RDRF bit after the RDRF bi | t has been set to 1, then writes a 0 in this bit. | | | 2. | The data transfer controller (DTC) reads the RD | PR. | | | 3. | The chip is reset or enters a standby mode. | | | 1 | Thi | s bit is set to 1 when one character is received with | out error and transferred from the RSR to | | | the | RDR | | Bit 5—Overrun Error (ORER): This bit indicates an overrun error during reception. ### Bit 5 | ORER | Description | | | | | | | |------|------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|--|--|--|--|--| | 0 | This bit is cleared from 1 to 0 when: | (Initial value) | | | | | | | | 1. The CPU reads the ORER bit after the ORER | bit has been set to 1, then writes a 0 in this bit. | | | | | | | | 2. The chip is reset or enters a standby mode. | | | | | | | | 1 | This bit is set to 1 if reception of the next character ends while the receive data register is still full | | | | | | | | | (RDRF = 1). | | | | | | | Bit 4—Framing Error (FER): This bit indicates a framing error during data reception in the asynchronous mode. It has no meaning in the synchronous mode. #### Bit 4 | 200 | DIL 4 | | D 4 61 4411 | | | | | | |-----|-------|------------------------------------------------|----------------------------------|----------------------------------------|--|--|--|--| | om; | FER | Description | DataSheet4U.com | DataSheet4U.com | | | | | | | 0 | This bit is cleared from 1 to 0 | when: | (Initial value) | | | | | | | | 1. The CPU reads the FE | R bit after the FER bit has been | set to 1, then writes a 0 in this bit. | | | | | | | | 2. The chip is reset or enters a standby mode. | | | | | | | | | 1 | This bit is set to 1 if a framing | g error occurs (stop bit = 0). | | | | | | Bit 3—Parity Error (PER): This bit indicates a parity error during data reception in the asynchronous mode, when a communication format with parity bits is used. This bit has no meaning in the synchronous mode, or when a communication format without parity bits is used. ### HITACHI 260 www.DataSheet4U.com DataShe | Bit 3 | Description | | | | | | | |-------|-----------------------------------------------------------------------------------------------------|-----------------------------------------|--|--|--|--|--| | PER | Description | | | | | | | | 0 | This bit is cleared from 1 to 0 when: (Initial value) | | | | | | | | | 1. The CPU reads the PER bit after the PER bit has been set to 1, then writes a 0 in this bit. | | | | | | | | | 2. The chip is reset or enters a standby mode. | | | | | | | | 1 | This bit is set to 1 when a parity error occurs (the parity of the received data does not match the | | | | | | | | | parity selected by the $O/\overline{E}$ bit in the SMR). | , — — — — — — — — — — — — — — — — — — — | | | | | | | | F | T-49-19-16 | | | | | | Bits 2 to 0—Reserved: These bits cannot be modified and are always read as 1. ## 13.2.8 Bit Rate Register (BRR)—H'FFD9 (Channel 1), H'FFC1 (Channel 2) The BRR is an 8-bit register that, together with the CKS1 and CKS0 bits in the SMR, determines the baud rate output by the baud rate generator. The BRR is initialized to H'FF (the slowest rate) at a reset and in the standby modes. Tables 13-3 and 13-5 show examples of BRR (N) and CKS (n) settings for commonly used bit rates. Different values can be set for each SCI channel. Table 13-4 indicates the maximum bit rates for various crystal oscillator frequencies in the asynchronous mode. DataShe 261 HITACHI DataSheet4U.com t4U.com Table 13-3 Examples of BRR Settings in Asynchronous Mode (1) ## XTAL Frequency (MHz) | | 2 | | | | 2.4576 | | | 4 | | | 4.19430 | )4 | |-------------|-------------|-----|--------------|-------------|--------|--------------|-----|-----|--------------|---|---------|--------------| | Bit<br>Rate | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | 110 | 1 | 70 | +0.03 | 1 | 86 | +0.31 | 1 | 141 | +0.03 | 1 | 148 | -0.04 | | 150 | 0 | 207 | +0.16 | 0 | 255 | 0 | 1 | 103 | +0.16 | 1 | 108 | +0.21 | | 300 | 0 | 103 | +0.16 | 0 | 127 | 0 | 0 | 207 | +0.16 | 0 | 217 | +0.21 | | 600 | 0 | 51 | +0.16 | 0 | 63 | 0 | 0 | 103 | +0.16 | 0 | 108 | +0.21 | | 1200 | 0 | 25 | +0.16 | 0 | 31 | 0 | 0 | 51 | +0.16 | 0 | 54 | -0.70 | | 2400 | 0 | 12 | +0.16 | 0 | 15 | 0 | . 0 | 25 | +0.16 | 0 | 26 | +1.14 | | 4800 | | | | 0 | 7 | 0 | 0 | 12 | +0.16 | 0 | 13 | -2.48 | | 9600 | _ | | _ | 0 | 3 | 0 | _ | _ | — | | | _ | | 19200 | <del></del> | | | 0 | 1 | 0 | _ | _ | | | | | | 31250 | _ | | _ | <del></del> | | | 0 | 1 | 0 | _ | _ | _ | | 38400 | | | <b></b> | 0 | 0 | 0 | | | _ | _ | - | | Table 13-3 Examples of BRR Settings in Asynchronous Mode (2) ### XTAL Frequency (MHz) | | | 4.915 | 2 | | 6 | | | 7.3728 | | | 8 | | | |-------------|---|--------------|--------------|---|-------------|--------------|---|--------|--------------|---|-----|--------------|--| | Bit<br>Rate | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | | 110 | 1 | 174 | -0.26 | 2 | 52 | +0.50 | 2 | 64 | +0.70 | 2 | 70 | +0.03 | | | 150 | 1 | 127 | 0 | 1 | 155 | +0.16 | 1 | 191 | 0 | 1 | 207 | +0.16 | | | 300 | 0 | 255 | 0 | 1 | 77 | +0.16 | 1 | 95 | 0 | 1 | 103 | +0.16 | | | 600 | 0 | 127 | 0 | 0 | 155 | +0.16 | 0 | 191 | 0 | 0 | 207 | +0.16 | | | 1200 | 0 | 63 | 0 | 0 | 77 | +0.16 | 0 | 95 | 0 | 0 | 103 | +0.16 | | | 2400 | 0 | 31 | 0 | 0 | 38 | +0.16 | 0 | 47 | 0 | 0 | 51 | +0.16 | | | 4800 | 0 | 15 | 0 | 0 | 19 | -2.34 | 0 | 23 | 0 | 0 | 25 | +0.16 | | | 9600 | 0 | 7 | 0 | | - | | 0 | 11 | 0 | 0 | 12 | +0.16 | | | 19200 | 0 | 3 | 0 | | | - | 0 | 5 | 0 | | | <del></del> | | | 31250 | | <del>-</del> | | 0 | 2 | 0 | _ | | _ | 0 | 3 | 0 | | | 38400 | 0 | 1 | 0 | | | | 0 | 2 | 0 | | | | | | | | | | | <del></del> | | | | | | • | | | 262 HITACHI www.DataSheet4U.com DataShe DataSheet4U.com DataSheet4U.com et4U.com Table 13-3 Examples of BRR Settings in Asynchronous Mode (3) XTAL Frequency (MHz) | | 9.8304 | | | 10 | | | 12 | | | 12.28 | } | | |-------------|--------|-----|--------------|----|-----|--------------|----|-----|--------------|-------|-----|--------------| | Bit<br>Rate | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | 110 | 2 | 86 | +0.31 | 2 | 88 | -0.25 | 2 | 106 | -0.44 | 2 | 108 | +0.88 | | 150 | 1 | 255 | 0 | 2 | 64 | +0.16 | 2 | 77 | 0 | 2 | 79 | 0 | | 300 | 1 | 127 | 0 | 1 | 129 | +0.16 | 1 | 155 | 0 | 1 | 159 | 0 | | 600 | 0 | 255 | 0 | 1 | 64 | +0.16 | 1 | 77 | 0 | 1 | 79 | 0 | | 1200 | 0 | 127 | 0 | 0 | 129 | +0.16 | 0 | 155 | +0.16 | 0 | 159 | 0 | | 2400 | 0 | 63 | 0 | 0 | 64 | +0.16 | 0 | 77 | +0.16 | 0 | 79 | 0 | | 4800 | 0 | 31 | 0 | 0 | 32 | -1.36 | 0 | 38 | +0.16 | 0 | 39 | 0 | | 9600 | 0 | 15 | 0 | 0 | 15 | +1.73 | 0 | 19 | -2.34 | 0 | 19 | 0 | | 19200 | 0 | 7 | 0 | 0 | 7 | +1.73 | | | - | 0 | 9 | 0 | | 31250 | 0 | 4 | -1.70 | 0 | 4 | 0 | 0 | 5 | 0 | 0 | 5 | +2.40 | | 38400 | 0 | 3 | 0 | 0 | 3 | +1.73 | | | _ | 0 | 4 | 0 | t4U.com DataSheet4U.com DataShe 263 **HITACHI** DataSheet4U.com Table 13-3 Examples of BRR Settings in Asynchronous Mode (4) XTAL Frequency (MHz) | | 14.7456 | | | | 16 | | | 19.660 | 08 | 20 | | | |-------------|---------|-----|--------------|---|-------------|--------------|---|--------|--------------|----|-----|--------------| | Bit<br>Rate | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | 110 | 2 | 130 | -0.07 | 2 | 141 | +0.03 | 2 | 174 | -0.26 | 3 | 43 | +0.88 | | 150 | 2 | 95 | 0 | 2 | 103 | +0.16 | 2 | 127 | 0 | 2 | 129 | +0.16 | | 300 | 1 | 191 | 0 | 1 | 207 | +0.16 | 1 | 255 | 0 | 2 | 64 | +0.16 | | 600 | 1 | 95 | 0 | 1 | 103 | +0.16 | 1 | 127 | 0 | 1 | 129 | +0.16 | | 1200 | 0 | 191 | 0 | 0 | 207 | +0.16 | 0 | 255 | 0 | 1 | 64 | +0.16 | | 2400 | 0 | 95 | 0 | 0 | 103 | +0.16 | 0 | 127 | 0 | 0 | 129 | +0.16 | | 4800 | 0 | 47 | 0 | 0 | 51 | +0.16 | 0 | 63 | 0 | 0 | 64 | +0.16 | | 9600 | 0 | 23 | 0 | 0 | 25 | +0.16 | 0 | 31 | 0 | 0 | 32 | -1.36 | | 19200 | 0 | 11 | 0 | 0 | 12 | +0.16 | 0 | 15 | . 0 | 0 | 15 | +1.73 | | 31250 | | | | 0 | 7 | 0 | 0 | 9 | -1.70 | 0 | 9 | 0 | | 38400 | 0 | 5 | 0 | | _ | _ | 0 | 7 | 0 | 0. | 7 | +1.73 | | 307200 | | | | | <del></del> | | 0 | 0 | 0 | | | | | 312500 | | | <b>→</b> | _ | | — | | | | 0 | 0 | 0 | | | | | | | | | | | | | | | Note: If possible, the error should be within 1%. $$B = OSC \times 10^6 / [64 \times 2^{2n} \times (N + 1)]$$ et4U.com Bit rate (bits/s) B: DataSheet4U.com N: BRR value $(0 \le N \le 255)$ Crystal oscillator frequency in MHz OSC: Internal clock source (0, 1, 2, or 3) n: The meaning of n is given by the table below: | n | CKS1 | CKS0 | Clock | |---|------|------|-------| | 0 | 0 | 0 | Ø | | 1 | 0 | 1 | ø/4 | | 2 | 1 | 0 | ø/16 | | 3 | 1 | 1 | ø/64 | HITACHI 264 www.DataSheet4U.com DataShe DataSheet4U.com | | | CKS a | nd BRR | |------------|---------------------------|-------|--------| | XTAL (MHz) | Maximum Bit Rate (bits/s) | n | N | | 2 | 31250 | 0 | 0 | | 2.4576 | 38400 | 0 | 0 | | 4 | 62500 | 0 | 0 | | 4.194304 | 65536 | 0 | 0 | | 4.9152 | 76800 | 0 | 0 | | 6 | 93750 | 0 | 0 | | 7.3728 | 115200 | 0 | 0 | | 8 | 125000 | 0 | 0 | | 9.8304 | 153600 | . 0 | 0 | | 10 | 156250 | 0 | 0 | | 12 | 187500 | 0 | 0 | | 12.288 | 192000 | 0 | 0 | | 14.7456 | 230400 | 0 | 0 | | 16 | 250000 | 0 | 0 | | 19.6608 | 307200 | 0 | 0 | | 20 | 312500 | 0 | 0 | t4U.com DataSheet4U.com DataShe 265 HITACHI DataSheet4U.com www.DataSheet4U.com Table 13-5 Examples of BRR Settings in Synchronous Mode | XTAI. | Frequency | (MHz) | |-------|------------|-----------| | 7 17L | i icquency | (121116-) | T-49-19-16 | Bit | 2 | | 4 | | | 8 | 1 | 0 | 1 | 16 | 2 | 20 | | |-------|---|-----|---|-----|---|-----|---|-----|---|-----|---|-----|--| | Rate | n | N | n | N | n | N | n | N | n | N | n | N | | | 100 | | _ | | | | | _ | | | | | | | | 250 | 1 | 249 | 2 | 124 | 2 | 249 | | | 3 | 124 | | | | | 500 | 1 | 124 | 1 | 249 | 2 | 124 | | | 2 | 249 | | | | | 1 k | 0 | 249 | 1 | 124 | 1 | 249 | | | 2 | 124 | | | | | 2.5 k | 0 | 99 | 0 | 199 | 1 | 99 | 1 | 124 | 1 | 199 | 1 | 249 | | | 5 k | 0 | 49 | 0 | 99 | 0 | 199 | 0 | 249 | 1 | 99 | 1 | 124 | | | 10 k | 0 | 24 | 0 | 49 | 0 | 99 | 0 | 124 | 0 | 199 | 0 | 249 | | | 25 k | 0 | 9 | 0 | 19 | 0 | 39 | 0 | 49 | 0 | 79 | 0 | 99 | | | 50 k | 0 | 4 | 0 | 9 | 0 | 19 | 0 | 24 | 0 | 39 | 0 | 49 | | | 100 k | | _ | 0 | 4 | 0 | 9 | | | 0 | 19 | 0 | 24 | | | 250 k | 0 | 0* | 0 | 1 | 0 | 3 | 0 | 4 | 0 | 7 | 0 | 9 | | | 500 k | | | 0 | 0* | 0 | 1 | | | 0 | 3 | 0 | 4 | | | 1 M | | | | | 0 | 0* | | | 0 | 1 | | | | | 2.5 M | | | | | | | | | | | 0 | 0* | | Notes: Blank: No setting is available. -: A setting is available, but the bit rate is inaccurate. \*: Continuous transfer is not possible. $$B = OSC/[8 \times 2^{2n} \times (N + 1)]$$ DataSheet4U.com B: Bit rate (bits/s) et4U.com N: BRR value $(0 \le N \le 255)$ OSC: Crystal oscillator frequency in MHz n: Internal clock source (0, 1, 2, or 3) The meaning of n is given by the table below: | CKS1 | CKS0 | Clock | |------|------|---------| | 0 | 0 | Ø | | 0 | 1 | ø/4 | | 1 | 0 | ø/16 | | 1 | 1 | ø/64 | | | | 0 0 0 1 | ### **HITACHI** 266 www.DataSheet4U.com DataShe DataSheet4U.com ## 13.3 Operation ### 13.3.1 Overview T-49-19-16 The SCI supports serial data transfer in both asynchronous and synchronous modes. The communication format depends on settings in the SMR as indicated in table 13-6. The clock source and usage of the SCK pin depend on settings in the SMR and SCR as indicated in table 13-7. Table 13-6 Communication Formats Used by SCI | SMR | | | | | | | Stop Bit | |-----|-----|----|------|--------------|------------|--------|----------| | C/Ā | CHR | PE | STOP | -<br>Mode | Format | Parity | Length | | 0 | 0 | 0 | 0 | Asynchronous | 8-Bit data | None | 1 | | | | | 1 | <b></b> - | | | 2 | | | | 1 | 0 | | | Yes | 1 | | | | | 1 | | | | 2 | | | 1 | 0 | 0 | <del></del> | 7-Bit data | None | 1 | | | | | 1 | _ | | | 2 | | | | 1 | 0 | _ | | Yes | 1 | | | | | 1 | <del>-</del> | | | 2 | | 1 | _ | | | Synchronous | 8-Bit data | _ | | | | | | | | | | | 411 com Table 13-7 SCI Clock Source Selection DataSheet4U.com | $\Box$ | oto | She | |---------|-----|-------| | $ \cup$ | alo | 10111 | | SMR | SCR | | Clock | | | | |--------|------|------|--------------|------------------------------------------------|--|--| | C/A | CKE1 | CKE0 | Source | SCK Pin | | | | 0 | 0 | 0 | Internal | I/O port* | | | | (Async | | 1 | <del>-</del> | Clock output at same frequency as bit rate | | | | mode) | 1 | 0 | External | Clock input at 16 times the bit rate frequency | | | | | | 1 | - | | | | | 1 | 0 | 0 | Internal | Serial clock output | | | | (Sync | | 1 | <del>-</del> | | | | | mode) | 1 | 0 | External | Serial clock input | | | | | | 1 | - | | | | Note: \* Not used by the SCI. Transmitting and receiving operations in the two modes are described next. 267 HITACHI ### 13.3.2 Asynchronous Mode In asynchronous mode, each character is individually synchronized by framing it with a start bit and stop bit. T-49-19-16 Full duplex data transfer is possible because the SCI has independent transmit and receive sections. Double buffering in both sections enables the SCI to be programmed for continuous data transfer. Figure 13-2 shows the general format of one character sent or received in the asynchronous mode. The communication channel is normally held in the mark state (high). Character transmission or reception starts with a transition to the space state (low). The first bit transmitted or received is the start bit (low). It is followed by the data bits, in which the least significant bit (LSB) comes first. The data bits are followed by the parity bit, if present, then the stop bit or bits (high) confirming the end of the frame. In receiving, the SCI synchronizes on the falling edge of the start bit, and samples each bit at the center of the bit (at the 8th cycle of the internal serial clock, which runs at 16 times the bit rate). Figure 13-2 Data Format in Asynchronous Mode **Data Format:** Table 13-8 lists the data formats that can be sent and received in asynchronous mode. Eight formats can be selected by bits in the SMR. **HITACHI** 268 | S | MR B | its | | | | | | | |-----|------|------|-------------|------------|------|------|------|------| | CHR | PE | STOP | Data Format | | | | | | | 0 | 0 | 0 | START | 8-Bit data | | STOP | | | | 0 | 0 | 1 | START | 8-Bit data | | STOP | STOP | | | 0 | 1 | 0 | START | 8-Bit data | | Р | STOP | | | ) | 1 | 1 | START | 8-Bit data | | Р | STOP | STOP | | | 0 | 0 | START | 7-Bit data | STOP | ] | | | | I | 0 | 1 | START | 7-Bit data | STOP | STOP | ] | | | i | 1 - | 0 | START | 7-Bit data | Р | STOP | ] | | | | 1 | 1 | START | 7-Bit data | Р | STOP | STOP | | Note: START: Start bit STOP: Stop bit P: Parity bit Clock: In the asynchronous mode it is possible to select either an internal clock created by the on-chip baud rate generator, or an external clock input at the SCK pin. Refer to table 13-7. If an external clock is input at the SCK pin, its frequency should be 16 times the desired bit rate. If the internal clock provided by the on-chip baud rate generator is selected and the SCK pin is used for clock output, the output clock frequency is equal to the bit rate, and the clock pulse rises at the center of the transmit data bits. Figure 13-3 shows the phase relationship between the output clock and transmit data. DataSheet4U.com t4U.com Figure 13-3 Phase Relationship Between Clock Output and Transmit Data 269 HITACHI www.DataSheet4U.com DataShe www.DataSheet4U.com **SCI Initialization:** Before data can be transmitted or received, the SCI must be initialized by software. To initialize the SCI, software must clear the TE and RE bits to 0, then execute the following procedure. 1. Set the desired communication format in the SMR. - 2. Write the value corresponding to the desired bit rate in the BRR. (This step is not necessary if an external clock is used.) - 3 Select the clock and enable desired interrupts in the SCR. - 4. Set the TE and/or RE bit in the SCR to 1. The TE and RE bits must both be cleared to 0 whenever the operating mode or data format is changed. After changing the operating mode or data format, before setting the TE and RE bits to 1 software must wait for at least 1 bit transfer time at the selected communication speed, to make sure the SCI is initialized. If an external clock is used, the clock must not be stopped. When clearing the TDRE bit during data transmission, to assure transfer of the correct data, do not clear the TDRE bit until after writing data in the TDR. Similarly, in receiving data, do not clear the RDRF bit until after reading data from the RDR. Data Transmission: The procedure for transmitting data in the asynchronous mode is as follows. DataSheet4U.com DataShe - 1. Set up the desired transmitting conditions in the SMR, SCR, and BRR. - 2. Set the TE bit in the SCR to 1. The TXD pin will automatically be switched to output and one frame\* of all 1s will be transmitted, after which the SCI is ready to transmit data. Note: \* A frame is the data for one character, including the start bit and stop bit(s). - 3. Check that the TDRE bit is set to 1, then write the first byte of transmit data in the TDR. Next clear the TDRE bit to 0. - 4. The first byte of transmit data is transferred from the TDR to the TSR and sent in the designated format as follows. - a. Start bit (one 0 bit). - b. Transmit data (seven or eight bits, starting from bit 0) HITACHI 270 DataSheet4U.com www.DataSheet4U.com et4U.com - c. Parity bit (odd or even parity bit, or no parity bit) - d. Stop bit (one or two consecutive 1 bits) vww.DataShe T-49-19-16 5. Transfer of the transmit data from the TDR to the TSR makes the TDR empty, so the TDRE bit is set to 1. If the TIE bit is set to 1, a transmit-end interrupt (TXI) is requested. When the transmit function is enabled but the TDR is empty (TDRE = 1), the output at the TXD pin is held at 1 until the TDRE bit is cleared to 0. Data Reception: The procedure for receiving data in the asynchronous mode is as follows. - 1. Set up the desired receiving conditions in the SMR, SCR, and BRR. - 2. Set the RE bit in the SCR to 1. The RXD pin will automatically be switched to input and the SCI is ready to receive data. - 3. The SCI synchronizes with the incoming data by detecting the start bit, and places the received bits in the RSR. At the end of the data, the SCI checks that the stop bit is 1. If the stop bit length is 2 bits, the SCI checks that both bits are 1. - 4. When a complete frame has been received, the SCI transfers the received data to the RDR so that it can be read. If the character length is 7 bits, the most significant bit of the RDR is cleared to 0. At the same time, the SCI sets the RDRF bit in the SSR to 1. If the RIE bit is set to 1, a receive-end interrupt (RXI) is requested. DataSheet4U.com 5. The RDRF bit is cleared to 0 when the CPU reads the SSR, then writes a 0 in the RDRF bit, or when the RDR is read by the data transfer controller (DTC). The RDR is then ready to receive the next character from the RSR. When a frame is not received correctly, a receive error occurs. There are three types of receive errors, listed in table 13-9. If a receive error occurs, the RDRF bit in the SSR is not set to 1. The corresponding error flag is set to 1 instead. If the RIE bit in the SCR is set to 1, a receive-error interrupt (ERI) is requested. When a framing or parity error occurs, the RSR contents are transferred to the RDR. If an overrun error occurs, however, the RSR contents are not transferred to the RDR. 271 **HITACHI** www.DataSheet4U.com DataShe t4U.com www.DataSheet4U.com If multiple receive errors occur simultaneously, all the corresponding error flags are set to 1. See section 13.5, "Application Notes". 7-49-19-16 To clear a receive-error flag (ORER, FER, or PER), software must read the SSR, then write a 0 in the flag bit. Table 13-9 Receive Errors | Name | <b>Abbreviation</b> | Description | |---------------|---------------------|--------------------------------------------------------------------------------| | Overrun error | ORER | Reception of the next frame ends while the RDRF bit is still set to 1. | | | | The RSR contents are not transferred to the RDR. | | Framing error | FER | A stop bit is 0. | | | | The RSR contents are transferred to the RDR. | | Parity error | PER | The parity of a frame does not match the value selected by the bit in the SMR. | | - | | The RSR contents are transferred to the RDR. | ### 13.3.3 Synchronous Mode The synchronous mode is suited for high-speed, continuous data transfer. Each bit of data is synchronized with a serial clock pulse. Continuous data transfer is enabled by the double buffering employed in both the transmit and receive sections of the SCI. Full duplex communication (with the same clock) is possible because the transmit and receive sections are independent. DataSheet4U.com data DataShe Data Format: Figure 13-4 shows the communication format used in the synchronous mode. The data length is 8 bits for both the transmit and receive directions. The least significant bit (LSB) is sent and received first. Each bit of transmit data is output from the falling edge of the serial clock pulse to the next falling edge. Received bits are latched on the rising edge of the serial clock pulse. HITACHI 272 www.DataSheet4U.com et4U.com Figure 13-4 Data Format in Synchronous Mode Clock: Either the internal serial clock created by the on-chip baud rate generator or an external clock input at the SCK pin can be selected in the synchronous mode. See table 13-7 for details. **SCI Initialization:** Before data can be transmitted or received, the SCI must be initialized by software. To initialize the SCI, software must clear the TE and RE bits to 0 to disable both the transmit and receive functions, then execute the following procedure. - 1. Write the value corresponding to the desired bit rate in the BRR. (This step is not necessary if an external clock is used.) - 2. Select the clock and enable desired interrupts in the SCR. - 3. Select the synchronous mode in the SMR. 4. Set the TE and/or RE bit in the SCR to 1. Note: The input/output status of the SCK pin depends on the C/A bit in the SMR and the CKE0 and CKE1 bits in the SCR. (See table 13-7.) To prevent incorrect output from the SCK pin, set the SCR before the SMR. The TE and RE bits must both be cleared to 0 whenever the operating mode or data format is changed. After changing the operating mode or data format, before setting the TE and RE bits to 1 software must wait for at least 1 bit transfer time at the selected communication speed, to make sure the SCI is initialized. 273 HITACHI www.DataSheet4U.com DataShe t4U.com www.DataSheet4U.com When clearing the TDRE bit during data transmission, to assure correct data transfer, do not clear the TDRE bit until after writing data in the TDR. Similarly, in receiving data, do not clear the RDRF bit until after reading data from the RDR. T-49-19-16 1-43-19-16 Data Transmission: The procedure for transmitting data in the synchronous mode is as follows. - 1. Set up the desired transmitting conditions in the SMR, BRR, and SCR. - 2. Set the TE bit in the SCR to 1. The TXD pin will automatically be switched to output, after which the SCI is ready to transmit data. - 3. Check that the TDRE bit in the SSR is set to 1, then write the first byte of transmit data in the TDR. Next clear the TDRE bit to 0. - 4. The first byte of transmit data is transferred from the TDR to the TSR and sent, each bit synchronized with a clock pulse. Bit 0 is sent first. Transfer of the transmit data from the TDR to the TSR makes the TDR empty, so the TDRE bit is set to 1. If the TIE bit is set to 1, a transmit-end interrupt (TXI) is requested. The TDR and TSR function as a double buffer. Continuous data transmission can be achieved by writing the next transmit data in the TDR and clearing the TDRE bit to 0 while the SCI is transmitting the current data from the TSR. et4U.com DataSheet4U.com DataShe If an internal clock source is selected, after transferring the transmit data from the TDR to the TSR, while transmitting the data from the TSR the SCI also outputs a serial clock signal at the SCK pin. When all data bits in the TSR have been transmitted, if the TDR is empty (TDRE = 1), serial clock output is suspended until the next data byte is written in the TDR and the TDRE bit is cleared to 0. During this interval the TXD pin is held at the value of the last bit transmitted. If the external clock source is selected, data transmission is synchronized with the clock signal input at the SCK pin. When all data bits in the TSR have been transmitted, if the TDR is empty (TDRE = 1) but external clock pulses continue to arrive, the TXD pin outputs a string of bits equal to the last bit transmitted. Data Reception: The procedure for receiving data in the synchronous mode is as follows. 1. Set up the desired receiving conditions in the SMR, BRR, and SCR. **HITACHI** 274 www.DataSheet4U.com DataSheet4U.com www.DataSheat41 from RE bit in the SCR to 1. The RXD pin will automatically be switched to input and the SCI is ready to receive data. - 3. Incoming data bits are latched in the RSR on eight clock pulses. T-49-19-16 When 8 bits of data have been received, the SCI sets the RDRF bit in the SSR to 1. If the RIE bit is set to 1, a receive-end interrupt (RXI) is requested. - 4. The SCI transfers the received data byte to the RDR so that it can be read. The RDRF bit is cleared when the program reads the RDRF bit in the SSR, then writes a 0 in the RDRF bit, or when the data transfer controller (DTC) reads the RDR. The RDR and RSR function as a double buffer. Data can be received continuously by reading each byte of data from the RDR and clearing the RDRF bit to 0 before the last bit of the next byte is received. In general, an external clock source should be used for receiving data. If an internal clock source is selected, the SCI starts receiving data as soon as the RE bit is set to 1. The serial clock is also output at the SCK pin. The SCI continues receiving until the RE bit is cleared to 0. If the last bit of the next data byte is received while the RDRF bit is still set to 1, an overrun error occurs and the ORER bit is set to 1. If the RIE bit is set to 1, a receive-error interrupt (ERI) is requested. The data received in the RSR are not transferred to the RDR when an overrun error occurs. After an overrun error, reception of the next data is enabled when the ORER bit is cleared to 0. **Simultaneous Transmit and Receive:** The procedure for transmitting and receiving simultaneously in the synchronous mode is as follows: - 1. Set up the desired communication conditions in the SMR, BRR, and SCR. - 2. Set the TE and RE bits in the SCR to 1. The TXD and RXD pins are automatically switched to output and input, respectively, and the SCI is ready to transmit and receive data. - 3. Data transmitting and receiving start when the TDRE bit in the SSR is cleared to 0. 275 HITACHI DataSheet4U.com t4U.com www.DataSheet4U.com DataShe - 5. First, the transmit data are transferred from the TDR to the TSR. This makes the TDR empty, so the TDRE bit is set to 1. If the TIE bit is set to 1, a transmit-end interrupt (TXI) is requested. If continuous data transmission is desired, the CPU must read the TDRE bit in the SSR, write the next transmit data in the TDR, then clear the TDRE bit to 0. Alternatively, the DTC can write the next transmit data in the TDR, in which case the TDRE bit is cleared automatically. If the TDRE bit is not cleared to 0 by the time the SCI finishes sending the current byte from the TSR, the TXD pin continues to output the last bit in the TSR. - 6. In the receiving section, when 8 bits of data have been received they are transferred from the RSR to the RDR, and the RDRF bit in the SSR is set to 1. If the RIE bit is set to 1, a receive-end interrupt (RXI) is requested. - 7. To clear the RDRF bit software must read the RDRF bit in the SSR, then write a 0 in the RDRF bit. Alternatively, the DTC can read the RDR, in which case the RDRF bit is cleared automatically. For continuous data reception, the RDRF bit must be cleared to 0 before the last bit of the next byte of data is received. If the last bit of the next data byte is received while the RDRF bit is still set to 1, an overrun error occurs and the ORER bit is set to 1. If the RIE bit is set to 1, a receive-error interrupt (ERI) is requested. The data received in the RSR are not transferred to the RDR when an overrun error occurs. After an overrun error, reception of the next data is enabled when the ORER bit is cleared to 0. DataShe An overrun error does not affect the transmit section of the SCI, which continues to transmit normally. ### 13.4 CPU Interrupts and DTC Interrupts The SCI can request three types of interrupts: transmit-end (TXI), receive-end (RXI), and receive-error (ERI). Interrupt requests are enabled or disabled by the TIE and RIE bits in the SCR. Independent signals are sent to the interrupt controller for each type of interrupt. The transmit-end and receive-end interrupt request signals are obtained from the TDRE and RDRF flags. The receive-error interrupt request signal is the logical OR of the three error flags: overrun error (ORER), framing error (FER), and parity error (PER). Table 13-10 lists information about these interrupts. **HITACHI** 276 www.DataSheet4U.com et4U.com | 14010 10 1 | | | T-49-19-16 | |------------|-----------------------------------------|-------------|------------| | | | DTC Service | | | Interrupt | Description | Available? | Priority | | ERI | Receive-error interrupt, requested when | No | High | | | ORER, FER, or PER is set. | | | | RXI | Receive-end interrupt, requested when | Yes | | | | RDRF is set. | | | | TXI | Transmit-end interrupt, requested when | Yes | | | | TDRE is set. | | | | | | | Low | The TXI and RXI interrupts can be served by the data transfer controller (DTC) to have a data transfer performed. When the DTC serves one of these interrupts, it clears the TDRE or RDRF bit to 0 under the following conditions, which differ between the two bits. When invoked by a TXI request, if the DTC writes to the TDR, it automatically clears the TDRE bit to 0. When invoked by an RXI request, if the DTC reads from the RDR, it automatically clears the RDRF bit to 0. See section 6, "Data Transfer Controller", for further information on the DTC. ### 13.5 Application Notes t4U.com DataSheet4U.com Application programmers should note the following features of the SCI. DataShe TDR Write: The TDRE bit in the SSR is simply a flag that indicates that the TDR contents have been transferred to the TSR. The TDR contents can be rewritten regardless of the TDRE value. If a new byte is written in the TDR while the TDRE bit is 0, before the old TDR contents have been moved into the TSR, the old byte will be lost. Normally, software should check that the TDRE bit is set to 1 before writing to the TDR. Multiple Receive Errors: Table 13-11 lists the values of flag bits in the SSR when multiple receive errors occur, and indicates whether the RSR contents are transferred to the RDR. 277 HITACHI Table 13-11 SSR Bit States and Data Transfer When Multiple Receive Errors Occur T-49-19-16 | Receive Error | RDRF | ORER | FER | PER | RSR to RDR*2 | |-----------------------------------|------|------|-----|-----|--------------| | Overrun error | 1*1 | 1 | 0 | 0 | No | | Framing error | 0 | 0 | 1 | 0 | Yes | | Parity error | 0 | 0 | 0 | 1 | Yes | | Overrun + framing errors | 1*1 | 1 | 1 | 0 | No | | Overrun + parity errors | 1*1 | 1 | 0 | 1 | No | | Framing + parity errors | 0 | 0 | 1 | 1 | Yes | | Overrun + framing + parity errors | 1*1 | 1 | 1 | 1 | No | Notes: 1. Set to 1 before the overrun error occurs. www.DataS et4U.com 2. Yes: The RSR contents are transferred to the RDR. No: The RSR contents are not transferred to the RDR. Line Break Detection: When the RXD pin receives a continuous stream of 0s in the asynchronous mode (line-break state), a framing error occurs because the SCI detects a 0 stop bit. The value H'00 is transferred from the RSR to the RDR. Software can detect the line-break state as a framing error accompanied by H'00 data in the RDR. The SCI continues to receive data, so if the FER bit is cleared to 0 another framing error will occur. Sampling Timing and Receive Margin in Asynchronous Mode: The serial clock used by the SCI in asynchronous mode runs at 16 times the bit rate. The falling edge of the start bit is detected by sampling the RXD input on the falling edge of this clock. After the start bit is detected, each bit of receive DataShe data in the frame (including the start bit, parity bit, and stop bit or bits) is sampled on the rising edge of the serial clock pulse at the center of the bit. See figure 13-5. It follows that the receive margin can be calculated as in equation (1). When the absolute frequency deviation of the clock signal is 0 and the clock duty factor is 0.5, data can theoretically be received with distortion up to the margin given by equation (2). This is a theoretical limit, however. In practice, system designers should allow a margin of 20% to 30%. HITACHI 278 www.DataSheet4U.com DataSheet4U.com Figure 13-5 Sampling Timing (Asynchronous Mode) $$M = \{(0.5 - 1/2N) - (D - 0.5)/N - (L - 0.5)F\} \times 100 [\%] (1)$$ M: Receive margin N: Ratio of serial clock to bit rate (N = 16) D: Duty cycle of high or low clock pulses, whichever is longer (0.5 to 1.0) L: Frame length (9 to 12) F: Absolute value of clock frequency deviation When D = 0.5 and F = 0: t4U.com $$M = (0.5 - 1/2 \times 16) \times 100 \ [\%] = 46.875\%$$ (2) 279 HITACHI www.DataSheet4U.com DataShe www.DataSheet4U.com T-49-19-16 et4U.com DataSheet4U.com HITACHI 286 DataSheet4U.com www.DataSheet4U.com ## Section 14 A/D Converter T-49-19-16 ### 14.1 Overview The H8/520 chip includes an analog-to-digital converter module which can be programmed for input of analog signals on up to four (or eight\*) channels. A/D conversion is performed by the successive approximations method with 10-bit resolution. ### 14.1.1 Features The features of the on-chip A/D module are as follows: - Four (or eight\*) analog input channels - External trigger A/D conversion can be started by an external trigger input. - · Sample and hold circuit - 10-Bit resolution - Rapid conversion Conversion time is 13.8 μs per channel (at Ø = 10 MHz) - Single and scan modes - -Single mode: A/D conversion is performed once. - -Scan mode: A/D conversion is performed in a repeated cycle on one to four channels. - Four 16-bit data registers These registers store A/D conversion results for up to four channels. A CPU interrupt (ADI) can be requested at the completion of each A/D conversion cycle. This interrupt can also be served by the on-chip data transfer controller (DTC), providing a convenient way to move results into memory. Note: \* CP-68 package only DataShe 281 **HITACHI** www.DataSheet4U.com t4U.com ### 14.1.2 Block Diagram Figure 14-1 shows a block diagram of A/D converter. T-49-19-16 Figure 14-1 Block Diagram of A/D Converter **HITACHI** 282 DataSheet4U.com Table 14-1 lists the input pins used by the A/D converter module. T-49-19-16 The eight analog input pins provided in the CP-68 package are divided into two groups, consisting of analog inputs 0 to 3 (ANe to AN3) and analog inputs 4 to 7 (AN4 to AN7), respectively. Table 14-1 A/D Input Pins | Name | <b>Abbreviation</b> | I/O | Function | |----------------------------|---------------------|-------|-------------------------------------------------------------| | Analog supply voltage | AVcc | Input | Power supply and reference voltage for the analog circuits. | | Analog ground | AVss | Input | Ground and reference voltage for the analog circuits. | | Analog input 0 | ANo | Input | Analog input pins, group 0 | | Analog input 1 | AN <sub>1</sub> | Input | • | | Analog input 2 | AN <sub>2</sub> | Input | • | | Analog input 3 | ANз | Input | | | Analog input 4 | AN4 | Input | · | | Analog input 5 | AN <sub>5</sub> | Input | Analog input pins, group 1*1 | | Analog input 6 | AN <sub>6</sub> | Input | • | | Analog input 7 | AN <sub>7</sub> | Input | | | A/D external trigger input | ADTRG | Input | External trigger for starting A/D conversion*2 | Notes: 1. CP-68 package only. 2. Not available in MCU mode 3 because this pin is used for the page address bus (A18). t4U.com DataSheet4U.com DataShe 283 HITACHI DataSheet4U.com ## 14.1.4 Register Configuration T-49-19-16 Table 14-2 lists the registers of the A/D converter module. Table 14-2 A/D Registers | Name | <b>Abbreviation</b> | R/W | Initial Value | Address | | |-----------------------------|---------------------|--------|---------------|---------|--| | A/D data register A (High) | ADDRA (H) | R | H'00 | H'FFE0 | | | A/D data register A (Low) | ADDRA (L) | R | H'00 | H'FFE1 | | | A/D data register B (High) | ADDRB (H) | R | H'00 | H'FFE2 | | | A/D data register B (Low) | ADDRB (L) | R | H'00 | H'FFE3 | | | A/D data register C (High) | ADDRC (H) | R | H'00 | H'FFE4 | | | A/D data register C (Low) | ADDRC (L) | R | H'00 | H'FFE5 | | | A/D data register D (High) | ADDRD (H) | R | H'00 | H'FFE6 | | | A/D data register D (Low) | ADDRD (L) | R | H'00 | H'FFE7 | | | A/D control/status register | ADCSR | R/(W)* | H'00 | H'FFE8 | | | A/D control register | ADCR | R/W | H'7F | H'FFE9 | | | | | | | | | Note: \* Software can write a 0 to clear the status flag in bit 7 but cannot write a 1. ## 14.2 Register Descriptions ## 14.2.1 A/D Data Registers (ADDR)—H'FFE0 to H'FFE7 | :4U | .CO | m | | |-----|-----|---|--| | | | | | | Bit | 7 | 6 | DataSh | eet4 <b>d</b> .com | 3 ' | 2 | 1 | 0 | |---------------|-----------------|-----------------|--------|--------------------|-----------------|-----|-------------|-----| | ADDRn H | AD9 | AD8 | AD7 | AD <sub>6</sub> | AD <sub>5</sub> | AD4 | AD3 | AD2 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R | R | R | R | R | R | R | R | | | | | | | | 1) | n = A to D) | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ADDRn L | AD <sub>1</sub> | AD <sub>0</sub> | | | | _ | - | | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R | R | R | R | R | R | R | R | | | | | | | | (1 | n = A to D) | ı | The four A/D data registers (ADDRA to ADDRD) are 16-bit read-only registers that store the results of A/D conversion. HITACHI 284 DataSheet4U.com www.DataSheet4U.com Each result consist of 10 bits. The first 8 bits are stored in the upper byte of the data register corresponding to the selected channel. The last two bits are stored in the lower data register byte. The data registers are assigned to analog input channels as indicated in table 14-3. T-49-19-16 The A/D data registers are always readable by the CPU. The upper byte can be read directly. The lower byte is read via a temporary register. See section 14-3, "CPU Interface", for details. The unused bits (bits 5 to 0) of the lower data register byte are always read as 0. The A/D data registers are initialized to H'0000 at a reset and in the standby modes. Table 14-3 Assignment of Data Registers to Analog Input Channels ### **Analog Input Channel** | Group 0 | Group 1 * | A/D Data Register | | | |---------|-----------|-------------------|--|--| | AN0 | AN4 | ADDRA | | | | AN1 | AN5 | ADDRB | | | | AN2 | AN6 | ADDRC | | | | AN3 | AN7 | ADDRD | | | Note: \* CP-68 package only. ### 14.2.2 A/D Control/Status Register (ADCSR)—H'FFE8 7 2 1 0 6 3 Bit 5<sub>DataSheet411</sub> CH<sub>2</sub> CH<sub>1</sub> CH<sub>0</sub> **ADF ADIE** ADST **SCAN CKS** 0 0 0 0 0 0 0 0 Initial value R/W R/W R/W R/W R/(W)\* R/W R/W R/W Read/Write Note: \* Software can write a 0 in bit 7 to clear the flag, but cannot write a 1 in this bit. The A/D control/status register (ADCSR) is an 8-bit readable/writable register that controls the operation of the A/D converter module. The ADCSR is initialized to H'00 at a reset and in the standby modes. 285 HITACHI www.DataSheet4U.com DataShe t4U.com D 4496204 0028074 562 **H**HIT3 www.DataSheet4U.com Bit 7—A/D End Flag (ADF): This status flag indicates the end of one cycle of A/D conversion. | Bit 7 | | | T-49-19-16 | |-------|------|---------------------------------------------------|----------------------------------------| | ADF | Des | scription | | | 0 | This | s bit is cleared from 1 to 0 when: | (Initial value) | | | 1. | The chip is reset or placed in a standby mode. | | | | 2. | The CPU reads the ADF bit after the ADF bit is | set to 1, then writes a 0 in this bit. | | | 3. | An A/D interrupt is served by the data transfer c | controller (DTC). | | 1 | This | s bit is set to 1 at the following times: | | | | 1. | Single mode: when one A/D conversion is com | pleted. | | | 2. | Scan mode: when inputs on all selected channel | els have been converted. | Bit 6—A/D Interrupt Enable (ADI): This bit selects whether to request an A/D interrupt (ADI) when A/D conversion is completed. #### Bit 6 | ADIE | Description | | | |------|----------------------------------------------|-----------------|--| | 0 | The A/D interrupt request (ADI) is disabled. | (Initial value) | | | 1 | The A/D interrupt request (ADI) is enabled. | | | Bit 5—A/D Start (ADST): The A/D converter operates while this bit is set to 1. In the single mode, this bit is automatically cleared to 0 at the end of each A/D conversion. et4U.com | _ | J | | | |---|---|--|--| | | | | | | | | | | DataSheet4U.com DataShe | ADST | Description | | | | | | |------|-------------|------------------------------------------------------------------------------------------|--|--|--|--| | 0 | A/D | conversion is halted. (Initial value) | | | | | | 1 | .1. | Single mode: One A/D conversion is performed. The ADST bit is automatically cleared to 0 | | | | | | | | at the end of the conversion. | | | | | | | 2. | Scan mode: A/D conversion starts and continues cyclically on the selected channels until | | | | | | | | the ADST bit is cleared to 0. | | | | | Bit 4—Scan Mode (SCAN): This bit selects the scan mode or single mode of operation. See section 14.4, "Operation", for descriptions of these modes. The mode should be changed only when the ADST bit is cleared to 0. ### Bit 4 | SCAN | Description | | |------|-------------|-----------------| | 0 | Single mode | (Initial value) | | 1 | Scan mode | | HITACHI 286 DataSheet4U.com The conversion time should be changed only when the ADST bit is cleared to 0. Bit 3 | CKS | Description | | | | | | |-----|------------------------------|-----------|-----------------|--|--|--| | 0 | Conversion time = 274 states | (maximum) | (Initial value) | | | | | 1 | Conversion time = 138 states | (maximum) | | | | | Bits 2 to 0—Channel Select 2 to 0 (CH2 to CH0): These bits and the SCAN bit combine to select one or more analog input channels. The channel selection should be changed only when the ADST bit is cleared to 0. | <b>Group Select</b> | <b>Channel Select</b> | | Selected Channels | | | | |---------------------|-----------------------|-----|-------------------|-------------------|--|--| | CH2 | CH1 | CH0 | Single Mode | Scan Mode | | | | 0 | 0 | 0 | AN <sub>0</sub> | ANo | | | | | 0 | 1 | AN <sub>1</sub> | ANo and AN1 | | | | | 1 | 0 | AN <sub>2</sub> | ANo to AN2 | | | | | 1 | 1 | AN <sub>3</sub> | ANo to AN3 | | | | 1 | 0 | 0 | AN4* | AN <sub>4</sub> * | | | | | 0 | 1 | AN5* | AN4 and AN5* | | | | | 1 | 0 | AN <sub>6</sub> * | AN4 to AN6* | | | | | 1 | 1 | AN7*DataSheet41 | AN4 to AN7* | | | t4U.com Note: \* CP-68 package only ### 14.2.3 A/D Control Register (ADCR)—H'FFE9 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|---|---|---|---|---|---|---| | | TRGE | | _ | - | | _ | | | | Initial value | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Read/Write | R/W | _ | | _ | _ | | _ | | The A/D control register (ADCR) is an 8-bit readable/writable register that enables or disables the A/D external trigger signal. The ADCR is initialized to H'7F at a reset and in the standby modes. 287 HITACHI DataSheet4U.com www.DataSheet4U.com DataShe Bit 7—Trigger Enable (TRGE): This bit enables the ADTRG (A/D external trigger) signal. When enabled, a high-to-low transition of ADTRG sets the ADST bit, starting A/D conversion. | Bit 7 | T4 | T-49-19-16 | | | | | |-------|-------------------------------------------------------------------------|-----------------|--|--|--|--| | TRGE | Description | | | | | | | 0 | A/D external trigger is disabled. ADTRG does not set the ADST bit. | (Initial value) | | | | | | 1 | A/D external trigger is enabled. A high-to-low transition of ADTRG sets | the ADST bit. | | | | | Bits 6 to 0—Reserved: These bits cannot be modified and are always read as 1. ### 14.3 CPU Interface www.DataSheet4U.com et4U.com The A/D data registers (ADDRA to ADDRD) are 16-bit registers, but they are accessed via an 8-bit module data bus. Accordingly, the upper byte of each register can be read directly, but the lower byte is accessed through an 8-bit temporary register (TEMP). When the CPU or DTC reads the upper byte of an A/D data register, at the same time as the upper byte is placed on the internal data bus, the lower byte is transferred to TEMP. When the lower byte is accessed, the value in TEMP is placed on the internal data bus. A program that requires all 10 bits of an A/D result should perform word access, or should read first the upper byte, then the lower byte of the A/D data register. Either way, it is assured of obtaining consistent data. Consistent data are not assured if the program reads the lower byte first. DataShe A program that requires only 8-bit A/D accuracy should perform byte access to the upper byte of the A/D data register. The value in TEMP can be left unread. Figure 14-2 shows the data flow when the CPU (or DTC) reads an A/D data register. HITACHI 288 Figure 14-2 Read Access to A/D Data Register (When Register Contains H'AA40) ## 14.4 Operation The A/D converter performs 10 successive approximations to obtain a result ranging from H'0000 (corresponding to AVss) to H'FFC0 (corresponding to AVcc). Only the first 10 bits of the result are significant. 289 **HITACHI** www.DataSheet4U.com The response of the A/D converter is shown below. H'FFC0 corresponds to voltages of approximately 0.999AVcc and above. T-49-19-16 The A/D converter module can be programmed to operate in single mode or scan mode as explained below. ### 14.4.1 Single Mode The single mode is suitable for obtaining a single data value from a single channel. A/D conversion starts when the ADST bit is set to 1 by software or external trigger input. During the conversion process the ADST bit remains set to 1. When conversion is completed, the ADST bit is automatically cleared to 0. When the conversion is completed, the ADF bit is set to 1. If the interrupt enable bit (ADIE) is also set to 1, an A/D conversion end interrupt (ADI) is requested, so that the converted data can be processed by an interrupt-handling routine. Alternatively, the interrupt can be served by the data transfer controller (DTC). When an A/D interrupt is served by the DTC, the DTC automatically clears the ADF bit to 0. When an A/D interrupt is served by the CPU, however, the ADF bit remains set until the CPU reads the ADCSR, then writes a 0 in the ADF bit. Before selecting the single mode, clock, and analog input channel, software should clear the ADST bit to 0 to make sure the A/D converter is stopped. Changing the mode, clock, or channel selection while A/D conversion is in progress can lead to conversion errors. DataShe The following example explains the A/D conversion process in single mode when channel 1 (AN1) is selected and external triggering is not used. Figure 14-3 shows the corresponding timing chart. 1. Software clears the ADST bit to 0, then selects the single mode (SCAN = 0) and channel 1 (CH2 to CH0 = 001), enables the A/D interrupt request (ADIE = 1), and sets the ADST bit to 1 to start A/D conversion. Coding Example: (when using the slow clock, CKS = 0) BCLR #7, @H'FFE9 BCLR #5, @H'FFE8 MOV.B #H'61, @H'FFE8 HITACHI 290 www.DataSheet4U.com - 2. The A/D converter samples the AN1 input and converts the voltage level to a digital value. At the end of the conversion process the A/D converter transfers the result to register ADDRB, sets the ADF bit to 1, clears the ADST bit to 0, and halts. - 3. ADF = 1 and ADIE = 1, so an A/D interrupt is requested. T-49-19-16 - 4. The user-coded A/D interrupt-handling routine is started. - 5. The interrupt-handling routine reads the ADCSR value, then writes a 0 in the ADF bit to clear this bit to 0. The reading and writing can be done with a single BCLR #7, @H'FFE8 instruction. - 6. The interrupt-handling routine reads and processes the A/D conversion result. - 7. The routine ends. Steps 2 to 7 can now be repeated by setting the ADST bit to 1 again. If the ADI bit in data transfer enable register D (bit 0 at address H'FFF7) is set to 1, the interrupt is served by the data transfer controller (DTC). Steps 4 to 7 then change as follows. - 4'. The DTC is started. - 5'. The DTC automatically clears the ADF bit to 0. - 6'. The DTC transfers the A/D conversion result from ADDRB to a specified destination address. - 7'. The DTC ends. t4U.com DataSheet4U.com DataShe 291 HITACHI DataShe **HITACHI** 292 DataSheet4U.com et4U.com The scan mode can be used to monitor analog inputs on one or more channels. When the ADST bit is set to 1 by software or by external trigger input, A/D conversion starts from the first channel (ANo) in the scan group.\* If the scan group includes more than one channel (i.e., if bit CH1 or CH0 is set), conversion of the next channel begins as soon as conversion of the first channel ends. Conversion of the selected channels continues cyclically until the ADST bit is cleared to 0. The conversion results are placed in the data registers corresponding to the selected channels. Before selecting the scan mode, clock, and analog input channels, software should clear the ADST bit to 0 to make sure the A/D converter is stopped. Changing the mode, clock, or channel selection while A/D conversion is in progress can lead to conversion errors. The following example explains the A/D conversion process when three channels in group 0 are selected (AN0, AN1, and AN2) and external triggering is not used. Figure 14-4 shows the timing. 1. Software clears the ADST bit to 0, then selects the scan mode (SCAN = 1), scan group 0 (CH2 = 0), and analog input channels AN0 to AN2 (CH1 = 1, CH0 = 0) and sets the ADST bit to 1 to start A/D conversion. Coding Example: (with slow clock and ADI interrupt enabled) BCLR #7, @H'FFE9 BCLR #5, @H'FFE8 MOV.B #H'72, @FFE8 DataSheet4U.com DataShe - 2. The A/D converter samples the input at ANo, converts the voltage level to a digital value, and transfers the result to register ADDRA. - 3. Next the A/D converter samples and converts AN1 and transfers the result to ADDRB. Then it samples and converts AN2 and transfers the result to ADDRC. - After all selected channels (AN0 to AN2) have been converted, the AD converter sets the ADF bit to If the ADIE bit is set to 1, an A/D interrupt (ADI) is requested. Then the A/D converter begins converting AN0 again. - 5. Steps 2 to 4 are repeated cyclically as long as the ADST bit remains set to 1. To stop the A/D converter, software must clear the ADST bit to 0. The data currently undergoing conversion when the ADST bit is cleared are ignored. The A/D data registers retain the last completed conversion results. Regardless of which channel is being converted when the ADST bit is cleared to 0, when the ADST bit is set to 1 again, conversion begins from the the first selected channel (AN0 or AN4). Note: \* In the CP-68 package, the first channel is AN0 if CH2 = 0, and AN4 if CH2 = 1. 293 HITACHI DataSheet4U.com t4U.com www.DataSheet4U.com • HITACHI 294 DataSheet4U.com www.DataSheet4U.com DataSheet4U.com DataShe | ww.DataSheat3Ufinpu | t Sampling | Time and A/I | ) Conversion | Time | |---------------------|------------|--------------|--------------|------| |---------------------|------------|--------------|--------------|------| T-49-19-16 The A/D converter includes a built-in sample-and-hold circuit. Sampling of the input starts at a time tD after the ADST bit is set to 1. The sampling process lasts for a time tspl. The actual A/D conversion begins after sampling is completed. Figure 14-5 shows the timing of these steps, and table 15-4 lists the total conversion times (tconv) for the single mode. The total conversion time includes to and tspl. The purpose of tD is to synchronize the ADCSR write time with the A/D conversion process, so the length of tD is variable. The total conversion time therefore varies within the minimum to maximum ranges indicated in table 14-4. In the scan mode, the ranges given in table 14-4 apply to the first conversion. The length of the second and subsequent conversion processes is fixed at 256 states (when CKS = 0) or 128 states (when CKS = 1). t4U.com DataSheet4U.com DataShe 295 HITACHI Figure 14-5 A/D Conversion Timing DataSheet4U.com Table 14-4 A/D Conversion Time (Single Mode) | Item | | | CKS = | 0 | CKS = 1 | | | | |---------------------------|--------|-----|-------------|-----|---------|-----|-------|--| | | Symbol | min | typ | max | min | typ | max | | | Synchronization delay | to | 18 | | 33 | 10 | | 17 | | | Input sampling time | tspl. | | 63 | _ | | 31 | ***** | | | Total A/D conversion time | tconv | 259 | <del></del> | 274 | 131 | _ | 138 | | Note: Values in the table are numbers of states. HITACHI 296 www.DataSheet4U.com DataShe The A/D conversion process can be started by an external trigger input. External trigger input is enabled at the ADTRG pin when the TRGE bit in the ADCR is set to 1. 1.0 ø clock cycles after the ADTRG input is sampled, the ADST bit in the ADCSR is set to 1 and A/D conversion commences. The timing of external triggering is shown in figure 14-6. Figure 14-6 Timing of Setting of ADST Bit ## 14.5 Interrupts and the Data Transfer Controller The ADI interrupt request is enabled or disabled by the ADIE bit in the ADCSR. When the ADI bit in data transfer enable register DTED (bit 0 at address H'FFF7) is set to 1, the ADI interrupt is served by the data transfer controller. The DTC can be used to transfer A/D results to a buffer in memory, or to an I/O port. The DTC automatically clears the ADF bit to 0. Note: In scan mode, the DTC can transfer data for only one channel per interrupt, even if two or more channels are selected. 297 HITACHI www.DataSheet4U.com DataShe www.DataSheet4U.com T-49-19-16 DataShe et4U.com DataSheet4U.com HITACHI 298 DataSheet4U.com www.DataSheet4U.com #### 15.1 Overview The H8/520 includes 512 bytes of on-chip static RAM, connected to the CPU by a 16-bit data bus. Both byte and word access to the on-chip RAM are performed in two states, enabling rapid data transfer and instruction execution. The on-chip RAM is assigned to addresses H'FD80 to H'FF7F in the chip's address space. A RAM control register (RAMCR) can enable or disable the on-chip RAM, permitting these addresses to be allocated to external memory instead, if so desired. #### 15.1.1 Block Diagram Figure 15-1 shows a block diagram of the on-chip RAM. Figure 15-1 Block Diagram of On-Chip RAM 299 HITACHI DataSheet4U.com t4U.com ### 15.1.2 Register Configuration T-49-19-16 The on-chip RAM is controlled by the register described in table 15-1. Table 15-1 RAM Control Register | Name | Abbreviation | R/W | Initial Value | Address | |----------------------|--------------|-----|---------------|---------| | RAM control register | RAMCR | R/W | H'FF | H'FFF9 | ## 15.2 RAM Control Register (RAMCR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|---|---|---|---|---|---|---| | | RAME | | | | _ | _ | | | | Initial value | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Read/Write | R/W | - | - | | _ | _ | | | The RAM control register (RAMCR) is an 8-bit register that enables or disables the on-chip RAM. Bit 7-RAM Enable (RAME): This bit enables or disables the on-chip RAM. The RAME bit is initialized by a reset. It is not initialized in the software standby mode. Bit 7 et4U.com | RAME | Description | Data Sheet 41 Loom | |------|--------------------------|--------------------| | 0 | On-chip RAM is disabled. | | | 1 | On-chip RAM is enabled. | (Initial value) | Bits 6 to 0—Reserved: These bits cannot be modified and are always read as 1. ## 15.3 Operation ### 15.3.1 Expanded Modes (Modes 1, 2, 3, and 4) If the RAME bit is set to 1, accesses to addresses H'FD80 to H'FF7F are directed to the on-chip RAM. If the RAME bit is cleared to 0, accesses to addresses H'FD80 to H'FF7F are directed to the external data bus. HITACHI 300 www.DataSheet4U.com DataShe www.DataSheet4U.com 15.3.2 Single-Chip Mode (Mode 7) T-49-19-16 If the RAME bit is set to 1, accesses to addresses H'FD80 to H'FF7F are directed to the on-chip RAM. If the RAME bit is cleared to 0, access of any type (instruction fetch or data read or write) to addresses H'FD80 to H'FF7F causes an address error and initiates the CPU's exception-handling sequence. t4U.com DataSheet4U.com 301 HITACHI DataShe DataSheet4U.com www.DataSheet4U.com DataSheet4U.com T-49-19-16 DataShe et4U.com DataSheet4U.com HITACHI 302 DataSheet4U.com www.DataSheet4U.com # Section 16 ROM T-49-19-16 #### 16.1 Overview The H8/520 includes 16 kbytes of high-speed on-chip ROM. The on-chip ROM is connected to the CPU via a 16-bit data bus and is accessed in two states. Users wishing to program the chip themselves can request electrically programmable ROM (PROM). The PROM version of the H8/520 has a PROM mode in which the chip can be programmed with a standard, external PROM writer. The chip is also available with masked ROM. The on-chip ROM is enabled or disabled depending on the MCU operating mode, which is determined by the inputs at the mode pins when the chip comes out of the reset state. See table 16-1. Table 16-1 ROM Usage in Each MCU Mode | Mode Pins | | | • | |-----------------|-----------------|---------------------------------|-------------------------------------------------| | MD <sub>2</sub> | MD <sub>1</sub> | MDo | ROM | | 0 | 0 | 1 | Disabled (external addresses) | | 0 | 1 | 0 | Enabled | | 0 | 1 | 1 | Disabled (external addresses) | | 1 | 0 | 0 | Enabled | | 1 | 1 | 1 | Enabled | | | | MD <sub>2</sub> MD <sub>1</sub> | MD <sub>2</sub> MD <sub>1</sub> MD <sub>0</sub> | t4U.com DataSheet4U.com ### DataShe ## 16.1.1 Block Diagram Figure 16-1 shows the block diagram of the on-chip ROM. 303 HITACHI DataSheet4U.com Figure 16-1 Block Diagram of On-Chip ROM #### 16.2 PROM Mode et4U.com ### 16.2.1 PROM Mode Setup The PROM version of the H8/520 has a PROM mode in which the usual microcomputer functions are halted to allow the on-chip PROM to be programmed. The programming method is the same as for the HN27C256. DataShe To select the PROM mode, apply the signal inputs listed in table 16-2 to the mode pins (MD2 to MD0) and pins P51 and P50. Table 16-2 Selection of PROM Mode | Pin | Input | |-------------------------------------|-------| | MD <sub>1</sub> | Low | | MD <sub>2</sub> and MD <sub>0</sub> | High | | P51 and P50 | High | HITACHI 304 www.DataSheet4U.com DataSheet4U.com T-49-19-16 The H8/520 can be programmed with a general-purpose PROM writer by attaching a socket adapter as listed in table 16-3. The socket adapter depends on the type of package. Figure 16-2 shows the socket adapter pin arrangements by giving the correspondence between H8/520 pins and HN27C256 pin functions. Figure 16-3 is a memory map. Table 16-3 Socket Adapter | Socket Adapter | | | |----------------|--|--| | HS528ESS01H | | | | | | | | HS528ESH01H | | | | HS528ESC01H | | | | | | | t4U.com DataSheet4U.com DataShe 305 HITACHI DataSheet4U.com Figure 16-2 Socket Adapter Pin Arrangements HITACHI 306 DataSheet4U.com www.DataSheet4U.com ww.DataSheet4U.com Figure 16-3 Memory Map in PROM Mode ## 16.3 Programming The write, verify, and inhibited sub-modes of the PROM mode are selected as shown in table 16-4. Table 16-4 Selection of Sub-Modes in PROM Mode | | Pins | | | | | | | | |-----------------------|------|------|---------|--------------------|----------------|---------------|--|--| | Mode | CE | OE | VPP | Vcc | 07 to 00 | A14 to A0 | | | | Write | Low | High | VPP | Vcc | Data input | Address input | | | | Verify | High | Low | VPP | Vcc | Data output | Address input | | | | Programming inhibited | High | High | DolaShe | eet <b>Vcc</b> com | High-impedance | Address input | | | | Read | Low | Low | Vpp | Vcc | Data output | Address input | | | Note: The VPP and Vcc pins must be held at the VPP and Vcc voltage levels. The H8/520 PROM uses the same, standard read/write specifications as the HN27C256 and HN27256. ### 16.3.1 Writing and Verifying An efficient, high-speed programming procedure can be used to write and verify PROM data. This procedure writes data quickly without subjecting the chip to voltage stress and without sacrificing data reliability. It leaves the data H'FF written in unused addresses. 307 HITACHI DataSheet4U.com t4U.com www.DataSheet4U.com DataShe Figure 16-4 shows the basic high-speed programming flowchart. DataShe Tables 16-5 and 16-6 list the electrical characteristics of the chip in the PROM mode. Figure 16-5 shows a write/verify timing chart. Figure 16-4 High-Speed Programming Flowchart HITACHI 308 DataSheet4U.com www.DataSheet4U.com DataSheet4U.com Table 16-5 DC Characteristics (When VCC = 6.0 V $\pm$ 0.25 V, VPP = 12.5 V $\pm$ 0.3 V, Vss = 0 V, Ta = 25°C $\pm$ 5°C) | item | | Symbol | min | typ_ | max | Unit | Measurement<br>Conditions | |-----------------------|-----------------------------|-------------|---------|------|-----------|------|---------------------------| | Input high | O7 to O0, A14 to A0, OE, CE | VH | 2.2 | | Vcc + 0.3 | V | T-49-19-16 | | Input low voltage | O7 to O0, A14 to A0, OE, CE | VIL | -0.3 | _ | 0.8 | ٧ | | | Output high voltage | O7 to O0 | Vон | 2.4 | | | V | Юн = −200 μА | | Output low voltage | O7 to O0 | Vol. | <u></u> | | 0.45 | V | lol. = 1.6 mA | | Input leakage current | O7 to O0, A14 to A0, OE, CE | lu | | | 2 | μА | Vin = 5.25 V/0.5 V | | Vcc current | | lcc | | | 50 | mA | | | VPP current | | <b>I</b> PP | | | 40 | mA | | Table 16-6 AC Characteristics (When VCC = 6.0 V $\pm$ 0.25 V, VPP = 12.5 V $\pm$ 0.3 V, Vss = 0 V, Ta = 25 °C $\pm$ 5 °C) | | | | | | | Measurement | |--------------------------|-------------|-------------|----------|--------|------|------------------| | ltem. | Symbol | min | typ | max | Unit | Conditions | | Address setup time | tas | <b>2</b> Da | ataSheet | 4LLcom | μs | See figure 16-5* | | OE setup time | toes | 2 | _ | | μs | _ | | Data setup time | tos | 2 | _ | | μs | _ | | Address hold time | tan | 0 | _ | | μs | _ | | Data hold time | <b>t</b> DH | 2 | | | μs | _ | | Data output disable time | tor | | | 130 | ns | _ | | VPP setup time | tvps | 2 | - | - | μs | _ | | Program pulse width | tpw | 0.95 | 1.0 | 1.05 | ms | <u>-</u> | | OE pulse width for | topw | 2.85 | _ | 78.75 | ms | | | overwrite-programming | | | | | | _ | | Vcc setup time | tvcs | 2 | | | μs | | | Data output delay time | toE | 0 | _ | 500 | ns | | Note: \* Input pulse level: 0.8 V to 2.2 V Input rise/fall time ≤ 20 ns Timing reference levels: input—1.0 V, 2.0 V; output—0.8 V, 2.0 V 309 HITACHI DataSheet4U.com t4U.com www.DataSheet4U.com DataShe Figure 16-5 PROM Write/Verify Timing et4U.com 16.3.2 Notes on Writing DataSheet4U.com DataShe 1. Write with the specified voltages and timing. The programming voltage (VPP) in the PROM mode is 12.5 V. Caution: Applied voltages in excess of the specified values can permanently destroy the chip. Be particularly careful about the PROM writer's overshoot characteristics. If the PROM writer is set to Intel specifications or Hitachi HN27256 or HN27C256 specifications, VPP will be 12.5 V. 2. Before writing data, check that the socket adapter and chip are correctly mounted in the PROM writer. Overcurrent damage to the chip can result if the index marks on the PROM writer, socket adapter, and chip are not correctly aligned. HITACHI 310 3. Don't touch the socket adapter or chip while writing. Touching either of these can cause contact faults and write errors. ## 16.3.3 Reliability of Written Data T-49-19-16 An effective way to assure the data holding characteristics of the programmed chips is to bake them at 150°C, then screen them for data errors. This procedure quickly eliminates chips with PROM memory cells prone to early failure. Figure 16-6 shows the recommended screening procedure. Figure 16-6 Recommended Screening Procedure If a series of write errors occurs while the same PROM writer is in use, stop programming and check the PROM writer and socket adapter for defects, using a microcomputer with a windowed package and on-chip EPROM. Please inform Hitachi of any abnormal conditions noted during programming or in screening of program data after high-temperature baking. 311 **HITACHI** DataSheet4U.com t4U.com The windowed package enables data to be erased by illuminating the window with ultraviolet light. Table 16-7 lists the erasing conditions. **Table 16-7 Erasing Conditions** | Item | Value | |------------------------|------------------------| | Ultraviolet wavelength | 2537 Å | | Minimum illumination | 15 W·s/cm <sup>2</sup> | The conditions in table 16-7 can be satisfied by placing a $12000 \,\mu\text{W/cm}^2$ ultraviolet lamp 2 or 3 centimeters directly above the chip and leaving it on for about 20 minutes. ### 16.4 Handling of Windowed Packages Glass Erasing Window: Rubbing the glass erasing window of a windowed package with a plastic material or touching it with an electrically charged object can create a static charge on the window surface which may cause the chip to malfunction. If the erasing window becomes charged, the charge can be neutralized by a short exposure to ultraviolet light. This returns the chip to its normal condition, but it also reduces the charge stored in the floating gates of the PROM, so it is recommended that the chip be reprogrammed afterward. DataSheet4U.com Accumulation of static charge on the window surface can be prevented by the following precautions: - 1. When handling the package, ground yourself. Don't wear gloves. Avoid other possible sources of static charge. - Avoid friction between the glass window and plastic or other materials that tend to accumulate static charge. - 3. Be careful when using cooling sprays, since they may have a slight ion content. - 4. Cover the window with an ultraviolet-shield label, preferably a label including a conductive material. Besides protecting the PROM contents from ultraviolet light, the label protects the chip by distributing static charge uniformly. Handling after Programming: Fluorescent light and sunlight contain small amounts of ultraviolet, so prolonged exposure to these types of light can cause programmed data to invert. In addition, exposure to any type of intense light can induce photoelectric effects that may lead to chip malfunction. It is recommended that after programming the chip, cover the erasing window with a light-proof label (such as an ultraviolet-shield label). HITACHI 312 www.DataSheet4U.com DataShe ## Section 17 Power-Down State ### 17.1 Overview T-49-19-16 The H8/520 has a power-down state that greatly reduces power consumption by stopping the CPU functions. The power-down state includes three modes: - 1. Sleep mode: software-triggered mode in which the CPU halts but the rest of the chip remains active. - 2. Software standby mode: software-triggered mode in which the entire chip is inactive. - 3. Hardware standby mode: hardware-triggered mode in which the entire chip is inactive. The sleep mode and software standby mode are entered from the program execution state by executing the SLEEP instruction under the conditions given in table 17-1. The hardware standby mode is entered from any other state by setting mode 6 at the mode pins (MD2 to MD0). Table 17-1 lists the conditions for entering and leaving the power-down modes. It also indicates the status of the CPU, on-chip supporting modules, etc. in each power-down mode. ODL Table 17-1 Power-Down State | | Entering | | | CPU | Peripheral | | 1/0 | Exiting | |---------|---------------|-------|------|-----------|-------------|------|-------|------------------------------------| | Mode | Procedure | Clock | CPU | Registers | Functions | RAM | Ports | Methods | | Sleep | Execute | Run | Halt | Held | Run | Held | Held | <ul> <li>Interrupt</li> </ul> | | mode | SLEEP | | | DataShee | t4U.com | | | • RES low | | | instruction | • | | | | | | Mode 6 | | Soft- | Set SSBY bit | Halt | Halt | Held | Hait | Held | Held | - NMI | | ware | in SBYCR to | | | | and | | | • RES low | | standby | 1, then | | | | initialized | | | <ul><li>Mode 6</li></ul> | | mode | execute SLEEP | | | | | | | | | | instruction* | | | | | | | | | Hard- | Set mode | Halt | Halt | Not | Halt | Held | High | <ul> <li>Mode 1,2,3,</li> </ul> | | ware | pins to | | | held | and | | impe- | 4, or 7 then | | standby | mode 6 | | | | initialized | | dance | $\overline{RES}$ low $\rightarrow$ | | mode | | | | | | | state | high | Darinhard Notes: \* The watchdog timer must also be stopped. SBYCR: Software standby control register SSBY: Software standby bit 313 HITACHI www.DataSheet4U.com DataSheet4U.com t4U.com II/O Evilina DataShe #### LA LECOA ONCOPOS 523 MEHILA # 17.2 Sleep Mode ## 17.2.1 Transition to Sleep Mode Execution of the SLEEP instruction causes a transition from the program execution state to the sleep mode. After executing the SLEEP instruction, the CPU halts, but the contents of its internal registers remain unchanged. The functions of the on-chip supporting modules do not stop in the sleep mode. #### 17.2.2 Exit from Sleep Mode The chip wakes up from the sleep mode when it receives an internal or external interrupt request or a low input at the $\overline{RES}$ pin, or when mode 6 is set at the mode pins. Wake-Up by Interrupt: An interrupt releases the sleep mode and starts either the CPU's interrupt-handling sequence or the data transfer controller (DTC). If the interrupt is served by the DTC, after the data transfer is completed the CPU executes the instruction following the SLEEP instruction, unless the count in the data transfer count register (DTCR) is 0. If an interrupt on a level equal to or less than the mask level in the CPU's status register (SR) is requested, the interrupt is left pending and the sleep mode continues. Also, if an interrupt from an on-chip supporting module is disabled by the corresponding enable/disable bit in the module's control register, the interrupt cannot be requested, so it cannot wake the chip up. DataSneet40.com DataShe Wake-Up by $\overline{RES}$ pin: When the $\overline{RES}$ pin goes low, the chip exits from the sleep mode to the reset state. Wake-Up by Mode 6: When the mode pins are set to mode 6, the chip exits from the sleep mode to the hardware standby mode. ## 17.3 Software Standby Mode ## 17.3.1 Transition to Software Standby Mode A program enters the software standby mode by setting the standby bit (SSBY) in the software standby control register (SBYCR) to 1, then executing the SLEEP instruction. Table 17-2 lists the attributes of the software standby control register. HITACHI 314 www.DataSheet4U.com | Name | Abbreviation | R/W | Initial Value | Address | |-----------------------------------|--------------|-----|---------------|---------| | Software standby control register | SBYCR | R/W | H'7F | H'FFFB | In the software standby mode, the CPU, clock, and the on-chip supporting module functions all stop, reducing power consumption to an extremely low level. The on-chip supporting modules and their registers are reset to their initial state, but as long as a minimum necessary voltage supply is maintained (at least 2 V), the contents of the CPU registers and on-chip RAM remain unchanged. The I/O ports also remain in their current states. ## 17.3.2 Software Standby Control Register (SBYCR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|---|---|---|---|---|---|---| | | SSBY | _ | | | | | | | | Initial value | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Read/Write | R/W | | - | - | | _ | | | The software standby control register (SBYCR) is an 8-bit register that controls the action of the SLEEP instruction. Bit 7—Software Standby (SSBY): This bit enables or disables the transition to the software standby mode. t4U.com DataSheet4U.com DataShe | SSBY | Description | | | |------|---------------------------------------------------------------------|-----------------|--| | 0 | The SLEEP instruction causes a transition to the sleep mode. | (Initial value) | | | 1 | The SLEEP instruction causes a transition to the software standby n | node. | | The watchdog timer must be stopped before the chip can enter the software standby mode. To stop the watchdog timer, clear the timer enable bit (TME) in the watchdog timer's timer control/status register (TCSR) to 0. The SSBY bit cannot be set to 1 while the TME bit is set to 1. When the chip is recovered from the software standby mode by a nonmaskable interrupt (NMI), the SSBY bit is automatically cleared to 0. It is also cleared to 0 by a reset or transition to the hardware standby mode. Bits 6 to 0—Reserved: These bits cannot be modified and are always read as 1. 315 HITACHI The chip can be brought out of the software standby mode by an input at the NMI pin, RES pin, or mode pins. Recovery by NMI Pin: When an NMI request signal is received, the clock oscillator begins operating but clock pulses are supplied only to the watchdog timer (WDT). The watchdog timer begins counting from H'00 at the rate determined by the clock select bits (CKS2 to CKS0) in its timer status/control register (TCSR). This rate should be set slow enough to allow the clock oscillator to stabilize before the count reaches H'FF. When the count overflows from H'FF to H'00, clock pulses are supplied to the whole chip, the software standby mode ends, and execution of the NMI interrupt-handling sequence begins. The clock select bits (CKS2 to CKS0) should be set as follows. Crystal Oscillator: Set CKS2 to CKS0 to a value that makes the watchdog timer interval equal to or greater than 10 ms, which is the clock stabilization time. External Clock Input: CKS2 to CKS0 can be set to any value. The minimum value (CKS2 = CKS1 = CKS0 = 0) is recommended. Recovery by RES Pin: When the RES pin goes low, the clock oscillator starts. Next, when the RES pin goes high, the CPU begins executing the reset sequence. DataSheet4U.com When the chip recovers from the software standby mode by a reset, clock pulses are supplied to the entire chip at once. Be sure to hold the $\overline{RES}$ pin low long enough for the clock to stabilize. **Recovery by Mode 6:** When the mode pins are set to mode 6, the chip exits from the software standby mode to the hardware standby mode. ### 17.3.4 Sample Application of Software Standby Mode In this example the chip enters the software standby mode on the falling edge of the NMI input and recovers from the software standby mode on the rising edge of NMI. Figure 17-1 shows a timing chart of the transitions. The nonmaskable interrupt edge bit (NMIEG) in the NMI control register (NMICR) is originally cleared to 0, selecting the falling edge as the NMI trigger. After accepting an NMI interrupt in this HITACHI 316 www.DataSheet4U.com DataShe condition, software changes the NMIEG bit to 1, sets the SSBY bit to 1, and executes the SLEEP instruction to enter the software standby mode. The chip recovers from the software standby mode on the next rising edge at the NMI pin. T-49-19-16 Figure 17-1 NMI Timing of Software Standby Mode (Application Example) #### 17.3.5 Application Notes The I/O ports remain in their current states in the software standby mode. If a port is in the high output state, the output current is not reduced in the software standby mode. ## 17.4 Hardware Standby Mode ### 17.4.1 Transition to Hardware Standby Mode Regardless of its current state, the chip enters the hardware standby mode whenever the mode pins are set to mode 6 (MD2 and MD1 high, MD0 low). The hardware standby mode reduces power consumption drastically by halting the CPU, stopping all the functions of the on-chip supporting modules, and placing I/O ports in the high-impedance state. 317 HITACHI www.DataSheet4U.com www.DataSheet4U.com The registers of the on-chip supporting modules are reset to their initial values. Only the on-chip RAM is held unchanged, provided the minimum necessary voltage supply is maintained (at least 2 V).\* - Notes: 1. The RAME bit in the RAM control register should be cleared to 0 before the mode pins are set to mode 6, to disable the on-chip RAM during the hardware standby mode. - 2. Do not change the inputs at the mode pins (MD2, MD1, MD0) during hardware standby mode. Be particularly careful not to let all three mode inputs go low, since that would place the chip in PROM mode, causing increased current dissipation. T-49-19-16 ### 17.4.2 Recovery from Hardware Standby Mode Recovery from the hardware standby mode requires inputs at both the mode and RES pins. When the mode pins are set to mode 1, 2, 3, 4, or 7, the clock oscillator begins running. The $\overline{RES}$ pin should be low at this time and should be held low long enough for the clock to stabilize. When the $\overline{RES}$ pin changes from low to high, the reset sequence is executed and the chip returns to the program execution state. ### 17.4.3 Timing Sequence of Hardware Standby Mode Figure 17-2 shows the usual sequence for entering and leaving the hardware standby mode. First the RES pin goes low, placing the chip in the reset state. Then the mode pins are set to mode 6, placing the chip in the hardware standby mode and stopping the clock. In the recovery sequence first the mode pins are set to mode 1, 2, 3, 4, or 7; then after the clock stabilizes, the RES pin is returned to the high level. DataShe HITACHI 318 www.DataSheet4U.com Figure 17-2 Hardware Standby Sequence t4U.com DataSheet4U.com DataShe 319 HITACHI DataSheet4U.com www.DataSheet4U.comCU/MPU) 50E D 4496204 0028108 775 HHTT3 T-49-19-16 DataShe DataSheet4U.com HITACHI 320 DataSheet4U.com www.DataSheet4U.com # Section 18 Electrical Specifications ## 18.1 Absolute Maximum Ratings T-49-19-16 Table 18-1 lists the absolute maximum ratings. **Table 18-1 Absolute Maximum Ratings** | Item | Symbol | Rating | Unit | |-------------------------------|--------|---------------------------------------|------| | Supply voltage | Vcc | -0.3 to +0.7 | V | | Programming voltage | VPP | -0.3 to +13.5 | V | | Input voltage (except port 6) | Vin | -0.3 to Vcc + 0.3 | ٧ | | Input voltage (port 6) | Vin | -0.3 to AVcc + 0.3 | V | | Analog supply voltage | AVcc | -0.3 to +7.0 | ٧ | | Analog input voltage | Van | -0.3 to AVcc + 0.3 | ٧ | | Operating temperature | Topr | Regular specifications: -20 to +75 | .c | | | | Wide-range specifications: -40 to +85 | •c | | Storage temperature | Tstg | -55 to +125 | •c | | | | | | Note: Permanent damage to the chip may result if the absolute maximum ratings shown in table 18-1 are exceeded. ## 18.2 Electrical Characteristics 18.2.1 DC Characteristics DataSheet4U.com Table 18-2 lists the DC characteristics. DataShe 321 HITACHI ### **Table 18-2 DC Characteristics** Conditions: $VCC = AVCC = 5.0 \text{ V} \pm 10\%^{*1}$ , VSS = AVSS = 0 V, T-49-19-16 $T_a = -20$ to 75°C (Regular specifications) $T_a = -40$ to 85°C (Wide-range specifications) | | | O!1 | | <b>A</b> | in or a | 1114 | Test | |-----------------------|-------------------------------------|--------------|---------------------------|----------|------------------|-------------|---------------------------| | Item | | Symbol | min | typ | max | Unit | Conditions | | Input high voltage | RES, MD <sub>2</sub> , | ViH | Vcc - 0.7 | | Vcc + 0.3 | V | | | | MD <sub>1</sub> , MD <sub>0</sub> | | | | | <del></del> | | | | EXTAL | | $Vcc \times 0.7$ | | Vcc + 0.3 | <u> </u> | | | | Port 6 | | 2.2 | | AVcc + 0.3 | | | | | Other input pins | | 2.2 | | Vcc + 0.3 | V | | | | (except port 5) | · | | | | | | | Input low voltage | RES, MD <sub>2</sub> , | VIL | -0.3 | _ | 0.5 | ٧ | | | | MD <sub>1</sub> , MD <sub>0</sub> | | | | | | | | | Other input pins | | -0.3 | | 0.8 | | | | | (except port 5) | | | | | | | | Schmitt trigger | Port 5 | VT- | 1.0 | | 2.5 | ٧ | | | input voltage | | VT+ | 2.0 | | 3.5 | `V | | | | | VT+ - VT | 0.4 | | | <u>v</u> | | | Input leakage current | RES | lin | | | 10.0 | μА | Vin = 0.5 to | | | NMI, MD2, | | | | 1.0 | μA | Vcc - 0.5 V | | | MD <sub>1</sub> , MD <sub>0</sub> , | | | | • | | | | | Port 6 | | _ | _ | 1.0 | μА | Vin = 0.5 to | | | | DeteCh | neet411 com | | | | AVcc - 0.5 V | | Leakage current | Port 7, | ITSI | <del>:ee:и ∪ .соги.</del> | | <sup>°</sup> 1.0 | μА | $V_{in} = 0.5 \text{ to}$ | | in 3-state | ports 5 to 1 | | | | | | Vcc - 0.5 V | | (off state) | • | | | | | | | | Input pull-up | Ports 3 and 4 | - <b>I</b> P | 50 | | 200 | μА | Vin = 0 V | | MOS current | | | | | | - | | | Output high voltage | All output pins | Vон | Vcc - 0.5 | | • | ٧ | loн = -200 µ | | | | | 3.5 | | | ٧ | lон = -1 mA | | Output low voltage | All output pins | Vol | _ | | 0.4 | ٧ | loL = 1.6 mA | | | (except RES) | | | | | | | | | Port 3 | | _ | | 1.0 | V | lot. = 8 mA | | | | | _ | _ | 1.2 | ٧ | loL = 10 mA | | | RES | | | | 0.4 | ٧ | loL = 2.6 mA | | Input capacitance | RES | Cin | <del></del> | _ | 60 | pF | Vin = 0 V | | e en commence | NMI | | | | 30 | pF | f = 1 MHz | | | All input pins | | | _ | 15 | pF | Ta = 25°C | | | except RES | | | | | • | | HITACHI 322 www.DataSheet4U.com DataShe Unit | | | | | | | | Test | |----------------------|------------------|--------|-----|------|-------------|------|------------| | Item | | Symbol | mln | typ | max | Unit | Conditions | | Current dissipation* | Normal operation | Icc | _ | 20 | 30 | mA | f = 6 MHz | | | | | _ | 25 | 40 | mA | f = 8 MHz | | | | | | 30 | 50 | mA | f = 10 MHz | | | | | | 12 | 20 | mA | f = 6 MHz | | | Sleep mode | | - | 16 | 25 | mA | f = 8 MHz | | | | | | 20 | 30 | mA | f = 10 MHz | | | Standby | | | 0.01 | 5.0 | μА | | | Analog supply | During A/D | Alcc | | 0.6 | 2.0 | mA | | | current | conversion | | | | | | | | | While waiting | | | 0.01 | 5.0 | μА | | | RAM standby voltage | | VRAM | 2.0 | | <del></del> | V | | Note: AVcc must be connected to a power supply even when the A/D converter is not used. Symbol min typ max **Table 18-3** Allowable Output Current Sink Values Conditions: $Vcc = AVcc = 5.0 V \pm 10\%$ , Vss = AVss = 0 V, $T_a = -20$ to 75°C (Regular specifications) $T_a = -40$ to 85°C (Wide-range specifications) | Allowable output low | Port 3 | <b>lo</b> L | | <br>10 | mA | |------------------------|-------------------------|-------------------|---|---------|----| | current sink (per pin) | RES | | | <br>2.6 | mA | | | Other output pins | | | <br>2.0 | mA | | Allowable output low | Port 3, total of 8 pins | Σ lo <sub>L</sub> | _ | <br>40 | mA | | current sink (total) | Total of all other | | | <br>80 | mA | | | output pins | | | | | DataShe | Allowable output high | All output pins | -Іон | _ | | 2.0 | mA | | |------------------------|---------------------|---------|---|---|-----|----|--| | current sink (per pin) | | | | | | | | | Allowable output high | Total of all output | ∑ -І́он | _ | _ | 40 | mA | | | current sink (total) | pins | | | | | | | Note: To avoid degrading the reliability of the chip, be careful not to exceed the output current sink values in table 18-3. In particular, when driving a Darlington transistor pair or LED directly, be sure to insert a current-limiting resistor in the output path. See figures 18-1 and 18-2. 323 HITACHI www.DataSheet4U.com t4U.com Item <sup>\*</sup> Current dissipation values assume that V<sub>H</sub> min = Vcc − 0.5 V, V<sub>I</sub>L max = 0.5 V, all output pins are in the no-load state, and all MOS input pull-ups are off. Figure 18-1 Example of Circuit for Driving a Darlington Transistor Pair Figure 18-2 Example of Circuit for Driving an LED #### 18.2.2 AC Characteristics The AC characteristics of the H8/520 chip are listed in three tables. Bus timing parameters are given in table 18-4, control signal timing parameters in table 18-5, and timing parameters of the on-chip supporting modules in table 18-6. See figure 18-3 for the output load circuit. ### Table 18-4 Bus Timing Conditions: $VCC = 5.0 \text{ V} \pm 10\%$ , $\emptyset = 0.5 \text{ to } 10 \text{ MHz}$ , VSS = 0 V $T_a = -20$ to 75°C (Regular specifications) $T_a = -40$ to 85°C (Wide-range specifications) | | | 6 MHz | | 8 MHz | | 10 MHz | | | Test | | |-------------------------------|-------------|---------------|----------------------|-----------------------|------|---------|------|------|-----------------|--| | item | Symbol | $\min^{\Box}$ | ataShe<br><b>max</b> | et4U.co<br><b>min</b> | max | min | max | Unit | Conditions | | | Clock cycle time | tcyc | 166.7 | 2000 | 125 | 2000 | 100 | 2000 | ns | See figure 18-4 | | | Clock pulse width low | tcL | 65 | | 45 | _ | 35 | - | ns | | | | Clock pulse width high | tсн | 65 | | 45 | | 35 | | ns | _ | | | Clock rise time | tCr | | 15 | | 15 | _ | 15 | ns | _ | | | Clock fall time | tor | | 15 | | 15 | | 15 | ns | _ | | | Address delay time | <b>t</b> AD | | 70 | | 60 | | 55 | ns | | | | Address hold time | <b>t</b> AH | 30 | | 25 | | 20 | | ns | _ | | | RD delay time 1 | tRDD1 | | 70 | | 60 | | 40 | ns | _ | | | RD delay time 2 | tRDD2 | | 70 | | 60 | | 50 | ns | | | | WR delay time 1 | twRD1 | | 70 | | 60 | <b></b> | 50 | ns | _ | | | WR delay time 2 | twRD2 | | 70 | | 60 | | 50 | ns | | | | Write data strobe pulse width | tosww | 200 | _ | 150 | | 120 | | ns | | | | Address setup time 1 | tas1 | 25 | | 20 | | 15 | _ | ns | | | | Address setup time 2 | tas2 | 105 | | 80 | | 65 | | ns | See figure 18-4 | | | Read data setup time | tros | 60 | _ | 50 | | 40 | | ns | | | **HITACHI** 324 www.DataSheet4U.com DataShe | | 77 | 10504 | nn59773 | 035 | HIT: | |--|----|-------|----------|-----|------| | | | (197 | FITTOTOM | 다그룹 | HIT: | | | | 6 | 6 MHz | | 8 MHz | | 10 MHz | | Test | |-----------------------|--------------|--------|--------|----------|-------|-----|--------|------|-----------------| | Item | Symbo | oi min | in max | min | max | min | max | Unit | Conditions | | Read data hold time | <b>t</b> rdh | 0 | _ | 0 | | 0 | _ | ns | See figure 18-4 | | Read data access time | tacc | | 280 | <b>—</b> | 190 | - | 160 | ns | T 40 | | Write data delay time | twdd | | 70 | | 60 | | 60 | ns | T-49-19-16 | | Write data setup time | twos | 30 | | 15 | | 10 | | ns | _ | | Write data hold time | twdh | 30 | | 25 | _ | 20 | _ | ns | _ | | Wait setup time | twrs | 40 | | 40 | | 40 | | ns | See figure 18-5 | | Wait hold time | twth | 10 | _ | 10 | | 10 | | ns | - | #### **Table 18-5 Control Signal Timing** Conditions: $VCC = 5.0 \text{ V} \pm 10\%$ , $\emptyset = 0.5 \text{ to } 10 \text{ MHz}$ , Vss = 0 V $T_a = -20$ to 75°C (Regular specifications) $T_a = -40$ to 85°C (Wide-range specifications) | | | 6 MHz | | 8 MHz | | 10 MHz | | | Test | | |-----------------------------------------------------------------|--------|------------------|--------|-------------------|-------------|--------|--------------|------|------------------|--| | Item | Symbol | min | max | min | max | min | max | Unit | Conditions | | | RES setup time | tness | 200 | | 200 | | 200 | | ns | See figure 18-6 | | | RES pulse width 1* | tresw1 | 6.0 | | 6.0 | | 6.0 | | tcyc | _ | | | RES pulse width 2* | tHESW2 | 520 | | 520 | _ | 520 | | tcyc | | | | RES output delay time | tnesd | | 100 | _ | 100 | _ | 100 | ns | See figure 18-7 | | | RES output pulse width | tresow | 132 | | 132 | <del></del> | 132 | **** | tcyc | _ | | | Mode programming setup time | tMDS | 4.0 <sub>D</sub> | ataShe | et4 <b>.0</b> .co | m | 4.0 | — | tcyc | See figure 18-6 | | | NMI setup time | tnmis | 150 | _ | 150 | | 150 | <del>-</del> | ns | See figure 18-8 | | | NMI hold time | tnmih | 10 | | 10 | | 10 | _ | ns | _ | | | IRQo setup time | tingos | 50 | | 50 | | 50 | | ns | _ | | | IRQ1 to IRQ7 setup time | tirqis | 50 | | 50 | | 50 | _ | ns | _ | | | IRQ1 to IRQ7 hold time | tiRQ1H | 10 | | 10 | | 10 | | ns | | | | NMI pulse width<br>(for recovery from<br>software standby mode) | tnmiw | 200 | _ | 200 | <del></del> | 200 | _ | ns | | | | A/D trigger setup time | trags | 50 | | 50 | | 50 | | ns | See figure 18-18 | | | A/D trigger hold time | tткан | 10 | _ | 10 | | 10 | | ns | _ | | | Crystal oscillator settling time (reset) | tosc1 | 20 | | 20 | | 20 | _ | ms | See figure 18-9 | | | Crystal oscillator settling time (software standby) | tosc2 | 10 | | 10 | | 10 | | ms | See figure 17-1 | | Note: \* tresw2 applies when the RSTOE bit in the reset control/status register (RSTCR) is set to 1. tresw1 applies when RSTOE is cleared to 0. tresw1 also applies at power-up. 325 **HITACHI** www.DataSheet4U.com DataShe # Table 18-6 Timing Conditions of On-Chip Supporting Modules Timing Conditions of On-Chip Supporting Modules Conditions: $Vcc = 5.0 \text{ V} \pm 10\%$ , $\emptyset = 0.5 \text{ to } 10 \text{ MHz}$ , Vss = 0 V $T_a = -20$ to 75°C (Regular specifications) $T_a = -40$ to 85°C (Wide-range specifications) T-49-19-16 | | | | | 6 N | AHZ | 8 MHz | | 10 1 | MHz | Test | | | |-------|------------------------------|---------|---------------|------|--------|-------|-----|------|-----|-------|------------------|--| | Item | | | Symbol | min | max | min | max | min | max | Unit | Conditions | | | FRT | Timer output delay time | | tftod | | 100 | | 100 | | 100 | ns | See figure 18-11 | | | | Timer input setup time | | <b>t</b> FTIS | 50 | | 50 | _ | 50 | | ns | | | | | Timer clock input setup tin | ne | trtcs | 50 | | 50 | | 50 | | ns | See figure 18-12 | | | | Timer clock pulse width | | trtcw | 1.5 | | 1.5 | _ | 1.5 | | tcyc | | | | TMR | R Timer output delay time | | | | 100 | _ | 100 | _ | 100 | ns | See figure 18-13 | | | | Timer clock input setup time | | | 50 | _ | 50 | | 50 | | ns | See figure 18-14 | | | | Timer clock pulse width | | | 1.5 | _ | 1.5 | | 1.5 | | tcyc | | | | | Timer reset input setup tin | ne | trmns | 50 | _ | 50 | | 50 | _ | ns | See figure 18-15 | | | SCI | Input clock cycle | (Async) | tScyc | 2 | | 2 | | 2 | | tcyc | See figure 18-16 | | | | | (Sync) | | 4 | | 4 | | 4 | | tcyc | - | | | | Input clock pulse width | | tsckw | 0.4 | 0.6 | 0.4 | 0.6 | 0.4 | 0.6 | tscyc | | | | | Transmit data delay time | (Sync) | txx | _ | 100 | | 100 | | 100 | ns | See figure 18-17 | | | | Receive data setup time | (Sync) | trxs | 100 | | 100 | _ | 100 | | ns | _ | | | | Receive data hold time | (Sync) | tяхн | | 100 | | 100 | | 100 | ns | | | | Ports | s Output data delay time | | <b>t</b> PWD | | 100 | | 100 | | 100 | ns | See figure 18-10 | | | | Input data setup time | | | 50 | | 50 | | 50 | | ns | _ | | | | Input data hold time | | <b>t</b> PRH | 50 | | 50 | | 50 | | ns | | | | | | | Dala | Snee | [4U.CO | 111 | | | | | | | et4U.com #### • Measurement Conditions for AC Characteristics Figure 18-3 Output Load Circuit HITACHI 326 www.DataSheet4U.com T-49-19-16 Table 18-7 lists the characteristics of the on-chip A/D converter. #### Table 18-7 (1) A/D Converter Characteristics Conditions: $VCC = AVCC = 5.0 \text{ V} \pm 10\%$ , Vss = AVss = 0 V, $T_a = -40$ to 85°C (Wide-range specifications) | | 6 MHz | | | 8 MHz | | | 10 MHz | | | | |-----------------------------------|-------|-----|-------|-------|-----|-------|--------|-----|------|------| | Item | min | typ | max | min | typ | max | min | typ | max | Unit | | Resolution | 10 | 10 | 10 | 10 | 10 | 10 | 10 | 10 | 10 | Bits | | Conversion time | | | 23.0 | | | 17.25 | | | 13.8 | μs | | Analog input capacitance | | | 20 | | | 20 | | _ | 20 | pF | | Allowable signal-source impedance | | | 10 | | | 10 | _ | | 10 | kΩ | | Nonlinearity error | | | :±2.0 | _ | _ | ±2.0 | | | ±2.0 | LSB | | Offset error | | _ | ±2.0 | _ | _ | ±2.0 | | _ | ±2.0 | LSB | | Full-scale error | _ | | ±2.0 | | | ±2.0 | | | ±2.0 | LSB | | Quantizing error | _ | | ±0.5 | | | ±0.5 | _ | | ±0.5 | LSB | | Absolute accuracy | | | ±2.5 | _ | | ±2.5 | _ | | ±2.5 | LSB | #### Table 18-7 (2) A/D Converter Characteristics Conditions: t4U.com $Vcc = \Lambda Vcc = 5.0 \text{ V} \pm 10\%$ , Vss = AVss = 0 V, $T_a = -20$ to 75°C (Regular specifications) | | 6 MHz | | | | 8 MH | Z | 10 MHz | | | | |-----------------------------------|-------|-----|------|-----|----------|-------|--------|-----|------|------| | Item | min | typ | max | min | typ | max | min | typ | max | Unit | | Resolution | 10 | 10 | 10 | 10 | 10 | 10 | 10 | 10 | 10 | Bits | | Conversion time | | | 23.0 | | | 17.25 | | | 13.8 | μs | | Analog input capacitance | | | 20 | | | 20 | _ | _ | 20 | pF | | Allowable signal-source impedance | • | | 10 | | | 10 | | | 10 | kΩ | | Nonlinearity error | - | - | ±3.5 | _ | _ | ±3.5 | _ | | ±3.5 | LSB | | Offset error | | - | ±3.5 | | <u> </u> | ±3.5 | | - | ±3.5 | LSB | | Full-scale error | | | ±3.5 | | | ±3.5 | | | ±3.5 | LSB | | Quantizing error | | _ | ±0.5 | | | ±0.5 | | | ±0.5 | LSB | | Absolute accuracy | | | ±4.0 | _ | | ±4.0 | | | ±4.0 | LSB | 327 **HITACHI** www.DataSheet4U.com #### www.DataSheet4U.com # 18.3 MCU Operational Timing This section provides the following timing charts: T-49-19-16 | 18.3.1 Bus timing | Figures 18-4 and 18-5 | |--------------------------------|------------------------------------| | 18.3.2 Control Signal Timing | Figures 18-6 to 18-8 | | 18.3.3 Clock Timing | Figure 18-9 | | 18.3.4 I/O Port Timing | Figure 18-10 | | 18.3.5 16-Bit Free-Running Tin | ner Timing Figures 18-11 and 18-12 | | 18.3.6 8-Bit Timer Timing | Figures 18-13 to 18-15 | | 18.3.7 SCI Timing | Figures 18-16 and 18-17 | #### 18.3.1 Bus Timing #### 1. Basic Bus Cycle (without Wait States) in Expanded Modes Figure 18-4 Basic Bus Cycle (without Wait States) in Expanded Modes HITACHI 328 ww.DataSheet4U com 2. Basic Bus Cycle (with 1 Wait State) in Expanded Modes ELIHEM 997 JATEBARA CAR Figure 18-5 Basic Bus Cycle (with 1 Wait State) in Expanded Modes et4U.com DataSheet4U.com DataShe 329 HITACHI DataSheet4U.com #### 1. Reset Input Timing Figure 18-6 Reset Input Timing #### 2. Reset Output Timing Figure 18-7 Reset Output Timing et4U.com #### 3. Interrupt Input Timing Figure 18-8 Interrupt Input Timing HITACHI 330 www.DataSheet4U.com T-49-19-16 tosci Hardware standby mode Figure 18-9 Clock Oscillator Stabilization Note: The H8/520 enters hardware standby mode when MD2 and MD1 are driven high and MD5 is driven low. ataSheet4U tosci MD2, MD1 Ŝ RES Ş DataShe 331 HITACHI DataSheet4U.com www.DataSheet4U.co www.DataSheet4U.com ETIH 575 0568500 PD58PPP 18.3.4 I/O Port Timing Figure 18-10 I/O Port Input/Output Timing et4U.com DataSheet4U.com DataShe HITACHI 332 www.DataSheet4U.com DataSheet4U.com #### 1. Free-Running Timer Input/Output Timing T-49-19-16 Figure 18-11 Free-Running Timer Input/Output Timing #### 2. External Clock Input Timing for Free-Running Timers Figure 18-12 External Clock Input Timing for Free-Running Timers 333 HITACHI www.DataSheet4U.com www.DataSheet4U.com #### 1. 8-Bit Timer Output Timing Figure 18-13 8-Bit Timer Output Timing #### 2. 8-Bit Timer Clock Input Timing Figure 18-14 8-Bit Timer Clock Input Timing # DataShe #### 3. 8-Bit Timer Reset Input Timing Figure 18-15 8-Bit Timer Reset Input Timing HITACHI 334 www.DataSheet4U.com ww.DataSheet4U.com ### 18.3.7 Serial Communication Interface Timing Figure 18-16 SCI Input Clock Timing Figure 18-17 SCI Input/Output Timing (Synchronous Mode) #### 18.3.8 A/D External Trigger Input Timing Figure 18-18 A/D External Trigger Input Timing 335 HITACHI # Appendix F Package Dimensions Figure F-1 shows the dimensions of the DC-64S package. Figure F-2 shows the dimensions of the DP-64S package. Figure F-3 shows the dimensions of the FP-64A package. Figure F-4 shows the dimensions of the CP-68 package. Figure F-1 Package Dimensions (DC-64S) Figure F-2 Package Dimensions (DP-64S) **HITACHI** 438 DataSheet4U.com www.DataSheet4U.com Figure F-3 Package Dimensions (FP-64A) Figure F-4 Package Dimensions (CP-68) 439 HITACHI DataSheet4U.com t4U.com