Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1151430imu; Mon, 5 Nov 2018 14:58:57 -0800 (PST) X-Google-Smtp-Source: AJdET5e6TOm6ZI3fmYLkP0pCC3HaH0heiK8zp3HLqrOq6mN78sQjsuutEFGt5biCbKqFd0lffe2Q X-Received: by 2002:a17:902:2468:: with SMTP id m37-v6mr24168984plg.154.1541458737103; Mon, 05 Nov 2018 14:58:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1541458737; cv=none; d=google.com; s=arc-20160816; b=fkyMx/ikaCRRlWF+W+EBxPReJU6z2wfj5fXJfWBTp2beUf0DL1rXWHdmkBT17OToxX lKEmCvB99uUPmquw+oMoFxHltA1svYH0sPNDOoLHrgkql5Mdtqrs+DYDFWfBmEcm3HyX ymhbGH+Z4BOJnV1U9sTeFgwmnfRF7BDwpduH9L13R/bVNpT0A6d6FW5HaiMeUTnhytJ3 7npVBnVEx6pfvkUzPl2YySf+na8Jhv6T22ph2RMXKZZyGZVbs/ds7OZ+dVdOy0QGoAG2 wgIenmxnsf3nfGhHEdfjjLC1TqUG6feC+oRE/AWg6i7AxcfKxU/A1gg75pHPbzz+NCOv 4Vkw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature; bh=1qMAVSnywWT1jNzaP9Dz12jcC6XfF9pDAxMfxNaT2nA=; b=PxD+2b1Vbe6ilxg1plsziF8YWizl5sbUuEhTKktnefeC6aNZQ/4vrqOkN70KB7iuKg q0f/NwnuZe4EptX7s9QKCUJn2mIv8johkiQqs2S6J0nstAVB6sYdsXylzNKZzw2zF3SA h/3ucFxbH05h2ou3ANeiLZ9ZjvMm9TaRT0e4Hdok2ujwx+jUunv7CBojeAEcrCL9SX1u et6FIjutk+5Gd50Pd4fEEQ+VSuIRbui1Z2zykm90AkelwMp6sf3JmrEUAjuABx97ZQMJ rJ3DUMDjAEvGUwXS1CZsETYH/s3fAoZZI1yfOC81FFir1/T1/YQWWlvyJ6v/DgAyi+PV SrSA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=d4ra9uBP; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h23-v6si13336029plr.101.2018.11.05.14.58.42; Mon, 05 Nov 2018 14:58:57 -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=@gmail.com header.s=20161025 header.b=d4ra9uBP; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388343AbeKFIUK (ORCPT + 99 others); Tue, 6 Nov 2018 03:20:10 -0500 Received: from mail-pg1-f196.google.com ([209.85.215.196]:38451 "EHLO mail-pg1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388222AbeKFIUI (ORCPT ); Tue, 6 Nov 2018 03:20:08 -0500 Received: by mail-pg1-f196.google.com with SMTP id f8-v6so4902344pgq.5; Mon, 05 Nov 2018 14:58:06 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=1qMAVSnywWT1jNzaP9Dz12jcC6XfF9pDAxMfxNaT2nA=; b=d4ra9uBPAAmaXzt9tx0OsjsWeY8LJMwuxLCAnpsrGxJq9R67gIIK2Ct6lTD94UTQO2 qNz1+j2vm+tSCqGB1YXfwA6a63vN8rbIAFU/wp1ZYejV4SNcCFz3F03Ip3vNb5SNAJeK xVwOtoez07w6sWdhytcLAlVYXU+W/jhWcGMd0Kw7g4vHsp+NmXtHYxm8CCTCqqbxkT9F hMK/E3NbAHDDhKgNR6DKQ6K540B/GCi5E6iX7n8svrjdPZT/ijiGsw2oG7c3BTAD0Gva 9DEy82/jaK56LGAx19a/gTMgEdTDIAPwmwfOkQF8e6maHuH4qzpLxUwMBQfzdo40gj6/ 8BAQ== 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:in-reply-to :references; bh=1qMAVSnywWT1jNzaP9Dz12jcC6XfF9pDAxMfxNaT2nA=; b=N68+Istr358QhzEcmyj6IzUtMcPN/RjYIjDeK4tCrkibF+agrv37DTd3HOU4wQZUcg 94chDexpBhvamA2YNtUhOVVneMr/+DWFbDkVIZtSKLFBNfIPj9LJckXDt9bI6F8rkIcn EtIrOJr6y4gRWuioZ2coFjqoknD9n1su5dN0r1AX3z2seO3Qw4N7mBxs7yYT77WTUMXb RNJXYP0/6iEfinQ/IRFkg3bwWUymNQW6tCdOChDVBhiAArdLiTzOPSL9jmIWaCaygNXp yoRMSMqVGrHXe91rbYUHFvLHNbffY76cMF2HALHJZnev3emFrfJ7R++FaQkkPq15WUub wYJQ== X-Gm-Message-State: AGRZ1gI0jBeQWhvyDBaUxaHbjiWEuIdsxRrBGORTfy9UoQRLSICFrBfp Jim0xOKT17VAfJNuK7iivYgIHr3v X-Received: by 2002:a63:920a:: with SMTP id o10mr6911746pgd.141.1541458685571; Mon, 05 Nov 2018 14:58:05 -0800 (PST) Received: from fainelli-desktop.igp.broadcom.net ([192.19.223.250]) by smtp.gmail.com with ESMTPSA id q195sm12898479pgq.7.2018.11.05.14.58.03 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 05 Nov 2018 14:58:04 -0800 (PST) From: Florian Fainelli To: linux-kernel@vger.kernel.org Cc: Florian Fainelli , Catalin Marinas , Will Deacon , Rob Herring , Frank Rowand , Andrew Morton , Marc Zyngier , Russell King , Andrey Ryabinin , Andrey Konovalov , Masahiro Yamada , Robin Murphy , Laura Abbott , Stefan Agner , Johannes Weiner , Greg Hackmann , Kristina Martsenko , CHANDAN VN , linux-arm-kernel@lists.infradead.org (moderated list:ARM64 PORT (AARCH64 ARCHITECTURE)), devicetree@vger.kernel.org (open list:OPEN FIRMWARE AND FLATTENED DEVICE TREE), rppt@linux.ibm.com, linux@armlinux.org.uk, green.hu@gmail.com, deanbo422@gmail.com, gxt@pku.edu.cn, ard.biesheuvel@linaro.org, linux-snps-arc@lists.infradead.org, vgupta@synopsys.com Subject: [PATCH v4 5/6] of/fdt: Remove custom __early_init_dt_declare_initrd() implementation Date: Mon, 5 Nov 2018 14:54:30 -0800 Message-Id: <20181105225431.24485-6-f.fainelli@gmail.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20181105225431.24485-1-f.fainelli@gmail.com> References: <20181105225431.24485-1-f.fainelli@gmail.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Now that ARM64 uses phys_initrd_start/phys_initrd_size, we can get rid of its custom __early_init_dt_declare_initrd() which causes a fair amount of objects rebuild when changing CONFIG_BLK_DEV_INITRD. In order to make sure ARM64 does not produce a BUG() when VM debugging is turned on though, we must avoid early calls to __va() which is what __early_init_dt_declare_initrd() does and wrap this around to avoid running that code on ARM64. Signed-off-by: Florian Fainelli --- arch/arm64/include/asm/memory.h | 8 -------- drivers/of/fdt.c | 15 ++++++++++----- 2 files changed, 10 insertions(+), 13 deletions(-) diff --git a/arch/arm64/include/asm/memory.h b/arch/arm64/include/asm/memory.h index b96442960aea..dc3ca21ba240 100644 --- a/arch/arm64/include/asm/memory.h +++ b/arch/arm64/include/asm/memory.h @@ -168,14 +168,6 @@ #define IOREMAP_MAX_ORDER (PMD_SHIFT) #endif -#ifdef CONFIG_BLK_DEV_INITRD -#define __early_init_dt_declare_initrd(__start, __end) \ - do { \ - initrd_start = (__start); \ - initrd_end = (__end); \ - } while (0) -#endif - #ifndef __ASSEMBLY__ #include diff --git a/drivers/of/fdt.c b/drivers/of/fdt.c index 88760a0983a7..cd72a41fcab2 100644 --- a/drivers/of/fdt.c +++ b/drivers/of/fdt.c @@ -891,15 +891,20 @@ const void * __init of_flat_dt_match_machine(const void *default_match, } #ifdef CONFIG_BLK_DEV_INITRD -#ifndef __early_init_dt_declare_initrd static void __early_init_dt_declare_initrd(unsigned long start, unsigned long end) { - initrd_start = (unsigned long)__va(start); - initrd_end = (unsigned long)__va(end); - initrd_below_start_ok = 1; + /* ARM64 would cause a BUG to occur here when CONFIG_DEBUG_VM is + * enabled since __va() is called too early. ARM64 does make use + * of phys_initrd_start/phys_initrd_size so we can skip this + * conversion. + */ + if (!IS_ENABLED(CONFIG_ARM64)) { + initrd_start = (unsigned long)__va(start); + initrd_end = (unsigned long)__va(end); + initrd_below_start_ok = 1; + } } -#endif /** * early_init_dt_check_for_initrd - Decode initrd location from flat tree -- 2.17.1