usb: mtu3: fix warning of sleep in atomic context in notifier callback
The notifier callbacks of extcon are called in atomic context, but the callbacks will call regulator_enable()/regulator_disable() which may sleep caused by mutex, so use work queue to call the sleep functions. Signed-off-by: Chunfeng Yun <chunfeng.yun@mediatek.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:

zatwierdzone przez
Greg Kroah-Hartman

rodzic
4f9f032c25
commit
681e948524
@@ -196,7 +196,12 @@ struct mtu3_gpd_ring {
|
||||
* @vbus: vbus 5V used by host mode
|
||||
* @edev: external connector used to detect vbus and iddig changes
|
||||
* @vbus_nb: notifier for vbus detection
|
||||
* @vbus_nb: notifier for iddig(idpin) detection
|
||||
* @vbus_work : work of vbus detection notifier, used to avoid sleep in
|
||||
* notifier callback which is atomic context
|
||||
* @vbus_event : event of vbus detecion notifier
|
||||
* @id_nb : notifier for iddig(idpin) detection
|
||||
* @id_work : work of iddig detection notifier
|
||||
* @id_event : event of iddig detecion notifier
|
||||
* @is_u3_drd: whether port0 supports usb3.0 dual-role device or not
|
||||
* @manual_drd_enabled: it's true when supports dual-role device by debugfs
|
||||
* to switch host/device modes depending on user input.
|
||||
@@ -205,7 +210,11 @@ struct otg_switch_mtk {
|
||||
struct regulator *vbus;
|
||||
struct extcon_dev *edev;
|
||||
struct notifier_block vbus_nb;
|
||||
struct work_struct vbus_work;
|
||||
unsigned long vbus_event;
|
||||
struct notifier_block id_nb;
|
||||
struct work_struct id_work;
|
||||
unsigned long id_event;
|
||||
bool is_u3_drd;
|
||||
bool manual_drd_enabled;
|
||||
};
|
||||
|
Reference in New Issue
Block a user