public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
From: Stephen Warren <swarren@wwwdotorg.org>
To: u-boot@lists.denx.de
Subject: [U-Boot] [U-Boot,v3,09/13] ns16550: unify serial_tegra
Date: Thu, 3 Dec 2015 15:55:44 -0700	[thread overview]
Message-ID: <5660C870.9030607@wwwdotorg.org> (raw)
In-Reply-To: <CAPnjgZ3Feq9t2Ke2VfBwRi_so+9fR0n=bufHBp93OkZ1qhDB=w@mail.gmail.com>

On 12/03/2015 02:43 PM, Simon Glass wrote:
> Hi Stephen,
>
> On 3 December 2015 at 14:33, Stephen Warren <swarren@wwwdotorg.org> wrote:
>> On 11/22/2015 08:53 AM, Tom Rini wrote:
>>>
>>> On Thu, Nov 19, 2015 at 09:48:11PM +0800, Thomas Chou wrote:
>>>
>>>> Unify serial_tegra, and use the generic binding.
>>>>
>>>> Signed-off-by: Thomas Chou <thomas@wytron.com.tw>
>>>> Reviewed-by: Tom Rini <trini@konsulko.com>
>>>> Acked-by: Simon Glass <sjg@chromium.org>
>>>
>>>
>>> Applied to u-boot/master, thanks!
>>
>>
>> FYI, this patch causes at least Jetson TK1 to immediately reset at boot
>> time. I imagine this affects all Tegra boards, at least those that use SPL
>> or those that are ARMv7; my p2371-2180 Jetson TX1 ARMv8 board which doesn't
>> use SPL seems to still work.
>>
>> I guess I'll see if I can pin-point the problem, unless you can spot an
>> obvious typo or something like that.
>>
>> Reported-by: Kevin Hilman <khilman@linaro.org>
>> (Bisected by me)
>
> Unfortunately I didn't test this patch.
>
> Things to check:
> - for SPL, that the platform data is available somewhere
> - clock-frequency and reg-shift are in the device tree

