Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp2731194ybi; Sun, 26 May 2019 06:49:41 -0700 (PDT) X-Google-Smtp-Source: APXvYqyzhx6FcluWWLpIZszYdXs9ahXhbTwUE3T/tqfet5tPNJV59l/yjNRoP/X4qqhvTtByu762 X-Received: by 2002:a62:2fc6:: with SMTP id v189mr91315443pfv.136.1558878581308; Sun, 26 May 2019 06:49:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558878581; cv=none; d=google.com; s=arc-20160816; b=rpInSlZSxeQNaFUDPKTwmJMV3GFjM/13BpKxPxHVG961ovgp9vGBxptUP8PvZa0zZM hoa9l0GKyqA9HOSx2q4k2TbGypeMAm9tXy9Y6g56DpShSH68j0Ls0mh1RbqSbjC6glPi knu0ox83UO3NLcgW/hKfW5qeuJh/vRI0hayHRqVAqPujBcma1EMdaujzVaziD8jO8EHX t2RrXGvJQvm4k/uKhVkgysOz/n0WFRQjTqpy0Sqcyc1Ib1JQdQYGXcZ4Gxyacsiowz/X M/Sr+86TJ9WgCojtO16Ef9uWeTdlQ8S8D8h9QueqtBYPBgNuGcq95H5h7jCMrMDvzkpF i7kg== 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; bh=yFTs4fyLad6UncTfB3veuWFviRBWYra8OYYLkHWIQ0Q=; b=CVagzCQodRrDxjPQ4eZT6eYOA5RmPLTIxFZ9kwpCp8/eHa6UBbuSLT4C1kf8QTTbNa e3BcW2JAdlIzgXocXKu8vO0H4PcGUXV4w2FFzcT+d3ZjD8ZT7d0E2OFUysGi7A11QqP9 SOyHmkuqj0Pl69K0pu4eMKKqzBJAx3oeugFikLY1yltC+cI/S1n4QYeEhVBrIpo4DsmU 85zkASPROJUtIv2O9UhwNYMtHeEmpFXsJmtJR9JA3d43Ro+6Xliprv/Lql4BfiD/DwMC IaAGU2wc0islQUuKpzwh9t+0uEW1Ut9kz1UfNYZ5jSXLMmRhStaIAkE6vEb6g5fHuhqG XADw== ARC-Authentication-Results: i=1; mx.google.com; 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 d5si14621201pla.376.2019.05.26.06.49.26; Sun, 26 May 2019 06:49:41 -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; 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 S1727829AbfEZNsB (ORCPT + 99 others); Sun, 26 May 2019 09:48:01 -0400 Received: from relay11.mail.gandi.net ([217.70.178.231]:43815 "EHLO relay11.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726953AbfEZNsA (ORCPT ); Sun, 26 May 2019 09:48:00 -0400 Received: from alex.numericable.fr (127.19.86.79.rev.sfr.net [79.86.19.127]) (Authenticated sender: alex@ghiti.fr) by relay11.mail.gandi.net (Postfix) with ESMTPSA id BD6A0100006; Sun, 26 May 2019 13:47:48 +0000 (UTC) From: Alexandre Ghiti To: Andrew Morton Cc: Christoph Hellwig , Russell King , Catalin Marinas , Will Deacon , Ralf Baechle , Paul Burton , James Hogan , Palmer Dabbelt , Albert Ou , Alexander Viro , Luis Chamberlain , Kees Cook , linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mips@vger.kernel.org, linux-riscv@lists.infradead.org, linux-fsdevel@vger.kernel.org, linux-mm@kvack.org, Alexandre Ghiti Subject: [PATCH v4 00/14] Provide generic top-down mmap layout functions Date: Sun, 26 May 2019 09:47:32 -0400 Message-Id: <20190526134746.9315-1-alex@ghiti.fr> 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 This series introduces generic functions to make top-down mmap layout easily accessible to architectures, in particular riscv which was the initial goal of this series. The generic implementation was taken from arm64 and used successively by arm, mips and finally riscv. Note that in addition the series fixes 2 issues: - stack randomization was taken into account even if not necessary. - [1] fixed an issue with mmap base which did not take into account randomization but did not report it to arm and mips, so by moving arm64 into a generic library, this problem is now fixed for both architectures. This work is an effort to factorize architecture functions to avoid code duplication and oversights as in [1]. [1]: https://www.mail-archive.com/linux-kernel@vger.kernel.org/msg1429066.html Changes in v4: - Make ARCH_WANT_DEFAULT_TOPDOWN_MMAP_LAYOUT select ARCH_HAS_ELF_RANDOMIZE by default as suggested by Kees, - ARCH_WANT_DEFAULT_TOPDOWN_MMAP_LAYOUT depends on MMU and defines the functions needed by ARCH_HAS_ELF_RANDOMIZE => architectures that use the generic mmap topdown functions cannot have ARCH_HAS_ELF_RANDOMIZE selected without MMU, but I think it's ok since randomization without MMU does not add much security anyway. - There is no common API to determine if a process is 32b, so I came up with !IS_ENABLED(CONFIG_64BIT) || is_compat_task() in [PATCH v4 12/14]. - Mention in the change log that x86 already takes care of not offseting mmap base address if the task does not want randomization. - Re-introduce a comment that should not have been removed. - Add Reviewed/Acked-By from Paul, Christoph and Kees, thank you for that. - I tried to minimize the changes from the commits in v3 in order to make easier the review of the v4, the commits changed or added are: - [PATCH v4 5/14] - [PATCH v4 8/14] - [PATCH v4 11/14] - [PATCH v4 12/14] - [PATCH v4 13/14] Changes in v3: - Split into small patches to ease review as suggested by Christoph Hellwig and Kees Cook - Move help text of new config as a comment, as suggested by Christoph - Make new config depend on MMU, as suggested by Christoph Changes in v2 as suggested by Christoph Hellwig: - Preparatory patch that moves randomize_stack_top - Fix duplicate config in riscv - Align #if defined on next line => this gives rise to a checkpatch warning. I found this pattern all around the tree, in the same proportion as the previous pattern which was less pretty: git grep -C 1 -n -P "^#if defined.+\|\|.*\\\\$" Alexandre Ghiti (14): mm, fs: Move randomize_stack_top from fs to mm arm64: Make use of is_compat_task instead of hardcoding this test arm64: Consider stack randomization for mmap base only when necessary arm64, mm: Move generic mmap layout functions to mm arm64, mm: Make randomization selected by generic topdown mmap layout arm: Properly account for stack randomization and stack guard gap arm: Use STACK_TOP when computing mmap base address arm: Use generic mmap top-down layout and brk randomization mips: Properly account for stack randomization and stack guard gap mips: Use STACK_TOP when computing mmap base address mips: Adjust brk randomization offset to fit generic version mips: Replace arch specific way to determine 32bit task with generic version mips: Use generic mmap top-down layout and brk randomization riscv: Make mmap allocation top-down by default arch/Kconfig | 11 +++ arch/arm/Kconfig | 2 +- arch/arm/include/asm/processor.h | 2 - arch/arm/kernel/process.c | 5 -- arch/arm/mm/mmap.c | 52 -------------- arch/arm64/Kconfig | 2 +- arch/arm64/include/asm/processor.h | 2 - arch/arm64/kernel/process.c | 8 --- arch/arm64/mm/mmap.c | 72 ------------------- arch/mips/Kconfig | 2 +- arch/mips/include/asm/processor.h | 5 -- arch/mips/mm/mmap.c | 84 ---------------------- arch/riscv/Kconfig | 11 +++ fs/binfmt_elf.c | 20 ------ include/linux/mm.h | 2 + kernel/sysctl.c | 6 +- mm/util.c | 107 ++++++++++++++++++++++++++++- 17 files changed, 137 insertions(+), 256 deletions(-) -- 2.20.1