libdill: Structured Concurrency for C


tcp_fromfd_mem - wraps an existing OS-level file descriptor


#include <libdill.h>

int tcp_fromfd_mem(
    int fd,
    struct tcp_storage* mem);


TCP protocol is a reliable bytestream protocol for transporting data over network. It is defined in RFC 793.

This function wraps an existing OS-level file descriptor.

This function allows to avoid one dynamic memory allocation by storing the object in user-supplied memory. Unless you are hyper-optimizing use tcp_fromfd instead.

fd: File descriptor of a connected TCP socket to wrap.

mem: The structure to store the newly created object in. It must not be deallocated before the object is closed.

The socket can be cleanly shut down using tcp_close function which will also close the underlying file descriptor.

There's no way to unwrap the file descriptor.

This function is not available if libdill is compiled with --disable-sockets option.


In case of success the function returns newly created socket handle. In case of error it returns -1 and sets errno to one of the values below.



int fd = socket(AF_INET, SOCK_STREAM, 0);
connect(fd, addr, sizeof(addr));
int s = tcp_fromfd(fd);
bsend(s, "ABC", 3, -1);
char buf[3];
brecv(s, buf, sizeof(buf), -1);


brecv(3) brecvl(3) bsend(3) bsendl(3) hclose(3) tcp_accept(3) tcp_accept_mem(3) tcp_close(3) tcp_connect(3) tcp_connect_mem(3) tcp_done(3) tcp_fromfd(3) tcp_listen(3) tcp_listen_mem(3) tcp_listener_fromfd(3) tcp_listener_fromfd_mem(3)