Serial Peripheral Interface (SPI) Module
MC9S08GB/GT Data Sheet, Rev. 2.3
196
Freescale Semiconductor
12.3.3
SPI Interrupts
There are three ag bits, two interrupt mask bits, and one interrupt vector associated with the SPI system.
The SPI interrupt enable mask (SPIE) enables interrupts from the SPI receiver full ag (SPRF) and mode
fault ag (MODF). The SPI transmit interrupt enable mask (SPTIE) enables interrupts from the SPI
transmit buffer empty ag (SPTEF). When one of the ag bits is set, and the associated interrupt mask bit
is set, a hardware interrupt request is sent to the CPU. If the interrupt mask bits are cleared, software can
poll the associated ag bits instead of using interrupts. The SPI interrupt service routine (ISR) should
check the ag bits to determine what event caused the interrupt. The service routine should also clear the
ag bit(s) before returning from the ISR (usually near the beginning of the ISR).
12.3.4
Mode Fault Detection
A mode fault occurs and the mode fault ag (MODF) becomes set when a master SPI device detects an
error on the SS1 pin (provided the SS1 pin is congured as the mode fault input signal). The SS1 pin is
congured to be the mode fault input signal when MSTR = 1, mode fault enable is set (MODFEN = 1),
and slave select output enable is clear (SSOE = 0).
The mode fault detection feature can be used in a system where more than one SPI device might become
a master at the same time. The error is detected when a master’s SS1 pin is low, indicating that some other
SPI device is trying to address this master as if it were a slave. This could indicate a harmful output driver
conict, so the mode fault logic is designed to disable all SPI output drivers when such an error is detected.
When a mode fault is detected, MODF is set and MSTR is cleared to change the SPI conguration back
to slave mode. The output drivers on the SPSCK1, MOSI1, and MISO1 (if not bidirectional mode) are
disabled.
MODF is cleared by reading it while it is set, then writing to the SPI control register 1 (SPI1C1). User
software should verify the error condition has been corrected before changing the SPI back to master
mode.
12.4
SPI Registers and Control Bits
The SPI has ve 8-bit registers to select SPI options, control baud rate, report SPI status, and for
transmit/receive data.
Refer to the direct-page register summary in
the Memory chapter of this data sheet for the absolute address
assignments for all SPI registers. This section refers to registers and control bits only by their names, and
a Freescale-provided equate or header le is used to translate these names into the appropriate absolute
addresses.