您的位置 首页 汽车

S3C24x0片内设备驱动编写时的时钟问题

前天编写S3C24x0芯片的ADC驱动。其实很简单,参考别人的驱动,把以前的驱动模板改改就好了。可是写好后没使用成功。测来测去,最后发…

前天编写S3C24x0芯片的ADC驱动。其实很简单,参阅他人的驱动,把曾经的驱动模板改改就好了。但是写好后没运用成功。测来测去,最终发现对ADC的寄存器底子无法写入,只能读出。抑郁!!一开始以为是我用的赋值句子不对,参阅我的驱动学习文档,试了一圈,问题仍旧!抑郁了整整两天之后,在网上看到有人也遇到了2410的外设寄存器无法赋值的状况,最终发现是时钟问题。受此启示,我回想起了曾经看的Linux的SPI驱动,里边有以下句子:

hw->clk=clk_get(&pdev->dev,”spi”);
if(IS_ERR(hw->clk)){
dev_err(&pdev->dev,”No clock for device\n”);
err=PTR_ERR(hw->clk);
gotoerr_no_clk;
}

/* for the moment, permanently enable the clock */

clk_enable(hw->clk);

其时也没怎么介意,懊悔啊!之后我在DAC驱动上加了相似的句子,参阅了他人的2410触摸屏驱动,将”spi”改为”adc“。试验成功!

三星的S3C24x0处理器为了完成低功耗,添加对外设的时钟和电源的办理。详细的内容请看芯片手册的《7. Clock & Power Management》这一章。尽管芯片启动时默许这些外设的时钟是使能的,但在Linux下,启动时为了节能考虑,将部分时钟封闭了。假如没有使能这些时钟,就会呈现无法对外设寄存器写操作的状况。Linux中时钟使能部分的源码主要有:

/include/asm-arm/plat-s3c24xx/clock.h
/include/asm-arm/arch-s3c2410/regs-clock.h
/arch/arm/mach-s3c2410/clock.c

参阅这些源码,就可以大致知道Linux是怎么操作S3C24x0处理器的外设时钟的。

特别是/arch/arm/mach-s3c2410/clock.c中的以下数据对编程有所协助:

/* standard clock definitions */

staticstructclk init_clocks_disable[]={
{
.name=”nand”,
.id=-1,
.parent=&clk_h,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_NAND,
},{
.name=”sdi”,
.id=-1,
.parent=&clk_p,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_SDI,
},{
.name=”adc”,
.id=-1,
.parent=&clk_p,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_ADC,
},{
.name=”i2c”,
.id=-1,
.parent=&clk_p,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_IIC,
},{
.name=”iis”,
.id=-1,
.parent=&clk_p,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_IIS,
},{
.name=”spi”,
.id=-1,
.parent=&clk_p,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_SPI,
}
};

staticstructclk init_clocks[]={
{
.name=”lcd”,
.id=-1,
.parent=&clk_h,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_LCDC,
},{
.name=”gpio”,
.id=-1,
.parent=&clk_p,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_GPIO,
},{
.name=”usb-host”,
.id=-1,
.parent=&clk_h,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_USBH,
},{
.name=”usb-device”,
.id=-1,
.parent=&clk_h,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_USBD,
},{
.name=”timers”,
.id=-1,
.parent=&clk_p,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_PWMT,
},{
.name=”uart“,
.id=0,
.parent=&clk_p,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_UART0,
},{
.name=”uart”,
.id=1,
.parent=&clk_p,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_UART1,
},{
.name=”uart”,
.id=2,
.parent=&clk_p,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_UART2,
},{
.name=”rtc”,
.id=-1,
.parent=&clk_p,
.enable=s3c2410_clkcon_enable,
.ctrlbit=S3C2410_CLKCON_RTC,
},{
.name=”watchdog”,
.id=-1,
.parent=&clk_p,
.ctrlbit=0,
},{
.name=”usb-bus-host”,
.id=-1,
.parent=&clk_usb_bus,
},{
.name=”usb-bus-gadget”,
.id=-1,
.parent=&clk_usb_bus,
},
};

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/qiche/275756.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部