精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

一文詳解51單片機的存儲器組織結構

j4AI_wujianying ? 來源:lq ? 2019-02-27 15:53 ? 次閱讀

程序存儲器:

① 用于存放程序(可執行的二進制代碼映像文件,包括程序中的數據信息),還包括初始化代碼等固件。

② 為只讀存儲器。注意,這里的“只讀”,是指單片機(CPU)在正常工作時對其的訪問方式是只讀的;而現在大多數單片機的程序存儲器(不管是內部還是外部)都采用了FLASH ROM,來取代以前所用的ROM、E2PROM等,可方便地進行在線編程(ISP)。

③ 標準8051的內部程序存儲器大小為4KB(0x0000 ~ 0x0FFF);而具體的51核的兼容單片機的內部ROM大小需要參考其Datasheet,例如P89C51RA2xx的內部程序存儲器是8K的Flash。

④ 內部、外部存儲器統一編址,在軟件設計上(指令系統中)沒有差別;是否使用外部程序存儲器是通過引腳EA在硬件電路上控制的:不使用外部程序存儲器時,EA=0(接地);如果擴展了外部程序存儲器,則使EA=1,當尋址到內部存儲空間以外時,會自動轉向外部程序存儲器空間(與擴展外部程序存儲器有關的還有PSEN和ALE的時序配合,以及P0和P2口用于地址線)。

[注] 一般直接選用內部程序存儲器滿足代碼大小要求的單片機型號,避免擴展外部存儲器,造成系統軟硬件設計上的復雜和額外開銷。

數據存儲器:

RAM。首先必須要強調的是,不管是物理上還是邏輯上,51單片機的內部、外部數據存儲器都在不同的地址空間。兩者不是一回事,用途也不一樣,訪問的指令也不同(內部RAM為MOV指令,外部為MOVX)。

1、內部數據存儲器(內部RAM)

相當于內存,為程序(進程)中的變量和常量分配存儲空間,掉電后內容消失。

標準8051的內部RAM為256B(0x00 ~ 0xFF):其中可供用戶自由使用的是低128B(0x00 ~ 0x7F)區域,高128B中定義了26B的特殊功能寄存器(SFR),其余沒有定義,因而沒有意義。

P89C51RA2xx的片內RAM是512B(片內RAM不等于內部RAM,見釋疑2)。

[說明] 關于內部RAM中的SFR,其中不但定義了一些控制字段,還包括累加器(ACC)、程序狀態字(PSW)、數據指針(DPTR)、堆棧指針(SP)等,值得注意的是,片上I/O口P0 ~ P3的地址也在這里定義(即有3個特殊功能寄存器的地址實際上是P口的地址)——這是因為51單片機的I/O口與存儲器是統一編址的*。

2、外部數據存儲器(外部RAM)

上面談到“I/O口與存儲器統一編址”的問題,因此,這里稱作外部RAM空間更為合適。在這個64KB地址空間中(0x0000 ~ 0xFFFF),除了可以擴展外部RAM外,還可以擴展外部I/O設備。

外部RAM主要用于存儲程序運行時產生的重要數據(如數據采集結果、數據處理結果、系統日志等),這時一般需要外加電源進行掉電保護,以在系統掉電時保存其中的數據信息;也可用于數據的暫時存儲,供CPU正常讀寫操作使用。因此外部RAM主要是使用其“可隨機訪問、讀寫方便且高速”的特性。

* 所謂I/O口與存儲器統一編址,是指I/O口與主存在同一地址空間,將處理器的可尋址存儲空間中專門劃出一部分地址空間分配給I/O口使用。這與PC機的x86處理器不同,x86體系結構為I/O口專門定義了獨立于存儲空間之外的地址空間(事實上,除X86外,其他體系結構的處理器都對I/O口與存儲器統一編址,可參考《Linux Device Drivers》)。

釋疑1:51只有16根地址線,為什么能同時將程序存儲器和外部數據存儲器都擴展到64KB呢?即外部即有ROM,又有RAM,如何知道訪問的是哪個?

在體系結構上,程序存儲器和數據存儲器是不同的地址空間,兩者的訪問是不會相互干擾的,這主要是通過在硬件和指令集設計上來實現的。

在硬件上,訪問外部ROM是通過EA和PSEN引腳來控制的;訪問外部RAM則是通過WR和RD信號來控制的;

在指令集上,訪問外部ROM不需要使用顯示指令,是通過PC(指令計數器)來控制取指地址的(跳轉指令也可能引起PC跳轉);而訪問外部RAM則需要在程序設計上使用指令MOVX來執行。另外,訪問內部RAM則使用了指令MOV,以區分外部RAM的訪問。

釋疑2:P89C51RA2xx的片內RAM是512B,是如何組織的?

P89C51RA2xx的片內RAM是512B:其中內部RAM為256B(使用MOV指令訪問,定義與標準51相同);另外的256B為XRAM(片內的外部數據存儲器),屬于外部存儲器的范疇,因此用途也同外部RAM,使用MOVX指令訪問,當程序中的全局變量或單個局部變量需占較大存儲空間時,可以定義為xdata型,保存到XRAM區。注意這個片內的XRAM掉電后其數據也會丟失;另外,如果要擴展外部RAM,則一般是設置XRAM為禁用態。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 存儲器
    +關注

    關注

    38

    文章

    7366

    瀏覽量

    163091
  • 51單片機
    +關注

    關注

    272

    文章

    5689

    瀏覽量

    122157

原文標題:MCS-51單片機的存儲器組織結構

文章出處:【微信號:wujianying_danpianji,微信公眾號:單片機精講吳鑒鷹】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    51單片機存儲器內存的講解

    51單片機當中的存儲器從功能性上來劃分可以分為程序存儲器與數據存儲器般來說
    發表于 08-10 16:40 ?1848次閱讀

    解析80C51單片機中的cpu、存儲器配置以及并行輸入/輸出口

    單片機存儲結構可分為二類:類是哈佛結構,另類是普林斯頓
    的頭像 發表于 02-06 09:02 ?2.7w次閱讀
    解析80C<b class='flag-5'>51</b><b class='flag-5'>單片機</b>中的cpu、<b class='flag-5'>存儲器</b>配置以及并行輸入/輸出口

    了解msp430單片機存儲器組織

    留有段Flash區域(information memory),用于存放掉電后需要永久保存的數據。利用430內部的Flash控制,可以完成較大容量的數據記錄、用戶設置參數在掉電后的保存等功能。 硬件介紹: 要對Flash讀寫,首先要了解MSP430的
    的頭像 發表于 11-06 10:14 ?5357次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>了解msp430<b class='flag-5'>單片機</b>的<b class='flag-5'>存儲器</b><b class='flag-5'>組織</b>

    MCS-51單片機存儲器結構

    MCS-51單片機存儲器結構
    發表于 08-19 21:12

    51單片機存儲器分為倆大部分

    :思維結構很重要:由上圖可知,51單片機存儲器分為倆大部分:程序存儲器ROM和數據存儲器RAM
    發表于 11-18 09:03

    淺析51單片機存儲器結構

    四、51單片機存儲器結構1.存儲器總體結構概述般微
    發表于 12-01 08:24

    51系列單片機的內部存儲器簡介

    51 系列單片機的內部存儲器般微型存儲器的配置不同。
    發表于 12-01 08:32

    單片機存儲器,單片機存儲器結構原理是什么?

    單片機存儲器,單片機存儲器結構原理是什么? 存儲器單片機
    發表于 03-11 09:15 ?6812次閱讀
    <b class='flag-5'>單片機</b><b class='flag-5'>存儲器</b>,<b class='flag-5'>單片機</b><b class='flag-5'>存儲器</b><b class='flag-5'>結構</b>原理是什么?

    51單片機存儲器結構的詳細資料說明

    MCS-51單片機在物理結構上有四個存儲空間:1、片內程序存儲器,2、片外程序存儲器,3、片內數
    發表于 08-14 17:32 ?0次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機</b><b class='flag-5'>存儲器</b><b class='flag-5'>結構</b>的詳細資料說明

    51單片機存儲器結構和原理解析

    51單片機存儲器采用的是哈佛結構,即是程序存儲器空間和數據存儲器空間分開,程序
    發表于 10-21 16:33 ?2.2w次閱讀
    <b class='flag-5'>51</b><b class='flag-5'>單片機</b><b class='flag-5'>存儲器</b>的<b class='flag-5'>結構</b>和原理解析

    51單片機存儲器

    :思維結構很重要:由上圖可知,51單片機存儲器分為倆大部分:程序存儲器ROM和數據存儲器RAM
    發表于 11-11 20:36 ?15次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機</b>之<b class='flag-5'>存儲器</b>

    51匯編():存儲器結構

    文章目錄內存結構程序存儲器數據存儲器通用寄存區位尋址區般RAM區特殊功能寄存區內存
    發表于 11-23 09:36 ?13次下載
    <b class='flag-5'>51</b>匯編(<b class='flag-5'>一</b>):<b class='flag-5'>存儲器</b><b class='flag-5'>結構</b>

    51單片機(2)硬件結構(2)存儲器

    .存儲器結構51單片機存儲采用的是哈佛結構,即程
    發表于 11-23 10:21 ?17次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機</b>(2)硬件<b class='flag-5'>結構</b>(2)<b class='flag-5'>存儲器</b>

    MCS-51系列單片機存儲器結構

    四、51單片機存儲器結構1.存儲器總體結構概述般微
    發表于 11-23 16:51 ?13次下載
    MCS-<b class='flag-5'>51</b>系列<b class='flag-5'>單片機</b><b class='flag-5'>存儲器</b><b class='flag-5'>結構</b>

    MCS51 系列單片存儲器結構

    51 系列單片機的內部存儲器般微型存儲器的配置不同。
    發表于 11-23 16:51 ?14次下載
    MCS<b class='flag-5'>51</b> 系列<b class='flag-5'>單片</b>的<b class='flag-5'>存儲器</b><b class='flag-5'>結構</b>