亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? sa9904_spi_read.c

?? 電能計量芯片SA9904的讀寫程序
?? C
字號:
#include  <msp430x44x.h>
#include  <in430.h>
#include  <math.h>
#include  <stdio.h>
#include  <stdlib.h>

#define VLD_1_9V            (0x10)  //1.9V
#define VLD_2_1V            (0x20)  //2.1V
#define VLD_2_2V            (0x30)  //2.2V
#define VLD_2_3V            (0x40)  //2.3V
#define VLD_2_4V            (0x50)  //2.4V
#define VLD_2_5V            (0x60)  //2.5V
#define VLD_2_65V           (0x70)  //2.65V
#define VLD_2_8V            (0x80)  //2.8V
#define VLD_2_9V            (0x90)  //2.9V
#define VLD_3_05V           (0xa0)  //3.05V
#define VLD_3_2V            (0xb0)  //3.2V
#define VLD_3_35V           (0xc0)  //3.35V
#define VLD_3_5V            (0xd0)  //3.5V
#define VLD_3_7V            (0xe0)  //3.7V
#define SVSOFF              (0x0)  //VLD=0;

#define POUT BIT4
#define QOUT BIT7

unsigned int Flag_Time=0;//時間標志字.BIT0位作125ms周期標志
unsigned int Flag_State=0;//狀態/事件標志字.BIT0標志有主電源;BIT1標志表示剛上電,將讀取的
                          //數據直接送Data_SA9904_Up[12];BIT2表示讀SA9904寄存器完成,
                          //等待處理;
unsigned char F50_Num=0;  //F50計數器(每5個F50脈沖啟動一次讀SA9904過程)
unsigned char Spi_Num1=0; //接收每個SA9904寄存器數據時的順序(0-3表示高位到低位)
unsigned char Spi_Num0=0; //SA9904寄存器順序( 0-->11 )
long          pl=0;       //讀SA9904時數據裝配單元
long          Sa9904_N=0;
long          Sa9904_NM=0;

long Data_SA9904_Up[12];
long Data_SA9904_Now[12];

static unsigned char P,Q;

void Power_Stste(void);
void Pulse_Compute(void);


void Delay(unsigned int i)
{
	for(;i!=0;i--);
}

void main(void)
{ 
	WDTCTL = WDTPW + WDTHOLD;
	FLL_CTL0 =XCAP18PF;       //配置晶振負載電容
	
	//TA定時器控制
	TACTL =MC1 +TASSEL_1;     //選擇ACLK時鐘
	
	BTCTL=BT_fLCD_DIV64+BT_ADLY_125;//BASIC Timer1定時器125ms中斷周期
	//LCDCTL=LCDON+LCD4MUX+LCDSG0_4;
	IE2 |= BTIE;
	//TACCTL1 = CCIE+CAP+CM_1;//捕獲方式,允許中斷,異步捕獲,輸入信號源為CCI1A,上升沿捕獲
	 _EINT();
    
    for(;;)
    {
    	if(Flag_State&BIT0)//有電
    	{
    		if(Flag_State&BIT2)//已經讀完
    		{
    			if(Flag_State&BIT1)//是上電后首次讀操作
    			{
    				unsigned int i;
    				Flag_State &= ~BIT1;
    				for(i=0;i<12;i++)
    					Data_SA9904_Up[i]=Data_SA9904_Now[i];//存底數
    			}
    			else
    			{
    				//確定5個F50的有功無功速率(兼考慮潛動)
    				Pulse_Compute();
    			}
     			Flag_State &= ~BIT2;//清SPI讀完標志
    		}
    		else
    		{
    			
    		}
    	}
    	
    	if(Flag_Time&BIT0)//每125ms檢測一次電源狀態
    	{
			Power_Stste();
			Flag_Time&=~BIT0;
    	}
    	_BIS_SR(LPM0_bits);
    }
}

