Zephyr Project API 4.2.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
chat.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2022 Trackunit Corporation
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7#include <zephyr/kernel.h>
8#include <zephyr/types.h>
9#include <zephyr/device.h>
11
12#include <zephyr/modem/pipe.h>
13#include <zephyr/modem/stats.h>
14
15#ifndef ZEPHYR_MODEM_CHAT_
16#define ZEPHYR_MODEM_CHAT_
17
18#ifdef __cplusplus
19extern "C" {
20#endif
21
31struct modem_chat;
32
41typedef void (*modem_chat_match_callback)(struct modem_chat *chat, char **argv, uint16_t argc,
42 void *user_data);
43
63
64#define MODEM_CHAT_MATCH(_match, _separators, _callback) \
65 { \
66 .match = (uint8_t *)(_match), .match_size = (uint8_t)(sizeof(_match) - 1), \
67 .separators = (uint8_t *)(_separators), \
68 .separators_size = (uint8_t)(sizeof(_separators) - 1), .wildcards = false, \
69 .callback = _callback, \
70 }
71
72#define MODEM_CHAT_MATCH_WILDCARD(_match, _separators, _callback) \
73 { \
74 .match = (uint8_t *)(_match), .match_size = (uint8_t)(sizeof(_match) - 1), \
75 .separators = (uint8_t *)(_separators), \
76 .separators_size = (uint8_t)(sizeof(_separators) - 1), .wildcards = true, \
77 .callback = _callback, \
78 }
79
80#define MODEM_CHAT_MATCH_INITIALIZER(_match, _separators, _callback, _wildcards, _partial) \
81 { \
82 .match = (uint8_t *)(_match), \
83 .match_size = (uint8_t)(sizeof(_match) - 1), \
84 .separators = (uint8_t *)(_separators), \
85 .separators_size = (uint8_t)(sizeof(_separators) - 1), \
86 .wildcards = _wildcards, \
87 .partial = _partial, \
88 .callback = _callback, \
89 }
90
91#define MODEM_CHAT_MATCH_DEFINE(_sym, _match, _separators, _callback) \
92 const static struct modem_chat_match _sym = MODEM_CHAT_MATCH(_match, _separators, _callback)
93
94#define MODEM_CHAT_MATCH_WILDCARD_DEFINE(_sym, _match, _separators, _callback) \
95 const static struct modem_chat_match _sym = \
96 MODEM_CHAT_MATCH_WILDCARD(_match, _separators, _callback)
97
98/* Helper struct to match any response without callback. */
99extern const struct modem_chat_match modem_chat_any_match;
100
101#define MODEM_CHAT_MATCHES_DEFINE(_sym, ...) \
102 const static struct modem_chat_match _sym[] = {__VA_ARGS__}
103
104/* Helper struct to match nothing. */
105extern const struct modem_chat_match modem_chat_empty_matches[0];
106
122
123#define MODEM_CHAT_SCRIPT_CMD_RESP(_request, _response_match) \
124 { \
125 .request = (uint8_t *)(_request), \
126 .request_size = (uint16_t)(sizeof(_request) - 1), \
127 .response_matches = &_response_match, \
128 .response_matches_size = 1, \
129 .timeout = 0, \
130 }
131
132#define MODEM_CHAT_SCRIPT_CMD_RESP_MULT(_request, _response_matches) \
133 { \
134 .request = (uint8_t *)(_request), \
135 .request_size = (uint16_t)(sizeof(_request) - 1), \
136 .response_matches = _response_matches, \
137 .response_matches_size = ARRAY_SIZE(_response_matches), \
138 .timeout = 0, \
139 }
140
141#define MODEM_CHAT_SCRIPT_CMD_RESP_NONE(_request, _timeout_ms) \
142 { \
143 .request = (uint8_t *)(_request), \
144 .request_size = (uint16_t)(sizeof(_request) - 1), \
145 .response_matches = NULL, \
146 .response_matches_size = 0, \
147 .timeout = _timeout_ms, \
148 }
149
150#define MODEM_CHAT_SCRIPT_CMDS_DEFINE(_sym, ...) \
151 const static struct modem_chat_script_chat _sym[] = {__VA_ARGS__}
152
153/* Helper struct to have no chat script command. */
155
161
169typedef void (*modem_chat_script_callback)(struct modem_chat *chat,
170 enum modem_chat_script_result result, void *user_data);
171
191
192#define MODEM_CHAT_SCRIPT_DEFINE(_sym, _script_chats, _abort_matches, _callback, _timeout_s) \
193 const static struct modem_chat_script _sym = { \
194 .name = #_sym, \
195 .script_chats = _script_chats, \
196 .script_chats_size = ARRAY_SIZE(_script_chats), \
197 .abort_matches = _abort_matches, \
198 .abort_matches_size = ARRAY_SIZE(_abort_matches), \
199 .callback = _callback, \
200 .timeout = _timeout_s, \
201 }
202
203#define MODEM_CHAT_SCRIPT_NO_ABORT_DEFINE(_sym, _script_chats, _callback, _timeout_s) \
204 MODEM_CHAT_SCRIPT_DEFINE(_sym, _script_chats, modem_chat_empty_matches, \
205 _callback, _timeout_s)
206
207#define MODEM_CHAT_SCRIPT_EMPTY_DEFINE(_sym) \
208 MODEM_CHAT_SCRIPT_NO_ABORT_DEFINE(_sym, modem_chat_empty_script_chats, NULL, 0)
209
218
224 /* Pipe used to send and receive data */
225 struct modem_pipe *pipe;
226
227 /* User data passed with match callbacks */
229
230 /* Receive buffer */
234
235 /* Work buffer */
238
239 /* Chat delimiter */
243
244 /* Array of bytes which are discarded out by parser */
247
248 /* Parsed arguments */
252
253 /* Matches
254 * Index 0 -> Response matches
255 * Index 1 -> Abort matches
256 * Index 2 -> Unsolicited matches
257 */
258 const struct modem_chat_match *matches[3];
260
261 /* Script execution */
271
272 /* Script sending */
277
278 /* Match parsing */
283
284 /* Process received data */
286
287 /* Statistics */
288#if CONFIG_MODEM_STATS
289 struct modem_stats_buffer receive_buf_stats;
290 struct modem_stats_buffer work_buf_stats;
291#endif
292};
293
321
328int modem_chat_init(struct modem_chat *chat, const struct modem_chat_config *config);
329
338int modem_chat_attach(struct modem_chat *chat, struct modem_pipe *pipe);
339
350int modem_chat_run_script_async(struct modem_chat *chat, const struct modem_chat_script *script);
351
362int modem_chat_run_script(struct modem_chat *chat, const struct modem_chat_script *script);
363
374static inline int modem_chat_script_run(struct modem_chat *chat,
375 const struct modem_chat_script *script)
376{
377 return modem_chat_run_script_async(chat, script);
378}
379
385
391
397
407int modem_chat_match_set_match(struct modem_chat_match *chat_match, const char *match);
408
419
427
434
440void modem_chat_match_enable_wildcards(struct modem_chat_match *chat_match, bool enable);
441
447
458 const char *request);
459
470 const struct modem_chat_match *response_matches,
471 uint16_t response_matches_size);
472
479 uint16_t timeout_ms);
480
486
493void modem_chat_script_set_name(struct modem_chat_script *script, const char *name);
494
505 const struct modem_chat_script_chat *script_chats,
506 uint16_t script_chats_size);
507
518 const struct modem_chat_match *abort_matches,
519 uint16_t abort_matches_size);
520
528
535
540#ifdef __cplusplus
541}
542#endif
543
544#endif /* ZEPHYR_MODEM_CHAT_ */
long atomic_t
Definition atomic_types.h:15
const struct modem_chat_script_chat modem_chat_empty_script_chats[0]
void modem_chat_match_init(struct modem_chat_match *chat_match)
Initialize modem chat match.
int modem_chat_script_chat_set_response_matches(struct modem_chat_script_chat *script_chat, const struct modem_chat_match *response_matches, uint16_t response_matches_size)
Set modem chat script chat matches.
void modem_chat_match_enable_wildcards(struct modem_chat_match *chat_match, bool enable)
Set modem chat match wildcards flag.
int modem_chat_match_set_separators(struct modem_chat_match *chat_match, const char *separators)
Set separators of modem chat match instance.
int modem_chat_run_script_async(struct modem_chat *chat, const struct modem_chat_script *script)
Run script asynchronously.
modem_chat_script_result
Definition chat.h:156
void modem_chat_script_set_callback(struct modem_chat_script *script, modem_chat_script_callback callback)
Set modem chat script callback.
void modem_chat_match_set_partial(struct modem_chat_match *chat_match, bool partial)
Set modem chat match partial flag.
void modem_chat_script_abort(struct modem_chat *chat)
Abort script.
void modem_chat_release(struct modem_chat *chat)
Release pipe from chat instance.
void(* modem_chat_script_callback)(struct modem_chat *chat, enum modem_chat_script_result result, void *user_data)
Callback called when script chat is received.
Definition chat.h:169
modem_chat_script_send_state
Definition chat.h:210
void modem_chat_script_set_timeout(struct modem_chat_script *script, uint32_t timeout_s)
Set modem chat script timeout.
void modem_chat_script_set_name(struct modem_chat_script *script, const char *name)
Set modem chat script name.
int modem_chat_script_set_abort_matches(struct modem_chat_script *script, const struct modem_chat_match *abort_matches, uint16_t abort_matches_size)
Set modem chat script abort matches.
static int modem_chat_script_run(struct modem_chat *chat, const struct modem_chat_script *script)
Run script asynchronously.
Definition chat.h:374
const struct modem_chat_match modem_chat_empty_matches[0]
int modem_chat_match_set_match(struct modem_chat_match *chat_match, const char *match)
Set match of modem chat match instance.
int modem_chat_script_set_script_chats(struct modem_chat_script *script, const struct modem_chat_script_chat *script_chats, uint16_t script_chats_size)
Set modem chat script chats.
const struct modem_chat_match modem_chat_any_match
int modem_chat_script_chat_set_request(struct modem_chat_script_chat *script_chat, const char *request)
Set request of modem chat script chat instance.
void modem_chat_script_chat_set_timeout(struct modem_chat_script_chat *script_chat, uint16_t timeout_ms)
Set modem chat script chat timeout.
int modem_chat_run_script(struct modem_chat *chat, const struct modem_chat_script *script)
Run script.
void(* modem_chat_match_callback)(struct modem_chat *chat, char **argv, uint16_t argc, void *user_data)
Callback called when matching chat is received.
Definition chat.h:41
void modem_chat_script_chat_init(struct modem_chat_script_chat *script_chat)
Initialize modem chat script chat.
int modem_chat_init(struct modem_chat *chat, const struct modem_chat_config *config)
Initialize modem pipe chat instance.
int modem_chat_attach(struct modem_chat *chat, struct modem_pipe *pipe)
Attach modem chat instance to pipe.
void modem_chat_script_init(struct modem_chat_script *script)
Initialize modem chat script.
void modem_chat_match_set_callback(struct modem_chat_match *chat_match, modem_chat_match_callback callback)
Set modem chat match callback.
@ MODEM_CHAT_SCRIPT_RESULT_TIMEOUT
Definition chat.h:159
@ MODEM_CHAT_SCRIPT_RESULT_SUCCESS
Definition chat.h:157
@ MODEM_CHAT_SCRIPT_RESULT_ABORT
Definition chat.h:158
@ MODEM_CHAT_SCRIPT_SEND_STATE_REQUEST
Definition chat.h:214
@ MODEM_CHAT_SCRIPT_SEND_STATE_IDLE
Definition chat.h:212
@ MODEM_CHAT_SCRIPT_SEND_STATE_DELIMITER
Definition chat.h:216
Public kernel APIs.
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
Semaphore structure.
Definition kernel.h:3364
A structure used to submit work after a delay.
Definition kernel.h:4281
A structure used to submit work.
Definition kernel.h:4253
Chat configuration.
Definition chat.h:297
uint8_t * receive_buf
Receive buffer used to store parsed arguments.
Definition chat.h:301
uint16_t argv_size
Elements in array of pointers.
Definition chat.h:315
const struct modem_chat_match * unsol_matches
Array of unsolicited matches.
Definition chat.h:317
uint16_t receive_buf_size
Size of receive buffer should be longest line + longest match.
Definition chat.h:303
uint8_t delimiter_size
Size of delimiter.
Definition chat.h:307
uint8_t * delimiter
Delimiter.
Definition chat.h:305
void * user_data
Free to use user data passed with modem match callbacks.
Definition chat.h:299
uint16_t unsol_matches_size
Elements in array of unsolicited matches.
Definition chat.h:319
uint8_t ** argv
Array of pointers used to point to parsed arguments.
Definition chat.h:313
uint8_t * filter
Bytes which are discarded by parser.
Definition chat.h:309
uint8_t filter_size
Size of filter.
Definition chat.h:311
Modem chat match.
Definition chat.h:47
modem_chat_match_callback callback
Type of modem chat instance.
Definition chat.h:61
uint8_t separators_size
Size of separators array.
Definition chat.h:55
const uint8_t * separators
Separators array.
Definition chat.h:53
bool partial
Set if script shall not continue to next step in case of match.
Definition chat.h:59
const uint8_t * match
Match array.
Definition chat.h:49
bool wildcards
Set if modem chat instance shall use wildcards when matching.
Definition chat.h:57
uint8_t match_size
Size of match.
Definition chat.h:51
Modem chat script chat.
Definition chat.h:110
uint16_t timeout
Timeout before chat script may continue to next step in milliseconds.
Definition chat.h:120
const struct modem_chat_match * response_matches
Expected responses to request.
Definition chat.h:116
const uint8_t * request
Request to send to modem.
Definition chat.h:112
uint16_t request_size
Size of request.
Definition chat.h:114
uint16_t response_matches_size
Number of elements in expected responses.
Definition chat.h:118
Modem chat script.
Definition chat.h:175
uint32_t timeout
Timeout in seconds within which the script execution must terminate.
Definition chat.h:189
const struct modem_chat_match * abort_matches
Array of abort matches.
Definition chat.h:183
uint16_t script_chats_size
Elements in array of script chats.
Definition chat.h:181
const struct modem_chat_script_chat * script_chats
Array of script chats.
Definition chat.h:179
modem_chat_script_callback callback
Callback called when script execution terminates.
Definition chat.h:187
uint16_t abort_matches_size
Number of elements in array of abort matches.
Definition chat.h:185
const char * name
Name of script.
Definition chat.h:177
Chat instance internal context.
Definition chat.h:223
uint16_t delimiter_size
Definition chat.h:241
uint16_t filter_size
Definition chat.h:246
uint16_t matches_size[3]
Definition chat.h:259
void * user_data
Definition chat.h:228
uint16_t parse_arg_len
Definition chat.h:281
uint16_t script_send_pos
Definition chat.h:274
struct k_work_delayable script_send_timeout_work
Definition chat.h:276
const struct modem_chat_match * parse_match
Definition chat.h:279
struct k_work script_run_work
Definition chat.h:264
struct k_work receive_work
Definition chat.h:285
struct k_work script_send_work
Definition chat.h:275
uint8_t work_buf[32]
Definition chat.h:236
const struct modem_chat_script * script
Definition chat.h:262
enum modem_chat_script_result script_result
Definition chat.h:269
uint16_t receive_buf_size
Definition chat.h:232
uint16_t work_buf_len
Definition chat.h:237
struct modem_pipe * pipe
Definition chat.h:225
enum modem_chat_script_send_state script_send_state
Definition chat.h:273
uint16_t script_chat_it
Definition chat.h:267
struct k_sem script_stopped_sem
Definition chat.h:270
uint8_t * delimiter
Definition chat.h:240
const struct modem_chat_script * pending_script
Definition chat.h:263
const struct modem_chat_match * matches[3]
Definition chat.h:258
uint16_t argv_size
Definition chat.h:250
uint16_t argc
Definition chat.h:251
struct k_work_delayable script_timeout_work
Definition chat.h:265
uint8_t * filter
Definition chat.h:245
uint16_t parse_match_len
Definition chat.h:280
uint16_t receive_buf_len
Definition chat.h:233
uint16_t parse_match_type
Definition chat.h:282
uint16_t delimiter_match_len
Definition chat.h:242
uint8_t ** argv
Definition chat.h:249
struct k_work script_abort_work
Definition chat.h:266
uint8_t * receive_buf
Definition chat.h:231
atomic_t script_state
Definition chat.h:268