标题:求CRC码的c语言实现
只看楼主
zcm211
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2005-10-28
 问题点数:0 回复次数:1 
求CRC码的c语言实现
求CRC码的c语言实现  谢谢
搜索更多相关主题的帖子: CRC c语言 
2005-10-28 11:49
ColorGost
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2005-11-17
得分:0 

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

2005-11-17 14:45



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-31707-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 2.330637 second(s), 9 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved