[U-Boot] [PATCH 04/13] dm: serial: Deal with stdout-path with an alias

Michal Simek monstr at monstr.eu
Mon Aug 31 13:13:14 CEST 2015


On 08/29/2015 05:10 PM, Simon Glass wrote:
> Sometimes stdout-path contains a UART alias along with speed, etc. For
> example:
> 
> 	stdout-path = "serial0:115200n8";
> 
> Add support for decoding this.
> 
> Signed-off-by: Simon Glass <sjg at chromium.org>
> ---
> 
>  drivers/serial/serial-uclass.c | 30 +++++++++++++++++++++++++-----
>  1 file changed, 25 insertions(+), 5 deletions(-)
> 
> diff --git a/drivers/serial/serial-uclass.c b/drivers/serial/serial-uclass.c
> index 55011cc..842f78b 100644
> --- a/drivers/serial/serial-uclass.c
> +++ b/drivers/serial/serial-uclass.c
> @@ -29,14 +29,34 @@ static const unsigned long baudrate_table[] = CONFIG_SYS_BAUDRATE_TABLE;
>  
>  static void serial_find_console_or_panic(void)
>  {
> +	const void *blob = gd->fdt_blob;

This is one change and should be separated from the rest.

>  	struct udevice *dev;
>  	int node;
>  
> -	if (CONFIG_IS_ENABLED(OF_CONTROL) && gd->fdt_blob) {
> +	if (CONFIG_IS_ENABLED(OF_CONTROL) && blob) {
>  		/* Check for a chosen console */
> -		node = fdtdec_get_chosen_node(gd->fdt_blob, "stdout-path");
> +		node = fdtdec_get_chosen_node(blob, "stdout-path");
> +		if (node < 0) {
> +			const char *str, *p, *name;
> +
> +			/*
> +			 * Deal with things like
> +			 *	stdout-path = "serial0:115200n8";
> +			 *
> +			 * We need to look up the alias and then follow it to
> +			 * the correct node.
> +			 */
> +			str = fdtdec_get_chosen_prop(blob, "stdout-path");
> +			if (str) {
> +				p = strchr(str, ':');
> +				name = fdt_get_alias_namelen(blob, str,
> +						p ? p - str : strlen(str));
> +				if (name)
> +					node = fdt_path_offset(blob, name);
> +			}
> +		}

And this is second.

>  		if (node < 0)

You have if (node < 0) above too which looks pretty odd.

> -			node = fdt_path_offset(gd->fdt_blob, "console");
> +			node = fdt_path_offset(blob, "console");
>  		if (!uclass_get_device_by_of_offset(UCLASS_SERIAL, node,
>  						    &dev)) {
>  			gd->cur_serial_dev = dev;
> @@ -48,14 +68,14 @@ static void serial_find_console_or_panic(void)
>  		* bind it anyway.
>  		*/
>  		if (node > 0 &&
> -		    !lists_bind_fdt(gd->dm_root, gd->fdt_blob, node, &dev)) {
> +		    !lists_bind_fdt(gd->dm_root, blob, node, &dev)) {
>  			if (!device_probe(dev)) {
>  				gd->cur_serial_dev = dev;
>  				return;
>  			}
>  		}
>  	}
> -	if (!SPL_BUILD || !CONFIG_IS_ENABLED(OF_CONTROL) || !gd->fdt_blob) {
> +	if (!SPL_BUILD || !CONFIG_IS_ENABLED(OF_CONTROL) || !blob) {
>  		/*
>  		* Try to use CONFIG_CONS_INDEX if available (it is numbered
>  		* from 1!).
> 

Thanks,
Michal

-- 
Michal Simek, Ing. (M.Eng), OpenPGP -> KeyID: FE3D1F91
w: www.monstr.eu p: +42-0-721842854
Maintainer of Linux kernel - Microblaze cpu - http://www.monstr.eu/fdt/
Maintainer of Linux kernel - Xilinx Zynq ARM architecture
Microblaze U-BOOT custodian and responsible for u-boot arm zynq platform


-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 198 bytes
Desc: OpenPGP digital signature
URL: <http://lists.denx.de/pipermail/u-boot/attachments/20150831/c8a1771f/attachment.sig>


More information about the U-Boot mailing list