summaryrefslogtreecommitdiff
path: root/hid/pico/src/ph_tools.h
blob: 489302c434d6472da84faa9c2f84f944cb734bfd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/*****************************************************************************
#                                                                            #
#    KVMD - The main PiKVM daemon.                                           #
#                                                                            #
#    Copyright (C) 2018-2024  Maxim Devaev <[email protected]>               #
#                                                                            #
#    This program is free software: you can redistribute it and/or modify    #
#    it under the terms of the GNU General Public License as published by    #
#    the Free Software Foundation, either version 3 of the License, or       #
#    (at your option) any later version.                                     #
#                                                                            #
#    This program is distributed in the hope that it will be useful,         #
#    but WITHOUT ANY WARRANTY; without even the implied warranty of          #
#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the           #
#    GNU General Public License for more details.                            #
#                                                                            #
#    You should have received a copy of the GNU General Public License       #
#    along with this program.  If not, see <https://www.gnu.org/licenses/>.  #
#                                                                            #
*****************************************************************************/


#pragma once

#include "ph_types.h"


inline u16 ph_crc16(const u8 *buf, uz len) {
	const u16 polinom = 0xA001;
	u16 crc = 0xFFFF;

	for (uz byte_count = 0; byte_count < len; ++byte_count) {
		crc = crc ^ buf[byte_count];
		for (uz bit_count = 0; bit_count < 8; ++bit_count) {
			if ((crc & 0x0001) == 0) {
				crc = crc >> 1;
			} else {
				crc = crc >> 1;
				crc = crc ^ polinom;
			}
		}
	}
	return crc;
}

inline s16 ph_merge8_s16(u8 a, u8 b) {
	return (((int)a << 8) | (int)b);
}

inline u16 ph_merge8_u16(u8 a, u8 b) {
	return (((u16)a << 8) | (u16)b);
}

inline void ph_split16(u16 from, u8 *to_a, u8 *to_b) {
	*to_a = (u8)(from >> 8);
	*to_b = (u8)(from & 0xFF);
}