

**DESCRIPTION**

The M5L8155P is a 2K-bit RAM (256-word by 8-bit) fabricated by the N-channel silicon-gate ED-MOS technology. This LSI has 3 I/O ports and a 14-bit counter/timer which make it a good extension of the functions of an 8-bit microcomputer. It is packaged in a 40-pin plastic DIL package and operates with a single 5V power supply.

**FEATURES**

- Single 5V supply voltage
- TTL compatible
- Static RAM: 256-word by 8-bit
- Programmable 8-bit I/O port: 2
- Programmable 6-bit I/O port: 1
- Programmable counter/timer: 14-bit
- Multiplexed address/data bus

**APPLICATION**

Extension of I/O ports and timer function for MELPS 85 and MELPS 8-48 devices

**FUNCTION**

The M5L8155P is composed of RAM, I/O ports and counter/timer. The RAM is a 2K-bit static RAM organized as 256 words by 8 bits. The I/O ports consist of 2 programmable 8-bit ports and 1 programmable 6-bit port. The terminals of the 6-bit port can be programmed as control terminals for the 8-bit ports, so that the 8-bit ports can be operated in a hand-shake mode. The counter/timer is composed of 14-bit down counter (events or time) and it can generate square wave pulses that can be used for counting and timing.

**PIN CONFIGURATION (TOP VIEW)**

Outline 40P4

**BLOCK DIAGRAM**

**OPERATION****Data Bus Buffer**

This 3-state bidirectional 8-bit buffer is used to transfer the data while input or output instructions are being executed by the CPU. Command and address information is also transferred through the data bus buffer.

**Read/Write Control Logic**

The read/write control logic controls the transfer of data and commands by interpreting the signals (CE, RD, WR, IO/M, ALE and RESET) from CPU.

**Bidirectional Address/Data Bus (AD<sub>0</sub>~AD<sub>7</sub>)**

The bidirectional address/data bus is a 3-state 8-bit bus. The 8-bit address is latched in the internal latch by the falling edge of ALE. Then if IO/M input signal is at high-level, the address of I/O port, counter/timer, or command register is selected. If it is at low-level, address of RAM is selected. The 8-bit data is transferred by read input (RD) or write input (WR).

**Chip Enable Input (CE)**

When CE is at low-level, the address information on address/data bus is stored in the M5L8155P.

**Read Input (RD)**

When RD is at low-level, the data bus buffer is active. If IO/M input signal is at low-level, the contents of RAM are read through the address/data bus. If IO/M input is at high-level, the contents of selected I/O port or counter/timer are read through the address/data bus.

**Write Input (WR)**

When WR is at low-level, the data on the address/data bus are written into RAM if IO/M is at low-level, or they are written into I/O port, counter/timer or command register if IO/M is at high-level.

**Address Latch Enable Input (ALE)**

An address on the address/data bus is latched in the M5L8155P on the falling edge of ALE along with the levels of CE and IO/M.

**IO/Memory Input (IO/M)**

When IO/M is at low-level, the RAM is selected, while at high-level the I/O port, counter/timer or command register are selected.

**I/O Port A (PA<sub>0</sub>~PA<sub>7</sub>)**

Port A is an 8-bit general-purpose I/O port. Input/output setting is controlled by the system software.

**I/O Port B (PB<sub>0</sub>~PB<sub>7</sub>)**

Port B is an 8-bit general-purpose I/O port. Input/output setting is controlled by the system software.

**I/O Port C (PC<sub>0</sub>~PC<sub>5</sub>)**

Port C is a 6-bit I/O port that can also be used to output control signals of port A (PA) or port B (PB). The functions of port C are controlled by the system software. When port C is used to output control signals of ports A or B, the assignment of the signals to the pins is as shown in Table 1.

**Table 1** Pin assignment of control signals of port C

| Pin             | Function |                      |
|-----------------|----------|----------------------|
| PC <sub>5</sub> | B STB    | (port B strobe)      |
| PC <sub>4</sub> | B BF     | (port B buffer full) |
| PC <sub>3</sub> | B INTR   | (port B interrupt)   |
| PC <sub>2</sub> | A STB    | (port A strobe)      |
| PC <sub>1</sub> | A BF     | (port A buffer full) |
| PC <sub>0</sub> | A INTR   | (port A interrupt)   |

**Timer Input (TIMER IN)**

The signal on this input terminal is used by the counter/timer for counting events or time. (3MHz max.)

**Timer Output (TIMER OUT)**

A square wave signal or pulse from the counter/timer is output through this pin when in the operation mode.

**Command Register (8 bits)**

The command register is an 8-bit latched register. The low-order 4 bits (bits 0~3) are used for controlling and determination of mode of the ports. Bits 4 and 5 are used as interrupt enable flags for ports A and B when port C is used as a control port. Bits 6 and 7 are used for controlling the counter/timer. The contents of the command register are rewritten by output instructions (I/O address XXXXX000). Details of the functions of the individual bits of the command register are shown in Table 2.

**Table 2** Bit functions of the command register

| Bit | Symbol          | Function                        |                                                                                                                                                                                                                                                            |
|-----|-----------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | PA              | PORt A I/O SET                  | 1: Output port A<br>0: Input port A                                                                                                                                                                                                                        |
| 1   | PB              | PORt B I/O SET                  | 1: Output port B<br>0: Input port B                                                                                                                                                                                                                        |
| 2   | PC <sub>1</sub> | PORt C SET                      | 00: ALT1<br>11: ALT2<br>01: ALT3<br>10: ALT4                                                                                                                                                                                                               |
| 3   | PC <sub>2</sub> |                                 |                                                                                                                                                                                                                                                            |
| 4   | IEA             | PORt A INTERRUPT<br>ENABLE FLAG | 1: Enable interrupt<br>0: Disable interrupt                                                                                                                                                                                                                |
| 5   | IEB             | PORt B INTERRUPT<br>ENABLE FLAG | 1: Enable interrupt<br>0: Disable interrupt                                                                                                                                                                                                                |
| 6   | TM1             | COUNTER/TIMER CONTROL           | 00: No influence on counter/timer operation<br>01: Counter/timer operation discontinued (if not already stopped)<br>10: Counter/timer operation discontinued after the current counter/timer operation is completed<br>11: Counter/timer operation started |
| 7   | TM2             |                                 |                                                                                                                                                                                                                                                            |

MITSUBISHI(MICMPTR/MIPRC)

2048-BIT STATIC RAM WITH I/O PORTS AND TIMER

T-46-23-12

**Status Register (7-bit)**

The status register is a 7-bit latched register. The low-order 6 bits (bits 0~5) are used as status flags for the I/O ports. Bit 6 is used as a status flag for the counter/timer. The con-

tents of the status register are transferred into the CPU by reading (INPUT instruction, I/O address XXXXX000). Details of the functions of the individual bits of the status register are shown in Table 3.

**Table 3 Bit functions of the status register**

| Bit | Symbol | Function                                                                                                                                          |
|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | INTR A | PORT A INTERRUPT REQUEST                                                                                                                          |
| 1   | A BF   | PORT A BUFFER FULL FLAG                                                                                                                           |
| 2   | INTE A | PORT A INTERRUPT ENABLE                                                                                                                           |
| 3   | INTR B | PORT B INTERRUPT REQUEST                                                                                                                          |
| 4   | B BF   | PORT B BUFFER FULL FLAG                                                                                                                           |
| 5   | INTE B | PORT B INTERRUPT ENABLE                                                                                                                           |
| 6   | TIMER  | COUNTER/TIMER INTERRUPT<br>(This flag is set to 1 when the final limit of the counter/timer is reached and is reset to 0 when the status is read) |
| 7   | —      | This bit is not used                                                                                                                              |

**I/O PORTS****Command/status registers (8-bit/7-bit)**

These registers are assigned address XXXXX000. When an OUTPUT command is executed, the contents of the command register are rewritten. When an INPUT command is executed, the contents of the status register are read.

**Port A Register (8-bit)**

Port A Register is assigned address XXXXX001. This register can be programmed as an input or output by setting the appropriate bits of the command register as shown in Table 2.

Port A can be operated in basic or strobe mode and is assigned I/O terminal PA<sub>0</sub>~PA<sub>7</sub>.

**Port B Register (8-bit)**

Port B register is assigned address XXXXX010. As with Port

A register, this register can be programmed as an input or output by setting the appropriate bits of the command register as shown in Table 2. Port B can be operated in basic or strobe mode and is assigned I/O terminals PB<sub>0</sub>~PB<sub>7</sub>.

**Port C Register (6-bit)**

Port C register is assigned address XXXXX011. This port is used not only for input or output but also for controlling input/output operations of ports A and B by selectively setting bits 2 and 3 of the command register as shown in Table 2. Details of the functions of the various setting of bits 2 and 3 are shown in Table 4. Port C is assigned I/O terminals PC<sub>0</sub>~PC<sub>5</sub>. When used as port control signals, the 3 low-order bits are assigned for port A while the 3 high-order bits are assigned for port B.

**Table 4 Functions of port C**

| State Terminal  | ALT 1 | ALT 2  | ALT 3                     | ALT 4                     |
|-----------------|-------|--------|---------------------------|---------------------------|
| PC <sub>5</sub> | Input | Output | Output                    | B STB (port B strobe)     |
| PC <sub>4</sub> | Input | Output | Output                    | B BF (port B buffer full) |
| PC <sub>3</sub> | Input | Output | Output                    | B INTR (port B interrupt) |
| PC <sub>2</sub> | Input | Output | A STB (port A strobe)     | A STB (port A strobe)     |
| PC <sub>1</sub> | Input | Output | A BF (port A buffer full) | A BF (port A buffer full) |
| PC <sub>0</sub> | Input | Output | A INTR (port A interrupt) | A INTR (port A interrupt) |

T-46-23-12

## 2048-BIT STATIC RAM WITH I/O PORTS AND TIMER

## CONFIGURATION OF PORTS

A block diagram of 1 bit of ports A and B is shown in Fig. 1. While port A or B is programmed as an output port, if the port is addressed by an input instruction, the contents of the selected port can be read. When a port is put in input mode, the output latch is cleared and writing into the output latch is

disabled. Therefore when a port is changed to output mode from input mode, low-level signals are output through the port. When a reset signal is applied, all 3 ports (PA, PB, and PC) will be input ports and their output latches are cleared. Port C has the same configuration as ports A and B in modes ALT1 and ALT2.



Fig. 1 Configuration for 1 bit of port A or B

Table 5 Basic functions of I/O ports

| Address  | RD | WR | Function                             |
|----------|----|----|--------------------------------------|
| XXXXX000 | L  | H  | AD bus $\leftarrow$ Status register  |
|          | H  | L  | Command register $\leftarrow$ AD bus |
| XXXXX001 | L  | H  | AD bus $\leftarrow$ Port A           |
|          | H  | L  | Port A $\leftarrow$ AD bus           |
| XXXXX010 | L  | H  | AD bus $\leftarrow$ Port B           |
|          | H  | L  | Port B $\leftarrow$ AD bus           |
| XXXXX011 | L  | H  | AD bus $\leftarrow$ Port C           |
|          | H  | L  | Port C $\leftarrow$ AD bus           |

Table 6 Port control signal levels at ALT3 and ALT4

| Control Signal | Output mode | Input mode |
|----------------|-------------|------------|
| STB            | Input       | Input      |
| BF             | "L"         | "L"        |
| INTR           | "H"         | "L"        |

The basic functions of the I/O ports are shown in Table 5. The control signal levels to ports A and B, when port C is programmed as a control port, are shown in Table 6.

## COUNTER/TIMER

The counter/timer is composed of a 14-bit counting register and 2 mode flags. The register has two sections: I/O address XXXXX100 is assigned to the low-order 8 bits and I/O address XXXXX101 is assigned to the high-order 6 bits and timer mode flag 2 bits. The low-order bits 0~13 are used for counting or timing. The counter is initialized by the program and then counted down to 0. The initial value can be ranged from  $2_{16}$  to  $3FFF_{16}$ . Bits 14 and 15 are used as mode flags.

