當(dāng)前位置:首頁 > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]一.51的存儲器從功能上來說可以分為程序存儲器和數(shù)據(jù)存儲器,至于到底能擴(kuò)展多少存儲空間,要看你擴(kuò)展的是哪一類存儲器。訪問存儲空間時,需要用到兩個指針變量,為DPTR和PC。其中pc為程序計數(shù)器,指向下一條需要執(zhí)行

一.51的存儲器從功能上來說可以分為程序存儲器和數(shù)據(jù)存儲器,至于到底能擴(kuò)展多少存儲空間,要看你擴(kuò)展的是哪一類存儲器。

訪問存儲空間時,需要用到兩個指針變量,為DPTR和PC。其中pc為程序計數(shù)器,指向下一條需要執(zhí)行的指令的地址,DPTR為數(shù)據(jù)指針寄存器,這兩個變量的長度都為16位,這是51單片機(jī)內(nèi)部結(jié)構(gòu)決定的,無法改變。所以這兩個指針的尋址能力都為64K。這樣看來,兩類存儲器的擴(kuò)展能力都為64K 。但是,如果你實際擴(kuò)展過存儲器,你就可以發(fā)現(xiàn)程序存儲器的擴(kuò)展能力并沒有64K!!!

這是為什么呢?

這得從51單片機(jī)的存儲空間的編址說起。這里僅作簡單說明,具體可以看教科書。簡單地說,內(nèi)部程序存儲器和外部程序存儲器是一起編址的,它們分別占用64K地址的一部分,所以外部擴(kuò)展時要減去內(nèi)部的地址空間,當(dāng)然小于64K啦。而數(shù)據(jù)存儲器是內(nèi)外部分別編址,內(nèi)外部數(shù)據(jù)存儲器用不同的指令進(jìn)行訪問,所以不用擔(dān)心單片機(jī)會混淆內(nèi)外部數(shù)據(jù)存儲器,所以外部數(shù)據(jù)存儲器擴(kuò)展能力有64K

擴(kuò)展閱讀:單片機(jī)存儲器的配置

二.MCS-51單片機(jī)擴(kuò)展系統(tǒng)中,片外程序存儲器和片外數(shù)據(jù)存儲器共處同一個地址空間,為什么不會發(fā)生總線沖突?

硬件上,控制信號不一樣:片外程序存儲器工作,要PSEN信號有效;片外數(shù)據(jù)存儲器工作,要RD或WR信號有效;

軟件上,尋址不一樣,片外程序存儲器工作,要用MOVC,

片外數(shù)據(jù)存儲器工作,要用MOVX;

雖然說他們的地址都是0000H~FFFFH,不會發(fā)生沖突的

因為控制信號線的不同:

外擴(kuò)的RAM芯片既能讀出又能寫入,所以通常都有讀寫控制引腳,記為OE和WE。外擴(kuò)RAM的讀、寫控制引腳分別與MCS-51的RD和WR引腳相連。

外擴(kuò)的EPROM在正常使用中只能讀出,不能寫入,故EPROM芯片沒有寫入控制引腳,只有讀出引腳,記為OE,該引腳與MCS-51單片機(jī)的PSEN相連

三.單片機(jī)中外接程序存儲器和數(shù)據(jù)存儲器公用16位地址線和8根數(shù)據(jù)線為什么不會起沖突

建議你閱讀一下單片機(jī)關(guān)于選通地址、傳遞數(shù)據(jù)方面的敘述。

下面我簡略的說一下大概過程,希望對你有所幫助。

第一,單片機(jī)采用三總線結(jié)構(gòu)傳遞數(shù)據(jù)。地址總線、數(shù)據(jù)總線、控制總線。傳遞數(shù)據(jù)的過程是先尋址,再傳遞數(shù)據(jù)。即先送一個地址信息(由微處理器向總線寫一個地址信息),由寄存器(也可能是程序存儲器,也可能是數(shù)據(jù)存儲器)根據(jù)這個地址,把微處理器要讀取的數(shù)據(jù)寫到總線上,微處理器再讀取這個數(shù)據(jù)。整個過程由控制總線控制。所以每次讀的數(shù)據(jù)是針對那個地址對應(yīng)的寄存器操作的,不會發(fā)生混亂。寫數(shù)據(jù)時一樣,先尋址,再寫數(shù)據(jù),數(shù)據(jù)就寫入剛才尋址時的地址對應(yīng)的那個寄存器里去了。

第二、程序存儲器、數(shù)據(jù)存儲器有不同的選通信號,在一個指令周期里,是不同的時間選通的,所以不會混亂。

第三。選通的引腳不同。拿片外數(shù)據(jù)存儲器來說,是P3的第6和第7引腳做選通信號,程序存儲器是PSEN做選通信號,他們接在各自器件的選通引腳上,所以不會混亂。

第四,指令不同。拿匯編指令來說。MOV是程序存儲器傳遞數(shù)據(jù)用,MOVX是數(shù)據(jù)存儲器傳遞數(shù)據(jù)用(對片外而言)。

總之,記住三總線傳遞的方式,先尋址,再傳數(shù),由控制總線控制,這個模式,你就容易理解這個了。

單片機(jī)的p2和p0分別傳遞地址的高八位和低八位。同時p0還傳遞數(shù)據(jù)。在時序信號的ALE高電平期間,鎖定地址信息。/PSEN是選通程序存儲器的。在/PSEN低電平期間是向程序存儲器傳遞程序代碼,/WR和/RD是選通數(shù)據(jù)存儲器的,即在/WR和/RD(p3的六腳和七腳)低電平期間把數(shù)據(jù)傳遞給數(shù)據(jù)寄存器。而/PSEN和/WR及/RD是在不同時間變?yōu)榈碗娖降?,沒有重疊的部分。也就是說,當(dāng)/WR及/RD變成低電平時,/PSEN已經(jīng)恢復(fù)高電平了,由P0口傳出的數(shù)據(jù)信息當(dāng)然只會傳到數(shù)據(jù)存儲器里,因為程序存儲器已經(jīng)不再處于選通狀態(tài)了!!從表面看,都是從p0口傳出的,但因為選通器件的時間不同而不會發(fā)生混亂。當(dāng)然我說的是片外程序存儲器和數(shù)據(jù)存儲器的的情況,其實對片內(nèi)也一樣,還是三總線的這種控制方式,使它們在不同的時間被選通,而不至于發(fā)生沖突。

看看單片機(jī)的一個電路圖。你會發(fā)現(xiàn)p0既跟74LS373連,又跟8155或8255或鍵盤或數(shù)模轉(zhuǎn)換器等等連。而8155或8255或鍵盤或數(shù)模轉(zhuǎn)換器等等對單片機(jī)而言是當(dāng)做數(shù)據(jù)存儲器處理的。74LS373連的多半是程序存儲器。那么p0送出的信號不是兩者都接受了嗎?注意看ALE接74LS373的G接口,鎖存地址用,PSEN有時用有時不用。WR和RD接數(shù)據(jù)存儲器的選通接口。因為WR和RD跟ALE的信號在時間上沒有重疊部分,所以p0的信號不會被程序存儲器和數(shù)據(jù)存儲器同時收到。這是一個舉例說明,具體情況要具體分析。

四,51單片機(jī),存儲器分為數(shù)據(jù)存儲器和程序儲存器,其地址空間、存取指令、和控制信號各有一套,

51是馮-諾依曼結(jié)構(gòu)

哈弗結(jié)構(gòu)說的是將程序存儲器和數(shù)據(jù)存儲器地址編碼分開,因而有兩種程序指令總線和數(shù)據(jù)指令總線。請注意這里說的是:地址編碼分開。取指令和取數(shù)據(jù)可以同時進(jìn)行。

因為馮-諾依曼結(jié)構(gòu)的數(shù)據(jù)線和指令線是分時復(fù)用的,在同一根線上,有時傳送的是數(shù)據(jù)有時是指令,所以它取指令和取數(shù)據(jù)不能同時進(jìn)行。你看mov,movx,movc,的功能,它告訴cpu什么時候取數(shù)據(jù)什么時候取指令。注意:數(shù)據(jù)和指令的區(qū)別!

又一種說法 哈佛結(jié)構(gòu)和馮.諾依曼結(jié)構(gòu)都是一種存儲器結(jié)構(gòu)。哈佛結(jié)構(gòu)是將指令存儲器和數(shù)據(jù)存儲器分開的一種存儲器結(jié)構(gòu);而馮.諾依曼結(jié)構(gòu)將指令存儲器和數(shù)據(jù)存儲器合在一起的存儲器結(jié)構(gòu)。

