[openib-general] [RFC] [PATCH] ib_cache: do not mask upper bit when searching for a pkey
Sean Hefty
sean.hefty at intel.com
Mon Feb 26 12:17:30 PST 2007
I think the following patch would make ipoib spec compliant.
ib_find_cached_pkey is called by ib_cm, rdma_cm, ib_srp, and ib_ipoib.
I'm not certain what this change would do to SRP, but the ib_cm and
rdma_cm look okay, given that non-reversible paths aren't supported
yet anyway.
--
ib_find_cached_pkey masks off the upper-bit of the PKey when searching
for a match. The upper bit indicates partial or full membership. Ignoring
the upper bit can result in a full membership PKey matching with a partial
membership PKey. For ipoib, this can result in joining a multicast group
that disallows communication between all members.
Signed-off-by: Sean Hefty <sean.hefty at intel.com>
---
drivers/infiniband/core/cache.c | 2 +-
1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/drivers/infiniband/core/cache.c b/drivers/infiniband/core/cache.c
index 558c9a0..6f366c3 100644
--- a/drivers/infiniband/core/cache.c
+++ b/drivers/infiniband/core/cache.c
@@ -179,7 +179,7 @@ int ib_find_cached_pkey(struct ib_device *device,
*index = -1;
for (i = 0; i < cache->table_len; ++i)
- if ((cache->table[i] & 0x7fff) == (pkey & 0x7fff)) {
+ if (cache->table[i] == pkey) {
*index = i;
ret = 0;
break;
--
1.4.4.3
More information about the general
mailing list