Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp1681518ybv; Fri, 21 Feb 2020 01:35:05 -0800 (PST) X-Google-Smtp-Source: APXvYqxjageG0yM2BC1lszIlpCym9TcCrlhk6Ap42CSzkwBC+we8rSPCXt8nogZEiTQdq/HnJ0Yy X-Received: by 2002:a9d:64d8:: with SMTP id n24mr25607480otl.71.1582277705082; Fri, 21 Feb 2020 01:35:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582277705; cv=none; d=google.com; s=arc-20160816; b=dap+ZSpEqMMe14Jx5eeWRFfQ+BPXiYCG/E6+u0P3t49CqpDrteXShKMcaCCT4z5v5g pOL4f0dN8Q0GYSXlegiACp0AfUS4Ixr3IpEv0Oo/tvW7SOCbVLC3HhfY8DYoNpH/sdyC 5jBeXM1P/HTBsveifcK5K1Cyqar7wJk/AboGnAHtoV46mgbdy8nzRDSSQuPBX7nVhkP/ vO7uovW57+2pl7+kWFCOOQ/orVbiABlOWt7heZen2VcWZp3L6pZpt/aA9U5qyDn9o29v PPq8mnglYf1z54679k8g0EYaCIOwU9+0foIchoSuIcRMHLrwGZw2bGYtDg199MxOwide TtkA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:message-id:references :in-reply-to:subject:cc:to:from:date:content-transfer-encoding :mime-version:dkim-signature; bh=Snop1RpX2rRCwWvJOlE+k0QPMCh/eFbh+WZC0GsS4uA=; b=IkR826hQnn87qjoXUlBlTakP6g9CZZBdzCUBRZlfP3j/+c39K0zT65MS33Cvwt3ewn 4Tr7GbDAsLbEu7vidCqVIXW4w1+HoYEGnEzquLn9uxu2oh0KhTIBUUeGgeLQRcx25v4E cwB2Y9wuIyio2EilXE9Alcaosfnsf6px4r2oIiG5GR7akX9N8zIfXODqD4g1fDq5cB4B GVE4WK6WkWa+Z9m4HDO9ON3xSGO8sWtn0n6taNJIX38154e+IYhYCSmtMtl8SBL9ljC2 EqYi5f3sLPj6eAOeNaV/65q3KGbK2pik9a/0zVDZIRcA9oXuLQLJdqAgMjauywQ82Bq8 JKpg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@walle.cc header.s=mail2016061301 header.b=KmGNlDaQ; 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 l11si1189583otn.189.2020.02.21.01.34.53; Fri, 21 Feb 2020 01:35:05 -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=@walle.cc header.s=mail2016061301 header.b=KmGNlDaQ; 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 S1727525AbgBUJer (ORCPT + 99 others); Fri, 21 Feb 2020 04:34:47 -0500 Received: from ssl.serverraum.org ([176.9.125.105]:44453 "EHLO ssl.serverraum.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726984AbgBUJer (ORCPT ); Fri, 21 Feb 2020 04:34:47 -0500 Received: from ssl.serverraum.org (web.serverraum.org [172.16.0.2]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ssl.serverraum.org (Postfix) with ESMTPSA id C90A023D18; Fri, 21 Feb 2020 10:34:43 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=walle.cc; s=mail2016061301; t=1582277684; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=Snop1RpX2rRCwWvJOlE+k0QPMCh/eFbh+WZC0GsS4uA=; b=KmGNlDaQ0PxdmjCYZnUUKedfMyyTcUd1gXD7yIRoHmxoX8UnGY0zb8lm/piMWP+VR63s+Q xDwYHFxwJHy9ZFrwvVkKljKvR6iTMLBWGm73MzpxQ7dvFMbKyX8tHOeOi7EYExgDLXEGCm m1eae/F2FAQ5vFJE9UpYBMB+T+cGQ+g= MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Fri, 21 Feb 2020 10:34:43 +0100 From: Michael Walle To: Peng Fan , Greg Kroah-Hartman Cc: linux-serial@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Rob Herring , Mark Rutland , Shawn Guo , Leo Li , Jiri Slaby , Yuan Yao , Vabhav Sharma Subject: Re: [PATCH 1/7] Revert "tty: serial: fsl_lpuart: drop EARLYCON_DECLARE" In-Reply-To: References: <20200220174334.23322-1-michael@walle.cc> Message-ID: <51db0e6ba10b4b32dab207e0df8ef0d8@walle.cc> X-Sender: michael@walle.cc User-Agent: Roundcube Webmail/1.3.10 X-Spamd-Bar: + X-Spam-Level: * X-Rspamd-Server: web X-Spam-Status: No, score=1.40 X-Spam-Score: 1.40 X-Rspamd-Queue-Id: C90A023D18 X-Spamd-Result: default: False [1.40 / 15.00]; FROM_HAS_DN(0.00)[]; TO_DN_SOME(0.00)[]; TO_MATCH_ENVRCPT_ALL(0.00)[]; TAGGED_RCPT(0.00)[dt]; MIME_GOOD(-0.10)[text/plain]; DKIM_SIGNED(0.00)[]; RCPT_COUNT_TWELVE(0.00)[13]; NEURAL_HAM(-0.00)[-0.601]; RCVD_COUNT_ZERO(0.00)[0]; FROM_EQ_ENVFROM(0.00)[]; MIME_TRACE(0.00)[0:+]; MID_RHS_MATCH_FROM(0.00)[]; SUSPICIOUS_RECIPS(1.50)[] Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, Am 2020-02-21 02:30, schrieb Peng Fan: >> Subject: [PATCH 1/7] Revert "tty: serial: fsl_lpuart: drop >> EARLYCON_DECLARE" >> >> This reverts commit a659652f6169240a5818cb244b280c5a362ef5a4. >> >> This broke the earlycon on LS1021A processors because the order of the >> earlycon_setup() functions were changed. Before the commit the normal >> lpuart32_early_console_setup() was called. After the commit the >> lpuart32_imx_early_console_setup() is called instead. > > How do you pass earlycon args to kernel? earlycon=lpuart32,mmio32be,0x2950000,115200 please note that there are two possible declarations: (1) an OF/ACPI based earlycon, eg just "earlycon" on the bootargs and (2) an elaborate one where you can give the offset and access method yourself, eg. the one from above. (1) will still work even with the EARLYCON_DECLARE() removed. But (2) will search through all possible OF_DELARE_EARLYCON(lpuart32,..) EARLYCON_DECLARE(lpuart32,..) and doesn't take the compatible into account. So which setup function is actually called depends on (a) the order of the OF_DECLARE_EARLYCON() and EARLYCON_DECLARE() statements and (b) on the compiler (thats just a guess!). For me, the order in which it will actually end up in the __earlycon_table is reversed, eg. the last one is called. So now that you've removed the EARLYCON_DECLARE() the last one is the imx setup function which will add the reg offset and doesn't work on LS1021A. I've proposed a fix of the underlying problem [1]. But that fix also requires the EARLYCON_DECLARE() in this driver. -michael [1] https://lore.kernel.org/linux-serial/20200220174607.24285-1-michael@walle.cc/