Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp4959628ybl; Mon, 9 Dec 2019 20:48:04 -0800 (PST) X-Google-Smtp-Source: APXvYqzpaKOslXjNulzruqk6I+mmOoqEMmmXNEmnCfwv5lDxrEtcuJeN8q7QxggApvzy2ecysYDh X-Received: by 2002:a05:6808:64d:: with SMTP id z13mr2527182oih.104.1575953284399; Mon, 09 Dec 2019 20:48:04 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1575953284; cv=none; d=google.com; s=arc-20160816; b=H2Gmn5HtD3g8NVNlTXsJTZ4jlhy8bBz6Laoc9dMsPDSQubuKWLSkQaAyTVvPS3bTRF O2l98xW2NFtvvE4awELb6/e6X5J4l+5+DI7uHDFw9t9zSxG0UEtIikHKBHJyC8opfxMN rxjATIaFBybUZAsLG2GYvxt7kbUcN6Xx/jp4lOk7j/hqHRJQyAjhGD/JY80sEgT/4Our bDH8AQzePFmizaZQeiWV7LcNzE4yKWiiGQvVB4cwAmxABFTEyQk4RDdB3S/y3BNX9mKd 4vIcdnXkEHyzzoQuiYWMq1KHCcp7nHQK/AVB9NZG5tE+J0ibzNb2WnQ7hNIysXaqAOnc 5rIg== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=y8tQSVFZXpglTzCwnCQJ/H8jDbSquTv0j0/ujEPlW6k=; b=Ar8RL2TKG0P2rvJQQG8WAG+BsCpGUeA53oLLn2RKtX2gy4wsogeHYfQCdfRgJjMzYQ Rp7Lpy1RrheST6/1DF5xdr73rQ5/Q4VVKzmK/S8UvxiQ+6Yo4AeHKyA7F3SwgdK9GijJ 3r0jKrmefldVcJrBgJImrD8vAe/9EZgImVQzdcQB0qh0ZMJbYk1l6H3FvyZO/9jEDktE AiZi8y7bCSi/9THhkN+anyG17NeuaF7phTU5wEvL3wMThzxySmuBPIEqRyZ/UQVNz56N QmMlTCZ9ZHv8z5F6lak/JCvjdZfnBMRLLyTIvQMyhqm8vsBVc3hagWsUfyn3YclC4Lgg mZMA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@axtens.net header.s=google header.b=Q5ohWjCI; 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 d4si1300331ote.135.2019.12.09.20.47.51; Mon, 09 Dec 2019 20:48:04 -0800 (PST) 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=Q5ohWjCI; 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 S1726841AbfLJErY (ORCPT + 99 others); Mon, 9 Dec 2019 23:47:24 -0500 Received: from mail-pl1-f196.google.com ([209.85.214.196]:44807 "EHLO mail-pl1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726819AbfLJErX (ORCPT ); Mon, 9 Dec 2019 23:47:23 -0500 Received: by mail-pl1-f196.google.com with SMTP id bh2so5634911plb.11 for ; Mon, 09 Dec 2019 20:47:23 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=axtens.net; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=y8tQSVFZXpglTzCwnCQJ/H8jDbSquTv0j0/ujEPlW6k=; b=Q5ohWjCIeOzukO5LCkWh2UDZUjzpG6Dg+k5QibSsNEXqnEUsNI3eOHJLFy8voZYt1D zWAwzTdpWafUiM/2V3jWWisOZsqR4bWCl+3Si1gmC/LlI61VQXqM8pt6m9UAyMGHCMQR a4aAP4oUxg9Iibn2yn+JTh0K/J6050DPkyO3I= 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:mime-version :content-transfer-encoding; bh=y8tQSVFZXpglTzCwnCQJ/H8jDbSquTv0j0/ujEPlW6k=; b=mhfnHRYpcBcJYrLdCO17Lax8HJFO+ZXbIWCE6IFN5JhIaJVHGeM/HjW7QiVzt6kV2w ooay6zgRzNoUW1rwgl+8nWPNV5HesZtGBwx/AsGURST+HFkYuem85W7bBeXc/wWgUlhN fwcBIl/nPMg0U1lGd4DwBltwJSfmwuh4FbhDDO2+BKqkewTTGTZthABp0ikPANCUm3iV HaF9/7sEQgBuQPM+NlOg4vJBULgqx3S3L8CPwo15yYBUzjaJ1SvIyaUTwJGN2EdigYpj QEyDSpTvvcPC13mrpydTjRZQtFpQPofmiKl/cIs6HPHsiNKdBKmcyGJ/OfNCiCaDKDus RxXg== X-Gm-Message-State: APjAAAV9+VvRtW7M2hhgAfLjG1ZTgwH2VQz5v/BXLiWrEYmeD8L9K7cL MGhJ6zoLiDSTKSmhdL0QUH6inCdgqxc= X-Received: by 2002:a17:902:9f83:: with SMTP id g3mr30957647plq.234.1575953242726; Mon, 09 Dec 2019 20:47:22 -0800 (PST) Received: from localhost (2001-44b8-1113-6700-e460-0b66-7007-c654.static.ipv6.internode.on.net. [2001:44b8:1113:6700:e460:b66:7007:c654]) by smtp.gmail.com with ESMTPSA id e16sm1159270pgk.77.2019.12.09.20.47.20 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 09 Dec 2019 20:47:21 -0800 (PST) From: Daniel Axtens To: linux-kernel@vger.kernel.org, linux-mm@kvack.org, linuxppc-dev@lists.ozlabs.org, linux-s390@vger.kernel.org, linux-xtensa@linux-xtensa.org, linux-arch@vger.kernel.org, linux-arm-kernel@lists.infradead.org, kasan-dev@googlegroups.com, christophe.leroy@c-s.fr, aneesh.kumar@linux.ibm.com, bsingharora@gmail.com Cc: Daniel Axtens Subject: [PATCH v2 0/4] KASAN for powerpc64 radix, plus generic mm change Date: Tue, 10 Dec 2019 15:47:10 +1100 Message-Id: <20191210044714.27265-1-dja@axtens.net> X-Mailer: git-send-email 2.20.1 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 Building on the work of Christophe, Aneesh and Balbir, I've ported KASAN to 64-bit Book3S kernels running on the Radix MMU. This provides full inline instrumentation on radix, but does require that you be able to specify the amount of physically contiguous memory on the system at compile time. More details in patch 4. The big change from v1 is the introduction of tree-wide(ish) MAX_PTRS_PER_{PTE,PMD,PUD} macros in preference to the previous approach, which was for the arch to override the page table array definitions with their own. (And I squashed the annoying intermittent crash!) Apart from that there's just a lot of cleanup. Christophe, I've addressed most of what you asked for and I will reply to your v1 emails to clarify what remains unchanged. Regards, Daniel Daniel Axtens (4): mm: define MAX_PTRS_PER_{PTE,PMD,PUD} kasan: use MAX_PTRS_PER_* for early shadow kasan: Document support on 32-bit powerpc powerpc: Book3S 64-bit "heavyweight" KASAN support Documentation/dev-tools/kasan.rst | 7 +- Documentation/powerpc/kasan.txt | 112 ++++++++++++++++++ arch/arm64/include/asm/pgtable-hwdef.h | 3 + arch/powerpc/Kconfig | 3 + arch/powerpc/Kconfig.debug | 21 ++++ arch/powerpc/Makefile | 11 ++ arch/powerpc/include/asm/book3s/64/hash.h | 4 + arch/powerpc/include/asm/book3s/64/pgtable.h | 7 ++ arch/powerpc/include/asm/book3s/64/radix.h | 5 + arch/powerpc/include/asm/kasan.h | 20 +++- arch/powerpc/kernel/process.c | 8 ++ arch/powerpc/kernel/prom.c | 59 ++++++++- arch/powerpc/mm/kasan/Makefile | 3 +- .../mm/kasan/{kasan_init_32.c => init_32.c} | 0 arch/powerpc/mm/kasan/init_book3s_64.c | 67 +++++++++++ arch/s390/include/asm/pgtable.h | 3 + arch/x86/include/asm/pgtable_types.h | 5 + arch/xtensa/include/asm/pgtable.h | 1 + include/asm-generic/pgtable-nop4d-hack.h | 9 +- include/asm-generic/pgtable-nopmd.h | 9 +- include/asm-generic/pgtable-nopud.h | 9 +- include/linux/kasan.h | 6 +- mm/kasan/init.c | 6 +- 23 files changed, 353 insertions(+), 25 deletions(-) create mode 100644 Documentation/powerpc/kasan.txt rename arch/powerpc/mm/kasan/{kasan_init_32.c => init_32.c} (100%) create mode 100644 arch/powerpc/mm/kasan/init_book3s_64.c -- 2.20.1