共3条
1/1 1 跳转至页
mega8,PWM mega8定时器一快速PWM一问

问
一个比较简单的快速PWM程序,据我理解,定时器是到了上限值后变为0再重新累加,但下面个程序设为8位快速PWM,在AVRstudio中用auto step发现定时器1的TCNT1是从0加1加到FF后并没有立即变为0,而是再从FF减1减到0,同相位可调PWM的工作方式一样。这是怎么回事还是AVRstudio有问题?请各位指点
#include <inttypes.h>
#include <AVR/io.h>
#include <AVR/interrupt.h>
#include <AVR/signal.h>
typedef struct _bit_struct
{
unsigned char bit0 : 1 ;
unsigned char bit1 : 1 ;
unsigned char bit2 : 1 ;
unsigned char bit3 : 1 ;
unsigned char bit4 : 1 ;
unsigned char bit5 : 1 ;
unsigned char bit6 : 1 ;
unsigned char bit7 : 1 ;
}bit_field;
#define GET_BITFIELD(addr) (*((volatile bit_field *) (addr)))
#define led GET_BITFIELD(0x38).bit1
#define direct GET_BITFIELD(0x37).bit1
#define led1 GET_BITFIELD(0x35).bit3
#define direct1 GET_BITFIELD(0x34).bit3
uint8_t i;
SIGNAL (SIG_OVERFLOW1)
{
led1=~led1; //此处设一中断1
}
SIGNAL (SIG_OUTPUT_COMPARE1A)
{
i++; //此处设一中断2,在快速PWM中一个周期中进入两次
}
void
ioinit (void) /* Note [5] */
{
TCCR1A = 0xc1; //设置为8位快速PWM
TCCR1B = 0xa;
OCR1A=0x20;
direct=1;
direct1=1;
/* enable interrupts */
TIMSK|=(1<<(TOIE1))|(1<<(OCIE1A));
sei ();
}
int main (void)
{
ioinit ();
/* loop forever, the interrupts are doing the rest */
while(1);
return (0);
} 答 1: 倘若如你所云,就是模式选错了,我一直在用,当然指实际应用 答 2: 模式应该没选错,我还在STUDIO4中从模式0到模式15都试了遍就快速PWM的几种模式象相位可调模式一样,其它的模式都对。
另问,在计数器中控制加1和减1的控制位是在其它什么地方? 答 3: 忘了问,你实际应用是不是指不在STUDIO4中软调试? 答 4: 我烧片试过了,是STUDIO软仿真的问题?不要钱到底...呵呵 答 5: AVRstudio的确有问题我在做快速PWM时,也碰到了相同的问题。后来在实验板上,我用LCD实时显示TCNT值,证实了当TCNT计数到TOP值后,TCNT值立即清零。 答 6: 我用快速PWM时遇到过类似问题MEGA8,参考的是MEGA8的那本中文书
当把OCR1设为0时,示波器上还能看到一尖刺的脉冲
后来联系SL的工程师一起讨论了一翻,结果是书上关于寄存器设置的翻译错了
datasheet上有没有错就忘了,自己去看吧,不行就取反 答 7: datasheet不会错吧?
#include <inttypes.h>
#include <AVR/io.h>
#include <AVR/interrupt.h>
#include <AVR/signal.h>
typedef struct _bit_struct
{
unsigned char bit0 : 1 ;
unsigned char bit1 : 1 ;
unsigned char bit2 : 1 ;
unsigned char bit3 : 1 ;
unsigned char bit4 : 1 ;
unsigned char bit5 : 1 ;
unsigned char bit6 : 1 ;
unsigned char bit7 : 1 ;
}bit_field;
#define GET_BITFIELD(addr) (*((volatile bit_field *) (addr)))
#define led GET_BITFIELD(0x38).bit1
#define direct GET_BITFIELD(0x37).bit1
#define led1 GET_BITFIELD(0x35).bit3
#define direct1 GET_BITFIELD(0x34).bit3
uint8_t i;
SIGNAL (SIG_OVERFLOW1)
{
led1=~led1; //此处设一中断1
}
SIGNAL (SIG_OUTPUT_COMPARE1A)
{
i++; //此处设一中断2,在快速PWM中一个周期中进入两次
}
void
ioinit (void) /* Note [5] */
{
TCCR1A = 0xc1; //设置为8位快速PWM
TCCR1B = 0xa;
OCR1A=0x20;
direct=1;
direct1=1;
/* enable interrupts */
TIMSK|=(1<<(TOIE1))|(1<<(OCIE1A));
sei ();
}
int main (void)
{
ioinit ();
/* loop forever, the interrupts are doing the rest */
while(1);
return (0);
} 答 1: 倘若如你所云,就是模式选错了,我一直在用,当然指实际应用 答 2: 模式应该没选错,我还在STUDIO4中从模式0到模式15都试了遍就快速PWM的几种模式象相位可调模式一样,其它的模式都对。
另问,在计数器中控制加1和减1的控制位是在其它什么地方? 答 3: 忘了问,你实际应用是不是指不在STUDIO4中软调试? 答 4: 我烧片试过了,是STUDIO软仿真的问题?不要钱到底...呵呵 答 5: AVRstudio的确有问题我在做快速PWM时,也碰到了相同的问题。后来在实验板上,我用LCD实时显示TCNT值,证实了当TCNT计数到TOP值后,TCNT值立即清零。 答 6: 我用快速PWM时遇到过类似问题MEGA8,参考的是MEGA8的那本中文书
当把OCR1设为0时,示波器上还能看到一尖刺的脉冲
后来联系SL的工程师一起讨论了一翻,结果是书上关于寄存器设置的翻译错了
datasheet上有没有错就忘了,自己去看吧,不行就取反 答 7: datasheet不会错吧?
共3条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【EEPW电子工程师创研计划】技术变现通道已开启~ | |
发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
【EEPW在线】E起听工程师的声音! | |
“我踩过的那些坑”主题活动——第001期 | |
高校联络员开始招募啦!有惊喜!! | |
【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
送您一块开发板,2025年“我要开发板活动”又开始了! | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
电流检测模块MAX4080S被打赏10分 | |
【我踩过的那些坑】calloc和malloc错误使用导致跑飞问题排查被打赏50分 | |
多组DCTODC电源方案被打赏50分 | |
【我踩过的那些坑】STM32cubeMX软件的使用过程中的“坑”被打赏50分 | |
新手必看!C语言精华知识:表驱动法被打赏50分 | |
【我踩过的那些坑】杜绑线问题被打赏50分 | |
【我踩过的那些坑】STM32的硬件通讯调试过程的“坑”被打赏50分 | |
【我踩过的那些坑】晶振使用的问题被打赏100分 | |
【我踩过的那些坑】电感选型错误导致的处理器连接不上被打赏50分 | |
【我踩过的那些坑】工作那些年踩过的记忆深刻的坑被打赏10分 |