diff options
author | Kaike Wan <kaike.wan@intel.com> | 2015-10-30 13:23:45 +0100 |
---|---|---|
committer | Doug Ledford <dledford@redhat.com> | 2015-12-07 22:43:01 +0100 |
commit | 3ebd2fd0d0119a5ac7906bf17be637b527f63d31 (patch) | |
tree | 518ee72b3460856c4eef08f6cf19d46d860b1d1c /lib/crc16.c | |
parent | IB/iser: use sector_div instead of do_div (diff) | |
download | linux-3ebd2fd0d0119a5ac7906bf17be637b527f63d31.tar.xz linux-3ebd2fd0d0119a5ac7906bf17be637b527f63d31.zip |
IB/sa: Put netlink request into the request list before sending
It was found by Saurabh Sengar that the netlink code tried to allocate
memory with GFP_KERNEL while holding a spinlock. While it is possible
to fix the issue by replacing GFP_KERNEL with GFP_ATOMIC, it is better
to get rid of the spinlock while sending the packet. However, in order
to protect against a race condition that a quick response may be received
before the request is put on the request list, we need to put the request
on the list first.
Signed-off-by: Kaike Wan <kaike.wan@intel.com>
Reviewed-by: Jason Gunthorpe <jgunthorpe@obsidianresearch.com>
Reviewed-by: Ira Weiny <ira.weiny@intel.com>
Reported-by: Saurabh Sengar <saurabh.truth@gmail.com>
Signed-off-by: Doug Ledford <dledford@redhat.com>
Diffstat (limited to 'lib/crc16.c')
0 files changed, 0 insertions, 0 deletions