summaryrefslogtreecommitdiff
path: root/altoslib/AltosTelemetry.java
diff options
context:
space:
mode:
authorBdale Garbee <bdale@gag.com>2017-12-11 21:39:38 -0700
committerBdale Garbee <bdale@gag.com>2017-12-11 21:39:38 -0700
commit8e0b575ad1dfd5a49136d3fe945d27f6afda1178 (patch)
tree74657870764e6a3792bdd7e90acd725353c20904 /altoslib/AltosTelemetry.java
parent132b92a95bdebabf573a680301bfb1e93eaa6721 (diff)
parentfe38c22595b050435dbacd35f1baae064fb7de75 (diff)
Merge branch 'branch-1.8' into debian
Diffstat (limited to 'altoslib/AltosTelemetry.java')
-rw-r--r--altoslib/AltosTelemetry.java12
1 files changed, 9 insertions, 3 deletions
diff --git a/altoslib/AltosTelemetry.java b/altoslib/AltosTelemetry.java
index f17e1171..a374519d 100644
--- a/altoslib/AltosTelemetry.java
+++ b/altoslib/AltosTelemetry.java
@@ -28,8 +28,11 @@ public abstract class AltosTelemetry implements AltosDataProvider {
int[] bytes;
/* All telemetry packets have these fields */
- public int rssi() { return AltosConvert.telem_to_rssi(AltosLib.int8(bytes, bytes.length - 3)); }
- public int status() { return AltosLib.uint8(bytes, bytes.length - 2); }
+ static public int rssi(int[] bytes) { return AltosConvert.telem_to_rssi(AltosLib.int8(bytes, bytes.length - 3)); }
+ static public int status(int[] bytes) { return AltosLib.uint8(bytes, bytes.length - 2); }
+
+ public int rssi() { return rssi(bytes); }
+ public int status() { return status(bytes); }
/* All telemetry packets report these fields in some form */
public abstract int serial();
@@ -51,7 +54,7 @@ public abstract class AltosTelemetry implements AltosDataProvider {
public void provide_data(AltosDataListener listener) {
listener.set_serial(serial());
- if (listener.state == AltosLib.ao_flight_invalid)
+ if (listener.state() == AltosLib.ao_flight_invalid)
listener.set_state(AltosLib.ao_flight_startup);
if (frequency != AltosLib.MISSING)
listener.set_frequency(frequency);
@@ -96,6 +99,9 @@ public abstract class AltosTelemetry implements AltosDataProvider {
if (!cksum(bytes))
throw new ParseException(String.format("invalid line \"%s\"", hex), 0);
+ if ((status(bytes) & PKT_APPEND_STATUS_1_CRC_OK) == 0)
+ throw new AltosCRCException(rssi(bytes));
+
/* length, data ..., rssi, status, checksum -- 4 bytes extra */
switch (bytes.length) {
case AltosLib.ao_telemetry_standard_len + 4: