Commit b448bf9a authored by Sebastian Sanchez's avatar Sebastian Sanchez Committed by Doug Ledford

IB/hfi1: Allocate context data on memory node

There are some memory allocation calls in hfi1_create_ctxtdata()
that do not use the numa function parameter. This
can cause cache lines to be filled over QPI.
Reviewed-by: default avatarMike Marciniszyn <mike.marciniszyn@intel.com>
Signed-off-by: default avatarSebastian Sanchez <sebastian.sanchez@intel.com>
Signed-off-by: default avatarDennis Dalessandro <dennis.dalessandro@intel.com>
Signed-off-by: default avatarDoug Ledford <dledford@redhat.com>
parent 338adfdd
...@@ -297,14 +297,15 @@ struct hfi1_ctxtdata *hfi1_create_ctxtdata(struct hfi1_pportdata *ppd, u32 ctxt, ...@@ -297,14 +297,15 @@ struct hfi1_ctxtdata *hfi1_create_ctxtdata(struct hfi1_pportdata *ppd, u32 ctxt,
* The resulting value will be rounded down to the closest * The resulting value will be rounded down to the closest
* multiple of dd->rcv_entries.group_size. * multiple of dd->rcv_entries.group_size.
*/ */
rcd->egrbufs.buffers = kcalloc(rcd->egrbufs.count, rcd->egrbufs.buffers = kzalloc_node(
sizeof(*rcd->egrbufs.buffers), rcd->egrbufs.count * sizeof(*rcd->egrbufs.buffers),
GFP_KERNEL); GFP_KERNEL, numa);
if (!rcd->egrbufs.buffers) if (!rcd->egrbufs.buffers)
goto bail; goto bail;
rcd->egrbufs.rcvtids = kcalloc(rcd->egrbufs.count, rcd->egrbufs.rcvtids = kzalloc_node(
sizeof(*rcd->egrbufs.rcvtids), rcd->egrbufs.count *
GFP_KERNEL); sizeof(*rcd->egrbufs.rcvtids),
GFP_KERNEL, numa);
if (!rcd->egrbufs.rcvtids) if (!rcd->egrbufs.rcvtids)
goto bail; goto bail;
rcd->egrbufs.size = eager_buffer_size; rcd->egrbufs.size = eager_buffer_size;
...@@ -322,8 +323,8 @@ struct hfi1_ctxtdata *hfi1_create_ctxtdata(struct hfi1_pportdata *ppd, u32 ctxt, ...@@ -322,8 +323,8 @@ struct hfi1_ctxtdata *hfi1_create_ctxtdata(struct hfi1_pportdata *ppd, u32 ctxt,
rcd->egrbufs.rcvtid_size = HFI1_MAX_EAGER_BUFFER_SIZE; rcd->egrbufs.rcvtid_size = HFI1_MAX_EAGER_BUFFER_SIZE;
if (ctxt < dd->first_user_ctxt) { /* N/A for PSM contexts */ if (ctxt < dd->first_user_ctxt) { /* N/A for PSM contexts */
rcd->opstats = kzalloc(sizeof(*rcd->opstats), rcd->opstats = kzalloc_node(sizeof(*rcd->opstats),
GFP_KERNEL); GFP_KERNEL, numa);
if (!rcd->opstats) if (!rcd->opstats)
goto bail; goto bail;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment