## **MODES OF 8253**

## 4.4.5 Modes

The following text describes all possible modes. The modes used in the MZ-700 and set by the monitor's startup are mode 0, mode 2, and mode 3.

| Mode      | Interrupt on Terminal Count                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0         | The counter will be programmed to an initial value and afterwards counts down at a rate equal to the input clock frequency. When the count is equal to 0, the OUT pin will be a logical 1. The output will stay a logical 1 until the counter is reloaded with a new value or the same value or until a mode word is written to the device.<br>Once the counter starts counting down, the GATE input can disable the internal counting by setting the GATE to a logical 0 ( see the table above ). |  |  |
| Mode<br>1 | Programmable One-Shot                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|           | In mode 1, the device can be setup to give an output pulse that is an integer number of clock pulses. The one-shot is triggered on the rising edge of the GATE input. If the trigger occurs during the pulse output, the 8253 will be retriggered again.                                                                                                                                                                                                                                           |  |  |

| Mode | Rate Generator                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                         |  |  |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 2    | pin of the counte                                                                                                                                                                          | is programmed for mode 2 becomes a "divide by n" counter. The OUT<br>r goes to low for one input clock period. The time between the pulses of<br>endent on the present count in the counter's register. I mean the time of<br>se.                                                                                                                       |  |  |
|      | be 1 / 1,000 s = 1<br>MHz ( Mega-Her<br>#0 would need to                                                                                                                                   | ppose to get an output frequency of 1,000 Hz (Hertz ), the period would ms (millisecond) or 1,000 $\mu$ s (microseconds). If an input clock of 1 rtz ) were applied to the clock input of the counter #0, then the counter be programmed to 1000 $\mu$ s. This could be done in decimal or in BCD. (input clock of 1 MHz is 1 / 1,000,000 = 1 $\mu$ s.) |  |  |
|      | The formula is: <b>n</b>                                                                                                                                                                   | ı=f <sub>i</sub> divided by f <sub>out</sub> .                                                                                                                                                                                                                                                                                                          |  |  |
|      |                                                                                                                                                                                            | requency, $f_{out} = output$ frequency, $n = value$ to be loaded.                                                                                                                                                                                                                                                                                       |  |  |
|      | My example: f <sub>i</sub> =                                                                                                                                                               | = 1 MHz = 1 x $10^{6}$ Hz, $f_{out} = 1$ kHz = 1 x $10^{3}$ Hz.                                                                                                                                                                                                                                                                                         |  |  |
|      | $n = 1 \times 10^{6}$ Hz / 1 x $10^{3}$ Hz = 1 x $10^{3}$ = 1,000. This is the decimal value to be low the hexadecimal value \$03E8. The following program example uses the decimal count. |                                                                                                                                                                                                                                                                                                                                                         |  |  |
|      | B000 3E35                                                                                                                                                                                  | LD A,\$35 ; load control word<br>; for counter 0 mode 2                                                                                                                                                                                                                                                                                                 |  |  |
|      | B002 3207E0                                                                                                                                                                                | LD (\$E007),A ; into port \$E007<br>; for BCD count                                                                                                                                                                                                                                                                                                     |  |  |
|      | B005 2104E0                                                                                                                                                                                | LD HL,\$E004 ; address to the port<br>; of counter 0                                                                                                                                                                                                                                                                                                    |  |  |
|      | B008 3E00                                                                                                                                                                                  | LD A,\$00                                                                                                                                                                                                                                                                                                                                               |  |  |
|      | B00A 77                                                                                                                                                                                    | LD (HL),A ; load least significant<br>; byte of 1000 first                                                                                                                                                                                                                                                                                              |  |  |
|      | B00B 3E10                                                                                                                                                                                  | LD A,\$10                                                                                                                                                                                                                                                                                                                                               |  |  |
|      | B00D 77                                                                                                                                                                                    | LD (HL),A ; load most significant<br>; byte of 1000 last                                                                                                                                                                                                                                                                                                |  |  |
|      | B00E 3E01                                                                                                                                                                                  | LD A,1                                                                                                                                                                                                                                                                                                                                                  |  |  |
|      | B010 3208E0                                                                                                                                                                                | LD (\$E008),A ; start counter 0 is only<br>; necessary for the MZ-700.<br>; Not necessary for                                                                                                                                                                                                                                                           |  |  |
|      |                                                                                                                                                                                            | ; counter #1 and #2                                                                                                                                                                                                                                                                                                                                     |  |  |
|      | ;<br>; The counter is now initialized and the output frequency<br>; will be 1000 Hz if the input frequency is 1 MHz.                                                                       |                                                                                                                                                                                                                                                                                                                                                         |  |  |
|      |                                                                                                                                                                                            | aded between output pulses, the present period will not be affected. A occur during the next count sequence.                                                                                                                                                                                                                                            |  |  |

| Mode      | Square Wave Generator                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 3         | Square wave Generator                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|           | <ul> <li>Mode 3 is similar to the mode 2 except that the output will be high for half the period and low for half. If the count is odd, the output will be high for (n + 1) / 2 and low for n - 1) / 2 counts.</li> <li>For example, I'll setup counter #0 for a square wave frequency of 10 kHz (kilo-Hertz) assuming the input frequency is 1 MHz.</li> </ul> |  |  |  |
|           |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|           | Please refer to the formula described at mode 2.<br>$1 \ge 10^6 / 10 \ge 10^3 = 100$ . This is the decimal value to be loaded or the hexadecimal value<br>\$0064. The following program example uses the binary load count.                                                                                                                                     |  |  |  |
|           | B000 3E35 LD A,\$36 ; load control word<br>; for counter 0 mode 3                                                                                                                                                                                                                                                                                               |  |  |  |
|           | B002 3207E0 LD (\$E007),A ; into port \$E007<br>; for binary count                                                                                                                                                                                                                                                                                              |  |  |  |
|           | B005 2104E0 LD HL,\$E004 ; address to the port<br>; of counter 0                                                                                                                                                                                                                                                                                                |  |  |  |
|           | B008 3E00 LD A,\$64 ; equals to<br>; 100 microseconds<br>; for 10,000 Hz                                                                                                                                                                                                                                                                                        |  |  |  |
|           | B00A 77 LD (HL),A ; load least significant<br>; byte of \$0064 first                                                                                                                                                                                                                                                                                            |  |  |  |
|           | B00B 3E10 LD A,\$00                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|           | B00D 77 LD (HL),A ; load most significant<br>; nyte of \$0064 last                                                                                                                                                                                                                                                                                              |  |  |  |
|           | BOOE 3E01 LD A,1                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|           | B010 3208E0 LD (\$E008),A ; start counter 0 is only<br>; necessary for the MZ-700.                                                                                                                                                                                                                                                                              |  |  |  |
|           | ; Not necessary for counter                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|           | ; #1 and #2                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|           | ; The counter is now initialized and the output frequency<br>; will be 10 kHz if the input frequency is 1 MHz.                                                                                                                                                                                                                                                  |  |  |  |
| Mode<br>4 | Software Triggered Strobe                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|           | In this mode the programmer can set up the counter to give an output timeout starting when the register is loaded. On the terminal count, when the counter equals to 0, the output will go to a logical 0 for one clock period and then returns to a logical 1. First the mode is set, the output will be a logical 1.                                          |  |  |  |
| Mode<br>5 | Hardware Triggered Strobe                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| 5         | In this mode the rising edge of the trigger input will start the counting of the counter. The                                                                                                                                                                                                                                                                   |  |  |  |

output goes low for one clock at the terminal count. The counter is retriggerable, thus meaning that if the trigger input is taken low and then high during a count sequence, the sequence will start over.

When the external trigger input goes to a logical 1, the timer will start to time out. If the external trigger occurs again, prior to the time completing a full timeout, the timer will retrigger.

Source : http://nprcet.org/e%20content/Misc/e-Learning/IT/IV%20Sem/CS%202252-Microprocessors%20and% 20Microcontrollers.pdf