bus/dpaa: fix logical to physical core affine logic
The code was treating the lcore id as physical core id.
The code is updated to use actual physical core value
for any core affinity logic.
Note that DPAA devices are single cluster systems.
Fixes: 5d944582d0
("bus/dpaa: check portal presence in the caller function")
Cc: stable@dpdk.org
Signed-off-by: Hemant Agrawal <hemant.agrawal@nxp.com>
This commit is contained in:
parent
04018a4552
commit
afb2f8fd5a
@ -250,52 +250,53 @@ dpaa_clean_device_list(void)
|
|||||||
|
|
||||||
int rte_dpaa_portal_init(void *arg)
|
int rte_dpaa_portal_init(void *arg)
|
||||||
{
|
{
|
||||||
cpu_set_t cpuset;
|
|
||||||
pthread_t id;
|
pthread_t id;
|
||||||
uint32_t cpu = rte_lcore_id();
|
unsigned int cpu, lcore = rte_lcore_id();
|
||||||
int ret;
|
int ret;
|
||||||
struct dpaa_portal *dpaa_io_portal;
|
struct dpaa_portal *dpaa_io_portal;
|
||||||
|
|
||||||
BUS_INIT_FUNC_TRACE();
|
BUS_INIT_FUNC_TRACE();
|
||||||
|
|
||||||
if ((size_t)arg == 1 || cpu == LCORE_ID_ANY)
|
if ((size_t)arg == 1 || lcore == LCORE_ID_ANY)
|
||||||
cpu = rte_get_master_lcore();
|
lcore = rte_get_master_lcore();
|
||||||
/* if the core id is not supported */
|
|
||||||
else
|
else
|
||||||
if (cpu >= RTE_MAX_LCORE)
|
if (lcore >= RTE_MAX_LCORE)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
/* Set CPU affinity for this thread */
|
cpu = lcore_config[lcore].core_id;
|
||||||
CPU_ZERO(&cpuset);
|
|
||||||
CPU_SET(cpu, &cpuset);
|
/* Set CPU affinity for this thread.*/
|
||||||
id = pthread_self();
|
id = pthread_self();
|
||||||
ret = pthread_setaffinity_np(id, sizeof(cpu_set_t), &cpuset);
|
ret = pthread_setaffinity_np(id, sizeof(cpu_set_t),
|
||||||
|
&lcore_config[lcore].cpuset);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
DPAA_BUS_LOG(ERR, "pthread_setaffinity_np failed on "
|
DPAA_BUS_LOG(ERR, "pthread_setaffinity_np failed on core :%u"
|
||||||
"core :%d with ret: %d", cpu, ret);
|
" (lcore=%u) with ret: %d", cpu, lcore, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Initialise bman thread portals */
|
/* Initialise bman thread portals */
|
||||||
ret = bman_thread_init();
|
ret = bman_thread_init();
|
||||||
if (ret) {
|
if (ret) {
|
||||||
DPAA_BUS_LOG(ERR, "bman_thread_init failed on "
|
DPAA_BUS_LOG(ERR, "bman_thread_init failed on core %u"
|
||||||
"core %d with ret: %d", cpu, ret);
|
" (lcore=%u) with ret: %d", cpu, lcore, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
DPAA_BUS_LOG(DEBUG, "BMAN thread initialized");
|
DPAA_BUS_LOG(DEBUG, "BMAN thread initialized - CPU=%d lcore=%d",
|
||||||
|
cpu, lcore);
|
||||||
|
|
||||||
/* Initialise qman thread portals */
|
/* Initialise qman thread portals */
|
||||||
ret = qman_thread_init();
|
ret = qman_thread_init();
|
||||||
if (ret) {
|
if (ret) {
|
||||||
DPAA_BUS_LOG(ERR, "bman_thread_init failed on "
|
DPAA_BUS_LOG(ERR, "qman_thread_init failed on core %u"
|
||||||
"core %d with ret: %d", cpu, ret);
|
" (lcore=%u) with ret: %d", cpu, lcore, ret);
|
||||||
bman_thread_finish();
|
bman_thread_finish();
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
DPAA_BUS_LOG(DEBUG, "QMAN thread initialized");
|
DPAA_BUS_LOG(DEBUG, "QMAN thread initialized - CPU=%d lcore=%d",
|
||||||
|
cpu, lcore);
|
||||||
|
|
||||||
dpaa_io_portal = rte_malloc(NULL, sizeof(struct dpaa_portal),
|
dpaa_io_portal = rte_malloc(NULL, sizeof(struct dpaa_portal),
|
||||||
RTE_CACHE_LINE_SIZE);
|
RTE_CACHE_LINE_SIZE);
|
||||||
@ -312,8 +313,8 @@ int rte_dpaa_portal_init(void *arg)
|
|||||||
|
|
||||||
ret = pthread_setspecific(dpaa_portal_key, (void *)dpaa_io_portal);
|
ret = pthread_setspecific(dpaa_portal_key, (void *)dpaa_io_portal);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
DPAA_BUS_LOG(ERR, "pthread_setspecific failed on "
|
DPAA_BUS_LOG(ERR, "pthread_setspecific failed on core %u"
|
||||||
"core %d with ret: %d", cpu, ret);
|
" (lcore=%u) with ret: %d", cpu, lcore, ret);
|
||||||
dpaa_portal_finish(NULL);
|
dpaa_portal_finish(NULL);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
Loading…
Reference in New Issue
Block a user