Received: by 2002:ab3:689a:0:b0:1da:d01c:d2b2 with SMTP id t26csp2624ltj; Fri, 19 Aug 2022 15:48:01 -0700 (PDT) X-Google-Smtp-Source: AA6agR65skmtD0KXXAPmAcAB/yJhlX5XOaC0se7a5m/fpH3MRmt8kAVqlGZ5Z585D/mKiZ6FcTqB X-Received: by 2002:a63:dd4b:0:b0:41d:e855:7137 with SMTP id g11-20020a63dd4b000000b0041de8557137mr8203581pgj.595.1660949281682; Fri, 19 Aug 2022 15:48:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1660949281; cv=none; d=google.com; s=arc-20160816; b=1CY5pe1tdMYLICPptx/f2D6y1YjVhu6a0Ia4yrASlrofVhfw+JDtOpQmIeifMDqC+H EIS/6YzRaGUEpjm/t8HIL613x3SXtB3KihYYaqmxf0pUcgucT/FLkEo0dHg843lpHfYt bKFxFSqiCI0qGj3VurH+do644aaZb+1bLNVXkCgj+j0ALJ37fJ5IaGvfk7ZscFmEp9Xm GYZShb8xTf8QNzFTe0bgWP53MsUkQiXqDu7jZOo1pzbQ3cjpTyuC4BqpEN6/57sleBYu 81Bm6Mt/kmP0UU/bb3Fnt6XNqr68qV0aciAF0TLok6o5AZHN6O9uf6csAXZ6eHTXPJ2s dIVQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=srw+B0lt25Uk8V1RVsMgpEZ2IPWMbJUx+/4Q3wVt0bA=; b=louky5ZAyuAAoCJ67G5hLA0bYdguAzMKlUc1BTJf4PX1gK74uycuradp3D4GLZRdZR TXnRMGeUtEpxNA40DTwmiWlO6mOKzCilApD5/cbsdVFdK40ApdOW0daxMF+3d82F9u72 r4iDoc/DlCfRoKlN3/lh3JJleky25H9Zej8FSSuBp0u+PzDBJYbW/WDn7GxplySVFwnm Mero0WwpVfg1uJJIsA1tD4ls019cmFcKgNrC3MGpe4Rf6F4p4MaNQ90zsEDBQbGZj8/I a4HGkPt4JZx+nzR/dJRV1mDZ6UgTVrg/rgn+5RMEvNAakb4VK2gv2kxLQ8r0sXeCzQhZ X8LQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=bombadil.20210309 header.b=reYgRlcm; 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id u4-20020a170902e80400b0016c049ada3csi5524104plg.454.2022.08.19.15.47.47; Fri, 19 Aug 2022 15:48:01 -0700 (PDT) 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=@infradead.org header.s=bombadil.20210309 header.b=reYgRlcm; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242454AbiHSWeh (ORCPT + 99 others); Fri, 19 Aug 2022 18:34:37 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40974 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242363AbiHSWee (ORCPT ); Fri, 19 Aug 2022 18:34:34 -0400 Received: from bombadil.infradead.org (bombadil.infradead.org [IPv6:2607:7c80:54:3::133]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E1FA76A4B8 for ; Fri, 19 Aug 2022 15:34:31 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20210309; h=Content-Transfer-Encoding: Content-Type:In-Reply-To:From:References:Cc:To:Subject:MIME-Version:Date: Message-ID:Sender:Reply-To:Content-ID:Content-Description; bh=srw+B0lt25Uk8V1RVsMgpEZ2IPWMbJUx+/4Q3wVt0bA=; b=reYgRlcmliYnCdzsm2mAVcPYgB CtidlA7Bqsu15v1f7j8GEehKhdqKu0N7ufjGrQAZVPR71+YDw1u3evzzW3ocdp9aDuDn0pSI4ZwTW yjxBB4qdh5l7DpheNC0oYb8AK5rKF2qTD32nNwIvdFQo88sevY4VZPLOM7MhjICee3UPzCCWOmCum cGjcvgrk/LNrED/1OxFe465et0dAjiYsBjaMfdpkEZSn8yZNs26f/7IVleBTpwqUpQfVMr4T1nuKD 4SqGBaljOX1PAp7QOxrMDydALnLVvtxSkjaqk0lYmS02I3J3jki18kGWZDMUfvoNMnx57zsVXqxEi 7o/ZPQCg==; Received: from [2601:1c0:6280:3f0::a6b3] by bombadil.infradead.org with esmtpsa (Exim 4.94.2 #2 (Red Hat Linux)) id 1oPAZD-00Cvld-FQ; Fri, 19 Aug 2022 22:34:15 +0000 Message-ID: <35c0ff6a-387d-3c01-66b3-f659cfe67c2a@infradead.org> Date: Fri, 19 Aug 2022 15:34:14 -0700 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.11.0 Subject: Re: [PATCH] powerpc: Add support for early debugging via Serial 16550 console Content-Language: en-US To: =?UTF-8?Q?Pali_Roh=c3=a1r?= , Michael Ellerman , Benjamin Herrenschmidt , Paul Mackerras , Nick Child Cc: linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org References: <20220819211254.22192-1-pali@kernel.org> From: Randy Dunlap In-Reply-To: <20220819211254.22192-1-pali@kernel.org> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.8 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_LOW, SPF_HELO_NONE,SPF_NONE,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 Hi-- On 8/19/22 14:12, Pali Rohár wrote: > Currently powerpc early debugging contains lot of platform specific > options, but does not support standard UART / serial 16550 console. > > Later legacy_serial.c code supports registering UART as early debug console > from device tree but it is not early during booting, but rather later after > machine description code finishes. > > So for real early debugging via UART is current code unsuitable. > > Add support for new early debugging option CONFIG_PPC_EARLY_DEBUG_16550 > which enable Serial 16550 console on address defined by new option > CONFIG_PPC_EARLY_DEBUG_16550_PHYSADDR and by stride by option > CONFIG_PPC_EARLY_DEBUG_16550_STRIDE. > > With this change it is possible to debug powerpc machine descriptor code. > For example this early debugging code can print on serial console also > "No suitable machine description found" error which is done before > legacy_serial.c code. > > Signed-off-by: Pali Rohár > --- > Tested on P2020 board. It allowed me do debug and implement this patch series: > https://lore.kernel.org/linuxppc-dev/20220819191557.28116-1-pali@kernel.org/ > --- > arch/powerpc/Kconfig.debug | 14 ++++++++++++++ > arch/powerpc/include/asm/udbg.h | 1 + > arch/powerpc/kernel/udbg.c | 2 ++ > arch/powerpc/kernel/udbg_16550.c | 33 ++++++++++++++++++++++++++++++++ > 4 files changed, 50 insertions(+) > > diff --git a/arch/powerpc/Kconfig.debug b/arch/powerpc/Kconfig.debug > index 9f363c143d86..a4e7d90a45d2 100644 > --- a/arch/powerpc/Kconfig.debug > +++ b/arch/powerpc/Kconfig.debug > @@ -276,6 +276,11 @@ config PPC_EARLY_DEBUG_OPAL_HVSI > Select this to enable early debugging for the PowerNV platform > using an "hvsi" console > > +config PPC_EARLY_DEBUG_16550 > + bool "Serial 16550" > + help > + Select this to enable early debugging via Serial 16550 console > + > config PPC_EARLY_DEBUG_MEMCONS > bool "In memory console" > help > @@ -355,6 +360,15 @@ config PPC_EARLY_DEBUG_CPM_ADDR > platform probing is done, all platforms selected must > share the same address. > > +config PPC_EARLY_DEBUG_16550_PHYSADDR > + hex "Early debug Serial 16550 physical address" > + depends on PPC_EARLY_DEBUG_16550 Is there any chance that you could provide a default value here so that 'make olddefconfig' does not end up like it does without having a default value? CONFIG_PPC_EARLY_DEBUG_16550=y # CONFIG_PPC_EARLY_DEBUG_MEMCONS is not set CONFIG_PPC_EARLY_DEBUG_16550_PHYSADDR= CONFIG_PPC_EARLY_DEBUG_16550_STRIDE=1 which then causes a kconfig prompt when starting the build... > + > +config PPC_EARLY_DEBUG_16550_STRIDE > + int "Early debug Serial 16550 stride" > + depends on PPC_EARLY_DEBUG_16550 > + default 1 > + > config FAIL_IOMMU > bool "Fault-injection capability for IOMMU" > depends on FAULT_INJECTION Thanks. -- ~Randy