Zephyr API Documentation  2.7.0-rc2
A Scalable Open Source RTOS
hl7800.h
Go to the documentation of this file.
1
11#ifndef ZEPHYR_INCLUDE_DRIVERS_MODEM_HL7800_H_
12#define ZEPHYR_INCLUDE_DRIVERS_MODEM_HL7800_H_
13
14#ifdef __cplusplus
15extern "C" {
16#endif
17
18#include <zephyr/types.h>
19
20#ifdef CONFIG_NEWLIB_LIBC
21#include <time.h>
22#endif
23
24/* The size includes the NUL character, the strlen doesn't */
25#define MDM_HL7800_REVISION_MAX_SIZE 29
26#define MDM_HL7800_REVISION_MAX_STRLEN (MDM_HL7800_REVISION_MAX_SIZE - 1)
27
28#define MDM_HL7800_IMEI_SIZE 16
29#define MDM_HL7800_IMEI_STRLEN (MDM_HL7800_IMEI_SIZE - 1)
30
31#define MDM_HL7800_ICCID_SIZE 21
32#define MDM_HL7800_ICCID_STRLEN (MDM_HL7800_ICCID_SIZE - 1)
33
34#define MDM_HL7800_SERIAL_NUMBER_SIZE 15
35#define MDM_HL7800_SERIAL_NUMBER_STRLEN (MDM_HL7800_SERIAL_NUMBER_SIZE - 1)
36
37#define MDM_HL7800_APN_MAX_SIZE 64
38#define MDM_HL7800_APN_USERNAME_MAX_SIZE 65
39#define MDM_HL7800_APN_PASSWORD_MAX_SIZE 65
40
41#define MDM_HL7800_APN_MAX_STRLEN (MDM_HL7800_APN_MAX_SIZE - 1)
42#define MDM_HL7800_APN_USERNAME_MAX_STRLEN \
43 (MDM_HL7800_APN_USERNAME_MAX_SIZE - 1)
44#define MDM_HL7800_APN_PASSWORD_MAX_STRLEN \
45 (MDM_HL7800_APN_PASSWORD_MAX_SIZE - 1)
46
47#define MDM_HL7800_APN_CMD_MAX_SIZE \
48 (32 + MDM_HL7800_APN_USERNAME_MAX_STRLEN + \
49 MDM_HL7800_APN_PASSWORD_MAX_STRLEN)
50
51#define MDM_HL7800_APN_CMD_MAX_STRLEN (MDM_HL7800_APN_CMD_MAX_SIZE - 1)
52
57};
58
59#define MDM_HL7800_LTE_BAND_STR_SIZE 21
60#define MDM_HL7800_LTE_BAND_STRLEN (MDM_HL7800_LTE_BAND_STR_SIZE - 1)
61
62#define MDM_HL7800_OPERATOR_INDEX_SIZE 3
63#define MDM_HL7800_OPERATOR_INDEX_STRLEN (MDM_HL7800_OPERATOR_INDEX_SIZE - 1)
64
65#define MDM_HL7800_IMSI_MIN_STR_SIZE 15
66#define MDM_HL7800_IMSI_MAX_STR_SIZE 16
67#define MDM_HL7800_IMSI_MAX_STRLEN (MDM_HL7800_IMSI_MAX_STR_SIZE - 1)
68
69#define MDM_HL7800_MODEM_FUNCTIONALITY_SIZE 2
70#define MDM_HL7800_MODEM_FUNCTIONALITY_STRLEN \
71 (MDM_HL7800_MODEM_FUNCTIONALITY_SIZE - 1)
72
73#define MDM_HL7800_MAX_GPS_STR_SIZE 33
74
75#define MDM_HL7800_MAX_POLTE_USER_ID_SIZE 16
76#define MDM_HL7800_MAX_POLTE_PASSWORD_SIZE 16
77#define MDM_HL7800_MAX_POLTE_LOCATION_STR_SIZE 33
78
79/* Assign the server error code (location response) to a value
80 * that isn't used by locate response so that a single status
81 * callback can be used.
82 */
83#define MDM_HL7800_POLTE_SERVER_ERROR 10
84
85#define MDM_HL7800_SET_POLTE_USER_AND_PASSWORD_FMT_STR "AT%%POLTECMD=\"SERVERAUTH\",\"%s\",\"%s\""
86
88 uint32_t earfcn; /* EUTRA Absolute Radio Frequency Channel Number */
90 int rsrp;
91 int rsrq;
92};
93
95
116};
117
127
136 /* Laird defined states */
139
145
156};
157
163
164/* The modem reports state values as an enumeration and a string.
165 * GPS values are reported with a type of value and string.
166 */
169 char *string;
170};
171
178};
179
184};
185
193};
194
207
208/* status: negative errno, 0 on success
209 * user and password aren't valid if status is non-zero.
210 */
213 char *user;
214 char *password;
215};
216
217/* status: negative errno, 0 on success, non-zero error code
218 * Data is not valid if status is non-zero.
219 */
226};
227
251 void *event_data);
252
259
266
273void mdm_hl7800_wakeup(bool awake);
274
283
292void mdm_hl7800_get_signal_quality(int *rsrp, int *sinr);
293
299
305
311
317
323
329int32_t mdm_hl7800_update_apn(char *access_point_name);
330
337
342
349
357
358#ifdef CONFIG_NEWLIB_LIBC
367int32_t mdm_hl7800_get_local_time(struct tm *tm, int32_t *offset);
368#endif
369
370#ifdef CONFIG_MODEM_HL7800_FW_UPDATE
379int32_t mdm_hl7800_update_fw(char *file_path);
380#endif
381
388
395
407
419
431
439int32_t mdm_hl7800_polte_enable(char *user, char *password);
440
452
462
463#ifdef __cplusplus
464}
465#endif
466
467#endif /* ZEPHYR_INCLUDE_DRIVERS_MODEM_HL7800_H_ */
void
Definition: eswifi_shell.c:15
#define MDM_HL7800_MAX_POLTE_LOCATION_STR_SIZE
Definition: hl7800.h:77
bool mdm_hl7800_valid_rat(uint8_t value)
int32_t mdm_hl7800_polte_locate(void)
Locate device using PoLTE.
int32_t mdm_hl7800_set_functionality(enum mdm_hl7800_functionality mode)
Set airplane, normal, or reduced functionality mode. Airplane mode persists when reset.
char * mdm_hl7800_get_sn(void)
Get the HL7800 serial number.
int32_t mdm_hl7800_polte_enable(char *user, char *password)
Enable PoLTE.
int32_t mdm_hl7800_set_gps_rate(uint32_t rate)
When rate is non-zero: Put modem into Airplane mode. Enable GPS and generate HL7800_EVENT_GPS events....
int32_t mdm_hl7800_get_operator_index(void)
Read the operator index from the modem.
mdm_hl7800_radio_mode
Definition: hl7800.h:94
@ MDM_RAT_CAT_NB1
Definition: hl7800.h:94
@ MDM_RAT_CAT_M1
Definition: hl7800.h:94
int32_t mdm_hl7800_get_functionality(void)
Get modem functionality.
int32_t mdm_hl7800_update_apn(char *access_point_name)
Update the Access Point Name in the modem.
mdm_hl7800_event
Definition: hl7800.h:96
@ HL7800_EVENT_NETWORK_STATE_CHANGE
Definition: hl7800.h:98
@ HL7800_EVENT_GPS_POSITION_STATUS
Definition: hl7800.h:111
@ HL7800_EVENT_STARTUP_STATE_CHANGE
Definition: hl7800.h:102
@ HL7800_EVENT_POLTE
Definition: hl7800.h:114
@ HL7800_EVENT_BANDS
Definition: hl7800.h:105
@ HL7800_EVENT_SITE_SURVEY
Definition: hl7800.h:115
@ HL7800_EVENT_FOTA_COUNT
Definition: hl7800.h:108
@ HL7800_EVENT_APN_UPDATE
Definition: hl7800.h:99
@ HL7800_EVENT_RESERVED
Definition: hl7800.h:97
@ HL7800_EVENT_SLEEP_STATE_CHANGE
Definition: hl7800.h:103
@ HL7800_EVENT_POLTE_LOCATE_STATUS
Definition: hl7800.h:113
@ HL7800_EVENT_REVISION
Definition: hl7800.h:109
@ HL7800_EVENT_ACTIVE_BANDS
Definition: hl7800.h:106
@ HL7800_EVENT_RSSI
Definition: hl7800.h:100
@ HL7800_EVENT_RAT
Definition: hl7800.h:104
@ HL7800_EVENT_SINR
Definition: hl7800.h:101
@ HL7800_EVENT_POLTE_REGISTRATION
Definition: hl7800.h:112
@ HL7800_EVENT_FOTA_STATE
Definition: hl7800.h:107
@ HL7800_EVENT_GPS
Definition: hl7800.h:110
char * mdm_hl7800_get_imei(void)
Get the HL7800 IMEI.
void mdm_hl7800_wakeup(bool awake)
Control the wake signals to the HL7800.
mdm_hl7800_gps_string_types
Definition: hl7800.h:195
@ HL7800_GPS_STR_GPS_TIME
Definition: hl7800.h:198
@ HL7800_GPS_STR_ALTITUDE
Definition: hl7800.h:201
@ HL7800_GPS_STR_ALT_UNC
Definition: hl7800.h:202
@ HL7800_GPS_STR_VER_SPEED
Definition: hl7800.h:205
@ HL7800_GPS_STR_LONGITUDE
Definition: hl7800.h:197
@ HL7800_GPS_STR_LATITUDE
Definition: hl7800.h:196
@ HL7800_GPS_STR_FIX_TYPE
Definition: hl7800.h:199
@ HL7800_GPS_STR_HOR_SPEED
Definition: hl7800.h:204
@ HL7800_GPS_STR_HEPE
Definition: hl7800.h:200
@ HL7800_GPS_STR_DIRECTION
Definition: hl7800.h:203
void mdm_hl7800_register_event_callback(mdm_hl7800_event_callback_t cb)
Register a function that is called when a modem event occurs.
mdm_hl7800_gnss_status
Definition: hl7800.h:180
@ HL7800_GNSS_STATUS_FAILURE
Definition: hl7800.h:182
@ HL7800_GNSS_STATUS_INVALID
Definition: hl7800.h:181
@ HL7800_GNSS_STATUS_SUCCESS
Definition: hl7800.h:183
char * mdm_hl7800_get_imsi(void)
Get the IMSI.
mdm_hl7800_gnss_event
Definition: hl7800.h:172
@ HL7800_GNSS_EVENT_POSITION
Definition: hl7800.h:177
@ HL7800_GNSS_EVENT_INVALID
Definition: hl7800.h:173
@ HL7800_GNSS_EVENT_INIT
Definition: hl7800.h:174
@ HL7800_GNSS_EVENT_START
Definition: hl7800.h:175
@ HL7800_GNSS_EVENT_STOP
Definition: hl7800.h:176
#define MDM_HL7800_APN_MAX_SIZE
Definition: hl7800.h:37
mdm_hl7800_network_state
Definition: hl7800.h:128
@ HL7800_EMERGENCY
Definition: hl7800.h:135
@ HL7800_SEARCHING
Definition: hl7800.h:131
@ HL7800_UNABLE_TO_CONFIGURE
Definition: hl7800.h:137
@ HL7800_REGISTRATION_DENIED
Definition: hl7800.h:132
@ HL7800_HOME_NETWORK
Definition: hl7800.h:130
@ HL7800_NOT_REGISTERED
Definition: hl7800.h:129
@ HL7800_ROAMING
Definition: hl7800.h:134
@ HL7800_OUT_OF_COVERAGE
Definition: hl7800.h:133
int32_t mdm_hl7800_send_at_cmd(const uint8_t *data)
Send an AT command to the HL7800.
int32_t mdm_hl7800_polte_register(void)
Register modem/SIM with polte.io.
mdm_hl7800_fota_state
Definition: hl7800.h:146
@ HL7800_FOTA_PAD
Definition: hl7800.h:150
@ HL7800_FOTA_REBOOT_AND_RECONFIGURE
Definition: hl7800.h:154
@ HL7800_FOTA_INSTALL
Definition: hl7800.h:153
@ HL7800_FOTA_WIP
Definition: hl7800.h:149
@ HL7800_FOTA_SEND_EOT
Definition: hl7800.h:151
@ HL7800_FOTA_FILE_ERROR
Definition: hl7800.h:152
@ HL7800_FOTA_IDLE
Definition: hl7800.h:147
@ HL7800_FOTA_COMPLETE
Definition: hl7800.h:155
@ HL7800_FOTA_START
Definition: hl7800.h:148
int32_t mdm_hl7800_reset(void)
Reset the HL7800 (and allow it to reconfigure).
int32_t mdm_hl7800_perform_site_survey(void)
Perform a site survey. This command may return different values each time it is run (depending on wha...
int32_t mdm_hl7800_update_rat(enum mdm_hl7800_radio_mode value)
Update the Radio Access Technology (mode).
mdm_hl7800_sleep_state
Definition: hl7800.h:140
@ HL7800_SLEEP_STATE_UNINITIALIZED
Definition: hl7800.h:141
@ HL7800_SLEEP_STATE_AWAKE
Definition: hl7800.h:143
@ HL7800_SLEEP_STATE_ASLEEP
Definition: hl7800.h:142
void mdm_hl7800_generate_status_events(void)
Force modem module to generate status events.
#define MDM_HL7800_APN_PASSWORD_MAX_SIZE
Definition: hl7800.h:39
char * mdm_hl7800_get_fw_version(void)
Get the HL7800 firmware version.
#define MDM_HL7800_APN_USERNAME_MAX_SIZE
Definition: hl7800.h:38
void mdm_hl7800_get_signal_quality(int *rsrp, int *sinr)
Get the signal quality of the HL7800.
int32_t mdm_hl7800_power_off(void)
Power off the HL7800.
mdm_hl7800_gnss_position_event
Definition: hl7800.h:186
@ HL7800_GNSS_POSITION_EVENT_2D_AVAILABLE
Definition: hl7800.h:190
@ HL7800_GNSS_POSITION_EVENT_3D_AVAILABLE
Definition: hl7800.h:191
@ HL7800_GNSS_POSITION_EVENT_FIXED_TO_INVALID
Definition: hl7800.h:192
@ HL7800_GNSS_POSITION_EVENT_INVALID
Definition: hl7800.h:187
@ HL7800_GNSS_POSITION_EVENT_LOST_OR_NOT_AVAILABLE_YET
Definition: hl7800.h:188
@ HL7800_GNSS_POSITION_EVENT_PREDICTION_AVAILABLE
Definition: hl7800.h:189
mdm_hl7800_startup_state
Definition: hl7800.h:118
@ HL7800_STARTUP_STATE_SIMLOCK
Definition: hl7800.h:122
@ HL7800_STARTUP_STATE_UNRECOVERABLE_ERROR
Definition: hl7800.h:123
@ HL7800_STARTUP_STATE_WAITING_FOR_ACCESS_CODE
Definition: hl7800.h:120
@ HL7800_STARTUP_STATE_SIM_NOT_PRESENT
Definition: hl7800.h:121
@ HL7800_STARTUP_STATE_INACTIVE_SIM
Definition: hl7800.h:125
@ HL7800_STARTUP_STATE_UNKNOWN
Definition: hl7800.h:124
@ HL7800_STARTUP_STATE_READY
Definition: hl7800.h:119
char * mdm_hl7800_get_iccid(void)
Get the SIM card ICCID.
mdm_hl7800_functionality
Definition: hl7800.h:158
@ HL7800_FUNCTIONALITY_AIRPLANE
Definition: hl7800.h:161
@ HL7800_FUNCTIONALITY_FULL
Definition: hl7800.h:160
@ HL7800_FUNCTIONALITY_MINIMUM
Definition: hl7800.h:159
void(* mdm_hl7800_event_callback_t)(enum mdm_hl7800_event event, void *event_data)
Definition: hl7800.h:250
__UINT32_TYPE__ uint32_t
Definition: stdint.h:60
__INT32_TYPE__ int32_t
Definition: stdint.h:44
__UINT8_TYPE__ uint8_t
Definition: stdint.h:58
Definition: hl7800.h:53
char value[64]
Definition: hl7800.h:54
char password[65]
Definition: hl7800.h:56
char username[65]
Definition: hl7800.h:55
Definition: hl7800.h:167
char * string
Definition: hl7800.h:169
uint8_t code
Definition: hl7800.h:168
Definition: hl7800.h:220
int status
Definition: hl7800.h:222
char confidence_in_meters[33]
Definition: hl7800.h:225
char longitude[33]
Definition: hl7800.h:224
uint32_t timestamp
Definition: hl7800.h:221
char latitude[33]
Definition: hl7800.h:223
int status
Definition: hl7800.h:212
char * password
Definition: hl7800.h:214
char * user
Definition: hl7800.h:213
Definition: hl7800.h:87
int rsrq
Definition: hl7800.h:91
int rsrp
Definition: hl7800.h:90
uint32_t cell_id
Definition: hl7800.h:89
uint32_t earfcn
Definition: hl7800.h:88
Definition: time.h:24
static fdata_t data[2]
Definition: test_fifo_contexts.c:15