第五讲 单周期处理器(Single Cycle Processor)

内容要点:控制器,数据通路

处理器的实际步骤

  • 分析指令系统,得出对数据通路的需求
  • 为数据通路选择合适的组件
  • 连接组件建立数据通路
  • 分析每条指令的实现,以确定控制信号
  • 集成控制信号,形成完整的控制逻辑

MIPS指令系统的简化版本

  • 无符号加法和减法(R指令)

    • addu rd, rs, rt

      1. MEM[PC]:从指令存储器中取回指令

      2. R[rd] = R[rs] + R[rt]:指令指定的操作

      3. PC = PC + 4:计算下一条指令的地址

    • subu rd, rs, rt

  • 立即数的逻辑或(I指令)

    • ori rt, rs, imm16

      1. MEM[PC]:从指令存储器中取回指令

      2. R[rt] = R[rs] | ZeroExt [imm16]:指令指定的操作

      3. PC = PC + 4:计算下一条指令的地址

  • 装载和存储一个字(32位/4Byte)(I指令)

    • lw rt, imm16(rs)
      1. MEM[PC]:从指令存储器中取回指令
      2. R[rt] = DataMemory{R[rs] + SignExt[imm16]}:指令指定的操作
      3. PC = PC + 4:计算下一条指令的地址
    • sw rt, imm16(rs)
      1. MEM[PC]:从指令存储器中取回指令
      2. DataMemory{R[rs] + SignExt[imm16]} = R[rt] :指令指定的操作
      3. PC = PC + 4:计算下一条指令的地址
  • 条件分支

    • beq rs, rt, imm16

      1. MEM[PC]

      2. if (R[rs] - R[rt] == o) //从指令存储器中取回指令,判断转移条件是否成立

        then zero = 1; else zero = 0 //zeroSignal传入IFU)

      3. then:PC = PC + 4 + SignExt[imm16] * 4; // label (imm16)的实际数值是转移目标地址和下一条指令地址之间的差值,此差值以4Byte(32bits)为一个单位

        else:PC = PC + 4;//计算下一条指令地址

指令系统的需求

  • 算术逻辑单元(ALU)

    • 运算类型:加、减、或、比较相等
    • 操作数:2个32位的数,来自寄存器或扩展后的立即数
  • 立即数扩展部件

    • 讲一个16立即数扩展为32位数
    • 扩展方式:零扩展、符号扩展
  • 程序计数器(PC)

    • 一个32位的寄存器
    • 支持两种加法:加4或者加一个立即数
  • 寄存器堆(两读一写)

    • 每个寄存器为32位宽,共32个
    • 支持读操作:rs和rt
    • 支持写操作:rt或rd
  • 存储器(对应了CPU中的指令和数据高速缓存(Cache))

    • 一个只读的指令存储器,地址和数据均为32位
    • 一个可读写的数据存储器,地址和数据均为32位
  • 建立数据通路

    • 基本原则:根据指令需求,连接组件,建立数据通路
    • 指令的需求
      1. 所有指令的共同需求
        • 取指令:
          • 程序计数器(PC)的内容是指令的地址
          • 用PC的内容作为地址,访问指令存储器获得指令编码
        • 更新程序计数器(PC)
          • 顺序执行:PC <- PC + 4
          • 发生分支时:PC <- 分支目标地址
      2. 不同指令的不同需求

控制信号的集成

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

推荐阅读更多精彩内容