PIC單片機人機接口模塊元器件選擇
12~20根為PIC16C5X的雙向可獨立編程I/O口,每根I/O口都可由程序來(lái)編程決定其輸入/輸出方向。PIC16C5X有5種型號,如表1所示
表一 PIC16C5X管腳
PIC16C5X管腳圖如圖1所示
圖1 PIC16C5X管腳圖
各引腳的功能描述如表2所示
表2 各引腳的功能
?。?)內部結構。
PIC16CSX在一個(gè)芯片上生成了一個(gè)8位算術(shù)邏輯單元ALU和工作寄存器W;384bit~2KB的12位程序存儲器ROM;32~80個(gè)8行數據寄存器RAM;12~20個(gè)I/O口端:8位計數器及預分頻器;時(shí)鐘、復位及看門(mén)狗計數器等,內部結構如圖2所示。
圖2 PIC16C5X的內部結構
如圖2所示,PIC16C5X有個(gè)特點(diǎn),就是把數據存儲器RAM當作寄存器來(lái)尋址以方便編程。寄存器組按功能分為兩部分,即特殊寄存器組和通用寄存器組。特殊寄存器組包括實(shí)時(shí)鐘計數器RTCC、程序計數器PC、狀態(tài)寄存器Status、I/O口寄存器以及存儲體選擇寄存器FSR。
PIC總線(xiàn)結構采取數據線(xiàn)(8位)和指令線(xiàn)(2位)獨立分離的哈佛(Harvard)結構,這樣可使單片機的指令速度得到提高。當一條指令在A(yíng)LU中執行時(shí),下一條指令己經(jīng)被取出放到指令寄存器等待執行了。算術(shù)邏輯單元ALU和工作寄存器(W)承擔算術(shù)邏輯操作任務(wù)。
PIC16C5X提供二級堆棧(Stack),所以子程序調用只有兩層,使用時(shí)一定要注意這點(diǎn),否則程序運行時(shí)將失去控制。PICIGC5X內部有384bit~2KB的只讀程序存儲器,下面介紹其結構和堆棧,PICIGC5X程序存儲器結構如圖3所示。
圖3 PIC16C5X程序存儲器結構
從圖3可以看出,PIC程序存儲器采用分頁(yè)結構,每頁(yè)長(cháng)0.5KB,因此PIC16C52程序存儲器在1頁(yè)之內,而PIC16C54和PICISC55程序存儲器容量為1頁(yè),PICI6C56和PICI6C57的容量則分別為2頁(yè)和4頁(yè)。頁(yè)面地址由狀態(tài)寄存器B的第5位和第6位(PA0、PA1)確定。
程序轉移時(shí),在本頁(yè)內可直接進(jìn)行,在需跨頁(yè)跳轉時(shí)(GOTO、CALL指令),則必須根據將要跳轉去的頁(yè)面,把f3中的PA0、PA1位置成相應的值。
?。?)相關(guān)指令。
堆棧PICIGC5X設有兩層堆棧,堆棧1和堆棧2,供子程序調用。涉及堆棧操作的指令有兩條。
?、貱ALL。
在主程序中第一次執行CALL指令時(shí),將PC值加1后推入堆棧1,堆棧1原有的內容則被推入堆棧2中。這時(shí)子程序中還可再做一次子程序嵌套,即再執行一次CALL指令。如果子程序調用多于二層時(shí),堆棧中只存放最近的兩個(gè)返回地址。
當執行一條CALL指令時(shí),狀態(tài)寄存器F3中將頁(yè)面尋址位PA1、PA0置入PC的最高兩位(第11位和第10位),而PC的第9位總是被置為0,如圖4所示。
圖4 PC值對應圖
這意味著(zhù)在PIC16C5X中,子程序起始地址只能放在每個(gè)程序存儲頁(yè)面的上半頁(yè),即低地址的那一半(000~0FF、200~2FF、400~4FF、600~6FF)。
調用子程序前必須先把F3中的PA0、PA1設置成該子程序所在的頁(yè)面地址,返回后再將其恢復成當前的頁(yè)面值,但如果這時(shí)子程序是在同一頁(yè)面,則可省去這一過(guò)程。
?、赗ETLW。
該指令把堆棧1的值寫(xiě)入PC,同時(shí)還把堆棧2的值拷貝到堆棧1去。子程序總是返回到調用它時(shí)所在的位置,不管它處在什么頁(yè)面,也不管F3寄存器中的PA0、PA1此時(shí)指在什么頁(yè)面。
但是執行RETLW(子程序返回)指令并不會(huì )改變F3中PA0、PA1的值,所以當從一次跨頁(yè)面的子程序調用返回時(shí),不要忘了恢復F3中原先PA0和PA1值。
由于堆棧和PC的寬度是相同的,所以可以在程序的任何位置執行一條CALL指令來(lái)調用子程序。但是對于跨頁(yè)面的調用,要小心處理B中的頁(yè)面地址位PA0和PA1。
分頻器相關(guān)文章:分頻器原理
評論