关于 s3c2416 hspi spi linux 驱动
最近在做samsung
s3c2416
在linux下的spi驱动程序,测试了下samsung发布的spi的内核源代码,无论是采用dma或者非dma模式都无法工作。阅读该驱动代码,发现
这码应该是一个未完成的版本,存在很多的bug。于是在这个版本的基础上进行修改,重写一个可用的、支持全双工的通讯的驱动。目前测试基本能够正常工作,
支持半双工、全双工、spi硬件中断模式和dma模式。
对hspi-s3c2443.[ch]源文件根据数据发送和接收的流程进行分析,在未采用dma模式下,函数调用的流程:s3c_spi_xfer
-> s3c_spi_doxfer -> s3c_spi_message_start ->
down_interruptible(&spi->sem),到这里,硬件会产生spi中断,进入到中断服务程序
s3c_spi_irq 中,中断函数调用 spi_s3c_irq_nextbyte
进行数据发送,根据spi->state的值做相应的操作,数据发送或接收完成后,调用 s3c_spi_stop
关闭spi,并up(&spi->sem),程序流程回到了s3c_spi_doxfer函数的
down_interruptible(&spi->sem),函数返回退出,一个spi的数据收发流程完成。
在这个发送接收流程中,中断服务程序存在很多不足的地方。
先看spi发送,发送最终调用的是:
while(!(tx_msgend(spi)))
s3c_spi_write_fifo(spi);
这两行代码的功能是判断写缓冲里是否还有数据,有的话就写入到spi发送寄存器(S3C_SPI_TX_DATA)中。我们知道spi的硬件能够缓冲64
个字节的数据,如果我们一次发送的数据长度小于64个字节,并且下一次发送数据时缓冲中的数据发送完成,那么这段代码表面上应该是没什么问题。如果我们发
送的数据长度大于64个字节,那么这段代码至少造成的后果是产生一个SPI transmit over run error。
在看spi接收,接收调用的代码是:
while(!(rx_msgend(spi))){
spi->msg->rbuf[spi->msg_rd_pt
相关文档:
setitimer()是比较精准的定时器,是Linux的API
以下代码是个倒计时例子:
#include <signal.h>
#include <sys/time.h>
static int time_count=30;
static void sigalrm_handler(int sig)
{
time_count--;
printf("timer signal.. %d\n", time_count);
}
struct itimerval v; ......
1# 发表于 2005-11-15 17:34 只看该作者
http://www.chinaunix.net 作者:bierdaci 发表于:2004-05-25 18:59:33
不知道该不该发这里,是我从proc改来的,懂内核源码的交流交流
hello.c
[code:1:3adb123188]
#include "hello.h"
struct inode * hello_get_inode(struct s ......
ubuntu 下编译 linux fetion 应用程序demo
注:这里给出界面模块的源代码,而libfetion库(32位)则是以静态库的形式放进去了。
1:建立编译环境:
在终端执行以下命令:
sudo apt-get install automake
sudo apt-get install libc-dev
sudo apt-get install g++
sudo apt-get install libcurl4-openssl-dev
sudo ......
今天在安装oracle过程中,参照网上下载的资料在RHEL5上安装oracle,整个过程比较顺利,但是却遇到了一点问题,虽然不是很严重,但是毕竟是个问题心里还是不很舒服,在此请路过的解决。
主要问题是oracle用户的环境变量,在安装oracle过程中,有一步是需要以oracle用户登录,然后编辑 ......
我们说一下Linux中的init命令
Init是Linux操作系统中不可缺少的程序之一。init进程是Linux内核引导运行的,是系统中的第一个进程,其进程号(PID)永远为1。你可以通过#ps -ef|head来查看进程命令。
1) 几个常用的命令
查看系统进程命令:#ps -ef|head
&n ......