Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp1562857pxj; Fri, 21 May 2021 18:28:37 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzE6TbuP9p46M1a/jQ+jCKgyr/X49j4aZxdUlXjUitTzF+dHa2wffqYUt3dwqI/VuffURev X-Received: by 2002:a05:6638:3010:: with SMTP id r16mr8543890jak.126.1621646917017; Fri, 21 May 2021 18:28:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621646917; cv=none; d=google.com; s=arc-20160816; b=Ls7zUo2lyAha0QabzhSPUkU8bY9bT6V0Ic4YtI9wxK8oBMVCvbjfCaXTwXTXCGwu82 lPDHCE7k5+GlHuUrd5iQQmmV27D0ZWPcGhwfJmx5wmPHhhEaz31Ev88R+x1hRhMyXGIk yeXThbnB7+QenbTKs0q/0L5VreA5PzxiMq2L/FrEEI5gejWGyLrhfH7bVNlJGfv7qMFH KMb6uHsllLLgI4nYDbmbfYFC3xxIiHasLAzr0bdW3obCzCVC2I7gvPyUEz5z2Yxv4fhx /iaaO4QSaZtfMngbzqnI7klsMFU0ItW/vUi1vIa58RD2eN3F6FlTm2um5ZF+1vyCgvU9 1q1w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:references:mime-version :message-id:in-reply-to:date:dkim-signature; bh=gS3/FjH30criEdlZq0ZHdAnAGJSA0ILT1HmCoVmE9Yc=; b=ff2BzdaDIUAsR9JG4ukgol934KPJGRylJPTao9fibcV1yBPs9bGTwciFcJOVoxOs48 ORjBb83IEHDMsJPtgtHszOdiXwAYmkPTxEuBdToASqpYgKs4PFuqcidYtqkWaCaq3iYM eLpSoCZOazVzrVpTKeRrcCQNTVyzoYMQ4S7Wtm1RwdMDZdCOvnhUM1NBtvvnBwLRtor+ otwmiA3uV9MUphoUWEC9bXAEKPZz5qwZkVXLeOd8963N6dkZp/ZClnauF7QpckhQ3x4K CgQyxvtTm9S+Ox4qiHO3lR0BefO71j4gc9fQzKzxNRf4ohYSrXl4PaP/9j3XxxvkraHw mWEg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=aV10v99J; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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. [23.128.96.18]) by mx.google.com with ESMTP id y15si7053352ilj.128.2021.05.21.18.28.23; Fri, 21 May 2021 18:28:37 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=aV10v99J; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S230442AbhEVB2D (ORCPT + 99 others); Fri, 21 May 2021 21:28:03 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48704 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230431AbhEVB2C (ORCPT ); Fri, 21 May 2021 21:28:02 -0400 Received: from mail-qv1-xf49.google.com (mail-qv1-xf49.google.com [IPv6:2607:f8b0:4864:20::f49]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3B74FC06138B for ; Fri, 21 May 2021 18:26:31 -0700 (PDT) Received: by mail-qv1-xf49.google.com with SMTP id i14-20020a0cf10e0000b02901eeced6480dso17534242qvl.4 for ; Fri, 21 May 2021 18:26:31 -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=gS3/FjH30criEdlZq0ZHdAnAGJSA0ILT1HmCoVmE9Yc=; b=aV10v99JMPHFg1NGBvCWnUWFb+H8K8fj4R2z1KjHTliOlyuuNv7N+E++NFeU+qFtZp 3+FqCv1he5VC08dsXqqBEoOp6dlq+Jim+eqm8bBhg3Wa39Dqo7D3c93BffdlaEcWXif9 gKyWuMLV4UfrKS62gts+QsiUfFhgZSM0wvBZ1vwWmHDaOkAIzh5gikMRUosZD8liZYjE BLZ4d9v3A4E2C1pTRMRgb2VRbAyQMKVD/JqJSvxrxPWl8UN18mHMBEgV8ftxpiAmIuWT dmxDu6tCcGafJAMnYk82Zo6sopbp3ZB6XTbx9MrZ3STv27IcXF//ymaHhlTkLron6P5f L8Ng== 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=gS3/FjH30criEdlZq0ZHdAnAGJSA0ILT1HmCoVmE9Yc=; b=F7xSQfKvwA0Rd0mKbst+sx4ftFrPBejRNDimLSsYqRWnAfZ15KiFqfnKZrq+3E56Dy Y4EgyIlzJ7ZUEpGr6gV49zUkZ1SXAmetQfpE0e7bpm/DtPBigD0hBc0GgjU5f/k03bFi FFn8p3d0mKrkbz392Y+jbstEPufm5Ee5hRyS/2I9r87ZKctKrkIMd5h1wgeYxBbQmmsC W/jpsBDaPwKwGuLnDxo0+TNj0kIjAawCIt/O8STi8qAOY6of2cr68YGfV3XLPY/74Euc K1kb1fR7wsbdpqmQMwYmdH0lhVyDUMDVnxz2+bjcbi2SLFOzT5kZAEpavNkePyYRVylB 1N1A== X-Gm-Message-State: AOAM532dVOgvjiortkuWlwK95tBAMWFTivtVN4AQ56YZKs7rSSY+voSC IF0z3hMjrDwKLXuRDLoDk5QKia3EIHBk9Z5SPto= X-Received: from ndesaulniers1.mtv.corp.google.com ([2620:15c:211:202:e55d:7de8:da36:30e8]) (user=ndesaulniers job=sendgmr) by 2002:a0c:f64e:: with SMTP id s14mr16600523qvm.56.1621646790253; Fri, 21 May 2021 18:26:30 -0700 (PDT) Date: Fri, 21 May 2021 18:26:24 -0700 In-Reply-To: Message-Id: <20210522012626.2811297-1-ndesaulniers@google.com> Mime-Version: 1.0 References: X-Mailer: git-send-email 2.31.1.818.g46aad6cb9e-goog Subject: [PATCH v2] Makefile: fix GDB warning with CONFIG_RELR From: Nick Desaulniers To: Will Deacon Cc: Catalin Marinas , linux-arm-kernel@lists.infradead.org, Lee Jones , Masahiro Yamada , clang-built-linux , Fangrui Song , Elliot Berman , Sami Tolvanen , Peter Collingbourne , Michal Marek , linux-kbuild@vger.kernel.org, linux-kernel@vger.kernel.org, Nick Desaulniers , Nathan Chancellor Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org GDB produces the following warning when debugging kernels built with CONFIG_RELR: BFD: /android0/linux-next/vmlinux: unknown type [0x13] section `.relr.dyn' when loading a kernel built with CONFIG_RELR into GDB. It can also prevent debugging symbols using such relocations. Peter sugguests: [That flag] means that lld will use dynamic tags and section type numbers in the OS-specific range rather than the generic range. The kernel itself doesn't care about these numbers; it determines the location of the RELR section using symbols defined by a linker script. Link: https://github.com/ClangBuiltLinux/linux/issues/1057 Suggested-by: Peter Collingbourne Reviewed-by: Nathan Chancellor Signed-off-by: Nick Desaulniers --- Changes V1 -> V2: * rebase * pick up Nathan's reviewed by tag. Makefile | 2 +- scripts/tools-support-relr.sh | 3 ++- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/Makefile b/Makefile index 0ed7e061c8e9..2dbb56f831d4 100644 --- a/Makefile +++ b/Makefile @@ -1031,7 +1031,7 @@ LDFLAGS_vmlinux += $(call ld-option, -X,) endif ifeq ($(CONFIG_RELR),y) -LDFLAGS_vmlinux += --pack-dyn-relocs=relr +LDFLAGS_vmlinux += --pack-dyn-relocs=relr --use-android-relr-tags endif # We never want expected sections to be placed heuristically by the diff --git a/scripts/tools-support-relr.sh b/scripts/tools-support-relr.sh index 45e8aa360b45..cb55878bd5b8 100755 --- a/scripts/tools-support-relr.sh +++ b/scripts/tools-support-relr.sh @@ -7,7 +7,8 @@ trap "rm -f $tmp_file.o $tmp_file $tmp_file.bin" EXIT cat << "END" | $CC -c -x c - -o $tmp_file.o >/dev/null 2>&1 void *p = &p; END -$LD $tmp_file.o -shared -Bsymbolic --pack-dyn-relocs=relr -o $tmp_file +$LD $tmp_file.o -shared -Bsymbolic --pack-dyn-relocs=relr \ + --use-android-relr-tags -o $tmp_file # Despite printing an error message, GNU nm still exits with exit code 0 if it # sees a relr section. So we need to check that nothing is printed to stderr. base-commit: 45af60e7ced07ae3def41368c3d260dbf496fbce -- 2.31.1.818.g46aad6cb9e-goog