Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp1018534ybg; Wed, 10 Jun 2020 21:33:10 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyFuz9VrupRVdcitNx4Yywy6mcFx7oeZzZPVh1XjVogR75uwesb43vYdSKCZOHL7OxMRyCz X-Received: by 2002:a17:906:5652:: with SMTP id v18mr6373715ejr.72.1591849990180; Wed, 10 Jun 2020 21:33:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1591849990; cv=none; d=google.com; s=arc-20160816; b=mNAsUH8k8LGdOq3MjuFiLLlmRGIz335NBtXG4h4cjPi0yyLgJK7oGIrvmkaqnlVDvX j0KYsKHmy9Sn3U2g4WU9o+wO/qfj1pLr7lBtT1BV6jPYHqBTsHI02/x+809FGtl0q1t8 Xylzems97eeLMriYPVh35U/tdabzYPZinD/06ygSq/kzzbe+8c3L8JcK6AXnE0Xl97NO wUUaUfcw1SfiZxDZc/62V3mL5lVI0EAo+x6Cxzo8Ni+0XwYOcRdc1LdQ8jebacMGBF6i iNi276ISKHJuf5okHA04cCzpRSvHgj8NK2qnf4omnSYMQP0p8e9RTSKh8RgRsXqpVi/D b4uQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:dkim-filter; bh=Rqj0PR+NrzTyHr6jbTe+YqJeUIzjprQ19xAuqb8Gon0=; b=1KJm0eNZFXeGfXsZGMWEwuh/RqO29yWx1jDyt2fWzr/wzqpFwT6gB9olzccEauFfvL hld0frThYpwn5y0Sy3kTCyDj5q2MTm+Kttf5vG6YOgQvFJHi8qd2qsDqtN9iUOn+U5CG QwuqHPMiZFQnW/++Tcb5PijwM/DIZmuiAe0MzrRED5C7JRLGu28a3t1RQXHIu3SwIHPc zOUyOU7tJ6Ylbt+yfHARRC/IaJnclpvlMA5ikvwKPXQD0lTcxOnmjJ6Rn7u6EtESRQXY +6zpbl7D5kuED9U+izhyOTlAtTc/O4+XLp9tnXD74CiuEDCQ6rvTtCRN6PzU5dxpyYv6 wl/w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linux.microsoft.com header.s=default header.b=eY8LDytR; 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=NONE sp=NONE dis=NONE) header.from=linux.microsoft.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 7si966042edj.329.2020.06.10.21.32.47; Wed, 10 Jun 2020 21:33:10 -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=@linux.microsoft.com header.s=default header.b=eY8LDytR; 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=NONE sp=NONE dis=NONE) header.from=linux.microsoft.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1725887AbgFKE2B (ORCPT + 99 others); Thu, 11 Jun 2020 00:28:01 -0400 Received: from linux.microsoft.com ([13.77.154.182]:51786 "EHLO linux.microsoft.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725300AbgFKE2B (ORCPT ); Thu, 11 Jun 2020 00:28:01 -0400 Received: from linuxonhyperv3.guj3yctzbm1etfxqx2vob5hsef.xx.internal.cloudapp.net (linux.microsoft.com [13.77.154.182]) by linux.microsoft.com (Postfix) with ESMTPSA id 7C40E20B4778; Wed, 10 Jun 2020 21:28:00 -0700 (PDT) DKIM-Filter: OpenDKIM Filter v2.11.0 linux.microsoft.com 7C40E20B4778 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linux.microsoft.com; s=default; t=1591849680; bh=Rqj0PR+NrzTyHr6jbTe+YqJeUIzjprQ19xAuqb8Gon0=; h=From:To:Cc:Subject:Date:From; b=eY8LDytRUY6ueet/V33x1QnLu9Wb4g+LRFvSUFTOqLk49ZWNpyvZwr6lqHLFWdKgW Sv18O0I0/dLH3ahaQrkiH43Hj2CeJA89Zr/S3bYmE7WGa6Q94BZkmDbsSqIvse7Cxs sOL3wmR+fbEuWKrsXtbNKxHf0uagG1Y59DiwmoKY= From: Vijay Balakrishna To: Dave Young , Baoquan He Cc: Vivek Goyal , kexec@lists.infradead.org, linux-kernel@vger.kernel.org, clang-built-linux@googlegroups.com, Tyler Hicks Subject: [PATCH v2][RFC] kdump: append kernel build-id string to VMCOREINFO Date: Wed, 10 Jun 2020 21:27:52 -0700 Message-Id: <1591849672-34104-1-git-send-email-vijayb@linux.microsoft.com> X-Mailer: git-send-email 1.8.3.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Make kernel GNU build-id available in VMCOREINFO. Having build-id in VMCOREINFO facilitates presenting appropriate kernel namelist image with debug information file to kernel crash dump analysis tools. Currently VMCOREINFO lacks uniquely identifiable key for crash analysis automation. Regarding if this patch is necessary or matching of linux_banner and OSRELEASE in VMCOREINFO employed by crash(8) meets the need -- IMO, build-id approach more foolproof, in most instances it is a cryptographic hash generated using internal code/ELF bits unlike kernel version string upon which linux_banner is based that is external to the code. I feel each is intended for a different purpose. Also OSRELEASE is not suitable when two different kernel builds from same version with different features enabled. Currently for most linux (and non-linux) systems build-id can be extracted using standard methods for file types such as user mode crash dumps, shared libraries, loadable kernel modules etc., This is an exception for linux kernel dump. Having build-id in VMCOREINFO brings some uniformity for automation tools. Signed-off-by: Vijay Balakrishna --- Changes since v2: ----------------- - v1 was sent out as a single patch which can be seen here: http://lists.infradead.org/pipermail/kexec/2020-June/025202.html - moved justification to commit commit log - renamed 'g_build_id' to 'note_sec' - fixed format specifier in pr_warn() from '%lu' to '%u' (failed to catch warning in v1) include/linux/crash_core.h | 6 +++++ kernel/crash_core.c | 50 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 56 insertions(+) diff --git a/include/linux/crash_core.h b/include/linux/crash_core.h index 525510a9f965..6594dbc34a37 100644 --- a/include/linux/crash_core.h +++ b/include/linux/crash_core.h @@ -38,6 +38,8 @@ phys_addr_t paddr_vmcoreinfo_note(void); #define VMCOREINFO_OSRELEASE(value) \ vmcoreinfo_append_str("OSRELEASE=%s\n", value) +#define VMCOREINFO_BUILD_ID(value) \ + vmcoreinfo_append_str("BUILD-ID=%s\n", value) #define VMCOREINFO_PAGESIZE(value) \ vmcoreinfo_append_str("PAGESIZE=%ld\n", value) #define VMCOREINFO_SYMBOL(name) \ @@ -64,6 +66,10 @@ extern unsigned char *vmcoreinfo_data; extern size_t vmcoreinfo_size; extern u32 *vmcoreinfo_note; +/* raw contents of kernel .notes section */ +extern const void __start_notes __weak; +extern const void __stop_notes __weak; + Elf_Word *append_elf_note(Elf_Word *buf, char *name, unsigned int type, void *data, size_t data_len); void final_note(Elf_Word *buf); diff --git a/kernel/crash_core.c b/kernel/crash_core.c index 9f1557b98468..64ac359cd17e 100644 --- a/kernel/crash_core.c +++ b/kernel/crash_core.c @@ -11,6 +11,8 @@ #include #include +#include + /* vmcoreinfo stuff */ unsigned char *vmcoreinfo_data; size_t vmcoreinfo_size; @@ -376,6 +378,53 @@ phys_addr_t __weak paddr_vmcoreinfo_note(void) } EXPORT_SYMBOL(paddr_vmcoreinfo_note); +#define NOTES_SIZE (&__stop_notes - &__start_notes) +#define BUILD_ID_MAX SHA1_DIGEST_SIZE +#define NT_GNU_BUILD_ID 3 + +struct elf_note_section { + struct elf_note n_hdr; + u8 n_data[]; +}; + +/* + * Add build ID from .notes section as generated by the GNU ld(1) + * or LLVM lld(1) --build-id option. + */ +static void add_build_id_vmcoreinfo(void) +{ + char build_id[BUILD_ID_MAX * 2 + 1]; + int n_remain = NOTES_SIZE; + + while (n_remain >= sizeof(struct elf_note)) { + const struct elf_note_section *note_sec = + &__start_notes + NOTES_SIZE - n_remain; + const u32 n_namesz = note_sec->n_hdr.n_namesz; + + if (note_sec->n_hdr.n_type == NT_GNU_BUILD_ID && + n_namesz != 0 && + !strcmp((char *)¬e_sec->n_data[0], "GNU")) { + if (note_sec->n_hdr.n_descsz <= BUILD_ID_MAX) { + const u32 n_descsz = note_sec->n_hdr.n_descsz; + const u8 *s = ¬e_sec->n_data[n_namesz]; + + s = PTR_ALIGN(s, 4); + bin2hex(build_id, s, n_descsz); + build_id[2 * n_descsz] = '\0'; + VMCOREINFO_BUILD_ID(build_id); + return; + } + pr_warn("Build ID is too large to include in vmcoreinfo: %u > %u\n", + note_sec->n_hdr.n_descsz, + BUILD_ID_MAX); + return; + } + n_remain -= sizeof(struct elf_note) + + ALIGN(note_sec->n_hdr.n_namesz, 4) + + ALIGN(note_sec->n_hdr.n_descsz, 4); + } +} + static int __init crash_save_vmcoreinfo_init(void) { vmcoreinfo_data = (unsigned char *)get_zeroed_page(GFP_KERNEL); @@ -394,6 +443,7 @@ static int __init crash_save_vmcoreinfo_init(void) } VMCOREINFO_OSRELEASE(init_uts_ns.name.release); + add_build_id_vmcoreinfo(); VMCOREINFO_PAGESIZE(PAGE_SIZE); VMCOREINFO_SYMBOL(init_uts_ns); -- 2.26.2