1 Cache的原理?
Cache即高速緩存,它的出現基于兩種因素:一、CPU的速度和性能提高很快,而主存速度較低且價格高;二、程序執行的局部性特點。將速度較快而容量有限的SRAM構成Cache,可以盡可能發揮CPU的高速度。CPU與外設交換數據時經常用到buffer(緩沖),這與緩存極其相似,只不過Cache是為了提高CPU和內存之間的數據交換速度而設計,而buffer是為了提高內存和硬盤(或其他I/O設備)之間的數據交換速度而設計的。?
Baidu快照(cache.baidu.com)就是一個緩存的例子,其作用與計算機CPU緩存有類似之處。? Cache的原理如圖1所示。?
在讀取內存數據的同時CPU將數據保存到Cache數據區,同時更新Cache映射表(保存地址信息,表示該地址的數據是否已在Cache數據區,即是否命中)。這樣,CPU再次讀取該地址數據時,就可以直接從Cache提取。讀Cache的時間遠小于直接讀內存,可提高CPU讀取數據的效率。???
Cache數據區有成塊讀取的特性(Cache映射表保存的地址是塊地址,節省空間,也符合程序執行的局部性特點)。Cache數據區遠遠小于內存空間,就需要相應的替代算法。比如最近最少使用算法,可將新數據替代使用頻率低的數據,同時更新映射表信息。可以推想,Cache空間越大,命中率越高。
寫內存需要直接更新內存。如果映射表存在該地址信息,還需要同時更新Cache數據區。這種Cache訪問方式就稱作“直寫”,Samsung公司的ARM7微處理器S3CA510B就是這種方式。以下所討論的Cache問題除非特殊說明,否則都是“直寫”方式。
2 嵌入式編程時需注意的問題
2.1?訪問外設使用Cache的問題
在訪問內存時使用Cache是不會出現問題的,但如果訪問數據易變外設(數據不依賴于CPU寫操作而改變)時使用Cache就可能出現問題。問題在于外設數據的改變不僅僅依靠CPU寫操作,CPU第一次讀取外設數據時將外設的數據和地址信息保存到Cache,第二次讀取外設數據時就可能有問題出現。這是因為數據直接從Cache提取,而外設的數據可能有改變。
因此,在訪問易變外設時要禁止使能Cache,直接讀取外設數據到CPU,而不經過Cache的任何環節,即保證不改變Cache映射表和Cache數據區內容。
S3C4510B的SYSCFG SFR(特殊功能寄存器)有用來控制Cache使能或不使能的,通過對該SFR的設置可暫時禁止Cache或重新恢復Cache功能。這樣就可以在讀取外設前禁止Cache,讀取結束后重新使能Cache,保證了外設數據讀取的正確性。寫數據到外設時采用“直寫”方式,更沒有問題。
2.2?開關Cache引發的新問題
在Cache開關期間,如果有另一個進程/任務訪問內存,在此期間寫內存并且該內存在Cache中已有映射(注意,它也是被禁止Cache的,所以它不會同時更新Cache數據區的內容),那么在Cache重新使能之后Cache數據區的信息已經過時了,而Cache映射表還是Cache禁止之前的狀態,如果CPU此時讀數據就會得到過時的數據。這樣看來,引發的問題范圍更廣了,連內存的數據讀寫正確性都無法保證。與內存泄漏的影響來比較,內存泄漏如果是一顆定時炸彈,那么Cache問題就可以說是隨時隨地都可能踩上的雷區,因為程序一旦開始就可能引發爆炸。
如圖2所示,Cache使能時Cache映射表和Cache數據區保存了內存的數據信息,這是CPU訪問內存時通過圖中實線箭頭通路實現的。內存的信息可以與Cache的信息保持一致。
Cache禁止時的情況有所變化。由圖2中虛線箭頭通路直接進行內存訪問,且地址0x00處的數據由55變為AA,但Cache區的信息仍為之前的狀態。很明顯,Cache的數據是應該廢棄的,但是Cache映射表仍保存0x00的地址信息。Cache重新使能后,CPU再次讀取0x00地址的數據,由于Cache仍是命中,直接從Cache數據區中提取數據,這樣讀出來的數據就是0x55了。
由S3C4510B數據手冊第4節的第21頁可知:通過對SYSCFG寄存器的CE位置1或清0可使能/關閉Cache,但是Cache沒有內容自動刷新功能,在重新使能Cache時需考慮Cache數據的正確性。
為了證實以上說法,循環執行如下測試程序:
如果沒有Cache的影響,結果應該是55 aa aa。可見,Cache關閉再打開的確可造成Cache數據過時。
3?其他CPU解決方案
Atmel公司的AT91RM9200和Samsung公司的S3C44B0,用這兩種CPU先后移植過操作系統,且在對外設訪問的整個過程中Cache都是使能的。它們的解決方案是什么呢?
AT91RM9200是ARM9系列帶有MMU的CPU。MMU對內存有分頁管理功能,可以實現多個進程的內存空間保護。Cache是通過MMU管理的,這也是Cache和MMU經常同時存在的原因。
S3C44B0和S3C4510B同樣都是Samsung公司產品,并且都不帶MMU。與S3CA510不同的是,S3C4480自帶的SFR可以配置非緩存范圍,即使Cache使能,所設置范圍的地址空間訪問也不通過Cache實現。這樣,可以很方便地實現內存是緩存區,其他外設是非緩存區。
這兩種方案對于S3C4510B都無法實現。網絡上有人用volatile關鍵字解決外設訪問問題。volatile關鍵字是在源代碼中給編譯器看的,它可能影響編譯器的編譯結果,但是最終CPU執行都體現到匯編語句,如果匯編語句都不能解決Cache問題,volatile語句也是不可能解決的。?
對于易變數據的外設使用volatile關鍵字是應該的,可避免編譯器的優化,比如以下語句:?
在兩次讀取portAdd地址的數據相同時等待,可以用到等待信號跳變的程序。如果將volatile關鍵字去除,有可能經編譯器優化,Value2不會從實際的portAdd地址讀取數據,而是利用Valuel讀取語句的中間寄存器直接獲得。
4 本文解決方案
由S3C4510B手冊上第5節的第4頁可知,可以通過兩種方式保證Cache數據的正確:
①對Cache映射表的Tag RAM數據清零。Cache映射表數據一般是通過上電復位清零的,如果Cache或內存段的設置被修改,則會造成Cache映射表數據廢棄,這時就需要通過程序對Cache映射表數據清0。?
②S3C4510B提供非Cache方式訪問控制位,控制位ADDR[26](地址線26位)為“1”時,按非Cache方式訪問。因此,Cache使能的情況下,地址0x000 0000~0x3FFFFFF按Cache方式訪問,而0x400 0000~0x7FF FFFF按非Cache方式訪問。實際上,0x000 0000+offset與0x400 0000+offset(offset在0x000 0000~0X3FF FFFF之間)是同一地址,不同的是Cache是否起作用。?
可以得到兩種解決方案:?
(1)Cache映射表手動更新? 既然在開關Cache之后內容過時,并且CPU不會自動刷新,可以通過手動更新的辦法來拋棄廢舊信息。也就是說,將Tag RAM區(前面所說的Cache映射表)清除,這樣所有Cache數據區的內容都不使能,再次讀取數據時同時更新Cache映射表和Cache數據區內容,之后才能使用。清除操作將Tag RAM的1 KB內容清零,需要消耗一定時間;并且這樣操作后Cache是0命中率的,只有一定訪問次數后Cache信息重新填滿,才能恢復正常的命中率。因此,頻繁地開關Cache時采用這種方案是不可取的。
(2)bit26位控制Cache使能
S3C4510B的地址線為26位(bit0~bit25),實際上CPU可訪問空間為32位(bit0~bit31)。一般我們都不使用bit26~bit31,不過S3C4510B的這些位有著特殊的控制功能。通過bit26的高電平可以禁止該地址的Cache功能,因此將外設的地址由原來的ADDR_PORT改為(ADDR PORT∣(1<<26)),就可以實現外設訪問時Cache不使能。這樣就不用改為SYSCFG的Cache使能控制位。比較來看,SYSCFG的Cache使能位是控制整個CPU訪問的Cache使能與否,而bit26只控制當前訪問的一個具體地址的Cache使能與否。采用這種解決方案理論上有依據,并且可以最大程度發揮CPU的功能。
5 修改程序后的試驗結果
修改Cache解決方案后,可以解決內存訪問錯誤的問題。經過測試,采用“bit26位控制Cache使能”的方案可以順利訪問外設,代碼執行始終是在Cache使能的情況下,并且不影響內存數據。若完全關閉Cache的程序,執行同樣代碼需要花費5~8倍的時間。
嵌入式編程需注意的Cache機制及其原理
- 嵌入式(286111)
- 編程(92184)
- CAC(8465)
相關推薦
0基礎沒編程經驗能學嵌入式嗎?
一直以來對于0基礎學習嵌入式的同學都非常的敬佩,畢竟這需要付出比別人更多的努力,才能追平那些本專業有編程基礎的同學。從我本人而言,見過0基礎學習嵌入式的同學并不在少數。今天主要談談0基礎學習嵌入式
2021-07-18 17:52:29
嵌入式C++編程的相關資料分享
特點展示如何使用 C ++ 來構建利用可用硬件資源的強大并發系統。從嵌入式編程入門和 C ++ 17 的最新特性開始,帶您了解優秀編程的各個方面您將學習如何使用 C ++ 的并發性、內存管理和函數式
2021-11-09 08:26:24
嵌入式C程序基礎與編程結構相關資料分享
嵌入式C程序基礎與編程結構Basics of Embedded C Program and Programming Structure嵌入式C編程是處理器在我們日常生活中遇到的每一個嵌入式系統(如
2021-12-15 06:43:56
嵌入式C程序開發需注意什么
今天看到一篇很優質的博客,轉發并推薦下:編寫優質嵌入式C程序:http://blog.csdn.net/zhzht19861011/article/details/45508029
2021-12-15 08:00:19
嵌入式Linux多線程編程
嵌入式Linux多線程編程-學習資源-華清遠見清遠見嵌入式學院:清遠見嵌入式學院:《嵌入式應用程序設計》——第5 章 嵌入式Linux 多線程編程第5 章 嵌入式Linux 多線程編程本章
2021-11-05 06:54:35
嵌入式Linux系統開發學習步驟,深圳嵌入式Linux培訓高薪一路相伴
、哈希表、各種查找排序算法等應用及其C語言實現過程。 六:C++ 、QT C++是Linux應用開發主要語言之一,本階段重點掌握面向對象編程的基本思想以及C++的重要內容。圖形界面編程是嵌入式開發中非
2015-11-25 17:23:50
嵌入式linux學***匯總
服務器配置、shell編程、Linux C語言基礎、Linux程序編譯和調試維護等內容?! ”緯神T利美主編。本書的完成需要感謝華清遠見嵌入式學院,教材內容參考了學院與嵌入式企業需求無縫對接的、科學
2020-06-08 08:31:35
嵌入式處理器中Cache一致性問題怎么解決?
隨著嵌入式計算機應用的發展,嵌入式CPU的主頻不斷提高,這就造成了慢速系統存儲器不能匹配高速CPU處理能力的情況。為了解決這個問題,許多高性能的嵌入式處理器內部集成了高速緩存Cache。其中,三星公司的S3C44B0X內部就集成了8KB空間統一的指令和數據Cache?!?/div>
2019-09-05 07:00:20
嵌入式學習步驟
管理機制 熟悉進程間通信的幾種方式 熟悉嵌入式Linux中的任務間同步與通信編寫一個簡單的管道程序實現文件傳輸 編寫一個使用共享內存的程序 8、嵌入式系統中多線程程序設計 線程的基礎知識 多線程編程
2019-06-03 23:28:35
嵌入式實時操作系統如何簡化應用軟件的設計
在嵌入式領域中,嵌入式實時操作系統(RTOS)正得到越來越廣泛的應用。采用嵌入式實時操作系統可以更合理、更有效地利用CPU的資源,簡化應用軟件的設計,縮短系統開發時間,更好地保證系統的實時性和可靠性。內存資源作為嵌入式系統中極為重要的資源之一,其管理機制歷來是嵌入式系統設計的重點和難點。
2020-11-25 06:48:44
嵌入式開發:你是如何理解嵌入式c編程的
一、新手常常問的一個問題是c語言和嵌入式c編程有什么區別?而嵌入式工程師一般都會告訴你其區別在于嵌入式的C語言是跑在嵌入式的開發板上的,CPU和我們電腦不一樣,所以編譯器也是不一樣的,生成的可執行
2017-06-28 10:14:58
嵌入式開發:你是如何理解嵌入式c編程的
本期的嵌入式開發學習將和大家討論什么是嵌入式c編程,你是如何理解嵌入式c編程的。在上個篇章我們有簡單介紹了什么是嵌入式系統的官方定義以及其發展的階段?如對嵌入式開發感興趣的童鞋不妨接著往下看。 一
2017-07-25 10:25:17
嵌入式的基本概念及其應用
文章目錄系統移植概述及環境搭建嵌入式基本概念嵌入式系統的應用領域什么是嵌入式系統用嵌入式系統硬件組成部分通用嵌入式系統軟件組成部分Linux 在嵌入式中應用的條件與前景嵌入式Linux內核結構
2021-10-27 07:59:07
嵌入式系統基礎階段的學習建議
嵌入式系統。前面說過,嵌入式系統是軟件與硬件的綜合體。因此,要逐步從MCU的最小系統開始,一點一點理解硬件原理及底層硬件驅動編程方法。要通過規范的例子,理解軟件工程封裝、可復用等思想。通過規范編程,積累
2020-10-29 07:36:20
嵌入式系統是什么意思
在我們的日常生活中,我們經常使用許多使用嵌入式系統技術設計的電氣和電子電路和套件。計算機,手機,平板,筆記本電腦,數字電子系統以及其他電子和電子設備都是使用嵌入式系統設計的。什么是嵌入式系統?將硬件
2021-10-28 08:58:02
嵌入式系統的組成及其特點
嵌入式系統的組成嵌入式系統的特點嵌入式系統分層組成硬件軟件嵌入式系統的發展單芯片為核心,可編程控制器階段以嵌入式 CPU 為基礎、簡單操作系統為核心以嵌入式操作系統為標志以物聯網為標志嵌入式系統
2021-10-27 09:30:15
嵌入式系統設計
在我們的日常生活中,我們經常使用許多使用嵌入式系統技術設計的電氣和電子電路和套件。計算機,手機,平板,筆記本電腦,數字電子系統以及其他電子和電子設備都是使用嵌入式系統設計的。什么是嵌入式系統?將硬件
2021-10-27 06:50:19
嵌入式系統軟件和編程語言
獨立工作的器件。 嵌入式系統的軟件部分包括操作系統軟件(要求實時和多任務操作)和應用程序編程。操作系統控制著應用程序編程與硬件的交互作用,而應用程序控制著系統的運作和行為。
2019-07-17 07:34:06
嵌入式網絡編程+嵌入式Linux系統
D2.25嵌入式網絡編程+嵌入式Linux系統一、Linux操作系統安裝與使用(命令)二、Linux開發工具(gcc、gdb、make)三、Linux系統編程(文件、進程、線程、網路、數據庫
2021-12-22 07:10:18
嵌入式軟件編程中const、static、extern和volatile的原理是什么?怎么使用?
嵌入式軟件編程中const、static、extern和volatile的原理是什么?怎么使用?
2021-04-28 06:21:42
[嵌入式linux] 嵌入式學習分享:那些繞不開的技術點
嵌入式繞不開各種接口比如:uart 、spi、i2c、u***、eth、mipi、edp、can、i2s、hdmi等等。需要了解各接口的使用場景、帶寬、機制、時序、工作模式、缺點,時序等等。我相信硬件
2020-04-16 09:51:11
[公告]嵌入式Linux內核設計高級研修班
;nbsp; 其實不然,我們需要在很多方面進行內核開發1、在嵌入式領域,由于有數不清處理器架構,所以內核在某些架構上就沒有得到完全支持。2、在工控領域,我們常常希望獲得高精確時鐘,而在絕大多數架構上
2009-07-24 13:04:45
【下載】《嵌入式C編程與Atmel.AVR》
`內容簡介 歡迎進入嵌入式編程和微控制器應用的世界!使用日益流行且價格適宜的Atmel AVR嵌入式控制器作為學習平臺。本書是目前可以獲得的最佳書籍之一。對于初學者,本書將會是極好的選擇。隨著
2018-01-11 18:02:05
什么是嵌入式編程
《C嵌入式編程設計模式》第一章 什么是嵌入式編程嵌入式系統的基本知識面向對象編程與結構化編程使用C語言實現類、繼承、狀態機 第二章 嵌入式實時過程Harmony的嵌入式編程嵌入式應用開發中的敏捷過程
2021-11-08 06:15:53
什么是嵌入式系統?
在我們的日常生活中,我們經常使用許多使用嵌入式系統技術設計的電氣和電子電路和套件。計算機,手機,平板,筆記本電腦,數字電子系統以及其他電子和電子設備都是使用嵌入式系統設計的。什么是嵌入式系統?將硬件
2021-12-22 06:11:56
你是如何理解嵌入式C編程
期的嵌入式開發學習將和大家討論什么是嵌入式c編程,你是如何理解嵌入式c編程的。在上個篇章我們有簡單介紹了什么是嵌入式系統的官方定義以及其發展的階段?如對嵌入式開發感興趣的童鞋不妨接著往下看。 一
2017-03-22 10:58:58
你是如何理解嵌入式C編程的
什么是嵌入式系統的官方定義以及其發展的階段?如對嵌入式開發感興趣的童鞋不妨接著往下看。 一、新手常常問的一個問題是c語言和嵌入式c編程有什么區別?而嵌入式工程師一般都會告訴你其區別在于嵌入式的C語言是跑在嵌入式
2017-03-07 21:15:35
你是如何理解嵌入式c編程的
嵌入式開發:你是如何理解嵌入式c編程的本期的嵌入式開發學習將和大家討論什么是嵌入式c編程,你是如何理解嵌入式c編程的。在上個篇章我們有簡單介紹了什么是嵌入式系統的官方定義以及其發展的階段?如對
2017-05-05 15:11:30
你是如何理解嵌入式c編程的?
一、新手常常問的一個問題是c語言和嵌入式c編程有什么區別?而嵌入式工程師一般都會告訴你其區別在于嵌入式的C語言是跑在嵌入式的開發板上的,CPU和我們電腦不一樣,所以編譯器也是不一樣的,生成的可執行
2015-10-17 13:23:00
你是如何理解嵌入式c編程的?
一、新手常常問的一個問題是c語言和嵌入式c編程有什么區別?而嵌入式工程師一般都會告訴你其區別在于嵌入式的C語言是跑在嵌入式的開發板上的,CPU和我們電腦不一樣,所以編譯器也是不一樣的,生成的可執行
2015-10-22 19:24:31
使用Java平臺怎么實現可編程嵌入式系統?
傳統的嵌入式產品只能實現某種特定的功能,不能滿足用戶可變的豐富多彩的應用需求。為解決這個問題,本文設計并實現了一種使用Java作為軟件平臺的基于FPGA的可編程嵌入式系統,以實現系統對多種本地應用和網絡的支持。
2020-03-25 06:30:05
關于嵌入式RTDBS的知識點總結的太棒了
嵌入式RTDBS內涵及其體系結構嵌入式RTDBS的數據模型嵌入式RTDBS的物理結構嵌入式RTDBS管理系統嵌入式RTDBS設計實例
2021-04-27 06:42:42
關于嵌入式系統高級編程語言的基本知識點都在這里
什么是嵌入式系統高級編程語言?嵌入式系統高級語言編程特點有哪些?常用嵌入式系統高級編程語言基本性能有哪些?Java的特點是什么?它與嵌入式系統有什么關系?
2021-04-27 07:06:58
到底什么是嵌入式?
、PCB設計在電子設計中,PCB是我們設計內容的物理載體,所有我們設計意圖的最終實現就是通過PCB板來表現的。三、C語言C語言是嵌入式開發中最重要的編程語言,要對這門語言有深入的理解,畢竟不僅僅要會寫程序,看懂
2021-09-19 14:17:58
在嵌入式開發中,你是如何理解嵌入式C編程的?
`本文來探討嵌入式開發中的嵌入式C編程,看看跟您理解的一樣嗎?一、新手常常問的一個問題:C語言和嵌入式C編程有什么區別?而嵌入式工程師一般都會告訴你,其區別在于嵌入式的C語言是跑在嵌入式的開發板上
2016-03-22 09:38:57
基于FPGA的帶Cache的嵌入式CPU該怎么設計?
隨著集成電路設計和工藝技術的發展,嵌入式系統已經在PDA、機頂盒、手機等信息終端中被廣泛應用。嵌入式系統具有電路尺寸小、成本低廉、可靠性高、功耗低等優點,是未來集成電路發展的方向。而作為嵌入式系統
2019-10-12 09:31:50
如何學習嵌入式?
籍:《UNIX環境高級編程》(第2版) (4) 了解ARM的架構,原理,以及其匯編指令,我們在嵌入式開發中,一般很少去寫匯編,但是起碼的要求是能夠看懂arm匯編?! ?5) 系統移植的時候,就需要你從下
2020-06-09 04:35:36
如何理解嵌入式c編程的?
一、新手常常問的一個問題是c語言和嵌入式c編程有什么區別?而嵌入式工程師一般都會告訴你其區別在于嵌入式的C語言是跑在嵌入式的開發板上的,CPU和我們電腦不一樣,所以編譯器也是不一樣的,生成的可執行
2017-06-13 10:11:45
如何設計帶Cache的嵌入式CPU?
隨著集成電路設計和工藝技術的發展,嵌入式系統已經在PDA、機頂盒、手機等信息終端中被廣泛應用。嵌入式系統具有電路尺寸小、成本低廉、可靠性高、功耗低等優點,是未來集成電路發展的方向。而作為嵌入式系統
2019-11-05 07:26:21
工業嵌入式計算平臺開發招聘
經驗2、熟悉ARM等微處理器架構,掌握嵌入式操作系統的移植、裁剪、驅動開發和應用開發3、精通C/C++編程,熟悉Linux內核架構和驅動開發。4、具有基于ARM ***可信應用開發經驗,熟悉ARMv8
2021-10-12 09:32:52
怎樣開始學習嵌入式?
嵌入式Linux系統開發學習路線致想學習嵌入式和正在學習嵌入式的寶寶們一:嵌入式c語言C語言是嵌入式領域最重要也是最主要的編程語言,通過大量編程實例重點理解C語言的基礎編程以及高級編程知識。包括
2017-08-14 15:36:15
求大神分享一種基于bootloader的嵌入式軟件自動更新機制
本文提出了一種具有較高穩定性和安全性、基于bootloader的嵌入式軟件自動更新機制。該更新機制同時保存了3個文件,需要較多的Flash存儲空間,但同時降低了維護成本。
2021-04-27 06:33:59
求大神推薦嵌入式Linux開發板
還是學生,之前一直和老師做一些模擬電路和單片機的項目,熟悉51和stm32的編程,現在想做一下嵌入式系統方向,本人比較看好嵌入式驅動工程師,想問一下前輩需要注意一下什么,以及比較適合的開發板
2015-09-21 20:11:52
解析嵌入式軟件開發語言:嵌入式C編程
在我們初學嵌入式開發的時候,總會出現一個問題。那就是C語言和嵌入式C編程有什么區別?而嵌入式工程師一般都會告訴你,其區別在于嵌入式的C語言是跑在嵌入式的開發板上的,CPU和電腦不一樣,所以編譯器也是
2017-10-18 10:09:19
請問如何成為嵌入式高手?
插槽機制4、 QT圖形界面編程技術5、QT應用程序與Linux驅動的銜接6、 QT在實際項目中具體應用第十部分:無線通訊應用1、無線wifi模塊應用2、3G模塊應用第十一分布:嵌入式系統應用程序
2020-08-30 11:28:25
嵌入式CPU指令Cache的設計與實現
針對嵌入式CPU 指令處理速度與存儲器指令存取速度不匹配問題,本文基于FPGA 設計并實現了可以有效解決這一問題的指令Cache。根據嵌入式五級流水線CPU 特性,所設計指令Cache 的地
2009-08-05 14:27:5436
詳談嵌入式編程需注意的Cache機制和原理
1 Cache的原理 Cache即高速緩存,它的出現基于兩種因素:一、CPU的速度和性能提高很快,而主存速度較低且價格高;二、程序執行的局部性特點。將速度較快而容量有限的SRAM構成Cache,可以
2017-11-01 16:16:200
Linux內核文件Cache機制
Linux內核文件Cache機制(開關電源技術與設計 第二版)-Linux內核文件Cache機制? ? ? ? ? ? ? ??
2021-08-31 16:34:544
評論
查看更多