12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442 |
- /*=========================================================================================================
- * File Name : HLW8110.c
- * Describe : HLW8110 UART 通讯程序,使用USATR2.(HLW8110 code,use USATE2)
- * Author : Tuqiang
- * Version : V1.3
- * Record : 2019/04/16,V1.2
- * Record : 2020/04/02, V1.3
- ==========================================================================================================*/
- #include "HLW8110.h"
- #include "stdio.h"
- #include "TM52F1386_bsp.h"
- #include "sTimeout.h"
- #include "iap.h"
- #include "uart2.h"
- #include "zigbee.h"
- #include "GLOBAL.h"
- #define HIGH 1
- #define LOW 0
- char HLW8110_Int_Result[3] = {0};
- //8112A通道或8110通道校正系数
- #define D_CAL_U 1000/1000 //电压校正系数
- #define D_CAL_A_I 1000/1000 //A通道电流校正系数
- #define D_CAL_A_P 1000/1000 //A通道功率校正系数
- #define D_CAL_A_E 1000/1000 //A通道电能校正系数
- //8112 B通道校正系数
- #define D_CAL_B_P 1000/1000 //B通道功率校正系数
- #define D_CAL_B_I 1000/1000 //B通道电流校正系数
- #define D_CAL_B_E 1000/1000 //B通道电能校正系数
- #define UART_SEND_TIME 30
- unsigned char HLW8110Msg = 0; //程序状态机
- hlw8110_power_t hlw8110_power_data;
- long int SystemTimer;
- unsigned char power_data[21] = {0};
- /*---------------------------------------------------------------------------------------------------------*/
- /*---------------------------------------------------------------------------------------------------------*/
- union IntData
- {
- unsigned int inte;
- unsigned char byte[2];
- };
- union LongData
- {
- unsigned long word_;
- unsigned int inte_[2];
- unsigned char byte_[4];
- };
- /*---------------------------------------------------------------------------------------------------------*/
- /*---------------------------------------------------------------------------------------------------------*/
- unsigned char u8_TxBuf[10] = {0xA5,0x70};
- unsigned char u8_RxBuf[10];
- unsigned char u8_TX_Length;
- unsigned char u8_RX_Length;
- unsigned char u8_RX_Index = 0;
- //unsigned char B_ReadReg_Time_EN; // 串口读取寄存器数据,时间计数器标志位,1--开启计数,0--关闭计数
- //unsigned char B_Tx_Finish;
- unsigned char B_Rx_Finish;
- unsigned char B_Rx_Data_ING; // 接收数据标志位 , < 1:接收数据中,0:未接收到数据 >
- unsigned char B_Read_Error; // UART读取出据校验和出错,< 1:数据读错,0:数据读取正确 >
- unsigned char Temp_Read_Error = 0;
- //unsigned char u8_ReadReg_Index;
- //unsigned char u8_ReadReg_Time; // 串口读取寄存器数据的时间
- /*---------------------------------------------------------------------------------------------------------*/
- /*---------------------------------------------------------------------------------------------------------*/
- unsigned int U16_TempData;
- unsigned int U16_IFData;
- unsigned int U16_RIFData;
- unsigned int U16_LineFData;
- unsigned int U16_AngleData;
- unsigned int U16_PFData;
- unsigned int U16_HFConst_RegData;
- /*---------------------------------------------------------------------------------------------------------*/
- /*---------------------------------------------------------------------------------------------------------*/
- unsigned int U16_RMSIAC_RegData[3]; // A通道电流转换系数
- unsigned int U16_RMSIBC_RegData[3]; // B通道电流转换系数
- unsigned int U16_RMSUC_RegData[3]; // 电压通道转换系数
- unsigned int U16_PowerPAC_RegData[3]; // A通道功率转换系数
- unsigned int U16_PowerPBC_RegData[3]; // B通道功率转换系数
- unsigned int U16_PowerSC_RegData[3]; // 视在功率转换系数,如果选择A通道,则是A通道视在功率转换系数。A和B通道只能二者选其一
- unsigned int U16_EnergyAC_RegData[3]; // A通道有功电能(量)转换系数
- unsigned int U16_EnergyBC_RegData[3]; // A通道有功电能(量)转换系数
- unsigned int U16_CheckSUM_RegData[3]; // 转换系数的CheckSum
- unsigned int U16_CheckSUM_Data; // 转换系数计算出来的CheckSum
- unsigned int U16_Check_SysconReg_Data;
- unsigned int U16_Check_EmuconReg_Data;
- unsigned int U16_Check_Emucon2Reg_Data;
- /*---------------------------------------------------------------------------------------------------------*/
- /*---------------------------------------------------------------------------------------------------------*/
- unsigned long U32_RMSIA_RegData = 0; // A通道电流有效值寄存器
- unsigned long U32_RMSU_RegData = 0; // 电压有效值寄存器
- unsigned long U32_POWERPA_RegData = 0; // A通道功率有效值寄存器
- unsigned long U32_ENERGY_PA_RegData = 0; // A通道有功电能(量)有效值寄存器
- unsigned long U32_RMSIB_RegData; // B通道电流有效值寄存器
- unsigned long U32_POWERPB_RegData; // B通道功率有效值寄存器
- unsigned long U32_ENERGY_PB_RegData; // B通道有功电能(量)有效值寄存器
- /*---------------------------------------------------------------------------------------------------------*/
- /*---------------------------------------------------------------------------------------------------------*/
- float FF_AC_V = 0; // 电压有效值
- float FF_AC_I = 0; // A通道电流
- float FF_AC_P = 0; // A通道有功功率
- float FF_AC_E = 0; // A通道有功电能(量)
- float F_AC_BACKUP_E; // A通道电量备份
- float F_AC_PF; // 功率因素,A通道和B通道只能选其一
- float F_Angle; // 相角,A通道和B通道只能选其一
- /*---------------------------------------------------------------------------------------------------------*/
- /*---------------------------------------------------------------------------------------------------------*/
- float a_pf = 0.0;
- unsigned long b_pf = 0;
- float a_ea = 0.0;
- unsigned long b_ea = 0;
- float a_pa = 0.0;
- unsigned long b_pa = 0;
- unsigned long c_pa = 0;
- float a_u = 0.0;
- unsigned long b_u = 0;
- float a_i = 0.0;
- unsigned long b_i = 0;
- /*=========================================================================================================
- * Function : void Clear_RxBuf(void)
- * Describe : 在准备接收串口数据前,清空接收缓存器的数据
- * Input : none
- * Output : none
- * Return : none
- * Record : 2019/04/03
- =========================================================================================================*/
- void Clear_RxBuf(void)
- {
- unsigned char i;
- for(i = 0;i<10;i++)
- {
- u8_RxBuf[i] = 0x00;
- }
-
- B_Rx_Data_ING = 0;
- B_Rx_Finish = FALSE;
- u8_RX_Index = 0;
- }
- /*=========================================================================================================
- * Function : unsigned char HLW8110_checkSum_Write(unsigned char u8_Reg_length)
- * Describe :
- * Input : none
- * Output : none
- * Return : none
- * Record : 2019/04/03
- =========================================================================================================*/
- unsigned char HLW8110_checkSum_Write(unsigned char u8_Reg_length)
- {
- unsigned char i;
- unsigned char Temp_u8_checksum;
- unsigned int a;
- a = 0x0000;
- Temp_u8_checksum = 0;
- for (i = 0; i< (u8_Reg_length-1); i++)
- {
- a += u8_TxBuf[i];
- }
-
- a = ~a;
- Temp_u8_checksum = a & 0xff;
- return Temp_u8_checksum;
-
- }
- /*=========================================================================================================
- * Function : unsigned char HLW8110_checkSum_Read(void)
- * Describe :
- * Input : none
- * Output : none
- * Return : none
- * Record : 2019/04/03
- ==========================================================================================================*/
- unsigned char HLW8110_checkSum_Read(unsigned char u8_Reg_length)
- {
- unsigned char i;
- unsigned char Temp_u8_checksum;
- unsigned int a;
- a = 0x0000;
- Temp_u8_checksum = 0;
- for (i = 0; i< (u8_Reg_length-1); i++)
- {
- a += u8_RxBuf[i];
- }
-
- a = a + u8_TxBuf[0] + u8_TxBuf[1];
- a = ~a;
-
- Temp_u8_checksum = a & 0xff;
- return Temp_u8_checksum;
-
- }
- /*=========================================================================================================
- * Function : void Uart_HLW8110_WriteREG_EN(void)
- * Describe :
- * Input : none
- * Output : none
- * Return : none
- * Record : 2019/04/03
- ==========================================================================================================*/
- void Uart_HLW8110_WriteREG_EN(void)
- {
- u8_TX_Length = 4;
- u8_RX_Length = 0;
-
- u8_TxBuf[0] = 0xa5;
- u8_TxBuf[1] = 0xea;
- u8_TxBuf[2] = 0xe5;
- // u8_TxBuf[3] = 0x8b; //checksum
- u8_TxBuf[3] = HLW8110_checkSum_Write(u8_TX_Length);
- Start_Send_UartData(u8_TX_Length);
-
- }
- /*=========================================================================================================
- * Function : void Uart_HLW8110_WriteREG_DIS(void)
- * Describe :
- * Input : none
- * Output : none
- * Return : none
- * Record : 2019/04/03
- ==========================================================================================================*/
- void Uart_HLW8110_WriteREG_DIS(void)
- {
-
- u8_TX_Length = 4;
- u8_RX_Length = 0;
-
- u8_TxBuf[0] = 0xa5;
- u8_TxBuf[1] = 0xea;
- u8_TxBuf[2] = 0xdc;
- // u8_TxBuf[3] = 0x94; //checksum
- u8_TxBuf[3] = HLW8110_checkSum_Write(u8_TX_Length);
-
- Start_Send_UartData(u8_TX_Length);
- }
- /*=========================================================================================================
- * Function : void Uart_HLW8110_Set_Channel_A(void)
- * Describe :
- * Input : none
- * Output : none
- * Return : none
- * Record : 2019/04/03
- ==========================================================================================================*/
- void Uart_HLW8110_Set_Channel_A(void)
- {
- u8_TX_Length = 4;
- u8_RX_Length = 0;
-
- u8_TxBuf[0] = 0xa5;
- u8_TxBuf[1] = 0xea;
- u8_TxBuf[2] = 0x5a;
- // u8_TxBuf[3] = 0x16; //checksum
- u8_TxBuf[3] = HLW8110_checkSum_Write(u8_TX_Length);
- Start_Send_UartData(u8_TX_Length);
- }
- /*=========================================================================================================
- * Function : void Uart_Read_HLW8110_Reg(unsigned char ADDR_Reg,unsigned char u8_reg_length)
- * Describe :
- * Input :
- * Output :
- * Return :
- * Record : 2019/04/04
- ==========================================================================================================*/
- void Uart_Read_HLW8110_Reg(unsigned char ADDR_Reg,unsigned char u8_reg_length)
- {
- u8_TxBuf[0] = 0xa5;
- u8_TxBuf[1] = ADDR_Reg;
- u8_TX_Length = 2;
- u8_RX_Length = u8_reg_length + 1; // +1,是因为接收的数据长度,除了REG值,还有一个校验和数据
-
-
- Clear_RxBuf(); //清空接收缓冲区
- Start_Send_UartData(u8_TX_Length);
- }
- /*=========================================================================================================
- * Function : void Uart_Write_HLW8110_Reg(unsigned char ADDR_Reg,unsigned char u8_reg_length,unsigned long u32_data)
- * Describe : 写寄存器命令,u8_reg_length:写入的寄存器数据字节长度
- * Input :
- * Output :
- * Return :
- * Record : 2019/04/03
- ==========================================================================================================*/
- void Uart_Write_HLW8110_Reg(unsigned char ADDR_Reg,unsigned char u8_reg_length,unsigned long u32_data)
- {
- // unsigned char i;
- union LongData;
-
- u8_TxBuf[0] = 0xa5;
- u8_TxBuf[1] = ADDR_Reg|0x80;
- // Temp_u32_a.word_ = u32_data;
- // for (i = 0; i< u8_reg_length; i++)
- // {
- // u8_TxBuf[i+2] = Temp_u32_a.byte_[u8_reg_length-1-i]; //STM32,32位MCU,union定义,是低位在前
- // //u8_TxBuf[i+2] = Temp_u32_a.byte[4-u8_reg_length + i]; //STM8,STC MCU, union定义,是高位在前
- // }
- u8_TxBuf[2] = (unsigned char)((u32_data>>8) & 0xff);
- u8_TxBuf[3] = (unsigned char)(u32_data & 0xff);
- u8_TX_Length = 3 + u8_reg_length ;
- u8_RX_Length = 0;
-
- u8_TxBuf[u8_TX_Length-1] = HLW8110_checkSum_Write(u8_TX_Length);
- Start_Send_UartData(u8_TX_Length);
- }
- /*=========================================================================================================
- * Function : void Uart_HLW8110_Reset(void)
- * Describe :
- * Input : none
- * Output : none
- * Return : none
- * Record : 2019/04/03
- ==========================================================================================================*/
- void Uart_HLW8110_Reset(void)
- {
-
- u8_TX_Length = 4;
- u8_RX_Length = 0;
-
- u8_TxBuf[0] = 0xa5;
- u8_TxBuf[1] = 0xea;
- u8_TxBuf[2] = 0x96;
- // u8_TxBuf[3] = 0xda; //checksum
-
- u8_TxBuf[3] = HLW8110_checkSum_Write(u8_TX_Length);
- Start_Send_UartData(u8_TX_Length);
- }
- /*=========================================================================================================
- * Function : void Judge_CheckSum_HLW8110_Calfactor(void)
- * Describe : 验证地址0x70-0x77地址的系数和
- * Input : none
- * Output : none
- * Return : none
- * Record : 2019/03/18
- ==========================================================================================================*/
- unsigned char Judge_CheckSum_HLW8110_Calfactor(unsigned char nun)
- {
- unsigned long a;
- unsigned int b;
- //unsigned int c;
- unsigned char d;
-
- //读取RmsIAC、RmsIBC、RmsUC、PowerPAC、PowerPBC、PowerSC、EnergAc、EnergBc的值
- //Uart_Read_HLW8110_Reg(REG_SYSCON_ADDR,2);
- Uart_Read_HLW8110_Reg(REG_RMS_IAC_ADDR,2);
- bsp_delay_ms(UART_SEND_TIME);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b = u8_RxBuf[0];
- if(nun == 1) //第一路
- {
- U16_RMSIAC_RegData[0] = (b<<8) + u8_RxBuf[1] ; //printf("A通道电流转换系数:%x\n " ,U16_RMSIAC_RegData);
- }
- else if(nun == 2) //第二路
- {
- U16_RMSIAC_RegData[1] = (b<<8) + u8_RxBuf[1] ; //printf("A通道电流转换系数:%x\n " ,U16_RMSIAC_RegData);
- }
- else if(nun == 3) //第三路
- {
- U16_RMSIAC_RegData[2] = (b<<8) + u8_RxBuf[1] ; //printf("A通道电流转换系数:%x\n " ,U16_RMSIAC_RegData);
- }
- else
- {}
- }
-
- Uart_Read_HLW8110_Reg(REG_RMS_IBC_ADDR,2);
- bsp_delay_ms(UART_SEND_TIME);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b = u8_RxBuf[0];
- if(nun == 1) //第一路
- {
- U16_RMSIBC_RegData[0] = (b<<8) + u8_RxBuf[1] ; //printf("B通道电流转换系数:%x\n " ,U16_RMSIBC_RegData);
- }
- else if(nun == 2) //第二路
- {
- U16_RMSIBC_RegData[1] = (b<<8) + u8_RxBuf[1] ; //printf("B通道电流转换系数:%x\n " ,U16_RMSIBC_RegData);
- }
- else if(nun == 3) //第三路
- {
- U16_RMSIBC_RegData[2] = (b<<8) + u8_RxBuf[1] ; //printf("B通道电流转换系数:%x\n " ,U16_RMSIBC_RegData);
- }
- }
-
- Uart_Read_HLW8110_Reg(REG_RMS_UC_ADDR,2);
- bsp_delay_ms(UART_SEND_TIME);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b = u8_RxBuf[0];
- if(nun == 1) //第一路
- {
-
- U16_RMSUC_RegData[0] = (b<<8) + u8_RxBuf[1] ;//printf("电压通道转换系数:%x\n " ,U16_RMSUC_RegData);
- }
- else if(nun == 2) //第二路
- {
- U16_RMSUC_RegData[1] = (b<<8) + u8_RxBuf[1] ;//printf("电压通道转换系数:%x\n " ,U16_RMSUC_RegData);
- }
- else if(nun == 3) //第三路
- {
- U16_RMSUC_RegData[2] = (b<<8) + u8_RxBuf[1] ;//printf("电压通道转换系数:%x\n " ,U16_RMSUC_RegData);
- }
- }
-
- Uart_Read_HLW8110_Reg(REG_POWER_PAC_ADDR,2);
- bsp_delay_ms(UART_SEND_TIME);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b = u8_RxBuf[0];
- if(nun == 1) //第一路
- {
- U16_PowerPAC_RegData[0] = (b<<8) + u8_RxBuf[1] ;//printf("A通道功率转换系数:%x\n " ,U16_PowerPAC_RegData);
- }
- else if(nun == 2) //第二路
- {
- U16_PowerPAC_RegData[1] = (b<<8) + u8_RxBuf[1] ;//printf("A通道功率转换系数:%x\n " ,U16_PowerPAC_RegData);
- }
- else if(nun == 3) //第三路
- {
- U16_PowerPAC_RegData[2] = (b<<8) + u8_RxBuf[1] ;//printf("A通道功率转换系数:%x\n " ,U16_PowerPAC_RegData);
- }
- }
-
- Uart_Read_HLW8110_Reg(REG_POWER_PBC_ADDR,2);
- bsp_delay_ms(UART_SEND_TIME);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b = u8_RxBuf[0];
- if(nun == 1) //第一路
- {
- U16_PowerPBC_RegData[0] = (b<<8) + u8_RxBuf[1] ;//printf("B通道功率转换系数:%x\n " ,U16_PowerPAC_RegData);
- }
- else if(nun == 2) //第二路
- {
- U16_PowerPBC_RegData[1] = (b<<8) + u8_RxBuf[1] ;//printf("B通道功率转换系数:%x\n " ,U16_PowerPAC_RegData);
- }
- else if(nun == 3) //第三路
- {
- U16_PowerPBC_RegData[2] = (b<<8) + u8_RxBuf[1] ;//printf("B通道功率转换系数:%x\n " ,U16_PowerPAC_RegData);
- }
- }
-
- Uart_Read_HLW8110_Reg(REG_POWER_SC_ADDR,2);
- bsp_delay_ms(UART_SEND_TIME);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b = u8_RxBuf[0];
- if(nun == 1) //第一路
- {
- U16_PowerSC_RegData[0] = (b<<8) + u8_RxBuf[1] ;//printf("视在功率转换系数:%x\n " ,U16_PowerSC_RegData);
- }
- else if(nun == 2) //第二路
- {
- U16_PowerSC_RegData[1] = (b<<8) + u8_RxBuf[1] ;//printf("视在功率转换系数:%x\n " ,U16_PowerSC_RegData);
- }
- else if(nun == 3) //第三路
- {
- U16_PowerSC_RegData[2] = (b<<8) + u8_RxBuf[1] ;//printf("视在功率转换系数:%x\n " ,U16_PowerSC_RegData);
- }
- }
-
- Uart_Read_HLW8110_Reg(REG_ENERGY_AC_ADDR,2);
- bsp_delay_ms(UART_SEND_TIME);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b = u8_RxBuf[0];
- if(nun == 1) //第一路
- {
- U16_EnergyAC_RegData[0] = (b<<8) + u8_RxBuf[1] ;//printf("A通道电量转换系数:%x\n " ,U16_EnergyAC_RegData);
- }
- else if(nun == 2) //第二路
- {
- U16_EnergyAC_RegData[1] = (b<<8) + u8_RxBuf[1] ;//printf("A通道电量转换系数:%x\n " ,U16_EnergyAC_RegData);
- }
- else if(nun == 3) //第三路
- {
- U16_EnergyAC_RegData[2] = (b<<8) + u8_RxBuf[1] ;//printf("A通道电量转换系数:%x\n " ,U16_EnergyAC_RegData);
- }
-
- }
- Uart_Read_HLW8110_Reg(REG_ENERGY_BC_ADDR,2);
- bsp_delay_ms(UART_SEND_TIME);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b = u8_RxBuf[0];
- if(nun == 1) //第一路
- {
- U16_EnergyBC_RegData[0] = (b<<8) + u8_RxBuf[1] ;//printf("B通道电量转换系数:%x\n " ,U16_EnergyBC_RegData);
- }
- else if(nun == 2) //第二路
- {
- U16_EnergyBC_RegData[1] = (b<<8) + u8_RxBuf[1] ;//printf("B通道电量转换系数:%x\n " ,U16_EnergyBC_RegData);
- }
- else if(nun == 3) //第三路
- {
- U16_EnergyBC_RegData[2] = (b<<8) + u8_RxBuf[1] ;//printf("B通道电量转换系数:%x\n " ,U16_EnergyBC_RegData);
- }
- }
-
-
- Uart_Read_HLW8110_Reg(REG_CHECKSUM_ADDR,2);
-
- bsp_delay_ms(UART_SEND_TIME);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b = u8_RxBuf[0];
- if(nun == 1) //第一路
- {
- U16_CheckSUM_RegData[0] = (b<<8) + u8_RxBuf[1] ;//printf("系数校验和:%x\n " ,U16_CheckSUM_RegData);
- }
- else if(nun == 2) //第二路
- {
- U16_CheckSUM_RegData[1] = (b<<8) + u8_RxBuf[1] ;//printf("系数校验和:%x\n " ,U16_CheckSUM_RegData);
- }
- else if(nun == 3) //第三路
- {
- U16_CheckSUM_RegData[2] = (b<<8) + u8_RxBuf[1] ;//printf("系数校验和:%x\n " ,U16_CheckSUM_RegData);
- }
- }
-
- Uart_Read_HLW8110_Reg(REG_EMUCON_ADDR,2);
-
- bsp_delay_ms(UART_SEND_TIME);
- a = 0;
- if(nun == 1)
- {
- a = ~(0xffff+U16_RMSIAC_RegData[0] + U16_RMSIBC_RegData[0] + U16_RMSUC_RegData[0] +
- U16_PowerPAC_RegData[0] + U16_PowerPBC_RegData[0] + U16_PowerSC_RegData[0] +
- U16_EnergyAC_RegData[0] + U16_EnergyBC_RegData[0] );
-
- U16_CheckSUM_Data = a & 0xffff;
-
- //printf("计算系数校验和:%x\n " ,U16_CheckSUM_Data);
-
- if ( U16_CheckSUM_Data == U16_CheckSUM_RegData[0])
- {
- d = 1;//printf("校验和正确\r\n ");
- HLW8110_Int_Result[0] = 1;
- }
- else
- {
- d = 0; //printf("校验和出错\r\n ");
- HLW8110_Int_Result[0] = 0;
- }
- }
- else if(nun == 2)
- {
- a = ~(0xffff+U16_RMSIAC_RegData[1] + U16_RMSIBC_RegData[1] + U16_RMSUC_RegData[1] +
- U16_PowerPAC_RegData[1] + U16_PowerPBC_RegData[1] + U16_PowerSC_RegData[1] +
- U16_EnergyAC_RegData[1] + U16_EnergyBC_RegData[1] );
-
- U16_CheckSUM_Data = a & 0xffff;
-
- //printf("计算系数校验和:%x\n " ,U16_CheckSUM_Data);
-
- if ( U16_CheckSUM_Data == U16_CheckSUM_RegData[1])
- {
- d = 1;//printf("校验和正确\r\n ");
- HLW8110_Int_Result[1] = 1;
- }
- else
- {
- d = 0; //printf("校验和出错\r\n ");
- HLW8110_Int_Result[1] = 0;
- }
- }
- else if(nun == 3)
- {
- a = ~(0xffff+U16_RMSIAC_RegData[2] + U16_RMSIBC_RegData[2] + U16_RMSUC_RegData[2] +
- U16_PowerPAC_RegData[2] + U16_PowerPBC_RegData[2] + U16_PowerSC_RegData[2] +
- U16_EnergyAC_RegData[2] + U16_EnergyBC_RegData[2] );
-
- U16_CheckSUM_Data = a & 0xffff;
-
- //printf("计算系数校验和:%x\n " ,U16_CheckSUM_Data);
-
- if ( U16_CheckSUM_Data == U16_CheckSUM_RegData[2])
- {
- d = 1;//printf("校验和正确\r\n ");
- HLW8110_Int_Result[2] = 1;
- }
- else
- {
- d = 0; //printf("校验和出错\r\n ");
- HLW8110_Int_Result[2] = 0;
- }
- }
- return d;
- }
- /*=========================================================================================================
- * Function : void Init_HLW8110(void)
- * Describe :
- * Input : none
- * Output : none
- * Return : none
- * Record : 2019/04/03
- ==========================================================================================================*/
- void Init_HLW8110(unsigned char nun)
- {
- unsigned char nun1;
- nun1 = nun;
- Uart_HLW8110_WriteREG_EN();
- bsp_delay_ms(UART_SEND_TIME);
-
- //电流通道A设置命令,指定当前用于计算视在功率、功率因数、相角、瞬时有功功率、瞬时视在功率和有功功率过载的信号指示 的通道为通道A
- Uart_HLW8110_Set_Channel_A();
- bsp_delay_ms(UART_SEND_TIME);
- Uart_Write_HLW8110_Reg(REG_SYSCON_ADDR,2,0x0a04); //开启A通道,关闭B通道,电压通道PGA = 1,电流通道PGA = 16
- bsp_delay_ms(UART_SEND_TIME);
-
- Uart_Write_HLW8110_Reg(REG_EMUCON_ADDR,2,0x0001); //1,使能PFA 脉冲输出和有功电能寄存器累加;
- // Uart_Write_HLW8110_Reg(REG_EMUCON_ADDR,2,0x0018); //正向和负向过零点均发生变化,ZXD0 = 1,ZXD1 = 1
- Uart_Write_HLW8110_Reg(REG_EMUCON2_ADDR,2,0x0465); //0x0001是EMUCON2的默认值,waveEn = 1,zxEn = 1,A通道电量寄存器,读后不清0,EPA_CB = 1;打开功率因素检测
- bsp_delay_ms(UART_SEND_TIME);
-
- Uart_HLW8110_WriteREG_DIS();
- bsp_delay_ms(UART_SEND_TIME);
- //读取地址是0x6F至0x77的寄存器,验证系数是否正确
- Judge_CheckSum_HLW8110_Calfactor(nun1);
- }
- /*=========================================================================================================
- * Function : void Check_WriteReg_Success(void)
- * Describe : 检验写入的REG是否正确写入
- * Input : none
- * Output : none
- * Return : none
- * Record : 2020/04/02
- ==========================================================================================================*/
- void Check_WriteReg_Success(void)
- {
- unsigned int b;
- Uart_Read_HLW8110_Reg(REG_SYSCON_ADDR,2);
- bsp_delay_ms(UART_SEND_TIME);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b = u8_RxBuf[0];
- U16_Check_SysconReg_Data = (b<<8) + (u8_RxBuf[1]);
- //printf("写入的SysconReg寄存器:%lx\n " ,U16_Check_SysconReg_Data);
- Temp_Read_Error = 0;
- }
- else
- {
- //printf("SysconReg寄存器读取出错\r\n");
- B_Read_Error = 1;
- Temp_Read_Error = 1;
- }
-
- Uart_Read_HLW8110_Reg(REG_EMUCON_ADDR,2);
- bsp_delay_ms(UART_SEND_TIME);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b = u8_RxBuf[0];
- U16_Check_EmuconReg_Data = (b<<8) + (u8_RxBuf[1]);
- //printf("写入的EmuconReg寄存器:%lx\n " ,U16_Check_EmuconReg_Data);
- }
- else
- {
- //printf("EmuconReg寄存器读取出错\r\n");
- B_Read_Error = 1;
- }
-
-
- Uart_Read_HLW8110_Reg(REG_EMUCON2_ADDR,2);
- bsp_delay_ms(UART_SEND_TIME);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b = u8_RxBuf[0];
- U16_Check_Emucon2Reg_Data = (b<<8) + (u8_RxBuf[1]);
- //printf("写入的Emucon2Reg寄存器寄存器:%lx\n " ,U16_Check_Emucon2Reg_Data);
- }
- else
- {
- //printf("Emucon2Reg寄存器读取出错\r\n");
- B_Read_Error = 1;
- }
-
- }
- /*=========================================================================================================
- * Function : void Read_HLW8112_IA(void)
- * Describe : 读取A通道电流
- * Input : none
- * Output : none
- * Return : none
- * Record : 2019/04/03
- ==========================================================================================================*/
- void Read_HLW8110_IA(unsigned char nun)
- {
- a_i = 0.0;
- b_i = 0;
-
- Uart_Read_HLW8110_Reg(REG_RMSIA_ADDR,3);
- bsp_delay_ms(UART_SEND_TIME);
- //delay_ms(3);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b_i = u8_RxBuf[0];
- b_i = (b_i<<8) + u8_RxBuf[1];
- b_i = (b_i<<8) + u8_RxBuf[2];
- U32_RMSIA_RegData = b_i;
- //U32_RMSIA_RegData = (unsigned long)(u8_RxBuf[0]<<16) + (unsigned long)(u8_RxBuf[1]<<8) + (unsigned long)(u8_RxBuf[2]);
- //printf("A通道电流寄存器:%lx\n " ,U32_RMSIA_RegData);
- }
- else
- {
- //printf("A通道电流寄存器读取出错\r\n");
- B_Read_Error = 1;
- }
-
-
- //A通道电流PGA = 16,电压通道PGA = 1;电流采样电阻1mR,电压采样电阻1M
- //计算公式,U16_AC_I = (U32_RMSIA_RegData * U16_RMSIAC_RegData)/(电流系数* 2^23)
-
- if ((U32_RMSIA_RegData & 0x800000) == 0x800000)
- {
- if(nun == 1)
- {
- hlw8110_power_data.F_AC_I[0] = 0;
- }
- else if(nun == 2)
- {
- hlw8110_power_data.F_AC_I[1] = 0;
- }
- else if(nun == 3)
- {
- hlw8110_power_data.F_AC_I[2] = 0;
- }
-
- }
- else
- {
- a_i = (float)U32_RMSIA_RegData;
- if(nun == 1)
- {
- a_i = a_i * U16_RMSIAC_RegData[0];
- }
- else if(nun == 2)
- {
- a_i = a_i * U16_RMSIAC_RegData[1];
- }
- else if(nun == 3)
- {
- a_i = a_i * U16_RMSIAC_RegData[2];
- }
- //a = a * U16_RMSIAC_RegData;
- a_i = a_i/0x800000; //电流计算出来的浮点数单位是mA,比如5003.12
- a_i = a_i/1; // 1 = 电流系数
- //a = a/1000; //a= 5003ma,a/1000 = 5.003A,单位转换成A
- a_i = a_i * D_CAL_A_I; //D_CAL_A_I是校正系数,默认是1
- //F_AC_I = a;
- //switchState.dp_cur_current = (unsigned long)a;//1000;//1000mA
-
- if(nun == 1)
- {
- hlw8110_power_data.F_AC_I[0] = a_i;
- }
- else if(nun == 2)
- {
- hlw8110_power_data.F_AC_I[1] = a_i;
- }
- else if(nun == 3)
- {
- hlw8110_power_data.F_AC_I[2] = a_i;
- }
- }
- }
- /*=========================================================================================================
- * Function : void Read_HLW8110_U(void)
- * Describe : 读取电压
- * Input : none
- * Output : none
- * Return : none
- * Record : 2019/04/03
- ==========================================================================================================*/
- void Read_HLW8110_U(unsigned char nun)
- {
- a_u = 0.0;
- b_u = 0;
- Uart_Read_HLW8110_Reg(REG_RMSU_ADDR,3);
- bsp_delay_ms(UART_SEND_TIME);
- //delay_ms(3);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b_u = u8_RxBuf[0];
- b_u = (b_u<<8) + u8_RxBuf[1];
- b_u = (b_u<<8) + u8_RxBuf[2];
- U32_RMSU_RegData = b_u;
- //U32_RMSU_RegData = (unsigned long)(u8_RxBuf[0]<<16) + (unsigned long)(u8_RxBuf[1]<<8) + (unsigned long)(u8_RxBuf[2]);
- //printf("电压通道寄存器:%lx\n " ,U32_RMSU_RegData);
- //switchState.dp_cur_voltage = 128;//(unsigned long)a;
- }
- else
- {
- //printf("电压通道寄存器读取出错\r\n");
- B_Read_Error = 1;
- }
-
- //电压
- //计算:U16_AC_V = (U32_RMSU_RegData * U16_RMSUC_RegData)/2^23
-
- if ((U32_RMSU_RegData &0x800000) == 0x800000)
- {
- //F_AC_V = 0;
- hlw8110_power_data.F_AC_V = 0;
- }
- else
- {
- a_u = (float)U32_RMSU_RegData;
- if(nun == 1)
- {
- a_u = a_u * U16_RMSUC_RegData[0];
- }
- else if(nun == 2)
- {
- a_u = a_u * U16_RMSUC_RegData[1];
- }
- else if(nun == 3)
- {
- a_u = a_u * U16_RMSUC_RegData[2];
- }
- // a = a*U16_RMSUC_RegData;
- a_u = a_u/0x400000;
- a_u = a_u/0.5319; // 1 = 电压系数
- a_u = a_u/100; //计算出a = 22083.12mV,a/100表示220.8312V,电压转换成V
- a_u = a_u*D_CAL_U; //D_CAL_U是校正系数,默认是1,
- // F_AC_V = a;
- //switchState.dp_cur_voltage = (unsigned long)(a * 10);
- if(nun == 1)
- {
- hlw8110_power_data.F_AC_V = a_u;
- }
- else if(nun == 2)
- {
- hlw8110_power_data.F_AC_V = a_u;
- }
- else if(nun == 3)
- {
- hlw8110_power_data.F_AC_V = a_u;
- }
- }
-
- }
- /*=========================================================================================================
- * Function : void Read_HLW8110_PA(void)
- * Describe : 读取A通道功率
- * Input : none
- * Output : none
- * Return : none
- * Record : 2019/04/03
- ==========================================================================================================*/
- void Read_HLW8110_PA(unsigned char nun)
- {
- a_pa = 0.0;
- b_pa = 0;
- c_pa = 0;
- Uart_Read_HLW8110_Reg(REG_POWER_PA_ADDR,4);
- bsp_delay_ms(UART_SEND_TIME);
- //delay_ms(3);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- c_pa = u8_RxBuf[0];
- c_pa = (c_pa<<8) + u8_RxBuf[1];
- c_pa = (c_pa<<8) + u8_RxBuf[2];
- c_pa = (c_pa<<8) + u8_RxBuf[3];
- U32_POWERPA_RegData = c_pa;
- //U32_POWERPA_RegData = (unsigned long)(u8_RxBuf[0]<<24) + (unsigned long)(u8_RxBuf[1]<<16) + (unsigned long)(u8_RxBuf[2]<<8) + (unsigned long)(u8_RxBuf[3]);
- //printf("A通道功率寄存器:%lx\n " ,U32_POWERPA_RegData);
- }
- else
- {
- //printf("A通道功率寄存器读取出错\r\n");
- B_Read_Error = 1;
- }
-
- if (B_Read_Error == 1)
- {
- B_Read_Error = 0;
- Uart_Read_HLW8110_Reg(REG_POWER_PA_ADDR,4);
- bsp_delay_ms(UART_SEND_TIME);
- //delay_ms(3);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- c_pa = u8_RxBuf[0];
- c_pa = (c_pa<<8) + u8_RxBuf[1];
- c_pa = (c_pa<<8) + u8_RxBuf[2];
- c_pa = (c_pa<<8) + u8_RxBuf[3];
- U32_POWERPA_RegData = c_pa;
- //U32_POWERPA_RegData = (unsigned long)(u8_RxBuf[0]<<24) + (unsigned long)(u8_RxBuf[1]<<16) + (unsigned long)(u8_RxBuf[2]<<8) + (unsigned long)(u8_RxBuf[3]);
- //printf("A通道功率寄存器:%lx\n " ,U32_POWERPA_RegData);
- }
- else
- {
- //printf("A通道功率寄存器读取出错\r\n");
- B_Read_Error = 1;
- }
- }
-
-
- if (U32_POWERPA_RegData > 0x80000000)
- {
- b_pa = ~U32_POWERPA_RegData;
- a_pa = (float)b_pa;
- }
- else
- a_pa = (float)U32_POWERPA_RegData;
-
-
- //功率需要分正功和负功
- //计算,U16_AC_P = (U32_POWERPA_RegData * U16_PowerPAC_RegData)/(2^31*电压系数*电流系数)
- //单位为W,比如算出来5000.123,表示5000.123W
- if(nun == 1)
- {
- a_pa = a_pa * U16_PowerPAC_RegData[0];
- }
- else if(nun == 2)
- {
- a_pa = a_pa * U16_PowerPAC_RegData[1];
- }
- else if(nun == 3)
- {
- a_pa = a_pa * U16_PowerPAC_RegData[2];
- }
- //a = a*U16_PowerPAC_RegData;
- a_pa = a_pa/0x80000000;
- a_pa = a_pa/1; // 1 = 电流系数
- a_pa = a_pa/0.5319; // 1 = 电压系数
- a_pa = a_pa * D_CAL_A_P; //D_CAL_A_P是校正系数,默认是1
- //F_AC_P = a; //单位为W,比如算出来5000.123,表示5000.123W
- //switchState.dp_cur_power = (unsigned long)(a*10);
-
- if(nun == 1)
- {
- hlw8110_power_data.F_AC_P[0] = a_pa;
- }
- else if(nun == 2)
- {
- hlw8110_power_data.F_AC_P[1] = a_pa;
- }
- else if(nun == 3)
- {
- hlw8110_power_data.F_AC_P[2] = a_pa;
- }
- }
- /*=========================================================================================================
- * Function : void void Read_HLW8112_EA(void)
- * Describe : 读取A通道有功电量
- * Input : none
- * Output : none
- * Return : none
- * Record : 2019/04/03
- ==========================================================================================================*/
- void Read_HLW8110_EA(unsigned char nun)
- {
- a_ea = 0.0;
- b_ea = 0;
- Uart_Read_HLW8110_Reg(REG_ENERGY_PA_ADDR,3);
- bsp_delay_ms(UART_SEND_TIME);
- //delay_ms(3);
-
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b_ea = u8_RxBuf[0];
- b_ea = (b_ea<<8) + u8_RxBuf[1];
- b_ea = (b_ea<<8) + u8_RxBuf[2];
- U32_ENERGY_PA_RegData = b_ea;
- //U32_ENERGY_PA_RegData = (unsigned long)(u8_RxBuf[0]<<16) + (unsigned long)(u8_RxBuf[1]<<8) + (unsigned long)(u8_RxBuf[2]);
- //printf("A通道有功电量寄存器:%lx\n " ,U32_ENERGY_PA_RegData);
- }
- else
- {
- //printf("A通道有功电量寄存器读取出错\r\n");
- B_Read_Error = 1;
- }
-
- Uart_Read_HLW8110_Reg(REG_HFCONST_ADDR,2);
- bsp_delay_ms(UART_SEND_TIME);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- U16_HFConst_RegData = (unsigned int)(u8_RxBuf[0]<<8) + (unsigned int)(u8_RxBuf[1]);
- //printf("HFCONST常数 = :%d\n " ,U16_HFConst_RegData);
- }
- else
- {
- //printf("HFCONST常数寄存器读取出错\r\n");
- B_Read_Error = 1;
- }
- //电量计算,电量 = (U32_ENERGY_PA_RegData * U16_EnergyAC_RegData * HFCONST) /(K1*K2 * 2^29 * 4096)
- //HFCONST:默认值是0x1000, HFCONST/(2^29 * 4096) = 0x20000000
- a_ea = (float)U32_ENERGY_PA_RegData;
- if(nun == 1)
- {
- a_ea = a_ea * U16_EnergyAC_RegData[0];
- }
- else if(nun == 2)
- {
- a_ea = a_ea * U16_EnergyAC_RegData[1];
- }
- else if(nun == 3)
- {
- a_ea = a_ea * U16_EnergyAC_RegData[2];
- }
- //a = a*U16_EnergyAC_RegData;
- a_ea = a_ea/0x20000000; //电量单位是0.001KWH,比如算出来是2.002,表示2.002KWH
- a_ea = a_ea/1; // 1 = 电流系数
- a_ea = a_ea/0.5319; // 1 = 电压系数
- a_ea = a_ea * D_CAL_A_E; //D_CAL_A_E是校正系数,默认是1
- // F_AC_E = a;
- //F_AC_BACKUP_E = F_AC_E;
- //switchState.dp_add_ele = (unsigned long)(a*100);
- if(nun == 1)
- {
- hlw8110_power_data.F_AC_E[0] = a_ea;
- }
- else if(nun == 2)
- {
- hlw8110_power_data.F_AC_E[1] = a_ea;
- }
- else if(nun == 3)
- {
- hlw8110_power_data.F_AC_E[2] = a_ea;
- }
-
- }
- /*=========================================================================================================
- * Function : void Read_HLW8110_PF(void)
- * Describe : 读取功率因素
- * Input : none
- * Output : none
- * Return : none
- * Record : 2019/03/18
- ==========================================================================================================*/
- void Read_HLW8110_PF(void)
- {
-
- //测量A通道的功率因素,需要发送EA+5A命令
- //测量B通道的功率因素,需要发送EA+A5命令
- b_pf = 0;
- a_pf = 0.0;
- Uart_Read_HLW8110_Reg(REG_PF_ADDR,3);
- bsp_delay_ms(UART_SEND_TIME);
- if ( u8_RxBuf[u8_RX_Length-1] == HLW8110_checkSum_Read(u8_RX_Length) )
- {
- b_pf = (unsigned long)(u8_RxBuf[0]<<16) + (unsigned long)(u8_RxBuf[1]<<8) + (unsigned long)(u8_RxBuf[2]);
- //printf("A通道功率因素寄存器:%ld\n " ,b);
- }
- else
- {
- //printf("读取A通道功率因素寄存器出错\r\n");
- B_Read_Error = 1;
- }
- if (b_pf>0x800000) //为负,容性负载
- {
- a_pf = (float)(0xffffff-b_pf + 1)/0x7fffff;
- }
- else
- {
- a_pf = (float)b_pf/0x7fffff;
- }
-
- if (FF_AC_P < 0.3) // 小于0.3W,空载或小功率,PF不准
- a_pf = 0;
-
- //功率因素*100,最大为100,最小负100
- F_AC_PF = a_pf;
-
- }
- /*=========================================================================================================
- * Function : void Calculate_HLW8110_MeterData(void);
- * Describe :
- * Input : none
- * Output : none
- * Return : none
- * Record : 2018/05/10
- ==========================================================================================================*/
- void Calculate_HLW8110_MeterData(unsigned char nun)
- {
-
- //Check_WriteReg_Success();
- bsp_delay_ms(UART_SEND_TIME);
- Read_HLW8110_IA(nun);
-
- if(nun == 1) //电压只读取第一路,三路共用
- {
- bsp_delay_ms(UART_SEND_TIME);
- Read_HLW8110_U(nun);
- }
-
- bsp_delay_ms(UART_SEND_TIME);
- Read_HLW8110_PA(nun);
- bsp_delay_ms(UART_SEND_TIME);
- Read_HLW8110_EA(nun);
-
- // Read_HLW8110_LineFreq();
- // Read_HLW8110_Angle();
- // Read_HLW8110_PF();
- }
- void Read_Power_Data_handle(void)
- {
- int i = 0;
- switch (HLW8110Msg)
- {
- case HLW8110_1int:
- if (sTimeout(&SystemTimer, 800)) // 等待1s初始化8110
- {
- open_first_passageway();
- bsp_delay_ms(UART_SEND_TIME);
- Init_HLW8110(1);
- bsp_delay_ms(UART_SEND_TIME);
- // Uart_HLW8110_Reset();
- if(HLW8110_Int_Result[0] == 1)
- {
- #ifdef ZIGBEE_ZTU_T1_SW
- HLW8110Msg = HLW8110_1;
- #endif
- #ifdef ZIGBEE_ZTU_T3_SW
- HLW8110Msg ++;
- #endif
- #ifdef ZIGBEE_ZTU_T2_SW
- HLW8110Msg ++;
- #endif
- //HLW8110Msg = HLW8110_1;//HLW8110_IDEL; 测试用直接跳转
- //增加上电读取存储的电量数据 start
- Raed_ele_data();
- //增加上电读取存储的电量数据 end
- open_second_passageway(); //第一路初始化成功以后开启第二路
- }
- else
- {
- HLW8110Msg = HLW8110_1int;
- }
- //HLW8110Msg = HLW8110_IDEL;
- sTimeout(&SystemTimer, 0);
- for(i=0;i<3;i++)
- {
- switchState.dp_add_ele[i] = 0;
- switchState.dp_cur_current[i] = 0;
- switchState.dp_cur_power[i] = 0;
- }
- switchState.dp_cur_voltage = 0;
-
- }
- break;
- case HLW8110_2int:
- if (sTimeout(&SystemTimer, 50)) // 等待1s初始化8110
- {
- bsp_delay_ms(UART_SEND_TIME);
- Init_HLW8110(2);
- bsp_delay_ms(UART_SEND_TIME);
- if(HLW8110_Int_Result[1] == 1) //第二路初始化成功
- {
- #ifdef ZIGBEE_ZTU_T3_SW
- HLW8110Msg++;
- open_third_passageway(); //第二路初始化成功以后开启第三路
- #endif
- #ifdef ZIGBEE_ZTU_T2_SW
- HLW8110Msg = HLW8110_1;
- open_first_passageway();
- #endif
-
- }
- else
- {
- HLW8110Msg = HLW8110_2int;
- }
- sTimeout(&SystemTimer, 0);
- }
- break;
- case HLW8110_3int:
- if (sTimeout(&SystemTimer, 50)) // 等待1s初始化8110
- {
- bsp_delay_ms(UART_SEND_TIME);
- Init_HLW8110(3);
- bsp_delay_ms(UART_SEND_TIME);
- if(HLW8110_Int_Result[2] == 1) //第三路初始化成功
- {
- HLW8110Msg++;
- open_first_passageway(); //第三路初始化成功以后开启第一路
- }
- else
- {
- HLW8110Msg = HLW8110_3int;
- }
- sTimeout(&SystemTimer, 0);
- }
- break;
-
- case HLW8110_1:
- if (sTimeout(&SystemTimer, 400)) // 等待5s读取第一路数据
- {
- Calculate_HLW8110_MeterData(1);
- #ifdef ZIGBEE_ZTU_T1_SW
- HLW8110Msg = HLW8110_IDEL;
- #endif
- #ifdef ZIGBEE_ZTU_T3_SW
- HLW8110Msg ++;
- #endif
- #ifdef ZIGBEE_ZTU_T2_SW
- HLW8110Msg ++;
- #endif
- open_second_passageway(); // 打开第二通道
- //HLW8110Msg = HLW8110_IDEL; //用于测试直接跳转
- sTimeout(&SystemTimer, 0);
- }
- break;
-
- case HLW8110_2:
- if (sTimeout(&SystemTimer, 100)) // 等待100ms读取第二路数据
- {
-
- Calculate_HLW8110_MeterData(2);
- #ifdef ZIGBEE_ZTU_T3_SW
- open_third_passageway(); // 打开第三通道
- HLW8110Msg++;
- #endif
- #ifdef ZIGBEE_ZTU_T2_SW
- HLW8110Msg = HLW8110_IDEL;
- #endif
-
- // HLW8110Msg = HLW8110_IDEL;
- sTimeout(&SystemTimer, 0);
- }
- break;
- case HLW8110_3:
- if (sTimeout(&SystemTimer, 100)) // 等待100ms读取第三路数据
- {
-
- Calculate_HLW8110_MeterData(3);
- sTimeout(&SystemTimer, 0);
- HLW8110Msg++;
- }
- break;
-
- case HLW8110_IDEL:
- if (sTimeout(&SystemTimer, 50)) //
- {
- open_first_passageway(); // 打开第一通道
- //open_second_passageway();
- // open_third_passageway(); // 打开第三通道
- // Uart_HLW8110_Reset();
- //增加发送数据给zigbee
- // FF_AC_I = hlw8110_power_data.F_AC_I[0];// + hlw8110_power_data.F_AC_I[1] + hlw8110_power_data.F_AC_I[2];
- // FF_AC_V = hlw8110_power_data.F_AC_V[0];// + hlw8110_power_data.F_AC_V[1] + hlw8110_power_data.F_AC_V[2];
- // FF_AC_P = hlw8110_power_data.F_AC_P[0];// + hlw8110_power_data.F_AC_P[1] + hlw8110_power_data.F_AC_P[2];
- // FF_AC_E = hlw8110_power_data.F_AC_E[0];// + hlw8110_power_data.F_AC_E[1] + hlw8110_power_data.F_AC_E[2];
- // FF_AC_I++;// = 100.4;// 模拟测试用
- // FF_AC_V++;// = 220.5;//
- // FF_AC_P++;// = 320.8;//
- // FF_AC_E++;// = 358.3;//
- for(i=0;i<3;i++)
- {
- switchState.dp_add_ele[i] = (unsigned long)(hlw8110_power_data.F_AC_E[i] *100); //100*100;//100 kW·h
- switchState.dp_add_ele[i] = switchState.dp_add_ele[i] + Flash_dp_add_ele[i];
- switchState.dp_cur_current[i] = (unsigned long)hlw8110_power_data.F_AC_I[i];//1000;//1000mA
- switchState.dp_cur_power[i] = (unsigned long)(hlw8110_power_data.F_AC_P[i]*10); //330*10;//330w
- // switchState.dp_add_ele[i] = (unsigned long)(FF_AC_E *100); //100*100;//100 kW·h 模拟测试用
- // switchState.dp_cur_current[i] = (unsigned long)FF_AC_I;//1000;//1000mA
- // switchState.dp_cur_power[i] = (unsigned long)(FF_AC_P*10); //330*10;//330w
- }
- switchState.dp_cur_voltage = (unsigned long)(hlw8110_power_data.F_AC_V*10); //220*10;//220v
- //switchState.dp_cur_voltage = (unsigned long)(FF_AC_V*10); //220*10;//220v 模拟测试用
-
- if(switchState.dp_add_ele[0] == 0) //如果数据丢失变为0,读取备份数据
- {
- if(Flash_dp_add_ele_backups[0] != 0)
- {
- for(i = 0; i < 3; i++)
- {
- switchState.dp_add_ele[i] = Flash_dp_add_ele_backups[i];
- Flash_dp_add_ele[i] = Flash_dp_add_ele_backups[i];
- }
- Save_data_ele_flag = 1;
- }
- }
-
- all_power_data_update(); //数据上报
-
- //增加电量数据保存
- if(Save_data_ele_flag)
- {
- for(i = 0; i < 3; i++)
- {
- power_data[i*4] = ((switchState.dp_add_ele[i] >>24) & 0xFF);
- power_data[i*4+1] = ((switchState.dp_add_ele[i] >>16) & 0xFF);
- power_data[i*4+2] = ((switchState.dp_add_ele[i] >>8) & 0xFF);
- power_data[i*4+3] = ((switchState.dp_add_ele[i]) & 0xFF);
- }
- user_write_INFO_byte(INFO6_ADDR, power_data, 20);
- Save_data_ele_flag = 0;
- if(Save_data_nun >= 86400) //24小时
- {
- Save_data_nun = 0;
- Flash_dp_add_ele_backups[0] = switchState.dp_add_ele[0];
- Flash_dp_add_ele_backups[1] = switchState.dp_add_ele[1];
- Flash_dp_add_ele_backups[2] = switchState.dp_add_ele[2];
- for(i = 0; i < 3; i++)
- {
- power_data[i*4] = ((Flash_dp_add_ele_backups[i] >>24) & 0xFF);
- power_data[i*4+1] = ((Flash_dp_add_ele_backups[i] >>16) & 0xFF);
- power_data[i*4+2] = ((Flash_dp_add_ele_backups[i] >>8) & 0xFF);
- power_data[i*4+3] = ((Flash_dp_add_ele_backups[i]) & 0xFF);
- }
- user_write_INFO_byte(INFO7_ADDR, power_data, 20);
- }
- }
- sTimeout(&SystemTimer, 0);
- for(i=0;i<3;i++)
- {
- switchState.dp_add_ele[i] = 0;
- switchState.dp_cur_current[i] = 0;
- switchState.dp_cur_power[i] = 0;
- }
- switchState.dp_cur_voltage = 0;
- HLW8110Msg = HLW8110_1; //返回读取第一路数据
- //HLW8110Msg = HLW8110_1int;
- }
- break;
-
- case HLW8110_ERR:
-
- HLW8110Msg++;
- break;
-
- default:
- HLW8110Msg = HLW8110_ERR; // 开机初始化
- break;
-
- }
- }
- void Raed_ele_data(void)
- {
- char i;
- user_read_INFO_byte(INFO6_ADDR, power_data, 20); // 读取INFO6地址存储的数据
- if(power_data[3] != 0xFF) //第一路电量数据
- {
- Flash_dp_add_ele[0] = power_data[0];
- Flash_dp_add_ele[0] = (Flash_dp_add_ele[0]<<8) + power_data[1];
- Flash_dp_add_ele[0] = (Flash_dp_add_ele[0]<<8) + power_data[2];
- Flash_dp_add_ele[0] = (Flash_dp_add_ele[0]<<8) + power_data[3];
- }
- if(power_data[7] != 0xFF) //第二路电量数据
- {
- Flash_dp_add_ele[1] = power_data[4];
- Flash_dp_add_ele[1] = (Flash_dp_add_ele[1]<<8) + power_data[5];
- Flash_dp_add_ele[1] = (Flash_dp_add_ele[1]<<8) + power_data[6];
- Flash_dp_add_ele[1] = (Flash_dp_add_ele[1]<<8) + power_data[7];
- }
- if(power_data[11] != 0xFF) //第三路电量数据
- {
- Flash_dp_add_ele[2] = power_data[8];
- Flash_dp_add_ele[2] = (Flash_dp_add_ele[2]<<8) + power_data[9];
- Flash_dp_add_ele[2] = (Flash_dp_add_ele[2]<<8) + power_data[10];
- Flash_dp_add_ele[2] = (Flash_dp_add_ele[2]<<8) + power_data[11];
- }
-
- for(i=0;i<12;i++)
- {
- power_data[i] = 0;
- }
-
- user_read_INFO_byte(INFO7_ADDR, power_data, 20); // 读取INFO6地址存储的数据
- if(power_data[3] != 0xFF) //第一路电量数据
- {
- Flash_dp_add_ele_backups[0] = power_data[0];
- Flash_dp_add_ele_backups[0] = (Flash_dp_add_ele_backups[0]<<8) + power_data[1];
- Flash_dp_add_ele_backups[0] = (Flash_dp_add_ele_backups[0]<<8) + power_data[2];
- Flash_dp_add_ele_backups[0] = (Flash_dp_add_ele_backups[0]<<8) + power_data[3];
- }
- if(power_data[7] != 0xFF) //第二路电量数据
- {
- Flash_dp_add_ele_backups[1] = power_data[4];
- Flash_dp_add_ele_backups[1] = (Flash_dp_add_ele_backups[1]<<8) + power_data[5];
- Flash_dp_add_ele_backups[1] = (Flash_dp_add_ele_backups[1]<<8) + power_data[6];
- Flash_dp_add_ele_backups[1] = (Flash_dp_add_ele_backups[1]<<8) + power_data[7];
- }
- if(power_data[11] != 0xFF) //第三路电量数据
- {
- Flash_dp_add_ele_backups[2] = power_data[8];
- Flash_dp_add_ele_backups[2] = (Flash_dp_add_ele_backups[2]<<8) + power_data[9];
- Flash_dp_add_ele_backups[2] = (Flash_dp_add_ele_backups[2]<<8) + power_data[10];
- Flash_dp_add_ele_backups[2] = (Flash_dp_add_ele_backups[2]<<8) + power_data[11];
- }
- }
|