X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=comm-common.h;h=baeb24e82954534cf9cf27bca2cf36b7e1940050;hb=4ea3eeb803a561e97407755eee34426bc639d49f;hp=44bb6c3d5fe080b7c3d471d497bbb874f44b7941;hpb=f7af31926b95660b98177fb4fd48c72edf32944d;p=secnet.git diff --git a/comm-common.h b/comm-common.h index 44bb6c3..baeb24e 100644 --- a/comm-common.h +++ b/comm-common.h @@ -72,6 +72,7 @@ struct udpsocks { struct udpsock socks[UDP_MAX_SOCKETS]; /* private for udp_socks_* */ struct udpcommon *uc; /* link to parent, for cfg, notify list, etc. */ + struct poll_interest *interest; }; struct udpcommon { @@ -82,8 +83,15 @@ struct udpcommon { union iaddr proxy; }; -void udp_make_socket(struct udpcommon *uc, struct udpsock *us); +bool_t udp_make_socket(struct udpcommon *uc, struct udpsock *us, + int failmsgclass); + /* Fills in us->fd. Logs any errors with lg_[v]perror. */ + +void udp_destroy_socket(struct udpcommon *uc, struct udpsock *us); + /* Idempotent. No errors are possible. */ + void udp_socks_register(struct udpcommon *uc, struct udpsocks *socks); +void udp_socks_deregister(struct udpcommon *uc, struct udpsocks *socks); #define UDP_APPLY_STANDARD(st,uc,desc) \ (uc)->use_proxy=False; \