共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 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动——B站互动赢积分】活动开启啦! | |
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |