Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/45046/?format=api
https://patches.dpdk.org/api/patches/45046/?format=api", "web_url": "https://patches.dpdk.org/project/dpdk/patch/ce592ded274774b9d5427fbda577e9fe633df688.1537456998.git.anatoly.burakov@intel.com/", "project": { "id": 1, "url": "https://patches.dpdk.org/api/projects/1/?format=api", "name": "DPDK", "link_name": "dpdk", "list_id": "dev.dpdk.org", "list_email": "dev@dpdk.org", "web_url": "http://core.dpdk.org", "scm_url": "git://dpdk.org/dpdk", "webscm_url": "http://git.dpdk.org/dpdk", "list_archive_url": "https://inbox.dpdk.org/dev", "list_archive_url_format": "https://inbox.dpdk.org/dev/{}", "commit_url_format": "" }, "msgid": "<ce592ded274774b9d5427fbda577e9fe633df688.1537456998.git.anatoly.burakov@intel.com>", "list_archive_url": "https://inbox.dpdk.org/dev/ce592ded274774b9d5427fbda577e9fe633df688.1537456998.git.anatoly.burakov@intel.com", "date": "2018-09-20T15:27:15", "name": "[v2,1/7] linuxapp: build with _GNU_SOURCE defined by default", "commit_ref": null, "pull_url": null, "state": "superseded", "archived": true, "hash": "3f7ece3f634ca4f55602d87b483bb511b2594254", "submitter": { "id": 4, "url": "https://patches.dpdk.org/api/people/4/?format=api", "name": "Anatoly Burakov", "email": "anatoly.burakov@intel.com" }, "delegate": { "id": 1, "url": "https://patches.dpdk.org/api/users/1/?format=api", "username": "tmonjalo", "first_name": "Thomas", "last_name": "Monjalon", "email": "thomas@monjalon.net" }, "mbox": "https://patches.dpdk.org/project/dpdk/patch/ce592ded274774b9d5427fbda577e9fe633df688.1537456998.git.anatoly.burakov@intel.com/mbox/", "series": [ { "id": 1423, "url": "https://patches.dpdk.org/api/series/1423/?format=api", "web_url": "https://patches.dpdk.org/project/dpdk/list/?series=1423", "date": "2018-09-20T15:27:21", "name": "Improve core EAL musl compatibility", "version": 2, "mbox": "https://patches.dpdk.org/series/1423/mbox/" } ], "comments": "https://patches.dpdk.org/api/patches/45046/comments/", "check": "success", "checks": "https://patches.dpdk.org/api/patches/45046/checks/", "tags": {}, "related": [], "headers": { "Return-Path": "<dev-bounces@dpdk.org>", "X-Original-To": "patchwork@dpdk.org", "Delivered-To": "patchwork@dpdk.org", "Received": [ "from [92.243.14.124] (localhost [127.0.0.1])\n\tby dpdk.org (Postfix) with ESMTP id 31E121B120;\n\tThu, 20 Sep 2018 17:27:50 +0200 (CEST)", "from mga09.intel.com (mga09.intel.com [134.134.136.24])\n\tby dpdk.org (Postfix) with ESMTP id D5A481B10E\n\tfor <dev@dpdk.org>; Thu, 20 Sep 2018 17:27:45 +0200 (CEST)", "from fmsmga003.fm.intel.com ([10.253.24.29])\n\tby orsmga102.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384;\n\t20 Sep 2018 08:27:44 -0700", "from irvmail001.ir.intel.com ([163.33.26.43])\n\tby FMSMGA003.fm.intel.com with ESMTP; 20 Sep 2018 08:27:22 -0700", "from sivswdev01.ir.intel.com (sivswdev01.ir.intel.com\n\t[10.237.217.45])\n\tby irvmail001.ir.intel.com (8.14.3/8.13.6/MailSET/Hub) with ESMTP id\n\tw8KFRMEi006738; Thu, 20 Sep 2018 16:27:22 +0100", "from sivswdev01.ir.intel.com (localhost [127.0.0.1])\n\tby sivswdev01.ir.intel.com with ESMTP id w8KFRLfB025118;\n\tThu, 20 Sep 2018 16:27:21 +0100", "(from aburakov@localhost)\n\tby sivswdev01.ir.intel.com with LOCAL id w8KFRLng025114;\n\tThu, 20 Sep 2018 16:27:21 +0100" ], "X-Amp-Result": "SKIPPED(no attachment in message)", "X-Amp-File-Uploaded": "False", "X-ExtLoop1": "1", "X-IronPort-AV": "E=Sophos;i=\"5.53,398,1531810800\"; d=\"scan'208\";a=\"81999811\"", "From": "Anatoly Burakov <anatoly.burakov@intel.com>", "To": "dev@dpdk.org", "Cc": "Jasvinder Singh <jasvinder.singh@intel.com>,\n\tCristian Dumitrescu <cristian.dumitrescu@intel.com>,\n\tThomas Monjalon <thomas@monjalon.net>, dpdk@stormmq.com,\n\tbruce.richardson@intel.com, stephen@networkplumber.org", "Date": "Thu, 20 Sep 2018 16:27:15 +0100", "Message-Id": "<ce592ded274774b9d5427fbda577e9fe633df688.1537456998.git.anatoly.burakov@intel.com>", "X-Mailer": "git-send-email 1.7.0.7", "In-Reply-To": [ "<cover.1537456998.git.anatoly.burakov@intel.com>", "<cover.1537456998.git.anatoly.burakov@intel.com>" ], "References": [ "<cover.1537456998.git.anatoly.burakov@intel.com>", "<cover.1535543250.git.anatoly.burakov@intel.com>\n\t<cover.1537456998.git.anatoly.burakov@intel.com>" ], "Subject": "[dpdk-dev] [PATCH v2 1/7] linuxapp: build with _GNU_SOURCE defined\n\tby default", "X-BeenThere": "dev@dpdk.org", "X-Mailman-Version": "2.1.15", "Precedence": "list", "List-Id": "DPDK patches and discussions <dev.dpdk.org>", "List-Unsubscribe": "<https://mails.dpdk.org/options/dev>,\n\t<mailto:dev-request@dpdk.org?subject=unsubscribe>", "List-Archive": "<http://mails.dpdk.org/archives/dev/>", "List-Post": "<mailto:dev@dpdk.org>", "List-Help": "<mailto:dev-request@dpdk.org?subject=help>", "List-Subscribe": "<https://mails.dpdk.org/listinfo/dev>,\n\t<mailto:dev-request@dpdk.org?subject=subscribe>", "Errors-To": "dev-bounces@dpdk.org", "Sender": "\"dev\" <dev-bounces@dpdk.org>" }, "content": "We use _GNU_SOURCE all over the place, but often times we miss\ndefining it, resulting in broken builds on musl. Rather than\nfixing every library's and driver's and application's makefile,\nfix it by simply defining _GNU_SOURCE by default for all\nLinuxapp builds.\n\nSigned-off-by: Anatoly Burakov <anatoly.burakov@intel.com>\n---\n app/meson.build | 9 ++++++++-\n drivers/bus/pci/linux/Makefile | 2 --\n drivers/meson.build | 6 ++++++\n drivers/net/softnic/conn.c | 1 -\n examples/meson.build | 6 ++++++\n lib/librte_eal/linuxapp/eal/Makefile | 16 ----------------\n lib/meson.build | 6 ++++++\n mk/exec-env/linuxapp/rte.vars.mk | 2 ++\n test/test/meson.build | 5 +++++\n 9 files changed, 33 insertions(+), 20 deletions(-)", "diff": "diff --git a/app/meson.build b/app/meson.build\nindex 99e0b93ec..c9a52a22b 100644\n--- a/app/meson.build\n+++ b/app/meson.build\n@@ -11,13 +11,20 @@ apps = ['pdump',\n # for BSD only\n lib_execinfo = cc.find_library('execinfo', required: false)\n \n+default_cflags = machine_args\n+\n+# on Linux, specify -D_GNU_SOURCE unconditionally\n+if host_machine.system() == 'linux'\n+\tdefault_cflags += '-D_GNU_SOURCE'\n+endif\n+\n foreach app:apps\n \tbuild = true\n \tname = app\n \tallow_experimental_apis = false\n \tsources = []\n \tincludes = []\n-\tcflags = machine_args\n+\tcflags = default_cflags\n \tobjs = [] # other object files to link against, used e.g. for\n \t # instruction-set optimized versions of code\n \ndiff --git a/drivers/bus/pci/linux/Makefile b/drivers/bus/pci/linux/Makefile\nindex 96ea1d540..90404468b 100644\n--- a/drivers/bus/pci/linux/Makefile\n+++ b/drivers/bus/pci/linux/Makefile\n@@ -4,5 +4,3 @@\n SRCS += pci.c\n SRCS += pci_uio.c\n SRCS += pci_vfio.c\n-\n-CFLAGS += -D_GNU_SOURCE\ndiff --git a/drivers/meson.build b/drivers/meson.build\nindex 47b4215a3..74fec716d 100644\n--- a/drivers/meson.build\n+++ b/drivers/meson.build\n@@ -16,6 +16,12 @@ default_cflags = machine_args\n if cc.has_argument('-Wno-format-truncation')\n \tdefault_cflags += '-Wno-format-truncation'\n endif\n+\n+# on Linux, specify -D_GNU_SOURCE unconditionally\n+if host_machine.system() == 'linux'\n+\tdefault_cflags += '-D_GNU_SOURCE'\n+endif\n+\n foreach class:driver_classes\n \tdrivers = []\n \tstd_deps = []\ndiff --git a/drivers/net/softnic/conn.c b/drivers/net/softnic/conn.c\nindex 990cf40fc..8b6658088 100644\n--- a/drivers/net/softnic/conn.c\n+++ b/drivers/net/softnic/conn.c\n@@ -8,7 +8,6 @@\n #include <unistd.h>\n #include <sys/types.h>\n \n-#define __USE_GNU\n #include <sys/socket.h>\n \n #include <sys/epoll.h>\ndiff --git a/examples/meson.build b/examples/meson.build\nindex 4ee7a1114..70c22eb62 100644\n--- a/examples/meson.build\n+++ b/examples/meson.build\n@@ -22,6 +22,12 @@ default_cflags = machine_args\n if cc.has_argument('-Wno-format-truncation')\n \tdefault_cflags += '-Wno-format-truncation'\n endif\n+\n+# on Linux, specify -D_GNU_SOURCE unconditionally\n+if host_machine.system() == 'linux'\n+\tdefault_cflags += '-D_GNU_SOURCE'\n+endif\n+\n foreach example: examples\n \tname = example\n \tbuild = true\ndiff --git a/lib/librte_eal/linuxapp/eal/Makefile b/lib/librte_eal/linuxapp/eal/Makefile\nindex fd92c75c2..bfee453bc 100644\n--- a/lib/librte_eal/linuxapp/eal/Makefile\n+++ b/lib/librte_eal/linuxapp/eal/Makefile\n@@ -85,22 +85,6 @@ SRCS-y += rte_cycles.c\n \n CFLAGS_eal_common_cpuflags.o := $(CPUFLAGS_LIST)\n \n-CFLAGS_eal.o := -D_GNU_SOURCE\n-CFLAGS_eal_interrupts.o := -D_GNU_SOURCE\n-CFLAGS_eal_vfio_mp_sync.o := -D_GNU_SOURCE\n-CFLAGS_eal_timer.o := -D_GNU_SOURCE\n-CFLAGS_eal_lcore.o := -D_GNU_SOURCE\n-CFLAGS_eal_memalloc.o := -D_GNU_SOURCE\n-CFLAGS_eal_thread.o := -D_GNU_SOURCE\n-CFLAGS_eal_log.o := -D_GNU_SOURCE\n-CFLAGS_eal_common_log.o := -D_GNU_SOURCE\n-CFLAGS_eal_hugepage_info.o := -D_GNU_SOURCE\n-CFLAGS_eal_common_whitelist.o := -D_GNU_SOURCE\n-CFLAGS_eal_common_options.o := -D_GNU_SOURCE\n-CFLAGS_eal_common_thread.o := -D_GNU_SOURCE\n-CFLAGS_eal_common_lcore.o := -D_GNU_SOURCE\n-CFLAGS_rte_cycles.o := -D_GNU_SOURCE\n-\n # workaround for a gcc bug with noreturn attribute\n # http://gcc.gnu.org/bugzilla/show_bug.cgi?id=12603\n ifeq ($(CONFIG_RTE_TOOLCHAIN_GCC),y)\ndiff --git a/lib/meson.build b/lib/meson.build\nindex 3acc67e6e..2c7ea436a 100644\n--- a/lib/meson.build\n+++ b/lib/meson.build\n@@ -32,6 +32,12 @@ if cc.has_argument('-Wno-format-truncation')\n endif\n \n enabled_libs = [] # used to print summary at the end\n+\n+# on Linux, specify -D_GNU_SOURCE unconditionally\n+if host_machine.system() == 'linux'\n+\tdefault_cflags += '-D_GNU_SOURCE'\n+endif\n+\n foreach l:libraries\n \tbuild = true\n \tname = l\ndiff --git a/mk/exec-env/linuxapp/rte.vars.mk b/mk/exec-env/linuxapp/rte.vars.mk\nindex 3129edc8c..91b778fcc 100644\n--- a/mk/exec-env/linuxapp/rte.vars.mk\n+++ b/mk/exec-env/linuxapp/rte.vars.mk\n@@ -17,6 +17,8 @@ else\n EXECENV_CFLAGS = -pthread\n endif\n \n+EXECENV_CFLAGS += -D_GNU_SOURCE\n+\n EXECENV_LDLIBS =\n EXECENV_ASFLAGS =\n \ndiff --git a/test/test/meson.build b/test/test/meson.build\nindex b1dd6eca2..c81fca439 100644\n--- a/test/test/meson.build\n+++ b/test/test/meson.build\n@@ -242,6 +242,11 @@ if cc.has_argument('-Wno-format-truncation')\n cflags += '-Wno-format-truncation'\n endif\n \n+# on Linux, specify -D_GNU_SOURCE unconditionally\n+if host_machine.system() == 'linux'\n+\tdefault_cflags += '-D_GNU_SOURCE'\n+endif\n+\n test_dep_objs = []\n compress_test_dep = dependency('zlib', required: false)\n if compress_test_dep.found()\n", "prefixes": [ "v2", "1/7" ] }{ "id": 45046, "url": "