]> git.ozlabs.org Git - ccan/blobdiff - ccan/io/backend.h
io: change io_idle() to io_wait()
[ccan] / ccan / io / backend.h
index fa4cf8ee9f638ec5a32f9d671b7a9ffe0d649d10..b6674025b0233cf7e2f3a801dd9b41b026a3e97a 100644 (file)
@@ -3,6 +3,17 @@
 #define CCAN_IO_BACKEND_H
 #include <stdbool.h>
 #include <ccan/timer/timer.h>
+#include <poll.h>
+
+/* A setting for actions to always run (eg. zero-length reads). */
+#define POLLALWAYS (((POLLIN|POLLOUT) + 1) & ~((POLLIN|POLLOUT)))
+
+struct io_alloc {
+       void *(*alloc)(size_t size);
+       void *(*realloc)(void *ptr, size_t size);
+       void (*free)(void *ptr);
+};
+extern struct io_alloc io_alloc;
 
 struct fd {
        int fd;
@@ -53,14 +64,22 @@ static inline void set_current(struct io_conn *conn)
 {
        current = conn;
 }
+static inline bool doing_debug_on(struct io_conn *conn)
+{
+       return io_debug_conn && io_debug_conn(conn);
+}
 static inline bool doing_debug(void)
 {
-       return io_debug != NULL;
+       return io_debug_conn;
 }
 #else
 static inline void set_current(struct io_conn *conn)
 {
 }
+static inline bool doing_debug_on(struct io_conn *conn)
+{
+       return false;
+}
 static inline bool doing_debug(void)
 {
        return false;
@@ -72,8 +91,11 @@ bool add_conn(struct io_conn *c);
 bool add_duplex(struct io_conn *c);
 void del_listener(struct io_listener *l);
 void backend_plan_changed(struct io_conn *conn);
+void backend_wait_changed(const void *wait);
 void backend_add_timeout(struct io_conn *conn, struct timespec ts);
 void backend_del_timeout(struct io_conn *conn);
+void backend_del_conn(struct io_conn *conn);
 
 void io_ready(struct io_conn *conn);
+void *do_io_loop(struct io_conn **ready);
 #endif /* CCAN_IO_BACKEND_H */