From 748b81930aca902ac3e5fca01c2479359f82f120 Mon Sep 17 00:00:00 2001 From: Jason Gunthorpe Date: Fri, 7 Apr 2017 11:30:59 -0600 Subject: [PATCH] vmw_pvrdma: Add sparse annotations Signed-off-by: Jason Gunthorpe Tested-by: Adit Ranadive Acked-by: Adit Ranadive --- CMakeLists.txt | 2 +- providers/vmw_pvrdma/pvrdma.h | 6 +++--- providers/vmw_pvrdma/verbs.c | 7 +------ 3 files changed, 5 insertions(+), 10 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index c2d6618eb..1e9b1a363 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -422,7 +422,7 @@ add_subdirectory(providers/mthca) add_subdirectory(providers/nes) # NO SPARSE add_subdirectory(providers/ocrdma) add_subdirectory(providers/qedr) -add_subdirectory(providers/vmw_pvrdma) # NO SPARSE +add_subdirectory(providers/vmw_pvrdma) endif() add_subdirectory(providers/hfi1verbs) diff --git a/providers/vmw_pvrdma/pvrdma.h b/providers/vmw_pvrdma/pvrdma.h index d4acefced..7840e11ee 100644 --- a/providers/vmw_pvrdma/pvrdma.h +++ b/providers/vmw_pvrdma/pvrdma.h @@ -152,7 +152,7 @@ struct pvrdma_qp { struct pvrdma_buf sbuf; int max_inline_data; int buf_size; - uint32_t sq_signal_bits; + __be32 sq_signal_bits; int sq_spare_wqes; struct pvrdma_wq sq; struct pvrdma_wq rq; @@ -210,12 +210,12 @@ static inline struct pvrdma_ah *to_vah(struct ibv_ah *ibah) static inline void pvrdma_write_uar_qp(void *uar, unsigned value) { - *(uint32_t *)(uar + PVRDMA_UAR_QP_OFFSET) = htole32(value); + *(__le32 *)(uar + PVRDMA_UAR_QP_OFFSET) = htole32(value); } static inline void pvrdma_write_uar_cq(void *uar, unsigned value) { - *(uint32_t *)(uar + PVRDMA_UAR_CQ_OFFSET) = htole32(value); + *(__le32 *)(uar + PVRDMA_UAR_CQ_OFFSET) = htole32(value); } static inline int ibv_send_flags_to_pvrdma(int flags) diff --git a/providers/vmw_pvrdma/verbs.c b/providers/vmw_pvrdma/verbs.c index 0a07748da..1bb163486 100644 --- a/providers/vmw_pvrdma/verbs.c +++ b/providers/vmw_pvrdma/verbs.c @@ -154,12 +154,7 @@ static int is_multicast_gid(const union ibv_gid *gid) static int is_link_local_gid(const union ibv_gid *gid) { - uint32_t *hi = (uint32_t *)(gid->raw); - uint32_t *lo = (uint32_t *)(gid->raw + 4); - if (hi[0] == htobe32(0xfe800000) && lo[0] == 0) - return 1; - - return 0; + return gid->global.subnet_prefix == htobe64(0xfe80000000000000ULL); } static int is_ipv6_addr_v4mapped(const struct in6_addr *a)