diff options
Diffstat (limited to 'drivers/usb/chipidea/core.c')
| -rw-r--r-- | drivers/usb/chipidea/core.c | 15 | 
1 files changed, 12 insertions, 3 deletions
diff --git a/drivers/usb/chipidea/core.c b/drivers/usb/chipidea/core.c index 27c601296130..798cb077867a 100644 --- a/drivers/usb/chipidea/core.c +++ b/drivers/usb/chipidea/core.c @@ -753,7 +753,7 @@ static int ci_get_platdata(struct device *dev,  		return ret;  	} -	if (of_find_property(dev->of_node, "non-zero-ttctrl-ttha", NULL)) +	if (of_property_read_bool(dev->of_node, "non-zero-ttctrl-ttha"))  		platdata->flags |= CI_HDRC_SET_NON_ZERO_TTHA;  	ext_id = ERR_PTR(-ENODEV); @@ -984,9 +984,16 @@ static ssize_t role_store(struct device *dev,  			     strlen(ci->roles[role]->name)))  			break; -	if (role == CI_ROLE_END || role == ci->role) +	if (role == CI_ROLE_END)  		return -EINVAL; +	mutex_lock(&ci->mutex); + +	if (role == ci->role) { +		mutex_unlock(&ci->mutex); +		return n; +	} +  	pm_runtime_get_sync(dev);  	disable_irq(ci->irq);  	ci_role_stop(ci); @@ -995,6 +1002,7 @@ static ssize_t role_store(struct device *dev,  		ci_handle_vbus_change(ci);  	enable_irq(ci->irq);  	pm_runtime_put_sync(dev); +	mutex_unlock(&ci->mutex);  	return (ret == 0) ? n : ret;  } @@ -1030,6 +1038,7 @@ static int ci_hdrc_probe(struct platform_device *pdev)  		return -ENOMEM;  	spin_lock_init(&ci->lock); +	mutex_init(&ci->mutex);  	ci->dev = dev;  	ci->platdata = dev_get_platdata(dev);  	ci->imx28_write_fix = !!(ci->platdata->flags & @@ -1099,7 +1108,7 @@ static int ci_hdrc_probe(struct platform_device *pdev)  	ret = ci_usb_phy_init(ci);  	if (ret) {  		dev_err(dev, "unable to init phy: %d\n", ret); -		return ret; +		goto ulpi_exit;  	}  	ci->hw_bank.phys = res->start;  |