summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
53f4e66)
polypath is going to want this.
Signed-off-by: Ian Jackson <ijackson@chiark.greenend.org.uk>
struct udpsock socks[UDP_MAX_SOCKETS];
/* private for udp_socks_* */
struct udpcommon *uc; /* link to parent, for cfg, notify list, etc. */
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;
/* Fills in us->fd. Logs any errors with lg_[v]perror. */
void udp_socks_register(struct udpcommon *uc, struct udpsocks *socks);
/* Fills in us->fd. Logs any errors with lg_[v]perror. */
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; \
#define UDP_APPLY_STANDARD(st,uc,desc) \
(uc)->use_proxy=False; \
void udp_socks_register(struct udpcommon *uc, struct udpsocks *socks)
{
socks->uc=uc;
void udp_socks_register(struct udpcommon *uc, struct udpsocks *socks)
{
socks->uc=uc;
- register_for_poll(socks,udp_socks_beforepoll,udp_socks_afterpoll,"udp");
+ socks->interest=
+ register_for_poll(socks,udp_socks_beforepoll,udp_socks_afterpoll,"udp");
+}
+
+void udp_socks_deregister(struct udpcommon *uc, struct udpsocks *socks)
+{
+ socks->uc=uc;
+ deregister_for_poll(socks->interest);
}
static void udp_phase_hook(void *sst, uint32_t new_phase)
}
static void udp_phase_hook(void *sst, uint32_t new_phase)