在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

            EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > PIC單片機(jī)CRC校驗(yàn)程序

            PIC單片機(jī)CRC校驗(yàn)程序

            作者: 時(shí)間:2012-10-29 來(lái)源:網(wǎng)絡(luò) 收藏

            和Dallas的iButtON通訊時(shí),編了段產(chǎn)生和的子

            本文引用地址:http://www.biyoush.com/article/170729.htm

            #include

            ;-------------------------------

            cblock 0x20

            datBuff:8 ;assign 8 byte data buffer

            bit_cnt ;bit counting

            _COUNT ;number of bytes for

            CRC_RESULT ;CRC resulr

            crc_temp ;temporary data buffer during CRC

            endc

            ;-------------------------------

            #define skp0 btfsc

            #define skp1 btfss

            ;===============================

            org 0x000

            movlw .7

            movwf CRC_COUNT

            movlw datBuff

            movwf FSR ;FSR point to data buffer

            call CRC_CHECK

            movwf datBuff+7

            goto $

            ;===============================

            ;CHECK THE CRC FOR ? BYTES DATA

            ;For the polynomial of X^8 + X^5 + X^4 + 1

            ;Derived from Dallas's iButton STandard

            ;Before calling, FSR = data buffer

            ; CRC_COUNT = number of bytes for CRC

            CRC_CHECK ;~~~~~~~~~~~~~~~

            clrf CRC_RESULT ;initialize the CRC buffer

            _crc_00

            movlw .8 ;number of bits for one byte

            movwf bit_cnt ;set bit counter

            movf INDF,w ;get one data byte

            movwf crc_temp ;copy to temporary location

            _crc_01

            rrf crc_temp,f ;get LSB in C

            skpc ;is this LSB=1?

            goto _crc_02 ;go if LSB=0

            movlw 0x01 ;do if LSB=1

            xorwf CRC_RESULT,f

            _crc_02

            rrf CRC_RESULT,w ;get LSB of CRC

            skpc ;test LSB

            goto _crc_03 ;go if LSB=0

            movlw 0x18 ;do if LSB=1

            xorwf CRC_RESULT,f ;polynomial implementation

            _crc_03

            rrf CRC_RESULT,w ;whole byte right rotate

            rrf CRC_RESULT,f

            decfsz bit_cnt,f ;bit counting

            goto _crc_01 ;go on until aa 8 bits done

            incf FSR,f ;pointer update to next byte

            decfsz CRC_COUNT,f ;byte counting

            goto _crc_00 ;go on until all byte done

            movf CRC_RESULT,w ;get CRC, Z set if CRC=0

            return ;return with CRC in W END



            評(píng)論


            相關(guān)推薦

            技術(shù)專區(qū)

            關(guān)閉