
Serial Communications Interface (S08SCIV3)
MC9S08QG8 and MC9S08QG4 Data Sheet, Rev. 1.01
206
Freescale Semiconductor
14.3.3
Receiver Functional Description
In this section, the receiver block diagram (
Figure 14-4
) is used as a guide for the overall receiver
functional description. Next, the data sampling technique used to reconstruct receiver data is described in
more detail. Finally, two variations of the receiver wakeup function are explained.
The receiver is enabled by setting the RE bit in SCIC2. Character frames consist of a start bit of logic 0,
eight (or nine) data bits (LSB first), and a stop bit of logic 1. For information about 9-bit data mode, refer
to
 Section 14.4.1, “8- and 9-Bit Data Modes
.” For the remainder of this discussion, we assume the SCI is
configured for normal 8-bit data mode.
Afterreceivingthestopbitintothereceiveshifter,andprovidedthereceivedataregisterisnotalreadyfull,
the data character is transferred to the receive data register and the receive data register full (RDRF) status
flagisset.IfRDRFwasalreadysetindicatingthereceivedataregister(buffer)wasalreadyfull,theoverrun
(OR) status flag is set and the new data is lost. Because the SCI receiver is double-buffered, the program
hasonefullcharactertimeafterRDRFissetbeforethedatainthereceivedatabuffermustbereadtoavoid
a receiver overrun.
When a program detects that the receive data register is full (RDRF = 1), it gets the data from the receive
data register by reading SCID. The RDRF flag is cleared automatically by a 2-step sequence which is
normally satisfied in the course of the user’s program that handles receive data. Refer to
 Section 14.3.4,
“Interrupts and Status Flags
,” for more details about flag clearing.
14.3.3.1
Data Sampling Technique
The SCI receiver uses a 16
×
 baud rate clock for sampling. The receiver starts by taking logic level samples
at 16 times the baud rate to search for a falling edge on the RxD1 serial data input pin. A falling edge is
defined as a logic 0 sample after three consecutive logic 1 samples. The 16
×
 baud rate clock is used to
dividethebittimeinto16 segmentslabeledRT1throughRT16.Whenafallingedgeislocated,three more
samples are taken at RT3, RT5, and RT7 to make sure this was a real start bit and not merely noise. If at
least two of these three samples are 0, the receiver assumes it is synchronized to a receive character.
The receiver then samples each bit time, including the start and stop bits, at RT8, RT9, and RT10 to
determine the logic level for that bit. The logic level is interpreted to be that of the majority of the samples
taken during the bit time. In the case of the start bit, the bit is assumed to be 0 if at least two of the samples
at RT3, RT5, and RT7 are 0 even if one or all of the samples taken at RT8, RT9, and RT10 are 1s. If any
sample in any bit time (including the start and stop bits) in a character frame fails to agree with the logic
level for that bit, the noise flag (NF) will be set when the received character is transferred to the receive
data buffer.
Thefallingedgedetectionlogiccontinuouslylooksforfallingedges,andifanedgeisdetected,thesample
clock is resynchronized to bit times. This improves the reliability of the receiver in the presence of noise
or mismatched baud rates. It does not improve worst case analysis because some characters do not have
any extra falling edges anywhere in the character frame.
Inthecaseofaframingerror,providedthereceivedcharacterwasnotabreakcharacter,thesamplinglogic
that searches for a falling edge is filled with three logic 1 samples so that a new start bit can be detected
almost immediately.