共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 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| OK1126B-S开发板下以导航按键控制云台/机械臂姿态调整被打赏¥29元 | |
| 【树莓派5】便携热成像仪被打赏¥36元 | |
| 【树莓派5】环境监测仪被打赏¥35元 | |
| OK1126B-S开发板下多时段语音提示型电子时钟被打赏¥27元 | |
| OK1126B-S开发板下函数构建及步进电机驱动控制被打赏¥25元 | |
| 【S32K3XX】LPI2C 参数配置说明被打赏¥20元 | |
| OK1126B-S开发板的脚本编程及应用设计被打赏¥27元 | |
| 5v升压8.4v两节锂电池充电芯片,针对同步和异步的IC测试被打赏¥35元 | |
| 【S32K3XX】S32DS LPI2C 配置失败问题解决被打赏¥22元 | |
| 【S32K3XX】FLASH 的 DID 保护机制被打赏¥19元 | |
我要赚赏金
