-
Notifications
You must be signed in to change notification settings - Fork 0
/
gps.h
73 lines (53 loc) · 1.32 KB
/
gps.h
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
/*
Decode GPS data.
Copyright (C) 2019, ENSIMAG students
This project is under the MIT license
*/
#pragma once
#include <stdint.h>
#include <stdbool.h>
#if GPS == 1
// Return codes.
#define GPS_SUCCESS 0
#define GPS_FAIL 1
// Store the GPS parsed data in ASCII.
typedef struct {
char data_type[6];
char latitude[10];
char latitude_pole[2];
char longitude[11];
char longitude_pole[2];
char fix_quality[2];
char altitude[8];
} gps_nmea_t;
// Store GPS data.
typedef struct {
bool has_fix; // Ara data fixed?
double latitude;
double longitude;
int32_t latitude_bin;
int32_t longitude_bin;
int16_t altitude;
} gps_data_t;
// GPS parsed data.
extern gps_data_t gps_data;
/**
* @brief Get the lastest GPS position in binary format.
* @param lat Where to store the latitude.
* @param lon Where to store the longitude.
* @param alt Where to store the altitude (in m).
* @return Either `GPS_SUCCESS` or `GPS_FAIL`.
*/
uint8_t gps_get_binary(int32_t *lat, int32_t *lon, int16_t *alt);
/**
* @brief Parse GPS data.
* @param rxBuffer GPS data to parse.
* @param rxBufferSize Length of data.
* @return Either `GPS_SUCCESS` or `GPS_FAIL`.
*/
uint8_t gps_parse_data(int8_t *rxBuffer, int32_t rxBufferSize);
/**
* @brief Reset parsed GPS data.
*/
void gps_reset_data(void);
#endif