版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
-.z?微机原理与接口技术?复习参考资料概述一、计算机中的数制1、无符号数的表示方法:〔1〕十进制计数的表示法特点:以十为底,逢十进一;共有0-9十个数字符号。〔2〕二进制计数表示方法:特点:以2为底,逢2进位;只有0和1两个符号。〔3〕十六进制数的表示法:特点:以16为底,逢16进位;有0--9及A—F〔表示10~15〕共16个数字符号。2、各种数制之间的转换〔1〕非十进制数到十进制数的转换按相应进位计数制的权表达式展开,再按十进制求和。〔见书本1.2.3,1.2.4〕〔2〕十进制数制转换为二进制数制十进制→二进制的转换:整数局部:除2取余;小数局部:乘2取整。十进制→十六进制的转换:整数局部:除16取余;小数局部:乘16取整。以小数点为起点求得整数和小数的各个位。〔3〕二进制与十六进制数之间的转换用4位二进制数表示1位十六进制数3、无符号数二进制的运算〔见教材P5〕4、二进制数的逻辑运算特点:按位运算,无进借位〔1〕与运算只有A、B变量皆为1时,与运算的结果就是1〔2〕或运算A、B变量中,只要有一个为1,或运算的结果就是1〔3〕非运算〔4〕异或运算A、B两个变量只要不同,异或运算的结果就是1二、计算机中的码制1、对于符号数,机器数常用的表示方法有原码、反码和补码三种。数*的原码记作[*]原,反码记作[*]反,补码记作[*]补。注意:对正数,三种表示法均一样。它们的差异在于对负数的表示。〔1〕原码定义:符号位:0表示正,1表示负;数值位:真值的绝对值。注意:数0的原码不唯一〔2〕反码定义:假设*>0,则[*]反=[*]原假设*<0,则[*]反=对应原码的符号位不变,数值局部按位求反注意:数0的反码也不唯一〔3〕补码定义:假设*>0,则[*]补=[*]反=[*]原假设*<0,则[*]补=[*]反+1注意:机器字长为8时,数0的补码唯一,同为000000002、8位二进制的表示围:原码:-127~+127反码:-127~+127补码:-128~+1273、特殊数10000000该数在原码中定义为:-0在反码中定义为:-127在补码中定义为:-128对无符号数:(10000000)2=128三、信息的编码十进制数的二进制数编码用4位二进制数表示一位十进制数。有两种表示法:压缩BCD码和非压缩BCD码。〔1〕压缩BCD码的每一位用4位二进制表示,0000~1001表示0~9,一个字节表示两位十进制数。〔2〕非压缩BCD码用一个字节表示一位十进制数,高4位总是0000,低4位的0000~1001表示0~9字符的编码计算机采用7位二进制代码对字符进展编码〔1〕数字0~9的编码是0110000~0111001,它们的高3位均是011,后4位正好与其对应的二进制代码〔BCD码〕相符。〔2〕英文字母A~Z的ASCII码从1000001〔41H〕开场顺序递增,字母a~z的ASCII码从1100001〔61H〕开场顺序递增,这样的排列对信息检索十分有利。微机组成原理第一节、微机的构造1、计算机的经典构造——.诺依曼构造〔1〕计算机由运算器、控制器、输入设备和输出设备五大局部组成〔运算器和控制器又称为CPU〕〔2〕数据和程序以二进制代码形式不加区分地存放在存储器总,存放位置由地址指定,数制为二进制。〔3〕控制器是根据存放在存储器中的指令序列来操作的,并由一个程序计数器控制指令的执行。系统总线的分类〔1〕数据总线〔DataBus〕,它决定了处理器的字长。〔2〕地址总线〔AddressBus〕,它决定系统所能直接的存储器空间的容量。〔3〕控制总线〔ControlBus〕第二节、8086微处理器1、8086是一种单片微处理芯片,其部数据总线的宽度是16位,外部数据总线宽度也是16位,片包含有控制计算机所有功能的各种电路。8086地址总线的宽度为20位,有1MB〔220〕寻址空间。8086CPU由总线接口部件BIU和执行部件EU组成。BIU和EU的操作是异步的,为8086取指令和执行指令的并行操作体统硬件支持。8086处理器的启动4、存放器构造8086微处理器包含有13个16位的存放器和9位标志位。4个通用存放器〔A*,B*,C*,D*〕4个段存放器〔CS,DS,SS,ES〕4个指针和变址存放器〔SP,BP,SI,DI〕指令指针〔IP〕1〕、通用存放器〔1〕8086含4个16位数据存放器,它们又可分为8个8位存放器,即:A*AH,ALB*BH,BLC*CH,CLD*DH,DL常用来存放参与运算的操作数或运算结果〔2〕数据存放器特有的习惯用法A*:累加器。多用于存放中间运算结果。所有I/O指令必须都通过A*与接口传送信息;B*:基址存放器。在间接寻址中用于存放基地址;C*:计数存放器。用于在循环或串操作指令中存放循环次数或重复次数;D*:数据存放器。在32位乘除法运算时,存放高16位数;在间接寻址的I/O指令中存放I/O端口地址。2〕、指针和变址存放器SP:堆栈指针存放器,其容为栈顶的偏移地址;BP:基址指针存放器,常用于在存时存放存单元的偏移地址。SI:源变址存放器DI:目标变址存放器变址存放器常用于指令的间接寻址或变址寻址。3〕、段存放器CS:代码段存放器,代码段用于存放指令代码DS:数据段存放器ES:附加段存放器,数据段和附加段用来存放操作数SS:堆栈段存放器,堆栈段用于存放返回地址,保存存放器容,传递参数4〕、指令指针〔IP〕16位指令指针存放器,其容为下一条要执行的指令的偏移地址。5〕、标志存放器〔1〕状态标志:进位标志位〔CF〕:运算结果的最高位有进位或有借位,则CF=1辅助进位标志位〔AF〕:运算结果的低四位有进位或借位,则AF=1溢出标志位〔OF〕:运算结果有溢出,则OF=1零标志位〔ZF〕:反映指令的执行是否产生一个为零的结果符号标志位〔SF〕:指出该指令的执行是否产生一个负的结果奇偶标志位〔PF〕:表示指令运算结果的低8位“1〞个数是否为偶数〔2〕控制标志位中断允许标志位〔IF〕:表示CPU是否能够响应外部可屏蔽中断请求跟踪标志〔TF〕:CPU单步执行5、8086的引脚及其功能〔重点掌握以下引脚〕AD15~AD0:双向三态的地址总线,输入/输出信号INTR:可屏蔽中断请求输入信号,高电平有效。可通过设置IF的值来控制。NMI:非屏蔽中断输入信号。不能用软件进展屏蔽。RESET:复位输入信号,高电平有效。复位的初始状态见P21MN/M*:最小最大模式输入控制信号。第三章8086指令系统8086寻址方式一、数据寻址方式1、立即寻址操作数(为一常数)直接由指令给出(此操作数称为立即数)立即寻址只能用于源操作数例:MOVA*,1C8FHMOVBYTEPTR[2A00H],8FH错误例:×MOV2A00H,A*;错误!指令操作例:MOVA*,3102H;A*3102H执行后,(AH)=31H,(AL)=02H2、存放器寻址〔1〕操作数放在*个存放器中〔2〕源操作数与目的操作数字长要一样〔3〕存放器寻址与段地址无关例:MOVA*,B*MOV[3F00H],A*MOVCL,AL错误例:×MOVA*,BL;字长不同×MOVES:A*,D*;存放器与段无关3、直接寻址〔1〕指令中直接给出操作数的16位偏移地址偏移地址也称为有效地址(EA,EffectiveAddress)〔2〕默认的段存放器为DS,但也可以显式地指定其他段存放器——称为段超越前缀〔3〕偏移地址也可用符号地址来表示,如ADDR、VAR例:MOVA*,[2A00H]MOVD*,ES:[2A00H]MOVSI,TABLE_PTR4、间接寻址操作数的偏移地址(有效地址EA)放在存放器中只有SI、DI、B*和BP可作间址存放器例:MOVA*,[B*]MOVCL,CS:[DI]错误例:×MOVA*,[D*]×MOVCL,[A*]5、存放器相对寻址EA=间址存放器的容加上一个8/16位的位移量例:MOVA*,[B*+8]MOVC*,TABLE[SI]MOVA*,[BP];默认段存放器为SS指令操作例:MOVA*,DATA[B*]假设(DS)=6000H,(B*)=1000H,DATA=2A00H,(63A00H)=66H,(63A01H)=55H则物理地址=60000H+1000H+2A00H=63A00H指令执行后:〔A*〕=5566H6、基址变址寻址假设操作数的偏移地址:由基址存放器(B*或BP)给出——基址寻址方式由变址存放器(SI或DI)给出——变址寻址方式由一个基址存放器的容和一个变址存放器的容相加而形成操作数的偏移地址,称为基址-变址寻址。EA=〔B*〕+〔SI〕或〔DI〕;EA=〔BP〕+〔SI〕或〔DI〕同一组的存放器不能同时出现。注意:除了有段跨越前缀的情况外,当基址存放器为B*时,操作数应该存放在数据段DS中,当基址存放器为BP时,操作数应放在堆栈段SS中。例:MOVA*,[B*][SI]MOVA*,[B*+SI]MOVA*,DS:[BP][DI]错误例:×MOVA*,[B*][BP]×MOVA*,[DI][SI]指令操作例:MOVA*,[B*][SI]假定:(DS)=8000H,(B*)=2000H,SI=1000H则物理地址=80000H+2000H+1000H=83000H指令执行后:(AL)=[83000H](AH)=[83001H]7、相对基址变址寻址在基址-变址寻址的根底上再加上一个相对位移量EA=〔B*〕+〔SI〕或〔DI〕+8位或16位位移量;EA=〔BP〕+〔SI〕或〔DI〕+8位或16位位移量指令操作例:MOVA*,DATA[DI][B*]假设(DS)=8000H,(B*)=2000H,(DI)=1000H,DATA=200H则指令执行后(AH)=[83021H],(AL)=[83020H]存放器间接、存放器相对、基址变址、相对基址变址四种寻址方式的比拟:寻址方式指令操作数形式存放器间接只有一个存放器〔B*/BP/SI/DI之一〕存放器相对一个存放器加上位移量基址—变址两个不同类别的存放器相对基址-变址两个不同类别的存放器加上位移量二、地址寻址方式〔了解有4类,能判断〕简要判断依据〔指令中间的单词〕:段直接short,near段间接word段间直接far段间间接dword8086指令系统一、数据传送指令1、通用传送指令(1)MOVdest,src;dest←src传送的是字节还是字取决于指令中涉及的存放器是8位还是16位。具体来说可实现:MOVmem/reg1,mem/reg2指令中两操作数中至少有一个为存放器②MOVreg,data;立即数送存放器③MOVmem,data;立即数送存储单元④MOVacc,mem;存储单元送累加器⑤MOVmem,acc;累加器送存储单元⑥MOVsegreg,mem/reg;存储单元/存放器送段存放器⑦MOVmem/reg,segreg;段存放器送存储单元/存放器MOV指令的使用规则①IP不能作目的存放器②不允许mem←mem③不允许segreg←segreg④立即数不允许作为目的操作数⑤不允许segreg←立即数⑥源操作数与目的操作数类型要一致⑦当源操作数为单字节的立即数,而目的操作数为间址、变址、基址+变址的存数时,必须用PTR说明数据类型。如:MOV[B*],12H是错误的。〔2〕、堆栈指令什么是堆栈.按“后进先出(LIFO)〞方式工作的存储区域。堆栈以字为单位进展压入弹出操作。规定由SS指示堆栈段的段基址,堆栈指针SP始终指向堆栈的顶部,SP的初值规定了所用堆栈区的大小。堆栈的最高地址叫栈底。压栈指令PUSHPUSHsrc ;src为16位操作数例:PUSH A* ;将A*容压栈执行操作:〔SP〕-1←高字节AH〔SP〕-2←低字节AL(SP)←〔SP〕-2注意进栈方向是高地址向低地址开展。`弹出指令POPPOP dest例:POP B* ;将栈顶容弹至B*执行操作:〔BL〕←〔SP〕〔BH〕←〔SP〕+1〔SP〕←〔SP〕+2堆栈指令在使用时需注意的几点:堆栈操作总是按字进展不能从栈顶弹出一个字给CS堆栈指针为SS:SP,SP永远指向栈顶④SP自动进展增减量〔-2,+2〕〔3〕、交换指令*CHG格式:*CHGreg,mem/reg功能:交换两操作数的容。要求:两操作数中必须有一个在存放器中;操作数不能为段存放器和立即数;源和目地操作数类型要一致。举例:*CHG A*,B**CHG [2000],CL〔4〕查表指令*LAT执行的操作:AL←[(B*)+(AL)]又叫查表转换指令,它可根据表项序号查出表中对应代码的容。执行时先将表的首地址〔偏移地址〕送到B*中,表项序号存于AL中。2、输入输出指令只限于用累加器AL或A*来传送信息。功能:(累加器)←→I/O端口输入指令IN格式:INacc,PORT;PORT端口号0~255HINacc,D*;D*表示的端口围达64K例:INAL,80H;(AL)←(80H端口)INAL,D*;(AL)←((D*))(2)输出指令OUT格式:OUTport,accOUTD*,acc例:OUT68H,A*;(69H,68H)←〔A*〕OUTD*,AL;((D*))←(AL)在使用间接寻址的IN/OUT指令时,要事先用传送指令把I/O端口号设置到D*存放器如:MOVD*,220HINAL,D*;将220H端口容读入AL3、目标地址传送指令LEA传送偏移地址格式:LEAreg,mem;将指定存单元的偏移地址送到指定存放器要求:源操作数必须是一个存储器操作数;目的操作数必须是一个16位的通用存放器。例:LEA B*,[SI+10H]设:〔SI〕=1000H则执行该指令后,〔B*〕=1010H注意以下二条指令差异:LEAB*,BUFFERMOVB*,BUFFER前者表示将符号地址为BUFFER的存储单元的偏移地址取到B*中;后者表示将BUFFER存储单元中的容取到B*中。下面两条指令等效:LEAB*,BUFFERMOVB*,OFFSETBUFFER其中OFFSETBUFFER表示存储器单元BUFFER的偏移地址。二者都可用于取存储器单元的偏移地址,但LEA指令可以取动态的地址,OFFSET只能取静态的地址。二、算术运算指令加法指令不带进位的加法指令ADD格式:ADD acc,dataADD mem/reg,dataADDmem/reg1,mem/reg2实例:ADD AL,30HADD SI,[B*+20H]ADD C*,SIADD [DI],200H•ADD指令对6个状态标志均产生影响。例:(B*)=D75FH指令ADDB*,8046H执行后,状态标志各是多少.D75FH=11100111010111118046H=10000000010001101111110110011110100101结果:C=1,Z=0,P=0,A=1,O=1,S=0判断溢出与进位从硬件的角度:默认参与运算的操作数都是有符号数,当两数的符号位一样,而和的结果相异时有溢出,则OF=1,否则OF=0带进位的加法ADCADC指令在形式上和功能上与ADD类似,只是相加时还要包括进位标志CF的容,例如:ADCAL,68H;AL←(AL)+68H+(CF)ADCA*,C*;A*←(A*)+(C*)+(CF)ADCB*,[DI];B*←(B*)+[DI+1][DI]+(CF)〔3〕加1指令INC格式:INCreg/mem功能:类似于C语言中的++操作:对指定的操作数加1例:INCALINCSIINCBYTEPTR[B*+4]注:本指令不影响CF标志。〔4〕非压缩BCD码加法调整指令AAAAAA指令的操作:如果AL的低4位>9或AF=1,则:①AL←(AL)+6,(AH)←(AH)+1,AF←1②AL高4位清零③CF←AF否则AL高4位清零〔5〕压缩BCD码加法调整指令DAA两个压缩BCD码相加结果在AL中,通过DAA调整得到一个正确的压缩BCD码.指令操作(调整方法):假设AL的低4位>9或AF=1则(AL)←(AL)+6,AF←1假设AL的高4位>9或CF=1则(AL)←(AL)+60H,CF←1除OF外,DAA指令影响所有其它标志。DAA指令应紧跟在ADD或ADC指令之后。减法指令〔1〕不考虑借位的减法指令SUB格式:SUBdest,src操作:dest←(dest)-(src)注:1.源和目的操作数不能同时为存储器操作数2.立即数不能作为目的操作数指令例子:SUBAL,60HSUB[B*+20H],D*SUBA*,C*〔2〕考虑借位的减法指令SBBSBB指令主要用于多字节的减法。格式:SBBdest,src操作:dest←(dest)-(src)-(CF)指令例子:SBBA*,C*SBBWORDPTR[SI],2080HSBB[SI],D*〔3〕减1指令DEC作用类似于C语言中的〞--〞操作符。格式:DECopr操作:opr←(opr)-1指令例子:DECCLDECBYTEPTR[DI+2]DECSI〔4〕求补指令NEG格式:NEGopr操作:opr←0-(opr)对一个操作数取补码相当于用0减去此操作数,故利用NEG指令可得到负数的绝对值。例:假设(AL)=0FCH,则执行NEGAL后,(AL)=04H,CF=1〔5〕比拟指令CMP格式:CMPdest,src操作:(dest)-(src)CMP也是执行两个操作数相减,但结果不送目标操作数,其结果只反映在标志位上。指令例子:CMPAL,0AHCMPC*,SICMPDI,[B*+03]〔6〕非压缩BCD码减法调整指令AAS对AL中由两个非压缩的BCD码相减的结果进展调整。调整操作为:假设AL的低4位>9或AF=1,则:①AL←(AL)-6,AH←(AH)-1,AF←1②AL的高4位清零③CF←AF否则:AL的高4位清零〔7〕压缩BCD码减法调整指令DAS对AL中由两个压缩BCD码相减的结果进展调整。调整操作为:假设AL的低4位>9或AF=1,则:AL←(AL)-6,且AF←1假设AL的高4位>9或CF=1,则:AL←(AL)-60H,且CF←1DAS对OF无定义,但影响其余标志位。DAS指令要求跟在减法指令之后。乘法指令进展乘法时:8位*8位→16位乘积16位*16位→32位乘积(1)无符号数的乘法指令MUL(MEM/REG)格式:MULsrc操作:字节操作数(A*)←(AL)×(src)字操作数(D*,A*)←(A*)×(src)指令例子:MULBL;(AL)×(BL),乘积在A*中MULC*;(A*)×(C*),乘积在D*,A*中MULBYTEPTR[B*]〔2〕有符号数乘法指令IMUL格式与MUL指令类似,只是要求两操作数均为有符号数。指令例子:IMULBL;(A*)←(AL)×(BL)IMULWORDPTR[SI];(D*,A*)←(A*)×([SI+1][SI])注意:MUL/IMUL指令中●AL(A*)为隐含的乘数存放器;●A*(D*,A*)为隐含的乘积存放器;●SRC不能为立即数;●除CF和OF外,对其它标志位无定义。4、除法指令进展除法时:16位/8位→8位商32位/16位→16位商对被除数、商及余数存放有如下规定:被除数商余数字节除法A*ALAH字除法D*:A*A*D*〔1〕无符号数除法指令DIV格式:DIVsrc操作:字节操作(AL)←(A*)/(SRC)的商(AH)←(A*)/(SRC)的余数字操作(A*)←(D*,A*)/(SRC)的商(D*)←(D*,A*)/(SRC)的余数指令例子:DIVCLDIVWORDPTR[B*]〔2〕有符号数除法指令IDIV格式:IDIVsrc操作与DIV类似。商及余数均为有符号数,且余数符号总是与被除数符号一样。注意:对于DIV/IDIV指令A*(D*,A*)为隐含的被除数存放器。AL(A*)为隐含的商存放器。AH(D*)为隐含的余数存放器。src不能为立即数。对所有条件标志位均无定关于除法操作中的字长扩展问题•除法运算要求被除数字长是除数字长的两倍,假设不满足则需对被除数进展扩展,否则产生错误。•对于无符号数除法扩展,只需将AH或D*清零即可。•对有符号数而言,则是符号位的扩展。可使用前面介绍过的符号扩展指令CBW和CWD三、逻辑运算和移位指令1、逻辑运算指令〔1〕逻辑与AND对两个操作数进展按位逻辑“与〞操作。格式:ANDdest,src用途:保存操作数的*几位,清零其他位。例1:保存AL中低4位,高4位清0。ANDAL,0FH〔2〕逻辑或OR对两个操作数进展按位逻辑〞或〞操作。格式:ORdest,src用途:对操作数的*几位置1;对两操作数进展组合。例1:把AL中的非压缩BCD码变成相应十进制数的ASCII码。ORAL,30H〔3〕逻辑非NOT对操作数进展按位逻辑〞非〞操作。格式:NOTmem/reg例:NOTC*NOTBYTEPTR[DI]〔4〕逻辑异或*OR对两个操作数按位进展〞异或〞操作。格式:*ORdest,src用途:对reg清零(自身异或)把reg/mem的*几位变反(与’1’异或)例1:把A*存放器清零。①MOVA*,0②*ORA*,A*③ANDA*,0④SUBA*,A*〔5〕测试指令TEST操作与AND指令类似,但不将〞与〞的结果送回,只影响标志位。TEST指令常用于位测试,与条件转移指令一起用。例:测试AL的容是否为负数。TESTAL,80H;检查AL中D7=1.JNZMINUS;是1(负数),转MINUS……;否则为正数2、移位指令(1)非循环移位指令算术左移指令SAL(ShiftArithmeticLeft)算术右移指令SAR(ShiftArithmeticRight)逻辑左移指令SHL(ShiftLeft)逻辑右移指令SHR(ShiftRight)这4条指令的格式一样,以SAL为例:CL;移位位数大于1时SALmem/reg;移位位数等于1时算术移位——把操作数看做有符号数;逻辑移位——把操作数看做无符号数。移位位数放在CL存放器中,如果只移1位,也可以直接写在指令中。例如: MOVCL,4 SHRAL,CL;AL中的容右移4位影响C,P,S,Z,O标志。结果未溢出时:左移1位≡操作数*2右移1位≡操作数/2例:把AL中的数*乘10因为10=8+2=23+21,所以可用移位实现乘10操作。程序如下: MOVCL,3 SALAL,1;2*MOVAH,AL SALAL,1;4*SALAL,1;8*ADDAL,AH;8*+2*=10*四、控制转移指令转移指令〔1〕无条件转移指令JMP格式:JMPlabel本指令无条件转移到指定的目标地址,以执行从该地址开场的程序段。〔2〕条件转移指令〔补充容〕①根据单个标志位设置的条件转移指令/JC;低于,或CF=1,则转移JNB/JNC/JAE;高于或等于,或CF=0,则转移JP/JPE;奇偶标志PF=1(偶),则转移JNP/JPO;奇偶标志PF=0(奇),则转移JZ/JE;结果为零(ZF=1),则转移JNZ/JNE;结果不为零(ZF=0),则转移JS;SF=1,则转移JNS;SF=0,则转移JO ;OF=1,则转移JNO ;OF=0,则转移②根据组合条件设置的条件转移指令这类指令主要用来判断两个数的大小。*判断无符号数的大小JA高于则转移条件为:CF=0∧ZF=0,即A>BJNA/E低于或等于则转移条件为:CF=1∨ZF=1,即A≤BA<B则转移JNBA≥B则转移*判断有符号数的大小JG;大于则转移(A>B)条件为:(SF⊕OF=0)∧ZF=0JGE;大于或等于则转移(A≥B)条件为:(SF⊕OF=0)∨ZF=1JLE;小于或等于则转移(A≤B)条件为:(SF⊕OF=1)∨ZF=1JL;小于则转移(A<B=条件为:(SF⊕OF=1)∧ZF=02、循环控制指令用在循环程序中以确定是否要继续循环。循环次数通常置于C*中。转移的目标应在距离本指令-128~+127的围之。循环控制指令不影响标志位。(1)LOOP格式:LOOPlabel操作:(C*)-1→C*;假设(C*)≠0,则转至label处执行;否则退出循环,执行LOOP后面的指令。LOOP指令与下面的指令段等价: DECC* JNZlabel3、过程调用指令〔1〕调用指令CALL一般格式:CALLsub;sub为子程序的入口4、中断指令(1)INTn执行类型n的中断效劳程序,N=0~255五、处理器控制指令1、标志位操作〔1〕CF设置指令CLC0→CFSTC1→CFCMCCF变反〔2〕DF设置指令CLD0→DF(串操作的指针移动方向从低到高)STD1→DF(串操作的指针移动方向从高到低)〔3〕IF设置指令CLI0→IF(制止INTR中断)STI1→IF(开放INTR中断)HLT〔halt〕执行HLT指令后,CPU进入暂停状态。第四章8086汇编语言程序设计伪指令CPU指令与伪指令之间的区别:(1)CPU指令是给CPU的命令,在运行时由CPU执行,每条指令对应CPU的一种特定的操作。而伪指令是给汇编程序的命令,在汇编过程中由汇编程序进展处理。(2)汇编以后,每条CPU指令产生一一对应的目标代码;而伪指令则不产生与之相应的目标代码。1、数据定义伪指令〔1〕数据定义伪指令的一般格式为:[变量名]伪指令操作数[,操作数…]DB 用来定义字节〔BYTE〕DW 用来定义字〔WORD〕DD 用来定义双字〔DWORD〕〔2〕操作数的类型可以是:①常数或常数表达式例如:DATA_BYTEDB10,5,10HDATA_WORDDW100H,100,-4DATA_DWDD2*30,0FFFBH②可以为字符串〔定义字符串最好使用DB〕例如:char1DB‘AB’③可以为变量④可以为.号操作符例如:*DB5,.,6.号只是为了给变量保存相应的存储单元,而不赋予变量*个确定的初值。⑤重复次数:NDUP〔初值[,初值…]〕例如:ZERODB2DUP〔3,5〕*YZDB2DUP〔0,2DUP〔1,3〕,5〕⑥在伪操作的操作数字段中假设使用$,则表示的是地址计数器的当前值。2、补充容:〔1〕类型PTR地址表达式例如:MOVBYTEPTR[B*],12HINCBYTEPTR[B*]注意:单操作数指令,当操作数为基址、变址、基+变的时候必须定义3、符号定义伪指令(1)EQU格式:名字EQU表达式EQU伪指令将表达式的值赋予一个名字,以后可用这个名字来代替上述表达式。例:CONSTANTEQU100NEW_PORTEQUPORT_VAL+1(2)=〔等号〕与EQU类似,但允许重新定义例:┇ EMP=7 ;值为7┇ EMP=EMP+1 ;值为8(3)LABELLABEL伪指令的用途是定义标号或变量的类型格式:名字LABEL类型变量的类型可以是BYTE,WORD,DWORD。标号的类型可以是NEAR或FAR4、段定义伪指令与段有关的伪指令有:SEGMENT、ENDS、ASSUME、ORG〔1〕段定义伪指令的格式如下:段名SEGMENT[定位类型][组合类型][’类别’]┇段名ENDSSEGMENT和ENDS这两个伪指令总是成对出现,二者前面的段名一致。二者之间的删节局部,对数据段、附加段及堆栈段,一般是符号、变量定义等伪指令。对于代码段则是指令及伪指令。此外,还必须明确段和段存放器的关系,这可由ASSUME语句来实现。〔2〕ASSUME格式:ASSUME段存放器名:段名[,段存放器名:段名[,…]]ASSUME伪指令告诉汇编程序,将*一个段存放器设置为*一个逻辑段址,即明确指出源程序中逻辑段与物理段之间的关系。〔3〕ORG伪指令ORG规定了段的起始地址或偏移地址,其格式为:ORG <表达式>表达式的值即为段的起始地址或偏移地址,从此地址起连续存放程序或数据。5、汇编程序的一般构造〔记住〕DATASEGMENT…DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATABGN:MOVA*,DATAMOVDS,A*….MOVAH,4CHINT21HCODEENDSENDBGN第三节程序设计顺序程序的设计〔略〕分支程序的设计典型例题:1*>0Y=0*=0-1*<0程序为:MOVAL,*CMPAL,0JGEBIGMOVY,-1JMPE*ITBIG:JEEQULMOVY,1JMPE*ITEQUL:MOVY,0E*IT:….循环程序见讲义。用计数控制循环第一章计算机根底知识本章的主要容为不同进位计数制计数方法、不同进位制数之间相互转换的方法、数和字符在计算机中的表示方法、简单的算术运算以及计算机系统的组成。下边将本章的知识点作了归类,图1为本章的知识要点图,图1.2为计算机系统组成的示意图。本章知识要点本章知识要点数制二进制数(B)八进制数(Q)十六进制数(H)十进制数(D)B)码制带符号数编码奇偶校验码字符编码原码反码补码奇校验码偶校验码ASCII码BCD码数字编码规则字母编码规则压缩BCD码非压缩BCD码计算机系统组成计算机系统组成硬件主机外部设备中央处理器(CPU)半导体存储器控制器运算器ROMRAM输入设备输出设备软件系统软件应用软件操作系统:如DOS、Windows、Uni*、Linu*等其他系统软件用户应用软件其他应用软件各种计算机语言处理软件:如汇编、解释、编译等软件8086微处理器本章要从应用角度上理解8086CPU的部组成、编程构造、引脚信号功能、最小工作模式的系统配置、8086的存储器组织、根本时序等概念。下面这一章知识的构造图。本章知识要点本章知识要点Intel8086微处理器时钟发生器〔8284〕地址锁存器〔74LS373、8282〕存储器组织存储器逻辑分段存储器分体三总线(DB、AB、CB)时序时钟周期(T状态)根本读总线周期系统配置〔最小模式〕8086CPU数据收发器(8286、74LS245)逻辑地址物理地址奇地址存储体〔BHE〕偶地址存储体〔A0〕总线周期指令周期根本写总线周期复位操作时序中断响应时序存放器的复位值执行单元EU〔A*、B*、C*、D*、SP、BP、SI、DI、标志存放器〕执行单元EU〔A*、B*、C*、D*、SP、BP、SI、DI、标志存放器〕内部组成内部组成总线接口单元BIU〔CS、DS、SS、ES、IP〕总线接口单元BIU〔CS、DS、SS、ES、IP〕地址/数据地址/数据控制负责地址BHE/S7、ALE引脚功能〔最小模式〕地址/状态数据允许和收发DEN、DT/R负责读写RD、WR、M/IO负责中断INTR、NMI、INTA负责总线HOLD、HLDA协调CLK、READY、TEST模式选择MN/M*=5V8086的指令系统本章重点是8086CPU指令的寻址方式,每条指令的格式、功能及标志的影响;同时还涉及到存储器单元的物理地址计算、标志位填写和堆栈操作。下列图为本章知识构造图。立即数寻址、存放器寻址、存储器寻址……立即数寻址、存放器寻址、存储器寻址…….操作数寻址方式本章知识要点逻辑地址、物理地址本章知识要点逻辑地址、物理地址指令功能指令格式指令功能指令格式对标志位影响对标志位影响填写标志位填写标志位堆栈操作〔入栈、出栈〕堆栈指针(SP)堆栈构造(后进先出)堆栈操作〔入栈、出栈〕堆栈指针(SP)堆栈构造(后进先出)直接寻址立即数寻址直接寻址立即数寻址存放器间接寻址存放器寻址存放器间接寻址存放器寻址存放器相对寻址存储器寻址寻址方式存放器相对寻址存储器寻址寻址方式基址变址寻址基址变址寻址串操作寻址串操作寻址相对基址变址寻址I/O端口寻址相对基址变址寻址I/O端口寻址隐含寻址隐含寻址指令功能指令功能数据传送类〔通用数据传送指令、堆栈指令、交换指令、I/O传送指令、换码指令、有效地址传送指令、标志存放器传送指令〕算术运算类指令〔加法指令,减法指令,乘法指令,除法指令,BCD码调整指令〕逻辑类指令〔逻辑运算指令、逻辑移位操作指令〕串操作类指令〔串传送、比拟、扫描、串存和取指令〕控制转移类指令〔条件和无条件转移、子程序调用和返回指令、子程序调用和返回、中断〕、〕处理器控制类指令其他应用软件用户应用软件应用软件其他应用软件用户应用软件应用软件第四章汇编语言程序设计本章主要容是汇编语言类别、伪指令语句格式和作用、根本程序构造、调用程序和被调用程序之间数据传递途径以及汇编源程序上机调试过程。本章重点是阅读程序和编写程序。下边是本章的知识构造图。汇编语言语句类别汇编语言语句类别程序根本构造顺序构造本章知识要点实指令语句分支构造循环构造过程〔子程序〕伪指令语句宏指令语句参数传递途径存放器约定存储器约定堆栈传递程序开发步骤:编辑汇编链接调试运行符号定义伪指令EQU、=符号定义伪指令EQU、=伪指令语句数据定义伪指令DB、DW、DD……段定义伪指令SEGMENT……ENDS过程定义伪指令PROC、ENDP段指派伪指令ASSUME程序定位伪指令ORG汇编完毕伪指令END其他伪指令…….第五章半导体存储器半导体存储器是用半导体器件作为存储介质的存储器。本章讨论半导体存储器芯片的类型、存储原理、引脚功能、如何与CPU〔或系统总线〕连接等问题。本章知识构造图如下。只存放二进制数存放程序和数据只存放二进制数存放程序和数据SRAMSRAMRAMRAMDRAM存储器作用DRAM存储器作用本章知识要点掩模ROM半导体存储器芯片分类本章知识要点掩模ROM半导体存储器芯片分类PROMROMPROMROM线译码局部译码与系统连接地址分配、片选逻辑、控制选择全译码计算芯片数主存储器设计引脚功能存储容量存储器芯片EEROMEPROMPROM`线译码局部译码与系统连接地址分配、片选逻辑、控制选择全译码计算芯片数主存储器设计引脚功能存储容量存储器芯片EEROMEPROMPROM第六章输入输出接口本章讨论输入/输出接口的根本概念,包括输入/输出接口的作用、部构造、传送信息的分析、IO端口编址以及主机通过接口与外设之间数据传送的方式。下边是本章的知识构造图。IO接口概念IO接口概念主机通过接口与外设数据传送方式本章知识要点接口作用接口传送信息的种类IO端口数据传送方式程序控制方式控制信息状态信息数据信息〔开关量、脉冲量、数据量、模拟量〕IO端口编址方式单独编址统一编址IO端口号简单的I/O芯片的使用中断控制方式直接存储器存取控制方式(DMA)无条件传送有条件传送(查询)中断与中断控制器本章主要容:中断的根本概念、CPU响应中断的条件、中断响应过程、中断效劳程序的执行;8086/8088中断系统;可编程中断控制器8259A的引脚功能、编程构造以及工作工程。中断概念中断概念本章知识要点实现中断与返回中断请求中断优先级控制软件查询中断源中断源的中断优先级别中断判优中断响应中断效劳中断返回中断系统功能实现中断优先级控制中断优先级排队中断嵌套〔高级中断请求能中断低级中断效劳〕硬件查询〔菊花链〕可编程中断控制器(PIC)8259A的中断管理方式实现中断与返回中断屏蔽方式优先级设置方式实现中断优先级控制全嵌套方式优先级自动循环方式优先级特殊循环方式特殊全嵌套方式中断完毕方式自动EOI完毕方式普通EOI完毕方式特殊EOI完毕方式中断请求引入方式边沿触发方式电平触发方式中断查询方式第八章定时器/计数器8253及应用本章主要容是定时器/计算器的应用场合;如何实现定时/计数;可编程计数器/定时器8253芯片的部构造、引脚功能、计数原理、6种工作方式下的工作条件和输出波形特征。下边是知识要点图。软件:延时子程序软件:延时子程序硬件:数字逻辑电路定时/计数的实现下硬件:数字逻辑电路定时/计数的实现下本章知识要点采用可编程定时器/计数器本章知识要点采用可编程定时器/计数器引脚功能引脚功能通道的编程构造通道的6种工作方式可编程定时器/计数器8253通道的编程构造通道的6种工作方式可编程定时器/计数器8253芯片的使用:硬件连线、软件编程芯片的使用:硬件连线、软件编程方式0:计数完毕中断方式方式0:计数完毕中断方式方式1:可重新触发单稳态输出方式方式1:可重新触发单稳态输出方式方式2:分频器方式方式2:分频器方式方式3:方波发生器方式方式3:方波发生器方式方式4:软件选通触发方式8253的工作方式方式4:软件选通触发方式8253的工作方式方式5:硬件选通触发方式方式5:硬件选通触发方式第九章A/D和D/A转换本章重点是A/D转换的任务和转换原理,D/A转换的任务和转换原理,常用A/D转换器(ADC)集成芯片和D/A转换器(DAC)集成芯片的外部引脚功能、部构造、工作过程、性能指标以及实际应用。数字量A/D:模拟量数字量A/D:模拟量转换任务转换任务D/A:数字量模拟量D/A:数字量模拟量基准电压、权电阻解码网络基准电压、权电阻解码网络A/D基准电压、T型电阻解码网络转换原理本章知识要点A/D基准电压、T型电阻解码网络转换原理本章知识要点常用方法常用方法逐次逼近式,计数器式D/A逐次逼近式,计数器式D/A积分式,并联式积分式,并联式硬件连线:同微机系统总线的连接硬件连线:同微机系统总线的连接集成芯片使用集成芯片使用软件编程:控制转换,控制数字量传送软件编程:控制转换,控制数字量传送ADC:将CPU处理后的数字量转换为模拟量ADC:将CPU处理后的数字量转换为模拟量将CPU处理后的数字量转换为模拟量,送控制现场集成芯片应用场合将CPU处理后的数字量转换为模拟量,送控制现场集成芯片应用场合DACDAC与运算放大器一起组成各种波形发生器与运算放大器一起组成各种波形发生器如下列图所示,以8088微处理器为核心的IBMPC/*T机与DAC0832连接,实现波形发生器。IBMPC/*T机使用10根地址线A0~A9寻址I/O端口,AEN为地址允许信号,低电平时选中端口。DAC0832的参考电压VREF=-5V,VREF的围为0~5V,计算式为,其中,N是由DAC0832转换的数字量对应的十进制值。Vout的输出围是-5V~5V。根据下列图一所示的DAC0832的硬件连接,说明其工作方式。假设DAC0832端口地址为140H,请在下列图一中画出相应的译码电路。现有1ms的延时子程序DELAY,请编写程序片段实现输出右图二的所示波形。什么是中断.什么是中断向量.中断向量表的地址围.答:中断就是CPU在执行当前程序时由于外部事件引起CPU暂时停顿当前正在执行的程序而转向执行请求CPU暂时停顿的外部事件的效劳程序,该程序处理完后又返回继续执行被停顿的程序;中断向量是中断处理子程序的入口地址;地址围是00000H-003FFH。微机系统的硬件由哪几局部组成.答:微型计算机〔微处理器,存储器,I/0接口,系统总线〕,外围设备,电源。什么是微机的总线,分为哪三组.答:是传递信息的一组公用导线。分三组:地址总线,数据总线,控制总线。8086/8088CPU的部构造分为哪两大模块,各自的主要功能是什么.答:总线接口部件〔BIU〕功能:根据执行单元EU的请求完成CPU与存储器或IO设备之间的数据传送。执行部件〔EU〕,作用:从指令对列中取出指令,对指令进展译码,发出相应的传送数据或算术的控制信号承受由总线接口部件传送来的数据或把数据传送到总线接口部件进展算术运算。8086指令队列的作用是什么.答:作用是:在执行指令的同时从存中取了一条指令或下几条指令,取来的指令放在指令队列中这样它就不需要象以往的计算机那样让CPU轮番进展取指和执行的工作,从而提高CPU的利用率。8086的存储器空间最大可以为多少.怎样用16位存放器实现对20位地址的寻址.完成逻辑地址到物理地址转换的部件是什么.答:8086的存储器空间最大可以为2^20〔1MB〕;8086计算机引入了分段管理机制,当CPU寻址*个存储单元时,先将段存放器的容左移4位,然后加上指令中提供的16位偏移地址形成20位物理地址。段存放器CS=1200H,指令指针存放器IP=FF00H,此时,指令的物理地址为多少?指向这一物理地址的CS值和IP值是唯一的吗?答:指令的物理地址为21F00H;CS值和IP值不是唯一的,例如:CS=2100H,IP=0F00H。设存储器的段地址是4ABFH,物理地址为50000H,其偏移地址为多少.答:偏移地址为54100H。〔物理地址=段地址*16+偏移地址〕8086/8088CPU有哪几个状态标志位,有哪几个控制标志位.其意义各是什么.答:状态标志位有6个:ZF,SF,CF,OF,AF,PF。其意思是用来反映指令执行的特征,通常是由CPU根据指令执行结果自动设置的;控制标志位有3个:DF,IF,TF。它是由程序通过执行特定的指令来设置的,以控制指令的操作方式。8086CPU的AD0~AD15是什么引脚.答:数据与地址引脚INTR、INTA、NMI、ALE、HOLD、HLDA引脚的名称各是什么?答:INTR是可屏蔽请求信号,INTA中断响应信号,NMI是不可屏蔽中断请求信号,ALE是地址锁存允许信号,HOLD总线请求信号,HLDA总线请求响应信号。虚拟存储器有哪两局部组成.答:有主存储器和辅助存储器。在80*86中,什么是逻辑地址、线性地址、物理地址.答:线性地址是连续的不分段的地址;逻辑地址是由程序提供的地址;物理地址是存单元的实际地址。
段描述符分为哪几种.答:分为三大类,程序段描述符,系统段描述符,门描述符。RAM有几种,各有什么特点.ROM有几种,各有什么特点.答:RAM有两种,SRAM(静态RAM),它采用触发器电路构成一个二进制位信息的存储单元,这种触发器一般由6个晶体管组成,它读出采用单边读出的原理,写入采用双边写入原理;DRAM〔动态RAM〕,它集成度高,部存储单元按矩阵形式排列成存储体,通常采用行,列地址复合选择寻址法。ROM有5种,固定掩摸编程ROM,可编程PROM,紫外光檫除可编程EPROM,电可檫除的可编程EPROM,闪速存储器。假设用4K*1位的RAM芯片组成8K*8为的存储器,需要多少芯片.A19—A0地址线中哪些参与片寻址,哪些用做芯片组的片选信号.答:需要16片芯片;其中A11-A0参与片寻址;A12做芯片组的片选信号。假设系统分别使用512K*8、1K*4、16K*8、64K*1的RAM,各需要多少条地址线进展寻址,各需要多少条数据线.答:512K*8需要19条地址线,8条数据线。1K*4需要10条地址线,4条数据线。16K*8需要14条地址线,8条数据线。64K*1需要14条地址线,1条数据线。*微机系统的RAM容量为8K*8,假设首地址为4800H,则最后一个单元的地址是多少.答:最后一个单元的地址是:4800H+2^13-1什么是总线,微机中的总线通常分为哪几类.答:是一组信号线的集合,是一种在各模块间传送信息的公共通路;有四类,片总线,微处理器总线,系统总线,外总线。微处理器为什么需要用接口和外设相连接.答:因为许多接口设备中,在工作原理,驱动方式,信息格式以及工作速度方面彼此相差很大,因此为了进展速度和工作方式的匹配,并协助完成二者之间数据传送控制任务。一般的I/O接口电路有哪四种存放器,它们各自的作用是什么.答:数据输入存放器,数据输入存放器,状态存放器和控制存放器。数据端口能对传送数据提供缓冲,隔离,存放的作用;状态存放器用来保存外设或接口的状态;控制存放器用来存放CPU通过数据总线发来的命令。8086最多可有多少级中断?按照产生中断的方法分为哪两大类?答:有8级;按照产生中断的方法可分为硬件中断和软件中断。什么是中断.什么是中断向量.中断向量表的地址围.答:中断就是CPU在执行当前程序时由于外部事件引起CPU暂时停顿当前正在执行的程序而转向执行请求CPU暂时停顿的外部事件的效劳程序,该程序处理完后又返回继续执行被停顿的程序;中断向量是中断处理子程序的入口地址;地址围是00000H-003FFH。中断向量表的功能是什么.假设中断向量号分别为1AH和20H,则它们的中断向量在中断向量表的什么位置上.答:中断向量表的功能是当中断源发出中断请求时,即可查找该表,找出其中断向量,就可转入相应的中断效劳子程序。1AH在中断向量表的位置是1AH*4=68H在中断向量表0000:0068处;20H在中断向量表的位置是80H在中断向量表0000:0080处。通常,解决中断优先级的方法有哪几种.答:3种,软件查询确定优先级,硬件优先级排队电路确定优先级,具体中断屏蔽的接口电路。8259A通过级联的方式可以由几片构成最多多少级优先权的中断源。答:8259A通过级联的方式由9片构成最多64级优先权的中断源。简述中断控制器8259A的部构造和主要功能。答:8259A的部构造有数据总线缓冲器,读写逻辑电路,级联缓冲比拟器,中断请求存放器〔IRR〕,中断屏蔽存放器〔IMR〕,中断效劳存放器〔ISR〕,优先权判别器〔PR〕,控制逻辑。8259A的部存放器中IRR、IMR、ISR三个存放器的作用是什么.答:见课本153页。8259A有哪些中断完毕方式,分别适用于哪些场合。答:8259A有2种中断完毕方式:中断自动完毕方式,中断非自动完毕方式〔一般中断和特殊中断〕;中断自动完毕方式只适合有一块8259A,并且各中断不发生嵌套的情况。中断非自动完毕方式只能适合与全嵌套方式下不能用与循环优先级方式。8259A对优先级的管理方式有哪几种,各是什么含义.答:有4种,普通全嵌套方式,特殊全嵌套方式,自动循环方式,优先级特殊循环方式〔详细见课本P159和P160〕8259A的初始化命令字和操作命令字有哪些,其功能是什么;哪些应写入奇地址,哪些应写入偶地址。答:8259A的初始化命令字ICW1,ICW2,ICW3,ICW4;操作命令字OCW1,OCW2,OCW3。〔见课本P155到P158〕;ICW2,ICW3,ICW4,OCW1写如奇地址,ICW1,OCW2,OCW3为偶地址。简述8259A的初始化过程。答:8259A的初始化编程,需要CPU向它输出一个2—4字节的初始化命令字,输出初始化命令字的流程如下图,其中ICW1和ICW2是必须的,而ICW3和ICW4需根据具体的情况来加以选择。各初始化命令字的安排与作用分叙如下:8253有几个计数通道,每条计数通道有哪些信号线,其作用是什么.答:8253有三个计数通道,每个计数通道有3条信号线:CLK:计数输入用于输入定时基准脉冲或计数脉冲.OUT:输出信号以相应的电平指示计数的完成或输出脉冲的波型.GATA:选通输入用于启动或制止计数器的操作,以使计数器和计数输入信号同步。8253有几种工作方式,其特点是什么.答:六种方式〔见课本P224〕8253的部存放器及各位的意义是什么.答:8253的部存放器有四个,8位的控制存放器:初始化时,将控制字写入该存放器;16位的计数器初值存放器,初始化是写入该计数器的初始值,其最大初始值为0000H;16位的减一计数器,计数器的初值由计数初值存放器送入减法计数器,当计数输入端输入一个计数脉冲时,减法计数器容减一;16位的输出锁存器用来锁存计数脉冲时,减法计数器容减一。8255A的功能是什么,有哪几个控制字,各位的意义是什么.答:8255A是一种通用的可编程程序并行I/O接口芯片.它有两个控制字,一个是方式选择控制字,它的作用是实现对8255A的各个端口的选择。一个是对C口进展置位或复位控制字.它的作用是能实现对端口C的每一位进展控制。8255A的A口、B口、C口有哪几种工作方式,其特点是什么.C口有哪些使用特点.答:8255A的A口可以工作在3种工作方式的任何一种,B口只能工作在方式0或方式1,C口则常常配合端口A和端口B工作,为这两个端口的输入/输出传输提供控制信号和状态信号。同步通信、异步通信的帧格式各是什么.什么是奇、偶校验.答:异步通信的帧格式是用一个起始位表示传送字符的开场,用1-2个停顿位表示字符完毕。起始位与停顿位之间是数据位,数据位后是校验位,数据的最底位紧跟起始位,其他各位顺序传送;同步通信的帧格式是在每组字符之前必须加上一个或多个同步字符做为一个信息帧的起始位。什么是波特率.假设在串行通信中的波特率是1200b/s,8位数据位,1个停顿位,无校验位,传输1KB的文件需要多长时间.答:波特率是单位时间通信系统所传送的信息量。需要多长时间=1024/〔1200/10〕=8.53s对8255A进展初始化,要求端口A工作于方式1,输入;端口B工作于方式0,输出;端口C的高4位配合端口A工作,低4位为输入。设控制口的地址为006CH。答:由题知应为10111001H(B9H)MOVAL,B9HMOVD*,006CHOUTD*,AL设8255A的四个端口地址分别为00C0H、00C2H、00C4H和00C6H,要求用置0、置1的方法对PC6置1,对PC4置0。答:MOVD*,00C0H;端口地址MOVAL,00001101;对PC6置1OUTD*,ALMOVAL,00001000;对PC4置0OUTD*,AL试按照如下要求对8259A进展初始化:系统中只有一片8259A,中断请求信号用电平触发方式,下面要用ICW4,中断类型码为60H、61H、62H……67H,用全嵌套方式,不用缓冲方式,采用中断自动完毕方式。设8259A的端口地址为94H和95H。答:MOVD*,94H;偶地址MOVAL,00011011B;ICW1OUTD*,ALMOVAL,10011111B;ICW2,中断源在IR7MOVD*,95H;奇地址OUTD*,ALMOVAL,00000011B;ICW4OUTD*,AL试编程对8253初始化启动其工作。要求计数器0工作于模式1,初值为3000H;计数器1工作于模式3,初值为100H;计数器2工作于模式4,初值为4030H。设端口地址为40H、41H、42H和43H。答:MOVAL,00011110H;控制字OUT43H,ALMOVAL,3000H;计数初值OUT40H,ALMOVAL,01010110H;计数器1OUT43H,ALMOVAL,100HOUT41H,ALMOVAL,10011000H;计数器2OUT43H,ALMOVAL,4030HOUT42H,AL模拟试题一一、简答题:1.简述USB总线的特点。答:1)具备即插即用特性,为USB接口设计的驱动程序和应用程序可自动启动、本钱低,节省空间,为开放性的不具备专利的理想工业标准。:2)可动态连接和重新配置外设,支持热插拔功能;3)允许多台设备同时工作;4)可以向USB总线上的设备供电,总线上的设备可以自备电源;5)通讯协议支持等时数据传输和异步消息传输的混合模式;6)支持实时语音、音频、和视频数据传输。2.什么是中断类型码.什么叫中断向量.什么叫中断向量表.它们之间有什么联系答:8086/8088系统可以处理256种中断,为了区别每一种中断,为每个中断安排一个,称为中断类型码。每一种中断效劳程序在存中的起始地址称为中断向量,以32位逻辑地址表示,即为CS:IP。把所有中断向量存储在存中的*一个连续区中,这个连续的存储区称为中断向量表。中断向量CS:IP在中断向量表中的位置为:中断向量表中偏移量为〔中断类型码×4〕的单元中存放IP的值,偏移量为〔中断类型码×4+2〕的单元中存放CS的值。3.简述高速缓冲存储器Cache为什么能够实现高速的数据存取.答:高速缓冲存储器Cache是根据程序局部性原理来实现高速的数据存取。即在一个较小的时间间隔,程序所要用到的指令或数据的地址往往集中在一个局部区域,因而对局部围的存储器地址频繁,而对围外的地址则围甚少的现象称为程序的局部性原理。如果把正在执行的指令地址附近的一小局部指令或数据,即当前最活泼的程序或数据从主存成批调入Cache,供CPU在一段时间随时使用,就一定能大大减少CPU主存的次数,从而加速程序的运行。有一个由20个字组成的数据区,其起始地址为3500H:0320H。试写出数据区首末单元的实际地址。答:数据区首地址=3500H×10H+0320H=33320H数据区末地址=33320H+28H-1=33347H设有一个具有16位地址和8位数据的存储器,问:(1)该存储器能存书多少个字节的信息.(2)如果存储器由8K×4位RAM芯片组成,需要多少片.(3)需要地址多少位做芯片选择.答:〔1〕因为8位二进制数为1个字节,所以16位地址能存储216=64KB个字节的信息;〔2〕需要64K×8/8K×4=16片RAM〔3〕因为需要16片来构成存储器,而16片需要4位地址线进展译码输出,故需要4位做芯片选择。定性分析微型计算机总线的性能指标。答:微型计算机总线的主要职能是负责计算机各模块间的数据传输,对总线性能的衡量也是围绕这一性能而进展的。性能中最重要的是数据传输率,另外,可操作性、兼容性和性能价格比也是很重要的技术特征。具体来说,总线的主要性能指标有以下几项:(1)总线宽度:以位数表示。(2)标准传输率Mb/s:是总线工作频率与总线宽度的字节数之积。(3)时钟同步/异步:总线中与时钟同步工作的称为同步总线;与时钟不同步工作的称为异步总线。这取决于数据传输时源模块与目标模块间的协议约定。(4)信号线数:这是地址总线、数据总线和控制总线线数的总和。信号线数和系统的复杂程度成正比关系。(5)负载能力:以系统中可以连接的扩展电路板数表示。(6)总线控制方法:包括突发传输、并发工作、自动配置、仲裁方式、逻辑方式、中断方式等项容。(7)扩展板尺寸:这项指标对电路板生产厂家很重要。(8)其他指标:电源是5V还是3V,能否扩展64位宽度等。任何系统的研制和外围模块的开发,都必须服从其采用的总线规。虚拟存储器的含义是什么.答:虚拟存储器是以存储器的局部性为根底,建立在主存-辅存物理体系构造上的存储管理技术。在存储系统中,由于主存容量不能满足用户的需要,因而引入辅存作为后援。即辅存做主存用,扩大编程者的使用空间。二、编程及综合题1.8255A的地址为0060H~0063H,A组设置方式1,端口A作为输入,PC6PC7作为输出,B组设置方式1,端口B作为输入,编制初始化程序.。答案:MOVD*,0063HMOVAL,00110111BOUTD*,AL2编写8253初始化程序。如下列图所示〔注意端口地址〕,要求3个计数通道分别完成以下功能:(1)通道0工作于方式3,输出频率为2KHZ的方波;(2)通道1产生宽度为480us的单脉冲;(3)通道2用硬件方式触发,输出负脉冲,时间常数为26。〔提示:8253的端口地址分别为:0310H、0312H、0314H、0316H〕答案:编写8253的初始化程序1.确定端口地址:0310H、0312H、0314H、0316H2.确定工作方式:通道0,方式3通道1,方式1通道2,方式53.确定计数值:通道0:N0=1MHz/2KHz=500通道1:N1=480us/(1/1mhz)=480通道2:N2=264.确定控制字:通道0:00110111B通道1:01110011B通道2:10011011B对3个通道的初始化程序如下:;通道0初始化程序MOVD*,316HMOVAL,00110111BOUTD*,ALMOVD*,310HMOVAL,00HOUTD*,ALMOVAL,05HOUTD*,AL;通道1的初始化程序MOVD*,316HMOVAL,001110011BOUTD*,ALMOVD*,312HMOVAL,80HOUTD*,ALMOVAL,04HOUTD*,AL;通道2初始化程序MOVD*,316HMOVAL,10011011BOUTD*,ALMOVD*,314HMOVAL,26HOUTD*,AL模式试题二一、
填空:1、设字长为八位,有*=1,y=124,则有:[*y]补=01111011[*y]补=10000011;2、数制转换:247.86=H=______________BCD;3、在8086CPU中,由于BIU和EU分开,所以_____和_____可以重叠操作,提高了CPU的利用率;4、8086的中断向量表位于存的_______区域,它可以容纳____个中断向量,每一个向量占____个字节;5、8086系统中,地址FFFF0H是___________________地址;6、8086CPU的MN/M*引脚的作用是____________________;7、8251芯片中设立了_____、_____和______三种出错标志;8、8086CPU中典型总线周期由____个时钟周期组成,其中T1期间,CPU输出______信息;如有必要时,可以在__________两个时钟周期之间插入1个或多个TW等待周期。9、8259A共有___个可编程的存放器,它们分别用于承受CPU送来的______命令字和________命令字。
二、简答题:1、什么是信号的调制与解调.为什么要进展调制和解调.试举出一种调制的方式。串行长距离通信时,需要利用模拟信道来传输数字信号,由于信道的频带窄,一般为300~3400HZ,而数字信号的频带相当宽,故传输时必须进展调制,以免发生畸变而导致传输出错。(3分)调制是将数字信号模拟信号。而解调则是相反。例如FSK制(调频制或称数字调频)可将数字“1〞和“0〞分别调制成2400HZ和1200HZ的正弦波信号。(2分)已有A*=E896H,B*=3976H,假设执行ADDB*,A*指令,则结果B*,A*,标志位CF,OF,ZF各为何值.B*=220CH(1分)A*=E896H(1分)CF=1(1分)OF=0(1分)ZF=0(1分)三、阅读程序与接口芯片初始化:1、源程序如下:MOVCL,4 MOVA*,[2000H]
SHLAL,CL
SHRA*,CLMOV[2000H],A*试问:假设程序执行前,数据段(2000H)=09H,(2001H)=03H,则执行后有(2000H)=_____,(2001H)=______。本程序段的功能_________________________。2、源程序如下:MOVAL,0B7H
ANDAL,0DDH
*ORAL,81H
ORAL,33HJPLAB1JMPLAB2试问:执行程序后AL=_______;程序将转到哪一个地址执行:__________。3、源程序如下:MOVC*,9MOVAL,01HMOVSI,1000HNE*T:MOV[SI],ALINCSISHLAL,1LOOPNE*T
试问:执行本程序后有:AL=_____;SI=______;C*=______;本程序的功能是______________________________。4、*系统中8253占用地址为100H~103H。初始化程序如下:MOVD*,103HMOVAL,16HOUTD*,ALSUBD*,3OUTD*,AL试问:此段程序是给8253的哪一个计数器初始化.安排工作在哪种工作方式.__________________;假设该计数器的输入脉冲的频率为1MHZ,则其输出脉冲的频率为:___________。5、*8255A在系统中占用88~8BH号端口地址,现欲安排其PA,PB,PC口全部为输出,PA,PB口均工作于方式0模式,并将PC6置位,使PC3复位,试编写出相应的初始化程序:模式试题二参考答案一、填空题2、F7DCH00100100011110000110BCD3、取指令执行指令4、00000H~003FFH区256个4个5、CPU复位以后执行第一条指令的地址6、决定CPU工作在什么模式(最小/最大)7、奇/偶错帧格式错溢出错8、4个地址T3和T49、7个初始化操作三、阅读程序与接口芯片初始化:1、(2000H)=39H(2001H)=00H将(2000H),(2001H)两相邻单元中存放的未组合型BCD码压缩成组合型BCD码,并存入(2000H)单元,0(2001H)2、37HLAB23、01009H0对数据段1000H~1008H单元置数,依次送入1,2,4,8,16,32,64,128,0共九个4、计数器0工作于方式345.454KHZ5、MOVAL,80HOUT8BH,ALMOVAL,ODHOUT8BH,ALMOVAL,06HOUT8BH,AL模式试题三一、填空题1、将十进制数27985转换成十六进制数、八进制数、二进制数及BCD码数分别为:________H,________Q,_____B,BCD。2、字长为8位的二进制数10010100B,假设它表示无符号数,或原码数,或补码数,则该数的真值应分别为______D,______D或______D。3、B*=7830H,CF=1,执行指令:ADCB*,87CFH之后,B*=____________,标志位的状态分别为CF=_______,ZF=_______,OF=________,SF=__________。4、8086中,BIU部件完成______功能,EU部件完成_____功能。5、8086中引脚BHE信号有效的含义表示________________。6、8086正常的存储器读/写总线周期由________个T状态组成,ALE信号在__________状态有效,其作用是______________。7、设8086系统中采用单片8259A,其8259A的ICW2=32H,则对应IR5的中断类型号为___________H,它的中断入口地址在中断向量表中的地址为______________H。
二、简答及判断题1、*指令对应当前段存放器CS=FFFFH,指令指针存放器IP=FF00H,此时,该指令的物理地址为多少.指向这一物理地址的CS值和IP值是唯一的吗.试举例说明2、8086CPU的FLAG存放器中,状态标志和控制标志有何不同.程序中是怎样利用这两类标志的.3、设采用16550进展串行异步传输,每帧信息对应1个起始位,7个数据位,1个奇/偶校验位,1个停顿位,波特率为4800,则每分钟能传输的最大字符数为多少个.三、读图和作图题1、8086系统中接口连接关系如下列图所示。要求答复以下问题:(1)试分别确定8255,8253,8259及8251的端口地址;(2)设8255的PA口为输出,PB口为输入,试写出对PA口和PB口执行输入/输出操作的指令。8255的端口地址为:___________________________________;8253的端口地址为:___________________________________;8259的端口地址为:___________________________________;8251的端口地址为:___________________________________;对PA口操作的I/O指令为_______________________________;对PB口操作的I/O指令为______________________________。
2、作图题。系统采用4个接口芯片:8253,8251,8259及8255。要求8253的通道0用作实时时钟,每当定时时间到之后向8259的IR2送入中断申请信号。8253通道1用作方波发生器作为8251的收发时钟脉冲。8253通道0,通道1的门控信号由8255PC口的PC3和PC2控制。(1)画出4个芯片之间控制线的连接图;(2)8253的两个通道应分别工作在什么方式.四、程序阅读题1、源程序如下:MOVAH,0MOVAL,9MOVBL,8ADDAL,BLAAAAADDIVAL结果AL_________,AH=___________,BL=_____________。
2、源程序如下:MOVA*,SEGTABLE;TABLE为表头MOVES,A*MOVDI,OFFSETTABLEMOVAL,‘0’MOVC*,100CLDREPNESCASB问:1)该段程序完成什么功能.2)该段程序执行完毕之后,ZF和C*有几种可能的数值.各代表什么含义.3、源程序如下:CMPA*,B*JNCL1JZL2JNSL3JNOL4JMPL5设A*=74C3H,B*=95C3H,则程序最后将转到哪个标号处执行.试说明理由。
4、源程序如下:MOVD*,143HMOVAL,77HOUTD*,ALMOVA*,0DECD*DECD*OUTD*,ALMOVAL,AHOUTD*,AL设8253的端口地址为140H~143H,问:(1)程序是对8253的哪个通道进展初始化.(2)该通道的计数常数为多少.(3)假设该通道时钟脉冲CLK的周期为1µs,则输出脉冲OUT的周期为多少µs.五、编程题1、8255的编程。设8255的端口地址为200H~203H。(1)要求PA口方式1,输入;PB口方式0输出;PC7~PC6为输入;PC1~PC0为输出。试写出8255的初始化程序。(2)程序要求当PC7=0时置位PC1,而当PC6=1时复位PC0,试编制相应的程序。2、自BUFFER开场的缓冲区有6个字节型的无符号数:10,0,20,15,38,236,试编制8086汇编语言程序,要求找出它们的最大值、最小值及平均值,分别送到MA*、MIN和AVI三个字节型的存单元。要求按完整的汇编语言格式编写源程序。模式试题三参考答案一、填空题001001111001.10000101BCD2、148D-20D-108D3、B*=0000HCF=1ZF=1OF=0SF=04、总线接口功能指令的译码及执行功能5、高8位数据线D15~D8有效6、4T1给外部的地址锁存器提供一个地址锁存信号7、35H000D4H~000D7H
二、简答及判断题FFFF0FFFF0FF00FF000FEF00FEF011自然丧失自然丧失故物理地址为0FEF0H。
指向该物理地址的CS,IP值不唯一。例如:CS:IP=0000:FEF0H也指向该物理地址。2、状态标志表示算术运算或逻辑运算执行之后,运算结果的状态,这种状态将作为一种条件,影响后面的操作。控制标志是人为设置的,指令系统中有专门的指令用于控制标志的设置或去除,每个控制标志都对*一特定的功能起控制作用。28800个28800个1048006028800(个)三、读图和作图题
1、(1)A7A6A5A4A3A2A1A01000任意0Y01001任意0Y11010任意0Y21011任意0Y38255的端口地址为80H,82H,84H,86H8253的端口地址为90H,92H,94H,96H8259的端口地址为A0H,A2H,8251的端口地址为B0H,B2H,(2)OUT80H,ALINAL,82H2、(1)控制线连接图如下图。通道0工作在方式2—分频发生器;通道1工作在方式3—方波速率发生器四、程序阅读题1、AL=01HAH=00HBL=08H
2、(1)从目的串中查找是否包含字符‘0’,假设找到则停顿,否则继续重复搜索。(2)ZF=1,说明已找到字符ZF=0,说明未找到字符
C*0,
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年度电商平台入驻协议及运营管理规范3篇
- 2024版房地产代理合同(含广告推广服务)3篇
- 第3单元 秦汉时期:统一多民族国家的建立和巩固 单元导学(新教学实录)2023-2024学年七年级上册历史(部编版)
- 2024全新金融产品典押与抵押合同范本下载3篇
- 六盘水幼儿师范高等专科学校《大学lT》2023-2024学年第一学期期末试卷
- 2024年度教育机构助学贷款借款合同2篇
- 2024年度专利技术使用权转让保密协议2篇
- 人教版历史与社会九年级上册:3.2 第二次世界大战的爆发与扩大-欧洲战争策源地的形成教学实录
- 2024年标准陆运协议书样本版B版
- 2024年环保型饲料批量销售协议
- 北京市西城区2023-2024学年六年级上学期语文期末试卷
- 市政苗木移植合同范例
- 化学与生活2023-2024-2学习通超星期末考试答案章节答案2024年
- 畜禽市场管理制度5则范文
- GB/T 30595-2024建筑保温用挤塑聚苯板(XPS)系统材料
- 2024年人教版八年级地理上册期末考试卷(附答案)
- 2024年初中七年级英语上册单元写作范文(新人教版)
- 2025年蛇年年会汇报年终总结大会模板
- 2024年度国家公务员考试公共基础知识复习试卷及答案(共四套)
- 中国高血压防治指南(2024年修订版)解读-治疗篇
- 内审检查表完整版本
评论
0/150
提交评论