COP87L84BC
8-Bit CMOS OTP Microcontrollers with 16k Memory,
Comparators, and CAN Interface
General Description
The COP87L84BC OTP (One Time Programmable) microcontrollers are highly integrated COP8
vices with 16k OTP EPROM memory and advanced features
including a CAN 2.0B (passive) interface and two Analog
comparators. These multi-chip CMOS devices are suited for
applications requiring a full featured controller with a CAN interface, and 8-bit 39 kHz PWM timer, and as pre-production
devices for a masked ROM design. Pin and software compatible 2k ROM versions are available (COP884BC) with a
range of COP8 software and hardware development tools.
™
Feature core de-
September 1999
Features include an 8-bit memory mapped architecture, 10
MHz CKI (-XE=crystal oscillator) with 1µs instruction cycle,
one multi-function 16-bit timer/counter, 8-bit 39 kHz PWM
timer with 2 outputs, CAN 2.0B (passive) interface,
MICROWIRE/PLUS
two power saving HALT/IDLE modes, idle timer, MIWU, software selectable I/O options, low EMI 4.5V to 5.5V operation,
and 28 pin packages.
Note: The companion devices with CAN interface, more I/O
and memory, A/D, and USART are the COP87L88EB/RB.
Device included in this datasheet is:
™
serial I/O, two Analog comparators,
COP87L84BC 8-Bit CMOS OTP Microcontrollers with 16k Memory, Comparators, and CAN
18
CAN Tx0O15
CAN Tx1O14
CAN Rx0IMIWU17
CAN Rx1IMIWU16
V
CC
6
GND23
CKII5
RESET
I24
www.national.com2
Absolute Maximum Ratings (Note 1)
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−0.3V to V
)6V
CC
CC
+0.3V
Total Current into V
Pin (Source)90 mA
CC
Total Current out of GND Pin (Sink)100 mA
Storage Temperature Range−65˚C to +150˚C
Note 1: Absolute maximum ratings indicate limits beyond which damage to
the device may occur. DC and AC electrical specifications are not ensured
when operating the device at absolute maximum ratings.
DC Electrical Characteristics
−40˚C ≤ TA≤ +85˚C
ParameterConditionsMinTypMaxUnits
Operating Voltage4.55.5V
Power Supply Ripple (Note 2)Peak-to-Peak0.1 V
Supply Current
CKI = 10 MHz (Note 3)V
HALT Current (Notes 4, 5)V
= 5.5V, tc=1µs19mA
CC
= 5.5V, CKI=0MHz
CC
Power-On Reset Enabled480µA
Power-On Reset Disabled380µA
IDLE Current (Note 5)
CKI = 10 MHzV
Input Levels (V
IH,VIL
)
= 5.5V, tc= 1 µs5.5mA
CC
Reset, CKI
Logic High0.8 V
CC
Logic Low0.2 V
All Other Inputs
Logic High0.7 V
CC
Logic Low0.2 V
Hi-Z Input LeakageV
Input Pull-up CurrentV
G and L Port Input Hysteresis0.05 V
= 5.5V
CC
= 5.5V, VIN= 0V−40−250µA
CC
CC
Output Current Levels D Outputs
SourceV
SinkV
= 4.5V, VOH= 3.3V−0.4mA
CC
= 4.5V, VOL= 1.0V10mA
CC
Comparator Output (L2, L6)
Source (Push-Pull)V
Sink (Push-Pull)V
= 4.5V, VOH= 3.3V−1.6mA
CC
= 4.5V, VOL= 0.4V1.6mA
CC
CAN Transmitter Outputs
Source (Tx1)V
Sink (Tx0)V
= 4.5V, VOH=VCC− 0.1V−1.5mA
CC
V
= 4.5V, VOH=VCC− 0.6V−10mA
CC
= 4.5V, VOL= 0.1V1.5mA
CC
V
= 4.5V, VOL= 0.6V10mA
CC
All Others
Source (Weak Pull-Up)V
Source (Push-Pull)V
Sink (Push-Pull)V
TRl-STATE LeakageV
= 4.5V, VOH= 2.7V−10−110µA
CC
= 4.5V, VOH= 3.3V−0.4mA
CC
= 4.5V, VOL= 0.4V1.6mA
CC
= 5.5V
CC
Allowable Sink/Source Current per
Pin
D Outputs (Sink)15mA
Tx0 (Sink)30mA
Tx1 (Source)
All Other
CC
CC
CC
±
2µA
±
2.0µA
30
3
V
V
V
V
V
V
mA
mA
www.national.com3
DC Electrical Characteristics (Continued)
−40˚C ≤ TA≤ +85˚C
ParameterConditionsMinTypMaxUnits
Maximum Input Current
without LatchupRoom Temp
RAM Retention Voltage, V
r
500 ns Rise and Fall Time2.0V
Input Capacitance7pF
Load Capacitance on D21000pF
Note 2: Maximum rate of voltage change must be less than 0.5 V/ms
Note 3: Supply current is measured after running 2000 cycles with a square wave CKI input, CKO open, inputs at V
Note 4: The HALTmode will stop CKI from oscillating in the Crystal configurations. Halt test conditions: All inputs tied to V
and programmed low; D outputs programmed low. Parameter refers to HALT mode entered via setting bit 7 of the G Port data register. Part will pull up CKI during
HALT in crystal clock mode.
Note 5: HALT and IDLE current specifications assume CAN block and comparators are disabled.
or GND, and outputs open.
CC
; L, and G port I/Os configured as outputs
CC
±
100mA
www.national.com4
Absolute Maximum Ratings (Note 1)
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−0.3V to V
)6V
CC
CC
+0.3V
Total Current into V
Pin (Source)90 mA
CC
Total Current out of GND Pin (Sink)100 mA
Storage Temperature Range−65˚C to +150˚C
Note 6: Absolute maximum ratings indicate limits beyond which damage to
the device may occur. DC and AC electrical specifications are not ensured
when operating the device at absolute maximum ratings.
AC Electrical Characteristics:
−40˚C ≤ TA≤ +85˚C
ParameterConditionsMinTypMaxUnits
Instruction Cycle Time (t
Crystal/ResonatorV
Inputs
t
SETUP
t
HOLD
PWM Capture Input
t
SETUP
t
HOLD
Output Propagation Delay
(t
)C
PD1,tPD0
SK, SOV
PWM OutputsV
All OthersV
MICROWIRE
Setup Time (t
Hold Time (t
UWS
UWH
Output Prop Delay (t
Input Pulse Width
Interrupt High Time1t
Interrupt Low Time1t
Timer 1,2 High Time1t
Timer 1,2 Low Time1t
Reset Pulse Width1.0µs
Power Supply Rise Time for Proper50 µs256*t
Operation of On-Chip RESET
Note 7: For device testing purposes of all AC parameters, VOHwill be tested at 0.5*VCC.
Note 8: The output propagation delay is referenced to the end of the instruction cycle where the output change occurs.
Note 9: Parameter not tested.
Note 10: t
= Instruction Cycle Time.
c
)
c
≥ 4.5V1.0DCµs
CC
VCC≥ 4.5V200ns
VCC≥ 4.5V60ns
VCC≥ 4.5V30ns
VCC≥ 4.5V70ns
= 100 pF, RL= 2.2 kΩ
L
≥ 4.5V0.7µs
CC
≥ 4.5V75ns
CC
≥ 4.5V1µs
CC
)20ns
)56ns
)220ns
UPD
c
c
c
c
c
On-Chip Voltage Reference:
−40˚C ≤ TA≤ +85˚C
ParameterConditionsMinMaxUnits
<
Reference VoltageI
V
REF
Reference Supply Current,I
I
DD
Note 11: Reference supply IDDis supplied for information purposes only, it is not tested.
80 µA,0.5 VCC−0.120.5 VCC+0.12V
OUT
VCC=5V
= 0A, (No Load)120µA
OUT
VCC= 5V (Note 11)
www.national.com5
Comparator DC/AC Characteristics:
4.5V ≤ VCC≤ 5.5V, −55˚C ≤ TA≤ +125˚C
ParameterConditionsMinTypMaxUnits
<
<
V
Input Offset Voltage0.4V
IN
VCC−1.5V
Input Common Mode Voltage Range0.4V
±
10
±
25mV
−1.5V
CC
Voltage Gain300kV/V
Outputs Sink/SourceSee I/O-Port DC Specifications
DC Supply Current (when enabled)V
= 6.0V250µA
CC
Response TimeTBD mV Step, TBD mV Overdrive,1µs
100 pF Load
CAN Comparator DC and AC Characteristics:
4.8V ≤ VCC≤ 5.2V, −40˚C ≤ TA≤ +125˚C
ParametersConditionsMinTypMaxUnits
±
Differential Input Voltage
<
Input Offset Voltage1.5V
V
IN
<
VCC− 1.5V
Input Common Mode Voltage Range1.5V
Input Hysteresis8mV
25mV
±
10mV
− 1.5V
CC
DS101137-3
FIGURE 3. MICROWIRE/PLUS Timing Diagram
DS101137-4
FIGURE 4. PWM/CAPTURE Timer
Input/Output Timing Diagram
www.national.com6
Typical Performance Characteristics −55˚C ≤ T
Port D Source Current
Port D Sink Current
≤ +125˚C
A
Ports G/L Source Current
Ports G/L Weak Pull-Up Source Current
DS101137-39
DS101137-41
Port G/L Sink Current
Dynamic IDDvs V
CC
DS101137-40
DS101137-42
DS101137-43
DS101137-44
www.national.com7
Typical Performance Characteristics −55˚C ≤ T
Idle I
vs V
DD
CC
Halt Supply Current
≤ +125˚C (Continued)
A
DS101137-45
CAN Tx0 Sink Current
DS101137-47
Pin Descriptions
VCCand GND are the power supply pins.
CKI is the clock input. The clockcan come from a crystalos-
cillator (in conjunction with CKO). See Oscillator Description
section.
RESET is the master reset input. See Reset Description section.
The device contains one bidirectional 8-bit I/O port (G), and
one 7-bit bidirectional I/O port (L) where each individual bit
may be independently configured as an input (Schmitt trigger inputs on ports G and L), output or TRI-STATE
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 5
shows the I/O port configurations for the device. The DATAand CONFIGURATION
registers allow for each port bit to be individually configured
under software control as shown below:
®
under
DS101137-46
CAN Tx1 Source Current
DS101137-48
ConfigurationData
RegisterRegister
Port Set-Up
00Hi-Z Input (TRI-STATE
Output)
01Input with Weak Pull-Up
10Push-Pull Zero Output
11Push-Pull One Output
PORT L is a 7-bit I/O port. All L-pins have Schmitt triggers on
the inputs.
Port L supports Multi-Input Wake Up (MIWU) on all seven
pins.
Port L has the following alternate features:
L6 MIWU or CMP2OUT or PWM0 or CAPTIN
L5 MIWU or CMP2IN− or PWM1
L4 MIWU or CMP2IN+
L3 MIWU or CMP2IN−
L2 MIWU or CMP1OUT
L1 MIWU or CMP1IN−
L0 MIWU or CMP1IN+
Port G is an 8-bit port with 5 I/O pins (G0–G5), an input pin
(G6), and one dedicated output pin (G7). Pins G0–G6 all
have Schmitt Triggerson their inputs. G7 serves as the dedicated output pin for the CKO clock output. There are two reg-
www.national.com8
Pin Descriptions (Continued)
isters associated with the G Port, a data register and a configuration register. Therefore, each of the 6 I/O bits (G0–G5)
can be individually configured under software control.
Since G6 is an input only pin and G7 is the dedicated CKO
clock output pin 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 zeroes.
Note that the chip will be placed in the HALT mode bywriting
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” tobit 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.
Config. RegisterData Register
G7HALT
G6Alternate SKIDLE
CAN pins: For the on-chip CAN interface thisdevice has five
dedicated pins with the following features:
V
On-chip reference voltage with the value of VCC/2
REF
Rx0CAN receive data input pin.
Rx1CAN receive data input pin.
Tx0CAN transmit data output pin. This pin may beput in
the TRI-STATE mode with the TXEN0 bit in the CAN
Bus control register.
Tx1CAN transmit data output pin. This pin may beput in
the TRI-STATE mode with the TXEN1 bit in the CAN
Bus control register.
Port G has the following alternate features:
G6 SI (MICROWIRE Serial Data Input)
G5 SK (MICROWIRE Serial Clock)
G4 SO (MICROWIRE Serial Data Output)
G3 T1A (Timer T1 I/O)
G2 T1B (Timer T1 Capture Input)
G0 INTR (External Interrupt Input)
Port G has the following dedicated function:
G7 CKO Oscillator dedicated output
Port D is a 4-bit output port that is preset high when RESET
goes low. The user can tie two or more D port outputs (except D2) together in order to get a higher drive.
Note: Care must be exercised with the D2 pin operation. At RESET, the ex-
ternal loads on this pin must ensure that the output voltages stay
above 0.8 V
keep the external loading on D2 to less than 1000 pF.
to prevent the chip from entering special modes. Also
CC
DS101137-5
FIGURE 5. I/O Port Configurations
Functional Description
The architecture of the device utilizes a modifiedHarvard 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 five 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 02F with reset.
All the CPU registers are memory mapped with the exception of the Accumulator (A) and the Program Counter (PC).
PROGRAM MEMORY
Program memory for the device consists of 16 kbytes of OTP
EPROM. These bytes may hold program instructions or constant data (data tables tor 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 device vector to
program memory location 0FF Hex.
The device can be configured to inhibit external reads of the
program memory. This is done by programming the Security
Byte.
SECURITY FEATURE
The program memory array has an associate Security Byte
that is located outside of the program address range. This
byte can be addressed only from programming mode by a
programmer tool.
) cycle time.
c
www.national.com9
Functional Description (Continued)
Security is an optional feature and can only be asserted after
the memory array has been programmed and verified. A secured part will read all 00(hex) by a programmer. The part
will fail Blank Check and will fail Verify operations. A Read
operation will fill the programmer’s memory with 00(hex).
The Security Byte itself is always readable with value of
00(hex) if unsecure and FF(hex) if secure.
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 and SP pointers.
The device has 64 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, and B
are memory mapped into this space at address locations
0FC to 0FE Hex respectively, with the other registers (other
than reserved register 0FF) being available for general usage.
The instruction set permits any bit in memory to beset, 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.
RESET
The RESET input when pulled low initializes the microcontroller. lnitialization will occur whenever the RESET input is
pulled low. Upon initialization, the data and configuration
registers for Ports L and G, are cleared, resulting in these
Ports being initialized to the TRI-STATE mode. Port D is initialized high with RESET. The PC, PSW, CNTRL, and ICNTRL control registers are cleared. The Multi-Input Wake Up
registers WKEN, WKEDG, and WKPND are cleared. The
Stack Pointer, SP, is initialized to 02F Hex.
The following initializations occur with RESET:
Port L: TRI-STATE
Port G: TRI-STATE
Port D: HIGH
PC: CLEARED
PSW, CNTRL and ICNTRL registers: CLEARED
Accumulator and Timer 1:
RANDOM after RESET with power already applied
RANDOM after RESET at power-on
SP (Stack Pointer): Loaded with 2F Hex
CMPSL (Comparator control register): CLEARED
PWMCON (PWM control register): CLEARED
B and X Pointers:
UNAFFECTED after RESET with power already applied
RANDOM after RESET at power-up
RAM:
UNAFFECTED after RESET with power already applied
RANDOM after RESET at power-up
CAN:
The CAN Interface comes out of external reset in the
“error-active” state and waits until the user’s software
sets either one or both of the TXEN0, TXEN1 bits to “1”.
After that, the device will not start transmission or reception of a frame until eleven consecutive “recessive” (undriven) bits have been received. This is done to ensure
that the output drivers are not enabled during an active
message on the bus.
CSCAL, CTlM, TCNTL, TEC, REC: CLEARED
RTSTAT: CLEARED with the exception of the TBE bit
which is set to 1
RID, RIDL, TID, TDLC: RANDOM
ON-CHIP POWER-ON RESET
The device is designed with an on-chip power-on reset circuit which will trigger a 256 t
minimum RAM retention voltage (V
oscillator to stabilize before the device exits the reset state.
delay as VCCrises above the
c
). This delay allows the
r
The contents of data registers and RAM are unknown following an on-chip power-on reset. The external reset takes priority over the on-chip reset and will deactivate the 256 t
lay if in progress.
de-
c
When using external reset, the external RC network shown
in
Figure 6
should be used to ensure that the RESET pin is
held low until the power supply to the chip stabilizes.
Under no circumstances should the RESET pin be allowed
to float. If the on-chip power-on reset feature is being used,
RESET should be connected directly to V
the Power Supply Rise Time requirements specified in the
. Be aware of
CC
DC Specifications Table. These requirements must be met
for the on-chip power-on reset to function properly.
The on-chip power-on reset circuit may reset the device if
the operating voltage (V
RC>5 x Power Supply Rise Time
) goes below Vr.
CC
DS101137-6
FIGURE 6. Recommended Reset Circuit
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. The CKI input frequency is divided by 10
to produce the instruction cycle clock (1/t
Figure 7
shows the Crystal diagram.
).
c
www.national.com10
Oscillator Circuits (Continued)
DS101137-7
FIGURE 7. Crystal Oscillator Diagram
CRYSTAL OSCILLATOR
CKI and CKO can be connected to make a closedloop crystal (or resonator) controlled oscillator.
Table 1
shows the component values required for various
standard crystal values.
TABLE 1. Crystal Oscillator Configuration, T
R1R2C1C2CKI Freq.
(kΩ)(MΩ) (pF)(pF)(MHz)
013030–3610V
013030–364V
01200 100–1500.455V
= 25˚C
A
Conditions
=5V
CC
=5V
CC
=5V
CC
T1ENATimer T1 Interrupt Enable for Timer Underflow
The Half-Carry flag is also affected by all the instructions that
affect the Carry flag. The SC (Set Carry) and R/C (Reset
Carry) instructions will respectively set or clear both the carry
flags. In addition to the SC and R/C instructions, ADC,
SUBC, RRC and RLC instructions affect the Carry and Half
Carry flags.
ICNTRL Register (Address X'00E8)
Reserved LPEN T0PND T0EN µWPND µWEN T1PNDB T1ENB
Bit 7Bit 0
The ICNTRL register contains the following bits:
Reserved This bit is reserved and must be zero.
LPENL Port Interrupt Enable (Multi-Input Wakeup/
ture edge
T1ENBTimer T1 Interrupt Enable for T1B Input cap-
ture edge
Control Registers
CNTRL Register (Address X'00EE)
T1C3 T1C2 T1C1 T1C0 MSEL IEDGSL1SL0
Bit 7Bit 0
The Timer1 (T1) and MICROWIRE/PLUS control register
contains the following bits:
T1C3Timer T1 mode control bit
T1C2Timer T1 mode control bit
T1C1Timer T1 mode control bit
T1C0Timer T1 Start/Stop control in timer
modes 1 and 2, T1 Underflow Interrupt
Pending Flag in timer mode 3
MSELSelects G5 and G4 as MICROWIRE/PLUS
signals SK and SO respectively
IEDGExternal interrupt edge polarity select
(0 = Rising edge, 1 = Falling edge)
SL1 & SL0 Select the MICROWIRE/PLUS clock divide
by (00 = 2, 01 = 4, 1x = 8)
PSW Register (Address X'00EF)
HC C T1PNDA T1ENA EXPND BUSY EXEN GIE
Bit 7Bit 0
The PSW register contains the following select bits:
HCHalf Carry Flag
CCarry Flag
T1PNDA Timer T1 Interrupt Pending Flag (Autoreload
RA in mode 1, T1 Underflow in Mode 2, T1A
capture edge in mode 3)
Timers
The device contains a very versatile set of timers (T0, T1,
and an 8-bit PWM timer). All timers and associated
autoreload/capture registers power up containing random
data.
Figure 8
shows a block diagram for timers T1 and T0 on the
device.
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
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)
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.096 ms at the maximum
clock frequency (t
terrupt from the thirteenth bit of Timer T0 to be enabled or
= 1 µs). A control flag T0EN allows the in-
c
disabled. Setting T0EN will enable the interrupt, while resetting it will disable the interrupt.
TIMER T1
The device has a powerful timer/counter block, T1.
The timer block consists of a 16-bit timer, T1, and two sup-
porting 16-bit autoreload/capture registers, R1A and R1B.
The timer block has two pins associated with it, T1A and
T1B. The pin T1A supports I/O required by the timer block,
. The user cannot read or
c
www.national.com11
Timers (Continued)
while the pin T1B 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 T1C3, T1C2, and T1C1 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 T1 counts down at a fixed rate of t
Upon every underflow the timer is alternately reloaded with
the contents of supporting registers, R1Aand R1B. The very
first underflow of the timer causes the timer to reload from
the register R1A. Subsequent underflows cause the timer to
be reloaded from the registers alternately beginning with the
register R1B.
The T1 Timer control bits, T1C3, T1C2 and T1C1 set up the
timer for PWM mode operation.
Figure 9
shows a block diagram of the timer in PWM mode.
The underflows can be programmed to toggle the T1Aoutput
pin. The underflows can also be programmed to generate interrupts.
Underflows from the timer are alternately latched into two
pending flags, T1PNDA and T1PNDB. The user must reset
these pending flags under software control. Two control enable flags, T1ENAand T1ENB, allow the interrupts from the
timer underflow to be enabled or disabled. Setting the timer
enable flag T1ENA will cause an interrupt when a timer underflow causes the R1A register to be reloaded into the
timer. Setting the timer enable flag T1ENB will cause an interrupt when a timer underflow causes the R1B 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 8. Timers T1 and T0
.
c
FIGURE 9. Timer 1 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,T1, is clocked by the input signal from theT1A pin. The
T1 timer control bits, T1C3, T1C2 and T1C1 allow the timer
to be clocked either on a positive or negative edge from the
T1A pin. Underflows from the timer are latched into the
T1PNDA pending flag. Setting the T1ENA control flag will
cause an interrupt when the timer underflows.
In this mode the input pin T1B can be used as an independent positive edge sensitive interrupt input if the T1ENB control flag is set. The occurrence of a positive edge on the T1B
input pin is latched into the T1PNDB flag.
Figure 10
shows a block diagram of the timer in External
Event Counter mode.
Note: The PWM output is not available in this mode since the T1A pin is be-
ing used as the counter input clock.
Mode 3. Input Capture Mode
The device can precisely measure external frequencies or
time external events by placing the timer block, T1, in the input capture mode.
In this mode, the timer T1 is constantly running at the fixed t
rate. The two registers, R1A and R1B, act as capture registers. Each register acts in conjunction with a pin. The register
R1A acts in conjunction with the T1A pin and the register
R1B acts in conjunction with the T1B pin.
DS101137-8
DS101137-9
c
www.national.com12
Timers (Continued)
The timer value gets copied over into the register when a
trigger event occurs on its corresponding pin. Control bits,
T1C3, T1C2 and T1C1, 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 T1A and T1B pins will be respectively latched into the
pending flags, T1PNDA and T1PNDB. The control flag
T1ENA allows the interrupt on T1A to be either enabled or
disabled. Setting the T1ENA flag enables interrupts to be
generated when the selected trigger condition occurs on the
T1A pin. Similarly, the flag T1ENB controls the interrupts
from the T1B pin.
Underflows from the timer can also be programmed to generate interrupts. Underflows are latched into the timer T1C0
pending flag (the T1C0 control bit serves as the timer underflow interrupt pending flag in the Input Capture mode). Consequently, the T1C0 control bit should be reset when entering the Input Capture mode. The timer underflow interrupt is
enabled with the T1ENA control flag. When a T1A interrupt
occurs in the Input Capture mode, the user must check both
the T1PNDA and T1C0 pending flags in order to determine
whether a T1A input capture or a timer underflow (or both)
caused the interrupt.
Figure 11
shows a block diagram of the timer in Input Cap-
ture mode.
FIGURE 10. Timer 1 in External Event Counter Mode
FIGURE 11. Timer 1 in Input Capture Mode
DS101137-10
DS101137-11
www.national.com13
Timers (Continued)
TIMER CONTROL FLAGS
T1PNDA Timer Interrupt Pending Flag
T1ENATimer Interrupt Enable Flag
The control bits and their functions are summarized below.
T1C3Timer mode control
T1C2Timer mode control
T1C1Timer mode control
T1PNDB Timer Interrupt Pending Flag
T1ENBTimer Interrupt Enable Flag
T1C0Timer Start/Stop control in Modes 1 and 2 (Pro-
cessor Independent PWM and External Event
Counter), where 1 = Start, 0 = Stop
Timer Underflow Interrupt Pending Flag in
Mode 3 (Input Capture)
The timer mode control bits (T1C3, T1C2 and T1C1) are detailed below:
T1A Neg. EdgeEdge or TimerEdge
T1B Neg. EdgeUnderflow
111Captures:Neg. T1ANeg. T1Bt
T1A Neg. EdgeEdge or TimerEdge
T1B Neg. EdgeUnderflow
HIGH SPEED, CONSTANT RESOLUTION
PWM TIMER
The device has one processor independent PWM timer.The
PWM timer operates in two modes: PWM mode and capture
mode. In PWM mode the timer outputs can be programmed
to two pins PWM0 and PWM1. In capture mode, pin PWM0
functions as the capture input.
gram for this timer in capture mode and
Figure 12
shows a block dia-
Figure 13
shows a
block diagram for the timer in PWM mode.
PWM Timer Registers
The PWM Timer has three registers: PWMCON, the PWM
control register, RLON, the PWM on-time register and
PSCAL, the prescaler register.
PWM Prescaler Register (PSCAL)(Address X’00A0)
The prescaler is the clock source for the counter in both
PWM mode and in frequency monitor mode.
PSCAL is a read/write register that can be used to program
the prescaler.The clock source to the timer in both PWM and
capture modes can be programmed to CKI/N where N =
Interrupt A
Source
Autoreload RAAutoreload RB
Timer
Underflow
Timer
Underflow
Interrupt B
Source
Timer
Counts On
C
t
C
Pos. T1B EdgePos. T1A
Edge
Pos. T1B EdgePos. T1A
Edge
C
C
C
C
PSCAL + 1, so the maximum PWM clock frequency = CKI
and the minimum PWM clock frequency = CKI/256. The processor is able to modify the PSCAL register regardless of
whether the counter is running or not and the change in frequency occurs with the next underflow of the prescaler (CKPWM).
PWM On-time Register (RLON)(Address X’00A1)
RLON is a read/write register. In PWM mode the timer output
will be a “1” for RLON counts out of a total cycle of 255 PWM
clocks. In capture mode it is used to program the threshold
frequency.
The PWM timer is specially designed to have a resolution of
255 PWM clocks. This allows the duty cycle of the PWM output to be selected between 1/255 and 254/255. A value of 0
in the RLON register will result in the PWM output being continuously low and a value of 255 will result in the PWM output
being continuously high.
Note: The effect of changing the RLON register during active PWM mode op-
eration is delayed until the boundary of a PWM cycle. In capture mode
the effect takes place immediately.
The PWMCON Register Bits are:
Reserved This bit is reserved and should be zero.
ESELEdge select bit, “1” for falling edge, “0” for rising
edge.
PWPND PWM interrupt pending bit.
PWIEPWM interrupt enable bit.
PWMDPWM Mode bit, “1” for PWM mode, “0” for fre-
quency monitor mode.
PWONPWM start Bit, “1” to start timer, “0” to stop timer.
DS101137-13
PWEN1Enable PWM1 output function on I/O port.
Note: The associated bits in the configuration and data register of the I/O-
port have to be setup as outputs and/or inputs in addition to setting the
PWEN bits.
PWEN0Enable PWM0 output/input function on I/O port.
PWM Mode
The PWM timer can generate PWM signals at frequencies
up to 39 kHz (
@
tc= 1 µs) with a resolution of 255 parts.
Lower PWM frequencies can be programmed via the prescaler.
If the PWM mode bit (PWMD) in the PWM configurationregister (PWMCON) is set to “1” the timer operates in PWM
mode. In this mode, the timer generates a PWM signal with
www.national.com15
Timers (Continued)
a fixed, non-programmable repetition rate of 255 PWM clock
cycles. The timer is clocked by the output of an 8-bit, programmable prescaler, which is clocked with the chip’s CKI
frequency. Thus the PWM signal frequency can be calculated with the formula:
Selecting the PWM mode by setting PWMD to “1”, but not
yet starting the timer (PWON is “0”), will set the timer output
to “1”.
The contents of an 8-bit register, RLON, multiplied by the
clock cycle of the prescaler output defines the time between
overflow (or starting) and the falling edge of the PWM output.
Once the timer is started, the timer output goes low after
RLON cycles and high after a total of 255cycles. The procedure is continually repeated. In PWM mode the timer is available at pins PWM0 and/or PWM1,provided the port configuration bits for those pins are defined as outputs and the
PWEN0 and/or PWEN1 bits in the PWMCON register are
set.
The PWM timer is started by the software setting the PWON
bit to “1”. Starting the timer initializes the timer register. From
this point, the timer will continually generate the PWM signal,
independent of any processor activity, until the timer is
stopped by software setting the PWON bit to “0”. The processor is able to modify the RLON register regardless of
whether the timer is running. If RLON is changed while the
timer is running, the previous value of RLON is used for comparison until the next overflow occurs, when the new value of
RLON is latched into the comparator inputs.
When the timer overflows, the PWM pending flag (PWPND)
is set to “1”. If the PWM interrupt enable bit (PWIE) is also
set to “1”, timer overflow will generate an interrupt. The
PWPND bit remains set until the user’s software writes a “0”
to it. If the software writes a “1” to the PWPND bit, this has no
effect. If the software writes a “0” to the PWPND bit at the
same time as the hardware writes to the bit, the hardware
has precedence.
Note: The software controlling the duty cycle is able to change the PWM duty
cycle without having to wait for the timer overflow.
Figure 14
shows how the PWM output is implemented. The
PWM Timer output is set to “1” on an overflow of the timer
and set to “0” when the timer is greater than RLON.The output can be multiplexed to two pins.
Capture Mode
If the PWM mode bit (PWMD) is set to “0” the PWM Timer
operates in capture mode. Capture mode allows the programmer to test whether the frequency of an external source
exceeds a certain threshold.
If PWMD is “0” and PWON is “0”, the timer output is set to
“0”. In capture mode the timer output is available at pin
PWM1, provided the port configuration register bit for that
pin is set up as an output and the PWEN1 bit in the
PWMCON register is set. Setting PWON to “1” will initialize
the timer register and start the counter.A rising edge, or if selected, a falling edge, on the FMONIN input pin will initialize
the timer register and clear the timer output. The counter
continues to count up after being initialized. The ESELbit determines whether the active edge is a rising or a falling edge.
FIGURE 14. PWM Mode Operation
If, in capture mode PWM0 is configured incorrectly as an
output and is enabled via the PWEN0 bit, the timer output
will feedback into the PWM block as the timer input.
The contents of the counter are continually compared with
the RLON register. If the frequency of the input edges is sufficiently high, the contents of the counter will always be less
www.national.com16
DS101137-14
than the value in RLON. However, if the frequency of the input edges is too low, the free-running counter value will
count up beyond the value in RLON.
When the counter is greater than RLON, the PWM timer output is set to “1”. It is set to “0” by a detected edge on the timer
input or when the counter overflows. When the counter be-
Timers (Continued)
comes greater than RLON, the PWPND bit in the PWM control register is set to “1”. If the PWIE bit is also set to “1”, the
PWPND bit is enabled to request an interrupt.
It should be noted that two other conditions could also set
the PWPND bit:
1. If the mode of operation is changed on the fly the timer
output will toggle. If frequency monitor mode is entered
on the fly such that the timer output changes from 0 to 1,
PWPND will be set.
2. If the timer is operating in frequency monitor mode and
the RLON value is changed on the fly so that RLON be-
comes less than the current timer value, PWPND will be
set.
The PWPND bit remains set until the user’s software writes
a “0” to it. If the software writes a “1” to the PWPND bit, this
has no effect. If the software writes a “0” to the PWPND bit at
the same time as the hardware writes to the bit, the hardware has precedence. (See
Figure 17
for Frequency Monitor
Mode Operation.)
Note: If the clock to the device stops while PWM0 is high,
and a subsequent Reset occurs while the clock is stopped,
the PWM0/L6 output will be put in the weak pull-up mode until the clock resumes.
FIGURE 15. Frequency Monitor Mode Operation
Power Save Modes
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 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 contents of all PWM Timer registers are frozen during
HALT mode and are left unchanged when exiting HALT
mode. The PWM timer resumes its previous mode of operation when exiting HALT mode.
The device is placed in the HALTmode by writing a “1” to the
HALT flag (G7 data bit). All microcontroller activities, including the clock, and timers, are stopped. In the HALT mode,
the power requirements of the device are minimal and the
applied voltage (V
without altering the state of the machine.
The device supports two different ways of exiting the HALT
mode. The first method of exiting the HALT mode is with the
Multi-Input Wake Up feature on the L port. The second
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 Wake Up signal is not allowed to start the chip
) may be decreased to Vr(Vr= 2.0V)
CC
DS101137-15
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 fac-
instruction cycle clock. The t
c
tor 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 start-up time-out from the
IDLE timer enables the clock signals to be routed to the rest
of the chip.
The device has two mask options associated with the HALT
mode. The first mask option enables the HALTmode feature,
while the second mask option disables the HALTmode. With
the HALT mode enable mask option, the device will enter
and exit the HALT mode as described above. With the HALT
disable mask option, the device cannot be placed in the
HALT mode (writing a “1” to the HALT flag will have no effect).
IDLE MODE
The device is placed in the IDLE mode bywriting a “1” to the
IDLE flag (G6 data bit). In this mode, all activities,except the
associated on-board oscillator circuitry, and the IDLE Timer
www.national.com17
c
Loading...
+ 37 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.