Commit 03de9bf6 authored by Sebastian Andrzej Siewior's avatar Sebastian Andrzej Siewior Committed by Felipe Balbi

usb: gadget: push iManufacturer into gadgets

This patch pushes the iManufacturer module argument from composite into
each gadget. Once the user uses the module paramter, the string is
overwritten with the final value.
Acked-by: default avatarMichal Nazarewicz <mina86@mina86.com>
Signed-off-by: default avatarSebastian Andrzej Siewior <bigeasy@linutronix.de>
Signed-off-by: default avatarFelipe Balbi <balbi@ti.com>
parent 1cf0d264
...@@ -32,10 +32,6 @@ ...@@ -32,10 +32,6 @@
* published in the device descriptor, either numbers or strings or both. * published in the device descriptor, either numbers or strings or both.
* String parameters are in UTF-8 (superset of ASCII's 7 bit characters). * String parameters are in UTF-8 (superset of ASCII's 7 bit characters).
*/ */
static char *iManufacturer;
module_param(iManufacturer, charp, S_IRUGO);
MODULE_PARM_DESC(iManufacturer, "USB Manufacturer string");
static char *iProduct; static char *iProduct;
module_param(iProduct, charp, S_IRUGO); module_param(iProduct, charp, S_IRUGO);
MODULE_PARM_DESC(iProduct, "USB Product string"); MODULE_PARM_DESC(iProduct, "USB Product string");
...@@ -916,8 +912,7 @@ static int get_string(struct usb_composite_dev *cdev, ...@@ -916,8 +912,7 @@ static int get_string(struct usb_composite_dev *cdev,
* check if the string has not been overridden. * check if the string has not been overridden.
*/ */
if (cdev->manufacturer_override == id) if (cdev->manufacturer_override == id)
str = iManufacturer ?: composite->iManufacturer ?: str = composite->iManufacturer ?: composite_manufacturer;
composite_manufacturer;
else if (cdev->product_override == id) else if (cdev->product_override == id)
str = iProduct ?: composite->iProduct; str = iProduct ?: composite->iProduct;
else if (cdev->serial_override == id) else if (cdev->serial_override == id)
...@@ -1408,6 +1403,7 @@ static void update_unchanged_dev_desc(struct usb_device_descriptor *new, ...@@ -1408,6 +1403,7 @@ static void update_unchanged_dev_desc(struct usb_device_descriptor *new,
__le16 idProduct; __le16 idProduct;
__le16 bcdDevice; __le16 bcdDevice;
u8 iSerialNumber; u8 iSerialNumber;
u8 iManufacturer;
/* /*
* these variables may have been set in * these variables may have been set in
...@@ -1417,6 +1413,7 @@ static void update_unchanged_dev_desc(struct usb_device_descriptor *new, ...@@ -1417,6 +1413,7 @@ static void update_unchanged_dev_desc(struct usb_device_descriptor *new,
idProduct = new->idProduct; idProduct = new->idProduct;
bcdDevice = new->bcdDevice; bcdDevice = new->bcdDevice;
iSerialNumber = new->iSerialNumber; iSerialNumber = new->iSerialNumber;
iManufacturer = new->iManufacturer;
*new = *old; *new = *old;
if (idVendor) if (idVendor)
...@@ -1427,6 +1424,8 @@ static void update_unchanged_dev_desc(struct usb_device_descriptor *new, ...@@ -1427,6 +1424,8 @@ static void update_unchanged_dev_desc(struct usb_device_descriptor *new,
new->bcdDevice = bcdDevice; new->bcdDevice = bcdDevice;
if (iSerialNumber) if (iSerialNumber)
new->iSerialNumber = iSerialNumber; new->iSerialNumber = iSerialNumber;
if (iManufacturer)
new->iManufacturer = iManufacturer;
} }
static struct usb_composite_driver *to_cdriver(struct usb_gadget_driver *gdrv) static struct usb_composite_driver *to_cdriver(struct usb_gadget_driver *gdrv)
...@@ -1487,9 +1486,8 @@ static int composite_bind(struct usb_gadget *gadget, ...@@ -1487,9 +1486,8 @@ static int composite_bind(struct usb_gadget *gadget,
update_unchanged_dev_desc(&cdev->desc, composite->dev); update_unchanged_dev_desc(&cdev->desc, composite->dev);
/* string overrides */ /* string overrides */
if (iManufacturer || !cdev->desc.iManufacturer) { if (!cdev->desc.iManufacturer) {
if (!iManufacturer && !composite->iManufacturer && if (!composite->iManufacturer)
!*composite_manufacturer)
snprintf(composite_manufacturer, snprintf(composite_manufacturer,
sizeof composite_manufacturer, sizeof composite_manufacturer,
"%s %s with %s", "%s %s with %s",
...@@ -1706,4 +1704,8 @@ void usb_composite_overwrite_options(struct usb_composite_dev *cdev, ...@@ -1706,4 +1704,8 @@ void usb_composite_overwrite_options(struct usb_composite_dev *cdev,
desc->iSerialNumber = dev_str[USB_GADGET_SERIAL_IDX].id; desc->iSerialNumber = dev_str[USB_GADGET_SERIAL_IDX].id;
dev_str[USB_GADGET_SERIAL_IDX].s = covr->serial_number; dev_str[USB_GADGET_SERIAL_IDX].s = covr->serial_number;
} }
if (covr->manufacturer) {
desc->iManufacturer = dev_str[USB_GADGET_MANUFACTURER_IDX].id;
dev_str[USB_GADGET_MANUFACTURER_IDX].s = covr->manufacturer;
}
} }
...@@ -401,6 +401,7 @@ struct usb_composite_overwrite { ...@@ -401,6 +401,7 @@ struct usb_composite_overwrite {
u16 idProduct; u16 idProduct;
u16 bcdDevice; u16 bcdDevice;
char *serial_number; char *serial_number;
char *manufacturer;
}; };
#define USB_GADGET_COMPOSITE_OPTIONS() \ #define USB_GADGET_COMPOSITE_OPTIONS() \
static struct usb_composite_overwrite coverwrite; \ static struct usb_composite_overwrite coverwrite; \
...@@ -416,7 +417,11 @@ struct usb_composite_overwrite { ...@@ -416,7 +417,11 @@ struct usb_composite_overwrite {
\ \
module_param_named(iSerialNumber, coverwrite.serial_number, charp, \ module_param_named(iSerialNumber, coverwrite.serial_number, charp, \
S_IRUGO); \ S_IRUGO); \
MODULE_PARM_DESC(iSerialNumber, "SerialNumber string") MODULE_PARM_DESC(iSerialNumber, "SerialNumber string"); \
\
module_param_named(iManufacturer, coverwrite.manufacturer, charp, \
S_IRUGO); \
MODULE_PARM_DESC(iManufacturer, "USB Manufacturer string")
void usb_composite_overwrite_options(struct usb_composite_dev *cdev, void usb_composite_overwrite_options(struct usb_composite_dev *cdev,
struct usb_composite_overwrite *covr); struct usb_composite_overwrite *covr);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment