IB/mlx4: Add strong ordering to local inval and fast reg work requests
authorJack Morgenstein <jackm@dev.mellanox.co.il>
Fri, 5 Jun 2009 17:36:24 +0000 (10:36 -0700)
committerRoland Dreier <rolandd@cisco.com>
Fri, 5 Jun 2009 17:36:24 +0000 (10:36 -0700)
commit2ac6bf4ddc87c3b6b609f8fa82f6ebbffeac12f4
tree7de468eac9f948f85faebb2f86efbfd66737d8d9
parentab6bf42e2339580b5d87746d0ff4da4b1578b03e
IB/mlx4: Add strong ordering to local inval and fast reg work requests

The ConnectX Programmer's Reference Manual states that the "SO" bit
must be set when posting Fast Register and Local Invalidate send work
requests.  When this bit is set, the work request will be executed
only after all previous work requests on the send queue have been
executed.  (If the bit is not set, Fast Register and Local Invalidate
WQEs may begin execution too early, which violates the defined
semantics for these operations)

This fixes the issue with NFS/RDMA reported in
<http://lists.openfabrics.org/pipermail/general/2009-April/059253.html>

Signed-off-by: Jack Morgenstein <jackm@dev.mellanox.co.il>
Cc: <stable@kernel.org>
Signed-off-by: Roland Dreier <rolandd@cisco.com>
drivers/infiniband/hw/mlx4/qp.c
include/linux/mlx4/qp.h