SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

### DESCRIPTION

The M32000D4AFP is a new generation microcomputer with a 32-bit CPU and built-in high capacity DRAM. Using this device it is possible to implement the complex applications of the multimedia age with high performance and low power consumption.

The M32000D4AFP contains 2M bytes of DRAM and 4K bytes of cache memory. The CPU is implemented with a RISC architecture and has a high performance figure of 52.4 MIPS (at an internal clock rate of 66.6 MHz ). Memory for main storage is provided internally to the device eliminating external memory and associated control circuits thus reducing overall system noise and power consumption.

The CPU, internal DRAM and cache memory are connected by a 128-bit, 15 ns/cycle internal bus which virtually eliminates transfer bottlenecks in between the CPU and the memory. The M32000D4AFP internally multiplies the frequency of the input clock signals by four. For an internal operating frequency of 66.6 MHz the input clock frequency is 16.65MHz.

A 16-bit data and 24-bit address bus are the M32000D4AFP's external bus and the interface to external peripheral controllers. When the hold state is set, the internal DRAM can be accessed from an external device.

A 3-chip basic system configuration using the M32000D4AFP is the device itself plus an ASIC as a peripheral controller and a program ROM. Execution starts from the reset vector entry on the external ROM after power on, a program requiring high speed execution is then transferred to internal DRAM and this is then executed. The M32000D4AFP also has a slave mode additional to its master mode. When set to slave mode the M32000D4AFP can be used as a coprocessor. In this mode it does not access its external bus immediatly after reset, but waits for the master to start its operation.

### FEATURES

| • CPU                                                                             |
|-----------------------------------------------------------------------------------|
| Pipeline                                                                          |
| Basic bus cycle 15 ns (at internal 66.6 MHz)                                      |
| Logical address space 4G-byte linear                                              |
| • External bus data bus: 16 bits                                                  |
| address bus: 24 bits                                                              |
| Internal DRAM 16M bits (2M bytes)                                                 |
| • Cache 4K bytes (direct map)                                                     |
| • Register configuration general-purpose registers: 32 bits x 16                  |
| control registers: 32 bits x 5                                                    |
| Instruction set                                                                   |
| Instruction format                                                                |
| <ul> <li>Multiply-accumulate operation unit (DSP function instruction)</li> </ul> |
| <ul> <li>Internal memory controller</li> </ul>                                    |
| Programmable I/O ports                                                            |
| Power management function standby mode                                            |
| /CPU sleep mode                                                                   |
| PLL clock generating circuit four-time clock PLL circuit                          |
| Operation mode master/slave mode                                                  |
| Interrupt input INT and SBI                                                       |
| • Power source 3.3 V (±10 %)                                                      |

#### **APPLICATIONS**

Portable equipment, Still camera, Navigation system, Digital instrument, Printer, Scanner, FA equipment











SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

| FUNCTIONS |
|-----------|
|-----------|

| function block        | characteristics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU core              | <ul> <li>bus specification<br/>basic bus cycle: 15 ns (internal operation at 66.6 MHz)<br/>logical address space: linear 4G bytes<br/>external address bus: 24 bits (external output pin: A8 to A30, BCH, BCL)<br/>external data bus: 16 bits</li> <li>implementation: 5-stage pipeline</li> <li>core internal: 32 bits</li> <li>register configuration<br/>general-purpose registers: 32 bits X 16<br/>control registers: 32 bits X 5</li> <li>instruction set<br/>16-bit/32-bit instruction format<br/>83 instructions/6 addressing modes</li> <li>multiply-accumulate operation built in</li> </ul> |
| internal DRAM         | 16M bits (2M bytes)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| cache memory          | • 4K bytes (internal instruction/data cache mode, instruction cache mode, cache-off mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| memory controller     | <ul> <li>cache control</li> <li>internal DRAM control, refresh control</li> <li>power management function (standby mode, CPU sleep mode selection control)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| programmable I/O port | two programmable I/O ports                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |



4





SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

| type              | pin name   | name                    | I/O            | function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------|------------|-------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| power<br>source   | VCC<br>VSS | power source<br>ground  | -              | All power source pins should be connected to VCC.<br>All ground pins should be connected to VSS.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| clock             | CLKIN      | clock input             | input          | Clock input pin. The M32000D4AFP has an internal PLL multiplier<br>circuit, and an input clock which is 1/4 of the internal operating<br>frequency (when the internal operating frequency is 66.6 MHz,<br>the CLKIN input is 16.65 MHz).                                                                                                                                                                                                                                                                                                                   |
|                   | PLLCAP     | C connection<br>for PLL | -              | Connects a capacitor for the internal PLL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | PLLVCC     | power source<br>for PLL | _              | Power source for the internal PLL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                   | PLLVSS     | ground<br>for PLL       | _              | Ground for the internal PLL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| system<br>control | RST        | reset                   | input          | Internally resets the M32000D4AFP. It is also used to return from standby mode and CPU sleep mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                   | M/Ŝ        | master/slave            | input          | Sets the M32000D4AFP default operation to either system bus<br>master ( $M/\overline{S} = "H"$ ) or bus slave ( $M/\overline{S} = "L"$ ).<br>When the M32000D4AFP is set to bus slave, it does not carry<br>out a reset vector entry fetch after a reset.<br>The setting of $M/\overline{S}$ cannot be changed during operation.<br>Keep at either an "H" or an "L" level.                                                                                                                                                                                 |
|                   | WKUP       | wakeup                  | input          | Input pin to request return from standby mode.<br>This is only accepted when STBY is "L" level.<br>It generates the wakeup interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                   | STBY       | standby                 | output         | Indicates that the M32000D4AFP has switched to standby mode. An "L" level is output while the device is in standby mode.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| address<br>bus    | A8 to A30  | address bus             | I/O<br>(Hi-z)* | The M32000D4AFP has a 24-bit address (A8 to A31) bus for<br>a 16 MB address space. A31 is not output. During the write<br>cycle, the valid byte positions on the 16-bit data bus are output<br>as BCH or BCL. During the read cycle, the 16-bit data bus is<br>read, however,only data in the valid byte positions is transferred<br>to the M32000D4AFP.<br>Address bus pins are bidirectional. When accessing the internal<br>DRAM from an external bus master while the M32000D4AFP is<br>in the hold state, input the address from the system bus side. |
| data bus          | D0 to D15  | data bus                | I/O<br>(Hi-z)* | 16-bit data bus for connecting to external devices.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

### **PIN DESCRIPTION (1/3)**

\* (Hi-z): This pin goes to high-impedance in the hold state.



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

| type           | pin name | name                | I/O               | function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|----------|---------------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bus<br>control | SID      | space<br>identifier | output<br>(Hi-z)* | Space identifier between user space and I/O space.<br>SID = "L": user space<br>SID = "H": I/O space<br>SID = undefined: when idle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                | BCH, BCL | byte control        | I/O<br>(Hi-z)*    | Indicates the valid byte positions of transferred data.<br>BCH corresponds to the MSB side (D0 to D7), and BCL correspond<br>to the LSB side (D8 to D15). During a read bus cycle, both BCH<br>and BCL are an "L" level.<br>During a write bus cycle, either BCH and/or BCL is an "L" level<br>depending on the byte(s) to be written.<br>When accessing the internal DRAM from an external bus master<br>the byte control signal is input from the system bus side.                                                                                                                                                                                                |
|                | BS       | bus start           | output<br>(Hi-z)* | When the M32000D4AFP drives an external bus cycle, BS goe<br>to an "L" level at the start of the bus cycle.<br>In burst transfer, BS goes to the "L" level for each transfer<br>cycle. When accessing internal resources such as an interna<br>DRAM or internal I/O register, BS is not output.                                                                                                                                                                                                                                                                                                                                                                     |
|                | ST       | bus status          | output<br>(Hi-z)* | Indicates whether the bus cycle that the M32000D4AFP drives i<br>an instruction fetch access cycle or an operand access cycle.<br>ST = "L": for instruction fetch access<br>ST = "H": for operand access<br>ST = undefined: when idle                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                | R/W      | read/write          | I/O<br>(Hi-z)*    | Outputs R/W to identify whether the external bus cycle a read o<br>a write cycle. When accessing the internal DRAM from an externa<br>bus master, R/W is input from the external bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                | BURST    | burst               | output<br>(Hi-z)* | The M32000D4AFP drives two consecutive bus cycles to access<br>32-bit data allocated on the 32-bit word boundary.<br>For instruction fetches, it drives 8 (max.) consecutive cycles<br>(8 cycles in instruction cache mode) to data on the 128-bit boundary<br>During these consecutive bus cycles, BURST goes to "L" level<br>When accessing 32-bit data, an "L" level followed by an "H" leve<br>is output from address A30, because the MSB-side 16 bits are<br>accessed prior to the LSB-side 16 bits.<br>When accessing 128-bit data, the addresses are output from ar<br>arbitrary 16-bit aligned address and wraparound within a 128-bi<br>aligned boundary. |

#### **PIN DESCRIPTION (2/3)**

\* (Hi-z): This pin goes to high-impedance in the hold state.



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

| type                       | pin name | name                         | I/O           | function                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------------------|----------|------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bus<br>control<br>(cont.)  | DC*      | data complete                | I/O<br>(Hi-z) | When the M32000D4AFP drives an external bus cycle, in<br>automatically inserts wait cycles until DC is input by the slave<br>device in the system bus.<br>When the M32000D4AFP is in the hold state and the internal<br>DRAM is accessed from an external bus master, the M32000D4AFP<br>outputs DC to notify to the external bus master that the bus<br>cycle to the internal DRAM has been completed. |
|                            | HREQ     | hold                         | input         | Bus right request input pin of the system bus. When HREQ is an "L" level, the M32000D4AFP switches to the hold state.                                                                                                                                                                                                                                                                                   |
|                            | HACK     | hold<br>acknowledge          | output        | Indicates that the M32000D4AFP has switched to the hold state<br>and releases the bus right of the system bus to the requestor.                                                                                                                                                                                                                                                                         |
|                            | ĊŚ       | chip<br>select               | input         | Signal input to the M32000D4AFP when it is in the hold state to<br>request access to the internal DRAM from an external bus master.<br>When an "L"level is input to CS, the M32000D4AFP access<br>accesses the internal DRAMat the address input via the address<br>pins.                                                                                                                               |
| interrupt<br>controller    | SBI      | system<br>break<br>interrupt | input         | System break interrupt input pin. The SBI is not masked by the IE bit in the PSW register. It is also used to return from CPU sleep mode and to request the start of operation in slave mode.                                                                                                                                                                                                           |
|                            | INT      | external<br>interrupt        | input         | External interrupt request input pin. It is also used to return from CPU sleep mode and to request the start of operation the slave mode.                                                                                                                                                                                                                                                               |
| programm-<br>able I/O port | PP0, PP1 | port                         | I/O           | Two programmable I/O ports.                                                                                                                                                                                                                                                                                                                                                                             |

### **PIN DESCRIPTION (3/3)**

\* The  $\overline{\text{DC}}$  pin becomes an output pin when the  $\overline{\text{CS}}$  signal is input to the M32000D4AFP.



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

#### FUNCTIONAL DESCRIPTION CPU

The M32R CPU has 16 general-purpose registers, 5 control registers, an accumulator and a program counter. The accumulator is of 64-bit width. The registers and program counter are of 32-bit width.

#### **General-purpose registers**

The 16 general-purpose registers (R0 - R15) are of 32-bit width and are used to retain data and base addresses. R14 is used as the link register and R15 as the stack pointer (SPI or SPU). The link register is used to store the return address when executing a subroutine call instruction. The interrupt stack pointer (SPI) and the user stack pointer (SPU) are alternatively represented by R15 depending on the value of the stack mode bit (SM) in the processor status word register (PSW).



Fig. 1 General-purpose registers

### **Control registers**

There are 5 control registers which are the processor status word register (PSW), the condition bit register (CBR), the interrupt stack pointer (SPI), the user stack pointer (SPU) and the backup PC (BPC). The **MVTC** and **MVFC** instructions are used for writing and reading these control registers.





# M32000D4AFP

SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

#### Processor status word register: PSW (CR0)

The processor status word register (PSW) shows the M32R CPU status. It consists of the current PSW field, and the BPSW field where a copy of the PSW field is saved when EIT occurs.

The PSW field is made up of the stack mode bit (SM), the interrupt enable bit (IE) and the condition bit (C). The BPSW field is made up of the backup stack mode bit (BSM), the backup interrupt enable bit (BIE) and the backup condition bit (BC).



Fig. 3 Processor status word register



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

#### **Condition bit register**

The condition bit register (CBR) is a separate read-only register which contains a copy of the current value of the condition bit (C) in the PSW. An attempt to write to the CBR with the **MVTC** instruction is ignored.

#### Interrupt stack pointer, User stack pointer

The interrupt stack pointer (SPI) and the user stack pointer (SPU) retain the current stack address. The SPI and SPU can be accessed as the general-purpose register R15. R15 switches between representing the SPI and SPU depending on the value of the stack mode bit (SM) in the PSW.

#### Backup PC

The backup PC (BPC) is the register where a copy of the PC value is saved when EIT occurs. Bit 31 is fixed at "0". When EIT occurs, the PC value immediately before EIT occurrence or that of the next instruction is set. The value of the BPC is reloaded to the PC when the **RTE** instruction is executed. However, the values of the lower 2 bits of the PC become "00" on returning (It always returns to the word boundary).



Fig. 4 Condition bit register, interrupt stack pointer, user stack pointer and backup PC



# M32000D4AFP

SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

#### Accumulator

The accumulator (ACC) is a 64-bit register used for DSP type functions. Use the **MVTACHI** and **MVTACLO** instructions for writing to the accumulator. The high-order 32 bits (bit 0 - bit 31) can be set with the **MVTACHI** instruction and the low-order 32 bits (bit 32 - bit 63) can be set with the **MVTACLO** instruction. Use the **MVFACHI**, **MVFACLO** and **MVFACMI** instructions for reading from the accumulator. The high-order 32 bits (bit 0 - bit 31) are read with the **MVFACHI** instruction, the low order 32 bits (bit 32 - bit 63) with the **MVFACLO** instruction and the middle 32 bits (bit 16 - bit 47) with the **MVFACMI** instruction.

#### **Program counter**

The program counter (PC) is a 32-bit counter that retains the address of the instruction being executed. Since the M32R CPU instruction starts with even-numbered addresses, the LSB (bit 31) is always "0".



Fig. 5 Accumulator



Fig. 6 Program counter



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

### Data types

Signed and unsigned integers of byte (8 bits), halfword (16 bits), and word (32 bits) types are supported as data in the M32R CPU instruction set. A signed integer is represented in a 2's complement format.



#### Data formats

Data size of a register of the M32R CPU is always a word (32 bits). Byte (8 bits) and halfword (16 bits) data in memory are sign-extended (the LDB and LDH instructions) or zero-extended (the LDUB and LDUH instructions) to 32 bits, and loaded into the register.

Word (32 bits) data in a register is stored to memory by the **ST** instruction. Halfword (16 bits) data in the LSB side of a register is stored to memory by the **STH** instruction. Byte (8 bits) data in the LSB side of a register is stored to memory by the **STB** instruction.

Data stored in memory can be one of these types: byte (8 bits), halfword (16 bits) or word (32 bits).

Although the byte data can be located at any address, the halfword data and the word data can only be located on the halfword boundary and the word boundary, respectively. If an attempt is made to access data in memory which is not located on the correct boundary, an address exception occurs.

Fig. 7 Data type





### M32000D4AFP

SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

#### Address space

The M32000D4AFP logical address is 32-bit wide and offers 4 GB linear space. The M32000D4AFP has address spaces allocated as shown below.

The user space is specified by SID = 0 (H'0000 0000 to H'7FFF FFFF). The area available to the user is 16 MB from address H'0000 0000 to address H'00FF FFFF.

The I/O space is specified by SID = 1 (H'8000 0000 to H'FFFF FFFF). The area available to the user is 16 MB from address H'FF00 0000 to address H'FFFF FFFF. The I/O space cannot be cached.

#### These areas below are allocated in each space.

- User space
  - internal DRAM area
- external area
- I/O space user I/O area system area internal I/O area





SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

The internal DRAM (2 MB) is allocated from address H'0000 0000 to address H'001F FFFF. The EIT vector entry (other than the reset interrupt) is allocated in the address H'0000 0000 to address H'0000 008F of this area.

The internal DRAM is connected to the M32R CPU via a 4 KB cache memory with a 128-bit bus. When the M32000D4AFP is in the hold state, the internal DRAM can be accessed from an external bus master by inputting control signals.

The external area consists of 14 MB from address H'0020 0000 to address H'00FF FFFF. When this space is accessed, the control signals to access external devices are output. The bottom 16 bytes in this area (H'00FF FFF0 to H'00FF FFFF) are the reset interrupt EIT vector entry.

The user I/O area is 8 MB from address H'FF00 0000 to address H'FF7F FFFF. When this space is accessed, the control signals to access external devices are output. The system area is 4 MB from address H'FF80 0000 to address H'FFBF FFFF. This area is reserved for development tools such as in-circuit emulators or debug monitors. The user cannot use this area.

The internal I/O area is 4 MB from address H'FFC0 0000 to address H'FFFF FFFF. The memory controller and programmable I/O port registers are allocated in this area.



Fig. 10 Internal I/O space memory map



### M32000D4AFP

#### SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

#### EIT

While the CPU is executing a program, sometimes it is necessary to suspend execution, because a certain event occurs, and execute another program. These kinds of events are referred to as EIT (Exception, Interrupt, Trap).

Exception

The event is related to the context being executed. It is generated by errors or violations that occur during instruction execution. With the M32000D4AFP, the address exception (AE) and reserved instruction exception (RIE) are of this type.

Interrupt

The event is not related to the context being executed. It is generated by an external hardware signal. With the M32000D4AFP, the external interrupt (EI), system break interrupt (SBI), wakeup interrupt (WI) and reset interrupt (RI) are of this type.

#### • Trap

This is a software interrupt which is generated by executing the TRAP instruction. It is intentionally added to the program by the programmer, as a system call.



Fig. 11 EIT events

EIT events are shown below.

• Reserved instruction exception (RIE)

The reserved instruction exception (RIE) occurs when execution of a reserved instruction (unimplemented instruction) is detected.

Address exception (AE)

The address exception (AE) occurs if an attempt is made to access an unaligned address with either a load instruction or a store instruction.

#### • Reset interrupt (RI)

The reset interrupt (RI) is always accepted when the  $\overrightarrow{\text{RST}}$  signal is input. It has the highest priority.

• Wakeup interrupt (WI)

The wakeup interrupt (WI) is accepted when the WKUP signal is input while the M32000D4AFP is in standby mode. It is only used to return from standby mode.

• System break interrupt (SBI)

The system break interrupt (SBI) is an interrupt request from the SBI pin. It is used when a break in power source or an error from an external watchdog timer is detected. It is also used to return from CPU sleep mode and to start an M32000D4AFP set to slave mode. • External interrupt (EI)

The external interrupt (EI) is an interrupt request from the INT pin. It is used by an interrupt from the external peripheral I/O and can be masked by the IE bit in the PSW register. It is also used to return from CPU sleep mode and to start an M32000D4AFP set to slave mode.

• Trap

The trap (TRAP) is a software interrupt which is generated by executing the TRAP instruction. A total of 16 EIT vector entries are available for operands 0 to 15 of the TRAP instruction.



# M32000D4AFP

SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

#### Internal memory system

The memory system built into the M32000D4AFP has the following characteristics.

- internal 16M-bit (2M-byte) DRAM
- internal 4K-byte cache memory
- CPU, cache and internal DRAM are connected by a 128-bit bus
- selectable cache memory operation mode
  - internal instruction/data cache mode
  - instruction cache mode
  - cache-off mode

| cache control register (MCCR) < address: H'FFFF FFFF>                                                                                                        |            |                     |         |            |                           |                                              |                          |      |       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------------------|---------|------------|---------------------------|----------------------------------------------|--------------------------|------|-------|
|                                                                                                                                                              | D24        | 024 D25 D26         |         |            | D28                       | D29                                          | D30                      | D3   | 1     |
| [                                                                                                                                                            | СР         |                     |         |            |                           |                                              | CM0                      | СМ   | 1     |
|                                                                                                                                                              |            |                     |         |            |                           | <                                            | at res                   | set: | H'01> |
| D                                                                                                                                                            | D bit name |                     |         |            | ction                     |                                              |                          | R    | W     |
| 24                                                                                                                                                           |            | CP<br>(cache purge) |         |            | no pur<br>purge           | 0                                            | 0                        |      |       |
| 25 - 2                                                                                                                                                       | 29 1       | lot ass             | signed. |            |                           |                                              |                          | 0    | X     |
| 30, 31 CM0, CM1<br>(cache mode)                                                                                                                              |            |                     |         | 01:<br>10: | cache<br>intern<br>instru | t chan<br>e-off m<br>al<br>ction/c<br>e mode | ged<br>iode<br>lata<br>e | 0    | 0     |
| $R = 0 \dots "0" \text{ when reading } R = \bigcirc \dots \text{ read enabled} \\ W = \bigcirc \dots \text{ write enabled } W = X : \text{ write disabled} $ |            |                     |         |            |                           |                                              |                          |      |       |

Fig. 12 Cache control register

When the internal instruction/data cache mode is selected, the cache memory functions as a cache for both instruction and data from the internal DRAM, and caches all bus access to the DRAM. This mode is for a system which uses the internal DRAM as main memory. Transfer between the M32R CPU, cache memory and internal DRAM is always carried out in blocks of 128 bits. Caching is carried out by the direct map method. Writing is by the copy back method.

When the M32000D4AFP access destination is an external space, data transfer between the M32R CPU and the external device is carried out via the bus interface unit (BIU). The BIU has a 128-bit data buffer which converts the bus width between the 128-bit bus in the M32000D4AFP and the external bus. Caching is not applicable in this case of data transfer.

When accessing the internal DRAM from an external bus master, and a cache hit occurs (the accessed data is inside the cache), data transfer between the cache memory and the external bus via the BIU is carried out. When a cache miss occurs, (the accessed data is not inside the cache) data transfer is carried out between the internal DRAM and the external bus via the BIU without cache replacement.



Fig. 13 Internal instruction/data cache mode



### MITSUBISHI MICROCOMPUTERS M32000D4AFP

SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

When the instruction cache mode is selected, the cache functions as an instruction cache for the internal DRAM or the external memory, and caching is carried out for instruction fetch access. This mode is designed for use when an external ROM is used as program memory and the internal DRAM is used as data memory, or when instructions are located in the internal DRAM. Caching is carried out by the direct map method. When instruction codes in the user space are overwritten by the external bus master or another source, instruction code coherency in the cache memory is not guaranteed. Furthermore, caching is not applied when accessing the internal DRAM from the external bus master.



When the cache-off mode is selected, the M32000D4AFP internal memory system is configured as follows. In this mode, caching is not applied, and all bus cycles are directly to the internal DRAM or external bus.



Fig. 15 Cache-off mode

Fig. 14 Instruction cache mode



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

#### Bus interface unit (BIU)

The M32000D4AFP has the following signals related to the external bus.

Address (A8 to A30)

The M32000D4AFP has a 24-bit address bus (A8 to A31) corresponding to a 16 MB address space. Of these, A31 (the LSB) is not output externally. In write cycles, the validity of the two bytes output on the 16-bit data bus is indicated by  $\overrightarrow{\text{BCH}}$  and/or  $\overrightarrow{\text{BCL}}$ . In read cycles, the 16-bit data bus is always read, however, only data in the valid byte position in the M32000D4AFP is transferred. The address pins are bidirectional. If the M32000D4AFP is in the hold state and the internal DRAM is accessed from an external bus master, the address signal is input from the system bus side.

• Space identifier (SID)

The space identifier is used to specify user space and I/O space.

user space: SID = "L" I/O space: SID = "H" hold: SID = high-impedance idle: SID = undefined

• Byte control (BCH, BCL)

Byte control signals indicate the byte position of valid data transferred of the external bus cycle. BCH corresponds to the MSB side (D0 to D7), and BCL corresponds to the LSB side (D8 to D15). During the bus read cycle, both BCH and BCL are an "L" level. During the bus write cycle, BCH and/or BCL go to an "L" level depending on the bytes to be written. If the M32000D4AFP is in the hold state and the internal DRAM is accessed from an external bus master, the byte control signal is input from the system bus side.

• Data bus (D0 to D15)

The M32000D4AFP has a 16-bit data bus to access external devices. If the M32000D4AFP is in the hold state and the internal DRAM is accessed from an external bus master, the data bus is used as a data I/O bus from the system bus side.

• Bus start (BS)

When the M32000D4AFP drives the bus cycle to the system bus, an "L" level is output to  $\overrightarrow{BS}$  at the start of the bus cycle. Also, for a burst transfer, the  $\overrightarrow{BS}$  signal is output for each transfer cycle. The  $\overrightarrow{BS}$  signal is not output when accessing internal resources such as the internal DRAM or internal I/O registers.

#### • Bus status (ST)

The ST signal identifies whether the bus cycle the M32000D4AFP is driving is an instruction fetch cycle or an operand access cycle.

instruction fetch access: ST = "L"

operand access: ST = "H" hold: ST = high-impedance

idle: ST = undefined

• Read/write (R/W)

The M32000D4AFP outputs a R $\overline{W}$  signal to identify whether the external bus cycle is a read or write operation. When accessing the internal DRAM from an external bus master, a R $\overline{W}$  signal is input from the system bus side.

read bus cycle: R/W = "H"write bus cycle: R/W = "L"

#### • Burst (BURST)

The M32000D4AFP drives two consecutive bus cycles to access 32bit data located on the 32-bit boundary. In instruction fetching, it drives a maximum of 8 (fixed to 8 cycles in instruction cache mode) consecutive read cycles to access data located on the 128-bit boundary. While driving these consecutive bus cycles, the M32000D4AFP outputs "L" level to BURST. When accessing 32-bit data, the address of the MSB-side 16 bits are output before the address of the LSB side 16 bits. When accessing 128-bit data, the addresses are output for every access cycle from the arbitrary 16-bit aligned addresses to wraparound within the 128-bit boundary.

Data complete (DC)

When starting an external bus cycle, the M32000D4AFP automatically inserts wait cycles until the  $\overline{DC}$  signal is input from external. Wait control using the  $\overline{DC}$  signal is effective also for bus cycles during burst transfer. When the M32000D4AFP is in the hold state and if the  $\overline{CS}$  signal is input, the M32000D4AFP outputs the  $\overline{DC}$  signal to notify the external bus master that internal DRAM access is complete.

#### • Hold control (HREQ, HACK)

The hold state is the state when the external bus access stops and all pins go to a high-impedance state. However, the internal DRAM can be accessed while the external bus is in the hold state. To put the M32000D4AFP into the hold state, input an "L" level to  $\overline{\text{HREQ}}$ . When the hold request is accepted and the M32000D4AFP enters the hold state, an "L" level is output from  $\overline{\text{HACK}}$ .



### M32000D4AFP

SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

• Internal DRAM access control (CS)

The internal DRAM can be accessed when  $\overline{CS}$  is driven to an "L" level after the M32000D4AFP enters the hold state ( $\overline{HACK} =$  "L"). To access the internal DRAM from external, the following signals from the system bus side should be controlled.

• A8 to A30

Input internal DRAM addresses to be read or written.

• BCH, BCL

Specify the byte position of data to be written into the internal DRAM.  $\overrightarrow{BCH}$  corresponds to the MSB side (D0 to D7), and  $\overrightarrow{BCL}$  corresponds to the LSB side (D8 to D15).

• R/W

Specify read or write operation. When reading,  $R/\overline{W} = "H"$ . When writing,  $R/\overline{W} = "L"$ .

• D0 to D15

- 16-bit data I/O bus.
- DC

This signal notifies to an external bus master that the internal DRAM access is complete. When access is complete, an "L" level is output to  $\overline{\text{DC}}$ .

#### Table 1 Pin condition in hold state

| pin name                                         | pin condition or operation                                                                                                                     |
|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| A8 - A30, SID,<br>BCH, BCL<br>ST, R/W, BS, BURST | high-impedance                                                                                                                                 |
| D0 - D15                                         | output when internal DRAM is read<br>by an external bus master ( $\overline{CS} = "L"$ ,<br>$\overline{R/W} = "H"$ ), otherwise high-impedance |
| DC                                               | output when internal DRAM is<br>accessed by an external bus master<br>(CS = "L"), otherwise high-impedance                                     |
| HACK                                             | output "L"                                                                                                                                     |
| other pins                                       | normal operation                                                                                                                               |

Read and write operations of the M32000D4AFP are carried out using the address bus, data bus, and the R/ $\overline{W}$ ,  $\overline{BCH}$ ,  $\overline{BCL}$  and  $\overline{DC}$  signals. When reading, the R/ $\overline{W}$  signal goes to an "H" level, and the  $\overline{BCH}$  and  $\overline{BCL}$  signals go to an "L" level. The CPU reads the data in the valid byte positions. When writing, an "L" level is output from R/ $\overline{W}$ , and  $\overline{BCH}$  and  $\overline{BCL}$  are output according to the valid byte positions, so as to specify the byte positions for writing into an external device.



Fig. 16 Read/write timing (two no-wait accesses)



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

When an "L" level is input to  $\overrightarrow{DC}$ , the next bus cycle is processed and wait cycles are inserted until this point. When a write cycle comes immediately after a read cycle, the M32000D4AFP inserts an idle cycle to prevent a collision with data on the system bus. The same applies to write cycles (burst write access) immediately after a burst read cycle.



Fig. 17 Read/write timing (two one-wait accesses)



Fig. 18 Automatic idle cycle insertion between consecutive read and write cycles



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

The M32000D4AFP outputs the BURST signal and carries out a burst transfer when reading "the word-size data aligned on the 32-bit boundary" or "a maximum 4 words of instructions aligned on the 128-bit boundary". The BURST signal is synchronized with the CLKIN falling edge of the first bus access cycle and output "L" level. It returns to an "H" level synchronized with the first CLKIN falling edge of the last bus access cycle. Addresses A8 to A30 are output for each cycle. When burst reading 32-bit data, the MSB-side 16-bit read bus cycle is carried out first followed by the LSB-side 16-bit read bus cycle. When the cache memory operation mode is the instruction cache mode, and burst reading of the instructions within the 128-bit boundary for cache replacement occurs, the bus cycle is driven a fixed 8 times from an arbitrary 32-bit boundary address and to wraparound within the 128-bit boundary. When other than the instruction cache mode is selected and burst reading a set of instructions of less than

128 bits, consecutive bus cycles are driven from an arbitrary 32-bit

boundary address as the top to the 128-bit line (A28 to A30 = "111").



Fig. 19 1-word (32-bit) burst read timing (1-0 wait)



Fig. 20 4-word (128-bit) burst read timing (1-0-0-0-0-0 wait)



### MITSUBISHI MICROCOMPUTERS M32000D4AFP

SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

When writing word-size data aligned on the 32-bit boundary, the M32000D4AFP carries out a burst-transfer by outputting the BURST signal. When burst-writing 32-bit data, the MSB-side 16-bit write bus cycle is driven first, followed by the LSB-side 16-bit write bus cycle. The BURST signal is synchronized with the CLKIN falling edge of the first bus access cycle, and "L" level is output. It returns to "H" level in synchronization with the CLKIN falling edge of the last bus access cycle. Addresses A8 to A30 are output for each cycle.



Fig. 21 1-word (32-bit) burst write timing (1-0 wait)

When an "L" level is input to  $\overrightarrow{\text{HREQ}}$ , the M32000D4AFP switches to the hold state and outputs an "L" level to  $\overrightarrow{\text{HACK}}$ . While the M32000D4AFP is in the hold state, bus related pins go to a high impedance state, and data transfer is carried out on the system bus. To return to normal operation mode from the hold state, the  $\overrightarrow{\text{HREQ}}$  signal should be changed to an "H" level.



Fig. 22 Bus arbitration timing



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

When the M32000D4AFP is in the hold state and an "L" level is input to CS, the M32000D4AFP interprets it as a bus access request to the internal DRAM. In this case, when the R/W signal is an "H" level, the memory controller drives a read cycle to the internal DRAM. In the read cycle, the 16-bit data for the address specified with A8 to A30, is output from D0 to D15 regardless of the BCH and BCL settings. Also the DC signal is output.

The M32000D4AFP reads 128 bits of data from the block on the 128-bit boundary including the requested address into the 128-bit buffer of the bus interface unit. 3 to 7 CLKIN clock periods are necessary for the first bus access, however, when reading consecutive address within the 128-bit boundary, the subsequent read bus cycles are completed in 1 CLKIN clock period because a read from the internal DRAM does not take place.

Once the external bus master read cycle has been driven, it cannot be aborted. When an "L" level is input to  $\overline{\text{CS}}$  and an access has started, the values of this and other control signals should be held during the wait cycles (that is while  $\overline{DC} = "H"$ ). After  $\overline{DC}$  outputs an "L" level (access complete), return CS to the "H" level between the CLKIN falling edge corresponding to the last read cycle and the following CLKIN falling edge. Return HREQ to the "H" level to return the M32000D4AFP to the normal operation mode from the hold state either at the same time as or after CS is returned to the "H" level.



Fig. 23 Read bus cycle to internal DRAM



# MITSUBISHI MICROCOMPUTERS M32000D4AFP

#### SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

When the M32000D4AFP is in the hold state and an "L" level is input to CS, the M32000D4AFP interprets it as a bus access request to the internal DRAM. In this case, when the R/W signal is at an "L" level, the memory controller drives a write cycle to the internal DRAM. Byte data control is specified by the BCH and BCL signals. Only data in the byte positions for which an "L" level is input to BCH or BCL are written. When writing is complete, an "L" level DC signal is output. The M32000D4AFP stores the requested data in the 128-bit data buffer of the BIU, before writing to the internal DRAM. This reduces the number of accesses to the internal DRAM when a request to writing to consecutive addresses is made, and improves bus cycle throughput. Consecutive write cycles within an 128-bit boundary are completed in 1 CLKIN clock period. 3 to 7 CLKIN clock periods are necessary for a write access crossing an 128-bit boundary when writing to the internal DRAM. Once the external bus master write cycle has been driven, it cannot be aborted. When an "L" level is input to CS and an access has started, the values of this and other control signals should be held during the wait cycles (that is while DC = "H"). After  $\overline{DC}$  outputs an "L" level (access complete), return  $\overline{CS}$  to the "H" level between the CLKIN falling edge corresponding to the last write cycle and the following CLKIN falling edge. Return HREQ to the "H" level to return the M32000D4AFP to the normal operation mode from the hold state either at the same time as or after CS is returned to the "H" level.



Fig. 24 Write bus cycle to internal DRAM

When the external bus master makes an access, the value of the R/W signal that controls the data direction of the bus interface cannot be changed during  $\overline{CS}$ ="L". Therefore, read cycles and write cycles cannot be mixed while  $\overline{CS}$  = "L". When starting a write cycle following after a read cycle and starting a read cycle following a write cycle, keep the  $\overline{CS}$  signal at an "H" level for at least 1 CLKIN.



Fig. 25 Read/write bus cycle



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

### Master/slave mode

The M32000D4AFP has an  $\text{M}/\overline{\text{S}}$  (master/slave) pin for multiprocessor configuration use.

master mode (M/S = "H")

This is normal operation mode. Set the  $M/\overline{S}$  pin to an "H" level. It is used when the M32000D4AFP is used as the main CPU in a system. • slave mode ( $M/\overline{S}$  = "L")

This operation mode is for when the M32000D4AFP is used as a coprocessor. Set the  $M/\overline{S}$  pin to an "L" level. When set to slave mode, the M32000D4AFP does not start operation even after a reset, until an interrupt request or the SBI is input. Processing is carried out by communicating with the master M32000D4AFP, using the two programmable I/O ports and the external interrupt signal.



Fig. 26 Lock control register

· Coprocessor only configuration example

The slave M32000D4AFP accesses only the internal DRAM and never the external bus. M/S and HREQ are fixed at the "L" level. The slave M32000D4AFP executes the instructions that the master M32000D4AFP downloads to the internal DRAM. The data transfer request (processing complete) from the slave M32000D4AFP is notified to the master M32000D4AFP by inputting the interrupt request via the programmable I/O port. The data transaction is carried out when the master M32000D4AFP accesses the internal DRAM in the slave M32000D4AFP.

Common bus coprocessor configuration example

In this configuration, the slave M32000D4AFP can also access the external bus. Communications between the master and slave CPUs is carried out using the programmable I/O ports and the interrupt request input.



Fig. 27 Master/slave system configuration example



# M32000D4AFP

SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

#### **Power management function**

The M32000D4AFP has the following two low-power consumption modes.

- standby mode
- CPU sleep mode

| power management (MPMR) < address: H'FFFF FFFB>                                                                              |      |                                                                                                                                                                                                    |     |     |     |     |                                                      |       |       |
|------------------------------------------------------------------------------------------------------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-----|-----|------------------------------------------------------|-------|-------|
|                                                                                                                              | D24  | D25                                                                                                                                                                                                | D26 | D27 | D28 | D29 | D30                                                  | D31   |       |
|                                                                                                                              |      |                                                                                                                                                                                                    |     |     |     |     | PM0                                                  | PM1   | ]     |
|                                                                                                                              |      |                                                                                                                                                                                                    |     |     |     |     | <at r<="" td=""><td>eset:</td><td>H'00&gt;</td></at> | eset: | H'00> |
| D                                                                                                                            |      | bit name function                                                                                                                                                                                  |     |     |     |     |                                                      | २     | W     |
| 24 ·                                                                                                                         | - 29 | Not assigned. 0 X                                                                                                                                                                                  |     |     |     |     |                                                      | x     |       |
| 30,                                                                                                                          | 31   | PM0, PM1     00: normal     O       (low power     operation     O       consumption     mode     01: (reserved)       mode     10: CPU sleep     mode       11: standby mode     11: standby mode |     |     |     |     |                                                      |       | 0     |
| $R = 0 \dots$ "0" when reading $R = \bigcirc \dots$ read enabled $W = \bigcirc \dots$ write enabled $W = X$ : write disabled |      |                                                                                                                                                                                                    |     |     |     |     |                                                      |       |       |

Fig. 28 Power management control register

In standby mode, all clock supply stops and only the contents of the internal DRAM are retained. The power requirement is only that which the internal DRAM needs for refreshing itself. When set to standby mode, the M32000D4AFP waits for the current bus operation to be completed. It then purges the cache memory and switches the internal DRAM to self-refresh mode. After that, the PLL and all clock supplies stop and the STBY signal goes to an "L" level to indicate the completion of the switch to standby mode. Input an "L" level to WKUP or  $\overline{\text{RST}}$  to return from standby mode to normal operation mode. The contents of the internal DRAM are retained upon return using the  $\overline{\text{WKUP}}$  signal.

In CPU sleep mode, clock supply to the M32R CPU stops. In this mode, the internal DRAM, cache memory, memory controller and external bus interface continue to operate and the internal DRAM can be accessed from the external bus. Input an "L" level to  $\overline{INT}$ ,  $\overline{SBI}$  or  $\overline{RST}$  to return to normal operation mode from CPU sleep mode. The contents of the cache memory, internal DRAM, general-purpose registers and programmable I/O control register are retained upon return using the  $\overline{INT}$  or  $\overline{SBI}$  signals.





# M32000D4AFP

SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

### Programmable I/O port

The M32000D4AFP has two programmable I/O ports (PP0, PP1). Each port can be set as input or output.

| prog | programmable I/O port direction control register 0 (PPCR0)<br>< address: H'FFFF FFE3>                        |        |        |     |     |        |                                                         |         |       |
|------|--------------------------------------------------------------------------------------------------------------|--------|--------|-----|-----|--------|---------------------------------------------------------|---------|-------|
|      | D24                                                                                                          | D25    | D26    | D27 | D28 | D29    | D30                                                     | D31     |       |
|      |                                                                                                              |        |        |     |     |        |                                                         | PP0C    | ]     |
| prog | programmable I/O port direction control register 1 (PPCR1)<br>< address: H'FFFF FFE7>                        |        |        |     |     |        |                                                         |         |       |
|      | D24                                                                                                          | D25    | D26    | D27 | D28 | D29    | D30                                                     | D31     | 1     |
|      |                                                                                                              |        |        |     |     |        |                                                         | PP1C    |       |
|      |                                                                                                              |        |        |     |     |        | <at re<="" td=""><td>eset: H</td><td>1'00&gt;</td></at> | eset: H | 1'00> |
| D    |                                                                                                              | bit na | me     |     | fur | oction |                                                         | R       | W     |
| 24 · | - 30                                                                                                         | Not as | ssigne | d.  |     |        |                                                         | 0       |       |
| 31   |                                                                                                              |        |        |     |     |        |                                                         |         |       |
|      | $R = 0 \dots$ "0" when reading $R = 0 \dots$ read enabled $W = 0 \dots$ write enabled $W = 1$ write disabled |        |        |     |     |        |                                                         |         |       |

| progi             | rogrammable I/O port data register 0 (PPDR0)<br>< address: H'FFFF FFEB>                                                                          |        |        |     |     |        |         |      |      |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|-----|-----|--------|---------|------|------|
|                   | D24                                                                                                                                              | D25    | D26    | D27 | D28 | D29    | D30     | D31  |      |
|                   |                                                                                                                                                  |        |        |     |     |        |         | PP0D |      |
| progi             | programmable I/O port data register 1 (PPDR1)<br>< address: H'FFFF FFEF>                                                                         |        |        |     |     |        |         |      | FEF> |
|                   | D24                                                                                                                                              | D25    | D26    | D27 | D28 | D29    | D30     | D31  | -    |
|                   |                                                                                                                                                  |        |        |     |     |        |         | PP1D |      |
|                   |                                                                                                                                                  |        |        |     |     |        | et: B'0 |      |      |
| <u>D</u>          |                                                                                                                                                  | bit na | -      |     | fur | nction |         | R    | W    |
| <u>24</u> -<br>31 | • 30                                                                                                                                             |        | ssigne |     | 0.  | data   | "0"     | 0    |      |
| 31                | PP0D, PP1D 0: data = "0" (<br>(port data) 1: data = "1"                                                                                          |        |        |     |     |        |         | 0    | 0    |
|                   | $R = 0 \dots \text{ "0" when reading } R = 0 \dots \text{ read enabled}$ $W = 0 \dots \text{ write enabled } W = 0 \dots \text{ write disabled}$ |        |        |     |     |        |         |      |      |

Fig. 31 Programmable I/O port data register

### Reset

When an "L" level is input to RST, the M32000D4AFP switches to the reset state. The reset state is released when an "H" level is input to RST, and the program is executed from the EIT vector entry of the reset interrupt. All internal resources including the internal PLL (4x clock generator) are initialized. In order to stabilize PLL oscillation, the "L" input to RST should last a minimum of 2 ms after the clock input to CLKIN stabilizes and VCC stabilizes to the specified voltage level.

#### Table 2 Internal state after reset

| internal resource                          | es                           | state                                                                                                                                                                                  |  |  |  |  |
|--------------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| DRAM                                       |                              | undefined                                                                                                                                                                              |  |  |  |  |
| cache memory                               |                              | invalid<br>(purged all)                                                                                                                                                                |  |  |  |  |
| general purpose<br>registers<br>(R0 - R15) | )                            | undefined                                                                                                                                                                              |  |  |  |  |
| control registers                          | PSW (CR0)                    | B'0000 0000 0000 0000 ??00 000? 0000 0000<br>(BSM, BIE, and BC are undefined)                                                                                                          |  |  |  |  |
|                                            | CBR (CR1)                    | H'0000 0000                                                                                                                                                                            |  |  |  |  |
|                                            | SPI (CR2)                    | undefined                                                                                                                                                                              |  |  |  |  |
|                                            | SPU (CR3)                    | undefined                                                                                                                                                                              |  |  |  |  |
|                                            | BPC (CR6)                    | undefined                                                                                                                                                                              |  |  |  |  |
|                                            | PC                           | master mode:<br>execute from address H'7FFF FFF0<br>slave mode:<br>wait for interrupt input at address<br>H'7FFF FFF0<br>• execute from address H'0000 0010<br>by inputting SBI signal |  |  |  |  |
|                                            |                              | execute from address H'0000 0080     by inputting INT signal                                                                                                                           |  |  |  |  |
|                                            | ACC                          |                                                                                                                                                                                        |  |  |  |  |
|                                            | (accumulator)                |                                                                                                                                                                                        |  |  |  |  |
| I/O registers                              | PPCR0, PPCR1<br>PPDR0, PPDR1 | H'00 (input)<br>B'0000 000? (depends on input<br>pin state)                                                                                                                            |  |  |  |  |
|                                            | MLCR                         | H'00 (HREQ exclusive lock mode)                                                                                                                                                        |  |  |  |  |
|                                            | MPMR                         | H'00 (normal operation)                                                                                                                                                                |  |  |  |  |
|                                            | MCCR                         | H'01 (cache-off mode)                                                                                                                                                                  |  |  |  |  |



28

Fig. 30 Programmable I/O port direction control register

SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

#### **Clock generating circuit**

The M32000D4AFP has a clock multiplier circuit and operates at four times the input frequency. The internal operation frequency becomes 66.6 MHz when a 16.65 MHz clock is input to CLKIN. A capacitor (C) should be connected to the PLLCAP pin, and the clock is input to the CLKIN pin. The PLLVCC and PLLVSS pins should be connected to the power source or the ground, respectively.



Fig. 32 Oscillation circuit

#### ADDRESSING MODE

M32R family supports the following addressing modes.

< register direct >

The general-purpose register or the control register to be processed is specified.

< register indirect >

The contents of the register specify the address in memory to be accessed. This mode can be used by all load/store instructions. < register relative indirect >

(The contents of the register) + (16-bit immediate value which is signextended to 32 bits) specify the address in memory to be accessed. < register indirect and register update >

- 4 is added to the register contents (the contents of the register before update specify the address in memory to be accessed) [LD instruction]
- 4 is added to the register contents (the contents of the register after update specify the address in memory to be accessed) [ST instruction]
- 4 is subtracted from the register contents (the contents of the register after update specify the address in memory to be accessed) [ST instruction]

< immediate >

The 4-, 5-, 8-, 16- or 24-bit immediate value.

< PC relative >

(The contents of PC) + (8, 16, or 24-bit displacement which is signextended to 32 bits and 2 bits left-shifted) specify the address in memory to be accessed.



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

### **INSTRUCTION FORMAT**

There are two major instruction formats: two 16-bit instructions packed together within a word boundary, and a single 32-bit instruction.

| op1             | R1        | op2 | R2       | R1 = R1 op R2           |                |
|-----------------|-----------|-----|----------|-------------------------|----------------|
| op1             | R1        | (   | ;        | R1 = R1 op c            |                |
| op1             | cond      | (   | ;        | Branch (Short Displacen | nent)          |
|                 |           |     |          |                         |                |
| 2-bit in        | structior | 1>  |          |                         |                |
| 2-bit in<br>op1 | R1        | op2 | R2       | c                       | ] R1 = R2 op c |
|                 | 1         |     | R2<br>R2 | C                       | R1 = R2 op c   |
| op1             | R1        | op2 |          | -                       | _              |

Fig. 33 Instruction format

#### **INSTRUCTION SET**

A total of 83 instructions are implemented.

<Load/store instructions>

The load/store instructions carry out data transfers between a register and a memory.

| LD     | Load                   |
|--------|------------------------|
| LDB    | Load byte              |
| LDUB   | Load unsigned byte     |
| LDH    | Load halfword          |
| LDUH   | Load unsigned halfword |
| LOCK   | Load locked            |
| ST     | Store                  |
| STB    | Store byte             |
| STH    | Store halfword         |
| UNLOCK | Store unlocked         |

#### <Transfer instructions>

The transfer instructions carry out data transfers between registers or a register and an immediate value.

| LD24 | Load 24-bit immediate      |
|------|----------------------------|
| LDI  | Load immediate             |
| MV   | Move register              |
| MVFC | Move from control register |
| MVTC | Move to control register   |
| SETH | Set high-order 16-bit      |
|      |                            |

<Operation instructions>

Compare, arithmetic/logic operation, multiply and divide, and shift

are carried out between registers.

| <ul> <li>compare instructions</li> </ul> |                                 |  |  |  |  |
|------------------------------------------|---------------------------------|--|--|--|--|
| CMP                                      | Compare                         |  |  |  |  |
| CMPI                                     | Compare immediate               |  |  |  |  |
| CMPU                                     | Compare unsigned                |  |  |  |  |
| CMPUI                                    | Compare unsigned immediate      |  |  |  |  |
| <ul> <li>arithmetic operation</li> </ul> | eration instructions            |  |  |  |  |
| ADD                                      | Add                             |  |  |  |  |
| ADD3                                     | Add 3-operand                   |  |  |  |  |
| ADDI                                     | Add immediate                   |  |  |  |  |
| ADDV                                     | Add with overflow checking      |  |  |  |  |
| ADDV3                                    | Add 3-operand                   |  |  |  |  |
| ADDX                                     | Add with carry                  |  |  |  |  |
| NEG                                      | Negate                          |  |  |  |  |
| SUB                                      | Subtract                        |  |  |  |  |
| SUBV                                     | Subtract with overflow checking |  |  |  |  |
| SUBX                                     | Subtract with borrow            |  |  |  |  |



#### SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

| <ul> <li>logic operation instructions</li> </ul> |                                  |  |  |  |  |
|--------------------------------------------------|----------------------------------|--|--|--|--|
| AND                                              | AND                              |  |  |  |  |
| AND3                                             | AND 3-operand                    |  |  |  |  |
| NOT                                              | Logical NOT                      |  |  |  |  |
| OR                                               | OR                               |  |  |  |  |
| OR3                                              | OR 3-operand                     |  |  |  |  |
| XOR                                              | Exclusive OR                     |  |  |  |  |
| XOR3                                             | Exclusive OR 3-operand           |  |  |  |  |
| <ul> <li>multiply/divide</li> </ul>              | e instructions                   |  |  |  |  |
| DIV                                              | Divide                           |  |  |  |  |
| DIVU                                             | Divide unsigned                  |  |  |  |  |
| MUL                                              | Multiply                         |  |  |  |  |
| REM                                              | Remainder                        |  |  |  |  |
| REMU                                             | Remainder unsigned               |  |  |  |  |
| <ul> <li>shift instruction</li> </ul>            | ns                               |  |  |  |  |
| SLL                                              | Shift left logical               |  |  |  |  |
| SLL3                                             | Shift left logical 3-operand     |  |  |  |  |
| SLLI                                             | Shift left logical immediate     |  |  |  |  |
| SRA                                              | Shift right arithmetic           |  |  |  |  |
| SRA3                                             | Shift right arithmetic 3-operand |  |  |  |  |
| SRAI                                             | Shift right arithmetic immediate |  |  |  |  |
| SRL                                              | Shift right logical              |  |  |  |  |
| SRL3                                             | Shift right logical 3-operand    |  |  |  |  |
| SRLI                                             | Shift right logical immediate    |  |  |  |  |
|                                                  |                                  |  |  |  |  |

<Branch instructions>

The branch instructions are used to change the program flow.

| BC   | Branch on C-bit                      |
|------|--------------------------------------|
| BEQ  | Branch on equal                      |
| BEQZ | Branch on equal zero                 |
| BGEZ | Branch on greater than or equal zero |
| BGTZ | Branch on greater than zero          |
| BL   | Branch and link                      |
| BLEZ | Branch on less than or equal zero    |
| BLTZ | Branch on less than zero             |
| BNC  | Branch on not C-bit                  |
| BNE  | Branch on not equal                  |
| BNEZ | Branch on not equal zero             |
| BRA  | Branch                               |
| JL   | Jump and link                        |
| JMP  | Jump                                 |
| NOP  | No operation                         |

<EIT-related instructions>

The EIT-related instructions carry out the EIT events (Exception, Interrupt and Trap). Trap initiation and return from EIT are EIT-related instructions.

| TRAP | Trap            |
|------|-----------------|
| RTE  | Return from EIT |

<DSP function instructions>

The DSP function instructions carry out multiplication of 32 bits  $\times$  16 bits and 16 bits  $\times$  16 bits or multiply and add operation; there are also instructions to round off data in the accumulator and carry out transfer of data between the accumulator and a general-purpose register.

| MACHI   | Multiply-accumulate high-order halfwords         |
|---------|--------------------------------------------------|
| MACLO   | Multiply-accumulate low-order halfwords          |
| MACWHI  | Multiply-accumulate word and high-order halfword |
| MACWLO  | Multiply-accumulate word and low-order halfword  |
| MULHI   | Multiply high-order halfwords                    |
| MULLO   | Multiply low-order halfwords                     |
| MULWHI  | Multiply word and high-order halfword            |
| MULWLO  | Multiply word and low-order halfword             |
| MVFACHI | Move from accumulator high-order word            |
| MVFACLO | Move from accumulator low-order word             |
| MVFACMI | Move from accumulator middle-order word          |
| MVTACHI | Move to accumulator high-order word              |
| MVTACLO | Move to accumulator low-order word               |
| RAC     | Round accumulator                                |
| RACH    | Round accumulator halfword                       |
|         |                                                  |



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

### **ABSOLUTE MAXIMUM RATINGS**

| Or weak as t | Deremeter             |              | Rat  |      |      |
|--------------|-----------------------|--------------|------|------|------|
| Symbol       | Parameter             | Conditions   | Min. | Max. | Unit |
| VCC          | Power source voltage  |              | -0.5 | 4.6  | V    |
| VI           | Input voltage         |              | -0.5 | 4.6  | V    |
| VO           | Output voltage        |              | -0.5 | 4.6  | V    |
| PD           | Power consumption     | TOPR = 25 °C |      | 1000 | mW   |
| TOPR         | Operating temperature |              | 0    | 70   | °C   |
| TSTG         | Storage temperature   |              | -65  | 150  | °C   |

### RECOMMENDED OPERATING CONDITIONS (VCC = 3.3 V ± 0.3 V, TOPR = 0 to 70 °C unless otherwise noted)

| Symbol         | Parameter            |                             |        | Unit |         |      |
|----------------|----------------------|-----------------------------|--------|------|---------|------|
| Symbol         | F                    | arameter                    | Min.   | Тур. | Max.    | Onit |
| VCC            | Power source voltage |                             | 3.0    |      | 3.6     | V    |
| VIH            | "H" input voltage    | All inputs except following | 2.0    |      | VCC+0.3 | V    |
|                |                      | RST pin                     | 0.8VCC |      | VCC+0.3 | V    |
| VIL            | "L" input voltage    | All inputs except following | -0.3   |      | 0.8     | V    |
|                |                      | RST pin                     | -0.3   |      | 0.2VCC  | V    |
| IOH (see note) | "H" output current   |                             |        |      | 2       | mA   |
| IOL (see note) | "L" output current   |                             |        |      | 2       | mA   |
| CL             | output load capacity |                             |        |      | 50      | рF   |

Note: IOH and IOL represent the maximum values of DC current load. Intermittent current that is generated during output need not to be considered as long as the output load capacity is within the specified range.



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

### DC CHARACTERISTICS ELECTRICAL CHARACTERISTICS (VCC = 3.3 V ± 0.3 V, TOPR = 0 to 70 °C unless otherwise noted)

| Symbol | Parameter                   | Test see ditions                                | Ratings |      | Unit  |    |
|--------|-----------------------------|-------------------------------------------------|---------|------|-------|----|
| Symbol | Faranielei                  | Test conditions                                 | Min.    | Тур. | Max.  |    |
| VOH    | "H" output voltage          | IOH = -2 mA                                     | 2.4     |      |       | V  |
| VOL    | "L" output voltage          | IOL = 2 mA                                      |         |      | 0.4   | V  |
| IOZ    | Output current in off state | VO = 0 to VCC                                   | -10.0   |      | 10.0  | μA |
| IIH    | "H" input current           | VIH = 0 to VCC +0.3 V                           |         |      | 10.0  | μA |
| IIL    | "L" input current           | VIH = 0 to VCC +0.3 V                           |         |      | -10.0 | μA |
| ICC    | Power source current        | Average in normal operation<br>mode VCC = 3.3 V |         | 140  | 220   | mA |
|        |                             | Average in CPU sleep mode<br>VCC = 3.3 V        |         | 100  | 170   | mA |
|        |                             | Average in standby mode<br>VCC = 3.3 V          |         |      | 2000  | μA |
| С      | Pin capacitance             | All pins                                        |         |      | 15    | pF |



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

# AC CHARACTERISTICS

TIMING REQUIREMENTS (VCC = 3.3 ± 0.3 V, CL = 50 pF, TOPR = 0 to 70 °C unless oth erwise noted)

#### (1) Input transition time

| Symbol    | Parameter                  | Testessilitieses | Limits |      |             | Reference |
|-----------|----------------------------|------------------|--------|------|-------------|-----------|
| Symbol    | Falanetei                  | Test conditions  | Min.   | Max. | Aax. Unit r | number    |
| tr(INPUT) | Input rise transition time | CMOS input       |        | 5    | ns          |           |
|           |                            | RST pin          |        | 2    | ms          |           |
| tf(INPUT) | Input fall transition time | CMOS input       |        | 5    | ns          |           |
|           |                            | RST pin          |        | 2    | ms          | 2         |

### (2) Clock, reset and wakeup timing

| Symbol     | Parameter                            | Test conditions | Li       |      | Reference |        |
|------------|--------------------------------------|-----------------|----------|------|-----------|--------|
| Symbol     |                                      | Test conditions | Min.     | Max. | Unit      | number |
| tc(CLKIN)  | Clock input cycle time               |                 | 60       | 100  | ns        | 5      |
| tw(CLKINH) | External clock input "H" pulse width |                 | 1/4CLKIN |      | ns        | 6      |
| tw(CLKINL) | External clock input "L" pulse width |                 | 1/4CLKIN |      | ns        | 7      |
| tr(CLKIN)  | External clock input rising time     |                 |          | 5    | ns        | 8      |
| tf(CLKIN)  | External clock input falling time    |                 |          | 5    | ns        | 9      |
| tw(RST)    | Reset input "L" pulse width          |                 | 2        |      | ms        | 10     |
| tw(WKUP)   | Wakeup input "L" pulse width         |                 | 2        |      | ms        | 11     |

### (3) Read and write timing

| Symbol         | Parameter                             | Test conditions |      | Limits |      | Reference |
|----------------|---------------------------------------|-----------------|------|--------|------|-----------|
| Symbol         |                                       |                 | Min. | Max.   | Unit | number    |
| tsu(D-CLKIN)   | Data input set-up time before CLKIN   |                 | 5.5  |        | ns   | 30        |
| th(CLKIN-D)    | Data input hold time after CLKIN      |                 | 2    |        | ns   | 31        |
| tsu(DCH-CLKIN) | DC input "H" set-up time before CLKIN |                 | 10   |        | ns   | 36        |
| th(CLKIN-DCH)  | DC input "H" hold time after CLKIN    |                 | 2    |        | ns   | 37        |
| tsu(DCL-CLKIN) | DC input "L" set-up time before CLKIN |                 | 10   |        | ns   | 38        |
| th(CLKIN-DCL)  | DC input "L" hold time after CLKIN    |                 | 2    |        | ns   | 39        |



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

### (4) Arbitration and external bus master read/write timing

| Symbol          | Parameter                              | Test conditions | Limits |      |      | Reference |
|-----------------|----------------------------------------|-----------------|--------|------|------|-----------|
| Symbol          |                                        |                 | Min.   | Max. | Unit | number    |
| tsu(HREQ-CLKIN) | HREQ input set-up time before CLKIN    |                 | 5      |      | ns   | 40        |
| th(CLKIN-HREQ)  | HREQ input hold time after CLKIN       |                 | 2      |      | ns   | (41)      |
| tsu(CS-CLKIN)   | CS input set-up time before CLKIN      |                 | 7      |      | ns   | 48        |
| th(CLKIN-CS)    | CS input hold time after CLKIN         |                 | 2      |      | ns   | 49        |
| tsu(A-CLKIN)    | Address input set-up time before CLKIN |                 | 5      |      | ns   | 60        |
| th(CLKIN-A)     | Address input hold time after CLKIN    |                 | 3      |      | ns   | 51        |
| tsu(D-CLKINL)   | Data input set-up time before CLKIN    |                 | 5      |      | ns   | 52        |
| th(CLKINL-D)    | Data input hold time after CLKIN       |                 | 3      |      | ns   | 53        |

#### (5) Interrupt control unit timing

| Symbol  | Parameter                        | Test conditions | Lin       | nits |      | Reference |
|---------|----------------------------------|-----------------|-----------|------|------|-----------|
| Symbol  | Falameter                        | Test conditions | Min.      | Max. | Unit | number    |
| tw(INT) | INT input pulse width (see note) |                 | tc(CLKIN) |      | ns   | 63        |
| tw(SBI) | SBI input pulse width (see note) |                 | tc(CLKIN) |      | ns   | 64        |

Note: Both INT and SBI are level-sense inputs. Keep them at an "L" level until the interrupt is accepted.

#### (6) I/O port timing

| Symbol      | Parameter Te               | Test conditions | Limits |      |      | Reference |
|-------------|----------------------------|-----------------|--------|------|------|-----------|
|             |                            | Test conditions | Min.   | Max. | Unit | number    |
| tw(PORTINL) | Port input "L" pulse width |                 | 30     |      | ns   | 69        |
| tw(PORTINH) | Port input "H" pulse width |                 | 30     |      | ns   | 70        |



# M32000D4AFP

SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

### SWITCHING CHARACTERISTICS (VCC = 3.3 ± 0.3 V, CL = 50 pF, TOPR = 0 to 70 °C unless oth erwise noted)

### (1) Output transition time

| Symbol     | Parameter Test conditions      | Limits |      |      |      | Reference |        |
|------------|--------------------------------|--------|------|------|------|-----------|--------|
| Symbol     |                                |        | Min. | Тур. | Max. | Unit      | number |
| tr(OUTPUT) | Output rising transition time  |        |      |      | 8    | ns        | 3      |
| tf(OUTPUT) | Output falling transition time |        |      |      | 8    | ns        | 4      |

### (2) Read and write timing

| Or work as        |                                                     | Test       |             | Limits        |      | Reference |
|-------------------|-----------------------------------------------------|------------|-------------|---------------|------|-----------|
| Symbol            | Parameter                                           | conditions | Min.        | Max.          | Unit | number    |
| td(CLKIN-BSHX)    | $\overline{BS}$ = "H" effective time after CLKIN    |            | 0           |               | ns   | (12)      |
| td(CLKIN-BSL)     | $\overline{\text{BS}}$ = "L" delay time after CLKIN |            |             | 12            | ns   | 13        |
| td(CLKIN-BSLX)    | $\overline{BS}$ = "L" effective time after CLKIN    |            | tc(CLKIN)/4 |               | ns   | 14        |
| td(CLKIN-BSH)     | $\overline{\text{BS}}$ = "H" delay time after CLKIN |            |             | tc(CLKIN)/4+8 | ns   | 15        |
| td(CLKIN-AV)      | Address delay time after CLKIN                      |            |             | 16            | ns   | 16        |
| td(CLKIN-AX)      | Address effective time after CLKIN                  |            | 0           |               | ns   |           |
| td(CLKIN-BCV)     | BCH, BCL delay time after CLKIN                     |            |             | 16            | ns   | 18        |
| td(CLKIN-BCX)     | BCH, BCL effective time after CLKIN                 |            | 0           |               | ns   | 19        |
| td(CLKIN-SIDV)    | SID delay time after CLKIN                          |            |             | 16            | ns   | 20        |
| td(CLKIN-SIDX)    | SID effective time after CLKIN                      |            | 0           |               | ns   | 21        |
| td(CLKIN-STV)     | ST delay time after CLKIN                           |            |             | 16            | ns   | 22        |
| td(CLKIN-STX)     | ST effective time after CLKIN                       |            | 0           |               | ns   | 23        |
| td(CLKIN-RWV)     | R/W delay time after CLKIN                          |            |             | 16            | ns   | 24)       |
| td(CLKIN-RWX)     | R/W effective time after CLKIN                      |            | 0           |               | ns   | 25        |
| td(CLKIN-BURSTHX) | BURST = "H" effective time after CLKIN              |            | 0           |               | ns   | 26        |
| td(CLKIN-BURSTL)  | BURST = "L" delay time after CLKIN                  |            |             | 12            | ns   | Ŵ         |
| td(CLKIN-BURSTLX) | BURST = "L" effective time after CLKIN              |            | 0           |               | ns   | 28        |
| td(CLKIN-BURSTH)  | BURST = "H" delay time after CLKIN                  |            |             | 12            | ns   | 29        |
| td(CLKIN-DZX)     | Data output enable time after CLKIN                 |            | 0           |               | ns   | 32        |
| td(CLKIN-DV)      | Data output delay time after CLKIN                  |            |             | 18            | ns   | 33        |
| td(CLKIN-DVX)     | Data output effective time after CLKIN              |            | 0           |               | ns   | 34)       |
| td(CLKIN-DXZ)     | Data output disable time after CLKIN                |            |             | 16            | ns   | 35        |



### M32000D4AFP

SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

| Symbol           | Devemeter                                                              | Test conditions | Limits |      |      | Reference |
|------------------|------------------------------------------------------------------------|-----------------|--------|------|------|-----------|
| Symbol           | Parameter                                                              |                 | Min.   | Max. | Unit | number    |
| td(CLKIN-HACKHX) | HACK = "H" effective time after CLKIN                                  |                 | 0      |      | ns   | (42)      |
| td(CLKIN-HACKL)  | $\overline{HACK}$ = "L" delay time after CLKIN                         |                 |        | 12   | ns   | 43        |
| td(CLKIN-HACKLX) | $\overline{HACK}$ = "L" effective time after CLKIN                     |                 | 0      |      | ns   | (44)      |
| td(CLKIN-HACKH)  | $\overline{HACK}$ = "H" delay time after CLKIN                         |                 |        | 12   | ns   | 45        |
| td(CLKIN-AZ)     | Address output disable time after CLKIN                                |                 |        | 16   | ns   | 46        |
| td(CLKIN-AZX)    | Address output enable time after CLKIN                                 |                 | 0      |      | ns   | (47)      |
| td(CLKIN-DZX)    | Data output enable time after CLKIN                                    |                 | 0      |      | ns   | 54        |
| td(CLKIN-DV)     | Data output delay time after CLKIN                                     |                 |        | 18   | ns   | 55        |
| td(CLKIN-DXZ)    | Data output disable time after CLKIN                                   |                 |        | 16   | ns   | 66        |
| td(CLKIN-DVX)    | Data output effective time after CLKIN                                 |                 | 0      |      | ns   | 57        |
| td(CS-DCZX)      | $\overline{\text{DC}}$ output enable time after $\overline{\text{CS}}$ |                 | 0      |      | ns   | 58        |
| td(CLKIN-DCHX)   | $\overline{DC}$ = "H" effective time after CLKIN                       |                 | 0      |      | ns   | 59        |
| td(CLKIN-DCL)    | $\overline{\text{DC}}$ = "L" delay time after CLKIN                    |                 |        | 16   | ns   | 60        |
| td(CLKIN-DCXZ)   | DC output disable time after CLKIN                                     |                 |        | 16   | ns   | 61        |
| td(CLKIN-DCLX)   | $\overline{DC}$ = "L" effective time after CLKIN                       |                 | 0      |      | ns   | 62        |

### (3) Arbitration and external bus master read/write timing

### (4) Standby timing

| Symbol           | Devementer                                   | Test conditions |      | Limits          |      | Reference |
|------------------|----------------------------------------------|-----------------|------|-----------------|------|-----------|
| Symbol           | Parameter                                    | Test conditions | Min. | Max.            | Unit | number    |
| td(CLKIN-STBYHX) | STBY = "H" effective time after CLKIN        |                 | 0    |                 | ns   | 65        |
| td(CLKIN-STBYL)  | STBY = "L" delay time after CLKIN (see note) |                 |      | tc(CLKIN)n/4+15 | ns   | 66        |
| td(CLKIN-STBYLX) | STBY = "L" effective time after CLKIN        |                 | 0    |                 | ns   | 67        |
| td(CLKIN-STBYH)  | STBY = "H" delay time after CLKIN (see note) |                 |      | tc(CLKIN)n/4+15 | ns   | 68        |

Note: The STBY signal is synchronized with the internal clock, therefore its timing changes at 0, 90, 180 and 270 (n=0, 1, 2, 3) degree phase of CLKIN.

### (5) I/O port timing

| Symbol       | Parameter                              | Parameter Test conditions | Lin  | nits | Unit | Reference |
|--------------|----------------------------------------|---------------------------|------|------|------|-----------|
|              | Falameter                              | Test conditions           | Min. | Max. |      | number    |
| tw(PORTOUTL) | Port output "L" pulse width (see note) |                           | 12   |      | ns   | 7)        |
| tw(PORTOUTH) | Port output "H" pulse width (see note) |                           | 12   |      | ns   | 72        |

Note: The minimum pulse width value is that where the output is changed within 1 clock of the internal clock. Software processing time to write to the port data register is not included.





Fig. 34 Output switching characteristic measurement circuit



Fig. 35 Input waveform and timing reference point during characteristic measurement



Fig. 36 Output timing measurement point during characteristic measurement





Fig. 37 Input transition time















Fig. 41 Bus arbitration timing



SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER



42



Fig. 43 Interrupt input timing



Fig. 44 Standby timing



Fig. 45 I/O port timing



### M32000D4AFP

SINGLE-CHIP 32-BIT CMOS MICROCOMPUTER

Keep safety first in your circuit designs!

Misubishi Electric Corporation puts the maximum effort into making semiconductor products better and more reliable, but there is always the possibility that trouble may occur with them. Trouble with semiconductors may lead to personal injury, fire or property damage. Remember to give due consideration to safety when making your circuit designs, with appropriate measures such as (i) placement of substitutive, auxiliary circuits, (ii) use of non-flammable material or (iii) prevention against any malfunction or mishap.

Notes regarding these materials

These materials are intended as a reference to assist our customers in the selection of the Mitsubishi semiconductor product best suited to the customer's application; they do not convey any license under any

Intelectual property rights, or any other rights, belonging to Mitsubishi Electric Corporation or a third party. Mitsubishi Electric Corporation assumes no responsibility for any damage, or infringement of any third-party's rights, originating in the use of any product data, diagrams, charts or circuit application examples contained in these materials, including product data, diagrams and charts, represent information on products at the time of publication of these materials, and are subject to change by Mitsubishi

All information contained in these materials, including broads data, bagrams and charts, tepresent information on products at the time of publication of mese materials, and are subject to charge by Misubishi Electric Corporation without notice due to product improvements or other reasons. It is therefore recommended that customers contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor for the latest product information before purchasing a product listed herein. Mitsubishi Electric Corporation semiconductors are not designed or manufactured for use in a device or system that is used under circumstances in which human life is potentially at stake. Please contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor when considering the use of a product contained herein for any specific purposes, such as apparatus or systems for transportation, vehicular, medical, aerospace, nuclear, or undersea repeater use. The prior written approval of Mitsubishi Electric Corporation is necessary to reprint or reproduce in whole or in part these materials. If these products or technologies are subject to the Japanese export control restrictions, they must be exported under a license from the Japanese government and cannot be imported into a country other than the constraint detaction form.

approved destination.

Any diversion or reexport contrary to the export control laws and regulations of Japan and/or the country of destination is prohibited. Please contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor for further details on these materials or the products contained therein.

© 1998 MITSUBISHI ELECTRIC CORP. Revised edition, effective May. 1998 Specifications subject to change without notice.



**REVISION DESCRIPTION LIST** 

### M32000D4AFP DATA SHEET

| Rev.<br>No. | Revision Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Rev.<br>date |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 1.0         | First Edition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 970901       |
| 1.1         | <ul> <li>"After DC outputs an ~ CLKIN falling edge." revised (line 18, page 24).</li> <li>Notes in Figure 23 revised (page 24).</li> <li>"After DC outputs an ~ CLKIN falling edge." revised (line 19, page 25).</li> <li>Notes in Figure 24 revised (page 25).</li> <li>Table 2 revised (page 28).</li> <li>(3) Arbitration and external bus master read/write timing <ul> <li>Symbol</li> <li>Parameter</li> <li>I</li> <li>Id(CS-DCZX)</li> <li>DC output enable time after CS</li> <li>corrected (page 37).</li> </ul> </li> <li>"(58) td(CS-DCZX) -1 " in Fig. 42 corrected (page 42).</li> </ul> | 980501       |
|             | Notes in Figure 44 revised (page 43).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |              |
| 1.2         | • Figure 23 revised (page 24).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 980911       |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              |