Merge pull request #11211 from TonyBlit/fix_gps_motion
[betaflight.git] / src / main / rx / frsky_crc.c
blobdafed42bc2d4b88a20a56c47d6d3f0166b45a149
1 /*
2 * This file is part of Cleanflight and Betaflight.
4 * Cleanflight and Betaflight are free software. You can redistribute
5 * this software and/or modify this software under the terms of the
6 * GNU General Public License as published by the Free Software
7 * Foundation, either version 3 of the License, or (at your option)
8 * any later version.
10 * Cleanflight and Betaflight are distributed in the hope that they
11 * will be useful, but WITHOUT ANY WARRANTY; without even the implied
12 * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
13 * See the GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this software.
18 * If not, see <http://www.gnu.org/licenses/>.
21 #include <stdbool.h>
22 #include <stdint.h>
24 #include "platform.h"
26 #include "rx/frsky_crc.h"
28 void frskyCheckSumStep(uint16_t *checksum, uint8_t byte)
30 *checksum += byte;
33 void frskyCheckSumFini(uint16_t *checksum)
35 while (*checksum > 0xFF) {
36 *checksum = (*checksum & 0xFF) + (*checksum >> 8);
39 *checksum = 0xFF - *checksum;
42 static uint8_t frskyCheckSum(uint8_t *data, uint8_t length)
44 uint16_t checksum = 0;
45 for (unsigned i = 0; i < length; i++) {
46 frskyCheckSumStep(&checksum, *data++);
48 frskyCheckSumFini(&checksum);
49 return checksum;
52 bool frskyCheckSumIsGood(uint8_t *data, uint8_t length)
54 return !frskyCheckSum(data, length);