Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp4011795ybg; Tue, 29 Oct 2019 00:25:04 -0700 (PDT) X-Google-Smtp-Source: APXvYqzmD/j/5hUOE9y1IvPtam2eDX1gQ5GG+TkC+w5DkY2M93DbZz0Tu/fw/8wLm1F/iNr97ok8 X-Received: by 2002:a17:906:5e08:: with SMTP id n8mr1807655eju.20.1572333904098; Tue, 29 Oct 2019 00:25:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1572333904; cv=none; d=google.com; s=arc-20160816; b=UM58+G1BhdFDEtH/DVOhWO+JGMwBhac5vy5v5CFsbx8r5i03n9+5z5v91hG+usdvp0 wQFjoEDsB0N+qFwIkDach6XyWv/6euObgqXvmMKpl+UjyGZMIK9NJLmhEcv6ReKmvq8s X8DccFfOieJVExJuHL4bBIzG4ODod/AmBXOJ98WIxX0L+ZLdH6lgAV4Cncjh+maHUZ/8 psjLUDeDDH7XPFA+UyeGaEdzmX+0Gr1uIHFr4h7scPVAZKBO281zD7WrKQDBmJDcNZMq N4dsAcGMPOX6HgT8igXzjuP3pBqKad8sF8wTpgQu8MWqbvzm29jWTGP9b9om8FKR+9Bf qXGg== 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=D9aL7CIPgVBLEowXwwKDN7h7+lLHlmYeACx0xfz4QPU=; b=SuU6wMG93EuvaOiJ4iJe/uLM/4wUrbdF40roJ29c6RO6gj2Nsr7Jgy4n+cABBtcayp 4ijoULekIVpWoeBjocK/2l6H3/9ySe+Zxn1sumpk1BJYxExtT2bZbG+txuBMKQb6bT45 WYkl79r065ei/SXB5oyCe3JAVx9OoDNa1ySPkHXDBas/LpXkeBp0FkRBAXK2+OS8Rlc6 Mp82aq8VTiVqqoR+ri/FyfFyyQMLC9OYDTsX3ky1NrUClmbkcsi/8v1FluiDgtJNq5B4 is/+D0CiBh0+GAbzRLebQOBgwlbaBAnk1OZJ0FEDMWB9WAXfluRmwsjKIPhcScBo0z54 MEbA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@axtens.net header.s=google header.b=p12QlXY0; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v9si7026553edl.90.2019.10.29.00.24.40; Tue, 29 Oct 2019 00:25:04 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@axtens.net header.s=google header.b=p12QlXY0; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731536AbfJ2EVW (ORCPT + 99 others); Tue, 29 Oct 2019 00:21:22 -0400 Received: from mail-pl1-f196.google.com ([209.85.214.196]:41997 "EHLO mail-pl1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728225AbfJ2EVV (ORCPT ); Tue, 29 Oct 2019 00:21:21 -0400 Received: by mail-pl1-f196.google.com with SMTP id c16so6900224plz.9 for ; Mon, 28 Oct 2019 21:21:20 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=axtens.net; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=D9aL7CIPgVBLEowXwwKDN7h7+lLHlmYeACx0xfz4QPU=; b=p12QlXY0PFm+XioTxaj3mxPpn879Km9XTAKXd1KZEJJs9pobJBz1Hm7UzcWyYJIVfp p19iZl76ObQBmsydeOqk8cdnw0S/vKCZsOXJW1brmjlSGcIN+W47CfOia1/FJPW82W6z jE6+JfudbahSDEuG53tccgkDvhpxU//9CJC4U= 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=D9aL7CIPgVBLEowXwwKDN7h7+lLHlmYeACx0xfz4QPU=; b=rT3rey/u0ctv4Mi6JeDYCAN8V7YC7tn2UomDwKogp/8P7GeoI4x509L1VSnnxfDEU2 3aMuPjiTd4rjjQWmGw21i0LVsigIxNIwZAT9ADU4KBYHiISZGeU4KqhCFn7Sarkv8IYm 5Evd8c2OQYxVndkasd70x7Gb37EUgZ05LnYOkMtv9qVi4IuzL6by/u6pGoXgNdq+8K5x 7MIlmQDqJPiod70doI1LGnCWFRYfJrvkhLFUGhi2g7VyqmWSKL7iBPcrXu+vkEFR07mu 0HVwp4rw5GBGw4B+Dwmog7jIFJxZYM9+j+DVsHp0S1AJjyBTgYHZYAorTF5tTmg9Pcfs ny1Q== X-Gm-Message-State: APjAAAVhGPtJrBlZloWp6xDxT+kK3+yFeRoDD7ImVO8ZSGUI2vxYE9j/ gWYuH3OVbd0/TFu3U7CHO5fQBA== X-Received: by 2002:a17:902:bcc2:: with SMTP id o2mr1697695pls.281.1572322880361; Mon, 28 Oct 2019 21:21:20 -0700 (PDT) Received: from localhost ([2001:44b8:802:1120:783a:2bb9:f7cb:7c3c]) by smtp.gmail.com with ESMTPSA id a5sm3908450pfk.172.2019.10.28.21.21.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 28 Oct 2019 21:21:19 -0700 (PDT) From: Daniel Axtens To: kasan-dev@googlegroups.com, linux-mm@kvack.org, x86@kernel.org, aryabinin@virtuozzo.com, glider@google.com, luto@kernel.org, linux-kernel@vger.kernel.org, mark.rutland@arm.com, dvyukov@google.com, christophe.leroy@c-s.fr Cc: linuxppc-dev@lists.ozlabs.org, gor@linux.ibm.com, Daniel Axtens Subject: [PATCH v10 3/5] fork: support VMAP_STACK with KASAN_VMALLOC Date: Tue, 29 Oct 2019 15:20:57 +1100 Message-Id: <20191029042059.28541-4-dja@axtens.net> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20191029042059.28541-1-dja@axtens.net> References: <20191029042059.28541-1-dja@axtens.net> 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 Supporting VMAP_STACK with KASAN_VMALLOC is straightforward: - clear the shadow region of vmapped stacks when swapping them in - tweak Kconfig to allow VMAP_STACK to be turned on with KASAN Reviewed-by: Dmitry Vyukov Signed-off-by: Daniel Axtens --- arch/Kconfig | 9 +++++---- kernel/fork.c | 4 ++++ 2 files changed, 9 insertions(+), 4 deletions(-) diff --git a/arch/Kconfig b/arch/Kconfig index 5f8a5d84dbbe..2d914990402f 100644 --- a/arch/Kconfig +++ b/arch/Kconfig @@ -843,16 +843,17 @@ config HAVE_ARCH_VMAP_STACK config VMAP_STACK default y bool "Use a virtually-mapped stack" - depends on HAVE_ARCH_VMAP_STACK && !KASAN + depends on HAVE_ARCH_VMAP_STACK + depends on !KASAN || KASAN_VMALLOC ---help--- Enable this if you want the use virtually-mapped kernel stacks with guard pages. This causes kernel stack overflows to be caught immediately rather than causing difficult-to-diagnose corruption. - This is presently incompatible with KASAN because KASAN expects - the stack to map directly to the KASAN shadow map using a formula - that is incorrect if the stack is in vmalloc space. + To use this with KASAN, the architecture must support backing + virtual mappings with real shadow memory, and KASAN_VMALLOC must + be enabled. config ARCH_OPTIONAL_KERNEL_RWX def_bool n diff --git a/kernel/fork.c b/kernel/fork.c index 954e875e72b1..a6e5249ad74b 100644 --- a/kernel/fork.c +++ b/kernel/fork.c @@ -94,6 +94,7 @@ #include #include #include +#include #include #include @@ -224,6 +225,9 @@ static unsigned long *alloc_thread_stack_node(struct task_struct *tsk, int node) if (!s) continue; + /* Clear the KASAN shadow of the stack. */ + kasan_unpoison_shadow(s->addr, THREAD_SIZE); + /* Clear stale pointers from reused stack. */ memset(s->addr, 0, THREAD_SIZE); -- 2.20.1