The mode flags select 1 of 4 modes with functions as follows:

- Mode 0: Outputs high-level signal during the former half of the counter operation
- Outputs low-level signal during the latter half of the counter operation

T-46-23-12

MITSUBISHI(MICMPTR/MIPRC)

## 2048-BIT STATIC RAM WITH I/O PORTS AND TIMER

Table 7 Format of counter/timer

| Address  | Bit Number     |                |                 |                 |                 |                 |                |                | Function                                                                                                                       |
|----------|----------------|----------------|-----------------|-----------------|-----------------|-----------------|----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------|
|          | 7              | 6              | 5               | 4               | 3               | 2               | 1              | 0              |                                                                                                                                |
| XXXXX100 | T <sub>7</sub> | T <sub>6</sub> | T <sub>5</sub>  | T <sub>4</sub>  | T <sub>3</sub>  | T <sub>2</sub>  | T <sub>1</sub> | T <sub>0</sub> | The low-order 8 bits of the counter register                                                                                   |
| XXXXX101 | M <sub>2</sub> | M <sub>1</sub> | T <sub>13</sub> | T <sub>12</sub> | T <sub>11</sub> | T <sub>10</sub> | T <sub>9</sub> | T <sub>8</sub> | M <sub>2</sub> ,M <sub>1</sub> : Timer mode<br>T <sub>13</sub> ~T <sub>8</sub> : The high-order 6 bits of the counter register |

Table 8 Timer mode

|   |   | Timer operation                                                                                                                                                |
|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | 0 | Outputs high-level signal during the former half of the counter operation<br>Outputs low-level signal during the latter half of the counter operation (mode 0) |
| 0 | 1 | Outputs square wave signals in mode 0 (mode 1)                                                                                                                 |
| 1 | 0 | Outputs a low-level pulse during the final count down (mode 2)                                                                                                 |
| 1 | 1 | Outputs a low-level pulse during each final count down (mode 3)                                                                                                |

Mode 1: Outputs square wave signals as in mode 0  
 Mode 2: Outputs a low-level pulse during the final count down  
 Mode 3: Outputs a low-level pulse during each final count down

Starting and stopping the counter/timer is controlled by bits 6 and 7 of the command register (see Table 2 for details). The format and timer modes of the counter/timer register are shown in Table 7 and Table 8.

The contents of counter/timer is not affected by a reset, but counting is discontinued. To resume counting, a start command must be written into the command register as shown in Table 2. While operating  $2n+1$  count down in modes 0 and 1, a high-level signal is output during the former  $n+1$  counting and a low-level signal is output during the later  $n$  counting.

## RESET

The M5L8155P is reset by 600ns (min) pulse input on RESET pin.

By reset, all 3 ports are set to input mode. And counter/timer stops, but contents of counter/timer is not reset. Therefore it is necessary to input start command again.

## ABSOLUTE MAXIMUM RATINGS

| Symbol           | Parameter                            | Conditions                      |  |  | Ratings | Unit |
|------------------|--------------------------------------|---------------------------------|--|--|---------|------|
|                  |                                      | With respect to V <sub>SS</sub> |  |  |         |      |
| V <sub>CC</sub>  | Supply voltage                       |                                 |  |  | -0.5~7  | V    |
| V <sub>I</sub>   | Input voltage                        |                                 |  |  | -0.5~7  | V    |
| V <sub>O</sub>   | Output voltage                       |                                 |  |  | -0.5~7  | V    |
| P <sub>D</sub>   | Maximum power dissipation            | T <sub>a</sub> =25°C            |  |  | 1.5     | W    |
| T <sub>opr</sub> | Operating free-air temperature range |                                 |  |  | -20~75  | °C   |
| T <sub>stg</sub> | Storage temperature range            |                                 |  |  | -65~150 | °C   |

