X-Git-Url: https://git.ozlabs.org/?a=blobdiff_plain;f=ccan%2Fio%2Fbackend.h;h=c071c5d6c5939372bcbb290a0a580e5257076e38;hb=1966714494a5de39b2ee944fcc01f333c1741dbd;hp=c8ceb4e864397c5e54c54fe20c3ceddaae2c9e20;hpb=e846b1a93ecf096164ff2c4faaf4a89c24a0e76b;p=ccan diff --git a/ccan/io/backend.h b/ccan/io/backend.h index c8ceb4e8..c071c5d6 100644 --- a/ccan/io/backend.h +++ b/ccan/io/backend.h @@ -25,8 +25,9 @@ struct io_listener { enum io_plan_status { /* As before calling next function. */ IO_UNSET, - /* Normal. */ - IO_POLLING, + /* Normal, but haven't started yet. */ + IO_POLLING_NOTSTARTED, + IO_POLLING_STARTED, /* Waiting for io_wake */ IO_WAITING, /* Always do this. */ @@ -36,6 +37,7 @@ enum io_plan_status { /** * struct io_plan - one half of I/O to do * @status: the status of this plan. + * @dir: are we plan[0] or plan[1] inside io_conn? * @io: function to call when fd becomes read/writable, returns 0 to be * called again, 1 if it's finished, and -1 on error (fd will be closed) * @next: the next function which is called if io returns 1. @@ -44,6 +46,7 @@ enum io_plan_status { */ struct io_plan { enum io_plan_status status; + enum io_direction dir; int (*io)(int fd, struct io_plan_arg *arg);