X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=lib%2Fnetdev.h;h=84ae16ee4279982b4176a53a779dd0367342a10d;hb=7778bd15dacc1e410b60ff6ec2996c475a875e6e;hp=d128f3f329bac6125196f508f1d895b09a4d0873;hpb=a14bc59fb8f27db193d74662dc9c5cb8237177ef;p=openvswitch diff --git a/lib/netdev.h b/lib/netdev.h index d128f3f3..84ae16ee 100644 --- a/lib/netdev.h +++ b/lib/netdev.h @@ -90,8 +90,9 @@ int netdev_get_features(struct netdev *, uint32_t *current, uint32_t *advertised, uint32_t *supported, uint32_t *peer); int netdev_set_advertisements(struct netdev *, uint32_t advertise); -bool netdev_get_in4(const struct netdev *, struct in_addr *); -int netdev_set_in4(struct netdev *, struct in_addr addr, struct in_addr mask); +bool netdev_get_in4(const struct netdev *, struct in_addr *addr, + struct in_addr *mask); +int netdev_set_in4(struct netdev *, struct in_addr in4, struct in_addr mask); int netdev_add_router(struct in_addr router); bool netdev_get_in6(const struct netdev *, struct in6_addr *); int netdev_get_flags(const struct netdev *, enum netdev_flags *); @@ -105,11 +106,18 @@ int netdev_set_policing(struct netdev *, uint32_t kbits_rate, uint32_t kbits_burst); void netdev_enumerate(struct svec *); +bool netdev_find_dev_by_in4(const struct in_addr *in4, char **netdev_name); +int netdev_get_next_hop(const struct in_addr *host, struct in_addr *next_hop, + char **netdev_name); int netdev_nodev_get_flags(const char *netdev_name, enum netdev_flags *); +bool netdev_nodev_get_in4(const char *netdev_name, struct in_addr *in4, + struct in_addr *mask); int netdev_nodev_set_etheraddr(const char *name, const uint8_t mac[6]); int netdev_nodev_get_etheraddr(const char *netdev_name, uint8_t mac[6]); int netdev_nodev_set_policing(const char *netdev_name, uint32_t kbits_rate, uint32_t kbits_burst); +int netdev_nodev_arp_lookup(const char *netdev_name, uint32_t ip, + uint8_t mac[6]); int netdev_nodev_get_carrier(const char *netdev_name, bool *carrier); int netdev_get_vlan_vid(const char *netdev_name, int *vlan_vid);