Commit df101c53 authored by Peter Chen's avatar Peter Chen Committed by Greg Kroah-Hartman

usb: chipidea: host: more enhancement when ci->hcd is NULL

Like http://marc.info/?l=linux-usb&m=138200449428874&w=2 said:
two more things are needed to be done:

- If host_start fails, the host_stop should not be called, so we
add check that ci->hcd is not NULL.
- if the host_start fails at the beginning, we need to consider
regulator mismatch issue.
Signed-off-by: default avatarPeter Chen <peter.chen@freescale.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent e55f7cd2
...@@ -103,15 +103,15 @@ static void host_stop(struct ci_hdrc *ci) ...@@ -103,15 +103,15 @@ static void host_stop(struct ci_hdrc *ci)
if (hcd) { if (hcd) {
usb_remove_hcd(hcd); usb_remove_hcd(hcd);
usb_put_hcd(hcd); usb_put_hcd(hcd);
if (ci->platdata->reg_vbus)
regulator_disable(ci->platdata->reg_vbus);
} }
if (ci->platdata->reg_vbus)
regulator_disable(ci->platdata->reg_vbus);
} }
void ci_hdrc_host_destroy(struct ci_hdrc *ci) void ci_hdrc_host_destroy(struct ci_hdrc *ci)
{ {
if (ci->role == CI_ROLE_HOST) if (ci->role == CI_ROLE_HOST && ci->hcd)
host_stop(ci); host_stop(ci);
} }
......
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