欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3964|回復: 1
收起左側

關于中檔PIC系列單片機的頁和PCLATH

[復制鏈接]
ID:104287 發表于 2016-1-31 20:49 | 顯示全部樓層 |閱讀模式

首先想從CALL和GOTO指令的機器碼講起。PIC16是14位的長字指令,操作碼和操作數放到同一個指令字里,也就是所謂單字指令。

CALL 指令(14位的指令字長)

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

| 1| 0| 0| k| k| k| k| k| k| k| k| k| k| k|

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

100是CALL指令的操作碼,GOTO指令類似上面,只是操作碼為101.后面11位的k,就是所要CALL或者GOTO的地址。顯然,11位的地址只能訪問2K的地址范圍,為了實現在8K范圍內調用和跳轉,于是引入了Page的概念。Page其實就是實際要調用或跳轉到的地址的高兩位。PC的高兩位在發生GOTO或CALL指令時從PCLATH寄存器的4:3位裝入(如下圖)

   PCLATH 5bits

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

|4|3|          |

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

  |

  V

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

|x|x|          | |                   |  (實際PC)

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

   PCH 5bits           PCL 8bits

PC 13bit地址,可尋址8K字程序空間。

所以,在CALL或者GOTO指令執行前,要設定好PCLATH的4:3位,也就是設置好Page.PC的高位字節PCH是不可由程序直接寫入的,它必須是在PC改變時通過它的鎖存器PCLATH裝入。PCLATH始終是作為裝載PCH用的一個鎖存器,它自己的值不會隨著PCH的改變而改變。一個很簡單的例子,程序假如順序執行從00一直到8K末尾,這樣PCH的最高兩位也就從00一直變成11,但PCLATH的高兩位,如果你沒有人為改變,原來是什么還是什么。當CALL子程序時,CALL指令當前PC+1的13位PC地址壓入堆棧(因為硬件堆棧是和PC等寬的)。所以RETURN時能從堆棧彈出整個13位PC的返回地址,就不再需瓚≒CLATH了。但是,要記住,不設定并不代表它自己會改變。假設你CALL之前設定到Page1了,Return之后回到Page0了,但此時,PCLATH里的4:3位還是0:1。當發生直接修改PC時,也就是直接改寫PCL,如addwf PCL,F

此時,在改寫PCL的同時,作為PCH鎖存器的PCLATH會把整個5位的值瞬間傳遞給PCH,如下圖

PCLATH 5bits

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

| 4| 3| 2| 1| 0|

----------------     程序修改PC低位字節

       |                  |

       V                  V

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

| x| x| x| x| x| |                   |  (實際PC)

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

  PCH 5bits           PCL 8bits


PCLATH是個很重要的寄存器,你對它稍不注意,它就會讓你跑飛.

回復

使用道具 舉報

ID:124627 發表于 2016-6-2 10:05 | 顯示全部樓層
謝謝樓主分享經驗
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表