[U-Boot] [PATCH v2 05/13] drivers: usb: common: add support to get maximum speed from dt

Vignesh R vigneshr at ti.com
Wed Jun 14 09:16:25 UTC 2017



On Tuesday 13 June 2017 07:31 PM, Marek Vasut wrote:
> On 06/13/2017 02:10 PM, Vignesh R wrote:
>> From: Mugunthan V N <mugunthanvnm at ti.com>
>>
>> Add support to get maximum speed from dt so that usb drivers
>> makes use of it for DT parsing.
>>
>> Signed-off-by: Mugunthan V N <mugunthanvnm at ti.com>
>> Signed-off-by: Vignesh R <vigneshr at ti.com>
>> Reviewed-by: Simon Glass <sjg at chromium.org>
>> ---
>>  drivers/usb/common/common.c | 29 +++++++++++++++++++++++++++++
>>  include/linux/usb/otg.h     |  9 +++++++++
>>  scripts/Makefile.spl        |  1 +
>>  3 files changed, 39 insertions(+)
>>
>> diff --git a/drivers/usb/common/common.c b/drivers/usb/common/common.c
>> index 35c2dc18d955..c11689dc36fa 100644
>> --- a/drivers/usb/common/common.c
>> +++ b/drivers/usb/common/common.c
>> @@ -10,6 +10,7 @@
>>  #include <common.h>
>>  #include <libfdt.h>
>>  #include <linux/usb/otg.h>
>> +#include <linux/usb/ch9.h>
>>  
>>  DECLARE_GLOBAL_DATA_PTR;
>>  
>> @@ -38,3 +39,31 @@ enum usb_dr_mode usb_get_dr_mode(int node)
>>  
>>  	return USB_DR_MODE_UNKNOWN;
>>  }
>> +
>> +static const char *const speed_names[] = {
>> +	[USB_SPEED_UNKNOWN] = "UNKNOWN",
>> +	[USB_SPEED_LOW] = "low-speed",
>> +	[USB_SPEED_FULL] = "full-speed",
>> +	[USB_SPEED_HIGH] = "high-speed",
>> +	[USB_SPEED_WIRELESS] = "wireless",
>> +	[USB_SPEED_SUPER] = "super-speed",
>> +};
>> +
>> +enum usb_device_speed usb_get_maximum_speed(int node)
>> +{
>> +	const void *fdt = gd->fdt_blob;
>> +	const char *max_speed;
>> +	int i;
>> +
>> +	max_speed = fdt_getprop(fdt, node, "maximum-speed", NULL);
>> +	if (!max_speed) {
>> +		error("usb dr_mode not found\n");
> 
> Really dr_mode ?

Sorry, will fix this.

> 
>> +		return USB_DR_MODE_UNKNOWN;
>> +	}
>> +
>> +	for (i = 0; i < ARRAY_SIZE(speed_names); i++)
>> +		if (!strcmp(max_speed, speed_names[i]))
>> +			return i;
> 
> Shouldn't this somehow take into account the controller capabilities if
> the maximum-speed node is missing ?

Idea was, this is just a helper function and will return
USB_SPEED_UNKNOWN when "maximum-speed" property is missing. The
particular USB controller driver (like dwc3) can take decision of
falling back to default capabilities.
I will leave this as is, but will update patch 6/13 to fall back to
default capability when USB_DR_MODE_UNKNOWN is returned.

> 
>> +	return USB_SPEED_UNKNOWN;
>> +}
>> diff --git a/include/linux/usb/otg.h b/include/linux/usb/otg.h
>> index 8f8ac6aeefe3..b61ef19b22f3 100644
>> --- a/include/linux/usb/otg.h
>> +++ b/include/linux/usb/otg.h
>> @@ -26,4 +26,13 @@ enum usb_dr_mode {
>>   */
>>  enum usb_dr_mode usb_get_dr_mode(int node);
>>  
>> +/**
>> + * usb_get_maximum_speed() - Get maximum speed for given device
>> + * @node: Node offset to the given device
>> + *
>> + * The function gets phy interface string from property 'maximum-speed',
>> + * and returns the correspondig enum usb_device_speed
>> + */
>> +enum usb_device_speed usb_get_maximum_speed(int node);
>> +
>>  #endif /* __LINUX_USB_OTG_H */
>> diff --git a/scripts/Makefile.spl b/scripts/Makefile.spl
>> index ac3c2c7f1342..bffea085b329 100644
>> --- a/scripts/Makefile.spl
>> +++ b/scripts/Makefile.spl
>> @@ -78,6 +78,7 @@ endif
>>  
>>  libs-$(CONFIG_SPL_LIBDISK_SUPPORT) += disk/
>>  libs-y += drivers/
>> +libs-y += drivers/usb/common/
> 
> This looks weird, drivers/ is already included so why this explicit path
> addition ?

Makefile under drivers/ neither includes usb/ directory nor does usb/
directory has a Makefile. Hence, above entry is needed.
I guess, this is how it is for SPL build.

> 
>>  libs-$(CONFIG_SPL_USB_GADGET_SUPPORT) += drivers/usb/dwc3/
>>  libs-y += dts/
>>  libs-y += fs/
>>
> 
> 

-- 
Regards
Vignesh


More information about the U-Boot mailing list