Zephyr API Documentation 4.4.0-rc1
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
gnss.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2023 Trackunit Corporation
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
12
13#ifndef ZEPHYR_INCLUDE_DRIVERS_GNSS_H_
14#define ZEPHYR_INCLUDE_DRIVERS_GNSS_H_
15
24
25#include <zephyr/kernel.h>
26#include <zephyr/types.h>
27#include <zephyr/device.h>
29#include <errno.h>
30
31#ifdef __cplusplus
32extern "C" {
33#endif
34
46
47
48
60
61
62
94
97
98
99
111
129
143
159
164
166typedef int (*gnss_set_fix_rate_t)(const struct device *dev, uint32_t fix_interval_ms);
167
169typedef int (*gnss_get_fix_rate_t)(const struct device *dev, uint32_t *fix_interval_ms);
170
172typedef int (*gnss_set_navigation_mode_t)(const struct device *dev,
173 enum gnss_navigation_mode mode);
174
176typedef int (*gnss_get_navigation_mode_t)(const struct device *dev,
177 enum gnss_navigation_mode *mode);
178
180typedef int (*gnss_set_enabled_systems_t)(const struct device *dev, gnss_systems_t systems);
181
183typedef int (*gnss_get_enabled_systems_t)(const struct device *dev, gnss_systems_t *systems);
184
186typedef int (*gnss_get_supported_systems_t)(const struct device *dev, gnss_systems_t *systems);
187
189typedef int (*gnss_get_latest_timepulse_t)(const struct device *dev, k_ticks_t *timestamp);
190
228
231
241
243typedef void (*gnss_data_callback_t)(const struct device *dev, const struct gnss_data *data);
244
252
270
272typedef void (*gnss_satellites_callback_t)(const struct device *dev,
273 const struct gnss_satellite *satellites,
274 uint16_t size);
275
283
293__syscall int gnss_set_fix_rate(const struct device *dev, uint32_t fix_interval_ms);
294
295static inline int z_impl_gnss_set_fix_rate(const struct device *dev, uint32_t fix_interval_ms)
296{
297 const struct gnss_driver_api *api = (const struct gnss_driver_api *)dev->api;
298
299 if (api->set_fix_rate == NULL) {
300 return -ENOSYS;
301 }
302
303 return api->set_fix_rate(dev, fix_interval_ms);
304}
305
315__syscall int gnss_get_fix_rate(const struct device *dev, uint32_t *fix_interval_ms);
316
317static inline int z_impl_gnss_get_fix_rate(const struct device *dev, uint32_t *fix_interval_ms)
318{
319 const struct gnss_driver_api *api = (const struct gnss_driver_api *)dev->api;
320
321 if (api->get_fix_rate == NULL) {
322 return -ENOSYS;
323 }
324
325 return api->get_fix_rate(dev, fix_interval_ms);
326}
327
337__syscall int gnss_set_navigation_mode(const struct device *dev,
338 enum gnss_navigation_mode mode);
339
340static inline int z_impl_gnss_set_navigation_mode(const struct device *dev,
341 enum gnss_navigation_mode mode)
342{
343 const struct gnss_driver_api *api = (const struct gnss_driver_api *)dev->api;
344
345 if (api->set_navigation_mode == NULL) {
346 return -ENOSYS;
347 }
348
349 return api->set_navigation_mode(dev, mode);
350}
351
361__syscall int gnss_get_navigation_mode(const struct device *dev,
362 enum gnss_navigation_mode *mode);
363
364static inline int z_impl_gnss_get_navigation_mode(const struct device *dev,
365 enum gnss_navigation_mode *mode)
366{
367 const struct gnss_driver_api *api = (const struct gnss_driver_api *)dev->api;
368
369 if (api->get_navigation_mode == NULL) {
370 return -ENOSYS;
371 }
372
373 return api->get_navigation_mode(dev, mode);
374}
375
385__syscall int gnss_set_enabled_systems(const struct device *dev, gnss_systems_t systems);
386
387static inline int z_impl_gnss_set_enabled_systems(const struct device *dev,
388 gnss_systems_t systems)
389{
390 const struct gnss_driver_api *api = (const struct gnss_driver_api *)dev->api;
391
392 if (api->set_enabled_systems == NULL) {
393 return -ENOSYS;
394 }
395
396 return api->set_enabled_systems(dev, systems);
397}
398
408__syscall int gnss_get_enabled_systems(const struct device *dev, gnss_systems_t *systems);
409
410static inline int z_impl_gnss_get_enabled_systems(const struct device *dev,
411 gnss_systems_t *systems)
412{
413 const struct gnss_driver_api *api = (const struct gnss_driver_api *)dev->api;
414
415 if (api->get_enabled_systems == NULL) {
416 return -ENOSYS;
417 }
418
419 return api->get_enabled_systems(dev, systems);
420}
421
431__syscall int gnss_get_supported_systems(const struct device *dev, gnss_systems_t *systems);
432
433static inline int z_impl_gnss_get_supported_systems(const struct device *dev,
434 gnss_systems_t *systems)
435{
436 const struct gnss_driver_api *api = (const struct gnss_driver_api *)dev->api;
437
438 if (api->get_supported_systems == NULL) {
439 return -ENOSYS;
440 }
441
442 return api->get_supported_systems(dev, systems);
443}
444
458__syscall int gnss_get_latest_timepulse(const struct device *dev, k_ticks_t *timestamp);
459
460static inline int z_impl_gnss_get_latest_timepulse(const struct device *dev,
461 k_ticks_t *timestamp)
462{
463 const struct gnss_driver_api *api = (const struct gnss_driver_api *)dev->api;
464
465 if (api->get_latest_timepulse == NULL) {
466 return -ENOSYS;
467 }
468
469 return api->get_latest_timepulse(dev, timestamp);
470}
471
478#if CONFIG_GNSS
479#define GNSS_DATA_CALLBACK_DEFINE(_dev, _callback) \
480 static const STRUCT_SECTION_ITERABLE(gnss_data_callback, \
481 _gnss_data_callback__##_callback) = { \
482 .dev = _dev, \
483 .callback = _callback, \
484 }
485
486#define GNSS_DT_DATA_CALLBACK_DEFINE(_node_id, _callback) \
487 static const STRUCT_SECTION_ITERABLE( \
488 gnss_data_callback, \
489 CONCAT(_gnss_data_callback_, DT_DEP_ORD(_node_id), _, _callback)) = { \
490 .dev = DEVICE_DT_GET(_node_id), \
491 .callback = _callback, \
492 }
493#else
494#define GNSS_DATA_CALLBACK_DEFINE(_dev, _callback)
495#define GNSS_DT_DATA_CALLBACK_DEFINE(_node_id, _callback)
496#endif
497
504#if CONFIG_GNSS_SATELLITES
505#define GNSS_SATELLITES_CALLBACK_DEFINE(_dev, _callback) \
506 static const STRUCT_SECTION_ITERABLE(gnss_satellites_callback, \
507 _gnss_satellites_callback__##_callback) = { \
508 .dev = _dev, \
509 .callback = _callback, \
510 }
511
512#define GNSS_DT_SATELLITES_CALLBACK_DEFINE(_node_id, _callback) \
513 static const STRUCT_SECTION_ITERABLE( \
514 gnss_satellites_callback, \
515 CONCAT(_gnss_satellites_callback_, DT_DEP_ORD(_node_id), _, _callback)) = { \
516 .dev = DEVICE_DT_GET(_node_id), \
517 .callback = _callback, \
518 }
519#else
520#define GNSS_SATELLITES_CALLBACK_DEFINE(_dev, _callback)
521#define GNSS_DT_SATELLITES_CALLBACK_DEFINE(_node_id, _callback)
522#endif
523
527
528#ifdef __cplusplus
529}
530#endif
531
532#include <zephyr/syscalls/gnss.h>
533
534#endif /* ZEPHYR_INCLUDE_DRIVERS_GNSS_H_ */
System error numbers.
uint32_t k_ticks_t
Tick precision used in timeout APIs.
Definition clock.h:48
int(* gnss_get_fix_rate_t)(const struct device *dev, uint32_t *fix_interval_ms)
API for getting fix rate.
Definition gnss.h:169
int(* gnss_set_fix_rate_t)(const struct device *dev, uint32_t fix_interval_ms)
API for setting fix rate.
Definition gnss.h:166
int(* gnss_set_enabled_systems_t)(const struct device *dev, gnss_systems_t systems)
API for enabling systems.
Definition gnss.h:180
int(* gnss_get_navigation_mode_t)(const struct device *dev, enum gnss_navigation_mode *mode)
API for getting navigation mode.
Definition gnss.h:176
int(* gnss_get_latest_timepulse_t)(const struct device *dev, k_ticks_t *timestamp)
API for getting timestamp of last PPS pulse.
Definition gnss.h:189
int(* gnss_get_enabled_systems_t)(const struct device *dev, gnss_systems_t *systems)
API for getting enabled systems.
Definition gnss.h:183
int(* gnss_set_navigation_mode_t)(const struct device *dev, enum gnss_navigation_mode mode)
API for setting navigation mode.
Definition gnss.h:172
int(* gnss_get_supported_systems_t)(const struct device *dev, gnss_systems_t *systems)
API for getting enabled systems.
Definition gnss.h:186
void(* gnss_data_callback_t)(const struct device *dev, const struct gnss_data *data)
Template for GNSS data callback.
Definition gnss.h:243
int gnss_get_enabled_systems(const struct device *dev, gnss_systems_t *systems)
Get enabled GNSS systems.
gnss_fix_status
GNSS fix status.
Definition gnss.h:101
int gnss_set_fix_rate(const struct device *dev, uint32_t fix_interval_ms)
Set the GNSS fix rate.
gnss_pps_mode
GNSS PPS modes.
Definition gnss.h:36
int gnss_get_supported_systems(const struct device *dev, gnss_systems_t *systems)
Get supported GNSS systems.
uint32_t gnss_systems_t
Type storing bitmask of GNSS systems.
Definition gnss.h:96
void(* gnss_satellites_callback_t)(const struct device *dev, const struct gnss_satellite *satellites, uint16_t size)
Template for GNSS satellites callback.
Definition gnss.h:272
int gnss_set_enabled_systems(const struct device *dev, gnss_systems_t systems)
Set enabled GNSS systems.
int gnss_get_fix_rate(const struct device *dev, uint32_t *fix_interval_ms)
Get the GNSS fix rate.
int gnss_get_latest_timepulse(const struct device *dev, k_ticks_t *timestamp)
Get the timestamp of the latest PPS timepulse.
gnss_system
Systems contained in gnss_systems_t.
Definition gnss.h:64
int gnss_set_navigation_mode(const struct device *dev, enum gnss_navigation_mode mode)
Set the GNSS navigation mode.
gnss_fix_quality
GNSS fix quality.
Definition gnss.h:113
gnss_navigation_mode
GNSS navigation modes.
Definition gnss.h:50
int gnss_get_navigation_mode(const struct device *dev, enum gnss_navigation_mode *mode)
Get the GNSS navigation mode.
@ GNSS_FIX_STATUS_ESTIMATED_FIX
Estimated fix acquired.
Definition gnss.h:109
@ GNSS_FIX_STATUS_DGNSS_FIX
Differential GNSS fix acquired.
Definition gnss.h:107
@ GNSS_FIX_STATUS_NO_FIX
No GNSS fix acquired.
Definition gnss.h:103
@ GNSS_FIX_STATUS_GNSS_FIX
GNSS fix acquired.
Definition gnss.h:105
@ GNSS_PPS_MODE_ENABLED_AFTER_LOCK
PPS output enabled from first lock.
Definition gnss.h:42
@ GNSS_PPS_MODE_DISABLED
PPS output disabled.
Definition gnss.h:38
@ GNSS_PPS_MODE_ENABLED
PPS output always enabled.
Definition gnss.h:40
@ GNSS_PPS_MODE_ENABLED_WHILE_LOCKED
PPS output enabled while locked.
Definition gnss.h:44
@ GNSS_SYSTEM_GALILEO
Galileo.
Definition gnss.h:70
@ GNSS_SYSTEM_BEIDOU
BeiDou Navigation Satellite System.
Definition gnss.h:72
@ GNSS_SYSTEM_SBAS
Satellite-Based Augmentation System (SBAS).
Definition gnss.h:78
@ GNSS_SYSTEM_IMES
Indoor Messaging System (IMES).
Definition gnss.h:80
@ GNSS_SYSTEM_GLONASS
GLObal NAvigation Satellite System (GLONASS).
Definition gnss.h:68
@ GNSS_SYSTEM_BEIDOU_B1C
BeiDou Navigation Satellite System B1C.
Definition gnss.h:88
@ GNSS_SYSTEM_GPS_L5
Global Positioning System (GPS) L5.
Definition gnss.h:82
@ GNSS_SYSTEM_QZSS_L5
Quasi-Zenith Satellite System (QZSS) L5.
Definition gnss.h:86
@ GNSS_SYSTEM_QZSS_L1S
Quasi-Zenith Satellite System (QZSS) L1S Augmentation service.
Definition gnss.h:92
@ GNSS_SYSTEM_IRNSS
Indian Regional Navigation Satellite System (IRNSS).
Definition gnss.h:76
@ GNSS_SYSTEM_GPS
Global Positioning System (GPS).
Definition gnss.h:66
@ GNSS_SYSTEM_GALILEO_L5
Galileo L5.
Definition gnss.h:84
@ GNSS_SYSTEM_QZSS
Quasi-Zenith Satellite System (QZSS).
Definition gnss.h:74
@ GNSS_SYSTEM_BEIDOU_B2A
BeiDou Navigation Satellite System B2a.
Definition gnss.h:90
@ GNSS_FIX_QUALITY_GNSS_SPS
Standard positioning service.
Definition gnss.h:117
@ GNSS_FIX_QUALITY_RTK
Real-time kinematic.
Definition gnss.h:123
@ GNSS_FIX_QUALITY_DGNSS
Differential GNSS.
Definition gnss.h:119
@ GNSS_FIX_QUALITY_INVALID
Invalid fix.
Definition gnss.h:115
@ GNSS_FIX_QUALITY_ESTIMATED
Estimated fix.
Definition gnss.h:127
@ GNSS_FIX_QUALITY_GNSS_PPS
Precise positioning service.
Definition gnss.h:121
@ GNSS_FIX_QUALITY_FLOAT_RTK
Floating real-time kinematic.
Definition gnss.h:125
@ GNSS_NAVIGATION_MODE_HIGH_DYNAMICS
High dynamics have higher impact on tracking.
Definition gnss.h:58
@ GNSS_NAVIGATION_MODE_ZERO_DYNAMICS
Dynamics have no impact on tracking.
Definition gnss.h:52
@ GNSS_NAVIGATION_MODE_BALANCED_DYNAMICS
Low and high dynamics have equal impact on tracking.
Definition gnss.h:56
@ GNSS_NAVIGATION_MODE_LOW_DYNAMICS
Low dynamics have higher impact on tracking.
Definition gnss.h:54
#define BIT(n)
Unsigned integer with bit position n set (signed in assembly language).
Definition util_macro.h:44
#define ENOSYS
Function not implemented.
Definition errno.h:82
#define NULL
Definition iar_missing_defs.h:20
Public kernel APIs.
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__INT32_TYPE__ int32_t
Definition stdint.h:74
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
Runtime device structure (in ROM) per driver instance.
Definition device.h:513
const void * api
Address of the API structure exposed by the device instance.
Definition device.h:519
GNSS callback structure.
Definition gnss.h:246
gnss_data_callback_t callback
Callback called when GNSS data is published.
Definition gnss.h:250
const struct device * dev
Filter callback to GNSS data from this device if not NULL.
Definition gnss.h:248
GNSS data structure.
Definition gnss.h:233
struct navigation_data nav_data
Navigation data acquired.
Definition gnss.h:235
struct gnss_info info
GNSS info when navigation data was acquired.
Definition gnss.h:237
struct gnss_time utc
UTC time when data was acquired.
Definition gnss.h:239
<span class="mlabel">Driver Operations</span> GNSS driver operations
Definition gnss.h:194
gnss_set_fix_rate_t set_fix_rate
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition gnss.h:198
gnss_set_enabled_systems_t set_enabled_systems
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition gnss.h:214
gnss_get_latest_timepulse_t get_latest_timepulse
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition gnss.h:226
gnss_get_navigation_mode_t get_navigation_mode
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition gnss.h:210
gnss_set_navigation_mode_t set_navigation_mode
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition gnss.h:206
gnss_get_enabled_systems_t get_enabled_systems
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition gnss.h:218
gnss_get_fix_rate_t get_fix_rate
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition gnss.h:202
gnss_get_supported_systems_t get_supported_systems
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition gnss.h:222
GNSS info data structure.
Definition gnss.h:131
enum gnss_fix_quality fix_quality
The fix quality.
Definition gnss.h:141
uint32_t hdop
Horizontal dilution of precision in 1/1000.
Definition gnss.h:135
int32_t geoid_separation
Geoid separation in millimeters.
Definition gnss.h:137
enum gnss_fix_status fix_status
The fix status.
Definition gnss.h:139
uint16_t satellites_cnt
Number of satellites being tracked.
Definition gnss.h:133
GNSS satellite structure.
Definition gnss.h:254
uint8_t prn
Pseudo-random noise sequence.
Definition gnss.h:256
uint16_t azimuth
Azimuth relative to True North in degrees [0, 359].
Definition gnss.h:262
uint8_t elevation
Elevation in degrees [0, 90].
Definition gnss.h:260
uint8_t is_corrected
True if satellite tracking has RTK corrections.
Definition gnss.h:268
uint8_t snr
Signal-to-noise ratio in dB.
Definition gnss.h:258
enum gnss_system system
System of satellite.
Definition gnss.h:264
uint8_t is_tracked
True if satellite is being tracked.
Definition gnss.h:266
GNSS callback structure.
Definition gnss.h:277
const struct device * dev
Filter callback to GNSS data from this device if not NULL.
Definition gnss.h:279
gnss_satellites_callback_t callback
Callback called when GNSS satellites is published.
Definition gnss.h:281
GNSS time data structure.
Definition gnss.h:145
uint8_t month
Month [1, 12].
Definition gnss.h:155
uint16_t millisecond
Millisecond [0, 60999].
Definition gnss.h:151
uint8_t minute
Minute [0, 59].
Definition gnss.h:149
uint8_t century_year
Year [0, 99].
Definition gnss.h:157
uint8_t hour
Hour [0, 23].
Definition gnss.h:147
uint8_t month_day
Day of month [1, 31].
Definition gnss.h:153
Navigation data structure.
Definition navigation.h:25