RECOMMENDED OPERATING CONDITIONS (T<sub>a</sub>=-20~75°C, unless otherwise noted)

| Symbol          | Parameter                  | Limits |     |      | Unit |
|-----------------|----------------------------|--------|-----|------|------|
|                 |                            | Min    | Nom | Max  |      |
| V <sub>CC</sub> | Supply voltage             | 4.75   | 5   | 5.25 | V    |
| V <sub>SS</sub> | Power-supply voltage (GND) |        | 0   |      | V    |

ELECTRICAL CHARACTERISTICS (T<sub>a</sub>=-20~75°C, V<sub>CC</sub>=5V±5%, V<sub>SS</sub>=0V, unless otherwise noted)

| Symbol             | Parameter                           | Test conditions                                             | Limits |     |                      | Unit |
|--------------------|-------------------------------------|-------------------------------------------------------------|--------|-----|----------------------|------|
|                    |                                     |                                                             | Min    | Typ | Max                  |      |
| V <sub>IH</sub>    | High-level input voltage            |                                                             | 2.0    |     | V <sub>CC</sub> +0.5 | V    |
| V <sub>IL</sub>    | Low-level input voltage             |                                                             | -0.5   |     | 0.8                  | V    |
| V <sub>OH</sub>    | High-level output voltage           | I <sub>OH</sub> =-400μA                                     | 2.4    |     |                      | V    |
| V <sub>OL</sub>    | Low-level output voltage            | I <sub>OL</sub> =2mA                                        |        |     | 0.45                 | V    |
| I <sub>I</sub>     | Input leak current                  | V <sub>I</sub> =0V, V <sub>CC</sub>                         | -10    |     | 10                   | μA   |
| I <sub>I(CE)</sub> | Input leak current, CE pin          | V <sub>I</sub> =0V, V <sub>CC</sub>                         | -100   |     | 100                  | μA   |
| I <sub>OZ</sub>    | Output floating leak current        | V <sub>O</sub> =0V~V <sub>CC</sub>                          | -10    |     | 10                   | μA   |
| C <sub>I</sub>     | Input terminal capacitance          | V <sub>IL</sub> =0V, f=1MHz, 25mVrms, T <sub>a</sub> =25°C  |        |     | 10                   | pF   |
| C <sub>I/O</sub>   | Input/output terminal capacitance   | V <sub>I/O</sub> =0V, f=1MHz, 25mVrms, T <sub>a</sub> =25°C |        |     | 20                   | pF   |
| I <sub>CC</sub>    | Supply current from V <sub>CC</sub> |                                                             |        |     | 180                  | mA   |

Note 5 : Current flowing into an IC is positive, out is negative.

## TIMING REQUIREMENTS (Ta=-20~75°C, Vcc=5V±5%, Vss=0V, unless otherwise noted)