哈佛結(jié)構(gòu)是為了高速數(shù)據(jù)處理而采用的,因為可以同時讀取指令和數(shù)據(jù)(分開存儲的)。大大提高了數(shù)據(jù)吞吐率。缺點是結(jié)構(gòu)復(fù)雜。

通用微機(jī)指令和數(shù)據(jù)是混合存儲的,結(jié)構(gòu)上簡單,成本低。假設(shè)是哈佛結(jié)構(gòu):你就得在電腦安裝兩塊硬盤,一塊裝程序,一塊裝數(shù)據(jù),內(nèi)存裝兩根,一根儲存指令,一根存儲數(shù)據(jù)……

是什么結(jié)構(gòu)要看總線結(jié)構(gòu)的。51單片機(jī)雖然數(shù)據(jù)指令存儲區(qū)是分開的,但總線是分時復(fù)用得,所以頂多算改進(jìn)型的哈佛結(jié)構(gòu),呵呵。ARM9雖然是哈佛德,但是之前的版本也還是馮諾結(jié)構(gòu)。早期的X86能迅速占有市場,一條很重要的原因,正是靠了馮 諾依曼這種實現(xiàn)簡單,成本低的總線結(jié)構(gòu)。樓上的兄弟有一點說的不確切,現(xiàn)在的處理器雖然外部總線上看是諾依曼結(jié)構(gòu)的,但是由于內(nèi)部CACHE的存在,因此實際上內(nèi)部來看已經(jīng)算是改進(jìn)型哈佛結(jié)構(gòu)的了。

這個問題21ic上討論翻了無數(shù)個帖子,沒有什么定論,見仁見智。

至于優(yōu)缺點,呵呵,樓上的兄弟說的就比較的明白了。哈佛結(jié)構(gòu)就是復(fù)雜,對外圍設(shè)備的連接與處理要求高,十分不適合外圍存儲器的擴(kuò)展。所以早期通用CPU難以采用這種結(jié)構(gòu)。而單片機(jī),由于內(nèi)部集成了所需的存儲器,所以采用哈佛結(jié)構(gòu)也未嘗不可?,F(xiàn)在的處理器,依托CACHE的存在,已經(jīng)很好的將二者統(tǒng)一起來了。

很多入門的書上基本上都說:由運算器、控制器、存儲器、輸入設(shè)備、輸出設(shè)備組成的系統(tǒng)

都叫馮氏結(jié)構(gòu)。

也有的說:“程序存儲器的數(shù)據(jù)線地址線”與“數(shù)據(jù)存儲器的數(shù)據(jù)線地址線”共用的話,就

是馮氏結(jié)構(gòu),所以51是該結(jié)構(gòu)。(我認(rèn)為說得太絕對了)

我認(rèn)為馮氏結(jié)構(gòu)與哈佛結(jié)構(gòu)的區(qū)別應(yīng)該在存儲器的空間分別上,哈佛結(jié)構(gòu)的數(shù)據(jù)區(qū)和代碼區(qū)是分開的,它們即使地址相同,但空間也是不同的,主要表現(xiàn)在數(shù)據(jù)不能夠當(dāng)作代碼來運行。

口線復(fù)用,就將它認(rèn)為成馮氏結(jié)構(gòu),我認(rèn)為這樣不足取,應(yīng)該是按照空間是否完全重合來辨別。比如PC機(jī)的代碼空間和數(shù)據(jù)空間是同一空間,所以是馮氏結(jié)構(gòu);51由于IO口不夠,但代碼空間和數(shù)據(jù)空間是分開的,所以還是哈佛結(jié)構(gòu)。

另外,還有的把CISC RISC 和 地址是否復(fù)用,是哪種結(jié)構(gòu) 這3這都混到一起。我認(rèn)為這三者都沒有必然的關(guān)系。只不過 RISC因為精簡了指令集,沒有了執(zhí)行復(fù)雜功能的指令,為了提高性能,常采用哈佛結(jié)構(gòu),并且不復(fù)用地址線。

【更多資源】

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(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è)卻面臨越來越多業(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)星通信

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

關(guān)鍵字: 通信 BSP 電信運營商 數(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)閉