MLK-11340-37 usb: chipidea: add query_available_role interface
authorPeter Chen <peter.chen@freescale.com>
Fri, 3 Jan 2014 05:42:56 +0000 (13:42 +0800)
committerNitin Garg <nitin.garg@nxp.com>
Mon, 19 Mar 2018 19:47:01 +0000 (14:47 -0500)
The glue layer may need to know current available role, add
ci_hdrc_query_available_role for that.

Signed-off-by: Peter Chen <peter.chen@freescale.com>
(cherry picked from commit 5c340402131ca6eacaeb122deb1ee59bcea2778c)

drivers/usb/chipidea/core.c
include/linux/usb/chipidea.h

index 701d4f7..2af01ee 100644 (file)
@@ -835,6 +835,33 @@ void ci_hdrc_remove_device(struct platform_device *pdev)
 }
 EXPORT_SYMBOL_GPL(ci_hdrc_remove_device);
 
+/**
+ * ci_hdrc_query_available_role: get runtime available operation mode
+ *
+ * The glue layer can get current operation mode (host/peripheral/otg)
+ * This function should be called after ci core device has created.
+ *
+ * @pdev: the platform device of ci core.
+ *
+ * Return USB_DR_MODE_XXX.
+ */
+enum usb_dr_mode ci_hdrc_query_available_role(struct platform_device *pdev)
+{
+       struct ci_hdrc *ci = platform_get_drvdata(pdev);
+
+       if (!ci)
+               return USB_DR_MODE_UNKNOWN;
+       if (ci->roles[CI_ROLE_HOST] && ci->roles[CI_ROLE_GADGET])
+               return USB_DR_MODE_OTG;
+       else if (ci->roles[CI_ROLE_HOST])
+               return USB_DR_MODE_HOST;
+       else if (ci->roles[CI_ROLE_GADGET])
+               return USB_DR_MODE_PERIPHERAL;
+       else
+               return USB_DR_MODE_UNKNOWN;
+}
+EXPORT_SYMBOL_GPL(ci_hdrc_query_available_role);
+
 static inline void ci_role_destroy(struct ci_hdrc *ci)
 {
        ci_hdrc_gadget_destroy(ci);
index 803b5e6..38f03e7 100644 (file)
@@ -93,4 +93,6 @@ struct platform_device *ci_hdrc_add_device(struct device *dev,
 /* Remove ci hdrc device */
 void ci_hdrc_remove_device(struct platform_device *pdev);
 
+/* Get current available role */
+enum usb_dr_mode ci_hdrc_query_available_role(struct platform_device *pdev);
 #endif