MSP430 5438 单片机学习笔记

发布者:Harmonious88最新更新时间:2015-11-10 来源: eefocus关键字:MSP430  单片机  学习笔记 手机看文章 扫描二维码
随时随地手机看文章
通过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的片子,有些问题不太明白,望各位大虾不吝赐教。谢了。[page]

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--);       // 延迟
     }
}

我用MSP5438的P2.1口做捕获试验,我觉得程序没问题,输入8HZ的方波,但是程序就是不进中断,很奇怪,请大家帮我看看是上面问题?
答案:设置错误。

九、关于中断
由于项目需要第一次使用MSP430单片机,通过半个月的学习,在各位朋友的帮助下小有心得,今天来谈谈中断,希望能和大家讨论,有说错的也请大家指证。
MSP430的中断和51,PIC16系列的比较
MSP430:
当同时有多个中断来的时候才有优先级的考虑(优先级顺序可查看向量表)在头文件中已经定义
有中断响应以后自动关闭总中断,这个时候即使来更高优先级的中断都不会响应
要中断嵌套的话,就必须在中断中打开总中断
msp430的指令中,DINT和EINT分别指关和开所有中断。
 
实现中断嵌套需要注意以下几点:
1、430默认的是关闭中断嵌套的,除非你在一个中断程序中再次开总中断EINT,当然各个请求允许标志位要置起来;
2、当进入中断程序时,只要不在中断中再次开中断,则总中断是关闭的,此时来中断不管是比当前中断的优先级高还是低都不执行;
3、若在中断A中开了总中断,则可以响应后来的中断B(不管B的优先级比A高还是低),B执行完再继续执行A。注意:进入中断B后总中断同样也会关闭,
如果B中断程序执行时需响应中断C,则此时也要开总中断,若不需响应中断,则不用开中断,B执行完后跳出中断程序进入A程序时,总中断会自动打开;
4、若在中断中开了总中断,后来的中断同时有多个,则会按优先级来执行,即中断优先级只有在多个中断同时到来时才起做用!中断服务不执行抢先原则。
5、对于单源中断,只要响应中断,系统硬件自动清中断标志位,对于TA/TB定时器的比较/捕获中断,只要访问TAIV/TBIV,标志位被自动清除;
对于多源中断要手动清标志位,比如P1/P2口中断,要手工清除相应的标志,如果在这种中断用"EINT();"开中断,而在打开中断前没有清标志,就会有相同的中
断不断嵌入,而导致堆栈溢出引起复位,所以在这类中断中必须先清标志再打开中断开关.
但是对于多源中断用向量方式这一点我不太明白,在例程里有这么一个例子
例1:#pragma vector = PORT2_VECTOR
__interrupt void port2(void)
{
     switch(P2IV)
    {
         case P2IV_P2IFG6:
           P1OUT ^= BIT0;break;           //LED1 亮灭
         case P2IV_P2IFG7:
           P1OUT ^= BIT1;break;           //LED2 亮灭
         default  :break;
      }

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

}
当使用向量方式的时候在例1中没有用软件清除中断标志,难道是使用向量方式硬件把它清除了?在这个里面开总中断会影响程序堆栈溢出吗?这个我没有验证过。
而在例2中清楚了,可以知道可以在里面打开中段嵌套。

PIC:
PIC的中低档单片机的中断入口地址只有一个,0004H,在有多个中断源来的时候,从0004H这个入口地址进入,然后软件判断优先级,PIC16的各个可屏蔽
中断的有先级是相同的,在中断中只有通过软件来判断有先级,进入中断的时候跟430一样把中断关闭(这一步是硬件来关闭的),当这个时候有其他中断

源来的时候,把标志置1,等结束完当前服务程序以后,在响应新的中断请求。
51:
51于430一样支持中断嵌套,可以通过专门的寄存器设置中断的优先级,只要堆栈不溢出可以一直嵌套。和430的区别是430在中断优先级上,430可以被低优先级别
的中断嵌套,而51不能被比自己低的优先级别的中断所嵌套。51必须软件把标志位清除。

此贴只表示个人观点,我提出的问题也希望能够得到解答,在此还是希望多得到各位大虾的指点。

十,bootload问题解决
在程序中实现地址跳转使用函数指针,使用嵌套汇编的跳转的方法会出现问题
typedef void (*pfunction)(void);
pfunction pMyreset=(pfunction) 0x453d2;
        pMyreset();

十一、fft的疑惑
请教圈圈,我在用软件模拟fft变换的时候这样做,但是分析出来的数据放到Re中,结果是Re[0]=1299,Re[1]=0,
在Re[8]=199,基波分量怎么会跑到Re[8],硬件做出来的结果也往数组的高位跑。不是很懂,为什么单周期是号的
换到多周期的时候会位子会发生变化。在做硬件的时候连续8周期的采样应该是没有问题的,下面的核心代码用的
是圈圈写的,我自己写的那段做出的结果也是这样,昨天还以为是我的程序出错了。
 for(uint16 j=0;j<1024;j++){
   dataR[j]=200*cos(6.28/128*j)+1300;
  }
  FftInput(dataR);       //位倒序
  FftExe(dataR,Re,Im);   //做FFT运算
  Re[0]=(LEN_TYPE )Re[0]/1024;
  for (i=1;i<1024;i++){
    Re[i]=(LEN_TYPE )(sqrt((Re[i]>>9)*(Re[i]>>9)+(Im[i]>>9)*(Im[i]>>9)));

/////////////////////////版权所有,如需转载注明出处鱼香茄子/////////////////////////////////////

关键字:MSP430  单片机  学习笔记 引用地址:MSP430 5438 单片机学习笔记

上一篇:一个字符串,将里面的数字字符和其他字符分开存放的程序
下一篇:P3DIR|=BIT0、P3OUT&=~BIT0 的含义

推荐阅读最新更新时间:2024-03-16 14:38

基于AtmelAVR Flash微控制器的基本原理及在汽车中的应用研究
  车上可自动关闭的电动车窗或车门设备潜藏着卡死,挤压以及可能伤人的危险。它们必须能够反向移动以防止马达所施加的力超出正常限制。这种特性意味着必须持续监视速度、电流和玻璃的位置。   现代汽车中的电动设备   目前,在高端客用汽车中电子组件和系统在成本中已占20%以上。增加电子设备的数目可以更好的控制传感器和致动器,从而增强汽车的舒适性和安全性。可以预测,大部分的中等或汽车将会系统性的装备电动车窗或车门系统。这些设备中的绝大多数是全自动的,这意味着它们必须附带安全系统以防止伤人或机械故障已有法规设立了电动系统必须遵守的规则。这一点在车窗的升起和车门的滑动上尤其正确的。这篇应用笔记介绍了如何实现一个防夹算法,该算法初是用于电动车
[单片机]
基于AtmelAVR Flash<font color='red'>微控制器</font>的基本原理及在汽车中的应用研究
内嵌微控制器的无线数据发射器的特性及应用
    摘要: 简要介绍内嵌AVR RISC微控制器的无线数据发射器AT86RF401的功能、内部结构、引脚排列及典型的应用电路。     关键词: 线数据传输 无线发射器 微控制器 概 述 AT86RF401是单片机集成内嵌AVR RISC微控制器的RF无线数据发射器,输出频率范围为250~450MHz,最大输出功率+6dBm,发射率10Kband。芯片内嵌AVR RISC微控制器、2KB(1K×16b)的Flash程序存储器、128B(字节)的可下载的EEPROM数据存储器、128B的RISC SRAM、看门狗定时器、6个通用I/O、在系统可编程。工作电压2.0~
[嵌入式]
基于MSP430F149的数据转发器设计
摘要:以MSP430F149单片机为核心,设计一种双串行通信的电能表自动抄收系统的转发器,给出转发器的硬件结构框架与软件设计方案。转发器通过三种通信方式实现主机与电表抄表器的数据通信。 关键词:转发器 串行通信 MSP430 微控制器 概述 目前大量存在的人工抄表的方法已远不能适应现代化管理的需要,并由此带来的线损率的增高也必然影响电力行业的发展。线损率较高的主要原因之一就是抄表、计算和管理手段的落后,管理损耗增大。如果采用电能表自动抄收系统,不仅可以大大提高电网运行的可靠性,而且可以充分利用现有设备的能力,降低劳动强度。该系统主要由电表抄表器(数据采集)、数据转发器(数据传输)和主机(数据处理)三大部分组成。本文主要设计
[应用]
关于stm32的USB学习笔记之USB_HW.c
#include stm32f10x_lib.h #include stm32f10x_map.h #include usbreg.h #include usbuser.h #include usbcore.h #include usb_hw.h #define _DEBUG_ #include debug.h #define USB_EP_NUM 4 /*端点缓冲区的开始地址 *因为每个缓冲块都需要一个端点描术表 *而所有的端点描述表放在,USB缓冲区的首部 *此地址是相对于USB缓冲区的地址,我认为加上Offset更好些 *这里使用2个端点 *端点0与端点1 *此时EP_BU
[单片机]
STM32NET学习笔记 UDP部分
1.前言 嵌入式以太网开发是一个很有挑战性的工作。通过几个月的学习,我个人觉得大致有两条途径。第一条途径,先通过高级语言熟悉socket编程,例如C#或C++,对bind,listen,connect,accept等函数熟悉之后,应用 lwIP。第二种途径,通过分析嵌入式以太网代码,结合TCPIP协议栈规范逐步实践代码。第一种途径效率高,开发周期短,编写出来的代码性能稳定,第二种途径花的时间长,开发出来的代码功能不完善,但是由于紧紧结合TCPIP规范,可以了解的内容较多,适合学习。本文通过分析和修改AVRNET源码,逐步实现TCPIP协议栈的各个子部分,包括ETHERNET部分,ARP部分,IP部分,ICMP部分,UDP部分
[单片机]
AVR单片机中断
系统在正常运行主程序时,如果突然有一个重要的任务要马上处理,那么系统就要保存现在的工作,然后再去处理这个任务,执行这个重要任务完毕以后再返回原来的主程序继续运行,这就是中断。 主程序一旦进入中断服务程序,那么AVR芯片将自动的关闭全局中断,在这个期间不再执行其它的中断请求,直到中断程序结束以后芯片才自动的重新开放全局中断。(注意,在这个期间某些中断请求可能会被丢弃,某些请求会留下中断请求标致,一旦当前的中断执行完毕,这个有中断标致的请求就有可能马上得到响应,如INT0的下降沿触发就会留下中断请求标致,而低电平触发就不会流下中断请求标致)。如果你想在执行中断服务程序时响应另外一个更重要的中断,那么就要在中断服务程序中加入一条打开全
[单片机]
AVR<font color='red'>单片机</font>中断
PIC16C65单片机在扫描隧道显微镜中的应用
1概述 扫描探针显微镜(STM)是纳米科技发展中最重要的工具。他基于量子力学中的隧道贯穿理论,其核心是一个能在金属样品表面上扫描并与样品间有一定的偏置电压的直径为原子尺度的针尖。当样品与针尖之间的距离非常接近时,电子就可以通过隧道效应由针尖转移到样品或从样品转移到针尖,从而形成隧道电流。隧道电流的大小与他们的间距成负指数关系[1]: I∝B exp(-KS)(1) 其中:I为样品与针尖之间的隧道电流; B为与样品和针尖之间的偏压有关的系数; K为与自由电子的质量及有效平均势垒高度等有关的系数; S为样品与针尖之间的隧道电流。 扫描隧道显微镜的基本构成可以分为3个部分:头部系统、电子学系统、计算机系统。头部系统中的扫描器是一
[单片机]
PIC16C65<font color='red'>单片机</font>在扫描隧道显微镜中的应用
STM32单片机FSMC的使用解析
在做项目的过程中遇到了这个问题,感觉文章写得不错,共享给对FSMC的使用怀有疑惑的同伴们! LCD有如下控制线: CS:Chip Select片选,低电平有效 RS:Register Select寄存器选择 WR:Write写信号,低电平有效 RD:Read读信号,低电平有效 RESET:重启信号,低电平有效 DB0-DB15:数据线 假如这些线,全部用普通IO口控制。根据LCD控制芯片手册(大部分控制芯片时序差不多): 如果情况如下: DB0-DB15的IO全部为1(表示数据0xff),也可以为其他任意值,这里以0xff为例。 CS为0(表示选上芯片,CS拉低时,芯片对传入的数据才会有效) RS为1(表示DB0-15上传
[单片机]
STM32<font color='red'>单片机</font>FSMC的使用解析
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved