From patchwork Thu Sep 14 15:59:21 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Thomas_Wei=C3=9Fschuh?= X-Patchwork-Id: 13385675 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 20E9FEEAA55 for ; Thu, 14 Sep 2023 15:59:42 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id A61768D0011; Thu, 14 Sep 2023 11:59:41 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 9EA358D0001; Thu, 14 Sep 2023 11:59:41 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 88AA68D0011; Thu, 14 Sep 2023 11:59:41 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0012.hostedemail.com [216.40.44.12]) by kanga.kvack.org (Postfix) with ESMTP id 73E668D0001 for ; Thu, 14 Sep 2023 11:59:41 -0400 (EDT) Received: from smtpin28.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay02.hostedemail.com (Postfix) with ESMTP id 320601205D9 for ; Thu, 14 Sep 2023 15:59:41 +0000 (UTC) X-FDA: 81235663362.28.2AF3140 Received: from todd.t-8ch.de (todd.t-8ch.de [159.69.126.157]) by imf04.hostedemail.com (Postfix) with ESMTP id D1D5F40024 for ; Thu, 14 Sep 2023 15:59:38 +0000 (UTC) Authentication-Results: imf04.hostedemail.com; dkim=pass header.d=weissschuh.net header.s=mail header.b=g2rkURrG; dmarc=none; spf=pass (imf04.hostedemail.com: domain of linux@weissschuh.net designates 159.69.126.157 as permitted sender) smtp.mailfrom=linux@weissschuh.net ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1694707179; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding:in-reply-to: references:dkim-signature; bh=XxWXfGTVP4QY+3yA3U7GjqYmRXsjsPRI9eO9Cr8CCt8=; b=d56/pw4Rquby8D440Yyv0uW+ojxBLQOhKXRUq0nAYnBbDuxuOdW3dm2REA3fHbZ5LBR0Yp WrioxKh2LYDnY3R0kZZenWZuh1hMVJL8Vq+cxk/VAQQSUxGwMgnpZjf5V2XBK0pVqRGlsn J1npUMxbdMlALifQPHNllGoRN0nxx4Q= ARC-Authentication-Results: i=1; imf04.hostedemail.com; dkim=pass header.d=weissschuh.net header.s=mail header.b=g2rkURrG; dmarc=none; spf=pass (imf04.hostedemail.com: domain of linux@weissschuh.net designates 159.69.126.157 as permitted sender) smtp.mailfrom=linux@weissschuh.net ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1694707179; a=rsa-sha256; cv=none; b=Zw8MGQRc+HZw4s91ZZW/InJ9vflBuh0RK88r/ZhD+ZhZRNwIqoocN46CaevRvJCDoVXZyK 0wQf90lsrZ1IX19OqMseaCbHFF50GXBuT9iHZc8658Cb2iqp9wuc11Jbf1iMgSvFmdX+VJ m3hHnQXiSDGGKpU/zsBNPmA5L6FTN5c= DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=weissschuh.net; s=mail; t=1694707175; bh=Xy4oeT6FjD8v9CNOFPDcyJo8MblgPr/wtL46w5RATVs=; h=From:Date:Subject:To:Cc:From; b=g2rkURrGUFg0K+EhUVCYp685HNlgScL0D2NzEVczWqYwfzzi/rc6T5Vn9Yby0Xy7r DwYlgXlIhIgLE/VU0l/udDlI59wIy+ytT6mnHylWjJAEBk4lzAjWvAfXxcnoQq13ow CIw5EuBzT+MCNAHJuV7B1xBVr7WC/I4Xz7WsulX0= From: =?utf-8?q?Thomas_Wei=C3=9Fschuh?= Date: Thu, 14 Sep 2023 17:59:21 +0200 Subject: [PATCH RFC] binfmt_elf: fully allocate bss pages MIME-Version: 1.0 Message-Id: <20230914-bss-alloc-v1-1-78de67d2c6dd@weissschuh.net> X-B4-Tracking: v=1; b=H4sIANgtA2UC/6tWKk4tykwtVrJSqFYqSi3LLM7MzwNyDHUUlJIzE vPSU3UzU4B8JSMDI2MDS0MT3aTiYt3EnJz8ZN00UyPjtEQzQ3NDi2QloPqCotS0zAqwWdFKQW7 OSrG1tQBPM4vQYAAAAA== To: Alexander Viro , Christian Brauner , Eric Biederman , Kees Cook Cc: Mark Brown , Willy Tarreau , linux-fsdevel@vger.kernel.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org, Sebastian Ott , stable@vger.kernel.org, =?utf-8?q?Thomas_Wei=C3=9Fschuh?= X-Mailer: b4 0.12.3 X-Developer-Signature: v=1; a=ed25519-sha256; t=1694707174; l=2558; i=linux@weissschuh.net; s=20221212; h=from:subject:message-id; bh=Xy4oeT6FjD8v9CNOFPDcyJo8MblgPr/wtL46w5RATVs=; b=dTmJBTY1kUzVp+M5Za8hnGEaOf2h8wZGp7RZPk+6qvGpvWNyDehekRbLjiD5C3wwkK8yAX1ss O3djcKTCYWTBg81Hxaq4IjMd6XfZUwlec4bCQ7Bj9DnYzPrJupLCwi8 X-Developer-Key: i=linux@weissschuh.net; a=ed25519; pk=KcycQgFPX2wGR5azS7RhpBqedglOZVgRPfdFSPB1LNw= X-Rspamd-Queue-Id: D1D5F40024 X-Rspam-User: X-Rspamd-Server: rspam05 X-Stat-Signature: 4jcs15mkhhxks6cmosgc8r1yci1obyii X-HE-Tag: 1694707178-544797 X-HE-Meta: U2FsdGVkX19R2si82f1nBKc4xOkr7RT/ZuCyd8ixP2rzM2SVZJSDq/TSgMSBmR7Z9VOtaICiVu1ItvTKENmYYthPgc7tuc+ERKh6EyQX3gjIuly2VJXPV4qu/yXJtE0DnAm7wwNkh7M85TEzxtZmzHBjzgBgUM/H5t8dl/yCtW3PK5VjD5dq4i2RsnN7gxeiGRM6eMCaE2n7oTTuIHEPlVz9ncPmGo0Ah2I4SxZTrQ1gV4qfa/z9cLkABRzy+yX+cBfUU/hjTysyAu9TgxkmemQgOt3yyN+VW1rthXUheA0j/NkYOD1t5J9lqE0CLLlAqF0hBoX2Z5DUekjPofRRlpRdU6pFS9+W7mETLQn4Wg7WBDszJZwLKe48fGGIbwnS0JIlo0FWrksJbiw6tfSnBS78RLXgK8KMYFg5VKwTfCDo9Db1WgTc/D5Tdax86tWk5nAD62EI2oTEQ1jcZ6H9rJ9IkhCwxzRTtbH5/sxIFBw48/aRWVaa7BrCjiRY2hQiqeal/cXgr3G8aOko9rQZVNywXfydBw0dDvmJJaylTGe6MhPdkDiI0IlBBed6F9tltKfJ7YilGy5Y6URU6wGVOe/xuQmVmmaqK1tAR+xuo3FMxTGqYoPy2+UAAa2IDOukmONyAnMtKBh1lZWEokXUrxfZ0usNqA3DL1+8p+BIeGxMhXpL+OSn9Api8SIOedlp4e7em/n0p42qOUzK6tvJG97nI2VyPmKy6OoQhhZEyb3mDsa8mFVH4O9jifc6NjdUoV3NLxEdh6MqWNKLmr/jXHg11bCQLCBVe83WQtzNDaVgGZ9UQlILtEeXSIqKsyti7a0LEN8EdM3fPcN3+ajadEMI4X4mRwBCH3qgdhFVk9n/BtDPeqAZdCq5KaO0iisXT56b+T8ehtsXq0064cSpxlDjn5V2Mw9DVXTwz5iGrcBwMdK8nhPpfP4aBgnN6h0ufwvSlYbxO/1tjM+MHLn JnBbun4F 4F+I1e9QJySzSynY7T77YmOD63wqLkpeDulpljisdKN+dOqwZe42PbxG8HAHk5syP9k8gouPfZzgUYi3SWL6lomD8ccFYGo7OBMw85FAd4wF9t8b7Om1e7L+29uf3uwMQX/kPd4I9fEhLznplMVsIL8s1+r+i8mmMl6XzMw3nlsDfBJFte1LaFLha5+CtHKMpld2xCfbeiSII+BT0znKQiglia/Yp2V+9jVG2tfxodglDQYCx95zqR47UDf6qUgGetlZk45pVAibgQUBGG0ubp1k+EWu0EAJmLXKl9D748n4TQRhRWEk6Eila4EbSgXIPuKa6y/IiOAyLIHjkOCrRug91Tkrjmy6/eIehv49EXxzFOpzLRikkzHPMaw== X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: When allocating the pages for bss the start address needs to be rounded down instead of up. Otherwise the start of the bss segment may be unmapped. The was reported to happen on Aarch64: Memory allocated by set_brk(): Before: start=0x420000 end=0x420000 After: start=0x41f000 end=0x420000 The triggering binary looks like this: Elf file type is EXEC (Executable file) Entry point 0x400144 There are 4 program headers, starting at offset 64 Program Headers: Type Offset VirtAddr PhysAddr FileSiz MemSiz Flags Align LOAD 0x0000000000000000 0x0000000000400000 0x0000000000400000 0x0000000000000178 0x0000000000000178 R E 0x10000 LOAD 0x000000000000ffe8 0x000000000041ffe8 0x000000000041ffe8 0x0000000000000000 0x0000000000000008 RW 0x10000 NOTE 0x0000000000000120 0x0000000000400120 0x0000000000400120 0x0000000000000024 0x0000000000000024 R 0x4 GNU_STACK 0x0000000000000000 0x0000000000000000 0x0000000000000000 0x0000000000000000 0x0000000000000000 RW 0x10 Section to Segment mapping: Segment Sections... 00 .note.gnu.build-id .text .eh_frame 01 .bss 02 .note.gnu.build-id 03 Reported-by: Sebastian Ott Closes: https://lore.kernel.org/lkml/5d49767a-fbdc-fbe7-5fb2-d99ece3168cb@redhat.com/ Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2") Cc: stable@vger.kernel.org Signed-off-by: Thomas Weißschuh --- I'm not really familiar with the ELF loading process, so putting this out as RFC. A example binary compiled with aarch64-linux-gnu-gcc 13.2.0 is available at https://test.t-8ch.de/binfmt-bss-repro.bin --- fs/binfmt_elf.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) --- base-commit: aed8aee11130a954356200afa3f1b8753e8a9482 change-id: 20230914-bss-alloc-f523fa61718c Best regards, diff --git a/fs/binfmt_elf.c b/fs/binfmt_elf.c index 7b3d2d491407..4008a57d388b 100644 --- a/fs/binfmt_elf.c +++ b/fs/binfmt_elf.c @@ -112,7 +112,7 @@ static struct linux_binfmt elf_format = { static int set_brk(unsigned long start, unsigned long end, int prot) { - start = ELF_PAGEALIGN(start); + start = ELF_PAGESTART(start); end = ELF_PAGEALIGN(end); if (end > start) { /*