usb: misc: usb3503: Adding device tree entry 'disabled-ports'
This patch is to add a property 'disabled-ports' representing the unused port of USB3503. USB3503 can support up to 3 USB host port and each ports can be controlled to be enabled or disabled. Do not describe this property if all ports must be enabled. You can represent the ports to disable in the device tree. usb3503@08{ ... disabled-ports = <2 3>; ... }; Signed-off-by: Dongjin Kim <tobetter@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
e8e44a4896
commit
e8b58b4913
@@ -186,6 +186,8 @@ static int usb3503_probe(struct i2c_client *i2c, const struct i2c_device_id *id)
|
||||
struct usb3503 *hub;
|
||||
int err = -ENOMEM;
|
||||
u32 mode = USB3503_MODE_UNKNOWN;
|
||||
const u32 *property;
|
||||
int len;
|
||||
|
||||
hub = kzalloc(sizeof(struct usb3503), GFP_KERNEL);
|
||||
if (!hub) {
|
||||
@@ -203,6 +205,18 @@ static int usb3503_probe(struct i2c_client *i2c, const struct i2c_device_id *id)
|
||||
hub->gpio_reset = pdata->gpio_reset;
|
||||
hub->mode = pdata->initial_mode;
|
||||
} else if (np) {
|
||||
hub->port_off_mask = 0;
|
||||
|
||||
property = of_get_property(np, "disabled-ports", &len);
|
||||
if (property && (len / sizeof(u32)) > 0) {
|
||||
int i;
|
||||
for (i = 0; i < len / sizeof(u32); i++) {
|
||||
u32 port = be32_to_cpu(property[i]);
|
||||
if ((1 <= port) && (port <= 3))
|
||||
hub->port_off_mask |= (1 << port);
|
||||
}
|
||||
}
|
||||
|
||||
hub->gpio_intn = of_get_named_gpio(np, "connect-gpios", 0);
|
||||
if (hub->gpio_intn == -EPROBE_DEFER)
|
||||
return -EPROBE_DEFER;
|
||||
|
Reference in New Issue
Block a user