30E NEC Electronics Inc. μPD70236 (V53) 16-Bit Microprocessor: High-Speed, High-Integration, CMOS T-49-17-15 ## Description The V53™ is a high-speed, high-integration 16-bit CMOS microprocessor with a CPU that is object and source code compatible with the V20®/V30®. Integrated on the same die is a 4-channel DMA controller, a UART, three timer/counters, an interrupt controller, a refresh controller, a clock generator, and a bus controller. - The DMA unit has four channels of high-bandwidth DMA (up to 8M bytes/sec). It has two sets of control registers, one compatible with the $\mu$ PD71087/8237 and another with the $\mu$ PD71071. - The UART offers asynchronous serial I/O and is functionally compatible with the $\mu$ PD71051 (8251). - The three 16-bit general-purpose timer/counters are compatible with the $\mu$ PD71054 (8254). - The interrupt controller is identical to the $\mu$ PD71059 (8259) and offers eight interrupt channels. External μPD71059s may be cascaded. - The refresh controller generates a 16-bit refresh cycle for use with dynamic or pseudostatic RAMs. - The clock generator uses a crystal at two times the desired frequency to produce the internal clock for the CPU and peripherals. A peripheral clock is also - The bus controller generates µPD71088-style control signals for easy interface to external devices. The full V33 bus is also provided. Bus cycles are nominally two clock cycles long and can be extended using the internal wait state generator. Dynamic bus sizing can be used to set the datapath width for every bus cycle. Both 8- and 16-bit cycles are supported, allowing the V53 to be used on both 8- and 16-bit systems. The V53 CPU is identical to the µPD70136 (V33™). Hardwired data-path control and a high-bandwidth bus give a performance level of 16 MHz, which is increased to four times that of the 10-MHz V30. The 1M-byte addressing range of the V30 is to 16M bytes using an on-chip address translation table. V20 and V30 are registered trademarks of NEC Corporation. V33, V40, V50, and V53 are trademarks of NEC Corporation. MS-DOS is a registered trademark of Microsoft Corporation. The V53 instruction set is upward compatible with the native modes of the V20, V30, V40™, and V50™. It includes bit processing, bit field insertion and extraction, and BCD string arithmetic. Using a modified Booth's algorithm, the 16-MHz V53 executes 16-bit multiplies in 750 ns. The CPU performance is the highest currently available in a high-integration microprocessor. The V53 has an undefined instruction trap that allows instructions not part of the V-series instruction set (such as commands for proprietary MMUs) to be emulated. High-speed numerics support is provided by the μPD72291 CMOS floating-point unit (530K FLOPs at 16 MHz). The V53's combination of high-speed CPU and DMA makes it ideal for high-bandwidth data control applications such as disk or LAN controllers. The high integration and software compatibility of the CPU and peripherals with the V33 and V30 makes the V53 ideal for very compact personal computer applications such as diskless work stations and lap top computers, or embedded MS-DOS® compatible PCs for POS terminals or control applications. #### **Features** - High-speed, V30-compatible CPU - 125-ns minimum instruction execution time at - 750-ns 16-bit multiply at 16 MHz - 1.19 μs 16-bit divide (16 MHz) - Fastest high-integration MPU available - Dual bus architecture - 8-byte instruction queue - Expanded LIM 4.0-compatible 24-bit addressing - □ Four DMA channels (to 8M bytes/sec) - On-chip serial I/O controller - Three μPD71054-compatible 16-bit counter/timers - Eight-channel μPD71059-compatible interrupt controller - □ Refresh controller - Bus controller with wait-state generator - Clock generator with STOP mode control for low power - □ 16-MHz (or 12.5-MHz) operation with 32-MHz (or 25-MHz) crystal NEC T-49-17-15 Ordering Information | Clock (MHz) | Package | |-------------|----------------------------| | 10 | 120-pin plastic QFP | | 12 | _ | | 16 | _ | | 10 | 132-pin ceramic PGA | | 12 | • | | 16 | • | | | 10<br>12<br>16<br>10<br>12 | ## **Pin Configurations** #### 120-Pin Plastic QFP ## μPD70236 (V53) T-49-17-15 #### 132-Pin Ceramic PGA | Pln | Symbol | Pin | Symbol | Pin | Symbol | Pin | Symbol | Pin | Symbol | Pin | Symbol | |-----|-----------------|-----|-----------------|-----|-----------------|-----|-----------------|-----|-----------------|-----|----------| | A1 | A <sub>22</sub> | В9 | Ag | D3 | DMARQ0 | H1 | INTP2 | L13 | GND | N7 | BUSLOCK | | A2 | A <sub>20</sub> | B10 | A <sub>5</sub> | D12 | D <sub>14</sub> | H2 | INTP3 | L14 | CPERR | N8 | RESOUT | | A3 | GND | B11 | GND | D13 | IC . | Нз | $v_{DD}$ | M1 | TOUT0 | N9 | X2 | | A4 | A 19 | B12 | A <sub>2</sub> | D14 | D <sub>11</sub> | H12 | GND | M2 | TCTL2 | N10 | BUSSTO | | A5 | A <sub>16</sub> | B13 | Ю | Ei | HLDRQ | H13 | $D_2$ | МЗ | TCLK | N11 | R/W | | A6 | A <sub>14</sub> | B14 | D <sub>12</sub> | E2 | DMAAK3 | H14 | $D_3$ | M4 | DTR | N12 | IORD | | A7 | A 12 | C1 | DMAAK2 | E3 | DMARQ2 | J1 | INTP4 | M5 | RxRDY | N13 | BCYST | | 8A | A <sub>11</sub> | C2 | DMAAK0 | E12 | $v_{DD}$ | J2 | INTP5 | M6 | AEX | N14 | UBE | | A9 | NC | C3 | IC | E13 | D <sub>10</sub> | J3 | INTP7 | M7 | GND | P1 | DSR | | A10 | A <sub>8</sub> | C4 | A <sub>23</sub> | E14 | D <sub>8</sub> | J12 | IC | M8 | v <sub>DD</sub> | P2 | CTS | | A11 | A <sub>6</sub> | C5 | IC | F1 | NC | J13 | D <sub>1</sub> | M9 | BUSSTI | P3 | SINT | | A12 | A4 | C6 | A <sub>18</sub> | F2 | HLDAK | J14 | NĊ | M10 | IC | P4 | TxD | | A13 | A <sub>3</sub> | C7 | V <sub>DD</sub> | F3 | REFRQ | K1 | INTP6 | M11 | MRD | P5 | READY | | A14 | A <sub>O</sub> | C8 | GND | F12 | D <sub>9</sub> | K2 | INTAK | M12 | IC | P6 | BS8/BS16 | | B1 | DMARQ1 | C9 | A <sub>7</sub> | F13 | D <sub>7</sub> | КЗ | TCTL1 | M13 | BUFEN | P7 | PCLKOUT | | B2 | END/TC | C10 | V <sub>DD</sub> | F14 | D <sub>6</sub> | K12 | v <sub>oo</sub> | M14 | CPREQ | P8 | CLKOUT | | B3 | A <sub>21</sub> | C11 | Α1 | G1 | INTP1 | K13 | CPBUSY | N1 | TOUT1 | P9 | X1 | | 84 | v <sub>oo</sub> | C12 | D <sub>15</sub> | G2 | INTP0 | K14 | D <sub>O</sub> | N2 | łC | P10 | RESET | | B5 | A <sub>17</sub> | C13 | D <sub>13</sub> | G3 | GND | Ł1 | TCTLO | N3 | RTS | P11 | BUSST2 | | B6 | A <sub>15</sub> | C14 | GND | G12 | V <sub>DD</sub> | L2 | IC | N4 | IC | P12 | MIO | | B7 | A 13 | D1 | DMARQ3 | G13 | D <sub>5</sub> | L3 | TOUT2 | N5 | RxD | P13 | IOWR | | B8 | A <sub>10</sub> | D2 | DMAAK1 | G14 | D <sub>4</sub> | L12 | DSTB | N6 | NMI | P14 | MWR | T-49-17-15 ## Pin Identification | Fill Idellilload | 211 | | |---------------------------------|-----|-----------------------------------------------------------| | Symbol | I/O | Function | | A <sub>0</sub> -A <sub>23</sub> | Out | Address bus | | AEX | Out | Address expansion mode flag | | BCYST | Out | Bus cycle start | | BS8/BS16 | ln | Data bus width specification | | BUFEN | Out | Buffer enable | | BUSLOCK | Out | Bus lock flag | | BUSSTO-BUSST2 | Out | Bus status . | | CLKOUT | Out | System clock | | CPBUSY | ln | Coprocessor busy | | CTS | Out | Clear to send | | D <sub>0</sub> -D <sub>15</sub> | 1/0 | Data bus | | DMAAKO-DMAAK3 | Out | DMA acknowledge | | DMARQ0-DMARQ3 | In | DMA request | | DSR | In | Data set ready | | DSTB | Out | Data strobe | | DTR · | Out | Data terminal ready | | END/TC | 1/0 | DMA service forced-end input; DMA service complete output | | HLDAK | Out | Bus hold acknowledge | | HLDRQ | ln | Bus hold request | | INTAK | Out | interrupt acknowledge | | INTPO-INTP7 | In | Maskable Interrupt request | | IORD | Out | I/O read | | IOWR | Out | I/O write | | M/ĪŎ | Out | Memory I/O select | | MRD | Out | Memory read | | MWR | Out | Memory write | | NMI | ln | Nonmaskable interrupt request | | PCLKOUT | Out | External I/O clock | | READY | In | Bus cycle end | | REFRO | Out | Refresh request | | RESET | ln | Reset | | RESOUT | Out | System reset | | ATS | Out | Request to send | | R∕W | Out | Read/write | | RxD | in | Serial receive data | | RxRDY | Qut | Serial receive ready | | SINT | Out | Serial Interrupt request | | TCLK | in | Timer clock | | TCTL0-TCTL2 | ln | Timer control | | TOUT0-TOUT2 | Out | Timer output | | <del></del> | | | | Symbol | 1/0 | Function | |-----------------|-------------|-----------------------------| | TxD | Out | Serial transmit data | | UBE | Out | Data bus higher byte enable | | X1, X2 | in | Crystal/external clock | | V <sub>DD</sub> | ln | +5-volt power source | | GND | | Ground | | IC | | Internal connection | | NC | <del></del> | No connection | ## Table 1. Output Pin States | Symbol | Hold | Halt | Reset | DMA<br>Cascade | |---------------------------------|--------|--------|-------|----------------| | A <sub>0</sub> -A <sub>23</sub> | HI-Z | L | HŀZ | Hi-Z | | AEX | Note 6 | Note 6 | H/L | Note 6 | | BCYST | Hi-Z | Note 4 | HŀZ | Hi-Z | | BUFEN | HI-Z | Н | HI-Z | HI-Z | | BUSLOCK | Note 5 | Note 5 | Н | Н | | BUSSTO-BUSST2 | HI-Z | Н | HI-Z | Н | | CLKOUT | 0 | 0 | 0 | 0 | | D <sub>0</sub> -D <sub>15</sub> | HI-Z | Note 3 | HI-Z | HI-Z | | DMAAKO-DMAAK3 | Н | 0 | Н | 0 | | DSTB | HI-Z | Н | HI-Z | HI-Z | | DTR | 0 | 0 | Н | 0 | | END/TC | HI-Z | 0 | HI-Z | 0 | | HLDAK | Н | H/L | L | L | | INTAK | Н | Н | Н | Н | | IORD | HI-Z | Н | Hi-Z | HI-Z | | IOWR | HI-Z | Н | HI-Z | HI-Z | | M/IO | HI-Z | L | Hi-Z | Н | | MRD | HI-Z | Н | Hi-Z | Hi-Z | | MWR | HI-Z | Н | Hi-Z | HI-Z | | PCLKOUT | 0 | 0 | 0 | 0 | | REFRQ | Н | 0 | Н | Н | | RESOUT | L. | L. | Н | L | | RTS | 0 | 0 | Н | 0 | | R∕W | HI-Z | L | HI-Z | Н | | RxRDY | 0 | 0 | Н | 0 | | SINT | 0 | 0 | L | 0 | μPD70236 (V53) T-49-17-15 Table 1. Output Pin States (cont) | Symbol | Hold | Halt | Reset | DMA<br>Cascade | |-------------|------|------|-------|----------------| | TOUTO-TOUT2 | 0 | 0 | 0 | 0 | | TxD | 0 | 0 | Н | 0 | | UBE | HI-Z | Н | HI-Z | HŀZ | - (1) The pin states are interpreted as follows: H is high level; L is low level; H/L is high or low level; Hi-Z is high impedance; O is indeterminate. - (2) Hait includes both the HALT and STOP modes. - (3) Undefined for the first two clocks of the hait acknowledge cycle and the HI-Z. - (4) L for the first clock of the halt acknowledge cycle and then H. - (5) L under either of the following conditions: an instruction is executed during hold with a BUSLOCK prefix, or the HALT instruction is executed with a BUSLOCK prefix. Otherwise, the value is H. - (6) H in address expansion mode; L in nonexpansion mode. #### **PIN FUNCTIONS** ## A<sub>0</sub>-A<sub>23</sub> (Address Bus) These pins constitute an address bus that outputs real addresses when memory or an I/O device is accessed. Up to 64K bytes of I/O space and up to 16M bytes of memory space (including reserved areas) can be accessed through the address bus. The address bus enters the high-impedance state if one of the following occurs. - RESET signal is applied - Microprocessor is in HQLD mode - DMA requests are cascade connected The status of the address bus is undefined during an interrupt acknowledge cycle. When interrupt requests are cascade connected, the slave ICU address is output on pins A<sub>0</sub>-A<sub>2</sub>. When I/O is accessed, pins A<sub>16</sub>-A<sub>23</sub> go low. The address can be expanded even when the interrupt vector table is accessed. ## **AEX (Address Extension)** AEX is asserted when the expanded addressing mode is enabled. When AEX is high, the memory address space is 16M bytes (24-bit address), and when low, 1M byte (20-bit address). ## **BCYST** (Bus Cycle Start Strobe) This signal indicates the start of a bus cycle by going low for one clock immediately after the bus cycle is started. When the bus is placed in the hold state, the BCYST pin enters the high-impedance state. ## BS8/BS16 (8-Bit Bus Size/16-Bit Bus Size) BS8/BS16 is driven low by external logic when the μPD70236 addresses a device with an 8-bit data path. If the $\mu$ PD70236 operand is 16 bits wide and $\overline{BS8}/BS16$ is low, then the $\mu\text{PD70236}$ will perform two 8-bit bus cycles. The current bus cycle will handle the low byte on D<sub>0</sub>-D<sub>7</sub>, and the next bus cycle will handle the upper byte also on D<sub>0</sub>-D<sub>7</sub>. This input is ignored during HLDAK, interrupt acknowledge, and coprocessor cycles. BS8/BS16 is sampled on the rising (middle) edge of T2 or the last TW state, coincident with READY. This input is not internally synchronized. To ensure proper device operation, minimum setup and hold times must be met. ## **BUFEN** (Buffer Enable) This signal is output to enable an external buffer, and becomes active during the read cycle, interrupt acknowledge cycle, and write cycle. It does not become active while the internal I/O is being accessed. ## **BUSLOCK** (Bus Lock) BUSLOCK should be used by external logic to exclude any other bus master (e.g., a DMA controller) from using a shared resource that the µPD70236 currently is using. When BUSLOCK is asserted high, HLDRQ will be ignored. BUSLOCK is asserted when the BUSLOCK prefix is executed or when the µPD70236 is performing a bus operation that must not be interfered with, such as an interrupt acknowledge cycle. BUSLOCK has the same timing as the address bus A<sub>0</sub>-A<sub>23</sub> and is driven high during HLDAK and RESET. #### BUSSTO-BUSST2 (Bus Status) These three pins encode and output information identifying the type of bus cycle currently being executed. They enter the high-impedance state in the bus hold mode. These pins are used with the $M/\overline{IO}$ and $R/\overline{W}$ signals, as shown in table 2. T-49-17-15 Table 2. Bus Cycles | | , | JU0012 | BUSST1 | BO2210 | Bus Cycle | |---|---|--------|--------|--------|------------------------------------------| | 0 | 1 | 0 | 0 | 0 | Interrupt acknowledge cycle (from SLAVE) | | 0 | 1 | 1 | 0 | 0 | Interrupt acknowledge cycle (from ICU) | | 0 | 1 | 0 | 0 | 1 | External I/O read cycle | | 0 | 1 | 1 | 0 | 1 | Internal I/O read cycle | | 0 | 0 | 0 | 0 | 1 | External I/O write cycle | | 0 | 0 | 1 | 0 | 1 | Internal I/O write cycle | | 0 | 1 | 0 | 1 | 0 | Coprocessor read cycle | | 0 | 0 | 0 | 1 | 0 | Coprocessor write cycle | | 0 | 0 | 0 | 1 | 1 | Halt acknowledge cycle | | 1 | 1 | 0 | 0 | 0 | Instruction fetch cycle | | 1 | 1 | 1 | 0 | 0 | Refresh cycle | | 1 | 1 | 0 | 0 | 1 | CPU memory read cycle | | 1 | 1 | 1 | 0 | 1 | DMA read transfer cycle | | 1 | 0 | 0 | 0 | 1 | CPU memory write cycle | | 1 | 0 | 1 | 0 | 1 | DMA write transfer cycle | | 1 | 1 | 0 | 1 | 0 | Coprocessor memory read cycle | | 1 | 0 | 0 | 1 , | 0 | Coprocessor memory write cycle | | 1 | 1 | 1 | 1 | 1 | DMA cascade | Interrupt Acknowledge Cycle (from SLAVE). This cycle is the second interrupt acknowledge cycle during which an interrupt request from a slave interrupt control unit (ICU) is acknowledged. During this cycle, the data output by an external interrupt controller is processed as a vector. The bus sizing function cannot be effected in this cycle. The programmable wait function and READY signals are both valid, however. Interrupt Acknowledge Cycle (from ICU). This cycle is output during the first Interrupt acknowledge cycle, during which an Interrupt request for a non-slave ICU is acknowledged. During this acknowledge cycle, the data output by the internal ICU is processed as a vector, and the bus sizing function cannot be effected. The programmable wait function and READY signal are both valid, however. External I/O Read Cycle. This cycle is output when an external I/O area is read by executing the IN instruction. During this cycle, the bus sizing function can be effected. Also, the programmable wait function and READY signal are both valid. Internal I/O Read Cycle. This cycle is output when the internal I/O area is read by executing the IN instruction. The bus sizing function cannot be effected. Both the programmable wait function and READY signal are invalid. However, two wait state clocks are automatically inserted into all internal I/O area cycles except those for the address expansion table and address expansion flag. **External I/O Write Cycle.** This cycle is output when an external I/O area is written by executing the OUT instruction. The bus sizing function can be effected. Also, the programmable wait function and READY signal are both valid. Internal I/O Write Cycle. This is output when the internal I/O area is written by executing the OUT instruction. The bus sizing function cannot be effected. Both the programmable wait function and READY signal are invalid. However, two wait state clocks are automatically inserted into all internal I/O area cycles except those for the address expansion table and address expansion flag. Coprocessor Read Cycle. This cycle indicates that an external coprocessor is accessed for data read when a coprocessor instruction is executed. The bus timing and ac characteristics of this cycle are the same as those of the ordinary I/O read cycle. Although the bus sizing function cannot be effected, coprocessor operations are not guaranteed if the bus sizing function is used. The programmable wait function is invalid, but the READY signal is valid. Coprocessor Write Cycle. This cycle indicates that an external coprocessor instruction is executed. The bus timing and ac characteristics of this cycle are the same as those of the ordinary I/O write cycle. Although the bus sizing function can be effected, coprocessor operations are not guaranteed if the bus sizing function is used. The programmable wait function is invalid, but the READY signal is valid. Halt Acknowledge Cycle. This cycle is output when the HALT instruction is executed. During this bus cycle, the DSTB pin does not output a low level. The bus sizing function cannot be effected. Both the programmable wait function and READY signal are invalid. Instruction Fetch Cycle. This cycle indicates that an instruction is being fetched. The bus sizing function can be effected. Also, the programmable wait function and READY signal are both valid. Refresh Cycle. This cycle indicates that DRAM refreshing is in progress. The bus sizing function cannot be effected. (Note that BS8/BS16 must be 16 bits.) The programmable wait function and READY signal are both valid. CPU Memory Read Cycle. This cycle is output when the CPU reads data from memory. The bus sizing function μPD70236 (V53) T-49-17-15 can be effected. Also, the programmable wait function and READY signal are both valid. DMA Read Transfer Cycle. This cycle is output when DMA transfer (that is, data transfer from memory to I/O) takes place. The bus sizing function cannot be effected. The programmable wait function and READY signal are both valid. CPU Memory Write Cycle. This cycle is output when the CPU writes data to memory. The bus sizing function can be effected. Also, the programmable wait function and READY signal are both valid. DMA Write Transfer Cycle. This cycle is output when write DMA transfer (that is, data transfer from I/O to memory) takes place. The bus sizing function cannot be effected. The programmable wait function and READY signal are both valid. Coprocessor Memory Read Cycle. This cycle is output when data read from memory is sent to the coprocessor. Although the bus sizing function cannot be effected, coprocessor operations are not guaranteed if bus sizing is used. The programmable wait function and READY signal are both valid. Coprocessor Memory Write Cycle. This cycle is output when data for a coprocessor is written to memory. The CPU does not drive the data bus. Instead, the coprocessor drives the data bus to write data to memory. Although the bus sizing function cannot be effected, coprocessor operations are not guaranteed if the bus sizing function is used. The programmable wait function and READY signal are both valid. **DMA Cascade.** This cycle indicates that the DMA is cascade connected to an external slave DMA controller. During this cycle, the buses are relinquished. #### **CLKOUT (Clock Output)** This pin outputs a square-wave clock pulse. The frequency of the output clock pulse is obtained by dividing the frequency of the clock signal input to the X1 and X2 pins by a specific value. The duty factor of the output clock pulse is 50%. The output frequency is the same as the operating frequency of the CPU (programmable to one-half, one-fourth, one-eighth, or one-sixteenth of the oscillation frequency). ## **CPBUSY** (Coprocessor Busy) CPBUSY is asserted low by a coprocessor (such as μPD72291) when it is busy with an internal operation. The μPD70236 uses this pin to check the status of the coprocessor. CPBUSY is sampled on the falling edge of each clock. This input is not internally synchronized. To ensure proper device operation, minimum setup and hold times must be met. If a coprocessor is not connected to the $\mu$ PD70236, $\overline{\text{CPBUSY}}$ should be grounded. ## CTS (Clear to Send) This is a serial transmission control input pin. The SCU is ready for data transmission when bit 0 of the SCM register is set to 1 and this pin is at low level. When this pin is made high while data transmission is in progress, transmission is stopped after the current data has been completely transmitted, and the TxD pin goes high. ## D<sub>0</sub>-D<sub>15</sub> (Data Bus) These pins constitute a data bus that inputs or outputs write data and read data when the external main memory or I/O device is accessed. The data bus is in the input mode during any bus cycle other than a write cycle. During the write bus cycle, the bus outputs data starting from the rising edge of the T1 clock until the cycle following the write bus end cycle. These pins output active-low DMA acknowledge signals from channels 0 to 3 of the internal DMAU. ## **DMARQ0-DMARQ3 (DMA Request)** These pins input active-high DMA request signals from channels 0 to 3 of the internal DMA control unit (DMAU). ## DSR (Data Set Ready) This is a general-purpose input pin. The status of this pin can be determined by reading bit 7 of the serial status (SST) register. #### DSTB (Data Strobe) This is a strobe signal for read and write operations. The signal does not go low during the halt acknowledge cycle that indicates that the HALT instruction has been executed. When the buses are placed in the hold state, the DSTB pin enters the high-impedance state. The signal output timing of this pin differs depending on whether a read or write operation is performed. The DSTB signal does not go low when the internal I/O area is accessed. #### **DTR** (Data Terminal Ready) This is a general-purpose output pin. The status of this pin can be set by bit 1 of the SCM register. ## C ELECTRONICS INC ## µPD70236 (V53) ## END/TC (End/Terminal Count) This pin inputs the END signal to or outputs the TC signal from the internal DMAU. END Input. When a low-level pulse is input to this pin during DMA transfer, the DMA service under execution is terminated after the current bus cycle is over. TC Output. When the count register of the DMAU channel currently performing DMA transfer becomes 0, and when the DMA transfer has been performed the specifled number of times, the TC pin outputs a low-level pulse. ## **HLDAK (Hold Acknowledge)** This is an acknowledge signal that indicates that the V53 has accepted the HLDRQ signal, placed the address, data, and control buses in the high-impedance state, and relinquished the buses to an external device. The external devices that can acquire the buses are assigned the following priority. REFU (highest priority) DMAU **HLDRQ** CPU REFU If a bus hold request takes place while the buses are idle (TI state), during the CPU bus cycle, or during lowestpriority refresh cycle, the HLDRQ signal is accepted immediately after the bus cycle is over and the buses are relinauished. If a DMA request or top-priority refresh request is generated while the buses are in the hold state, the HLDAK signal is forcibly made inactive. In this case, the external device must return control of the bus to the V53 (making the HLDRQ signal inactive). Therefore, the high-level width of the HLDAK signal when it is made inactive forcibly is 1 clock minimum. ## **HLDRQ** (Hold Request) HLDRQ is asserted high by external logic when an external bus master (e.g., a DMA controller) wants to take over the µPD70236 bus. When HLDRQ is detected high, the µPD70236 will release the bus after the current bus operation is completed. Note that this is not necessarily the current bus cycle. The µPD70236 releases its bus by floating the address, data, and control buses. HLDRQ is sampled on the rising edge of each clock. It will be ignored while BUSLOCK is asserted. This input is not internally synchronized. To ensure proper device operation, minimum setup and hold times must be met. ## INTAK (Interrupt Acknowledge) This is an active-low acknowledge signal for a maskable interrupt. ## INTPO-INTP7 (Interrupt from Peripherals) These are asynchronous interrupt request input pins for the internal interrupt control unit (ICU). The input signals can be triggered either at the rising edge or at high level. The priority of these signals can be fixed or rotated. These interrupt request inputs are also used to release the HALT and STOP modes. ## **IORD** (I/O Read) This active-low read signal goes low during the I/O read cycle. This signal is also output when write DMA transfer is performed. However, it is not output during the CPU's internal I/O read cycle. ## **IOWR** (I/O Write) This is an active-low write signal that goes low during the I/O write cycle. This signal is also output when read DMA transfer is performed in two output timing modes: the expansion write mode and the ordinary write mode. It is not output during the CPU's internal I/O write cycle. ## M/IO (Memory I/O) This pin indicates whether a memory or other device (such as an I/O device or coprocessor) is currently accessed. The device to be accessed is determined by this pin and the BUSST0 and BUSST1 signals. The M/IO pin enters the high-impedance state in the bus hold mode. Its status changes at the falling edge of the T1 clock. #### MRD (Memory Read) This is an active-low read signal that goes low during a read cycle in which data is read from memory. This signal is output not only during the CPU's memory read, but also during the refresh cycle and when read DMA transfer is performed. #### MWR (Memory Write) This active-low write signal goes low when the memory write cycle is in progress. This signal is output not only during the CPU's memory write cycle, but also during the write DMA transfer and when write DMA transfer is performed in two output timing modes: the expansion write mode and the ordinary write mode. T-49-17-15 ## NMI (Nonmaskable Interrupt Request) $\overline{\text{NMI}}$ is asserted by external logic to notify the CPU that an external event requires the CPU's immediate attention. When $\overline{\text{NMI}}$ is sampled low, interrupt processing will begin immediately after the current instruction is completed. A trap will be taken through vector 2. The state of the IE bit in the PSW has no effect on $\overline{\text{NMI}}$ acceptance. NMI is sampled on the falling edge of each CPU clock. This input is not internally synchronized. To ensure proper device operation, minimum setup and hold times must be met. Interrupt processing begins immediately after the end of the current instruction. Once NMI processing comences, no further NMI requests will be accepted until termination of the current NMI routine, which is indicated by the RETI instruction. ## **PCLKOUT (Peripheral Clock Output)** This pin outputs a square-wave clock pulse with a frequency one-fourth the frequency of the clock signal input to the X1 and X2 pins. The duty factor of the output clock pulse is 50%. ## **READY** (System Ready) The $\overline{\text{READY}}$ signal is asserted low when the external system is ready for the current bus cycle to terminate. While $\overline{\text{READY}}$ is not asserted, the $\mu\text{PD70236}$ will add TW (wait) states to the current bus cycle. The bus state in which $\overline{\text{READY}}$ is sampled low will be the last state of the cycle. During CPU read cycles, $\overline{READY}$ gives slow devices time to drive the $D_0$ - $D_7$ inputs, and during write cycles gives slow devices enough time to finish the write operation. The READY input is sampled on the rising (middle) edge of T2 and all TW states. It is ignored during the HLDAK state. This input is not internally synchronized. To ensure proper device operation, minimum setup and hold times must be met. ## **REFRQ** (Refresh Request) This signal is asserted during refresh cycles. #### RESET (Reset) This signal initializes the processor. The processor is reset when this signal is held low for six clocks or longer and then returned to the high level. #### **RESOUT (Reset Output)** This pin outputs an active-high signal which is an asynchronous RESET signal synchronized with the internal clock. This signal can be used to reset the system. ## RTS (Request to Send) This is a general-purpose output pin. The status of this pin can be set by bit 5 of the serial command (SCM) register. ## R/W (Read/Write) This pin indicates whether the current bus cycle is a read cycle or a write cycle. This pin is valid only while a bus cycle is being executed, and goes high if the current bus cycle is a read cycle or during an interrupt acknowledge cycle; it goes low if the current bus cycle is a write cycle. The R/W pin enters the high-impedance state in the bus hold mode. The level of this pin changes at the falling edge of the T1 clock. ## RxD (Receive Data) When the serial control unit does not receive data, this pin is at high level (mark state). When the pin detects a start bit, the SCU starts receiving serial data from an external device. ## **RxRDY** (Receive Ready) When the serial control unit has received one character of data, and when that data is transferred to the receive data buffer (that is, when the receive data is ready to be read), this pin goes high. ## SINT (Serial Interrupt) This signal becomes active to output an interrupt request signal from the SCU when the transmit data buffer of the SCU is empty and when the interrupt of the transmitting side is not masked, or when it contains the SCU's receive buffer data to be read and the receive interrupt is not masked. #### TCLK (Timer Clock) This pin inputs a clock pulse from an external source to the internal timer/counter unit (TCU). When the system is initialized, either the external clock or the internal clock is selected to be supplied to the TCU. #### TCTL0-TCTL2 (Timer Control) These pins input control signals to the three TCU counters. The functions of the control signals input 4 .. through these pins differ depending on the mode (six modes are available) set by the TCU. #### **TOUT0-TOUT2** (Timer Output) These are output pins for the internal timer/counter unit. The TCU outputs signals through these pins in six different modes. ## TxD (Transmit Data) When the serial control unit (SCU) has no data to be transmitted to an external device, this pin is at high level (mark state). When transmit data is set in the SCU, the TxD pin automatically outputs a start bit, serial data that has been set in the SCU, a parity bit, and 1 or 2 stop bits. ## **UBE** (Upper Byte Enable) When the microprocessor accesses external main memory or an I/O device that requires the upper 8 bits (D<sub>8</sub>-D<sub>15</sub>) of the data bus, this pin goes low at the falling edge of the T1 clock, enabling the upper byte on the bus. The lower 8 bits $(D_0-D_7)$ of the data bus are controlled by the Ao pin as shown in the following table. | UBE | Ao | Operation | |-----|----|-------------------------------------------------| | 0 | ō | 16 bits accessed | | 0 | 1 | Upper 8 bits accessed | | 1 | 0 | Lower 8 bits accessed | | 1 | 1 | Second cycle (for use with bus sizing function) | When dynamic bus sizing is used to make a 16-bit access into an 8-bit, Ao must be used as an address bit; UBE can be ignored. #### X1, X2 (Crystal) To use the internal clock generator, connect a crystal with a frequency twice the operating frequency across these pins. When using an external clock generator, input square waves with a frequency twice the operating frequency to the X1 pin. To the X2 pin, make the input signal 180° out of phase (an inverter output) with the signal input to the X1 pin. ## **UNIT OPERATION** #### Central Processing Unit (CPU) The µPD70236 CPU is a high-performance engine whose performance surpasses most other 16-bit CPUs. To achieve this performance level, hardwired data path control was used (no microcode) so that instruction execution times are greatly reduced. The µPD70236 CPU has functions equivalent to those of the µPD70136 (V33) and is therefore completely software compatible with the V33. The µPD70236 instruction set is upward compatible with the native modes of the V20, V30, V40, and V50. ## Clock Generator (CG) The clock generator divides the oscillation frequency of the crystal or external oscillator connected across pins X1 and X2 by 2, 4, 8, or 16 to generate a clock that is supplied to the CPU as an operation clock and to an external device through the CLKOUT pin. A clock having a frequency one-fourth the oscillation frequency is also output to the PCLKOUT pin. ## **Bus Interface Unit (BIU)** The bus interface unit controls the pins of the address bus, data bus, and control bus, which are used by the CPU, DMA unit (DMAU), and refresh control unit (REFU). ## **Bus Arbitration Unit (BAU)** The bus arbitration unit arbitrates the internal bus mastership. The priority of the bus mastership is: CPU with BUSLOCK (highest priority) REFU of top priority DMAU **HLDRQ** Ordinary CPU **REFU of lowest priority** #### Wait Control Unit (WCU) The function of the wait control unit is to insert wait states equivalent to 0 to 7 clocks automatically into the memory, I/O, DMA, and refresh cycles. The 16M-byte memory space can be divided into three blocks. In addition, any 1M-byte memory space can also be divided into three blocks. ## Refresh Control Unit (REFU) The REFU supports the DRAM refresh operation by generating 16-bit refresh addresses and a refresh signal (REFRQ) indicating that the refresh cycle is currently taking place. #### Timer/Counter Unit (TCU) The timer/counter unit of the µPD70236 performs the same functions as the µPD71054. It provides a set of three independent 16-bit timer/counters. T-49-17-15 ## Serial Control Unit (SCU) The $\mu\text{PD70236}$ SCU has the same functions as the $\mu$ PD71051 except the synchronous mode for supporting RS-232C protocol. This SCU is equipped with a dedicated baud rate generator. The SCU provides serial communications functions of the start-stop synchronization type. Commands for the SCU in the V53 are similar to those of the $\mu$ PD71051 except that the V53 uses two registers-SCM (serial command) register and SMD (serial mode) register-to implement the functions of the control word register of the µPD71051. ## Interrupt Control Unit (ICU) The ICU in the V53 has the same functions as those on the $\mu$ PD71059 except the V53 does not have the CALL mode (8085 mode) or the slave mode of cascade connection. The $\mu PD70236$ ICU has eight external interrupt input pins and can arbitrate up to eight interrupt requests. The number of external interrupt inputs can be increased by cascade connecting the ICU to an external interrupt controller. Unlike the $\mu$ PD71059, $\mu$ PD70208, and $\mu$ PD70216, the INTPO to INTP7 pins in the V53 do not have internal pullup resistors to reduce current dissipation. ## DMA Control Unit (DMAU) The DMAU on the $\mu$ PD70236 functions the same as the DMAUs on the $\mu$ PD71071 and $\mu$ PD71037 and, therefore, it can operate in two modes (µPD71071 mode and $\mu$ PD71037 mode). You can set the operation modes using a register in the system I/O area. In $\mu PD71071$ mode, source and destination addresses are 24 bits. In μPD71037 mode, source and destination addresses are 16 bits. To extend these addresses to 20 or 24 bits, four 8-bit bank registers are provided. These registers supply the upper address bits. The DMA unit provides four channels of $\mu PD71071$ compatible or µPD71037-compatible DMA. External hardware requests DMA cycles via the DMA request inputs. DMA is always between an I/O device and memory (fly-by style DMA). External DMA controllers may be cascaded using the V53 DMAU. T-49-17-15 ## μPD70236 Block Diagram μPD70236 (V53) T-49-17-15 ## **ELECTRICAL SPECIFICATIONS** # Absolute Maximum Ratings TA = +25°C | Power supply voltage, V <sub>DD</sub> | -0.5 to +7.0 V | | |---------------------------------------|---------------------------------|--| | input voltage, V <sub>i</sub> | -0.5 to V <sub>DD</sub> + 0.3 V | | | Clock input voltage, V <sub>K</sub> | -0.5 to V <sub>DD</sub> + 1.0 V | | | Output voltage, Vo | -0.5 to V <sub>DD</sub> + 0.3 V | | | Output short circuit current, Io | · 50 mA | | | Operating temperature, TOPT | -10 to +70°C | | | Storage temperature, TSTG | -65 to +150°C | | DC Characteristics T<sub>A</sub> = -10 to +70°C; V<sub>DD</sub> = +5 V 10% | Parameter | Symbol | Min | Max | Unit | Conditions | |------------------------------|------------------|---------------------|-----------------------|------------|----------------------------------| | input voitage, high | V <sub>IH</sub> | 2.2 | V <sub>DD</sub> + 0.3 | ٧ | Except RESET | | | | 0.8 V <sub>DD</sub> | | ٧ | RESET | | Input voltage, low | V <sub>IL</sub> | -0.5 | 0.8 | ٧ | Except RESET | | | | | 0.2 V <sub>DD</sub> | . Λ | RESET | | Clock input voltage, high | V <sub>KH</sub> | 0.8 V <sub>DD</sub> | V <sub>DD</sub> + 0.5 | . <b>V</b> | | | Clock input voltage, low | V <sub>KL</sub> | ~0.5 | 0.6 | V | | | Output voltage,high | V <sub>OH</sub> | 0.7 V <sub>DD</sub> | | ٧ | I <sub>OH</sub> = -400 μA | | Output voltage, low | V <sub>OL</sub> | | 0.45 | . V | I <sub>OL</sub> = 2.5 mA | | input leakage current, high | l <sub>LIH</sub> | | 10 | μΑ | $V_i = V_{DD}$ | | input leakage current, low | ILIL | | -10 | · μA | V <sub>I</sub> = 0 V | | Output leakage current, high | Гьон | • • | 10 | μA | V <sub>0</sub> = V <sub>DD</sub> | | Output leakage current, low | LOL | • . | -10 | μA | V <sub>0</sub> = 0 V | | Supply current | مما | | 10 f + 40 | mA | Operating; f = 2 to 16 MHz | | | | | 40 | mA | HALT mode | | | | | 200 | μА | STOP mode | ## **Voltage Thresholds for Timing Measurements** T-49-17-15 AC Characteristics $T_A = -10 \text{ to } +70^{\circ}\text{C}; V_{DD} = 5 \text{ V} \pm 10\%; C_L \text{ of output terminals} =$ | 100 pF max | | | | | |---------------------------------|--------------------|-----------------------------|------------|------------------| | Parameter | Symbol | Min | Max | Unit | | Clocks (figure 1) | | | | | | CLKOUT period | <sup>t</sup> CYK | 62.5 | 500 | ns | | CLKOUT high-level width | ҍккн | 0.5 t <sub>CYK</sub> - 7 | | ns | | CLKOUT low-level width | †KKL | 0.5 t <sub>CYK</sub> - 7 | <b>t</b> . | ns | | CLKOUT rise time | <sup>‡</sup> KR | | 7 | ns | | CLKOUT fall time | t <sub>KF</sub> | | 7 | ns | | X1 input period | tcyx | 31,25 | 250 | ns | | X1 input high-level width | tхкн | 11 | | ns | | X1 input low-level width | †xkl | • 11 | | ns | | X1 input rise time | t <sub>XKR</sub> | | 5 | ns | | X1 input fall time | <sup>t</sup> XKF | | 5 | ns | | X1 to CLKOUT delay | <sup>t</sup> DXK | | 20 | ns | | PCLKOUT period | <sup>‡</sup> CYPK | 125 | 1000 | ns | | PCLKOUT high-level width | ₽кн | 4 t <sub>CYK</sub> - 7 | | ns | | PCLKOUT low-level width | <sup>†</sup> PKL | 4 t <sub>CYK</sub> - 7 | | ns | | PCLKOUT rise time | t <sub>PKR</sub> | | 7 | กร | | PCLKOUT fall time | <sup>t</sup> PKF | | 7 | ns | | Reset (figure 2) | | | | | | RESET setup time vs<br>CLKOUT ↓ | <sup>t</sup> SRSTK | 30 | | ns | | RESET hold time vs | †нкя <b>з</b> т | 15 | | ns | | RESET low-level width | twrstl. | 6 | | t <sub>CYC</sub> | | RESOUT delay from CLKOUT ↓ | †DKRO | 0 | 40 | ns | | Write, Read (figure | s 3-12, 16 | -19, 23-24, 28, 31 | /) Note | 2 | | BCYST delay from CLKOUT ↓ | <sup>†</sup> DKBC | 5 | 40 | ns | | BCYST low-level width | †BCBCL | t <sub>CYK</sub> 10 | | ns | | BCYST high-level width | <sup>t</sup> вовон | t <sub>CYK</sub> (n+1) - 10 | | ns | | Address delay from CLKOUT ↓ | <sup>†</sup> DKA | 5 | 40 | ns | | Control 2 delay from<br>CLKOUT | †DKCT2 | 0 | 40 | пѕ | | Status delay from CLKOUT ↓ | t <sub>DKST</sub> | 5 | 40 | ns | | Parameter | Symbol | Min | Max | Unit | |-------------------------------------------------------------|--------------------|-----------------------------------------|-----|--------------------------| | Data float delay from<br>CLKOUT | ŧғк | 0 | 50 | ns | | DSTB ↓ delay from<br>CLKOUT ↓ | <sup>t</sup> DKDS | 5 | 40 | ns | | DSTB low-level width | <sup>‡</sup> DSDSL | t <sub>CYC</sub> (n+1) - 10 | | ns | | DSTB high-level width | <sup>‡</sup> DSDSH | t <sub>KKL</sub> +t <sub>KR</sub> - 10 | | ns | | CLKOUT to IOWR delay | <sup>†</sup> okw | 0 | 40 | ns | | CLKOUT to IORD delay | tokr | 0 | 40 | ns<br>'₹' <i>≅</i> '¢८'द | | CLKOUT to MRD delay | <sup>†</sup> DKMR | 0 | 40 | ns | | CLKOUT to MWR delay | †DKMW | 0 | 40 | <sub>ਦ</sub> . ⊓8 | | CLKOUT ↑ to DSTB ↑ | <sup>‡</sup> DKDSH | 5 | 40 | · ns | | Address/status output delay to DSTB ↓ | <sup>t</sup> DADSL | t <sub>KKL</sub> + t <sub>KR</sub> - 15 | | <b>П8</b> | | Address/status hold time from DSTB ↑ | <sup>‡</sup> HDSHA | t <sub>KKL</sub> + t <sub>KR</sub> - 15 | | ns | | Data output delay from DSTB ↑ | форено | t <sub>KKL</sub> + t <sub>KR</sub> - 15 | | ns | | Data output delay<br>from address/status<br>output | <sup>†</sup> DAD | t <sub>KKL</sub> + t <sub>KR</sub> - 15 | | ns | | Data output delay from CLKOUT ↑ | фоко | 5 | 40 | ns | | Data setup time to CLKOUT ↓ | t <sub>SDK</sub> | 7 | | ns | | Data hold time from<br>CLKOUT ↓ | Чко | 10 | | ns | | Data hold time from | tHOSO | 0 | | ns | | Data hold time from<br>change point of<br>address or status | <sup>t</sup> HASD | 0 | | ns | | Dat hold time from<br>R/W 1 | †HRWD | 0 | | ns | | READY setup time to CLKOUT 1 | †SRYK | 7 | | ns | | READY hold time from CLKOUT ↑ | thkry | 15 | | ns | | | | | | | #### Notes: - (1) t<sub>CYC</sub> = CPU clock period n = number of wait states - (2) The clock-to-signal delays in the -10 (10 MHz) and -12 (12.5 MHz) parts are 45 ns compared to 40 ns in the -16 (16 MHz) part. For full electrical characteristics of the -10 and -12 parts, contact T-49-17-15 AC Characteristics (cont) | Parameter | Symbol | Min | Max | Unit | |--------------------------------------------------------|--------------------|-----------------------------------------|-----|------| | Bus Sizing (figures | 13, 14) | | | | | BS8/BS16 setup time to CLKOUT ↑ | t <sub>SBSK</sub> | 7 | | ns | | BS8/BS16 hold time from CLKOUT 1 | <sup>†</sup> HKBS | 15 | | ns | | Bus Hold (figure 17) | | | | | | HLDRQ setup time to CLKOUT 1 | tsнак | 7 | , | ns | | HLDRQ hold time form CLKOUT 1 | <b>†</b> нкно | 15 | | ns | | CLKOUT 1 to HLDAK delay | <sup>t</sup> DKHA | 5 | 40 | ns | | Output floating to<br>HLDAK delay | <sup>†</sup> DFHA | t <sub>KKL</sub> + t <sub>KR</sub> - 15 | | ns | | Input Setup and Ho | ld (figure | 15) | | | | NMI, INTP0-INTP7,<br>CPBUSY setup time<br>to CLKOUT ↓ | <sup>t</sup> sıĸ | 10 | | ns | | NMI, INTP0-INTP7,<br>CPBUSY hold time<br>from CLKOUT ↓ | Ҹҝт | 10 | | ns | | Timer/Counter Unit | TCU (figu | ures 20-21) | | | | TCTL0-TCTL2 setup time to CLKOUT ↓ | tsgk | 50 | | ns | | TCTL0-TCTL2 hold time from CLKOUT ↓ | tнка | 100 | | | | TCTL0-TCTL2 low-level width | tggL | 50 | | ns | | TCTL0-TCTL2 high-<br>level width | <sup>t</sup> ggH | 50 | | ns | | TOUT0-TOUT2 output delay from CLKOUT ↓ | <sup>t</sup> DKTO | | 100 | ns | | TCLK period | <sup>t</sup> CYTK | 100 | | ns | | TCLK rise time | · tткн | | 15 | ns | | TCLK fall time | tTKF | | 15 | ns | | TCLK low-level width | <sup>†</sup> TKTKL | 45 | | ns | | TCLK high-level width | tткткн | 30 | | ns | | TCTL0-TCTL2 setup time to TCLK 1 | tsатк | 50 | | ns | | TCTL0-TCTL2 hold time from TCLK 1 | <sup>†</sup> нтка | 100 | | ns | | TOUT0-TOUT2 output<br>delay from TCLK↓ | <sup>†</sup> откто | | 100 | ns | | TOUT0-TOUT2 output<br>delay from TCTL ↓ | <sup>‡</sup> DGTO | | 100 | ns | | Parameter | Symbol | Min | Max | Uni | |----------------------------------------------------|---------------------|------------------------|-----|-----| | Serial Control Unit, | SCU (figu | re 22) | | | | RxD setup time vs<br>SCU internal CLK ↓ | <sup>t</sup> SRX | 1 | | ns | | RxD hold time vs SCU<br>internal CLK↓ | tHRX | 1 | | ns | | TOUT1 ↑ to TxD delay | tотх | | 500 | ns | | Direct Memory Acce | ss, DMA (f | igures 24-26) | | | | CLKOUT ↓ to MRD,<br>IORD ↑ delay | †DKRH | 0 | 40 | ns | | CLKOUT ↓ to MRD,<br>IORD ↓ delay | <sup>t</sup> OKRL | 0 | 40 | กร | | CLKOUT ↑ to<br>DMAAKO-DMAAK3<br>delay | <sup>‡</sup> DKHDA | 0 | 40 | ns | | IORD ↓, IOWR ↓ delay '<br>from DMAAK0-<br>DMAAK3 ↓ | <sup>‡</sup> ODARW | t <sub>KKH</sub> - 30 | | ns | | DMAAKO-DMAAK3 ↑<br>delay from IORD ↑ | <sup>†</sup> DRHDAH | t <sub>KKH</sub> − 30 | | ns | | CLKOUT to control 1 delay | <sup>†</sup> DKCT1 | 0 | 40 | ns | | IORD ↑ delay to IOWR<br>↑ | †owhrh | 5 | 40 | | | TC output delay from<br>CLKOUT ↑ | toktol. | 0 | 40 | ns | | TC off output delay from CLKOUT 1 | †DKTCF | 0 | 40 | ns | | TC pullup delay from<br>CLKOUT 1 | <sup>†</sup> DKTCH | 0 | 40 | ns | | TC low-level width | †TCTCL | toyo - 15 | | ns | | END setup time to CLKOUT ↑ | tsedk | 35 | | ns | | END low-level width | †EDEDL | 100 | | ns | | IORD, MRD low-level<br>width | t <sub>RR</sub> | 2t <sub>CYC</sub> - 40 | | | | OWR, MWR low-level<br>width (Expanded<br>write) | tww | 2t <sub>CYC</sub> 40 | | | | OWR, MWR low-level<br>width (Normal write) | t <sub>WW2</sub> | t <sub>CYC</sub> - 40 | | | | DMARQ0-DMARQ3<br>setup time to<br>CLKOUT 1 | tsdak | 15 | | ns | | CLKOUT↓to<br>DMAAKO-DMAAK3<br>delay | <sup>‡</sup> DKLDA | 0 | 45 | ns | | Interrupt Control Ur | nit, ICU (fig | ure 27) | | | | NTP0-INTP7 low-level width | t <sub>IPIPL</sub> | 100 | | ns | | | | | | | Figure 1. Clock Timing Figure 2. Reset Timing T-49-17-15 Figure 3. Basic Write (0 Wait) Figure 4. Basic Write (1 Wait) Figure 5. Basic Read (0 Wait) NEC T-49-17-15 Figure 6. Basic Read (1 Walt) Figure 7. External I/O Read (0 Wait) NEC T-49-17-15 Figure 8. External I/O Read (1 Wait) Figure 9. External I/O Write (0 Wait) T-49-17-15 Figure 10. External I/O Write (1 Wait) NEC T-49-17-15 Figure 14. Bus Sizing (1 Wait) T-49-17-15 ## Figure 15. Input Setup/Hold ## Figure 16. Bus Lock Hi - Z ## μPD70236 (V53) 63YL-6371B # NEC ## μPD70236 (V53) Figure 18. Interrupt Acknowledge (Single Mode) Figure 19. Interrupt Acknowledge (Cascade Mode) T-49-17-15 ## Figure 20. Timer Control Unit (TCU) ## Figure 22. Refresh Timing NEC μPD70236 (V53) Figure 23. DMA Timing 1 NEC T-49-17-15 Figure 24. DMA Timing 2 Figure 25. DMA Timing 3; Cascade Mode (Normal Operation) T-49-17-15 Figure 26. DMA Timing 4; Refresh Cycles To Be Inserted Figure 27. ICU Timing NEC T-49-17-15 Figure 28. Memory Write for Coprocessor (0 Wait) NEC T-49-17-15 Figure 30. Memory Read for Coprocessor (0 Wait) T-49-17-15 Figure 31. Memory Read for Coprocessor (1 Wait) T-49-17-15 #### **FUNCTIONAL OPERATION** The $\mu$ PD70236 is described under these major headings. - Central Processing Unit - Clock Generator - Bus Operation - System Control I/O - Wait Control Unit - Refresh Control Unit - Timer/Counter Unit Serial Control Unit - Interrupt Control Unit - DMA Control Unit - Power Conservation Figure 32. CPU Block Diagram T-49-17-15 ### **CENTRAL PROCESSING UNIT (CPU)** #### **Architecture** A unique hardware architecture feature of the CPU is that it contains no microcode. Instruction decode and data path control are implemented using logic and small independent state machines. This greatly enhances instruction execution speed. The V53 is four times faster than the V30. The CPU comprises the execution unit and the address generator. Figure 32 is the CPU block diagram. #### **CPU** Execution Unit The execution unit consists of a register file, an ALU, and instruction decode and execution control logic. In addition to the hardware control logic, the most significant feature of the execution unit is a dual-bus internal data path (figure 33). The ALU and many registers are dual ported with a data bus on each port. This allows two operands to be transferred in one clock cycle instead of two. Performance is improved as much as 30% by the dual data bus concept. Figure 33. Dual Data Buses Register File. There are 12 registers in the internal RAM. Four are temporary registers used in the execution of certain instructions (LC, TA, TB, and TC). The other eight are general-purpose registers (AW, BW, CW, DW, IX, IY, BP, and SP). These contain either operand data or point-tooperand data in memory. The temporary registers speed up instruction execution by serving as scratch pad registers during complex operations. The loop counter (LC) is used during primitive block transfer operations. It contains the count value. It is also a shift counter for multiple-bit shift and rotate instruc- Temporary registers TA, TB, and TC are inputs to the ALU. They are used as temporary registers/shifters during multiply, divide, shift/rotate, and BCD rotate opera- ALU. The ALU consists of a complete adder and logical operation unit. It executes arithmetic (ADD, SUB, MUL, DIV, INC, DEC, NEG, etc.) and logical (TEST, AND, OR, XOR, NOT, SET1, CLR1, etc.) instructions. blocks. Its purpose is to determine which operations must be done and to schedule them. It transfers operands, as required, and controls the ALU. State machines implement long, complex instructions. Instruction Prefetching. The V53 is a pipelined machine. To keep the pipeline running efficiently, it should be kept full of instructions in various stages of execution. Instructions are fetched before they are needed and placed in the instruction processing queue (IPQ). Data in the IPQ is broken out by the decoder logic to determine what addressing modes will be used and what CPU resources are required to execute the prefetched instruction. To keep the 8-byte IPQ full, the bus control logic schedules an instruction prefetch cycle whenever there are at least 2 unused bytes in the IPQ. The IPQ is cleared whenever a control transfer instruction (any branch, call, return, or break is executed). This is done because a different instruction stream will be used following a control transfer, and the IPQ will then contain instruction data that will never be used. When this happens, the V53's pipeline is emptied and performance is reduced. To maximize performance, the number of control transfers should be minimized. Effective Address Generator. The effective address generator (EAG) logic computes a 16-bit effective address for each operand. This address is an offset into one of the four segments. Refer to figure 34. This effective address is passed on to the address modifier adder. The EAG decodes the first byte(s) of each instruction to T-49-17-15 determine the addressing mode and initiates any bus cycles required to fetch pointers/offsets from memory. Effective addresses are calculated in a maximum of 1 clock period as compared with 5 to 12 clocks for a microprogrammed machine. Figure 34. Effective Address Generator #### **Address Generator** The address generator comprises the address register file, the address modifier (ADM), the address translation table, and the needed control logic. The registers in the address register file are PS, SS, DS0, DS1, PC, and PFP. The ADM is a dedicated adder that adds one of the segment registers to the effective address to produce the 20-bit normal address. The ADM also increments the prefetch pointer. If extended addressing is enabled, the address translation table is accessed to map the 20-bit address into a 24-bit extended address. For instruction stream data, addresses are generated differently. The prefetch pointer contains a 16-bit offset into the PS segment that points to the next instruction word to be prefetched. The program counter contains an offset into the PS segment that points to the instruction that is currently being executed. As part of all control transfers, the PFP is set to the same value as the PC. #### CPU Addressing Mechanism The V53 is completely compatible with the $\mu$ PD70108/116 in its addressing modes and in the way that addresses are computed. It offers a method of expanding the memory address space to 16M bytes. The I/O space is 64K bytes (16-bit address). The normal memory address space is 1M byte (20-bit address), and the expanded address space is 16M bytes (24-bit address). See figure 35. Expanded addressing is enabled or disabled using the BRKXA and RETXA Instructions. The memory space is accessed when an instruction uses a memory addressing mode. Memory addresses are calculated as described below. The I/O space can only be accessed through the IN, OUT, INM, and OUTM instructions. Certain areas of the V53 address spaces (physical for normal mode and logical for expanded addressing mode) are reserved. Memory addresses 0-3FCH are used for the interrupt vector table (figure 35) located in the interrupt operation section. Memory addresses FFFF0H-FFFFFH must contain a branch to boot code; PC, PFP, and PS are initialized at RESET to point to this area. I/O addresses FF00H-FFFFH are reserved for the address translation registers and system control registers. The DMAU, TCU, ICU, and SCU sections each contain a block of registers with programmable base addresses. They may be located inside any 256-byte block in the I/O space. See figure 36. Figure 35. Memory Address Space #### I/O Addresses I/O devices can be referenced by 8-bit immediate addresses or by 16-bit addresses via the DW register. If I/O operations require other more complex addressing modes, the I/O devices must be placed in the memory address space (using memory-mapped I/O techniques). For memory-mapped I/O devices, there are no restrictions on instruction or addressing mode usage. However, the V53 will not automatically insert 6 clock cycles after T-49-17-15 memory-mapped I/O operations; external logic must provide the necessary I/O device recovery time. Figure 36. I/O Address Space #### **Normal Memory Addresses** The V53 is a 16-bit device with 16-bit registers. To allow a memory address space larger than 64K bytes, memory segmentation is used. The 1M-byte memory address space is divided into 64K-byte segments. Up to four segments can be in use at any given time. The base addresses of the four active segments (program segment, stack segment, data segment 0, and data segment 1) are contained in four 16-bit segment registers (PS, SS, DS0, and DS1, respectively). The 16-bit value in each register is the upper 16 bits of the 20-bit memory address. Thus, segments must start on 16-byte boundaries. As described above, the V53 hardware generates a 16-bit effective address for each memory operation. This effective address is an offset into one of the four active segments. The actual 20-bit memory address is computed by adding the EA to the segment register value expanded with zeros to 20 bits. Figure 37 shows this process. Figure 37. 20-Bit Address If normal addressing mode is enabled, this 20-bit result is presented on the address bus during the bus cycle. If expanded addressing mode is enabled, this address is used as a logical address. #### **Expanded Addresses** In the expanded addressing mode, the memory space is divided into 1024 pages (figure 35). Each page is 16K bytes. Each page of the normal 20-bit address space is mapped to a page in the expanded address space using a 64-entry address translation table. The table is made up of 64 page registers that reside in the I/O space. The programming model of this mode is the same as for the normal mode. Address expansion is a layer added to the normal mode that is transparent to executing code. The program still sees a 20-bit contiguous logical memory address space, but the hardware sees 64 pages mapped into a set of 1024 physical pages. The I/O space is not affected by the expanded addressing mode. The address translation mechanism is shown in figure 38. The upper 6 bits of the logical 20-bit address select one of the entries in the address translation table, which supplies a 10-bit value. This value is substituted for the original 6 bits in the normal address to create a 24-bit expanded address. #### **Address Expansion Registers** These are the page and XAM registers, accessed by the word IN and OUT instructions. Figure 39 shows page register usage and I/O addresses. The page registers contain the 10-bit physical page base address. The XAM register is a read-only status flag that indicates whether expanded addressing is enabled. Unused data bits in the XAM register are read as 0. Expanded addressing must be disabled before accessing any of the page registers. That is, if expanded mode is enabled, the page registers cannot be accessed. This prevents an expanded mode task from accidentally modifying its memory map. Figure 39. Address Expansion Registers | | Page Registers | | |--------------------------------------------------|----------------|-----------------| | Logical Address A <sub>19</sub> -A <sub>14</sub> | PGR Selected | PGR I/O Address | | 0 | PGR1 | FF00 | | 1 | PGR2 | FF02 | | 2 | PGR3 | FF04 | | 3 | PGR4 | FF06 | | : | : | : | | 63 | PGR64 | FF7E | | XAM | Register | | | |-----|----------|---|---------| | | | • | XA Flag | | 15 | | 1 | 0 | #### **Operand Addressing Modes** For operand addressing, the V53 offers nine modes. - Register - Immediate - Direct - Register indirect - Indexed - Based - Based indexed - Rit - Autoincrement/autodecrement **Register.** The operand is in a V53 register pointed to by the instruction. Immediate. The operand is in the instruction stream following the opcode of the instruction. This data will have been prefetched. Immediate data uses the V53 pipeline efficiently. Direct. Immediate data in the instruction stream points directly to the operand. This data can be a 16-bit effective address or a bit field length of 4 bits. Register Indirect. A 16-bit register (IX, IY, or BW) contains a 16-bit effective address. Indexed. One or two bytes of immediate data are treated as a signed displacement that is added to the contents of a 16-bit index register (IX or IY) to obtain a 16-bit effective address. **Based.** One or two bytes of immediate data are treated as a signed displacement that is added to the contents of a 16-bit base register (BP or BW) to form a 16-bit effective address. **Based Indexed.** One or two bytes of immediate data are treated as a signed displacement that is added to two T-49-17-15 16-bit registers (BP or BW and IX or IY) to form the effective address. This mode is useful for array addressing. Bit. Used with NOT1, CLR1, or TEST1. A 4-bit immediate data value SET1 selects a bit in a 16-bit operand. For 8-bit operands, only 3 bits are used. Autoincrement/Autodecrement. Some iterative operations (such as MOVBK or INS) will automatically increment or decrement index registers after each iteration. Specifically, IX is used in addressing a source pointer, and/or IY is used in addressing a destination pointer. After the operation, both will be incremented or decremented (according to the PSW DIR control flag) to point to the next operand in the array. #### Instruction Addressing Modes Instruction address modes are basically the same as the operand addressing modes, but the PC is always used in the register. These modes are used in control transfer instructions. - Direct - Relative - Register - Register indirect - Indexed - Based - Based indexed **Direct.** Four bytes of immediate data are taken as an absolute address and loaded directly into the PS and PC (and PFP). **Relative.** One or two bytes of immediate data are a signed displacement that is added to the contents of the PC, and then placed in the PC (and PFP). This mode is useful to create position-independent code. Register. The register selected by the instruction (AW, BW, etc.) contains an effective address, which is loaded into the PC (and PFP). Register Indirect. An index register (IX, IY, or BW) points to a memory location that contains an effective address (short pointer) or a segment register value and the effective address (far pointer). This effective address is read from memory and loaded into the PS and/or PC (and PFP). Indexed. One or two bytes of immediate data are a signed displacement added to the contents of a 16-bit index register (IX or IY) to form an effective address. This address is used to fetch another effective address from memory, which is then loaded into the PC (and PFP). Based. One or two bytes of immediate date are a signed displacement added to the contents of a 16-bit base register (BP or BW) to form an effective address. This address is used to fetch another effective address from memory, which is then loaded into the PC (and PFP). Based Indexed. One or two bytes of immediate data are a signed displacement added to the contents of two 16-bit registers (BP or BW and IX or IY) to form an effective address. This address is used to fetch another effective address from memory, which is then loaded into the PC (and PFP). #### **CPU Register Configuration** Program Counter (PC). The PC is a 16-bit register containing the effective address of the instruction currently being executed. The PC is incremented each time the instruction decoder accepts a new instruction from the prefetch queue. The PC is then loaded with a new value during execution of a branch, call, return, or break instruction, and during interrupt processing. Segment Registers (PS, SS, DS0, DS1). There are four segment registers, each containing the upper 16 bits of the base address of a 64K logical segment. Since logical segments reside on 16-byte boundaries, the lower 4 bits of the base address are always zero. Normal 20-bit memory addresses are formed by adding the 16-bit effective address to the base address of one of the segments. During this operation, certain types of effective addresses will be paired with specific segment registers. | Segment Register | Default Offset | |----------------------|-----------------------| | PS (program segment) | PFP | | SS (stack segment) | SP, effective address | | DS0 (data segment 0) | IX, effective address | | DS1 (data segment 1) | ΙΫ́ | Program instructions will always be fetched from the program segment. Whenever the IY index register addresses an operand, the DS1 segment register will be used. DS0 is usually used with IX. Stack operations with the SP will always use the stack segment. For other effective addresses, the table above shows the default segment, but another segment may be selected by a segment override prefix instruction. General-Purpose Registers (AW, BW, CW, DW). The four 16-bit general-purpose registers can be accessed as 16-bit or 8-bit quantities. When the AW, BW, CW, or DW destination is used, the register will be 16 bits. When AL, AH, BL, BH, CL, CH, DL, or DH is used, the register will be 8 bits. AL will be the low byte of AW and AH will be the high byte, etc. Some operations require the use of specific registers. | Register | Operation | |----------|-------------------------------------------------------| | AW | Word multiplication/division, word I/O, | | | data conversion | | AL | Byte multiplication/division, byte I/O, BCD | | | rotation, data conversion, translation | | AH | Byte multiplication/division | | BW | Translation | | CW | Shift instructions, rotation instructions, | | | BCD operations | | DW | Word multiplication/division, indirect addressing I/O | | | | Pointer (SP, BP) and Index Registers (iX, IY). These registers are used as base pointers and index registers when based, indexed, or based indexed addressing modes are used. They may also be used as general-purpose registers for data transfer, arithmetic, and logical instructions. They can only be accessed as 16-bit registers. Some operations use these registers in specific ways. | Register | <u>Operation</u> | |----------|-----------------------------------------------| | SP | Stack operations | | IX | Source pointer for block transfer, bit field, | | | and BCD string operations | | ΙΥ | Destination pointer for block transfer, bit | | | field, and BCD string operations | Program Status Word (PSW). The program status word reflects the status of the CPU by six status flags and affects the operation of the CPU by three control flags. | 15 | | | | F | PSW | | | 8 | |----|---|---|-----|----|-----|-----|----|-----| | | 1 | 1 | 1 | 1 | ٧ | DIR | IE | BRK | | 7_ | | | | | | | | 0 | | | S | Z | . 0 | AC | 0 | P | 1 | CY | | | <del></del> | <u> </u> | | |----|-----------------|----------|------------------| | | s Flags | Contro | | | ٧ | Overflow | DIR | Direction | | S | Sign | ΙE | Interrupt enable | | Z | Zero | BRK | Break | | AC | Auxiliary carry | | | | Р | Parity | | | The DIR control flag determines whether address pointers are incremented (1) or decremented (0) for block (string) operations. IE enables interrupts (1) or disables interrupts (0). BRK enables (1) or disables (0) the single stepping trap (vector 1). The PSW cannot be accessed directly as a 16-bit register. Specific instructions set/reset the control flags. When the PSW is pushed on the stack (as during interrupt processing), the PSW is set as shown in the diagram #### Interrupt Operation The interrupts supported by the V53 can be divided into two types: those generated by external interrupt requests and traps generated by software processing. Interrupts of each type are listed below. - External Interrupts - NMI input (nonmaskable) - INTPO-INTP7 (maskable) - Software Traps - Divide error during DIV or DIVU instruction - Array bound error during CHKIND - Single-step (PSW BRK flag = 1) - Undefined instruction - Coprocessor error - Coprocessor not connected - Break instructions (BRKV, BRK3, BRK imm8, BRKXA) The eight INTP interrupts are handled by the interrupt control unit (ICU). The ICU prioritizes the INTPs and produces a single INT output, an internal signal that goes to the CPU interrupt logic. There the interrupt prioritization flow diagram (figure 40) is implemented. Interrupts are prioritized by the CPU as follows. NMI (highest priority INT **BRK** flag Other software interrupts and exceptions CY Carry T-49-17-15 Figure 40. Interrupt Prioritization Flow Diagram T-49-17-15 Interrupts are not accepted by the CPU at certain times. NMI, INT, and BRK flags are not accepted under the following conditions. - Between execution of a MOV or POP that uses a segment register as an operand and the next instruction. - (2) Between a segment override prefix and the next instruction. - (3) Between a repeat or BUSLOCK prefix and the next instruction. INT is not accepted when the PSW IE flag is 0, or between an RETI or POP PSW and the next instruction. Once an interrupt has been accepted by the CPU, an interrupt service routine will be entered. The address of this routine is specified by an interrupt vector stored in the interrupt vector table (figure 41). For most interrupts, the vector used depends on what interrupt is being processed (e.g., NMI always uses vector 2). For INT and BRK imm8 interrupts, any vector may be used; the vector number is supplied by the ICU or an external device (such as a $\mu$ PD71059) in the case of INT, or by immediate data in the case of BRK. The interrupt vector table uses 1K bytes of memory at addresses 000H to 3FFH and stores up to 256 vectors. Figure 41. Interrupt Vector Table Each interrupt vector consists of four bytes. The two low bytes are loaded into the PC as the offset, and the two high bytes are loaded into the PS as the base address. See figure 42. Figure 42. Interrupt Vector 0 Based on this format, the contents of each vector should be initialized at the beginning of the program. The basic mechanism for servicing an interrupt follows. $$(SP - 1, SP - 2) \leftarrow PSW$$ $(SP - 3, SP - 4) \leftarrow PS$ $(SP - 5, SP - 6) \leftarrow PC$ $SP \leftarrow SP - 6$ $IE \leftarrow 0, BRK \leftarrow 0$ $PS \leftarrow vector high bytes$ $PC \leftarrow vector low bytes$ When an Interrupt is accepted, two possible PC values could be saved. For some interrupts, the offset of the current instruction is saved. These interrupts are divide error, CHKIND, illegal opcode, $\mu$ PD72291 FPP error, other coprocessor error, and CP not present. For the other interrupts (NMI, BRK flag, BRK instruction, or ICU interrupt), the offset of the next instruction is saved. #### **CLOCK GENERATOR (CG)** The clock generator (figure 43) is driven by a crystal connected to pins X1 and X2 or an oscillator connected to pin X1 with no connection at pin X2. The source frequency is divided to supply various clocks to internal units (CPU, DMAU, etc.) and to external devices at pins CLKOUT and PCLKOUT. T-49-17-15 Figure 43. Clock Generator Diagram #### **BUS OPERATION** The V53 uses a synchronous bus interface. The X1 and X2 inputs provide a reference oscillator frequency for the internal clock generator, which supplies the main system clock to the other internal devices and to external devices via the CLKOUT pin. All V53 bus timings and instruction execution clock counts are specified relative to the CLKOUT signal. Bus cycles start on the falling edge of CLKOUT. The V53's internal bus is a multimaster, shared bus. The CPU, DMAU, or REFU can all be bus masters. Each requests bus mastership from the bus arbitration unit (BAU). External devices can also request mastership of the bus using the HLDRQ input. #### **Bus Interface Unit (BIU)** The BIU contains the interface logic that allows the three Internal bus masters (CPU, DMAU, and REFU) to control the external address, data, and control buses. The BIU also synchronizes the BS8/BS16, RESET, and READY inputs to the system clock. When a reset signal is accepted, the BIU asserts the RESOUT output. #### **Bus Arbitration Unit (BAU)** The BAU accepts and grants five different requests for bus mastership in the following priority order. REFU demand (highest) DMAU request HLDRQ CPU request REFU request The refresh unit is assigned both the highest and the lowest priorities. Normally, REFU requests are made, and if the bus is not granted, they are placed in a queue. Once the queue depth reaches seven requests, a refresh demand is made, and the BAU gives this the highest priority. #### **Bus Wait Function** When the bus is active and the BAU receives a higher priority request, the BAU will take away its grant to the current bus master. But the current master may not release the bus immediately. The BAU will wait until the current master takes away its request before granting the bus to the higher priority requester. This is called bus waiting. For example, if an external device has been granted the bus via the HLDAK output, and the DMAU requests the bus (DMA is higher priority than HLDRQ), the V53 will deassert HLDAK but will not take the bus back until the external master deasserts HLDRQ. Note that the external master is not required to immediately release the bus back to the V53; the BAU will wait until HLDRQ is removed. Usually a higher priority request will be granted quickly; for example, if a DMA request is accepted during T2 of a CPU bus cycle, the next bus cycle will usually be a DMA cycle. However, each internal bus master will hold onto the bus under certain circumstances. The CPU will not let go of the bus as long as the BUSLOCK prefix is used, or until the current bus operation is completely finished (an unaligned or bus-sizing operation may take more than one bus cycle). Likewise, when it is in bus hold mode, the DMAU will not release the bus until all active DMA requests have been processed. This mode should be used with care as it can result in DRAM refresh errors if the DMA takes a long time to complete. Note that bus hold mode is only available when DMAU is in $\mu$ PD71071 compatibility mode; $\mu$ PD71037 mode is always in bus release mode. NEC T-49-17-15 #### **External Bus Masters** At times, external bus masters will need to use the V53 bus. There are two methods provided for that purpose: hold request and DMA cascade. Up to five external bus masters can be connected to the V53. Hold Request. The external bus master can request the bus using a hold request. Hold request is implemented using the HLDRQ and HLDAK signals. The V53 grants the bus by floating many of its outputs and asserting HLDAK to notify the external device that the bus is now free. DMA Cascade. DMA cascade is very similar to hold request; the difference is that a DMARQ/DMAAK signal pair requests and grants the bus. While DMA cascade is meant to be used to connect additional DMA controllers, it can be used by any type of external bus master. Since there are four DMA channels, each of which can be in cascade mode, up to four external masters can be connected by DMA cascade. #### **Bus Cycle Descriptions** Each of the internal bus masters uses the V53 bus interface in a different way: DMA bus cycles have a different structure than CPU bus cycles or REFU cycles. There are 18 different V53 bus cycles summarized previously in table 1. #### **CPU Bus Cycles** The bus state diagram for CPU cycles is shown in figure 44. CPU bus cycles are nominally two clock periods long, and may be extended by adding wait states using either the internal wait state generator or the external READY input. Figure 44. CPU Bus State Diagram The first state of every bus cycle is T1, and it is followed immediately by T2. READY is sampled on the rising (middle) edge of T2. If READY is not asserted, the next bus state will be the TW wait state. TWs will be inserted until READY is sampled low, after which the bus cycle will finish. TWs also will be inserted by the wait state generator, and the READY input is ignored until all TWs programmed in the wait state have been inserted. The dynamic bus sizing input, BS8/BS16, is sampled at the same time as READY. Note that dynamic bus sizing is only implemented for CPU cycles; DMAU or REFU cycles do not use this input. Address and bus status are output after the leading edge of T1, and maintained until after the cycle is completed. A strobe, BCYST, is asserted during T1 to indicate the beginning of a bus cycle. BCYST is output following the leading edge of T1 and deasserted after the leading edge of T2. Write data is driven on $D_0$ - $D_{15}$ following the rising (middle) edge of T1, and maintained until after the rising edge of T2 or the last TW. Read data is sampled on the trailing T-49-17-15 edge of T2 or the last TW state. A strobe, DSTB, gives the status of the V53 data bus. DSTB is asserted after the rising (middle) edge of T1. DSTB is deasserted after the rising edge of T2 or the last TW for a write cycle, and after the trailing edge of T2 or the last TW for a read cycle. I/O cycles are identical to memory cycles except for the encoding of the bus status lines. However, six idle states are inserted after every I/O bus cycle to provide a recovery time for the I/O devices. #### **Dynamic Bus Sizing for CPU Cycles** The V53 supports dynamic bus sizing for CPU cycles. On a cycle-by-cycle basis, the width of the data bus can be changed from 16 to 8 bits. This simplifies connection with 8-bit I/O devices that may have internal registers at consecutive byte addresses. Other 16-bit CPUs require two ROMs for startup code, but the V53 dynamic bus sizing makes it possible to use a single 8-bit wide ROM. External logic requests an 8-bit data path by driving BS8/BS16 low in time for the V53 to sample it on the rising edge of T2 (or TW). The V53 will perform an additional cycle if needed to finish the operation in byte-wide pieces. If the bus operation is already 8 bits wide, no further bus cycles will occur (refer to tables 3 and 4). For a read cycle, the data will be sampled on D7-D0. For a write cycle to an even address, data will be driven on D7-D0. On all byte writes to an odd address, the V53 will put the byte data on both the upper and lower data buses so that the write data will be on D<sub>7</sub>-D<sub>0</sub> as well as D<sub>15</sub>-D<sub>8</sub>. If the bus operation is 16-bit, two bus cycles will be required. The first one, in which BS8/BS16 is sampled low, will handle the low byte. The second cycle will take the form of a byte read or write using D7-D0. Table 3. Write Cycle Bus Sizing | | | | | | 16-Bit Bus (B | \$8/B\$16 = 1) | 8-Bit Bus (BS | 88/BS16 = 0) | |------|---------|----------------|-----|-------|---------------------------------|--------------------------------|---------------------------------|--------------------------------| | Туре | Address | A <sub>0</sub> | ÜBE | Cycle | D <sub>15</sub> -D <sub>8</sub> | D <sub>7</sub> -D <sub>0</sub> | D <sub>15</sub> -D <sub>8</sub> | D <sub>7</sub> -D <sub>0</sub> | | Byte | Even | 0 | 1 | 1st | invalid | Lower | Invalid | Lower | | | Odd | 1 | 0 | 1st | Lower · | Lower | Lower | Lower | | Word | Even | 0 | 1 | 1st | Upper | Lower | Upper | Lower | | | | 1 | 0 | 2nd | Not needed t | or 16-bit bus | Upper | Upper | | | Odd | 1 | 0 | 1st | Lower | Lower | Lower | Lower | | | | 0 | 1 | 2nd | Lower | Upper | Lower | Upper | Note: Lower = low-order byte; Upper = high-order byte Table 4. Read Cycle Bus Sizing | | | | | | 16-Bit Bus (BS8/BS16 = 1) | | 8-Bit Bus (BS8/BS16 = 0) | B/BS16 = 0) | |---------------------------------|------|-------|---------------------------------|--------------------------------|---------------------------------|--------------------------------|--------------------------|-------------| | Type Address A <sub>0</sub> UBE | UBE | Cycle | D <sub>15</sub> -D <sub>8</sub> | D <sub>7</sub> -D <sub>0</sub> | D <sub>15</sub> -D <sub>8</sub> | D <sub>7</sub> -D <sub>0</sub> | | | | Byte | Even | 0 | 1 | 1st | Not used | Lower | Not used | Lower | | | Odd | 1 | 0 | 1st | Lower | Not used | Not used | Lower | | Word | Even | 0 | 1 | 1st | Upper | Lower | Not used | Lower | | | | 1 | 0 | 2nd | Not needed | for 16-bit bus | Not used | Upper | | | Odd | 1 | 0 | 1st | Lower | Not used | Not used | Lower | | | | 0 | 1 | 2nd | Not used | Upper | Not used | Upper | Note: Lower = low-order byte; Upper = high-order byte CPU Bus Cycle Types. There are many types of CPU bus cycles (shown previously in table 2). They comprise read, write, and acknowledge cycles. CPU Read Cycles. There are six CPU read cycles: memory, external I/O, internal I/O coprocessor, coprocessor data reads, and instruction fetch. All have the general timing described previously. Coprocessor reads access the internal registers of an external coprocessor. Coprocessor data reads transfer data from memory to an internal coprocessor register. Instruction fetches fill the V53's 8-byte instruction queue from the memory space. I/O and memory reads transfer data to the V53 from an ## ■ 6427525 0026881 T μPD70236 (V53) internal or external I/O device or a memory location. During internal I/O reads, the IORD and BUFEN outputs are not asserted. Dynamic bus sizing is ignored during internal I/O read cycles, and is not recommended for coprocessor data read cycles. The wait state generator does not affect internal I/O reads or coprocessor reads. READY is used for all CPU read cycles. CPU Write Cycles. There are five types of CPU writes. Memory writes transfer data from the V53 to a memory location. External and internal I/O writes transfer data from the V53 to external or internal I/O devices. During Internal I/O writes, the IOWR and BUFEN outputs are not asserted. Coprocessor data writes transfer data from an external coprocessor to a memory location. Coprocessor writes transfer data from the V53 directly to a coprocessor internal register. Dynamic bus sizing is ignored during internal I/O read/ writes, and is not recommended for coprocessor data write cycles. The wait state generator does not affect Internal I/O writes or coprocessor writes. READY is used for all CPU write cycles. Interrupt Acknowledge Cycles. The CPU interrupt acknowledge operation takes two consecutive bus cycles. The first cycle freezes the state of the internal interrupt control unit (ICU) and any external slave µPD71059 interrupt controllers. The second bus cycle reads an 8-bit vector number on D<sub>7</sub>-D<sub>0</sub>, supplied by either the ICU or an external slave. This vector number is then used by the CPU as an index into the interrupt vector table to select an interrupt handler. The BUSLOCK output is asserted for the first cycle, and remains asserted until after the second to guarantee that no other bus master will take control of the bus until the interrupt has been There are two types of interrupt acknowledge cycles produced by the V53: a master and a slave. The INTAK output is asserted for both types, and should be connected to the interrupt acknowledge inputs of all slave devices. The master cycle is used for the first INTAK to both internal and external ICUs, and the second INTAK to the internal ICU. The slave cycle is used only for the second INTAK to an external slave device. During the slave cycle, the address of the slave device to be used is presented on A2-A0. These address lines should be buffered and then connected to the slave address inputs of the external ICUs. Buffering is necessary because the slave address pins of external devices might be in an output state on power-up, producing a bus conflict on A<sub>2</sub>-A<sub>0</sub> if they are connected directly. Dynamic bus sizing is ignored during the interrupt acknowledge cycles. Wait states can be inserted by the Internal wait state generator or by the READY input. Halt Acknowledge Cycle. When the CPU executes a HALT instruction, a halt acknowledge bus cycle is issued to notify external logic that the V53 is entering a standby mode. This cycle is always two clocks long; READY is ignored and DSTB is not asserted. The V53 has several standby modes. #### **DMA Unit Bus Cycles** Figure 45 shows the bus state diagram for DMA bus cycles. There are eight different states. When the DMAU is idle, it is in state SI. In this state, it is continually sampling the four DMARQ inputs. When a request is detected, the DMAU requests use of the V53 bus from the BAU, and enters state So. It remains in So until the BAU grants the bus to the DMAU, at which point the actual DMA bus cycle starts with state S1. Addresses and control status are output along with BCYST and DMAAK. DMA bus cycles are nominally four clocks long, but they can be stretched by the internal wait state generator or READY. S1 always changes to S2 and then to S3. Memory and I/O strobes are asserted during \$2, \$3, and SW. READY is sampled during \$2 for use during \$3. If waits are inserted, the SW state is entered. Control stays in that state until no more waits are desired. If no waits are inserted, S3 moves to S4 and the current cycle is Depending on the DMA mode, another DMA cycle might be ready to start immediately (e.g., in burst mode), or another DMA request input may now be asserted. During S4, a decision is made whether to begin another DMA cycle at S1, to return to SI, or to enter the bus wait state S4W. The latter transition will be made if another DMA cycle is ready to start but the BAU has taken the bus away from the DMAU. In S4W, the DMAU releases the bus, but is ready to begin as soon as the bus is granted again and the DMA request is still pending. T-49-17-15 Figure 45. DMAU Bus State Diagram DMA Read Cycle . The DMAU performs "fly-by" DMA. During one DMA read bus cycle, data moves from the source address in memory to the destination I/O device. The V53 puts the memory address on $A_{23}$ - $A_{0}$ , and asserts MRD. At the same time, $\overline{IOWR}$ is asserted. Memory will drive the DMA data onto the bus, and the $\overline{IOWR}$ signal will latch the data into the I/O device. $\overline{DMAAK}$ should be used to control chip select at the I/O device. Since the V53 does not use the data, $\overline{BUFEN}$ is not asserted during DMA bus cycles. DMA Write Cycle.The DMAU performs "fly-by" DMA. During one DMA write bus cycle, data moves from the source I/O device to the destination address in memory. The V53 puts the memory address on A<sub>23</sub>-A<sub>0</sub>, and asserts MWR. At the same time, IORD is asserted. The I/O device will drive the DMA data onto the bus, and the MWR signal will latch the data into memory. DMAAK should be used to control chip select at the I/O device. Since the V53 does not use the data, BUFEN is not asserted during DMA bus cycles Note that when DMA writes are made to DRAM, it may be necessary to generate a delayed CAS strobe because the data is being supplied by an I/O device that may have long access time. The write data may not be valid when the normal CAS signal is asserted. Dynamic bus sizing cannot be used for DMA operations. The Internal wait state generator and READY can be used to stretch the cycle. DMA Cascade. During DMA cascade, the DMA state machine releases the V53 bus to an external bus master such as a $\mu\text{PD71071}$ or $\mu\text{PD71037}$ DMA controller. DMAAK is connected to the HLDAK input of the external device. DMAAK will stay asserted until the external master deasserts DMARQ. If the V53 BAU needs to give the bus to a higher priority bus master, DMAAK will be deasserted. The external bus master is expected to then deassert the DMARQ input, at which point the bus will be given to the higher priority bus master. #### Refresh Unit Bus Cycles The refresh unit performs memory read cycles from consecutive memory addresses. These bus cycles are the same as CPU memory read cycles, except that the REFRQ output is asserted. External logic should use the REFRQ logic to enable RAS for all memory banks, regardless of the address decoding scheme, so that all banks are refreshed. NEC Dynamic bus sizing cannot be used during refresh operations. The internal wait state generator and $\overline{\text{READY}}$ can be used to stretch the cycle. #### SYSTEM INTERFACE #### **System Memory Access Time** Table 5 shows the system memory access time required for 12.5-MHz and 16-MHz V53 systems to run with zero, one, two, and three wait states. This is the time from when the address bus is valid to when the external system must present the read data on the data bus. These numbers are based on the preliminary ac timing given in this document and are subject to change. Table 5. Performance vs. Wait States | | | 12.5 MHz | 2 | 16 MHz | | | | |-----------------------------|---------------------------------|----------------------------------|-------------------------------------|---------------------------------|----------------------------------|-------------------------------------|--| | Number<br>of Wait<br>States | Memory<br>Cycle<br>Time<br>(ns) | System<br>Access<br>Time<br>(ns) | Relative<br>Perfor-<br>mance<br>(%) | Memory<br>Cycle<br>Time<br>(ns) | System<br>Access<br>Time<br>(ns) | Relative<br>Perfor-<br>mance<br>(%) | | | 0 | 160 | 113 | 78 | 125 | 78 | 100 | | | 1 | 240 | 193 | 64 | 187.5 | 140.5 | 82 | | | 2 | 320 | 273 | 52 | 250 | 203 | 67 | | | 3 | 400 | 353 | 43 | 312.5 | 265.5 | 56 | | Note: Performance is relative to the 0 wait state, 16 MHz. #### **Wait States** Table 5 also illustrates the effect of wait states on performance. The V53 CPU overlaps bus interface operations in time with instruction execution. This greatly reduces the effect of wait states on performance. Each bus cycle is nominally two clocks long, while the minimum instruction is two clocks with many instructions taking longer. There is some idie bus time when the CPU is processing a long instruction and the prefetch queue is full. Wait states can often fill these idle states. However, adding wait states to bus cycles reduces the bus bandwidth available for other bus masters, such as DMA controllers. This is because some of the idle time that would have been available to them is used for CPU cycles. Note that in all cases, a 16-MHz V53 with N+1 wait states is faster than a 12.5-MHz device with N wait states but slower memory. Note also that the numbers are for comparison only. Different results will be obtained for other program mixes. #### Interfacing the µPD72291 AFPP The AFPP is a very-high-performance floating-point coprocessor able to process more than 530K floating-point operations per second at 16 MHz. The AFPP is programmed as an extension of the V53 instruction set. The AFPP executes floating-point operations, computes transcendental functions, and performs vector multiplications. AFPP instructions use the FP01 and FP02 formats. When one of these opcodes is encountered and an AFPP is connected, a coprocessor protocol routine is entered. The V53 computes any effective addresses required, reads or writes the operands for the AFPP, and tells the AFPP which operation should be performed. The AFPP responds by asserting its BUSY output when it starts the operation. The V53 will not start another AFPP operation until BUSY is deasserted, but may execute CPU instructions. When BUSY is deasserted, the V53 will transfer the AFPP status to the AW register. Figure 46 shows how to connect a V53 CPU to a $\mu$ PD72291 AFPP. The CPU reads and writes status and commands to the AFPP using coprocessor read and write cycles, which always take two clocks. AFPP operands are written using coprocessor memory write/read cycles, which always require one wait state. The V53 automatically inserts one wait state into these cycles so no external wait generation logic is required. T-49-17-15 Figure 46. Connections Between the V53 and µPD72291 On reset, CPBUSY is sampled. If it is low, the V53 assumes that a coprocessor is connected. CPERR is also sampled to determine what kind of coprocessor is connected as follows. | CPBUSY | CPERR | Coprocessor Connected | |--------|-------|-----------------------| | 1 | x | None | | 0 | 0 | μPD72291 | | 0 | 1 | Another kind | AFPP memory operands must always begin on an even address and may not reside in 8-bit wide memory. Dynamic bus sizing may not be used for AFPP operands. ### SYSTEM CONTROL I/O #### **On-Chip Control Registers** The V53 provides many on-chip control registers. Some of these reside in the 256-byte system I/O area (I/O space addresses FF00 to FFFF). These are shown in table 6. Other registers reside in small blocks associated with an on-chip peripheral (addresses are programmable). There are register blocks for DMAU, TCU, ICU, and SCU. The base addresses for these register blocks are programmable using the OPHA, DULA, TULA, and SULA registers in the system I/O area. See figure 47. Figure 47. Peripheral Relocation Table 6. System I/O Area | I/O Address | Register Name | Figure | |-------------|---------------|--------| | FFFFH | Reserved | - | | FFFEH | SCTL | 48 | | FFFDH | OPSEL | 49 | | FFFCH | ОРНА | 50 | | FFFBH | DULA | 50 | | FFFAH | IULA | 50 | | FFF9H | TULA | 50 | | FFF8H | SULA | 50 | | FFF7H | Reserved | | | FFF6H | WCY4 | 61 | | FFF6H | WCY3 | 60 | | FFF4H | WCY2 | 59 | | FFF3H | WMB1 | 55 | | FFF2H | RFC | 62 | | FFF1H | SBCR | 110 | | FFF0H | TCKS | 51 | | FFEFH-FFEEF | Reserved | - | | FFEDH | WAC | 56 | | FFECH | WCY0 | 57 | | FFEBH | WCY1 | 58 | | FFEAH | WMB0 | 54 | | FFE9H | BRC | 52 | | FFE8H | Reserved | - | | FFE7H-FFE2H | Reserved | - | T-49-17-15 Table 6. System I/O Area (cont) | | Figure | |-----------------|-------------------------------------| | BADR | 102 | | BSEL | 103 | | Reserved | _ | | XAM (Read Only) | 39 | | PGR64-PGR1 | 39 | | | BSEL<br>Reserved<br>XAM (Read Only) | #### System Control Register (SCTL) The SCTL register (figure 48) selects the 8-bit or 16-bit boundary of an internal peripheral relocation address. It also sets the internal DMAU in the $\mu\text{PD71071}$ or $\mu\text{PD71037}$ modes. In $\mu\text{PD71037}$ mode, SCTL controls propagation of carry from $A_{15}$ to $A_{16}$ or from $A_{19}$ to $A_{20}$ SCTL selects the baud rate generator or TOUT as the SCU clock. Figure 48. System Control Register (SCTL) | _ | | - | SC | CE1 | CE0 | DMAM | IOAG | | | | |------|--|--------------------------------------|----------------------|-----------|---------|------|------|--|--|--| | 7 | | | Address | FFFEH | | | . 0 | | | | | SC | | SCU Input Clock | | | | | | | | | | 0 | | | FOUT1 | ıd rate g | enerato | • | | | | | | CE1 | | Carry to A <sub>20</sub> in μPD71037 | | | | | | | | | | 0 | | Does not propagate<br>Propagates | | | | | | | | | | CEO | | Ç | erry to A | 16 ln μP | D71037 | | | | | | | 0 | | | Does not<br>Propagat | | ite | | | | | | | DMAM | | DI | MAU Mo | de | | | | | | | | 0 | | | μPD7107<br>μPD7103 | | | | | | | | | IOAG | | ln | ternal I/ | O Addre | 88 | | | | | | | 0 | | | Even or o | | | | | | | | #### On-Chip Peripheral Selection Register (OPSEL) The OPSEL registers (figure 49) controls the V53 internal peripherals. Any of the four peripherals (DMAU, TCU, ICU, or SCU) can be independently enabled or disabled by setting the appropriate OPSEL bit. Figure 49. On-Chip Peripheral Selection Register (OPSEL) | _ | _ | - | I – | SS | TS | IS | DS | | | |-----|---------------------|---------------|---------------------|---------|----|----|----|--|--| | 7 | | | | | | | 0 | | | | SS | | SC | CU Oper | ation | | | | | | | 0 | Disabled<br>Enabled | | | | | | | | | | TS | | TCU Operation | | | | | | | | | 0 | Disabled<br>Enabled | | | | | | | | | | IS | | IC | U Opera | tion | | | | | | | 0 | | | Disabled<br>Enabled | | | | 4 | | | | D\$ | | DI | MAU Op | eration | | | | | | | 0 | | | Disabled<br>Enabled | | | | : | | | | | | | | | | | | | | #### Internal Peripheral Relocation Registers The five internal peripheral registers fix the I/O addresses of the DMAU, ICU, TCU, and SCU. Register OPHA fixes the high-order byte of the 16-bit I/O addresses. Registers DULA, IULA, TULA, and SULA select the low-order byte of the I/O addresses for the DMAU, ICU, TCU, and SCU peripherals, respectively. The formats of the individual internal peripheral registers are shown in figure 50. Since address checking is not performed, two peripheral I/O address spaces should not be overlapped. T-49-17-15 Figure 50. Internal Peripheral Relocation Registers I/O Address FFF8H The IOAG bit of the SCTL register changes how the DULA, IULA, TULA, and SULA registers are used. When IOAG = 1, the DAMU, ICU, TCU, and SCU registers are on contiguous bytes. When IOAG = 0, each of these byte-wide registers is put on a word boundary. Bit $A_0$ selects the low or high byte of the word. This allows code written for a 16-bit system to be ported to a V53 design with no modifications. Because the DMAU registers in $\mu$ PD71071 mode are 16-bit, the IOAG bit in figure 50 is noted as "x" (don't care). ### Timer Clock Selection Register (TCKS) The TCKS register (figure 51) selects the clock source for the timer/counters as well as the divisor for the internal clock prescaler. The clock source for each timer/counter is independently selected from an internal clock (figure 43) or an external clock source (TCLK). The frequency of the internal clock selected by bits 2, 3, and 4 is programmable. The PS bits allow the clock to be set to the external oscillator frequency divided by 4, 8, 16, or 32. Figure 51. Timer Clock Selection Register (TCKS) | rigure | :01. | imer ( | CIOCK | seiect | ıon Kegi | ster (TCKS) | | | | | |----------------------|----------------------------|----------------------------|---------------------|----------|------------|-------------|--|--|--|--| | | - | _ | CS2 | CS1 | CS0 | PS | | | | | | 7 | I/O Address FFF0H | | | | | | | | | | | CS2 | | Clock input to TCT2 | | | | | | | | | | 0 | | Internal clock<br>TCLK pin | | | | | | | | | | CS1 | Clock Input to TCT1 | | | | | | | | | | | 0 | internal clock<br>TCLK pin | | | | | | | | | | | CS0 | | Cle | ock Inpu | t to TCT | 0 | | | | | | | 0 | | | nternal<br>ICLK pin | | | | | | | | | PS | | Pre | scale D | ivisor o | f External | Oscillator | | | | | | 00<br>01<br>10<br>11 | | | | | | | | | | | T-49-17-15 #### **Baud Rate Counter (BRC)** The BRC (figure 52) is an 8-bit, frequency-division counter for the dedicated baud rate generator. It sets the value by which an internal frequency is to be divided to provide the SCU with its baud rate clock. Flaure 52. Band Rate Counter (BRC) | - | -5 | | | | | ( | | | | |---|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--| | ı | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | ż | , | | | I/O Addr | ess FFE | 9H | ٠, | 0 | | Table 7 Illustrates the relationship between the baud rate and the value set in the BRC. Table 7. Baud Rate Setting by BRC | Oscillation frequency | 24,576 MHz | | 29.4912 | MHz | |---------------------------|------------|-----------|-------------|--------| | Oscillation frequency ÷ 2 | 12.288 | MHz | 14.7456 | MHz | | Baud rate factor (+) | 16 | 64 | 16 | 64 | | Internal frequency | 0.768 | 0.192 | 0.9216 | 0.2304 | | Baud Rate | Numbe | r of Coun | ts Set in E | BRC | | 1200 | | 160 | | 192 | | 2400 | _ | 80 | _ | 96 | | 4800 | 160 | 40 | 192 | 48 | | 9600 | 80 | 20 | 96 | 24 | | 19,200 | 40 | 10 | 48 | 12 | | 38,400 | 20 | 5 | 24 | 6 | #### WAIT CONTROL UNIT The wait control unit (WCU) inserts from 0 to 7 wait states (TW) into a bus cycle to compensate for the varying access times of different memory and I/O devices. Each wait state is equivalent to one CPU clock cycle. The number of wait states can be individually programmed for CPU, DMAU, REFU, INTAK, and external I/O cycles. The INTAK cycles can be programmed for 2-7 wait states. For memory accesses, the address space is divided into a total of six sections (labeled High, Middle, and Low in figure 53). A different number of wait states can be programmed for each section, allowing much flexibility in the system design. The WCU works with the external READY input. After the proper number of TWs have been inserted into the bus cycle, READY will be sampled, and wait states will be inserted until it is asserted. Figure 53. Memory Space Division The WCU can insert waits into memory or external I/O cycles, but not into coprocessor, internal I/O, or halt acknowledge cycles. Eight system I/O registers (figures 54-61) control the WCU. They are the wait state memory boundary registers (WMB0 and WMB1), the WCU address control register (WAC), and the wait state cycle count registers (WCY0-WCY4). #### Memory Boundary Registers (WMB0, WMB1) The WMB0 register divides the entire 16M-byte address space into three sections. The ELMB and EUMB fields specify the size of the upper and lower memory blocks. The middle block is the area left in between. The WCY0 and WCY1 registers specify the wait states of each expanded memory block. In addition to dividing expanded memory, a specific 1M-byte memory area can also be partitioned into three blocks for wait state generation. The WAC register determines which 1M-byte area is referenced. The WMB1 register divides this area into three blocks in the same manner as described above for WMB0. Registers WCY2 and WCY3 specify the wait states for each block and also I/O. T-49-17-15 #### Figure 54. Memory Boundary Register 0 (WMB0) | _ | ELMB | _ <u>-</u> - | EUMB | Ź | | |---|-------------------|--------------|------|---|--| | 7 | I/O Address FFEAH | | | | | | | | ~ | | _ | | | ELMB/EUMB | Memory Block Size (Bytes) | | | | | |-----------|---------------------------|---|--|--|--| | 000 | 1M | | | | | | 001 | 2M | | | | | | 010 | 3M | | | | | | 011 | 4M | | | | | | 100 | 5M | | | | | | 101 | 6M | · | | | | | 110 | 7M | | | | | | 111 | 8M | | | | | ### Figure 55. Memory Boundary Register 1 (WMB1) | | LMB | - | UMB | |---|-------|---------------------------------------|------| | 7 | I/O A | ddress FFF | 3H 0 | | | | · · · · · · · · · · · · · · · · · · · | | | LMB/UMB | Memory Block Size (Bytes) | | | | | |---------|---------------------------|--|--|--|--| | 000 | 32K | | | | | | 001 | 64K | | | | | | 010 | 96K | | | | | | 011 | 128K | | | | | | 100 | 192K | | | | | | 101 | 256K | | | | | | 110 | 384K | | | | | | 111 | 512K | | | | | ### Figure 58. WCU Address Control Register (WAC) | | | o control frequency | |---|---------|---------------------| | | | UWA | | 7 | I/O Add | ress FFEDH 0 | UWA = Upper 4 bits of expanded address specifying a 1M-byte memory space ### Wait State Cycle Count Registers (WCY0-WCY4) Each WCY register has one or two 3-bit fields that set the number of waits for a particular kind of cycle or the number of waits to be inserted into cycles during which certain memory blocks are accessed. - (1) WCY0 and WCY1 (figures 57 and 58) pertain to the 16M-byte memory space set by the WMB0 register. - (2) WCY2 and WCY3 (figures 59 and 60) pertain to the 1M-byte memory space set by the WMB1 register. - (3) Also, the IOW field of WCY3 sets the number of waits for external I/O cycles and interrupt acknowledge cycles. - (4) The waits set by WCY3 cannot be inserted into the internal I/O area read/write cycle. - WCY4 (figure 61) sets the number of waits for DMA cycles and refresh cycles. After RESET, the WCY registers are set to all 1s, thereby inserting seven waits into all cycles. This allows the use of slow ROMs. Initialization code must set the WCY registers to their values. Figure 57. WCY0 Register | | - 1 | | _ | - | EUMW | | |------|-----|-----|----------|----------|------|---| | 7 | | 1/ | O Addi | ess FFEC | Н | 0 | | EUMW | | *Wa | it State | 99 | | | | 000 | | 0 | | | | | | 001 | | 1 | | | | | | 010 | | 2 | • | | | | | 011 | | 3 | | | | | | 100 | | 4 | | | | | | 101 | | 5 | | | | | | 110 | | 6 | | | | | | 111 | | 7 | | | | | Upper section of 16M-byte memory space ### Figure 58. WCY1 Register | - | EMMW | - | ELMW | | |-----------|-----------|-------------|------|---| | 7 | I/O Ad | dress FFEBH | | 0 | | EMMW/ELMW | *Walt Sta | ites | | | | 000 | 0 | | | | | 001 | 1 | | | | | 010 | 2 | | | | | 011 | 3 | | | | | 100 | 4 | | | | | 101 | 5 | | | | | 110 | 6 | | | | | 111 | 7 | | | | Middle and lower sections of 16M-byte memory space #### Figure 59. WCY2 Register | | MMW | - | LMW | | |---------|-----------|-------------|-----|---| | 7 | I/O Ad | dress FFF4H | | 0 | | MMW/LMW | *Walt Sta | ates | | | | 000 | 0 | | | | | 001 | 1 | | | | | 010 | 2 | | | | | 011 | 3 | | | | | 100 | 4 | | | | | 101 | 5 | | | | | 110 | 6 | | | | | 111 | 7 | | | | <sup>\*</sup> Middle and lower sections of 1M-byte memory space Flaure 60. WCY3 Register | _ | IOW | - | UMW | |---|----------|---------|------| | 7 | I/O Addı | ess FFF | 5H 0 | | | Wait | States | |-----|----------------|---------------| | IOW | Ext I/O Cycles | Int Ack Cycle | | 000 | . 0 | . 2 | | 001 | 1 | 3 | | 010 | 2 . | 2 . | | 011 | 3 | ą | | 100 | 4 | 4 | | 101 | 5 | 5 | | 110 | 6 | 6 | | 111 | 7 | 7 | | 111 | 7 | · · · · · · · · · · · · · · · · · · · | |-----|--------------|---------------------------------------| | UMW | *Walt States | | | 000 | 0 | | | 001 | 1 | | | 010 | 2 | | | 011 | 3 | | | 100 | 4 | | | 101 | 5 | | | 110 | 6 | | | 111 | 7 | | <sup>\*</sup> Upper section of 1M-byte memory space Figure 61. WCY4 Register | - | DMAW ' | - 1 | RFW | | | | |---------------------|-------------|-----|-----|--|--|--| | 7 I/O Address FFF6H | | | | | | | | DMAW/RFW | *Walt State | 8 | | | | | | 000 | 0 | | | | | | | 001 | 1 | | | | | | | 010 | 2 | | | | | | | 011 | 3 | • | • | | | | | 100 | 4 | | | | | | | 101 | 5 | | • | | | | | 110 | 6 | | | | | | | 111 | 7 | | | | | | <sup>\*</sup> DMA cycle or refresh cycle. #### REFRESH CONTROL UNIT The refresh control unit (REFU) refreshes external dynamic devices by periodically performing a memory read cycle from consecutive, incrementing addresses. A 16-bit counter provides the refresh address. The upper bits (A23-A16) are low during refreshes. Each refresh bus cycle has two walt states inserted, so that it will be a minimum of 4 clocks long. Refresh cycles can be distinguished from other memory reads by the assertion of the REFRQ output or by the bus status code. If the V53 is busy when it is time to perform a refresh, the refresh request is placed in a refresh queue until the bus is no longer busy. Normally, the REFU has the lowest bus priority. However, after seven refreshes are queued, the REFU is given the highest bus priority. The REFU gets control of the bus, performs a burst of four refreshes, and then falls back to the lowest priority. This refresh queue ensures that refresh cycles are not lost even when the V53 is busy for long periods of time. #### Refresh Control Register (RFC) The RFC (figure 62) controls the refresh control unit. The RE bit enables or disables the REFU. The refresh interval is set by the RTM field by choosing refresh interval factor N, which determines how many CPU clock cycles elapse between refreshes. Refresh interval = 16 x N x toyo With a 16-MHz CPU clock, this allows a range of intervals from 1 to 32 μs. After RESET, N will be 9, which gives an interval of 9 µs. Since the V53 may operate with either 8- or 16-bit memory devices, the refresh address can be incremented by 1 (for 8-bit memory) or by 2 (for 16-bit memory). The RDB8 bit in the RFC makes the selection. In the word mode, UBE is always low (active) for refresh cycles. In the byte mode, UBE is asserted only for refreshes to an odd address. Figure 62. Refresh Control Register (RFC) | 3 | | | | |-------|--------|----------|------------------------------------------------------------------| | RE | RDB8 | - | RTM | | 7 | | | I/O Address FFF2H | | RE | Refres | h | | | 0 | Disal | elc | | | 1 | Enab | le | | | RDB8 | TCU C | lock for | Channel 2 | | 0 | Incre | ment by | 2 (UBE = low level) | | 1 . | | | y 1 (UBE = high level for even addresses<br>I for odd-addresses) | | RTM | Refres | h Inter | val Factor N | | 00000 | 1 | | | | 00001 | 2 | | | | 00010 | 3 | 1. | | | 00011 | 4 | | | | 00100 | 5 | | - | | : | : | | | | : | : | | | | : | : | | | | 11110 | 31 | | | | | | | | #### TIMER/COUNTER UNIT The timer/counter unit (TCU) provides a set of three independent 16-bit timer/counters. Each timer has an individual output and gate control input. The clock source for each channel is set individually to either the # NEC ### μPD70236 (V53) T-49-17-15 prescaled CPU clock or the external TCLK. TOUT1 is also internally connected to supply the baud rate clock to the SCU. Figure 63 is the TCU block diagram. The TCU has the following features. - Three 16-bit timer/counters - Six programmable count modes - Binary/BCD counting - Multiple latch command - Count latch command - Choice of two clock sources - 16-MHz operation - Functionally compatible with μPD71054 (8254) Because RESET leaves the TCU in an uninitialized state, each timer/counter must be initialized by specifying an operating mode and a count. Once programmed, a timer/counter will continue to operate in that mode until another mode is selected. When the count has been written to the counter and transferred to the down counter, a new count operation starts. Both the current count and the counter status can be read while count operations are in progress. Figure 64 is a flow diagram for TCU operations. ### Figure 63. TCU Block Diagram T-49-17-15 #### Figure 64. TCU Operating Procedure ### **TCU Commands** The TCU is programmed by issuing I/O instructions to the I/O port addresses programmed in the OPHA and TULA registers. The Individual TCU registers are selected by address bits A2 and A1 or (A1) and (A0) as follows. | $A_2 (A_1)$ | A <sub>1</sub> (A <sub>0</sub> ) | Register | Operation | |-------------|----------------------------------|--------------|--------------------| | 0 | 0 | TCT0<br>TST0 | Read/write<br>Read | | 0 | 1 | TCT1<br>TST1 | Read/write<br>Read | | 1 | 0 | TCT2<br>TST2 | Read/write<br>Read | | 1 | 1 | TMD | Write | #### Timer Mode Register (TMD) The TMD register selects the operating mode for each timer/counter and issues the latch command for one or more timer/counters. Figures 65, 66, and 67 show three configurations of the TMD register. Figure 65. TMD Register; Mode Word | SC | S | С | RWM | CMODE | BD | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------|-----------------|---------------|-----------| | 00 TCT0 01 TCT1 10 TCT2 11 Multiple latch command RWM Read/Write Mode 00 Counter latch command 01 Lower byte only 10 Upper byte only 11 Lower byte followed by upper byte CMODE Count Mode 000 Mode 0 001 Mode 1 x10 Mode 2 x11 Mode 3 100 Mode 4 101 Mode 5 BD Count 0 Binary count 1 BCD count | 7 | | | | 0 | | 01 TCT1 10 TCT2 11 Multiple latch command RWM Read/Write Mode 00 Counter latch command 01 Lower byte only 10 Upper byte only 11 Lower byte followed by upper byte CMODE Count Mode 000 Mode 0 001 Mode 1 x10 Mode 2 x11 Mode 3 100 Mode 4 101 Mode 5 BD Count 0 Binary count 1 BCD count | SC. | Counte | r | | | | 10 TCT2 11 Multiple latch command RWM Read/Write Mode 00 Counter latch command 01 Lower byte only 10 Upper byte only 11 Lower byte followed by upper byte CMODE Count Mode 000 Mode 0 001 Mode 1 x10 Mode 2 x11 Mode 3 100 Mode 4 101 Mode 5 BD Count 0 Binary count 1 BCD count | 00 | TCTO | | | | | Multiple latch command RWM Read/Write Mode OO Counter latch command O1 Lower byte only 10 Upper byte only 11 Lower byte followed by upper byte CMODE Count Mode OOO Mode 0 OO1 Mode 1 x10 Mode 2 x11 Mode 3 100 Mode 4 101 Mode 5 BD Count O Binary count 1 BCD count | 01 | TCT1 | | | | | RWM Read/Write Mode OO Counter latch command O1 Lower byte only 10 Upper byte only 11 Lower byte followed by upper byte CMODE Count Mode OOO Mode 0 OO1 Mode 1 x10 Mode 2 x11 Mode 3 100 Mode 4 101 Mode 5 BD Count O Binary count 1 BCD count | 10 | TCT2 | | | | | 00 Counter latch command 01 Lower byte only 10 Upper byte only 11 Lower byte followed by upper byte CMODE Count Mode 000 Mode 0 001 Mode 1 x10 Mode 2 x11 Mode 3 100 Mode 4 101 Mode 5 BD Count 0 Binary count 1 BCD count | 11 | Multi | ple latch comm | nand | | | 01 Lower byte only 10 Upper byte only 11 Lower byte followed by upper byte CMODE Count Mode 000 Mode 0 001 Mode 1 x10 Mode 2 x11 Mode 3 100 Mode 4 101 Mode 5 BD Count 0 Binary count 1 BCD count | RWM | Read/V | Vrite Mode | | | | 10 Upper byte only 11 Lower byte followed by upper byte CMODE Count Mode 000 Mode 0 001 Mode 1 x10 Mode 2 x11 Mode 3 100 Mode 4 101 Mode 5 BD Count 0 Binary count 1 BCD count | 00 | Cour | ter latch comn | nand | | | 11 Lower byte followed by upper byte CMODE Count Mode 000 Mode 0 001 Mode 1 x10 Mode 2 x11 Mode 3 100 Mode 4 101 Mode 5 BD Count 0 Binary count 1 BCD count | 01 | Lowe | r byte only | | D.5 ** ;* | | CMODE Count Mode 000 | 10 | Uppe | r byte only | | | | 000 Mode 0 001 Mode 1 x10 Mode 2 x11 Mode 3 100 Mode 4 101 Mode 5 BD Count 0 Binary count 1 BCD count | 11 | Lowe | r byte followed | by upper byte | 1.1 | | 001 | CMODE | Count | Mode | | | | x10 | 000 | Mode | 9 0 | | • | | x11 Mode 3 100 Mode 4 101 Mode 5 BD Count 0 Binary count 1 BCD count | 001 | Mode | ∍ 1 | | | | 100 Mode 4 101 Mode 5 BD Count 0 Binary count 1 BCD count | x10 | Mode | 2 | | | | 101 Mode 5 BD Count 0 Binary count 1 BCD count | x11 | Mode | 3 | | £ | | BD Count 0 Binary count 1 BCD count | 100 | Mode | 9 4 | | | | 0 Binary count<br>1 BCD count | 101 | Mode | 9 5 | | | | 1 BCD count | BD | Count | | | | | | 0 | Bina | ry count | | | | x = Don't care. | 1 | BCD | count | | | | | x = Dor | it care. | | | | ### Figure 66. TMD Register; Count Latch Command 0 | sc | Counter To Be Latched | | |----|-----------------------|--| | 00 | TCT0 | | | 01 | TCT1 | | | 10 | TCT2 | | #### Figure 67. TMD Register; Multiple Latch Command 0 | 1 | 1 | CL | SL | CT2 | CT1 | СТО | 0 | |-----|--------|---------|---------|-----|-----|-----|---| | 7 | | | | | | | | | CL | Latche | s Count | Data | | | | | | 0 | Yes | | | | | | | | 1 | No | | | | | | | | SL | Latche | s Statu | 3 | | | | | | 0 | Yes | | | | | | | | 1 | No | | | | | | | | CTn | Select | s Count | er TCTn | | | | | | 0 | No | | | | | | | | 1 | Yes | | | | | | | ## E C FLECIKONICZ INC μPD70236 (V53) T-49-17-15 ### Timer/Counter Registers (TCT) Writes to the timer/counter registers (TCT0-TCT2) stores the new count in the appropriate timer/counter. The count latch command is used before reading count data to latch the current count and prevent inaccuracies. #### **Timer Status Registers (TST)** The timer status registers (TST0-TST2) contain status information for the specified counter. See figure 68. The latch command is used to latch the appropriate counter status before reading status information. If both status and counter data are latched for a counter, the first read operation returns the status data and subsequent read operations obtain the count data. Figure 68. Timer Status Registers (TSTn) | · · · · · · | | mer claids i | registers (1311) | | |-------------|------------------|------------------|---------------------------------------|----| | OL | NC | FWM | CMODE | BD | | 7 | | | | C | | OL | TOUTn L | .evel | | | | 0 | Low<br>High | | ····· | | | NC | Null Cou | nt | · · · · · · · · · · · · · · · · · · · | | | 0 | Valid<br>Invalid | | | | | RWM | Read/Wr | Ite Mode | | * | | | Same a | as TMD register. | | | | CMODE | Count M | ode | | | | | Same a | as TMD register. | | | | BD | Count | | | | | | Same a | s TMD register | · · · · · · · · · · · · · · · · · · · | | #### **Count Modes** There are six programmable timer/counter modes. The timing waveforms for these modes are shown in figure 69. Mode 0 (Interrupt on End of Count). In mode 0, TOUT changes from low to high level when the specified count is reached. This mode is available on all timer/counters. Mode 1 (Retriggerable One-Shot). In mode 1, a low-level, one-shot pulse triggered by TCTL is output from the TOUT pin. Mode 2 (Rate Generator). In mode 2, TOUT cyclically goes low for one clock period when the counter reaches the 0001H count. A counter in this mode operates as a frequency divider. Mode 3 (Square-Wave Generator). Mode 3 is a frequency divider similar to mode 2, but the output has a symmetrical duty cycle. Mode 4 (Software-Triggered Strobe). In mode 4, when the specified count is reached, TOUT goes low for the duration of one clock pulse. Mode 5 (Hardware-Triggered Strobe). Mode 5 is similar to mode 4 except that operation is triggered by the TCTL input and can be retriggered. T-49-17-15 T-49-17-15 83-001853B NEC T-49-17-15 T-49-17-15 #### SERIAL CONTROL UNIT The serial control unit (SCU) is a single asynchronous channel that performs serial communication between the V53 and an external device. The SCU is similar to the $\mu\text{PD71051}$ Serial Control Unit except for the lack of synchronous communication protocols. Figure 70 is a block diagram of the SCU. Figure 70. SCU Block Diagram The SCU has the following features. - Full-duplex, asynchronous serial controller - Clock rate divisor: 16 or 64 - Baud rates to 640 kb/s (external clock), 500 kb/s (Internal clock) - Dedicated baud-rate generator or can use timer 1 - Full modem signaling support (ATS, CTS, DSR, DTR) - Character length: 7 or 8 bits - Stop bit length: 1 or 2 bits - Break transmission and detection - Full-duplex, double-buffered transmitter/receiver - Even, odd, or no parity - Parity, overrun, and framing error detection - Receiver-full/transmitter-empty interrupt The SCU contains four separately addressable registers for reading/writing data, reading status, and controlling operation of the SCU. The serial receive buffer (SRB) and the serial transmit buffer (STB) store the incoming and outgoing character data. The serial status register (SST) allows software to determine the current state of both the transmitter and the receiver. The serial command (SCM) and serial mode registers (SMD) determine the operating mode of the SCU while the serial interrupt mask register (SIMK) allows software control of the SCU receive and transmit interrupts. #### Serial Data Format Figure 71 shows the format of the serial data processed by the SCU. In this serial data, the character bits are transferred between the CPU and SCU. The start bit, parity bit, and stop bit(s) sandwiching the character bits are control information necessary for serial data communications. They are automatically appended when data is transmitted or deleted when data is received by the SCU. Figure 71. Serial Data Format #### **Receiver Operation** While the RxD pin is high, the receiver is in an idle state. A transition on RxD from high to low indicates the start of new serial data. When a complete character has been received, it is transferred to the SRB register. The receive buffer ready (RBRDY) bit in the SST register is set and (if unmasked) an interrupt is generated. The SST also latches any parity, overrun, or framing errors at this time. The receiver detects a break condition when a null character with zero parity is received. The BRK bit is set for as long as the subsequent receive data is low and resets when RxD returns to a high level. #### **Transmitter Operation** TxD is kept high while the STB register is empty. When the transmitter is enabled and a character is written to the STB register, the data is converted to serial format and output on the TxD pin. The start bit indicates the start of the transmission and is followed by the character stream (LSB to MSB) and an optional parity bit. One or two stop bits are then appended, depending on the programmed mode. When the character has been transferred from the STB, the TBRDY bit in the SST is set and if unmasked, a transmit buffer empty interrupt is generated. Serial data can be transmitted and received by polling the SST register and checking the TBRDY or RBRDY flags. Data can also be transmitted and received by SCU-generated interrupts. The SCU generates an interrupt in either of these conditions: - (1) The receiver is enabled, the SRB is full, and receive interrupts are unmasked. - (2) The transmitter is enabled, the STB is empty, and transmit interrupts are unmasked. #### **SCU Registers and Commands** I/O instructions to the I/O addresses selected by the OPHA and SULA registers are used to read/write the SCU registers. Address bits A2 and A1 (or A1 and A0) and the read/write lines select one of the six internal registers as shown below. | A <sub>2</sub> (A <sub>1</sub> ) | A1 (A0) | Register | Operation | | |----------------------------------|---------|----------|------------|-----| | 0 | 0 | SRB | Read | b · | | 0 | 0 | STB | Write | • | | 0 | 1 | SST | Read | į | | 0 | 1 | SCM | Write | | | 1 | 0 | SMD | Write | : | | 1 | 1 | SIMK | Read/write | | The baud rate counter (BRC) register is fixed at address FFE9H in the system I/O area. The SRB and STB are 8-bit registers. When the character length is 7 bits, the lower 7 bits of the SRB register are valid and bit 7 is cleared to 0. If programmed for 7-bit characters, bit 7 of the STB is ignored. The SST register (figure 72) contains the status of the transmit and receive data buffers and the error flags. Error flags are persistent. Once an error flag is set, it remains set until a clear error flags command is issued. #### SCU Initialization After a hardware reset, the SCU is set to the following condition. | Baud rate factor | x64 | |------------------|------------| | Character length | 7 bits | | Stop bit | 1 bit | | Transmit/receive | Disabled | | Break detection | No | | Errors | No | | RTS, DTR pins | High level | | | | N E C ELECTRONICS INC μPD70236 (V53) T-49-17-15 #### Figure 72. Serial Status Register (SST) | I Mare 12. Gerial Status negister (551) | | | | | | | | |-----------------------------------------|--------|----------|----------|----|---|-------|-------| | DSR | BKD | FE | OVE | PE | 1 | RBRDY | TBRDY | | 7 | | | | | • | | Ö | | DSR | DSR In | put Pin | | | | | | | 0 | High | | | | | | | | 1 | Low | level | | | | | | | BKD | Break | Detectio | n | | | | | | 0 | | al recep | | | | | | | 1 | Breal | status · | detected | | | , | | | FE | Framin | g Error | | | | | | | 0 | No e | rror | | | | | | | _1 | Error | | | | | | | | OVE | Overru | n Error | | | | | | | 0 | No e | ror | | _ | | | | | 1 | Error | | | | | | | | PE | Parity | Error | | | | | | | 0 | No er | ror | | | | | | | | Error | | | | | | | | RBRDY | Receiv | e Data E | uffer | | | | | | 0 | | empty | | | | | | | 1 | SRB | fuli | | | | | | | TBRDY | Transm | ilt Data | Buffer | _ | | | | | 0 | STB | | | | | | | | _1 | STB 6 | empty | j | | | | | The SCM register (figure 73) stores the command word that controls transmission, reception, error flag reset and break transmission. The SMD register (figure 74) stores the mode word that determines serial characteristics such as baud rate divisor, parity, character length, and stop bit length. initialization software should first program the SMD register followed by the SCM register. Unlike the $\mu$ PD71051, the SMD register can be modified anytime without resetting the SCU. ### Figure 73. Serial Command Register (SCM) | | | RTS | ECL | SBRK | RE | DTR | TE | |------|---------------|------------------------|----------|----------|-----|-----|----| | 7 | | | | | | | 0 | | RTS | Contro | Is RTS ( | Output F | in | | | | | 0 | High<br>Low I | | | | | | | | ECL | Clears | Error Fl | ags | | | | | | 0 | | peration<br>s error fi | ags | | | | | | SBRK | Break 1 | Transmi: | ssion | | ··· | | | | 0 | | in opera | | | | · | | | RE | Enable | s/Disabi | es Rece | ption | | | | | 0 | Disab<br>Enab | | | | | | | | DTR | Contro | la DTR F | In | | | | ·- | | 0 | High<br>Low i | | | | | | | | TE | Enable | s/Disabi | es Tran | smission | | | | | 0 | Disab<br>Enab | | | | | | | | | | | | | | | | ## ST. ### Figure 74. Serial Mode Register (SMD) | | STL | PS | CL | BF | |------|----------|--------------|-----|--------------------------| | 7 | | | | 0 | | STL. | Number | of Stop Bits | | | | x0 | Illegal | | ··· | ···· | | 01 | 1 stop | bit | | | | _11 | 2 stop | bits | | | | PS | Parity S | election | | <del></del> | | x0 | Parity | disabled | | | | 01 | Odd p | arity | | | | 11 | Even p | arity | | | | CL | Charact | er Length | · | ························ | | xo | illegal | | | <del></del> | | 10 | 7 bits | | | • | | _ 11 | 8 bits | | | | | BF | Baud Ra | ite | | | | 0x | lliegal | | | ····· | | 10 | RTČLK | frequency/16 | | | | 11 | | frequency 64 | • • | | The SIMK register (figure 75) controls the occurrence of RBRDY and TBRDY Interrupts. When an interrupt is masked, it is prevented from propagating to the interrupt control unit. T-49-17-15 Figure 75. Serial Interrupt Mask Register (SIMK) | _ | | _ | _ | TM | RM | |----|----------------------|---|---|----|----| | 7 | <del></del> | | | | ( | | TM | TBRDY Interrupt Mask | | • | | | | 0 | Unmasked<br>Masked | | | | | | RM | RBRDY Interrupt Mask | | | | | | 0 | Unmasked<br>Masked | | • | , | | #### **Baud Rate Clock** The baud rate clock may come from either of two sources: the internal baud rate generator or timer 1. The internal baud rate generator is discussed in the System I/O section, and timer 1 is described in the TCU section. The SCTL system I/O register controls the selection of the baud rate clock. #### INTERRUPT CONTROL UNIT The interrupt control unit (ICU) is a programmable interrupt controller equivalent to the $\mu$ PD71059. The ICU arbitrates up to eight interrupt inputs, generates a CPU interrupt request, and outputs the interrupt vector number on the internal data bus during an interrupt acknowledge cycle. Cascading up to seven external slave $\mu$ PD71059 interrupt controllers permits the V53 to support up to 56 interrupt sources. Figure 76 is the block diagram for the ICU. Figure 76. ICU Block Diagram To reduce current drain in the standby modes, the V53 does not have internal pullup resistors on the INTP0-INTP7 pins. This is different from the $\mu$ PD71059 and V40/V50. The ICU has the following features. - Eight external interrupt request inputs - Cascadable with μPD71059 interrupt controllers - Programmable edge- or level-triggered interrupts (TCU, edge-triggered only) - Individually maskable interrupt requests - · Programmable interrupt request priority - Polling mode #### **ICU Registers** Use I/O instructions to the I/O addresses selected by the OPHA and IULA registers to read from and write to the ICU registers. Address bit $A_1$ and the command word select an ICU internal register. See table 7. T-49-17-15 Table 7. ICU Register Selection | | A <sub>1</sub> (A <sub>0</sub> ) | Other Condition | Operation | |-------|----------------------------------|-----------------------|--------------------| | Read | 0 | IMD selects IRQ | CPU ← IRQ data | | | 0 | IMD selects IIS | CPU ← IIS data | | | 0 | *Polling phase | CPU ← Polling data | | | 1 | | CPU ← IMKW | | Write | 0 | D4 = 1 | CPU → IJW1 | | | 0 | D4 = 0 and $D3 = 0$ | CPU → IPFW | | | 0 | D4 = 0 and D3 = 1 | CPU → IMDW | | | 1 | During Initialization | CPU → IIW2 | | | 1 | | CPU → IIW3 | | | 1 | | CPU → IIW4 | | | 1 | After initialization | CPU → IMKW | <sup>\*</sup> In the polling phase, polling data has priority over the contents of the IRQ or IIS register when read. # Initializing the ICU The ICU is always used to service maskable interrupts in a V53 system. Prior to accepting maskable interrupts, the ICU must first be initialized. See figure 77. Note that RESET does not initialize the ICU. Interrupt Initialization Words 1-4. Words IIW1-IIW4 (figures 78-81) indicate whether external $\mu\text{PD71059s}$ are connected as slaves, select the base interrupt vector, and select edge- or level-triggered inputs for INT1-INT7. Interrupt sources from the TCU are fixed as edge-triggering. INT0 is internally connected to TOUT0, and INT2 may be connected to TOUT1 by the IRSW field in the OPCN . The Initialization words are written in consecutive order starting with IIW1. IIW2 sets the interrupt vector. IIW3 specifies which interrupts are connected to slaves. IIW3 is only required in extended systems. The ICU will only expect to receive IIW3 if SNGL = 0 (bit $D_1$ of IIW1). IIW4 is only written if II4 = 1 (bit $D_0$ of IIW1). Figure 77. Initialization Sequence Figure 78. ICU Initialize, Word 1 (IIW1) | -garata too madaaco, noto i (ami) | | | | | | | | | |-----------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | - | | 1 | LEV | _ | SNGL | 114 | | | | | · | <u>-</u> | | | | | | | | Input T | rigger i | /lode | | · | | | | | | | | | | | | | | | | High- | level trig | ger | | | | | | | | Mode | | | | | | | | | | Expa | nded mo | de (slav | e control | lers) | | | | | | Singi | e mode | (no slav | e controll | ers) | | | | | | Write t | 0 W4 | | | | | | | | | IIW4 t | not requ | ired | | | | | | | | | | | | | | | | | | | Risin<br>High-<br>Mode<br>Expai<br>Singi<br>Write to | Input Trigger Institution Input Trigger Institution Input Trigger Institution Input Trigger Institution Institutio | Input Trigger Mode Rising-edge trigger High-level trigger Mode Expanded mode (slav Single mode (no slave | Input Trigger Mode Rising-edge trigger High-level trigger Mode Expanded mode (slave control Single mode (no slave control) Write to W4 IIW4 not required | Input Trigger Mode Rising-edge trigger High-level trigger Mode Expanded mode (slave controllers) Single mode (no slave controllers) Write to W4 IIW4 not required | Input Trigger Mode Rising-edge trigger High-level trigger Mode Expanded mode (slave controllers) Single mode (no slave controllers) Write to W4 IIW4 not required | | | #### Figure 79. ICU Initialize, Word 2 (IIW2) | _ | | | ~, | | | | | | |---|----------------|----------------|----------------|----------------|----------------|--------|---|----| | L | V <sub>7</sub> | V <sub>6</sub> | V <sub>5</sub> | V <sub>4</sub> | V <sub>3</sub> | 1 | - | _ | | D | • | = Higher | 5 bits o | f Interru | pt vector | number | | DO | T-49-17-15 #### Figure 80. ICU Initialize, Word 3 (IIW3) | 87 | S <sub>6</sub> | S <sub>5</sub> | S <sub>4</sub> | S <sub>3</sub> | S <sub>2</sub> | S <sub>1</sub> | 0 | |----------------|----------------|-----------------------|----------------|----------------|----------------|----------------|---| | D7 | | l | <u> </u> | <del>'</del> | | | D | | s <sub>n</sub> | Slave ( | Connect | lon | | | | | | 0 | | is not a<br>is a slav | slave inp | out | | | | # Figure 81. ICU Initialize, Word 4 (IIW4) | 0 | 0 | 0 | "EXTN. | _ | _ | SFI | 1 | |------|--------------|------------------|----------|---|---|-----|----| | D7 | | | | | | | D0 | | EXTN | Extern | al Nest | ing Mode | | | | | | 0 | Norm<br>Expa | | | | | | | | SFI | Self-Fir | ılsh ini | errupt | | | | | | 0 | | mmand<br>Inish m | | | | | | Command Words. The interrupt mask word (MKW) contains programmable mask bits for each of the eight interrupt inputs. The interrupt priority and finish word (IPFW) is used by the interrupt handler to terminate processing of an interrupt or change interrupt priorities. The interrupt mode word (IMDW) selects the polling register, interrupt request (IRQ) or interrupt in-service (IIS) register, and the nesting mode. See figures 82-84. Figure 82. Command Word IMKW | M <sub>7</sub> | M <sub>6</sub> | M <sub>5</sub> | M <sub>4</sub> | Мз | M <sub>2</sub> | M <sub>1</sub> | M <sub>0</sub> | |----------------|----------------|----------------|----------------|----|----------------|----------------|----------------| | D7 | | | | | | | Do | | Mn | Interrupt Request Mask | _ | |----|------------------------|---| | 0 | INTn not masked | | | 1 | INTn masked | | | - | | _ | #### Figure 83. Command Word IPFW | RP | SIL | FI | 0 | 0 | IL2 | IL1 | ILO | |---------|---------|----------|-----|---|-----|-----|-----------------------------------------| | D7 | | | | | | | DO | | RP. | Rotate | Priority | | | | | | | 0 | | tation | | | | | • | | 1 | Rota | llon | | | | | | | SIL | Level | | | | | | | | 0 . | Not s | pecified | | | | | | | 1 | Spec | ified | | | | | | | FI | Finish | Interrup | t | | | | | | 0 | Non- | FI comm | and | | | | | | 1 | FI co | mmand | | | | | | | IL2-IL0 | Interru | pt Level | 1 | | | | | | 000 | INTO | | | | | | | | 001 | INT1 | | | | | | . *101 | | 010 | INT2 | | | | | | | | 011 | INT3 | | | | | | h | | 100 | INT4 | | | | | | • • • • • • • • • • • • • • • • • • • • | | 101 | INT5 | | | | | | 7. 12 | | 110 | INT6 | | | | | | Section and Section 19 | | 111 | INT7 | | | | | | | # Figure 84. Command Word IMDW | | _ | SNM | EXCN | 0 | 1 | POL | \$R | IS/IR | |---|-----|-------|--------|-----------|-----------|------------|------|-------| | | D7 | | | | | | | DO | | | SNM | EXCN | Nestli | ng Mode | 2 | | | | | | 0 | _ | No ( | peration | n | | | | | | 1 | 0 | Rele | ase exc | eptional | nesting | mode | | | | 1 | 1 | Set | exceptic | nal nest | ing mod | 9 | | | į | POL | | Poliin | g Mode | | | | | | | 0 | | No ( | operation | n | | | | | | 1 | | Poli | ing com | mand | | | | | | SR | IS/IR | Regis | ter to B | e Read | | | | | • | 0 | _ | No | operatio | n | | | | | | 1 | 0 | Inte | rrupt rec | uest reg | ister (IR | Q) | | | | 1 | 1 | Inte | rrupt in- | service r | egister (l | IS) | | ## μPD71059 Cascade Connection To increase the number of maskable interrupts, up to seven slave $\mu\text{PD71059}$ interrupt controllers can be cascaded. During cascade operation, each slave $\mu\text{PD71059}$ INT output is routed to one of the V53 INTP inputs. During the second interrupt acknowledge bus cycle, the ICU places the slave address on the address lines AD<sub>10</sub>-AD<sub>8</sub>. Each slave compares this address with the slave address programmed using interrupt initialization word 3 (IIW3). If the same, the slave will place the interrupt vector on pins AD<sub>7</sub>-AD<sub>0</sub> during the second interrupt acknowledge bus cycle. T-49-17-15 #### **DMA CONTROL UNIT** The DMA control unit (DMAU) is a high-speed DMA controller compatible with the $\mu$ PD71071 and $\mu$ PD71037 DMA controllers. The DMAU has four independent DMA channels and performs high-speed data transfers between memory and external peripheral devices at speeds as high as 4M words/second in a 16-MHz system. Figure 85 is the block diagram for the DMAU. The DMAU has the following features. Four independent DMA channels - μPD71037 or μPD71071 compatibility modes - Cascade mode for slave DMA controllers - 24-bit address registers - 16-bit transfer count registers - Single, demand, and block transfer modes - Autoinitialization - Address increment/decrement - Fixed/rotating channel priorities - TC output at transfer end - Forced termination of service by END input Figure 85. DMAU Block Diagram ## μPD71071 and μPD71037 Mode Comparison The DMAU has two operating modes selected by the SCTL system control register. Respectively, the $\mu$ PD71071 and $\mu$ PD71037 modes offer hardware and software compatibility with existing systems based on the $\mu$ PD71071 DMA controller (also the V40/V50 microprocessor) and the $\mu$ PD8237 DMA controller. In applications where DMA software compatibility is not an issue, programming flexibility is greater in the $\mu$ PD71071 mode. However, the software DMA request capability of the $\mu$ PD71037 mode is often useful. The following compares the major functional differences between the two modes. # 30E μPD70236 (V53) T-49-17-15 MARQ input of that channel is masked. Othe | Function | <u>μPD71037</u><br>Mode | <u>μΡD71071 Mode</u> | |----------------------------------------|--------------------------------------------------------------------------------------|--------------------------------------------| | DMA channel<br>selection | Mode control register by write data (operand); other registers have a unique address | Referenced by<br>channel register<br>(DCH) | | Base and<br>current register<br>access | Consecutive<br>8-bit quantities | 16-bit quantities | | Base registers | Write only | Read and write | | DMA<br>termination | Bus release<br>mode | Bus release and bus hold modes | | Software DMA requests | Yes | No | | DMA transfers | Byte | Byte or word | The DMAU is intended for high-speed data transfers between memory and peripherals with minimum latency. Neither mode provides memory-to-memory DMA transfers because the powerful string moves of the CPU can accomplish block memory transfers as fast as dedicated DMA hardware could. The DMAU does not provide compressed timing as do the $\mu$ PD71071 and $\mu$ PD71037. #### Master/Slave Mode The DMAU operates in either master or slave mode. In slave mode, the DMAU samples the four DMARQ input pins every clock. If one or more inputs are active, the corresponding DMA request bits are set and the DMAU sends a bus request to the BAU while continuing to sample the DMA request inputs. After the BAU returns the DMA bus acknowledge signal, the DMAU stops DMA request sampling, selects the DMA channel with the highest priority, and enters the bus master mode to perform the DMA transfer. While in the bus master mode, the DMAU controls the external bus and performs DMA transfers based on the preprogrammed channel information. See figure 45 and the associated text for a detailed description of DMA bus cycles. #### **Terminal Count** The DMAU ends DMA service when the terminal count condition is generated or when the END input is asserted. A terminal count (TC) is produced when the contents of the current count register underflows from zero. If autoinitialization is not enabled when DMA service terminates, the mask bit of the channel is set and the DMARQ input of that channel is masked. Otherwise, the current count and address registers are reloaded from the base registers, and new DMA transfers are again enabled. #### **DMA Transfer Type** The type of transfer the DMAU performs depends on the following conditions. - Transfer direction (each channel) - Bus mode - Transfer mode (each channel) #### **Transfer Direction** All DMA transfers use memory as a reference point. Therefore, a DMA read operation (figure 86) transfers data from memory to I/O port and writes the data into memory. During memory-to-I/O transfer, the DMA mode register (DMD) is used to select the transfer directions for each channel and activate the appropriate control signals. | Operation | Transfer | Signals Activated | |------------|---------------|-------------------| | DMA read | Memory to I/O | IOWR, MRD | | DMA write | I/O to memory | IORD, MWR | | DMA verify | No transfer | Addresses only | #### **Bus Mode** The two available modes for determining how the DMAU releases the CPU bus are bus release and bus hold. In $\mu$ PD71037 mode, the DMAU always functions in bus release mode. In $\mu$ PD71071 mode, the DMAU is programmable for bus release or bus hold mode via the DMA device control (DDC) register. In bus release mode, bus control is always relinquished each time the service has completed. Therefore, if multiple DMA requests are generated simultaneously, a bus cycle other than that for the DMAU is inserted between consecutive DMA services (see figure 87). Consequently, in certain applications DMA response may be delayed. However, bus release mode gives better assurance that the CPU will continue to execute programs in DMA intensive environments. In bus hold mode, if another DMA request is generated before the end of one service, that request can be serviced without the DMAU relinquishing the bus. However, the same channel cannot be serviced consecutively. This mode provides better DMA response but may prevent CPU bus activity for extended periods of time. T-49-17-15 Figure 86. Typical Memory-to-I/O DMA Cycle The operation of single, demand, and block transfers depends on whether the DMAU is in bus release or bus hold mode. Figure 88 shows the operations flow for the six possible transfer and bus mode operations in DMA transfer. #### Figure 87. Bus Modes #### **Transfer Modes** The DMAU has three transfer modes as listed below. In $\mu\text{PD71071}$ mode, bits 6 and 7 (TMODE) of the mode control register (DMD) select the transfer mode. In $\mu\text{PD71037}$ mode, bits 6 and 7 of the channel mode register specify the mode. Transfer mode operation is the same in both $\mu\text{PD71071}$ and $\mu\text{PD71037}$ modes. **Transfer Mode** Termination Conditions Single After each byte/word transfer END input Terminal count Demand END input Terminal count Service channel DMARQ dropped Generation of a higher priority DMARQ (bus hold mode) Block **END** input Terminal count T-49-17-15 Figure 88. Transfer Modes T-49-17-15 Single Transfer Mode. In bus release mode, when a channel completes transfer of a single byte or word, the DMAU enters the slave mode regardless of the state of DMA request inputs. In this manner, other lower priority bus masters can access the bus. In bus hold mode ( $\mu$ PD71071 mode only), when a channel completes transfer of a single byte or word, the DMAU terminates the channel's service even if the DMARQ request signal is asserted. The DMAU will then service any other requesting channel. If there are no requests from any other DMA channels, the DMAU releases the bus and enters the idle state. Demand Transfer Mode. In bus release mode, the currently active channel continues to transfer data as long as the DMA request of that channel is active, even though other DMA channels are issuing higher priority requests. When the DMA request of the serviced channel becomes inactive, the DMAU releases the bus and enters the idie state. In bus hold mode (not available in $\mu$ PD71037 mode), when the active channel completes a single transfer, the DMAU checks the other DMA request lines without ending the current service. If there is a higher priority DMA request, the DMAU stops the service of the current channel and starts servicing the highest priority channel requesting service. If there is no higher request than the current one, the DMAU continues to service the currently active channel. Lower priority DMA requests are honored without releasing the bus after the current channel service is complete. Block Transfer Mode. In bus release mode, the current channel continues DMA transfers until a terminal count or the external END input becomes active. During this time, the DMAU ignores all other DMA requests. After completion of the block transfer, the DMAU releases the bus and enters the idle state, even if DMA requests from other channels are active. In bus hold mode ( $\mu$ PD71071 mode only), the current channel transfers data until an internal or external $\overline{\text{END}}$ signal becomes active. When the service is complete, the DMAU checks all DMA requests without releasing the bus. If there is an active request, the DMAU immediately begins servicing the request. The DMAU releases the bus after it honors all DMA requests or a higher priority bus master requests the bus. # **Autoinitialize** This function is enabled by programming the mode register ( $\mu$ PD71071 and $\mu$ PD71037 modes). When a mode register enables autoinitialize for a channel, the DMAU automatically reinitializes the address and count registers when END is asserted or the terminal count condition is reached. The contents of the base address and base count registers are transferred to the current address and current count registers, and the applicable bit of the mask register remains cleared. ## **Channel Priority** Each of the four DMAU channels is assigned a priority. When multiple DMA requests from several channels occur simultaneously, the channel with the highest priority will be serviced first. The device control register selects one of two priority schemes: fixed or rotating (figure 89). In fixed priority, channel 0 is assigned the highest priority, and channel 3, the lowest. In rotating priority, priority order is rotated after each service so that the channel last serviced receives the lowest priority. This method prevents the exclusive servicing of higher priority channels and the lockout of lower priority DMA channels. The rotating priority feature is selected by programming the DMA device control (DDC) register in $\mu$ PD71071 mode or by a write to the command register in $\mu$ PD71037 mode. Figure 89. Priority Order T-49-17-15 #### **Cascade Connection** Slave DMA controllers can be cascaded to easily expand the system DMA channel capacity to 16 DMA channels. Figure 90 shows an example of cascade connection. During cascade operation, the DMAU acts as a mediator between the BAU and the slave DMA controller. During DMA cascade mode operation, it is the responsibility of external logic to isolate the cascade bus master from the V53 control outputs. These outputs are listed near the beginning of this document. The DMAU always operates in the bus release mode while a cascade channel is in service, even when the bus hold mode is programmed. Other DMA requests are held pending while a slave DMA controller channel is in service. When the cascaded device ends service and moves into the idle state, the DMAU also moves to the idle state and releases the bus. The DMAU continues to operate normally with the other noncascaded channels. Figure 90. µPD71071 Cascade Example ## **Bus Waiting Operation** The DMAU automatically performs a bus waiting operation (figure 91) whenever the REFU refresh request queue fills. When the DMA bus acknowledge goes inactive, the DMAU enters the bus waiting mode and inactivates the DMA bus request signal. Control of the bus is then transferred to the higher priority REFU by the BAU. Two clocks later, the DMAU reasserts its internal DMA bus request. The bus waiting mode is continued until the DMA bus acknowledge signal again becomes active and the interrupted DMA service is immediately restarted. Figure 91. Bus Waiting Operation ## **Address and Count Registers** Each DMA channel has a 24-bit base address register and a 24-bit current address register. In addition, each channel also has its own 16-bit current count register and base count register. The base registers hold a value determined by the CPU and transfer this value to the current registers during autoinitialization. These registers are available in both $\mu$ PD71071 mode and $\mu$ PD71037 mode, but the method of accessing these registers changes with compatibility mode. The BNKR registers extend the $\mu$ PD71037 mode addresses from 16 to 24 bits. In $\mu$ PD71071 mode, the count register and lower word of the address registers can be accessed in 16-bit quantities. In $\mu$ PD71037 mode, these registers must be accessed in 8-bit quantities. #### Programming the DMAU To prepare a channel for DMA transfer, the following characteristics must be programmed. - · Starting address for the transfer - Transfer count - DMA operating mode - Transfer size (byte/word in μPD71071 mode) The contents of the OPHA and DULA registers determine the base I/O port address of DMAU. Addresses $A_3\text{-}A_0$ are used to select a particular register. There are two register sets, one for $\mu\text{PD71071}$ mode and the other for $\mu\text{PD71037}$ mode. ## **µPD71071** Mode The $\mu$ PD71071 mode is selected by programming the DMAU bit of the SCTL register to zero. The register set for this mode (table 7) is mapped into A<sub>3</sub>-A<sub>0</sub> regardless of the IOAG value in the SCTL register. T-49-17-15 Table 7. Register Selection (uPD71071 Mode) | A <sub>3</sub> -A <sub>0</sub> | Address | Register | Operation | Notes | |--------------------------------|---------|-----------------|--------------|-------| | 0000 | он | DICM | Write | 1 | | 0001 | 1H | DCH | Read/Write | 1 | | 0010 | 2H | DBC/DCC (low) | Read/Write | 2 | | 0011 | зн | DBC/DCC (high) | Read/Write | 2 | | 0100 | 4H | DBA/DCA (low) | Read/Write | 2 | | 0101 | 5H | DBA/DCA (high) | Read/Write | 2 | | 0110 | 6H | DBA/DCA (upper) | Read/Write 1 | 1, 2 | | 0111 | 7H | Reserved | _ | | | 1000 | 8H | DDC (low) | Read/Write | | | 1001 | 9H | DDC (high) | Read/Write | | | 1010 | AH | DMD | Read/Write | 1, 2 | | 1011 | BH | DST | Read | 1 | | 1100 | СН | Reserved | _ | | | 1101 | DH | Reserved | _ | | | 1110 | EH | Reserved | | | | 1111 | FH | DMK | Read/Write | 1 | #### Notes: - (1) Register can be accessed only with byte in/Out instructions. All others can be accessed with 16-bit in/Out instructions. - (2) There are four such registers, one for each DMA channel. The particular register accessed is determined by the DCH register. ## DMAU Registers in µPD71071 Mode initialize. The DMA initialize command register (DICM) performs a software reset of the DMAU. The DICM is accessed using the byte OUT instruction. See figure 92. The DMAU initializes the registers as follows. | Register<br>DICM<br>DCH<br>DBC, DCC | <u>Name</u><br>Initlalize<br>Channel<br>Count | Operation<br>Clear<br>Select channel 0<br>No change | |-------------------------------------|-----------------------------------------------|-----------------------------------------------------| | DBA, DCA<br>DDC<br>DMD<br>DST | Address Device control Mode control Status | No change<br>Clear<br>Clear<br>Clear | | DMK | Mask | Set (mask all channels) | Figure 92. DMA Initialize Command Register (DICM); µPD71071 Mode Channel Register. Writes to the DMA channel register (DCH) select one of the four DMA channels for programming and also the base/current registers. Reads of the DCH register return the currently selected channel and the register access mode. See figure 93. Figure 93. DMA Channel Register (DCH); μPD71071 Mode | | | | BASE | SEL3 | SEL2 | SEL1 | SELO | |------|---|---|-----------------------|----------------------|------|------|-------| | | _ | | DAGE | OCLO | SELZ | OELI | OCTO. | | 7 | | | Addr<br>Byte IN | ess 1H<br>nstruction | on | | Ö | | BASE | | | s Condi | | | | | | 0 | | | d: currer<br>te: base | | ent | | · | | | | П | ا معدادية اس | 1· | | | | Channel Register Read | | Titles dado ana carions | | | | |-----------|-------------------------|-----------------------|--|--| | 1 | Read/write: base only | Read/write: base only | | | | SEL3-SEL0 | Selected Channel | | | | | 0001 | 0 | | | | | 0010 | 1 | | | | | 0100 | 2 | | | | | 1000 | 3 | | | | | - | | | | | | Channel Register Write | | | | | | | |-------------------------------------|-----------------------------------------------|--------------------------------------|---|------|-------|--| | F- - | <b>—</b> | - | _ | BASE | SELCH | | | 7 Address 1H 0 Byte OUT Instruction | | | | | | | | BASE | Access Conditions | | | | | | | 0 | Read: current only<br>Write: base and current | | | | | | | 1 | Read/write: base only | | | | | | | SELCH | Selected Channel | | | | | | | 00<br>01<br>10<br>11 | Cha<br>Cha | nnel 0<br>nnel 1<br>nnel 2<br>nnel 3 | | | | | Count Registers. When bit 2 of the DCH register is cleared, a write to the DMA count register (figure 94) updates both the DMA base count (DBC) and the DMA current count (DCC) registers with a new count. If bit 2 of the DCH register is set, a write to the DMA count register affects only the DBC register. T-49-17-15 The DBC register holds the initial count value until a new count is specified. If autoinitialization is enabled, this value is transferred to the DCC register when a terminal count or END condition occurs. For each DMA transfer, the current count register is decremented by 1. The count value loaded into the DBC/DCC register is 1 less than the desired transfer count. Figure 94. DMA Count Registers (DBC, DCC); µPD71071 Mode Address Register. Use either byte or word I/O instructions with the lower 2 bytes (4H and 5H) of the DMA address register (figure 95). However, byte I/O instructions must be used to access the high-order byte (6H) of this register. When bit 2 of the channel register is cleared, a write to the DMA address register updates both the DMA base address (DBA) and the DMA current address (DCA) registers with the new address. If bit 2 of the DCH register is set, a write to the DMA address register affects only the DBA register. The DBA register holds the starting address value until a new address is specified. This value is transferred to the DCA register automatically if autoinitialization is selected. For each DMA transfer, the current address register is updated by 2 during word transfers and by 1 during byte transfers. Figure 95. DMA Address Registers (DBA, DCA); µPD71071 Mode | A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | A <sub>4</sub> | Aз | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> | |-----------------|-----------------|-----------------|-----------------|----------------------|-----------------|-----------------|-----------------| | , | | | | ess 4H<br>nstructio | on | | ( | | A <sub>15</sub> | A <sub>14</sub> | A <sub>13</sub> | A <sub>12</sub> | A <sub>11</sub> | A <sub>10</sub> | Ag | Aa | | | · | ı | | ess 5H<br>nstructio | on | | | | A <sub>23</sub> | A <sub>22</sub> | A <sub>21</sub> | A <sub>20</sub> | A <sub>19</sub> | A <sub>18</sub> | A <sub>17</sub> | A <sub>16</sub> | | | | | | ess 6H<br>nstruction | חכ | | ( | Device Control Register. The DMA device control register (DDC) (figure 96) is used to program the DMA transfer characteristics common to all DMA channels. It controls the bus mode, write timing, priority logic, and enable/disable of the DMAU See figure 97. Figure 96. DMA Device Control Register (DDC); µPD71071 Mode #### Notes - Disables BUSRQ to the BAU to prevent incorrect DMA operation while the DMAU registers are being initialized or modified. - (2) When EXW = 0, the write signal becomes active (normal write) during S3 and SW. When EXW = 1, the write signal becomes active during S2, S3, and SW (like the read signal). - (3) Walt states are generated by the READY signal during a verify transfer. T-49-17-15 Figure 97. Early Write Cycle Timing Mode Control Register. The DMA mode control register (DMD) selects the operating mode for each DMA channel. The DCH register selects which DMD register will be accessed. A byte IN/OUT instruction must be used to access this register. See figure 98. Figure 98. DMA Mode Control Register (DMD); μPD71071 Mode | 7 Address OAH TMODE Transfer Mode 00 Demand 01 Single 10 Block 11 Cascade ADIR Address Direction 0 Increment 1 Decrement AUTI Autoinitialize 0 Disable 1 Enable TDIR Transfer Direction | Addres Transfer Mode Demand Single Block Cascade | R | — W/B 0 | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|---|---------| | TMODE Transfer Mode OO Demand O1 Single 10 Block 11 Cascade ADIR Address Direction O Increment 1 Decrement AUTI Autoinitialize O Disable 1 Enable TDIR Transfer Direction | Transfer Mode Demand Single Block Cascade | | O | | 00 Demand 01 Single 10 Block 11 Cascade ADIR Address Direction 0 Increment 1 Decrement AUTI AutoInitialize 0 Disable 1 Enable TDIR Transfer Direction | Demand<br>Single<br>Block<br>Cascade | | | | 01 Single 10 Block 11 Cascade ADIR Address Direction 0 Increment 1 Decrement AUTI Autoinitialize 0 Disable 1 Enable TDIR Transfer Direction | Single<br>Block<br>Cascade | | | | 10 Block 11 Cascade ADIR Address Direction 0 Increment 1 Decrement AUTI AutoInitialize 0 Disable 1 Enable TDIR Transfer Direction | Block<br>Cascade | | | | 10 Block 11 Cascade ADIR Address Direction 0 Increment 1 Decrement AUTI Autoinitialize 0 Disable 1 Enable TDIR Transfer Direction | Block<br>Cascade | | | | ADIR Address Direction O Increment 1 Decrement AUTI AutoInitialize O Disable 1 Enable TDIR Transfer Direction | <del></del> | | | | 0 Increment 1 Decrement AUTI AutoInitialize 0 Disable 1 Enable TDIR Transfer Direction | Address Direct | | | | 1. Decrement AUTI Autoinitialize 0 Disable 1 Eñable TDIR Transfer Direction | | | | | AUTI Autoinitialize 0 Disable 1 Enable TDIR Transfer Direction | Increment | | | | 0 Disable 1 Eñable TDIR Transfer Direction | Decrement | | | | 1 Enable TDIR Transfer Direction | Autoinitialize | | | | TDIR Transfer Direction | Disable | | | | | Eńable | | | | OO Vorit. | Transfer Direct | | | | OO Veniy | Verify | | | | 01 I/O-to-memory | I/O-to-memory | | | | 10 Memory-to-I/O | | | | | 11 Not allowed | | | | | W/B Word/Byte Transfer | Word/Byte Tran | | | | O Byte | Byte | | | | 1 Word | | | | Addresses and count registers are updated as follows during byte/word transfers. | Register | <b>Byte Transfer</b> | Word Transfer | |------------------|----------------------|---------------| | Address register | ±1 | ±2 | | Count register | -1 | ~1 | During word transfers, two bytes starting at an even address are handled as a single word. If the starting address is odd, a DMA transfer is started after first decrementing the address by 1. For this reason, always select even addresses. The Ao and UBE outputs control byte and word DMA transfers. The following shows the relationship between the data bus width, Ao, and UBE signals, and data bus status. | Ao | UBE | Data Bus Status | |-----------------------------------------------|-----|---------------------------------------| | <u>o </u> | 1 | D <sub>0</sub> -D <sub>7</sub> valid | | 1 | 0 | D <sub>8</sub> -D <sub>15</sub> valid | | 0 | 0 | D <sub>0</sub> -D <sub>15</sub> valid | Status Register. The DMA status register (DST) contains information about the current state of each DMA channel. Software can determine if a termination condition has been reached (TC0-TC3) or if a DMA service request is present (RQO-RQ3). The byte IN instruction must be used to read this register. See figure 99. Figure 99. DMA Status Register (DST); μPD71071 Mode | RQ3 | RQ2 | RQ1 | RQ0 | TC3 | TC2 | TC1 | TC0 | | |-----|------------------------------------------|-----|-----------------------|----------|------|-----|-----|--| | 7 | Address 0BH<br>Byte IN instruction | | | | | | | | | RQn | | DMA | Reques | t, Chann | el n | | • | | | 0 | No DMA request active DMA request active | | | | | | | | | TCn | Terminal Count, Channel n | | | | | | | | | 0 | | | ended (1<br>D or term | | | | | | Mask Register. The DMA mask register (DMK) allows software to individually enable and disable DMA channels. The DMK register can only be accessed via byte I/O instructions. See figure 100. Figure 100. DMA Mask Register (DMK); μPD71071 Mode | - | - | _ | - | МЗ | M2 | M1 | МО | |----|-------------------------------------|------|--------|----------|------|----|----| | 7 | Address 0FH Byte IN/OUT Instruction | | | | | | 0 | | Mn | | DMAF | Q Masi | ς, Chann | el n | | | | 0 | | Not | masked | | | | | | 1 | | Mas | ked | | | | | #### μPD71037 Mode The µPD71037 mode is selected by programming the DMAM bit of the SCTL register to 1. See figure 48. Note that on RESET, the DMAU is put into $\mu$ PD71071 mode. The register set for the $\mu$ PD71037 mode (table 8) is mapped into $A_3$ - $A_0$ (IOAG = 0) or $A_4$ - $A_1$ (IOAG = 1). For the case where IOAG = 1, the DULA system I/O register determines whether the DMAU responds to $A_0 = 0$ or 1. Table 8. Register Set for uPD71037 Mode | Channel | Register | Read/Write | Address | |---------|-----------------|------------|---------| | 0 | DCA<br>DCA, DCB | R<br>W | 0000 | | | DCC<br>DCC, DBC | R<br>W | 0001 | | 1 | DCA<br>DCA, DCB | R<br>W | 0010 | | | DCC<br>DCC, DBC | R<br>W | 0011 | | 2 | DCA<br>DCA, DCB | R<br>W | 0100 | | | DCC<br>DCC, DBC | R<br>W | 0101 | | 3 | DCA<br>DCA, DCB | R<br>W | 0110 | | | DCC<br>DCC, DBC | R<br>W | 0111 | | | DST<br>DDC | R<br>W | 1000 | | | DSRQ | W | 1001 | | | DSCM | w | 1010 | | | DMD | W | 1011 | | | DMK | W | 1111 | The registers in table 8 can be accessed only by byte I/O operations. The IOAG bit of the SCTL register determines whether these registers reside in contiguous bytes, or whether they each occupy one-half word (i.e., whether the registers are byte or word aligned). If word aligned (IOAG = 1), the low bit of the DULA register determines whether the DMAU will use the upper or lower byte of the word. In µPD71071 mode, the setting of the IOAG bit makes no difference; the register addresses do not change. #### µPD71037 Commands In addition to the registers explained above, three I/O addresses cause commands to be executed when they are written to. The value of the data written is not important; it is the action of performing an I/O write to one of these addresses that initiates the desired action. The commands and their corresponding addresses (A<sub>4</sub>-A<sub>0</sub>) are shown here. | Command | 10AG = 0 | 10AG = 1 | |------------------------|----------|----------| | Clear byte select flag | x1100 | 1100x | | Initialize | x1101 | 1101x | | Clear mask register | x1110 | 1110x | # DMAU Registers in µPD71037 Mode Most of the DMAU registers in this mode are the same as those in the µPD71071 mode, but with a different I/O address or method of access. Count and Address Registers. The DCA, DBA, DCC, and DBC registers are 16 bits wide, but can only be accessed in byte-wide chunks. The byte select flag (BSF) determines which byte is accessed. When the BSF is low, the low byte is used; when the BSF is high, the high byte is used. The BSF cannot be read; to set it to a known state, a byte select flag clear command must be issued by performing an 8-bit I/O write to address x1100b. To read or write one of these registers, first clear the BSF, and then perform two consecutive 8-bit I/O operations. The low byte will be accessed first and the high byte Bank Registers. The DMA memory addresses in the μPD71037 mode are 16 bits, compared with 24-bit addresses in the $\mu$ PD71071 mode. To expand the 16-bit addresses into the full 24-bit address space of the V53, a set of bank registers is provided, BNKR0-BNKR3, one per DMA channel. Each 8-bit register contains the upper address bits, A<sub>23</sub>-A<sub>16</sub>, to be used when a DMA channel is active. DMA addresses are modified after each transfer to point to the next address in the DMA buffer. The SCTL system I/O register, CE1-CE0 bits, control whether a carry is propagated into the upper address bits when the DMA address is incremented or decremented. CE0 controls the carry propagation to A<sub>16</sub> and CE1 controls the carry to The BNKR registers are read or written using byte I/O operations. See figure 101. As with other V53 internal registers, the I/O address to which the BNKR registers respond is programmable. The BADR system I/O register (address FFE1H) sets the base address of the BNKR registers in the 256-byte block of I/O space selected by the OPHA register. See figure 102. Also, to allow maximum flexibility, the low two address bits of each BNKR register are programmable. The BSEL system I/O register (address FFE0H) sets the low two address bits for each BNKR register. See figure 103. As with other programmable addresses, the IOAG bit of the # NEC # μPD70236 (V53) T-49-17-15 SCTL register has the effect of shifting the settable address one bit position to the left. The bank registers are only enabled in $\mu$ PD71037 mode. In $\mu$ PD71071 mode, they cannot be read or written. | | | μευτι | W/ M | oue | | | | |-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------| | A <sub>23</sub> | A <sub>22</sub> | A <sub>21</sub> | A <sub>20</sub> | A <sub>19</sub> | A <sub>18</sub> | A <sub>17</sub> | A <sub>18</sub> | | 7 | | | BN | KRO<br>OUT | | • | 0 | | A <sub>23</sub> | A <sub>22</sub> | A <sub>21</sub> | A <sub>20</sub> | A <sub>19</sub> | A <sub>18</sub> | A <sub>17</sub> | A <sub>16</sub> | | 7 | | | | KR1<br>OUT | | | 0 | | A <sub>23</sub> | A <sub>22</sub> | A <sub>21</sub> | A <sub>20</sub> | A <sub>19</sub> | A <sub>18</sub> | A <sub>17</sub> | A <sub>16</sub> | | 7 | | | BN | KR2<br>OUT | | | 0 | | A <sub>23</sub> | A <sub>22</sub> | A <sub>21</sub> | A <sub>20</sub> | A <sub>19</sub> | A <sub>18</sub> | A <sub>17</sub> | A <sub>16</sub> | | 7 | | | BN | KR3<br>OUT | | • | 0 | Figure 102. Bank Address Register (BADR); µPD71037 Mode | | | μPD7 | 1037 M | oae | | | | |----------------|----------------|----------------|----------------|------------------|----------------|-----------------|-----------------| | A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | A4 | A <sub>3</sub> | A <sub>2</sub> | *A1 | *A <sub>0</sub> | | 7 | | | | 9 FFE1H<br>3 = 0 | i | | 0 | | A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | A <sub>4</sub> | A <sub>3</sub> | *A2 | *A <sub>1</sub> | A <sub>0</sub> | | 7 | | | | s FFE1H<br>3 = 1 | į | | 0 | <sup>\*</sup>Address bits are set by the BSEL register, Figure 103. Bank Select Register (BSEL); µPD71037 Mode | викз | BNK2 | BNK1 | BNK0 | | | | | | |------|--------------------------------|----------|------|--|--|--|--|--| | 7 | Addres | ss FFE0H | 0 | | | | | | | BNKn | *Address Bits In BADR Register | | | | | | | | | 00 | 00 | | | | | | | | | 01 | 01 | | | | | | | | | 10 | 10 | | | | | | | | | | 11 | | | | | | | | <sup>\*</sup> Address bits are A<sub>1</sub>, A<sub>0</sub> if IOAG = 0 or A<sub>2</sub>, A<sub>1</sub> if IOAG = 1. (IOAG is a bit in the SCTL register.) Device Control Register. In $\mu$ PD71037 mode, there are fewer device options. The wait during verify and bus hold control bits are not offered. The DMA device control register (DDC) has only one byte to control early write cycles, channel priority, and global DMA enable. See figure 104. Figure 104. DMA Device Control Register (DDC); #PD71037 Mode | | | μΓΟΙ | 037 M | <i>oue</i> | | | | |------|---|-------|-----------|------------|-------|--|-------------| | | _ | EXW | ROT | _ | DDMA | | - | | 7 | | E | yte OU1 | Instru | ction | | 0 | | EXW | | Write | Timing | (Note 1) | | | | | 0 | | Nor | mal | | | | | | _1 | | Early | | | | | | | ROT | | Chan | nel Prior | ity | | | | | 0 | | Fixe | d | | | | <del></del> | | _1 | | Rote | ational | | | | | | DDMA | | DMA | Operatio | n | | | | | 0 | | Ena | ble | | | | | | 1 | | Disa | ıble | | | | ٠. | | | | | | | | | | #### Notes: When EXW = 0, the write signal becomes active during S3 and SW. When EXW = 1, the write strobe is asserted earlier during S2, S3, and SW (same as read strobe). Channel Mode Registers. Each channel has a mode register allocated to it. All four registers are accessed using the same I/O address. The low two bits of the data written to the DMD register select the channel. Note that byte transfers are supported but 16-bit transfers are not. Figure 105 shows the format of the channel mode register. T-49-17-15 Figure 105. DMA Channel Mode Registers (DMD); µРD71037 Mode | | μεσι | W/ MU | ue | | |-------|-------|-----------------------|--------------|--------| | TMODE | ADIR | AUTI | TDIR | SELCH | | 7 | В | yte OUT in | etruction | C | | TMODE | Trans | fer Mode | | | | 00 | Den | nand | | | | 01 | Sing | gle | | | | 10 | Bloc | k | | | | 11 | Cas | cade | | | | ADIR | Addre | ss Direct | ion | Ł | | 0 | Incr | ement | | | | 1 | Dec | rement | | | | AUTI | Autoi | nitializ <del>o</del> | | | | 0 | Disa | able | | | | 1 | Ena | ble | | | | TDIR | Trans | fer Direct | lon | | | 00 | Veri | fy | | | | 01 | 1/0- | to-memory | <b>y</b> | | | 10 | Mer | nory-to-I/C | j | | | 11 | Not | allowed | | | | SELCH | Chan | nel Select | ion for Mode | Change | | 00 | Cha | nnel O | | | | 01 | Cha | nnel 1 | | | | 10 | Cha | nnel 2 | | ÷ | | 11 | Cha | nnel 3 | | | Status Register. This DST register (figure 74) is identical to the µPD71071 mode DST register, but is at I/O address x1000b. Figure 106. DMA Status Registers (DST); μPD71037 Mode | | | <i></i> | | | | | | | | |-----|-----|-----------------------|---------------------|------------------------|-------|----------|-----|--|--| | RQ3 | RQ2 | RQ1 | RQ0 | TC3 | TC2 | TC1 | TCO | | | | 7 | | | Addres<br>Byte IN I | s x1000b<br>nstruction | | <u> </u> | 0 | | | | RQn | | DMA | Reques | t, Chann | el n | | | | | | 0 | | No DMA request active | | | | | | | | | _ 1 | | DM | A reques | t active | | | | | | | TCn | | Termi | nal Cou | nt, Chai | nei n | | | | | | 0 | | Not | ended ( | for each | read) | | | | | | 1 | | EN | or term | inal cou | nt | | | | | Mask Register and Single-Channel Mask Control Register. The format and I/O address of this DMK register (figure 107) is the same as in μPD71071 mode except that it cannot be read; it is a write-only register. The DMK register can be put into a known state by writing to it directly, by using the clear mask register command, or by using the single-channel mask control register (DSCM) at I/O address x1010b to set or clear the enable bit for an individual channel (figure 108). Figure 107. DMA Mask Register (DMK); µРD71037 Mode | _ | - | - | _ | МЗ | M2 | M1 | MO | | | | |----|---------------------------------------|-----------------------|--------|----|----|----|----|--|--|--| | 7 | 7 Address 0FH<br>Byte OUT Instruction | | | | | | | | | | | Mn | | DMARQ Mask, Channel n | | | | | | | | | | 0 | | Not | masked | | | | | | | | | 1 | | Mas | ked | | | | | | | | Figure 108. DMA Single-Channel Mask Control Register (DSCM); µPD71037 Mode | - | - | - | – | - | SMQ | SELCH | | | | |---|----------------------------------------------------|----------------------------|-------------------------------------------|--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--| | | Byte OUT Instruction Mask Setting Clear mask bit | | | | | | | | | | | Mask | Setting | | | | | | | | | | | | | | | | | | | | | Set mask bit DMARQ Mask Channel Selection | | | | | | | | | | | Cha | nnel 0 | | | ···· | | | | | | | Cha | nnel 1 | | | | *** | | | | | | Cha | nnel 2 | | | | | | | | | | Cha | nnel 3 | | | | | | | | | | - | Mask Clee Set DMAF Cha Cha | Mask Setting<br>Clear mask<br>Set mask bi | Mask Setting Clear mask bit Set mask bit DMARQ Mask Channe Channel 0 Channel 1 Channel 2 | Mask Setting Clear mask bit Set mask bit DMARQ Mask Channel Select Channel 0 Channel 1 Channel 2 | Byte OUT Instruction Mask Setting Clear mask bit Set mask bit DMARQ Mask Channel Selection Channel 0 Channel 1 Channel 2 | | | | Software DMA Request Register. The DSRQ register is used by software to trigger a DMA operation. One application is to simulate the assertion of a hardware DMA request for diagnostic purposes. This register is written with the number of the targeted channel and a bit that sets or clears an internal request flag associated with that channel. Figure 109 shows the format of this register. Figure 109. Software DMA Request Register (DSRQ); µPD71037 Mode | | | • | | | | | | |-------|---|-------|----------|----------|----------------------------------------|---------|-------| | | _ | - | - | <b>–</b> | - | SRQ | SELCH | | 7 | | В | yte OUT | Instruct | ion | | 0 | | SRQ | | Requ | est | | ······································ | | | | 0 | | Clea | ar reque | st bit | | | | | 1 | | Set | request | bit | | | | | SELCH | | Softw | are DM | ARQ Ch | ennel Se | lection | | | 00 | | Cha | nnel 0 | | | | | | 01 | | Cha | nnel 1 | | | | | | 10 | • | Cha | nnel 2 | | | | | | 11 | | Cha | nnel 3 | | | | | | | | | | | | | | Initialization. In $\mu$ PD71037 mode, there is no DICM initialize register. Instead, the DMAU is initialized by performing an I/O write to address x1100b. T-49-17-15 NEC **POWER CONSERVATION** The V53 has three power conservation features. - Scalable system clock - Low-power HALT standby mode - Very-low-power STOP mode These features give three levels of power reduction, making the V53 ideal for use in portable or other low-power applications. The standby control register (SBCR) at address 0FFF1H in the system I/O area controls all three functions. See figure 110. # Scalable System Clock The V53 is a CMOS device and power consumption is directly proportional to clock frequency. By reducing the frequency, power use can be significantly decreased. The system clock is used by the CPU and internal peripherals. The CLKC field in the SBCR selects a scale factor that divides the oscillation frequency by 2, 4, 8, or 16 to produce the system clock. This value can be changed dynamically to adjust the clock rate to the most efficient performance level for the task at hand. Caution: The system clock must not be set to less than the minimum frequency specified in the AC Characteristics Figure 110. Standby Control Register (SBCR) | | | | anday Control Hegister (CDOI) | | | | | | | | |------|---|----------------------|-------------------------------|--------------|------|--|--|--|--|--| | | _ | - 1 | CLKC | WT | STOP | | | | | | | 7 | | | Address FFF1H | | 0 | | | | | | | CLKC | | Syster | n Clock Freque | ncy folk | | | | | | | | 00 | | fcuk | = Osc freq + : | 2 | | | | | | | | 01 | | | = Osc freq ÷ | | | | | | | | | . 10 | | | = Osc freq + t | | | | | | | | | _ 11 | | fCLK = Osc freq ÷ 16 | | | | | | | | | | WT | | * Osci | llation Stabiliza | tion Time | | | | | | | | 00 | | 219 - | ÷ folk | | | | | | | | | 01 | | 218 - | ÷ fc⊬k | | | | | | | | | 10 | | 217 | + fork | | | | | | | | | _11 | | 216 . | + folk | | | | | | | | | STOP | | When | HALT instruction | n is Execute | d | | | | | | | 0 | | Sets | HALT mode | | | | | | | | | 1 | | Sets | STOP mode | | | | | | | | | | | | | | | | | | | | <sup>\*</sup> For example, if WT = 11 and f<sub>CLK</sub> = 16 MHz, time = 4.096 ms #### **HALT Standby Mode** Power can be further reduced by putting the CPU in HALT standby mode. In this mode, the CPU is not operating, but all the internal peripherals are still enabled and may be drawing power. HALT mode is entered by setting the STOP bit in the SBCR to 0 and executing a HALT instruction. The V53 will come out of HALT standby mode in response to RESET, NMI, or an interrupt from the internal interrupt control unit. If interrupts were enabled (IE=1) before HALT mode was entered, an ICU interrupt wakeup will result in the interrupt handler being entered; if interrupts were not enabled (IE=0), then execution will resume at the instruction following the HALT that put the CPU in the standby mode. If NMI wakes up the CPU, the NMI handler is always entered. The bus hold (HLDRQ/HLDAK) function still operates during standby mode. External bus masters can take the bus from V53. Also, refresh and DMA cycles can still occur. The SCU and TCU can both be active, and can supply the wakeup interrupt if desired. Refer to table 1 to find out what state the V53 outputs will be in HALT standby mode. #### STOP Mode This mode provides the maximum power reduction. The clock generator is disabled; the oscillator circuit is turned off. Power usage is minimal. STOP mode is entered by setting the STOP bit in the SBCR to 1 and executing a HALT instruction. Since the system clock is not active, none of the on-chip peripherals can be used in this mode. If the timer unit's TCLK input is used and driven by an external oscillator, the timer will continue to function and consume power. The output pins in STOP mode are in the same state as in the HALT mode. Refer to table 1 for details. The V53 will wake up from STOP mode in response to a RESET or NMI. # **Oscillator Stabilization Time** When the V53 is reset or when it wakes up from STOP mode, the oscillator circuit is started up. This circuit can take a relatively long time to come up to speed and to stabilize. The oscillator stabilization time field (WT) in the SBCR does not affect the physical startup time; it determines how long the V53 will wait for the clock generator oscillator circuit to stabilize. The user should determine the worst case stabilization time and select a longer value of WT. ## **RESET FUNCTION** The V53 is reset when a falling edge is input to the RESET pin and is subsequently held low for six clocks or longer than the oscillator stabilization time and then made high. T-49-17-15 # **CPU Operations** When the V53 is reset, the CPU is initialized as shown in figure 111 and starts prefetching instructions from address FFFF0H. Figure 111. CPU Reset Status | Program Counter PC 0000H Program Segment Register PS FFFFF Stack Segment Register SS 0000H Data Segment 0 Register DS0 0000H Data Segment 1 Register DS1 0000H Queue Cleare Program Status Word PSW 1 1 1 1 V DIR IE BRK 15 0 0 0 0 0 0 S Z 0 AC 0 P 1 CY 0 0 0 0 0 0 0 | | | | | | | | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------------------|----------|----|-----|-----|---|---------| | Program Segment Register | Prefetch | Pointer | | | | PFP | | 0000H | | Stack Segment Register | Program | Counter | | | | PC | | 0000H | | Data Segment 0 Register | Program | Segmen | t Regist | er | | PS | | FFFFH | | Data Segment 1 Register | Stack Se | Stack Segment Register | | | | SS | | 0000H | | Queue Cleare Program Status Word PSW 1 1 1 1 V DIR IE BRK 15 0 0 0 0 0 0 S Z 0 AC 0 P 1 CY 0 0 0 0 0 0 0 | Data Se | gment 0 | Register | | | | | | | Program Status Word PSW 1 | Data Se | gment 1 | Register | | DS1 | | | 0000H | | 1 1 1 1 V DIR IE BRK 0 0 0 0 0 15 0 AC 0 P 1 CY 0 0 0 0 | Queue | | | | | | | Cleared | | | Program | Status \ | Nord | | | | | | | S Z 0 AC 0 P 1 CY 0 0 0 0 0 0 | 1 | 1 | 1 | 1 | | | | | | 0 0 0 0 0 | 15 | J | 1 | | | | | 0 | | 7 | | _ | 0 | | 0 | | 1 | 1 - | | | 7 | | ····· | | | | | 0 | # **Internal Register Operations** Some internal registers are also initialized by the RESET Input signal. See figure 112. The rest of the registers retain the status they had immediately before the RESET signal was applied, but their contents are undefined at power up. Figure 112. Register Reset Status | | | initiai Value, Bits 7-0 | | | | | | | | | | |-----------|--------|-------------------------|---|---|---|---|---|----|--|--|--| | Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | System I/ | O Area | ? | | | | | | | | | | | SCTL | _ | . – | _ | 0 | 0 | 0 | 0 | 0 | | | | | OPSEL | | _ | _ | - | 0 | Q | 0 | 0 | | | | | WCY0 | _ | | | - | | 1 | 1 | 1 | | | | | WCY1 | _ | 1 | 1 | 1 | | 1 | 1 | 1 | | | | | WCY2 | | 1 | 1 | 1 | _ | 1 | 1 | 1 | | | | | WCY3 | | 1 | 1 | 1 | | 1 | 1 | 1 | | | | | WCY4 | _ | 1 | 1 | 1 | | 1 | 1 | 1 | | | | | WMB0 | | 1 | 1 | 1 | _ | 1 | 1 | _1 | | | | | WMB1 | _ | 1 | 1 | 1 | | 1 | 1 | 1 | | | | | WAC | _ | _ | _ | _ | 0 | 0 | 0 | 0 | | | | | TCKS | | | | 0 | 0 | 0 | 0 | 0 | | | | | RFC | _ | 0 | _ | 0 | 1 | 0 | 0 | 0 | | | | | SBCR | - | - | _ | 0 | 0 | 0 | 0 | C | | | | | | | | | | | | | | | | | # Figure 112. Register Reset Status (cont) | | | | Init | ial Value | , Bits 7- | 0 | | | |-------------|---------|------|------|-----------|-----------|-----|-----|------| | Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Serial Co. | ntrol ( | Jnit | | | | | | | | SMD | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | | SCM | | _ | 0 | 0 | 0 | 0 | 0 | 0 | | SIMK | _ | | _ | | _ | _ | 1 | 1 | | SST | _ | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | DMA Con | trol U | nit | | | | | | | | DCH | | _ | | 0 | 0 | 0 | 0 | 1 | | DMD | 0 | 0 | 0 | 0 | 0 | 0 | _ | 0 | | DDC<br>(8H) | _ | - | 0 | 0 | _ | 0 | - | ः क् | | DDC<br>(9H) | | _ | - | _ | _ | _ | 0 ; | 0 | | DST | 0 | 0 | 0 | 0 | 0 | . 0 | 0 | . 0 | | DMK | _ | _ | | _ | 1 | 1 | 1 | - 1 | # INSTRUCTION SET HIGHLIGHTS # **Enhanced Instructions** In addition to the $\mu PD8088/86$ instructions, the $\mu$ PD70236 has enhanced instructions listed in table 8. Table 8. Enhanced Instruction | Instruction | Function | |-------------------------------------------------------------------------------------|---------------------------------------------------------------------------| | PUSH imm | Pushes immediate data onto stack | | PUSH R | Pushes 8 general registers onto stack | | POP R | Pops 8 general registers onto stack | | MUL Imm | Executes 16-bit multiply of register or memory contents by immediate data | | SHL imm8<br>SHR imm8<br>SHRA imm8<br>ROL imm8<br>ROR imm8<br>ROLC imm8<br>ROLC imm8 | Shifts/rotates register or memory by immediate value | | CHKIND | Checks array index against designated boundaries | | INM | Moves a string from an I/O port to memory | | OUTM | Moves a string from memory to an I/O port | | PREPARE | Allocates an area for a stack frame and copies<br>previous frame pointers | | DISPOSE | Frees the current stack frame on a procedure exi | | | | T-49-17-15 # **Enhanced Stack Operation Instructions** **PUSH imm.** This instruction allows immediate data to be pushed onto the stack. **PUSH R; POP R.** These instructions allow the contents of the eight general registers to be pushed onto or popped from the stack with a single instruction. #### **Enhanced Multiplication Instructions** MUL reg16, Imm16; MUL mem16, Imm16. These instructions allow the contents of a register or memory location to be multiplied by immediate data. # **Enhanced Shift and Rotate Instructions** SHL reg, imm8; SHR reg, imm8; SHRA reg, imm8. These instructions allow the contents of a register to be shifted by the number of bits defined by the immediate data. ROL reg, Imm8; ROR reg Imm8; ROLC reg, Imm8; RORC reg, Imm8. These instructions allow the contents of a register to be rotated by the number of bits defined by the immediate data. ## **Check Array Boundary Instruction** CHKIND reg16, mem32. This instruction is used to verify that index values pointing to the elements of an array data structure are within the defined range. See figure 113. The lower limit of the array should be in memory location mem32, the upper limit in mem32 + 2. If the index value in reg16 is not between these limits when CHKIND is executed, a BRK 5 will occur. This causes a jump to the location in interrupt vector 5. Figure 113. Check Array Boundary #### Block I/O Instruction **OUTM DW, src-block; INM dist-block, DW.** These instructions are used to output or input a string to or from memory, when preceded by a repeat prefix. #### Stack Frame Instruction PREPARE imm16,imm8. This instruction is used to generate the stack frames required by block-structured languages, such as PASCAL and Ada. The stack frame consists of two areas. One area has a pointer that points to another frame which has variables that the current frame can access. The other is a local variable area for the current procedure. DISPOSE. This instruction releases that last stack frame generated by the PREPARE instruction. It returns the stack and base pointers to the values they had before the PREPARE instruction was used to call a procedure. # **Unique Instructions** In addition to the $\mu$ PD8088/86 instructions and the enhanced instructions, the $\mu$ PD70236 has the unique instructions listed in table 9. # Variable Length Bit Field Operation Instructions This category has two instructions: INS (Insert Bit Field) and EXT (Extract Bit Field). These instructions are highly effective for computer graphics and high-level languages. They can, for example, be used for data structures such as packed arrays and record type data used in PASCAL. NEC T-49-17-15 INS reg8, reg8; INS reg8, Imm4. This instruction transfers low bits from the 16-bit AW register (the number of bits is specified by the second operand) to the memory location specified by the segment base (DS1 register) plus the byte offset (IY register). The starting bit position within this byte is specified as an offset by the lower 4 bits of the first operand. See figure 114. After each complete data transfer, the IY register and the register specified by the first operand are automatically updated to point to the next bit field. Either immediate data or a register may specify the number of bits transferred (second operand). Because the maximum transferable bit length is 16 bits, only the lower 4 bits of the specified register (00H to 0FH) will be valid. Bit field data may overlap the byte boundary of memory. Figure 114. Bit Field Insertion **EXT reg8, reg8; EXT reg8, imm4.** This instruction loads to the AW registers the bit field data whose bit length is specified by the second operand of the instruction from the memory location that is specified by the DS0 segment register (segment base), the IX index register (byte offset), and the lower 4 bits of the first operand (bit offset). See figure 115. After the transfer is complete, the IX register and the lower 4 bits of the first operand are automatically updated to point to the next bit field. Either Immediate data or a register may be specified for the second operand. Because the maximum transferable bit length is 16 bits, however, only the lower 4 bits of the specified register (00H to 0FH) will be valid. Bit field data may overlap the byte boundary of memory. Figure 115. Bit Field Extraction # **Packed BCD Operation Instructions** The instructions described here process packed BCD data either as strings (ADD4S, SUB4S, CMP4S) or byte-format operands (ROR4, ROL4). Packed BCD strings may be from 1 to 254 digits in length. When the number of digits is even, the zero (Z) and carry (CY) flags will be set according to the result of the operation. When the number of digits is odd, the Z and CY flags may not be set correctly. In this case (CL = odd), the Z flag will not be set unless the upper 4 bits of the highest byte are all 0s. The CY flag will not be set unless there is a carry out of the upper 4 bits of the highest byte. When CL is odd, the contents of the upper 4 bits of the highest byte of the result are undefined. ADD4S. This instruction adds the packed BCD string addressed by the IX index register to the packed BCD string addressed by the IY index register, and stores the result in the string addressed by the IY register. The length of the string (number of BCD digits) is specified by the CL register, and the result of the operation will affect the V (overflow), CY, and Z flags. BCD string (IY, CL) $\leftarrow$ BCD string (IY, CL) + BCD string (IX, CL) SUB4S. This instruction subtracts the packed BCD string addressed by the IX index register from the packed BCD string addressed by the IY register, and stores the result in the string addressed by the IY register. The length of the string (number of BCD digits) is specified by the CL register, and the result of the operation will affect the V, CY, and Z flags. BCD string (IY, CL) $\leftarrow$ BCD string (IY, CL) – BCD string (IX, CL) CMP4S. This instruction performs the same operation as SUB4S except that the result is not stored and only the V, CY, and Z flags are affected. BCD string (IY, CL) - BCD string (IX, CL) ROL4. This instruction treats the byte data of the register or memory operand specified by the instruction as T-49-17-15 BCD data and uses the lower 4 bits of the AL register (ALL) to rotate that data one BCD digit to the left. See figure 116. #### Figure 116. BCD Rotate Left ROR4. This instruction treats the byte data of the register or memory specified by the instruction as BCD data and uses the lower 4 bits of the AL register (AL<sub>L</sub>) to rotate that data one BCD digit to the right. See figure 117. ## Figure 117. BCD Rotate Right #### **Bit Manipulation Instructions** **TEST1.** This instruction tests a specific bit in a register or memory location. If the bit is 1, the Z flag is reset to 0. If the bit is 0, the Z flag is set to 1. **NOT1.** This instruction inverts a specific bit in a register or memory location. **CLR1.** This instruction clears a specific bit in a register or memory location. **SET1.** This instruction sets a specific bit in a register or memory location. ## Repeat Prefix Instructions **REPC.** This instruction causes the $\mu$ PD70236 to repeat the following primitive block transfer instruction until the CY flag becomes cleared or the CW register becomes zero. **REPNC.** This instruction causes the $\mu$ PD70236 to repeat the following primitive block transfer instruction until the CY flag becomes set or the CW register becomes zero. ### **Address Expansion Control Instructions** BRKXA Imm8. This instruction is used to turn on expanded addressing. The 8-bit immediate data specifies an interrupt vector. The PC field of this vector is loaded into the PC (and PFP). The XA flag in the XAM register is set to 1, thereby enabling the expanded addressing mode. The $\mu$ PD70236 will begin fetching from the new PFP through the address translation table. That is, the new PC is treated as a logical address and is translated to the new, larger physical address space. This instruction does not save any return address information, such as PC, PS, or PSW to the stack. RETXA imm8. This instruction is used to turn off expanded addressing. It is identical in operation to BRKXA, except that the expanded addressing mode is turned off before fetching from the new address. That is, the XA flag in the XAM register is set to 0, and the PC is loaded with the value of the PC field in the interrupt vector selected by the immediate data. This instruction does not save any return address information such as PC, PS, or PSW to the stack. # Porting μPD70116/70108 Code to μPD70236 CHKIND LDEA MOV DS0/DS1 BR 1,id CALL 1,id - (2) During signed division (DIV), if the quotient is 80H (byte operation) or 8000H (word), the μPD70116 will take a Divide By 0 trap. The μPD70236 will perform the calculation. - (3) When the μPD70116 executes the POLL instruction, it will wait for the POLL input signal to be asserted. The μPD70236 has no POLL input; instead, when this instruction is executed, if a coprocessor is not connected, then a Coprocessor Not Present trap will be taken. If a coprocessor is attached, then no operation takes place. The $\mu$ PD70116 accepts FP01 and FP02 as opcodes for the iAPX8087 coprocessor. The $\mu$ PD70236 accepts these as opcodes for the $\mu$ PD72291 coprocessor, which is not compatible with the IAPX8087. (4) During the POP R instruction, the $\mu$ PD70116 does not restore the SP register. The $\mu$ PD70236 does restore the SP. (5) When processing a divide error, the $\mu$ PD70116 saves the address of the next instruction. The $\mu$ PD70236 saves the address of the current instruction (the divide instruction). (6) The μPD70116 allows up to three prefix instructions in any combination. The μPD70236 also allows three prefixes, but only one of each type can be used. The μPD70236 could operate incorrectly if there are two prefixes of the same type. For example, consider: REPC REPC CMPBK SS: src-block, dst-block If the compare operation is interrupted, then when it resumes following the interrupt service, execution will begin at the REPC instruction, not the REP instruction, because two repeat prefixes were used. (7) The μPD70116 accepts NMI requests even while processing an NMI. The μPD70236 does not allow nesting of NMIs; the NMI input will be ignored until the NMI interrupt handler is exited. ### **INSTRUCTION SET** ## Symbols Preceding the instruction set, several tables explain symbols, abbreviations, and codes. #### Clocks In the Clocks column of the instruction set, the numbers cover these operations: instruction decoding, effective address calculation, operand fetch, and instruction execution. Clock timings assume the instruction has been prefetched and is present in the 8-byte instruction queue. Otherwise, add two clocks for each pair of bytes not present. Word operands require two additional clocks for each transfer to an unaligned (odd address) memory operand. These times are shown on the right side of the slash (/). For conditional control transfer or branch instructions, the number on the left side of the slash is applicable if the transfer or branch takes place. The number on the right side is applicable if it does not take place. If a range of numbers is given, the execution time depends on the operands involved. AC AH # μPD70236 (V53) T-49-17-15 | Symbols<br>Symbol | Mooning | |-------------------|-----------------------------------------------------------------------------| | | Meaning | | acc | Accumulator(AW or AL) | | duso | Displacement (8 or 16 bits) | | dmem | Direct memory address | | dat | Destination operand or address | | ext-disp8 | 16-bit displacement (sign-extension byte + 8-<br>bit displacement) | | far_label | Label within a different program segment | | far_proc | Procedure within a different program segment | | <u>fp_op</u> | Floating-point instruction operation | | imm | 8- or 16-bit immediate operand | | lmm3/4 | 3- or 4-bit immediate bit offset | | imm8 | 8-bit immediate operand | | imm16 | 16-bit immediate operand | | mem | Memory field (000 to 111); 8- or 16-bit memory<br>location | | mem8 | 8-bit memory location | | mem16 | 16-bit memory location | | mem32 | 32-bit memory location | | memptr16 | Word containing the destination address within the current segment | | memptr32 | Double word containing a destination address in<br>another segment | | mod | Mode field (00 to 10) | | near_label | Label within the current segment | | near_proc | Procedure within the current segment | | offset | Immediate offset data (16 bits) | | pop_value | Number of bytes to discard from the stack | | reg | Register field (000 to 111); 8- or 16-bit general-<br>purpose register | | reg8 | 8-bit general-purpose register | | reg16 | 16-bit general-purpose register | | regptr | 16-bit register containing a destination address within the current segment | | regptr16 | Register containing a destination address within the current segment | | seg | Immediate segment data (16 bits) | | short_label | Label between —128 and +127 bytes from the end of the current instruction | | sr | Segment register | | src | Source operand or address | | temp | Temporary register (8/16/32 bits) | Auxiliary carry flag Accumulator (high byte) | Symbol | Meaning | |------------------|--------------------------------------------------------------| | AL | Accumulator (low byte) | | AW | Accumulator (16 bits) | | вн | BW register (high byte) | | BL | BW register (low byte) | | BP | BP register | | BRK | Break flag | | BW | BW register (16 bits) | | СН | CW register (high byte) | | CL | CŴ register (low byte) | | CW | CW register (16 bits) | | CY | Carry flag | | DH | DW register (high byte) | | DIR | Direction flag | | DL | DW register (low byte) | | DSO | Data segment 0 register (16 bits) | | DS1 | Data segment 1 register (16 bits) | | DW | DW register (16 bits) | | IE | Interrupt enable flag | | ix | Index register (source) (16 bits) | | IY | Index register (destination) (16 bits) | | MD | Mode flag | | P | Parity flag | | PC | Program counter (16 bits) | | PS | Program segment register (16 bits) | | PSW | Program status word (16 bits) | | R | Register set | | S | Sign extend operand field | | | S = No sign extension S = Sign extend immediate byte operand | | <u> </u> | Sign flag | | SP | Stack pointer (16 bits) | | SS | Stack segment register (16 bits) | | v | Overflow flag | | <del>.</del> | Word/byte field (0 to 1) | | X, XXX, YYY, ZZZ | Data to identify the instruction code of the | | • | external floating-point arithmetic chip | | XXH | Two-digit hexadecimal value | | XXXXH | Four-digit hexadecimal value | | Z . | Zero flag | | Flag | Oper | rations | |------|------|---------| | | | | | Symbol | Meaning | |---------|------------------------------------| | (blank) | No change | | 0 | Cleared to 0 | | 1 | Set to 1 | | × | Set or cleared according to result | | u | Undefined | | R | Restored to previous state | # **Memory Addressing Modes** | mem | mod = 00 | mod = 01 | mod = 10 | |-----|----------|-----------------|------------------| | 000 | BW + IX | BW + IX + disp8 | BW + IX + disp16 | | 001 | BW + IY | BW + IY + disp8 | BW + IY + disp16 | | 010 | BP + IX | BP + IX + disp8 | BP + IX + disp16 | | 011 | BP + IY | BP + IY + disp8 | BP + IY + disp16 | | 100 | IX | IX + disp8 | IX + disp16 | | 101 | ΙΥ | IY + disp8 | iY + disp16 | | 110 | Direct | BP + disp8 | BP + disp16 | | 111 | BW | BW + disp8 | BW + disp16 | # Register Selection (mod = 11) | reg | W = 0 | W = 1 | |-----|-------|-------| | 000 | AL | WA | | 001 | CL | CW | | 010 | DL | Wa | | 011 | BL | BW | | 100 | AH | SP | | 101 | СН | BP | | 110 | DH | iX | | 111 | BH | ΙΥ | # Segment Register Selection | ar . | Segment Register | • | |------|------------------|---------------------| | 00 | DS1 | *55 | | 01 | PS | ,· • | | 10 - | SS | . <sup>*</sup> =*** | | 11 | DSO | | | | ····· | | # Instruction Set | | | | | | | | | | Opc | ebo | | | | | | | | | | 1 | Flag | | | | |-----------|-------------------|---|----|---|---|---|---|-----|-----|-----|---|-----|-------|---|-----|---|--------|-------|----|----|------|---|---|---| | Mnemonic | Operand | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 6 | 5 | 4 | 3 | 2 | 1 | 0 | Clocks | Bytes | AC | CY | ٧ | P | S | Z | | Data Tran | sfer Instructions | | | | | | | | | | | | | | | | | | | | | | | | | MOV | reg, reg | 1 | 0 | 0 | 0 | 1 | 0 | 1 | W | 1 1 | | reg | | | reg | | 2 | 2 | | | | | | | | | mem, reg | 1 | 0 | 0 | 0 | 1 | 0 | 0 | W | mod | | reg | | | men | 1 | 3/5 | 2-4 | | | | | | | | | reg, mem | 1 | 0 | 0 | 0 | 1 | 0 | 1 | W | mod | | reg | | | men | 1 | 5/7 | 2-4 | | | | | | | | | mem, imm | 1 | 1 | 0 | 0 | 0 | 1 | 1 | W | mod | | 000 | ) | | men | n | 3/5 | 3-6 | | | | | | | | - | reg, imm | 1 | 0. | 1 | 1 | W | | reç | , | | | | | | | | 2 | 2-3 | | | | | | _ | | | acc, dmem | 1 | 0 | 1 | 0 | 0 | 0 | 0 | W | | | | | | | | 5/7 | 3 | | | | | | | | | dmem, acc | 1 | 0 | 1 | 0 | 0 | 0 | 1 | W | | | | - | | | | 3/5 | 3 | | | | | | | | | sr, reg16 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 1 | 0 | ; | 3r | | reg | | 2 | 2 | | | | | | | | | sr, mem16 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | mod | 0 | | er | | men | n | 5/7 | 2-4 | | | | | | | | | reg16, sr | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 1 | 0 | ; | er . | | reg | | 2 | 2 | | | | | | | | | mem16, sr | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | mod | 0 | - 1 | 97 | | men | n | 3/5 | 2-4 | | | | | | | | | DS0, reg16, mem32 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | mod | | reg | <br>J | | mer | n | 10/14 | 2-4 | • | | | | | - | | | DS1, reg16, mem32 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | mod | | 1eč | ı | | men | n | 10/14 | 2-4 | • | | | | | | | | AH, PSW | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | | | | | _ | | | 2 | . 1 | | | | | | _ | | ٠ | PSW, AH | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | | | | | | | | 2 | 1 | x | x | | х | x | , | | LDEA | reg16, mem16 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | mod | | reç | , | | mer | n | 2 | 2-4 | | | | | | | | TRANS | src_table | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | | | | | | | | 5 | 1 | | | | | | | | | | | | | | | | | Opc | ode | | | | | | | | | | | | | | Flag | \$ | | | |----------------|-------------|------|-----|-----|-----|---|---|-----|-----|-----|----|---|-------|---|---|-----|---|-------------|-------------------------|-------|------------|-------------|-----------------|---------|----------------|---|---| | Mnemonic | Operand | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Cloc | ks | Byt | 0 <b>8</b> | AC | CY | V | P | S | 2 | | Data Tran | sfer Instru | otic | ons | (co | nt) | | | | | | | | | | | • | | | | | | | | | | | | | XCH | reg, reg | 1 | 0 | 0 | 0 | 0 | 1 | 1 | W | 1 | 1 | | reg | | | reg | | 3 | · · · · · · · · · · · · | 2 | | | | | | | _ | | | mem, reg | 1 | 0 | 0 | 0 | 0 | 1 | 1 | W | m | od | | reg | | | men | n | 8/12 | | 2- | 4 | | | | | | _ | | | AW, reg16 | 1 | 0 | 0 | 1 | 0 | | reg | | | | | | | | | | 3 | | 1 | | | | | | | | | Repeat Pr | efixes | | | | | • | | | | | _ | | | | | | | | | | | | | | | | _ | | REPC | | 0 | 1 | 1 | 0 | 0 | 1 | 0 | · 1 | | | - | | | | | | 2 | | 1 | | | | | | | _ | | REPNC | | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | | - | | | | | | - | 2 | | 1 | | | | | | • | _ | | REP | | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | | | | | | | | | 2 | • | 1 | | | | | | | _ | | REPE<br>REPZ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | REPNE<br>REPNZ | | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | | | | | | | | | 2 | | 1 | | | | | | | | | Block Tra | nsfer Instr | uct | ion | 8 | | | | | | | | | ····· | | | | • | ···-·· | | | • | | | | | | _ | | MOVBK | dst, src | 1 | 0 | 1 | 0 | 0 | 1 | 0 | W | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | 3 + | 4n (W | = 0) | | | | | | | | | | | | | | | | | | | | | | | | | | | 3 + | 4n (W | = 1, | even | add | resse | s) | | | _ | | | | | | | | | | | | | | | | | | | | | 8n (W<br>6n (W | | | | | | s) | | | | СМРВК | dst, src | 1 | 0 | 1 | 0 | n | 1 | 1 | W | | | | | | _ | | | <del></del> | <del></del> | | | × | × | | <del>У</del> / | | _ | | | , | • | , | • | · | • | • | • | •• | | | | | | | | | áт | 7n (W | • | | ^ | ^ | ^ | • | ^ | • | | | | | | | | | | | | | | | | • | | | | | 7n (W | | | add | resse | s) | | | | | | | | | | | | | | | | | | | | | | | 3 + | 11n (M | / = 1 | , odd | add | resse | s) | | | | | | | | | | | | | | | | | | | | | | | 3 + | 9n (Ŵ | = 1, | odd/ | even | addr | 6556 | s) | | | | CMPM | dst | 1 | 0 | 1 | 0 | 1 | 1 | 1 | W | | | | | | | | | | | 1 | | x | X | x | x | x | > | | | | | | | | | | | | | | | | | | | | | 5n (W | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 5n (W | | | | | | | | | | | | | | | | | | | | | | | | | | | | 3 + | 7n (W | | | aaar | esses | ) | | | | | LDM | STO | 1 | 0 | 1 | 0 | 1 | 1 | 0 | W | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2n (W | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2n (W<br>4n (W | | | | | | | | | | STM | | | _ | | | | | | 111 | | | | | | | | | 0 + | 411 (44 | | | aggi | 95595 | | | | | | OIM | dst | 1 | 0 | 1 | 0 | 1 | 0 | 1 | W | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2n (W | | | | | ۸۱ | | | | | | | | | | | | | | | | | | | | | | | 3 + | 2n (W<br>4n (W | = 1, | odd | auu<br>addr | 1 4556<br>A35A9 | 3)<br>1 | | | | T-49-17-1 | | | | | | | | | | Opc | ode | | | | | | | | | . === | | | Flag | 8 | | _ | |------------|--------------------------------|-------|-------|------|------|-------|------------|------------|-------------|------|------|------|------|-----|-----|-------|-------|-------------|------------------------------------------------------|---------------------------------|----------------------------|-------------|---|------------|-----| | Mnemonic | Operand | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Clocks | Bytes | AC | CY | ٧ | P | s | : | | I/O Instru | ctions (con | t) | | | | | | | | | | | | | | | | | | | | | | | | | IN | acc, imm8 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | W | | | | | | | | | 6/7 | 2 | | | | | | _ | | | acc, DW | 1 | 1 | 1 | 0 | 1 | 1 | 0 | W | | | | | | | | | 3/5 | 1 | | | | | | | | OUT | imm8, acc | 1 | 1 | 1 | 0 | 0 | 1 | 1 | W | | | | | | | | | 3/5 | 2 | | | | | | Т | | | DW, acc | 1 | 1 | 1 | 0 | 1 | 1 | 1 | W | | | | | | | | | 3/5 | 1 | | | | | | _ | | INM | dst, DW | 0 | 1 | 1 | 0 | 1 | 1 | 0 | W, | | | | | | | | | | 1 | | • | | | | _ | | | | | | | | | | | | | | | | | | | | 3 + 13n (\ | / = 1, eve<br>/ = 1, od<br>/ = 1, od<br>(d for I/O) | dd add<br>d/ever<br>dd/eve | iresse<br>n addi<br>n add | s)<br>resse | | <i>i</i> , | (ex | | OUTM | DW, arc | 0 | 1 | 1 | 0 | 1 | 1 | 1 | W | | | | | | | | | 3 + 13n (\ | / = 1, eve<br>// = 1, oo<br>// = 1, oo<br>dd for I/O | dd add<br>dd add<br>)<br>dd add | iresse<br>iresse<br>iresse | s)<br>18; | | | | | | n = nu<br>String is<br>Use the | nstru | ictic | on e | Xeci | ition | clo<br>h ( | ocks for I | oras<br>DMA | ingi | -ins | truc | tior | өхө | cut | lon a | are l | n parenthes | 99. | | | | | | | | BCD Instr | uctions | | | | | | | | | | | | | | | | | | | | | | | | | | ADJBA | | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | | | | | | | | | 4 | 1 | × | x | u | u | u | - | | ADJ4A | | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | | | | | | | | | 2 | 1 | × | × | u | x | x | -: | | ADJBS | | 0 | 0 | 1 | 1 | 1_ | 1 | 1 | 1 | | | | | | | | | 4 | 1 | × | x | u | u | u | _ | | ADJ4S | | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | | | | | | | 2 | 1 | х | x | u | x | x | -: | | ADD4S | dst, src | 0 | Q | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 2 + 18n | 2 | u | × | u | u | u | -; | | SUB4S | dst, src | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 2 + 18n | 2 | u | x | u | u | u | : | | CMP4S | dst, sro | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 7 + 14n | 2 | u | x | u | u | u | -: | | ROL4 | reg8 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 9 | 3 | | | | | | _ | | | | 1 | 1 | 0 | 0 | 0 | | reg | | | | | | | | | | | | | | | | | | | | mem8 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 15 | 3-5 | | | | | | _ | | | | m | od | 0 | 0 | 0 | | mem | 1 | | | | | | | | | | | | | | | | | | ROR4 | reg8 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 13 | 3 | | | | | | _ | | | | 1 | 1 | 0 | 0 | ٥ | | rea | | | | | | | | | | | | | | | | | | 0 0 0 0 1 1 1 1 0 0 1 0 1 0 1 0 19 mem8 mod 0 0 0 mem n = number of BCD digits divided by 2 T-49-17-15 Instruction Set (cont) | | | | | | | | | | | ode | | | | | | | | | | | | Flag | | | | |----------|---------------|------|------|----|------|-----|----|-----|---|-----|----|----|-----|---|---|-----|---|--------|-------|----|----|------|---|----------|----| | Mnemonic | <del>i</del> | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Clocks | Bytes | AC | CY | ٧ | P | <u> </u> | Z | | | e Conversion | on l | nsti | uc | tion | 8 | | | | | | | | | | | | | | | | | | | | | CVTBD | | _1_ | _1_ | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | _0 | 0 | 1 | 0 | _1 | 0 | 12 | 2 | ·u | u | u | × | × | × | | CVTDB | | 1 | 1 | 0 | 1 | 0 | _1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 8 | 2 | u | u | u | × | X | х | | CVTBW | | _1 | 0 | 0 | _1 | 1 | 0 | 0 | 0 | | | | | | | | | 2 | 1 | | | | | | | | CVTWL | | 1 | 0 | 0 | 1 | _1_ | 0 | 0 | 1 | | | | | | | | | 2 | 1 | | | | | | | | Arithmet | io Instructio | ns | | | | | | | | ι. | | | | | | | | | | | | | | | | | ADD | reg, reg | 0 | 0 | 0 | 0 | 0 | 0 | 1 | W | 1 | 1 | | reg | | | reg | | 2 | 2 | x | х | × | × | х | х | | | mem, reg | 0 | 0 | 0 | 0 | 0 | 0 | 0 | W | m | od | | reg | | | mer | n | 7/11 . | 2-4 | × | х | x | × | х | × | | | reg, mem | 0 | 0 | 0 | 0 | 0 | 0 | 1 | W | m | od | | reg | | | men | n | 6/8 | 2-4 | х | х | х | x | × | × | | | reg, imm | 1 | 0 | 0 | 0 | 0 | 0 | s | W | 1 | 1 | 0 | 0 | 0 | | reg | | 2 | 3-4 | x | x | × | × | × | × | | | mem, imm | 1 | 0 | 0 | Q | 0 | 0 | S | W | m | od | 0 | 0 | 0 | | men | n | 7/11 | 3-6 | x | х | × | × | х | × | | | acc, imm | 0 | 0 | 0 | 0 | 0. | 1 | 0 | W | | | | | | | | | 2 | 2-3 | × | × | × | x | x | × | | ADDC | reg, reg | Q | 0 | 0 | 1 | 0 | 0 | 1 | W | 1 | 1 | | reg | | | reg | | 2 | 2 | х | x | х | × | × | × | | | mem, reg | 0 | 0 | 0 | 1 | 0 | 0 | 0 | W | m | od | | reg | | | mer | n | 7/11 | 2-4 | x | × | × | х | × | × | | | reg, mem | 0 | 0 | 0 | 1 | 0 | 0 | 1 | W | m | od | | reg | | | men | n | 6/8 | 2-4 | х | х | × | × | × | ·x | | | reg, imm | 1 | 0 | 0 | 0 | 0 | 0 | S | W | 1 | 1 | 0 | 1 | 0 | | reg | | 2 | 3-4 | × | х | × | × | x | × | | | mem, imm | 1 | 0 | 0 | 0 | 0 | ō | S | W | m | od | 0 | 1 | 0 | | men | n | 7/11 | 3-6 | х | х | х | × | × | × | | | acc, Imm | 0 | 0 | 0 | 1 | 0 | 1 | 0 | W | | | | | | | | | 2 | 2-3 | × | х | × | × | × | × | | SUB | reg, reg | 0 | Ô | 1 | 0 | 1 | 0 | 1 | W | 1 | 1 | | teg | | | reg | | 2 | 2 | × | × | х | х | × | × | | | mem, reg | 0 | 0 | 1 | 0 | 1 | 0 | 0 | W | m | od | | reg | | | men | n | 7/11 | 2-4 | × | × | × | х | x | × | | | reg, mem | 0 | 0 | 1 | 0 | 1 | 0 | 1 | W | m | od | | reg | | | men | n | 6/8 | 2-4 | × | х | х | × | × | × | | | reg, Imm | 1 | 0 | 0 | 0 | 0 | 0 | S | W | 1 | 1 | 1 | 0 | 1 | | reg | | 2 | 3-4 | х | х | × | × | × | × | | | mem, imm | 1 | 0 | 0 | 0 | 0 | 0 | \$ | W | m | od | 1 | 0 | 1 | | men | n | 7/11 | 3-6 | × | x | × | × | × | × | | | aco, Imm | 0 | 0 | 1 | 0 | 1 | 1 | 0 | W | | | | | | | | | 2 | 2-3 | × | х | × | × | × | × | | SUBC | reg, reg | 0 | 0 | 0 | 1 | 1 | 0 | 1 | W | 1 | 1 | | reg | | | reg | | 2 | 2 | x | х | × | × | × | × | | | mem, reg | 0 | 0 | 0 | 1 | -1 | 0 | 0 | W | m | od | | reg | | | men | n | 7/11 | 2-4 | х | х | х | × | × | × | | | reg, mem | 0 | 0 | 0 | 1 | 1 | 0 | 1 | W | m | od | | reg | | | men | n | 6/8 | 2-4 | × | × | × | × | × | × | | | reg, Imm | 1 | 0 | 0 | 0 | 0 | 0 | s | W | 1 | 1 | 0 | 1 | 1 | | reg | | 2 | 3-4 | × | x | х | х | х | × | | | mem, imm | 1 | 0 | 0 | 0 | 0 | 0 | S | W | m | ođ | 0 | 1 | 1 | | men | n | 7/11 | 3-6 | × | х | х | x | × | х | | | acc, imm | 0 | 0 | 0 | 1 | 1 | 1 | 0 | W | | | | | | | | | 2 | 2-3 | x | × | × | × | × | × | | INC | reg8 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | | reg | | 2 | 2 | x | | × | × | × | × | | | mem | 1 | 1 | 1 | 1 | 1 | 1 | 1 | W | m | od | 0 | 0 | 0 | | men | n | 7/11 | 2-4 | × | | x | × | × | × | | | reg16 | 0 | 1 | 0 | 0 | 0 | | reg | | | | | | | | | | 2 | 1 | × | | × | × | × | × | | DEC | reg8 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | | reg | | 2 | 2 | × | | x | x | × | × | | | mem | 1 | 1 | 1 | 1 | 1 | 1 | 1 | W | m | ođ | 0 | 0 | 1 | | men | n | 7/11 | 2-4 | х | | х | х | х | x | | | reg16 | 0 | 1 | 0 | 0 | 1 | | reg | | | | | | | | | | 2 | 1 | х | - | × | × | × | × | | MULU | reg8 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | | reg | | 8 | 2 | u | × | х | u | u | u | | | reg16 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | | reg | | 12 | 2 | u | х | х | u | u | u | | | mem8 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | m | od | 1 | 0 | 0 | | men | | 12 | 2-4 | u | x | х | u | u | u | | | mem16 | t | 1 | 1 | 1 | 0 | 1 | 1 | 1 | m | od | 1 | 0 | 0 | | men | n | 16/18 | 2-4 | u | × | × | u | u | | | | | | | | | | | | | | | | | | | | | | | | | | _ | | _ | N E C ELECTRONICS INC 30E D = 6427525 0026925 4 = NEC | | | | | | | | | | Opc | ode | | | | | | | | i | Flag | 8 | | | |------------|----------------------|----|----|---|---|---|----------|---|-----|-----|----------|-----|------|-------|--------|-------|----|----|------|---|---|----| | Mnemonic | Operand | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 ( | 3 5 | 4 | 3 | 2 1 0 | Clocks | Bytes | AC | CY | ٧ | P | s | ; | | Arithmeti | c Instructions (cont | ) | | | | | | | | | | | | | | | | | | | | _ | | MUL | reg8 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 1 | 0 | 1 | reg | 8 | 2 | u | х | х | ч | u | 7 | | | reg16 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 1 | 0 | 1 | reg | 12 | 2 | u | х | х | u | u | _ | | | mem8 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | mod | 1 1 | 0 | 1 | mem | 12 | 2-4 | u | x | × | u | u | - | | | mem16 | 1 | 1, | 1 | 1 | 0 | 1 | 1 | 1 | mod | 1 1 | 0 | 1 | mem | 16/18 | 2-4 | u | x | х | u | u | i | | | reg16, reg16, lmm8 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | . 1 | 1 | reg | ı | reg | 12 | 3 . | u | х | х | u | u | 1 | | | reg16, mem16, imm8 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | mod | 1 | reç | ı | mem | 16/18 | 3-5 | u | х | x | u | u | 7 | | | reg16, reg16, lmm16 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | reg | ı | reg | 12 | 4 | u | × | х | u | u | , | | | reg16, mem16, lmm16 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | mod | Ī | reg | 1 | mem | 16/8 | 4-6 | u | х | х | u | u | 1 | | DIVU | reg8 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 . | 1 1 | 1 | 0 | reg | 11 | 2 | u | u | u | u | u | _ | | | reg16 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 . | 1 1 | 1 | 0 | reg | 19 | 2 | u | ч | u | u | u | _ | | | mem8 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | mod | 1 1 | 1 | 0 | mem | 15 | 2-4 | u | u | u | u | u | ı | | | mem16 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | mod | 1 | 1 | 0 | mem | 23/25 | 2-4 | u | u | u | u | ű | - | | DIV | reg8 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 . | 1 1 | 1 | 1 | reg | 16 | 2 | u | u | и | u | u | | | | reg16 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 1 | 1 | 1 | reg | 24 | 2 | u | u | u | u | u | - | | | mem8 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | mod | 1 1 | 1 | 1 | mem | 20 | 2-4 | u | u | u | u | u | _ | | | mem16 | 1. | 1 | 1 | 1 | 0 | 1 | 1 | 1 | mod | 1 1 | 1 | 1 | mem | 28/30 | 2-4 | u | u | u | u | u | , | | Comparia | on Instructions | | | | | | | | | | | | | | | | | | | | | _ | | CMP | reg, reg | 0 | 0 | 1 | 1 | 1 | 0 | 1 | W | 1 1 | ı | reg | ) | řeg | 2 | 2 | x | × | | x | x | ; | | | mem, reg | 0 | 0 | 1 | 1 | 1 | 0 | 0 | W | mod | | reg | , | mem | 6/8 | 2-4 | × | × | x | × | × | | | | reg, mem | 0 | 0 | 1 | 1 | 1 | 0 | 1 | W | mod | ı . | reg | | mem | 6/8 | 2-4 | × | x | x | × | x | _, | | | reg, imm | 1 | 0 | 0 | 0 | 0 | 0 | s | W | 1 | 1 | 1 | 1 | reg | 2 | 3-4 | x | × | × | × | × | _, | | | mem, imm | 1 | 0 | 0 | 0 | 0 | 0 | Ş | W | mod | 1 | 1 | 1 | mem | 6/8 | 3-6 | x | × | х | х | х | _, | | | acc, imm | 0 | 0 | 1 | 1 | 1 | 1 | 0 | W | | | | | | 2 | 2-3 | х | х | х | х | х | _, | | Logical In | structions | | | | | | | | | | | | | | | - | | | | | | _ | | NOT | reg | 1 | 1 | 1 | 1 | 0 | 1 | 1 | W | 1 1 | 0 | 1 | 0 | reg | 2 | 2 | | | | | | _ | | • | mem | 1 | 1 | 1 | 1 | 0 | 1 | 1 | W | mod | | 1 | 0 | mem | 7/11 | 2-4 | | | | | _ | _ | | NEG | reg | 1 | 1 | 1 | 1 | 0 | 1 | 1 | W | 1 1 | | 1 | 1 | reg | 2 | 2 | × | x | × | х | х | _, | | | mem | 1 | 1 | 1 | 1 | 0 | 1 | 1 | W | mod | 0 | 1 | 1 | mem | 7/11 | 2-4 | х | x | x | × | × | | | TEST | reg, reg | 1 | 0 | 0 | 0 | 0 | 1 | 0 | W | 1 1 | l | reg | <br> | reg | 2 | 2 | u | 0 | 0 | x | | _, | | | mem, reg | 1 | 0 | 0 | 0 | 0 | 1 | 0 | W | mod | <br>I | reg | | mem | 6/8 | 2-4 | u | 0 | 0 | × | × | | | | reg, Imm | 1 | 1 | 1 | 1 | 0 | 1 | 1 | W | 1 1 | 0 | 0 | 0 | reg | 2 | 3-4 | u | 0 | 0 | x | | , | | | mem, imm | 1 | 1 | 1 | 1 | 0 | 1 | 1 | W | mod | 0 | 0 | 0 | mem | 6/8 | 3-6 | u | 0 | 0 | | x | | | | acc, imm | 1 | 0 | 1 | 0 | 1 | 0 | 0 | W | | | | | | 2 | 2-3 | u | 0 | 0 | - | x | _ | | AND | reg, reg | | | _ | | | _ | _ | W | 1 1 | <u>.</u> | reg | _ | reg | 2 | 2 | u | 0 | | | × | | | | mem, reg | 0 | 0 | | | | 0 | | W | mod | | geı | | mem | 7/11 | 2-4 | u | 0 | | | × | _ | | | reg, mem | 0 | 0 | 1 | 0 | 0 | 0 | 1 | W | mod | | reg | | mem | 6/8 | 2-4 | u | 0 | | × | | | | | reg, lmm | | 0 | | | 0 | <u> </u> | 0 | W | 1 1 | | _ | | reg | 2 | 3-4 | u | 0 | | | | | | | mem, imm | 1 | 0 | 0 | 0 | | _ | | W | mod | | 0 | | mem | 7/11 | 3-6 | u | 0 | | _ | × | _ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Op | code | | | | | | | | | | | | ı | Flag | <b>J</b> \$ | | | |-----------|----------------|------|-------------|---|-----|----|---|-----|----|------|----|---|-----|----------|-----|-----|----|---|--------|-------|----|----|------|-------------|-----|---| | Mnemonic | Operand | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | _ 2 | 2 | 1 | 0 | Clocks | Bytes | AC | CY | ٧ | P | S | 2 | | | structions (co | ont) | | | | | | | | | | | | | | | | | | | | | | | | | | OR | reg, reg | 0 | 0 | 0 | 0 | _1 | 0 | 1 | W | 1 | 1 | | reg | ) | | r | eg | | 2 | 2 | u | 0 | 0 | × | X | × | | | mem, reg | 0 | 0 | 0 | 0 | 1 | 0 | 0 | W | m | od | | reg | 1 | | m | en | n | 7/11 | 2-4 | u | 0 | 0 | х | х | × | | | reg, mem | 0 | 0 | 0 | 0 | 1 | 0 | 1 | W | m | od | | reg | 1 | | m | en | n | 6/8 | 2-4 | u | 0 | 0 | х | x | × | | | reg, imm | 1 | 0 | 0 | 0 | 0 | 0 | 0 | W | 1 | 1 | 0 | 0 | 1 | | Ţ. | eg | | 2 | 3-4 | u | 0 | 0 | х | х | × | | | mem, Imm | 1 | 0 | 0 | 0 | 0 | 0 | 0 | Ŵ | m | od | 0 | 0 | _1 | | m | en | n | 7/11 | 3-6 | u | 0 | 0 | × | · x | × | | | aco, imm | 0 | 0 | 0 | | 1 | 1 | 0 | W | | | | | | | | | | 2 | 2-3 | u | 0 | 0 | х | х | х | | XOR | reg, reg | 0 | 0 | 1 | | 0 | 0 | 1 | W | 1 | 1 | | reg | <u> </u> | | r | eg | | 2 ` | 2 | u | 0 | 0 | × | X | × | | | mem, reg | 0 | 0 | 1 | _1_ | 0 | 0 | 0 | W | m | od | | 198 | 1 | | m | en | n | 7/11 | 2-4 | u | 0 | 0 | х | x | × | | | reg, mem | 0 | 0 | 1 | 1. | 0 | 0 | 1 | W | m | od | | 1eg | 1 | | m | en | n | 6/8 | 2-4 | u | 0 | 0 | × | × | x | | | reg, Imm | 1 | 0 | 0 | 0 | 0 | 0 | 0 | W | 1 | 1 | 1 | 1 | 0 | | r | eg | ! | 2 | 3-4 | u | 0 | 0 | × | x | × | | | mem, imm | _1_ | 0 | 0 | 0 | 0 | 0 | 0 | W | m | od | 1 | 1 | 0 | | m | en | n | 7/11 | 3-6 | u | 0 | 0 | × | x | × | | | acc, Imm | 0 | 0 | 1 | 1 | 0 | 1 | 0 | W | | | | | | | | | | 2 | 2-3 | u | 0 | 0 | × | х | × | | Bit Manip | ulation Instru | otic | on <b>s</b> | | | | | | | | | | | | | | | | | | | | | | | _ | | INS | reg8, reg8 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | - 0 | ) ( | 0 | 1 | 37-61/ | 3 | | | | | | | | | | 1 | 1 | | reg | | | reg | | | | | | | | | | | 39-77 | | | | | | | | | | reg8, imm4 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | C | ) ( | 0 | 1 | 37-69/ | 4 | | | | | | | | | | 1 | 1 | 0 | 0 | 0 | | reg | | | | | | | | | | | 39-77 | | | | | | | | | EXT | reg8, reg8 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | C | ) . | 1 | 1 | 29-61/ | 3 | | | _ | | | | | | | 1 | 1 | | reg | | | reg | | | | | | | | | | | 33-63 | | | | | | | | | | reg8, lmm4 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | , . | 1 | 1 | 29-61/ | 4 | | | _ | | | | | | | 1 | 1 | 0 | 0 | 0 | | reg | | | | | | | | | | | 33-63 | | | | | | | | | TEST1 | reg, CL | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | ) ( | ) | W | 4 | 3 | u | 0 | 0 | u | u | | | | | 1 | 1 | 0 | 0 | 0 | | reg | | | | | | | | | | | | | | | | | | | | | mem8, CL | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | ) ( | 5 | 0 | 8 | 3-5 | u | 0 | 0 | u | u | | | | | m | od | 0 | 0 | 0 | | men | n | | | | | | | | | | | | | | | | | | | | mem16, CL | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | ) ( | ) | 1 | 8/10 | 3-5 | u | 0 | 0 | u | u | | | | | m | od | 0 | 0 | 0 | | men | n | | | | | | | | | | | | | | | | | | | | reg, imm3/4 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | ) ( | ) | W | 4 | 4 | u | 0 | 0 | u | u | | | | | 1 | 1 | 0 | 0 | 0 | | reg | | | | | | | | | | | | | | | | | | | | | mem8, imm3 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | ) ( | ) | 0 | 13 | 4-6 | u | 0 | 0 | u | u | | | | | me | od | 0 | 0 | 0 | | men | n | | | | | | | | | | | | | | | | | | | | mem16, imm4 | 0 | Ó | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | ) ( | ) | 1 | 8/10 | 4-6 | u | 0 | 0 | u | u | | | | | m | od | 0 | 0 | 0 | | men | 1 | | | | | | | | | | | | | | | | | | | SET1 | reg, CL | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | ( | ) | W | 4 | 3 | | | | _ | | — | | | | 1 | 1 | 0 | 0 | 0 | | reg | | | | | | | | | | | | | | | | | | | | | mem, CL | 0. | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | ( | ) | w | 9 | 3-5 | | | | | | — | | | | m | od | 0 | 0 | 0 | | men | 1 | | | | | | | | | | | | | | | | | | | | reg, imm3/4 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | C | ) | W | 4 | 4 | | | | | | _ | | | | | | _ | _ | _ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Opo | ode | ) | | | | | | | | | | I | Flags | | |-------------|-----------------|-----|-----|-----|-----|---|---|-----|-----|-----|---|---|---|---|---|---|---|--------|-------|----|----|-------|------------| | Mnemonic | Operand | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Clocks | Bytes | AC | CY | V P | SZ | | Bit Manipu | ilation Instruc | tio | ns | (00 | nt) | | | | | | | | | | | | | | | | | | | | SET1 (cont) | mem8, imm3 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 9 | 4-6 | | | | | | | | m | od | 0 | 0 | 0 | | mem | l | | | | | | | | | | | | | | | | | mem 16, imm4 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 9/13 | 4-6 | | | | | | | | m | od | 0 | 0 | 0 | _ | mem | 1 | | | | | | | | | | | | | | | | | CY | 1 | 1 | 1 | 1 | 1 | Ò | 0, | 1 | | | | | | | | | 2 | 1 | | 1 | | | | | DIR | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1_ | | | | | | | | | 2 | 1 | | | | | | CLR1 | reg, CL | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | W | 4 , | 3 | | | | | | | | 1 | 1 | 0 | 0 | 0 | | reg | | | | | | _ | | | | | | | | | | | | mem8, CL | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 9 | 3-5 | | | | | | | | m | od | 0 | 0 | 0 | | mem | ) | | | | | | | | | | | | - | | | | | mem 16, CL | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 9/13 | 3-5 | | | | | | | | m | od | 0 | 0 | 0 | | mem | 1 | | | | | | | | | | | | | | • | | | reg, lmm3/4 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | W | 4 | 4 | | | | - | | | | 1 | 1 | 0 | 0 | 0 | | reg | | | | | | | | | | | - | | | | E state as | | | mem8, imm3 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 9 | 4-6 | | | | | | | | m | od | 0 | 0 | 0 | | mem | 1 | | | | | | | | | | | | | | | | | mem16, lmm4 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 9/13 | 4-6 | | | | | | | | m | nod | 0 | 0 | 0 | | mem | 1 | | | | | | | | | | | | | | | | | CY | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | | | | | | | | | 2 | 1 | | 0 | | | | | DIR | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | | | | | | | | | 2 | 1 | | | | | | NOT1 | reg, CL | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | W | 4 | 3 | | | | | | | | 1 | 1 | 0 | 0 | 0 | | reg | | | | | | | | | | | | | | | | | | mem8, CL | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 9 | 3-5 | | | | | | | | m | bor | 0 | 0 | 0 | | mem | 1 | | | | | | | | | | | | | | | | | mem16, CL | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 9/13 | 3-5 | | | | | | | | m | nod | 0 | 0 | 0 | | mem | ì | | | | | | | | | | | | | | | | | reg, imm3/4 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | W | 4 | 4 | | | | | | | | 1 | 1 | 0 | 0 | 0 | | reg | | | | | | | | | | | | | | | | | | mem8, imm3 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | W | 9 | 4-6 | | | | | | | _ | m | nod | 0 | 0 | 0 | | mem | 1 | | | | | | | | | | | | | | | | | mem 16, imm4 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 9/13 | 4-6 | | | | | | | | m | nod | 0 | 0 | 0 | | mem | 1 | | | | | | | | | | | | | | | | | CY | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | | | | | | | | | 2 | 1 | | × | | | T-49-17-15 Instruction Set (cont) | | | | | | | | | | Оро | eboc | | | | | | | | | Flag | gs | | | |--------------|--------------|-----|----|---|---|---|---|---|-----|-------|-----|---|----|-----|----------|-------|----|----------|------|----|---|----| | Mnemonic | Operand | 7 | 6 | 5 | 4 | | 2 | 1 | 0 | 7 6 | 5 | 4 | 3 | 2 1 | 0 Clocks | Bytes | AC | CY | ٧ | P | S | 7 | | <u> </u> | te Instructi | ons | } | | | | | | | | | | | | | | | | _ | | | | | SHL | reg, 1 | 1 | _1 | 0 | 1 | 0 | 0 | 0 | W | 1 1 | 1 | 0 | 0 | reg | 2 | 2 | u | x | х | х | х | ; | | | mem, 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | W | mod | 1 | 0 | 0 | mem | 7/11 | 2-4 | u | × | × | х | × | , | | | reg, CL | 1 | 1 | 0 | 1 | 0 | 0 | 1 | W | 1 1 | 1 | 0 | 0 | reg | 2 + n | 2 | u | × | u | х | × | , | | | mem, CL | 1 | _1 | 0 | 1 | 0 | 0 | 1 | W | mod | 1 | Ò | 0 | mem | 6/10 + n | 2-4 | u | × | u | х | х | -; | | | reg, imm8 | 1 | _1 | 0 | 0 | 0 | 0 | 0 | W | ٠ 1 1 | 1 | 0 | 0 | reg | 2 + n | 3 | u | × | u | × | х | , | | <del> </del> | mem, imm8 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | W | mod | 1 | 0 | 0 | mem | 6/10 + n | 3-5 | u | × | u | × | × | -, | | SHR | reg, 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | W | 1 1 | 1 | 0 | 1 | reg | 2 . | 2 | u | х | x | х | × | , | | | mem, 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | W | mod | · 1 | 0 | 1 | mem | 7/11 | 2-4 | u | x | x | × | x | , | | | reg, CL | 1 | 1 | 0 | 1 | 0 | 0 | 1 | W | 1 1 | 1 | 0 | 1 | reg | 2 + n | 2 | u | x | u | x | x | , | | | mem, CL | 1 | 1 | 0 | 1 | 0 | 0 | 1 | W | mod | 1 | 0 | 1 | mem | 6/10 + n | 2-4 | u | × | u | × | × | , | | | reg, lmm8 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | W | 1 1 | 1 | 0 | 1 | reg | 2 + n | 3 | u | × | u | × | х | , | | | mem, imm8 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | W | mod | 1 | 0 | 1 | mem | 6/10 + n | 3-5 | u | x | u | × | х | | | SHRA | reg, 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | W | 1 1 | 1 | 1 | 1 | reg | 2 | 2 | u | × | 0 | × | x | _, | | | mem, 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | W | mod | 1 | 1 | 1 | mem | 7/11 | 2-4 | u | х | 0 | х | x | × | | | reg, CL | 1 | 1 | 0 | 1 | 0 | 0 | 1 | W | 1 1 | 1 | 1 | 1 | reg | 2 + n | 2 | u | × | u | x | × | x | | | mem, CL | 1 | 1 | 0 | 1 | 0 | 0 | 1 | W | mod | 1 | 1 | 1 | mem | 6/10 + n | 2-4 | u | x | u | × | x | x | | | reg, imm8 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | W | 1 1 | 1 | 1 | 1 | reg | 2 + n | 3 | u | × | u | × | × | x | | | mem, imm8 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | W | mod | 1 | 1 | 1 | mem | 6/10 + n | 3-5 | u | х | ш | × | × | x | | ROL | reg, 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | W | 1 1 | 0 | 0 | 0 | reg | 2 | 2 | | × | × | | | | | | mem, 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | W | mod | 0 | 0 | 0 | mem | 7/11 | 2-4 | | × | × | | | _ | | | reg, CL | 1 | 1 | 0 | 1 | 0 | 0 | 1 | W | 1. 1 | 0 | 0 | 0 | reg | 2 + n | 2 | | x | u | | | | | | mem, CL | 1 | 1 | 0 | 1 | 0 | 0 | 1 | W | mod | 0 | 0 | 0 | mem | 6/10 + n | 2-4 | | x | u | | | | | | reg, imm | 1 | 1 | 0 | 0 | 0 | 0 | 0 | W | 1 1 | 0 | 0 | 0 | reg | 2 + n | 3 | | × | u | | | _ | | | mem, imm | 1 | 1 | 0 | 0 | 0 | 0 | 0 | W | mod | 0 | 0 | 0 | mem | 6/10 + n | 3-5 | | x | u | | | | | ROR | reg, 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | W | 1 1 | 0 | 0 | 1 | reg | 2 + n | 2 | | x | u | | | | | | mem, 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | W | mod | 0 | 0 | 1 | mem | 7/11 | 2-4 | | × | × | | | - | | | reg, CL . | 1 | 1 | 0 | 1 | 0 | 0 | 1 | W | 1 1 | 0 | 0 | 1 | reg | 7 + n | 2 | | x | u | | | - | | | mem, CL | 1 | 1 | 0 | 1 | 0 | 0 | 1 | W | mod | 0 | 0 | 1 | mem | 6/10 + n | 2-4 | | × | u | | | _ | | | reg, imm8 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | W | 1 1 | 0 | 0 | 1: | reg | 2 + n | 3 | | x | u | | | - | | ··· | mem, imm8 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | W | mod | 0 | 0 | 1 | mem | 6/10 + n | 3-5 | | × | u | | | _ | | ROLC | reg, 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | W | 1 1 | 0 | 1 | 0 | reg | 2 | 2 | | x | x | | | | | | mem, 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | W | mod | 0 | 1 | 0 | mem | 7/11 | 2-4 | | x | × | | | _ | | • | reg, CL | 1 | 1 | 0 | 1 | 0 | 0 | 1 | W | 1 1 | 0 | 1 | 0 | reg | 2 + n | 2 | | x | u | | | _ | | • | mem, CL | 1 | 1 | 0 | 1 | 0 | 0 | 1 | W | mod | 0 | 1 | 0 | mem | 6/10 + n | 2-4 | | <u>x</u> | u | | | - | | • | reg, imm8 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | W | 1 1 | 0 | 1 | 0 | reg | 2 + n | 3 | | × | u | | | - | | | mem, imm8 | 1 | 1 | 0 | Q | 0 | 0 | 0 | W | mod | 0 | 1 | 0 | mem | 6/10 + n | 3-5 | | <u>x</u> | u | | | | | | | | | | | | | | | | | | | | n = numb | | | | _ | | | | | | | | | | | | | | Оро | ebo | | | | | | | | | | | Flag | 38 | | | |------------|----------------|------|------|-----|---|----|----|-----|-----|-----|-------|------|-----|-----|------|----------|--------------|------------|-------------|------|------|----|---|---| | Mnemonic | Operand | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 5 | 4 | ; | 3 : | 2 1 | 0 | Clocks | Bytes | AC | CY | ٧ | P | S | Z | | Shift/Rota | te Instruction | ns ( | (co1 | ıt) | | | | | | | | | | | | | | | | | | | | | | RORC | reg, 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | W | 1 | 1 0 | 1 | • | 1 | reg | 1 | 2 | 2 | | x | × | | | | | | mem, 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | W | mod | 0 b | 1 | _ | 1 | mer | ກ | 7/11 | 2-4 | | × | х | | | | | | reg, CL | 1 | 1 | 0 | 1 | 0 | 0 | 1 | W | 1 | 1 0 | 1 | | 1 | reç | 1 | 2 + n | 2 | | x | u | | | | | | mem, CL | 1 | 1 | 0 | 1 | 0 | 0 | 1 | W | mod | d 0 | 1 | | 1 | mer | n | 6/10 + n | 2-4 | | × | u | | | | | | reg, lmm8 | 1 | 1 | 0 | 0 | 0 | 0 | ٥, | W | 1 | 1 0 | 1 | | 1 | reg | ı | 2 + n | 3 | | х | u | | | | | | mem, lmm8 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | W | mod | d O | _1 | | 1 | mer | n | 6/10 + n | 3-5 | | × | u | | | | | | | | | | | | | | | | | | | | | | n = numb | er of shif | ts | | | | | | | Stack Ma | nipulation Ins | itru | icti | ons | ; | | | | | | | | | | | | | | | | | | | | | PUSH | mem16 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | mod | d 1 | 1 | ( | 0 | mer | n | 5/9 | 2-4 | | | | | | | | | reg16 | 0 | 1 | 0 | 1 | 0 | | reg | | | | | | | • | | 3/5 | 1 | | | | | | | | | sr | 0 | 0 | 0 | | )r | 1 | 1 | 0 | | | | | | | | 3/5 | 1 | | | | | | _ | | | PSW | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | | | | | | | | 3/5 | 1 | | | | | • | | | | R | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | | | | | | | | 20/36 | 1 | | | | | - | | | | lmm | 0 | 1 | 1 | 0 | 1 | 0 | S | 0 | | | | | | | | 3/5 | 2-3 | | | | | | | | POP | mem16 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | mod | d 0 | 0 | ( | 0 | mer | n | 5/9 | 2-4 | | | | | | | | | reg16 | 0 | 1 | 0 | 1 | 1 | | reg | | | | | | | | | 5/7 | 1 | | | | | | | | | sr | 0 | 0 | 0 | | 31 | 1 | 1 | 1 | | | | | | | | 5/7 | 1 | | | | | | | | | PSW | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | | | | | | | | 5/7 | 1 | R | R | R | R | R | R | | | R | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | | | | | | | | 22/38 | 1 | | | | | | | | PREPARE | imm16, imm8 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | | | | | | | | * | 4 | | , | | | | | | | | | | | | | | | | | m8 = | | | | _ | | | | | | | | | | | | | | | _ | | | | | | imm | 18≥ ' | : 17 | + | 12 | (imm | 8 – 1 | l) odd, 15 + | <u>-</u> | -1) ev | en . | | | | | | DISPOSE | | | | | 0 | | 0 | 0 | 1 | | | | | | | | 6/10 | 1 | <del></del> | | | | | | | | ransfer Instru | | | | | | | | | | | | | | | | · | | | | | | | | | CALL | near_proc | 1 | 1 | 1 | 0 | | 0 | 0 | 0 | | | | | | | | 7/9 | 3 | | | | | | | | | regptr16 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 1 0 | | | 0 | reg | <u> </u> | 7/9 | 2 | | | | | | | | | memptr16 | 1 | 1 | 1 | | 1 | 1 | 1 | 1 | mod | d 0 | | | 0 | mer | n | 11/15 | 2-4 | | | | | | | | | far_proc | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | | | | | | | | 9/13 | 5 | | | | | | | | | memptr32 | 1 | 1 | 1 | 1 | 1 | _1 | 1 | 1 | mod | d 0 | 1 | | 1 | mer | n_ | 15/23 | 2-4 | | | | | | | | RET | | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | | | | | | | | 10/12 | 1 | | | | | | | | | pop_value | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | | | | | | | | 10/12 | 3 | | | | | | | | • | <del></del> | 1 | 1 | | 0 | 1 | 0 | 1 | 1_ | | | | | | | | 12/16 | 1 | | | | | | | | | pop_value | | 1 | 0 | | 1 | 0 | | 0 | | | | | | | | 12/16 | 3 | | | | | | | | BR | near_label | 1 | | 1 | | 1 | | 0 | 1_ | | | | | | | | 7 | 3 | | | | | | | | | short_label | 1 | | 1 | | 1 | 0 | 1 | 1 | | | | | | | | 7 | 2 | | | | | | | | | regptr16 | 1 | | | | 1 | | _1 | 1_ | 1 | | 0 | | | reç | _ | 7 | 2 | | | | | | | | | memptr16 | 1 | | 1 | | | | 1 | 1 | mo | d 1 | 0 | . ( | 0 | mer | n | 11/13 | 2-4 | | | | | | | | | far_label | 1 | | | 0 | | | 1 | 0 | | | | | | | | 7 | 5 | | | | | | | | | memptr32 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | mo | d 1 | 0 | | 1 | met | n | 13/17 | 2-4 | | | | | | | T-49-17-15 instruction Set (cont) | | | | | | | | | | Ope | eboo | | | | | | | | | | | | Flag | 18 | | | |-----------|----------------|------|-----|-----|-----|---|---|---|-----|------|---|-----|-----|-----|-----|------|------|-----------------|-------|----|----|------|----|-------------|-------------| | Mnemonic | | 7 | | | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | ! ' | 1 0 | Clocks | Bytes | AC | CY | ٧ | P | S | 2 | | | ransfer Instru | ctic | ons | (00 | nt) | | | | | | | | | | | | | | | | | | | | | | BV | short_label | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | | ··· | | | | | | 3/6 | 2 | | | | | | | | BNV | short_label | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | | | | | | | | | 3/6 | 2 | | | | | | | | BC, BL | short_label | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | | | | | | | | | 3/6 | 2 | | | | | | | | BNC, BNL | short_label | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | | | | | | | | | 3/6 | 2 | | | | | | | | BE, BZ | short_label | 0 | 1 | 1 | 1 | 0 | 1 | 0 | Q, | | | | | | | | | 3/6 | 2 | | | | | | | | BNE, BNZ | short_label | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | | | | | | | | | 3/6 | 2 | | | | | | | | BNH | short_label | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | | | | | | | | | 3/6 , | 2 | | | | | | | | BH | short_label | 0 | 1 | 1 | _1 | 0 | 1 | 1 | 1 | | | | | | | | | 3/6 | 2 | | | | | | _ | | BN | short_label | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | | | | | | | | | 3/6 | 2 | | | | | | | | BP | short_label | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | | | | | | | | | 3/6 | 2 | | | | | | _ | | BPE | short_label | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | | | | | | | | | 3/6 | 2 | | | | | | _ | | вро | short_label | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | | | | | | | | | 3/6 | 2 | | | | | | | | Interrupt | Instructions | | | | | | | | | | | | | _ | | | | • | | | | | | | _ | | BLT | short_label | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | | _ | | | | | | | 3/6 | 2 | | | | | | _ | | BGE | short_label | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | | | | | | | | | 3/6 | 2 | | | | | | - | | BLE | short_label | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | | | | | | | | | 3/6 | 2 | | | | | | | | BGT | short_label | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | 3/6 | 2 | | | | | | | | DBNZNE | short_label | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | 3/6 | 2 | | | | | | _ | | DBNZE | short_label | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | | | | | | | | | 3/6 | 2 | | | | | | | | DBNZ | short_label | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | | | | | | | | | 3/6 | 2 | | | | | | — | | BCWZ | short_label | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | | | | | | | | | 3/6 | 2 | | | | | <del></del> | | | BRK | 3 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | | | | | | | | | 18/24 | 1 | | | | | | — | | | lmm8 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | | | | | | _ | | | 18/24 | 2 | | | | | | _ | | BRKV | lmm8 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | | | | | _ | | | | 20/26 | | | | | | | | | RETI | | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | | | - | | - | | 13/19 | 1 | R | R | R | R | R | R | | CHKIND | reg16, mem32 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | mo | d | | reg | | | me | m | 24-26/<br>30-32 | 2-4 | | | | | <u></u> | <del></del> | | CPU Cont | rol Instructio | ns | | | | | | | | | | | | | | | | | | | | | | | _ | | HALT | | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | | | | | _ | | | | 2 | 1 | | | | | | - | | BUSLOCK | | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | | | - | | | | | 2 | 1 | | | | | | — | | FP01 | fp_op | 1 | 1 | 0 | 1 | 1 | x | x | х | 1 | 1 | Υ | Υ | Y | z | Z | . z | * | 2 | | | | | | _ | | | fp_op, mem | 1 | 1 | 0 | 1 | 1 | х | Х | Х | mo | ď | Υ | Υ | Y | | me | m | * | 2-4 | | | | | | - | | FP02 | fp_op | 0 | 1 | 1 | 0 | 0 | 1 | 1 | X | 1 | 1 | Υ | Y | Υ | z | 2 | . z | * | 2 | | | | | | - | | | fp_op, mem | 0 | 1 | 1 | 0 | 0 | 1 | 1 | X | mo | d | Υ | Υ | Υ | | me | m | * | 2-4 | | | | | | - | | POLL | | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | | | | | | | | | 2 + 5n | 1 | | | | | | | | | | | | | | | | | | | | n | = n | umi | ber | of t | imes | POLL pin is | - | | | | | | | | NOP | | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | | | | | | | | 3 | 1 | | | | | | - | | DI | <del></del> | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | | | | | | | | | 2 | 1 | | | | | | | | EI | | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | | | | _ | | | | | 2 | 1 | | | | | | | 30E **D 📟** 6427525 0026931 T 🖿 # μPD70236 (V53) NEC | | | | | | | | | | Ope | ode | | | | | | | | | | | | Flag | \$ | | _ | |--------------------------------|------------------------------|-----|-------|-----|-----|-----|----|---|-----|-----|---|---|---|---|---|---|---|--------|-------|----|----|------|----|---|---| | Mnemonic | Operand | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Clocks | Bytes | AC | CY | V | P | s | Z | | CPU Conti | ol Instruction | ns | (co | nt) | | | | | | | | | | | | | | | | | | | | | | | DS0:, DS1:, F<br>(segment over | PS:, SS:<br>erride prefixes) | 0 | 0 | 1 | 8 | g | 1 | 1 | 0 | | | | - | | | | • | 2 | 1 . | | | | • | | | | Address E. | xpansion Co | ntr | ol li | ıst | ruc | lor | 18 | | | | | | | | | | | | | | | | | | | | BRKXA | lmm8 | 0 | 0 | 0 | ō | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 12 | 3 | | | | - | | _ | | | | | | | imm | 8. | | , | ι | | | | | | | | | | | | | | | | | | RETXA | imm8 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 12 | 3 | | - | | | | | | | | | | | lmm | 8 | | | | | | | | | | | | | | | | | | | |