1.7. SPI

硬件SPI接口,spi0被系统占用,不可使用。硬件spi时钟源是lsb,分频:1~256。每个spi配一个dma,不能同时双向dma。

spi模式:主从;dma半双工;位宽1,2,4;四种位流;时钟极性,采样极性可配

1.7.1. 硬件spi基本接口

1.7.1.1. get_hw_spi_config

为兼容旧接口新增,功能:获取硬件spi配置结构体。

原型:

struct spi_platform_data *get_hw_spi_config(hw_spi_dev spi);
参数:

spi

硬件spi索引号0~n

返回值

硬件spi配置信息

1.7.1.2. spi_open

初始化硬件spi。

原型:

int spi_open(hw_spi_dev spi, spi_hardware_info *spi_info);
参数:

spi

硬件spi索引号0~n

spi_info

硬件spi配置信息

返回值

返回执行状态:0:ok;<0:error

示例:

struct spi_platform_data spix_p_data_test = {
    .port = { // 未用到的io配置为0xff
        IO_PORTC_00, //clk any io
        IO_PORTC_01, //do  any io
        IO_PORTC_02, //di  any io
        IO_PORTC_03, //d2  any io
        IO_PORTC_04, //d3  any io
        0xff,        //cs  (主机不操作cs)
    },
    .role = SPI_ROLE_MASTER,
    .mode = SPI_MODE_UNIDIR_2BIT,//SPI_MODE_BIDIR_1BIT,
    .bit_mode = SPI_FIRST_BIT_MSB,
    .cpol = 0,//clk level in idle state:0:low,  1:high
    .cpha = 0,//sampling edge:0:first,  1:second
    .ie_en = 0, //ie enbale:0:disable,  1:enable
    .spi_isr_callback = NULL,  //spi isr callback
    .clk  = 1000000L,
};

//init
int ret = spi_open(spi, &spix_p_data_test);
if (ret < 0) {
    log_error("spi init error(%d)!", ret);
}

1.7.1.3. spi_deinit

关闭硬件spi,释放io为高阻状态,关闭crossbar映射。

原型:

void spi_deinit(hw_spi_dev spi);
参数:

spi

硬件spi索引号0~n

返回值

1.7.1.4. spi_suspend

挂起硬件spi,关闭io及spi。

原型:

void spi_suspend(hw_spi_dev spi);
参数:

spi

硬件spi索引号0~n

返回值

1.7.1.5. spi_resume

恢复硬件spi,还原io状态到初始化状态。

原型:

void spi_resume(hw_spi_dev spi);
参数:

spi

硬件spi索引号0~n

返回值

1.7.1.6. spi_set_bit_mode

设置或改变spi位宽工作模式,初始化对应的io,不会注销已经初始化的io。

原型:

void spi_set_bit_mode(hw_spi_dev spi, enum spi_mode mode);
参数:

spi

硬件spi索引号0~n

mode

位宽模式,详见枚举enum spi_mode

返回值

1.7.1.7. spi_set_baud

设置或改变硬件spi通信频率。

原型:

int spi_set_baud(hw_spi_dev spi, u32 baud);
参数:

spi

硬件spi索引号0~n

baud

频率,单位hz

返回值

执行状态:<0:error;0:ok

1.7.1.8. spi_get_baud

获取硬件spi当前频率。

原型:

u32 spi_get_baud(hw_spi_dev spi);
参数:

spi

硬件spi索引号0~n

返回值

频率,单位hz

1.7.1.9. spi_set_ie

仅配置硬件spi中断使能位,不注册中断回调函数。

原型:

void spi_set_ie(hw_spi_dev spi, u8 en);
参数:

spi

硬件spi索引号0~n

en

中断状态:1:使能;0:关闭

返回值

1.7.1.10. spi_get_pending

获取硬件spi中断标志。

原型:

u8 spi_get_pending(hw_spi_dev spi);
参数:

spi

硬件spi索引号0~n

返回值

中断标志:1:被置位;0:无

1.7.1.11. spi_clear_pending

清除硬件spi中断标志。

原型:

void spi_clear_pending(hw_spi_dev spi);
参数:

spi

硬件spi索引号0~n

返回值

1.7.1.12. spi_send_byte

硬件spi主机模式cpu发送一个byte数据,返回发送状态,阻塞发送,会一直等spi发送完成。

原型:

int spi_send_byte(hw_spi_dev spi, u8 byte);
参数:

spi

硬件spi索引号0~n

byte

待发送的数据

返回值

执行状态:<0:error;0:ok

1.7.1.13. spi_recv_byte

硬件spi主机模式cpu接收一个byte数据,返回接收的数据,阻塞接收,会一直等spi接收完成。

原型:

u8 spi_recv_byte(hw_spi_dev spi, int *err);
参数:

spi

硬件spi索引号0~n

err

返回错误信息,若err为非空指针,0 成功,< 0 失败,若为空指针,忽略

返回值

接收的数据

