Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp723145pxf; Wed, 31 Mar 2021 14:34:58 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzZcC3+qDjSGZ6DSqKM/blaTBS7VskbbdfKQ69BPQKs0IfHU6Tzq7SQsEIRVIXSfS+Im/+F X-Received: by 2002:aa7:cb4d:: with SMTP id w13mr6272723edt.249.1617226498146; Wed, 31 Mar 2021 14:34:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617226498; cv=none; d=google.com; s=arc-20160816; b=nPiaQ1ikFrUqZo5Izd86+1wozibgYgrmps6AgHXwisxd/VKYfj4xtAKn3O4gBRNMFr RhvDpCnJafzbXc+sWbTklhqfqaSkc6Ocs2K/d9XU0uVTn+CpGyykValJwvk24Q9Xus9w XrWNV5/uJkr58wqt7Q9l2vJ4wA/0S7fUO2l68NI42CZO0shwMBLgwTn8NdYxTtZOCLu4 xuIedCD0qkx7SXX/eBOxcpx3W25tSs6OKw39Lzbd0nSyzBlULIRHjBtlEpgpBfSGkgUZ oTiCg3oNE6QBTkQtervFD3UE33t4siAPUouChFG7UjxCmnEAxZG3lYBAWucphSAYnWZr obzQ== 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=YGJePCNXceByqZDSpRB0j7cl0450LnSJo98Rt1jHcOo=; b=kdt4pgsG/BOFKbhKqmUqs5DPlhK7ZUbCwK9nh0SCQnITaMH1HI6cG21fq2zShR/UVb +/xw+oWZcuXrTI2HNhKeB/rMtRb3RvQRzr2IqkINJhCUD7/2Bnc4GhzSXxh/09aUsy9g E3tW2SulOY7DiLuiWyl7SIh/MquPbdjdQTB6P3Buj8jjtlSWFPTdo/XcpayETZWRoC2f bl+fn7+PpE4Oso5fu0a/H7SKMkWFQB91T7W8ma5YROtLb3ynSGsygjtB1RTuqgNihsig mcOtJ4PBFRBIlEGNkazULC9DxdJKdxuifqXClQ6VD/8CAXeYra66l1ngYC7Pl9sfS2Hj fktg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=UKPRZLEV; 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 bu23si2779888edb.336.2021.03.31.14.34.35; Wed, 31 Mar 2021 14:34:58 -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=UKPRZLEV; 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 S232982AbhCaV2X (ORCPT + 99 others); Wed, 31 Mar 2021 17:28:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51762 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230284AbhCaV1e (ORCPT ); Wed, 31 Mar 2021 17:27:34 -0400 Received: from mail-yb1-xb4a.google.com (mail-yb1-xb4a.google.com [IPv6:2607:f8b0:4864:20::b4a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 87864C061764 for ; Wed, 31 Mar 2021 14:27:30 -0700 (PDT) Received: by mail-yb1-xb4a.google.com with SMTP id x8so3714469ybo.6 for ; Wed, 31 Mar 2021 14:27:30 -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=YGJePCNXceByqZDSpRB0j7cl0450LnSJo98Rt1jHcOo=; b=UKPRZLEVzQZ3FHZ8QXJYCx4bJrAbgSI5gphfsVy9Eh1BZdT2ViP6pqHMKIIiVfgLu4 /gi1KUU5U2+ZkKwNjqjYEauBXMhyzaSePxCZZn171LdZoYhov4+U6PkkZu9CI0t9VE/g EcO6T6hhaf/UW1kedb1b3JSsszfVLrEJhTCLBirrO1Sv5c7XmHwbUaDImN6AyVRm9sC5 J+yHAq4xdOdlx2p9fxnW5OfqPxrdOhlT6KJpdZflXru7nEv1aCTjAwHr1fD1LSJrpxDT Po9hlnSXcQkFp6fw0Jac0NpPJzt8tzOpYjDqVdhCzOoPiSuJW5f5frOQhykp/SJ/gkA0 Eadg== 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=YGJePCNXceByqZDSpRB0j7cl0450LnSJo98Rt1jHcOo=; b=hPPQ/zEX+0t1Kk7VLbxFWN3ybPyNekKxldw3ndcITKnEDpzgf6IukBS5Xlj7S/OiVO 32QYEOUuk4HlmvwoQ64y/pDcdvVpniDQtCImPBku5b0XZaDEI9XE9J1qG7Qnx8MOlk64 TI6loVZgK7XtzdjVJdb5F9pAnnEpDRfaMIP++pHcC+GxAiULG3n5XnOikY3ihudzQFhf yyhAclxnOggkA+7jhAO2yN8OvSVrafuoDE8DtEzIHGECOehBpCD/2shzYqdWUsh6ByLB b92Alf6jVKWGOWUen6rggOVMtlNYSgGAiGBXpyDnkaGIWjxMZeo/KNfEOpLdxtgE0u0a E2AA== X-Gm-Message-State: AOAM530fzqYN7sKmq8Fz2vG0hvqlfbVlRqLHN9mfAA2ahHkdr+xbpqeI tBQKDY0bekfEdQSllC+V70TrB7k7hfoQP1p0NrE= X-Received: from samitolvanen1.mtv.corp.google.com ([2620:15c:201:2:7933:7015:a5d5:3835]) (user=samitolvanen job=sendgmr) by 2002:a25:ba87:: with SMTP id s7mr7123638ybg.222.1617226049790; Wed, 31 Mar 2021 14:27:29 -0700 (PDT) Date: Wed, 31 Mar 2021 14:27:07 -0700 In-Reply-To: <20210331212722.2746212-1-samitolvanen@google.com> Message-Id: <20210331212722.2746212-4-samitolvanen@google.com> Mime-Version: 1.0 References: <20210331212722.2746212-1-samitolvanen@google.com> X-Mailer: git-send-email 2.31.0.291.g576ba9dcdaf-goog Subject: [PATCH v4 03/17] mm: add generic function_nocfi macro 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 , 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 addresses in instrumented C code with jump table addresses. This means that __pa_symbol(function) returns the physical address of the jump table entry instead of the actual function, which may not work as the jump table code will immediately jump to a virtual address that may not be mapped. To avoid this address space confusion, this change adds a generic definition for function_nocfi(), which architectures that support CFI can override. The typical implementation of would use inline assembly to take the function address, which avoids compiler instrumentation. Signed-off-by: Sami Tolvanen Reviewed-by: Kees Cook --- include/linux/mm.h | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/include/linux/mm.h b/include/linux/mm.h index 8ba434287387..22cce9c7dd05 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h @@ -124,6 +124,16 @@ extern int mmap_rnd_compat_bits __read_mostly; #define lm_alias(x) __va(__pa_symbol(x)) #endif +/* + * With CONFIG_CFI_CLANG, the compiler replaces function addresses in + * instrumented C code with jump table addresses. Architectures that + * support CFI can define this macro to return the actual function address + * when needed. + */ +#ifndef function_nocfi +#define function_nocfi(x) (x) +#endif + /* * To prevent common memory management code establishing * a zero page mapping on a read fault. -- 2.31.0.291.g576ba9dcdaf-goog