git: 3e142e07675b - main - ofed: Mechanically convert to IfAPI
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Fri, 24 Mar 2023 15:49:11 UTC
The branch main has been updated by jhibbits: URL: https://cgit.FreeBSD.org/src/commit/?id=3e142e07675be6df39e4aaf5003637dca54cdcea commit 3e142e07675be6df39e4aaf5003637dca54cdcea Author: Justin Hibbits <jhibbits@FreeBSD.org> AuthorDate: 2023-02-09 02:31:24 +0000 Commit: Justin Hibbits <jhibbits@FreeBSD.org> CommitDate: 2023-03-24 14:04:33 +0000 ofed: Mechanically convert to IfAPI Summary: Because of the intricacies of this code it wasn't purely scripted, but instead hand-mechanical. Reviewed by: hselasky Sponsored by: Juniper Networks, Inc. Differential Revision: https://reviews.freebsd.org/D38560 --- sys/ofed/drivers/infiniband/core/core_priv.h | 10 +- sys/ofed/drivers/infiniband/core/ib_addr.c | 88 +++++---- sys/ofed/drivers/infiniband/core/ib_cache.c | 26 +-- sys/ofed/drivers/infiniband/core/ib_cm.c | 6 +- sys/ofed/drivers/infiniband/core/ib_cma.c | 74 ++++---- sys/ofed/drivers/infiniband/core/ib_device.c | 12 +- sys/ofed/drivers/infiniband/core/ib_multicast.c | 2 +- .../drivers/infiniband/core/ib_roce_gid_mgmt.c | 152 +++++++++------- sys/ofed/drivers/infiniband/core/ib_sa_query.c | 6 +- sys/ofed/drivers/infiniband/ulp/ipoib/ipoib.h | 10 +- sys/ofed/drivers/infiniband/ulp/ipoib/ipoib_cm.c | 36 ++-- .../drivers/infiniband/ulp/ipoib/ipoib_ethtool.c | 16 +- sys/ofed/drivers/infiniband/ulp/ipoib/ipoib_fs.c | 4 +- sys/ofed/drivers/infiniband/ulp/ipoib/ipoib_ib.c | 26 +-- sys/ofed/drivers/infiniband/ulp/ipoib/ipoib_main.c | 201 +++++++++++---------- .../drivers/infiniband/ulp/ipoib/ipoib_multicast.c | 20 +- .../drivers/infiniband/ulp/ipoib/ipoib_verbs.c | 8 +- sys/ofed/drivers/infiniband/ulp/ipoib/ipoib_vlan.c | 10 +- sys/ofed/include/rdma/ib_addr.h | 43 ++--- sys/ofed/include/rdma/ib_addr_freebsd.h | 12 +- sys/ofed/include/rdma/ib_cache.h | 4 +- sys/ofed/include/rdma/ib_sa.h | 4 +- sys/ofed/include/rdma/ib_verbs.h | 10 +- 23 files changed, 401 insertions(+), 379 deletions(-) diff --git a/sys/ofed/drivers/infiniband/core/core_priv.h b/sys/ofed/drivers/infiniband/core/core_priv.h index ebbb46d73933..db6cbac386ba 100644 --- a/sys/ofed/drivers/infiniband/core/core_priv.h +++ b/sys/ofed/drivers/infiniband/core/core_priv.h @@ -82,10 +82,10 @@ void ib_cache_setup(void); void ib_cache_cleanup(void); typedef void (*roce_netdev_callback)(struct ib_device *device, u8 port, - struct ifnet *idev, void *cookie); + if_t idev, void *cookie); typedef int (*roce_netdev_filter)(struct ib_device *device, u8 port, - struct ifnet *idev, void *cookie); + if_t idev, void *cookie); void ib_enum_roce_netdev(struct ib_device *ib_dev, roce_netdev_filter filter, @@ -107,7 +107,7 @@ int ib_cache_gid_parse_type_str(const char *buf); const char *ib_cache_gid_type_str(enum ib_gid_type gid_type); void ib_cache_gid_set_default_gid(struct ib_device *ib_dev, u8 port, - struct ifnet *ndev, + if_t ndev, unsigned long gid_type_mask, enum ib_cache_gid_default_mode mode); @@ -118,8 +118,8 @@ int ib_cache_gid_del(struct ib_device *ib_dev, u8 port, union ib_gid *gid, struct ib_gid_attr *attr); int ib_cache_gid_del_all_netdev_gids(struct ib_device *ib_dev, u8 port, - struct ifnet *ndev); -void ib_cache_gid_del_all_by_netdev(struct ifnet *ndev); + if_t ndev); +void ib_cache_gid_del_all_by_netdev(if_t ndev); int roce_gid_mgmt_init(void); void roce_gid_mgmt_cleanup(void); diff --git a/sys/ofed/drivers/infiniband/core/ib_addr.c b/sys/ofed/drivers/infiniband/core/ib_addr.c index 974860b77caf..ee5e792027d3 100644 --- a/sys/ofed/drivers/infiniband/core/ib_addr.c +++ b/sys/ofed/drivers/infiniband/core/ib_addr.c @@ -140,32 +140,34 @@ rdma_copy_addr_sub(u8 *dst, const u8 *src, unsigned min, unsigned max) memset(dst + min, 0, max - min); } -int rdma_copy_addr(struct rdma_dev_addr *dev_addr, struct ifnet *dev, +int rdma_copy_addr(struct rdma_dev_addr *dev_addr, if_t dev, const unsigned char *dst_dev_addr) { + int dev_type = if_gettype(dev); + /* check for loopback device */ - if (dev->if_flags & IFF_LOOPBACK) { + if (if_getflags(dev) & IFF_LOOPBACK) { dev_addr->dev_type = ARPHRD_ETHER; memset(dev_addr->src_dev_addr, 0, MAX_ADDR_LEN); memset(dev_addr->broadcast, 0, MAX_ADDR_LEN); memset(dev_addr->dst_dev_addr, 0, MAX_ADDR_LEN); - dev_addr->bound_dev_if = dev->if_index; + dev_addr->bound_dev_if = if_getindex(dev); return (0); - } else if (dev->if_type == IFT_INFINIBAND) + } else if (dev_type == IFT_INFINIBAND) dev_addr->dev_type = ARPHRD_INFINIBAND; - else if (dev->if_type == IFT_ETHER || dev->if_type == IFT_L2VLAN) + else if (dev_type == IFT_ETHER || dev_type == IFT_L2VLAN) dev_addr->dev_type = ARPHRD_ETHER; else dev_addr->dev_type = 0; - rdma_copy_addr_sub(dev_addr->src_dev_addr, IF_LLADDR(dev), - dev->if_addrlen, MAX_ADDR_LEN); - rdma_copy_addr_sub(dev_addr->broadcast, dev->if_broadcastaddr, - dev->if_addrlen, MAX_ADDR_LEN); + rdma_copy_addr_sub(dev_addr->src_dev_addr, if_getlladdr(dev), + if_getaddrlen(dev), MAX_ADDR_LEN); + rdma_copy_addr_sub(dev_addr->broadcast, if_getbroadcastaddr(dev), + if_getaddrlen(dev), MAX_ADDR_LEN); if (dst_dev_addr != NULL) { rdma_copy_addr_sub(dev_addr->dst_dev_addr, dst_dev_addr, - dev->if_addrlen, MAX_ADDR_LEN); + if_getaddrlen(dev), MAX_ADDR_LEN); } - dev_addr->bound_dev_if = dev->if_index; + dev_addr->bound_dev_if = if_getindex(dev); return 0; } EXPORT_SYMBOL(rdma_copy_addr); @@ -173,7 +175,7 @@ EXPORT_SYMBOL(rdma_copy_addr); int rdma_translate_ip(const struct sockaddr *addr, struct rdma_dev_addr *dev_addr) { - struct ifnet *dev; + if_t dev; int ret; if (dev_addr->bound_dev_if) { @@ -198,7 +200,7 @@ int rdma_translate_ip(const struct sockaddr *addr, if (dev != NULL) { /* disallow connections through 127.0.0.1 itself */ - if (dev->if_flags & IFF_LOOPBACK) + if (if_getflags(dev) & IFF_LOOPBACK) ret = -EINVAL; else ret = rdma_copy_addr(dev_addr, dev, NULL); @@ -241,7 +243,7 @@ static void queue_req(struct addr_req *req) } #if defined(INET) || defined(INET6) -static int addr_resolve_multi(u8 *edst, struct ifnet *ifp, struct sockaddr *dst_in) +static int addr_resolve_multi(u8 *edst, if_t ifp, struct sockaddr *dst_in) { struct sockaddr *llsa; struct sockaddr_dl sdl; @@ -250,14 +252,10 @@ static int addr_resolve_multi(u8 *edst, struct ifnet *ifp, struct sockaddr *dst_ sdl.sdl_len = sizeof(sdl); llsa = (struct sockaddr *)&sdl; - if (ifp->if_resolvemulti == NULL) { - error = EOPNOTSUPP; - } else { - error = ifp->if_resolvemulti(ifp, &llsa, dst_in); - if (error == 0) { - rdma_copy_addr_sub(edst, LLADDR((struct sockaddr_dl *)llsa), - ifp->if_addrlen, MAX_ADDR_LEN); - } + error = if_resolvemulti(ifp, &llsa, dst_in); + if (error == 0) { + rdma_copy_addr_sub(edst, LLADDR((struct sockaddr_dl *)llsa), + if_getaddrlen(ifp), MAX_ADDR_LEN); } return (error); } @@ -268,7 +266,7 @@ static int addr4_resolve(struct sockaddr_in *src_in, const struct sockaddr_in *dst_in, struct rdma_dev_addr *addr, u8 *edst, - struct ifnet **ifpp) + if_t *ifpp) { enum { ADDR_VALID = 0, @@ -279,7 +277,7 @@ static int addr4_resolve(struct sockaddr_in *src_in, in_port_t src_port; struct sockaddr *saddr = NULL; struct nhop_object *nh; - struct ifnet *ifp; + if_t ifp; int error; int type; @@ -332,13 +330,13 @@ static int addr4_resolve(struct sockaddr_in *src_in, if (ifp == NULL) { error = ENETUNREACH; goto done; - } else if (ifp->if_flags & IFF_LOOPBACK) { + } else if (if_getflags(ifp) & IFF_LOOPBACK) { /* * Source address cannot be a loopback device. */ error = EHOSTUNREACH; goto error_put_ifp; - } else if (nh->nh_ifp->if_flags & IFF_LOOPBACK) { + } else if (if_getflags(nh->nh_ifp) & IFF_LOOPBACK) { if (memcmp(&src_in->sin_addr, &dst_in->sin_addr, sizeof(src_in->sin_addr))) { /* @@ -364,7 +362,7 @@ static int addr4_resolve(struct sockaddr_in *src_in, break; case ADDR_SRC_ANY: /* check for loopback device */ - if (nh->nh_ifp->if_flags & IFF_LOOPBACK) + if (if_getflags(nh->nh_ifp) & IFF_LOOPBACK) saddr = (struct sockaddr *)&dst_tmp; else saddr = nh->nh_ifa->ifa_addr; @@ -381,8 +379,8 @@ static int addr4_resolve(struct sockaddr_in *src_in, * Step 3 - resolve destination MAC address */ if (dst_tmp.sin_addr.s_addr == INADDR_BROADCAST) { - rdma_copy_addr_sub(edst, ifp->if_broadcastaddr, - ifp->if_addrlen, MAX_ADDR_LEN); + rdma_copy_addr_sub(edst, if_getbroadcastaddr(ifp), + if_getaddrlen(ifp), MAX_ADDR_LEN); error = 0; } else if (IN_MULTICAST(ntohl(dst_tmp.sin_addr.s_addr))) { bool is_gw = (nh->nh_flags & NHF_GATEWAY) != 0; @@ -391,7 +389,7 @@ static int addr4_resolve(struct sockaddr_in *src_in, goto error_put_ifp; else if (is_gw) addr->network = RDMA_NETWORK_IPV4; - } else if (ifp->if_flags & IFF_LOOPBACK) { + } else if (if_getflags(ifp) & IFF_LOOPBACK) { memset(edst, 0, MAX_ADDR_LEN); error = 0; } else { @@ -440,7 +438,7 @@ static int addr4_resolve(struct sockaddr_in *src_in, const struct sockaddr_in *dst_in, struct rdma_dev_addr *addr, u8 *edst, - struct ifnet **ifpp) + if_t *ifpp) { return -EADDRNOTAVAIL; } @@ -451,7 +449,7 @@ static int addr6_resolve(struct sockaddr_in6 *src_in, const struct sockaddr_in6 *dst_in, struct rdma_dev_addr *addr, u8 *edst, - struct ifnet **ifpp) + if_t *ifpp) { enum { ADDR_VALID = 0, @@ -462,7 +460,7 @@ static int addr6_resolve(struct sockaddr_in6 *src_in, in_port_t src_port; struct sockaddr *saddr = NULL; struct nhop_object *nh; - struct ifnet *ifp; + if_t ifp; int error; int type; @@ -530,13 +528,13 @@ static int addr6_resolve(struct sockaddr_in6 *src_in, if (ifp == NULL) { error = ENETUNREACH; goto done; - } else if (ifp->if_flags & IFF_LOOPBACK) { + } else if (if_getflags(ifp) & IFF_LOOPBACK) { /* * Source address cannot be a loopback device. */ error = EHOSTUNREACH; goto error_put_ifp; - } else if (nh->nh_ifp->if_flags & IFF_LOOPBACK) { + } else if (if_getflags(nh->nh_ifp) & IFF_LOOPBACK) { if (memcmp(&src_in->sin6_addr, &dst_in->sin6_addr, sizeof(src_in->sin6_addr))) { /* @@ -562,7 +560,7 @@ static int addr6_resolve(struct sockaddr_in6 *src_in, break; case ADDR_SRC_ANY: /* check for loopback device */ - if (nh->nh_ifp->if_flags & IFF_LOOPBACK) + if (if_getflags(nh->nh_ifp) & IFF_LOOPBACK) saddr = (struct sockaddr *)&dst_tmp; else saddr = nh->nh_ifa->ifa_addr; @@ -586,7 +584,7 @@ static int addr6_resolve(struct sockaddr_in6 *src_in, goto error_put_ifp; else if (is_gw) addr->network = RDMA_NETWORK_IPV6; - } else if (nh->nh_ifp->if_flags & IFF_LOOPBACK) { + } else if (if_getflags(nh->nh_ifp) & IFF_LOOPBACK) { memset(edst, 0, MAX_ADDR_LEN); error = 0; } else { @@ -628,18 +626,18 @@ static int addr6_resolve(struct sockaddr_in6 *src_in, const struct sockaddr_in6 *dst_in, struct rdma_dev_addr *addr, u8 *edst, - struct ifnet **ifpp) + if_t *ifpp) { return -EADDRNOTAVAIL; } #endif -static int addr_resolve_neigh(struct ifnet *dev, +static int addr_resolve_neigh(if_t dev, const struct sockaddr *dst_in, u8 *edst, struct rdma_dev_addr *addr) { - if (dev->if_flags & IFF_LOOPBACK) { + if (if_getflags(dev) & IFF_LOOPBACK) { int ret; /* @@ -647,7 +645,7 @@ static int addr_resolve_neigh(struct ifnet *dev, * sure the destination device address is global by * clearing the bound device interface: */ - if (addr->bound_dev_if == dev->if_index) + if (addr->bound_dev_if == if_getindex(dev)) addr->bound_dev_if = 0; ret = rdma_translate_ip(dst_in, addr); @@ -659,7 +657,7 @@ static int addr_resolve_neigh(struct ifnet *dev, } /* If the device doesn't do ARP internally */ - if (!(dev->if_flags & IFF_NOARP)) + if (!(if_getflags(dev) & IFF_NOARP)) return rdma_copy_addr(addr, dev, edst); return rdma_copy_addr(addr, dev, NULL); @@ -670,7 +668,7 @@ static int addr_resolve(struct sockaddr *src_in, struct rdma_dev_addr *addr) { struct epoch_tracker et; - struct ifnet *ndev = NULL; + if_t ndev = NULL; u8 edst[MAX_ADDR_LEN]; int ret; @@ -860,7 +858,7 @@ static void resolve_cb(int status, struct sockaddr *src_addr, int rdma_addr_find_l2_eth_by_grh(const union ib_gid *sgid, const union ib_gid *dgid, - u8 *dmac, struct ifnet *dev, + u8 *dmac, if_t dev, int *hoplimit) { int ret = 0; @@ -874,7 +872,7 @@ int rdma_addr_find_l2_eth_by_grh(const union ib_gid *sgid, memset(&dev_addr, 0, sizeof(dev_addr)); - dev_addr.bound_dev_if = dev->if_index; + dev_addr.bound_dev_if = if_getindex(dev); dev_addr.net = dev_net(dev); ctx.addr = &dev_addr; diff --git a/sys/ofed/drivers/infiniband/core/ib_cache.c b/sys/ofed/drivers/infiniband/core/ib_cache.c index 1f44841348fe..17b283c48e14 100644 --- a/sys/ofed/drivers/infiniband/core/ib_cache.c +++ b/sys/ofed/drivers/infiniband/core/ib_cache.c @@ -183,7 +183,7 @@ static int write_gid(struct ib_device *ib_dev, u8 port, __releases(&table->rwlock) __acquires(&table->rwlock) { int ret = 0; - struct ifnet *old_net_dev; + if_t old_net_dev; enum ib_gid_type old_gid_type; /* in rdma_cap_roce_gid_table, this funciton should be protected by a @@ -311,12 +311,12 @@ static int find_gid(struct ib_gid_table *table, const union ib_gid *gid, return found; } -static void addrconf_ifid_eui48(u8 *eui, struct ifnet *dev) +static void addrconf_ifid_eui48(u8 *eui, if_t dev) { - if (dev->if_addrlen != ETH_ALEN) + if (if_getaddrlen(dev) != ETH_ALEN) return; - memcpy(eui, IF_LLADDR(dev), 3); - memcpy(eui + 5, IF_LLADDR(dev) + 3, 3); + memcpy(eui, if_getlladdr(dev), 3); + memcpy(eui + 5, if_getlladdr(dev) + 3, 3); /* NOTE: The scope ID is added by the GID to IP conversion */ @@ -325,7 +325,7 @@ static void addrconf_ifid_eui48(u8 *eui, struct ifnet *dev) eui[0] ^= 2; } -static void make_default_gid(struct ifnet *dev, union ib_gid *gid) +static void make_default_gid(if_t dev, union ib_gid *gid) { gid->global.subnet_prefix = cpu_to_be64(0xfe80000000000000LL); addrconf_ifid_eui48(&gid->raw[8], dev); @@ -400,7 +400,7 @@ out_unlock: } int ib_cache_gid_del_all_netdev_gids(struct ib_device *ib_dev, u8 port, - struct ifnet *ndev) + if_t ndev) { struct ib_gid_table **ports_table = ib_dev->cache.gid_cache; struct ib_gid_table *table; @@ -447,8 +447,8 @@ static int __ib_cache_gid_get(struct ib_device *ib_dev, u8 port, int index, memcpy(attr, &table->data_vec[index].attr, sizeof(*attr)); /* make sure network device is valid and attached */ if (attr->ndev != NULL && - (attr->ndev->if_flags & IFF_DYING) == 0 && - attr->ndev->if_addr != NULL) + (if_getflags(attr->ndev) & IFF_DYING) == 0 && + if_getifaddr(attr->ndev) != NULL) dev_hold(attr->ndev); else attr->ndev = NULL; @@ -490,7 +490,7 @@ static int _ib_cache_gid_table_find(struct ib_device *ib_dev, static int ib_cache_gid_find(struct ib_device *ib_dev, const union ib_gid *gid, enum ib_gid_type gid_type, - struct ifnet *ndev, u8 *port, + if_t ndev, u8 *port, u16 *index) { unsigned long mask = GID_ATTR_FIND_MASK_GID | @@ -507,7 +507,7 @@ static int ib_cache_gid_find(struct ib_device *ib_dev, int ib_find_cached_gid_by_port(struct ib_device *ib_dev, const union ib_gid *gid, enum ib_gid_type gid_type, - u8 port, struct ifnet *ndev, + u8 port, if_t ndev, u16 *index) { int local_index; @@ -672,7 +672,7 @@ static void cleanup_gid_table_port(struct ib_device *ib_dev, u8 port, } void ib_cache_gid_set_default_gid(struct ib_device *ib_dev, u8 port, - struct ifnet *ndev, + if_t ndev, unsigned long gid_type_mask, enum ib_cache_gid_default_mode mode) { @@ -899,7 +899,7 @@ EXPORT_SYMBOL(ib_get_cached_gid); int ib_find_cached_gid(struct ib_device *device, const union ib_gid *gid, enum ib_gid_type gid_type, - struct ifnet *ndev, + if_t ndev, u8 *port_num, u16 *index) { diff --git a/sys/ofed/drivers/infiniband/core/ib_cm.c b/sys/ofed/drivers/infiniband/core/ib_cm.c index 45f316252b69..f7812fe4259a 100644 --- a/sys/ofed/drivers/infiniband/core/ib_cm.c +++ b/sys/ofed/drivers/infiniband/core/ib_cm.c @@ -503,7 +503,7 @@ static int cm_init_av_by_path(struct ib_sa_path_rec *path, struct cm_av *av, unsigned long flags; int ret; u8 p; - struct ifnet *ndev = ib_get_ndev_from_path(path); + if_t ndev = ib_get_ndev_from_path(path); read_lock_irqsave(&cm.device_lock, flags); list_for_each_entry(cm_dev, &cm.device_list, list) { @@ -1819,7 +1819,7 @@ static int cm_req_handler(struct cm_work *work) &gid, &gid_attr); if (!ret) { if (gid_attr.ndev) { - work->path[0].ifindex = gid_attr.ndev->if_index; + work->path[0].ifindex = if_getindex(gid_attr.ndev); work->path[0].net = dev_net(gid_attr.ndev); dev_put(gid_attr.ndev); } @@ -1833,7 +1833,7 @@ static int cm_req_handler(struct cm_work *work) &work->path[0].sgid, &gid_attr); if (!err && gid_attr.ndev) { - work->path[0].ifindex = gid_attr.ndev->if_index; + work->path[0].ifindex = if_getindex(gid_attr.ndev); work->path[0].net = dev_net(gid_attr.ndev); dev_put(gid_attr.ndev); } diff --git a/sys/ofed/drivers/infiniband/core/ib_cma.c b/sys/ofed/drivers/infiniband/core/ib_cma.c index 85af3330f08a..f8a346dac35e 100644 --- a/sys/ofed/drivers/infiniband/core/ib_cma.c +++ b/sys/ofed/drivers/infiniband/core/ib_cma.c @@ -461,7 +461,7 @@ static inline void sdp_set_ip_ver(struct sdp_hh *hh, u8 ip_ver) hh->ipv_cap = (ip_ver << 4) | (hh->ipv_cap & 0xF); } -static int cma_igmp_send(struct ifnet *ndev, const union ib_gid *mgid, bool join) +static int cma_igmp_send(if_t ndev, const union ib_gid *mgid, bool join) { int retval; @@ -470,7 +470,7 @@ static int cma_igmp_send(struct ifnet *ndev, const union ib_gid *mgid, bool join rdma_gid2ip(&addr._sockaddr, mgid); - CURVNET_SET_QUIET(ndev->if_vnet); + CURVNET_SET_QUIET(if_getvnet(ndev)); if (join) retval = -if_addmulti(ndev, &addr._sockaddr, NULL); else @@ -603,7 +603,7 @@ static inline int cma_validate_port(struct ib_device *device, u8 port, const struct rdma_dev_addr *dev_addr) { const int dev_type = dev_addr->dev_type; - struct ifnet *ndev; + if_t ndev; int ret = -ENODEV; if ((dev_type == ARPHRD_INFINIBAND) && !rdma_protocol_ib(device, port)) @@ -1396,21 +1396,21 @@ static bool validate_ipv4_net_dev_addr(struct vnet *vnet, } #endif -static bool validate_ipv4_net_dev(struct ifnet *net_dev, +static bool validate_ipv4_net_dev(if_t net_dev, const struct sockaddr_in *dst_addr, const struct sockaddr_in *src_addr) { #ifdef INET __be32 daddr = dst_addr->sin_addr.s_addr, saddr = src_addr->sin_addr.s_addr; - struct ifnet *dst_dev; + if_t dst_dev; struct nhop_object *nh; bool ret; - if (validate_ipv4_net_dev_addr(net_dev->if_vnet, saddr, daddr)) + if (validate_ipv4_net_dev_addr(if_getvnet(net_dev), saddr, daddr)) return false; - dst_dev = ip_ifp_find(net_dev->if_vnet, daddr); + dst_dev = ip_ifp_find(if_getvnet(net_dev), daddr); if (dst_dev != net_dev) { if (dst_dev != NULL) dev_put(dst_dev); @@ -1424,7 +1424,7 @@ static bool validate_ipv4_net_dev(struct ifnet *net_dev, if (saddr == daddr) return true; - CURVNET_SET(net_dev->if_vnet); + CURVNET_SET(if_getvnet(net_dev)); nh = fib4_lookup(RT_DEFAULT_FIB, src_addr->sin_addr, 0, NHR_NONE, 0); if (nh != NULL) ret = (nh->nh_ifp == net_dev); @@ -1437,19 +1437,19 @@ static bool validate_ipv4_net_dev(struct ifnet *net_dev, #endif } -static bool validate_ipv6_net_dev(struct ifnet *net_dev, +static bool validate_ipv6_net_dev(if_t net_dev, const struct sockaddr_in6 *dst_addr, const struct sockaddr_in6 *src_addr) { #ifdef INET6 struct sockaddr_in6 src_tmp = *src_addr; struct sockaddr_in6 dst_tmp = *dst_addr; - struct ifnet *dst_dev; + if_t dst_dev; struct nhop_object *nh; bool ret; - dst_dev = ip6_ifp_find(net_dev->if_vnet, dst_tmp.sin6_addr, - net_dev->if_index); + dst_dev = ip6_ifp_find(if_getvnet(net_dev), dst_tmp.sin6_addr, + if_getindex(net_dev)); if (dst_dev != net_dev) { if (dst_dev != NULL) dev_put(dst_dev); @@ -1457,15 +1457,15 @@ static bool validate_ipv6_net_dev(struct ifnet *net_dev, } dev_put(dst_dev); - CURVNET_SET(net_dev->if_vnet); + CURVNET_SET(if_getvnet(net_dev)); /* * Make sure the scope ID gets embedded. */ - src_tmp.sin6_scope_id = net_dev->if_index; + src_tmp.sin6_scope_id = if_getindex(net_dev); sa6_embedscope(&src_tmp, 0); - dst_tmp.sin6_scope_id = net_dev->if_index; + dst_tmp.sin6_scope_id = if_getindex(net_dev); sa6_embedscope(&dst_tmp, 0); /* @@ -1478,7 +1478,7 @@ static bool validate_ipv6_net_dev(struct ifnet *net_dev, } else { /* non-loopback case */ nh = fib6_lookup(RT_DEFAULT_FIB, &src_addr->sin6_addr, - net_dev->if_index, NHR_NONE, 0); + if_getindex(net_dev), NHR_NONE, 0); if (nh != NULL) ret = (nh->nh_ifp == net_dev); else @@ -1491,7 +1491,7 @@ static bool validate_ipv6_net_dev(struct ifnet *net_dev, #endif } -static bool validate_net_dev(struct ifnet *net_dev, +static bool validate_net_dev(if_t net_dev, const struct sockaddr *daddr, const struct sockaddr *saddr) { @@ -1514,7 +1514,7 @@ static bool validate_net_dev(struct ifnet *net_dev, } } -static struct ifnet * +static if_t roce_get_net_dev_by_cm_event(struct ib_device *device, u8 port_num, const struct ib_cm_event *ib_event) { @@ -1534,13 +1534,13 @@ roce_get_net_dev_by_cm_event(struct ib_device *device, u8 port_num, return (sgid_attr.ndev); } -static struct ifnet *cma_get_net_dev(struct ib_cm_event *ib_event, +static if_t cma_get_net_dev(struct ib_cm_event *ib_event, const struct cma_req_info *req) { struct sockaddr_storage listen_addr_storage, src_addr_storage; struct sockaddr *listen_addr = (struct sockaddr *)&listen_addr_storage, *src_addr = (struct sockaddr *)&src_addr_storage; - struct ifnet *net_dev; + if_t net_dev; const union ib_gid *gid = req->has_gid ? &req->local_gid : NULL; struct epoch_tracker et; int err; @@ -1672,7 +1672,7 @@ static bool cma_protocol_roce(const struct rdma_cm_id *id) } static bool cma_match_net_dev(const struct rdma_cm_id *id, - const struct ifnet *net_dev, + const if_t net_dev, u8 port_num) { const struct rdma_addr *addr = &id->route.addr; @@ -1694,7 +1694,7 @@ static bool cma_match_net_dev(const struct rdma_cm_id *id, return !addr->dev_addr.bound_dev_if || (net_eq(dev_net(net_dev), addr->dev_addr.net) && - addr->dev_addr.bound_dev_if == net_dev->if_index); + addr->dev_addr.bound_dev_if == if_getindex(net_dev)); } static struct rdma_id_private *cma_find_listener( @@ -1702,7 +1702,7 @@ static struct rdma_id_private *cma_find_listener( const struct ib_cm_id *cm_id, const struct ib_cm_event *ib_event, const struct cma_req_info *req, - const struct ifnet *net_dev) + const if_t net_dev) { struct rdma_id_private *id_priv, *id_priv_dev; @@ -1729,7 +1729,7 @@ static struct rdma_id_private *cma_find_listener( static struct rdma_id_private *cma_id_from_event(struct ib_cm_id *cm_id, struct ib_cm_event *ib_event, - struct ifnet **net_dev) + if_t *net_dev) { struct cma_req_info req; struct rdma_bind_list *bind_list; @@ -1864,7 +1864,7 @@ static void cma_leave_mc_groups(struct rdma_id_private *id_priv) if (mc->igmp_joined) { struct rdma_dev_addr *dev_addr = &id_priv->id.route.addr.dev_addr; - struct ifnet *ndev = NULL; + if_t ndev = NULL; if (dev_addr->bound_dev_if) ndev = dev_get_by_index(dev_addr->net, @@ -2053,7 +2053,7 @@ out: static struct rdma_id_private *cma_new_conn_id(struct rdma_cm_id *listen_id, struct ib_cm_event *ib_event, - struct ifnet *net_dev) + if_t net_dev) { struct rdma_id_private *id_priv; struct rdma_cm_id *id; @@ -2115,7 +2115,7 @@ err: static struct rdma_id_private *cma_new_udp_id(struct rdma_cm_id *listen_id, struct ib_cm_event *ib_event, - struct ifnet *net_dev) + if_t net_dev) { struct rdma_id_private *id_priv; struct rdma_cm_id *id; @@ -2183,7 +2183,7 @@ static int cma_req_handler(struct ib_cm_id *cm_id, struct ib_cm_event *ib_event) { struct rdma_id_private *listen_id, *conn_id = NULL; struct rdma_cm_event event; - struct ifnet *net_dev; + if_t net_dev; int offset, ret; listen_id = cma_id_from_event(cm_id, ib_event, &net_dev); @@ -2731,7 +2731,7 @@ static int cma_resolve_iw_route(struct rdma_id_private *id_priv, int timeout_ms) return 0; } -static int iboe_tos_to_sl(struct ifnet *ndev, int tos) +static int iboe_tos_to_sl(if_t ndev, int tos) { /* get service level, SL, from IPv4 type of service, TOS */ int sl = (tos >> 5) & 0x7; @@ -2758,7 +2758,7 @@ static int cma_resolve_iboe_route(struct rdma_id_private *id_priv) struct rdma_addr *addr = &route->addr; struct cma_work *work; int ret; - struct ifnet *ndev = NULL; + if_t ndev = NULL; work = kzalloc(sizeof *work, GFP_KERNEL); @@ -2786,8 +2786,8 @@ static int cma_resolve_iboe_route(struct rdma_id_private *id_priv) goto err2; } - route->path_rec->net = ndev->if_vnet; - route->path_rec->ifindex = ndev->if_index; + route->path_rec->net = if_getvnet(ndev); + route->path_rec->ifindex = if_getindex(ndev); supported_gids = roce_gid_type_mask_support(id_priv->id.device, id_priv->id.port_num); route->path_rec->gid_type = @@ -2820,7 +2820,7 @@ static int cma_resolve_iboe_route(struct rdma_id_private *id_priv) route->path_rec->mtu_selector = IB_SA_EQ; route->path_rec->sl = iboe_tos_to_sl(ndev, id_priv->tos); route->path_rec->traffic_class = id_priv->tos; - route->path_rec->mtu = iboe_get_mtu(ndev->if_mtu); + route->path_rec->mtu = iboe_get_mtu(if_getmtu(ndev)); route->path_rec->rate_selector = IB_SA_EQ; route->path_rec->rate = iboe_get_rate(ndev); dev_put(ndev); @@ -4083,7 +4083,7 @@ static int cma_ib_mc_handler(int status, struct ib_sa_multicast *multicast) if (!status) { struct rdma_dev_addr *dev_addr = &id_priv->id.route.addr.dev_addr; - struct ifnet *ndev = + if_t ndev = dev_get_by_index(dev_addr->net, dev_addr->bound_dev_if); enum ib_gid_type gid_type = id_priv->cma_dev->default_gid_type[id_priv->id.port_num - @@ -4310,7 +4310,7 @@ static int cma_iboe_join_multicast(struct rdma_id_private *id_priv, struct rdma_dev_addr *dev_addr = &id_priv->id.route.addr.dev_addr; int err = 0; struct sockaddr *addr = (struct sockaddr *)&mc->addr; - struct ifnet *ndev = NULL; + if_t ndev = NULL; enum ib_gid_type gid_type; bool send_only; @@ -4345,7 +4345,7 @@ static int cma_iboe_join_multicast(struct rdma_id_private *id_priv, } mc->multicast.ib->rec.rate = iboe_get_rate(ndev); mc->multicast.ib->rec.hop_limit = 1; - mc->multicast.ib->rec.mtu = iboe_get_mtu(ndev->if_mtu); + mc->multicast.ib->rec.mtu = iboe_get_mtu(if_getmtu(ndev)); if (addr->sa_family == AF_INET || addr->sa_family == AF_INET6) { if (gid_type == IB_GID_TYPE_ROCE_UDP_ENCAP) { @@ -4456,7 +4456,7 @@ void rdma_leave_multicast(struct rdma_cm_id *id, struct sockaddr *addr) if (mc->igmp_joined) { struct rdma_dev_addr *dev_addr = &id->route.addr.dev_addr; - struct ifnet *ndev = NULL; + if_t ndev = NULL; if (dev_addr->bound_dev_if) ndev = dev_get_by_index(dev_addr->net, diff --git a/sys/ofed/drivers/infiniband/core/ib_device.c b/sys/ofed/drivers/infiniband/core/ib_device.c index dc0e6a5866d2..f4ab1f945f58 100644 --- a/sys/ofed/drivers/infiniband/core/ib_device.c +++ b/sys/ofed/drivers/infiniband/core/ib_device.c @@ -732,12 +732,12 @@ void ib_enum_roce_netdev(struct ib_device *ib_dev, for (port = rdma_start_port(ib_dev); port <= rdma_end_port(ib_dev); port++) if (rdma_protocol_roce(ib_dev, port)) { - struct ifnet *idev = NULL; + if_t idev = NULL; if (ib_dev->get_netdev) idev = ib_dev->get_netdev(ib_dev, port); - if (idev && (idev->if_flags & IFF_DYING)) { + if (idev && (if_getflags(idev) & IFF_DYING)) { dev_put(idev); idev = NULL; } @@ -779,7 +779,7 @@ void ib_enum_all_roce_netdevs(roce_netdev_filter filter, * * @ndev: Pointer to netdevice */ -void ib_cache_gid_del_all_by_netdev(struct ifnet *ndev) +void ib_cache_gid_del_all_by_netdev(if_t ndev) { struct ib_device *ib_dev; u8 port; @@ -875,7 +875,7 @@ EXPORT_SYMBOL(ib_modify_port); * parameter may be NULL. */ int ib_find_gid(struct ib_device *device, union ib_gid *gid, - enum ib_gid_type gid_type, struct ifnet *ndev, + enum ib_gid_type gid_type, if_t ndev, u8 *port_num, u16 *index) { union ib_gid tmp_gid; @@ -959,13 +959,13 @@ EXPORT_SYMBOL(ib_find_pkey); * @addr: Contains the IP address that the request specified as its * destination. */ -struct ifnet *ib_get_net_dev_by_params(struct ib_device *dev, +if_t ib_get_net_dev_by_params(struct ib_device *dev, u8 port, u16 pkey, const union ib_gid *gid, const struct sockaddr *addr) { - struct ifnet *net_dev = NULL; + if_t net_dev = NULL; struct ib_client_data *context; if (!rdma_protocol_ib(dev, port)) diff --git a/sys/ofed/drivers/infiniband/core/ib_multicast.c b/sys/ofed/drivers/infiniband/core/ib_multicast.c index 3784a3e5e290..b323f17a99ea 100644 --- a/sys/ofed/drivers/infiniband/core/ib_multicast.c +++ b/sys/ofed/drivers/infiniband/core/ib_multicast.c @@ -723,7 +723,7 @@ EXPORT_SYMBOL(ib_sa_get_mcmember_rec); int ib_init_ah_from_mcmember(struct ib_device *device, u8 port_num, struct ib_sa_mcmember_rec *rec, - struct ifnet *ndev, + if_t ndev, enum ib_gid_type gid_type, struct ib_ah_attr *ah_attr) { diff --git a/sys/ofed/drivers/infiniband/core/ib_roce_gid_mgmt.c b/sys/ofed/drivers/infiniband/core/ib_roce_gid_mgmt.c index fb19f2944180..1396a4aacf3a 100644 --- a/sys/ofed/drivers/infiniband/core/ib_roce_gid_mgmt.c +++ b/sys/ofed/drivers/infiniband/core/ib_roce_gid_mgmt.c @@ -56,7 +56,7 @@ enum gid_op_type { struct roce_netdev_event_work { struct work_struct work; - struct ifnet *ndev; + if_t ndev; }; struct roce_rescan_work { @@ -91,7 +91,7 @@ unsigned long roce_gid_type_mask_support(struct ib_device *ib_dev, u8 port) EXPORT_SYMBOL(roce_gid_type_mask_support); static void update_gid(enum gid_op_type gid_op, struct ib_device *ib_dev, - u8 port, union ib_gid *gid, struct ifnet *ndev) + u8 port, union ib_gid *gid, if_t ndev) { int i; unsigned long gid_type_mask = roce_gid_type_mask_support(ib_dev, port); @@ -119,9 +119,9 @@ static void update_gid(enum gid_op_type gid_op, struct ib_device *ib_dev, static int roce_gid_match_netdev(struct ib_device *ib_dev, u8 port, - struct ifnet *idev, void *cookie) + if_t idev, void *cookie) { - struct ifnet *ndev = (struct ifnet *)cookie; + if_t ndev = (if_t )cookie; if (idev == NULL) return (0); return (ndev == idev); @@ -129,7 +129,7 @@ roce_gid_match_netdev(struct ib_device *ib_dev, u8 port, static int roce_gid_match_all(struct ib_device *ib_dev, u8 port, - struct ifnet *idev, void *cookie) + if_t idev, void *cookie) { if (idev == NULL) return (0); @@ -138,7 +138,7 @@ roce_gid_match_all(struct ib_device *ib_dev, u8 port, static int roce_gid_enum_netdev_default(struct ib_device *ib_dev, - u8 port, struct ifnet *idev) + u8 port, if_t idev) { unsigned long gid_type_mask; @@ -150,32 +150,81 @@ roce_gid_enum_netdev_default(struct ib_device *ib_dev, return (hweight_long(gid_type_mask)); } +struct ipx_entry { + STAILQ_ENTRY(ipx_entry) entry; + union ipx_addr { + struct sockaddr sa[0]; + struct sockaddr_in v4; + struct sockaddr_in6 v6; + } ipx_addr; + if_t ndev; +}; + +STAILQ_HEAD(ipx_queue, ipx_entry); + +#ifdef INET +static u_int +roce_gid_update_addr_ifa4_cb(void *arg, struct ifaddr *ifa, u_int count) +{ + struct ipx_queue *ipx_head = arg; + struct ipx_entry *entry; + + entry = kzalloc(sizeof(*entry), GFP_ATOMIC); + if (entry == NULL) { + pr_warn("roce_gid_update_addr_callback: " + "couldn't allocate entry for IPv4 update\n"); + return (0); + } + entry->ipx_addr.v4 = *((struct sockaddr_in *)ifa->ifa_addr); + entry->ndev = ifa->ifa_ifp; + STAILQ_INSERT_TAIL(ipx_head, entry, entry); + + return (1); +} +#endif + +#ifdef INET6 +static u_int +roce_gid_update_addr_ifa6_cb(void *arg, struct ifaddr *ifa, u_int count) +{ + struct ipx_queue *ipx_head = arg; + struct ipx_entry *entry; + + entry = kzalloc(sizeof(*entry), GFP_ATOMIC); + if (entry == NULL) { + pr_warn("roce_gid_update_addr_callback: " + "couldn't allocate entry for IPv6 update\n"); + return (0); + } + entry->ipx_addr.v6 = *((struct sockaddr_in6 *)ifa->ifa_addr); + entry->ndev = ifa->ifa_ifp; + + /* trash IPv6 scope ID */ + sa6_recoverscope(&entry->ipx_addr.v6); + entry->ipx_addr.v6.sin6_scope_id = 0; + + STAILQ_INSERT_TAIL(ipx_head, entry, entry); + + return (1); +} +#endif + static void roce_gid_update_addr_callback(struct ib_device *device, u8 port, - struct ifnet *ndev, void *cookie) + if_t ndev, void *cookie) { - struct ipx_entry { - STAILQ_ENTRY(ipx_entry) entry; - union ipx_addr { - struct sockaddr sa[0]; - struct sockaddr_in v4; - struct sockaddr_in6 v6; - } ipx_addr; - struct ifnet *ndev; *** 1566 LINES SKIPPED ***