专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
在atmega16中使用中断来修改快速PWM的占空比问题
2019-03-24 20:46
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
Atmel MCU
6115
4
1100
在快速PWM 模式15下计划通过INT0,和INT1来修改占空比的增减;可是试验发现中断失灵了。中断配置是正确的,屏蔽快速PWM模式后,中断可用。
请问什么原因》 此帖出自
小平头技术问答
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
4条回答
selfstudy
2019-03-25 01:05
#include <avr/io.h>
#include <avr/interrupt.h>//ISR(BADISR_vect){ //服务程序}
#include <avr/delay.h>
#include <stdio.h>
#define uint unsigned int
#define uchar unsigned char
volatile uint actual_plus,set_plus;//占空比
volatile uchar i;
ISR(INT0_vect)
{
/*actual_plus=actual_plus+set_plus*5/100;
if (actual_plus<=set_plus*90/100)
{OCR1B=actual_plus;}
else
{OCR1B=set_plus*90/100;}
// if (i==0) {PORTD|=_BV(7);}
// else{PORTD&=~_BV(7);i=0;}
// i++;
*/
i=1; //验证中断是否执行
PORTB=0X01;
}
ISR(INT1_vect)
{
/*actual_plus=actual_plus-set_plus*5/100;
if (actual_plus<=set_plus*10/100)
{OCR1B=set_plus*10/100;}
else
{OCR1B=actual_plus;}*/
i=2;PORTB=0X02;
}
int main(void)
{
DDRD|=_BV(4)|_BV(5)|_BV(7);//设置PD4,PD5输出
TIMSK|=_BV(4)|_BV(5);//开启A,B口中断
TCCR1A=0B01100011;// A口取反;B口 0 1 WGM[3:0]=15:比较匹配时O C1A取反,OC1B不占用物理引脚;
// 1 0 比较匹配发生时将清零OC1A/OC1B,计数到0XFF时OC1A/OC1B置位
//200Hz 设定,64分频
TCCR1B= 0B00011011;//0 1 1 =64分频
set_plus=624;//8000000/(200*64)-1=624;周期1/200=5ms;
OCR1A=set_plus ;
actual_plus=124;
OCR1B=124;//占空比1ms;1/5
//产生的0C1B频率为200Hz;0C1A频率为100Hz。
//增加一个按键来增减占空比
DDRD&=~(_BV(2)|_BV(3));//设置中断为输入
GICR|=_BV(7)|_BV(6);//开启中断0和中断1;
MCUCR|=0B00001011;//中断0上升沿有效;中断1下降沿有效。中断1次响应加1.
GIFR|=_BV(7)|_BV(6);//清除中断0和1的标志位;置1中断
SREG|=_BV(7);//开中断
DDRB|=0X03;//
PORTB=00;
while(1)
{
}
}
加载中...
查看其它4个回答
一周热门
更多
>
相关问题
相关文章
Arduino-每个人的微控制器
0个评论
一款由长短音密码控制的门禁密码锁的设计
0个评论
IAR Embedded Workbench for Atmel AVR 6.10 环境配置
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
#include <avr/interrupt.h>//ISR(BADISR_vect){ //服务程序}
#include <avr/delay.h>
#include <stdio.h>
#define uint unsigned int
#define uchar unsigned char
volatile uint actual_plus,set_plus;//占空比
volatile uchar i;
ISR(INT0_vect)
{
/*actual_plus=actual_plus+set_plus*5/100;
if (actual_plus<=set_plus*90/100)
{OCR1B=actual_plus;}
else
{OCR1B=set_plus*90/100;}
// if (i==0) {PORTD|=_BV(7);}
// else{PORTD&=~_BV(7);i=0;}
// i++;
*/
i=1; //验证中断是否执行
PORTB=0X01;
}
ISR(INT1_vect)
{
/*actual_plus=actual_plus-set_plus*5/100;
if (actual_plus<=set_plus*10/100)
{OCR1B=set_plus*10/100;}
else
{OCR1B=actual_plus;}*/
i=2;PORTB=0X02;
}
int main(void)
{
DDRD|=_BV(4)|_BV(5)|_BV(7);//设置PD4,PD5输出
TIMSK|=_BV(4)|_BV(5);//开启A,B口中断
TCCR1A=0B01100011;// A口取反;B口 0 1 WGM[3:0]=15:比较匹配时O C1A取反,OC1B不占用物理引脚;
// 1 0 比较匹配发生时将清零OC1A/OC1B,计数到0XFF时OC1A/OC1B置位
//200Hz 设定,64分频
TCCR1B= 0B00011011;//0 1 1 =64分频
set_plus=624;//8000000/(200*64)-1=624;周期1/200=5ms;
OCR1A=set_plus ;
actual_plus=124;
OCR1B=124;//占空比1ms;1/5
//产生的0C1B频率为200Hz;0C1A频率为100Hz。
//增加一个按键来增减占空比
DDRD&=~(_BV(2)|_BV(3));//设置中断为输入
GICR|=_BV(7)|_BV(6);//开启中断0和中断1;
MCUCR|=0B00001011;//中断0上升沿有效;中断1下降沿有效。中断1次响应加1.
GIFR|=_BV(7)|_BV(6);//清除中断0和1的标志位;置1中断
SREG|=_BV(7);//开中断
DDRB|=0X03;//
PORTB=00;
while(1)
{
}
}
一周热门 更多>