modemu2k 0.2.2
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
38
39#include <poll.h> /* struct pollfd, used by m2k_get_pollfds()/m2k_step() below */
40#include <stddef.h> /* size_t */
41
42#include "modemu2k_version.h" /* M2K_VERSION_MAJOR / _MINOR / _PATCH / M2K_VERSION */
43
57#ifndef M2K_API
58# if defined(_WIN32)
59# if defined(M2K_BUILDING_DLL)
60# define M2K_API __declspec(dllexport)
61# else
62# define M2K_API __declspec(dllimport)
63# endif
64# elif defined(__GNUC__) && __GNUC__ >= 4
65# define M2K_API __attribute__((visibility("default")))
66# else
67# define M2K_API
68# endif
69#endif
70
71/* Deprecation marker. Consumers see a -Wdeprecated-declarations
72 * warning at the call site. modemu2k's own build defines
73 * M2K_SUPPRESS_DEPRECATED so the in-tree tests that still exercise
74 * the deprecated path build clean. */
75#if defined(M2K_SUPPRESS_DEPRECATED)
76# define M2K_DEPRECATED(msg)
77#elif defined(__GNUC__) || defined(__clang__)
78# define M2K_DEPRECATED(msg) __attribute__((deprecated(msg)))
79#elif defined(_MSC_VER)
80# define M2K_DEPRECATED(msg) __declspec(deprecated(msg))
81#else
82# define M2K_DEPRECATED(msg)
83#endif
84
85#ifdef __cplusplus
86extern "C" {
87#endif
88
90typedef struct m2k_s m2k_t;
91
103M2K_API const char *m2k_version(void);
104
110typedef void (*m2k_log_fn)(const char *msg, void *userdata);
111
115/* Note: new codes are appended; existing values must never be reordered
116 so external callers can safely cache numeric values across releases. */
130
136
142
157M2K_API void m2k_set_log_fn(m2k_t *ctx, m2k_log_fn fn, void *userdata);
158
160#define M2K_ERROR_BUFFER_SIZE 256
161
184M2K_API void m2k_set_error_buffer(m2k_t *ctx, char *buf, size_t size);
185
208M2K_API m2k_err_t m2k_atcmd(m2k_t *ctx, const char *cmd);
209
227M2K_API M2K_DEPRECATED("use m2k_run() or the step API instead")
228m2k_err_t m2k_dial(m2k_t *ctx, const char *host, const char *port);
229
243M2K_API M2K_DEPRECATED("use m2k_run() or the step API instead")
244m2k_err_t m2k_online(m2k_t *ctx);
245
252
271
278
288
304M2K_API m2k_err_t m2k_setup_pty(m2k_t *ctx, const char **slave_out);
305
319
327M2K_API m2k_err_t m2k_setup_dev(m2k_t *ctx, const char *dev);
328
346M2K_API m2k_err_t m2k_setup_listen(m2k_t *ctx, const char *port);
347
364
384M2K_API m2k_err_t m2k_write_from_app(m2k_t *ctx, const void *buf, size_t len,
385 size_t *consumed);
386
417M2K_API m2k_err_t m2k_read_to_app(m2k_t *ctx, void *buf, size_t max, size_t *len_out);
418
433
448
463
488
489/* ── Steppable event-loop API ───────────────────────────────────────
490 *
491 * The functions below let a host application integrate modemu2k into
492 * its own event loop (poll/epoll/select/etc.) instead of handing the
493 * fds to the blocking m2k_run() above.
494 *
495 * Usage:
496 * while (!m2k_run_done(ctx)) {
497 * struct pollfd fds[M2K_MAX_POLLFDS]; // caller-provided buffer
498 * size_t nfds = M2K_MAX_POLLFDS;
499 * int timeout_ms;
500 * m2k_get_pollfds(ctx, fds, &nfds, &timeout_ms);
501 * // Splice fds into your own pollset, call poll()/epoll_wait().
502 * // On return, write back the .revents the OS reported into the
503 * // corresponding entries of `fds`.
504 * m2k_step(ctx, fds, nfds);
505 * }
506 *
507 * Dialing (ATD) is non-blocking: m2k_step() transitions the context
508 * into an internal DIAL state on ATD, returns control immediately,
509 * and resumes the connect() across subsequent m2k_step() calls. The
510 * host event loop is not held up by connect(). m2k_get_pollfds()
511 * publishes the in-progress socket fd while DIAL is active, so the
512 * host pollset stays accurate without special-casing.
513 */
514
516#define M2K_MAX_POLLFDS 3
517
535M2K_API m2k_err_t m2k_get_pollfds(m2k_t *ctx, struct pollfd *fds,
536 size_t *nfds_inout, int *timeout_ms);
537
553M2K_API m2k_err_t m2k_step(m2k_t *ctx, struct pollfd *fds, size_t nfds);
554
561M2K_API int m2k_run_done(const m2k_t *ctx);
562
575
588
602M2K_API void m2k_set_dtr(m2k_t *ctx, int on);
603
615M2K_API void m2k_set_rts(m2k_t *ctx, int on);
616
618M2K_API int m2k_get_dtr(const m2k_t *ctx);
619
621M2K_API int m2k_get_rts(const m2k_t *ctx);
622
637
640
641#ifdef __cplusplus
642}
643#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:110
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:90
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:117
@ M2K_ERR_PTY
Definition modemu2k.h:120
@ M2K_ERR_NOMEM
Definition modemu2k.h:119
@ M2K_ERR_WOULDBLOCK
Definition modemu2k.h:125
@ M2K_ERR_TIMEOUT
Definition modemu2k.h:122
@ M2K_OK
Definition modemu2k.h:118
@ M2K_ERR_CANCELED
Definition modemu2k.h:123
@ M2K_ERR_BUG
Definition modemu2k.h:124
@ M2K_ERR_SOCKET
Definition modemu2k.h:121
@ M2K_ERR_AT
Definition modemu2k.h:128
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:67
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).