返回列表 发帖
ripple哥,你忘了讲L-Bank啦,呵呵。

L-Bank就是逻辑bank,是内存芯片的存储阵列,内存芯片由于技术、成本等原因,不可能只做一个全容量的L-Bank,所以一般都有好几个,更所以,内存芯片的容量就是所有L-Bank中的存储单元的容量总合。再所以,内存容量的计算公式就出来了:存储单元数量=行数×列数(得到一个L-Bank的存储单元数量)×L-Bank的数量,内存容量(Mbit)=存储单元数量(M)X位宽(bit)。

example:MT47H256M4 – 32 Meg x 4 x 8 bank

这个是Miron的1Gddr2内存芯片。32M一个L-Bank的存储单元数量,4位宽,8L-Bank的数量。

新手意见,还请各位达人多指教!

TOP

L-BANK 不是bank么

TOP

ripple哥,你忘了讲L-Bank啦,呵呵。

L-Bank就是逻辑bank,是内存芯片的存储阵列,内存芯片由于技术、成本等原因,不可能只做一个全容量的L-Bank,所以一般都有好几个,更所以,内存芯片的容量就是所有L-Bank中的存 ...
teargas 发表于 2009-8-7 17:31



应该不是忘记讲
而是L-bank的概念很好理解
I8023SI...不問可不可行,而問如果一定要做,該怎麼做

TOP

关于数据的存储和操作,不得不提到两个概念“big endian”和"little endian"这个对嵌入式比较重要。最近也才刚搞清楚。分享一下:
Big Endian和Little Endian的区别
1.故事的起源 “endian”这个词出自《格列佛游记》。小人国的内战就源于吃鸡蛋时是究竟从大头(Big-Endian)敲开还是从小头(Little-Endian)敲开,由此曾发生过六次叛乱,其中一个皇帝送了命,另一个丢了王位。 我们一般将endian翻译成“字节序”,将big endian和little endian称作“大尾”和“小尾”。
2.什么是Big Endian和Little Endian? 在设计计算机系统的时候,有两种处理内存中数据的方法。一种叫为little-endian,存放在内存中最低位的数值是来自数据的最右边部分(也就是数据的最低位部分)。 比如某些文件需要在不同平台处理,或者通过Socket通信。这方面我们可以借助ntohl(), ntohs(), htonl(), and htons()函数进行格式转换, 个人补充:一个操作数作htonl或ntohl结果不一定相同,当机器字节序跟网络字节序刚好是仅仅big endian和little endian的区别时是相同的。
3. 如何理解Big Endian和Little Endian    举个例子: int a = 1; a这个数本身的16进制表示是0x00 00 00 01 在内存中怎么存储呢? 如果你的CPU是intel x86架构的(基本上就是通常我们说的奔腾cpu),那么就是0x01 0x00 0x00 0x00 , 这也就是所谓的little-endian, 低字节存放在内存的低位. 如果你的CPU是老式AMD系列的(很老很老的那种,因为最新的AMD系列已经是x86架构了), 它的字节序就是big-endian, 其内存存储就是 0x00 0x00 0x00 0x01在内存中从高字节开始存放。 现在世界上绝大多数的CPU都是little-endian。
4. 了解big-endian和little-endian有什么作用? 一个重要的作用就是了解在网络上不同的机器间的数据如何传输。 假设我们在网络上有两台机器A和B, 其中A为little-endian,B为big-endian 机器A要传输上面的整数a给机器B,如何传输呢? 过程是这样的: 机器A先把a在内存中的四个字节0x 01 0x00 0x00 0x00转化为网络字节序0x00 0x00 0x00 0x01,然后一个字节一个字节(从0x00到0x01)喂到网络上去 然后机器B从网络上一个字节一个字节地取出四个字节0x00 0x00 0x00 0x01后又会转化为本地字节序 0x00 0x00 0x00 0x01后放入内存。因而B正确地得到了来自A的数据a 如果数据缺少在网络上的字节序转换的话,情况会怎样呢? 机器A先把a由在内存的四个字节0x 01 0x00 0x00 0x00 一个字节一个字节地喂到网络上,然后机器B从网络上一个字节一个字节地收到0x 01 0x00 0x00 0x00并放入到内存中, B认为他收到了0x01000000, 也就是十进制数1677216,这显然是错误的.
5.如何判断系统是Big Endian还是Little Endian? 在/usr/include/中(包括子目录)查找字符串BYTE_ORDER(或_BYTE_ORDER, __BYTE_ORDER),确定其值。这个值一般在endian.h或machine/endian.h文件中可以找到,有时在feature.h中,不同的操作系统可能有所不同。一般来说,Little Endian系统BYTE_ORDER(或_BYTE_ORDER,__BYTE_ORDER)为1234,Big Endian系统为4321。大部分用户的操作系统(如windows, FreeBsd,Linux)是Little Endian的。少部分,如MAC OS ,是Big Endian 的。本质上说,Little Endian还是Big Endian与操作系统和芯片类型都有关系。

TOP

写的太好了,收益匪浅啊
不过在请教一下:
Bank 其实就是内存颗粒里面的地址扩展吗?

TOP

写的太好了,收益匪浅啊
不过在请教一下:
Bank 其实就是内存颗粒里面的地址扩展吗?
yawyw 发表于 2010-4-22 10:13


可以这么认为。

TOP

可以这么认为。
ripple 发表于 2010-4-22 15:01

那么如何才能知道内存上面是几个BANK呢
曾经碰到一些问题,电脑上有一种内存可以开机,用另外一种就不能开机,最后差出来就是因为一根BANK线断掉了

TOP

在颗粒上有BA[n..0]的信号线。通常对于内存颗粒在1Gb以上的DDR2,n一般为2,小于1G以下的为1。而对于DDR3,n通常为2。
可以参考如下图,为一内存颗粒的引脚分配,红色椭圆部分就是BA信号。
附件: 您需要登录才可以下载或查看附件。没有帐号?敬请注册

TOP

回复 38# ripple


    good

TOP

回复 34# ripple


    顶起,ripple

TOP

返回列表