[U-Boot] [PATCH v3 05/13] ns16550: unify serial_ppc

Simon Glass sjg at chromium.org
Sat Nov 21 01:27:26 CET 2015


Hi Thomas,

On 20 November 2015 at 17:19, Thomas Chou <thomas at wytron.com.tw> wrote:
>
> Hi Simon,
>
> On 2015年11月21日 01:18, Simon Glass wrote:
>>
>> Hi Thomas,
>>
>> On 19 November 2015 at 06:48, Thomas Chou <thomas at wytron.com.tw> wrote:
>>>
>>> Unify serial_ppc, and use the generic binding.
>>>
>>> Signed-off-by: Thomas Chou <thomas at wytron.com.tw>
>>> Reviewed-by: Tom Rini <trini at konsulko.com>
>>> ---
>>>   arch/powerpc/include/asm/config.h |  4 ++++
>>>   drivers/serial/Kconfig            |  2 +-
>>>   drivers/serial/Makefile           |  1 -
>>>   drivers/serial/serial_ppc.c       | 40 ---------------------------------------
>>>   4 files changed, 5 insertions(+), 42 deletions(-)
>>>   delete mode 100644 drivers/serial/serial_ppc.c
>>>
>>> diff --git a/arch/powerpc/include/asm/config.h b/arch/powerpc/include/asm/config.h
>>> index 65496d0..7391066 100644
>>> --- a/arch/powerpc/include/asm/config.h
>>> +++ b/arch/powerpc/include/asm/config.h
>>> @@ -104,4 +104,8 @@
>>>   /* All PPC boards must swap IDE bytes */
>>>   #define CONFIG_IDE_SWAP_IO
>>>
>>> +#if defined(CONFIG_DM_SERIAL)
>>> +#define CONFIG_SYS_NS16550_CLK         get_serial_clock()
>>> +#endif
>>> +
>
>
> I move the get_serial_clock here.
>
>
>>>   #endif /* _ASM_CONFIG_H_ */
>>> diff --git a/drivers/serial/Kconfig b/drivers/serial/Kconfig
>>> index 93faa4c..b41f508 100644
>>> --- a/drivers/serial/Kconfig
>>> +++ b/drivers/serial/Kconfig
>>> @@ -198,7 +198,7 @@ config ROCKCHIP_SERIAL
>>>   config NS16550_SERIAL
>>>          bool "NS16550 UART or compatible"
>>>          depends on DM_SERIAL
>>> -       default y if X86
>>> +       default y if X86 || PPC
>>>          help
>>>            Support NS16550 UART or compatible with driver model. This can be
>>>            enabled in the device tree with the correct input clock frequency.
>>> diff --git a/drivers/serial/Makefile b/drivers/serial/Makefile
>>> index 9036a8e..9f61113 100644
>>> --- a/drivers/serial/Makefile
>>> +++ b/drivers/serial/Makefile
>>> @@ -8,7 +8,6 @@
>>>   ifdef CONFIG_DM_SERIAL
>>>   obj-y += serial-uclass.o
>>>   obj-$(CONFIG_PL01X_SERIAL) += serial_pl01x.o
>>> -obj-$(CONFIG_PPC) += serial_ppc.o
>>>   else
>>>   obj-y += serial.o
>>>   obj-$(CONFIG_PL010_SERIAL) += serial_pl01x.o
>>> diff --git a/drivers/serial/serial_ppc.c b/drivers/serial/serial_ppc.c
>>> deleted file mode 100644
>>> index 47141c6..0000000
>>> --- a/drivers/serial/serial_ppc.c
>>> +++ /dev/null
>>> @@ -1,40 +0,0 @@
>>> -/*
>>> - * Copyright (c) 2014 Google, Inc
>>> - *
>>> - * SPDX-License-Identifier:    GPL-2.0+
>>> - */
>>> -
>>> -#include <common.h>
>>> -#include <dm.h>
>>> -#include <ns16550.h>
>>> -#include <serial.h>
>>> -
>>> -static const struct udevice_id ppc_serial_ids[] = {
>>> -       { .compatible = "ns16550" },
>>> -       { }
>>> -};
>>> -
>>> -static int ppc_serial_ofdata_to_platdata(struct udevice *dev)
>>> -{
>>> -       struct ns16550_platdata *plat = dev_get_platdata(dev);
>>> -       int ret;
>>> -
>>> -       ret = ns16550_serial_ofdata_to_platdata(dev);
>>> -       if (ret)
>>> -               return ret;
>>> -       plat->clock = get_serial_clock();
>>
>>
>> You are dropping this call. We certainly don't want it for driver
>> model, but I suspect it will break some PPC boards if they don't have
>> the clock-frequency in the device tree. Do they?
>
>
> I moved it to a macro.
> #define CONFIG_SYS_NS16550_CLK         get_serial_clock()

Ah, we shouldn't do that with driver model. This should be in some
sort of clock driver. Perhaps we should leave this serial driver along
for now?

Regards,
Simon


More information about the U-Boot mailing list