CRC 코드 작성 질문 있습니다.
안녕하세요
PIC microchip 공부를 하고 있습니다.
PIC32 칩을 사용하고 있는데
CRC 코드를 하나 만들었는데
여기저기서 보고 만드느라 이해가 안가는 부분이 있어 질문 드립니다.
unsigned char CRC_Cal(unsigned int NCV78247_DATA){
unsigned int CRC_Seed = 0x9C;
unsigned int CRC_Poly = 0x39;
unsigned int i = 0;
unsigned int Check_CRC_Buffer = 0;
unsigned int Check_CRC_Seed_Buffer = 0;
unsigned int Cal_CRC_Seed = 0;
unsigned int Cal_CRC = 0;
NCV78247_DATA = NCV78247_DATA & 0xFFF;
for (i = 0 ; i < 20 ; i++){
Cal_CRC_Seed = (CRC_Seed / 0x80); <<<<<<<<<<<<<<<<<<<<여기
Check_CRC_Seed_Buffer = (Cal_CRC_Seed & 0x01);
Cal_CRC = (NCV78247_DATA / 0x80000); <<<<<<<<<<<<<<<<<<<<여기
Check_CRC_Buffer = (Check_CRC_Seed_Buffer ^ Cal_CRC) & 0x01;
CRC_Seed = (CRC_Seed << 1);
if (Check_CRC_Buffer != 0){
CRC_Seed = CRC_Seed ^ CRC_Poly;
}
NCV78247_DATA = (NCV78247_DATA << 1);
}
CRC_Seed = CRC_Seed & 0xFF;
return ((unsigned char)CRC_Seed);
}
위 코드에서
"/0x80"과 "/0x8000"
이렇게 연산을 해주는데
왜 그런지 작성당시에는 알았는데
곱씹어보니 또 몰라서
문의를 드립니다.
천재님들 도와주세요
아마 좌우로 1 bit 씩 옮기기 위해서 취하는
아마 좌우로 1 bit 씩 옮기기 위해서 취하는 동작일 겁니다.
bit shift 연산의 비용이 매우 비싸기 때문에 보통은 모든 bit shift 연산을 미리 해놓은 crc lookup table을 만들어서 씁니다.
공부삼아 구현해 보시고, 실제 업무 적용시에는 그냥 crc 오픈 소스를 사용하십시요.
댓글 달기