eal: add cpuset into lcore config
The patch adds 'cpuset' into per-lcore configure 'lcore_config[]', as the lcore no longer always 1:1 pinning with physical cpu. The lcore now stands for a EAL thread rather than a logical cpu. It doesn't change the default behavior of 1:1 mapping, but allows to affinity the EAL thread to multiple cpus. Signed-off-by: Cunming Liang <cunming.liang@intel.com> Acked-by: Olivier Matz <olivier.matz@6wind.com> Acked-by: Konstantin Ananyev <konstantin.ananyev@intel.com>
This commit is contained in:
parent
0e2e511b38
commit
798a71d703
@ -76,11 +76,18 @@ rte_eal_cpu_init(void)
|
|||||||
* ones and enable them by default.
|
* ones and enable them by default.
|
||||||
*/
|
*/
|
||||||
for (lcore_id = 0; lcore_id < RTE_MAX_LCORE; lcore_id++) {
|
for (lcore_id = 0; lcore_id < RTE_MAX_LCORE; lcore_id++) {
|
||||||
|
/* init cpuset for per lcore config */
|
||||||
|
CPU_ZERO(&lcore_config[lcore_id].cpuset);
|
||||||
|
|
||||||
lcore_config[lcore_id].detected = (lcore_id < ncpus);
|
lcore_config[lcore_id].detected = (lcore_id < ncpus);
|
||||||
if (lcore_config[lcore_id].detected == 0) {
|
if (lcore_config[lcore_id].detected == 0) {
|
||||||
config->lcore_role[lcore_id] = ROLE_OFF;
|
config->lcore_role[lcore_id] = ROLE_OFF;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* By default, lcore 1:1 map to cpu id */
|
||||||
|
CPU_SET(lcore_id, &lcore_config[lcore_id].cpuset);
|
||||||
|
|
||||||
/* By default, each detected core is enabled */
|
/* By default, each detected core is enabled */
|
||||||
config->lcore_role[lcore_id] = ROLE_RTE;
|
config->lcore_role[lcore_id] = ROLE_RTE;
|
||||||
lcore_config[lcore_id].core_id = cpu_core_id(lcore_id);
|
lcore_config[lcore_id].core_id = cpu_core_id(lcore_id);
|
||||||
|
@ -50,6 +50,13 @@ extern "C" {
|
|||||||
|
|
||||||
#define LCORE_ID_ANY -1 /**< Any lcore. */
|
#define LCORE_ID_ANY -1 /**< Any lcore. */
|
||||||
|
|
||||||
|
#if defined(__linux__)
|
||||||
|
typedef cpu_set_t rte_cpuset_t;
|
||||||
|
#elif defined(__FreeBSD__)
|
||||||
|
#include <pthread_np.h>
|
||||||
|
typedef cpuset_t rte_cpuset_t;
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Structure storing internal configuration (per-lcore)
|
* Structure storing internal configuration (per-lcore)
|
||||||
*/
|
*/
|
||||||
@ -65,6 +72,7 @@ struct lcore_config {
|
|||||||
unsigned socket_id; /**< physical socket id for this lcore */
|
unsigned socket_id; /**< physical socket id for this lcore */
|
||||||
unsigned core_id; /**< core number on socket for this lcore */
|
unsigned core_id; /**< core number on socket for this lcore */
|
||||||
int core_index; /**< relative index, starting from 0 */
|
int core_index; /**< relative index, starting from 0 */
|
||||||
|
rte_cpuset_t cpuset; /**< cpu set which the lcore affinity to */
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -91,6 +91,7 @@ SRCS-$(CONFIG_RTE_LIBRTE_EAL_LINUXAPP) += eal_common_dev.c
|
|||||||
SRCS-$(CONFIG_RTE_LIBRTE_EAL_LINUXAPP) += eal_common_options.c
|
SRCS-$(CONFIG_RTE_LIBRTE_EAL_LINUXAPP) += eal_common_options.c
|
||||||
|
|
||||||
CFLAGS_eal.o := -D_GNU_SOURCE
|
CFLAGS_eal.o := -D_GNU_SOURCE
|
||||||
|
CFLAGS_eal_lcore.o := -D_GNU_SOURCE
|
||||||
CFLAGS_eal_thread.o := -D_GNU_SOURCE
|
CFLAGS_eal_thread.o := -D_GNU_SOURCE
|
||||||
CFLAGS_eal_log.o := -D_GNU_SOURCE
|
CFLAGS_eal_log.o := -D_GNU_SOURCE
|
||||||
CFLAGS_eal_common_log.o := -D_GNU_SOURCE
|
CFLAGS_eal_common_log.o := -D_GNU_SOURCE
|
||||||
|
@ -158,11 +158,19 @@ rte_eal_cpu_init(void)
|
|||||||
* ones and enable them by default.
|
* ones and enable them by default.
|
||||||
*/
|
*/
|
||||||
for (lcore_id = 0; lcore_id < RTE_MAX_LCORE; lcore_id++) {
|
for (lcore_id = 0; lcore_id < RTE_MAX_LCORE; lcore_id++) {
|
||||||
|
/* init cpuset for per lcore config */
|
||||||
|
CPU_ZERO(&lcore_config[lcore_id].cpuset);
|
||||||
|
|
||||||
|
/* in 1:1 mapping, record related cpu detected state */
|
||||||
lcore_config[lcore_id].detected = cpu_detected(lcore_id);
|
lcore_config[lcore_id].detected = cpu_detected(lcore_id);
|
||||||
if (lcore_config[lcore_id].detected == 0) {
|
if (lcore_config[lcore_id].detected == 0) {
|
||||||
config->lcore_role[lcore_id] = ROLE_OFF;
|
config->lcore_role[lcore_id] = ROLE_OFF;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* By default, lcore 1:1 map to cpu id */
|
||||||
|
CPU_SET(lcore_id, &lcore_config[lcore_id].cpuset);
|
||||||
|
|
||||||
/* By default, each detected core is enabled */
|
/* By default, each detected core is enabled */
|
||||||
config->lcore_role[lcore_id] = ROLE_RTE;
|
config->lcore_role[lcore_id] = ROLE_RTE;
|
||||||
lcore_config[lcore_id].core_id = cpu_core_id(lcore_id);
|
lcore_config[lcore_id].core_id = cpu_core_id(lcore_id);
|
||||||
|
Loading…
Reference in New Issue
Block a user