共2条
1/1 1 跳转至页
149,P4,PWM 【求助】怎样才能让149的P4口前七个都输出PWM?

问
发现TI提供的例子中P4.0都没有输出PWM,怎么样才能使P4.0--P4.6都输出PWM,这时pwm的周期怎么确定呢?
希望高手帮我回答一下,我很急啊! 答 1: //*******************************************************************************
// MSP-FET430P140 Demo - Timer_B PWM TB1-6 upmode, 32kHz ACLK
//
// Description; This program will generate six PWM outputs on P4.x using
// Timer_B in upmode. The value in CCR0, defines the period and the
// values in CCRx the duty PWM cycles. Using 32kHz ACLK as TBCLK,
// the timer period is 15.6ms.
// ACLK = TBCLK = LFXT1 = 32768, MCLK = SMCLK = default DCO ~ 800kHz.
// Normal mode LPM3
// //*External watch crystal installed on XIN XOUT is required for ACLK*//
//
// MSP430F149
// -----------------
// /|\| XIN|-
// | | | 32k
// --|RST XOUT|-
// | |
// | P4.1|--> CCR1 - 75% PWM
// | P4.2|--> CCR2 - 25% PWM
// | P4.3|--> CCR3 - 12.5% PWM
// | P4.4|--> CCR4 - 6.25% PWM
// | P4.5|--> CCR5 - 3.125% PWM
// | P4.6|--> CCR6 - 1.5625% PWM
//
// M.Buccini
// Texas Instruments, Inc
// September 2003
// Built with IAR Embedded Workbench Version: 1.26B
// June 2004
// Updated for IAR Embedded Workbench Version: 2.21B
//******************************************************************************
#include <MSP430x14x.h>
void main(void)
{
WDTCTL = WDTPW + WDTHOLD; // Stop WDT
P4DIR |= 0x7e; // P4.1 - P4.6 output
P4SEL |= 0x7e; // P4.1 - P4.6 TBx options
TBCCR0 = 512-1; // PWM Period
TBCCTL1 = OUTMOD_7; // CCR1 reset/set
TBCCR1 = 384; // CCR1 PWM duty cycle
TBCCTL2 = OUTMOD_7;
TBCCR2 = 128;
TBCCTL3 = OUTMOD_7;
TBCCR3 = 64;
TBCCTL4 = OUTMOD_7;
TBCCR4 = 32;
TBCCTL5 = OUTMOD_7;
TBCCR5 = 16;
TBCCTL6 = OUTMOD_7;
TBCCR6 = 8;
TBCTL = TBSSEL_1 + MC_1; // ACLK, up mode
_BIS_SR(LPM3_bits); // Enter LPM3
}
希望高手帮我回答一下,我很急啊! 答 1: //*******************************************************************************
// MSP-FET430P140 Demo - Timer_B PWM TB1-6 upmode, 32kHz ACLK
//
// Description; This program will generate six PWM outputs on P4.x using
// Timer_B in upmode. The value in CCR0, defines the period and the
// values in CCRx the duty PWM cycles. Using 32kHz ACLK as TBCLK,
// the timer period is 15.6ms.
// ACLK = TBCLK = LFXT1 = 32768, MCLK = SMCLK = default DCO ~ 800kHz.
// Normal mode LPM3
// //*External watch crystal installed on XIN XOUT is required for ACLK*//
//
// MSP430F149
// -----------------
// /|\| XIN|-
// | | | 32k
// --|RST XOUT|-
// | |
// | P4.1|--> CCR1 - 75% PWM
// | P4.2|--> CCR2 - 25% PWM
// | P4.3|--> CCR3 - 12.5% PWM
// | P4.4|--> CCR4 - 6.25% PWM
// | P4.5|--> CCR5 - 3.125% PWM
// | P4.6|--> CCR6 - 1.5625% PWM
//
// M.Buccini
// Texas Instruments, Inc
// September 2003
// Built with IAR Embedded Workbench Version: 1.26B
// June 2004
// Updated for IAR Embedded Workbench Version: 2.21B
//******************************************************************************
#include <MSP430x14x.h>
void main(void)
{
WDTCTL = WDTPW + WDTHOLD; // Stop WDT
P4DIR |= 0x7e; // P4.1 - P4.6 output
P4SEL |= 0x7e; // P4.1 - P4.6 TBx options
TBCCR0 = 512-1; // PWM Period
TBCCTL1 = OUTMOD_7; // CCR1 reset/set
TBCCR1 = 384; // CCR1 PWM duty cycle
TBCCTL2 = OUTMOD_7;
TBCCR2 = 128;
TBCCTL3 = OUTMOD_7;
TBCCR3 = 64;
TBCCTL4 = OUTMOD_7;
TBCCR4 = 32;
TBCCTL5 = OUTMOD_7;
TBCCR5 = 16;
TBCCTL6 = OUTMOD_7;
TBCCR6 = 8;
TBCTL = TBSSEL_1 + MC_1; // ACLK, up mode
_BIS_SR(LPM3_bits); // Enter LPM3
}
共2条
1/1 1 跳转至页
回复
打赏帖 | |
---|---|
C语言函数宏的三种封装方式被打赏50分 | |
嵌入式LinuxC语言程序调试和宏使用技巧被打赏50分 | |
让代码中包含最新的编译时间信息被打赏50分 | |
【分享开发笔记,赚取电动螺丝刀】STM32F769LVGL优化显示被打赏26分 | |
rtthread硬件加密--2crc加密分析被打赏10分 | |
【分享开发笔记,赚取电动螺丝刀】STM32F769驱动ST7789以及显示优化被打赏36分 | |
【分享开发笔记,赚取电动螺丝刀】S32K146 PAL模拟I2C驱动适配被打赏23分 | |
我想要一部加热台+电源硬件设计规范被打赏16分 | |
我想要一部加热台+LED背光驱动芯片RT9293知识被打赏18分 | |
【分享开发笔记,赚取电动螺丝刀】S32K146 ADC 模块配置使用被打赏24分 |