第六章

随机访问存储器 Random-Access Memory,RAM

  1. 静态RAM(SRAM)
    速度比动态的RAM要快,但是也贵得多,通常作为高速缓存存储器。
    电路类似于下面的图,只有两个状态是稳定的,其他状态都是不稳定的,从不稳定状态开始,电路会迅速地转移到两个稳定状态的其中一个。每位用六晶体管来实现。


    image.png

    SRAM只要有电,就会永远保持它的值,有干扰的电压也不会改变值,干扰消除时,电路就会恢复稳定。

  2. 动态RAM(DRAM)
    DRAM将每个位存储为对一个电容的充电,这个电容非常小,对干扰非常敏感,当电容的电压被扰乱之后,它就无法恢复了。
    很多原因会导致漏电,所以内存系统必须周期性地通过读出,然后重写刷新内存每一位。
    每位一个晶体管。

  3. 传统DRAM
    为了方便寻址,将DRAM芯片中的单元(位)划分为d个超单元,每个超单元都由w个DRAM单元组成。超单元被组织成一个r行c列的长方形阵列,rc = 。每个单元有形如(i,j)的二维地址。
    取值的时候先传送i,再传送j,再通过(i,j)取值。这样可以减少引脚的数量,但是需要加倍的传送时间。
    内部有一个行缓冲区,比如读取(2,1)的时候,会先将2读入内部行缓冲区,再将列1读出发给内存控制器。


    image.png
  4. 内存模块
    将多个DRAM组合成一个内存模块,例如将8个8Mx8的DRAM组成64M的内存模块,8个芯片编号0-7,每个超单元存储主存的一个字节,一个地址(i,j)表示的是64位。内部将64位组合成8字节返回给内存控制器。


    image.png
  5. 非易失性存储器
    断电后仍然可以保存数据的存储器。
    ROM中有的类型既可以读,也可以写,但是被统称为只读存储器(Read-Only Memory)。

  • PROM(Programmable ROM)只能被编程一次。
  • 可擦写可编程ROM(Erasable Programmable ROM,EPROM)可以写入与擦除次数达1000次。
  • 电子可擦除PROM(Electrically Erasable PROM,EEPROM),可以达10^5次编程次数。
  • 闪存(flash memory)是基于EEPROM的存储器
    存储在ROM中的程序称为固件(firmware),当计算机系统通电后机会运行存储器在ROM中的固件。
  1. 访问主存
    数据流通过称为总线(bus)的电路在CPU和DRAM主存之间来来回回。每次传送数据的一系列步骤称为总线事务(bus transaction)。读事务从主存传送数据到CPU。写事务从CPU传送数据到主存。


    image.png

    I/O桥包括内存控制器。
    movq A,%rax的具体过程:


    image.png

    image.png
  1. 旋转磁盘


    image.png

    每个盘片有两面,有磁性记录材料。每个同心圆都是一个磁道(track),每个磁道被划分为一组扇区(sector)。多个半径相等的磁道被称为一个柱面(cylinder)。
    磁盘为了对操作系统隐藏复杂性,将磁盘构造呈现为一个简单的视图,一个B个扇区大小的逻辑块的序列,序号为0,1,...,B-1。磁盘中有一个固件设备,称为磁盘控制器,扶着维护逻辑块号与实际磁盘扇区之间的映射关系,会将逻辑块号翻译成一个(盘面,磁道,扇区)三元组。

局部性(locality)

时间局部性(temporal locality):被引用过一次的内存位置很可能在不远的将来再被多次引用。
空间局部性(spatial locality):如果一个内存位置被引用了一次,那么程序很可能在不远的将来引用附件的一个内存位置。
此种程序具有较好的局部性:sum具有时间局部性,a数组具有空间局部性。但是如果将a[i][j]变为 a[j][i]那么空间局部性很可能会降低。


image.png

存储器层次结构

image.png
  1. 缓存
    高速缓存(cache)是一个小而快速的存储设备,它作为存储在更大、也更慢的设备中的数据对象的缓冲区域。使用高速缓存的过程称为缓存(caching)。
  • 缓存命中:在第k层的某些块中找到了要访问的第k+1层的数据对象d,就是缓存命中。
  • 缓存不命中:如果第k层中没有数据对象d,就是缓存不命中。此时要从k+1层中取出包含d的那个块,放到第k层中缓存起来,如果缓存已满,则需要一定的替换策略(replacement policy)进行覆盖,例如LRU,最近最少被使用。
  • 缓存不命中的种类
    冲突不命中:一定的放置策略导致无法命中。
    容量不命中:缓存太小。
  1. 高速缓存存储器


    image.png
  2. 有关写的问题
    当更新了缓存的字w,如何写回低一层的副本中呢?

  3. 直写(write-through),立即将w的高速缓存块写回到第一层中。

  4. 写回(write-back),当替换算法要替换这个更新过的块时,才写到第一层中。必须维护一个额外的修改位(dirty bit),表明是否被修改过。

  5. 真实高速缓存层次结构
    真实的高速缓存可以分为i-cache(只保存指令),d-cache(只保存数据),统一高速缓存(都可以保存)


    image.png
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容