-
Notifications
You must be signed in to change notification settings - Fork 38
/
Copy pathmisc.ino
81 lines (68 loc) · 2.25 KB
/
misc.ino
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
int BuildSentence(char *TxLine, const char *PayloadID)
{
int Count, i, j;
unsigned char c;
unsigned int CRC, xPolynomial;
char LatitudeString[16], LongitudeString[16], CRCString[8];
SentenceCounter++;
dtostrf(GPS.Latitude, 7, 5, LatitudeString);
dtostrf(GPS.Longitude, 7, 5, LongitudeString);
snprintf(TxLine,
SENTENCE_LENGTH-6,
"$$%s,%d,%02d:%02d:%02d,%s,%s,%05.5ld" EXTRA_FIELD_FORMAT,
PayloadID,
SentenceCounter,
GPS.Hours, GPS.Minutes, GPS.Seconds,
LatitudeString,
LongitudeString,
GPS.Altitude
EXTRA_FIELD_LIST
);
/*
"$$%s,%d,%02d:%02d:%02d,%s,%s,%05.5u,%d,%d,%d",
PAYLOAD_ID,
SentenceCounter,
GPS.Hours, GPS.Minutes, GPS.Seconds,
LatitudeString,
LongitudeString,
GPS.Altitude,
(int)((GPS.Speed * 13) / 7),
GPS.Direction,
GPS.Satellites);
*/
Count = strlen(TxLine);
CRC = 0xffff; // Seed
xPolynomial = 0x1021;
for (i = 2; i < Count; i++)
{ // For speed, repeat calculation instead of looping for each bit
CRC ^= (((unsigned int)TxLine[i]) << 8);
for (j=0; j<8; j++)
{
if (CRC & 0x8000)
CRC = (CRC << 1) ^ 0x1021;
else
CRC <<= 1;
}
}
TxLine[Count++] = '*';
TxLine[Count++] = Hex((CRC >> 12) & 15);
TxLine[Count++] = Hex((CRC >> 8) & 15);
TxLine[Count++] = Hex((CRC >> 4) & 15);
TxLine[Count++] = Hex(CRC & 15);
TxLine[Count++] = '\n';
TxLine[Count++] = '\0';
return strlen(TxLine) + 1;
}
int BuildLoRaCall(unsigned char *TxLine)
{
char Frequency[8];
dtostrf(LORA_FREQUENCY, 7, 3, Frequency);
sprintf((char *)TxLine, "^^%s,%s,%d,%d,%d,%d,%d",
LORA_PAYLOAD_ID, Frequency,
LORA_MODE == 1 ? 1 : 0,
LORA_MODE == 1 ? ERROR_CODING_4_5 : ERROR_CODING_4_8,
LORA_MODE == 2 ? BANDWIDTH_62K5 : BANDWIDTH_20K8,
LORA_MODE == 2 ? SPREADING_8 : (LORA_MODE == 1 ? SPREADING_6 : SPREADING_11),
LORA_MODE == 0 ? 0x08 : 0);
return strlen((char *)TxLine) + 1;
}