內存顆粒位寬和容量_SDRAM的邏輯Bank與芯片容量表示方法

1、邏輯Bank與芯片位寬

講完SDRAM的外在形式,就該深入了解SDRAM的內部結構了。這里主要的概念就是邏輯Bank。簡單地說,SDRAM的內部是一個存儲陣列。因為如果是管道式存儲(就如排隊買票),就很難做到隨機訪問了。

陣列就如同表格一樣,將數據“填”進去,你可以把它想象成一張表格。和表格的檢索原理一樣,先指定一個行(Row),再指定一個列(Column),我們就可以準確地找到所需要的單元格,這就是內存芯片尋址的基本原理。對于內存,這個單元格可稱為存儲單元,那么這個表格(存儲陣列)叫什么呢?它就是邏輯Bank(Logical Bank,下文簡稱L-Bank)。

L-Bank存儲陣列示意圖

由于技術、成本等原因,不可能只做一個全容量的L-Bank,而且最重要的是,由于SDRAM的工作原理限制,單一的L-Bank將會造成非常嚴重的尋址沖突,大幅降低內存效率(在后文中將詳細講述)。所以人們在SDRAM內部分割成多個L-Bank,較早以前是兩個,目前基本都是4個,這也是SDRAM規范中的最高L-Bank數量。到了RDRAM則最多達到了32個,在最新DDR-Ⅱ的標準中,L-Bank的數量也提高到了8個。

這樣,在進行尋址時就要先確定是哪個L-Bank,然后再在這個選定的L-Bank中選擇相應的行與列進行尋址。可見對內存的訪問,一次只能是一個L-Bank工作,而每次與北橋交換的數據就是L-Bank存儲陣列中一個“存儲單元”的容量。在某些廠商的表述中,將L-Bank中的存儲單元稱為Word(此處代表位的集合而不是字節的集合)。

從前文可知,SDRAM內存芯片一次傳輸率的數據量就是芯片位寬,那么這個存儲單元的容量就是芯片的位寬(也是L-Bank的位寬),但要注意,這種關系也僅對SDRAM有效,原因將在下文中說明。

2、內存芯片的容量

現在我們應該清楚內存芯片的基本組織結構了。那么內存的容量怎么計算呢?顯然,內存芯片的容量就是所有L-Bank中的存儲單元的容量總合。計算有多少個存儲單元和計算表格中的單元數量的方法一樣:

存儲單元數量=行數×列數(得到一個L-Bank的存儲單元數量)×L-Bank的數量

在很多內存產品介紹文檔中,都會用M×W的方式來表示芯片的容量(或者說是芯片的規格/組織結構)。M是該芯片中存儲單元的總數,單位是兆(英文簡寫M,精確值是1048576,而不是1000000),W代表每個存儲單元的容量,也就是SDRAM芯片的位寬(Width),單位是bit。計算出來的芯片容量也是以bit為單位,但用戶可以采用除以8的方法換算為字節(Byte)。比如8M×8,這是一個8bit位寬芯片,有8M個存儲單元,總容量是64Mbit(8MB)。

不過,M×W是最簡單的表示方法。下圖則是某公司對自己內存芯片的容量表示方法,這可以說是最正規的形式之一。

業界正規的內存芯片容量表示方法

我們可以計算一下,結果可以發現這三個規格的容量都是128Mbits,只是由于位寬的變化引起了存儲單元的數量變化。從這個例子就也可以看出,在相同的總容量下,位寬可以采用多種不同的設計。

3、與芯片位寬相關的DIMM設計

為什么在相同的總容量下,位寬會有多種不同的設計呢?這主要是為了滿足不同領域的需要。現在大家已經知道P-Bank的位寬是固定的,也就是說當芯片位寬確定下來后,一個P-Bank中芯片的個數也就自然確定了,而前文講過P-Bank對芯片集合的位寬有要求,對芯片集合的容量則沒有任何限制。高位寬的芯片可以讓DIMM的設計簡單一些(因為所用的芯片少),但在芯片容量相同時,這種DIMM的容量就肯定比不上采用低位寬芯片的模組,因為后者在一個P-Bank中可以容納更多的芯片。比如上文中那個內存芯片容量標識圖,容量都是128Mbit,合16MB。如果DIMM采用雙P-Bank+16bit芯片設計,那么只能容納8顆芯片,計128MB。但如果采用4bit位寬芯片,則可容納32顆芯片,計512MB。DIMM容量前后相差出4倍,可見芯片位寬對DIMM設計的重要性。因此,8bit位寬芯片是桌面臺式機上容量與成本之間平衡性較好的選擇,所以在市場上也最為普及,而高于16bit位寬的芯片一般用在需要更大位寬的場合,如顯卡等,至于4bit位寬芯片很明顯非常適用于大容量內存應用領域,基本不會在標準的Unbuffered 模組設計中出現。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/258480.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/258480.shtml
英文地址,請注明出處:http://en.pswp.cn/news/258480.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

[Unity菜鳥] Time

