用C对RN8302B进行数据读写
- typedef unsigned char u8;
- typedef signed char s8;
- typedef unsigned short u16;
- typedef signed short s16;
- typedef unsigned long int u32;
- typedef signed long int s32;
- typedef unsigned short WORD;
- typedef unsigned char BOOL;
- #define PinWrite_ADSCLK(x) ( (x) ? (P0_bit.no6 = 1 , PM0_bit.no6 = 1) : (PM0_bit.no6 = 0 , P0_bit.no6 = 0) ) //
- #define PinMode_ADSCLK(x) ( (x == GPIO_MODE_OUT) ? (PM0_bit.no6 = 0) : (PM0_bit.no6 = 1) )
- #define PinRead_ADSDI() (P4_bit.no4)
- #define PinWrite_ADSDO(x) ( (x) ? (P6_bit.no0 = 1 , PM6_bit.no0 = 1) : (PM6_bit.no0 = 0 , P6_bit.no0 = 0) ) //
- #define PinWrite_ADCS(x) ( (x) ? (P6_bit.no1 = 1 , PM6_bit.no1 = 1) : (PM6_bit.no1 = 0 , P6_bit.no1 = 0 ) )
- #define PinWrite_ADRST(x) ( (x) ? (P0_bit.no5 = 1 , PM0_bit.no5 = 1) : (PM0_bit.no5 = 0 , P0_bit.no5 = 0 ) )
- typedef enum {ERROR = 0 , SUCCESS = !ERROR} ErrorStatus;
- typedef struct {
- // u32 Dat : 23;
- // u32 S : 1;
- u8 Dat0;
- u8 Dat1;
- u8 Dat2 : 7;
- u8 S : 1;
- } sDF09;
- typedef struct {
- u32 Dat;
- } sDF11;
- typedef sDF11 sFsEgSh_TypeDef;
- #pragma vector = INTTM01_vect
- __interrupt void MD_INTTM01(void)
- {
- TMIF01 = 0; /* INTTM01 interrupt flag clear */
- SysStamp ++ ;
- }
- u16 fnStamp_Through(u16 Ago)
- {
- extern u16 SysStamp;
- if (SysStamp >= Ago)
- {return (SysStamp - Ago);}
- else
- {return ( (0xffff - Ago) + SysStamp);}
- }
- u16 fnHexToBcd_u16(u16 Dat)
- {
- u16 Result = 0;
- Dat = Dat % 10000;
- Result += (Dat / 1000) * 0x1000;
- Dat = Dat % 1000;
- Result += (Dat / 100) * 0x100;
- Dat = Dat % 100;
- Result += (Dat / 10) * 0x10;
- Dat = Dat % 10;
- Result += Dat;
-
- return(Result);
- }
- u32 fnHexToBcd_u32(u32 Dat)
- {
- u32 result = 0;
-
- Dat = Dat % 100000000;
- result += (Dat / 10000000) * 0x10000000;
- Dat = Dat % 10000000;
- result += (Dat / 1000000) * 0x1000000;
- Dat = Dat % 1000000;
- result += (Dat / 100000) * 0x100000;
- Dat = Dat % 100000;
- result += (Dat / 10000) * 0x10000;
- Dat = Dat % 10000;
- result += (Dat / 1000) * 0x1000;
- Dat = Dat % 1000;
- result += (Dat / 100) * 0x100;
- Dat = Dat % 100;
- result += (Dat / 10) * 0x10;
- Dat = Dat % 10;
- result += Dat;
-
- return(result);
- }
- u16 fnDFConver_Bcd16To16(s16 Dat)
- {
- u16 Result;
- Result = abs(Dat) % 8000;
- Result = fnHexToBcd_u16(Result);
- if(Dat < 0 ) Result |= 0x8000;
- else Result &= 0x7fff;
- return(Result);
- }
- u32 fnDFConver_Bcd32To32(s32 Dat)
- {
- u32 Result;
- Result = labs(Dat) % 80000000;
- Result = fnHexToBcd_u32(Result);
- if(Dat < 0 ) Result |= 0x80000000;
- else Result &= 0x7fffffff;
- return(Result);
- }
- sDF09 fnDFConver_Hex32ToDF09(s32 Dat)
- {
- sDF09 Result;
- memset(&Result , 0 , sizeof(sDF09) );
- if(Dat < 0) Result.S = 1;
- else Result.S = 0;
-
- Dat = labs(Dat) % 800000;
- Dat = fnHexToBcd_u32(Dat);
-
- Result.Dat0 = Dat;
- Result.Dat1 = Dat >> 8;
- Result.Dat2 = Dat >> 16;
- return(Result);
- }
- typedef union //公共数据运算区8字节
- {
- u8 ucTempBuf[8];
- u32 lTemp32;
- u16 wTemp16;
- u8 ucTemp8;
- }sDl645StruDataComm_TypeDef;
- __no_init sDl645StruDataComm_TypeDef Dl645RN8302DataComm;
- __no_init sDl645FrontTmp_TypeDef Dl645FrontTmp;
- __no_init sDl645Front_TypeDef Dl645Front;
- __no_init sDl645Eg_TypeDef Dl645Eg;
- __no_init sDl645FirmParaFile_TypeDef Dl645FirmPara;
- typedef struct
- {
- u8 ChkErrCnt; //读错误计数1
-
- s32 Pw[12]; //{Pa Pb Pc P Qa Qb Qc Q Sa Sb Sc S} 48
- s32 UI[7]; //Ua Ub Uc Ia Ib Ic Inal 28
- s32 VectorU[9]; // 正序、负序、零序电压
- s32 VectorI[9]; // 正序、负序、零序电流
- s32 Pf[4]; //Pf Pfa Pfb Pfc 16
- u32 Frequency; //电网频率,单位: 4
- s32 YUI[3],YUU[2]; //20
-
- s32 Pulse[15]; //前台高频脉冲48
- //---电能脉冲---
- s32 Pulse_EgTmp[20]; //高频脉冲{P,Q,Ps},{Pa,Qa,Psa},{Pb,Qb,Psb},{Pc,Qc,Psc}{Fp,Fq}{Fpa,Fqa}{Fpb,Fqb}{Fpc,Fqc}
- u32 Pulse_Eg[20]; //低频脉冲数
- //---需量脉冲---
- s32 Pulse_NeedTmp[12];
- u16 Pulse_Need[12]; //{PNeed,QNeed,PsNeed},{PNeeda,QNeeda,PsNeeda},{PNeedb,QNeedb,PsNeedb},{PNeedc,QNeedc,PsNeedc}48
-
- u16 Angle[9];
- u16 PDirect; //4
- u32 ChkSum1; //4
- u32 ChkSum2; //4
-
- u16 Temperature; //温度4
- u32 ClockBat; //时钟电池4
- u32 BackupBat; //后备电池4
-
- u16 CF1DelayStamp;
- u16 CF2DelayStamp;
-
- u16 CfIn_P;
- u16 CfIn_q;
-
- u16 CfTime_P;
- u16 CfTime_q;
-
- } sDl645FrontTmp_TypeDef;
- typedef struct
- {
- struct sFrontPubData_TypeDef {
- u16 U[3]; //---电压---NNN.N6
- u16 VectorU[9]; // 正序电压 0--2 负序电压 3---5 零序电压 6---8
- u32 I[4]; //---电流NNNN.NNNN(电流值要求3整3小,整定值要求2整4小,最高位表示方向)---16
- u32 VectorI[9]; // 正序电流 0--2 负序电流 3---5 零序电流 6---8
- sDF09 Pw[12]; //---瞬时有功/无功/视在功率NN.NNNN---{P Pa Pb Pc Q Qa Qb Qc S Sa Sb Sc}36
- u16 Pf[4]; //---功率因数N.NNN--- 最高位表示方向{Pf Pfa Pfb Pfc} 8 sDF05
- u16 Angle[9]; //---相角NNN.N--- 18
- //PhUb,PhUc, 以A相电压为基准,B、C相角度 //(hyg) BCD码
- //PhIa,PhIb,PhIc,A相电流与A相电压间角度、B相电流与B相电压间角度、C相电流与C相电压间角度
- //Angle A,Angle B,Angle C, A相电流与A相电压间角度、B相电流与A相电压间角度、C相电流与A相电压间角度
- //Angle C-Angle A
- u32 UnblU; //电压不平衡度NNNN.NN%4
- u32 UnblI; //电流不平衡度NNNN.NN%4
-
- u16 FuzzyU[3]; //---电压波形失真度NN.NN%--- 6
- u16 FuzzyI[3]; //---电流波形失真度NN.NN%--- 6
- u16 WaveU[3][21]; //---相电压谐波含量NN.NN%--- 126
- u16 WaveI[3][21]; //---相电流谐波含量NN.NN%--- 126
- //---其他---
- u16 Frequency; //NN.NN 2
- u32 PPwave; //NN.NNNN 4
-
- u16 Temperature; //NNN.N 2
- u16 ClockBat; //NN.NN 2
- u16 BackupBat; //NN.NN 2
- u8 PDirect; //原功率方向,用于需量处理(0总/1A/2B/3C , 注意与FrontTmp不同) 1
- } PubData;
-
- struct sFrontPriData_TypeDef {
- u8 Flag; //---工作异常标志---1
- u8 PhaseCalStep;
- u16 FrontStamp;
- // u8 BatCalStep;
- u16 BatStamp;
- // u16 BatDetStamp;
- } PriData;
-
- struct sFrontPriPara_TypeDef {
- u32 PConstE; //有功常数
- u32 QConstE; //无功常数(Hex码)4
- u16 Crc;//2
- } PriPara;
- } sDl645Front_TypeDef; //缓冲区转换后的有效数据
- typedef struct
- {
- u8 FractionI;/*电流小数位数*/
- u8 FractionU;/*电压小数位数*/
- u8 FractionE;/*电能小数位数*/
- u8 FractionP;/*功率需量小数位数*/
- u16 ConstE;/*电表有功常数*/
- u16 Pulse_deltaE;/*数*/
- u8 HighPulseRate;
- u8 PhaseCalStep;
- u32 IRmsConst; //10
- u16 Reserve[2];
- u16 NOLOAD;
- u16 ZEROSTAR; //20
- u32 ChkSum1;
- u16 HFConst1;
- u16 HFConst2;
- u32 VRmsConst; //30
- u16 Reserve1;
- u32 PRmsConst;
- u16 Reserve2;
- u16 VGain[3]; // 42
- u16 IGain[4]; //48
- u8 PHSU[2]; // 56
- u32 PHSI[3];
- u16 PRth[4]; //70
- u16 UI_Offset[7];
- u16 P_PHS[3];/*有功相位校正寄存器*/ // 92
- u16 PGain[3];/*有功增益校正寄存器*/
- }sDl645FirmParaFile_TypeDef;
- typedef struct {
- #pragma pack(1)
- struct sDl645EgPubData_TypeDef
- {
- sFsEgSh_TypeDef AllPEgSh[DL645_MAX_FL + 1];
- sFsEgSh_TypeDef PtPEgSh[DL645_MAX_FL + 1];
- sFsEgSh_TypeDef NtPEgSh[DL645_MAX_FL + 1];
-
- sFsEgSh_TypeDef AllQEgSh[DL645_MAX_FL + 1];
- sFsEgSh_TypeDef PtQEgSh[DL645_MAX_FL + 1];
- sFsEgSh_TypeDef NtQEgSh[DL645_MAX_FL + 1];
-
- sFsEgSh_TypeDef Qd1QEgSh[DL645_MAX_FL + 1];
- sFsEgSh_TypeDef Qd2QEgSh[DL645_MAX_FL + 1];
- sFsEgSh_TypeDef Qd3QEgSh[DL645_MAX_FL + 1];
- sFsEgSh_TypeDef Qd4QEgSh[DL645_MAX_FL + 1];
-
- sFsEgSh_TypeDef PtPsEgSh[DL645_MAX_FL + 1];
- sFsEgSh_TypeDef NtPsEgSh[DL645_MAX_FL + 1];
-
- sFsEgSh_TypeDef AssEgSh;
- sFsEgSh_TypeDef BasePtPEgSh;
- sFsEgSh_TypeDef BaseNtPEgSh;
- sFsEgSh_TypeDef WavePtPEgSh;
- sFsEgSh_TypeDef WaveNtPEgSh;
- sFsEgSh_TypeDef CopPEgSh;
- sFsEgSh_TypeDef IronPEgSh;
- //-------------
- ……………………
- …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码
msp430单片机源程序如下:
所有资料51hei提供下载:
三相计量RN8302B.7z
(4.52 MB, 下载次数: 202)
|