Received: by 2002:a05:6a10:413:0:0:0:0 with SMTP id 19csp1801588pxp; Mon, 7 Mar 2022 02:40:43 -0800 (PST) X-Google-Smtp-Source: ABdhPJz5Vb+zBcaSTaRoToFfPaXxFzEpM2HxVQF9EVZZjqz2oKK1tXDbid0rRJUTO5BHjtdrUy/w X-Received: by 2002:a17:907:720a:b0:6da:e533:6440 with SMTP id dr10-20020a170907720a00b006dae5336440mr8891388ejc.679.1646649643175; Mon, 07 Mar 2022 02:40:43 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1646649643; cv=none; d=google.com; s=arc-20160816; b=x6yJCYt7XSc8Oo3KfVnqywnnByVfJxtG0goV+Ge7N8upW2r/H+NFjQzb1zmXWD9WTX 9mTRXroo7b525QNTxyLwF4bBvEYtlpcNOQmoBnbSRHmWBXvuG2GR8rlV/LKSbpcW9vWR cu7sOHsk109c23gFCpUOygbp9whs6ZmADsF8pdD6PjViU856LmRECGidkkcFcWiFgTvP zSQffDZB2b4OAqV9A9gSoUPlZhg2x0FznzEszfOkimUgxlznJPHHN16d3aLA1j+zo3BZ qTtvAlIYcb/E8CnNEsFZC0XSD1LxB2sh/nYbbA2ThF767PxC3ngDxWau0R2d2oEkdUAg SXGg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=c5rGMCgQduKYy6MRlQoZ/e/BMOkOuXM7YPYyTKFIvgY=; b=HPosgnbZm/AnL+oz9oMZgRv+M5JbgTHLxcgsuCLFPmGLzeMTdRteSQqkB8UgAUivay x/AmcD28JEmGf0G8Znq7ffiVqGWSbl/J7XsX1U4n8LWe4W3YUfjQF/XmsHAlycmhSBPq 0bqdA0eUPmzzuwQ5H/eOoux3ZfIxYAOfnqNU+mKcj/yzYPS5fGRhN3BSjphYZcYPZSdJ vQEhREBqIruG1L8mr7Yh2ZDEg3FvbMiSl9oqWRzNuoM9e/gY75TVhg94RXDfaMC4PRCj WF+d4XhMq1l5FVpS0Wzv8OSOKVFIW+N3zPJrKRaJsAKyUyFRaoXzmh89v4I8EbgfwRqw Cn/g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=NieYrSNd; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id l7-20020a056402254700b00415322bd915si11902917edb.610.2022.03.07.02.40.16; Mon, 07 Mar 2022 02:40:43 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=NieYrSNd; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236887AbiCGKM0 (ORCPT + 99 others); Mon, 7 Mar 2022 05:12:26 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47768 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238730AbiCGJyx (ORCPT ); Mon, 7 Mar 2022 04:54:53 -0500 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4B0CC77A8D; Mon, 7 Mar 2022 01:45:32 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 8F7D161382; Mon, 7 Mar 2022 09:45:30 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 80630C340E9; Mon, 7 Mar 2022 09:45:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1646646330; bh=x+/m0XSob4i8XhaSbKnkLEgxtn13mwwPLD6Br4nANn4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=NieYrSNdiyZia+llTzXr8m2nFNuoMl7zkyjzIBFX+pfEuqRHtGpVxcOxfg6fnt6cc YYHOxYXzMALx2DSLypctg3Ah/ei5lBVNov2XFAi+qY4Nvy7EJRHr4wlRC2uEZepX7R oQHavygF647Bvnm5L5uc/EJoIvqvjSyYApYoMP9M= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Rui Salvaterra , Chuanhong Guo , Sergio Paracuellos , Thomas Bogendoerfer , Sasha Levin Subject: [PATCH 5.15 207/262] MIPS: ralink: mt7621: do memory detection on KSEG1 Date: Mon, 7 Mar 2022 10:19:11 +0100 Message-Id: <20220307091708.646624628@linuxfoundation.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220307091702.378509770@linuxfoundation.org> References: <20220307091702.378509770@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.6 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Chuanhong Guo [ Upstream commit cc19db8b312a6c75645645f5cc1b45166b109006 ] It's reported that current memory detection code occasionally detects larger memory under some bootloaders. Current memory detection code tests whether address space wraps around on KSEG0, which is unreliable because it's cached. Rewrite memory size detection to perform the same test on KSEG1 instead. While at it, this patch also does the following two things: 1. use a fixed pattern instead of a random function pointer as the magic value. 2. add an additional memory write and a second comparison as part of the test to prevent possible smaller memory detection result due to leftover values in memory. Fixes: 139c949f7f0a MIPS: ("ralink: mt7621: add memory detection support") Reported-by: Rui Salvaterra Signed-off-by: Chuanhong Guo Tested-by: Sergio Paracuellos Tested-by: Rui Salvaterra Signed-off-by: Thomas Bogendoerfer Signed-off-by: Sasha Levin --- arch/mips/ralink/mt7621.c | 36 +++++++++++++++++++++++------------- 1 file changed, 23 insertions(+), 13 deletions(-) diff --git a/arch/mips/ralink/mt7621.c b/arch/mips/ralink/mt7621.c index bd71f5b14238..fd9a872d5713 100644 --- a/arch/mips/ralink/mt7621.c +++ b/arch/mips/ralink/mt7621.c @@ -20,31 +20,41 @@ #include "common.h" -static void *detect_magic __initdata = detect_memory_region; +#define MT7621_MEM_TEST_PATTERN 0xaa5555aa + +static u32 detect_magic __initdata; phys_addr_t mips_cpc_default_phys_base(void) { panic("Cannot detect cpc address"); } +static bool __init mt7621_addr_wraparound_test(phys_addr_t size) +{ + void *dm = (void *)KSEG1ADDR(&detect_magic); + + if (CPHYSADDR(dm + size) >= MT7621_LOWMEM_MAX_SIZE) + return true; + __raw_writel(MT7621_MEM_TEST_PATTERN, dm); + if (__raw_readl(dm) != __raw_readl(dm + size)) + return false; + __raw_writel(!MT7621_MEM_TEST_PATTERN, dm); + return __raw_readl(dm) == __raw_readl(dm + size); +} + static void __init mt7621_memory_detect(void) { - void *dm = &detect_magic; phys_addr_t size; - for (size = 32 * SZ_1M; size < 256 * SZ_1M; size <<= 1) { - if (!__builtin_memcmp(dm, dm + size, sizeof(detect_magic))) - break; + for (size = 32 * SZ_1M; size <= 256 * SZ_1M; size <<= 1) { + if (mt7621_addr_wraparound_test(size)) { + memblock_add(MT7621_LOWMEM_BASE, size); + return; + } } - if ((size == 256 * SZ_1M) && - (CPHYSADDR(dm + size) < MT7621_LOWMEM_MAX_SIZE) && - __builtin_memcmp(dm, dm + size, sizeof(detect_magic))) { - memblock_add(MT7621_LOWMEM_BASE, MT7621_LOWMEM_MAX_SIZE); - memblock_add(MT7621_HIGHMEM_BASE, MT7621_HIGHMEM_SIZE); - } else { - memblock_add(MT7621_LOWMEM_BASE, size); - } + memblock_add(MT7621_LOWMEM_BASE, MT7621_LOWMEM_MAX_SIZE); + memblock_add(MT7621_HIGHMEM_BASE, MT7621_HIGHMEM_SIZE); } void __init ralink_of_remap(void) -- 2.34.1