CRC 코드 작성 질문 있습니다.

kit9090의 이미지

안녕하세요

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 씩 옮기기 위해서 취하는 동작일 겁니다.
bit shift 연산의 비용이 매우 비싸기 때문에 보통은 모든 bit shift 연산을 미리 해놓은 crc lookup table을 만들어서 씁니다.

공부삼아 구현해 보시고, 실제 업무 적용시에는 그냥 crc 오픈 소스를 사용하십시요.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.