4284|4

2

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

关于MSP430F6736 UCS的问题! [复制链接]

用6736做了一块板子,在进行UCS的初始化时,运行初始化代码如下:
PJDIR |= BIT0 | BIT1 | BIT3;           // ACLK, MCLK, SMCLK set out to pins
PJSEL |= BIT0 | BIT1 | BIT3;           // PJ.0,1,3 for debugging purposes.
UCSCTL6 &= ~(XT1OFF);                   // Enable XT1
   UCSCTL6 |= XCAP_1;                      // Internal load cap
   // Loop until XT1, XT2 & DCO fault flag is cleared
   do
   {
       UCSCTL7 &= ~(XT2OFFG | XT1LFOFFG | DCOFFG);
       // Clear XT2,XT1,DCO fault flags
       SFRIFG1 &= ~OFIFG;                  // Clear fault flags
       //for(unsigned int i=0;i<50000;i++);
   }
   while (SFRIFG1 & OFIFG);              // Test oscillator fault flag

虽然能够从while( SFRIFG1 & OFIFG )里面跳出来,可是OFIFG的值仍然是1,同时DCOFFG的值也是1,从PJ.3管脚也看不到32k的波形。换了好几个晶振了仍然不行,这是为什么,OFIFG置位了自检还能通过?
同时我看到了UG上说,DCO=0或者31时DCOFFG会置位,可是DCO的值似乎不是用户软件可以设置的啊,请大神赐教啊!
补充一个,在单步运行时,运行完了SFRIFG1 &= ~OFIFG; 这一句之后,UCSCTL0寄存器会变成0x00F8也就是DCO的值变成了0。DCOFFG为1,XT1LFOFFG和XT2OFFG为0。在清空OFIFG之前,从PJ管脚读出来的ACLK,SMCLK和MCLK都是正确的。执行清空操作之后就不对了。

最新回复

如果跑25m不设置内核电压有没有异常呢?  详情 回复 发表于 2014-12-20 11:48
 
点赞 关注

回复
举报

34

帖子

0

TA的资源

一粒金砂(中级)

沙发
 
请问楼主这个问题解决了吗,我也遇到了,不知道那里出问题了,求赐教。
 
 

回复

1560

帖子

24

TA的资源

五彩晶圆(初级)

板凳
 
应该支持32768HZ晶振啊。既然这段程序能通过while循环,OFIFG怎能够又变了呢。奇怪,既然能跳出,很可能是已经配置成功了。楼主试试定时器中断,看时间对不对。
 
个人签名这孩子,成熟的象征,理智的典范。
 
 

回复

180

帖子

3

TA的资源

一粒金砂(中级)

4
 
我发个我的配置吧,我用的5438A,时钟配置应该差不多,因为我用的25M高频晶振,要设置内核电压。。。
  1.   WDTCTL= WDTPW + WDTHOLD; // 关看门狗
  2.   PMMCTL0_H=0xA5;//开PMM电源管理                             
  3.   SVSMLCTL|=SVSMLRRL_1+SVMLE;//配置SVML电压
  4.   PMMCTL0=PMMPW+PMMCOREV_2;//配置内核电压
  5.   while((PMMIFG&SVSMLDLYIFG )==0);//等待设置完成
  6.   PMMIFG&=~(SVMLVLRIFG + SVMLIFG+SVSMLDLYIFG);
  7.   if((PMMIFG&SVMLIFG)==1)//判断内核电压是否上升到VSVML
  8.   while((PMMIFG&SVMLVLRIFG)==0);//如果没有等待
  9.   SVSMLCTL&=~SVMLE;//关掉SVML模块
  10.   PMMCTL0_H =0X00;//锁存配置
  11.   P5SEL |=0x0C; // 选择 XT2
  12.   UCSCTL6&=~XT2OFF; //使能XT2
  13.   UCSCTL3|=SELREF_2; // FLLref = REFO
  14.   UCSCTL4|=SELA_2; // ACLK=REFO,SMCLK=DCO,MCLK=DCO
  15.   do
  16.   {
  17.     UCSCTL7&=~(XT2OFFG+XT1LFOFFG+DCOFFG);
  18.     SFRIFG1&=~OFIFG;// 清除失效标志位
  19.   }while(SFRIFG1&OFIFG);
  20.   UCSCTL4|=SELS_5+SELM_5;// SMCLK=MCLK=XT2
  21.   //UCSCTL5|=DIVM_1+DIVS_2;
复制代码
 
 
 

回复

9

帖子

0

TA的资源

一粒金砂(初级)

5
 
如果跑25m不设置内核电压有没有异常呢?
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表