| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1267 人关注过本帖
标题:求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
快速回复:求CRC码的c语言实现
数据加载中...
 
   



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

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