Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp1728370pxk; Fri, 18 Sep 2020 23:45:59 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyJmjXJSNWWbCcKzSFBB6Sq3p/22mQZ09ynkxiw89e1jH2UqbeetW5JVo5QML+xWeJTkpN5 X-Received: by 2002:a17:906:6d92:: with SMTP id h18mr38905790ejt.405.1600497959486; Fri, 18 Sep 2020 23:45:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600497959; cv=none; d=google.com; s=arc-20160816; b=D2u64tezzx5VSRnq84XkvFd7fmpTdUmhYw/66uxYG3GLs6sQ08UHfdjD/3ydrVa9L0 83yAivrFMDu6cxY4c6f73LwsaRz7N3pkglZGCfqitskR3uqNVbKsI02DaXHXiO/k2wyC Ef85Y7ZMvCb/PFEx0uOkk6Iqi2e2i1AhR5i37rOIwIAHwoQD4woxStxNMNLjClnR0LKj JsGRo6fiJK6NrcVKki/KaBF2K3u+Xf22iPWsCPwMHUQ2NtnhTjxBRUYETgKUNEz4to4b NJh/UY08SSe4AkhHRVYUCrpTkvxFIL9uSeGJ8Le5pPjWDYT8mnxpi7ogALQaEsFRHvJW Mx4A== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=g5DNwEJpdlREbpxxNUWXwnzTcfAjTXzmIWah8QsBFAI=; b=ZIJ+vOiNmFSAd3u7rHMYp1RVkvfw9XT7jZOHsXx3XNgGd3OMb09oIZLqP2oRbkkn99 IeYjWnTN+VDwzWBSSeQSLf4bv2uuHGOXTRz+OMPjKFu98h55eygtv214bUeaMftPDFAt q58ieIAk0Dt8CYCikMFECzQO2fiwRDjwrqr+zyV56psAB4ysH/l6lAUE8LV66p7fkoFQ Sjw5+tbuDKLTPU2vRsJ9mon/m7qlPP/ipPiSFepQQUAcf++NQ9IBpw9CQQpokTLNBlO9 igDKWkIgy6RcZPdixY5iCbOYaN5lYmbupnqlHtH7zMQgWgavcEY5TVFhNrGjUoIoUkHm oQpg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=gcOYcGHH; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id qc23si3629421ejb.25.2020.09.18.23.45.34; Fri, 18 Sep 2020 23:45:59 -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=@gmail.com header.s=20161025 header.b=gcOYcGHH; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726174AbgISGlt (ORCPT + 99 others); Sat, 19 Sep 2020 02:41:49 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36254 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726097AbgISGls (ORCPT ); Sat, 19 Sep 2020 02:41:48 -0400 Received: from mail-wm1-x342.google.com (mail-wm1-x342.google.com [IPv6:2a00:1450:4864:20::342]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 32429C0613CE for ; Fri, 18 Sep 2020 23:41:48 -0700 (PDT) Received: by mail-wm1-x342.google.com with SMTP id e11so8047200wme.0 for ; Fri, 18 Sep 2020 23:41:48 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=g5DNwEJpdlREbpxxNUWXwnzTcfAjTXzmIWah8QsBFAI=; b=gcOYcGHH4MsI7f7Eh8FIRg1V4TNDV8TEC7JFMjCSiWUdFN3wLnF1BoqaW8824MYEpI AqGfGUtCN1Bw6s2WafciAgwz5NDFoMDPFWKkbJZNGIdPnUg26ZR9K/Chn9qyyonTOMF3 yTjwu+dP+oMlZLj+/t6ySUyjCSrzrvaaioNDjF1bivITW33PT84XyHQfXvXeC8xV3nKN D9/X6Pt0AVfKkYJqymQezH6gsI/d8p1i0lHCxAntMA68YQRxp/PuPkcv9wPlPMawuWgB lrTRl/7JrMywy071UWR5XihWXng2n8d/gp0znS/tJ7VTaXr+Hj3NgUzG8l2IbZcEICE6 5tow== 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=g5DNwEJpdlREbpxxNUWXwnzTcfAjTXzmIWah8QsBFAI=; b=QYLrx3w7Jn1rP2afpju5griFWyy59SOR/+K1jKCObmL+ut6o3lf8O+q5c/SAd9c8qj SP1nyNkin4Em/xqKdd7HTbMTtb24OSmHBJLhO+79hXyYi5XV72frTx1CpDJmXlvni7OG r1zI8Hk5gSsmqVNXU/heqxWP9ZZaUCQ9OjVqV8VAcdpSZnXUe6tfVtt6xAb733HV6U/4 pL7D1ahBOOExZxP/n8rtOznJU3CMzfSoABrsj6GlL+42by8AqeyVzRY4Cupu5qa93J2h 9ZJMbafZ9ZqtF+y7osUIFMP1hwxUkLnyMJ6FX6dnWtHITe5BCXS0B3Dyal3TbNsv+lgI NugQ== X-Gm-Message-State: AOAM531pIQl4rmTJIKQ52LcWqFQBpBM3xL5c+bb5bRN+mbUg3cqidk6n JULk+pVUjTCCPbfyJBKnwoie9K8FT4/Qol3E X-Received: by 2002:a1c:9e0e:: with SMTP id h14mr18723255wme.18.1600497706567; Fri, 18 Sep 2020 23:41:46 -0700 (PDT) Received: from localhost.localdomain ([2a02:a58:8532:8700:329c:23ff:fea8:6c81]) by smtp.gmail.com with ESMTPSA id l5sm9218927wmf.10.2020.09.18.23.41.44 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 18 Sep 2020 23:41:45 -0700 (PDT) From: Ilie Halip To: linux-kernel@vger.kernel.org Cc: Ilie Halip , Nick Desaulniers , Rong Chen , Marco Elver , Philip Li , Borislav Petkov , kasan-dev@googlegroups.com, x86@kernel.org, clang-built-linux@googlegroups.com, kbuild test robot , Josh Poimboeuf , Peter Zijlstra , Nathan Chancellor Subject: [PATCH v2] objtool: ignore unreachable trap after call to noreturn functions Date: Sat, 19 Sep 2020 09:41:18 +0300 Message-Id: <20200919064118.1899325-1-ilie.halip@gmail.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200918154840.h3xbspb5jq7zw755@treble> References: <20200918154840.h3xbspb5jq7zw755@treble> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org With CONFIG_UBSAN_TRAP enabled, the compiler may insert a trap instruction after a call to a noreturn function. In this case, objtool warns that the ud2 instruction is unreachable. This is a behavior seen with clang, from the oldest version capable of building the mainline x64_64 kernel (9.0), to the latest experimental version (12.0). objtool silences similar warnings (trap after dead end instructions), so so expand that check to include dead end functions. Cc: Nick Desaulniers Cc: Rong Chen Cc: Marco Elver Cc: Philip Li Cc: Borislav Petkov Cc: kasan-dev@googlegroups.com Cc: x86@kernel.org Cc: clang-built-linux@googlegroups.com BugLink: https://github.com/ClangBuiltLinux/linux/issues/1148 Link: https://lore.kernel.org/lkml/CAKwvOdmptEpi8fiOyWUo=AiZJiX+Z+VHJOM2buLPrWsMTwLnyw@mail.gmail.com Suggested-by: Nick Desaulniers Reviewed-by: Nick Desaulniers Tested-by: Nick Desaulniers Reported-by: kbuild test robot Signed-off-by: Ilie Halip --- Changed in v2: - added a mention that this is a clang issue across all versions - added Nick's Reviewed-by, Tested-by - added Reported-by tools/objtool/check.c | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/tools/objtool/check.c b/tools/objtool/check.c index e034a8f24f46..eddf8bf16b05 100644 --- a/tools/objtool/check.c +++ b/tools/objtool/check.c @@ -2612,9 +2612,10 @@ static bool is_ubsan_insn(struct instruction *insn) "__ubsan_handle_builtin_unreachable")); } -static bool ignore_unreachable_insn(struct instruction *insn) +static bool ignore_unreachable_insn(struct objtool_file *file, struct instruction *insn) { int i; + struct instruction *prev_insn; if (insn->ignore || insn->type == INSN_NOP) return true; @@ -2639,8 +2640,11 @@ static bool ignore_unreachable_insn(struct instruction *insn) * __builtin_unreachable(). The BUG() macro has an unreachable() after * the UD2, which causes GCC's undefined trap logic to emit another UD2 * (or occasionally a JMP to UD2). + * CONFIG_UBSAN_TRAP may also insert a UD2 after calling a __noreturn + * function. */ - if (list_prev_entry(insn, list)->dead_end && + prev_insn = list_prev_entry(insn, list); + if ((prev_insn->dead_end || dead_end_function(file, prev_insn->call_dest)) && (insn->type == INSN_BUG || (insn->type == INSN_JUMP_UNCONDITIONAL && insn->jump_dest && insn->jump_dest->type == INSN_BUG))) @@ -2767,7 +2771,7 @@ static int validate_reachable_instructions(struct objtool_file *file) return 0; for_each_insn(file, insn) { - if (insn->visited || ignore_unreachable_insn(insn)) + if (insn->visited || ignore_unreachable_insn(file, insn)) continue; WARN_FUNC("unreachable instruction", insn->sec, insn->offset); -- 2.25.1