配置内核gpio模拟spi时序的方法

来源:互联网 发布:什么叫erp软件 编辑:程序博客网 时间:2024/06/18 05:47

假如你现在有一份基于内核接口SPI的驱动,但是现在你的硬件已经没有多余的SPI接口了。怎么办?难道我们需要重新写驱动吗,像单片机一样去操作IO的高低来符合时序。那么你的工作量就加大了。其实,linux内核已经写好了模拟SPI时序,你只需要配置好。就可以使用了。下面分享一下个人经验。

首先,你需要配置CONFIG。

config SPI_GPIO
tristate "GPIO-based bitbanging SPI Master"
depends on GENERIC_GPIO
select SPI_BITBANG

其次,你需要在你的平台注册platform_device,保证能让spi-gpio.c能执行到probe函数。

static struct spi_gpio_platform_data xxx_data = {.sck = Pin(1),.mosi = Pin(2),.miso  = Pin(3),.num_chipselect = 1,};struct platform_device xxx_device = {.name= DRIVER_NAME,.id             = 0,.dev = {.platform_data = &xxx_data,},};
然后,你需要注册spi_board_info结构体,并初始化。

static struct spi_board_info xxxxx_board_info[] __initdata = {{.modalias= xxxx,.max_speed_hz= 1200000,.bus_num= 0,.chip_select= 0,.mode= SPI_MODE_x,.controller_data = (void *)Pin(4), },};

当你完成了以上步骤,恭喜你。模拟SPI已经配置成功了。接下来,你的硬件SPI驱动也可以兼容模拟IO的了。

那么内核是如何实现模拟SPI时序的呢?实现接口在spi-bitbang-txrx.h。

        

static inline u32bitbang_txrx_be_cpha0(struct spi_device *spi,unsigned nsecs, unsigned cpol, unsigned flags,u32 word, u8 bits){/* if (cpol == 0) this is SPI_MODE_0; else this is SPI_MODE_2 *//* clock starts at inactive polarity */for (word <<= (32 - bits); likely(bits); bits--) {/* setup MSB (to slave) on trailing edge */if ((flags & SPI_MASTER_NO_TX) == 0)setmosi(spi, word & (1 << 31));spidelay(nsecs);/* T(setup) */setsck(spi, !cpol);spidelay(nsecs);/* sample MSB (from slave) on leading edge */word <<= 1;if ((flags & SPI_MASTER_NO_RX) == 0)word |= getmiso(spi);setsck(spi, cpol);}return word;}

面是SPI模式0和模式2的接口时序实现方法。 仔细分析下,是不是和单片机SPI模拟时序一样。

0 1
原创粉丝点击