Intel 8254 Timer HMOS
-
Upload
jeff-sales -
Category
Documents
-
view
251 -
download
0
Transcript of Intel 8254 Timer HMOS
-
8/6/2019 Intel 8254 Timer HMOS
1/21
September 1993 Order Number 231164-005
8254PROGRAMMABLE INTERVAL TIMER
Y Compatible with All Intel and MostOther Microprocessors
Y Handles Inputs from DC to 10 MHz 8 MHz 8254 10 MHz 8254-2
Y Status Read-Back Command
Y Six Programmable Counter Modes
Y Three Independent 16-Bit Counters
Y Binary or BCD CountingY Single a5V Supply
Y Available in EXPRESS Standard Temperature Range
The Intel 8254 is a countertimer device designed to solve the common timing control problems in microcom-puter system design It provides three independent 16-bit counters each capable of handling clock inputs upto 10 MHz All modes are software programmable The 8254 is a superset of the 8253
The 8254 uses HMOS technology and comes in a 24-pin plastic or CERDIP package
2311641
Figure 1 8254 Block Diagram
2311642
Figure 2 Pin Configuration
-
8/6/2019 Intel 8254 Timer HMOS
2/21
8254
Table 1 Pin Description
SymbolPin
Type Name and FunctionNo
D7 D0 1 8 IO DATA Bi-directional three state data bus lines connected to systemdata bus
CLK 0 9 I CLOCK 0 Clock input of Counter 0OUT 0 10 O OUTPUT 0 Output of Counter 0
GATE 0 11 I GATE 0 Gate input of Counter 0
GND 12 GROUND Power supply connection
VCC 24 POWER a5V power supply connection
WR 23 I WRITE CONTROL This input is low during CPU write operations
RD 22 I READ CONTROL This input is low during CPU read operations
CS 21 I CHIP SELECT A low on this input enables the 8254 to respond toRD and WR signals RD and WR are ignored otherwise
A1 A0 20 19 I ADDRESS Used to select one of the three Counters or the ControlWord Register for read or write operations Normally connected tothe system address bus
A1 A0 Selects
0 0 Counter 00 1 Counter 11 0 Counter 21 1 Control Word Register
CLK 2 18 I CLOCK 2 Clock input of Counter 2
OUT 2 17 O OUT 2 Output of Counter 2
GATE 2 16 I GATE 2 Gate input of Counter 2
CLK 1 15 I CLOCK 1 Clock input of Counter 1
GATE 1 14 I GATE 1 Gate input of Counter 1
OUT 1 13 O OUT 1 Output of Counter 1
FUNCTIONAL DESCRIPTION
General
The 8254 is a programmable interval timercounterdesigned for use with Intel microcomputer systemsIt is a general purpose multi-timing element that canbe treated as an array of IO ports in the systemsoftware
The 8254 solves one of the most common problemsin any microcomputer system the generation of ac-curate time delays under software control Instead ofsetting up timing loops in software the programmerconfigures the 8254 to match his requirements andprograms one of the counters for the desired delayAfter the desired delay the 8254 will interrupt theCPU Software overhead is minimal and variablelength delays can easily be accommodated
Some of the other countertimer functions commonto microcomputers which can be implemented withthe 8254 are
Real time clock
Event-counter
Digital one-shot
Programmable rate generator
Square wave generator
Binary rate multiplier
Complex waveform generator
Complex motor controller
Block Diagram
DATA BUS BUFFER
This 3-state bi-directional 8-bit buffer is used to in-
terface the 8254 to the system bus (see Figure 3)
2
-
8/6/2019 Intel 8254 Timer HMOS
3/21
8254
2311643
Figure 3 Block Diagram Showing Data Bus Buffer and ReadWrite Logic Functions
READWRITE LOGIC
The ReadWrite Logic accepts inputs from the sys-tem bus and generates control signals for the otherfunctional blocks of the 8254 A1 and A0 select oneof the three counters or the Control Word Registerto be read fromwritten into A low on the RD in-put tells the 8254 that the CPU is reading one of thecounters A low on the WR input tells the 8254that the CPU is writing either a Control Word or aninitial count Both RD and WR are qualified by CSRD and WR are ignored unless the 8254 has beenselected by holding CS low
CONTROL WORD REGISTER
The Control Word Register (see Figure 4) is selectedby the ReadWrite Logic when A1A0 e 11 If theCPU then does a write operation to the 8254 thedata is stored in the Control Word Register and isinterpreted as a Control Word used to define theoperation of the Counters
The Control Word Register can only be written tostatus information is available with the Read-Back
Command
COUNTER 0 COUNTER 1 COUNTER 2
These three functional blocks are identical in opera-tion so only a single Counter will be described Theinternal block diagram of a single counter is shownin Figure 5
The Counters are fully independent Each Countermay operate in a different Mode
The Control Word Register is shown in the figure itis not part of the Counter itself but its contents de-termine how the Counter operates
The status register shown in Figure 5 whenlatched contains the current contents of the ControlWord Register and status of the output and nullcount flag (See detailed explanation of the Read-Back command)
The actual counter is labelled CE (for Counting Ele-ment) It is a 16-bit presettable synchronous downcounter
OLM and OLL are two 8-bit latches OL stands forOutput Latch the subscripts M and L stand forMost significant byte and Least significant byte
3
-
8/6/2019 Intel 8254 Timer HMOS
4/21
8254
2311644
Figure 4 Block Diagram Showing Control Word Register and Counter Functions
2311645
Figure 5 Internal Block Diagram of a Counter
4
-
8/6/2019 Intel 8254 Timer HMOS
5/21
8254
respectively Both are normally referred to as oneunit and called just OL These latches normally fol-low the CE but if a suitable Counter Latch Com-mand is sent to the 8254 the latches latch thepresent count until read by the CPU and then returnto following the CE One latch at a time is enabled
by the counters Control Logic to drive the internalbus This is how the 16-bit Counter communicatesover the 8-bit internal bus Note that the CE itselfcannot be read whenever you read the count it isthe OL that is being read
Similarly there are two 8-bit registers called CRMand CRL (for Count Register) Both are normallyreferred to as one unit and called just CR When anew count is written to the Counter the count isstored in the CR and later transferred to the CE TheControl Logic allows one register at a time to beloaded from the internal bus Both bytes are trans-ferred to the CE simultaneously CRM and CRL arecleared when the Counter is programmed In thisway if the Counter has been programmed for onebyte counts (either most significant byte only or least
significant byte only) the other byte will be zeroNote that the CE cannot be written into whenever acount is written it is written into the CR
The Control Logic is also shown in the diagramCLK n GATE n and OUT n are all connected to theoutside world through the Control Logic
8254 SYSTEM INTERFACE
The 8254 is a component of the Intel MicrocomputerSystems and interfaces in the same manner as all
other peripherals of the family It is treated by thesystems software as an array of peripheral IOports three are counters and the fourth is a controlregister for MODE programming
Basically the select inputs A0A1 connect to the A0
A1 address bus signals of the CPU The CS can bederived directly from the address bus using a linearselect method Or it can be connected to the outputof a decoder such as an Intel 8205 for larger sys-tems
OPERATIONAL DESCRIPTION
General
After power-up the state of the 8254 is undefinedThe Mode count value and output of all Countersare undefined
How each Counter operates is determined when it is
programmed Each Counter must be programmedbefore it can be used Unused counters need not beprogrammed
Programming the 8254
Counters are programmed by writing a Control Wordand then an initial count
The Control Words are written into the Control WordRegister which is selected when A1A0 e 11 TheControl Word itself specifies which Counter is beingprogrammed
2311646
Figure 6 8254 System Interface
5
-
8/6/2019 Intel 8254 Timer HMOS
6/21
8254
Control Word FormatA1A0 e 11 CS e 0 RD e 1 WR e 0
D7 D6 D5 D4 D3 D2 D1 D0
SC1 SC0 RW1 RW0 M2 M1 M0 BCD
SCSelect Counter
SC1 SC0
0 0 Select Counter 0
0 1 Select Counter 1
1 0 Select Counter 2
1 1 Read-Back Command
(see Read Operations)
RWReadWrite
RW1 RW0
0 0 Counter Latch Command (see ReadOperations)
0 1 ReadWrite least significant byte only
1 0 ReadWrite most significant byte only
1 1 ReadWrite least significant byte first
then most significant byte
MMode
M2 M1 M0
0 0 0 Mode 0
0 0 1 Mode 1
X 1 0 Mode 2
X 1 1 Mode 3
1 0 0 Mode 4
1 0 1 Mode 5
BCD
0 Binary Counter 16-bits
1 Binary Coded Decimal (BCD) Counter
(4 Decades)
NOTEDont care bits (X) should be 0 to insure compatibility with future Intel products
Figure 7 Control Word Format
By contrast initial counts are written into the Coun-ters not the Control Word Register The A1A0 in-puts are used to select the Counter to be writteninto The format of the initial count is determined bythe Control Word used
Write Operations
The programming procedure for the 8254 is veryflexible Only two conventions need to be remem-bered
1) For each Counter the Control Word must be writ-ten before the initial count is written
2) The initial count must follow the count formatspecified in the Control Word (least significantbyte only most significant byte only or least sig-nificant byte and then most significant byte)
Since the Control Word Register and the threeCounters have separate addresses (selected by theA1A0 inputs) and each Control Word specifies theCounter it applies to (SC0SC1 bits) no special in-struction sequence is required Any programmingsequence that follows the conventions in Figure 7 isacceptable
A new initial count may be written to a Counter atany time without affecting the Counters pro-grammed Mode in any way Counting will be affectedas described in the Mode definitions The new countmust follow the programmed count format
If a Counter is programmed to readwrite two-bytecounts the following precaution applies A programmust not transfer control between writing the firstand second byte to another routine which also writesinto that same Counter Otherwise the Counter willbe loaded with an incorrect count
6
-
8/6/2019 Intel 8254 Timer HMOS
7/21
8254
A1 A0Control WordCounter 0 1 1
LSB of countCounter 0 0 0
MSB of countCounter 0 0 0
Control WordCounter 1 1 1LSB of countCounter 1 0 1
MSB of countCounter 1 0 1
Control WordCounter 2 1 1
LSB of countCounter 2 1 0
MSB of countCounter 2 1 0
A1 A0Control WordCounter 0 1 1
Control WordCounter 1 1 1
Control WordCounter 2 1 1
LSB of countCounter 2 1 0
LSB of countCounter 1 0 1
LSB of countCounter 0 0 0
MSB of countCounter 0 0 0
MSB of countCounter 1 0 1
MSB of countCounter 2 1 0
A1 A0Control WordCounter 2 1 1
Control WordCounter 1 1 1
Control WordCounter 0 1 1
LSB of countCounter 2 1 0MSB of countCounter 2 1 0
LSB of countCounter 1 0 1
MSB of countCounter 1 0 1
LSB of countCounter 0 0 0
MSB of countCounter 0 0 0
A1 A0Control WordCounter 1 1 1
Control WordCounter 0 1 1
LSB of countCounter 1 0 1
Control WordCounter 2 1 1
LSB of countCounter 0 0 0
MSB of countCounter 1 0 1
LSB of countCounter 2 1 0
MSB of countCounter 0 0 0
MSB of countCounter 2 1 0
NOTEIn all four examples all Counters are programmed to readwrite two-byte counts These are only four of many possibleprogramming sequences
Figure 8 A Few Possible Programming Sequences
Read Operations
It is often desirable to read the value of a Counterwithout disturbing the count in progress This is easi-ly done in the 8254
There are three possible methods for reading thecounters a simple read operation the CounterLatch Command and the Read-Back Command
Each is explained below The first method is to per-form a simple read operation To read the Counterwhich is selected with the A1 A0 inputs the CLKinput of the selected Counter must be inhibited byusing either the GATE input or external logic Other-wise the count may be in the process of changingwhen it is read giving an undefined result
COUNTER LATCH COMMAND
The second method uses the Counter Latch Com-mand Like a Control Word this command is writtento the Control Word Register which is selectedwhen A1A0 e 11 Also like a Control Word theSC0 SC1 bits select one of the three Counters buttwo other bits D5 and D4 distinguish this commandfrom a Control Word
A1A0 e 11 CS e 0 RD e 1 WR e 0
D7 D6 D5 D4 D3 D2 D1 D0
SC1 SC0 0 0 X X X X
SC1SC0specify counter to be latched
SC1 SC0 Counter
0 0 0
0 1 1
1 0 2
1 1 Read-Back Command
D5D400 designates Counter Latch Command
Xdont care
NOTEDont care bits (X) should be 0 to insure compatibilitywith future Intel products
Figure 9 Counter Latching Command Format
7
-
8/6/2019 Intel 8254 Timer HMOS
8/21
8254
The selected Counters output latch (OL) latches thecount at the time the Counter Latch Command isreceived This count is held in the latch until it is readby the CPU (or until the Counter is reprogrammed)The count is then unlatched automatically and theOL returns to following the counting element (CE)
This allows reading the contents of the Counterson the fly without affecting counting in progressMultiple Counter Latch Commands may be used tolatch more than one Counter Each latched Coun-ters OL holds its count until it is read Counter LatchCommands do not affect the programmed Mode ofthe Counter in any way
If a Counter is latched and then some time laterlatched again before the count is read the secondCounter Latch Command is ignored The count readwill be the count at the time the first Counter LatchCommand was issued
With either method the count must be read accord-ing to the programmed format specifically if theCounter is programmed for two byte counts two
bytes must be read The two bytes do not have to beread one right after the other read or write or pro-gramming operations of other Counters may be in-serted between them
Another feature of the 8254 is that reads and writesof the same Counter may be interleaved for exam-ple if the Counter is programmed for two bytecounts the following sequence is valid
1) Read least significant byte
2) Write new least significant byte
3) Read most significant byte
4) Write new most significant byte
If a Counter is programmed to readwrite two-bytecounts the following precaution applies A programmust not transfer control between reading the firstand second byte to another routine which also readsfrom that same Counter Otherwise an incorrectcount will be read
READ-BACK COMMAND
The third method uses the Read-Back CommandThis command allows the user to check the countvalue programmed Mode and current states of theOUT pin and Null Count flag of the selected coun-ter(s)
The command is written into the Control Word Reg-ister and has the format shown in Figure 10 Thecommand applies to the counters selected by set-
ting their corresponding bits D3 D2 D1 e 1
A0 A1 e 11 CS e 0 RD e 1 WR e 0
D7 D6 D5 D4 D3 D2 D1 D0
1 1 C OUNT S TAT US CNT 2 CNT 1 CNT 0 0
D5
0 e Latch count of selected counter(s)D4 0 e Latch status of selected counters(s)D3 1 e Select Counter 2D2 1 e Select Counter 1D1 1 e Select Counter 0D0 Reserved for future expansion Must be 0
Figure 10 Read-Back Command Format
The read-back command may be used to latch multi-ple counter output latches (OL) by setting theCOUNT bit D5 e 0 and selecting the desired coun-ter(s) This single command is functionally equiva-lent to several counter latch commands one foreach counter latched Each counters latched countis held until it is read (or the counter is repro-grammed) The counter is automatically unlatchedwhen read but other counters remain latched until
they are read If multiple count read-back commandsare issued to the same counter without reading thecount all but the first are ignored ie the countwhich will be read is the count at the time the firstread-back command was issued
The read-back command may also be used to latchstatus information of selected counter(s) by settingSTATUS bit D4 e 0 Status must be latched to beread status of a counter is accessed by a read fromthat counter
The counter status format is shown in Figure 11 BitsD5 through D0 contain the counters programmedMode exactly as written in the last Mode ControlWord OUTPUT bit D7 contains the current state ofthe OUT pin This allows the user to monitor the
counters output via software possibly eliminatingsome hardware from a system
D7 D6 D5 D4 D3 D2 D1 D0
OutputNull
RW1 RW0 M2 M1 M0 BCDCount
D7 1 e OUT Pin is 10 e OUT Pin is 0
D6 1 e Null Count0 e Count available for reading
D5 D0 Counter programmed mode (see Figure7)
Figure 11 Status Byte
8
-
8/6/2019 Intel 8254 Timer HMOS
9/21
8254
NULL COUNT bit D6 indicates when the last countwritten to the counter register (CR) has been loadedinto the counting element (CE) The exact time thishappens depends on the Mode of the counter and isdescribed in the Mode Definitions but until the countis loaded into the counting element (CE) it cant be
read from the counter If the count is latched or readbefore this time the count value will not reflect thenew count just written The operation of Null Countis shown in Figure 12
This Action Causes
A Write to the control word register (1) Null Count e 1
B Write to the count register (CR) (2) Null Count e 1
C New Count is loaded into Null Count e 0
CE (CRxCE)
NOTE1 Only the counter specified by the control word willhave its Null Count set to 1 Null count bits of othercounters are unaffected2 If the counter is programmed for two-byte counts(least significant byte then most significant byte) Null
Count goes to 1 when the second byte is written
Figure 12 Null Count Operation
If multiple status latch operations of the counter(s)are performed without reading the status all but thefirst are ignored ie the status that will be read isthe status of the counter at the time the first statusread-back command was issued
Both count and status of the selected counter(s)may be latched simultaneously by setting both
COUNT and STATUS bits D5D4 e 0 This is func-tionally the same as issuing two separate read-backcommands at once and the above discussions ap-ply here also Specifically if multiple count andorstatus read-back commands are issued to the samecounter(s) without any intervening reads all but the
first are ignored This is illustrated in Figure 13
If both count and status of a counter are latched thefirst read operation of that counter will return latchedstatus regardless of which was latched first Thenext one or two reads (depending on whether thecounter is programmed for one or two type counts)return latched count Subsequent reads return un-latched count
CS RD WR A1 A0
0 1 0 0 0 Write into Counter 0
0 1 0 0 1 Write into Counter 1
0 1 0 1 0 Write into Counter 2
0 1 0 1 1 Write Control Word0 0 1 0 0 Read from Counter 0
0 0 1 0 1 Read from Counter 1
0 0 1 1 0 Read from Counter 2
0 0 1 1 1 No-Operation (3-State)
1 X X X X No-Operation (3-State)
0 1 1 X X No-Operation (3-State)
Figure 14 ReadWrite Operations Summary
CommandDescription Result
D7 D6 D5 D4 D3 D2 D1 D0
1 1 0 0 0 0 1 0 Read back count and status of Count and status latched
Counter 0 for Counter 0
1 1 1 0 0 1 0 0 Read back status of Counter 1 Status latched for Counter 1
1 1 1 0 1 1 0 0 Read back status of Counters 2 1 Status latched for Counter
2 but not Counter 1
1 1 0 1 1 0 0 0 Read back count of Counter 2 Count latched for Counter 2
1 1 0 0 0 1 0 0 Read back count and status of Count latched for Counter 1
Counter 1 but not status
1 1 1 0 0 0 1 0 Read back status of Counter 1 Command ignored status
already latched for Counter 1
Figure 13 Read-Back Command Example
9
-
8/6/2019 Intel 8254 Timer HMOS
10/21
8254
Mode Definitions
The following are defined for use in describing theoperation of the 8254
CLK Pulse a rising edge then a falling edge in
that order of a Counters CLK in-put
Trigger a rising edge of a Counters GATEinput
Counter loading the transfer of a count from the CRto the CE (refer to the FunctionalDescription)
MODE 0 INTERRUPT ON TERMINAL COUNT
Mode 0 is typically used for event counting After theControl Word is written OUT is initially low and willremain low until the Counter reaches zero OUT thengoes high and remains high until a new count or anew Mode 0 Control Word is written into the Coun-ter
GATE e 1 enables counting GATE e 0 disablescounting GATE has no effect on OUT
After the Control Word and initial count are written toa Counter the initial count will be loaded on the nextCLK pulse This CLK pulse does not decrement thecount so for an initial count of N OUT does not gohigh until N a 1 CLK pulses after the initial count iswritten
If a new count is written to the Counter it will beloaded on the next CLK pulse and counting will con-tinue from the new count If a two-byte count is writ-ten the following happens
1) Writing the first byte disables counting OUT is setlow immediately (no clock pulse required)
2) Writing the second byte allows the new count tobe loaded on the next CLK pulse
This allows the counting sequence to be synchroniz-ed by software Again OUT does not go high untilNa1 CLK pulses after the new count of N is written
If an initial count is written while GATE e 0 it willstill be loaded on the next CLK pulse When GATEgoes high OUT will go high N CLK pulses later noCLK pulse is needed to load the Counter as this hasalready been done
MODE 1 HARDWARE RETRIGGERABLEONE-SHOT
OUT will be initially high OUT will go low on the CLKpulse following a trigger to begin the one-shot pulseand will remain low until the Counter reaches zero
OUT will then go high and remain high until the CLKpulse after the next trigger
After writing the Control Word and initial count theCounter is armed A trigger results in loading theCounter and setting OUT low on the next CLK pulse
thus starting the one-shot pulse An initial count of Nwill result in a one-shot pulse N CLK cycles in dura-tion The one-shot is retriggerable hence OUT willremain low for N CLK pulses after any trigger Theone-shot pulse can be repeated without rewriting thesame count into the counter GATE has no effect onOUT
If a new count is written to the Counter during a one-shot pulse the current one-shot is not affected un-less the counter is retriggered In that case theCounter is loaded with the new count and the one-shot pulse continues until the new count expires
MODE 2 RATE GENERATOR
This Mode functions like a divide-by-N counter It istypically used to generate a Real Time Clock inter-rupt OUT will initially be high When the initial counthas decremented to 1 OUT goes low for one CLKpulse OUT then goes high again the Counter re-loads the initial count and the process is repeatedMode 2 is periodic the same sequence is repeatedindefinitely For an initial count of N the sequencerepeats every N CLK cycles
GATE e 1 enables counting GATE e 0 disablescounting If GATE goes low during an output pulseOUT is set high immediately A trigger reloads theCounter with the initial count on the next CLK pulseOUT goes low N CLK pulses after the trigger Thusthe GATE input can be used to synchronize theCounter
After writing a Control Word and initial count theCounter will be loaded on the next CLK pulse OUTgoes low N CLK Pulses after the initial count is writ-ten This allows the Counter to be synchronized bysoftware also
Writing a new count while counting does not affectthe current counting sequence If a trigger is re-ceived after writing a new count but before the endof the current period the Counter will be loaded withthe new count on the next CLK pulse and countingwill continue from the new count Otherwise thenew count will be loaded at the end of the currentcounting cycle In mode 2 a COUNT of 1 is illegal
MODE 3 SQUARE WAVE MODE
Mode 3 is typically used for Baud rate generationMode 3 is similar to Mode 2 except for the duty cycleof OUT OUT will initially be high When half the
10
-
8/6/2019 Intel 8254 Timer HMOS
11/21
8254
2311647
NOTEThe following conventions apply to all mode timing diagrams1 Counters are programmed for binary (not BCD) counting and for readingwriting least significant byte (LSB) only2 The counter is always selected (CS always low)3 CW stands for Control Word CW e 10 means a control word of 10 HEX is written to the counter4 LSB stands for Least Significant Byte of count5 Numbers below diagrams are count values The lower number is the least significant byte The upper number is themost significant byte Since the counter is programmed to readwrite LSB only the most significant byte cannot be read
N stands for an undefined countVertical lines show transitions between count values
Figure 15 Mode 0
11
-
8/6/2019 Intel 8254 Timer HMOS
12/21
-
8/6/2019 Intel 8254 Timer HMOS
13/21
8254
2311649
NOTEA GATE transition should not occur one clock prior to terminal count
Figure 17 Mode 2
new count Otherwise the new count will be loadedat the end of the current half-cycle
Mode 3 is implemented as follows
Even counts OUT is initially high The initial count isloaded on one CLK pulse and then is decrementedby two on succeeding CLK pulses When the countexpires OUT changes value and the Counter is re-loaded with the initial count The above process isrepeated indefinitely
Odd counts OUT is initially high The initial countminus one (an even number) is loaded on one CLKpulse and then is decremented by two on succeed-ing CLK pulses One CLK pulse after the count ex-pires OUT goes low and the Counter is reloadedwith the initial count minus one Succeeding CLKpulses decrement the count by two When the countexpires OUT goes high again and the Counter isreloaded with the initial count minus one The aboveprocess is repeated indefinitely So for odd countsOUT will be high for (N a 1)2 counts and low for(N b 1)2 counts
13
-
8/6/2019 Intel 8254 Timer HMOS
14/21
8254
23116410
NOTEA GATE transition should not occur one clock prior to terminal count
Figure 18 Mode 3
14
-
8/6/2019 Intel 8254 Timer HMOS
15/21
8254
MODE 4 SOFTWARE TRIGGERED STROBE
OUT will be initially high When the initial count ex-pires OUT will go low for one CLK pulse and thengo high again The counting sequence is triggeredby writing the initial count
GATE e 1 enables counting GATE e 0 disablescounting GATE has no effect on OUT
After writing a Control Word and initial count theCounter will be loaded on the next CLK pulse ThisCLK pulse does not decrement the count so for an
initial count of N OUT does not strobe low until N a
1 CLK pulses after the initial count is written
If a new count is written during counting it will beloaded on the next CLK pulse and counting will con-tinue from the new count If a two-byte count is writ-
ten the following happens1) Writing the first byte has no effect on counting
2) Writing the second byte allows the new count tobe loaded on the next CLK pulse
This allows the sequence to be retriggered bysoftware OUT strobes low N a 1 CLK pulses afterthe new count of N is written
23116411
Figure 19 Mode 4
15
-
8/6/2019 Intel 8254 Timer HMOS
16/21
8254
MODE 5 HARDWARE TRIGGERED STROBE(RETRIGGERABLE)
OUT will initially be high Counting is triggered by arising edge of GATE When the initial count has ex-pired OUT will go low for one CLK pulse and then
go high again
After writing the Control Word and initial count thecounter will not be loaded until the CLK pulse after atrigger This CLK pulse does not decrement thecount so for an initial count of N OUT does notstrobe low until N a 1 CLK pulses after a trigger
A trigger results in the Counter being loaded with theinitial count on the next CLK pulse The countingsequence is retriggerable OUT will not strobe lowfor N a 1 CLK pulses after any trigger GATE hasno effect on OUT
If a new count is written during counting the currentcounting sequence will not be affected If a triggeroccurs after the new count is written but before thecurrent count expires the Counter will be loadedwith the new count on the next CLK pulse andcounting will continue from there
23116412
Figure 20 Mode 5
16
-
8/6/2019 Intel 8254 Timer HMOS
17/21
8254
Signal Low
Status Or Going Rising High
Modes Low
0 Disables Enables
Counting Counting
1 1) Initiates Counting
2) Resets Output
after Next
Clock
2 1) Disables
Counting Initiates Enables
2) Sets Output Counting Counting
Immediately
High
3 1) Disables
Counting Initiates Enables
2) Sets Output Counting Counting
Immediately
High
4 Disables Enables
Counting Counting
5 Initiates
Counting
Figure 21 Gate Pin Operations Summary
ModeMin Max
Count Count
0 1 0
1 1 0
2 2 0
3 2 0
4 1 0
5 1 0
NOTE0 is equivalent to 216 for binary counting and 104 forBCD counting
Figure 22 Minimum and Maximum Initial Counts
Operation Common to All Modes
PROGRAMMING
When a Control Word is written to a Counter all
Control Logic is immediately reset and OUT goes toa known initial state no CLK pulses are required forthis
GATE
The GATE input is always sampled on the risingedge of CLK In Modes 0 2 3 and 4 the GATE inputis level sensitive and the logic level is sampled onthe rising edge of CLK In Modes 1 2 3 and 5 theGATE input is rising-edge sensitive In these Modesa rising edge of GATE (trigger) sets an edge-sensi-tive flip-flop in the Counter This flip-flop is then sam-pled on the next rising edge of CLK the flip-flop isreset immediately after it is sampled In this way atrigger will be detected no matter when it occursahigh logic level does not have to be maintained until
the next rising edge of CLK Note that in Modes 2and 3 the GATE input is both edge- and level-sensi-tive In Modes 2 and 3 if a CLK source other thanthe system clock is used GATE should be pulsedimmediately following WR of a new count value
COUNTER
New counts are loaded and Counters are decre-mented on the falling edge of CLK
The largest possible initial count is 0 this is equiva-lent to 216 for binary counting and 104 for BCDcounting
The Counter does not stop when it reaches zero InModes 0 1 4 and 5 the Counter wraps around tothe highest count either FFFF hex for binary count-ing or 9999 for BCD counting and continues count-ing Modes 2 and 3 are periodic the Counter reloadsitself with the initial count and continues countingfrom there
17
-
8/6/2019 Intel 8254 Timer HMOS
18/21
8254
ABSOLUTE MAXIMUM RATINGS
Ambient Temperature Under Bias 0C to 70C
Storage Temperature b65C to a150C
Voltage on Any Pin with
Respect to Groundb05V to a7VPower Dissipation 1W
NOTICE This is a production data sheet The specifi-cations are subject to change without notice
WARNING Stressing the device beyond the AbsoluteMaximum Ratings may cause permanent damageThese are stress ratings only Operation beyond the
Operating Conditions is not recommended and ex-tended exposure beyond the Operating Conditionsmay affect device reliability
DC CHARACTERISTICS TA e 0C to 70C VCC e 5V g10%
Symbol Parameter Min Max Units Test Conditions
VIL Input Low Voltage b05 08 V
VIH Input High Voltage 20 VCC a05V V
VOL Output Low Voltage 045 V IOL e 20 mA
VOH Output High Voltage 24 V IOH e b400 mA
IIL Input Load Current g10 mA VIN e VCC to 0V
IOFL Output Float Leakage g10 mA VOUT e VCC to 045V
ICC VCC Supply Current 170 mA
CIN Input Capacitance 10 pF fc e 1 MHz
CI0 IO Capacitance 20 pF Unmeasured pins
returned to VSS(4)
AC CHARACTERISTICS TA e 0C to 70C VCC e 5V g10% GND e 0V
Bus Parameters(1)
READ CYCLE
Symbol Parameter8254 8254-2
UnitMin Max Min Max
tAR Address Stable Before RDv 45 30 ns
tSR CS Stable Before RDv 0 0 ns
tRA Address Hold Time After RDu 0 0 ns
tRR RD Pulse Width 150 95 ns
tRD Data Delay from RDv 120 85 ns
tAD Data Delay from Address 220 185 ns
tDF RDu to Data Floating 5 90 5 65 ns
tRV Command Recovery Time 200 165 ns
NOTE1 AC timings measured at VOH e 20V VOL e 08V
18
-
8/6/2019 Intel 8254 Timer HMOS
19/21
8254
AC CHARACTERISTICS TA e 0C to 70C VCC e 5V g10% GND e 0V (Continued)
WRITE CYCLE
Symbol Parameter8254 8254-2
Unit
Min Max Min Max
tAW Address Stable Before WRv 0 0 ns
tSW CS Stable Before WRv 0 0 ns
tWA Address Hold Time After WRv 0 0 ns
tWW WR Pulse Width 150 95 ns
tDW Data Setup Time Before WRu 120 95 ns
tWD Data Hold Time After WRu 0 0 ns
tRV Command Recovery Time 200 165 ns
CLOCK AND GATE
Symbol Parameter8254 8254-2
Unit
Min Max Min Max
tCLK Clock Period 125 DC 100 DC ns
tPWH High Pulse Width 60(3) 30(3) ns
tPWL Low Pulse Width 60(3) 50(3) ns
tR Clock Rise Time 25 25 ns
tF Clock Fall Time 25 25 ns
tGW Gate Width High 50 50 ns
tGL Gate Width Low 50 50 ns
tGS Gate Setup Time to CLKu 50 40 ns
tGH Gate Setup Time After CLKu 50(2) 50(2) ns
tOD Output Delay from CLKv 150 100 ns
tODG Output Delay from Gatev 120 100 ns
tWC CLK Delay for Loadingv 0 55 0 55 ns
tWG Gate Delay for Sampling b5 50 b5 40 ns
tWO OUT Delay from Mode Write 260 240 ns
tCL CLK Set Up for Count Latch b40 45 b40 40 ns
NOTES2 In Modes 1 and 5 triggers are sampled on each rising clock edge A second trigger within 120 ns (70 ns for the 8254-2) ofthe rising clock edge may not be detected3 Low-going glitches that violate tPWH tPWL may cause errors requiring counter reprogramming4 Sampled not 100% tested TA e 25C5 If CLK present at TWC min then Count equals Na2 CLK pulses TWC max equals Count Na1 CLK pulse TWC min toTWC max count will be either Na1 or Na2 CLK pulses6 In Modes 1 and 5 if GATE is present when writing a new Count value at TWG min Counter will not be triggered at TWGmax Counter will be triggered7 If CLK present when writing a Counter Latch or ReadBack Command at TCL min CLK will be reflected in count value
latched at TCL max CLK will not be reflected in the count value latched
19
-
8/6/2019 Intel 8254 Timer HMOS
20/21
8254
WAVEFORMS
WRITE
23116413
READ
23116414
20
-
8/6/2019 Intel 8254 Timer HMOS
21/21
8254
WAVEFORMS (Continued)
RECOVERY
23116415
CLOCK AND GATE
23116416
Last byte of count being written
AC TESTING INPUT OUTPUT WAVEFORM
23116417AC Testing Inputs are driven at 24V for a Logic 1 and 045Vfor a Logic 0 Timing measurements are made at 20V for aLogic 1 and 08V for a Logic 0
AC TESTING LOAD CIRCUIT
23116418CL e 150 pFCL Includes Jig Capacitance
REVISION SUMMARY
The following list represents the key differences be-tween Rev 004 and Rev 005 of the 8254 DataSheet
1 References to and specifications for the 5 MHz8254-5 are removed Only the 8 MHz 8254 andthe 10 MHz 8254-2 remain in production
21