1、《单片机原理及应用》模拟卷 1 除非特别声明,编程题可以使用汇编语言编写,也可以使用C语言编写 1、 分析程序的执行结果,将结果填写到空格中。 ORG 0000H MOV 30H,#50H MOV R0,#30H MOV A,@R0 ;(A= 50H ) MOV A,#79H MOV B,#20H ;(A= 79H B= 20H ) DIV AB ;(A= 03H B= 19H ) PUSH B MOV B,#0AH MUL AB ;(A= 1EH B
2、 0 ) POP B ADD A,B ;(A=37H B=19H ) MOV 30H,A ;(30H单元的内容=37H ) MOV 20H,30H CLR 01H ;(20H单元的内容= 37H ) MOV A,20H ;(PSW中P的内容= 1 ) CPL A RR A ;( PSW中C的内容= 0 ) SWAP A ;(A= 46H ) ADDC A,#0F0H ;(A= 36H )
3、 ;(PSW中P的内容= 0 ) ;( PSW中C的内容= 1 ) RL A ;(A= 6CH ) ;(PSW中P的内容= 0 ) ;( PSW中C的内容= 0 ) LOOP: AJMP LOOP 2、 将MCS51内部RAM60H~65H单元存放的12个16进制数变为ASCII码,放到0090H单元开始的外部RAM中。[使用汇编语言编写] ORG 0000H AJMP MAIN ORG 0030H MIAN: MOV R0,#50H MOV R1,#06H
4、 MOV R2,#02H MOV DPTR,#2800H MOV A,@R0 MOV B,A CH:ANL A,#0FH PUSH ACC SUB A,#0AH JNC AD37 POP ACC ADD A,#30H JMP SAV AD37: POP ACC ADD A,#37H SAV: DJNZ R2,LL MOVX @DPTR,A INC DPTR SWAP B MOV B,A JMP CH LL:INC R0 DJNZ R1,DONE
5、 DONE:HLT END 3、 某一故障检测系统,当出现故障1时,线路1上出现上升沿;当出现故障2时,线路2上出现下降沿。没有故障时,线路1为低电平,线路2为高电平。出现故障时,相应的指示灯变亮。故障消失后,指示灯熄灭。试用MSC1211为单片机实现该故障检测功能,画出电路原理图,并写出相应程序。 解答:如下图所示:故障1从P32输入,利用INT0, 故障2从P33输入,利用INT1,使用L1作为故障1的指示灯,L2作为故障2的指示灯。 程序清单: ORG 0000H AJMP MIAN ORG 0003H AJMP GU1
6、 ORG 0013H AJMP GU2 ORG 1000H MAIN: MOV TCON,#05H MOV IE,#85H HERE: SETB P1.0 SETB P1.1 GU1:CLR P1.0 JB P3.2,GU1 RETI GU2: CLR P1.1 JB P3.3,GU2 RETI END 4、 利用MSC1211或8051设计应答方式下的多机通讯程序。通讯参数:晶振为11.0592MHz,9600,n,8,1。通讯过程如下:主机首先发送从机地址,
7、从机收到地址后进行比较,如果地址相符,则将从机地址回发给主机作为应答信号。主机收到从机的地址应答信号后,将内存单元中的120个数据发送给从机,并进行数据块校验(将各个数据进行异或),若校验正确,则从机发送00H给主机,否则发送0FFH给主机,主机重新发送数据。(应在适当的地方加程序注释) 解:主机程序如下: ORG 0000H LJMP MAINT ;跳至主程序入口地址 ORG 0023H ;串行口中断服务程序入口 LJMP INTST MAINT: MOV SCON,#90H ;置工作方式2,并允许接收 MOV TMOD,#20H ;置T1工作方式2 MOV T
8、H1,#0FDH MOV TL1,#0FDH MOV DPTR,#ADDR ;设置数据块首址ADDR的地址指针 MOV R0,#120 ;设置发送字节数 MOV R1,#00H ;设置校验和的初值 MOV R2,#NAME SETB TB8 ;置位TB8位,作为发送地址桢信息特征 SETB TR1 SETB EA ;CPU开中断 SETB ES ;允许串行口中断 MOV A,R2 ;发送地址桢信息 MOV SBUF,A SJMP $ ;中断服务程序 INTST: MOV A,TB8 ;判断是发送地址还是数据,若为数据
9、则转LOOP0 CJNE A,01H,LOOP0 CLR TI ;地址桢信息发送完后清发送中断 LOOP0:JB RI,LOOP1 ;检查是否是接受中断?若RI=1则转入接受乙机发送应答信息 CLR TI ;因RI=0,表明是甲机发送中断数据的中断请求。CPU响应中断,在中断服务程序中应清中断标志 MOV A,TB8; CJNE A,#01H,LOO3 ;若为发送数据中断则转LOOP3继续发送数据 LJMP ENDT ;甲机发送一数据完毕跳至中断返回程序 LOOP1:CLR RI ;清接受中断标志 MOV A,TB8 ;判断是发送地址还是数据,若为数据则
10、转LOOP2 CJNE A,#01H,LOOP4;若TB8为0则接受的为乙机数据校验应答 MOV A,SBUF ;取乙机的应答数据 CJNE A,@R2,LOOP2 ;若乙机应答信息不是从机地址,则地址传送不正确,则转LOOP2程序重新发送地址信息,否则清TB8,发送数据 CLR TB8 LOOP3:MOVX A,@DPTR ;取下一个数 MOV SBUF,A ;启动串行口,发送新的数据 XRL A,@R1 MOV @R1,A INC DPTR ;修改地址指针 DEC R0 ;修改发送字节数记数值 CJNE R0,#00H,ENDT ;判别120个字
11、节数据都发送完没有。如果没有发送完则跳至中断返回程序。继续发送 MOV A,@R1 MOV SBUF,A ;数据全部发送完毕则发送校验和 LJMP ENDT LOOP4:MOV A,SBUF ;取乙机的应答数据 CJNE A,#00H,LOOP5 ;若数据发送不正确,则转LOOP5重新发送 CLR ES ;全部发送完毕,禁止串行口中断 LOOP5:MOV DPTR,#ADDR ;设置数据块首址ADDR的地址指针 MOV R0,#120 ;设置发送字节数 MOV R1,#00H ;设置校验和的初值 LJMP LOOP2 LOOP2:MOV A,
12、R2 ;发送地址桢信息 MOV SBUF,A RETI ENDT: RETI END 从机程序如下: ORG 0000H LJMP MAINR ;跳至主程序入口地址 ORG 0023H ;串行口中断服务程序入口 LJMP INTSR MAINR:MOV SCON,#0B0H ;置工作方式2,并允许接收 MOV TMOD,#20H ;置T1工作方式2 MOV TH1,#0FDH MOV TL1,#0FDH MOV DPTR,#ADDR ;设置数据块接收首址为ADDR MOV R0,#120 ;设置接收字节数 MOV R2,#NA
13、ME MOV R1,#00H ;设置校验和的初值 SETB RB8 ;置位RB8位,作为接受地址信息特征 SETB TR1 SETB EA ;CPU开中断 SETB ES ;允许串行口中断 SJMP $ ;中断服务程序 INTSR: MOV A, RB8 ;判断是接收地址还是数据,若为数据则转LOOP0 CJNE A,01H,LOOP0 CLR RI ;地址桢信息接受完后清接收中断 MOV A,SBUF XRL A,@R2 JZ LOOP ;若地址相符则转LOOP,否则中断返回 LJMP ENDR LOOP: CLR SM2 CLR
14、 RB8 MOV A,@R2 MOV SBUF,A ;想主机发送从机地址 LJMP ENDR LOOP0:JB RI,LOOP1 ;检查是否是接受中断?若RI=1则转入接受甲机发送的数据 CLR TI ;因RI=0,表明是乙机发送中断数据的中断请求。CPU响应中断,在中断服务程序中应清中断标志 LJMP ENDR ;甲机发送一数据完毕跳至中断返回程序 LOOP1:CLR RI ;清接受中断标志 DEC @R0 JZ LOOP2 ;数据未接收完则中断返回,若接收完则转LOOP2,校验 MOV A,SBUF ;取甲机发送的数据 MOVX @DPT
15、R,A XRL A,@R1 MOV @R1,A LOOP2:MOV A,SBUF :取甲机发送的校验和 XRL A,@R1 JZ RIGHT LJMP WRONG RIGHT:MOV A,#00H MOV SBUF,A LJMP ENDR WRONG:MOV A,#0FFH MOV SBUF,A MOV DPTR,#ADDR ;设置数据块接收首址为ADDR MOV R0,#120 ;设置接收字节数 LJMP ENDR ENDR: RETI END 5、 利用MSC1211的A/D构成数据采集系统。使用模拟通道0进行连续数
16、据采集,采集8次后取得平均值,存放到预先分配好的100个内存单元中,这100个单元存满后,再从第一个单元进行覆盖保存。写出完整的程序清单(应在适当的地方加程序注释)。
解:#include
17、序 { if(PAI==6) //处理AD中断 { w[out++]=bipolar(); temp=w[out]; SUMR0=temp&0xff; SUMR1=(temp>>8)&0xff; SUMR2=(temp>>16)&0xff; SUMR3=(temp>>24)&0xff; if(out==8) { SUM=SUMR3<<24+SUMR2<<16+SUMR1<<8+SUMR0; } SUM/=8; a[j++]=SUM; if(j>=100) {j=0;} } } min(
18、void) { float dummy; int decimation; decimationg=1440;//抽取因子 PDCON&=0x77;//打开ADC ACLK=9;//模拟采样频率 ADMUX=0;//使用通道0 ADCON0=0x30;//内部基准2.5V,缓冲器关,BOD关,PGA=0 ADCON1=0x01;//双极性,自动稳定模式,偏移增益自校准 ADCON2=decimation&0xff;//写入抽取因子低字节 ADCON3=(decimation>>8)&0x07;//写入抽取因子高字节 AIE=&0x20; autobaud(); //等待校准 for(i=0;i<4;i++) { while(!(AIE&0X20)) { dummy=ADRESL; } SSCON=0;//清除求和寄存器 EAI=1; While(1); } }






