Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp6446759ybv; Wed, 12 Feb 2020 12:22:59 -0800 (PST) X-Google-Smtp-Source: APXvYqyZmXweHFHnzWetqwzPqJMLNFofLvYhC9sX4q0tIOCxP3gMN6Z12PnVFM960aLspxLpuEl1 X-Received: by 2002:a9d:7509:: with SMTP id r9mr10234783otk.270.1581538978915; Wed, 12 Feb 2020 12:22:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581538978; cv=none; d=google.com; s=arc-20160816; b=sGHe3B8kUABf8UQ0cIciKsvKAuu8GKb29WMLfmXxvO98iPX9TDkEYt54eIIGSnp95a iHExJyNhFQVpEOH//neFfEsMYwO97fbLtZzsrjwDR5v8zM13fytOiVQd9EwuhStt/GuL 5kDFG1F1Ah959filkcOviZH1sLcyzvq4IuhMnTGE8cdcO4vlz+8sva7q+moWb3wJHRfT ndcefhq8b2vjtkKkBcwnGQDwuLlYvDCYf6JWjpoSRm8WVM2sL99z4dKKPG+hKI7Iwj/Y XbXi17b+dU3Lw+jZcFv52o+pfzc5hc1ggFU1hmbgSB5rFNRxIrQFvl+Cc3IxyqQmUa15 Hztw== 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=2DNPHWOep8QcJ95jz+HxlpBWa5iebLnkE4jUyw5CpGo=; b=oNLiWIfiwMqUKHc5o+Qg4gG46uCwUyb+kVqZbS8Iy2Sg8oiW5/lpewFyZf0GYLNwBl J98B/7uZ6m5VF52VA5DuhrWNHrmOtzXUYoQ6c3YtDdT7dM/giIbgtA/4NFp8xY5A3uax 6zCzqoxITkCInN1PXM9x+Wi/XayWjK9sY7J1kE9o+DX9dWkLeVo/WCujy9yePTnT5gyJ nB6BtiQRl20e5uwDIOyliIsKKw9D2HKpeKdbTnmpQp0ZCp5ByxcOhfSRtQzN+k6Twg/s 8iix4vE6yWxAifK9xyxONIwtB9N96Usc46b+Qh2Ilxz+NMicYsHVSaw07nKt1qpJNq8+ 89Xg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=AmE1UPqT; 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 l26si730255oti.152.2020.02.12.12.22.46; Wed, 12 Feb 2020 12:22:58 -0800 (PST) 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=AmE1UPqT; 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 S1729121AbgBLUV4 (ORCPT + 99 others); Wed, 12 Feb 2020 15:21:56 -0500 Received: from mail-wm1-f73.google.com ([209.85.128.73]:41241 "EHLO mail-wm1-f73.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727439AbgBLUVz (ORCPT ); Wed, 12 Feb 2020 15:21:55 -0500 Received: by mail-wm1-f73.google.com with SMTP id f207so1416536wme.6 for ; Wed, 12 Feb 2020 12:21:52 -0800 (PST) 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=2DNPHWOep8QcJ95jz+HxlpBWa5iebLnkE4jUyw5CpGo=; b=AmE1UPqTX9ECKV1YOGGpTha7cgV8T6d/rPVacICrc/OXRYCbnBHxDeSLdQeDusdnhl pg616Kby5BUfC/GvJbkaSRg0+yW583b0Hpzvv04B12STCq0v5jMx/rj1DfyecIMEYyn6 P8x/1+EELKbWBjW+op+08FEyAhUBcv8Dn0Q3aE73P8wgao1vwzR8y1VgvGygT/b9VXg+ +/NfD9LLHWw0Us14UJ8xwrqwXfe40qCQD1giLHfF+XywXDa55D3G8MTjROb3yiRYt6iT xpUL+UtzHu8lETu8k0iRcrOkOh9QnGat/DvTebiMkllmPTemjiedUdsnvOivFVCGAHw0 JqCw== 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=2DNPHWOep8QcJ95jz+HxlpBWa5iebLnkE4jUyw5CpGo=; b=UV5Jp11Ff8X9HKOP3o1bCFCwK/a3kCOnqgwf88OjuZeFh250A/EEJo7xd9ja5djQSj vUoocTUZjfQPbRb40JbhrygiBLa04iPE9vshGE1gcRLwllDk/2HjV31vRugQFcnnPzao b6B9MmBjehXncpKheyGREb/Jz53dAEec+TRgM1bEJMRzfwPSDL3muM+qsZXvSPKq1kbR qKkhkuxnoUwsu4ukBguW0U+toOeZOoLIEGqbOS6W6EQx+TEETL+EUZn9sn/5w8Jucxmj +OYYk+u85AuySN7PltXfX1vc4liYZTzaBPVqIoQDHk1tOE8FkijioiFPoOaoGhEaCyqE MoOA== X-Gm-Message-State: APjAAAX1JHyPzDeS1U4FqPv/jaTSmJvoED7LAqUHILBH9RfVtnNALZ9e 6u5WjtSoEuNQG1xt6hP6+EYa1Zk9rw2y X-Received: by 2002:a5d:4f0f:: with SMTP id c15mr17922390wru.251.1581538911573; Wed, 12 Feb 2020 12:21:51 -0800 (PST) Date: Wed, 12 Feb 2020 20:21:40 +0000 In-Reply-To: <20200212202140.138092-1-qperret@google.com> Message-Id: <20200212202140.138092-4-qperret@google.com> Mime-Version: 1.0 References: <20200212202140.138092-1-qperret@google.com> X-Mailer: git-send-email 2.25.0.225.g125e21ebc7-goog Subject: [PATCH v4 3/3] kbuild: generate autoksyms.h early From: Quentin Perret To: masahiroy@kernel.org, nico@fluxnic.net Cc: linux-kernel@vger.kernel.org, linux-kbuild@vger.kernel.org, maennich@google.com, kernel-team@android.com, jeyu@kernel.org, hch@infradead.org, qperret@google.com 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 When doing a cold build, autoksyms.h starts empty, and is updated late in the build process to have visibility over the symbols used by in-tree drivers. But since the symbol whitelist is known upfront, it can be used to pre-populate autoksyms.h and maximize the amount of code that can be compiled to its final state in a single pass, hence reducing build time. Do this by using gen_autoksyms.sh to initialize autoksyms.h instead of creating an empty file. Signed-off-by: Quentin Perret --- Makefile | 7 +++++-- scripts/gen_autoksyms.sh | 3 ++- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/Makefile b/Makefile index 84b71845c43f..17b7e7f441bd 100644 --- a/Makefile +++ b/Makefile @@ -1062,9 +1062,12 @@ endif autoksyms_h := $(if $(CONFIG_TRIM_UNUSED_KSYMS), include/generated/autoksyms.h) +quiet_cmd_autoksyms_h = GEN $@ + cmd_autoksyms_h = mkdir -p $(dir $@); $(CONFIG_SHELL) \ + $(srctree)/scripts/gen_autoksyms.sh $@ + $(autoksyms_h): - $(Q)mkdir -p $(dir $@) - $(Q)touch $@ + $(call cmd,autoksyms_h) ARCH_POSTLINK := $(wildcard $(srctree)/arch/$(SRCARCH)/Makefile.postlink) diff --git a/scripts/gen_autoksyms.sh b/scripts/gen_autoksyms.sh index 2cea433616a8..f52b93ad122c 100755 --- a/scripts/gen_autoksyms.sh +++ b/scripts/gen_autoksyms.sh @@ -32,7 +32,8 @@ cat > "$output_file" << EOT EOT -sed 's/ko$/mod/' modules.order | +[ -f modules.order ] && modlist=modules.order || modlist=/dev/null +sed 's/ko$/mod/' $modlist | xargs -n1 sed -n -e '2{s/ /\n/g;/^$/!p;}' -- | cat - "$ksym_wl" | sort -u | -- 2.25.0.225.g125e21ebc7-goog