Packages:
Ð 44 PLCC with 40 I/O pins
Ð 40 DIP with 36 I/O pins
Ð 28 DIP with 24 I/O pins
Ð 28 SO with 24 I/O pins
CPU/Instruction Set Feature
Y
1 ms instruction cycle time
Y
Fourteen multi-source vectored interrupts servicing
Ð External interrupt with selectable edge
Ð Idle timer T0
Ð Three timers (each with 2 interrupts)
Ð MICROWIRE/PLUS
Ð Multi-Input WAke Up
Ð Software trap
Ð UART (2)
Ð Default VIS (default interrupt)
Y
Versatile and easy to use instruction set
Y
8-bit Stack Pointer (SP)Ðstack in RAM
Y
Two 8-bit register indirect data memory pointers (B, X)
Fully Static CMOS
Y
Low current drain (typicallyk1 mA)
Y
Single supply operation: 2.5V to 6.0V
Y
Temperature range:b40§Ctoa85§C
Development Support
Y
Emulation and OTP devices
Y
Real time emulation and full program debug offered by
MetaLink Development System
COP884CG/COP888CG 8-Bit Microcontroller with UART and Three Multi-Function Timers
Block Diagram
TRI-STATEÉis a registered trademark of National Semiconductor Corporation.
MICROWIRE/PLUS
iceMASTER
C
1996 National Semiconductor CorporationRRD-B30M106/Printed in U. S. A.
TM
,M2CMOSTM, COP8TMmicrocontrollers, MICROWIRETMand WATCHDOGTMare trademarks of National Semiconductor Corporation.
TM
is a trademark of MetaLink Corporation.
TL/DD/9765
FIGURE 1. Block Diagram
TL/DD/9765– 1
http://www.national.com
General Description (Continued)
They are fully static parts, fabricated using double-metal silicon gate microCMOS technology. Features include an 8-bit
memory mapped architecture, MICROWIRE/PLUS serial
I/O, three 16-bit timer/counters supporting three modes
(Processor Independent PWM generation, External Event
counter, and Input Capture mode capabilities), full duplex
UART, two comparators, and two power savings modes
(HALT and IDLE), both with a multi-sourced wakeup/interrupt capability. This multi-sourced interrupt capability may
Connection Diagrams
Plastic Chip Carrier
also be used independent of the HALT or IDLE modes.
Each I/O pin has software selectable configurations. The
device operates over a voltage range of 2.5V to 6V. High
throughput is achieved with an efficient, regular instruction
set operating at a maximum of 1 ms per instruction rate.
The device has reduced EMI emissions. Low radiated emissions are achieved by gradual turn-on output drivers and
internal I
If Military/Aerospace specified devices are required,
please contact the National Semiconductor Sales
Office/Distributors for availability and specifications.
Supply Voltage (V
Voltage at Any Pin
Total Current into V
DC Electrical Characteristics
)7V
CC
Pin (Source)100 mA
CC
b
0.3V to V
a
CC
b
40§CsT
0.3V
ParameterConditionsMinTypMaxUnits
Operating Voltage2.56V
Power Supply Ripple (Note 1)Peak-to-Peak0.1 V
Supply Current (Note 2)
e
CKI
10 MHzV
e
CKI
4 MHzV
CKIe4 MHzV
e
CKI
1 MHzV
HALT Current (Note 3)V
e
6V, t
CC
e
6V, t
CC
e
4.0V, t
CC
e
4.0V, t
CC
e
6V, CKIe0 MHz
CC
e
V
4.0V, CKIe0 MHz
CC
c
c
IDLE Current
e
CKI
10 MHzV
e
CKI
4 MHzV
CKIe1 MHzV
CC
CC
CC
e
e
e
6V, t
6V, t
4.0V, t
c
c
Input Levels
RESET
Logic High0.8 V
Logic Low0.2 V
CKI (External and Crystal Osc. Modes)
Logic High0.7 V
Logic Low0.2 V
All Other Inputs
Logic High0.7 V
Logic Low0.2 V
Hi-Z Input LeakageV
Input Pullup CurrentV
CC
CC
e
6V
e
6V, V
G and L Port Input Hysteresis0.35 V
Output Current Levels
D Outputs
SourceV
SinkV
All Others
Source (Weak Pull-Up Mode)V
Source (Push-Pull Mode)V
Sink (Push-Pull Mode)V
TRI-STATE LeakageV
Note 1: Rate of voltage change must be less then 0.5 V/ms.
Note 2: Supply current is measured after running 2000 cycles with a crystal/resonator oscillator, inputs at rails and outputs open.
Note 3: The HALT mode will stop CKI from oscillating in the RC and the Crystal configurations. Test conditions: All inputs tied to V
as outputs and set high. The D port set to zero. The clock monitor and the comparators are disabled.
e
4V, V
CC
e
V
2.5V, V
CC
e
4V, V
CC
e
V
2.5V, V
CC
e
4V, V
CC
e
V
2.5V, V
CC
e
4V, V
CC
e
V
2.5V, V
CC
e
4V, V
CC
e
V
2.5V, V
CC
e
6.0V
CC
Total Current out of GND Pin (Sink)110 mA
Storage Temperature Range
Note:
Absolute maximum ratings indicate limits beyond
b
65§Ctoa140§C
which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.
s
a
85§C unless otherwise specified
A
CC
e
1 ms8.0mA
e
2.5 ms4.5mA
e
2.5 ms2.5mA
c
e
10 ms1.4mA
c
k
110 mA
k
0.56mA
e
1 ms3.5mA
e
2.5 ms2.5mA
e
10 ms0.7mA
c
CC
CC
CC
b
2
e
0V
IN
e
3.3V
OH
e
1.8V
OH
e
1V10mA
OL
e
0.4V2.0mA
OL
e
2.7V
OH
e
1.8V
OH
e
3.3V
OH
e
1.8V
OH
e
0.4V1.6mA
OL
e
0.4V0.7mA
OL
b
40
b
0.4mA
b
0.2mA
b
10
b
2.5
b
0.4mA
b
0.2mA
b
2
CC
CC
CC
a
2mA
b
250mA
CC
b
100mA
b
33mA
a
2mA
, L, C, and G0 –G5 configured
CC
V
V
V
V
V
V
V
V
http://www.national.com4
DC Electrical Characteristics
b
40§CsT
s
a
85§C unless otherwise specified (Continued)
A
ParameterConditionsMinTypMaxUnits
Allowable Sink/Source
Current per Pin
D Outputs (Sink)15mA
All others3mA
Maximum Input CurrentT
without Latchup
RAM Retention Voltage, V
r
e
25§C
A
500 ns Rise
and Fall Time (Min)
g
100mA
2V
Input Capacitance7pF
Load Capacitance on D21000pF
AC Electrical Characteristics
b
40§CsT
s
a
85§C unless otherwise specified
A
ParameterConditionsMinTypMaxUnits
Instruction Cycle Time (tc)
s
4V
2.5V
s
V
6V1DCms
CC
k
s
V
4V2.5DCms
CC
s
s
V
6V3DCms
CC
k
s
V
4V7.5DCms
CC
Crystal, Resonator,4V
R/C Oscillator2.5V
Inputs
t
SETUP
t
HOLD
4VsV
2.5V
4VsV
2.5V
Output Propagation Delay (Note 4)R
t
PD1,tPD0
SO, SK4VsV
2.5V
All Others4V
2.5V
MICROWIRETMSetup Time (t
MICROWIRE Hold Time (t
MICROWIRE Output Propagation Delay (t
)20ns
UWS
)56ns
UWH
)220ns
UPD
s
6V200ns
CC
k
s
V
4V500ns
CC
s
6V60ns
CC
k
s
V
4V150ns
CC
e
L
s
s
s
e
2.2k, C
CC
V
V
CC
V
100 pF
L
s
6V0.7ms
k
4V1.75ms
CC
s
6V1ms
k
4V2.5ms
CC
Input Pulse Width
Interrupt Input High Time1t
Interrupt Input Low Time1t
Timer Input High Time1t
Timer Input Low Time1t
Reset Pulse Width1ms
Note 4: The output propagation delay is referenced to the end of the instruction cycle where the output change occurs.
c
c
c
c
http://www.national.com5
Comparators AC and DC Characteristics V
CC
e
5V, T
e
25§C
A
ParameterConditionsMinTypMaxUnits
Input Offset Voltage0.4VsV
b
V
CC
1.5V
IN
g
10
s
Input Common Mode Voltage Range0.4V
Low Level Output CurrentV
High Level Output CurrentV
e
0.4V1.6mA
OL
e
4.6V1.6mA
OH
DC Supply Current Per Comparator
(When Enabled)
Response TimeTBD mV Step, TBD mV
Overdrive, 100 pF Load
1ms
g
25mV
b
1.5V
CC
250mA
FIGURE 2. MICROWIRE/PLUS Timing
TL/DD/9765– 7
Pin Descriptions
VCCand GND are the power supply pins.
CKI is the clock input. This can come from an R/C generated oscillator, or a crystal oscillator (in conjunction with
CKO). See Oscillator Description section.
RESET
is the master reset input. See Reset Description
section.
The device contains three bidirectional 8-bit I/O ports (C, G
and L), where each individual bit may be independently configured as an input (Schmitt trigger inputs on ports L and G),
output or TRI-STATE under program control. Three data
memory address locations are allocated for each of these
I/O ports. Each I/O port has two associated 8-bit memory
mapped registers, the CONFIGURATION register and the
output DATA register. A memory mapped address is also
reserved for the input pins of each I/O port. (See the memory map for the various addresses associated with the I/O
ports.)
Figure 3
DATA and CONFIGURATION registers allow for each port
bit to be individually configured under software control as
shown below:
CONFIGURATIONDATA
RegisterRegister
shows the I/O port configurations. The
Port Set-Up
00Hi-Z Input
(TRI-STATE Output)
01Input with Weak Pull-Up
10Push-Pull Zero Output
11Push-Pull One Output
FIGURE 3. I/O Port Configurations
TL/DD/9765– 8
PORT L is an 8-bit I/O port. All L-pins have Schmitt triggers
on the inputs.
The Port L supports Multi-Input Wake Up on all eight pins.
L1 is used for the UART external clock. L2 and L3 are used
for the UART transmit and receive. L4 and L5 are used for
the timer input functions T2A and T2B. L6 and L7 are used
for the timer input functions T3A and T3B.
The Port L has the following alternate features:
L0MIWU
L1MIWU or CKX
L2MIWU or TDX
L3MIWU or RDX
L4MIWU or T2A
L5MIWU or T2B
L6MIWU or T3A
L7MIWU or T3B
Port G is an 8-bit port with 5 I/O pins (G0, G2 –G5), an input
pin (G6), and two dedicated output pins (G1 and G7). Pins
G0 and G2 –G6 all have Schmitt Triggers on their inputs. Pin
G1 serves as the dedicated WDOUT WATCHDOG output,
while pin G7 is either input or output depending on the oscillator mask option selected. With the crystal oscillator option
selected, G7 serves as the dedicated output pin for the CKO
clock output. With the single-pin R/C oscillator mask option
selected, G7 serves as a general purpose input pin but is
also used to bring the device out of HALT mode with a low
to high transition on G7. There are two registers associated
with the G Port, a data register and a configuration register.
Therefore, each of the 5 I/O bits (G0, G2 – G5) can be individually configured under software control.
http://www.national.com6
Pin Descriptions (Continued)
Since G6 is an input only pin and G7 is the dedicated CKO
clock output pin (crystal clock option) or general purpose
input (R/C clock option), the associated bits in the data and
configuration registers for G6 and G7 are used for special
purpose functions as outlined below. Reading the G6 and
G7 data bits will return zeros.
Note that the chip will be placed in the HALT mode by writing a ‘‘1’’ to bit 7 of the Port G Data Register. Similarly the
chip will be placed in the IDLE mode by writing a ‘‘1’’ to bit 6
of the Port G Data Register.
Writing a ‘‘1’’ to bit 6 of the Port G Configuration Register
enables the MICROWIRE/PLUS to operate with the alternate phase of the SK clock. The G7 configuration bit, if set
high, enables the clock start up delay after HALT when the
R/C clock configuration is used.
Config Reg.Data Reg.
G7CLKDLYHALT
G6Alternate SKIDLE
Port G has the following alternate features:
G0 INTR (External Interrupt Input)
G2 T1B (Timer T1 Capture Input)
G3 T1A (Timer T1 I/O)
G4 SO (MICROWIRE
G5 SK (MICROWIRE Serial Clock)
G6 SI (MICROWIRE Serial Data Input)
Port G has the following dedicated functions:
G1 WDOUT WATCHDOG and/or Clock Monitor dedicat-
ed output
G7 CKO Oscillator dedicated output or general purpose
input
Port C is an 8-bit I/O port. The 40-pin device does not have
a full complement of Port C pins. The unavailable pins are
not terminated. A read operation for these unterminated
pins will return unpredicatable values.
PORT I is an eight-bit Hi-Z input port. The 28-pin device
does not have a full complement of Port I pins. The unavailable pins are not terminated i.e., they are floating. A read
operation for these unterminated pins will return unpredictable values. The user must ensure that the software takes
this into account by either masking or restricting the accesses to bit operations. The unterminated Port I pins will draw
power only when addressed.
Port I1–I3 are used for Comparator 1. Port I4 –I6 are used
for Comparator 2.
The Port I has the following alternate features.
I1COMP1
I2COMP1aIN (Comparator 1 Positive Input)
I3COMP1OUT (Comparator 1 Output)
I4COMP2bIN (Comparator 2 Negative Input)
I5COMP2
I6COMP2OUT (Comparator 2 Output)
Port D is an 8-bit output port that is preset high when
RESET
goes low. The user can tie two or more D port out-
puts together in order to get a higher drive.
TM
Serial Data Output)
b
IN (Comparator 1 Negative Input)
a
IN (Comparator 2 Positive Input)
Functional Description
The architecture of the device is modified Harvard architecture. With the Harvard architecture, the control store program memory (ROM) is separated from the data store memory (RAM). Both ROM and RAM have their own separate
addressing space with separate address buses. The architecture, though based on Harvard architecture, permits
transfer of data from ROM to RAM.
CPU REGISTERS
The CPU can do an 8-bit addition, subtraction, logical or
shift operation in one instruction (t
There are six CPU registers:
A is the 8-bit Accumulator Register
PC is the 15-bit Program Counter Register
PU is the upper 7 bits of the program counter (PC)
PL is the lower 8 bits of the program counter (PC)
B is an 8-bit RAM address pointer, which can be optionally
post auto incremented or decremented.
X is an 8-bit alternate RAM address pointer, which can be
optionally post auto incremented or decremented.
SP is the 8-bit stack pointer, which points to the subroutine/
interrupt stack (in RAM). The SP is initialized to RAM address 06F with reset.
S is the 8-bit Data Segment Address Register used to extend the lower half of the address range (00 to 7F) into 256
data segments of 128 bytes each.
All the CPU registers are memory mapped with the exception of the Accumulator (A) and the Program Counter (PC).
PROGRAM MEMORY
The program memory consists of 4096 bytes of ROM.
These bytes may hold program instructions or constant data
(data tables for the LAID instruction, jump vectors for the
JID instruction, and interrupt vectors for the VIS instruction).
The program memory is addressed by the 15-bit program
counter (PC). All interrupts in the devices vector to program
memory location 0FF Hex.
DATA MEMORY
The data memory address space includes the on-chip RAM
and data registers, the I/O registers (Configuration, Data
and Pin), the control registers, the MICROWIRE/PLUS SIO
shift register, and the various registers, and counters associated with the timers (with the exception of the IDLE timer).
Data memory is addressed directly by the instruction or indirectly by the B, X, SP pointers and S register.
The device has 192 bytes of RAM. Sixteen bytes of RAM
are mapped as ‘‘registers’’ at addresses 0F0 to 0FF Hex.
These registers can be loaded immediately, and also decremented and tested with the DRSZ (decrement register and
skip if zero) instruction. The memory pointer registers X, SP,
B and S are memory mapped into this space at address
locations 0FC to 0FF Hex respectively, with the other registers being available for general usage.
The instruction set permits any bit in memory to be set,
reset or tested. All I/O and registers (except A and PC) are
memory mapped; therefore, I/O bits and register bits can be
directly and individually set, reset and tested. The accumulator (A) bits can also be directly and individually tested.
Note: RAM contents are undefined upon power-up.
) cycle time.
c
http://www.national.com7
Data Memory Segment RAM Extension
Data memory address 0FF is used as a memory mapped
location for the Data Segment Address Register (S).
The data store memory is either addressed directly by a
single byte address within the instruction, or indirectly relative to the reference of the B, X, or SP pointers (each contains a single-byte address). This single-byte address allows
an addressing range of 256 locations from 00 to FF hex.
The upper bit of this single-byte address divides the data
store memory into two separate sections as outlined previously. With the exception of the RAM register memory from
address locations 00F0 to 00FF, all RAM memory is memory mapped with the upper bit of the single-byte address being equal to zero. This allows the upper bit of the single-byte
address to determine whether or not the base address
range (from 0000 to 00FF) is extended. If this upper bit
equals one (representing address range 0080 to 00FF),
then address extension does not take place. Alternatively, if
this upper bit equals zero, then the data segment extension
register S is used to extend the base address range (from
0000 to 007F) from XX00 to XX7F, where XX represents the
8 bits from the S register. Thus the 128-byte data segment
extensions are located from addresses 0100 to 017F for
data segment 1, 0200 to 027F for data segment 2, etc., up
to FF00 to FF7F for data segment 255. The base address
range from 0000 to 007F represents data segment 0.
Figure 4
illustrates how the S register data memory extension is used in extending the lower half of the base address
range (00 to 7F hex) into 256 data segments of 128 bytes
each, with a total addressing range of 32 kbytes from XX00
to XX7F. This organization allows a total of 256 data segments of 128 bytes each with an additional upper base segment of 128 bytes. Furthermore, all addressing modes are
available for all data segments. The S register must be
changed under program control to move from one data segment (128 bytes) to another. However, the upper base segment (containing the 16 memory registers, I/O registers,
control registers, etc.) is always available regardless of the
contents of the S register, since the upper base segment
(address range 0080 to 00FF) is independent of data segment extension.
The instructions that utilize the stack pointer (SP) always
reference the stack as part of the base segment (Segment
0), regardless of the contents of the S register. The S register is not changed by these instructions. Consequently, the
stack (used with subroutine linkage and interrupts) is always
located in the base segment. The stack pointer will be intitialized to point at data memory location 006F as a result of
reset.
The 128 bytes of RAM contained in the base segment are
split between the lower and upper base segments. The first
116 bytes of RAM are resident from address 0000 to 006F
in the lower base segment, while the remaining 16 bytes of
RAM represent the 16 data memory registers located at addresses 00F0 to 00FF of the upper base segment. No RAM
is located at the upper sixteen addresses (0070 to 007F) of
the lower base segment.
Additional RAM beyond these initial 128 bytes, however, will
always be memory mapped in groups of 128 bytes (or less)
at the data segment address extensions (XX00 to XX7F) of
the lower base segment. The additional 64 bytes of RAM
(beyond the initial 128 bytes) are memory mapped at address locations 0100 to 013F hex.
*Reads as all ones.
FIGURE 4. RAM Organization
TL/DD/9765– 9
Reset
The RESET input when pulled low initializes the microcontroller. Initialization will occur whenever the RESET
pulled low. Upon initialization, the data and configuration
registers for ports L, G and C are cleared, resulting in these
Ports being initialized to the TRI-STATE mode. Pin G1 of the
G Port is an exception (as noted below) since pin G1 is
dedicated as the WATCHDOG and/or Clock Monitor error
output pin. Port D is set high. The PC, PSW, ICNTRL,
CNTRL, T2CNTRL and T3CNTRL control registers are
cleared. The UART registers PSR, ENU (except that TBMT
bit is set), ENUR and ENUI are cleared. The Comparator
Select Register is cleared. The S register is initialized to
zero. The Multi-Input Wakeup registers WKEN, WKEDG and
WKPND are cleared. The stack pointer, SP, is initialized to
6F Hex.
The device comes out of reset with both the WATCHDOG
logic and the Clock Monitor detector armed, with the
WATCHDOG service window bits set and the Clock Monitor
bit set. The WATCHDOG and Clock Monitor circuits are inhibited during reset. The WATCHDOG service window bits
being initialized high default to the maximum WATCHDOG
service window of 64k t
being initialized high will cause a Clock Monitor error following reset if the clock has not reached the minimum specified
frequency at the termination of reset. A Clock Monitor error
will cause an active low error output on pin G1. This error
output will continue until 16 t
the clock frequency reaching the minimum specified value,
at which time the G1 output will enter the TRI-STATE mode.
The external RC network shown in
to ensure that the RESET
supply to the chip stabilizes.
clock cycles. The Clock Monitor bit
C
–32 tCclock cycles following
C
Figure 5
pin is held low until the power
input is
should be used
http://www.national.com8
Reset (Continued)
RCl5cPower Supply Rise Time
FIGURE 5. Recommended Reset Circuit
TL/DD/9765– 10
Oscillator Circuits
The chip can be driven by a clock input on the CKI input pin
which can be between DC and 10 MHz. The CKO output
clock is on pin G7 (crystal configuration). The CKI input frequency is divided down by 10 to produce the instruction
cycle clock (1/t
Figure 6
CRYSTAL OSCILLATOR
CKI and CKO can be connected to make a closed loop
crystal (or resonator) controlled oscillator.
Table A shows the component values required for various
standard crystal values.
R/C OSCILLATOR
By selecting CKI as a single pin oscillator input, a single pin
R/C oscillator circuit can be connected to it. CKO is available as a general purpose input, and/or HALT restart input.
Table B shows the variation in the oscillator frequencies as
functions of the component (R and C) values.
).
c
shows the Crystal and R/C diagrams.
TL/DD/9765– 12
TABLE A. Crystal Oscillator Configuration, T
R1R2C1C2CKI Freq
(kX)(MX) (pF)(pF)(MHz)
013030 –3610V
013030 –364V
01200 100–1500.455V
TABLE B. RC Oscillator Configuration, T
RCCKI FreqInstr. Cycle
(kX)(pF)(MHz)(ms)
3.3822.2 to 2.73.7 to 4.6V
5.61001.1 to 1.37.4 to 9.0V
6.81000.9 to 1.18.8 to 10.8V
Note: 3ksRs200k
50 pF
sCs
200 pF
e
25§C
A
Conditions
e
5V
CC
e
5.0V
CC
e
5V
CC
e
25§C
A
Conditions
e
5V
CC
e
5V
CC
e
5V
CC
Control Registers
CNTRL Register (Address XÊ00EE)
The Timer1 (T1) and MICROWIRE/PLUS control register
contains the following bits:
SL1 & SL0 Select the MICROWIRE/PLUS clock divide
IEDGExternal interrupt edge polarity select
MSELSelects G5 and G4 as MICROWIRE/PLUS
T1C0Timer T1 Start/Stop control in timer
T1C1Timer T1 mode control bit
T1C2Timer T1 mode control bit
T1C3Timer T1 mode control bit
T1C3 T1C2 T1C1 T1C0 MSEL IEDG SL1SL0
Bit 7Bit 0
e
by (00
(0
2, 01e4, 1xe8)
e
Rising edge, 1eFalling edge)
signals SK and SO respectively
modes 1 and 2
Timer T1 Underflow Interrupt Pending Flag in
timer mode 3
FIGURE 6. Crystal and R/C Oscillator Diagrams
TL/DD/9765– 11
http://www.national.com9
Control Registers (Continued)
PSW Register (Address X
The PSW register contains the following select bits:
GIEGlobal interrupt enable (enables interrupts)
EXENEnable external interrupt
BUSYMICROWIRE/PLUS busy shifting flag
EXPND External interrupt pending
T1ENA Timer T1 Interrupt Enable for Timer Underflow
or T1A Input capture edge
T1PNDA Timer T1 Interrupt Pending Flag (Autoreload RA
in mode 1, T1 Underflow in Mode 2, T1A capture edge in mode 3)
CCarry Flag
HCHalf Carry Flag
HC C T1PNDA T1ENA EXPND BUSY EXEN GIE
Bit 7Bit 0
The Half-Carry bit is also affected by all the instructions that
affect the Carry flag. The SC (Set Carry) and RC (Reset
Carry) instructions will respectively set or clear both the carry flags. In addition to the SC and RC instructions, ADC,
SUBC, RRC and RLC instructions affect the carry and Half
Carry flags.
ICNTRL Register (Address X
The ICNTRL register contains the following bits:
T1ENB Timer T1 Interrupt Enable for T1B Input capture
edge
T1PNDB Timer T1 Interrupt Pending Flag for T1B cap-
ture edge
mWENEnable MICROWIRE/PLUS interrupt
mWPND MICROWIRE/PLUS interrupt pending
T0ENTimer T0 Interrupt Enable (Bit 12 toggle)
T0PND Timer T0 Interrupt pending
LPENL Port Interrupt Enable (Multi-Input Wakeup/In-
terrupt)
Bit 7 could be used as a flag
Unused LPEN T0PND T0EN mWPND mWEN T1PNDB T1ENB
Bit 7Bit 0
T2CNTRL Register (Address XÊ00C6)
The T2CNTRL register contains the following bits:
T2ENB Timer T2 Interrupt Enable for T2B Input capture
edge
T2PNDB Timer T2 Interrupt Pending Flag for T2B cap-
ture edge
T2ENA Timer T2 Interrupt Enable for Timer Underflow
or T2A Input capture edge
T2PNDA Timer T2 Interrupt Pending Flag (Autoreload RA
in mode 1, T2 Underflow in mode 2, T2A capture edge in mode 3)
T2C0Timer T2 Start/Stop control in timer modes 1
and 2 Timer T2 Underflow Interrupt Pending
Flag in timer mode 3
00EF)
Ê
00E8)
Ê
T2C1Timer T2 mode control bit
T2C2Timer T2 mode control bit
T2C3Timer T2 mode control bit
T2C3 T2C2 T2C1 T2C0 T2PNDA T2ENA T2PNDB T2ENB
Bit 7Bit 0
T3CNTRL Register (Address XÊ00B6)
The T3CNTRL register contains the following bits:
T3ENB Timer T3 Interrupt Enable for T3B
T3PNDB Timer T3 Interrupt Pending Flag for T3B pin
T3ENA Timer T3 Interrupt Enable for Timer Underflow
T3PNDA Timer T3 Interrupt Pending Flag (Autoload RA
T3C0Timer T3 Start/Stop control in timer modes 1
T3C1Timer T3 mode control bit
T3C2Timer T3 mode control bit
T3C3Timer T3 mode control bit
T3C3 T3C2 T3C1 T3C0 T3PNDA T3ENA T3PNDB T3ENB
Bit 7Bit 0
(T3B capture edge)
or T3A pin
in mode 1, T3 Underflow in mode 2, T3a capture edge in mode 3)
and 2
Timer T3 Underflow Interrupt Pending Flag in
timer mode 3
Timers
The device contains a very versatile set of timers (T0, T1,
T2, T3). All timers and associated autoreload/capture registers power up containing random data.
TIMER T0 (IDLE TIMER)
The device supports applications that require maintaining
real time and low power with the IDLE mode. This IDLE
mode support is furnished by the IDLE timer T0, which is a
16-bit timer. The Timer T0 runs continuously at the fixed
rate of the instruction cycle clock, t
or write to the IDLE Timer T0, which is a count down timer.
The Timer T0 supports the following functions:
Exit out of the Idle Mode (See Idle Mode description)
WATCHDOG logic (See WATCHDOG description)
Start up delay out of the HALT mode
The IDLE Timer T0 can generate an interrupt when the thirteenth bit toggles. This toggle is latched into the T0PND
pending flag, and will occur every 4 ms at the maximum
clock frequency (t
interrupt from the thirteenth bit of Timer T0 to be enabled or
disabled. Setting T0EN will enable the interrupt, while resetting it will disable the interrupt.
e
1 ms). A control flag T0EN allows the
c
. The user cannot read
c
http://www.national.com10
Timers (Continued)
TIMER T1, TIMER T2 AND TIMER T3
The device has a set of three powerful timer/counter
blocks, T1, T2 and T3. The associated features and functioning of a timer block are described by referring to the
timer block Tx. Since the three timer blocks, T1, T2 and T3
are identical, all comments are equally applicable to any of
the three timer blocks.
Each timer block consists of a 16-bit timer, Tx, and two
supporting 16-bit autoreload/capture registers, RxA and
RxB. Each timer block has two pins associated with it, TxA
and TxB. The pin TxA supports I/O required by the timer
block, while the pin TxB is an input to the timer block. The
powerful and flexible timer block allows the device to easily
perform all timer functions with minimal software overhead.
The timer block has three operating modes: Processor Independent PWM mode, External Event Counter mode, and
Input Capture mode.
The control bits TxC3, TxC2, and TxC1 allow selection of
the different modes of operation.
Mode 1. Processor Independent PWM Mode
As the name suggests, this mode allows the device to generate a PWM signal with very minimal user intervention. The
user only has to define the parameters of the PWM signal
(ON time and OFF time). Once begun, the timer block will
continuously generate the PWM signal completely independent of the microcontroller. The user software services the
timer block only when the PWM parameters require updating.
In this mode the timer Tx counts down at a fixed rate of t
Upon every underflow the timer is alternately reloaded with
the contents of supporting registers, RxA and RxB. The very
first underflow of the timer causes the timer to reload from
the register RxA. Subsequent underflows cause the timer to
be reloaded from the registers alternately beginning with the
register RxB.
The Tx Timer control bits, TxC3, TxC2 and TxC1 set up the
timer for PWM mode operation.
Figure 7
shows a block diagram of the timer in PWM mode.
The underflows can be programmed to toggle the TxA output pin. The underflows can also be programmed to generate interrupts.
Underflows from the timer are alternately latched into two
pending flags, TxPNDA and TxPNDB. The user must reset
these pending flags under software control. Two control enable flags, TxENA and TxENB, allow the interrupts from the
timer underflow to be enabled or disabled. Setting the timer
enable flag TxENA will cause an interrupt when a timer underflow causes the RxA register to be reloaded into the timer. Setting the timer enable flag TxENB will cause an interrupt when a timer underflow causes the RxB register to be
reloaded into the timer. Resetting the timer enable flags will
disable the associated interrupts.
Either or both of the timer underflow interrupts may be enabled. This gives the user the flexibility of interrupting once
per PWM period on either the rising or falling edge of the
PWM output. Alternatively, the user may choose to interrupt
on both edges of the PWM output.
FIGURE 7. Timer in PWM Mode
Mode 2. External Event Counter Mode
This mode is quite similar to the processor independent
PWM mode described above. The main difference is that
the timer, Tx, is clocked by the input signal from the TxA pin.
The Tx timer control bits, TxC3, TxC2 and TxC1 allow the
timer to be clocked either on a positive or negative edge
from the TxA pin. Underflows from the timer are latched into
the TxPNDA pending flag. Setting the TxENA control flag
will cause an interrupt when the timer underflows.
In this mode the input pin TxB can be used as an independent positive edge sensitive interrupt input if the TxENB
control flag is set. The occurrence of a positive edge on the
TxB input pin is latched into the TxPNDB flag.
.
c
Figure 8
shows a block diagram of the timer in External
Event Counter mode.
Note: The PWM output is not available in this mode since the TxA pin is
being used as the counter input clock.
FIGURE 8. Timer in External Event Counter Mode
Mode 3. Input Capture Mode
The device can precisely measure external frequencies or
time external events by placing the timer block, Tx, in the
input capture mode.
In this mode, the timer Tx is constantly running at the fixed
t
rate. The two registers, RxA and RxB, act as capture
c
registers. Each register acts in conjunction with a pin. The
register RxA acts in conjunction with the TxA pin and the
register RxB acts in conjunction with the TxB pin.
TL/DD/9765– 14
TL/DD/9765– 15
http://www.national.com11
Timers (Continued)
The timer value gets copied over into the register when a
trigger event occurs on its corresponding pin. Control bits,
TxC3, TxC2 and TxC1, allow the trigger events to be specified either as a positive or a negative edge. The trigger condition for each input pin can be specified independently.
The trigger conditions can also be programmed to generate
interrupts. The occurrence of the specified trigger condition
on the TxA and TxB pins will be respectively latched into the
pending flags, TxPNDA and TxPNDB. The control flag
TxENA allows the interrupt on TxA to be either enabled or
disabled. Setting the TxENA flag enables interrupts to be
generated when the selected trigger condition occurs on the
TxA pin. Similarly, the flag TxENB controls the interrupts
from the TxB pin.
Underflows from the timer can also be programmed to generate interrupts. Underflows are latched into the timer TxC0
pending flag (the TxC0 control bit serves as the timer underflow interrupt pending flag in the Input Capture mode). Consequently, the TxC0 control bit should be reset when entering the Input Capture mode. The timer underflow interrupt is
enabled with the TxENA control flag. When a TxA interrupt
occurs in the Input Capture mode, the user must check both
the TxPNDA and TxC0 pending flags in order to determine
whether a TxA input capture or a timer underflow (or both)
caused the interrupt.
Figure 9
shows a block diagram of the timer in Input Capture
mode.
FIGURE 9. Timer in Input Capture Mode
TL/DD/9765– 16
TIMER CONTROL FLAGS
The timers T1, T2 and T3 have indentical control structures.
The control bits and their functions are summarized below.
TxC0Timer Start/Stop control in Modes 1 and 2
(Processor Independent PWM and External
Event Counter), where 1
e
Start, 0eStop
Timer Underflow Interrupt Pending Flag in
Mode 3 (Input Capture)
TxPNDA Timer Interrupt Pending Flag
TxPNDB Timer Interrupt Pending Flag
TxENA Timer Interrupt Enable Flag
TxENB Timer Interrupt Enable Flag
e
1
Timer Interrupt Enabled
e
0
Timer Interrupt Disabled
TxC3Timer mode control
TxC2Timer mode control
TxC1Timer mode control
http://www.national.com12
Timers (Continued)
The timer mode control bits (TxC3, TxC2 and TxC1) are detailed below:
The device offers the user two power save modes of operation: HALT and IDLE. In the HALT mode, all microcontroller
activities are stopped. In the IDLE mode, the on-board oscillator circuitry the WATCHDOG logic, the Clock Monitor and
timer T0 are active but all other microcontroller activities are
stopped. In either mode, all on-board RAM, registers, I/O
states, and timers (with the exception of T0) are unaltered.
HALT MODE
The device can be placed in the HALT mode by writing a
‘‘1’’ to the HALT flag (G7 data bit). All microcontroller activities, including the clock and timers, are stopped. The
WATCHDOG logic is disabled during the HALT mode. However, the clock monitor circuitry if enabled remains active
and will cause the WATCHDOG output pin (WDOUT) to go
low. If the HALT mode is used and the user does not want
to activate the WDOUT pin, the Clock Monitor should be
disabled after the device comes out of reset (resetting the
Clock Monitor control bit with the first write to the WDSVR
register). In the HALT mode, the power requirements of the
device are minimal and the applied voltage (V
decreased to V
machine.
e
2.0V) without altering the state of the
r(Vr
The device supports three different ways of exiting the
HALT mode. The first method of exiting the HALT mode is
with the Multi-Input Wakeup feature on the L port. The second method is with a low to high transition on the CKO (G7)
pin. This method precludes the use of the crystal clock con-
) may be
CC
figuration (since CKO becomes a dedicated output), and so
may be used with an RC clock configuration. The third
method of exiting the HALT mode is by pulling the RESET
pin low.
Since a crystal or ceramic resonator may be selected as the
oscillator, the Wakeup signal is not allowed to start the chip
running immediately since crystal oscillators and ceramic
resonators have a delayed start up time to reach full amplitude and frequency stability. The IDLE timer is used to generate a fixed delay to ensure that the oscillator has indeed
stabilized before allowing instruction execution. In this case,
upon detecting a valid Wakeup signal, only the oscillator
circuitry is enabled. The IDLE timer is loaded with a value of
256 and is clocked with the t
clock is derived by dividing the oscillator clock down by a
instruction cycle clock. The t
c
factor of 10. The Schmitt trigger following the CKI inverter
on the chip ensures that the IDLE timer is clocked only
when the oscillator has a sufficiently large amplitude to
meet the Schmitt trigger specifications. This Schmitt trigger
is not part of the oscillator closed loop. The startup timeout
from the IDLE timer enables the clock signals to be routed
to the rest of the chip.
If an RC clock option is being used, the fixed delay is introduced optionally. A control bit, CLKDLY, mapped as configuration bit G7, controls whether the delay is to be introduced or not. The delay is included if CLKDLY is set, and
excluded if CLKDLY is reset. The CLKDLY bit is cleared on
reset.
http://www.national.com13
c
Loading...
+ 30 hidden pages
You need points to download manuals.
1 point = 1 manual.
You can buy points or you can get point for every manual you upload.