The patch below appears to solve the problem. Any ideas how to fix this 
cleanly? I don't think we want to introduce a CONFIG_SPL_xxx for every 
CONFIG_xxx, yet CONFIG_IS_ENABLED() (e.g. used around 
arch/arm/mach-tegra/board.c's U_BOOT_DEVICE(ns16550_com1) definition) 
seems to require this.

Unfortunately, the patch doesn't revert cleanly, or at least would 
require other more recent patches to be reverted first.

Also, while debugging this I found that U-Boot force-probes any device 
referenced by /chosen/stdout-path even if the DT node is disabled; yet 
more fundamental incorrect DT processing:-( That's why the patch below 
only affects SPL. More fixes to actually enable the serial port in DT 
should be required.

diff --git a/arch/arm/mach-tegra/Kconfig b/arch/arm/mach-tegra/Kconfig
index fbfb204e6ec8..15609e7dc773 100644
--- a/arch/arm/mach-tegra/Kconfig
+++ b/arch/arm/mach-tegra/Kconfig
@@ -1,5 +1,8 @@
  if TEGRA

+config SPL_DM_SERIAL
+	bool "Fix build"
+
  config TEGRA_COMMON
  	bool "Tegra common options"
  	select DM
@@ -12,6 +15,7 @@ config TEGRA_COMMON
  	select DM_SPI
  	select DM_SPI_FLASH
  	select OF_CONTROL
+	select SPL_DM_SERIAL

  config TEGRA_ARMV7_COMMON
  	bool "Tegra 32-bit common options"
diff --git a/drivers/serial/ns16550.c b/drivers/serial/ns16550.c
index 166deabcd436..256c7eafd76e 100644
--- a/drivers/serial/ns16550.c
+++ b/drivers/serial/ns16550.c
@@ -451,5 +451,6 @@ U_BOOT_DRIVER(ns16550_serial) = {
  	.priv_auto_alloc_size = sizeof(struct NS16550),
  	.probe = ns16550_serial_probe,
  	.ops	= &ns16550_serial_ops,
+	.flags	= DM_FLAG_PRE_RELOC,
  };
  #endif /* CONFIG_DM_SERIAL */

  reply	other threads:[~2015-12-03 22:55 UTC|newest]

Thread overview: 112+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-11-16 14:36 [U-Boot] [PATCH 00/12] ns16550: add generic binding to unify the drivers Thomas Chou
2015-11-16 14:36 ` [U-Boot] [PATCH 01/12] debug_uart: restore ns16550 as default Thomas Chou
2015-11-16 18:22   ` Tom Rini
2015-11-18  0:51   ` Bin Meng
2015-11-18  1:53     ` Thomas Chou
2015-11-16 14:36 ` [U-Boot] [PATCH 02/12] arc: add mapping between physical and virtual address Thomas Chou
2015-11-17  0:18   ` Thomas Chou
2015-11-16 14:36 ` [U-Boot] [PATCH 03/12] ns16550: change map_sysmem to map_physmem Thomas Chou
2015-11-16 21:08   ` Simon Glass
2015-11-17  0:12     ` Thomas Chou
2015-11-16 14:36 ` [U-Boot] [PATCH 04/12] ns16550: add generic binding to unify the drivers Thomas Chou
2015-11-16 18:22   ` Tom Rini
2015-11-18  1:03   ` Bin Meng
2015-11-18  1:59     ` Thomas Chou
2015-11-16 14:36 ` [U-Boot] [PATCH 05/12] ns16550: unify serial_x86 Thomas Chou
2015-11-16 18:22   ` Tom Rini
2015-11-18  1:07   ` Bin Meng
2015-11-18  2:02     ` Thomas Chou
2015-11-16 14:36 ` [U-Boot] [PATCH 06/12] ns16550: unify serial_ppc Thomas Chou
2015-11-16 18:22   ` Tom Rini
2015-11-16 14:36 ` [U-Boot] [PATCH 07/12] ns16550: unify serial_rockchip Thomas Chou
2015-11-16 18:22   ` Tom Rini
2015-11-17  0:35   ` Thomas Chou
2015-11-18 14:05     ` Ariel D'Alessandro
2015-11-16 14:36 ` [U-Boot] [PATCH 08/12] ns16550: unify serial_keystone Thomas Chou
2015-11-16 18:22   ` Tom Rini
2015-11-16 14:36 ` [U-Boot] [PATCH 09/12] ns16550: unify serial_dw Thomas Chou
2015-11-16 18:22   ` Tom Rini
2015-11-16 14:36 ` [U-Boot] [PATCH 10/12] ns16550: unify serial_tegra Thomas Chou
2015-11-16 18:22   ` Tom Rini
2015-11-16 14:36 ` [U-Boot] [PATCH 11/12] ns16550: unify serial_omap Thomas Chou
2015-11-16 18:23   ` Tom Rini
2015-11-16 14:36 ` [U-Boot] [PATCH 12/12] nios2: 10m50: change to ns16550 uart Thomas Chou
2015-11-18 13:44 ` [U-Boot] [PATCH v2 00/13] ns16550: add generic binding to unify the drivers Thomas Chou
2015-11-18 13:44   ` [U-Boot] [PATCH v2 01/13] debug_uart: restore ns16550 as default Thomas Chou
2015-11-18 13:51     ` Bin Meng
2015-11-19  6:38     ` Heiko Schocher
2015-11-18 13:44   ` [U-Boot] [PATCH v2 02/13] ns16550: change map_sysmem to map_physmem Thomas Chou
2015-11-18 13:44   ` [U-Boot] [PATCH v2 03/13] ns16550: add generic binding to unify the drivers Thomas Chou
2015-11-18 13:55     ` Bin Meng
2015-11-19  6:39     ` Heiko Schocher
2015-11-18 13:44   ` [U-Boot] [PATCH v2 04/13] ns16550: unify serial_x86 Thomas Chou
2015-11-18 13:56     ` Bin Meng
2015-11-18 13:44   ` [U-Boot] [PATCH v2 05/13] ns16550: unify serial_ppc Thomas Chou
2015-11-18 13:44   ` [U-Boot] [PATCH v2 06/13] ns16550: unify serial_rockchip Thomas Chou
2015-11-18 13:44   ` [U-Boot] [PATCH v2 07/13] ns16550: unify serial_keystone Thomas Chou
2015-11-18 13:44   ` [U-Boot] [PATCH v2 08/13] ns16550: unify serial_dw Thomas Chou
2015-11-18 13:44   ` [U-Boot] [PATCH v2 09/13] ns16550: unify serial_tegra Thomas Chou
2015-11-18 13:44   ` [U-Boot] [PATCH v2 10/13] ns16550: unify serial_omap Thomas Chou
2015-11-18 13:44   ` [U-Boot] [PATCH v2 11/13] ns16550: zap CONFIG_NS16550_SERIAL Thomas Chou
2015-11-18 14:09     ` Bin Meng
2015-11-18 14:36       ` Thomas Chou
2015-11-19  7:17         ` Bin Meng
2015-11-18 13:44   ` [U-Boot] [PATCH v2 12/13] ns16550: move CONFIG_SYS_NS16550 to Kconfig Thomas Chou
2015-11-18 13:44   ` [U-Boot] [PATCH v2 13/13] nios2: 10m50: change to ns16550 uart Thomas Chou
2015-11-19 13:48 ` [U-Boot] [PATCH v3 00/13] ns16550: add generic binding to unify the drivers Thomas Chou
2015-11-19 13:48   ` [U-Boot] [PATCH v3 01/13] debug_uart: restore ns16550 as default Thomas Chou
2015-11-19 20:05     ` Simon Glass
2015-11-22 15:52     ` [U-Boot] [U-Boot, v3, " Tom Rini
2015-11-19 13:48   ` [U-Boot] [PATCH v3 02/13] ns16550: change map_sysmem to map_physmem Thomas Chou
2015-11-19 20:05     ` Simon Glass
2015-11-22 15:52     ` [U-Boot] [U-Boot, v3, " Tom Rini
2015-11-19 13:48   ` [U-Boot] [PATCH v3 03/13] ns16550: add generic binding to unify the drivers Thomas Chou
2015-11-19 20:34     ` Simon Glass
2015-11-22 15:52     ` [U-Boot] [U-Boot, v3, " Tom Rini
2015-11-19 13:48   ` [U-Boot] [PATCH v3 04/13] ns16550: unify serial_x86 Thomas Chou
2015-11-20 17:18     ` Simon Glass
2015-11-22 15:52     ` [U-Boot] [U-Boot,v3,04/13] " Tom Rini
2015-11-19 13:48   ` [U-Boot] [PATCH v3 05/13] ns16550: unify serial_ppc Thomas Chou
2015-11-20 17:18     ` Simon Glass
2015-11-21  0:19       ` Thomas Chou
2015-11-21  0:27         ` Simon Glass
2015-11-21  2:39           ` Thomas Chou
2015-11-21 15:22             ` Tom Rini
2015-11-21 16:10               ` Simon Glass
2015-11-22  2:50                 ` Tom Rini
2015-11-22 15:52     ` [U-Boot] [U-Boot,v3,05/13] " Tom Rini
2015-11-19 13:48   ` [U-Boot] [PATCH v3 06/13] ns16550: unify serial_rockchip Thomas Chou
2015-11-20 17:18     ` Simon Glass
2015-11-22 15:52     ` [U-Boot] [U-Boot,v3,06/13] " Tom Rini
2015-11-19 13:48   ` [U-Boot] [PATCH v3 07/13] ns16550: unify serial_keystone Thomas Chou
2015-11-20 17:18     ` Simon Glass
2015-11-22 15:52     ` [U-Boot] [U-Boot,v3,07/13] " Tom Rini
2015-11-19 13:48   ` [U-Boot] [PATCH v3 08/13] ns16550: unify serial_dw Thomas Chou
2015-11-20 17:18     ` Simon Glass
2015-11-22 15:53     ` [U-Boot] [U-Boot,v3,08/13] " Tom Rini
2015-11-19 13:48   ` [U-Boot] [PATCH v3 09/13] ns16550: unify serial_tegra Thomas Chou
2015-11-20 17:18     ` Simon Glass
2015-11-22 15:53     ` [U-Boot] [U-Boot,v3,09/13] " Tom Rini
2015-12-03 21:33       ` Stephen Warren
2015-12-03 21:43         ` Simon Glass
2015-12-03 22:55           ` Stephen Warren [this message]
2015-12-04 13:59             ` Thomas Chou
2015-12-04 14:10               ` Yegor Yefremov
2015-12-04 15:09                 ` Tom Rini
2015-12-04 15:52                   ` Simon Glass
2015-11-19 13:48   ` [U-Boot] [PATCH v3 10/13] ns16550: unify serial_omap Thomas Chou
2015-11-20 17:18     ` Simon Glass
2015-11-22 15:53     ` [U-Boot] [U-Boot,v3,10/13] " Tom Rini
2015-11-19 13:48   ` [U-Boot] [PATCH v3 11/13] ns16550: zap CONFIG_NS16550_SERIAL Thomas Chou
2015-11-20 17:18     ` Simon Glass
2015-11-22 15:53     ` [U-Boot] [U-Boot,v3,11/13] " Tom Rini
2015-11-19 13:48   ` [U-Boot] [PATCH v3 12/13] ns16550: move CONFIG_SYS_NS16550 to Kconfig Thomas Chou
2015-11-20 17:18     ` Simon Glass
2015-11-21  0:24       ` Thomas Chou
2015-11-21  0:27         ` Simon Glass
2015-11-21  0:44           ` Thomas Chou
2015-11-21  1:56             ` Tom Rini
2015-11-22 15:53     ` [U-Boot] [U-Boot, v3, " Tom Rini
2015-11-19 13:48   ` [U-Boot] [PATCH v3 13/13] nios2: 10m50: change to ns16550 uart Thomas Chou
2015-11-20 17:18     ` Simon Glass
2015-11-22 15:53     ` [U-Boot] [U-Boot, v3, " Tom Rini

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=5660C870.9030607@wwwdotorg.org \
    --to=swarren@wwwdotorg.org \
    --cc=u-boot@lists.denx.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox