X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=src%2Fkernel%2Fao_log.h;h=1faea957639ce667ad44895b60dd22bf52b893d7;hb=065c60d38f38343bd1f319a87f6b50367a3abbe3;hp=09ae7add80b683f469454cf721c4ad5f7c185410;hpb=ea0ab578e4e745f4ee94c2551834e105152fdba1;p=fw%2Faltos diff --git a/src/kernel/ao_log.h b/src/kernel/ao_log.h index 09ae7add..1faea957 100644 --- a/src/kernel/ao_log.h +++ b/src/kernel/ao_log.h @@ -29,7 +29,7 @@ * the log. Tasks may wait for this to be initialized * by sleeping on this variable. */ -extern int16_t ao_flight_number; +extern uint16_t ao_flight_number; extern uint8_t ao_log_mutex; extern uint32_t ao_log_current_pos; extern uint32_t ao_log_end_pos; @@ -59,13 +59,13 @@ extern enum ao_flight_state ao_log_state; #define AO_LOG_FORMAT_TELESTATIC 17 /* 32 byte typed telestatic records */ #define AO_LOG_FORMAT_MICROPEAK2 18 /* 2-byte baro values with header */ #define AO_LOG_FORMAT_TELEMEGA_4 19 /* 32 byte typed telemega records with 32 bit gyro cal and Bmx160 */ -#define AO_LOG_FORMAT_EASYMOTOR 20 /* ? byte typed easymotor records with pressure sensor and adxl375 */ +#define AO_LOG_FORMAT_EASYMOTOR 20 /* 16 byte typed easymotor records with pressure sensor and adxl375 */ #define AO_LOG_FORMAT_TELEMEGA_5 21 /* 32 byte typed telemega records with 32 bit gyro cal, mpu6000 and mmc5983 */ #define AO_LOG_FORMAT_NONE 127 /* No log at all */ /* Return the flight number from the given log slot, 0 if none, -slot on failure */ -int16_t +int32_t ao_log_flight(uint8_t slot); /* Checksum the loaded log record */ @@ -230,7 +230,7 @@ struct ao_log_mega { struct { uint16_t flight; /* 4 */ int16_t ground_accel; /* 6 */ - uint32_t ground_pres; /* 8 */ + int32_t ground_pres; /* 8 */ int16_t ground_accel_along; /* 12 */ int16_t ground_accel_across; /* 14 */ int16_t ground_accel_through; /* 16 */ @@ -242,7 +242,7 @@ struct ao_log_mega { struct { uint16_t flight; /* 4 */ int16_t ground_accel; /* 6 */ - uint32_t ground_pres; /* 8 */ + int32_t ground_pres; /* 8 */ int16_t ground_accel_along; /* 12 */ int16_t ground_accel_across; /* 14 */ int16_t ground_accel_through; /* 16 */ @@ -390,7 +390,7 @@ struct ao_log_metrum { struct { uint16_t flight; /* 4 */ int16_t ground_accel; /* 6 */ - uint32_t ground_pres; /* 8 */ + int32_t ground_pres; /* 8 */ uint32_t ground_temp; /* 12 */ } flight; /* 16 */ /* AO_LOG_STATE */ @@ -450,7 +450,7 @@ struct ao_log_mini { struct { uint16_t flight; /* 4 */ uint16_t r6; - uint32_t ground_pres; /* 8 */ + int32_t ground_pres; /* 8 */ } flight; /* AO_LOG_STATE */ struct { @@ -469,9 +469,9 @@ struct ao_log_mini { }; /* 16 */ #define ao_log_pack24(dst,value) do { \ - (dst)[0] = (value); \ - (dst)[1] = (value) >> 8; \ - (dst)[2] = (value) >> 16; \ + (dst)[0] = (uint8_t) (value); \ + (dst)[1] = (uint8_t) ((value) >> 8); \ + (dst)[2] = (uint8_t) ((value) >> 16); \ } while (0) struct ao_log_gps {