<li id="8g3ty"><tbody id="8g3ty"><th id="8g3ty"></th></tbody></li>
    <label id="8g3ty"><samp id="8g3ty"></samp></label>
  • <span id="8g3ty"></span>

    1. <center id="8g3ty"><optgroup id="8g3ty"></optgroup></center>
    2. <bdo id="8g3ty"><meter id="8g3ty"><bdo id="8g3ty"></bdo></meter></bdo><center id="8g3ty"><optgroup id="8g3ty"></optgroup></center>
      <label id="8g3ty"><samp id="8g3ty"></samp></label>

    3. 電子開發網

      電子開發網電子設計 | 電子開發網Rss 2.0 會員中心 會員注冊
      搜索: 您現在的位置: 電子開發網 >> 電子開發 >> 單片機 >> 正文

      MCS-51單片機的指令時序

      作者:佚名    文章來源:本站原創    點擊數:    更新時間:2008-10-31
           時序是用定時單位來描述的,MCS-51的時序單位有四個,它們分別是節拍、狀態、機器周期和指令周期,接下來我們分別加以說明。
      •     節拍與狀態:
            我們把振蕩脈沖的周期定義為節拍(為方便描述,用P表示),振蕩脈沖經過二分頻后即得到整個單片機工作系統的時鐘信號,把時鐘信號的周期定義為狀態(用S表示),這樣一個狀態就有兩個節拍,前半周期相應的節拍我們定義為1(P1),后半周期對應的節拍定義為2(P2)。
      •    機器周期:
            MCS-51有固定的機器周期,規定一個機器周期有6個狀態,分別表示為S1-S6,而一個狀態包含兩個節拍,那么一個機器周期就有12個節拍,我們可以記著S1P1、S1P2……S6P1、S6P2,一個機器周期共包含12個振蕩脈沖,即機器周期就是振蕩脈沖的12分頻,顯然,如果使用6MHz的時鐘頻率,一個機器周期就是2us,而如使用12MHz的時鐘頻率,一個機器周期就是1us。
      •     指令周期:
            執行一條指令所需要的時間稱為指令周期,MCS-51的指令有單字節、雙字節和三字節的,所以它們的指令周期不盡相同,也就是說它們所需的機器周期不相同,可能包括一到四個不等的機器周期(這些內容,我們將在下面的章節中加以說明)。

          MCS-51的指令時序:
          MCS-51指令系統中,按它們的長度可分為單字節指令、雙字節指令和三字節指令。執行這些指令需要的時間是不同的,也就是它們所需的機器周期是不同的,有下面幾種形式:

      •     單字節指令單機器周期
      •     單字節指令雙機器周期
      •     雙字節指令單機器周期
      •     雙字節指令雙機器周期
      •     三字節指令雙機器周期
      •     單字節指令四機器周期(如單字節的乘除法指令)

          下圖是MCS-51系列單片機的指令時序圖:
        
           上圖是單周期和雙周期取指及執行時序,圖中的ALE脈沖是為了鎖存地址的選通信號,顯然,每出現一次該信號單片機即進行一次讀指令操作。從時序圖中可看出,該信號是時鐘頻率6分頻后得到,在一個機器周期中,ALE信號兩次有效,第一次在S1P2和S2P1期間,第二次在S4P2和S5P1期間。
          接下來我們分別對幾個典型的指令時序加以說明。

      •     單字節單周期指令:
            單字節單周期指令只進行一次讀指令操作,當第二個ALE信號有效時,PC并不加1,那么讀出的還是原指令,屬于一次無效的讀操作。
      •     雙字節單周期指令:
            這類指令兩次的ALE信號都是有效的,只是第一個ALE信號有效時讀的是操作碼,第二個ALE信號有效時讀的是操作數。
      •    單字節雙周期指令:
            兩個機器周期需進行四讀指令操作,但只有一次讀操作是有效的,后三次的讀操作均為無效操作。
            單字節雙周期指令有一種特殊的情況,象MOVX這類指令,執行這類指令時,先在ROM中讀取指令,然后對外部數據存儲器進行讀或寫操作,頭一個機器周期的第一次讀指令的操作碼為有效,而第二次讀指令操作則為無效的。在第二個指令周期時,則訪問外部數據存儲器,這時,ALE信號對其操作無影響,即不會再有讀指令操作動作。

          上頁的時序圖中,我們只描述了指令的讀取狀態,而沒有畫出指令執行時序,因為每條指令都包含了具體的操作數,而操作數類型種類繁多,這里不便列出,有興趣的讀者可參閱有關書籍。

          外部程序存儲器(ROM)讀時序
       
          圖8051外部程序存儲器讀時序圖,從圖中可看出,P0口提供低8位地址,P2口提供高8位地址,S2結束前,P0口上的低8位地址是有效的,之后出現在P0口上的就不再是低8位的地址信號,而是指令數據信號,當然地址信號與指令數據信號之間有一段緩沖的過度時間,這就要求,在S2其間必須把低8位的地址信號鎖存起來,這時是用ALE選通脈沖去控制鎖存器把低8位地址予以鎖存,而P2口只輸出地址信號,而沒有指令數據信號,整個機器周期地址信號都是有效的,因而無需鎖存這一地址信號。 
           從外部程序存儲器讀取指令,必須有兩個信號進行控制,除了上述的ALE信號,還有一個PSEN(外部ROM讀選通脈沖),上圖顯然可看出,PSEN從S3P1開始有效,直到將地址信號送出和外部程序存儲器的數據讀入CPU后方才失效。而又從S4P2開始執行第二個讀指令操作。

          外部數據存儲器(RAM)讀時序
       
          上圖8051外部數據存儲器讀寫時序圖,從ROM中讀取的需執行的指令,而CPU對外部數據存儲的訪問是對RAM進行數據的讀或寫操作,屬于指令的執行周期,值得一提的是,讀或寫是兩個不同的機器周期,但他們的時序卻是相似的,我們只對RAM的讀時序進行分析。
          上一個機器周期是取指階段,是從ROM中讀取指令數據,接著的下個周期才開始讀取外部數據存儲器RAM中的內容。 
           在S4結束后,先把需讀取RAM中的地址放到總線上,包括P0口上的低8位地址A0-A7和P2口上的高8位地址A8-A15。當RD選通脈沖有效時,將RAM的數據通過P0數據總線讀進CPU。第二個機器周期的ALE信號仍然出現,進行一次外部ROM的讀操作,但是這一次的讀操作屬于無效操作。
          對外部RAM進行寫操作時,CPU輸出的則是WR(寫選通信號),將數據通過P0數據總線寫入外部存儲器。

      Tags:51單片機,MCS-51單片機,指令時序  
      責任編輯:admin
      相關文章列表
      沒有相關文章
      請文明參與討論,禁止漫罵攻擊,不要惡意評論、違禁詞語。 昵稱:
      1分 2分 3分 4分 5分

      還可以輸入 200 個字
      [ 查看全部 ] 網友評論
      關于我們 - 聯系我們 - 廣告服務 - 友情鏈接 - 網站地圖 - 版權聲明 - 在線幫助 - 文章列表
      返回頂部
      刷新頁面
      下到頁底
      晶體管查詢
      主站蜘蛛池模板: 亚洲丁香婷婷综合久久| 亚洲乱码中文字幕小综合| 天天综合色一区二区三区| 成人精品综合免费视频| 国产精品综合久成人| 亚洲AV综合色区无码一区| 色综合久久综合中文小说| 狠狠色丁香久久综合婷婷 | 色婷婷综合久久久中文字幕| 五月天婷婷综合网| 九九综合VA免费看| 亚洲欧美熟妇综合久久久久| 狠狠色综合网站久久久久久久高清| 亚洲av永久综合在线观看尤物 | 狠狠88综合久久久久综合网| 亚洲国产精品成人综合久久久 | 伊人色综合一区二区三区| 一本色道久久综合无码人妻| 国产成人麻豆亚洲综合无码精品| 婷婷综合久久狠狠色99H| 91综合精品网站久久| 国产精品国色综合久久| 伊人不卡久久大香线蕉综合影院| 色噜噜狠狠狠色综合久| 色噜噜狠狠色综合成人网| 在线精品国产成人综合| 久久综合鬼色88久久精品综合自在自线噜噜 | 亚洲综合一区二区精品久久| 久久久久一级精品亚洲国产成人综合AV区| 综合五月激情五月开心婷婷| 五月丁香综合激情六月久久| 色噜噜狠狠狠综合曰曰曰| 成人综合伊人五月婷久久| 亚洲国产综合精品中文字幕| 亚洲国产aⅴ综合网| 亚洲国产成人精品无码久久久久久综合| 亚洲a∨国产av综合av下载| 狠狠色丁香婷婷综合潮喷| 色婷婷综合久久久久中文字幕| 狠狠色综合久久婷婷色天使| 久久综合久久鬼色|