staging: rdma: hfi1: Do not use | with a variable with value 0
authorJanani Ravichandran <janani.rvchndrn@gmail.com>
Wed, 24 Feb 2016 01:06:12 +0000 (20:06 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 12 Mar 2016 06:09:09 +0000 (22:09 -0800)
mr->lkey has a value equal to 0. There is no need to combine it with
other things with | as for any value x, 0|x is always x.
Semantic patch used:
@@
expression x, e, e1;
statement S;
@@

  if (x == 0) {
    ... when != x = e1
        when != while(...) S
when != for(...;...;...) S
(
* x |= e
|
* x | e
)
  ... when any
}

Signed-off-by: Janani Ravichandran <janani.rvchndrn@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/rdma/hfi1/keys.c

index cb4e6087dfdb263669292140d65da108d825b86e..e34f093a6b555d595dda3d9cd2028f4ed842372e 100644 (file)
@@ -113,7 +113,7 @@ int hfi1_alloc_lkey(struct hfi1_mregion *mr, int dma_region)
                ((((1 << (24 - hfi1_lkey_table_size)) - 1) & rkt->gen)
                 << 8);
        if (mr->lkey == 0) {
-               mr->lkey |= 1 << 8;
+               mr->lkey = 1 << 8;
                rkt->gen++;
        }
        rcu_assign_pointer(rkt->table[r], mr);