S12(X)系列MCU的存儲器分頁訪問機制

来源:https://www.cnblogs.com/wsc19950809/archive/2018/03/19/8603346.html
-Advertisement-
Play Games

本文由“汽車電子expert成長之路”公眾號中“S12(X)系列MCU的片上存儲器資源與分頁訪問機制詳解”文章整理得來 最近接觸S12MCU中關於FLASH的擦寫相關知識,需要捋清楚幾個概念。 (16位單片機) 具體記憶體分配看 MC9S12G系列晶元手冊中 40 頁 本地地址(Local Addre ...


本文由“汽車電子expert成長之路”公眾號中“S12(X)系列MCU的片上存儲器資源與分頁訪問機制詳解”文章整理得來

最近接觸S12MCU中關於FLASH的擦寫相關知識,需要捋清楚幾個概念。  (16位單片機  具體記憶體分配看 MC9S12G系列晶元手冊中 40 頁

 

 

本地地址(Local Address):也稱為局部地址,指內核CPU能夠線性訪問的地址,對於16位MCU來說就是0x0000~0xFFFF的64KB地址空間;

邏輯地址(Logic Address):  也可以稱為虛擬地址,是鏈接文件.prm和記憶體映射文件.map以及預設的編譯結果S19文件所使用的地址。為分頁號 + 分頁視窗(Paging Window)組成的24-bit間斷地址空間,對邏輯地址的訪問需要使用__far指針。

全局地址(Global Address):也稱為物理地址(Physical Address),是晶元在設計時給P-Flash分配的線性連續地址空間,一般在多P-Flash進行操作(比如編寫P-Flash驅動程式,對P-Flash進行擦除、編寫/寫入等)時使用。

地址映射:CPU的定址是對物理地址操作,但是單片機的RESET之後只有相對地址。相對地址,顧名思義,是個相對的,沒有映射之前,CPU是找不到他的,也用不了相對地址的數據。

為了保證CPU執行指令時可正確訪問存儲單元,需將用戶程式中的邏輯地址轉換為運行時由機器直接定址的物理地址,這一過程稱為地址映射。

 

按照地址是否位於分頁段,可將地址分為未分頁地址(Non-paged address/non-bank address)及分頁地址(paged/bandked address)

   ① 分頁地址:其實就是邏輯地址。根據不同的器件,其可能存在P-Flash分地址、RAM分頁地址和EEPROM/D-Flash分頁地址。

        P-Flash分頁地址:其地址空間是16KB對齊的的間斷地址,由P-Flash分頁號+Flash分頁視窗地址(0x8000~0xBFFF,本地地址的第三個和16KB地址空間)組成。Flash分頁號(Page Number)保存在存儲器映射控制器PPAGE寄存器(地址為0x0015)中,用於在通過分頁視窗訪問Flash時索引邏輯地址。

        RAM分頁地址:其地址空間為4KB對齊的間斷地址,由RAM分頁號+RAM分頁視窗地址(0x1000~0x1FFFF,其在本地地址的第一個16KB地址空間)組成。RAM分頁號(Page Number)保存在存儲器映射控制RPAGE寄存器(地址為0x0016)中,用於在通過分頁視窗訪問RAM時索引邏輯地址。

        EEPROM分頁地址:其地址空間為1KB對齊的間斷地址,由EEPROM分頁號+EEPROM分頁視窗地址(0x0800~0x0BFF,其在本地地址的第一個16KB地址空間)組成。EEPROM分頁號(Page Number)保存在存儲器映射控制器EPAGE寄存器(地址為0x0017)中,用於在通過分頁視窗訪問EEPROM時索引邏輯地址。

              

   ② 未分頁地址:本地地址中除了分頁視窗(0x8000~0xBFFF,第三個16KB地址空間)之外的48KB地址空間都被稱為未分頁區。

邏輯地址直接由分頁號+分頁視窗組成,該地址容易得到。例如 Page E的Flash對應的邏輯地址為0xE8000~0xEBFFF。

 

全局地址由邏輯地址計算得出:

       分頁段: 全局地址 = ( 分頁號  <<  14 )  |  ( 本地地址  -  0x8000 )

       非分頁段: 全局地址 =  本地地址 | 0x30000

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1 using System; 2 using System.Configuration; 3 using System.Data; 4 using System.Data.SqlClient; 5 6 namespace ADO連接資料庫 7 { 8 public static class Sql... ...
  • 系統信息 arch 顯示機器的處理器架構(1) uname -m 顯示機器的處理器架構(2) uname -r 顯示正在使用的內核版本 dmidecode -q 顯示硬體系統部件 - (SMBIOS / DMI) hdparm -i /dev/hda 羅列一個磁碟的架構特性 hdparm -tT / ...
  • groupadd grptest1 按照系統預設的gid創建組。根uid一樣,gid也是從1000開始的。 groupadd -g 1008 grptest2 創建gid=1008的用戶組:grptest2 groupdel grptest2 刪除組grptest2 groupdel不能刪除user ...
  • 解決辦法: 下載好固件 rt2800.bin 文件,複製到 /lib/firmware 中 如果完成以上步驟後,運行 ifconfig wlan0 up 仍然提示 ~~~~ phy0 rt2x00lib_request_firmware: Error Failed to request Firmwa ...
  • 本地變數:作用於當前shell,對當前shell之外的其他shell進程和當前shell子進程均無效。 本地變數賦值為 value可以是字元串或者是變數,引用變數使用${name}或$name或``. 註:單引號是強引用而雙引號是弱引用。 使用set顯示已定義的所有變數,unset name 銷毀變 ...
  • 此次學習採用CentOS Linux發行版。使用的虛擬機是VirtualBox CentOS 7 下載地址:http://mirrors.163.com/centos/7.4.1708/isos/x86_64/CentOS-7-x86_64-DVD-1708.iso 1. 打開VirtualBox, ...
  • 1.Centos 6.5的預設yum源可以直接安裝httpd服務 1 [root@httpd ~]# ll /etc/yum.repos.d/ 2 total 24 3 -rw-r--r--. 1 root root 1926 Nov 27 2013 CentOS-Base.repo 4 -rw-r ...
  • 1.1 jumpserver安裝 同步時間:ntpdate ntp1.aliyun.com 關閉selinux 關閉防火牆 系統字體修改成英文 1.1.1 安裝依賴(前提需要epel源) yum install -y git python-pip mariadb-devel gcc automake ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...