
Timer Interface Module B (TIMB)
Technical Data
MC68HC08AB16A
 — 
Rev. 2.0
198
Timer Interface Module B (TIMB)
MOTOROLA
12.5.4.3  PWM Initialization
To ensure correct operation when generating unbuffered or buffered 
PWM signals, use the following initialization procedure:
1.
In the TIMB status and control register (TBSC):
a.
Stop the TIMB counter by setting the TIMB stop bit, TSTOP.
b.
Reset the TIMB counter by setting the TIMB reset bit, TRST.
2.
In the TIMB counter modulo registers (TBMODH:TBMODL), write 
the value for the required PWM period.
3.
In the TIMB channel x registers (TBCHxH:TBCHxL), write the 
value for the required pulse width.
4.
In TIMB channel x status and control register (TBSCx):
a.
Write 0:1 (for unbuffered output compare or PWM signals) or 
1:0 (for buffered output compare or PWM signals) to the 
mode select bits, MSxB:MSxA. See 
Table 12-3
.
a.
Write 1 to the toggle-on-overflow bit, TOVx.
b.
Write 1:0 (to clear output on compare) or 1:1 (to set output on 
compare) to the edge/level select bits, ELSxB:ELSxA. The 
output action on compare must force the output to the 
complement of the pulse width level. See 
Table 12-3
.
NOTE:
In PWM signal generation, do not program the PWM channel to toggle 
on output compare. Toggling on output compare prevents reliable 0% 
duty cycle generation and removes the ability of the channel to self-
correct in the event of software error or noise. Toggling on output 
compare can also cause incorrect PWM signal generation when 
changing the PWM pulse width to a new, much larger value.
5.
In the TIMB status control register (TBSC), clear the TIMB stop bit, 
TSTOP.
Setting MS0B links channels 0 and 1 and configures them for buffered 
PWM operation. The TIMB channel 0 registers (TBCH0H:TBCH0L) 
initially control the buffered PWM output. TIMB channel 0 status and 
control register (TBSC0) controls and monitors the PWM signal from 
the linked channels. MS0B takes priority over MS0A.