我们需要根据设备的寄存器编写驱动么?

本文以赛灵思Zynq-7000芯片为例,阐述了如何利用开发工具ISE自动生成驱动程序,并通过SDK提供的example深入理解外设驱动流程。接着,作者分享了编写Linux驱动时遇到的挑战,包括复杂外设的DMA、结构体构建、等待队列使用等。最后,提出了通过理解设备性能和官方驱动API来定制驱动的建议。

刚开始做linux驱动的时候,比较迷惑:我应该怎么做驱动呢,看设备的官方文档然后根据寄存器的设置编写驱动?

但是随手打开一个设备的datasheet,就头大无比,N多的寄存器,N多的操作限制。想要读懂datasheet很难,想要根据datasheet编写驱动更难,想要编写一个能够使设备性能最大化的驱动难上加难。

但是驱动还是应该写的,否则项目不就over了。但是应该怎么写呢?

OK,以最近接手的赛灵思的zynq-7000芯片为例。

开发工具ISE提供了集成的软件开发环境,只要你包含了一个外设IP核,它就自动生成了裸机环境下该外设的驱动程序,你所要做的只是在应用程序中以正确的步骤调用驱动提供的API接可以了,POLL和中断模式任君选择。更人性化的是,SDK为每一个IP 核都提供了至少一个example,想要了解外设的驱动流程,先去读懂这些example吧。阅读中最重要的是要逐层深入,一窥究竟xilinx自带的驱动是如何操作外设的registers的。


有了上面的基础后,就开始编写linux下的驱动吧,ioremap、mmap、read32、write32、request_irq等等任君选择。

coding....

问题来了,驱动好难写啊!!!

复杂的外设还要考虑dma,还要构造外设结构体,还要使用等待队列等等....项目等不及啊


怎么办?

其实有捷径:你想想,硬件生产商其实每做一个外设,都是给它编写驱动了,否则设备不就裸奔了。关键是你要去理解设备的性能,然后在官方的驱动上加以利用,调用它的API编写自己的驱动,达到用户定制的目的。


个人理解而已,大拿们肯定自己写完所有的驱动code了,努力吧





#include #define uchar unsigned char #define uint unsigned int sbit led=P2^5; sbit wei=P2^7; sbit duan=P2^6; sbit DQ=P2^2; uchar mazhi_duan[]={0x3f,0x06,0x5b,0x4f, 0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71,0x00}; uchar mazhi_wei[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xff}; void delayl(uint n) { uint i,j; for(i=n;i>0;i--) for(j=114;j>0;j--); } void delays(uchar i) { while(i--); } bit init_DS18B20() //DS8B20初始化 { bit x; DQ=1; //DQ复位 delays(8); DQ=0; //单片机将DQ拉低 delays(75); DQ=1; //拉高总线 delays(15); x=DQ; //延时过后 若x=0则初始化成功 若x=1则初始化失败 delays(5); return x; } void write_data(uchar dat) { uchar i,temp; temp=dat; DQ=1; for(i=0;i>=1; } } uchar read_data() { uchar i,dat; DQ=1; for(i=0;i>=1; DQ=1;//配置为输入 if(DQ) dat|=0x80; delays(4); } return dat; } uint readtemp() { uchar temph,templ; uint temp; float wendu; init_DS18B20(); write_data(0xcc);//跳过ROM write_data(0x44);//启动温度转换 //delayl(100); init_DS18B20(); write_data(0xcc);//跳过ROM write_data(0xBE);//温度 //以下温度,低八位在前 //高8位在后 templ=read_data(); temph=read_data(); temp = (temph<<8)|templ; wendu = temp*0.625+0.5;//温度扩大10倍,四舍五入 temp = wendu;//10倍温度 return temp; } void STC_init() { P1=0x00;//关闭led led=0; //锁存 wei=0; duan=0; } void display(uchar weil,uchar duanl,bit dp) { wei=1; P0=mazhi_wei[weil-1]; wei=0; duan=1; if(dp==1) P0=(mazhi_duan[duanl]|0x80); else P0=mazhi_duan[duanl]; duan=0; } void main() { uchar i; uint wendu; STC_init(); wendu=readtemp(); delayl(500); wendu=readtemp(); delayl(500); while(1) { wendu=readtemp(); for(i=0;i<80;i++) { display(1,wendu/100,0); delayl(3); display(2,wendu0/10,1); delayl(3); display(3,wendu,0); delayl(3); } } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值