Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2959983imu; Mon, 19 Nov 2018 08:38:58 -0800 (PST) X-Google-Smtp-Source: AJdET5d/FN0htjzMMfOp9czqrqW9D9BEO2g8Y1iAlaTiAc9CMZLoEGRarqUFfct1uXnK48VeJMkj X-Received: by 2002:a17:902:7e44:: with SMTP id a4mr23093324pln.338.1542645538105; Mon, 19 Nov 2018 08:38:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542645538; cv=none; d=google.com; s=arc-20160816; b=ClqoP9myo4bLxvASeSrDqav4NLcgEkHW6W01yZpiYKNlmFdE7FouiGHKo/JkzzGxZt mbOqR495q2dLhOrSazgYRCudIcsIheg7d33wyqs+GH3Dl/m+Ot+XXCZrKfQvMM1dzbE7 ynmZN/qw73yca/N7w4WRVvw1wMdeJGORVYhZeoD6AgC65hQ6fEPqLYrSTTvB+H2/0eS7 cdtrYXaAC9M8uwDSctpdmfMBUJ7KFBrT0mbnzL5GMee95Vq2ip2/JMd3wCX6q9yTWLtR GX5Uq/Fjv6twvhfYzCO309pO7XKRQTczUldnzJumRsA+t+SNq7Vq0oMCrJmaytmcUPS1 tlEA== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=kDvssBLwm63HmHWjM7w0WGRWG8WrU3ddU74TODTlOeQ=; b=EqRQ2GnWQ+63+PQeejJ9HOaPD1sqsbeysCoG51diWxHtNVqXCRGr1Y0CM0xKNaSUnE kPZ38Lf2P8e0jNAnbR8ZQRp7AKdvzEatqYVma/ukMyb3jcAWzzJ9HFjJ0mafQgKUUGeP mzOm4A2Vb379i3+nVZKUbhLtilHmlC3tg6RzeHwktW7UFrkLLFXwIhATJDIcdDbHOSya Z2p31IryIEH+TBz8YuD51GrZ6RXmuAD9d6xYxK6QlBqc9+f2QqLFHy0iMJ6mAx2I8y23 kW/CEm+AwQfcbl9Nf8UOva2QIyobqlsaaM4Bp/sbBA+2Hw5XuaqFQxgmJoKTmk/WiLFl E19Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="X6o4b/tU"; 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 k62si1382702pfc.208.2018.11.19.08.38.43; Mon, 19 Nov 2018 08:38:58 -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=@kernel.org header.s=default header.b="X6o4b/tU"; 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 S1732270AbeKTDBs (ORCPT + 99 others); Mon, 19 Nov 2018 22:01:48 -0500 Received: from mail.kernel.org ([198.145.29.99]:33870 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731329AbeKTDBr (ORCPT ); Mon, 19 Nov 2018 22:01:47 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 2F351206BA; Mon, 19 Nov 2018 16:37:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1542645458; bh=XjwywqNVjT8DKvYAThdV3hx8JPJbM/E/r5bhSB3C50g=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=X6o4b/tUxeJWkN3SYlBcZjE5Q9B0vkMRrfqRQY53KNqYVXXt6c0bGvhF3Ec8o3Wij JXViY7Zia5+l8nLFH0iEhyrWJ0x2Bs7SPsd6mgdVBJyKGaU3fKn8wo8DK/ClfKblPZ HbLZciGEuHJEQ6dxXYwG9W8mUC13Hw8+uSL4zDFQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Ard Biesheuvel , Linus Torvalds , Peter Zijlstra , Thomas Gleixner , linux-efi@vger.kernel.org, Ingo Molnar Subject: [PATCH 4.19 170/205] efi/arm/libstub: Pack FDT after populating it Date: Mon, 19 Nov 2018 17:27:57 +0100 Message-Id: <20181119162640.388446693@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181119162616.586062722@linuxfoundation.org> References: <20181119162616.586062722@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ From: Ard Biesheuvel commit 72a58a63a164b4e9d2d914e65caeb551846883f1 upstream. Commit: 24d7c494ce46 ("efi/arm-stub: Round up FDT allocation to mapping size") increased the allocation size for the FDT image created by the stub to a fixed value of 2 MB, to simplify the former code that made several attempts with increasing values for the size. This is reasonable given that the allocation is of type EFI_LOADER_DATA, which is released to the kernel unless it is explicitly memblock_reserve()d by the early boot code. However, this allocation size leaked into the 'size' field of the FDT header metadata, and so the entire allocation remains occupied by the device tree binary, even if most of it is not used to store device tree information. So call fdt_pack() to shrink the FDT data structure to its minimum size after populating all the fields, so that the remaining memory is no longer wasted. Signed-off-by: Ard Biesheuvel Cc: # v4.12+ Cc: Linus Torvalds Cc: Peter Zijlstra Cc: Thomas Gleixner Cc: linux-efi@vger.kernel.org Fixes: 24d7c494ce46 ("efi/arm-stub: Round up FDT allocation to mapping size") Link: http://lkml.kernel.org/r/20181114175544.12860-4-ard.biesheuvel@linaro.org Signed-off-by: Ingo Molnar Signed-off-by: Greg Kroah-Hartman --- drivers/firmware/efi/libstub/fdt.c | 4 ++++ 1 file changed, 4 insertions(+) --- a/drivers/firmware/efi/libstub/fdt.c +++ b/drivers/firmware/efi/libstub/fdt.c @@ -158,6 +158,10 @@ static efi_status_t update_fdt(efi_syste return efi_status; } } + + /* shrink the FDT back to its minimum size */ + fdt_pack(fdt); + return EFI_SUCCESS; fdt_set_fail: