用汇编语言实现80c51 Int0 外部事件中断引脚接一个按钮;(2)P0 口接8位 D/A;(3)Int0中断时,D/A输出一个方波;(4)可输出其它波形(可选项)

时间: 2024-01-21 19:02:09 浏览: 22
以下是实现80c51 Int0 外部事件中断引脚接一个按钮,P0口接8位D/A,并在Int0中断时D/A输出一个方波的汇编语言代码: ``` ORG 0H ;程序起始地址 MOV P0, #00H ;初始化P0口输出为低电平 MOV TMOD, #01H ;使用定时器0,工作在模式1(16位定时器模式) MOV TH0, #0FFH ;定时器初值设为0xFFFF MOV TL0, #0FFH SETB IT0 ;设置Int0为下降沿触发方式 SETB EA ;开启总中断 WAIT: SJMP WAIT ;等待Int0中断 ORG 03H ;Int0中断向量地址 MOV P0, #FFH ;P0口输出高电平 MOV A, #55H ;A寄存器存储输出的方波的占空比 ACALL WAVEFORM ;调用WAVEFORM子程序输出方波 CLR EX0 ;清除Int0中断标志位 RET ;返回主程序 WAVEFORM: PUSH ACC ;保存现场 MOV R1, #08H ;循环8次,输出8位D/A LOOP: MOV P0, A ;输出D/A的值 SETB P3.5 ;输出方波高电平 ACALL DELAY ;延时一段时间 CLR P3.5 ;输出方波低电平 ACALL DELAY RR A, #1 ;右移一位,改变输出D/A的值 DJNZ R1, LOOP ;循环8次 POP ACC ;恢复现场 RET DELAY: MOV R2, #0FFH ;延时计数器初值设为0xFF MOV R3, #0FFH DJNZ R2, $ ;循环延时 DJNZ R3, DELAY RET ``` 其中,WAVEFORM子程序用于输出方波,可以根据需要修改实现其它波形的输出。DELAY子程序用于实现延时,可以根据需要修改实现不同的延时时间。

相关推荐

最新推荐

recommend-type

单片机C51串口中断接收和发送测试例程(含通信协议的实现)

这是一个单片机C51串口接收(中断)和发送例程,可以用来测试51单片机的中断接收和查询发送,另外我觉得发送没有必要用中断,因为程序的开销是一样的
recommend-type

51单片机步进电机控制汇编语言程序

本程序是通过秒信号触发中断来实现的,要求中断程序必须在1S内执行完毕;步进电机转速控制是通过8255输入信号在每次执行中断程序内调整控制信号的循环次数来实现的。
recommend-type

51单片机驱动步进电机(汇编语言)

在这里介绍一下用51单片机驱动步进电机的方法。这款步进电机的驱动电压12V,步进角为 7.5度 . 一圈 360 度 , 需要 48 个脉冲完成。
recommend-type

16/32位微机原理、汇编语言及接口技术__钱晓捷_第2版_课后习题答案

16/32位微机原理、汇编语言及接口技术__钱晓捷_第2版_课后习题答案
recommend-type

汇编 从键盘输入一个数字N(0~9),然后显示N个大写字母“A”

(1)键盘输入使用21H功能调用 MOV AH,1 INT 21H ;输入字符的ASCII码将保存在AL寄存器中 (2)将输入数字的ASCII码转换成数字本身 (3)循环输出
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【实战演练】MATLAB用遗传算法改进粒子群GA-PSO算法

![MATLAB智能算法合集](https://static.fuxi.netease.com/fuxi-official/web/20221101/83f465753fd49c41536a5640367d4340.jpg) # 2.1 遗传算法的原理和实现 遗传算法(GA)是一种受生物进化过程启发的优化算法。它通过模拟自然选择和遗传机制来搜索最优解。 **2.1.1 遗传算法的编码和解码** 编码是将问题空间中的解表示为二进制字符串或其他数据结构的过程。解码是将编码的解转换为问题空间中的实际解的过程。常见的编码方法包括二进制编码、实数编码和树形编码。 **2.1.2 遗传算法的交叉和
recommend-type

openstack的20种接口有哪些

以下是OpenStack的20种API接口: 1. Identity (Keystone) API 2. Compute (Nova) API 3. Networking (Neutron) API 4. Block Storage (Cinder) API 5. Object Storage (Swift) API 6. Image (Glance) API 7. Telemetry (Ceilometer) API 8. Orchestration (Heat) API 9. Database (Trove) API 10. Bare Metal (Ironic) API 11. DNS
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。