On 26-Jun-18 8:08 AM, Qi Zhang wrote:
We know the limitation that sync IPC can't be invoked in mp handler
itself which will cause deadlock, the patch introduce new API
rte_eal_mp_task_add to support mp handler be delegated in a separate
task.
Signed-off-by: Qi Zhang <qi.z.zh...@intel.com>
---
I would really like to find another solution to this problem. Creating a
new thread per hotplug request seems like an overkill - even more so
than having two threads. Creating a new thread potentially while the
application is working may have other implications (e.g. there's a
non-zero amount of time between thread created and thread affinitized,
which may disrupt hotpaths).
It seems to me that the better solution would've been to leave the IPC
thread in place. There are two IPC threads in the first place because
there was a circular dependency between rte_malloc and alarm API. My
patch fixes that - so how about we remove *one* IPC thread, but leave
the other one in place?
Thomas, any thoughts? (quick description - hotplug needs IPC, and
hotplug may need to allocate memory, which also needs IPC, which will
cause a deadlock if IPC is one thread)
--
Thanks,
Anatoly