1998-2011 Microchip Technology Inc.
DS21290F-page 21
MCP3201
6.0
APPLICATIONS INFORMATION
6.1
Using the MCP3201 Device with
Microcontroller SPI Ports
With most microcontroller SPI ports, it is required to
clock out eight bits at a time. If this is the case, it will be
necessary to provide more clocks than are required for
interfaced to a microcontroller with a standard SPI port.
Since the MCP3201 always clocks data out on the
falling edge of clock, the MCU SPI port must be
configured to match this operation. SPI Mode 0,0 (clock
idles low) and SPI Mode 1,1 (clock idles high) are both
compatible with the MCP3201.
Figure 6-1 depicts the
operation shown in SPI Mode 0,0, which requires that
the CLK from the microcontroller idles in the ‘low’ state.
As shown in the diagram, the MSB is clocked out of the
A/D Converter on the falling edge of the third clock
pulse. After the first eight clocks have been sent to the
device, the microcontroller’s receive buffer will contain
two unknown bits (the output is at high-impedance for
the first two clocks), the null bit and the highest order
five bits of the conversion. After the second eight clocks
have been sent to the device, the MCU receive register
will contain the lowest-order seven bits and the B1 bit
repeated as the A/D Converter has begun to shift out
LSB first data with the extra clock. Typical procedure
would then call for the lower-order byte of data to be
shifted right by one bit to remove the extra B1 bit. The
B7 bit is then transferred from the high-order byte to the
lower-order byte, and then the higher-order byte is
shifted one bit to the right as well. Easier manipulation
of the converted data can be obtained by using this
method.
which requires that the clock idles in the high state. As
with mode 0,0, the A/D Converter outputs data on the
falling edge of the clock and the MCU latches data from
the A/D Converter in on the rising edge of the clock.
FIGURE 6-1:
SPI Communication using 8-bit segments (Mode 0,0: SCLK idles low).
FIGURE 6-2:
SPI Communication using 8-bit segments (Mode 1,1: SCLK idles high).
CS
CLK
9
10
11
1213
1415
16
DOUT
NULL
BIT B11 B10
B9
B8
B7
B6
B5
B4
B3
B2
B1
B0
HI-Z
B7
B6 B5 B4 B3 B2 B1 B0
B11 B10 B9
B8
??
0
MCU latches data from A/D
Data is clocked out of A/D
Converter on falling edges
Converter on rising edges of SCLK
123
4
5
6
7
8
HI-Z
B1
LSB first data begins
to come out
B2
Data stored into MCU receive register
after transmission of first 8 bits
Data stored into MCU receive register
after transmission of second 8 bits
CS
CLK
9
101112
13
14
15
16
DOUT
NULL
BIT
B11 B10 B9
B8
B7
B6 B5 B4 B3 B2 B1 B0
HI-Z
B7
B6 B5 B4 B3 B2 B1 B0
B11 B10 B9
B8
??
0
MCU latches data from A/D
Data is clocked out of A/D
Converter on falling edges
Converter on rising edges of SCLK
12
3
4
56
7
8
B1
LSB first data begins
to come out
HI-Z
Data stored into MCU receive register
after transmission of first 8 bits
Data stored into MCU receive register
after transmission of second 8 bits