www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]AT89S51單片機(jī)存儲器結(jié)構(gòu)的特點(diǎn)之一是將程序存儲器和數(shù)據(jù)存儲器分開(稱為哈佛結(jié)構(gòu)),并有各自的對這兩個不同的存儲器空間的訪問指令。

AT89S51單片機(jī)存儲器結(jié)構(gòu)的特點(diǎn)之一是將程序存儲器和數(shù)據(jù)存儲器分開(稱為哈佛結(jié)構(gòu)),并有各自的對這兩個不同的存儲器空間的訪問指令。

AT89S51的存儲器空間可劃分為如下4類。

1.程序存儲器空間

單片機(jī)能夠按照一定的次序工作是由于程序存儲器中存放了經(jīng)調(diào)試正確的程序。程序存儲器可以分為片內(nèi)和片外兩部分。

AT89Ssl單片機(jī)的片內(nèi)程序存儲器為4 KB的Flash存儲器,編程和擦除完全是電氣實(shí)現(xiàn),且速度快??墒褂猛ㄓ玫木幊唐鲗ζ渚幊蹋部稍诰€編程。

當(dāng)AT89S51片內(nèi)的4 KB的Flash存儲器不夠用時,用戶可在片外擴(kuò)展程序存儲器,最多可擴(kuò)展至64 KB。

2.數(shù)據(jù)存儲器空間

數(shù)據(jù)存儲器空間分為片內(nèi)與片外兩部分。

AT89S51單片機(jī)內(nèi)部有128 B的RAM(增強(qiáng)型的52子系列為256 B),用來存放可讀/寫的數(shù)據(jù)。

當(dāng)AT89S51的片內(nèi)RAM不夠用時,又給用戶提供了在片外可擴(kuò)展至64 KB RAM的功能。至于究竟擴(kuò)展多少RAM,則根據(jù)用戶實(shí)際需要來定。

3.特殊功能寄存器(SFR,Special Function Register)

特殊功能寄存器實(shí)際上是AT89S51片內(nèi)各功能部件的控制寄存器及狀態(tài)寄存器。SFR綜合反映了整個單片機(jī)基本系統(tǒng)內(nèi)部實(shí)際的工作狀態(tài)及工作方式。

4.位地址空間

AT89S51單片機(jī)內(nèi)共有211個可尋址位,構(gòu)成了位地址空間。它們位于內(nèi)部RAM(共128位)和特殊功能寄存器區(qū)(共83位)中。

程序存儲器空間

程序存儲器是只讀存儲器(ROM),用于存放程序和表格之類的固定常數(shù)。AT89S51單片機(jī)的片內(nèi)程序存儲器為4 KB的Flash存儲器,地址范圍為0000H~0FFFH。AT89S51有16位地址線,可外擴(kuò)的程序存儲器空間最大為64KB,地址范圍為0000H~FFFFH。片內(nèi)與片外擴(kuò)展的程序存儲器在使用時應(yīng)注意以下問題:

(1)整個程序存儲器空間可以分為片內(nèi)和片外兩部分,CPU究竟是訪問片內(nèi)的還是片外的程序存儲器,可由EA(的反)引腳上所接的電平來確定。

EA(的反)引腳接高電平時,CPU從片內(nèi)OOOOH開始取指令,當(dāng)PC值沒有超出OFFFH(0000H~0FFFH為片內(nèi)4 KB的Flash存儲器的地址范圍)時,CPU只訪問片內(nèi)的Flash程序存儲器,當(dāng)PC值超出0FFFH會自動轉(zhuǎn)向讀取片外程序存儲器空間1000H~FFFFH內(nèi)的程序。

EA(的反)引腳接地時,單片機(jī)只能執(zhí)行片外程序存儲器(地址范圍為0000H~FFFFH)中的程序。

CPU不理會片內(nèi)4 KB的Flash存儲器(地址范圍0000H~0FFFH)。

(2)程序存儲器的某些單元被固定用于各中斷源的中斷服務(wù)程序的入口地址。

64 KB程序存儲器空間中有5個特殊單元分別對應(yīng)于5個中斷源的中斷服務(wù)程序的人口地址,見表2-3。AT89 S51復(fù)位后,程序存儲器地址指針PC的內(nèi)容為OOOOH,程序從程序存儲器中的OOOOH地址開始執(zhí)行。一般在該單元存放一條跳轉(zhuǎn)指令,跳向主程序的入口地址。

表2-3 5個中斷源的中斷入口地址

通常在這5個中斷入口地址處都放一條跳轉(zhuǎn)指令跳向?qū)?yīng)的中斷服務(wù)子程序,而不是直接存放中斷服務(wù)子程序。這是因?yàn)閮蓚€中斷入口間隔僅有8個單元,如果這8個單元存放中斷服務(wù)子程序,往往是不夠用的,所以中斷入口地址處都放一條跳轉(zhuǎn)指令,來跳向?qū)?yīng)的中斷服務(wù)子程序。

數(shù)據(jù)存儲器空間

該空間分為片內(nèi)與片外兩部分。

1.片內(nèi)數(shù)據(jù)存儲器

AT89S51的片內(nèi)數(shù)據(jù)存儲器(RAM)共有128個單元,字節(jié)地址為OOH~7FH。圖2-4為AT89S51片內(nèi)數(shù)據(jù)存儲器的結(jié)構(gòu)。

地址為00H~1FH的32個單元是4組通用工作寄存器區(qū),每個區(qū)包含8B的工作寄存器,編號為R7~RO。用戶可以通過指令改變特殊功能寄存器PSW中的RS1、RSO這兩位來切換當(dāng)前選擇的工作寄存器區(qū)。

地址為20H~2FH的16個單元的128位可進(jìn)行位尋址,也可以進(jìn)行字節(jié)尋址。

地址為30H~7FH的單元為用戶RAM區(qū),只能進(jìn)行字節(jié)尋址,用于存放數(shù)據(jù)以及作為堆棧區(qū)使用。

2.片外數(shù)據(jù)存儲器

當(dāng)片內(nèi)128B的RAM不夠用時,需要外擴(kuò)數(shù)據(jù)存儲器,AT89S51最多可外擴(kuò)64KB的RAM。注意,片內(nèi)RAM與片外RAM兩個空間是相互獨(dú)立的,片內(nèi)RAM與片外RAM的低128B的地址是相同的,但由于使用的是不同的訪問指令,所以不會發(fā)生沖突。

特殊功能寄存器

AT89S51中的CPU對片內(nèi)各功能部件的控制是采用特殊功能寄存器集中控制方式。特殊功能寄存器(SFR)的單元地址映射在片內(nèi)RAM的80H~FFH區(qū)域中,共有26個,離散地分布在該區(qū)域中,表2-4是SFR的名稱及其分布。其中有些SFR還可以進(jìn)行位尋址,其位地址已在表2-4中列出。

表2-4 SFR的名稱及其分布

與AT89C51相比,新增加的5個SFR是:DPIL、DPIH、AUXR、AUXR1和WDTRST,已在表2-4中標(biāo)出。

從表2-4中可以發(fā)現(xiàn),凡是可以進(jìn)行位尋址的SFR,其字節(jié)地址的末位只能是OH或8H。

另外,若讀/寫沒有定義的單元,將得到一個不確定的隨機(jī)數(shù)。

SFR塊中的累加器A和程序狀態(tài)字寄存器PSW已在前面介紹過,下面簡單介紹SFR塊中的某些SFR。

1.堆棧指針SP

堆棧指針SP的內(nèi)容指示出堆棧頂部在內(nèi)部RAM塊中的位置。它可指向內(nèi)部RAM OOH~7FH的任何單元。AT89S51的堆棧結(jié)構(gòu)屬于向上生長型的堆棧(即每向堆棧壓人1個字節(jié)數(shù)據(jù)時,SP的內(nèi)容自動增1)。單片機(jī)復(fù)位后,SP中的內(nèi)容為07H,使得堆棧實(shí)際上從08H單元開始,考慮到08H~1FH單元分別是屬于1~3組的工作寄存器區(qū),若在程序設(shè)計中用到這些工作寄存器區(qū),最好在復(fù)位后且運(yùn)行程序前,把SP值改置為60H或更大的值,以避免堆棧區(qū)與工作寄存器區(qū)發(fā)生沖突。

堆棧主要是為子程序調(diào)用和中斷操作而設(shè)立的。堆棧的具體功能有兩個:保護(hù)斷點(diǎn)和現(xiàn)場保護(hù)。

(1)保護(hù)斷點(diǎn)。因?yàn)闊o論是子程序調(diào)用操作還是中斷服務(wù)子程序調(diào)用操作,最終都要返回主程序。因此,應(yīng)預(yù)先把主程序的斷點(diǎn)在堆棧中保護(hù)起來,為程序的正確返回做準(zhǔn)備。

(2)現(xiàn)場保護(hù)。在單片機(jī)執(zhí)行子程序或中斷服務(wù)子程序時,很可能要用到單片機(jī)中的一些寄存器單元,這會破壞主程序運(yùn)行時這些寄存器單元中的原有內(nèi)容。所以在執(zhí)行子程序或中斷服務(wù)程序之前,要把單片機(jī)中有關(guān)寄存器單元的內(nèi)容保存起來,送入堆棧,這就是所謂的“現(xiàn)場保護(hù)”。

堆棧的操作有兩種:一種是數(shù)據(jù)壓入(PUSH)堆棧,另一種是數(shù)據(jù)彈出(POP)堆棧。每次當(dāng)一個字節(jié)數(shù)據(jù)壓人堆棧以后,SP自動加1;一個字節(jié)數(shù)據(jù)彈出堆棧后,SP自動減1。例如,(SP)=60H,CPU執(zhí)行一條子程序調(diào)用指令或響應(yīng)中斷后,PC內(nèi)容(斷點(diǎn)地址)進(jìn)棧,PC的低8位PCL的內(nèi)容壓人到61H單元,PC的高8位PCH的內(nèi)容壓人到62H,此時,(SP)=62H。

2.寄存器B

寄存器B是為執(zhí)行乘法和除法操作設(shè)置的。在不執(zhí)行乘、除法操作的情況下,可把它當(dāng)作一個普通寄存器來使用。

乘法中,兩個乘數(shù)分別在A、B中,執(zhí)行乘法指令后,乘積存放在BA寄存器對中。B中放乘積的高8位,A中放乘積的低8位。

除法中,被除數(shù)取自A,除數(shù)取自B,商存放在A中,余數(shù)存放于B中。

3.AUXR寄存器

AUXR是輔助寄存器,其格式如圖2-5所示。

圖中:

DISALE:ALE的禁止/允許位。

DISALE=0,ALE有效,發(fā)出恒定頻率脈沖。

DISALE=1,ALE僅在CPU執(zhí)行MOVC和MOVX類指令時有效,不訪問外部存儲器時,ALE不輸出脈沖信號。

DISRTO:禁止/允許WDT溢出時的復(fù)位輸出。

DISRTO=0,WDT溢出時,在RST引腳輸出一個高電平脈沖。

DISRTO=1,RST引腳僅為輸入腳。

WDIDLE:WDT在空閑模式下的禁止/允許位。

WDIDLE=0,WDT在空閑模式下繼續(xù)計數(shù)。

WDIDLE=1,WDT在空閑模式下暫停計數(shù)。

4.數(shù)據(jù)指針DPTRO和DPTR1

DPTRO和DPTR1是雙數(shù)據(jù)指針寄存器。為了便于訪問數(shù)據(jù)存儲器,AT89S51設(shè)置了兩個數(shù)據(jù)指針寄存器。DPTRO為AT89C51單片機(jī)原有的數(shù)據(jù)指針,DPTR1為AT89S51新增加的數(shù)據(jù)指針。AUXR1的DPS位用于選擇這兩個數(shù)據(jù)指針。當(dāng)DPS=0時,選用DPTRO;當(dāng)DPS=1時,選用DPTR1。AT89C51復(fù)位時,默認(rèn)選用DPTRO。

DPTRO(或DPTR1)是一個16位的SFR,其高位字節(jié)寄存器用DPOH(或DPIH)表示,低位字節(jié)寄存器用DPOL(或DPIL)表示。DPTRO(或DPTR1)既可以作為一個16位寄存器使用,也可以作為兩個獨(dú)立的8位寄存器DPOH(或DPIH)和DPOL(或DPIL)使用。

5.AUXR1寄存器

AUXR1是輔助寄存器,其格式如圖2-6所示。

圖中:

DPS:數(shù)據(jù)指針寄存器選擇位。

DPS=0,選擇數(shù)據(jù)指針寄存器DPTRO。

DPS=1,選擇數(shù)據(jù)指針寄存器DPTR1。

6.看門狗定時器WDT

看門狗定時器WDT包含一個14位計數(shù)器和看門狗定時器復(fù)位寄存器(WDTRST)。當(dāng)CPU由于干擾,程序陷入死循環(huán)或“跑飛”狀態(tài)時,看門狗定時器WDT提供了一種使程序恢復(fù)正常運(yùn)行的有效手段。

有關(guān)WDT在抗干擾設(shè)計中的應(yīng)用以及低功耗模式下運(yùn)行的狀態(tài),將在相應(yīng)的章節(jié)中具體介紹。

上面介紹的特殊功能寄存器除了前兩個SP和B以外,其余的均為AT89S51在AT89C51的基礎(chǔ)上新增加的SFR。

位地址空間

AT89S51在RAM和SFR中共有211個尋址位的位地址,位地址范圍為OOH~FFH,其中OOH~7FH這128位處于片內(nèi)RAM字節(jié)地址20H~2FH單元中,見表2-5。其余的83個可尋址位分布在特殊功能寄存器SFR中,見表2-6。可被位尋址的寄存器有11個,共有位地址88個,其中5個位未用,其余83個位的位地址離散地分布于片內(nèi)數(shù)據(jù)存儲器區(qū)字節(jié)地址為80H~FFH的范圍內(nèi),其最低的位地址等于其字節(jié)地址,并且其字節(jié)地址的末位都為OH或8H。

表2-5 AT89S51片內(nèi)RAM的可尋址位及其位地址

 

表2-6 SFR中的位地址分布

作為對AT89S51存儲器結(jié)構(gòu)的總結(jié),圖2-7給出了AT89S51中各類存儲器的結(jié)構(gòu)圖。從圖2-7中可以清楚地看出AT89S51的各類存儲器在存儲器空間的位置。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