123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293 |
- /**************************************************************************************************
-
- Phyplus Microelectronics Limited confidential and proprietary.
- All rights reserved.
- IMPORTANT: All rights of this software belong to Phyplus Microelectronics
- Limited ("Phyplus"). Your use of this Software is limited to those
- specific rights granted under the terms of the business contract, the
- confidential agreement, the non-disclosure agreement and any other forms
- of agreements as a customer or a partner of Phyplus. You may not use this
- Software unless you agree to abide by the terms of these agreements.
- You acknowledge that the Software may not be modified, copied,
- distributed or disclosed unless embedded on a Phyplus Bluetooth Low Energy
- (BLE) integrated circuit, either as a product or is integrated into your
- products. Other than for the aforementioned purposes, you may not use,
- reproduce, copy, prepare derivative works of, modify, distribute, perform,
- display or sell this Software and/or its documentation for any purposes.
- YOU FURTHER ACKNOWLEDGE AND AGREE THAT THE SOFTWARE AND DOCUMENTATION ARE
- PROVIDED AS IS WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED,
- INCLUDING WITHOUT LIMITATION, ANY WARRANTY OF MERCHANTABILITY, TITLE,
- NON-INFRINGEMENT AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL
- PHYPLUS OR ITS SUBSIDIARIES BE LIABLE OR OBLIGATED UNDER CONTRACT,
- NEGLIGENCE, STRICT LIABILITY, CONTRIBUTION, BREACH OF WARRANTY, OR OTHER
- LEGAL EQUITABLE THEORY ANY DIRECT OR INDIRECT DAMAGES OR EXPENSES
- INCLUDING BUT NOT LIMITED TO ANY INCIDENTAL, SPECIAL, INDIRECT, PUNITIVE
- OR CONSEQUENTIAL DAMAGES, LOST PROFITS OR LOST DATA, COST OF PROCUREMENT
- OF SUBSTITUTE GOODS, TECHNOLOGY, SERVICES, OR ANY CLAIMS BY THIRD PARTIES
- (INCLUDING BUT NOT LIMITED TO ANY DEFENSE THEREOF), OR OTHER SIMILAR COSTS.
-
- **************************************************************************************************/
- /*
- crc16
- */
- #include "crc16.h"
- void InvertUint8(unsigned char *dBuf, unsigned char *srcBuf)
- {
- int i;
- unsigned char tmp[4];
- tmp[0] = 0;
- for (i = 0; i< 8; i++)
- {
- if (srcBuf[0] & (1 << i))
- tmp[0] |= 1 << (7 - i);
- }
- dBuf[0] = tmp[0];
- }
- void InvertUint16(unsigned short *dBuf, unsigned short *srcBuf)
- {
- int i;
- unsigned short tmp[4];
- tmp[0] = 0;
- for (i = 0; i< 16; i++)
- {
- if (srcBuf[0] & (1 << i))
- tmp[0] |= 1 << (15 - i);
- }
- dBuf[0] = tmp[0];
- }
- void InvertUint32(unsigned int *dBuf, unsigned int *srcBuf)
- {
- int i;
- unsigned int tmp[4];
- tmp[0] = 0;
- for (i = 0; i< 32; i++)
- {
- if (srcBuf[0] & (1 << i))
- tmp[0] |= 1 << (15 - i);
- }
- dBuf[0] = tmp[0];
- }
- unsigned short crc16_CCITT(unsigned char *puchMsg, unsigned int usDataLen)
- {
- unsigned short wCRCin = 0x0000;
- unsigned short wCPoly = 0x1021;
- unsigned char wChar = 0;
- while (usDataLen--)
- {
- wChar = *(puchMsg++);
- InvertUint8(&wChar, &wChar);
- wCRCin ^= (wChar << 8);
- for (int i = 0; i < 8; i++)
- {
- if (wCRCin & 0x8000)
- wCRCin = (wCRCin << 1) ^ wCPoly;
- else
- wCRCin = wCRCin << 1;
- }
- }
- InvertUint16(&wCRCin, &wCRCin);
- return (wCRCin);
- }
- unsigned short crc16_CCITT_FALSE(unsigned char *puchMsg, unsigned int usDataLen)
- {
- unsigned short wCRCin = 0xFFFF;
- unsigned short wCPoly = 0x1021;
- unsigned char wChar = 0;
- while (usDataLen--)
- {
- wChar = *(puchMsg++);
- wCRCin ^= (wChar << 8);
- for (int i = 0; i < 8; i++)
- {
- if (wCRCin & 0x8000)
- wCRCin = (wCRCin << 1) ^ wCPoly;
- else
- wCRCin = wCRCin << 1;
- }
- }
- return (wCRCin);
- }
- unsigned short crc16_XMODEM(unsigned char *puchMsg, unsigned int usDataLen)
- {
- unsigned short wCRCin = 0x0000;
- unsigned short wCPoly = 0x1021;
- unsigned char wChar = 0;
- while (usDataLen--)
- {
- wChar = *(puchMsg++);
- wCRCin ^= (wChar << 8);
- for (int i = 0; i < 8; i++)
- {
- if (wCRCin & 0x8000)
- wCRCin = (wCRCin << 1) ^ wCPoly;
- else
- wCRCin = wCRCin << 1;
- }
- }
- return (wCRCin);
- }
- unsigned short crc16_X25(unsigned char *puchMsg, unsigned int usDataLen)
- {
- unsigned short wCRCin = 0xFFFF;
- unsigned short wCPoly = 0x1021;
- unsigned char wChar = 0;
- while (usDataLen--)
- {
- wChar = *(puchMsg++);
- InvertUint8(&wChar, &wChar);
- wCRCin ^= (wChar << 8);
- for (int i = 0; i < 8; i++)
- {
- if (wCRCin & 0x8000)
- wCRCin = (wCRCin << 1) ^ wCPoly;
- else
- wCRCin = wCRCin << 1;
- }
- }
- InvertUint16(&wCRCin, &wCRCin);
- return (wCRCin ^ 0xFFFF);
- }
- unsigned short crc16_MODBUS(unsigned char *puchMsg, unsigned int usDataLen)
- {
- unsigned short wCRCin = 0xFFFF;
- unsigned short wCPoly = 0x8005;
- unsigned char wChar = 0;
- while (usDataLen--)
- {
- wChar = *(puchMsg++);
- InvertUint8(&wChar, &wChar);
- wCRCin ^= (wChar << 8);
- for (int i = 0; i < 8; i++)
- {
- if (wCRCin & 0x8000)
- wCRCin = (wCRCin << 1) ^ wCPoly;
- else
- wCRCin = wCRCin << 1;
- }
- }
- InvertUint16(&wCRCin, &wCRCin);
- return (wCRCin);
- }
- unsigned short crc16_IBM(unsigned char *puchMsg, unsigned int usDataLen)
- {
- unsigned short wCRCin = 0x0000;
- unsigned short wCPoly = 0x8005;
- unsigned char wChar = 0;
- while (usDataLen--)
- {
- wChar = *(puchMsg++);
- InvertUint8(&wChar, &wChar);
- wCRCin ^= (wChar << 8);
- for (int i = 0; i < 8; i++)
- {
- if (wCRCin & 0x8000)
- wCRCin = (wCRCin << 1) ^ wCPoly;
- else
- wCRCin = wCRCin << 1;
- }
- }
- InvertUint16(&wCRCin, &wCRCin);
- return (wCRCin);
- }
- unsigned short crc16_MAXIM(unsigned char *puchMsg, unsigned int usDataLen)
- {
- unsigned short wCRCin = 0x0000;
- unsigned short wCPoly = 0x8005;
- unsigned char wChar = 0;
- while (usDataLen--)
- {
- wChar = *(puchMsg++);
- InvertUint8(&wChar, &wChar);
- wCRCin ^= (wChar << 8);
- for (int i = 0; i < 8; i++)
- {
- if (wCRCin & 0x8000)
- wCRCin = (wCRCin << 1) ^ wCPoly;
- else
- wCRCin = wCRCin << 1;
- }
- }
- InvertUint16(&wCRCin, &wCRCin);
- return (wCRCin ^ 0xFFFF);
- }
- unsigned short crc16_USB(unsigned char *puchMsg, unsigned int usDataLen)
- {
- unsigned short wCRCin = 0xFFFF;
- unsigned short wCPoly = 0x8005;
- unsigned char wChar = 0;
- while (usDataLen--)
- {
- wChar = *(puchMsg++);
- InvertUint8(&wChar, &wChar);
- wCRCin ^= (wChar << 8);
- for (int i = 0; i < 8; i++)
- {
- if (wCRCin & 0x8000)
- wCRCin = (wCRCin << 1) ^ wCPoly;
- else
- wCRCin = wCRCin << 1;
- }
- }
- InvertUint16(&wCRCin, &wCRCin);
- return (wCRCin ^ 0xFFFF);
- }
- static uint16_t crc16_byte(uint16_t crc, uint8_t byte)
- {
- static const uint16_t crc16_table[16] =
- {
- 0x0000, 0xCC01, 0xD801, 0x1400, 0xF001, 0x3C00, 0x2800, 0xE401,
- 0xA001, 0x6C00, 0x7800, 0xB401, 0x5000, 0x9C01, 0x8801, 0x4400
- };
- uint16_t temp;
- // Compute checksum of lower four bits of a byte.
- temp = crc16_table[crc & 0xF];
- crc = (crc >> 4u) & 0x0FFFu;
- crc = crc ^ temp ^ crc16_table[byte & 0xF];
- // Now compute checksum of upper four bits of a byte.
- temp = crc16_table[crc & 0xF];
- crc = (crc >> 4u) & 0x0FFFu;
- crc = crc ^ temp ^ crc16_table[(byte >> 4u) & 0xF];
- return crc;
- }
- uint16_t crc16(uint16_t seed, const volatile void * p_data, uint32_t size)
- {
- uint8_t * p_block = (uint8_t *)p_data;
- while (size != 0)
- {
- seed = crc16_byte(seed, *p_block);
- p_block++;
- size--;
- }
- return seed;
- }
|