1.7.1.14. spi_send_recv_byte

硬件spi主机模式cpu全双工通信,同时发送并接收一个byte数据,返回接收的数据,阻塞接收,会一直等spi完成。

原型:

u8 spi_send_recv_byte(hw_spi_dev spi, u8 byte, int *err);
参数:

spi

硬件spi索引号0~n

byte

待发送的数据

err

返回错误信息,若err为非空指针,0 成功,< 0 失败,若为空指针,忽略

返回值

接收的数据

1.7.1.15. spi_dma_recv

硬件spi主机模式使用dma接收指定长度的数据,阻塞模式,一直等待spi接收完成。

原型:

int spi_dma_recv(hw_spi_dev spi, void *buf, u32 len);
参数:

spi

硬件spi索引号0~n

buf

接收缓存buf

len

接收长度

返回值

接收的数据长度:=len:成功;其他值:失败

1.7.1.16. spi_dma_send

硬件spi主机模式dma发送指定长度的数据,阻塞模式,一直等待spi发送完成。

原型:

int spi_dma_send(hw_spi_dev spi, const void *buf, u32 len);
参数:

spi

硬件spi索引号0~n

buf

发送缓存buf

len

发送长度

返回值

发送的数据长度:=len:成功;其他值:失败

1.7.2. 硬件spi主从机中断接口

1.7.2.1. spi_byte_transmit_for_isr

硬件spi收发一个byte数据,单向或全双工模式,无返回值,不会等spi发送完成,可用于中断, 适用主从。

原型:

void spi_byte_transmit_for_isr(hw_spi_dev spi, u8 tx_byte, u8 *rx_byte, u8 rw);//rw:1-rx; 0-tx
参数:

spi

硬件spi索引号0~n

tx_byte

待发送的数据

rx_byte

待发接收的数据的地址

rw

收发控制。0:发送或全双工;1:接收

返回值

1.7.2.2. spi_buf_transmit_for_isr

硬件spi收发len个byte数据,单向或全双工模式,无返回值,不会等spi发送完成,可用于中断, 适用主从。

原型:

void spi_buf_transmit_for_isr(hw_spi_dev spi, u8 *tx_buf, u8 *rx_buf, int len, u8 rw);//rw:1-rx; 0-tx
参数:

spi

硬件spi索引号0~n

tx_buf

待发送的数据的地址

rx_buf

待发接收的数据的地址

len

收发长度

rw

收发控制。0:发送或全双工;1:接收

返回值

1.7.2.3. spi_dma_transmit_for_isr

硬件spi dma发送或接收指定长度的数据,不会等待spi操作完成,半双工,可用于中断, 适用主从。

原型:

void spi_dma_transmit_for_isr(hw_spi_dev spi, void *buf, int len, u8 rw);//rw:1-rx; 0-tx
参数:

spi

硬件spi索引号0~n

buf

发送或接收缓存buf地址

len

发送或接收长度

rw

收发控制。0:发送;1:接收

返回值

1.7.2.4. hw_spix_irq_change_callback

切换中断回调函数。

原型:

void hw_spix_irq_change_callback(hw_spi_dev spi, void (*spi_isr_callback_f)(hw_spi_dev spi, enum hw_spi_isr_status sta));
参数:

spi

硬件spi索引号0~n

spi_isr_callback_f

中断回调函数或NULL

返回值

1.7.2.5. hw_spix_get_isr_status

获取硬件spi主机或从机byte或dma收发状态,并清除收发状态(只用于中断模式)。

原型:

enum hw_spi_isr_status hw_spix_get_isr_status(hw_spi_dev spi);
参数:

spi

硬件spi索引号0~n

返回值

收发状态:详见枚举

1.7.2.6. hw_spix_clear_isr_len

每包数据前清空收发长,在通信中间调用,会导致数据长不准(只用于中断模式)。

原型:

void hw_spix_clear_isr_len(hw_spi_dev spi);
参数:

spi

硬件spi索引号0~n

返回值

1.7.2.7. hw_spix_get_isr_len

主机或从机且开中断模式下:获取硬件spibyte或dma收发长度(只用于中断模式)。返回带符号数据,符号表示dma(-)还是byte(+),数据表示长度,结合hw_spix_get_isr_status可知是接收还是发送

原型:

int hw_spix_get_isr_len(hw_spi_dev spi);
参数:

spi

硬件spi索引号0~n

返回值

收发长度(符号表示dma(-)还是byte(+),数据表示长度)

1.7.2.8. hw_spix_slave_get_dma_len

从机且不开中断模式下:获取硬件spi dma收发长度(dma未完成获取当前已传输个数)。返回带符号数据,符号表示dma(-),数据表示长度,不能区分收发。

原型:

int hw_spix_slave_get_dma_len(hw_spi_dev spi);
参数:

spi

硬件spi索引号0~n

返回值

收发长度(符号表示dma(-),数据表示长度)

1.7.3. 示例

详见文件 spi_demo.c或spi_test.c文件