DSPIC30F2012 Microchip Technology Inc., DSPIC30F2012 Datasheet - Page 91

no-image

DSPIC30F2012

Manufacturer Part Number
DSPIC30F2012
Description
Dspic30f2011/2012/3012/3013 High-performance Digital Signal Controllers
Manufacturer
Microchip Technology Inc.
Datasheet

Available stocks

Company
Part Number
Manufacturer
Quantity
Price
Part Number:
DSPIC30F2012-20E/ML
Manufacturer:
MICROCHIP/微芯
Quantity:
20 000
Part Number:
DSPIC30F2012-20E/SO
Manufacturer:
MICROCHIP/微芯
Quantity:
20 000
Part Number:
DSPIC30F2012-20I/ML
Manufacturer:
MICROCHIP/微芯
Quantity:
20 000
Part Number:
DSPIC30F2012-20I/SO
Manufacturer:
MICROCHI
Quantity:
20 000
Part Number:
DSPIC30F2012-20I/SO
0
Part Number:
DSPIC30F2012-20I/SP
Manufacturer:
Microchip Technology
Quantity:
135
Part Number:
DSPIC30F2012-20I/SP
Manufacturer:
MICROCHIP/微芯
Quantity:
20 000
13.0
The Serial Peripheral Interface (SPI) module is a syn-
chronous serial interface. It is useful for communicating
with other peripheral devices, such as EEPROMs, shift
registers, display drivers and A/D converters, or other
microcontrollers. It is compatible with Motorola's SPI
and SIOP interfaces. The dsPIC30F2011/2012/3012/
3013 devices feature one SPI module, SPI1.
13.1
Figure 13-1 is a simplified block diagram of the SPI
module, which consists of a 16-bit shift register,
SPI1SR , used for shifting data in and out, and a buffer
register, SPI1BUF. Control register SPI1CON (not
shown) configures the module. Additionally, status reg-
ister SPI1STAT (not shown) indicates various status
conditions.
Four I/O pins comprise the serial interface:
• SDI1 (serial data input)
• SDO1 (serial data output)
• SCK1 (shift clock input or output)
FIGURE 13-1:
© 2006 Microchip Technology Inc.
Note: This data sheet summarizes features of this group
of dsPIC30F devices and is not intended to be a complete
reference source. For more information on the CPU,
peripherals, register descriptions and general device
functionality, refer to the “dsPIC30F Family Reference
Manual “ (DS70046).
Note:
SPI MODULE
Operating Function Description
SDO1
SCK1
SDI1
SS1
See “dsPIC30F Family Reference Man-
ual” (DS70046) for detailed information on
the control and status registers.
SPI BLOCK DIAGRAM
SS & FSYNC
Control
Receive
SPIxBUF
Read
bit 0
SPI1SR
dsPIC30F2011/2012/3012/3013
Control
Clock
Clock
Shift
SPIxBUF
Write
Transmit
Data Bus
Internal
Select
Edge
• SS1 (active-low slave select).
In Master mode operation, SCK1 is a clock output. In
Slave mode, it is a clock input.
A series of eight (8) or sixteen (16) clock pulses shift
out bits from the SPI1SR to SDO1 pin and simulta-
neously shift in data from SDI1 pin. An interrupt is
generated when the transfer is complete and the
interrupt flag bit (SPI1IF) is set. This interrupt can be
disabled through the interrupt enable bit, SPI1IE.
The receive operation is double-buffered. When a com-
plete byte is received, it is transferred from SPI1SR to
SPI1BUF.
If the receive buffer is full when new data is being trans-
ferred from SPI1SR to SPI1BUF, the module will set the
SPIROV bit indicating an overflow condition. The trans-
fer of the data from SPI1SR to SPI1BUF is not com-
pleted and the new data is lost. The module will not
respond to SCL transitions while SPIROV is ‘1’, effec-
tively disabling the module until SPI1BUF is read by
user software.
Transmit writes are also double-buffered. The user
writes to SPI1BUF. When the master or slave transfer
is completed, the contents of the shift register
(SPI1SR) are moved to the receive buffer. If any trans-
mit data has been written to the buffer register, the con-
tents of the transmit buffer are moved to SPI1SR. The
received data is thus placed in SPI1BUF and the trans-
mit data in SPI1SR is ready for the next transfer.
Note:
Enable Master Clock
Both the transmit buffer (SPI1TXB) and
the receive buffer (SPI1RXB) are mapped
to the same register address, SPI1BUF.
Secondary
Prescaler
1:1 – 1:8
1, 4, 16, 64
Prescaler
Primary
DS70139E-page 89
F
CY

Related parts for DSPIC30F2012