Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp734212pxf; Thu, 8 Apr 2021 11:32:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzpUvx6v+xVduF2ppoRRhP4vz+VJAa28fzV+kjbp7fy6GjTlR3khrkw43sdFVY95PGrL1gY X-Received: by 2002:aa7:cc94:: with SMTP id p20mr13452262edt.353.1617906733059; Thu, 08 Apr 2021 11:32:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617906733; cv=none; d=google.com; s=arc-20160816; b=URIgvMQaxqUc07EOA+37E7WvJKgH4E/8PIQm704rIylvV0ncsddPKK5xX8QSsz5qGN vzfvbY7aWV58FItWuHg0UVDlukPK0GY/A0lonEIOqrSxteoYO0RVqWIKqBAYLceHEfrs VcpNuItGnXVK5WhBB6Q6s7Xt+PBuXmyc7cZhqcZQhq2SggZBWRc5MjOYtBBncVG3gUK1 DAfU6+lyxZ7Spv1ZKx/lRy1TnU8jH7892Z7jgOb0sHhfR42+yuDDL/UdnsJgtyeVIkw1 lQ2cZ5l+AReoT613LZAN3EzGMZZpaIpp+qeax7ygdKbaYsy4WdCKBuFEEAAt6fy+Roh6 PNFg== 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=E//9MgjgyGyGzfpqyqWq2doSFEPDUmVLoRf38lFR7Ug=; b=PvOD+q5lJHwnTBaVIWwiAQpyabgertLQCqyZLNl0rFfI+ba7U3bwn7tZ5eau+kbbQm EWg9KJj0UNvJL98Kq3Ir5uxdJR9vyzLRJ9WtqBTCv8UI2iUuqkvXEqtko1l+JFoTqRx1 FpLvJVHUZx83eee6AUX2cFbwNIl1stLARI2yexQlkynUP2sbrRqssQQjSscEkV0QupSs ziKxqhauvYxl2LMKlJBuUMGkesqWuAETOasNH6k6deuuAMG/ZCd4Ds39c5hYcTf1OVXf 98uqvAwkPGaF1dq3ziPEiTSZz9JCC+7Oi4Bbg34XoTt2rik4wwDsJDZMvxv6295CPSi2 GCIg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=RkrEMcjE; 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 y15si295959edv.49.2021.04.08.11.31.49; Thu, 08 Apr 2021 11:32:13 -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=RkrEMcjE; 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 S232866AbhDHSa6 (ORCPT + 99 others); Thu, 8 Apr 2021 14:30:58 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48760 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232909AbhDHSaZ (ORCPT ); Thu, 8 Apr 2021 14:30:25 -0400 Received: from mail-pj1-x1049.google.com (mail-pj1-x1049.google.com [IPv6:2607:f8b0:4864:20::1049]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 073C5C061225 for ; Thu, 8 Apr 2021 11:29:17 -0700 (PDT) Received: by mail-pj1-x1049.google.com with SMTP id nm17so1377801pjb.3 for ; Thu, 08 Apr 2021 11:29:17 -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=E//9MgjgyGyGzfpqyqWq2doSFEPDUmVLoRf38lFR7Ug=; b=RkrEMcjEGks9eZDKQu+2cXBVixhfRtfNzurKOb7kj5G0lHbsNG+kVYT00dZ5fCwZZm oGJ3H14LgsxmvSmAONHP3AD4DqcsZiijiViY54PVPWASyhlBWJKul0uk2D6FHPy5MGCI hRwVaWPtPODb24A1fAYvc3Pk8kJw73Wgq0qpJVjB3nsOpeMmHe8UyFYE027vmCmfDH59 TeMeJF97gfJcV1bR86XXNmc9WzLb/xoI5eyDhzlmA3A8LFSbl+CVN1qG+Ng6f1ydMu6m HP+jBZVA3ShA+iChc9OSbbyum7a0Xu8+WCER3+MJXJ4MzHQMgKZMSbyX49ZilNruBraI +ZqQ== 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=E//9MgjgyGyGzfpqyqWq2doSFEPDUmVLoRf38lFR7Ug=; b=d1bRzIJj8EXPB8wAFqVEK507PAEuNLbNOK43Mrr2gDOIFwAdwehnFARIrGEI56y8XD jUueoVg5bq0DMrvHcMGhvOzvHALTzfKg/dwTtXPqlSjaii8u5y2v12NpBcvz705D8uJt NLFeZNhAglu6LMktr0YZvVt07Qe81azsgLjTydAA9MQAVQA/Xe9NMwGGLwkR8D4dWMZ6 7nhGvaCm/uRy3jGIu2813+W8dQ4cp7nV0NlzjztN9+FYnD0k746MhifzL8gm2eshvXEy V/vsTczZnRX/8TrMNDm7yRN/5tzoRBZESqu4MfD1ZJNAokcGyqjrujTuHqhbz+rZbXq8 BHuQ== X-Gm-Message-State: AOAM530QbQGfrjgiiRBfe2HaO4to7SYzvvf08bzYnRj97CWoM2KBZK7o 4sXaJiVj67K4JDCsuVKFtvnak201KTUiiXE3CxM= X-Received: from samitolvanen1.mtv.corp.google.com ([2620:15c:201:2:3560:8505:40a2:e021]) (user=samitolvanen job=sendgmr) by 2002:a17:902:7896:b029:e8:fa73:ad22 with SMTP id q22-20020a1709027896b02900e8fa73ad22mr8974621pll.66.1617906556287; Thu, 08 Apr 2021 11:29:16 -0700 (PDT) Date: Thu, 8 Apr 2021 11:28:41 -0700 In-Reply-To: <20210408182843.1754385-1-samitolvanen@google.com> Message-Id: <20210408182843.1754385-17-samitolvanen@google.com> Mime-Version: 1.0 References: <20210408182843.1754385-1-samitolvanen@google.com> X-Mailer: git-send-email 2.31.1.295.g9ea45b61b8-goog Subject: [PATCH v6 16/18] arm64: ftrace: use function_nocfi for ftrace_call From: Sami Tolvanen To: Kees Cook Cc: Nathan Chancellor , Nick Desaulniers , Masahiro Yamada , Will Deacon , Jessica Yu , Arnd Bergmann , Tejun Heo , "Paul E. McKenney" , Christoph Hellwig , Peter Zijlstra , Sedat Dilek , Mark Rutland , Catalin Marinas , bpf@vger.kernel.org, linux-hardening@vger.kernel.org, linux-arch@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kbuild@vger.kernel.org, linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, clang-built-linux@googlegroups.com, Sami Tolvanen Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org With CONFIG_CFI_CLANG, the compiler replaces function pointers with jump table addresses, which breaks dynamic ftrace as the address of ftrace_call is replaced with the address of ftrace_call.cfi_jt. Use function_nocfi() to get the address of the actual function instead. Suggested-by: Ben Dai Signed-off-by: Sami Tolvanen Acked-by: Mark Rutland Tested-by: Nathan Chancellor --- arch/arm64/kernel/ftrace.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/arch/arm64/kernel/ftrace.c b/arch/arm64/kernel/ftrace.c index 86a5cf9bc19a..b5d3ddaf69d9 100644 --- a/arch/arm64/kernel/ftrace.c +++ b/arch/arm64/kernel/ftrace.c @@ -55,7 +55,7 @@ int ftrace_update_ftrace_func(ftrace_func_t func) unsigned long pc; u32 new; - pc = (unsigned long)&ftrace_call; + pc = (unsigned long)function_nocfi(ftrace_call); new = aarch64_insn_gen_branch_imm(pc, (unsigned long)func, AARCH64_INSN_BRANCH_LINK); -- 2.31.1.295.g9ea45b61b8-goog