eal: deinline lcore APIs
Those functions are used to setup or take control decisions. Move them into the EAL common code and put them directly in the stable ABI. Signed-off-by: David Marchand <david.marchand@redhat.com> Acked-by: Thomas Monjalon <thomas@monjalon.net>
This commit is contained in:
parent
ab35397e7a
commit
56564391d7
@ -16,6 +16,16 @@
|
|||||||
#include "eal_private.h"
|
#include "eal_private.h"
|
||||||
#include "eal_thread.h"
|
#include "eal_thread.h"
|
||||||
|
|
||||||
|
unsigned int rte_get_master_lcore(void)
|
||||||
|
{
|
||||||
|
return rte_eal_get_configuration()->master_lcore;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned int rte_lcore_count(void)
|
||||||
|
{
|
||||||
|
return rte_eal_get_configuration()->lcore_count;
|
||||||
|
}
|
||||||
|
|
||||||
int rte_lcore_index(int lcore_id)
|
int rte_lcore_index(int lcore_id)
|
||||||
{
|
{
|
||||||
if (unlikely(lcore_id >= RTE_MAX_LCORE))
|
if (unlikely(lcore_id >= RTE_MAX_LCORE))
|
||||||
@ -43,6 +53,34 @@ rte_cpuset_t rte_lcore_cpuset(unsigned int lcore_id)
|
|||||||
return lcore_config[lcore_id].cpuset;
|
return lcore_config[lcore_id].cpuset;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int rte_lcore_is_enabled(unsigned int lcore_id)
|
||||||
|
{
|
||||||
|
struct rte_config *cfg = rte_eal_get_configuration();
|
||||||
|
|
||||||
|
if (lcore_id >= RTE_MAX_LCORE)
|
||||||
|
return 0;
|
||||||
|
return cfg->lcore_role[lcore_id] == ROLE_RTE;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned int rte_get_next_lcore(unsigned int i, int skip_master, int wrap)
|
||||||
|
{
|
||||||
|
i++;
|
||||||
|
if (wrap)
|
||||||
|
i %= RTE_MAX_LCORE;
|
||||||
|
|
||||||
|
while (i < RTE_MAX_LCORE) {
|
||||||
|
if (!rte_lcore_is_enabled(i) ||
|
||||||
|
(skip_master && (i == rte_get_master_lcore()))) {
|
||||||
|
i++;
|
||||||
|
if (wrap)
|
||||||
|
i %= RTE_MAX_LCORE;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
|
||||||
unsigned int
|
unsigned int
|
||||||
rte_lcore_to_socket_id(unsigned int lcore_id)
|
rte_lcore_to_socket_id(unsigned int lcore_id)
|
||||||
{
|
{
|
||||||
|
@ -49,11 +49,7 @@ rte_lcore_id(void)
|
|||||||
* @return
|
* @return
|
||||||
* the id of the master lcore
|
* the id of the master lcore
|
||||||
*/
|
*/
|
||||||
static inline unsigned
|
unsigned int rte_get_master_lcore(void);
|
||||||
rte_get_master_lcore(void)
|
|
||||||
{
|
|
||||||
return rte_eal_get_configuration()->master_lcore;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the number of execution units (lcores) on the system.
|
* Return the number of execution units (lcores) on the system.
|
||||||
@ -61,12 +57,7 @@ rte_get_master_lcore(void)
|
|||||||
* @return
|
* @return
|
||||||
* the number of execution units (lcores) on the system.
|
* the number of execution units (lcores) on the system.
|
||||||
*/
|
*/
|
||||||
static inline unsigned
|
unsigned int rte_lcore_count(void);
|
||||||
rte_lcore_count(void)
|
|
||||||
{
|
|
||||||
const struct rte_config *cfg = rte_eal_get_configuration();
|
|
||||||
return cfg->lcore_count;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the index of the lcore starting from zero.
|
* Return the index of the lcore starting from zero.
|
||||||
@ -171,14 +162,7 @@ rte_lcore_cpuset(unsigned int lcore_id);
|
|||||||
* @return
|
* @return
|
||||||
* True if the given lcore is enabled; false otherwise.
|
* True if the given lcore is enabled; false otherwise.
|
||||||
*/
|
*/
|
||||||
static inline int
|
int rte_lcore_is_enabled(unsigned int lcore_id);
|
||||||
rte_lcore_is_enabled(unsigned int lcore_id)
|
|
||||||
{
|
|
||||||
struct rte_config *cfg = rte_eal_get_configuration();
|
|
||||||
if (lcore_id >= RTE_MAX_LCORE)
|
|
||||||
return 0;
|
|
||||||
return cfg->lcore_role[lcore_id] == ROLE_RTE;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the next enabled lcore ID.
|
* Get the next enabled lcore ID.
|
||||||
@ -193,25 +177,8 @@ rte_lcore_is_enabled(unsigned int lcore_id)
|
|||||||
* @return
|
* @return
|
||||||
* The next lcore_id or RTE_MAX_LCORE if not found.
|
* The next lcore_id or RTE_MAX_LCORE if not found.
|
||||||
*/
|
*/
|
||||||
static inline unsigned int
|
unsigned int rte_get_next_lcore(unsigned int i, int skip_master, int wrap);
|
||||||
rte_get_next_lcore(unsigned int i, int skip_master, int wrap)
|
|
||||||
{
|
|
||||||
i++;
|
|
||||||
if (wrap)
|
|
||||||
i %= RTE_MAX_LCORE;
|
|
||||||
|
|
||||||
while (i < RTE_MAX_LCORE) {
|
|
||||||
if (!rte_lcore_is_enabled(i) ||
|
|
||||||
(skip_master && (i == rte_get_master_lcore()))) {
|
|
||||||
i++;
|
|
||||||
if (wrap)
|
|
||||||
i %= RTE_MAX_LCORE;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return i;
|
|
||||||
}
|
|
||||||
/**
|
/**
|
||||||
* Macro to browse all running lcores.
|
* Macro to browse all running lcores.
|
||||||
*/
|
*/
|
||||||
|
@ -310,6 +310,16 @@ DPDK_19.08 {
|
|||||||
|
|
||||||
} DPDK_19.05;
|
} DPDK_19.05;
|
||||||
|
|
||||||
|
DPDK_19.11 {
|
||||||
|
global:
|
||||||
|
|
||||||
|
rte_get_master_lcore;
|
||||||
|
rte_get_next_lcore;
|
||||||
|
rte_lcore_count;
|
||||||
|
rte_lcore_is_enabled;
|
||||||
|
|
||||||
|
} DPDK_19.08;
|
||||||
|
|
||||||
EXPERIMENTAL {
|
EXPERIMENTAL {
|
||||||
global:
|
global:
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user