modemu2k 0.2.3
Library that provides telnet capability to a comm program
Loading...
Searching...
No Matches
modemu2k.h
Go to the documentation of this file.
1#pragma once
2
43
44#include <poll.h> /* struct pollfd, used by m2k_get_pollfds()/m2k_step() below */
45#include <stddef.h> /* size_t */
46
47#include "modemu2k_version.h" /* M2K_VERSION_MAJOR / _MINOR / _PATCH / M2K_VERSION */
48
62#ifndef M2K_API
63# if defined(_WIN32)
64# if defined(M2K_BUILDING_DLL)
65# define M2K_API __declspec(dllexport)
66# else
67# define M2K_API __declspec(dllimport)
68# endif
69# elif defined(__GNUC__) && __GNUC__ >= 4
70# define M2K_API __attribute__((visibility("default")))
71# else
72# define M2K_API
73# endif
74#endif
75
76/* Deprecation marker. Consumers see a -Wdeprecated-declarations
77 * warning at the call site. modemu2k's own build defines
78 * M2K_SUPPRESS_DEPRECATED so the in-tree tests that still exercise
79 * the deprecated path build clean. */
80#if defined(M2K_SUPPRESS_DEPRECATED)
81# define M2K_DEPRECATED(msg)
82#elif defined(__GNUC__) || defined(__clang__)
83# define M2K_DEPRECATED(msg) __attribute__((deprecated(msg)))
84#elif defined(_MSC_VER)
85# define M2K_DEPRECATED(msg) __declspec(deprecated(msg))
86#else
87# define M2K_DEPRECATED(msg)
88#endif
89
90#ifdef __cplusplus
91extern "C" {
92#endif
93
95typedef struct m2k_s m2k_t;
96
108M2K_API const char *m2k_version(void);
109
115typedef void (*m2k_log_fn)(const char *msg, void *userdata);
116
120/* Note: new codes are appended; existing values must never be reordered
121 so external callers can safely cache numeric values across releases. */
135
141
147
162M2K_API void m2k_set_log_fn(m2k_t *ctx, m2k_log_fn fn, void *userdata);
163
165#define M2K_ERROR_BUFFER_SIZE 256
166
191M2K_API void m2k_set_error_buffer(m2k_t *ctx, char *buf, size_t size);
192
219M2K_API m2k_err_t m2k_atcmd(m2k_t *ctx, const char *cmd);
220
238M2K_API M2K_DEPRECATED("use m2k_run() or the step API instead")
239m2k_err_t m2k_dial(m2k_t *ctx, const char *host, const char *port);
240
254M2K_API M2K_DEPRECATED("use m2k_run() or the step API instead")
255m2k_err_t m2k_online(m2k_t *ctx);
256
263
282
290
300
316M2K_API m2k_err_t m2k_setup_pty(m2k_t *ctx, const char **slave_out);
317
331
339M2K_API m2k_err_t m2k_setup_dev(m2k_t *ctx, const char *dev);
340
361M2K_API m2k_err_t m2k_setup_listen(m2k_t *ctx, const char *port);
362
379
400M2K_API m2k_err_t m2k_write_from_app(m2k_t *ctx, const void *buf, size_t len,
401 size_t *consumed);
402
434M2K_API m2k_err_t m2k_read_to_app(m2k_t *ctx, void *buf, size_t max, size_t *len_out);
435
450
465
482
507
508/* ── Steppable event-loop API ───────────────────────────────────────
509 *
510 * The functions below let a host application integrate modemu2k into
511 * its own event loop (poll/epoll/select/etc.) instead of handing the
512 * fds to the blocking m2k_run() above.
513 *
514 * Usage:
515 * while (!m2k_run_done(ctx)) {
516 * struct pollfd fds[M2K_MAX_POLLFDS]; // caller-provided buffer
517 * size_t nfds = M2K_MAX_POLLFDS;
518 * int timeout_ms;
519 * m2k_get_pollfds(ctx, fds, &nfds, &timeout_ms);
520 * // Splice fds into your own pollset, call poll()/epoll_wait().
521 * // On return, write back the .revents the OS reported into the
522 * // corresponding entries of `fds`.
523 * m2k_step(ctx, fds, nfds);
524 * }
525 *
526 * Dialing (ATD) is non-blocking: m2k_step() transitions the context
527 * into an internal DIAL state on ATD, returns control immediately,
528 * and resumes the connect() across subsequent m2k_step() calls. The
529 * host event loop is not held up by connect(). m2k_get_pollfds()
530 * publishes the in-progress socket fd while DIAL is active, so the
531 * host pollset stays accurate without special-casing.
532 */
533
535#define M2K_MAX_POLLFDS 3
536
554M2K_API m2k_err_t m2k_get_pollfds(m2k_t *ctx, struct pollfd *fds,
555 size_t *nfds_inout, int *timeout_ms);
556
572M2K_API m2k_err_t m2k_step(m2k_t *ctx, struct pollfd *fds, size_t nfds);
573
580M2K_API int m2k_run_done(const m2k_t *ctx);
581
594
607
621M2K_API void m2k_set_dtr(m2k_t *ctx, int on);
622
634M2K_API void m2k_set_rts(m2k_t *ctx, int on);
635
637M2K_API int m2k_get_dtr(const m2k_t *ctx);
638
640M2K_API int m2k_get_rts(const m2k_t *ctx);
641
656
659
660#ifdef __cplusplus
661}
662#endif
M2K_API void m2k_set_force_verbose(m2k_t *ctx, int on)
Bypass the ATV verbose mask in verboseOut() / verbosePerror().
M2K_API m2k_err_t m2k_setup_app_io(m2k_t *ctx)
Embed mode: no real TTY fd; the host application supplies the bytes a TTY would normally produce,...
void(* m2k_log_fn)(const char *msg, void *userdata)
Log callback type.
Definition modemu2k.h:115
M2K_API int m2k_is_online(const m2k_t *ctx)
Test whether the modem is currently in online mode.
M2K_API int m2k_get_dtr(const m2k_t *ctx)
M2K_API m2k_err_t m2k_listen_accept(m2k_t *ctx)
Accept a single incoming connection on the listening socket opened by m2k_setup_listen() and adopt it...
M2K_API m2k_err_t m2k_run(m2k_t *ctx)
Run the modem command/online loop until the PTY closes.
M2K_API void m2k_set_error_buffer(m2k_t *ctx, char *buf, size_t size)
Install a buffer that receives a detailed message for the most recent error.
M2K_API void m2k_free(m2k_t *ctx)
Release all resources held by ctx.
M2K_API m2k_err_t m2k_setup_comm_program(m2k_t *ctx, const char *cmd)
Allocate a PTY and fork/exec a comm program on the slave.
M2K_API int m2k_run_done(const m2k_t *ctx)
Test whether the session has ended.
M2K_API m2k_err_t m2k_setup_stdin(m2k_t *ctx)
Use stdin/stdout as the TTY (standalone mode).
M2K_API void m2k_set_log_fn(m2k_t *ctx, m2k_log_fn fn, void *userdata)
Install a log callback.
M2K_API m2k_err_t m2k_setup_dev(m2k_t *ctx, const char *dev)
Open an existing PTY device as the TTY.
M2K_API m2k_err_t m2k_escape(m2k_t *ctx)
Request an immediate return to command mode from online mode.
M2K_API const char * m2k_version(void)
Runtime version string of the linked libmodemu2k.
struct m2k_s m2k_t
Opaque modem emulator context. Create with m2k_new(), destroy with m2k_free().
Definition modemu2k.h:95
M2K_API m2k_err_t m2k_atcmd(m2k_t *ctx, const char *cmd)
Feed a Hayes AT command string to the modem.
M2K_API m2k_err_t m2k_hangup(m2k_t *ctx)
Tear down the active TCP connection.
M2K_API m2k_t * m2k_new(void)
Allocate and initialise a new modem context.
M2K_API m2k_err_t m2k_step(m2k_t *ctx, struct pollfd *fds, size_t nfds)
Run one non-blocking iteration of the state machine.
M2K_API int m2k_has_pending_output(const m2k_t *ctx)
Test whether the modem has TTY-bound bytes still buffered.
M2K_API int m2k_get_rts(const m2k_t *ctx)
m2k_err_t
Return codes used by all m2k_* functions.
Definition modemu2k.h:122
@ M2K_ERR_PTY
Definition modemu2k.h:125
@ M2K_ERR_NOMEM
Definition modemu2k.h:124
@ M2K_ERR_WOULDBLOCK
Definition modemu2k.h:130
@ M2K_ERR_TIMEOUT
Definition modemu2k.h:127
@ M2K_OK
Definition modemu2k.h:123
@ M2K_ERR_CANCELED
Definition modemu2k.h:128
@ M2K_ERR_BUG
Definition modemu2k.h:129
@ M2K_ERR_SOCKET
Definition modemu2k.h:126
@ M2K_ERR_AT
Definition modemu2k.h:133
M2K_API m2k_err_t m2k_write_from_app(m2k_t *ctx, const void *buf, size_t len, size_t *consumed)
Push bytes into the modem as if they had been read from the TTY.
M2K_API m2k_err_t m2k_setup_pty(m2k_t *ctx, const char **slave_out)
Allocate a PTY master and return the slave device path.
M2K_API m2k_err_t m2k_read_to_app(m2k_t *ctx, void *buf, size_t max, size_t *len_out)
Drain bytes from the modem that would normally have been written to the TTY.
M2K_API int m2k_has_carrier(const m2k_t *ctx)
Test whether the modem has an active carrier (live TCP socket).
M2K_API m2k_err_t m2k_get_pollfds(m2k_t *ctx, struct pollfd *fds, size_t *nfds_inout, int *timeout_ms)
Describe the fds and timeout the caller's event loop should watch.
M2K_API const char * m2k_strerror(m2k_err_t err)
Return a human-readable string for err.
M2K_API void m2k_set_rts(m2k_t *ctx, int on)
Set the host's RTS (Request to Send) signal state.
M2K_API int m2k_get_force_verbose(const m2k_t *ctx)
M2K_API m2k_err_t m2k_setup_listen(m2k_t *ctx, const char *port)
Bind a TCP listening socket on port.
M2K_API void m2k_set_dtr(m2k_t *ctx, int on)
Set the host's DTR (Data Terminal Ready) signal state.
#define M2K_API
Public-symbol visibility/export marker.
Definition modemu2k.h:72
M2K_API int m2k_get_listen_fd(const m2k_t *ctx)
Expose the listening socket's fd (after m2k_setup_listen, before m2k_listen_accept).