diff options
| author | Bdale Garbee <bdale@gag.com> | 2013-05-16 00:36:23 -0600 | 
|---|---|---|
| committer | Bdale Garbee <bdale@gag.com> | 2013-05-16 00:36:23 -0600 | 
| commit | 02d111b1b53ef01fc6e9ab6c4bc60b8af1be0067 (patch) | |
| tree | 8356f4a019969ee99a45e264c87d38555cf316cc /ao-tools/lib/cc-telemetry.c | |
| parent | 7a2e1f05adad990a6b161865267abf07ffec7a7e (diff) | |
| parent | 7699a55aed3a9a7daeb4c6a5a9a280f43edf455f (diff) | |
Merge branch 'branch-1.2' into debian
Diffstat (limited to 'ao-tools/lib/cc-telemetry.c')
| -rw-r--r-- | ao-tools/lib/cc-telemetry.c | 30 | 
1 files changed, 30 insertions, 0 deletions
diff --git a/ao-tools/lib/cc-telemetry.c b/ao-tools/lib/cc-telemetry.c index 99da2680..88da7f03 100644 --- a/ao-tools/lib/cc-telemetry.c +++ b/ao-tools/lib/cc-telemetry.c @@ -60,3 +60,33 @@ cc_telemetry_parse(const char *input_line, union ao_telemetry_all *telemetry)  	memcpy(telemetry, hex+1, 34);  	return TRUE;  } + +uint8_t +cc_telemetry_cksum(const union ao_telemetry_all *telemetry) +{ +	const uint8_t	*x = (const uint8_t *) telemetry; +	int i; +	uint8_t	sum = 0x5a; +	for (i = 0; i < 34; i++) +		sum += x[i]; +	return sum; +} + +void +cc_telemetry_unparse(const union ao_telemetry_all *telemetry, char output_line[CC_TELEMETRY_BUFSIZE]) +{ +	uint8_t hex[36]; +	int i; +	int p; + +	hex[0] = 34; +	memcpy(hex+1, telemetry, 34); +	hex[35] = cc_telemetry_cksum(telemetry); +	strcpy(output_line, "TELEM "); +	p = strlen(output_line); +	for (i = 0; i < 36; i++) { +		sprintf(output_line + p, "%02x", hex[i]); +		p += 2; +	} +} +		  | 
