
Technical Data
MC68HC705C8A
—
Rev. 3
142
Serial Peripheral Interface (SPI)
MOTOROLA
Serial Peripheral Interface (SPI)
11.4 Operation
The master/slave SPI allows full-duplex, synchronous, serial
communication between the microcontroller unit (MCU) and peripheral
devices, including other MCUs. As the 8-bit shift register of a master SPI
transmits each byte to another device, a byte from the receiving device
enters the master SPI shift register. A clock signal from the master SPI
synchronizes data transmission.
Only a master SPI can initiate transmissions. Software begins the
transmission from a master SPI by writing to the SPI data register
(SPDR). The SPDR does not buffer data being transmitted from the SPI.
Data written to the SPDR goes directly into the shift register and begins
the transmission immediately under the control of the serial clock. The
transmission ends after eight cycles of the serial clock when the SPI flag
(SPIF) becomes set. At the same time that SPIF becomes set, the data
shifted into the master SPI from the receiving device transfers to the
SPDR. The SPDR buffers data being received by the SPI. Before the
master SPI sends the next byte, software must clear the SPIF bit by
reading the SPSR and then accessing the SPDR.
Addr.
Register Name
Bit 7
6
5
4
3
2
1
Bit 0
$000A
SPI Control Register
(SPCR)
See page 149.
Read:
SPIE
SPE
MSTR
CPOL
CPHA
SPR1
SPR0
Write:
Reset:
0
0
0
U
U
U
U
$000B
SPI Status Register
(SPSR)
See page 151.
Read:
SPIF
WCOL
MODF
Write:
Reset:
0
0
0
$000C
SPI Data Register
(SPDR)
See page 149.
Read:
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
BIt 2
Bit 1
Bit 0
Write:
Reset:
Unaffected by reset
= Unimplemented
U = Unaffected
Figure 11-2. SPI I/O Register Summary