From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from proxy.6wind.com (host.76.145.23.62.rev.coltfrance.com [62.23.145.76]) by dpdk.org (Postfix) with ESMTP id CA1551B6B8 for ; Tue, 3 Apr 2018 15:04:56 +0200 (CEST) Received: from glumotte.dev.6wind.com. (unknown [10.16.0.195]) by proxy.6wind.com (Postfix) with ESMTP id 875F715588B; Tue, 3 Apr 2018 15:03:52 +0200 (CEST) From: Olivier Matz To: dev@dpdk.org Cc: Anatoly Burakov Date: Tue, 3 Apr 2018 15:04:35 +0200 Message-Id: <20180403130439.11151-1-olivier.matz@6wind.com> X-Mailer: git-send-email 2.11.0 Subject: [dpdk-dev] [PATCH v2 0/4] fix control thread affinities X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 03 Apr 2018 13:04:57 -0000 Some parts of dpdk use their own management threads. Most of the time, the affinity of the thread is not properly set: it should not be scheduled on the dataplane cores, because interrupting them can cause packet losses. This patchset introduces a new wrapper for thread creation that does the job automatically, avoiding code duplication. v2: * set affinity to master core if no core is off, as suggested by Anatoly Olivier Matz (4): eal: use sizeof to avoid a double use of a define eal: new function to create control threads eal: set name when creating a control thread eal: set affinity for control threads drivers/net/kni/Makefile | 1 + drivers/net/kni/rte_eth_kni.c | 3 +- lib/librte_eal/bsdapp/eal/eal.c | 2 +- lib/librte_eal/bsdapp/eal/eal_thread.c | 2 +- lib/librte_eal/common/eal_common_thread.c | 72 ++++++++++++++++++++++++++ lib/librte_eal/common/include/rte_lcore.h | 26 ++++++++++ lib/librte_eal/linuxapp/eal/eal.c | 4 +- lib/librte_eal/linuxapp/eal/eal_interrupts.c | 17 ++---- lib/librte_eal/linuxapp/eal/eal_thread.c | 2 +- lib/librte_eal/linuxapp/eal/eal_timer.c | 12 +---- lib/librte_eal/linuxapp/eal/eal_vfio_mp_sync.c | 10 +--- lib/librte_eal/rte_eal_version.map | 1 + lib/librte_pdump/Makefile | 1 + lib/librte_pdump/rte_pdump.c | 13 ++--- lib/librte_vhost/socket.c | 7 +-- 15 files changed, 125 insertions(+), 48 deletions(-) -- 2.11.0