From patchwork Sun Jun 11 15:50:49 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Masahiro Yamada X-Patchwork-Id: 10602 Return-Path: Delivered-To: ouuuleilei@gmail.com Received: by 2002:a59:994d:0:b0:3d9:f83d:47d9 with SMTP id k13csp2106174vqr; Sun, 11 Jun 2023 09:01:52 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ4cO9KceHzlAqLQhNbuu/exE3K1M0eJH0XsrehQpbqOwwGnQNLBXQcaBkdFmySKvMS68O0M X-Received: by 2002:a17:902:c408:b0:1ac:6fc3:6beb with SMTP id k8-20020a170902c40800b001ac6fc36bebmr5589481plk.9.1686499312374; Sun, 11 Jun 2023 09:01:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1686499312; cv=none; d=google.com; s=arc-20160816; b=NVeWY2BV/SGIg0PCpoK0jJgt6zJIAF92bbI/sTFxjfYzOFmetrkU+8outdxTfUaf1s QEpPjgL2hI1clHVAxlShMR4ni3KxQcDhrRuSVnFBa6NMz9OQ7K1OF4qTndAGqNAFDUcu sKLgrmgN+LAJ15QNf5+YOoZCcMu0oJCRgWcKj+oB55ThFKvme0zuqWEHm81uuuLpTuRr x8Q4XUOQ+u/krdG6uG+u2lh/smMMKWmRY5ZD0dbc8aJ9Zj9XixCllTvtmceOgdROxq2i tgOLOjpy8rRTD+JtTaAzi/HP3rbF2CRRtN9DyViiMxc8mADRDz1OCaFdFJBba1lmTV/B k/NA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=l7uIWf2kO8/1N7ioMV/QnDRGdOOElaQ8zk0EbTXyi+4=; b=Uk4dz0KPjlAubYBDDbnKuYaadQ76Zq4a9vd7WfUWiZo0YhoFoL8c2TbcUSRxs8xJ2x 3diVoJEKUpJnY3+7gTtDd/7W0ZusRYzk2KnadxgDWc8SVD2NnnMTQbHWOHD9nFb41QLG fVANFs8ynwMSd1KRi5g80xZU42twujNd2KzjljlfBslLMgRXdSCBRNsDYE0XRHjvEh7U 5t6yyHx/L/qAtJYkgP5zE2keYmS/+9Cu8e8XgKNzJcOP5kV55fFX8+T0URlkSV9TU0A/ 8hSqWbrkV8L9WwwSEvMoJnD0QLIB8uwSJMkHAsEl+Y+U1X1aHABEFChrKQT9Ls5ytf+c qnHQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=n+W+kqhg; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id n14-20020a170903110e00b001aadba392c1si2957366plh.464.2023.06.11.09.01.28; Sun, 11 Jun 2023 09:01:51 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=n+W+kqhg; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229616AbjFKPvK (ORCPT + 99 others); Sun, 11 Jun 2023 11:51:10 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56672 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229530AbjFKPvJ (ORCPT ); Sun, 11 Jun 2023 11:51:09 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 45FFBE68; Sun, 11 Jun 2023 08:51:08 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id CFA0861C0C; Sun, 11 Jun 2023 15:51:07 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id B82E1C433EF; Sun, 11 Jun 2023 15:51:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1686498667; bh=M3P3Tt70oSF0U8/09BUo6OTsoFwqdfvzt/GIo8FG5HI=; h=From:To:Cc:Subject:Date:From; b=n+W+kqhgipjQhbBWZzfaqidf3aqKOK/oETi8tjadKHGBAAYVrtcswAgyfd0GlKAeA NfWQRlr+Xo5ueNaRQnJYa78jPB7639OIk9K4yL07oIJkeCQI+icCHSt+lQrCgAchJC 7AiTvTdVnvYCFp7VLbNdW4n2EO8M9d/uZOrtEKJCw950095tH4AU7OQxwyjDuZ6Wbl v19QKzLpcMk6aWyaYhOr89oP7E12h4gx9FAbVaKqvaK/42AjI2Pvtj4Gh2ezllTmIy 1FjZALS2Ij4XN8eQ9cIZmg8VbSl2QBuXZGXesINi11iHYuKXzj4qdtCwlKyBi06YSx b8oWhgxfqHqtQ== From: Masahiro Yamada To: linux-kbuild@vger.kernel.org Cc: linux-kernel@vger.kernel.org, Nathan Chancellor , Nick Desaulniers , Nicolas Schier , linux-snps-arc@lists.infradead.org, Masahiro Yamada Subject: [PATCH v9 00/11] Unify and , remove EXPORT_DATA_SYMBOL(), faster TRIM_UNUSED_KSYMS Date: Mon, 12 Jun 2023 00:50:49 +0900 Message-Id: <20230611155100.2553804-1-masahiroy@kernel.org> X-Mailer: git-send-email 2.39.2 MIME-Version: 1.0 X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1768306504001833590?= X-GMAIL-MSGID: =?utf-8?q?1768422701643251659?= My goals: - Refactors EXPORT_SYMBOL, and . You can still put EXPORT_SYMBOL() in *.S file, very close to the definition, but you do not need to care about whether it is a function or a data. This removes EXPORT_DATA_SYMBOL(). - Re-implement TRIM_UNUSED_KSYMS in one-pass. This makes the building faster. - Move the static EXPORT_SYMBOL check to modpost. This also makes the building faster. This patch set is applicable to linux-next 20230609. Previous version v8: https://lore.kernel.org/linux-kbuild/CAK7LNARBVqdWgsPOwGJu87AKNVZvnWjL-bBJ3xJ-2w+fpidZZA@mail.gmail.com/T/#t v7: https://lore.kernel.org/linux-kbuild/20230608142428.256985-1-masahiroy@kernel.org/T/#mbaddcee18c9a8cf0a9b1f3fc562d09526cb69540 v6: https://lore.kernel.org/linux-kbuild/CAK7LNARjzGnj+sYX=_5yQ+8qoOQ2KB5N-_Ye53Ru3=XicezTYw@mail.gmail.com/T/#t v5: https://lore.kernel.org/linux-kbuild/CAK7LNARBiOywrMLbR=9N35sk19U0QM3xcPy7d1WqV-eyb4W23w@mail.gmail.com/T/#t v4: https://lore.kernel.org/linux-kbuild/CAK7LNASDzy9RERN6+q6WgR4ROYZQue=SBqgbcoYuVePByHtk6Q@mail.gmail.com/T/#t v3: https://lore.kernel.org/all/20220928063947.299333-1-masahiroy@kernel.org/ Masahiro Yamada (11): ARC: define ASM_NL and __ALIGN(_STR) outside #ifdef __ASSEMBLY__ guard modpost: pass struct module pointer to check_section_mismatch() kbuild: generate KSYMTAB entries by modpost ia64,export.h: replace EXPORT_DATA_SYMBOL* with EXPORT_SYMBOL* modpost: check static EXPORT_SYMBOL* by modpost again modpost: squash sym_update_namespace() into sym_add_exported() modpost: use null string instead of NULL pointer for default namespace kbuild: implement CONFIG_TRIM_UNUSED_KSYMS without recursion modpost: merge two similar section mismatch warnings modpost: show offset from symbol for section mismatch warnings linux/export.h: rename 'sec' argument to 'license' .gitignore | 2 - Makefile | 22 +-- arch/arc/include/asm/linkage.h | 8 +- arch/ia64/include/asm/Kbuild | 1 + arch/ia64/include/asm/export.h | 3 - arch/ia64/kernel/head.S | 2 +- arch/ia64/kernel/ivt.S | 2 +- include/asm-generic/export.h | 83 +--------- include/asm-generic/vmlinux.lds.h | 1 + include/linux/export-internal.h | 49 ++++++ include/linux/export.h | 128 ++++------------ include/linux/pm.h | 10 +- kernel/module/internal.h | 12 ++ scripts/Makefile.build | 27 +--- scripts/Makefile.modpost | 7 + scripts/adjust_autoksyms.sh | 73 --------- scripts/basic/fixdep.c | 3 +- scripts/check-local-export | 70 --------- scripts/gen_autoksyms.sh | 62 -------- scripts/gen_ksymdeps.sh | 30 ---- scripts/mod/modpost.c | 242 +++++++++++++++++++----------- scripts/mod/modpost.h | 1 + scripts/remove-stale-files | 4 + 23 files changed, 283 insertions(+), 559 deletions(-) delete mode 100644 arch/ia64/include/asm/export.h delete mode 100755 scripts/adjust_autoksyms.sh delete mode 100755 scripts/check-local-export delete mode 100755 scripts/gen_autoksyms.sh delete mode 100755 scripts/gen_ksymdeps.sh