Saturday, 24 November 2012

Specification


SPI MASTER CORE SPECIFICATION

INTRODUCTION:
The Serial Peripheral Interface Bus or SPI bus is a synchronous serial data link standard, named by Motorola, that operates in full duplex  mode. Devices communicate in master/slave mode where the master device initiates the data frame.
SPI (Serial Peripheral Interface) Master core. Synchronous serial interfaces are widely used to provide economical board-level interfaces between different devices such as microcontrollers, DACs, ADCs and other. Although there is no single standard for a synchronous serial bus, there are industry-wide accepted guidelines based on two most popular implementations:
·         SPI (a trademark of Motorola Semiconductor)
·         Microwire/Plus (a trademark of National Semiconductor)

Many IC manufacturers produce components that are compatible with SPI and Microwire/Plus.
The SPI Master core is compatible with both above-mentioned protocols as master with some additional functionality.
At the hosts side, the core acts like a WISHBONE compliant slave device.
Features:
·         Full duplex synchronous serial data transfer
·         Variable length of transfer word up to 128 bits
·         MSB or LSB first data transfer
·         Rx and Tx on both rising or falling edge of serial clock independently
·         8 slave select lines
·         Fully static synchronous design with one clock domain
·         Technology independent Verilog
·         Fully synthesizable

WISHBONE interface signals

Port
Width
Direction
Description
wb_clk_i
1
Input
Master clock
wb_rst_i
1
Input
Synchronous reset, active high
wb_adr_i
5
Input
Lower address bits
wb_dat_i
32
Input
Data towards the core
wb_dat_o
32
Output
Data from the core
wb_sel_i
4
Input
Byte select signals
wb_we_i
1
Input
Write enable input
wb_stb_i
1
Input
Strobe signal/Core select input
wb_cyc_i
1
Input
Valid bus cycle input
wb_ack_o
1
Output
Bus cycle acknowledge output
wb_err_o
1
Output
Bus cycle error output
wb_int_o
1
Output
Interrupt signal output
Table 1: Wishbone interface signals
All output WISHBONE signals are registered and driven on the rising edge of wb_clk_i. All input WISHBONE signals are latched on the rising edge of wb_clk_i.

SPI external connections

Port
Width
Direction
Description
/ss_pad_o
8
Output
Slave select output signals
sclk_pad_o
1
Output
Serial clock output
mosi_pad_o
1
Output
Master out slave in data signal output
miso_pad_i
1
Input
Master in slave out data signal input
Table 2: SPI  external connections

Core Registers list

Name
Address
Width
Access
Description
Rx0
0x00
32
R
Data receive register 0
Rx1
0x04
32
R
Data receive register 1
Rx2
0x08
32
R
Data receive register 2
Rx3
0x0c
32
R
Data receive register 3
Tx0
0x00
32
R/W
Data transmit register 0
Tx1
0x04
32
R/W
Data transmit register 1
Tx2
0x08
32
R/W
Data transmit register 2
Tx3
0x0c
32
R/W
Data transmit register 3
CTRL
0x10
32
R/W
Control and status register
DIVIDER
0x14
32
R/W
Clock divider register
SS
0x18
32
R/W
Slave select register
Table 3: List of core registers
All registers are 32-bit wide and accessible only with 32 bits (all wb_sel_i signals must be active).

Control and status register [CTRL]

Bit #
31:14
13
12
11
10
9
8
7
6:0
Access
R
R/W
R/W
R/W
R/W
R/W
R/W
R
R/W
Name
Reserved
ASS
IE
LSB
Tx_NEG
Rx_NEG
GO_BSY
Reserved
CHAR_LEN
Table 6: Control and Status register
Reset Value: 0x00000000

ASS

If this bit is set, ss_pad_o signals are generated automatically. This means that slave select signal, which is selected in SS register is asserted by the SPI controller, when transfer is started by setting CTRL[GO_BSY] and is de-asserted after transfer is finished. If this bit is cleared, slave select signals are asserted and de-aserted by writing and clearing bits in SS register.

IE

If this bit is set, the interrupt output is set active after a transfer is finished. The Interrupt signal is deasserted after a Read or Write to any register.

LSB

If this bit is set, the LSB is sent first on the line (bit TxL[0]), and the first bit received from the line will be put in the LSB position in the Rx register (bit RxL[0]). If this bit is cleared, the MSB is transmitted/received first (which bit in TxX/RxX register that is depends on the CHAR_LEN field in the CTRL register).

Tx_NEG

If this bit is set, the mosi_pad_o signal is changed on the falling edge of a sclk_pad_o clock signal, or otherwise the mosi_pad_o signal is changed on the rising edge of sclk_pad_o.

Rx_NEG

If this bit is set, the miso_pad_i signal is latched on the falling edge of a sclk_pad_o clock signal, or otherwise the miso_pad_i signal is latched on the rising edge of sclk_pad_o.

GO_BSY

Writing 1 to this bit starts the transfer. This bit remains set during the transfer and is automatically cleared after the transfer finished. Writing 0 to this bit has no effect.

Divider register [DIVIDER]

Bit #
31:16
15:0
Access
R
R/W
Name
Reserved
DIVIDER
Table 7: Divider register
Reset Value: 0x0000ffff

DIVIDER

The value in this field is the frequency divider of the system clock wb_clk_i to generate the serial clock on the output sclk_pad_o. The desired frequency is obtained according to the following equation:

fclk = fwb_clk_i / (DIVIDER + 1 )*2

  Slave select register [SS]

Bit #
31:8
7:0
Access
R
R/W
Name
Reserved
SS
Table 8: Slave Select register
Reset Value: 0x00000000

SS

If CTRL[ASS] bit is cleared, writing 1 to any bit location of this field sets the proper ss_pad_o line to an active state and writing 0 sets the line back to inactive state. If CTRL[ASS] bit is set, writing 1 to any bit location of this field will select appropriate ss_pad_o line to be automatically driven to active state for the duration of the transfer, and will be driven to inactive state for the rest of the time.