Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp890341ybe; Fri, 6 Sep 2019 08:48:12 -0700 (PDT) X-Google-Smtp-Source: APXvYqx56RN1Yqgt5VuZ3LzjX8x1PzwMFIJxpcIqBun1/jaQxwkZP8/0RN4qp9sexmYaSxHLSPM6 X-Received: by 2002:a17:902:b201:: with SMTP id t1mr10087652plr.144.1567784892694; Fri, 06 Sep 2019 08:48:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567784892; cv=none; d=google.com; s=arc-20160816; b=BtuT+wvo46Aym9QZjoJEFmWzGRlLUZIMivdWyrWLWu1LrFdxyaIrvWj5nYNyh1Wcon tpu7azh6wxZJloNMEIYMxdkSGS4dh5iiIsso3W1gCUM8mhRHWLlO04qXAIp9zpKAIiHw t2cOMJLkTiir0jO1d4q0Q5RwC/tjeSQftR94n/N+ZYZvK8fpFlWXqxlxRGHjFx7pmVpY DMXjdjFxzQEeW0eLA3WFix3LWGZy3QCoGd64fym2tfRk1Mw4GHoGNcThrbrpIFiiZlnd VdTUrzgmLkfISNPozh3p8JBSq5uP+RGkH9sCWYvq77+8rMVcqNv8h8z2O6y3dcArYYM/ KCTg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:from:subject:references :mime-version:message-id:in-reply-to:date:dkim-signature; bh=QzLwUka7MndmPbLBfBjtnVUWcO8y+yUapUjSVd2AkdE=; b=LfBWax75Jwu2HIiWPFgeu30WQF7kdSIg1nR+D7z7es0WSZnW9EOG0Ix0qSoO2swLIk CGifqWzadqX5A5wBrSZ1auhn0R36QmehC3W36TAAs2hJxkiFDBBWbVrp6YdYGxSB5mvs sdCvKgzBTBbLE23JDscgNScEdYk/Gh65fZ3WYWNoQ6XQiz7U1wbQd08xLRK26mF4UfBP DR4ffEanzKjZGnoTjE0dwqdWcDDWPujHyT6NjG/1nEF8+/KboK8M3Nv5r5VQym2K7Xo0 +cAygZYvNTIZ7sYYOBqaPXKvvOH4TMDntv8sPptIkXvJwntlSNbLMWZa7QopwOmH9aNn 8Qnw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=Cwgi2TD2; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 32si5071949pla.178.2019.09.06.08.47.57; Fri, 06 Sep 2019 08:48:12 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=Cwgi2TD2; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2393061AbfIFKdD (ORCPT + 99 others); Fri, 6 Sep 2019 06:33:03 -0400 Received: from mail-qt1-f202.google.com ([209.85.160.202]:39701 "EHLO mail-qt1-f202.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390403AbfIFKdA (ORCPT ); Fri, 6 Sep 2019 06:33:00 -0400 Received: by mail-qt1-f202.google.com with SMTP id y13so5783168qtn.6 for ; Fri, 06 Sep 2019 03:33:00 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc; bh=QzLwUka7MndmPbLBfBjtnVUWcO8y+yUapUjSVd2AkdE=; b=Cwgi2TD2axl7EA3tVfizddxZpfimXndhfzAvvjo1Y/HcF0VNlztN/wh+wlfI/QRMJC 721inxt51pWefqg1V5l9Jg7vIvYwuyDi50jczACweEFPDlE/63bksbkxrFi6ZvDA+Ym2 j3wxi6QRKlHrIjsNMFF2l41QKQDbNXwohYCQEXBJFuJagd5DP0vvlpheldo7lDu3TQjU lutZes51nFw36amBGFM2Gc2HE/HknAUImyvRXHV9Dq1T3uWnqG76xU9CdO6hwmYZ7q48 u0bilHqGVhc7stv688zzu+ASd0t01d+jII1ubYlyGWstv7sY5hXWCc0De+ZsQ/p899eq hzVA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=QzLwUka7MndmPbLBfBjtnVUWcO8y+yUapUjSVd2AkdE=; b=bghPAp/5/IpTJ1Kmj7PpAtWZeeo4tXOukat1rfKjlfPV876E323RT+ap34oRSWsYIw tNQh3Q0pl2WceIMkeIw+zzMOVfAXllDI01GJm+YE3lQxt2vRbTL1EXE4pqGQE/yI4AJ0 gysKfzaoF4YNekwpStxBl7KYx97Go5hM93vsmPwJMUOvJ5pq46EZ6j/nYwU+LB2vDeJy FV5tt1YweuVPs91jNkl5licvcncUNArKQC7o8tKwLl+DgjTy1OzJ9TukMykZrkxfJhdl YYnc/H1B/k96HE5ml8bPe5QntG8hE1enNBgt0779sLEaqOqKndtLuAOZmucBaDYnFajV rOfw== X-Gm-Message-State: APjAAAWBJqORsnPrjq+opWqwITyvMsXhCeaD0fTO16yEcnW2YrPKJNSj wN4xAFeO2UfXaQDkdHVopatm6H2M02E/TmK243v0gS9/XN5HrDNJrXaVQALbyJBWsbE0GnK9ujO 3+2ZcZX4vMuj6mTDNqxz8sna6v9DTYyGsp31BBZwgBFfAhChHMfuKnQPUEtSE4uBnrJrAJjqSFv I= X-Received: by 2002:ad4:5149:: with SMTP id g9mr4868362qvq.115.1567765979457; Fri, 06 Sep 2019 03:32:59 -0700 (PDT) Date: Fri, 6 Sep 2019 11:32:30 +0100 In-Reply-To: <20190906103235.197072-1-maennich@google.com> Message-Id: <20190906103235.197072-7-maennich@google.com> Mime-Version: 1.0 References: <20180716122125.175792-1-maco@android.com> <20190906103235.197072-1-maennich@google.com> X-Mailer: git-send-email 2.23.0.187.g17f5b7556c-goog Subject: [PATCH v5 06/11] export: allow definition default namespaces in Makefiles or sources From: Matthias Maennich To: linux-kernel@vger.kernel.org Cc: kernel-team@android.com, maennich@google.com, arnd@arndb.de, gregkh@linuxfoundation.org, jeyu@kernel.org, joel@joelfernandes.org, lucas.de.marchi@gmail.com, maco@android.com, sspatil@google.com, will@kernel.org, yamada.masahiro@socionext.com, linux-kbuild@vger.kernel.org, linux-modules@vger.kernel.org, linux-usb@vger.kernel.org, usb-storage@lists.one-eyed-alien.net Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org To avoid excessive usage of EXPORT_SYMBOL_NS(sym, MY_NAMESPACE), where MY_NAMESPACE will always be the namespace we are exporting to, allow exporting all definitions of EXPORT_SYMBOL() and friends by defining DEFAULT_SYMBOL_NAMESPACE. For example, to export all symbols defined in usb-common into the namespace USB_COMMON, add a line like this to drivers/usb/common/Makefile: ccflags-y += -DDEFAULT_SYMBOL_NAMESPACE=USB_COMMON That is equivalent to changing all EXPORT_SYMBOL(sym) definitions to EXPORT_SYMBOL_NS(sym, USB_COMMON). Subsequently all symbol namespaces functionality will apply. Another way of making use of this feature is to define the namespace within source or header files similar to how TRACE_SYSTEM defines are used: #undef DEFAULT_SYMBOL_NAMESPACE #define DEFAULT_SYMBOL_NAMESPACE USB_COMMON Please note that, as opposed to TRACE_SYSTEM, DEFAULT_SYMBOL_NAMESPACE has to be defined before including include/linux/export.h. If DEFAULT_SYMBOL_NAMESPACE is defined, a symbol can still be exported to another namespace by using EXPORT_SYMBOL_NS() and friends with explicitly specifying the namespace. Suggested-by: Arnd Bergmann Reviewed-by: Martijn Coenen Reviewed-by: Greg Kroah-Hartman Signed-off-by: Matthias Maennich --- include/linux/export.h | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/include/linux/export.h b/include/linux/export.h index d59461e71478..2c5468d8ea9a 100644 --- a/include/linux/export.h +++ b/include/linux/export.h @@ -166,6 +166,12 @@ struct kernel_symbol { #define __EXPORT_SYMBOL ___EXPORT_SYMBOL #endif +#ifdef DEFAULT_SYMBOL_NAMESPACE +#undef __EXPORT_SYMBOL +#define __EXPORT_SYMBOL(sym, sec) \ + __EXPORT_SYMBOL_NS(sym, sec, DEFAULT_SYMBOL_NAMESPACE) +#endif + #define EXPORT_SYMBOL(sym) __EXPORT_SYMBOL(sym, "") #define EXPORT_SYMBOL_GPL(sym) __EXPORT_SYMBOL(sym, "_gpl") #define EXPORT_SYMBOL_GPL_FUTURE(sym) __EXPORT_SYMBOL(sym, "_gpl_future") -- 2.23.0.187.g17f5b7556c-goog