单片机原理及应用A答案
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
单片机原理及应用A答案
《单片机原理及应用》模拟卷 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= 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 )
;(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
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 SA V
AD37:
POP ACC
ADD A,#37H
SA V:
DJNZ R2,LL
MOVX @DPTR,A
INC DPTR
SWAP B
MOV B,A
JMP CH
LL:INC R0
DJNZ R1,DONE
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
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。
通讯过程如下:主机首先发送从机地址,从机收到地址后进行比较,如果地址相符,则将从机地址回发给主机作为应答信号。
主机收到从机的地址应答信号后,将内存单元中的120个数据发送给从机,并进行数据块校验(将各个数据进行异或),若校验正确,则从机
发送00H给主机,否则发送0FFH给主机,主机重新发送数据。
(应在适当的地方加程序注释)
解:主机程序如下:
ORG 0000H
LJMP MAINT ;跳至主程序入口地址
ORG 0023H ;串行口中断服务程序入口
LJMP INTST
MAINT:MOV SCON,#90H ;置工作方式2,并允许接收
MOV TMOD,#20H ;置T1工作方式2
MOV TH1,#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 ;判断是发送地址还是数据,若为数据则转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 ;判断是发送地址还是数据,若为数据则转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个字节数据都发送完没有。
如果
没有发送完则跳至中断返回程序。
继续发送
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,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,#NAME
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 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 @DPTR,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进行连续数据采
集,采集8次后取得平均值,存放到预先分配好的100个内存单元中,这100个单元存满后,再从第一个单元进行覆盖保存。
写出完整的程序清单(应在适当的地方加程序注释)。
解:#include
#include
extern void autobaud(void);//声明外部函数
extern void bipolar(void);
float a[100]={0},w[8]={0};int out=0;long result,temp;int j;
int AUXinterrupts(void)interrupt6 using1//中断服务程序{
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(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);
}
}。