[RFC PATCH 07/44] eal: move hugepage size info to platform info struct
Bruce Richardson
bruce.richardson at intel.com
Wed Apr 29 18:57:59 CEST 2026
The hugepage information should not change for the lifetime of the
process, so store it in the platform_info structure in EAL, moving it
out of the internal_config.
Signed-off-by: Bruce Richardson <bruce.richardson at intel.com>
---
lib/eal/common/eal_common_dynmem.c | 29 ++++++-------
lib/eal/common/eal_common_options.c | 7 +--
lib/eal/common/eal_internal_cfg.h | 5 +--
lib/eal/freebsd/eal.c | 7 ++-
lib/eal/freebsd/eal_hugepage_info.c | 28 ++++++------
lib/eal/freebsd/eal_memory.c | 21 ++++-----
lib/eal/linux/eal.c | 12 +++---
lib/eal/linux/eal_hugepage_info.c | 37 ++++++++--------
lib/eal/linux/eal_memalloc.c | 27 ++++++------
lib/eal/linux/eal_memory.c | 66 +++++++++++++----------------
lib/eal/windows/eal_hugepages.c | 7 ++-
lib/eal/windows/eal_memalloc.c | 26 ++++++------
12 files changed, 122 insertions(+), 150 deletions(-)
diff --git a/lib/eal/common/eal_common_dynmem.c b/lib/eal/common/eal_common_dynmem.c
index 73a55794e0..c1c72499c4 100644
--- a/lib/eal/common/eal_common_dynmem.c
+++ b/lib/eal/common/eal_common_dynmem.c
@@ -30,8 +30,7 @@ eal_dynmem_memseg_lists_init(void)
uint64_t max_mem, max_mem_per_type;
unsigned int max_seglists_per_type;
unsigned int n_memtypes, cur_type;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
const struct eal_user_cfg *user_cfg = eal_get_user_configuration();
/* no-huge does not need this at all */
@@ -74,7 +73,7 @@ eal_dynmem_memseg_lists_init(void)
*/
/* create space for mem types */
- n_memtypes = internal_conf->num_hugepage_sizes * rte_socket_count();
+ n_memtypes = platform_info->num_hugepage_sizes * rte_socket_count();
memtypes = calloc(n_memtypes, sizeof(*memtypes));
if (memtypes == NULL) {
EAL_LOG(ERR, "Cannot allocate space for memory types");
@@ -83,12 +82,12 @@ eal_dynmem_memseg_lists_init(void)
/* populate mem types */
cur_type = 0;
- for (hpi_idx = 0; hpi_idx < (int) internal_conf->num_hugepage_sizes;
+ for (hpi_idx = 0; hpi_idx < (int) platform_info->num_hugepage_sizes;
hpi_idx++) {
struct hugepage_info *hpi;
uint64_t hugepage_sz;
- hpi = &internal_conf->hugepage_info[hpi_idx];
+ hpi = &platform_info->hugepage_info[hpi_idx];
hugepage_sz = hpi->hugepage_sz;
for (i = 0; i < (int) rte_socket_count(); i++, cur_type++) {
@@ -229,14 +228,13 @@ eal_dynmem_hugepage_init(void)
struct hugepage_info used_hp[MAX_HUGEPAGE_SIZES];
uint64_t memory[RTE_MAX_NUMA_NODES];
int hp_sz_idx, socket_id;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
const struct eal_user_cfg *user_cfg = eal_get_user_configuration();
memset(used_hp, 0, sizeof(used_hp));
for (hp_sz_idx = 0;
- hp_sz_idx < (int) internal_conf->num_hugepage_sizes;
+ hp_sz_idx < (int) platform_info->num_hugepage_sizes;
hp_sz_idx++) {
#ifndef RTE_ARCH_64
struct hugepage_info dummy;
@@ -244,7 +242,7 @@ eal_dynmem_hugepage_init(void)
#endif
/* also initialize used_hp hugepage sizes in used_hp */
struct hugepage_info *hpi;
- hpi = &internal_conf->hugepage_info[hp_sz_idx];
+ hpi = &platform_info->hugepage_info[hp_sz_idx];
used_hp[hp_sz_idx].hugepage_sz = hpi->hugepage_sz;
#ifndef RTE_ARCH_64
@@ -272,12 +270,12 @@ eal_dynmem_hugepage_init(void)
/* calculate final number of pages */
if (eal_dynmem_calc_num_pages_per_socket(memory,
- internal_conf->hugepage_info, used_hp,
- internal_conf->num_hugepage_sizes) < 0)
+ platform_info->hugepage_info, used_hp,
+ platform_info->num_hugepage_sizes) < 0)
return -1;
for (hp_sz_idx = 0;
- hp_sz_idx < (int)internal_conf->num_hugepage_sizes;
+ hp_sz_idx < (int)platform_info->num_hugepage_sizes;
hp_sz_idx++) {
for (socket_id = 0; socket_id < RTE_MAX_NUMA_NODES;
socket_id++) {
@@ -356,11 +354,10 @@ get_socket_mem_size(int socket)
{
uint64_t size = 0;
unsigned int i;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
- for (i = 0; i < internal_conf->num_hugepage_sizes; i++) {
- struct hugepage_info *hpi = &internal_conf->hugepage_info[i];
+ for (i = 0; i < platform_info->num_hugepage_sizes; i++) {
+ struct hugepage_info *hpi = &platform_info->hugepage_info[i];
size += hpi->hugepage_sz * hpi->num_pages[socket];
}
diff --git a/lib/eal/common/eal_common_options.c b/lib/eal/common/eal_common_options.c
index a2f305fc68..0750a52373 100644
--- a/lib/eal/common/eal_common_options.c
+++ b/lib/eal/common/eal_common_options.c
@@ -494,6 +494,7 @@ void
eal_reset_internal_config(struct internal_config *internal_cfg)
{
struct eal_user_cfg *user_cfg = eal_get_user_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
int i;
user_cfg->memory = 0;
@@ -514,9 +515,9 @@ eal_reset_internal_config(struct internal_config *internal_cfg)
user_cfg->hugepage_file.unlink_existing = true;
/* zero out hugedir descriptors */
for (i = 0; i < MAX_HUGEPAGE_SIZES; i++) {
- memset(&internal_cfg->hugepage_info[i], 0,
- sizeof(internal_cfg->hugepage_info[0]));
- internal_cfg->hugepage_info[i].lock_descriptor = -1;
+ memset(&platform_info->hugepage_info[i], 0,
+ sizeof(platform_info->hugepage_info[0]));
+ platform_info->hugepage_info[i].lock_descriptor = -1;
}
user_cfg->base_virtaddr = 0;
diff --git a/lib/eal/common/eal_internal_cfg.h b/lib/eal/common/eal_internal_cfg.h
index 3aec3b0020..fbbe5dce82 100644
--- a/lib/eal/common/eal_internal_cfg.h
+++ b/lib/eal/common/eal_internal_cfg.h
@@ -92,7 +92,8 @@ struct eal_user_cfg {
* Immutable after initialization, so no need for atomic types or locks.
*/
struct eal_platform_info {
- uint8_t reserved;
+ uint8_t num_hugepage_sizes; /**< how many sizes on this system */
+ struct hugepage_info hugepage_info[MAX_HUGEPAGE_SIZES];
};
/**
@@ -108,8 +109,6 @@ struct eal_runtime_state {
* internal configuration
*/
struct internal_config {
- unsigned num_hugepage_sizes; /**< how many sizes on this system */
- struct hugepage_info hugepage_info[MAX_HUGEPAGE_SIZES];
rte_cpuset_t ctrl_cpuset; /**< cpuset for ctrl threads */
volatile unsigned int init_complete;
/**< indicates whether EAL has completed initialization */
diff --git a/lib/eal/freebsd/eal.c b/lib/eal/freebsd/eal.c
index 7e00010771..996a2de9ff 100644
--- a/lib/eal/freebsd/eal.c
+++ b/lib/eal/freebsd/eal.c
@@ -329,11 +329,10 @@ eal_get_hugepage_mem_size(void)
{
uint64_t size = 0;
unsigned i, j;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
- for (i = 0; i < internal_conf->num_hugepage_sizes; i++) {
- struct hugepage_info *hpi = &internal_conf->hugepage_info[i];
+ for (i = 0; i < platform_info->num_hugepage_sizes; i++) {
+ struct hugepage_info *hpi = &platform_info->hugepage_info[i];
if (strnlen(hpi->hugedir, sizeof(hpi->hugedir)) != 0) {
for (j = 0; j < RTE_MAX_NUMA_NODES; j++) {
size += hpi->hugepage_sz * hpi->num_pages[j];
diff --git a/lib/eal/freebsd/eal_hugepage_info.c b/lib/eal/freebsd/eal_hugepage_info.c
index 586c5d9f17..b46ae4b689 100644
--- a/lib/eal/freebsd/eal_hugepage_info.c
+++ b/lib/eal/freebsd/eal_hugepage_info.c
@@ -57,16 +57,15 @@ eal_hugepage_info_init(void)
size_t sysctl_size;
int num_buffers, fd, error;
int64_t buffer_size;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
/* re-use the linux "internal config" structure for our memory data */
- struct hugepage_info *hpi = &internal_conf->hugepage_info[0];
+ struct hugepage_info *hpi = &platform_info->hugepage_info[0];
const struct eal_user_cfg *user_cfg = eal_get_user_configuration();
struct hugepage_info *tmp_hpi;
unsigned int i;
- internal_conf->num_hugepage_sizes = 1;
+ platform_info->num_hugepage_sizes = 1;
sysctl_size = sizeof(num_buffers);
error = sysctlbyname("hw.contigmem.num_buffers", &num_buffers,
@@ -116,23 +115,23 @@ eal_hugepage_info_init(void)
return 0;
tmp_hpi = create_shared_memory(eal_hugepage_info_path(),
- sizeof(internal_conf->hugepage_info));
+ sizeof(platform_info->hugepage_info));
if (tmp_hpi == NULL ) {
EAL_LOG(ERR, "Failed to create shared memory!");
return -1;
}
- memcpy(tmp_hpi, hpi, sizeof(internal_conf->hugepage_info));
+ memcpy(tmp_hpi, hpi, sizeof(platform_info->hugepage_info));
/* we've copied file descriptors along with everything else, but they
* will be invalid in secondary process, so overwrite them
*/
- for (i = 0; i < RTE_DIM(internal_conf->hugepage_info); i++) {
+ for (i = 0; i < RTE_DIM(platform_info->hugepage_info); i++) {
struct hugepage_info *tmp = &tmp_hpi[i];
tmp->lock_descriptor = -1;
}
- if (munmap(tmp_hpi, sizeof(internal_conf->hugepage_info)) < 0) {
+ if (munmap(tmp_hpi, sizeof(platform_info->hugepage_info)) < 0) {
EAL_LOG(ERR, "Failed to unmap shared memory!");
return -1;
}
@@ -144,24 +143,23 @@ eal_hugepage_info_init(void)
int
eal_hugepage_info_read(void)
{
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
- struct hugepage_info *hpi = &internal_conf->hugepage_info[0];
+ struct hugepage_info *hpi = &platform_info->hugepage_info[0];
struct hugepage_info *tmp_hpi;
- internal_conf->num_hugepage_sizes = 1;
+ platform_info->num_hugepage_sizes = 1;
tmp_hpi = open_shared_memory(eal_hugepage_info_path(),
- sizeof(internal_conf->hugepage_info));
+ sizeof(platform_info->hugepage_info));
if (tmp_hpi == NULL) {
EAL_LOG(ERR, "Failed to open shared memory!");
return -1;
}
- memcpy(hpi, tmp_hpi, sizeof(internal_conf->hugepage_info));
+ memcpy(hpi, tmp_hpi, sizeof(platform_info->hugepage_info));
- if (munmap(tmp_hpi, sizeof(internal_conf->hugepage_info)) < 0) {
+ if (munmap(tmp_hpi, sizeof(platform_info->hugepage_info)) < 0) {
EAL_LOG(ERR, "Failed to unmap shared memory!");
return -1;
}
diff --git a/lib/eal/freebsd/eal_memory.c b/lib/eal/freebsd/eal_memory.c
index cfb17fb3fa..e925fa9743 100644
--- a/lib/eal/freebsd/eal_memory.c
+++ b/lib/eal/freebsd/eal_memory.c
@@ -59,9 +59,8 @@ rte_eal_hugepage_init(void)
uint64_t total_mem = 0;
void *addr;
unsigned int i, j, seg_idx = 0;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
const struct eal_user_cfg *user_cfg = eal_get_user_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
/* get pointer to global configuration */
mcfg = rte_eal_get_configuration()->mem_config;
@@ -101,13 +100,13 @@ rte_eal_hugepage_init(void)
}
/* map all hugepages and sort them */
- for (i = 0; i < internal_conf->num_hugepage_sizes; i++) {
+ for (i = 0; i < platform_info->num_hugepage_sizes; i++) {
struct hugepage_info *hpi;
rte_iova_t prev_end = 0;
uint64_t page_sz, mem_needed;
unsigned int n_pages, max_pages;
- hpi = &internal_conf->hugepage_info[i];
+ hpi = &platform_info->hugepage_info[i];
page_sz = hpi->hugepage_sz;
max_pages = hpi->num_pages[0];
mem_needed = RTE_ALIGN_CEIL(user_cfg->memory - total_mem,
@@ -270,15 +269,14 @@ attach_segment(const struct rte_memseg_list *msl, const struct rte_memseg *ms,
int
rte_eal_hugepage_attach(void)
{
+ struct eal_platform_info *platform_info = eal_get_platform_info();
struct hugepage_info *hpi;
int fd_hugepage = -1;
unsigned int i;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
- hpi = &internal_conf->hugepage_info[0];
+ hpi = &platform_info->hugepage_info[0];
- for (i = 0; i < internal_conf->num_hugepage_sizes; i++) {
+ for (i = 0; i < platform_info->num_hugepage_sizes; i++) {
const struct hugepage_info *cur_hpi = &hpi[i];
struct attach_walk_args wa;
@@ -356,9 +354,8 @@ memseg_primary_init(void)
int hpi_idx, msl_idx = 0;
struct rte_memseg_list *msl;
uint64_t max_mem, total_mem;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
const struct eal_user_cfg *user_cfg = eal_get_user_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
/* no-huge does not need this at all */
if (user_cfg->no_hugetlbfs)
@@ -378,7 +375,7 @@ memseg_primary_init(void)
total_mem = 0;
/* create memseg lists */
- for (hpi_idx = 0; hpi_idx < (int) internal_conf->num_hugepage_sizes;
+ for (hpi_idx = 0; hpi_idx < (int) platform_info->num_hugepage_sizes;
hpi_idx++) {
uint64_t max_type_mem, total_type_mem = 0;
uint64_t avail_mem;
@@ -386,7 +383,7 @@ memseg_primary_init(void)
struct hugepage_info *hpi;
uint64_t hugepage_sz;
- hpi = &internal_conf->hugepage_info[hpi_idx];
+ hpi = &platform_info->hugepage_info[hpi_idx];
hugepage_sz = hpi->hugepage_sz;
/* no NUMA support on FreeBSD */
diff --git a/lib/eal/linux/eal.c b/lib/eal/linux/eal.c
index 4b33e461fd..f692521fe7 100644
--- a/lib/eal/linux/eal.c
+++ b/lib/eal/linux/eal.c
@@ -412,20 +412,18 @@ rte_config_init(void)
static void
eal_hugedirs_unlock(void)
{
+ struct eal_platform_info *platform_info = eal_get_platform_info();
int i;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
-
for (i = 0; i < MAX_HUGEPAGE_SIZES; i++)
{
/* skip uninitialized */
- if (internal_conf->hugepage_info[i].lock_descriptor < 0)
+ if (platform_info->hugepage_info[i].lock_descriptor < 0)
continue;
/* unlock hugepage file */
- flock(internal_conf->hugepage_info[i].lock_descriptor, LOCK_UN);
- close(internal_conf->hugepage_info[i].lock_descriptor);
+ flock(platform_info->hugepage_info[i].lock_descriptor, LOCK_UN);
+ close(platform_info->hugepage_info[i].lock_descriptor);
/* reset the field */
- internal_conf->hugepage_info[i].lock_descriptor = -1;
+ platform_info->hugepage_info[i].lock_descriptor = -1;
}
}
diff --git a/lib/eal/linux/eal_hugepage_info.c b/lib/eal/linux/eal_hugepage_info.c
index 74c55327ff..f35446cdc9 100644
--- a/lib/eal/linux/eal_hugepage_info.c
+++ b/lib/eal/linux/eal_hugepage_info.c
@@ -453,8 +453,7 @@ hugepage_info_init(void)
unsigned int reusable_pages;
DIR *dir;
struct dirent *dirent;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
const struct eal_user_cfg *user_cfg = eal_get_user_configuration();
dir = opendir(sys_dir_path);
@@ -475,7 +474,7 @@ hugepage_info_init(void)
if (num_sizes >= MAX_HUGEPAGE_SIZES)
break;
- hpi = &internal_conf->hugepage_info[num_sizes];
+ hpi = &platform_info->hugepage_info[num_sizes];
hpi->hugepage_sz =
rte_str_to_size(&dirent->d_name[dirent_start_len]);
@@ -546,17 +545,17 @@ hugepage_info_init(void)
if (dirent != NULL)
return -1;
- internal_conf->num_hugepage_sizes = num_sizes;
+ platform_info->num_hugepage_sizes = num_sizes;
/* sort the page directory entries by size, largest to smallest */
- qsort(&internal_conf->hugepage_info[0], num_sizes,
- sizeof(internal_conf->hugepage_info[0]), compare_hpi);
+ qsort(&platform_info->hugepage_info[0], num_sizes,
+ sizeof(platform_info->hugepage_info[0]), compare_hpi);
/* now we have all info, check we have at least one valid size */
for (i = 0; i < num_sizes; i++) {
/* pages may no longer all be on socket 0, so check all */
unsigned int j, num_pages = 0;
- struct hugepage_info *hpi = &internal_conf->hugepage_info[i];
+ struct hugepage_info *hpi = &platform_info->hugepage_info[i];
for (j = 0; j < RTE_MAX_NUMA_NODES; j++)
num_pages += hpi->num_pages[j];
@@ -578,8 +577,7 @@ eal_hugepage_info_init(void)
{
struct hugepage_info *hpi, *tmp_hpi;
unsigned int i;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
const struct eal_user_cfg *user_cfg = eal_get_user_configuration();
if (hugepage_info_init() < 0)
@@ -589,26 +587,26 @@ eal_hugepage_info_init(void)
if (user_cfg->no_shconf)
return 0;
- hpi = &internal_conf->hugepage_info[0];
+ hpi = &platform_info->hugepage_info[0];
tmp_hpi = create_shared_memory(eal_hugepage_info_path(),
- sizeof(internal_conf->hugepage_info));
+ sizeof(platform_info->hugepage_info));
if (tmp_hpi == NULL) {
EAL_LOG(ERR, "Failed to create shared memory!");
return -1;
}
- memcpy(tmp_hpi, hpi, sizeof(internal_conf->hugepage_info));
+ memcpy(tmp_hpi, hpi, sizeof(platform_info->hugepage_info));
/* we've copied file descriptors along with everything else, but they
* will be invalid in secondary process, so overwrite them
*/
- for (i = 0; i < RTE_DIM(internal_conf->hugepage_info); i++) {
+ for (i = 0; i < RTE_DIM(platform_info->hugepage_info); i++) {
struct hugepage_info *tmp = &tmp_hpi[i];
tmp->lock_descriptor = -1;
}
- if (munmap(tmp_hpi, sizeof(internal_conf->hugepage_info)) < 0) {
+ if (munmap(tmp_hpi, sizeof(platform_info->hugepage_info)) < 0) {
EAL_LOG(ERR, "Failed to unmap shared memory!");
return -1;
}
@@ -617,21 +615,20 @@ eal_hugepage_info_init(void)
int eal_hugepage_info_read(void)
{
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
- struct hugepage_info *hpi = &internal_conf->hugepage_info[0];
+ struct eal_platform_info *platform_info = eal_get_platform_info();
+ struct hugepage_info *hpi = &platform_info->hugepage_info[0];
struct hugepage_info *tmp_hpi;
tmp_hpi = open_shared_memory(eal_hugepage_info_path(),
- sizeof(internal_conf->hugepage_info));
+ sizeof(platform_info->hugepage_info));
if (tmp_hpi == NULL) {
EAL_LOG(ERR, "Failed to open shared memory!");
return -1;
}
- memcpy(hpi, tmp_hpi, sizeof(internal_conf->hugepage_info));
+ memcpy(hpi, tmp_hpi, sizeof(platform_info->hugepage_info));
- if (munmap(tmp_hpi, sizeof(internal_conf->hugepage_info)) < 0) {
+ if (munmap(tmp_hpi, sizeof(platform_info->hugepage_info)) < 0) {
EAL_LOG(ERR, "Failed to unmap shared memory!");
return -1;
}
diff --git a/lib/eal/linux/eal_memalloc.c b/lib/eal/linux/eal_memalloc.c
index 7121f933ea..5ae81429d9 100644
--- a/lib/eal/linux/eal_memalloc.c
+++ b/lib/eal/linux/eal_memalloc.c
@@ -964,9 +964,8 @@ eal_memalloc_alloc_seg_bulk(struct rte_memseg **ms, int n_segs, size_t page_sz,
#endif
struct alloc_walk_param wa;
struct hugepage_info *hi = NULL;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
const struct eal_user_cfg *user_cfg = eal_get_user_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
memset(&wa, 0, sizeof(wa));
@@ -974,10 +973,10 @@ eal_memalloc_alloc_seg_bulk(struct rte_memseg **ms, int n_segs, size_t page_sz,
if (user_cfg->legacy_mem)
return -1;
- for (i = 0; i < (int) RTE_DIM(internal_conf->hugepage_info); i++) {
+ for (i = 0; i < (int) RTE_DIM(platform_info->hugepage_info); i++) {
if (page_sz ==
- internal_conf->hugepage_info[i].hugepage_sz) {
- hi = &internal_conf->hugepage_info[i];
+ platform_info->hugepage_info[i].hugepage_sz) {
+ hi = &platform_info->hugepage_info[i];
break;
}
}
@@ -1034,9 +1033,8 @@ int
eal_memalloc_free_seg_bulk(struct rte_memseg **ms, int n_segs)
{
int seg, ret = 0;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
const struct eal_user_cfg *user_cfg = eal_get_user_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
/* dynamic free not supported in legacy mode */
if (user_cfg->legacy_mem)
@@ -1057,13 +1055,13 @@ eal_memalloc_free_seg_bulk(struct rte_memseg **ms, int n_segs)
memset(&wa, 0, sizeof(wa));
- for (i = 0; i < (int)RTE_DIM(internal_conf->hugepage_info);
+ for (i = 0; i < (int)RTE_DIM(platform_info->hugepage_info);
i++) {
- hi = &internal_conf->hugepage_info[i];
+ hi = &platform_info->hugepage_info[i];
if (cur->hugepage_sz == hi->hugepage_sz)
break;
}
- if (i == (int)RTE_DIM(internal_conf->hugepage_info)) {
+ if (i == (int)RTE_DIM(platform_info->hugepage_info)) {
EAL_LOG(ERR, "Can't find relevant hugepage_info entry");
ret = -1;
continue;
@@ -1327,11 +1325,10 @@ sync_walk(const struct rte_memseg_list *msl, void *arg __rte_unused)
{
struct rte_mem_config *mcfg = rte_eal_get_configuration()->mem_config;
struct rte_memseg_list *primary_msl, *local_msl;
+ struct eal_platform_info *platform_info = eal_get_platform_info();
struct hugepage_info *hi = NULL;
unsigned int i;
int msl_idx;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
if (msl->external)
return 0;
@@ -1340,12 +1337,12 @@ sync_walk(const struct rte_memseg_list *msl, void *arg __rte_unused)
primary_msl = &mcfg->memsegs[msl_idx];
local_msl = &local_memsegs[msl_idx];
- for (i = 0; i < RTE_DIM(internal_conf->hugepage_info); i++) {
+ for (i = 0; i < RTE_DIM(platform_info->hugepage_info); i++) {
uint64_t cur_sz =
- internal_conf->hugepage_info[i].hugepage_sz;
+ platform_info->hugepage_info[i].hugepage_sz;
uint64_t msl_sz = primary_msl->page_sz;
if (msl_sz == cur_sz) {
- hi = &internal_conf->hugepage_info[i];
+ hi = &platform_info->hugepage_info[i];
break;
}
}
diff --git a/lib/eal/linux/eal_memory.c b/lib/eal/linux/eal_memory.c
index 69314656c2..36763bb44f 100644
--- a/lib/eal/linux/eal_memory.c
+++ b/lib/eal/linux/eal_memory.c
@@ -598,14 +598,13 @@ unlink_hugepage_files(struct hugepage_file *hugepg_tbl,
{
unsigned socket, size;
int page, nrpages = 0;
- const struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ const struct eal_platform_info *platform_info = eal_get_platform_info();
/* get total number of hugepages */
for (size = 0; size < num_hp_info; size++)
for (socket = 0; socket < RTE_MAX_NUMA_NODES; socket++)
nrpages +=
- internal_conf->hugepage_info[size].num_pages[socket];
+ platform_info->hugepage_info[size].num_pages[socket];
for (page = 0; page < nrpages; page++) {
struct hugepage_file *hp = &hugepg_tbl[page];
@@ -629,13 +628,12 @@ unmap_unneeded_hugepages(struct hugepage_file *hugepg_tbl,
{
unsigned socket, size;
int page, nrpages = 0;
- const struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ const struct eal_platform_info *platform_info = eal_get_platform_info();
/* get total number of hugepages */
for (size = 0; size < num_hp_info; size++)
for (socket = 0; socket < RTE_MAX_NUMA_NODES; socket++)
- nrpages += internal_conf->hugepage_info[size].num_pages[socket];
+ nrpages += platform_info->hugepage_info[size].num_pages[socket];
for (size = 0; size < num_hp_info; size++) {
for (socket = 0; socket < RTE_MAX_NUMA_NODES; socket++) {
@@ -691,8 +689,6 @@ remap_segment(struct hugepage_file *hugepages, int seg_start, int seg_end)
size_t memseg_len;
int socket_id;
#ifndef RTE_ARCH_64
- const struct internal_config *internal_conf =
- eal_get_internal_configuration();
#endif
page_sz = hugepages[seg_start].size;
socket_id = hugepages[seg_start].socket_id;
@@ -859,13 +855,12 @@ memseg_list_free(struct rte_memseg_list *msl)
static int __rte_unused
prealloc_segments(struct hugepage_file *hugepages, int n_pages)
{
+ const struct eal_platform_info *platform_info = eal_get_platform_info();
struct rte_mem_config *mcfg = rte_eal_get_configuration()->mem_config;
int cur_page, seg_start_page, end_seg, new_memseg;
unsigned int hpi_idx, socket, i;
int n_contig_segs, n_segs;
int msl_idx;
- const struct internal_config *internal_conf =
- eal_get_internal_configuration();
/* before we preallocate segments, we need to free up our VA space.
* we're not removing files, and we already have information about
@@ -880,10 +875,10 @@ prealloc_segments(struct hugepage_file *hugepages, int n_pages)
/* we cannot know how many page sizes and sockets we have discovered, so
* loop over all of them
*/
- for (hpi_idx = 0; hpi_idx < internal_conf->num_hugepage_sizes;
+ for (hpi_idx = 0; hpi_idx < platform_info->num_hugepage_sizes;
hpi_idx++) {
uint64_t page_sz =
- internal_conf->hugepage_info[hpi_idx].hugepage_sz;
+ platform_info->hugepage_info[hpi_idx].hugepage_sz;
for (i = 0; i < rte_socket_count(); i++) {
struct rte_memseg_list *msl;
@@ -1088,11 +1083,10 @@ eal_get_hugepage_mem_size(void)
{
uint64_t size = 0;
unsigned i, j;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
- for (i = 0; i < internal_conf->num_hugepage_sizes; i++) {
- struct hugepage_info *hpi = &internal_conf->hugepage_info[i];
+ for (i = 0; i < platform_info->num_hugepage_sizes; i++) {
+ struct hugepage_info *hpi = &platform_info->hugepage_info[i];
if (strnlen(hpi->hugedir, sizeof(hpi->hugedir)) != 0) {
for (j = 0; j < RTE_MAX_NUMA_NODES; j++) {
size += hpi->hugepage_sz * hpi->num_pages[j];
@@ -1147,8 +1141,7 @@ eal_legacy_hugepage_init(void)
struct rte_mem_config *mcfg;
struct hugepage_file *hugepage = NULL, *tmp_hp = NULL;
struct hugepage_info used_hp[MAX_HUGEPAGE_SIZES];
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
struct eal_user_cfg *user_cfg = eal_get_user_configuration();
uint64_t memory[RTE_MAX_NUMA_NODES];
@@ -1265,11 +1258,11 @@ eal_legacy_hugepage_init(void)
/* calculate total number of hugepages available. at this point we haven't
* yet started sorting them so they all are on socket 0 */
- for (i = 0; i < (int) internal_conf->num_hugepage_sizes; i++) {
+ for (i = 0; i < (int) platform_info->num_hugepage_sizes; i++) {
/* meanwhile, also initialize used_hp hugepage sizes in used_hp */
- used_hp[i].hugepage_sz = internal_conf->hugepage_info[i].hugepage_sz;
+ used_hp[i].hugepage_sz = platform_info->hugepage_info[i].hugepage_sz;
- nr_hugepages += internal_conf->hugepage_info[i].num_pages[0];
+ nr_hugepages += platform_info->hugepage_info[i].num_pages[0];
}
/*
@@ -1293,7 +1286,7 @@ eal_legacy_hugepage_init(void)
memory[i] = user_cfg->numa_mem[i];
/* map all hugepages and sort them */
- for (i = 0; i < (int)internal_conf->num_hugepage_sizes; i++) {
+ for (i = 0; i < (int)platform_info->num_hugepage_sizes; i++) {
unsigned pages_old, pages_new;
struct hugepage_info *hpi;
@@ -1302,7 +1295,7 @@ eal_legacy_hugepage_init(void)
* we just map all hugepages available to the system
* all hugepages are still located on socket 0
*/
- hpi = &internal_conf->hugepage_info[i];
+ hpi = &platform_info->hugepage_info[i];
if (hpi->num_pages[0] == 0)
continue;
@@ -1365,9 +1358,9 @@ eal_legacy_hugepage_init(void)
/* clean out the numbers of pages */
- for (i = 0; i < (int) internal_conf->num_hugepage_sizes; i++)
+ for (i = 0; i < (int) platform_info->num_hugepage_sizes; i++)
for (j = 0; j < RTE_MAX_NUMA_NODES; j++)
- internal_conf->hugepage_info[i].num_pages[j] = 0;
+ platform_info->hugepage_info[i].num_pages[j] = 0;
/* get hugepages for each socket */
for (i = 0; i < nr_hugefiles; i++) {
@@ -1375,11 +1368,11 @@ eal_legacy_hugepage_init(void)
/* find a hugepage info with right size and increment num_pages */
const int nb_hpsizes = RTE_MIN(MAX_HUGEPAGE_SIZES,
- (int)internal_conf->num_hugepage_sizes);
+ (int)platform_info->num_hugepage_sizes);
for (j = 0; j < nb_hpsizes; j++) {
if (tmp_hp[i].size ==
- internal_conf->hugepage_info[j].hugepage_sz) {
- internal_conf->hugepage_info[j].num_pages[socket]++;
+ platform_info->hugepage_info[j].hugepage_sz) {
+ platform_info->hugepage_info[j].num_pages[socket]++;
}
}
}
@@ -1390,15 +1383,15 @@ eal_legacy_hugepage_init(void)
/* calculate final number of pages */
nr_hugepages = eal_dynmem_calc_num_pages_per_socket(memory,
- internal_conf->hugepage_info, used_hp,
- internal_conf->num_hugepage_sizes);
+ platform_info->hugepage_info, used_hp,
+ platform_info->num_hugepage_sizes);
/* error if not enough memory available */
if (nr_hugepages < 0)
goto fail;
/* reporting in! */
- for (i = 0; i < (int) internal_conf->num_hugepage_sizes; i++) {
+ for (i = 0; i < (int) platform_info->num_hugepage_sizes; i++) {
for (j = 0; j < RTE_MAX_NUMA_NODES; j++) {
if (used_hp[i].num_pages[j] > 0) {
EAL_LOG(DEBUG,
@@ -1427,7 +1420,7 @@ eal_legacy_hugepage_init(void)
* also, sets final_va to NULL on pages that were unmapped.
*/
if (unmap_unneeded_hugepages(tmp_hp, used_hp,
- internal_conf->num_hugepage_sizes) < 0) {
+ platform_info->num_hugepage_sizes) < 0) {
EAL_LOG(ERR, "Unmapping and locking hugepages failed!");
goto fail;
}
@@ -1462,7 +1455,7 @@ eal_legacy_hugepage_init(void)
/* free the hugepage backing files */
if (user_cfg->hugepage_file.unlink_before_mapping &&
- unlink_hugepage_files(tmp_hp, internal_conf->num_hugepage_sizes) < 0) {
+ unlink_hugepage_files(tmp_hp, platform_info->num_hugepage_sizes) < 0) {
EAL_LOG(ERR, "Unlinking hugepage files failed!");
goto fail;
}
@@ -1715,8 +1708,7 @@ memseg_primary_init_32(void)
struct rte_memseg_list *msl;
uint64_t extra_mem_per_socket, total_extra_mem, total_requested_mem;
uint64_t max_mem;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
const struct eal_user_cfg *user_cfg = eal_get_user_configuration();
/* no-huge does not need this at all */
@@ -1783,7 +1775,7 @@ memseg_primary_init_32(void)
/* create memseg lists */
for (i = 0; i < rte_socket_count(); i++) {
- int hp_sizes = (int) internal_conf->num_hugepage_sizes;
+ int hp_sizes = (int) platform_info->num_hugepage_sizes;
uint64_t max_socket_mem, cur_socket_mem;
unsigned int main_lcore_socket;
struct rte_config *cfg = rte_eal_get_configuration();
@@ -1831,7 +1823,7 @@ memseg_primary_init_32(void)
struct hugepage_info *hpi;
int type_msl_idx, max_segs, total_segs = 0;
- hpi = &internal_conf->hugepage_info[hpi_idx];
+ hpi = &platform_info->hugepage_info[hpi_idx];
hugepage_sz = hpi->hugepage_sz;
/* check if pages are actually available */
diff --git a/lib/eal/windows/eal_hugepages.c b/lib/eal/windows/eal_hugepages.c
index ff72b8ee38..4e9e958c65 100644
--- a/lib/eal/windows/eal_hugepages.c
+++ b/lib/eal/windows/eal_hugepages.c
@@ -62,12 +62,11 @@ hugepage_info_init(void)
struct hugepage_info *hpi;
unsigned int socket_id;
int ret = 0;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ struct eal_platform_info *platform_info = eal_get_platform_info();
/* Only one hugepage size available on Windows. */
- internal_conf->num_hugepage_sizes = 1;
- hpi = &internal_conf->hugepage_info[0];
+ platform_info->num_hugepage_sizes = 1;
+ hpi = &platform_info->hugepage_info[0];
hpi->hugepage_sz = GetLargePageMinimum();
if (hpi->hugepage_sz == 0)
diff --git a/lib/eal/windows/eal_memalloc.c b/lib/eal/windows/eal_memalloc.c
index 26d9cae54c..35eaf3a180 100644
--- a/lib/eal/windows/eal_memalloc.c
+++ b/lib/eal/windows/eal_memalloc.c
@@ -33,7 +33,7 @@ eal_memalloc_get_seg_fd_offset(int list_idx, int seg_idx, size_t *offset)
static int
alloc_seg(struct rte_memseg *ms, void *requested_addr, int socket_id,
- struct hugepage_info *hi)
+ const struct hugepage_info *hi)
{
HANDLE current_process;
unsigned int numa_node;
@@ -166,7 +166,7 @@ free_seg(struct rte_memseg *ms)
}
struct alloc_walk_param {
- struct hugepage_info *hi;
+ const struct hugepage_info *hi;
struct rte_memseg **ms;
size_t page_sz;
unsigned int segs_allocated;
@@ -273,7 +273,7 @@ alloc_seg_walk(const struct rte_memseg_list *msl, void *arg)
}
struct free_walk_param {
- struct hugepage_info *hi;
+ const struct hugepage_info *hi;
struct rte_memseg *ms;
};
static int
@@ -313,9 +313,8 @@ eal_memalloc_alloc_seg_bulk(struct rte_memseg **ms, int n_segs,
unsigned int i;
int ret = -1;
struct alloc_walk_param wa;
- struct hugepage_info *hi = NULL;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ const struct hugepage_info *hi = NULL;
+ const struct eal_platform_info *platform_info = eal_get_platform_info();
const struct eal_user_cfg *user_cfg = eal_get_user_configuration();
if (user_cfg->legacy_mem) {
@@ -323,8 +322,8 @@ eal_memalloc_alloc_seg_bulk(struct rte_memseg **ms, int n_segs,
return -ENOTSUP;
}
- for (i = 0; i < internal_conf->num_hugepage_sizes; i++) {
- struct hugepage_info *hpi = &internal_conf->hugepage_info[i];
+ for (i = 0; i < platform_info->num_hugepage_sizes; i++) {
+ const struct hugepage_info *hpi = &platform_info->hugepage_info[i];
if (page_sz == hpi->hugepage_sz) {
hi = hpi;
break;
@@ -368,8 +367,7 @@ int
eal_memalloc_free_seg_bulk(struct rte_memseg **ms, int n_segs)
{
int seg, ret = 0;
- struct internal_config *internal_conf =
- eal_get_internal_configuration();
+ const struct eal_platform_info *platform_info = eal_get_platform_info();
const struct eal_user_cfg *user_cfg = eal_get_user_configuration();
/* dynamic free not supported in legacy mode */
@@ -378,7 +376,7 @@ eal_memalloc_free_seg_bulk(struct rte_memseg **ms, int n_segs)
for (seg = 0; seg < n_segs; seg++) {
struct rte_memseg *cur = ms[seg];
- struct hugepage_info *hi = NULL;
+ const struct hugepage_info *hi = NULL;
struct free_walk_param wa;
size_t i;
int walk_res;
@@ -392,12 +390,12 @@ eal_memalloc_free_seg_bulk(struct rte_memseg **ms, int n_segs)
memset(&wa, 0, sizeof(wa));
- for (i = 0; i < RTE_DIM(internal_conf->hugepage_info); i++) {
- hi = &internal_conf->hugepage_info[i];
+ for (i = 0; i < RTE_DIM(platform_info->hugepage_info); i++) {
+ hi = &platform_info->hugepage_info[i];
if (cur->hugepage_sz == hi->hugepage_sz)
break;
}
- if (i == RTE_DIM(internal_conf->hugepage_info)) {
+ if (i == RTE_DIM(platform_info->hugepage_info)) {
EAL_LOG(ERR, "Can't find relevant hugepage_info entry");
ret = -1;
continue;
--
2.51.0
More information about the dev
mailing list