diff options
-rw-r--r-- | include/osmocom/netif/stream.h | 4 | ||||
-rw-r--r-- | src/stream.c | 23 |
2 files changed, 27 insertions, 0 deletions
diff --git a/include/osmocom/netif/stream.h b/include/osmocom/netif/stream.h index ceace28..4363a67 100644 --- a/include/osmocom/netif/stream.h +++ b/include/osmocom/netif/stream.h @@ -9,6 +9,8 @@ void osmo_stream_server_link_destroy(struct osmo_stream_server_link *link); void osmo_stream_server_link_set_addr(struct osmo_stream_server_link *link, const char *addr); void osmo_stream_server_link_set_port(struct osmo_stream_server_link *link, uint16_t port); void osmo_stream_server_link_set_accept_cb(struct osmo_stream_server_link *link, int (*accept_cb)(struct osmo_stream_server_link *link, int fd)); +void osmo_stream_server_link_set_data(struct osmo_stream_server_link *link, void *data); +void *osmo_stream_server_link_get_data(struct osmo_stream_server_link *link); int osmo_stream_server_link_open(struct osmo_stream_server_link *link); void osmo_stream_server_link_close(struct osmo_stream_server_link *link); @@ -16,6 +18,7 @@ void osmo_stream_server_link_close(struct osmo_stream_server_link *link); struct osmo_stream_server_conn; struct osmo_stream_server_conn *osmo_stream_server_conn_create(void *ctx, struct osmo_stream_server_link *link, int fd, int (*cb)(struct osmo_stream_server_conn *conn, struct msgb *msg), int (*closed_cb)(struct osmo_stream_server_conn *conn), void *data); +void *osmo_stream_server_conn_get_data(struct osmo_stream_server_conn *conn); void osmo_stream_server_conn_destroy(struct osmo_stream_server_conn *conn); void osmo_stream_server_conn_send(struct osmo_stream_server_conn *conn, struct msgb *msg); @@ -25,6 +28,7 @@ struct osmo_stream_client_conn; void osmo_stream_client_conn_set_addr(struct osmo_stream_client_conn *link, const char *addr); void osmo_stream_client_conn_set_port(struct osmo_stream_client_conn *link, uint16_t port); void osmo_stream_client_conn_set_data(struct osmo_stream_client_conn *link, void *data); +void *osmo_stream_client_conn_get_data(struct osmo_stream_client_conn *link); void osmo_stream_client_conn_set_connect_cb(struct osmo_stream_client_conn *link, int (*connect_cb)(struct osmo_stream_client_conn *link)); void osmo_stream_client_conn_set_read_cb(struct osmo_stream_client_conn *link, int (*read_cb)(struct osmo_stream_client_conn *link, struct msgb *msgb)); diff --git a/src/stream.c b/src/stream.c index 65d7f5a..bdb76ff 100644 --- a/src/stream.c +++ b/src/stream.c @@ -206,6 +206,11 @@ osmo_stream_client_conn_set_data(struct osmo_stream_client_conn *link, link->flags |= OSMO_STREAM_CLIENT_F_RECONFIG; } +void *osmo_stream_client_conn_get_data(struct osmo_stream_client_conn *link) +{ + return link->data; +} + void osmo_stream_client_conn_set_connect_cb(struct osmo_stream_client_conn *link, int (*connect_cb)(struct osmo_stream_client_conn *link)) @@ -341,6 +346,19 @@ void osmo_stream_server_link_set_port(struct osmo_stream_server_link *link, link->flags |= OSMO_STREAM_SERVER_F_RECONFIG; } +void +osmo_stream_server_link_set_data(struct osmo_stream_server_link *link, + void *data) +{ + link->data = data; + link->flags |= OSMO_STREAM_SERVER_F_RECONFIG; +} + +void *osmo_stream_server_link_get_data(struct osmo_stream_server_link *link) +{ + return link->data; +} + void osmo_stream_server_link_set_accept_cb(struct osmo_stream_server_link *link, int (*accept_cb)(struct osmo_stream_server_link *link, int fd)) @@ -492,6 +510,11 @@ osmo_stream_server_conn_create(void *ctx, struct osmo_stream_server_link *link, return conn; } +void *osmo_stream_server_conn_get_data(struct osmo_stream_server_conn *link) +{ + return link->data; +} + void osmo_stream_server_conn_destroy(struct osmo_stream_server_conn *conn) { close(conn->ofd.fd); |