Message ID | 1464768141-25420-10-git-send-email-k.kozlowski@samsung.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Quoting Krzysztof Kozlowski (2016-06-01 01:02:18) > Parse usb-pwrseq property from Device Tree to get the phandle to pwrseq > device. The pwrseq device will be used by USB hub to cycle the power > before activating ports. > > Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com> Drive by review comment. I was hoping this would help me with a problem I'm having where I have a hub (smsc4604) that needs to be taken out of reset before my HSIC controller sends a USB reset to it, but it seems this is more about doing some sort of power on sequence after enumeration? > diff --git a/drivers/usb/core/port.c b/drivers/usb/core/port.c > index 460c855be0d0..89b9bdfc7061 100644 > --- a/drivers/usb/core/port.c > +++ b/drivers/usb/core/port.c > @@ -18,6 +18,8 @@ > > #include <linux/slab.h> > #include <linux/pm_qos.h> > +#include <linux/pwrseq.h> > +#include <linux/usb/of.h> > > #include "hub.h" > > @@ -526,6 +528,14 @@ int usb_hub_create_port_device(struct usb_hub *hub, int port1) > return retval; > } > > + port_dev->dev.of_node = usb_of_get_child_node(hdev->dev.parent->of_node, > + port1); > + port_dev->pwrseq = pwrseq_alloc(&port_dev->dev, "usb-pwrseq"); > + if (IS_ERR(port_dev->pwrseq)) { > + device_unregister(&port_dev->dev); > + return PTR_ERR(port_dev->pwrseq); Are we certain that port_dev hasn't been freed at this point? We just called device_unregister() on it, so it seems safer to save away the return value before calling device_unregister() here. -- To unsubscribe from this list: send the line "unsubscribe linux-mmc" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On 06/01/2016 10:57 AM, Stephen Boyd wrote: > Quoting Krzysztof Kozlowski (2016-06-01 01:02:18) >> Parse usb-pwrseq property from Device Tree to get the phandle to pwrseq >> device. The pwrseq device will be used by USB hub to cycle the power >> before activating ports. >> >> Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com> > > Drive by review comment. > > I was hoping this would help me with a problem I'm having where I have a > hub (smsc4604) that needs to be taken out of reset before my HSIC > controller sends a USB reset to it, but it seems this is more about > doing some sort of power on sequence after enumeration? This example is not finished but from what you wrote, it might suit your needs as well. The power sequence is done before enumeration because without it, the device won't enumerate. The exact power sequence for USB devices has to be still developed. Comments are welcomed. >> diff --git a/drivers/usb/core/port.c b/drivers/usb/core/port.c >> index 460c855be0d0..89b9bdfc7061 100644 >> --- a/drivers/usb/core/port.c >> +++ b/drivers/usb/core/port.c >> @@ -18,6 +18,8 @@ >> >> #include <linux/slab.h> >> #include <linux/pm_qos.h> >> +#include <linux/pwrseq.h> >> +#include <linux/usb/of.h> >> >> #include "hub.h" >> >> @@ -526,6 +528,14 @@ int usb_hub_create_port_device(struct usb_hub *hub, int port1) >> return retval; >> } >> >> + port_dev->dev.of_node = usb_of_get_child_node(hdev->dev.parent->of_node, >> + port1); >> + port_dev->pwrseq = pwrseq_alloc(&port_dev->dev, "usb-pwrseq"); >> + if (IS_ERR(port_dev->pwrseq)) { >> + device_unregister(&port_dev->dev); >> + return PTR_ERR(port_dev->pwrseq); > > Are we certain that port_dev hasn't been freed at this point? We just > called device_unregister() on it, so it seems safer to save away the > return value before calling device_unregister() here. Right, good point. Thanks for feedback. Best regards, Krzysztof -- To unsubscribe from this list: send the line "unsubscribe linux-mmc" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Wed, Jun 01, 2016 at 01:57:23AM -0700, Stephen Boyd wrote: > Quoting Krzysztof Kozlowski (2016-06-01 01:02:18) > > Parse usb-pwrseq property from Device Tree to get the phandle to pwrseq > > device. The pwrseq device will be used by USB hub to cycle the power > > before activating ports. > > > > Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com> > > Drive by review comment. > > I was hoping this would help me with a problem I'm having where I have a > hub (smsc4604) that needs to be taken out of reset before my HSIC > controller sends a USB reset to it, but it seems this is more about > doing some sort of power on sequence after enumeration? > No, you may need to do reset before enumeration, the general purpose of reset is eliminate unstable hardware state, and let the controller find the device. Try to do it at bootloader to see if it works for you.
Quoting Peter Chen (2016-06-01 05:05:20) > On Wed, Jun 01, 2016 at 01:57:23AM -0700, Stephen Boyd wrote: > > Quoting Krzysztof Kozlowski (2016-06-01 01:02:18) > > > Parse usb-pwrseq property from Device Tree to get the phandle to pwrseq > > > device. The pwrseq device will be used by USB hub to cycle the power > > > before activating ports. > > > > > > Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com> > > > > Drive by review comment. > > > > I was hoping this would help me with a problem I'm having where I have a > > hub (smsc4604) that needs to be taken out of reset before my HSIC > > controller sends a USB reset to it, but it seems this is more about > > doing some sort of power on sequence after enumeration? > > > > No, you may need to do reset before enumeration, the general purpose of > reset is eliminate unstable hardware state, and let the controller find > the device. > > Try to do it at bootloader to see if it works for you. > Sorry the bootloader doesn't do this so that doesn't work for me. -- To unsubscribe from this list: send the line "unsubscribe linux-mmc" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Wed, Jun 01, 2016 at 11:16:34AM -0700, Stephen Boyd wrote: > Quoting Peter Chen (2016-06-01 05:05:20) > > On Wed, Jun 01, 2016 at 01:57:23AM -0700, Stephen Boyd wrote: > > > Quoting Krzysztof Kozlowski (2016-06-01 01:02:18) > > > > Parse usb-pwrseq property from Device Tree to get the phandle to pwrseq > > > > device. The pwrseq device will be used by USB hub to cycle the power > > > > before activating ports. > > > > > > > > Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com> > > > > > > Drive by review comment. > > > > > > I was hoping this would help me with a problem I'm having where I have a > > > hub (smsc4604) that needs to be taken out of reset before my HSIC > > > controller sends a USB reset to it, but it seems this is more about > > > doing some sort of power on sequence after enumeration? > > > > > > > No, you may need to do reset before enumeration, the general purpose of > > reset is eliminate unstable hardware state, and let the controller find > > the device. > > > > Try to do it at bootloader to see if it works for you. > > > > Sorry the bootloader doesn't do this so that doesn't work for me. I mean try to see if the HUB can work if you reset it at bootloader. If it works, it means you need to do reset before enumeration, and you don't need to do anything after enumeration.
diff --git a/drivers/usb/core/hub.h b/drivers/usb/core/hub.h index 34c1a7e22aae..68ca89780d26 100644 --- a/drivers/usb/core/hub.h +++ b/drivers/usb/core/hub.h @@ -24,6 +24,8 @@ #include <linux/usb/hcd.h> #include "usb.h" +struct pwrseq; + struct usb_hub { struct device *intfdev; /* the "interface" device */ struct usb_device *hdev; @@ -101,6 +103,7 @@ struct usb_port { struct usb_dev_state *port_owner; struct usb_port *peer; struct dev_pm_qos_request *req; + struct pwrseq *pwrseq; enum usb_port_connect_type connect_type; usb_port_location_t location; struct mutex status_lock; diff --git a/drivers/usb/core/port.c b/drivers/usb/core/port.c index 460c855be0d0..89b9bdfc7061 100644 --- a/drivers/usb/core/port.c +++ b/drivers/usb/core/port.c @@ -18,6 +18,8 @@ #include <linux/slab.h> #include <linux/pm_qos.h> +#include <linux/pwrseq.h> +#include <linux/usb/of.h> #include "hub.h" @@ -526,6 +528,14 @@ int usb_hub_create_port_device(struct usb_hub *hub, int port1) return retval; } + port_dev->dev.of_node = usb_of_get_child_node(hdev->dev.parent->of_node, + port1); + port_dev->pwrseq = pwrseq_alloc(&port_dev->dev, "usb-pwrseq"); + if (IS_ERR(port_dev->pwrseq)) { + device_unregister(&port_dev->dev); + return PTR_ERR(port_dev->pwrseq); + } + find_and_link_peer(hub, port1); /* @@ -567,8 +577,13 @@ void usb_hub_remove_port_device(struct usb_hub *hub, int port1) struct usb_port *port_dev = hub->ports[port1 - 1]; struct usb_port *peer; + pwrseq_power_off(port_dev->pwrseq); + peer = port_dev->peer; if (peer) unlink_peers(port_dev, peer); + + pwrseq_free(port_dev->pwrseq); + port_dev->pwrseq = NULL; device_unregister(&port_dev->dev); }
Parse usb-pwrseq property from Device Tree to get the phandle to pwrseq device. The pwrseq device will be used by USB hub to cycle the power before activating ports. Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com> --- drivers/usb/core/hub.h | 3 +++ drivers/usb/core/port.c | 15 +++++++++++++++ 2 files changed, 18 insertions(+)