Jasper Lake EDS Vol1
Datasheet
Timer Programming
The counter/timers are programmed in the following fashion:
- Write a control word to select a counter.
- Write an initial count for that counter.
- Load the least and/or most significant bytes (as required by Control Word Bits 5, 4) of the 16-bit counter.
- Repeat with other counters.
Only two conventions need to be observed when programming the counters. First, for each counter, the control word must be written before the initial count is written. Second, the initial count must follow the count format specified in the control word (least significant byte only, most significant byte only, or least significant byte, and then most significant byte).
A new initial count may be written to a counter at any time without affecting the counter's programmed mode. Counting is affected as described in the mode definitions. The new count must follow the programmed count format.
If a counter is programmed to read/write two-byte counts, the following precaution applies – a program must not transfer control between writing the first and second byte to another routine which also writes into that same counter. Otherwise, the counter will be loaded with an incorrect count.
The Control Word Register at port 43h controls the operation of all three counters. Several commands are available:
- Control Word Command. Specifies which counter to read or write, the operating mode, and the count format (binary or BCD).
- Counter Latch Command. Latches the current count so that it can be read by the system. The countdown process continues.
- Read Back Command. Reads the count value, programmed mode, the current state of the OUT pins, and the state of the Null Count Flag of the selected counter.
This table lists the six operating modes for the interval counters.
Mode | Function | Description |
---|---|---|
0 | Out signal on end of count (=0) | Output is 0. When count goes to 0, output goes to 1 and stays at 1 until counter is reprogrammed. |
1 | Hardware retriggerable one-shot | Output is 0. When count goes to 0, output goes to 1 for one clock time. |
2 | Rate generator (divide by n counter) | Output is 1. Output goes to 0 for one clock time, then back to 1 and counter is reloaded. |
3 | Square wave output | Output is 1. Output goes to 0 when counter rolls over, and counter is reloaded. Output goes to 1 when counter rolls over, and counter is reloaded, and so on |
4 | Software triggered strobe | Output is 1. Output goes to 0 when count expires for one clock time. |
5 | Hardware triggered strobe | Output is 1. Output goes to 0 when count expires for one clock time. |