void *conn_arg;
};
+enum io_result {
+ RESULT_AGAIN,
+ RESULT_FINISHED,
+ RESULT_CLOSE
+};
+
enum io_state {
- /* These wait for something to input */
- READ,
- READPART,
-
- /* These wait for room to output */
- WRITE,
- WRITEPART,
-
- NEXT, /* eg starting, woken from idle, return from io_break. */
- IDLE,
- FINISHED,
- PROCESSING /* We expect them to change this now. */
+ IO_IO,
+ IO_NEXT, /* eg starting, woken from idle, return from io_break. */
+ IO_IDLE,
+ IO_FINISHED
};
static inline enum io_state from_ioplan(struct io_plan *op)
struct io_conn *duplex;
struct io_timeout *timeout;
+ enum io_result (*io)(struct io_conn *conn);
+
int pollflag; /* 0, POLLIN or POLLOUT */
enum io_state state;
union {
bool add_conn(struct io_conn *c);
bool add_duplex(struct io_conn *c);
void del_listener(struct io_listener *l);
-void backend_set_state(struct io_conn *conn, struct io_plan *op);
+void backend_wakeup(struct io_conn *conn);
void backend_add_timeout(struct io_conn *conn, struct timespec ts);
void backend_del_timeout(struct io_conn *conn);