Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp2906910pxa; Tue, 25 Aug 2020 06:40:30 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwChz/lUvUBkOBdqrXUGcKjVplhHq7l46EPkNFHBtGz6t1Czle6GCFH+KbREnNHqUM55uBY X-Received: by 2002:a17:906:35d6:: with SMTP id p22mr2482717ejb.221.1598362830115; Tue, 25 Aug 2020 06:40:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1598362830; cv=none; d=google.com; s=arc-20160816; b=v+f/NvwaBrE7VGH3p3Eqz3MZbEGEdjmBKP5f68exR/L+i5cEhZNv+dOhEaHL+ab11B bpEwy9Rle0ZAqJFxCtx9KfQVR+LLGX9lh0explnVHzqtpe2CtZ5VaPSIAHJpsGEKBzix J6njnGadkhyEFtA63WudGd7EQrXaJf5b6V6vFd+QxKUFaB7vSc4CGVPO+fH6ic6DqNG2 CJzam7XZvxfN2qkEyinZgN2QVm9U+q1LPd+pTtPwPpczjmrL4/Z1HvZ2sZFCpL413tF7 jjjuGBgwSlqIaWJNT/b5BNzc5cpDzidnmPLo6AYTdKQlIwTTN4W/F/SWvPbJgCSXbEPw ioGQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=6Lt1zqqhm2CGmlHDeQ3bT35ThL4m7L3OGAZXD3Jlb4w=; b=WkVba/Z+kB/QCEfvWaFrGefLxmD1+BOkiGNjg25grbTNunO66TEn70baQslu24NF6l 9+ngtZF6lenwLVMakiLYV+L0IYCl5bjVt+ix6Mhej8DwISHGpmDuREy8jGn1B2xgl7ZA 6et4/kn3i8VeJmg2Rt0/6AFIvQTAFYQO3aN3B3KP+1/IzvbKGHMPDHL0KuAEKSZiSi2N a5vnZ78oTs8uF4pnnmTkvVSWKIiw6D2mL9zWJuPQUWnOVSpQ0Ts0nUIPffkC14yB6muE sX55NV52Fpuo0Phnee4XJtAWepPjOSGDzx0p3NWp13sOXiLmO+eeVRILZS5tutPYVabG z9pQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=NwwsLrSA; 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=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t11si2450898ejb.154.2020.08.25.06.40.07; Tue, 25 Aug 2020 06:40:30 -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=@redhat.com header.s=mimecast20190719 header.b=NwwsLrSA; 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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728641AbgHYMr6 (ORCPT + 99 others); Tue, 25 Aug 2020 08:47:58 -0400 Received: from us-smtp-1.mimecast.com ([205.139.110.61]:37318 "EHLO us-smtp-delivery-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1728538AbgHYMru (ORCPT ); Tue, 25 Aug 2020 08:47:50 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1598359669; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=6Lt1zqqhm2CGmlHDeQ3bT35ThL4m7L3OGAZXD3Jlb4w=; b=NwwsLrSAZ5UNNPzCfdvE2Y4Iqn0KDTYnUmz4a9pz/mHCCXLn3HjOCUXGzSsSH+NSJw1cUH ufczHbZSiAwxUmDAlJrvjR1hyizwT38FHYoSL3QPUsNUa2hr/l4EAflnHSVTJ1GhqVAuPN 0xB6n1Ef+XBaOtTwZJrmDHknacWB2vU= Received: from mail-wr1-f71.google.com (mail-wr1-f71.google.com [209.85.221.71]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-186-4bL_0hIYPiu9SYDtH_MZrQ-1; Tue, 25 Aug 2020 08:47:48 -0400 X-MC-Unique: 4bL_0hIYPiu9SYDtH_MZrQ-1 Received: by mail-wr1-f71.google.com with SMTP id k23so2925939wrd.5 for ; Tue, 25 Aug 2020 05:47:47 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=6Lt1zqqhm2CGmlHDeQ3bT35ThL4m7L3OGAZXD3Jlb4w=; b=RB709UsAYbHkC1SyIsUmucmjIZeTbCF/11V4l/law6nazearK5E2bePhVkrxFtYrf3 poeDRSyX3G80/u3kNEDF1U4zxuSavkLsUXxxvP409Z/Wg2RBsb8XJ1j23DZukOrtJqMg honwMJBgHIKgHk1bHXI17RTasOVcE1jx8TYxG5Z8Z4ltx4Y1NJm56+xOC4hkjqr8AExU +PGcr6NFmtWqSlYBD7hv6MD8Xbk5xwOsl7WZZgSQCjMsfdVcypwbKwKcgxJGJ9hCh8q6 uYGN96c7mt5AuOL/pZInjge/noGjicEoIPooiRF+sOJj1sxQJB9VScMG35kNRbkSVnoq 3rTw== X-Gm-Message-State: AOAM530WnXzzW2jfHPCAHXMjVpqvNdIYbRGmD2HZNo9RSBy1HOJKzD++ /5otfTe0szdni8GJQIJgoBnH3pz7ta2qL0bRkWHcIgnRqhc2zeUQcP0+sK0/SyxAqDAygAp8wUE tkxL2CnNiGoyld/4M0nFQMFiK X-Received: by 2002:adf:b18d:: with SMTP id q13mr10436835wra.256.1598359666292; Tue, 25 Aug 2020 05:47:46 -0700 (PDT) X-Received: by 2002:adf:b18d:: with SMTP id q13mr10436815wra.256.1598359666000; Tue, 25 Aug 2020 05:47:46 -0700 (PDT) Received: from redfedo.redhat.com ([2a01:cb14:499:3d00:cd47:f651:9d80:157a]) by smtp.gmail.com with ESMTPSA id u6sm27469306wrn.95.2020.08.25.05.47.45 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Aug 2020 05:47:45 -0700 (PDT) From: Julien Thierry To: linux-kernel@vger.kernel.org Cc: jpoimboe@redhat.com, peterz@infradead.org, mbenes@suse.cz, benh@kernel.crashing.org, Julien Thierry Subject: [PATCH v4 1/4] objtool: Move object file loading out of check Date: Tue, 25 Aug 2020 13:47:39 +0100 Message-Id: <20200825124742.29782-2-jthierry@redhat.com> X-Mailer: git-send-email 2.21.3 In-Reply-To: <20200825124742.29782-1-jthierry@redhat.com> References: <20200825124742.29782-1-jthierry@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Structure objtool_file can be used by different subcommands. In fact it already is, by check and orc. Provide a function that allows to initialize objtool_file, that builtin can call, without relying on check to do the correct setup for them and explicitly hand the objtool_file to them. Reviewed-by: Miroslav Benes Signed-off-by: Julien Thierry --- tools/objtool/builtin-check.c | 7 ++++++- tools/objtool/builtin-orc.c | 8 ++++++- tools/objtool/check.c | 39 +++++++++++------------------------ tools/objtool/objtool.c | 29 ++++++++++++++++++++++++++ tools/objtool/objtool.h | 4 +++- tools/objtool/weak.c | 4 +--- 6 files changed, 58 insertions(+), 33 deletions(-) diff --git a/tools/objtool/builtin-check.c b/tools/objtool/builtin-check.c index 7a44174967b5..0126ec3bb6c9 100644 --- a/tools/objtool/builtin-check.c +++ b/tools/objtool/builtin-check.c @@ -41,6 +41,7 @@ const struct option check_options[] = { int cmd_check(int argc, const char **argv) { const char *objname, *s; + struct objtool_file *file; argc = parse_options(argc, argv, check_options, check_usage, 0); @@ -53,5 +54,9 @@ int cmd_check(int argc, const char **argv) if (s && !s[9]) vmlinux = true; - return check(objname, false); + file = objtool_open_read(objname); + if (!file) + return 1; + + return check(file, false); } diff --git a/tools/objtool/builtin-orc.c b/tools/objtool/builtin-orc.c index b1dfe2007962..3979f275a775 100644 --- a/tools/objtool/builtin-orc.c +++ b/tools/objtool/builtin-orc.c @@ -31,13 +31,19 @@ int cmd_orc(int argc, const char **argv) usage_with_options(orc_usage, check_options); if (!strncmp(argv[0], "gen", 3)) { + struct objtool_file *file; + argc = parse_options(argc, argv, check_options, orc_usage, 0); if (argc != 1) usage_with_options(orc_usage, check_options); objname = argv[0]; - return check(objname, true); + file = objtool_open_read(objname); + if (!file) + return 1; + + return check(file, true); } if (!strcmp(argv[0], "dump")) { diff --git a/tools/objtool/check.c b/tools/objtool/check.c index e034a8f24f46..ef8e9300e1a3 100644 --- a/tools/objtool/check.c +++ b/tools/objtool/check.c @@ -27,7 +27,6 @@ struct alternative { bool skip_orig; }; -const char *objname; struct cfi_init_state initial_func_cfi; struct instruction *find_insn(struct objtool_file *file, @@ -2777,36 +2776,22 @@ static int validate_reachable_instructions(struct objtool_file *file) return 0; } -static struct objtool_file file; - -int check(const char *_objname, bool orc) +int check(struct objtool_file *file, bool orc) { int ret, warnings = 0; - objname = _objname; - - file.elf = elf_open_read(objname, O_RDWR); - if (!file.elf) - return 1; - - INIT_LIST_HEAD(&file.insn_list); - hash_init(file.insn_hash); - file.c_file = !vmlinux && find_section_by_name(file.elf, ".comment"); - file.ignore_unreachables = no_unreachable; - file.hints = false; - arch_initial_func_cfi_state(&initial_func_cfi); - ret = decode_sections(&file); + ret = decode_sections(file); if (ret < 0) goto out; warnings += ret; - if (list_empty(&file.insn_list)) + if (list_empty(&file->insn_list)) goto out; if (vmlinux && !validate_dup) { - ret = validate_vmlinux_functions(&file); + ret = validate_vmlinux_functions(file); if (ret < 0) goto out; @@ -2815,41 +2800,41 @@ int check(const char *_objname, bool orc) } if (retpoline) { - ret = validate_retpoline(&file); + ret = validate_retpoline(file); if (ret < 0) return ret; warnings += ret; } - ret = validate_functions(&file); + ret = validate_functions(file); if (ret < 0) goto out; warnings += ret; - ret = validate_unwind_hints(&file, NULL); + ret = validate_unwind_hints(file, NULL); if (ret < 0) goto out; warnings += ret; if (!warnings) { - ret = validate_reachable_instructions(&file); + ret = validate_reachable_instructions(file); if (ret < 0) goto out; warnings += ret; } if (orc) { - ret = create_orc(&file); + ret = create_orc(file); if (ret < 0) goto out; - ret = create_orc_sections(&file); + ret = create_orc_sections(file); if (ret < 0) goto out; } - if (file.elf->changed) { - ret = elf_write(file.elf); + if (file->elf->changed) { + ret = elf_write(file->elf); if (ret < 0) goto out; } diff --git a/tools/objtool/objtool.c b/tools/objtool/objtool.c index 58fdda510653..84e89e79be9b 100644 --- a/tools/objtool/objtool.c +++ b/tools/objtool/objtool.c @@ -22,6 +22,8 @@ #include #include "builtin.h" +#include "objtool.h" +#include "warn.h" struct cmd_struct { const char *name; @@ -39,6 +41,33 @@ static struct cmd_struct objtool_cmds[] = { bool help; +const char *objname; +static struct objtool_file file; + +struct objtool_file *objtool_open_read(const char *_objname) +{ + if (objname) { + if (strcmp(objname, _objname)) { + WARN("won't handle more than one file at a time"); + return NULL; + } + return &file; + } + objname = _objname; + + file.elf = elf_open_read(objname, O_RDWR); + if (!file.elf) + return NULL; + + INIT_LIST_HEAD(&file.insn_list); + hash_init(file.insn_hash); + file.c_file = !vmlinux && find_section_by_name(file.elf, ".comment"); + file.ignore_unreachables = no_unreachable; + file.hints = false; + + return &file; +} + static void cmd_usage(void) { unsigned int i, longest = 0; diff --git a/tools/objtool/objtool.h b/tools/objtool/objtool.h index 528028a66816..42b27c4ed683 100644 --- a/tools/objtool/objtool.h +++ b/tools/objtool/objtool.h @@ -19,7 +19,9 @@ struct objtool_file { bool ignore_unreachables, c_file, hints, rodata; }; -int check(const char *objname, bool orc); +struct objtool_file *objtool_open_read(const char *_objname); + +int check(struct objtool_file *file, bool orc); int orc_dump(const char *objname); int create_orc(struct objtool_file *file); int create_orc_sections(struct objtool_file *file); diff --git a/tools/objtool/weak.c b/tools/objtool/weak.c index 942ea5e8ac36..82698319f008 100644 --- a/tools/objtool/weak.c +++ b/tools/objtool/weak.c @@ -17,9 +17,7 @@ return ENOSYS; \ }) -const char __weak *objname; - -int __weak check(const char *_objname, bool orc) +int __weak check(struct objtool_file *file, bool orc) { UNSUPPORTED("check subcommand"); } -- 2.21.3