fet140_tb_pwm01.c

来自「msp430f14x 系列片内外设的实例代码」· C语言 代码 · 共 56 行

C
56
字号
//*******************************************************************************
//  MSP-FET430P140 Demo - Timer_B PWM TB1-6 upmode, DCO SMCLK
//
//  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 ~ 800kHz SMCLK as TBCLK,
//  the timer period is ~ 640us. 
//  ACLK = na, SMCLK = MCLK = TBCLK = default DCO ~ 800kHz. 
//
//               MSP430F149
//            -----------------
//        /|\|              XIN|-  
//         | |                 | 
//         --|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_2 + MC_1;              // SMCLK, up mode
  
  _BIS_SR(CPUOFF);                      // Enter LPM0
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?