1. Time.deltaTime 增量時間 以秒計算,完成最后一幀的時間(秒)(只讀) 幀數所用的時間不是你能控制的。每一幀都不一樣,游戲一般都是每秒60幀,也就是updata方法調用60次(假如你按60幀來算 而真實情況是不到60幀 那么物體就不會運動…

【轉】七個例子幫你更好地理解 CPU 緩存

我的大多數讀者都知道緩存是一種快速、小型、存儲最近已訪問的內存的地方。這個描述相當準確,但是深入處理器緩存如何工作的“枯燥”細節,會對嘗試理解程序性能有很大幫助。在這篇博文中,我將通過示例代碼來說明緩存是如何工作的,…

Pytorch——對應點相乘和矩陣相乘

1. 點乘,對應元素相乘,不求和 import torcha torch.Tensor([[1,2], [3,4], [5,6]]) b1 a.mul(a)// b2a*a b1 Out[79]: tensor([[ 1., 4.],[ 9., 16.],[25., 36.]]) b2 Out[80]: tensor([[ 1., 4.],[ 9., 16.],[25., 36.]]) 以上兩種方法都可以表…

mysql初始化錯誤【一】Can't find error-message file '/usr/local/mysql/errmsg.sys'

環境:CentOS 7.2MySQL 5.7.18從mysql官方網站下載rpm包到服務器本地,依次安裝下面的RPM包:mysql-community-common-5.7.18-1.el7.x86_64.rpmmysql-community-server-5.7.18-1.el7.x86_64.rpmmysql-community-client-5.7.18-1.el7.x86_64.rpmm…

雙極型adc與stm32_關于STM32 雙ADC同步規則轉換兩路數據的問題?

因系統要求需升級ADC的采樣方式(以前方式:掃描方式,TIMER2觸發ADC軟啟動,2通道規則序列,DMA傳完中斷),為了進一步實現兩路信號的同步性能,采樣STM32 雙ADC同步規則轉換。(timer2觸發ADC軟啟動,2…

面試金典--11.5

題目描述:給定排序后的字符串數組,中間有一些空串,要求找到給定字符串的位置 思路: (1)遍歷,最慢的 (2)二分查找,當mid處為空串,就找到最近的非空…

win10 平臺VS2019最簡安裝實現C++/C開發

這兩天一直在安裝vs2015,總是卡在visual studio 2015 出現安裝包丟失或損壞的現象,盡管按照網上很多方法嘗試解決,但是一直不行。算了。還是使用最新版的VS 2019安裝,沒想到很順利。 下面總結一下在win10平臺上最簡安裝VS2019,實…

Hook的兩個小插曲

看完了前面三篇文章后,這里我們來一個小插曲~~~~ 第一個小插曲。是前面文章一個CM精靈的分析。我們這里使用hook代碼來搞定。 第二個小插曲,是如今一些游戲,都有了支付上限,比如每天僅僅能花20塊錢來購買。好了。以下我們分開敘述…

### C++總結-[類成員函數]

C類中的常見函數。 #author: gr #date: 2015-07-23 #email: forgeruigmail.com 一、constructor, copy constructor, copy assignment, destructor 1. copy constructor必須傳引用,傳值編譯器會報錯 2. operator 返回值為引用,為了…

微信小程序和vue雙向綁定哪里不一樣_個人理解Vue和React區別

本文轉載自掘金,作者:binbinsilk,監聽數據變化的實現原理不同Vue 通過 getter/setter 以及一些函數的劫持,能精確知道數據變化,不需要特別的優化就能達到很好的性能React 默認是通過比較引用的方式進行的,如…

JS 省,市,區

1 // 純JS省市區三級聯動2 // 2011-11-30 by http://www.cnblogs.com/zjfree3 var addressInit function (_cmbProvince, _cmbCity, _cmbArea, defaultProvince, defaultCity, defaultArea) {4 var cmbProvince document.getElementById(_cmbProvince);5 var cmbCity…

使用極鏈/AutoDL云服務器復盤caffe安裝

繼上一次倒騰caffe安裝以后,因為博士畢業等原因,舊的服務器已經不能再使用,最近因論文等原因,不得不繼續來安裝一下我的caffe。這次運氣比較好,經歷了一晚上和一早上的痛苦之后,最終安裝成功了,…

ibatis中使用List作為傳入參數的使用方法及 CDATA使用

ibatis中list做回參很簡單,resultClass設為list中元素類型,dao層調用: (List)getSqlMapClientTemplate().queryForList("sqlName", paraName); 并經類型轉換即可,做入參還需要稍微調整下,本文主要講list做入參碰到的幾…

Samba服務

####################samba####################1.samba作用提供cifs協議實現共享文件2.安裝yum install samba samba-common samba-client -ysystemctl start smb nmbsystemctl enable smb nmb3.添加smb用戶smb用戶必須是本機用戶[rootlocalhost ~]# smbpasswd -a student New…

wpf 窗口的返回值_WPF Tips: Window.ShowDialog() 返回 true

Window.ShowDialog() 返回值為bool?。希望在窗口點擊OK時返回True。解決方法:ShowDialog()的注釋為:// Returns:// A System.Nullable value of type System.Boolean that specifies whether// the activity was accepted (true) or canceled (false). …

CodeForces 543D 樹形DP Road Improvement

題意: 有一顆樹,每條邊是好邊或者是壞邊,對于一個節點為x,如果任意一個點到x的路徑上的壞邊不超過1條,那么這樣的方案是合法的,求所有合法的方案數。 對于n個所有可能的x,輸出n個答案。 分析&am…

理解Javascritp中的引用

Author: bugall Wechat: bugallF Email: 769088641qq.com Github: https://github.com/bugall一: 函數中的引用傳遞 我們看下下面的代碼的正確輸出是什么 function changeStuff(a, b, c) {a a * 10;b.item "changed";c {item: "changed"}; …

通過擴展改善ASP.NET MVC的驗證機制[實現篇]

通過擴展改善ASP.NET MVC的驗證機制[實現篇] 原文:通過擴展改善ASP.NET MVC的驗證機制[實現篇]在《使用篇》中我們談到擴展的驗證編程方式,并且演示了本解決方案的三大特性:消息提供機制的分離、多語言的支持和多驗證規則的支持,我們現在來看…

canopen和1939區別_CAN 和 CANopen的區別和聯系

1、CAN與CANopen的共同點與不同點:CAN只定義了物理層與鏈路層,而沒有定義用戶層,用戶可根據自己的需要定義一些網絡上的通信約定; CANopen是在CAN的基礎上定義了用戶層,即規定了用戶、軟件、網絡終端等之間用來進行信…

ONOS系統架構演進,實現高可用性解決方案

上一篇文章《ONOS高可用性和可擴展性實現初探》講到了ONOS系統架構在高可用、可擴展方面技術概況,提到了系統在分布式集群中怎樣保證數據的一致性。在數據終于一致性方面,ONOS採用了Gossip協議。這一部分的變化不大,而在強一致性方案的選擇方…