線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:3848
推到 Plurk!
推到 Facebook!

請問如何運算CRC?

答題得分者是:李國維
RS
一般會員


發表:7
回覆:12
積分:3
註冊:2009-12-04

發送簡訊給我
#1 引用回覆 回覆 發表時間:2009-12-30 22:03:09 IP:59.113.xxx.xxx 訂閱
請問各位前輩 有關於CRC的製作


小弟我最近寫一個程式 然後要用Modbus RUT來做通連測試 若我送出去的資料是

ID碼 : 01
Function : 03
Starting Address Hi : 00
Starting Address Lo : 00
No. of Registers Hi : 00
No. of Registers Lo : 01
CRC --

而Modbus的Communication Traffic 就會顯示

01 03 00 00 00 01 XX XX


因為我知道 把上面這些值 丟入CRC的運算法裡 就會得到CRC的值


但我試了很多網路上的程式 還是無法讓CRC的值出來


不知道各位前輩 是否可以幫忙指點一下


我的程式軟體是BCB6.0 RS232通連 通訊元件 VB MSComm 謝謝

foreman
高階會員


發表:3
回覆:124
積分:190
註冊:2004-09-10

發送簡訊給我
#2 引用回覆 回覆 發表時間:2009-12-31 11:24:28 IP:114.39.xxx.xxx 未訂閱
RS
一般會員


發表:7
回覆:12
積分:3
註冊:2009-12-04

發送簡訊給我
#3 引用回覆 回覆 發表時間:2010-01-06 00:47:16 IP:59.113.xxx.xxx 訂閱

===================引 用 foreman 文 章===================
大大:
參考這篇看看
http://www.haifeng.idv.tw/leo/cgi-bin/topic.cgi?forum=46&topic=51




抱歉 因為最近很忙 所以沒上來看


foreman前輩 很感謝你提供的資料 但我看不太懂意思


能麻煩foreman前輩 or 各位前輩 可以再指點小弟一下嗎? 謝謝
李國維
高階會員


發表:42
回覆:287
積分:235
註冊:2003-02-07

發送簡訊給我
#4 引用回覆 回覆 發表時間:2010-01-06 11:18:26 IP:61.67.xxx.xxx 訂閱

[code cpp]
static Byte CRCHi[]={
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,
0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,
0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,
0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40
};
static Byte CRCLo[]={
0x00, 0xC0, 0xC1, 0x01, 0xC3, 0x03, 0x02, 0xC2, 0xC6, 0x06,
0x07, 0xC7, 0x05, 0xC5, 0xC4, 0x04, 0xCC, 0x0C, 0x0D, 0xCD,
0x0F, 0xCF, 0xCE, 0x0E, 0x0A, 0xCA, 0xCB, 0x0B, 0xC9, 0x09,
0x08, 0xC8, 0xD8, 0x18, 0x19, 0xD9, 0x1B, 0xDB, 0xDA, 0x1A,
0x1E, 0xDE, 0xDF, 0x1F, 0xDD, 0x1D, 0x1C, 0xDC, 0x14, 0xD4,
0xD5, 0x15, 0xD7, 0x17, 0x16, 0xD6, 0xD2, 0x12, 0x13, 0xD3,
0x11, 0xD1, 0xD0, 0x10, 0xF0, 0x30, 0x31, 0xF1, 0x33, 0xF3,
0xF2, 0x32, 0x36, 0xF6, 0xF7, 0x37, 0xF5, 0x35, 0x34, 0xF4,
0x3C, 0xFC, 0xFD, 0x3D, 0xFF, 0x3F, 0x3E, 0xFE, 0xFA, 0x3A,
0x3B, 0xFB, 0x39, 0xF9, 0xF8, 0x38, 0x28, 0xE8, 0xE9, 0x29,
0xEB, 0x2B, 0x2A, 0xEA, 0xEE, 0x2E, 0x2F, 0xEF, 0x2D, 0xED,
0xEC, 0x2C, 0xE4, 0x24, 0x25, 0xE5, 0x27, 0xE7, 0xE6, 0x26,
0x22, 0xE2, 0xE3, 0x23, 0xE1, 0x21, 0x20, 0xE0, 0xA0, 0x60,
0x61, 0xA1, 0x63, 0xA3, 0xA2, 0x62, 0x66, 0xA6, 0xA7, 0x67,
0xA5, 0x65, 0x64, 0xA4, 0x6C, 0xAC, 0xAD, 0x6D, 0xAF, 0x6F,
0x6E, 0xAE, 0xAA, 0x6A, 0x6B, 0xAB, 0x69, 0xA9, 0xA8, 0x68,
0x78, 0xB8, 0xB9, 0x79, 0xBB, 0x7B, 0x7A, 0xBA, 0xBE, 0x7E,
0x7F, 0xBF, 0x7D, 0xBD, 0xBC, 0x7C, 0xB4, 0x74, 0x75, 0xB5,
0x77, 0xB7, 0xB6, 0x76, 0x72, 0xB2, 0xB3, 0x73, 0xB1, 0x71,
0x70, 0xB0, 0x50, 0x90, 0x91, 0x51, 0x93, 0x53, 0x52, 0x92,
0x96, 0x56, 0x57, 0x97, 0x55, 0x95, 0x94, 0x54, 0x9C, 0x5C,
0x5D, 0x9D, 0x5F, 0x9F, 0x9E, 0x5E, 0x5A, 0x9A, 0x9B, 0x5B,
0x99, 0x59, 0x58, 0x98, 0x88, 0x48, 0x49, 0x89, 0x4B, 0x8B,
0x8A, 0x4A, 0x4E, 0x8E, 0x8F, 0x4F, 0x8D, 0x4D, 0x4C, 0x8C,
0x44, 0x84, 0x85, 0x45, 0x87, 0x47, 0x46, 0x86, 0x82, 0x42,
0x43, 0x83, 0x41, 0x81, 0x80, 0x40 } ;
void __ fastcall TForm1::Send()
{
byte buf[8];
int i,j,i_Hi=0xFF,i_Low=0xFF,i_CRC;
buf[0] = 1;
buf[1] = 3;
buf[2] = 0;
buf[3] = 0;
buf[4] = 0;
buf[5] = 1;

for (i=0 ; i < 6 ; i )
{
j = i_Hi ^ buf[i];
i_Hi = i_Low ^ CRCHi[j];
i_Low = CRCLo[j];
}
i_CRC = (i_Hi << 8 | i_Low);
if (i_CRC > 256)
{
buf[6] = i_CRC /256 ;
buf[7] = i_CRC % 256 ;
}
else
{
buf[6] = 0x00;
buf[7] = i_CRC;
}

[/code]

RS
一般會員


發表:7
回覆:12
積分:3
註冊:2009-12-04

發送簡訊給我
#5 引用回覆 回覆 發表時間:2010-01-12 16:28:34 IP:118.171.xxx.xxx 訂閱

===================引 用 李國維 文 章===================

[code cpp]
static Byte CRCHi[]={
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,
0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,
0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,
0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40
};
static Byte CRCLo[]={
0x00, 0xC0, 0xC1, 0x01, 0xC3, 0x03, 0x02, 0xC2, 0xC6, 0x06,
0x07, 0xC7, 0x05, 0xC5, 0xC4, 0x04, 0xCC, 0x0C, 0x0D, 0xCD,
0x0F, 0xCF, 0xCE, 0x0E, 0x0A, 0xCA, 0xCB, 0x0B, 0xC9, 0x09,
0x08, 0xC8, 0xD8, 0x18, 0x19, 0xD9, 0x1B, 0xDB, 0xDA, 0x1A,
0x1E, 0xDE, 0xDF, 0x1F, 0xDD, 0x1D, 0x1C, 0xDC, 0x14, 0xD4,
0xD5, 0x15, 0xD7, 0x17, 0x16, 0xD6, 0xD2, 0x12, 0x13, 0xD3,
0x11, 0xD1, 0xD0, 0x10, 0xF0, 0x30, 0x31, 0xF1, 0x33, 0xF3,
0xF2, 0x32, 0x36, 0xF6, 0xF7, 0x37, 0xF5, 0x35, 0x34, 0xF4,
0x3C, 0xFC, 0xFD, 0x3D, 0xFF, 0x3F, 0x3E, 0xFE, 0xFA, 0x3A,
0x3B, 0xFB, 0x39, 0xF9, 0xF8, 0x38, 0x28, 0xE8, 0xE9, 0x29,
0xEB, 0x2B, 0x2A, 0xEA, 0xEE, 0x2E, 0x2F, 0xEF, 0x2D, 0xED,
0xEC, 0x2C, 0xE4, 0x24, 0x25, 0xE5, 0x27, 0xE7, 0xE6, 0x26,
0x22, 0xE2, 0xE3, 0x23, 0xE1, 0x21, 0x20, 0xE0, 0xA0, 0x60,
0x61, 0xA1, 0x63, 0xA3, 0xA2, 0x62, 0x66, 0xA6, 0xA7, 0x67,
0xA5, 0x65, 0x64, 0xA4, 0x6C, 0xAC, 0xAD, 0x6D, 0xAF, 0x6F,
0x6E, 0xAE, 0xAA, 0x6A, 0x6B, 0xAB, 0x69, 0xA9, 0xA8, 0x68,
0x78, 0xB8, 0xB9, 0x79, 0xBB, 0x7B, 0x7A, 0xBA, 0xBE, 0x7E,
0x7F, 0xBF, 0x7D, 0xBD, 0xBC, 0x7C, 0xB4, 0x74, 0x75, 0xB5,
0x77, 0xB7, 0xB6, 0x76, 0x72, 0xB2, 0xB3, 0x73, 0xB1, 0x71,
0x70, 0xB0, 0x50, 0x90, 0x91, 0x51, 0x93, 0x53, 0x52, 0x92,
0x96, 0x56, 0x57, 0x97, 0x55, 0x95, 0x94, 0x54, 0x9C, 0x5C,
0x5D, 0x9D, 0x5F, 0x9F, 0x9E, 0x5E, 0x5A, 0x9A, 0x9B, 0x5B,
0x99, 0x59, 0x58, 0x98, 0x88, 0x48, 0x49, 0x89, 0x4B, 0x8B,
0x8A, 0x4A, 0x4E, 0x8E, 0x8F, 0x4F, 0x8D, 0x4D, 0x4C, 0x8C,
0x44, 0x84, 0x85, 0x45, 0x87, 0x47, 0x46, 0x86, 0x82, 0x42,
0x43, 0x83, 0x41, 0x81, 0x80, 0x40 } ;
void __ fastcall TForm1::Send()
{
? byte buf[8];
? int? i,j,i_Hi=0xFF,i_Low=0xFF,i_CRC;
? buf[0] = 1;
? buf[1] = 3;
? buf[2] = 0;
? buf[3] = 0;
? buf[4] = 0;
? buf[5] = 1;

for (i=0 ; i < 6? ; i )
{
j = i_Hi ^ buf[i];
i_Hi = i_Low ^ CRCHi[j];
i_Low = CRCLo[j];
}
i_CRC = (i_Hi << 8 | i_Low);
if (i_CRC > 256)
{
buf[6] = i_CRC /256 ;
buf[7] = i_CRC % 256 ;
}
else
{
?buf[6] = 0x00;
?buf[7] = i_CRC;
}

[/code]




感謝國維前輩的指點 但在測試的時候 還是出現了小問題

因為ASCii碼只要大於128的值 Modbus就會顯示00的數字( 原本該顯示0x80的值 )

請問一下國維前輩or各位前輩 誰可以幫忙指點一下 謝謝




李國維
高階會員


發表:42
回覆:287
積分:235
註冊:2003-02-07

發送簡訊給我
#6 引用回覆 回覆 發表時間:2010-01-12 17:04:16 IP:118.165.xxx.xxx 訂閱
宣告為unsigned char
===================引 用 RS 文 章===================

===================引 用 李國維 文 章===================

[code cpp]
static Byte CRCHi[]={
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,
0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,
0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,
0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40
};
static Byte CRCLo[]={
0x00, 0xC0, 0xC1, 0x01, 0xC3, 0x03, 0x02, 0xC2, 0xC6, 0x06,
0x07, 0xC7, 0x05, 0xC5, 0xC4, 0x04, 0xCC, 0x0C, 0x0D, 0xCD,
0x0F, 0xCF, 0xCE, 0x0E, 0x0A, 0xCA, 0xCB, 0x0B, 0xC9, 0x09,
0x08, 0xC8, 0xD8, 0x18, 0x19, 0xD9, 0x1B, 0xDB, 0xDA, 0x1A,
0x1E, 0xDE, 0xDF, 0x1F, 0xDD, 0x1D, 0x1C, 0xDC, 0x14, 0xD4,
0xD5, 0x15, 0xD7, 0x17, 0x16, 0xD6, 0xD2, 0x12, 0x13, 0xD3,
0x11, 0xD1, 0xD0, 0x10, 0xF0, 0x30, 0x31, 0xF1, 0x33, 0xF3,
0xF2, 0x32, 0x36, 0xF6, 0xF7, 0x37, 0xF5, 0x35, 0x34, 0xF4,
0x3C, 0xFC, 0xFD, 0x3D, 0xFF, 0x3F, 0x3E, 0xFE, 0xFA, 0x3A,
0x3B, 0xFB, 0x39, 0xF9, 0xF8, 0x38, 0x28, 0xE8, 0xE9, 0x29,
0xEB, 0x2B, 0x2A, 0xEA, 0xEE, 0x2E, 0x2F, 0xEF, 0x2D, 0xED,
0xEC, 0x2C, 0xE4, 0x24, 0x25, 0xE5, 0x27, 0xE7, 0xE6, 0x26,
0x22, 0xE2, 0xE3, 0x23, 0xE1, 0x21, 0x20, 0xE0, 0xA0, 0x60,
0x61, 0xA1, 0x63, 0xA3, 0xA2, 0x62, 0x66, 0xA6, 0xA7, 0x67,
0xA5, 0x65, 0x64, 0xA4, 0x6C, 0xAC, 0xAD, 0x6D, 0xAF, 0x6F,
0x6E, 0xAE, 0xAA, 0x6A, 0x6B, 0xAB, 0x69, 0xA9, 0xA8, 0x68,
0x78, 0xB8, 0xB9, 0x79, 0xBB, 0x7B, 0x7A, 0xBA, 0xBE, 0x7E,
0x7F, 0xBF, 0x7D, 0xBD, 0xBC, 0x7C, 0xB4, 0x74, 0x75, 0xB5,
0x77, 0xB7, 0xB6, 0x76, 0x72, 0xB2, 0xB3, 0x73, 0xB1, 0x71,
0x70, 0xB0, 0x50, 0x90, 0x91, 0x51, 0x93, 0x53, 0x52, 0x92,
0x96, 0x56, 0x57, 0x97, 0x55, 0x95, 0x94, 0x54, 0x9C, 0x5C,
0x5D, 0x9D, 0x5F, 0x9F, 0x9E, 0x5E, 0x5A, 0x9A, 0x9B, 0x5B,
0x99, 0x59, 0x58, 0x98, 0x88, 0x48, 0x49, 0x89, 0x4B, 0x8B,
0x8A, 0x4A, 0x4E, 0x8E, 0x8F, 0x4F, 0x8D, 0x4D, 0x4C, 0x8C,
0x44, 0x84, 0x85, 0x45, 0x87, 0x47, 0x46, 0x86, 0x82, 0x42,
0x43, 0x83, 0x41, 0x81, 0x80, 0x40 } ;
void __ fastcall TForm1::Send()
{
? byte buf[8];
? int? i,j,i_Hi=0xFF,i_Low=0xFF,i_CRC;
? buf[0] = 1;
? buf[1] = 3;
? buf[2] = 0;
? buf[3] = 0;
? buf[4] = 0;
? buf[5] = 1;

for (i=0 ; i < 6? ; i )
{
j = i_Hi ^ buf[i];
i_Hi = i_Low ^ CRCHi[j];
i_Low = CRCLo[j];
}
i_CRC = (i_Hi << 8 | i_Low);
if (i_CRC > 256)
{
buf[6] = i_CRC /256 ;
buf[7] = i_CRC % 256 ;
}
else
{
?buf[6] = 0x00;
?buf[7] = i_CRC;
}

[/code]




感謝國維前輩的指點 但在測試的時候 還是出現了小問題

因為ASCii碼只要大於128的值 Modbus就會顯示00的數字(原本該顯示0x80的值 )

請問一下國維前輩or各位前輩 誰可以幫忙指點一下 謝謝




RS
一般會員


發表:7
回覆:12
積分:3
註冊:2009-12-04

發送簡訊給我
#7 引用回覆 回覆 發表時間:2010-01-13 11:17:48 IP:118.171.xxx.xxx 訂閱

感謝國維前輩的指點 但改unsigned char 情況還是一樣


不知道是不是不能這樣使用 還是我修改的宣告部份錯誤


不知道國維前輩 還是各位前輩 能有比較好的辦法 能指點我一下 謝謝


還是我傳送給Modbus的程式是有問題的 下面是我傳送給Modbus的程式

String A;

MSComm1->Output =(A.sprintf("\%c",buf[0])) ;


如果有錯誤能麻煩各位前輩指點一下嗎


最近一直麻煩 國維前輩 跟 各位前輩們 抱歉了


編輯記錄
RS 重新編輯於 2010-01-13 15:29:17, 註解 無‧
暗黑破壞神
版主


發表:9
回覆:2301
積分:1627
註冊:2004-10-04

發送簡訊給我
#8 引用回覆 回覆 發表時間:2010-01-15 09:00:11 IP:114.46.xxx.xxx 未訂閱
http://www.lammertbies.nl/comm/info/crc-calculation.html

去了解一下吧.
RS
一般會員


發表:7
回覆:12
積分:3
註冊:2009-12-04

發送簡訊給我
#9 引用回覆 回覆 發表時間:2010-01-15 10:41:13 IP:118.171.xxx.xxx 訂閱

===================引 用 暗黑破壞神 文 章===================
http://www.lammertbies.nl/comm/info/crc-calculation.html

去了解一下吧.




很感謝暗黑破壞神前輩的指點 但這個網站 我之前就去了解過了


但我現在的疑問是 VB MSComm要傳送超過128的值 是否要改變VB MSComm傳送的格式?


還是要怎樣處理 才能讓VB MSComm正常的傳送


不知道各位前輩有什麼建議 是否能提出來讓我試試看 謝謝


有勞各位前輩 抱歉了~

李國維
高階會員


發表:42
回覆:287
積分:235
註冊:2003-02-07

發送簡訊給我
#10 引用回覆 回覆 發表時間:2010-01-15 16:21:50 IP:61.67.xxx.xxx 訂閱
我沒用過VB的MSCOMM元件。要不要試著用WinAPI去控制RS232

請參考:
http://delphi.ktop.com.tw/board.php?cid=168&fid=917&tid=97624
http://delphi.ktop.com.tw/board.php?cid=168&fid=917&tid=77628

或是透過KTOP找尋,相信會有很多更好的資料

===================引 用 RS 文 章===================

===================引 用 暗黑破壞神 文 章===================
http://www.lammertbies.nl/comm/info/crc-calculation.html

去了解一下吧.




很感謝暗黑破壞神前輩的指點 但這個網站 我之前就去了解過了


但我現在的疑問是 VB MSComm要傳送超過128的值 是否要改變VB MSComm傳送的格式?


還是要怎樣處理 才能讓VB MSComm正常的傳送


不知道各位前輩有什麼建議 是否能提出來讓我試試看 謝謝


有勞各位前輩 抱歉了~

RS
一般會員


發表:7
回覆:12
積分:3
註冊:2009-12-04

發送簡訊給我
#11 引用回覆 回覆 發表時間:2010-01-19 09:00:42 IP:118.171.xxx.xxx 訂閱
我試了 Win32 API 去控制RS232 雖然可以傳送ASC128以上的值


但也發現有一點小缺點 那就是我傳送
buf[0] = 1;
buf[1] = 3;
buf[2] = 0;
buf[3] = 0;
buf[4] = 0;
buf[5] = 1;
CRC

Modbus卻顯示 01 03 01 84 0A

正確的顯示是 01 03 00 00 00 01 84 0A

好像有"0"的值 都無法顯示在Modbus上

我也試了很久 但也無法弄出來 能請各位前輩幫忙一下嗎 謝謝 麻煩各位了


這是我連接RS232的程式
h_RS232 = CreateFile("Com1" ,
GENERIC_READ | GENERIC_WRITE ,
0 ,
NULL ,
OPEN_EXISTING ,
0 ,
NULL );

這是我傳輸給Modbus的程式
if (SetCommState(h_RS232 , &dcb))
{
DWORD ByteCount;
WriteFile(h_RS232 ,
Label3->Caption.c_str() ,
strlen(Label3->Caption.c_str()) ,
&ByteCount ,
NULL);

}

編輯記錄
RS 重新編輯於 2010-01-20 18:08:43, 註解 無‧
RS 重新編輯於 2010-01-21 08:42:34, 註解 無‧
系統時間:2024-11-23 0:08:01
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!