














										
					
	//功能:数据加上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;
}