Zephyr API Documentation 4.4.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
cellular.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2023 Bjarki Arge Andreasen
3 * Copyright (c) 2023 Lucas Denefle
4 *
5 * SPDX-License-Identifier: Apache-2.0
6 */
7
13
14#ifndef ZEPHYR_INCLUDE_DRIVERS_CELLULAR_H_
15#define ZEPHYR_INCLUDE_DRIVERS_CELLULAR_H_
16
23
24#include <zephyr/types.h>
25#include <zephyr/device.h>
26#include <errno.h>
27
28#ifdef __cplusplus
29extern "C" {
30#endif
31
71
84
91
107
135
147
148/* Opaque bit-mask large enough for all current & future events */
150
155
160
165
167#define CELLULAR_EUTRAN_CELL_ID_MAX 0xFFFFFFFU
169#define CELLULAR_EUTRAN_CELL_ID_INVALID UINT32_MAX
170
189
202typedef void (*cellular_event_cb_t)(const struct device *dev, enum cellular_event event,
203 const void *payload, void *user_data);
204
206typedef int (*cellular_api_configure_networks)(const struct device *dev,
207 const struct cellular_network *networks,
208 uint8_t size);
209
211typedef int (*cellular_api_get_supported_networks)(const struct device *dev,
212 const struct cellular_network **networks,
213 uint8_t *size);
214
216typedef int (*cellular_api_get_signal)(const struct device *dev,
217 const enum cellular_signal_type type, int16_t *value);
218
220typedef int (*cellular_api_get_modem_info)(const struct device *dev,
221 const enum cellular_modem_info_type type, char *info,
222 size_t size);
223
225typedef int (*cellular_api_get_registration_status)(const struct device *dev,
227 enum cellular_registration_status *status);
228
230typedef int (*cellular_api_set_apn)(const struct device *dev, const char *apn);
231
233typedef int (*cellular_api_set_callback)(const struct device *dev, cellular_event_mask_t mask,
234 cellular_event_cb_t cb, void *user_data);
235
246
267static inline int cellular_configure_networks(const struct device *dev,
268 const struct cellular_network *networks, uint8_t size)
269{
270 const struct cellular_driver_api *api = DEVICE_API_GET(cellular, dev);
271
272 if (api->configure_networks == NULL) {
273 return -ENOSYS;
274 }
275
276 return api->configure_networks(dev, networks, size);
277}
278
289static inline int cellular_get_supported_networks(const struct device *dev,
290 const struct cellular_network **networks,
291 uint8_t *size)
292{
293 const struct cellular_driver_api *api = DEVICE_API_GET(cellular, dev);
294
295 if (api->get_supported_networks == NULL) {
296 return -ENOSYS;
297 }
298
299 return api->get_supported_networks(dev, networks, size);
300}
301
313static inline int cellular_get_signal(const struct device *dev,
314 const enum cellular_signal_type type, int16_t *value)
315{
316 const struct cellular_driver_api *api = DEVICE_API_GET(cellular, dev);
317
318 if (api->get_signal == NULL) {
319 return -ENOSYS;
320 }
321
322 return api->get_signal(dev, type, value);
323}
324
337static inline int cellular_get_modem_info(const struct device *dev,
338 const enum cellular_modem_info_type type, char *info,
339 size_t size)
340{
341 const struct cellular_driver_api *api = DEVICE_API_GET(cellular, dev);
342
343 if (api->get_modem_info == NULL) {
344 return -ENOSYS;
345 }
346
347 return api->get_modem_info(dev, type, info, size);
348}
349
361static inline int cellular_get_registration_status(const struct device *dev,
363 enum cellular_registration_status *status)
364{
365 const struct cellular_driver_api *api = DEVICE_API_GET(cellular, dev);
366
367 if (api->get_registration_status == NULL) {
368 return -ENOSYS;
369 }
370
371 return api->get_registration_status(dev, tech, status);
372}
373
389static inline int cellular_set_apn(const struct device *dev, const char *apn)
390{
391 const struct cellular_driver_api *api = DEVICE_API_GET(cellular, dev);
392
393 if (api->set_apn == NULL) {
394 return -ENOSYS;
395 }
396
397 return api->set_apn(dev, apn);
398}
399
413static inline int cellular_set_callback(const struct device *dev, cellular_event_mask_t mask,
414 cellular_event_cb_t cb, void *user_data)
415{
416 const struct cellular_driver_api *api = DEVICE_API_GET(cellular, dev);
417
418 if (api->set_callback == NULL) {
419 return -ENOSYS;
420 }
421
422 return api->set_callback(dev, mask, cb, user_data);
423}
424
425#ifdef __cplusplus
426}
427#endif
428
432
433#endif /* ZEPHYR_INCLUDE_DRIVERS_CELLULAR_H_ */
#define DEVICE_API_GET(_class, _dev)
Expands to the pointer of a device's API for a given class.
Definition device.h:1425
System error numbers.
static int cellular_get_signal(const struct device *dev, const enum cellular_signal_type type, int16_t *value)
Get signal for the device.
Definition cellular.h:313
int(* cellular_api_get_modem_info)(const struct device *dev, const enum cellular_modem_info_type type, char *info, size_t size)
API for getting modem information.
Definition cellular.h:220
int(* cellular_api_get_registration_status)(const struct device *dev, enum cellular_access_technology tech, enum cellular_registration_status *status)
API for getting registration status.
Definition cellular.h:225
cellular_access_technology
Cellular access technologies (3GPP TS 27.007 AcT).
Definition cellular.h:33
cellular_event
Events emitted asynchronously by a cellular driver.
Definition cellular.h:137
static int cellular_set_apn(const struct device *dev, const char *apn)
Set the APN used for PDP context.
Definition cellular.h:389
int(* cellular_api_get_supported_networks)(const struct device *dev, const struct cellular_network **networks, uint8_t *size)
API for getting supported networks.
Definition cellular.h:211
static int cellular_get_supported_networks(const struct device *dev, const struct cellular_network **networks, uint8_t *size)
Get supported cellular networks for the device.
Definition cellular.h:289
int(* cellular_api_configure_networks)(const struct device *dev, const struct cellular_network *networks, uint8_t size)
API for configuring networks.
Definition cellular.h:206
cellular_registration_status
Cellular registration status (3GPP TS 27.007).
Definition cellular.h:109
cellular_signal_type
Cellular signal type.
Definition cellular.h:86
static int cellular_get_modem_info(const struct device *dev, const enum cellular_modem_info_type type, char *info, size_t size)
Get modem info for the device.
Definition cellular.h:337
int(* cellular_api_get_signal)(const struct device *dev, const enum cellular_signal_type type, int16_t *value)
API for getting network signal strength.
Definition cellular.h:216
static int cellular_set_callback(const struct device *dev, cellular_event_mask_t mask, cellular_event_cb_t cb, void *user_data)
Subscribe to asynchronous cellular events.
Definition cellular.h:413
uint32_t cellular_event_mask_t
Definition cellular.h:149
static int cellular_configure_networks(const struct device *dev, const struct cellular_network *networks, uint8_t size)
Configure cellular networks for the device.
Definition cellular.h:267
int(* cellular_api_set_apn)(const struct device *dev, const char *apn)
API for programming APN.
Definition cellular.h:230
void(* cellular_event_cb_t)(const struct device *dev, enum cellular_event event, const void *payload, void *user_data)
Prototype for cellular event callbacks.
Definition cellular.h:202
int(* cellular_api_set_callback)(const struct device *dev, cellular_event_mask_t mask, cellular_event_cb_t cb, void *user_data)
API for registering an asynchronous callback.
Definition cellular.h:233
cellular_modem_info_type
Cellular modem info type.
Definition cellular.h:93
static int cellular_get_registration_status(const struct device *dev, enum cellular_access_technology tech, enum cellular_registration_status *status)
Get network registration status for the device.
Definition cellular.h:361
@ CELLULAR_ACCESS_TECHNOLOGY_EC_GSM_IOT
Extended Coverage GSM for IoT (2G, 3GPP Rel 13).
Definition cellular.h:51
@ CELLULAR_ACCESS_TECHNOLOGY_UTRAN
UMTS Terrestrial Radio Access Network (3G, 3GPP Rel 99).
Definition cellular.h:39
@ CELLULAR_ACCESS_TECHNOLOGY_E_UTRA_NR_DUAL
LTE/E-UTRA & NR dual connectivity (5G, 3GPP Rel 15).
Definition cellular.h:61
@ CELLULAR_ACCESS_TECHNOLOGY_E_UTRAN_NB_S1
EUTRAN Narrowband-IoT (4G, 3GPP Rel 13).
Definition cellular.h:53
@ CELLULAR_ACCESS_TECHNOLOGY_NG_RAN
Next Generation RAN (5G, 3GPP Rel 15).
Definition cellular.h:59
@ CELLULAR_ACCESS_TECHNOLOGY_E_UTRAN
Evolved UTRAN (4G, 3GPP Rel 8).
Definition cellular.h:49
@ CELLULAR_ACCESS_TECHNOLOGY_E_UTRAN_NB_S1_SAT
Narrowband-IoT over Satellite (4G, 3GPP Rel 17).
Definition cellular.h:63
@ CELLULAR_ACCESS_TECHNOLOGY_UTRAN_HSDPA_HSUPA
UTRAN with HSDPA and HSUDP (HSPA) (3.75G, 3GPP Rel 6).
Definition cellular.h:47
@ CELLULAR_ACCESS_TECHNOLOGY_UTRAN_HSUPA
UTRAN with High Speed Uplink Packet Access (3.75G, 3GPP Rel 6).
Definition cellular.h:45
@ CELLULAR_ACCESS_TECHNOLOGY_GSM
Global System for Mobile communications (2G, 3GPP Rel 99).
Definition cellular.h:35
@ CELLULAR_ACCESS_TECHNOLOGY_UNKNOWN
Unknown access technology.
Definition cellular.h:69
@ CELLULAR_ACCESS_TECHNOLOGY_GSM_EGPRS
GSM Enhanced General Packet Radio Service (2.5G, 3GPP Rel 99).
Definition cellular.h:41
@ CELLULAR_ACCESS_TECHNOLOGY_E_UTRAN_WB_S1_SAT
LTE (wideband) over Satellite (4G, 3GPP Rel 17).
Definition cellular.h:65
@ CELLULAR_ACCESS_TECHNOLOGY_NR_5G_CN
New Radio with 5G Core Network (5G, 3GPP Rel 15).
Definition cellular.h:57
@ CELLULAR_ACCESS_TECHNOLOGY_E_UTRA_5G_CN
LTE/E-UTRA connected to 5G Core Network (5G, 3GPP Rel 15).
Definition cellular.h:55
@ CELLULAR_ACCESS_TECHNOLOGY_NG_RAN_SAT
Next Generation RAN over Satellite (5G, 3GPP Rel 17).
Definition cellular.h:67
@ CELLULAR_ACCESS_TECHNOLOGY_GSM_COMPACT
Bandwidth & Spectrum limited variant of GSM (2G, 3GPP Rel 99).
Definition cellular.h:37
@ CELLULAR_ACCESS_TECHNOLOGY_UTRAN_HSDPA
UTRAN with High Speed Downlink Packet Access (3.5G, 3GPP Rel 5).
Definition cellular.h:43
@ CELLULAR_EVENT_MODEM_COMMS_CHECK_RESULT
Result of a communications link check to the modem.
Definition cellular.h:143
@ CELLULAR_EVENT_MODEM_INFO_CHANGED
One or more modem-info field changed (e.g.
Definition cellular.h:139
@ CELLULAR_EVENT_REGISTRATION_STATUS_CHANGED
Cellular network registration status changed.
Definition cellular.h:141
@ CELLULAR_EVENT_NETWORK_STATUS_CHANGED
Cellular network status changed.
Definition cellular.h:145
@ CELLULAR_REGISTRATION_UNKNOWN
Unknown (e.g.
Definition cellular.h:119
@ CELLULAR_REGISTRATION_CSFB_NOT_PREFERRED_ROAMING
Registered for "CSFB not preferred", roaming network.
Definition cellular.h:131
@ CELLULAR_REGISTRATION_SEARCHING
Not registered, searching for an operator.
Definition cellular.h:115
@ CELLULAR_REGISTRATION_DENIED
Registration denied.
Definition cellular.h:117
@ CELLULAR_REGISTRATION_SMS_ONLY_HOME
Registered for "SMS only", home network.
Definition cellular.h:123
@ CELLULAR_REGISTRATION_SMS_ONLY_ROAMING
Registered for "SMS only", roaming network.
Definition cellular.h:125
@ CELLULAR_REGISTRATION_REGISTERED_HOME
Registered, home network.
Definition cellular.h:113
@ CELLULAR_REGISTRATION_NOT_REGISTERED
Not registered, not searching.
Definition cellular.h:111
@ CELLULAR_REGISTRATION_CSFB_NOT_PREFERRED_HOME
Registered for "CSFB not preferred", home network.
Definition cellular.h:129
@ CELLULAR_REGISTRATION_RLOS
Attached for access to "Restricted Local Operator Services".
Definition cellular.h:133
@ CELLULAR_REGISTRATION_EMERGENCY_ONLY
Attached for emergency bearer services only.
Definition cellular.h:127
@ CELLULAR_REGISTRATION_REGISTERED_ROAMING
Registered, roaming.
Definition cellular.h:121
@ CELLULAR_SIGNAL_RSRQ
Definition cellular.h:89
@ CELLULAR_SIGNAL_RSRP
Definition cellular.h:88
@ CELLULAR_SIGNAL_RSSI
Definition cellular.h:87
@ CELLULAR_MODEM_INFO_SIM_IMSI
International Mobile Subscriber Identity.
Definition cellular.h:103
@ CELLULAR_MODEM_INFO_MANUFACTURER
Modem manufacturer.
Definition cellular.h:99
@ CELLULAR_MODEM_INFO_MODEL_ID
Modem model ID.
Definition cellular.h:97
@ CELLULAR_MODEM_INFO_SIM_ICCID
Integrated Circuit Card Identification Number (SIM).
Definition cellular.h:105
@ CELLULAR_MODEM_INFO_FW_VERSION
Modem fw version.
Definition cellular.h:101
@ CELLULAR_MODEM_INFO_IMEI
International Mobile Equipment Identity.
Definition cellular.h:95
#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
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
__INT8_TYPE__ int8_t
Definition stdint.h:72
__INT16_TYPE__ int16_t
Definition stdint.h:73
Cellular driver API.
Definition cellular.h:237
cellular_api_get_supported_networks get_supported_networks
Definition cellular.h:239
cellular_api_set_apn set_apn
Definition cellular.h:243
cellular_api_set_callback set_callback
Definition cellular.h:244
cellular_api_get_registration_status get_registration_status
Definition cellular.h:242
cellular_api_get_signal get_signal
Definition cellular.h:240
cellular_api_get_modem_info get_modem_info
Definition cellular.h:241
cellular_api_configure_networks configure_networks
Definition cellular.h:238
Payload for CELLULAR_EVENT_MODEM_COMMS_CHECK_RESULT.
Definition cellular.h:162
bool success
Communications to modem checked successfully.
Definition cellular.h:163
Payload for CELLULAR_EVENT_MODEM_INFO_CHANGED.
Definition cellular.h:152
enum cellular_modem_info_type field
Which field changed.
Definition cellular.h:153
Payload for CELLULAR_EVENT_NETWORK_STATUS_CHANGED.
Definition cellular.h:172
enum cellular_registration_status status
Registration status.
Definition cellular.h:173
uint16_t phys_cell_id
Physical cell ID.
Definition cellular.h:182
uint16_t mnc
Mobile Network Code.
Definition cellular.h:178
int8_t rsrq
Received signal quality (dB).
Definition cellular.h:185
struct cellular_evt_network_status::@150331017227312054123027032261144033315032011003::@303376020136156326235373225142223153065252167310 lte
LTE Cell information.
uint16_t band
Band number (from 3GPP TS 36.101).
Definition cellular.h:183
uint32_t tac
Tracking Area Code.
Definition cellular.h:179
uint32_t gci
E-UTRAN cell ID (0 - CELLULAR_EUTRAN_CELL_ID_MAX).
Definition cellular.h:181
enum cellular_access_technology access_tech
Access technology.
Definition cellular.h:174
int16_t rsrp
Received signal power (dBm).
Definition cellular.h:184
union cellular_evt_network_status::@150331017227312054123027032261144033315032011003 cell
Generic Cell information.
uint16_t mcc
Mobile Country Code.
Definition cellular.h:177
uint32_t earfcn
E-UTRAN assigned radio channel.
Definition cellular.h:180
Payload for CELLULAR_EVENT_REGISTRATION_STATUS_CHANGED.
Definition cellular.h:157
enum cellular_registration_status status
New registration status.
Definition cellular.h:158
Cellular network structure.
Definition cellular.h:73
uint16_t * bands
List of bands, as defined by the specified cellular access technology, to enables.
Definition cellular.h:80
uint16_t size
Size of bands.
Definition cellular.h:82
enum cellular_access_technology technology
Cellular access technology.
Definition cellular.h:75
Runtime device structure (in ROM) per driver instance.
Definition device.h:513