Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754210AbbHMSRP (ORCPT ); Thu, 13 Aug 2015 14:17:15 -0400 Received: from mail-bn1bn0105.outbound.protection.outlook.com ([157.56.110.105]:51721 "EHLO na01-bn1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1753852AbbHMSMB (ORCPT ); Thu, 13 Aug 2015 14:12:01 -0400 Authentication-Results: spf=fail (sender IP is 192.88.168.50) smtp.mailfrom=freescale.com; mgd.freescale.com; dkim=none (message not signed) header.d=none; From: Ramneek Mehresh To: CC: , , , , Ramneek Mehresh , Li Yang Subject: [PATCH 3/8][v3]usb:fsl:otg: Add support to add/remove usb host driver Date: Thu, 13 Aug 2015 23:54:51 +0530 Message-ID: <1439490305-29215-4-git-send-email-ramneek.mehresh@freescale.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1439490305-29215-1-git-send-email-ramneek.mehresh@freescale.com> References: <1439490305-29215-1-git-send-email-ramneek.mehresh@freescale.com> X-EOPAttributedMessage: 0 X-Microsoft-Exchange-Diagnostics: 1;BY2FFO11FD013;1:EFuDICO9vjL3pkQhP3tiPp6LCCQTtebiSfnYfNX+9ixAa/wqsQNdORfEwP2mGDQfbfvr0FzPG+Z+RR1q1KJeNTPeYqeXGBrw+lSo3MKP1KlH+uywT9ve3OMIE7duxu459Kro4IRxRr1y0QDB80Y+sNU/KMroOz+TORmxsV82IYtrQ6yRM8Ik6W26a6hZAfGv6SE/zi+Nje++CDYdumbMbKY62OgvKSQFmIIZgPa5IHFFqY3gGCalrMSb/kYVxxkVG0SaoQF57lxaIutVjdODieXMeqUfwhTh6CgHe+d0z2RDTPHKwr3MHlBntOztIRMUAA/LvqEwCUFr0ROZNz+HeJfzJXSrZVh2BjGfDC0+h13W5uw+Ym/ClurSWXWVG5lDHRxCEPuc1YAnRMJ9FJzveQ== X-Forefront-Antispam-Report: CIP:192.88.168.50;CTRY:US;IPV:NLI;EFV:NLI;SFV:NSPM;SFS:(10019020)(6009001)(2980300002)(3050300001)(339900001)(199003)(189002)(77156002)(19580395003)(19580405001)(46102003)(6806004)(48376002)(85426001)(50986999)(76506005)(86362001)(50466002)(64706001)(76176999)(189998001)(47776003)(4001540100001)(81156007)(87936001)(110136002)(107886002)(5001960100002)(5001830100001)(5001860100001)(5001920100001)(97736004)(92566002)(2950100001)(105606002)(5003940100001)(50226001)(68736005)(33646002)(62966003)(106466001)(104016003)(36756003)(2351001)(229853001)(77096005)(4001430100001);DIR:OUT;SFP:1102;SCL:1;SRVR:CY1PR0301MB1580;H:tx30smr01.am.freescale.net;FPR:;SPF:Fail;PTR:InfoDomainNonexistent;A:1;MX:1;LANG:en; MIME-Version: 1.0 Content-Type: text/plain X-Microsoft-Exchange-Diagnostics: 1;CY1PR0301MB1580;2:4nTPuwsnu/FyPwr/RzhSjk99yqAABjjn9bRLxj5PgpzIOswSJbChJrGf4+TRHG4hvXBzuua0/8sufqKqWoF4IeA8sVAeJOy3V4GzmZiqr3J9nRGnCGnNAxOR+r9cM6gh9wsnP+NaxttCaPhGbpylvkHsFiNwk3esOFamgwYiwSc=;3:rcBhtrmj18ehNYCbVapj5DwTAUt4pL8ql4XqczRsVau1Z1nZJ7S+zYBBjaG8Ns8aYfE8jjSW/k9mjWlD9gQLrhpRQRwEuAoQx9V8jwfpRlCcw0D+lnc0mpgh1rf4xHO8yqMwXAKtsOW8MtwQJmaMG2FryX1N/fULndFrXpqlBj5HLjnlGoHxGspDcu+ZqKAkxN54/m8pW8stSm+Ef+4mP6czTXMRkb2Nv39/EM4ACGA=;25:EylqjIA1kqTkCIT51HIDn65jfaOMBBl4LQp+nu1NQplN/anMA4MAekzbhv8ZYYnvMP/qHKlZNbycbOSGH4qySYeJWN8Z3HJzASAXPWw2Gf+8gzERHXXNPq2HW7FlaHaPW/9vyFCfkzxg22mwJvYNwmHil5DvqEJ+f042JsaVCo0tZYeuCXAQ5lRZX6AIJeNkV6wtflvUdRy5x6k+V036TDWnmmeJELeRXNMynRTz1JdOOQY0/CBurs6GhVZ2rkYQdQ+/Pcm/4CUQk4l8J4tyOQ== X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:CY1PR0301MB1580; X-Microsoft-Exchange-Diagnostics: 1;CY1PR0301MB1580;20:tLOj5qiHpGbJqBBBMiQNQ2K8/2sa7cbkuZMbdsVinmZIRIWHIgan3PNtC/Wm4DGmf5LDx19AsDfnHsT2kTVzOrWM5vCb0zQstLFfAyRatm77EmbqADs7C9RsTEUlxNujOvPGOL19f9EUcz2zNRupQIJjmtkaAXVMak/ApDO4M7caOOVyZxBfIfk100ZGmm2CVr2kPxI8L70scadQcGRu5L034+InNHAvdnGnOx51FDW/oyTZxCM4uGxLM5UXYm5NeKTNFFvDOBxN2b7L9jeK70f0IhIwWfb3HvqUXIn9AeVHVbpAcWgNCTg4O0t8B/G8ITgJ2Raq2n7pExZ2kCAcuEl5YYFkIgTcVoXzVETGudo=;4:WkmfDGALGinQeFYj21DncaRx7FIz1bW613LV3IBkhk7Vc1eM1oiYml/TeJeyJLcK5PE5uMgp86wLi1AexQ98YKr8Vk/+CJN4hcxvyGAaftaZz2iX+BAP4PPYxc6E5mrpOyfVQa1Stq/GOfhlpgvoN0MXu4bCfmM5tRL7KdENgn2yIpKlbzq9Yw33qJ7t/pNVX0EWwgnhPOIFsVwgZEC3EP5QqdVpTqAf7xq1m2rAzI865LNRwNLyNE1S61Rt+53l2SBKX/hkdXKj1HAaC3jxVbDM6yy2f5fNSgg2HVR3Cb4= X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(601004)(5005006)(3002001);SRVR:CY1PR0301MB1580;BCL:0;PCL:0;RULEID:;SRVR:CY1PR0301MB1580; X-Forefront-PRVS: 0667289FF8 X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1;CY1PR0301MB1580;23:ahTul6zwSGp4NYIVHqQ6tYffM61FqWkis/Ferv2?= =?us-ascii?Q?fUIjkFQ4uiiEFUsA/t2tE/FFFHIYnglCCQAOreQTF9vf76a+b9tY1iLhI8Kr?= =?us-ascii?Q?Nj55mUe3mOovW7YdvG0kMw7WZgMIg4hTT+xHMtN0GO/hNz9ZtJEdwmvMGIww?= =?us-ascii?Q?DtLhIB0IV90Gg5o0p++kaQsJR5XVFY0YECMgiJ94uTuKU0rXluMlc5jbwc5q?= =?us-ascii?Q?eC2CNO/glUFuE+6AbKhCDgFwtywx1falXEbmi9lfegRU0wab/vwadQJAYGDq?= =?us-ascii?Q?Nwz5By1wSKYwBQE0wQDUUR5xMTqFNwu+2GlMOBy2z6EOKPKOc1K6syi3qL6B?= =?us-ascii?Q?5F9WLRcrzY9AeSJ3jnkHbte1RNhgYOxvcHUvp3S66Zksi1AINXeQ1EVxFTm5?= =?us-ascii?Q?3XQmjWyVoUtl0SLlC2vGpgp7khhfxahehcl8lmH/T8Dv9Wb/a6e5HhH8pGQj?= =?us-ascii?Q?jWqsQMb7+vqjYLsPhFg3xP/PXXotoZZRhXsbczpftx9HPDVMtB6RGu8rRRn1?= =?us-ascii?Q?bW9RAbOUPe4pjYBTjZXt/xCPX1dYuKQhDb9dcIaCM3nBVvTPPkIZNgQM/FF3?= =?us-ascii?Q?lXrRxe+/fwEdIzkcoBv3Y6Ibtc96z38hufKh+v4+DU49TCV/H4HQOQwclza/?= =?us-ascii?Q?3K2jEaX/mI9YXkiFLdYJaZ4qZfr6g8xGGrmcogUjhxOb4w+lWzZTZ0Utgvz+?= =?us-ascii?Q?WX/ELv7zM4DnwEbOON5ZFXzF+35txuJC/7b6ew4LZ9Hv0HAWikPI7VVDhh0N?= =?us-ascii?Q?aeVjTrG7eP/ZaZQEW3QJlHTkZJjlvxF4a9r3+CrTxrHZiUcnz39aIerCWa3V?= =?us-ascii?Q?ccc8lO/91dnesEqgO527xJMSjoFFt5bqk7u/AJwPiCvmOL0IUVRGAF/FHJm7?= =?us-ascii?Q?XJcEj3CCSL5yKxcvN7ww1v8rh8oS8G1TMl/pbtfecIMSRMRH6kOwGJtvDGb6?= =?us-ascii?Q?xhsi6Q0faJOY5Qeouit8WzNsdzc7Q09yHFeshlXA3XPzHgVZCqkXGzHpBuNW?= =?us-ascii?Q?/FlYdgbpEzgNol4MaAdnohsePbhHJruoZ8IYeLgMSgZ7xH1fFmroim/+MdyC?= =?us-ascii?Q?OY2mfUK89l5oPJnteXDio1E9LOBNvSQaDwl6BDpSXJl19TVhpCA2/lAz98xu?= =?us-ascii?Q?jJKLA7sKnlHhL8s1mjt6zzFGH7hoIRJGkiZGq8Kw40f57eZgus+tI4rIa9S1?= =?us-ascii?Q?zQenBcznuNhk+eLNHFqe7ZI3Lm282cSI8GK6XuOrwJC/DWfffCOsdyoN3HA?= =?us-ascii?Q?=3D=3D?= X-Microsoft-Exchange-Diagnostics: 1;CY1PR0301MB1580;5:PaAne3m2rJcZPkDoKm7vXza+MjdWpSJIa4oIhuhGBfFSeAthCPaq3TvWybNjQPHulqQq4jO5xePaXbe60O0z+VEDia03gdx922RfRIBM4EMIqAoPb+xwhPMH0s4U4vEXSOJLfuwpVi3q9eQl9fozvQ==;24:M5m5UxsvjT/l6eGMuVkudWFPKufX32CAT9G1RHmHrECA5ldiTBQeANq5UA9oGb9Dr9vzDBgy0eu4eXdYIHhZ5jVHdafIscXCPeFCCsX7Gv4=;20:2C0F8V+jFMcfQXRPRn4I+8SeAThGC9DD5Ot0AjSXPw5642aijbj2j+qZkU7vjwjNmCjhDP+n4Xtyd4qvgGHDFg== X-OriginatorOrg: freescale.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 13 Aug 2015 18:11:57.6739 (UTC) X-MS-Exchange-CrossTenant-Id: 710a03f5-10f6-4d38-9ff4-a80b81da590d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=710a03f5-10f6-4d38-9ff4-a80b81da590d;Ip=[192.88.168.50];Helo=[tx30smr01.am.freescale.net] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: CY1PR0301MB1580 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 5507 Lines: 190 Add workqueue to add/remove host driver (outside interrupt context) upon each id change. Signed-off-by: Li Yang Signed-off-by: Ramneek Mehresh --- Changes for v3: - removed CONFIG_FSL_USB2_OTG and CONFIG_FSL_USB2_OTG_MODULE macros - removed call to usb_hcd_resume_root_hub(hcd) from ehci_fsl_drv_resume() drivers/usb/host/ehci-fsl.c | 71 ++++++++++++++++++++++++++++++++------------- drivers/usb/host/ehci-fsl.h | 18 ++++++++++++ 2 files changed, 69 insertions(+), 20 deletions(-) diff --git a/drivers/usb/host/ehci-fsl.c b/drivers/usb/host/ehci-fsl.c index 202dafb..ef04c5a 100644 --- a/drivers/usb/host/ehci-fsl.c +++ b/drivers/usb/host/ehci-fsl.c @@ -44,6 +44,31 @@ static struct hc_driver __read_mostly fsl_ehci_hc_driver; +static struct ehci_fsl *hcd_to_ehci_fsl(struct usb_hcd *hcd) +{ + return (struct ehci_fsl *)hcd_to_ehci(hcd)->priv; +} + +static void do_change_hcd(struct work_struct *work) +{ + struct ehci_fsl *ehci_fsl = container_of(work, struct ehci_fsl, + change_hcd_work); + struct usb_hcd *hcd = ehci_fsl->hcd; + void __iomem *non_ehci = hcd->regs; + int retval; + + if (ehci_fsl->hcd_add && !ehci_fsl->have_hcd) { + writel(USBMODE_CM_HOST, non_ehci + FSL_SOC_USB_USBMODE); + /* host, gadget and otg share same int line */ + retval = usb_add_hcd(hcd, hcd->irq, IRQF_SHARED); + if (retval == 0) + ehci_fsl->have_hcd = 1; + } else if (!ehci_fsl->hcd_add && ehci_fsl->have_hcd) { + usb_remove_hcd(hcd); + ehci_fsl->have_hcd = 0; + } +} + /* configure so an HC device and id are always provided */ /* always called with process context; sleeping is OK */ @@ -147,11 +172,15 @@ static int fsl_ehci_drv_probe(struct platform_device *pdev) goto err2; device_wakeup_enable(hcd->self.controller); -#ifdef CONFIG_USB_OTG if (pdata->operating_mode == FSL_USB2_DR_OTG) { struct ehci_hcd *ehci = hcd_to_ehci(hcd); + struct ehci_fsl *ehci_fsl = hcd_to_ehci_fsl(hcd); + ehci_fsl->hcd = hcd; hcd->usb_phy = usb_get_phy(USB_PHY_TYPE_USB2); + + INIT_WORK(&ehci_fsl->change_hcd_work, do_change_hcd); + dev_dbg(&pdev->dev, "hcd=0x%p ehci=0x%p, phy=0x%p\n", hcd, ehci, hcd->usb_phy); @@ -168,7 +197,7 @@ static int fsl_ehci_drv_probe(struct platform_device *pdev) goto err2; } } -#endif + return retval; err2: @@ -371,15 +400,6 @@ static int ehci_fsl_setup(struct usb_hcd *hcd) return retval; } -struct ehci_fsl { - struct ehci_hcd ehci; - -#ifdef CONFIG_PM - /* Saved USB PHY settings, need to restore after deep sleep. */ - u32 usb_ctrl; -#endif -}; - #ifdef CONFIG_PM #ifdef CONFIG_PPC_MPC512x @@ -527,24 +547,26 @@ static inline int ehci_fsl_mpc512x_drv_resume(struct device *dev) } #endif /* CONFIG_PPC_MPC512x */ -static struct ehci_fsl *hcd_to_ehci_fsl(struct usb_hcd *hcd) -{ - struct ehci_hcd *ehci = hcd_to_ehci(hcd); - - return container_of(ehci, struct ehci_fsl, ehci); -} - static int ehci_fsl_drv_suspend(struct device *dev) { struct usb_hcd *hcd = dev_get_drvdata(dev); - struct ehci_fsl *ehci_fsl = hcd_to_ehci_fsl(hcd); void __iomem *non_ehci = hcd->regs; + struct ehci_fsl *ehci_fsl = hcd_to_ehci_fsl(hcd); + struct usb_bus host = hcd->self; if (of_device_is_compatible(dev->parent->of_node, "fsl,mpc5121-usb2-dr")) { return ehci_fsl_mpc512x_drv_suspend(dev); } + if (host.is_otg) { + /* remove hcd */ + ehci_fsl->hcd_add = 0; + schedule_work(&ehci_fsl->change_hcd_work); + host.is_otg = 0; + return 0; + } + ehci_prepare_ports_for_controller_suspend(hcd_to_ehci(hcd), device_may_wakeup(dev)); if (!fsl_deep_sleep()) @@ -557,15 +579,24 @@ static int ehci_fsl_drv_suspend(struct device *dev) static int ehci_fsl_drv_resume(struct device *dev) { struct usb_hcd *hcd = dev_get_drvdata(dev); - struct ehci_fsl *ehci_fsl = hcd_to_ehci_fsl(hcd); struct ehci_hcd *ehci = hcd_to_ehci(hcd); void __iomem *non_ehci = hcd->regs; + struct ehci_fsl *ehci_fsl = hcd_to_ehci_fsl(hcd); + struct usb_bus host = hcd->self; if (of_device_is_compatible(dev->parent->of_node, "fsl,mpc5121-usb2-dr")) { return ehci_fsl_mpc512x_drv_resume(dev); } + if (host.is_otg) { + /* add hcd */ + ehci_fsl->hcd_add = 1; + schedule_work(&ehci_fsl->change_hcd_work); + host.is_otg = 0; + return 0; + } + ehci_prepare_ports_for_controller_resume(ehci); if (!fsl_deep_sleep()) return 0; diff --git a/drivers/usb/host/ehci-fsl.h b/drivers/usb/host/ehci-fsl.h index 1a8a60a..7c46725 100644 --- a/drivers/usb/host/ehci-fsl.h +++ b/drivers/usb/host/ehci-fsl.h @@ -63,4 +63,22 @@ #define UTMI_PHY_EN (1<<9) #define ULPI_PHY_CLK_SEL (1<<10) #define PHY_CLK_VALID (1<<17) + +struct ehci_fsl { +#ifdef CONFIG_PM + /* Saved USB PHY settings, need to restore after deep sleep. */ + u32 usb_ctrl; +#endif + struct usb_hcd *hcd; + struct work_struct change_hcd_work; + /* + * store current hcd state for otg; + * have_hcd is true when host drv al already part of otg framework, + * otherwise false; + * hcd_add is true when otg framework wants to add host + * drv as part of otg;flase when it wants to remove it + */ + unsigned have_hcd:1; + unsigned hcd_add:1; +}; #endif /* _EHCI_FSL_H */ -- 1.8.3.1 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/