共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 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| 【S32DS】S32K3 RTD7.0.1 HSE 组件配置报错问题解决被打赏¥27元 | |
| 【S32K3XX】MCME 启动 CORE1被打赏¥23元 | |
| AG32VH407下温度大气压传感器及其检测被打赏¥20元 | |
| AG32VH407下光照强度传感器BH1750及其检测被打赏¥22元 | |
| AT32VH407下使用温湿度传感器DHT22进行检测被打赏¥20元 | |
| DIY一个婴儿澡盆温度计被打赏¥34元 | |
| 【FreeRtos】FreeRtos+MPU region 配置规则被打赏¥23元 | |
| 【分享开发笔记,赚取电动螺丝刀】三分钟快速上手驱动墨水屏(ArduinoIDE)被打赏¥28元 | |
| 【S32K3XX】LIN 通讯模块使用被打赏¥31元 | |
| 【FreeRtos】FreeRtos + MPU模块的配置使用被打赏¥32元 | |
我要赚赏金
