# **OKI semiconductor** MSM82C54-2RS/GS/JS

CMOS PROGRAMMABLE INTERVAL TIMER

### **GENERAL DESCRIPTION**

The MSM82C54-2RS/GS/JS is a programmable universal timer designed for use in microcomputer systems. Based on silicon gate CMOS technology, it requires a standby current of only 10  $\mu$ A (max.) when the chip is in the non-selected state. And during timer operation, the power consumption is still very low with only 10mA (max.) of current required.

It consists of three independent counters, and can count up to a maximum of 10 MHz. The timer features six different counter modes, and binary count/BCD count functions. Count values can be set in byte or word units, and all functions are freely programmable.

### **FEATURES**

- Maximum operating frequency of 10 MHz (V<sub>CC</sub>=5V)
- High speed and low power consumption achieved by
- silicon gate CMOS technology. • Completely static operation
- Completely static operation
- Three independent 16-bit down-counters
- Status Read Back Commound

• Six counter modes available for each counter

Preliminary

- Binary and decimal counting possible
- 24-pin DIP (MSM82C54-2RS)
- 32-pin flat package (MSM82C54-2GS)
- 28-pin PLCC package (MSM82C54-2JS)



## FUNCTIONAL BLOCK DIAGRAM

### **PIN CONFIGURATION**

MSM82C54-2RS (TOP VIEW) 24 LEAD PLASTIC DIP



MSM82C54-2GS (TOP VIEW) 32 LEAD PLASTIC FLAT PACKAGE

MSM82C54-2JS (TOP VIEW)



### ABSOLUTE MAXIMUM RATINGS

| Parameter           | Symbol           | Conditions     |                               | Limits                     |              | Unit |
|---------------------|------------------|----------------|-------------------------------|----------------------------|--------------|------|
|                     |                  |                | MSM82C54-2RS                  | MSM82C54-2GS               | MSM82C54-2JS |      |
| Supply voltage      | v <sub>cc</sub>  |                |                               | -0.5 to +7                 |              | v    |
| Input Voltage       | VIN              | Respect to GND | -0.5 to V <sub>cc</sub> + 0.5 |                            |              | v    |
| Output Voltage      | Vout             | 0000           | _                             | 0.5 to V <sub>cc</sub> + 0 | .5           | v    |
| Storage Temperature | T <sub>stg</sub> |                | - 55 to + 150                 |                            |              | °C   |
| Power Dissipation   | PD               | Ta = 25°C      | 0.9                           | 0.7                        | 0.9          | w    |

### **RECOMMENDED OPERATING CONDITIONS**

| Parameter             | Symbol | Min  | Тур | Max                   | Unit |
|-----------------------|--------|------|-----|-----------------------|------|
| Supply Voltage        | Vcc    | 4,5  | 5   | 5,5                   | v    |
| Operating Temperature | TOP    | -40  | +25 | +85                   | °C   |
| "L" Input Voltage     | VIL    | -0.5 |     | +0.8                  | v    |
| "H" Input Voltage     | VIH    | 2.2  |     | V <sub>CC</sub> + 0.5 | v    |

## DC CHARACTERISTICS

| Parameter                | Symbol | Cond                                                  | itions                        | Min  | Түр | Max  | Unit |
|--------------------------|--------|-------------------------------------------------------|-------------------------------|------|-----|------|------|
| "L" Output Voltage       | VOL    | IOL = 2.5mA                                           |                               |      |     | 0.40 | v    |
| "H" Output Voltage       | ∙∨он   | I <sub>OH</sub> = -2.5mA<br>I <sub>OH</sub> =-100µA , |                               | _3.0 |     |      | v    |
| Input Leak Current       | ILI.   | 0 ≦ VIN ≦ VCC                                         | V <sub>CC</sub> =4.5V to 5.5V | -10  |     | 10   | μA   |
| Output Leak Current      | 1LO    | O≦VOUT≦VCC                                            | Ta=-40°C to +85°C             | -10  |     | 10   | μA   |
| Standby Supply Current   | Iccs   |                                                       |                               |      |     | 10   | μΑ   |
| Operating Supply Current | 'cc    | <sup>t</sup> CLK <sup>=</sup> 100ns CL=0pF            |                               |      |     | 10   | mA   |

### AC CHARACTERISTICS

(V<sub>CC</sub> = 4.5V ~ 5.5V, Ta = -40 ~ +85°C)

| Deserves                                                                         | <b>A</b> | 82C | 54-2 | 1.1-10 |             |          |  |
|----------------------------------------------------------------------------------|----------|-----|------|--------|-------------|----------|--|
| Parameter                                                                        | Symbol   | Min | Max  | Unit   | Conditions  |          |  |
| Address set-up time to falling edge of RD                                        | tAR      | 30  |      | nS     |             |          |  |
| Chip select input set-up time to falling edge of RD                              | tSR      | 0   |      | nS     |             | Ì        |  |
| Address hold time from rising edge of RD                                         | tRA      | 0   |      | nS     | 9           | -        |  |
| RD pulse width                                                                   | tRR      | 95  |      | nS`    | imir        |          |  |
| Data access time from falling edge of RD                                         | tRD      |     | 94   | nS     | Reed timing |          |  |
| Data access time, after address determination                                    | tAD      |     | 185  | nS     | Re          |          |  |
| Delay time from rising edge of RD to data floating state                         | tDF      | 5   | 65   | nS     |             |          |  |
| RD recovery time                                                                 | tRV      | 165 |      | nS     | - 5         |          |  |
| Address set-up time to falling edge of WR                                        | tAW      | 0   | 0.   | nŞ     |             |          |  |
| Chip select input set-up time to falling edge of WR                              | tSW      | 0   |      | nS     |             |          |  |
| Address hold time from rising edge of WR                                         | tWA      | 0   |      | nS     | timing      |          |  |
| WR pulse width                                                                   | tWW      | 95  |      | nS     | tin         |          |  |
| Data determination set-up time to rising edge of WR                              | tDW      | 85  |      | nS -   | Write       |          |  |
| Data hold time after rising edge of WR                                           | tWD      | 0   |      | nS     | >           |          |  |
| WR recovery time                                                                 | tRV      | 165 |      | nS     |             | CL=150pF |  |
| CLK cycle time                                                                   | tCLK     | 100 | D.C. | nS     |             |          |  |
| CLK "H" level width                                                              | tPWH     | 30  |      | nS     |             |          |  |
| CLK "L" level width                                                              | tPWL     | 50  |      | nS     |             |          |  |
| CLK rise time                                                                    | tR       | -   | 25   | nS     |             |          |  |
| CLK fall time                                                                    | tF       |     | 25   | nS     |             |          |  |
| GATE "H" level width                                                             | tGW      | 50  |      | nS     |             |          |  |
| GATE "L" level width                                                             | tGL      | 50  |      | nS     | ē           |          |  |
| GATE input set-up time before rising edge of CLK                                 | tGS      | 40  |      | nS     | gate timing |          |  |
| GATE input hold time before rising edge of CLK                                   | tGH      | 50  |      | nS     | ate t       |          |  |
| Output delay time after falling edge of CLK                                      | tOD      |     | 100  | nS     | к<br>б      |          |  |
| Output delay time after falling edge of GATE                                     | tODG     |     | 100  | nS     | Clock       |          |  |
| CLK rise delay time after rising edge of $\overline{WR}$ for count value loading | tWC      | 0   | 55.  | nS     |             |          |  |
| GATE sampling delay time after rising edge of WR for count value loading         | tWG      | -5  | 40   | nS     |             |          |  |
| Output delay time after falling edge of WR for mode set                          | tWO      | 3   | 240  | nS     |             |          |  |
| CLK fall set-up time to falling edge of for counter latch command                | tCL      | -40 | 40   | nS     |             |          |  |

Note: Timing measured at  $V_L = 0.8V$  and  $V_H = 2.2V$  for both inputs and outputs.

### TIME CHART

Write Timing



#### **Read Timing**



#### Clock & Gate Timing



| Pin Symbol | Name                      | Input/output | Function                                                                                                                                                                                                                                                              |
|------------|---------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D7 ~ D0    | Bidirectional<br>data bus | Input/output | Three-state 8-bit bidirectional data bus used when writing<br>control words and count values, and reading count values<br>upon reception of WR and RD signals from CPU.                                                                                               |
| CS         | Chip select<br>input      | Input        | Data transfer with the CPU is enabled when this pin is at low level. When at high level, the data bus $(D_0 \text{ thru } D_7)$ is switched to high impedance state where neither writing nor reading can be executed. Internal registers, however, remain unchanged. |
| RD         | Read input                | Input        | Data can be transferred from MSM82C54-2 to CPU when this pin is at low level.                                                                                                                                                                                         |
| WR         | Write input               | Input        | Data can be transferred from CPU to MSM82C54-2 when this pin is at low level.                                                                                                                                                                                         |
| A0, A1     | Address input             | Input        | One of the three internal counters or the control word regis-<br>ter is selected by A0/A1 combination. These two pins are<br>normally connected to the two lower order bits of the<br>address bus.                                                                    |
| CLK0~2     | Clock input               | Input        | Supply of three clock signals to the three counters incorporated in MSM82C54-2.                                                                                                                                                                                       |
| GATE0~2    | Gate input                | Input        | Control of starting, interruption, and restarting of counting<br>in the three respective counters in accordance to the set con-<br>trol word contents.                                                                                                                |
| OUT0~2     | Counter output            | Output       | Output of counter output waveform in accordance with the set mode and count value.                                                                                                                                                                                    |

### DESCRIPTION OF PIN FUNCTIONS

### SYSTEM INTERFACING



### DESCRIPTION OF BASIC OPERATIONS

Data transfers between the internal registers and the external data bus is outlined in the following table.

| <b>CS</b> | RD | WR | A1 | AO | Function                                              |
|-----------|----|----|----|----|-------------------------------------------------------|
| 0         | 1  | 0  | 0  | 0  | Data bus to counter #0 Writing                        |
| 0         | 1  | 0  | 0  | 1  | Data bus to counter # 1 Writing                       |
| 0         | 1  | 0  | 1  | 0  | Data bus to counter # 2 Writing                       |
| 0         | 1  | 0  | 1  | 1  | Data bus to control word register Writing             |
| 0         | 0  | 1  | 0  | 0  | Data bus from counter # 0 Reading                     |
| 0         | 0  | 1  | 0  | 1  | Data bus from counter # 1 Reading                     |
| 0         | 0  | 1  | 1  | 0  | Data bus from counter # 2 Reading                     |
| 0         | 0  | 1  | 1  | 1  |                                                       |
| 1         | ×  | ×  | ×  | ×  | <ul> <li>Data bus in high impedance status</li> </ul> |
| 0         | 1  | 1  | ×  | x  |                                                       |

x denotes "not specified".

### DESCRIPTION OF OPERATION

82C54-2 functions are selected by control words from the CPU. In the required program sequence, the control word setting is followed by the count value setting and execution of the desired timer operation.

#### **Control Word and Count Value Program**

Each counter operating mode is set by control word programming. The control word format is outlined below.

| D7 .                                                                       | DĢ  | D5        | D4  | D3   | D2 | D1 | D0  |   |
|----------------------------------------------------------------------------|-----|-----------|-----|------|----|----|-----|---|
| SC1                                                                        | SC0 | RL1       | RLO | M2   | M1 | MO | BCD | ] |
| Select                                                                     |     | Read/Load |     | Mode |    |    | BCD | J |
| $(\overline{CS} = 0, A0, A1 = 1, 1, \overline{RD} = 1, \overline{WR} = 0)$ |     |           |     |      |    |    |     |   |

• Select Counter (SCO, SC1): Selection of set counter

| SC1 | SC0 | Set Contents          |
|-----|-----|-----------------------|
| 0   | 0   | Counter # 0 selection |
| 0   | 1   | Counter # 1 selection |
| 1   | 0   | Counter # 2 selection |
| 1   | 1   | READ BACK COMMAND     |

 Read/Load (RL1, RL0): Count value Reading/ Loading format setting

| RL1 | RLO | Set Contents                                      |
|-----|-----|---------------------------------------------------|
| 0   | 0   | Counter Latch operation                           |
| 0   | 1   | Reading/Loading of Least Significant byte (LSB)   |
| 1   | 0   | Reading/Loading of Most Significant<br>byte (MSB) |
| ÷1  | 1   | Reading/Loading of LSB followed by<br>MSB         |

Mode (M2, M1, M0): Operation waveform mode setting

| M2 | M1 | мо | Set Contents                         |
|----|----|----|--------------------------------------|
| 0  | 0  | 0  | Mode 0 (Interrupt on Terminal Count) |
| 0  | 0  | 1  | Mode 1 (Programmable One-Shot)       |
| ×  | 1  | 0  | Mode 2 (Rate Generator)              |
| ×  | 1  | 1  | Mode 3 (Square Wave Generator)       |
| 1  | 0  | 0  | Mode 4 (Software Triggered Strobe)   |
| 1  | 0  | 1  | Mode 5 (Hardware Triggered Strobe)   |

x denotes "not specified".

BCD: Operation count mode setting

| BCD | Set Contents                                  |
|-----|-----------------------------------------------|
| 0   | Binary Count (16-bits Binary)                 |
| 1   | BCD Count (4-decades Binary Coded<br>Decimal) |

After setting Read/Load, Mode, and BCD in each counter as outlined above, next set the desired count value. (In some Modes, the count value is set first. In next clock, loading is performed, then counting starts.) This count value setting must conform with the Read/Load format set in advance. Note that the internal counters are reset to OOOOH during control word setting. The counter value (OOOOH) can't be read.

The program sequence of the 82C54-2 is flexible. Free sequence programming is possible as long as the two following rules are observed:

- (i) Write the control word before writing the initial count value in each counter.
- (ii) Write the initial count value according to the count value read/write format specified by "the control word.
- (Note) Unlike the 82C53-5, the 82C54-2 allows count value setting for another counter between LSB and MSB settings.

### ■ I/O MSM82C54-2RS/GS/JS ■

### • Example of control word and count value setting

- Counter # 0: Read/Load LSB only, Mode 3, Binary count, count value 3H
- Counter # 1: Read/Load MSB only, Mode 5, Binary count, count value AA00H
- Counter #2: Read/Load LSB and MSB, Mode 0, BCD count, count value 1234

| MVI A, 1EH<br>OUT n3 | Counter #0 control word setting               |
|----------------------|-----------------------------------------------|
| MVI A, 6AH<br>OUT n3 | Counter #1 control word setting               |
| MVI A, B1H<br>OUT n3 | Counter #2 control word setting               |
| MVI A, 03H<br>OUT n0 | Counter #0 count value setting                |
| MVI A, AAH<br>OUT n1 | Counter #1 count value setting                |
| MVI A, 34H "         |                                               |
| OUT n2               | Counter #2 count value setting                |
| -MVI A, 12H          | Counter #2 count value setting (LSB then MSB) |
| OUT n2               |                                               |

INTERNAL BLOCK DIAGRAM OF A COUNTER

#### Note: n0: Counter #0 address

- n1: Counter #1 address
- n2: Counter #2 address
- n3: Control word register address
- The minimum and maximum count values which can be counted in each mode are listed below.

| Mode | Min | Max | Remarks                                           |
|------|-----|-----|---------------------------------------------------|
| 0    | 1   | 0   | 0 executes 10000H count<br>(ditto in other modes) |
| 1    | 1   | 0   |                                                   |
| 2    | 2   | 0   | 1 cannot be counted                               |
| 3    | 2   | 0   | 1 cannot be counted                               |
| 4    | 1   | 0   |                                                   |
| 5    | 1   | 0   |                                                   |



#### **Mode definition**

#### Mode 0

- Use: Event counter
- Output operation: The output is set to "L" level by the control word setting, and kept at "L" level until the counter value becomes 0.
- Gate function: "H" level validates the count operation, and "L" level invalidates it. The gate does not affect the output.
- Count value load timing: after the control word and initial count value are written, the count value is loaded to the CE at the falling edge of the next clock pulse. The first clock pulse does not cause the count value to be decremented. In other words, if the initial count value is N, the output is not set to "H" level until the input of (N+1) the clock pulse after the initial count value writing.
- Count value writing during counting:

The count value is loaded in the CE at the falling edge of the next clock, and counting with the new count value continues. The operation for 2-byte count is as follows:

- The counting operation is suspended when the first byte is written. The output is immediately set to "L" level. (no clock pulse is required.)
- After the scond byte is written, the new count value is loaded to the CE at the falling edge of the next clock.

For the output to go to "H" level again, N+1 clock pulses are necessary after new count value N is written.

• Count value writing when the gate signal is "L" level:

The count value is also loaded to the CE at the falling edge of the next clock pulse in this case. When the gate signal is set to "H" level, the output is set to "H" level after the lapse of N clock pulses. Since the count value is already loaded in the CE, no clock pulse for loading in the CE is necessary.

#### Mode 1

- Use: Digital one-shot
- Output operation: The output is set to "H" level by the control word setting. It is set to "L" level at the falling edge of the clock succeeding the gate trigger, and kept at "L" level until the counter value becomes 0. Once the output is set to "H" level, it is kept at "H" level until the clock pulse succeeding the next trigger pulse.
- Count value load timing:

After the control word and initial count value are written, the count value is loaded to the CE at the falling edge of the clock pulse succeeding the gate trigger and set the output to "L" level. The one-shot pulse starts in this way. If the initial count value is N, the one-shot pulse interval equals N clock pulses. The one-shot pulse is not repetitive.

• Gate function: The gate signal setting to "L" level after the gate trigger does not affect the output. When it is set to "H" level again from "L" level, gate retriggering occurs, the CR count value is loaded again, and counting continues.  Count value writing during counting It does not affect the one-shot pulse being counted until retriggering occurs.

#### Mode 2

- Use: Rate generator, real-time interrupt clock.
- Output operation: The output is set to "H" level by control word setting. When the initial count value is decremented to 1, the output is set to "L" level during one clock pulse, and is then set to "H" level again. The initial count value is reloaded, and the above sequence repeats. In mode 2, the same sequence is repeated at intervals of N clock pulses if the initial count value is N for example.
- Gate function: "H" level validates counting, and "L" level invalidates it. If the gate signal is set to "L" level when the output pulse is "L" level, the output is immediately set to "H" level. At the falling edge of the clock pulse succeeding the trigger, the count value is reloaded and counting starts. The gate input can be used for counter synchronization in this way.
- Count value load timing:

After the control word and initial count value is written, the count value is loaded to the CE at the falling edge of the next clock pulse. The output is set to "L" level upon lapse of N clock pulses after writing the initial count value N. Counter synchronization by software is possible in this way.

Count value writing during counting:

Count value writing does not affect the current counting operation sequence. If new count value writing completes and the gate trigger arrives before the end of current counting operation, the count value is loaded to the CE at the falling edge of the next clock pulse and counting continues from the new count value. If no gate trigger arrives, the new count value is loaded to the CE at the end of the current counting operation cycle. In mode 2, count value of 1 is prohibited.

#### Mode 3

- Use: Baud rate generator, square wave generator
- Output operation: Same as mode 2 except that the output duty is different.

The output is set to "H" level by control word setting. When the count becomes half the initial count value, the output is set to "L" level and kept at "L" level during the remainder of the count.

Mode 3 repeats the above sequence periodically. If the initial count value is N, the output becomes a square wave with a period of N.

• Gate operation: "H" level validates counting, and "L" level invalidates it. If the gate signal is set to "L" level when the output is "L" level, the output is immediately set to "H" level.

The initial count value is reloaded at the falling edge of the clock pulse succeeding the next gate trigger. The gate can be used for counter synchronization in this way.

#### I/O MSM82C54-2RS/GS/JS

Count value load timing:

After the control word and initial count value are written, the count value is loaded to the CE at the falling edge of the next clock pulse. Counter synchronization by software is possible in this way.

Count value writing during counting:

The count value writing does not affect the current counting operation. When the gate trigger input arrives before the end of a half cycle of the square wave after writing the new count value, the new count value is loaded in the CE at the falling edge of the next clock pulse, and counting continues using the new count value. If there is no gate trigger, the new count value is loaded at the end of the half cycle and counting continues.

• Even number counting operation:

The output is initially set to "H" level. The initial count value is loaded to the CE at the falling edge of the next clock pulse, and is decremented by 2 by consecutive clock pulses. When the counter value becomes 2, the output is set to "L" level, the initial value is reloaded and then the above operation is repeated.

Odd number counting operation:

The output is initially set to "H" level. At the falling edge of the next clock pulse, the initial count value minus one is loaded in the CE, and then the value is decremented by 2 by consecutive clock pulses. When the counter value becomes 0, the output is set to "L" level, and then the initial count value minus 1 is reloaded to the CE. The value is then decremented by 2 by consecutive clock pulses. When the counter value becomes 2, the output is again set to "H" level and the initial count value minus 1 is again reloaded. The above operations are repeated. In other words, the output is set to "H" level during (N-1)/2 counting and to "L" level during in the case of odd number counting.

#### Mode 4

- Use: Software trigger strobe
- Output operation: The output is initially set to "H" level. When the counter value becomes 0, the output goes to "L" level during one clock pulse, and then restores "H" level again.

The count sequence starts when the initial count value is written.

- Gate function: "H" level validates counting, and "L" level invalidates counting. The gate signal does not affect the output.
- Count value load timing:

After the control word and initial count value are written, the count value is loaded to the CE at the falling edge of the next clock pulse. The clock pulse does not decrement the initial count value. If the initial count value is N, the strobe is not output unless N+1 clock pulses are input after the initial count value is written.

• Count value writing during counting:

The new count value is written to the CE at the falling edge of the next clock pulse, and counting continues using the new count value. The operation for 2-byte count is as follows:

- 1) First byte writing does not affect the counting operation.
- After the second byte is written, the new count value is loaded to the CE at the falling edge of the next clock pulse.

This means that the counting operation is retriggered by software. The output strobe is set to "L" level upon input of N+1 clock pulses after the new count value N is written.

#### Mode 5

- Use: Hardware trigger strobe
- Output operation: The output is initially set to "H" level. When the counter value becomes 0 after triggering by the rising edge of the gate pulse, the output goes to "L" level during one clock pulse, and then restores "H" level.
- Count value load timing:

Even after the control word and initial count value are written, loading to the CE does not occur until the input of the clock pulse succeeding the trigger. For the clock pulse for CE loading, the count value is not decremented. If the initial count value is N, therefore, the output is not set to "L" level until N+1 clock pulses are input after triggering.

• Gate function:

The initial count value is loaded to the CE at the falling edge of the clock pulse succeeding gate triggering. The count sequence can be retriggered. The gate pulse does not affect the output.

Count value writing during counting:

The count value writing does not affect the current counting sequence. If the gate trigger is generated after the new count value is written and before the current counting ends, the new count value is loaded to the CE at the falling edge of the next clock pulse, and counting continues using the new count value.

The various roles of the gate input signals in the above modes are summarized in the following table.

## ------ I/O·MSM82C54-2RS/GS/JS =

| Gate | "L" Level Falling Edge                                                                | Rising Edge                                                         | "H" Level         |
|------|---------------------------------------------------------------------------------------|---------------------------------------------------------------------|-------------------|
| 0    | Counting not possible                                                                 |                                                                     | Counting possible |
| 1    |                                                                                       | <ol> <li>(1) Start of counting</li> <li>(2) Retriggering</li> </ol> |                   |
| 2    | <ol> <li>Counting not possible</li> <li>Counter output forced to "H" level</li> </ol> | Start of counting                                                   | Counting possible |
| 3    | <ol> <li>Counting not possible</li> <li>Counter output forced to "H" level</li> </ol> | Start of counting                                                   | Counting possible |
| 4    | Counting not possible                                                                 |                                                                     | Counting possible |
| 5    |                                                                                       | (1) Start of counting<br>(2) Retriggering                           |                   |



■ I/O·MSM82C54-2RS/GS/JS ■-



#### Reading Counter Values

All 82C54-2 counting is down-counting, the counting being in steps of 2 in mode 3. Counter values can be read during counting by (1) direct reading, (2) counter latching ("read on the fly"), and (3) read back command.

#### (1) Direct reading

Counter values can be read by direct reading operations.

Since the counter value read according to the timing of the  $\overline{RD}$  and CLK signals is not guaranteed, it is necessary to stop the counting by a gate input signal, or to interrupt the clock input temporarily by an external circuit to ensure that the counter value is correctly read.

#### (2) Counter latching

In this method, the counter value is latched by writing a counter latch command, thereby enabling a stable value to be read without effecting the counting in any way at all. The output latch (OL) of the selected counter latches the count value when a counter latch command is written. The count value is held until it is read by the CPU or the control word is set again.

If a counter latch command is written again before reading while a certain counter is latched, the second counter latch command is ignored and the value latched by the first counter latch command is maintained.

The 82C54-2 features independent reading and writing from and to the same counter.

When a counter is programmed for the 2-byte counter value, the following sequence is possible:

- 1. Count value (LSB) reading
- 2. New count value (LSB) writing
- 3. Count value (MSB) reading
- 4. New count value (MSB) writing

An example of a counter latching program is given below.

Counter latching executed for counter #1 (Read/ Load 2-byte setting)

| MVIA 0100                     | x x x x<br>— Denotes counter latching                                                                                        |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| OUT n3                        | <ul> <li>Write in control word address<br/>(n3)</li> <li>The counter value at this point<br/>is latched</li> </ul>           |
| IN n1                         | <ul> <li>Reading of the LSB of the<br/>counter value latched from<br/>counter #1.</li> <li>n1: Counter #1 address</li> </ul> |
| MOV B, A<br>IN n1<br>MOV C, A | Reading of MSB from counter<br>#1.                                                                                           |

(3) Read Back Command Operation

Use of the read back command enables the user to check the count value, program mode, output pin state and null count flag of the selected counter.

The command is written in the control word register,

and the format is as shown below. For this command, the counter selection occurs according to bits D3, D2 and D1.

| D7                      | D6                                     | 05                                        | D4                                                          | D3                                       | D2     | D1    | DO |  |
|-------------------------|----------------------------------------|-------------------------------------------|-------------------------------------------------------------|------------------------------------------|--------|-------|----|--|
| 1                       | 1                                      | COUNT                                     | STATUS                                                      | CNT2                                     | CNT1   | CNTO  | 0  |  |
| D5: 0<br>D4: 0<br>D3: 1 | ≕ Sel<br>= Sel<br>= Co<br>= Co<br>= Co | ected<br>ected<br>unter<br>unter<br>unter | A1 = 1<br>counte<br>counte<br>#2 sele<br>#1 sele<br>#0 sele | er latcl<br>er stati<br>ection<br>ection | h oper | ation |    |  |

It is possible to latch multiple counters by using the read back command. Latching of a read counter is automatically cancelled but other counters are kept latched. If multiple read back commands are written for the same counter, commands other than the first one are ignored.

It is also possible to latch the status information of each counter by using the read back command. The status of a certain counter is read when the counter is read.

The counter status format is as follows:

Bits D5 to D0 indicates the mode programmed by the most recently written control word.

Bit D7 indicates the status of the output pin.

Use of this bit makes it possible to monitor the counter output, so the corresponding hardware may be omitted.

| D7     | D6    | D5  | D4  | D3 | D2 | D1 | DO  |
|--------|-------|-----|-----|----|----|----|-----|
| OUTPUT | COUNT | RL1 | RLO | M2 | М1 | MO | BCD |

D7: 1 = Output pin status is 1.

0 = Output pin status is 0.

D6: 1 = Null count

0 = Count value reading is effective

D5 – D0: Programmed mode of counter (See the control word format.)

Null count indicates the count value finally written in the counter register (CR) has been loaded in the counter element (CE). The time when the count value was loaded in the CE depends on the mode of each counter, and it cannot be known by reading the counter value because the count value does not tell the new count value if the counter is latched. The null count operation is shown below.

### I/O·MSM82C54-2RS/GS/JS

#### Operation

- Result A. Control word register writing Null count = 1
- B. Count register (CR) writing Null count = 1
- C. New count loading to Null count = 0
  - CE (CR CE)
- (Note) The null count operation for each counter is independent. When the 2byte count is programmed, the null count is set to 1 when the count value of the second byte is written.

If status latching is carried out multiple times before status reading, other than the first status latch is ianored

Simultaneous latching of the count and status of the selected counter is also possible. For this purpose, set bits D4 and D3, COUNT and STATUS bits, to 00. This is functionally the same as writing two separate read back commands at the same time. If counter/status latching is carried out multiple times before each reading, other than the first one is ignored here again. The example is shown below.

| Command |    |    |    | nd |    |    | Contents | Cour                                   | Counter 0 |        | Counter 1 |        | Counter 2 |        |
|---------|----|----|----|----|----|----|----------|----------------------------------------|-----------|--------|-----------|--------|-----------|--------|
| D7      | D6 | D5 | D4 | D3 | D2 | D1 | DO       | Contents                               | Count     | Status | Count     | Status | Count     | Status |
| 1       | 1  | 0  | 0  | 0  | 0  | 1  | 0        | Read back status and count (counter 0) | L         | L      | -         | -      | -         | -      |
| 1       | 1  | 1  | 0  | 0  | 1  | 0  | 0        | Read back status (counter 1)           | L         | L      | -         | L      | -         | -      |
| 1       | 1  | 1  | 0  | 1  | 1  | 0  | 0        | Read back status (counters 1 and 2)    | L         | L      | -         |        | -         | L      |
| 1       | 1  | 0  | 1  | 1  | 0  | 0  | 0        | Read back count (counter 2)            | L         | L      | -         | L      | L         | L      |
| 1       | 1  | 0  | 0  | 0  | 1  | 0  | 0        | Read back status and count (counter 1) | L         | L      | L         | INOTE  | L         | L      |
| 1       | 1  | 1  | 0  | 0  | 0  | 1  | 0        | Read back status (counter 0)           | L         | INOTE  | L         | L      | L         | L      |

L: Latched, -: Not latched

(Note) The latch command at this time point is ignored, and the first latch command is valid.

If both the count and status are latched, the status latched in the first counter read operation is read. The order of count latching and status latching is irrelevant.

The count(s) of the next one or two reading opera-

tions is or are read.

82C54-2 CLKO OUTO CLK1 OUT1 ഹം CLK2 OUT2

Use counter #1 and counter #2

Example of Practical Application

82C54-2 used as a 32-bit counter.

Counter #1: mode 0, upper order 16-bit counter value

Counter #2: mode 2, lower order 16-bit counter value

This setting enables counting up to a maximum of 2<sup>32</sup>.