mem: fix allocation failure on non-NUMA kernel
Running dpdk-helloworld on Linux with lib numa present, but no kernel support for NUMA (CONFIG_NUMA=n) causes rte_service_init() to fail with EAL: error allocating rte services array. alloc_seg() calls get_mempolicy to verify that the allocation has happened on the correct socket, but receives ENOSYS from the kernel and fails the allocation. The allocated socket should only be verified if check_numa() is true. Fixes: 2a96c88be83e ("mem: ease init in a docker container") Cc: stable@dpdk.org Signed-off-by: Nick Connolly <nick.connolly@mayadata.io> Reviewed-by: Nicolas Dichtel <nicolas.dichtel@6wind.com> Acked-by: Anatoly Burakov <anatoly.burakov@intel.com>
This commit is contained in:
parent
7cf3d07c3a
commit
9d42642e86
@ -625,6 +625,13 @@ alloc_seg(struct rte_memseg *ms, void *addr, int socket_id,
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef RTE_EAL_NUMA_AWARE_HUGEPAGES
|
#ifdef RTE_EAL_NUMA_AWARE_HUGEPAGES
|
||||||
|
/*
|
||||||
|
* If the kernel has been built without NUMA support, get_mempolicy()
|
||||||
|
* will return an error. If check_numa() returns false, memory
|
||||||
|
* allocation is not NUMA aware and the socket_id should not be
|
||||||
|
* checked.
|
||||||
|
*/
|
||||||
|
if (check_numa()) {
|
||||||
ret = get_mempolicy(&cur_socket_id, NULL, 0, addr,
|
ret = get_mempolicy(&cur_socket_id, NULL, 0, addr,
|
||||||
MPOL_F_NODE | MPOL_F_ADDR);
|
MPOL_F_NODE | MPOL_F_ADDR);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
@ -637,6 +644,7 @@ alloc_seg(struct rte_memseg *ms, void *addr, int socket_id,
|
|||||||
__func__, socket_id, cur_socket_id);
|
__func__, socket_id, cur_socket_id);
|
||||||
goto mapped;
|
goto mapped;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
#else
|
#else
|
||||||
if (rte_socket_count() > 1)
|
if (rte_socket_count() > 1)
|
||||||
RTE_LOG(DEBUG, EAL, "%s(): not checking hugepage NUMA node.\n",
|
RTE_LOG(DEBUG, EAL, "%s(): not checking hugepage NUMA node.\n",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user