在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

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

            S3C24x0片內(nèi)設(shè)備驅(qū)動(dòng)編寫(xiě)時(shí)的時(shí)鐘問(wèn)題

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

            本文引用地址:http://www.biyoush.com/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)時(shí)也沒(méi)怎么在意,后悔啊!之后我在DAC驅(qū)動(dòng)上加了類似的語(yǔ)句,參考了別人的2410觸摸屏驅(qū)動(dòng),將"spi"改為"adc"。實(shí)驗(yàn)成功!

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

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

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

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

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




            評(píng)論


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

            關(guān)閉