[转载]MSP430 5438 单片机学习笔记(鱼香茄子)

2019-08-08 21:57发布

通过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个字节一起擦除。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
18条回答
meishizhaoshi
2019-08-09 13:12
但是对于多源中断用向量方式这一点我不太明白,在例程里有这么一个例子
例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)));
/////////////////////////版权所有,如需转载注明出处 鱼香茄子/////////////////////////////////////

一周热门 更多>