当前位置: 首页 > news >正文

MSP430 5438 单片机学习笔记(鱼香茄子)

标签: 单片机  

单片机MSP430F5438学习笔记

通过430一年的学习遇到的很多问题,也收获了很多,以下是学习中遇到的一些问题,和解决方法,还有很多没有整理出来,慢慢整理中。。。。

一、多源中断问题
#pragma vector = PORT2_VECTOR
__interrupt void port2(void)
{
     switch(P2IV)
    {
         case P2IV_P2IFG6:
           P2IFG &=~BIT6;
           P1OUT ^= BIT0;break;           //LED1 亮灭
         case P2IV_P2IFG7:
           P2IFG &=~BIT7;
           P1OUT ^= BIT1;break;           //LED2 亮灭
         default  :break;
      }

}


#pragma vector = PORT2_VECTOR
__interrupt void port2(void)
{  
     if(P1IFG&BIT6){
          P2IFG &=~BIT6;
     }
     if(P1IFG&BIT7){
          P2IFG &=~BIT7;
     }  

}

这两种方法有说明不同吗?上面一种是通过向量中断号进行判断,下面是用中断标志进行判断,在上面的判断中是否需要用软件把中断标志清0

二、关于flash的块擦除
void Seg_Erase(void){
     _DINT();
     WDTCTL = WDTPW + WDTHOLD;
     char *flase_erase;
     flase_erase = (char *)0x8000;                  //指向要檫写的段地址
     while(FCTL3&BUSY);
     FCTL3 = FWKEY;                                 //清除LOCK
     FCTL1 = FWKEY +ERASE;                         //段檫除
     *flase_erase = 0;                              //空写将0写为1
     FCTL3 = FWKEY + LOCK;                          //LOCK置1
     _EINT();
}
请问在进行FLASH段擦除的时候,调用这个函数是只擦除一个字节?要进行整段擦除的时候是用for语句调这个函数128次。
还是调用一次这个函数把128个字节一起擦除。

三、_root问题
    当编译器碰到该条指令的时候就把它进行编译。

四、关于MSP430的中断嵌套,和优先级问题?

五、msp430没有自带的EEPROM,但是information ABCD四个块相当于EEPROM在5系列中他们的地址分别是
A:001800H~00187fH
B:001880H~0018FFH
C: 001900H~00197FH
D: 001980H~0019FFH

六、硬件乘法器
MPY = 125;                           
OP2 = 125;
result = RESHI;
result = (result<<16)|RESLO;

result=125*125;

这两个编译的效率哪个更加高一点,result=125*125编译器会不会直接把它编译成
MPY = 125;                           
OP2 = 125;
result = RESHI;
result = (result<<16)|RESLO;
使用硬件乘法器去算这个值。

七、关于内存的问题
我在用MSP5438片子求1024点FFT的时候,定义
float dataR[1024]={0};
float dataI[1024]={0};在RAN区

定义正余弦表在flash程序存储器里
const  float sin_tab[1024]={.....};
const  float cos_tab[1024]={.....};
做软仿的时候可以计算,用JTAG往片子里下的时候就不行,观察RAM区时候发现,是定义的const  float sin_tab[1024]
const  float cos_tab[1024]本应该在flash区的数据,怎么会出现在RAM区里?导致不能进行仿真。
编译以后这里看所消耗的资源应该是可以的承受的。 
892 bytes of CODE  memory
8194 bytes of CONST memory
8194 bytes of DATA  memory
我是第一次用430的片子,有些问题不太明白,望各位大虾不吝赐教。谢了。

int __low_level_init(void)
{
 float dataR[1024]={0};
 float dataI[1024]={0};
 const  float sin_tab[1024]={.....};
 const  float cos_tab[1024]={.....};
  return (1);
}
然后在
__low_level_init();
void main(void)
.....
这样用吗? 请教!
解决方法:
//防止在编译的时候狗复位
__low_level_init(){
WDTCTL = WDTPW + WDTHOLD;
}
八、CCP捕获问题
void Init_Ta0(void){
      P11DIR |= BIT0 + BIT1 + BIT2;                    // ACLK ,MCLK ,sMCLK  输出方向
      P11SEL |= BIT0 + BIT1 + BIT2;
      P1DIR |= BIT0;
      P2DIR   &= ~BIT1;
      P2SEL   |=  BIT1;                          //配置输入脚的第二功能ccr0捕获
      TA0CCTL0  &=~(CCIS0+CCIS1);                //CCIXA捕获
      TA0CCTL0 |= CM_3 + SCS + CAP;              //在上升沿和下降沿都进行捕获 ,同步信号捕获,捕获模式

      TA0CTL   =  TASSEL_2;                       //SMCLK,
      //TA0CTL  |=  ID_3;                           //输入信号分频
      TA0CTL  |=  MC_2;                           //定时器开始计数(连续计数模式0~0xFFFF)
      TA0CTL  |=  TACLR;                          //计数器清除
      TA0CCTL0 |= CCIE;
      _EINT();

#pragma vector=TIMER0_A0_VECTOR
__interrupt void Timer_A0(void){
   if(TA0CCTL0 & CM1)                        //捕获到下降沿
     {
       TA0CTL  |= TACLR;                     //清定时器
       TA0CCTL0=(TA0CCTL0&(~CM1))| CM0;    //改为上升沿捕获:CM1置零,CM0置一

     }
   else if(TA0CCTL0 & CM_0)                    //捕获到上升沿
     {
       width  = TA0CCR0;                  //记录下结束时间
       TA0CCTL0=(TA0CCTL0&(~CM0))| CM1;   //改为下降沿捕获:CM0置零,CM1置一
     }

}

void main(void){
     WDTCTL = WDTPW + WDTHOLD;                      //关看门狗
     P7SEL   |= 0x03;                                   // XT1 开始振荡
     UCSCTL1 |= DCORSEL_2;                             // 选择DCO频率范围
     UCSCTL3 |= SELREF__REFOCLK;                             // 选择 Fll 参考频率 REFO
     UCSCTL4 = SELM__DCOCLK + SELA__XT1CLK + SELS__DCOCLKDIV;              // 配置 MCLK = DCOC,SMCLK =DCODIV,ACLK=XT1
     while (SFRIFG1 & OFIFG)                          //清除 OFIFG,and  XT1OFFG ,DCOFFG
     {
           UCSCTL7 &= ~(XT1LFOFFG + DCOFFG);
           SFRIFG1 &= ~OFIFG;
     }
     while(1){
      P1OUT ^= BIT0;                            //LED 闪烁,说明没有晶体失效
     for(unsigned  int i=60000;i>0;i--);  

相关文章:

  • 6月2日 周四 晴   MSP430 5438 定时器A TIMER A 新认识
  • msp430的定时器A 划分几个独立时间间隔
  • msp430的中断优先级和中断嵌套(及容易理解错误的说明)_liangchaoxi的IT博客_新浪博客......
  • msp430的中断优先级和中断嵌套(及容易理解错误的说明)
  • 一个字符串,将里面的数字字符和其他字符分开存放的程序_liangchaoxi的IT博客_新浪博客......
  • 一个字符串,将里面的数字字符和其他字符分开存放的程序
  • 关于float与double结果的误差_liangchaoxi的IT博客_新浪博客
  • 关于float与double结果的误差
  • 如何将int整型、float类型(或double)转换成字符串(或CString)_liangchaoxi的IT博客_新浪博客......
  • 如何将int整型、float类型(或double)转换成字符串(或CString)
  • C语言 低通滤波器\带通滤波器\高通滤波器_liangchaoxi的IT博客_新浪博客
  • C语言 低通滤波器\带通滤波器\高通滤波器
  • 如何学习matlab
  • 如何学习matlab_liangchaoxi的IT博客_新浪博客
  • 奈奎斯特抽样定理_liangchaoxi的IT博客_新浪博客
  • 【vuex入门系列02】mutation接收单个参数和多个参数
  • 【知识碎片】第三方登录弹窗效果
  • 2017-09-12 前端日报
  • 2018一半小结一波
  • AHK 中 = 和 == 等比较运算符的用法
  • canvas实际项目操作,包含:线条,圆形,扇形,图片绘制,图片圆角遮罩,矩形,弧形文字...
  • docker容器内的网络抓包
  • exports和module.exports
  • input的行数自动增减
  • JS笔记四:作用域、变量(函数)提升
  • Sass 快速入门教程
  • Vultr 教程目录
  • 二维平面内的碰撞检测【一】
  • 关于Java中分层中遇到的一些问题
  • 机器人定位导航技术 激光SLAM与视觉SLAM谁更胜一筹?
  • 看域名解析域名安全对SEO的影响
  • 聊聊sentinel的DegradeSlot
  • 名企6年Java程序员的工作总结,写给在迷茫中的你!
  • 前端工程化(Gulp、Webpack)-webpack
  • 如何胜任知名企业的商业数据分析师?
  • 想写好前端,先练好内功
  • 写代码的正确姿势
  • 新手搭建网站的主要流程
  • 再次简单明了总结flex布局,一看就懂...
  • Play Store发现SimBad恶意软件,1.5亿Android用户成受害者 ...
  • 容器镜像
  • $.ajax,axios,fetch三种ajax请求的区别
  • (¥1011)-(一千零一拾一元整)输出
  • (17)Hive ——MR任务的map与reduce个数由什么决定?
  • (39)STM32——FLASH闪存
  • (Java)【深基9.例1】选举学生会
  • (附源码)springboot高校宿舍交电费系统 毕业设计031552
  • (附源码)springboot美食分享系统 毕业设计 612231
  • (论文阅读40-45)图像描述1
  • (强烈推荐)移动端音视频从零到上手(下)
  • (小白学Java)Java简介和基本配置
  • (转)h264中avc和flv数据的解析
  • (转)nsfocus-绿盟科技笔试题目
  • (转)如何上传第三方jar包至Maven私服让maven项目可以使用第三方jar包
  • (转)为C# Windows服务添加安装程序