機(jī)電之家資源網(wǎng)
單片機(jī)首頁(yè)|單片機(jī)基礎(chǔ)|單片機(jī)應(yīng)用|單片機(jī)開(kāi)發(fā)|單片機(jī)文案|軟件資料下載|音響制作|電路圖下載 |嵌入式開(kāi)發(fā)
培訓(xùn)信息
贊助商
一種多時(shí)鐘系統(tǒng)的設(shè)計(jì)源程序
一種多時(shí)鐘系統(tǒng)的設(shè)計(jì)源程序
 更新時(shí)間:2010-1-11 16:11:34  點(diǎn)擊數(shù):0
【字體: 字體顏色

以下是筆者用AHDL Altera HDL語(yǔ)言寫(xiě)的關(guān)于外部PLL控制器,50%占空比的5分頻和50%占空比的3分頻模塊的源程序及其生成的模塊圖,程序中文字部分為注釋。

AHDL Altera 公司的硬件邏輯描述語(yǔ)言的簡(jiǎn)稱(chēng),其特點(diǎn)是非常易學(xué)易用,學(xué)過(guò)高級(jí)語(yǔ)言的人可以在很短的時(shí)間(如幾周)內(nèi)掌握AHDL。它的缺點(diǎn)是移植性不好,通常只用于ALTERA自己的開(kāi)發(fā)系統(tǒng)。

    由于我們研發(fā)的系統(tǒng)采用“自頂向下”層次化設(shè)計(jì)的思想,這里提供的只是各個(gè)模塊的源程序,在實(shí)際設(shè)計(jì)中采用以下源程序生成各個(gè)相應(yīng)的模塊,然后在頂層文件中加以組合,以完成相應(yīng)的功能。

----------------------------------------------------------------------------------------------------------------------

--該程序?yàn)橥獠?/SPAN>PLL系數(shù)控制源程序

SUBDESIGN Pll_control      -- 設(shè)計(jì)實(shí)體名;

(

         gear_v[1..0]: INPUT;     --定義一個(gè)模4計(jì)數(shù)器的輸出值作為該控制器的輸入;       --4計(jì)數(shù)器用于記錄切換按鍵的脈沖,每按一次按鍵,計(jì)數(shù)器加1;

       v[8..0],r[6..0],s[2..0]: OUTPUT;

)

BEGIN

  TABLE

       gear_v[1..0]=> v[8..0],r[6..0],s[2..0];

        0       => B"001111000",B"0010111",B"100";

        1       => B"100000000",B"0010111",B"100";

        2       => B"010101011",B"0010111",B"100";

           3       => B"100001000",B"0010111",B"100";

  END TABLE;

END;

----------------------------------------------------------------------------------------------------------------------

 

-----------------------------------------------------------------------------------------------------------------------

--該程序?yàn)?/SPAN>50%占空比5分頻模塊源程序

SUBDESIGN clk_divider_5      -- 設(shè)計(jì)實(shí)體名;

(

    Clock, en         : INPUT;

    Divide_Clk       : OUTPUT;

)

VARIABLE

    Interior_Clk          : Node; -- 建立一個(gè)內(nèi)部時(shí)鐘;

    Divide_DFF[1..0]      : DFF;  -- 說(shuō)明一個(gè) D 觸發(fā)組;

    Result_DFF          : DFF;  -- 建立一個(gè)輸出 D 觸發(fā)器;

BEGIN

    IF en THEN

      Interior_Clk       = Clock $ Result_DFF;   -- 輸入時(shí)鐘異或結(jié)果觸發(fā)器值;    

      Divide_DFF[].Clk  = Interior_Clk;            -- D 觸發(fā)器的時(shí)鐘連接;

      IF Divide_DFF[] = = 2  THEN  --D 觸發(fā)器的輸入端處理;

         Divide_DFF[].D = 0;         

      ELSE

         Divide_DFF[].D = Divide_DFF[] + 1;  

      END IF;

    -- 計(jì)數(shù)器計(jì)滿一次,結(jié)果觸發(fā)器翻轉(zhuǎn)一次;

      Result_DFF.Clk = Divide_DFF[1];

      Result_DFF.D  = !Result_DFF;             

      Divide_Clk     =  Result_DFF;  -- 分頻信號(hào)輸出;

    END IF;

END;

-----------------------------------------------------------------------------------------------------------------------

-----------------------------------------------------------------------------------------------------------------------

--該程序?yàn)?/SPAN>50%占空比3分頻模塊源程序

SUBDESIGN clk_divider_3      -- 設(shè)計(jì)實(shí)體名;

(

    Clock, en         : INPUT;

    Divide_Clk       : OUTPUT;

)

VARIABLE

    Interior_Clk         : Node; -- 建立一個(gè)內(nèi)部時(shí)鐘;

    Divide_DFF         : DFF;  -- 說(shuō)明一個(gè) D 觸發(fā)器;

    Result_DFF         : DFF;  -- 建立一個(gè)輸出 D 觸發(fā)器;

BEGIN

    IF en THEN

      Interior_Clk       = Clock $ Result_DFF;   -- 輸入時(shí)鐘異或結(jié)果觸發(fā)器值;    

      Divide_DFF[].Clk  = Interior_Clk;            -- D 觸發(fā)器的時(shí)鐘連接;

      IF Divide_DFF[] = = 1  THEN  --D 觸發(fā)器的輸入端處理;

         Divide_DFF[].D = 0;          

      ELSE

         Divide_DFF[].D = Divide_DFF[] + 1;  

      END IF;

    -- 計(jì)數(shù)器計(jì)滿一次,結(jié)果觸發(fā)器翻轉(zhuǎn)一次;

      Result_DFF.Clk  = Divide_DFF;

      Result_DFF.D   = !Result_DFF;             

      Divide_Clk     =  Result_DFF;  -- 分頻信號(hào)輸出;

    END IF;

END;

-------------------------------------------------------------------------------------------------------------------

 對(duì)于模10分頻器,因?yàn)槭桥紨?shù)倍分頻,可直接調(diào)用Quartus II開(kāi)發(fā)工具中參數(shù)化計(jì)數(shù)器來(lái)實(shí)現(xiàn)。為確保占空比為50%,先進(jìn)行5分頻,然后進(jìn)行2分頻實(shí)現(xiàn)。具體如下圖所示:

  • 上一篇: 一種基于PCI IP核的碼流接收卡的設(shè)計(jì)
  • 下一篇: 沒(méi)有了
  • 發(fā)表評(píng)論   告訴好友   打印此文  收藏此頁(yè)  關(guān)閉窗口  返回頂部
    熱點(diǎn)文章
     
    推薦文章
     
    相關(guān)文章
    網(wǎng)友評(píng)論:(只顯示最新5條。)
    關(guān)于我們 | 聯(lián)系我們 | 廣告合作 | 付款方式 | 使用幫助 | 機(jī)電之家 | 會(huì)員助手 | 免費(fèi)鏈接

    點(diǎn)擊這里給我發(fā)消息66821730(技術(shù)支持)點(diǎn)擊這里給我發(fā)消息66821730(廣告投放) 點(diǎn)擊這里給我發(fā)消息41031197(編輯) 點(diǎn)擊這里給我發(fā)消息58733127(審核)
    本站提供的機(jī)電設(shè)備,機(jī)電供求等信息由機(jī)電企業(yè)自行提供,該企業(yè)負(fù)責(zé)信息內(nèi)容的真實(shí)性、準(zhǔn)確性和合法性。
    機(jī)電之家對(duì)此不承擔(dān)任何保證責(zé)任,有侵犯您利益的地方請(qǐng)聯(lián)系機(jī)電之家,機(jī)電之家將及時(shí)作出處理。
    Copyright 2007 機(jī)電之家 Inc All Rights Reserved.機(jī)電之家-由機(jī)電一體化網(wǎng)更名-聲明
    電話:0571-87774297 傳真:0571-87774298
    杭州濱興科技有限公司提供技術(shù)支持

    主辦:杭州市高新區(qū)(濱江)機(jī)電一體化學(xué)會(huì)
    中國(guó)行業(yè)電子商務(wù)100強(qiáng)網(wǎng)站

    網(wǎng)站經(jīng)營(yíng)許可證:浙B2-20080178-1