| Symbol                 | Parameter                          | Test conditions | Limits |     |     | Unit |
|------------------------|------------------------------------|-----------------|--------|-----|-----|------|
|                        |                                    |                 | Min    | Typ | Max |      |
| t <sub>su(A-L)</sub>   | Address setup time before latch    |                 | 50     |     |     | ns   |
| t <sub>h(L-A)</sub>    | Address hold time after latch      |                 | 80     |     |     | ns   |
| t <sub>d(L-RW)</sub>   | Delay time, latch to read/write    |                 | 100    |     |     | ns   |
| t <sub>w(L)</sub>      | Latch pulse width                  |                 | 100    |     |     | ns   |
| t <sub>d(RW-L)</sub>   | Delay time, read/write to latch    |                 | 20     |     |     | ns   |
| t <sub>w(RW)</sub>     | Read/write pulse width             |                 | 250    |     |     | ns   |
| t <sub>su(DQ-W)</sub>  | Data setup time before write       |                 | 150    |     |     | ns   |
| t <sub>h(W-DQ)</sub>   | Data hold time after write         |                 | 0      |     |     | ns   |
| t <sub>c(RW)</sub>     | Read/write cycle time              |                 | 300    |     |     | ns   |
| t <sub>su(P-R)</sub>   | Port setup time before read        |                 | 70     |     |     | ns   |
| t <sub>h(R-P)</sub>    | Port hold time after read          |                 | 50     |     |     | ns   |
| t <sub>w(STB)</sub>    | Strobe pulse width                 |                 | 200    |     |     | ns   |
| t <sub>su(P-STB)</sub> | Port setup time before strobe      |                 | 50     |     |     | ns   |
| t <sub>h(STB-P)</sub>  | Port hold time after strobe        |                 | 120    |     |     | ns   |
| t <sub>w(#H)</sub>     | Timer input high-level pulse width |                 | 120    |     |     | ns   |
| t <sub>w(#L)</sub>     | Timer input low-level pulse width  |                 | 80     |     |     | ns   |
| t <sub>c(#)</sub>      | Timer input cycle time             |                 | 320    | DC  |     | ns   |
| t <sub>r(#)</sub>      | Timer input rise time              |                 |        |     | 30  | ns   |
| t <sub>f(#)</sub>      | Timer input fall time              |                 |        |     | 30  | ns   |

## SWITCHING CHARACTERISTICS (Ta=-20~75°C, Vcc=5V±5%, Vss=0V, unless otherwise noted.)

| Symbol                     | Parameter                                            | Test conditions | Limits |     |     | Unit |
|----------------------------|------------------------------------------------------|-----------------|--------|-----|-----|------|
|                            |                                                      |                 | Min    | Typ | Max |      |
| t <sub>pzv(r-dq)</sub>     | Propagation time from read to data output            |                 |        |     | 170 | ns   |
| t <sub>pzv(a-dq)</sub>     | Propagation time from address to data output         |                 |        |     | 400 | ns   |
| t <sub>pzv(r-dq)</sub>     | Propagation time from read to data floating (Note 6) |                 | 0      |     | 100 | ns   |
| t <sub>phl(w-p)</sub>      | Propagation time from write to data output           |                 |        |     | 400 | ns   |
| t <sub>plh(w-p)</sub>      |                                                      |                 |        |     | 400 | ns   |
| t <sub>plh(stb-bf)</sub>   | Propagation time from strobe to BF flag              |                 |        |     | 400 | ns   |
| t <sub>phl(r-bf)</sub>     | Propagation time from read to BF flag                |                 |        |     | 400 | ns   |
| t <sub>plh(stb-intr)</sub> | Propagation time from strobe to interrupt            |                 |        |     | 400 | ns   |
| t <sub>phl(r-intr)</sub>   | Propagation time from read to interrupt              |                 |        |     | 400 | ns   |
| t <sub>phl(stb-bf)</sub>   | Propagation time from strobe to BF flag              |                 |        |     | 400 | ns   |
| t <sub>plh(w-bf)</sub>     | Propagation time from write to BF flag               |                 |        |     | 400 | ns   |
| t <sub>phl(w-intr)</sub>   | Propagation time from write to interrupt             |                 |        |     | 400 | ns   |
| t <sub>phl(#-out)</sub>    | Propagation time from timer input to timer output    |                 |        |     | 400 | ns   |

Note 6 : Test conditions are not applied.

7 : A.C Testing waveform

Input pulse level 0.45~2.4V  
 Input pulse rise time 20ns  
 Input pulse fall time 20ns  
 Reference level Input output V<sub>ih</sub>=2V, V<sub>il</sub>=0.8V  
 V<sub>oh</sub>=2V, V<sub>ol</sub>=0.8V



T-46-23-12

MITSUBISHI(MICMPTR/MIPRC)

2048-BIT STATIC RAM WITH I/O PORTS AND TIMER

## TIMING DIAGRAM

Basic Output



Basic Input



T-46-23-12

MITSUBISHI(MICMPTR/MIPRC)

2048-BIT STATIC RAM WITH I/O PORTS AND TIMER

## Strobed Output



## Strobed Input



## Timer



Note 8 : The wave form is shown for the case of counting down from 5 to 1.

9 : As long as the M1 mode flag of the timer register is at high-level, pulses are continuously output.