51單片機程序存儲器和數據存儲器

轉載地址:http://www.eeworld.com.cn/mcu/2015/0817/article_21731.html

(文字略有改動)

      爲了保證程序能夠連續地執行下去,CPU必須具有某些手段來確定一條指令的地址。程序計數器PC正是起到了這種作用,所以通常又稱其爲指令地址計數器。在程序開始執行前,必須將其起始地址即程序的第一條指令所在的內存單元地址送入PC。當執行指令時,CPU將自動修改PC的內容,使之總是保存將要執行的下一個條指令的地址。由於大多數都是按順序執行的,所以修改的過程只是簡單的加1操作。

下面我們看看8051的存儲器系統:(此章非常重要,請仔細理解)

        8051序列單片機與一般微機的存儲器配置方式不相同。一般微機通常只有一個地址空間,ROM和RAM可以隨意安排在這一地址範圍內不同的空間,即ROM和RAM的地址同在一個隊列裏分配不同的地址空間。CPU訪問存儲器時,一個地址對應唯一的存儲單元,可以是ROM也可以是RAM,並用同類訪問指令。此種存儲器結構稱普林斯頓結構(普林斯頓結構 VS 哈佛結構)。

 

       8051的存儲器在物理結構上分程序存儲器空間和數據存儲器空間。有四個存儲空間:片內程序存儲器和片外程序存儲空間以及片內數據存儲器和片外數據存儲器。這種程序存儲器和數據存儲器分開的結構形式,稱爲哈佛結構。但從用戶使用的角度,8051存儲器地址空間分爲三類:

1、片內,片外統一編址0000H—FFFFH的64K字節的程序存儲器地址空間,用16位地址;

2、64K字節片外數據存儲器地址空間,地址也從0000H—FFFFH,用16位地址;

3、256K字節數據存儲器地址空間,用8位地址。

上述三個存儲空間地址是重迭的,任何區別這三個不同的邏輯空間呢?8051的指令系統設計了不同的數據傳送指令符號:CPU訪問片內片外ROM指令用MOVC,訪問片外指令用MOVX,訪問片內RAM指令用MOV。

一  程序存儲器地址空間

       8051程序存儲器用於存放編好的程序和表格常數。程序存儲器通過16位程序計數器PC尋址,尋址能力爲64K字節。8051,8751的64程序存儲器片內ROM爲4K字節,地址爲0000H—0FFFH,片外最多可擴至64K字節ROM,地址1000H—FFFFH,片內外是統一編址的。

        當引腳EA接高電平時,8051程序計數器PC在0000H—0FFFH範圍內,即前4K字節地址執行片內ROM中的程序;當指令地址超過0FFFH後,就自動地轉向片外ROM指令。

        當引腳EA接低電平時,8051片內ROM不起作用,CPU只能從片外ROM中取指令,地址可以從000H開始編址。這種接法特別適用於採用8031單片機的場合,由於8031片內不帶ROM,所以使用使必須使EA=0.以便能夠從外部擴展EPROM中取指令。

 

       8051從片內程序存儲器和片外程序存儲器取值時執行速度相同。程序存儲器的某些單元是留給系統使用的。

       存儲單元0000H-0002H用作8051上電覆位後引導程序存放單元。因爲8051上電覆位後程序計數器PC的內容爲         0000H,所以CPU總是從0000H開始執行程序。如果在這三個單元中存有轉移指令,那麼程序就被引導到轉移指令指定的ROM空間去執行。

        0003H—0023H單元均勻地分爲五段,用作五個中斷服務程序的入口,因爲這五個入口之間的間隔較小,因此,一般說來這五個入口處都是放的一條跳轉指令,而把真正的中斷服務程序視情況安排在後面的存儲器中。這五個入口分別是:

0003h:

外部中斷0的入口地址,當外部中斷引腳INT0,即P3.2有效時,引起中斷申請,CPU響應中斷後自動將地址0003H裝入程序計數器PC,程序就被轉換到0003H去執行外部中斷0的中斷服務程序。

000Bh:

定時器0溢出中斷的入口地址,當定時器T0產生溢出時,引起中斷申請,CPU響應中斷後自動將地址000BH裝入程序計數器PC, 程序就被轉移到000BH去執行定時器0的中斷服務程序。

     0013h:

  外部中斷1的入口地址,當外部中斷引腳INT1,即P3.3有效時,引起中斷申請,CPU響應中斷後自動將地址0013H裝入程序計數器PC, 程序就被轉移到0013H去執行外部中斷1的中斷服務程序。

     001Bh:

定時器1溢出中斷的入口地址,當定時器T1產生溢出時,引起中斷申請,CPU響應中斷後自動將地址001BH裝入程序計數器PC, 程序就被轉3移到0003H去執行定時器1的中斷服務程序。

    0023h:

串行接口中斷的入口地址,當串行接口接收或發送完一個數據後,引起中斷申請,CPU響應中斷後自動將地址0023H裝入程序計數器PC,程序就被轉移到0023H去串行接口中斷服務程序。

 

 二.數據存儲器地址空間。

        數據存儲器RAM用於存放運算中的中間結果,數據暫存,緩衝,標誌位等。數據存儲器空間也分爲片內和片外兩部分,即片內RAM和片外RAM。

   8051片外數據存儲器空間爲64K,從0000H—FFFFH;片內存儲器空間爲256字節,地址從0000H—00FFH。

(一)片外RAM

         片外數據存儲器與片內數據存儲器空間低地址0000H—00FFH是重迭的,如何區分片內,片外RAM空間呢?8051有MOV和MOVX兩種指令,用於區分片內片外RAM空間。片內RAM使用MOV指令,片外64KRAM空間專門爲MOVX指令使用。

 

(二)片內RAM數據存儲器最大可尋址256個單元,它們又分爲兩個部分:

低128字節,00H—7FH,是真正的RAM區。高128字節,80H—FFH,爲特殊功能寄存器區。

       低128字節RAM ,00H—1FH地址安排爲四組寄存器區,每組有八個工作寄存器,即R0-R7,,共佔32個單元。通過對程序狀態字PSW中RS1,RS0兩位的設置,每組寄存器可選作CPU的當前工作寄存器組。若程序中並不需要四組,那麼其餘可用作一般RAN單元。CPU復位後,選中第0組工作寄存器。

工作寄存器區後的16字節單元,即20H—2FH,可以位尋址方式訪問其各位,這128個位的地址爲00H—7FH。低128字節RAM單元地址範圍也是00H—7FH,8051採用不同尋址方式加以區分,即訪問128個位地址用位尋址方式。訪問低128字節單元用直接尋址或間接尋址,這樣就可以區分開00H—7FH是位地址還是字節地址,尋址方式以後再講。通過執行指令可直接對某一位操作,如置1,請0或判1,判0等,可用作軟件標誌位或用於位處理。

       高128字節RAM,特殊功能寄存器,8051片內高128字節RAM中,除程序計數器PC外,有21專用寄存器,也稱特殊功能寄存器,它們離散地分佈在80H—FFH的RAM空間中。在21個特殊功能寄存器中,有11個特殊功能寄存器具有位尋址能力,它們的字節地址正好能被8整除,下面介紹部分特殊功能寄存器,其餘將在後面講述:

(1)累加器ACC

累加器ACC是8051最常見,最繁忙的八位特殊功能寄存器,許多指令的操作數取自於ACC,許多運算結果也存放於ACC中。在指令系統中採用A作爲累加器ACC的助記符。

(2)寄存器B

在乘,除指令中,用到了8位B寄存器。乘法指令的兩個操作數分別來自A和B,乘積存放於B,A兩個8位寄存器中。除法指令中,A中存放被除數,B中放除數,商存放於A中,B中存放餘數。在其他指令中,B可作爲一般通用寄存器或一個RAM單元使用。

 

(3)程序狀態寄存器PSW

PSW是一個8位特殊功能寄存器,它的各位包含了程序執行後的狀態信息,供程序查詢或判別之用。各位的含義及其格式如下:

 PSW除有確定的字節地址D0H外,每一位均有位地址。

PY,PSW.7,進位標誌位。在執行加法或減法運算指令時,如果運算結果最高位即位7,向前有進位或借位,CY位由硬件置1,如運算結果最高位無進位或借位,則CY清0。CY也是8051在進行位操作時的累加器。

AC,PSW.6半標記位,也稱輔助進位標誌。當執行加法或減法操作時,其運算結果產生由低半字節,即位3向高半字節有半進位或借位時AC位將被硬件自動置1,否則AC被自動清0。

PSW.5,用戶標誌位。用戶可以根據自己的需要對F0位賦予一定含義,由用戶置位,復位,系統沒有規定它的意義。

RS0,和RS1,PSW.3,和PSW.4,工作寄存器組選擇控制位。這兩位的值決定選擇哪一組工作寄存器爲當前工作寄存器組。由用戶用軟件改變RS1和RS0值的組合,以切換當前選用的工作寄存器組。

當RS1=0,RS0=0時,工作寄存器組定位在00到07單元,即此時R0就是00,R1就是01,R2就是02,R3就是03,R4就是04,R5就是05,R6就是06,R7就是07。

當RS1=0,RS0=1時,工作寄存器組定位在08到0F單元;

       當RS1=1,RS0=0時,工作寄存器組定位在10到17單元;

       當RS1=1,RS0=1時,工作寄存器組定位在18到1F單元;

8051上電覆位後, RS1=0,RS0=0,工作寄存器組定位在00到07單元;

根據需要,可利用傳送指令對PSW整字節操作或用位操作指令改變RS1和RS0的狀態,以切換當前工作寄存器組。這樣的設置對程序中保護現場提供了方便。

OV,PSW.2,溢出標誌位。當進行補碼運算時,如有溢出,即當運算結果超出-128到+127的範圍時,OV位由硬件自動置1;無溢出時,OV=0,

PSW.1,爲保留位,8051未用,8052爲F1用戶標誌位。P, PSW.0,奇偶檢驗標誌位。每條指令執行後,該位始終跟蹤指示累加器A中1的個數。如結果A中有奇數個1,則置P=1,否則P=0.常用於校驗串行通訊中的數據傳送是否出錯。

 

(4)堆棧指針SP

堆棧指針SP爲8位特殊功能寄存器,SP的內容即堆棧指針可指向8051片內00H—7FH RAM的任何單元。系統復位後,SP初始化爲07H,即指向07H的RAM單元。下面介紹一下堆棧的概念。

   8051同一般微機處理器一樣,設有堆棧。在片內RAM中專門開闢出一個區域,數據的存取是以“後進先出”的結構方式處理的。這種數據結構方式對於中斷,調用子程序都非常方便。堆棧的操作有兩種:

一種叫數據壓入,即PUSH;另一種叫數據彈出,即POP。棧頂由堆棧指針SP自動管理。每次進行壓入或彈出操作以後,堆棧指針便自動調整以保持指示堆棧頂部的位置。在使用堆棧之前,先給SP賦值,以規定堆棧的起始位置,稱爲棧 底。

當數據壓入堆棧後SP自動加1以指出當前棧頂位置。8051的堆棧指針SP是一個雙向計數器。在壓棧時SP內容自動增值,出棧時自動減值,存取信號必須按照“後進先出”的原則。

 

(5)數據指針DPTR

DPTR是一個16位的特殊功能寄存器,其高位字節寄存器用DPH表示,地址83H,低位字節寄存器用DPL表示,地址82H。DPTR既可以作爲一個16位寄存器來處理,也可以作爲兩個獨立的8位寄存器DPH和DPL使用。

 

(6)IO端口P0,P1,P2,P3.

P0,P1,P2,P3.爲四個8位特殊功能寄存器,分別是四個並行IO端口的鎖存器。它們都是有字節地址,每一個鎖存器還有位地址,所以每一個IO線獨立地作輸入時,數據可以鎖存,作輸出時數據可以緩衝。8051的中斷源包括:定時計數器0,定時計數器1,外中斷0,外中斷1,串口中斷,除上述資源外8051還有40條引腳(關於這40條引腳,請查看相關資料)。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章