From mboxrd@z Thu Jan 1 00:00:00 1970 From: Marvin Liu Subject: [PATCH] mk: using initial-exec model for thread local variable Date: Sat, 28 Apr 2018 17:54:07 +0800 Message-ID: <1524909247-6581-1-git-send-email-yong.liu@intel.com> Cc: Marvin Liu To: dev@dpdk.org Return-path: Received: from mga18.intel.com (mga18.intel.com [134.134.136.126]) by dpdk.org (Postfix) with ESMTP id 4A1C05B34 for ; Sat, 28 Apr 2018 04:06:03 +0200 (CEST) List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" When building share library, thread-local storage model will be changed to global-dynamic. It will cost additional protect for read thread local variable. By now only lcore id is this kind of varaible and not need to dynamic share with other threads. So make TLS model back to initial-exec like static library for better performance. Signed-off-by: Marvin Liu diff --git a/mk/toolchain/gcc/rte.vars.mk b/mk/toolchain/gcc/rte.vars.mk index 7e4531b..7b5e71c 100644 --- a/mk/toolchain/gcc/rte.vars.mk +++ b/mk/toolchain/gcc/rte.vars.mk @@ -43,6 +43,10 @@ ifeq (,$(findstring -O0,$(EXTRA_CFLAGS))) endif endif +ifeq ($(CONFIG_RTE_BUILD_SHARED_LIB),y) +TOOLCHAIN_CFLAGS += -ftls-model=initial-exec +endif + WERROR_FLAGS := -W -Wall -Wstrict-prototypes -Wmissing-prototypes WERROR_FLAGS += -Wmissing-declarations -Wold-style-definition -Wpointer-arith WERROR_FLAGS += -Wcast-align -Wnested-externs -Wcast-qual -- 1.9.3