linux内核驱动spi-mt7621.c里mt7621_spi_set_cs()函数的实现讨论

spi_mt7621.c的函数mt7621_spi_set_cs的实现很奇怪,此函数的功能是设置片选信号,但实际上是设置MT7621_SPI_POLAR的内容,查手册,MT7621_SPI_POLAR的功能是定义片选信号是低有效还是高有效。所以,表面上看,似乎实现的功能不大对。但实际上是对的,原因如下:

首先,CS都应该是低电平有效的。初始化时,SPI_MASTER寄存器的rs_slave_sel被设置为7:

    master |= 7 << 29;

那就意味着,CS0到CS6都没有被选中,这样,SPI master控制器将CS0和CS1都设置为高(缺省为低电平有效)。然后,需要选中CS1有两种方法:1,设置rs_slave_sel为1。2,设置MT7621_SPI_POLAR,将CS1变为高电平有效。这样,因为rs_slave_sel被设置为7,意味着CS1没有被选中,由于CS1是高电平有效,SPI master控制器就将CS1变为低电平,而这正好“选中”了CS1。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
`spi-slave-time.c` 是一个 Linux 内核模块,它提供了一个 SPI 从设备驱动程序,并且可以在从设备上测量 SPI 时序。下面是这个模块的详细内容: 1. 首先,这个模块定义了一个 `spi_slv_time` 结构体,用于保存从设备的 SPI 时序信息。这个结构体包含了以下字段: ```c struct spi_slv_time { ktime_t tx_start; ktime_t rx_end; ktime_t irq_start; ktime_t irq_end; }; ``` `tx_start` 字段保存了 SPI 传输的开始时间,`rx_end` 字段保存了 SPI 接收的结束时间,`irq_start` 字段保存了 SPI 中断处理程序开始执行的时间,`irq_end` 字段保存了 SPI 中断处理程序结束执行的时间。 2. 接下来,这个模块实现了一个 `spi_slv_time_irq()` 函数作为 SPI 从设备的中断处理程序。这个函数会记录 SPI 中断处理程序的开始和结束时间,并且在中断处理完成后,将时序信息保存到 `spi_slv_time` 结构体中。 3. 然后,这个模块实现了一个 `spi_slv_time_transfer()` 函数作为 SPI 从设备的传输函数。这个函数会记录 SPI 传输的开始时间,并且在传输完成后,将时序信息保存到 `spi_slv_time` 结构体中。 4. 最后,这个模块提供了一个 `spi_slv_time_probe()` 函数作为从设备的驱动程序。这个函数会注册 SPI 从设备,并且将 `spi_slv_time_irq()` 和 `spi_slv_time_transfer()` 函数设置为中断处理程序和传输函数。 综上所述,`spi-slave-time.c` 是一个为 SPI 从设备提供时序测量功能的 Linux 内核模块。它可以记录 SPI 传输和中断处理程序的开始和结束时间,并且保存这些信息到一个结构体中,以便后续分析。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值