存儲器是許多存儲單元的集合,存儲器單元實際上是時序邏輯電路(鎖存器)的一種,按單元號順序排列。每個單元由若干二進制位構(gòu)成,以表示存儲單元中存放的數(shù)值,這種結(jié)構(gòu)和數(shù)組的結(jié)構(gòu)非常相似。按存儲器的使用類型可分為只讀存儲器(ROM)和隨機存取存儲器(RAM)。
1.1 存儲單位
位(bit):它是計算機中最小的數(shù)據(jù)單位。由于計算機采用二進制數(shù),所以1位二進制數(shù)稱作1bit,例如101011為6bit。
字節(jié)(Byte,單位簡寫為B):8位二進制數(shù)稱為一個字節(jié),1B=8bit。
字(Word):兩個字節(jié)構(gòu)成一個字,即2Byte=1Word。
在單片機中還有一個常用術(shù)語:字長。所謂字長是指單片機一次能處理的二進制數(shù)的位數(shù)。51單片機一次能處理8位二進制數(shù),所以51單片機的字長為8位。
1.2 存儲器編址
如下圖所示是一個容量為256字節(jié)的存儲器,內(nèi)部有256個存儲單元,每個存儲單元可以存放8位二進制數(shù),為了存取數(shù)據(jù)方便,需要對每個存儲單元進行編號,也即對存儲單元編址,編址采用二進制數(shù),對256個存儲單元全部編址至少要用到8位二進制數(shù),第1個存儲單元編址為00000000,編寫程序時為了方便,一般用十六進制數(shù)表示,二進制數(shù)00000000用十六進制表示就是00H,H表示十六制數(shù),第二個存儲單元編址為01H,第256個存儲單元編址為FFH(也可以寫成0FFH)。
圖1 存儲器結(jié)構(gòu)
1.3存儲器數(shù)據(jù)讀寫說明
要對256字節(jié)存儲器的每個存儲單元進行讀寫,需要8根地址線和8根數(shù)據(jù)線,先送8位地址選中某個存儲單元,再根據(jù)讀控制或?qū)懣刂疲瑢⑦x中的存儲單元的8位數(shù)據(jù)從8根數(shù)據(jù)線送出,或通過8根數(shù)據(jù)線將8位數(shù)據(jù)存入選中的存儲單元中。以圖1 存儲器結(jié)構(gòu)為例,當?shù)刂房偩€A7~A0將8位地址00011111(1FH)送入存儲器時,會選中內(nèi)部編址為1FH的存儲單元,這時再從讀控制線送入一個讀控制信號,1FH 存儲單元中的數(shù)據(jù)00010111從8根數(shù)據(jù)總線D7~D0送出。
1.4 存儲器的地址空間說明
MCS-51單片機采用哈佛結(jié)構(gòu),即程序空間(ROM)和數(shù)據(jù)空間(RAM)分開編址,它們有各自的地址空間,互不重疊,因此ROM和RAM可以有相同的地址編碼。為區(qū)分同一地址的變量是來自ROM還是RAM,要求編程時定義的任何變量都必須以一定的存儲器類型的方式定位在MCS-51單片機的某一存儲區(qū)中。使用C51編程時,只需用關(guān)鍵字就可定義變量的存儲器類型。C51變量的存儲器類型見下表所示。
從物理地址空間看,MCS-51單片機的存儲器有4個地址空間,分別是4KB的片內(nèi)ROM、64KB的片外ROM、256B的片內(nèi)RAM、64KB的片外RAM。
ROM(程序存儲器)存放程序、表格和始終要保留的常數(shù),相當于計算機系統(tǒng)的硬盤;
2.1 片內(nèi)外ROM(程序存儲器)
8051單片機內(nèi)部有4KB的程序存儲器,如果內(nèi)部程序存儲器不夠用(或無內(nèi)部程序存儲器),可以外接程序存儲器。8051單片機最大可以外接容量為64KB的程序存儲器(ROM),它與片內(nèi)4KB程序存儲器統(tǒng)一編址。?
當單片機的
端接高電平(接電源正極)時,片內(nèi)、片外程序存儲器都可以使用,片內(nèi)4KB 程序存儲器的編址為0000H~0FFFH,片外64KB 程序存儲器的編址為1000H~FFFFH,片外程序存儲器低4KB存儲空間無法使用。
如下圖所示:
當單片機的
端接低電平(接地)時,只能使用片外程序存儲器,其編址為0000H~FFFFH,片內(nèi)4KB程序存儲器無法使用。
如下圖所示:?
2.2 片內(nèi)外ROM(程序存儲器)說明
(1)無論是使用片內(nèi)ROM還是使用片外ROM,程序的起始地址都是從ROM的0000H單元開始的。
(2)盡管單片機可以同時具備內(nèi)、外ROM,但是在一般情況下,都需要通過
EA的設(shè)定來選擇其一。
(3)如果EA=1,當程序超過片內(nèi)ROM容量(4KB:0000H~0FFFH)時,單片機就會自動轉(zhuǎn)向片外ROM,并且從1000H單元開始執(zhí)行程序(無法使用片外ROM的低4KB空間)。目前,一般單片機的片內(nèi)ROM容量都夠,因此,很少或沒必要擴展片外ROM。
ROM空間一般可以根據(jù)用戶需要任意安排使用,但ROM中的某些地址被中斷程序的入口地址占用。
具體如下表所示:
RAM(數(shù)據(jù)存儲器)存放數(shù)據(jù)(常量或變量)或運算的結(jié)果,相當于計算機的內(nèi)存;
3.1 片內(nèi)外RAM(數(shù)據(jù)存儲器)
8051單片機內(nèi)部有256字節(jié)的數(shù)據(jù)存儲器,如果內(nèi)部數(shù)據(jù)存儲器不夠用,可以外接數(shù)據(jù)存儲器。8051單片機最大可以外接容量為64KB的數(shù)據(jù)存儲器(RAM),它與片內(nèi)256字節(jié)數(shù)據(jù)存儲器分開編址。
如下圖所示:? ??
當8051單片機連接片外RAM時,片內(nèi)RAM的00H~FFH存儲單元地址與片外RAM的0000H~00FFH存儲單元地址相同,為了區(qū)分兩者,在用匯編語言編程時,讀寫片外RAM時要用“MOVX”指令(讀寫片內(nèi)RAM時要用“MOV”指令),在用C語言編程時,讀寫RAM時須先聲明數(shù)據(jù)類型(內(nèi)部數(shù)據(jù)或外部數(shù)據(jù)),若讀寫的數(shù)據(jù)存放在片內(nèi)RAM中,要聲明數(shù)據(jù)類型為內(nèi)部數(shù)據(jù)類型(如用“data”聲明),若讀寫的數(shù)據(jù)存放在片外RAM中,應(yīng)聲明數(shù)據(jù)類型為外部數(shù)據(jù)類型(如用“xdata”聲明),單片機會根據(jù)聲明的數(shù)據(jù)類型自動選擇讀寫片內(nèi)或片外RAM。
3.2? RAM(數(shù)據(jù)存儲器)的分區(qū)?
8051單片機內(nèi)部有128字節(jié)的數(shù)據(jù)存儲器(地址為00H~7FH)和128字節(jié)的特殊功能寄存器區(qū)(地址為80H~FFH),如下圖所示。根據(jù)功能不同,8051單片機的數(shù)據(jù)存儲器可分為工作寄存器區(qū)(0~3組)(32 Bytes)、位尋址區(qū)(16 Bytes)、用戶RAM區(qū)(80 Bytes)、特殊功能寄存器區(qū)(128 bytes)。?
3.2.1 工作寄存器區(qū)
單片機在工作時需要處理很多數(shù)據(jù),有些數(shù)據(jù)要用來運算,有些要反復(fù)調(diào)用,有些要用來比較校驗等,在處理這些數(shù)據(jù)時需要有地方能暫時存放這些數(shù)據(jù),單片機提供暫存數(shù)據(jù)的地方就是工作寄存器。8051單片機的工作寄存器區(qū)總存儲空間為32字節(jié),由0~3組工作寄存器組成,每組有8個工作寄存器(R0~R7),共32個工作寄存器(存儲單元),地址編號為00H~1FH,每個工作寄存器可存儲一個字節(jié)數(shù)據(jù)(8位),四組工作寄存器的各個寄存器地址編號如下:
單片機上電復(fù)位后,默認使用第0組工作寄存器,可以通過編程設(shè)置PSW(程序狀態(tài)字寄存器)的RS1、RS0位的值來換成其他組工作寄存器。當PSW的RS1位=0、RS0位=0時,使用第0組工作寄存器,RS1位=0、RS0位=1時使用第1組工作寄存器,RS1位=1、RS0位=0時使用第2組工作寄存器,RS1位=1、RS0位=1時使用第3組工作寄存器,如下圖所示。不使用的工作寄存器可當作一般的數(shù)據(jù)存儲器使用。
3.2.2 位尋址區(qū)
位尋址區(qū)位于工作寄存器區(qū)之后,總存儲空間為16字節(jié),有16個字節(jié)存儲單元,字節(jié)地址為20H~2FH,每個字節(jié)存儲單元有8個存儲位,一共有16×8=128個存儲位,每個位都有地址,稱為位地址,利用位地址可以直接對位進行讀寫。位尋址區(qū)的16個字節(jié)單元與128個位的地址編號如下圖所示,從圖中可以看出,字節(jié)單元和存儲位有部分相同的地址編號,單片機是以指令類型來區(qū)分訪問地址為字節(jié)單元還是位單元,比如用字節(jié)指令訪問地址20H時,訪問的為20H字節(jié)單元,可以同時操作該字節(jié)單元的8位數(shù),用位指令訪問地址20H時,訪問的為24H字節(jié)單元的D0位,只能操作該位的數(shù)據(jù)。
3.2.3 用戶RAM區(qū)
用戶RAM區(qū)又稱為數(shù)據(jù)緩存區(qū),8051單片機的用戶RAM區(qū)有80個存儲單元(字節(jié)),地址編號為30H~7FH,用戶RAM區(qū)一般用來存儲隨機數(shù)據(jù)和運算中間結(jié)果等。
3.2.4 特殊功能寄存區(qū)
特殊功能寄存器簡稱SFR(Special Function Register),主要用于管理單片機內(nèi)部各功能部件(如定時器/計數(shù)器、I/O 端口、中斷控制器和串行通信口等),通過編程設(shè)定一些特殊功能寄存器的值,可以讓相對應(yīng)的功能部件進入設(shè)定的工作狀態(tài)。
1.特殊功能寄存器的符號、字節(jié)地址、位地址和復(fù)位值
8051單片機有21個特殊功能寄存器(SFR),見下表1,每個特殊功能寄存器都是一個字節(jié)單元(有8位),它們的地址離散分布在80H~FFH 范圍內(nèi),51單片機規(guī)定特殊寄存器只能用直接尋址(直接寫出 SFR 的地址或符號)方式訪問。
21個特殊功能寄存器都能以字節(jié)為單位進行訪問,其中有一些特殊功能寄存器還可以進行位訪問,能訪問的位都有符號和位地址,位地址為特殊功能寄存器的字節(jié)地址加位號。以特殊功能寄存器P0為例,其字節(jié)地址為80H(字節(jié)地址值可以被8整除),其P0.0~P0.7位的位地址為80H~87H,訪問字節(jié)地址80H時可讀寫8位(P0.0~P0.7位),訪問位地址82H時僅可讀寫P0.2位。
有位地址的特殊寄存器既可以用字節(jié)地址訪問整個寄存器(8位),也可以用位地址(或位符號)訪問寄存器的某個位,無位地址的特殊寄存器只能用字節(jié)地址訪問整個寄存器。當位地址和字節(jié)地址相同時,單片機會根據(jù)指令類型來確定該地址的類型。單片機上電復(fù)位后,各特殊功能寄存器都有個復(fù)位初始值,具體見表1,x表示數(shù)值不定(或1或0)。
表1?8051單片機的21個特殊功能寄存器(SFR)
2.部分特殊功能寄存器介紹
單片機的特殊功能寄存器很多,可以分為特定功能型和通用型。對于特定功能型特殊功能寄存器,當往某些位寫入不同的值,可以將其控制的功能部件設(shè)為不同工作方式,讀取某些位的值,可以了解相應(yīng)功能部件的工作狀態(tài);通用型特殊功能寄存器主要用于運算、尋址和反映運算結(jié)果狀態(tài)。
下面介紹一些通用型特殊功能寄存器。
(1)累加器(ACC)
累加器又稱ACC,簡稱A,是一個8位寄存器,其字節(jié)地址為E0H。累加器是單片機中使用最頻繁的寄存器,在進行算術(shù)或邏輯運算時,數(shù)據(jù)大多數(shù)先進入ACC,運算完成后,結(jié)果大多數(shù)也送入ACC。
(2)寄存器B
寄存器B主要用于乘、除運算,其字節(jié)地址是F0H。在乘法運算時,一個數(shù)存放在A(累加器)中,另一個數(shù)存放在B中,運算結(jié)果得到的積(16位)的高字節(jié)存放在B中,低字節(jié)存放在A中;在除法運算時,被除數(shù)存取自A,除數(shù)取自B,運算結(jié)果得到商(8位)和余數(shù)(8位),商存放在A中,余數(shù)存放在B中。
(3)數(shù)據(jù)指針寄存器(DPTR)
數(shù)據(jù)指針寄存器(DPTR)簡稱數(shù)據(jù)指針,是一個16位寄存器,由DPH和DPL兩個8位寄存器組成,地址分別為83H、82H。DPTR主要在單片機訪問片外RAM時使用,用于存放片外RAM的16位地址,DPH保存高8位地址,DPL保存低8位地址。
(4)堆棧指針寄存器(SP)
人們在洗碗碟時,通常是將洗完的碗碟一只一只由下往上堆起來,使用時則是將碗碟從上往下一只一只取走。這個過程有兩個要點:一是這些碗碟的堆放是連續(xù)的;二是先堆放的后取走,后堆放的先取走。單片機的堆棧與上述情況類似。堆棧是指在單片機數(shù)據(jù)存儲器中劃分出的一個連續(xù)的存儲空間,這個存儲空間存取數(shù)據(jù)時具有“先進后出,后進先出”的特點。在存儲器存取數(shù)據(jù)時,首先根據(jù)地址選中某個單元,再將數(shù)據(jù)存入或取出。如果有一批數(shù)據(jù)要連續(xù)存入存儲器,比如將5個數(shù)據(jù)(每個數(shù)據(jù)為8位)依次存入地址為30H~34H的5個存儲單元中,按一般的操作方法是:先選中地址為30H的存儲單元,再將第1個數(shù)據(jù)存入該單元,然后選中地址為31H的存儲單元,再將第2個數(shù)據(jù)存入該單元……顯然這樣存取數(shù)據(jù)比較麻煩,采用堆棧可以很好地解決這個問題。
在數(shù)據(jù)存儲器中劃分堆棧的方法是:通過編程的方法設(shè)置堆棧指針寄存器(SP)的值,如讓SP=2FH,SP就將存儲器地址為2FH的存儲單元設(shè)為堆棧的棧頂?shù)刂罚?FH單元后面的連續(xù)存儲單元就構(gòu)成了堆棧,如下圖所示。堆棧設(shè)置好后,就可以將數(shù)據(jù)按順序依次存入堆棧或從堆棧中取出,在堆棧中存取數(shù)據(jù)按照“先進后出,后進先出”的規(guī)則進行。
需要注意的是,堆棧指針寄存器(SP)中的值并不是堆棧的第一個存儲單元的地址,而是前一個單元的地址,例如SP=2FH,那么堆棧的第一個存儲單元的地址是30H,第1個數(shù)據(jù)存入30H單元。單片機通電復(fù)位后,SP的初始值為07H,這樣堆棧第一個存儲單元的地址就為08H,由于08H~1FH地址已劃分給1~3組工作寄存器,在需要用到堆棧時,通常在編程時設(shè)SP=2FH,這樣就將堆棧設(shè)置在數(shù)據(jù)存儲器的用戶RAM區(qū)(30H~7FH)。
(5)程序狀態(tài)字寄存器(PSW)
程序狀態(tài)字寄存器(PSW)的地址是 D0H,它是一個狀態(tài)指示寄存器(又稱標志寄存器),用來指示系統(tǒng)的工作狀態(tài)。PSW是一個8位寄存器,可以存儲8位數(shù),各位代表不同的功能。程序狀態(tài)字寄存器(PSW)的字節(jié)地址、各位地址和各位功能如下圖所示。
D7位(C):進位標志位。當單片機進行加、減運算時,若運算結(jié)果最高位有進位或借位時,C位置1,無進位或借位時,C位置0。在進行位操作時,C用作位操作累加器。
D6位(AC):半進位標志位。單片機進行加、減運算時,當?shù)桶胱止?jié)的D3位向高半字節(jié)的D4位有進位或借位時,AC位置1,否則AC位置0。
D5位(F0):用戶標志位0。用戶可設(shè)定的標志位,可置1或置0。
D4位(RS1)、D3位(RS0):工作寄存器組選擇位。這兩位有4種組合狀態(tài),用來控制工作寄存器區(qū)(00H~1FH)4組中的某一組寄存器進入工作狀態(tài)。
D2位(OV):溢出標志位。在進行有符號數(shù)運算時,若運算結(jié)果超出?128~+127范圍,OV=1,否則OV=0;當進行無符號數(shù)乘法運算時,若運算結(jié)果超出255,OV=1,否則OV=0;當進行無符號數(shù)除法運算時,若除數(shù)為0,OV=1,否則OV=0。
D1位(F1):用戶標志位1。同F(xiàn)0位,用戶可設(shè)定的標志位,可置1或置0。
D0位(P):奇偶校驗位。該位用于對累加器A中的數(shù)據(jù)進行奇偶校驗,當累加器A中“1”的個數(shù)為奇數(shù)值時,P=1,若累加器A中的“1”的個數(shù)為偶數(shù)值時,P=0。51系列單片機總是保持累加器A與P中“1”的總個數(shù)為偶數(shù)值,比如累加器A中有3個“1”,即“1”的個數(shù)為奇數(shù)值,那么 P 應(yīng)為“1”,這樣才能讓兩者“1”的總個數(shù)為偶數(shù)值,這種校驗方式稱作偶校驗。
編輯:黃飛
?
評論
查看更多