新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > S3C24x0片內(nèi)設(shè)備驅(qū)動編寫時的時鐘問題

S3C24x0片內(nèi)設(shè)備驅(qū)動編寫時的時鐘問題

作者: 時間:2016-11-10 來源:網(wǎng)絡(luò) 收藏
前天編寫S3C24x0芯片的ADC驅(qū)動。其實(shí)很簡單,參考別人的驅(qū)動,把以前的驅(qū)動模板改改就好了??墒菍懞煤鬀]使用成功。測來測去,最后發(fā)現(xiàn)對ADC的寄存器根本無法寫入,只能讀出。郁悶!!一開始以為是我用的賦值語句不對,參考我的驅(qū)動學(xué)習(xí)文檔,試了一圈,問題依舊!郁悶了整整兩天之后,在網(wǎng)上看到有人也遇到了2410的外設(shè)寄存器無法賦值的情況,最后發(fā)現(xiàn)是時鐘問題。受此啟發(fā),我回想起了以前看的Linux的SPI驅(qū)動,里面有以下語句:

本文引用地址:http://butianyuan.cn/article/201611/317276.htm

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

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

clk_enable(hw->clk);

當(dāng)時也沒怎么在意,后悔??!之后我在DAC驅(qū)動上加了類似的語句,參考了別人的2410觸摸屏驅(qū)動,將"spi"改為"adc"。實(shí)驗(yàn)成功!

三星的S3C24x0處理器為了實(shí)現(xiàn)低功耗,增加對外設(shè)的時鐘和電源的管理。具體的內(nèi)容請看芯片手冊的《7. Clock & Power Management》這一章。雖然芯片啟動時默認(rèn)這些外設(shè)的時鐘是使能的,但在Linux下,啟動時為了節(jié)能考慮,將部分時鐘關(guān)閉了。如果沒有使能這些時鐘,就會出現(xiàn)無法對外設(shè)寄存器寫操作的情況。Linux中時鐘使能部分的源碼主要有:

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

參考這些源碼,就可以大致知道Linux是如何操作S3C24x0處理器的外設(shè)時鐘的。

特別是/arch/arm/mach-s3c2410/clock.c中的以下數(shù)據(jù)對編程有所幫助:

/* 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,
},
};




評論


技術(shù)專區(qū)

關(guān)閉