X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib%2Fvconn-provider.h;h=1c8b86da60a83e1750677d0c8e315ab4e055471f;hb=c1fdab010642441ca14954383ab351fc5f38465a;hp=ada61368ce9c9dda49a00ebcd5195534659c2267;hpb=a14bc59fb8f27db193d74662dc9c5cb8237177ef;p=sliver-openvswitch.git diff --git a/lib/vconn-provider.h b/lib/vconn-provider.h index ada61368c..1c8b86da6 100644 --- a/lib/vconn-provider.h +++ b/lib/vconn-provider.h @@ -34,13 +34,19 @@ struct vconn { int error; int min_version; int version; - uint32_t ip; + uint32_t remote_ip; + uint16_t remote_port; + uint32_t local_ip; + uint16_t local_port; char *name; - bool reconnectable; }; void vconn_init(struct vconn *, struct vconn_class *, int connect_status, - uint32_t ip, const char *name, bool reconnectable); + const char *name); +void vconn_set_remote_ip(struct vconn *, uint32_t remote_ip); +void vconn_set_remote_port(struct vconn *, uint16_t remote_port); +void vconn_set_local_ip(struct vconn *, uint32_t local_ip); +void vconn_set_local_port(struct vconn *, uint16_t local_port); static inline void vconn_assert_class(const struct vconn *vconn, const struct vconn_class *class) { @@ -102,6 +108,18 @@ struct vconn_class { * accepted for transmission, it should return EAGAIN. */ int (*send)(struct vconn *vconn, struct ofpbuf *msg); + /* Allows 'vconn' to perform maintenance activities, such as flushing + * output buffers. + * + * May be null if 'vconn' doesn't have anything to do here. */ + void (*run)(struct vconn *vconn); + + /* Arranges for the poll loop to wake up when 'vconn' needs to perform + * maintenance activities. + * + * May be null if 'vconn' doesn't have anything to do here. */ + void (*run_wait)(struct vconn *vconn); + /* Arranges for the poll loop to wake up when 'vconn' is ready to take an * action of the given 'type'. */ void (*wait)(struct vconn *vconn, enum vconn_wait_type type);