public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
From: Thomas Chou <thomas@wytron.com.tw>
To: u-boot@lists.denx.de
Subject: [U-Boot] [U-Boot,v3,09/13] ns16550: unify serial_tegra
Date: Fri, 4 Dec 2015 21:59:22 +0800	[thread overview]
Message-ID: <56619C3A.2070005@wytron.com.tw> (raw)
In-Reply-To: <5660C870.9030607@wwwdotorg.org>

Hi Stephen,

On 2015?12?04? 06:55, Stephen Warren wrote:
> 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
>

But all serial drivers should be converted to driver model by the end of 
Jan, 2016. The DM_SERIAL should be removed then.

As SPL might not use OF_CONTROL. We might need better logic in tegra 
board.c like,
   SPL_BUILD ? SPL_OF_CONTROL : OF_CONTROL


>   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,

Yes, this pre-reloc flag should be added.

>   };
>   #endif /* CONFIG_DM_SERIAL */
>

Best regards,
Thomas

  reply	other threads:[~2015-12-04 13:59 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
2015-12-04 13:59             ` Thomas Chou [this message]
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=56619C3A.2070005@wytron.com.tw \
    --to=thomas@wytron.com.tw \
    --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