Received: by 2002:ac0:98c7:0:0:0:0:0 with SMTP id g7-v6csp5339171imd; Tue, 30 Oct 2018 16:09:00 -0700 (PDT) X-Google-Smtp-Source: AJdET5cvn2hue9HTqPZ3YcavJ4ouLLhFHcMvIx4zJJ7I0JVrfaeNmgvOpabpWB9zuE+oOPSQ32oA X-Received: by 2002:a63:2c8a:: with SMTP id s132-v6mr654269pgs.73.1540940940869; Tue, 30 Oct 2018 16:09:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1540940940; cv=none; d=google.com; s=arc-20160816; b=RYqR8rzDQ6uwHNVleBcTd+AF+eRMM2Yp8j5SwOYgS519cfDzeKeYw6nJHAyzYzH7B3 RFaa6izKIy7vs7AR8rcxBsjqM58aShYiyqkd48roJoMxmr2Q3m1ABI1ln8JEU26z2HTD 1DXN043nLZkc1aJy326JfSnpiueYEja6uI3QQXBefusGDpxdV2WC6LTKZIMLcfrySe6w qqs749rp66ldC01thMcXb+8p5XRtbXTucUjHnk10cN1yJ0s0r2kdRNa0NaT5BwnhzqJh VjxjEIOPb68E7TbUWW3litKrakb9m8cdzpjLxWSO1z6jXAQBeHVuZGgYnsP6aphQInbV v16Q== 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=CteUHCiT3bh5b73LsUL36lgcSDw4lEHSbSt99SlriBg=; b=retKtOrWAsGY9WWcd2X8CHL9yxahMDhBinUNrrGNinJzhrCF2h9hdKqciq5/Jsuv5q 9wvLzzG3h6BPz62VgCtHGfw/vA4TYhgYZ1AOwdfubh4m7hUz6VsOuQmMr8jeSAtemLSH o9EDNFyt/2zDFZ89g7f09mbXhpK5bWFZHZayxHUjBPFbb+W0XdmcE7rbOfXwCi8VlUoK BtIX+o50CnamnGkiqyOi0LmCF+GNgClXfC6xoSFfNjunj/x5kCDvsPMh6I+QwesqIC5o FR2Ev+7XHEXGHZdwidW3Tj3PhZMcUbXcg06OhLpGPOp+fxeYfkUhVkAL13Gxvg5V9O/T M7pg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=UUXhujGf; 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 k135-v6si9441690pfd.239.2018.10.30.16.08.45; Tue, 30 Oct 2018 16:09:00 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=UUXhujGf; 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 S1728740AbeJaIDX (ORCPT + 99 others); Wed, 31 Oct 2018 04:03:23 -0400 Received: from mail-pl1-f195.google.com ([209.85.214.195]:32827 "EHLO mail-pl1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727858AbeJaIDW (ORCPT ); Wed, 31 Oct 2018 04:03:22 -0400 Received: by mail-pl1-f195.google.com with SMTP id x6-v6so6303872pln.0; Tue, 30 Oct 2018 16:07:54 -0700 (PDT) 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=CteUHCiT3bh5b73LsUL36lgcSDw4lEHSbSt99SlriBg=; b=UUXhujGfL14NRDqPfKn6FSvhZSCfkSHNuSb5jfvBJnOc0CLZptOttqXRuyXYZg2bMd 7rj6ddzD+CbrCTySSyyZzBwZoBP/QKiK7yU0bxDG5+vIHY+OX0ecE83Yl/qeIYA3az1f y9RBbutQnQaMojkxq1YZSJUxRQWhDoJnyZeo1czpiEbFe8K9prQ5RmosLxexxJkH6MJ7 56Aq9Ic81IH1sCbTEPIBvrCY8yJXlTyob+r0xkB+g/K6pxUgDvn9WefsWoE4CBcW5hBC oaVUKTab5Zn17XsO9uVcyKnoV+2Y9QiAmGFc9CVGigSw4tRmSOo8xFUGd8S/Jt5SS5Xb 1Pmg== 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=CteUHCiT3bh5b73LsUL36lgcSDw4lEHSbSt99SlriBg=; b=DztnVcRTmrfH39jhSA51rhtTooCm11B3N70B7GFeIjaWTEPKfKF+6tpd+YNdO7xWFh vxhZxPh460Sbs076tnB1wwEWRUIwb/9GDJZDdV4LTmvJ050TiToCNFObJcBBBhvra0aT Fye+N4lmxeGDorvIlItgfDS7w4cESYx708n5O7Cfb00tHAX9Kgto4TxIhPA9yjNTJBxR HX9v7W9SCitUUmFyF3WrK5T9zTh73jeUrNvRgqK0PzMLylMg2M3o7atF67DrJ0BQT6mV 9K2p0JBw7H/auyIlIj68Uo2lds1vSJZbBLCXvXQ7kw2ouT8lj8MbRJf7N4Lnhc4ewCKq /gig== X-Gm-Message-State: AGRZ1gJQ56vPRyh5RLu9HPOY8AsxapFBQ9WE52/feCumBdu9c76RdEqZ Pq8saZOzmYQfnoELdu4mKjHvMWJ4 X-Received: by 2002:a17:902:8bc6:: with SMTP id r6-v6mr728986plo.0.1540940873633; Tue, 30 Oct 2018 16:07:53 -0700 (PDT) Received: from fainelli-desktop.igp.broadcom.net ([192.19.223.250]) by smtp.gmail.com with ESMTPSA id f14-v6sm3431689pgr.87.2018.10.30.16.07.51 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 30 Oct 2018 16:07:52 -0700 (PDT) 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 v2 4/6] arm64: Utilize phys_initrd_start/phys_initrd_size Date: Tue, 30 Oct 2018 16:07:19 -0700 Message-Id: <20181030230721.28429-5-f.fainelli@gmail.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20181030230721.28429-1-f.fainelli@gmail.com> References: <20181030230721.28429-1-f.fainelli@gmail.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org ARM64 is the only architecture that re-defines __early_init_dt_declare_initrd() in order for that function to populate initrd_start/initrd_end with physical addresses instead of virtual addresses. Instead of having an override we can leverage drivers/of/fdt.c populating phys_initrd_start/phys_initrd_size to populate those variables for us. Signed-off-by: Florian Fainelli --- arch/arm64/mm/init.c | 21 +++++++++------------ 1 file changed, 9 insertions(+), 12 deletions(-) diff --git a/arch/arm64/mm/init.c b/arch/arm64/mm/init.c index 3cf87341859f..e95cee656a55 100644 --- a/arch/arm64/mm/init.c +++ b/arch/arm64/mm/init.c @@ -72,8 +72,8 @@ static int __init early_initrd(char *p) if (*endp == ',') { size = memparse(endp + 1, NULL); - initrd_start = start; - initrd_end = start + size; + phys_initrd_start = start; + phys_initrd_size = size; } return 0; } @@ -408,14 +408,14 @@ void __init arm64_memblock_init(void) memblock_add(__pa_symbol(_text), (u64)(_end - _text)); } - if (IS_ENABLED(CONFIG_BLK_DEV_INITRD) && initrd_start) { + if (IS_ENABLED(CONFIG_BLK_DEV_INITRD) && phys_initrd_size) { /* * Add back the memory we just removed if it results in the * initrd to become inaccessible via the linear mapping. * Otherwise, this is a no-op */ - u64 base = initrd_start & PAGE_MASK; - u64 size = PAGE_ALIGN(initrd_end) - base; + u64 base = phys_initrd_start & PAGE_MASK; + u64 size = PAGE_ALIGN(phys_initrd_size); /* * We can only add back the initrd memory if we don't end up @@ -460,13 +460,10 @@ void __init arm64_memblock_init(void) */ memblock_reserve(__pa_symbol(_text), _end - _text); #ifdef CONFIG_BLK_DEV_INITRD - if (initrd_start) { - memblock_reserve(initrd_start, initrd_end - initrd_start); - - /* the generic initrd code expects virtual addresses */ - initrd_start = __phys_to_virt(initrd_start); - initrd_end = __phys_to_virt(initrd_end); - } + /* the generic initrd code expects virtual addresses */ + initrd_start = __phys_to_virt(phys_initrd_start); + initrd_end = initrd_start + phys_initrd_size; + initrd_below_start_ok = 0; #endif early_init_fdt_scan_reserved_mem(); -- 2.17.1