|
EDA365欢迎您!
您需要 登录 才可以下载或查看,没有帐号?注册
x
#include "msp430g2553.h"
\& L% k) ?; A) w x//p1.2输出50%方波,p2.1和2.4输出50%和25%波形
+ t( |$ z* c4 ?& K1 _2 _, g: Xvoid main (void) 9 t' }8 q! {7 J+ J
{
( V D- Q! T1 G2 `2 y) W9 k- @ WDTCTL= WDTPW + WDTHOLD; //设置看门狗控制寄存器,关看门狗 5 a8 t4 ^. ]: G) m/ [6 S- c+ i) ~5 I
" H* R4 Y8 w' C7 Y# g //定时器A0的
" d' b, o; ^" I4 W TACTL = TASSEL_1 +TACLR+MC_1; // 设置定时器A控制寄存器,
8 j! w K" i4 F8 I( Z: D, _, l& q+ k // TASSEL_1选择辅助时钟ACLK,TASSEL_2选择子系统时钟SMCLK;
0 k0 N4 |8 S% y // TACLR=0x0004,清除定时器A计数器
& A' O8 k% ?$ G ( {9 J3 {7 H |1 S
CCR0 =12000; //设置捕获/比较寄存器,初始值为12000,对于12KHz的频率,周期相当于1s 0 o. H8 T% C* O7 V2 K9 c* [
CCR1=6000; //占空比50%
3 T; n8 e, ^3 A! r: p% X& T( f CCTL1=OUTMOD_3;//置位复位,TAR等于CCR1时置位1,等于CCR0复位0,7 q/ M, f' w7 `" ~% L f8 T' Z
//增计数时相当于0到CCR1为低电平,ccr1到CCR0为高电平,( o# U3 E' D$ W" ?
//OUTMOD_7与之相反
, v5 ?7 s8 H2 _& |6 E
; E1 ~% [1 b0 \1 l9 R CCR2=3000; //占空比25%,错了,没有TA0.2
: f/ T* ~( D4 q+ l! b CCTL2=OUTMOD_3;//置位复位,TAR等于CCR1时置位1,等于CCR0复位0,3 V7 {; b% y h# |9 `( _( Y/ E
//增计数时相当于0到CCR1为低电平,ccr1到CCR0为高电平,
: q' O9 h B+ u //OUTMOD_7与之相反
& X6 e8 J. |! _ t6 ~+ t/ C P1SEL |=BIT2; `- J7 R" D, v
P1DIR |=BIT2; //输出 TA0.1( w1 n9 T5 t. c* e. e$ m8 s- h5 Z. F
! i% p) F1 T4 s( c0 E - M0 U0 F2 }" n X N8 O/ }
3 o7 F0 F" S& M# f //定时器A1的( U( @# A- M. G; ~+ t! @
TA1CTL = TASSEL_1 +TACLR+MC_1; // 设置定时器A控制寄存器, . i% X3 w; A c9 P( o
// TASSEL_1选择辅助时钟ACLK,TASSEL_2选择子系统时钟SMCLK;
% R( `( t8 A1 P8 X2 e5 ] // TACLR=0x0004,清除定时器A计数器
+ l9 Y9 v$ _- P4 v, y; K- u9 ^ TA1CCR0 =12000; //设置捕获/比较寄存器,初始值为32768,对于32768Hz的频率,周期相当于1s * g: @! ^, h x% k* m' u7 Z) @% y
5 \5 c. v! ^7 U6 u$ ~9 T TA1CCR1=6000; //占空比50%
Z7 k" @% \+ b7 ~1 F( V TA1CCTL1=OUTMOD_3;//置位复位,TAR等于CCR1时置位1,等于CCR0复位0,6 s$ ~& v+ n, \* o2 p1 v
//增计数时相当于0到CCR1为低电平,ccr1到CCR0为高电平,
9 h' g2 \- Z3 ]) w0 w //OUTMOD_7与之相反
6 _- f; ~% M: h8 |& \9 { TA1CCR2=3000; //占空比25%" ^# _2 a' R# D. M, N" J t
TA1CCTL2=OUTMOD_3;//置位复位,TAR等于CCR1时置位1,等于CCR0复位0,
: u* A' B# m+ I% f$ w) A //增计数时相当于0到CCR1为低电平,ccr1到CCR0为高电平,' P) x2 Y V2 Q" f/ q. T1 _
//OUTMOD_7与之相反4 y* V, \4 _& o5 K$ @! J$ b& \2 o! L! L
P2DIR |=BIT1+BIT4; //输出 TA2.1和TA2.2, |( \5 F2 G3 `9 l0 I; L
P2SEL |=BIT1+BIT4; ! x# A* F# R9 U9 @2 y- Z$ g
while(1) //无限次while循环 * Y8 Q* r4 E0 Q1 g$ M+ Q- \7 K
{
8 M$ A9 h# Y2 h" X6 h! J! H& G _NOP();
; E1 O" Z2 r! C6 s, c }
9 \) H3 S$ h6 J M% e1 }} |
|