日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 電源 > 功率器件
[導讀]flash連接CPU時,根據(jù)不同的數(shù)據(jù)寬度,比如16位的NOR FLASH (A0-A19),處理器的地址線要(A1-A20)左移偏1位。為什么要偏1位?從軟件和CPU的角度而言,一個地址對應一個字節(jié),

flash連接CPU時,根據(jù)不同的數(shù)據(jù)寬度,比如16位的NOR FLASH (A0-A19),處理器的地址線要(A1-A20)左移偏1位。為什么要偏1位?

從軟件和CPU的角度而言,一個地址對應一個字節(jié),就是8位數(shù)據(jù)。這是肯定的,不要懷疑這點。

對于具體器件而言,它的位寬是一定的,所謂位寬,指的是“讀/寫操作時,最小的數(shù)據(jù)單元”──別說最小單元是“位”,一般設備上沒有單獨的“位操作”,修改位時通過把整個字節(jié)、字或雙字讀出來、修改,再回寫。

CPU的地址線(A0-A20)對應的最小數(shù)據(jù)單元是字節(jié),即8位;

而位寬為16的NOR FLASH的地址線(A0-A19)對應的最小數(shù)據(jù)單元是16位。

這兩個怎么對應起來?

如果說外設的位寬是16,難道我們寫程序時會“特意”以16位進行操作嗎?不用的,我們寫程序時根本不用管外設位寬是8、16還是32。

仔細想想,其實是可以想通的:既然CPU、外設NOR FLASH的最小讀/寫單元已經(jīng)固定,那么肯定就是CPU與NOR FLASH之間有個中間層,它來做處理:

這個中間層被稱為“Memory Controller”,CPU要進行讀寫操作時,“Memory Controller”根據(jù)NOR FLASH的位寬,每次總是讀/寫16位數(shù)據(jù)。

以讀操作為例:

CPU想進行8位操作時,它選擇其中的8位返回給CPU;

CPU想進行16位操作時,它直接把這16位數(shù)據(jù)返回給CPU;

CPU想進行32位操作時,它發(fā)起2次讀/寫,把結果組合成32位返回給CPU。

現(xiàn)在的連線是:CPU的(A1-A20)接到 16位的NOR FLASH (A0-A19),即CPU的A0不接──這說明:不管A0是0還是1,NOR FLASH接收到的地址是一樣的。

CPU發(fā)出地址0bxxxxxxxxx0、0bxxxxxxxxx1時,NOR FLASH看到的都是0bxxxxxxxxx,返回給“Memory Controller”的都是同一個16位數(shù)據(jù)。

再由“Memory Controller”選擇其中的低8位或高8位給CPU。

“Memory Controller”會幫助我們做這些事情,舉例為證:

1. 軟件要讀取地址0上的8位數(shù)據(jù)時,硬件是這樣進行的:

① “Memory Controller”發(fā)出0b000000000000000000000的地址信號,NOR FLASH的A0-A19線上的信號是:0b00000000000000000000

② NOR FLASH在數(shù)據(jù)總線D0~D15上提供一個16位的數(shù)據(jù),這是NOR FLASH中的第1個“最小數(shù)據(jù)單元”

③ “Memory Controller”讀入這個16位數(shù)據(jù)

④ “Memory Controller”把這個16位數(shù)據(jù)的低8位返回給CPU,這就是一個8位數(shù)據(jù)。

軟件要讀取地址1上的8位數(shù)據(jù)時,硬件是這樣進行的:

① “Memory Controller”發(fā)出0b000000000000000000001的地址信號,NOR FLASH的A0-A19線上的信號是:0b00000000000000000000

② NOR FLASH在數(shù)據(jù)總線D0~D15上提供一個16位的數(shù)據(jù),這是NOR FLASH中的第1個“最小數(shù)據(jù)單元”

③ “Memory Controller”讀入這個16位數(shù)據(jù)

④ “Memory Controller”把這個16位數(shù)據(jù)的高8位(注意,前面的低8位)返回給CPU,這就是一個8位數(shù)據(jù)。

軟件要讀取地址2上的8位數(shù)據(jù)時,硬件是這樣進行的:

① “Memory Controller”發(fā)出0b000000000000000000010的地址信號,NOR FLASH的A0-A19線上的信號是:0b00000000000000000001

② NOR FLASH在數(shù)據(jù)總線D0~D15上提供一個16位的數(shù)據(jù),這是NOR FLASH中的第2個“最小數(shù)據(jù)單元”

③ “Memory Controller”讀入這個16位數(shù)據(jù)

④ “Memory Controller”把這個16位數(shù)據(jù)的低8位返回給CPU,這就是一個8位數(shù)據(jù)。

軟件要讀取地址3上的8位數(shù)據(jù)時,硬件是這樣進行的:

① “Memory Controller”發(fā)出0b000000000000000000011的地址信號,NOR FLASH的A0-A19線上的信號是:0b00000000000000000001