//在主程序中檢測電源狀態,負責上電初始化,掉電保存數據等工作
void Power_Stste(void)
{
    SVSCTL |= (VLD_3_2V);//判斷是否上電(ATT3221改成3.5V輸出)  VLD_3_2V
    Delay(20);//延時,等待SVS電路正常工作
    if( !(SVSCTL & SVSOP) )//當前有電源!!!
    {
    	if( !(Flag_State&BIT0) )
    	{
    		//因為Flag_State的BIT0等于0,表明系統剛上電
			SCFQCTL = SCFQ_4M;
			FLL_CTL1 &= ~XT2OFF;       //啟動XT2高速晶振
    		do FLL_CTL0 &= ~XT2OF;
    		while(FLL_CTL0 & XT2OF);
    		Delay(100);
    		FLL_CTL0 &= ~XT2OF;
    		FLL_CTL1 |= SELS;
			
			//POUT,QOUT為輸入方向時滅,輸出方向時亮
			P3DIR &= ~POUT;
			P2DIR &= ~QOUT;
			//增加讀FM24CL16程序(初始化,累計校驗(RAM和24CL16數據))
    		//...............
    		
    		//SA9904的CS端為0
    		P4OUT &= ~BIT2;  //SA9904的CS端等于0
    		P4DIR &= ~BIT4;
    		P4DIR |= BIT2+BIT3+BIT5;
    		P4SEL |= BIT3+BIT4+BIT5;
    		UCTL1 = CHAR+SYNC+MM;//CHAR表示8位模式,SYNC表示當前是SPI模式,MM表示主機模式
			UTCTL1 = SSEL1+SSEL0+STC+CKPL;//SMCLK時鐘源+3線模式+下降沿開始發數據
			UBR01  = 10;//20K
			UBR11  = 0;
			UMCTL1 = 0;
			
			//P1.3啟動讀SA9904周期
			//P1IES &= ~BIT2;//上升沿觸發中斷11968
			//P1IFG &= ~BIT2;
			//P1IE |= BIT2;
			
			//系統剛上電后,啟動一次讀SA9904,將讀取的數據存放到
			F50_Num=4;  //往后第一個F50立即讀數據
			Flag_State |= BIT1;//讀得的數據直接送Data_SA9904_Up[12],不需要運算
			Sa9904_N=0;
			Sa9904_NM=0;
    	}
    	else//系統上一次檢測時有電,當前仍然有電
    	{
    		
    	}
    	Flag_State |= BIT0;//有主電源
    }
    else//系統沒有電源
    {
    	if( !(Flag_State&BIT0) )
    	{
    		//因為Flag_State的BIT0等于0,表明系統維持停電狀態
    		
    	}
    	else
    	{
    		//因為Flag_State的BIT0等于1,表明系統剛停電
    		//關閉指示燈
    		P3DIR &= ~POUT;
    		P2DIR &= ~QOUT;
    		
    		//增加關閉485的控制端,發送端,紅外發送端,寫累計到24CL16等內容,取消禁止SA9904
    		//....................
    		
    		//F50計數清0
    		P1IE &= ~BIT2;//禁止F50觸發中斷
    		F50_Num = 0;
    		Flag_State &= ~BIT1;//禁止讀SA9904
    		SCFQCTL = SCFQ_512K;
    		
    	}
    	Flag_State &= ~BIT0;//沒有主電源
    }
    SVSCTL = SVSOFF;//關閉電源檢測電路,降低功耗
}

void Spi_Start(void)
{
	P4DIR |=BIT2+BIT3+BIT5;
	P4SEL |=BIT3+BIT4+BIT5;    
	IFG2 &= ~(URXIFG1+UTXIFG1);//清接收中斷標志,清發送中斷標志
	
	UTCTL1 = SSEL1+SSEL0+STC+CKPL;  // 下降沿開始發數據
	P4OUT |= BIT2;
	ME2 |= USPIE1;
	IE2 |= UTXIE1;//允許發送中斷
	U1TXBUF = 0x01;//啟動發送過程,發送高字節地址
}

#pragma vector=PORT1_VECTOR
__interrupt void  SPI_START(void)
{
	//while( (UTCTL1&TXEPT)==0 );
	F50_Num++;
	if(F50_Num>4)
	{
		F50_Num=0;
		//Spi_Start();
	}
	P1IFG &= ~BIT2;//清P1.2中斷標志
}


#pragma vector=BASICTIMER_VECTOR
__interrupt void  Clock(void)
{
	Flag_Time |=BIT0;
	Spi_Start();
	_BIC_SR_IRQ(LPM0_bits);
}

#pragma vector=USART1TX_VECTOR
__interrupt void  SPI_TXD(void)
{
	IFG2 &= ~UTXIFG1;
	U1TXBUF = 0x80;
	while((UTCTL1&TXEPT)==0);//等待發送完畢
	
	IE2 &= ~UTXIE1;//禁止發送中斷
	IFG2 &= ~(URXIFG1+UTXIFG1);
	IE2 |= URXIE1;//允許接收中斷
	UTCTL1 = SSEL1+SSEL0+STC;//上升沿發數據,下降沿接收數據
	ME2 |= USPIE1;
	Spi_Num1=0;
	Spi_Num0=0;
	pl=0;
	U1TXBUF = 0;   //發送偽數據
}


#pragma vector=USART1RX_VECTOR
__interrupt void  SPI_RXD(void)
{
	unsigned long x;
	x=(unsigned long)U1RXBUF;
	pl |= x;
	Spi_Num1++;
	if(Spi_Num1>=3)
	{
		Spi_Num1=0;
		Data_SA9904_Now[Spi_Num0++]=pl;
		pl=0;
		if(Spi_Num0>=12)
		{
			P4OUT &= ~BIT2;
			P4DIR &= ~(BIT3+BIT5);
			ME2 &= ~USPIE1;
			IE2 &= ~URXIE1;
			Flag_State |= BIT2;//接收完畢,等待處理
			_BIC_SR_IRQ(LPM0_bits);//在主循環處理
		}
		else
		{
			U1TXBUF = 0;
		}
	}
	else
	{
		pl<<=8;
		U1TXBUF = 0;
	}
}

unsigned char Sa9904_Data_right(void)
{
	unsigned int i;
	for(i=3;i<12;i=i+4)
	{
		if(Data_SA9904_Now[i]&0x3fc00)
			return 0;
	}
	return 1;
}
#define Pulse_N  261818   //每脈沖的讀數  

void Pulse_Compute(void)
{
	unsigned int i;
	long x,y=0;
	
	//驗證讀出的數據是否合法
	if(Sa9904_Data_right())
	{
		//有功脈沖計算,計算在一次間隔采樣中總的讀數
		for(i=0;i<=8;i=i+4)    //3相有功總加
		{
			x=Data_SA9904_Now[i]-Data_SA9904_Up[i];  //A,B,C相有功
			
			if( (x<0)&&(x<-400000) )
			{
				x+=0x1000000;     //正向
			}
			else if( (x>0)&&(x>400000) )
			{
				x=x-0x1000000;    //反向
			}
			y+=x;
			Data_SA9904_Up[i]=Data_SA9904_Now[i];
		}
		if(y<0)
			y=-y;
		if(y<150)
			y=0;
		Sa9904_N+=y;
		
		x=Pulse_N-Sa9904_N;
		if(x<=0)
		{
			P=1;
			TACCTL1=CCIE+CCIFG;//立即發送脈沖
		}
		else
		{
			if( (y!=0)&&(x<=y) )
			{
				x*=4096/y;
				TACCR1=TAR+(unsigned int)x;
				P=1;
				TACCTL1=CCIE;
			}
			else
			{
				//TACCTL1=0;
			}
		}
		
		//無功計算
		for(i=1;i<=9;i=i+4)
		{
			x=Data_SA9904_Now[i]-Data_SA9904_Up[i];
		
			if( (x<0)&&(x<-400000) )
			{
				x+=0x1000000;
			}
			else if( (x>0)&&(x>400000) )
			{
				x=x-0x1000000;
			}
			if( (x>400000)||(x<-400000) )
				x=0;
			y+=x;
		}
		if(y<0)
			y=-y;
		if(y<150)
			y=0;
		Sa9904_NM+=y;
		
		x=Pulse_N-Sa9904_NM;
		
		if(x<=0)
		{
			Q=1;
			TACCTL2=CCIE+CCIFG;//立即發送脈沖
		}
		else
		{
			if( (y!=0)&&(x<y) )
			{
				x*=4096/y;
				TACCR2=TAR+(unsigned int)x;
				Q=1;
				TACCTL2=CCIE;
			}
			else
			{
				//TACCTL2=0;
			}
		}
		//脈沖輸出處理結束
	}
}

//TA中斷服務函數
#pragma vector=TIMERA1_VECTOR
__interrupt void  Timer(void)
{
	//_EINT();????????????????????
	switch (TAIV)
	{
		case 2:  //CCR1
		if( P )
		{
			TACCR1 =TAR+2950;
			P=0;
			Sa9904_N-=Pulse_N;
			P3DIR |= POUT;
		}
		else
		{
			P3DIR &= ~POUT;
			TACCTL1 &= ~CCIE;
		}
        break;
        
        case 4:  //CCR2
		if( Q )
		{
			TACCR2 =TAR+2950;
			Q=0;
			Sa9904_NM-=Pulse_N;
			P2DIR |= QOUT;
		}
		else
		{
			P2DIR &= ~QOUT;
			TACCTL1 &= ~CCIE;
		}
        break;
              		
		case 10:  //TA
        
        break;   //TA中斷服務程序
              		
        default:break;
	}
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区在线视频| 国产精品麻豆欧美日韩ww| 日韩一区二区三区四区五区六区| 久久婷婷综合激情| 一级日本不卡的影视| 精品中文av资源站在线观看| 99精品欧美一区二区蜜桃免费| 91麻豆精品国产91久久久资源速度| 国产日韩欧美麻豆| 久久国产精品第一页| 91国产成人在线| 亚洲国产精品国自产拍av| 午夜欧美电影在线观看| 94色蜜桃网一区二区三区| 欧美成人精品1314www| 亚洲福利一区二区| 91福利在线看| 亚洲视频在线一区二区| 国产a视频精品免费观看| 日韩三级.com| 免费不卡在线观看| 欧美日韩大陆在线| 亚洲v中文字幕| 欧洲中文字幕精品| 亚洲综合自拍偷拍| 在线精品视频小说1| 亚洲欧美日韩在线不卡| 成人a免费在线看| 中文字幕一区二区三区在线不卡| 国产风韵犹存在线视精品| 欧美精品一区在线观看| 国内精品自线一区二区三区视频| 日韩亚洲欧美综合| 久久电影网电视剧免费观看| 欧美电影免费观看高清完整版| 日本va欧美va瓶| 日韩一级成人av| 国产一区在线不卡| 国产日韩欧美精品电影三级在线 | 久久精品一区二区三区av| 老司机精品视频导航| 日韩免费成人网| 极品美女销魂一区二区三区 | 蜜桃在线一区二区三区| 日韩你懂的在线播放| 蜜臀av性久久久久蜜臀av麻豆| 日韩视频在线观看一区二区| 开心九九激情九九欧美日韩精美视频电影 | 成人精品在线视频观看| 国产精品婷婷午夜在线观看| av中文字幕不卡| 一区二区三区日韩精品视频| 在线看不卡av| 久久99国产精品久久99| 国产午夜亚洲精品理论片色戒| 国产成人av电影在线观看| 国产精品污www在线观看| 色偷偷一区二区三区| 亚洲成人一区二区| 久久久精品国产99久久精品芒果| 成人av网站免费| 午夜精品福利一区二区三区av | 欧美日韩国产美| 久久精品国产亚洲高清剧情介绍 | ww久久中文字幕| 成人一道本在线| 亚洲一区视频在线观看视频| 337p亚洲精品色噜噜噜| 国产精品18久久久久久久久| 综合色中文字幕| 精品国内二区三区| 一本大道综合伊人精品热热| 日韩国产高清影视| 久久精品久久久精品美女| 国产精品毛片a∨一区二区三区| 在线观看亚洲一区| 国产酒店精品激情| 亚洲观看高清完整版在线观看| 久久久噜噜噜久噜久久综合| 欧美影片第一页| 国产另类ts人妖一区二区| 亚洲一二三四在线| 中文字幕成人av| 日韩一区二区在线观看| 91色综合久久久久婷婷| 精品一区二区在线播放| 亚洲一二三四区不卡| 中文在线资源观看网站视频免费不卡| 欧美视频自拍偷拍| aaa亚洲精品一二三区| 久久97超碰国产精品超碰| 亚洲午夜电影在线| ...xxx性欧美| 国产精品免费久久| 久久久亚洲欧洲日产国码αv| 欧美日韩在线三级| 91麻豆免费看片| 成人激情免费视频| 国产剧情一区二区三区| 免费在线看成人av| 日韩精品久久理论片| 伊人色综合久久天天| 日韩理论片在线| 成人欧美一区二区三区| 中文久久乱码一区二区| xfplay精品久久| 精品国产1区二区| 正在播放亚洲一区| 欧美一区二区三区四区在线观看| 欧美亚洲综合另类| 欧美亚洲国产bt| 在线视频国内自拍亚洲视频| 91免费看片在线观看| 99久久综合色| 国产人伦精品一区二区| 久久久久久**毛片大全| 久久伊99综合婷婷久久伊| 日韩欧美一二区| 26uuu国产电影一区二区| 精品电影一区二区| 久久久91精品国产一区二区三区| 欧美大片一区二区| 久久综合九色综合欧美就去吻 | 日韩欧美美女一区二区三区| 91精品国模一区二区三区| 91精品国产综合久久小美女| 日韩一级黄色大片| 久久亚洲精精品中文字幕早川悠里| 欧美va在线播放| 国产欧美日韩中文久久| 中文一区一区三区高中清不卡| 国产欧美精品一区二区色综合| 国产精品三级av在线播放| 中文字幕视频一区| 亚洲一二三区视频在线观看| 日本三级韩国三级欧美三级| 美国精品在线观看| 成人综合婷婷国产精品久久免费| 9l国产精品久久久久麻豆| 欧美性大战xxxxx久久久| 91精品国产91久久综合桃花| 欧美白人最猛性xxxxx69交| 久久九九99视频| 一级女性全黄久久生活片免费| 日韩激情在线观看| 国产1区2区3区精品美女| 91蝌蚪porny| 日韩一区二区三区在线视频| 久久精品日韩一区二区三区| 亚洲欧美偷拍卡通变态| 秋霞午夜av一区二区三区 | 日韩国产成人精品| 粉嫩久久99精品久久久久久夜| 色婷婷综合视频在线观看| 欧美日韩成人高清| 国产欧美视频一区二区三区| 一区二区三区欧美在线观看| 久久99精品久久久| 91丨porny丨国产入口| 日韩精品一区二区在线观看| 中文字幕日韩一区二区| 蜜桃av一区二区| 色噜噜狠狠一区二区三区果冻| 欧美精品一区二| 亚洲一二三专区| 99热精品国产| 久久午夜羞羞影院免费观看| 亚洲综合视频在线观看| 粉嫩av亚洲一区二区图片| 宅男噜噜噜66一区二区66| 亚洲久草在线视频| 国产精品影音先锋| 欧美一区二区国产| 亚洲一区二区三区四区在线观看| 国产一区二区中文字幕| 欧美性色黄大片| 亚洲少妇最新在线视频| 国产黄色精品视频| 日韩欧美精品在线| 天涯成人国产亚洲精品一区av| 国产v日产∨综合v精品视频| 日韩欧美一区二区在线视频| 亚洲一区二区精品久久av| av亚洲精华国产精华精华| 久久欧美一区二区| 麻豆国产欧美日韩综合精品二区| 国产精品久久久久四虎| 狠狠色丁香婷综合久久| 欧美年轻男男videosbes| 亚洲男人电影天堂| 不卡的av网站| 国产精品免费视频观看| 国产黄色成人av| 国产色产综合产在线视频| 国产真实乱偷精品视频免| 日韩欧美激情一区| 卡一卡二国产精品| 日韩精品一区二区三区在线播放| 日韩精品一二三四| 9191成人精品久久|