共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 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
与电子爱好者谈读图二被打赏50分 | |
【FRDM-MCXN947评测】Core1适配运行FreeRtos被打赏50分 | |
【FRDM-MCXN947评测】双核调试被打赏50分 | |
【CPKCORRA8D1B评测】---移植CoreMark被打赏50分 | |
【CPKCORRA8D1B评测】---打开硬件定时器被打赏50分 | |
【FRDM-MCXA156评测】4、CAN loopback模式测试被打赏50分 | |
【CPKcorRA8D1评测】--搭建初始环境被打赏50分 | |
【FRDM-MCXA156评测】3、使用FlexIO模拟UART被打赏50分 | |
【FRDM-MCXA156评测】2、rt-thread MCXA156 BSP制作被打赏50分 | |
【FRDM-MCXN947评测】核间通信MUTEX被打赏50分 |