② NOR FLASH在數(shù)據(jù)總線D0~D15上提供一個16位的數(shù)據(jù),這是NOR FLASH中的第2個“最小數(shù)據(jù)單元”

③ “Memory Controller”讀入這個16位數(shù)據(jù)

④ “Memory Controller”把這個16位數(shù)據(jù)的高8位(注意,第3點是低8位)返回給CPU,這就是一個8位數(shù)據(jù)。

軟件要讀取地址0和1上的16位數(shù)據(jù)時,硬件是這樣進行的:

① “Memory Controller”發(fā)出0b000000000000000000000的地址信號,NOR FLASH的A0-A19線上的信號是:0b00000000000000000000

② NOR FLASH在數(shù)據(jù)總線D0~D15上提供一個16位的數(shù)據(jù),這是NOR FLASH中的第1個“最小數(shù)據(jù)單元”

③ “Memory Controller”讀入這個16位數(shù)據(jù)

④ “Memory Controller”把這個16位數(shù)據(jù)返回給CPU

軟件要讀取地址2和3上的16位數(shù)據(jù)時,硬件是這樣進行的:

① “Memory Controller”發(fā)出0b000000000000000000010的地址信號,NOR FLASH的A0-A19線上的信號是:0b00000000000000000001

② NOR FLASH在數(shù)據(jù)總線D0~D15上提供一個16位的數(shù)據(jù),這是NOR FLASH中的第2個“最小數(shù)據(jù)單元”

③ “Memory Controller”讀入這個16位數(shù)據(jù)

④ “Memory Controller”把這個16位數(shù)據(jù)返回給CPU

軟件要讀取地址0、1、2、3上的32位數(shù)據(jù)時,硬件是這樣進行的:

① “Memory Controller”發(fā)出0b000000000000000000000的地址信號,NOR FLASH的A0-A19線上的信號是:0b00000000000000000000

② NOR FLASH在數(shù)據(jù)總線D0~D15上提供一個16位的數(shù)據(jù),這是NOR FLASH中的第1個“最小數(shù)據(jù)單元”

③ “Memory Controller”讀入這個16位數(shù)據(jù)

④ “Memory Controller”發(fā)出0b000000000000000000010的地址信號,NOR FLASH的A0-A19線上的信號是:0b00000000000000000001

⑤ NOR FLASH在數(shù)據(jù)總線D0~D15上提供一個16位的數(shù)據(jù),這是NOR FLASH中的第2個“最小數(shù)據(jù)單元”

⑥ “Memory Controller”讀入這個16位數(shù)據(jù)

⑦ “Memory Controller”把兩個16位的數(shù)據(jù)組合成一個32位的數(shù)據(jù),返回給CPU。

從1~7可知:

① 對于軟件而言,它不知道底下發(fā)生了什么事,它只管結果:

讀取地址0的8位數(shù)據(jù),就得到了一個8位數(shù)據(jù);讀取地址1的8位數(shù)據(jù),就得到另一個緊挨著的8位數(shù)據(jù)

讀取地址0開始的16位數(shù)據(jù),就得到了一個16位數(shù)據(jù);讀取地址2開始的16位數(shù)據(jù),就得到另一個緊挨著的16位數(shù)據(jù)

讀取地址0開始的32位數(shù)據(jù),就得到了一個32位數(shù)據(jù);讀取地址4開始的32位數(shù)據(jù),就得到另一個緊挨著的32位數(shù)據(jù)

② 對于NOR FLASH,它只按照A0-A19地址線,提供16位數(shù)據(jù),才不管軟件要的是8位、16位,還是32位呢。

③ “Memory Controller”完成了這些位寬之間的數(shù)據(jù)選擇、合并。

所以:

外設位寬是8時,CPU的A0~AXX與外設的A0~AXX直接相連

外設位寬是16時,CPU的A1~AXX與外設的A0~AYY直接相連,表示不管CPU的A0是0還是1,外設看到的都是同一個地址,對應16位的數(shù)據(jù),“Memory Controller”對數(shù)據(jù)進行選擇或組合,再提供給CPU。

外設位寬是32時,CPU的A2~AXX與外設的A0~AZZ直接相連,表示不管CPU的A0A1是00,01,10還是11,外設看到的都是同一個地址,對應32位的數(shù)據(jù),“Memory Controller”對數(shù)據(jù)進行選擇或組合,再提供給CPU。

但是也不是所有位寬16bit的flash與cpu的連接 都是像上述那樣錯開一位的,與具體的flash芯片設計有關系,所以需要查看其datsheet,下文以芯片士通的29LV650和intel的E29F128為例進行說明

這里看來intel nor flash在位寬為16bit時(由VPEN選擇),把A0忽略掉了(需要查手冊查證)

下面研究一下系統(tǒng)總線地址(cpu_addr)、寬度(bus_width)與nor flash設備總線地址(device_addr)、位度(device_width)的區(qū)別與聯(lián)系:

一、對于nor flash設備來說

1、nor flash設備的位寬視芯片廠商而定,有x8、x16兩總方式(雖然現(xiàn)在主要使用x16的方式,不過內核于啟動代碼里面仍然保留著對x8和x16兩種方式的支持);把多片nor flash并起來使用可以擴大位寬(比如兩片x8的nor flash并起來使用位寬擴大為x16)。

2、nor flash設備的總線地址(尋址)范圍視具體芯片以及其采用的位寬而定:

以富士通的29LV650為例:

(29LV650的容量是8Mbyte,共128個sector,每個sector的大小是64 kbyte)

1)如果選擇位寬為x8,設備總線的每個地址代表了一個byte的存儲單元,固其總線地址范圍為8M(0x000000~0x7fffff);

2)如果選擇位寬為x16,設備總線的每個地址代表了兩個byte的存儲單元,固其總線地址范圍為4M(0x000000~0x3fffff);

再來看看intel的E29F128:

(E29F128的容量為16Mbyte,共128個sector,每個sector的大小是128Kbyte)

1)如果選擇位寬為x8,設備總線的每個地址代表了一個byte的存儲單元,固其總線地址范圍為16M(0x000000~0xffffff);

2)如果選擇位寬為x16,情況和富士通的29LV650不同,這時候設備的A0腳不可用,所以你不能訪問到奇地址的存儲單元,而只能0、2、4…地址的來訪問,其總線地址范圍為8M(0x000000~0xffffff的偶地址)

二、對于系統(tǒng)來說

以S3C2410為例,cpu總線寬度是32位,可以通過8、16、32位的總線寬度來訪問nor flash設備,視設備的位寬和是否并起來使用而定:

注:

buswidth=device_width*interleave:

然而,在cpu的眼里,每一個地址代表1byte的存儲單元,不像nor flash設備那樣,還有byte、word之分。

三、好了,了解了系統(tǒng)總線地址、寬度與nor flash設備總線地址、位寬后的區(qū)別后,

現(xiàn)在討論一下cpu與nor flash的接法問題(通過舉例來說明):

1、對于富士通的29LV650

1)選擇x8方式,cpu的A0~A22接nor flash的A0~A22

2)選擇x16方式,cpu的A1~A22接nor flash的A0~A21

注意:

cpu的A1接nor flash的A0,cpu只能訪問偶地址,cpu的一次操作訪問了2byte大小的存儲單元。

2、對于intel的E29F128

1)選擇x8方式,cpu的A0~A23接nor flash的A0~A23

2)選擇x16方式,由于這時候地址線A0不再有效(這點與富士通的29LV650不同),

intel E29F128的A1等價于富士通的29LV650的A0,所以系統(tǒng)總線A1~A23接nor flash的A1~A23

四、在cpu對nor flash尋址方面

1、對于富士通的29LV650

1)在x8模式,系統(tǒng)總線和nor flash總線一一對應,直接訪問

2)在x16模式,nor flash的對外總線縮小一半,一個地址可尋址的存儲單元由原來的1 byte變?yōu)? word(1 sector的地址范圍由原來的1<<16變?yōu)?<<15),所以我們對其進行尋址的時候,需要把所要尋址的存儲單元地址>>1位

注意:

我這里說的是以byte為單位的存儲單元地址

由于系統(tǒng)總線的A1接nor flash的A0,固系統(tǒng)總線地址等于nor flash總線地址<<1位12

注意:

我這里說的是nor flash的總線地址,對于x8方式以byte為單位,對于x16方式以word為單位

2、對于intel的E29F128

1)在x8模式,系統(tǒng)總線和nor flash總線一一對應,直接訪問

2)在x16模式,nor flash總線的A0不再使用,有效的總線為A1~A23,所以我們對其尋址的時候,不必像富士通的29LV650那樣需要把所要訪問的存儲單元地址>>1位(因為A0不再有效,等于奇地址自動被忽略,只有偶地址起作用)

同樣:

由于nor flash總線的A0不起作用,系統(tǒng)總線的A1接nor flash的A1,所以我們只要直接給出存儲單元的地址即可,不比對其進行<<1位操作(不過由于設備總線A0不起作用,所以系統(tǒng)只能訪問到偶地址的存儲單元,奇地址將會被忽略)

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

LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅動性能的關鍵。

關鍵字: 工業(yè)電機 驅動電源

LED 驅動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅動電源 照明系統(tǒng) 散熱

根據(jù)LED驅動電源的公式,電感內電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質量和效率直接關系到城市的公共安全、居民生活質量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅動電源 功率因數(shù)校正

在LED照明技術日益普及的今天,LED驅動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅動電源

關鍵字: LED 驅動電源 開關電源

LED驅動電源是把電源供應轉換為特定的電壓電流以驅動LED發(fā)光的電壓轉換器,通常情況下:LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅動電源
關閉