//功能:数据加上CRC校验码
//参数:BitLength: 待编码的数据比特数
// StartBitPos: 待编码的第一个比特在第一个字节中的位置(0~7)。第一个比特之前的位应事先清零
// TransData: 指向待发送的数据,数据区应预留CRC的位置并清零。
// CRC采用HDLC规定的生成多项式:g(x)=x^16+x^15+x^2+1,共产生16位CRC
void DNP3CRCGenerator( INT16U BitLength, INT16U StartBitPos, INT8U *LTransData )
{
unsigned long lTemp;
INT8U cTemp;
INT16U tmp,i, j, k,CRCtemp[2];
INT32U *VCP;
LTransData=lpDNP3->TransData; //为了去掉编译警告临时加的
cTemp = lpDNP3->TransData[4];
tmp=lpDNP3->TransData[1];
CRCtemp[0]=lpDNP3->TransData[0]|(tmp<<8);
tmp=lpDNP3->TransData[3];
CRCtemp[1]=lpDNP3->TransData[2]|(tmp<<8);
VCP=(INT32U *)CRCtemp;
lTemp=*VCP;
for ( k = 0, j = 0, i = 0; i < BitLength+StartBitPos; i ++ ) //除法运算
{
if ( j == 8 )
{
j = 0;
k ++;
cTemp = lpDNP3->TransData[k+4];
}
if ( lTemp & 1 ) lTemp ^= 0x14d79;//0x0x14003;
lTemp >>= 1;
if ( cTemp & 1 ) lTemp |= 0x80000000;
cTemp >>= 1;
j ++;
}
//除法运算完毕,lTemp的低字中含有CRC
lTemp <<= j;
for ( i = 0; i < 3; i ++ )
{
lpDNP3->TransData[k] ^= (INT8U)( lTemp & 0xff );
k ++;
lTemp >>= 8;
}
//Invert the Crc code ----Special for Dnp
cTemp = ~lpDNP3->TransData[k-1];
lpDNP3->TransData[k-1] = cTemp;
cTemp = ~lpDNP3->TransData[k-2];
lpDNP3-> TransData[k-2] = cTemp;
return;
}