Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp819300ybx; Thu, 7 Nov 2019 03:11:30 -0800 (PST) X-Google-Smtp-Source: APXvYqyKfrWdf9P0Rzp2VKLehOuhYQi8zFE+mT85VvYGR3YP/jhW4Fgxm9r34oNVH4rGTpfZgH6c X-Received: by 2002:a50:cd0f:: with SMTP id z15mr2833646edi.244.1573125090221; Thu, 07 Nov 2019 03:11:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573125090; cv=none; d=google.com; s=arc-20160816; b=F6Xaz5y6gkARXwO0DxhVA9sQp/rCDGZPMKpDfy0pRhp3QrrrmdFoeczdHqx2sdz1cS /9tUvAvV3i1xYkQnqoXkFGCBGQS09V6tcXuX1HEJKmH5ik+YB1LIOQF1ndsfYfa54lsn V/W06V9+9GOd1D7NL9GmywoYKWGpY7Txj27jbtQwWgZtvuGEgCzuaVX76d4bZbHyPUvi EjfuDwVUZsK3ccAqF710JP8YwKVxJh+O0CeSDbxzYOUDvbq/kbPTa7592+G5JcOJ3zRT vCtqvkyr229F2A2XYMFuPpPmgCmqCmGNMehQTgstIDO/FxIKA+XmrkTSLIAaNAUaa65p 79Vg== 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:in-reply-to :mime-version:user-agent:date:message-id:from:cc:references:to :subject; bh=jJPq9zsLo5CTo6R2XUPwnZrE2rIC4qO7Pg27bVLFFGM=; b=koQD6HS9FSDymnX4mgFnULBAzlGaQRB4AICC+sLvrYqL0xoAGKQc/eu0eXOMetWtK8 oMJ+7dSq5MPgBaEXWkmfzIKv79bDSV/5BB19d9i6RUFPI51Se6UvCN1v2PWckwI9j55L mM8D4D3JW+75s6TUDBQnFXnh3RYYW7Uilsnd+4hRx0QZSHkUHwMRpqs8GpzyewEToj4F jILouAt6Ll2fQnAQL7+3DrOa4Jbqbpz8VJ8NVOX4SHaguG6Cto1uRtQoLix7HhZY71bs VRs8diw4B3WEpY/nvDPcTh2N/jPtOZGrWqL1b8PS58gW9hoh9G4keB/ftvFhpXuENJii e6hA== ARC-Authentication-Results: i=1; mx.google.com; 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 r18si1100009edw.65.2019.11.07.03.11.06; Thu, 07 Nov 2019 03:11:30 -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; 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 S2388266AbfKGLIC (ORCPT + 99 others); Thu, 7 Nov 2019 06:08:02 -0500 Received: from mail.loongson.cn ([114.242.206.163]:60157 "EHLO mail.loongson.cn" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727278AbfKGLIB (ORCPT ); Thu, 7 Nov 2019 06:08:01 -0500 Received: from [10.20.41.27] (unknown [10.20.41.27]) by mail (Coremail) with SMTP id QMiowPDx72MC+8NdK2MAAA--.14S3; Thu, 07 Nov 2019 19:07:53 +0800 (CST) Subject: Re: [PATCH] MIPS: Scan the DMI system information To: Jean Delvare References: <5959f904-5c46-30a7-7a4f-17f692aca320@loongson.cn> <5c042bd8-40ad-e84f-588d-f3ee56f7216d@loongson.cn> <20191107114209.5e4cfa4d@endymion> Cc: Jiaxun Yang , Paul Burton , Ralf Baechle , James Hogan , Huacai Chen , linux-mips@vger.kernel.org, linux-kernel@vger.kernel.org, Yinglu Yang , Xuefeng Li From: Tiezhu Yang Message-ID: Date: Thu, 7 Nov 2019 19:07:25 +0800 User-Agent: Mozilla/5.0 (X11; Linux mips64; rv:45.0) Gecko/20100101 Thunderbird/45.4.0 MIME-Version: 1.0 In-Reply-To: <20191107114209.5e4cfa4d@endymion> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit X-CM-TRANSID: QMiowPDx72MC+8NdK2MAAA--.14S3 X-Coremail-Antispam: 1UD129KBjvJXoWxKF18ArWDZr4rKryftryUtrb_yoWxAw4rpF y8J3W5KF4UXr17Gr1Sq343XFnIyrs5JFWrXFy7JF17Awn0qr17Jr4Dt3yjkFy8Ar1kKFy0 9r1FgFW3uF15G3DanT9S1TB71UUUUUUqnTZGkaVYY2UrUUUUjbIjqfuFe4nvWSU5nxnvy2 9KBjDU0xBIdaVrnRJUUU9Y14x267AKxVW8JVW5JwAFc2x0x2IEx4CE42xK8VAvwI8IcIk0 rVWrJVCq3wAFIxvE14AKwVWUJVWUGwA2ocxC64kIII0Yj41l84x0c7CEw4AK67xGY2AK02 1l84ACjcxK6xIIjxv20xvE14v26r1I6r4UM28EF7xvwVC0I7IYx2IY6xkF7I0E14v26r4j 6F4UM28EF7xvwVC2z280aVAFwI0_Cr1j6rxdM28EF7xvwVC2z280aVCY1x0267AKxVW0oV Cq3wAS0I0E0xvYzxvE52x082IY62kv0487Mc02F40EFcxC0VAKzVAqx4xG6I80ewAv7VC0 I7IYx2IY67AKxVWUGVWUXwAv7VC2z280aVAFwI0_Gr0_Cr1lOx8S6xCaFVCjc4AY6r1j6r 4UM4x0Y48IcVAKI48JM4x0x7Aq67IIx4CEVc8vx2IErcIFxwACI402YVCY1x02628vn2kI c2xKxwCYjI0SjxkI62AI1cAE67vIY487MxAIw28IcxkI7VAKI48JMxC20s026xCaFVCjc4 AY6r1j6r4UMI8I3I0E5I8CrVAFwI0_Jr0_Jr4lx2IqxVCjr7xvwVAFwI0_JrI_JrWlx4CE 17CEb7AF67AKxVWUtVW8ZwCIc40Y0x0EwIxGrwCI42IY6xIIjxv20xvE14v26r1j6r1xMI IF0xvE2Ix0cI8IcVCY1x0267AKxVWUJVW8JwCI42IY6xAIw20EY4v20xvaj40_WFyUJVCq 3wCI42IY6I8E87Iv67AKxVWUJVW8JwCI42IY6I8E87Iv6xkF7I0E14v26r4j6r4UJbIYCT nIWIevJa73UjIFyTuYvjfUOGQDUUUUU X-CM-SenderInfo: p1dqw3xlh2x3gn0dqz5rrqw2lrqou0/ Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11/07/2019 06:42 PM, Jean Delvare wrote: > On Thu, 7 Nov 2019 17:26:58 +0800, Tiezhu Yang wrote: >> Sorry to resend this email because the mail list server was denied >> due to it is not plain text. >> >> On 11/07/2019 11:42 AM, Jiaxun Yang wrote: >>> 于 2019年11月7日 GMT+08:00 上午10:42:23, Tiezhu Yang 写到: >>>> On 11/07/2019 08:35 AM, Jiaxun Yang wrote: >>>>> 于 2019年11月7日 GMT+08:00 上午12:05:41, Tiezhu Yang >>>> 写到: >>>>>> Enable DMI scanning on the MIPS architecture, this setups DMI >>>>>> identifiers >>>>>> (dmi_system_id) for printing it out on task dumps and prepares DIMM >>>>>> entry >>>>>> information (dmi_memdev_info) from the SMBIOS table. With this >>>> patch, >>>>>> the >>>>>> driver can easily match various of mainboards. >>>>>> >>>>>> In the SMBIOS reference specification, the table anchor string >>>> "_SM_" >>>>>> is >>>>>> present in the address range 0xF0000 to 0xFFFFF on a 16-byte >>>> boundary, >>>>>> but there exists a special case for loongson platform, when call >>>>>> function >>>>>> dmi_early_remap, it should specify the start address to 0xFFFE000 >>>> due >>>>>> to >>>>>> it is reserved for SMBIOS and can be normally access in the BIOS. >>>>>> >>>>>> Co-developed-by: Yinglu Yang >>>>>> Signed-off-by: Yinglu Yang >>>>>> Signed-off-by: Tiezhu Yang >>>>>> --- >>>>>> arch/mips/Kconfig | 12 ++++++++++++ >>>>>> arch/mips/include/asm/dmi.h | 43 >>>>>> +++++++++++++++++++++++++++++++++++++++++++ >>>>>> arch/mips/kernel/setup.c | 2 ++ >>>>>> 3 files changed, 57 insertions(+) >>>>>> create mode 100644 arch/mips/include/asm/dmi.h >>>>>> >>>>>> diff --git a/arch/mips/Kconfig b/arch/mips/Kconfig >>>>>> index 7cb8947..0a67b18 100644 >>>>>> --- a/arch/mips/Kconfig >>>>>> +++ b/arch/mips/Kconfig >>>>>> @@ -2757,6 +2757,18 @@ config HW_PERF_EVENTS >>>>>> Enable hardware performance counter support for perf events. If >>>>>> disabled, perf events will use software events only. >>>>>> >>>>>> +# Mark as expert because too many people got it wrong. >>>>>> +# The code disables itself when not needed. >>>>>> +config DMI >>>>>> + default y >>>>>> + select DMI_SCAN_MACHINE_NON_EFI_FALLBACK >>>>>> + bool "Enable DMI scanning" if EXPERT >>>>>> + help >>>>>> + Enabled scanning of DMI to identify machine quirks. Say Y >>>>>> + here unless you have verified that your setup is not >>>>>> + affected by entries in the DMI blacklist. Required by PNP >>>>>> + BIOS code. >>>>>> + >>>>>> config SMP >>>>>> bool "Multi-Processing support" >>>>>> depends on SYS_SUPPORTS_SMP >>>>>> diff --git a/arch/mips/include/asm/dmi.h >>>> b/arch/mips/include/asm/dmi.h >>>>>> new file mode 100644 >>>>>> index 0000000..1f3da37 >>>>>> --- /dev/null >>>>>> +++ b/arch/mips/include/asm/dmi.h >>>>>> @@ -0,0 +1,43 @@ >>>>>> +/* SPDX-License-Identifier: GPL-2.0 */ >>>>>> +#ifndef _ASM_MIPS_DMI_H >>>>>> +#define _ASM_MIPS_DMI_H >>>>>> + >>>>>> +#define dmi_early_remap mips_early_memremap >>>>>> +#define dmi_early_unmap mips_early_memunmap >>>>>> +#define dmi_remap(_x, _l) mips_memremap(_x, _l, MEMREMAP_WB) >>>>>> +#define dmi_unmap(_x) mips_memunmap(_x) >>>>>> + >>>>>> +#define dmi_alloc(l) memblock_alloc_low(l, PAGE_SIZE) >>>>>> + >>>>>> +void __init *mips_early_memremap(resource_size_t phys_addr, >>>> unsigned >>>>>> long size) >>>>>> +{ >>>>>> +#if defined(CONFIG_MACH_LOONGSON64) >>>>>> + if (phys_addr == 0xF0000) >>>>>> + phys_addr = 0xFFFE000; >>>>>> + >>>>>> + return (void *)TO_CAC(phys_addr); >>>>>> +#else >>>>>> + return NULL; >>>>>> +#endif >>>>>> +} >>>>> Hi Tiezhu, >>>>> >>>>> It is really tricky to hijack dmi address here during remap. >>>>> I think we should set the dmi table address at dmi_scan.c by a marco >>>> or something else rather than hijack it during remap. >>>> >>>> Hi Jiaxun, >>>> >>>> Thanks for your review. I agree with you, let me think about it and try >>>> to >>>> find a proper way, and then I will send a v2 patch. >> Hi Jiaxun, >> >> It seems that there is no absolutely better way to handle this case. >> >> 1. use conditional compilation in drivers/firmware/dmi_scan.c: >> >> #if defined(CONFIG_MACH_LOONGSON64) >> >> p = dmi_early_remap(0xFFFE000, 0x10000); >> >> #else >> >> p = dmi_early_remap(0xF0000, 0x10000); >> >> #endif >> >> >> This will influence the common code. >> >> 2. use callback function in arch/mips/include/asm/dmi.h: > I see no reason to go that route if the decision can be made at build > time. Callback functions are good when the decision is made at run time. > >> struct plat_dmi_ops { >> >> void (*early_memremap)(void); >> >> void (*memremap)(void); >> >> }; >> >> extern struct plat_dmi_ops *dmi_ops; >> >> void __init *mips_early_memremap(resource_size_t phys_addr, unsigned long size) >> >> { >> >> dmi_ops->early_memremap(); >> >> } >> >> void *mips_memremap(resource_size_t offset, size_t size, unsigned long flags) >> >> { >> >> dmi_ops->memremap(); >> >> } >> >> >> we can implement the callback function in various of MIPS platforms, >> like this: >> >> struct plat_dmi_ops loongson3_dmi_ops = { >> >> .early_memremap = loongson3_early_memremap, >> >> .memremap = loongson3_memremap, >> >> }; >> >> register_dmi_ops(&loongson3_dmi_ops); >> >> #ifdef CONFIG_DMI >> >> void __init *loongson3_early_memremap(resource_size_t phys_addr, unsigned long size) >> >> { >> >> if (phys_addr == 0xF0000) >> >> phys_addr = 0xfffe000; >> >> return (void *)TO_CAC(phys_addr); >> >> } >> >> void *loongson3_memremap(resource_size_t offset, size_t size, unsigned long flags) >> >> { >> >> return (void *)TO_CAC(phys_addr); >> >> } >> >> #else >> >> void __init __iomem *loongson3_early_memremap(u64 phys_addr, unsigned long size) >> >> { >> >> return NULL; >> >> } >> >> void __init __iomem *loongson3_memremap(u64 phys_addr, unsigned long size) >> >> { >> >> return NULL; >> >> } >> >> #endif >> >> >> This will not influence the common code. >> >> What do you think? >> >> >> Hi Jean, >> >> Could you give some suggestions? > What about: > > #if defined(CONFIG_MACH_LOONGSON64) > #define SMBIOS_ENTRY_POINT_SCAN_START 0xFFFE000 > #else > #define SMBIOS_ENTRY_POINT_SCAN_START 0xF0000 > #endif > > And then just use SMBIOS_ENTRY_POINT_SCAN_START instead of the raw > address everywhere it is needed? OK, good idea, thank you very much! I will send a v2 patch as soon as possible. Thanks, Tiezhu Yang >