版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
数字系统设计
DigitalSystemDesign-----微处理器设计22讲义第十章微处理器设计2微处理器内部结构微处理器的两个主要部分:控制单元用于控制数据通路的所有操作,实现微处理器运算的正确性数据通路主要包括运算单元ALU、存储单元(寄存器)及其相互连接3微处理器内部结构微处理器的三个执行步骤指令周期(1)取指即从程序存储器中把PC所指向的指令取出,拷贝到IR;PC+1指向下一条指令的地址;(2)译指从IR中提取出操作码,对指令所要做的操作进行翻译;决定当前执行那一条指令,跳转到那一个对应的状态去;(3)执行指令每一步将在有限状态机的一个状态被执行。每个指令通常在一个时钟周期内执行有些情况下一些存储器操作的指令可能需要两个甚至更长的时钟周期,这种情况下就需要更多的状态来实现正确的时序。一般而言,程序的指令都是存储在外部寄存器中的,所以除了CPU外,微处理器一般还需要外部存储器以及连接外部存储器与CPU的地址以及数据总线。4mips指令格式1)R型------三个寄存器操作数格式用于如add和sub指令,有三个寄存器操作数。2)I型--------两个寄存器操作数格式用于如lw和sw指令,具有两个寄存器操作数和一个16位立即数。3)J型-------无寄存器格式有一个26位的立即数,无寄存器。
MIPS采用32位指令5微处理器实例1分析
--------simple4-bitCPUhttp://jaromir.xf.cz/fourbit/fourbit.html6Another4-bitTTLCPU7TheReducedInstructionSet-APOLLO181
only2^4=16operationcodes(orop-codes)Eachinstructionthentakesanargumentof4-bitdataasimmediateoperandNotesforthe4-bitimmediateoperands:§"n"isa4-bitbinarydata§"r"pointsoneofthe16registers§"p"isabinaryoperandwhichreferstothefourfunction–selectlines(S0,S1,S2,S3)oftheALUitincludesAddition,Subtraction,Shiftoperand,MagnitudeComparisonplustwelveotherArithmeticoperations.Thenitincludes
Exclusive-OR,Comparator,AND,NAND,OR,NORplustenotherLogicOperations§"s"canonlytakethebinaryvaluesof“0000”(0Hex)or“1111”(FHex)8NewInstructionset9InstructionOpCodeSummaryDescriptionLOAD(Mem)0000Accum=mem[Operand];LoaddatatotheaccumulatorfromavalueheldinRAMwiththeaddresssetbytheoperand.
LOAD(Value)0001Accum=Operand;Loadtheoperanddatatotheaccumulaor.ADD(Mem)0010Accum+=mem[Operand];AddvalueheldinmemorytotheaccumuatorADD(Value)0011Accum+=Operand;Addoperandtotheaccumuator
SUB(Mem)0100Accum-=mem[Operand];Subtractvalueheldinmemoryfromtheaccumuator
SUB(Value)0101Accum-=Operand;Subtractoperandfromtheaccumuator
STO(Mem)0110mem[mem[Operand]]=Accum;
Storeaccumulator'svaluetomemory,addressheldinmemory.
STO(Value)0111mem[Operand]=Accum;Storeaccumulator'svaluetomemory,operandequalsaddress.
READ(Mem)1000Addr=mem[Operand];Readfromaddress,addressheldinmemory.READ(Value)1001Addr=Operand;
Readfromaddress,operandequalsaddress.JMPLOW(Mem)1010PCLowAddr=mem[Operand]Jumpthelower4-bitsoftheProgramCountertoanaddressheldinmemory.JMPLOW(Value)1011PCLowAddr=OperandJumpthelower4-bitsoftheProgramCountertoanaddressheldbytheoperand.JMPHIGH(Mem)1100PCHighAddr=mem[Operand]
Jumptheupper4-bitsoftheProgramCountertoanaddressheldinmemory.
JMPHIGH(Value)1101PCHighAddr=Operand
Jumptheupper4-bitsoftheProgramCountertoanaddressheldbytheoperand.JMPZERO(Mem)1110if(Accum==0){
PC=mem[Operand];
}Ifaccumulatorequalszero,programcounteraddressequalsavalueinprogrammemory.JMPZERO(Value)1111if(Accum==0){
PC=Operand;
}Ifaccumulatorequalszero,programcounteraddressequalstheoperand.
NewInstructionsetTheMath(Command#4,#5,#6,#7,#8,#9)Movedatainsideandoutside(Command#1,#2,#3,#E,#F)ComparisonandJump(Command#0,#A,#B,#C,#D)10MicrocodeTheop-codeoftheinstructionisdecodedimmediatelybytheROM(74188)becausethemostsignificantdata-outputsoftheRAMarehard-wiredtotheROMaddresses.Foreach
op-codetheROMprovidesamicroprogrammed
sequenceoffourstates.Sixteendifferentop-codeswithfourstateseachmakesixty-fourpossiblecombinations.Thus
four
ROM74188are
tiedtogethertoformalargerarrayofmemorythatconsistsof
64words.11Schematicformicrocode124bitCPU-Micro-instructionmicrocodedetailStartingataddresszeroandincrementingbyoneforeachline,fourforeachinstruction13ADDRESSROM0ROM10FFFF17FFF2BFFF3FFFF4FFFD5DFFF6FFFF7FFFD8FFFB9DFFF10FFFF11FFFB12FFFF13FDFF14FFFF15FFFF16FFFF17EFFF18FFFF19FFFF20FFFF21F7FF22FFFF23FFFF24FFFF25FBFF26FFFF27FFFF28FFFD29FEFF30FFFF31FFFD32FFFB33FEFF34FFFF35FFFB36FFFF37FFEF38FFFF39FFFF40FFFF41FF7F42FFEF43FFFF44FFFF45FFBF46FFEF47FFFF48FFFF49FFDF50FFEF51FFFF52FFFE53DFFF54FFFF55FFFE56FFFB57FFF758FFFF59FFFB60FFFF61FFFF62FFFF63FFFFLTCHINC/LD/INC/DECLTCH/WRLTCH/RSTLTCH/RDINS/EROMINSPCACCACCACCREGREGFLAGJMPLJMPEJMPGPCOUTREGDATAIN01FETCH1111111111111111FFFF01111111111111117FFF1011111111111111BFFF1111111111111111FFFFLIT1111111111111101FFFD1101111111111111DFFF1111111111111111FFFF1111111111111101FFFDLOAD1111111111111011FFFB1101111111111111DFFF1111111111111111FFFF1111111111111011FFFBSTORE1111111111111111FFFF1111110111111111FDFF1111111111111111FFFF1111111111111111FFFFINC1111111111111111FFFF1110111111111111EFFF1111111111111111FFFF1111111111111111FFFFInterruptInterruptsignalsserveinAPOLLO181thesamepurposesasinterruptsinothersmicroprocessorswhenanexternalasynchronouseventhasoccurred,theCPUjumptoanotherportionoftheprogram.Asimplenon-maskableinterrupttechniquehasbeenimplementedviahardware.Whenadeviceassertstheinterruptsignal(inoursimplecaseabuttonkey)theCPUwaitstofinishthecurrentinstructionexecutionandthendefinitelyjumpsatthememorylocationpointedbyasetof8-bitswitchesplacedontheboard.Inthiswayitistheoreticallypossibletoimplement2^8=256differentinterruptswhichcouldpointall256RAMlocationsoftheprogramspace.Herewecanputaconditionaljumptabletoenhanceinterruptcapability.Unfortunatelythelackofamemorystackandthelimitednumberofavailableinstructionshaspreventedtheimplementationofa“returnfrominterrupt”whichwouldhaveallowedtheprogramtoflowbacktothemainprogramwhereitwasinterrupted.14ComputerOrganizationComputerdesignasanapplicationofdigitallogicdesignproceduresComputer=processingunit+memorysystemProcessingunit=control+datapathControl=finitestatemachineInputs=machineinstruction,datapathconditionsOutputs=registertransfercontrolsignals,ALUoperationcodesInstructioninterpretation=instructionfetch,decode,executeDatapath=functionalunits+registersFunctionalunits=ALU,multipliers,dividers,etc.Registers=programcounter,shifters,storageregisters总结16ALU时钟PC计数器寄存器程序存储器寄存器组总线LDassertedduringalo-to-hiclock
transitionloadsnewdataintoFFsOEassertedcausesFFstatetobe
connectedtooutputpins;otherwisethey
areleftunconnected(highimpedance)OEQ7Q6Q5Q4Q3Q2Q1Q0LDD7D6D5D4D3D2D1D0CLKRegistersSelectivelyloaded–ENorLDinputOutputenable–OEinputMultipleregisters–
group4or8inparallelRDWRA9A8A7A6A5A4A3A2A2A1A0IO3IO2IO1IO0MemoriesLargerCollectionsofStorageElementsImplementednotasFFsbutasmuchmoreefficientlatchesHigh-densitymemoriesuse1-5switches(transitors)perbitStaticRAM–1024wordseach4bitswideOncewritten,memoryholdsforever(nottruefordenserdynamicRAM)Addresslinestoselectword(10linesfor1024words)ReadenableSameasoutputenableOftencalledchipselectPermitsconnectionofmany
chipsintolargerarrayWriteenable(sameasloadenable)Bi-directionaldatalinesoutputwhenreading,inputwhenwriting1616ABSZNOperation16DataPath(ALU)ALUBlockDiagramInput:dataandoperationtoperformOutput:resultofoperationandstatusinformation16ZNOP8ACREG1616loadpathstore
pathDataMemory(16-bitwords)16OP16PCIR1616dataaddrrdwrMARControl
FSMBlockDiagramofProcessorRegisterTransferViewofPrincetonArchitectureWhichregisteroutputsareconnectedtowhichregisterinputsArrowsrepresentdata-flow,otherarecontrolsignalsfromcontrolFSMMARmaybeasimplemultiplexer
ratherthanseparateregisterMBRissplitintwo
(REGandIR)Loadcontrol
foreachregisterControl
FSM1616ZNOP16ACREG16loadpathstore
pathDataMemory(16-bitwords)1616OP16PCIR16dataaddrrdwrInstMemory(8-bitwords)dataaddrBlockDiagramofProcessorRegistertransferviewofHarvardarchitectureWhichregisteroutputsareconnectedtowhichregisterinputsArrowsrepresentdata-flow,otherarecontrolsignalsfromcontrolFSMTwoMARs(PCandIR)TwoMBRs(REGandIR)LoadcontrolforeachregisterASimplifiedProcessorData-pathandMemoryPrincetonarchitectureRegisterfileInstructionregisterPCincremented
throughALUModeledafter
MIPSrt000
(usedin61C
textbookby
Patterson&
Hennessy)Reallya32bit
machineWe’lldoa16bit
versionmemoryhasonly255words
withadisplayonthelastoneReviewofFSMTimingstep1step2step3fetchdecodeexecuteIR
mem[PC];PC
PC+1;rd
A+B
A
rsB
rttoconfigurethedata-pathtodothishere,whendowesetthecontrolsignals?FSMControllerforCPUNowweneedtorepeatthisforalltheinstructionsofourprocessorFetchanddecodestatesstaythesameDifferentexecutionstatesforeachinstructionSomemayrequiremultiplestatesifavailableregistertransferpathsrequiresequencingofstepsAlternativeWaystoImplementProcessorFSMs"RandomLogic"basedonMooreandMealyDesignClassicalFiniteStateMachineDesignDivideandConquerApproach:Time-StateMethodPartitionFSMintomultiplecommunicatingFSMsExploitLogicBlockFunctionality:JumpCountersCounters,Multiplexers,DecodersMicroprogramming:ROM-basedmethodsDirectencodingofnextstatesandoutputs74LS181Computers2610.3微处理器设计示例EC-1指令集-1五个8bits指令Opcode=3bits,000,001和010三个编码没有定义,nop271)指令INA输入一个8比特的数值,并存储到累加器A中;2)指令OUTA将累加器A中的数值拷贝到输出端口;3)指令DECA把累加器A中的数值减1后再存入到累加器A中;4)指令JNZ(JumpNotZero)测试A中的数值是否为0,假如为0,这个指令什么也不做,假如不为0,则将指令中的后四位,即aaaa(表示跳转地址)加载到寄存器PC中;5)指令HALT通过使CPU停止在halt状态从而停止微处理器的运行,直到系统复位跳出halt状态。数据通路-1指令集中操作的数据通路(1)执行指令周期中的取指操作,并递增PC值或者加载新的PC值;(2)存储器;(3)实现指令集中所有指令的操作。28数据通路-1一个PC寄存器,4比特,+递增单元一个IR寄存器,8比特一个具有16个存储单元的8位程序存储器一个8比特的累加器A,+递减单元指令INA,累加器A的输入来自于数据输入端口;指令DECA,累加器A的输入来自于递减单元的输出;指令OUTA,无需特别的数据通路的操作,累加器的输出直接连接到数据输出端口;指令JNZA,需要一个8比特的OR门连接到累加器的所有输出上,来测试条件A是否不等于0。IR寄存器的低4位数据加载到PC寄存器中;指令HALT,不需要任何额外的操作。29控制信号数据通路中的控制字主要有5个即IRload,PCload,INmux,Aload和JNZmux。给控制单元提供一个状态反馈信号Aneq030我们的设计中,为了保持设计的简洁,我们把程序存储器跟CPU一起设计在数据通路中了控制单元-1控制单元的状态图状态START(000)作为初始复位状态指令JNZA需要额外的时钟周期完成PC加载新地址在下一个时钟沿发生在FETCH状态控制IRload信号有效,将PC寄存器指向的程序加载到IR寄存器,然后PC寄存器中的内容递增1后,信号PCload将新PC加载到PC寄存器中。在DECODE状态测试IR寄存器的高三位,即IR_7-5解码,跳转到对应的状态。31五个指令的执行状态指令INA操作设置INmux信号为1来选择输入信号为外部端口,设置Aload信号为1来加载输入信号到累加器A。注意,为了输入指令能够读取到正确的输入值,输入数据需要在微处理器复位之前就设置好。而且,由于INPUT状态不需要等待一个类似于回车键的信号,因此,即使有多个数据输入,也只能有一个数据会被读入进来。指令DECA需要设置INmux信号为0、Aload信号为1,以使递减单元的输出被连接到累加器并加载进来。指令JNZ使JNZmux信号有效以将IR寄存器中的低4位地址信号加载到PC寄存器。状态反馈信号Aneq0=1时,控制信号PCload信号被设置为有效。到HALT状态将会无条件的停留在HALT状态微处理器看上去像停止操作一样。32状态图次态表、实现表,激励方程33状态控制输出表、输出方程34控制单元完整控制电路35完整电路-1数据通路电路与控制单元电路信号连接36示例汇编程序-1测试程序输入一个数据,将此数据进行递减直至0。手工编译37指令JNZ,最右边4位表示当检测条件为真时程序跳转的地址。假设第一个指令INA存储在程序存储器的地址为0000,指令JNZ将跳转到第二个指令OUTA(在程序存储器中的地址是0001)JNZ指令的最后四位操作数被设置为0001。由于指令JNZ的操作码为110,所以综合起来指令JNZ完整的编码是11000001。程序必须在数据通路和微处理器实现之前,加载到存储器中去硬件电路实现-1完整的计算机微处理器,存储器、输入和输出设备。八个拨码开关作为输入设备,2个七段数码管作为输出设备。一个LED来显示是否已经结束工作,一个按钮作为复位按钮。较高频率(如25MHz)的时钟分频后变成4Hz,作为微处理器的时钟。38指令集扩展---EC-2微处理器指令集-28个指令,仍是8位39指令LOAD指令把存储器特定地址中的内容赋给累加器A,地址是由指令的低5位表示。STORE指令把A中存储的内容赋给存储器特定地址单元。ADD和SUB指令分别表示把A的内容和存储器特定地址的内容相加、相减,并把其结果再赋给A。IN指令输入一个值并存入A。JZ指令如果A=0则把特定地址赋给PC。把新地址赋给PC会导致微处理器跳转到存储器这个新地址继续执行程序。JPOS表示如果A是正数则把A中的内容作为特定地址赋给PC。因为A是用补码表示,所以如果A的最高位为0时,则A是正数。HALT指令使得微处理器停止运行。40数据通路-2执行指令周期操作和实现所有指令操作41PC和递增单元的位宽:需要有32个位置的存储器,因此地址、PC和递增单元的位宽均为为5比特。在PC的输出和存储器地址的输入之间的加入了一个2选1多路选择器。多路选择器的一个输入来自于PC,另一个输入则来自IR的低四位,IR4-0。操作数指令:LOAD、STORE、ADD、SUB多路选择器的一个输入来自于PC,另一个输入则来自IR的低5位,IR4-0。
用地址作为操作数。它们的存储器地址是由IR的低五位给定的。2选1多路选择器的选通信号是Meminst。存储器大小增加到32个位置,因此需要5比特位宽LOAD&STORE指令:为了把数据从存储器中读出,也能把A的值赋给特定地址存储器,需要用一个RAM来代替之前的ROM。为了实现STORE操作,把A的输出与存储器的数据输入D7-0相连。当信号MemWr有效时,则把A的值写入内存的指令地址。存储器的输出Q7-0与累加器A的相连是为了执行LOAD的指令,通过4选1多路选择器加-减单元为了执行ADD和SUB指令多路选择器的选通信号为Asel1-0,第四个多路选择端没有使用42反馈信号两个条件跳转指令JZ和JPOS数据通路提供给状态机两个反馈信号,Aeq0和Apos。如果A的值是0,则Aeq信号输出为1,故只需一个8输入NOR门。如果A的值是正数,则Apos为1,因为A是补码表示,首位为0表示正数,首位为1表示负数,所以Apos只须等于A7的取反信号。数据通路有八个控制信号
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 教育公司聘用合同范例
- 天津滨海职业学院《基础化学实验Ⅰ》2023-2024学年第一学期期末试卷
- 施工合同范例 投料试车
- 电站工程合同范例
- 幼儿游泳培训合同范例
- 打板合同范例
- 电子商务交易合同范例
- 厦门保结合同范例
- 劳务公司分包合同范例
- 梅赛德斯租赁合同范例
- 2024版首诊负责制度课件
- 新西兰饮食文化英文介绍课件
- 改沟改渠施工方案
- DB11T 2081-2023 道路工程混凝土结构表层渗透防护技术规范
- 贵州省贵阳市2023-2024学年高一上学期期末考试 物理 含解析
- 2024年问政山东拆迁协议书模板
- 我的教育故事
- 山东省青岛市2023-2024学年高一年级上册1月期末选科测试 生物 含解析
- 电工技术(第3版)表格式教案教学详案设计
- 中学教职工安全知识测试练习试题
- 2024年青岛市技师学院招考聘用48人高频500题难、易错点模拟试题附带答案详解
评论
0/150
提交评论