Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2977621imu; Mon, 19 Nov 2018 08:53:47 -0800 (PST) X-Google-Smtp-Source: AJdET5cTUiE6uMkFOZ3wRgMY7c0/S6cleK0QPJWWMibQacLlgWVGb/gMG+/lDZhueLvRYiBcuRT4 X-Received: by 2002:a62:35c2:: with SMTP id c185-v6mr23938814pfa.82.1542646427200; Mon, 19 Nov 2018 08:53:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542646427; cv=none; d=google.com; s=arc-20160816; b=RkAzIxGKcRdYd1/XFDEKsXqhaWrZoe9xUWCtFmc+/R25cS2PhgOHA1hwdB1f0XdKB/ 0NYVEWfd6zG4sf0FI4owaHOaC64XkOW6+PKJO++6KcAdO9smNXq3OKS1WHtfpCVkjC51 0nzL02USJ87etlcLVoXqdiGPGBS4awUxFjDsodfJiBEB6Aq3y9MeD5u1sB4UqtVb4txI eRsfQmiHx2bBJKqO8pp3U26mGCDEwQ3dGJU5RUUgokvfo23dqUvAKBtgYxJuD7EU4lhR A8/0a4OrCOcE3AjCBgzyXKLs6MPU+H1rG9IoLaacVUr3/EqbhCM41+mi3NGYv3/b/lcD HwDw== 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=7sEQTlHBOIT/zLtxdEChiF1BBTwzYXdGMIhkoxm5E24=; b=wydhh8xljbbyD4jCi30eW587AXPAkbDgoypoy80jvwrtIkbL3WH3GS6o276mmM4KC8 T2JzhNk3kKnk58yVnzI48Uiu624iol22+zYamCR2U1/iZ+kek8SMBi1oqcP/yX6QR9cy Ag0+2fSlHkHwpmHJi65Iki3ka4H8CfvgfXKXgyEkl/IfrhOp0ieEeeWufYhnkcAg3d/P hVraBoglN8ZuOUqsC8xm6xNqZipVphZArDYNltEI+UwK11KV6y8GQK9pcaoENfbPIYjM OBpliEX77QG6SG7IJ9dnbkoXIBxcgGutUDk19gk1Hveyr1SxX6NXxpO+rCGixRGmDm+P IInA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="qRq/ZU6U"; 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 n18-v6si39744544plp.294.2018.11.19.08.53.32; Mon, 19 Nov 2018 08:53:47 -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="qRq/ZU6U"; 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 S2390291AbeKTDPi (ORCPT + 99 others); Mon, 19 Nov 2018 22:15:38 -0500 Received: from mail.kernel.org ([198.145.29.99]:53280 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388976AbeKTDPi (ORCPT ); Mon, 19 Nov 2018 22:15:38 -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 632C121104; Mon, 19 Nov 2018 16:51:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1542646284; bh=NFTAlqOm3CNhrPW097BdSYQkk3pTnK0hzBLye1OUn1Y=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=qRq/ZU6UFY8PBHXftpxBITIq/cwnVlEbnPV0Zzfz/4GJ+c0+xROqFks6JRMQnsjF2 0BZKba2dhAbHv6+XSx95coFH+r7P5hnTTBlwmGild3idxMUzp85xV17P+Cq9wJhq1b T/NsYdg/VnX8lfO1Gkk+ZAdMUKrzIhcmdvbBPmvI= 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.14 106/124] efi/arm/libstub: Pack FDT after populating it Date: Mon, 19 Nov 2018 17:29:20 +0100 Message-Id: <20181119162632.045038306@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181119162612.951907286@linuxfoundation.org> References: <20181119162612.951907286@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.14-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: