HT82K94E/HT82K94A
Rev. 1.00
16
November 22, 2005
(TMR0/TMR1) pin. The timer mode functions as a nor-
mal timer with the clock source coming from the f
SYS
/4
(Timer0/Timer1). The pulse width measurement mode
can be used to count the high or low level duration of the
external signal (TMR0/TMR1). The counting is based on
the f
SYS
/4 (Timer0/Timer1).
In the event count or timer mode, once the Timer/Event
Counter 0/1 starts counting, it will count from the current
contents in the Timer/Event Counter 0/1 to FFH or
FFFFH. Once overflow occurs, the counter is reloaded
from the Timer/Event Counter 0/1 preload register and
generates the interrupt request flag (T0F/T1F; bit 5/6 of
INTC) at the same time.
In the pulse width measurement mode with the TON
and TE bits equal to one, once the TMR0/TMR1 has re-
ceived a transient from low to high (or high to low if the
TE bits is 0 ) it will start counting until the TMR0/TMR1
returns to the original level and resets the TON. The
measured result will remain in the Timer/Event Counter
0/1 even if the activated transient occurs again. In other
words, only one cycle measurement can be done. Until
setting the TON, the cycle measurement will function
again as long as it receives further transient pulse. Note
that, in this operating mode, the Timer/Event Counter
0/1 starts counting not according to the logic level but
according to the transient edges. In the case of counter
overflows, the counter 0/1 is reloaded from the
Timer/Event Counter 0/1 preload register and issues the
interrupt request just like the other two modes. To en-
able the counting operation, the timer ON bit (TON; bit 4
ofTMR0C/TMR1C)shouldbesetto1.Inthepulsewidth
measurement mode, the TON will be cleared automati-
cally after the measurement cycle is completed. But in
the other two modes the TON can only be reset by in-
structions. The overflow of the Timer/Event Counter 0/1
is one of the wake-up sources. No matter what the oper-
ation mode is, writing a 0 to ET0I/ET1I can disable the
corresponding interrupt services.
In the case of Timer/Event Counter 0/1 OFF condition,
writingdatatotheTimer/EventCounter0/1preloadregis-
ter will also reload that data to the Timer/Event Counter
0/1. But if the Timer/Event Counter 0/1 is turned on, data
written to it will only be kept in the Timer/Event Counter
0/1preloadregister.TheTimer/EventCounter0/1willstill
operate until overflow occurs (a Timer/Event Counter 0/1
reloading will occur at the same time). When the
Timer/Event Counter 0/1 (reading TMR0/TMR1) is read,
theclockwillbeblockedtoavoiderrors.Asclockblocking
may results in a counting error, this must be taken into
consideration by the programmer.
Input/Output Ports
There are 40 bidirectional input/output lines in the
microcontroller, labeled from PA to PE, which are
mapped to the data memory of [12H], [14H], [16H],
[18H] and [1AH] respectively. All of these I/O ports can
be used for input and output operations. For input oper-
ation, these ports are non-latching, that is, the inputs
must be ready at the T2 rising edge of instruction MOV
A,[m] (m=12H, 14H, 16H, 18H or 1AH). For output op-
eration, all the data is latched and remains unchanged
until the output latch is rewritten.
Each I/O line has its own control register (PAC, PBC,
PCC, PDC, PEC) to control the input/output configura-
tion. With this control register, CMOS/NMOS/PMOS
output or Schmitt trigger input with or without pull-high
resistor structures can be reconfigured dynamically un-
der software control. To function as an input, the corre-
sponding latch of the control register must write a 1 .
The input source also depends on the control register. If
the control register bit is 1 , the input will read the pad
state. If the control register bit is 0 , the contents of the
latches will move to the internal bus. The latter is possi-
ble in the
function, CMOS is the only except port A which can be
read-modify-write
instruction. For output
-
2 E (
* )
1
-
1 0
-
0
-
0
-
0
" (
(
!
G
G
, ( 1
>
( 1
!
+
(
, (
!
$
(
!
" (
, (
!
+
(
(
!
( 1
#
+
<
5
( %
(
( )
(
0 )
(
%
G
G
+
<
5
(
( %
(
( )
(
Input/Output Ports