中文字幕 另类精品,亚洲欧美一区二区蜜桃,日本在线精品视频免费,孩交精品乱子片免费

<sup id="3hn2b"></sup>

    1. <sub id="3hn2b"><ol id="3hn2b"></ol></sub><legend id="3hn2b"></legend>

      1. <xmp id="3hn2b"></xmp>

      2. 新聞中心

        EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 飛思卡爾那些事之定時(shí)中斷(PIT)

        飛思卡爾那些事之定時(shí)中斷(PIT)

        作者: 時(shí)間:2016-11-27 來源:網(wǎng)絡(luò) 收藏
        前言:
        上次說到因?yàn)樵从趯τ⑽牡目謶?,沒有閱讀英文DATASHEET,想當(dāng)然的認(rèn)為XS128單片機(jī)中的定時(shí)器模塊也和DG128中定時(shí)器模塊一樣。結(jié)果造成了致命性的錯(cuò)誤,最后在瘋狂的熬夜中才將問題檢測到。
        當(dāng)然,找到問題,解決起來就簡單多了。后頭拿起DATASHEET狂肯,終于有所收獲,同時(shí)也知道了在XS128單片機(jī)中用于定時(shí)的另一個(gè)模塊:PIT(定時(shí)中斷)。為了測試一下定時(shí)中斷的,同時(shí)也解決之前單片機(jī)一直沒辦法進(jìn)入中斷的問題,特寫了一個(gè)簡單的基于定時(shí)器中斷的閃爍燈程序。
        目的:
        1、學(xué)習(xí)使用XS128PIT模塊。
        2、測試XS128核心板的中斷木塊。
        功能描述:
        通過定時(shí)中斷實(shí)現(xiàn)500MS定時(shí)。當(dāng)定時(shí)中斷觸發(fā)時(shí),對IO口進(jìn)行取反操作即可以實(shí)現(xiàn)LED500MS的閃爍。
        資源:
        1、XS128核心板,8個(gè)LED接XS128的B口。
        2、XS128的PIT模塊。
        PIT說明:
        S12PIT24B4CV1是一個(gè)模數(shù)遞減計(jì)數(shù)器。首先給計(jì)數(shù)寄存器設(shè)定一個(gè)初值,每經(jīng)過一個(gè)總線周期,計(jì)數(shù)器進(jìn)行一次減一操作,當(dāng)計(jì)數(shù)器自減溢出時(shí),觸發(fā)中斷。因?yàn)榭偩€周期是已知的,即可以通過計(jì)數(shù)器自減實(shí)現(xiàn)定時(shí)。
        在XS128PIT模塊中,需要用到得是如下幾個(gè)寄存器。
        1)、PIT Contorl and force Lad Micro Timer Register(PITCFLMT)
        該寄存器用于PIT模塊的使能設(shè)置和工作方式設(shè)置。通常設(shè)置該寄存器中的PITE為即可,即PITCFLMT_PITE=1,使PIT使能。
        2)、PIT Channel Enable Register(PITCE)
        該寄存器用于對PIT模塊中的4個(gè)通道使能進(jìn)行設(shè)置。如果使用某個(gè)通道時(shí),對對應(yīng)位進(jìn)行置一即可,即PITCE_PCEx=1,其中x代表通道序號,為0~3。
        3)、PIT Micro Timer Load Register 0 to 1 (PITMTLD0-1)
        該寄存器用于設(shè)置PIT模塊中的8位計(jì)數(shù)器初值,以實(shí)現(xiàn)24位的計(jì)數(shù)。設(shè)定值為0到255范圍。
        4)、PIT Load Register 0 to 3(PITLD0-3)
        該寄存器用于設(shè)置PIT模塊中的16位計(jì)數(shù)器初值,和8位計(jì)數(shù)器配合而成24位計(jì)數(shù)器。設(shè)定值范圍0-65535。
        5)、PIT Multiplex Register(PITMUX)
        該寄存器對定時(shí)器通道的8位時(shí)基進(jìn)行選擇。因?yàn)?位計(jì)數(shù)器只有兩個(gè),所以在將8位計(jì)數(shù)器和16位計(jì)數(shù)器連接時(shí),可以選擇不同的8位時(shí)基。
        當(dāng)設(shè)置為0時(shí),對應(yīng)通道選擇時(shí)基0;置一時(shí),對應(yīng)通道選擇時(shí)基1。
        如PITMUX_PMUX0=1為通道0選擇時(shí)基1。
        6)、PIT Interrupt Enable Register(PITINTE)
        該寄存器為中斷使能寄存器,為不同的PIT通道中斷使能。設(shè)定為0時(shí),相應(yīng)通道中斷禁止。置一時(shí),相應(yīng)通道使能。
        如PITINTE_PINTE0=1時(shí),PIT通道0定時(shí)中斷使能,當(dāng)計(jì)數(shù)器遞減溢出時(shí),申請中斷。
        7)、PIT Time-Out Flag Register(PITTF)
        該寄存器為溢出標(biāo)志位,當(dāng)某一通道的8位計(jì)數(shù)器和16位計(jì)數(shù)器遞減到0時(shí),該位置一。給改位寫1則清除該標(biāo)志位。
        可以通過查詢該位來判斷定時(shí)是否完成。

        CODE:
        #include
        #include
        #pragma LINK_INFO DERIVATIVE "mc9s12xs128"
        //==================================================
        //定時(shí)中斷函數(shù)
        //定時(shí)中斷0實(shí)現(xiàn)500MS定時(shí)
        //author:yangtze
        //time:2009/5/2
        //==================================================
        #define PITTIME5000//設(shè)定為50MS定時(shí)
        unsigned int vTmpPIT=0;

        void pllclk(void)//24MHz,外部時(shí)鐘為16MHz
        {
        CLKSEL=0X00;
        PLLCTL=0xe1;
        SYNR=2;//PLLCLK =2*OSCCLK*(SYNR + 1)/(REFDV + 1)
        REFDV=1;
        PLLCTL=0X60;
        asmNOP;
        asmNOP;
        asmNOP;
        while((CRGFLG&0X08)==0);//時(shí)鐘校正同步
        CLKSEL=0X80;
        }
        void initIOBoutput(void)//IO口初始化,B口為輸出
        {
        DDRB=0XFF;
        PORTB=0XFF;
        }
        void initPIT(void)//定時(shí)中斷初始化函數(shù) 50MS定時(shí)中斷設(shè)置
        {
        PITCFLMT_PITE=0; //定時(shí)中斷通道0關(guān)
        PITCE_PCE0=1;//定時(shí)器通道0使能
        PITMTLD0=240-1;//8位定時(shí)器初值設(shè)定。240分頻,在24MHzBusClock下,為0.1MHz。即
        10us.
        PITLD0=PITTIME-1;//16位定時(shí)器初值設(shè)定。PITTIME*0.01MS
        PITINTE_PINTE0=1;//定時(shí)器中斷通道0中斷使能
        PITCFLMT_PITE=1;//定時(shí)器通道0使能
        }

        void main(void)
        {
        pllclk();
        initIOBoutput();
        initPIT();
        EnableInterrupts;
        for(;;) {}

        }

        #pragma CODE_SEG __NEAR_SEG NON_BANKED
        void interrupt 66 PIT0(void)
        {
        vTmpPIT++;
        if(vTmpPIT==10)
        {
        PORTB=~PORTB;//輸出取反
        vTmpPIT=0;
        }
        PITTF_PTF0=1;//清中斷標(biāo)志位
        }


        評論


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

        關(guān)閉