* [Bug 918] RTE EAL is unable to complete its work
@ 2021-12-27 13:53 bugzilla
0 siblings, 0 replies; only message in thread
From: bugzilla @ 2021-12-27 13:53 UTC (permalink / raw)
To: dev
https://bugs.dpdk.org/show_bug.cgi?id=918
Bug ID: 918
Summary: RTE EAL is unable to complete its work
Product: DPDK
Version: 20.11
Hardware: All
OS: All
Status: UNCONFIRMED
Severity: normal
Priority: Normal
Component: core
Assignee: dev@dpdk.org
Reporter: interferation3@gmail.com
Target Milestone: ---
Hi guys,
I am one of two authors of Dataplane SDK, where a lot of C-based OOP modules.
Part of them is related to DPDK.
For example:
sb_class.dpdk.eal
sb_class.dpdk.lpm
sb_class.dpdk.mempool
sb_class.dpdk.ring
sb_class.netdev.dpdk
sb_class.netdev.dpdk.eth
sb_class.netdev.dpdk.eth.bonding
sb_class.netdev.dpdk.pcap
sb_class.netdev.dpdk.tap
sb_class.task.node.group.dpdk.eth
sb_class.task.node.group.dpdk.tap
I also have a module sb_class.hal (Hardware Abstraction Layer) his object runs
before sb_object.dpdk.eal and its task is to determine the hardware and
initialize the synonym table between DPDK device number and SDK object name.
Also sb_object.hal calls /usr/bin/dpdk-devbind.py script in order to connect
network cards to the required drivers.
that is, the order of initialization is as follows:
sb_object.some_project - children initialization (they below)
sb_object.hal - hardware detection, bind drivers
sb_object.dpdk.eal - rte_eal_init
sb_object.dpdk.mempool - rte_pktmbuf_pool_create
sb_object.netdev.dpdk.eth - rte_eth_dev_configure queues etc
sb_object.lcore.scheduler.roundrobin - sb_lcore_launch
*** other objects ***
the application terminates in reverse order
and this is what I noticed when sb_object.dpdk.eal exits, I call the following
code (on the lcore that started everything)
void IMPLEMENTATION (object_free) (
sb_status_t * a_out_err,
sb_class_t * a_class,
sb_object_t * a_obj)
{
sb_object_dpdk_eal_t * obj
= (sb_object_dpdk_eal_t *) a_obj;
sb_object_super_class_free (a_out_err, a_class, a_obj);
obj-> eal_cmd_line [0] = '\ 0';
#if RTE_VERSION_NUM (19, 2, 0, 0) <= RTE_VERSION
{
unsigned lcore_id;
// wait for threads to stop
// RTE_LCORE_FOREACH_WORKER (lcore_id) {
RTE_LCORE_FOREACH (lcore_id) {
rte_eal_wait_lcore (lcore_id);
}
// clean up the EAL
rte_eal_cleanup ();
}
#endif
}
and in gdb I still see that DPDK has not finished working and its threads are
still running.
how can I stop DPDK completely?
because when object_free of sb_object.hal is called, it attempts to bind
network cards back to the kernel stack, but DPDK is still running and the
parent would be killed as a result thole application would be marked as
"defunct" and only hardware reboot can help
Please tell me how to correctly shutdown DPDK so that:
all DPDK resources were freed
all threads created by DPDK were closed
Regards, screenshots attached
Hi guys,
I am one of two authors of Dataplane SDK, where a lot of C-based OOP modules.
Part of them is related to DPDK.
For example:
sb_class.dpdk.eal
sb_class.dpdk.lpm
sb_class.dpdk.mempool
sb_class.dpdk.ring
sb_class.netdev.dpdk
sb_class.netdev.dpdk.eth
sb_class.netdev.dpdk.eth.bonding
sb_class.netdev.dpdk.pcap
sb_class.netdev.dpdk.tap
sb_class.task.node.group.dpdk.eth
sb_class.task.node.group.dpdk.tap
I also have a module sb_class.hal (Hardware Abstraction Layer) his object runs
before sb_object.dpdk.eal and its task is to determine the hardware and
initialize the synonym table between DPDK device number and SDK object name.
Also sb_object.hal calls /usr/bin/dpdk-devbind.py script in order to connect
network cards to the required drivers.
that is, the order of initialization is as follows:
sb_object.some_project - children initialization (they below)
sb_object.hal - hardware detection, bind drivers
sb_object.dpdk.eal - rte_eal_init
sb_object.dpdk.mempool - rte_pktmbuf_pool_create
sb_object.netdev.dpdk.eth - rte_eth_dev_configure queues etc
sb_object.lcore.scheduler.roundrobin - sb_lcore_launch
*** other objects ***
the application terminates in reverse order
and this is what I noticed when sb_object.dpdk.eal exits, I call the following
code (on the lcore that started everything)
void IMPLEMENTATION (object_free) (
sb_status_t * a_out_err,
sb_class_t * a_class,
sb_object_t * a_obj)
{
sb_object_dpdk_eal_t * obj
= (sb_object_dpdk_eal_t *) a_obj;
sb_object_super_class_free (a_out_err, a_class, a_obj);
obj-> eal_cmd_line [0] = '\ 0';
#if RTE_VERSION_NUM (19, 2, 0, 0) <= RTE_VERSION
{
unsigned lcore_id;
// wait for threads to stop
// RTE_LCORE_FOREACH_WORKER (lcore_id) {
RTE_LCORE_FOREACH (lcore_id) {
rte_eal_wait_lcore (lcore_id);
}
// clean up the EAL
rte_eal_cleanup ();
}
#endif
}
and in gdb I still see that DPDK has not finished working and its threads are
still running.
how can I stop DPDK completely?
because when object_free of sb_object.hal is called, it attempts to bind
network cards back to the kernel stack, but DPDK is still running and the
parent would be killed as a result thole application would be marked as
"defunct" and only hardware reboot can help
Please tell me how to correctly shutdown DPDK so that:
all DPDK resources were freed
all threads created by DPDK were closed
Regards, screenshots attached
--
You are receiving this mail because:
You are the assignee for the bug.
^ permalink raw reply [flat|nested] only message in thread
only message in thread, other threads:[~2021-12-27 13:53 UTC | newest]
Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-12-27 13:53 [Bug 918] RTE EAL is unable to complete its work bugzilla
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).