Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754070AbbHMSM2 (ORCPT ); Thu, 13 Aug 2015 14:12:28 -0400 Received: from mail-by2on0118.outbound.protection.outlook.com ([207.46.100.118]:47328 "EHLO na01-by2-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1753990AbbHMSMY (ORCPT ); Thu, 13 Aug 2015 14:12:24 -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][v2]usb:fsl:otg: Add support to add/remove usb host driver Date: Thu, 13 Aug 2015 23:55:00 +0530 Message-ID: <1439490305-29215-13-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;BL2FFO11FD023;1:4CZQ1JOjLfWH0Yde681OFeUwSXyoWMmetNGVHFAibD1X/1ZiISTbdMTV2E0cOXv2a0KO07QYZJHOTRFh1T+A8Cj+dS6aYzYPIkGI4CAEInbY52luwdn1rmKMDzsFOMQrgRmyJ4sCWbWvePnPbknuR1ujPekehAk8waveil3K51yAagV8xOn9pguKGYg805DIIIQB+Cb8FenC6bdfEZQD9uNS6wV9BtaMUv7H/Td6kXZSTzQhk4AaZmDSqP98YOqYhJOvMm9RfpnrbXRyYTrziGYx24gzgQBovOgqhbNVrgPGCES2XEpbGq34bcb6UFuMEm4lGR7KsohCb+TxbgiyX4vMXzBtSYs6ARlrAceDK/fjpU8+wzxqiBUOmUB0yAjWgrbRuwatd/fqGrbIDSI8kA== X-Forefront-Antispam-Report: CIP:192.88.168.50;CTRY:US;IPV:NLI;EFV:NLI;SFV:NSPM;SFS:(10019020)(6009001)(2980300002)(339900001)(3050300001)(189002)(199003)(50226001)(2351001)(50986999)(46102003)(47776003)(76176999)(68736005)(19580395003)(19580405001)(2950100001)(85426001)(6806004)(64706001)(77156002)(87936001)(229853001)(77096005)(62966003)(86362001)(33646002)(104016003)(92566002)(5003940100001)(36756003)(76506005)(97736004)(48376002)(5001920100001)(81156007)(5001960100002)(110136002)(107886002)(189998001)(5001860100001)(5001830100001)(105606002)(106466001)(4001540100001)(50466002)(4001430100001);DIR:OUT;SFP:1102;SCL:1;SRVR:BY2PR0301MB0727;H:tx30smr01.am.freescale.net;FPR:;SPF:Fail;PTR:InfoDomainNonexistent;MX:1;A:1;LANG:en; MIME-Version: 1.0 Content-Type: text/plain X-Microsoft-Exchange-Diagnostics: 1;BY2PR0301MB0727;2:fin3I8pTaJCIFj5z/zXBg5/AlxR6bZ9oSGQD9+M1aVKjGw69BAETn6YcUD6/eCpHFLZZM/DxwplZGYlYYecQtSQ1BKFjj8hRagktyDQYmlxkxinIWAbEaAHXqZXlSdqr7Bx6lbe2IA3GeYHJ1Gy7YnFuDCG/X1rQIOQlFwCtbo0=;3:6GzVRATvDmpFfGfQojpCvdUP+Sv3SRQmyf2VuVXBPoiocHtQNUC1UFdg3BEZBfB5ChfbzvzJh2IiPOShiOImXi1t9VEf3RXHSLX7OEecZ+HHhflvgBHlxUg5thSF+8ZrelMxpKkihIYINZ2+o47pJX/VvMEyEnSZb8vb9kgzio1IWoVAfZg4WYrngJxa4w3nEFYZrcuMUE8rBQGHk1SNLyud+sDkuAYuEICMcFzLoqU=;25:bghUlNZLpGkDFEZMgWThyB7Rgb5PFi8aXYVKsKgwlGK/mnDq9aN9NQJF9PqSNMvWRQY3XzBZT1aDCrghvFtPqLk+cP7qvx/Id6Sp/KQHlLq91g6ETZuViKZ6fYJyVPS6v58ZMvD4JMCirzVBsXGOyWztUKuCwiI600THOJ5SFTQmU5AkNgqhj121CTDLgf3KkawItCW/CAuvrTAPMHyttIwHNjx4mzfeGM2nBHiTPgH7YyWsuBe2YRRNkm6FvbuoaZtlkdW48/JJtmg3br03bA== X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:BY2PR0301MB0727;UriScan:;BCL:0;PCL:0;RULEID:;SRVR:BY2PR0301MB0598; X-Microsoft-Exchange-Diagnostics: 1;BY2PR0301MB0727;20:wg7gzEAvSBTHq9cISG0lDZR07a6+iIrCJtUqFJoDMVqZA6i8uKt/FrlFKwYx9gH6P/uhl8AKACDQ+9LSVvqAzo7Z9mQCV9wojyl9Tp2jpbo/wE2syW/o8Ka+Jo6jq6mN7f/u08WKbPcLRhFRYaK4MksUBElKPczG0SBNFr5o4nYifCjaSFhCLzpXhPHdycmaXvvtNoOdx3JbkBPrkj83eFi6Xg2WMxeJplsT3tpv+5R6Jm3KtWEpIehUDmnH9vOH5E2NzrmOovIFtfpk3p24LVe8g0qunkQ4Hs4VTGRztKIL0c7MYlQgqU96eNzCTWsO3ZqiCDpa/+NAhur8hMvG8o9cpJX+59y/yGkUj2/CIJE=;4:UHF0Skp0pwyXgrReD1ou3ZzMs1FAwphmBPbMBz0PsUYmRWIkgZI70PUrZ+d0JZ0YSrdS4kLS1EDvgQ7V/JHUvOv/qMjZ9p2FQ9qLmRYmUvi/V/qkL4lBHjtNdYM47EM6BO+zhLSLD5KTPuZiyulecf6FT8s9BLOM2EJqtBmHopXBnIiPVgbWp9rPM3+aSgzlfkrx8+fjtDcGRHKxtrkc2QRRt9FTUIgTT4rGcVzdHtikEKPp0bbbUcU6wY6/8rIpRpc2V+9SLNvG3YtzNFKkSVtsBGw9EhDKoMio1kpudZM= 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:BY2PR0301MB0727;BCL:0;PCL:0;RULEID:;SRVR:BY2PR0301MB0727; X-Forefront-PRVS: 0667289FF8 X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1;BY2PR0301MB0727;23:gtP271BllD/wMqtFEer6N92ATqCTbKsYnrlNaoN?= =?us-ascii?Q?JIZehR4jI7EfrTKXpUAolbPJjZpMP0OGeylYx2BCTy0M2uNau5xrcXDqNfGB?= =?us-ascii?Q?B5gW/ewwhO95//ryvbZHuuyQs+wZMunInIT0Tw/v5CeCvm9nJBIw1OTnghKE?= =?us-ascii?Q?zKNX4LrulNWMuSti+O0uj82BlLD5iCDRqrKoD0gDCLqIgVysX37FCjASkrbC?= =?us-ascii?Q?nf/oh7HVRqLp4ryXIRUyWtPw7N+DMq6raql0CMxSmFqRGRYnBAcN4+uWkfG7?= =?us-ascii?Q?VBXc7UQ8xSrbq4Vm0F+lXkCHT7rFOFTGY/gxjjFG9RRlrnpZp7c+z1/QKmES?= =?us-ascii?Q?YAwkiK/FhgtmM0s9HAjBafgsjRir5xL9G7ECVWOq/oyD7BRMTtvJNcpuFWIB?= =?us-ascii?Q?tMBR0EvC0/ioOj8VO4c/GWrH6KYLlNeund6SK9CSnHXbJikJk9t5kQffqW66?= =?us-ascii?Q?wY1I7aSbONZdnyb2aRlHQH7lbVZWCIpVPoFuCANQbC9w3NMykBziofqeynGA?= =?us-ascii?Q?WC7s7zfQRzTQAC2klpx0DjfjAQr6MFTpn1NzncEeXjXh8o88cPBI2Vd255bm?= =?us-ascii?Q?LN2hNSaFPmijDWvzA59tEkVQMjhVEs8N6q/p/rOr3m2ctApMtnyJAvTxcebV?= =?us-ascii?Q?qIb0Bu0zAwU1DLRL5dAJpUmliXTvzZlIKs77iFYOoQHDTga9/nAWat3dn/xG?= =?us-ascii?Q?cqJ5dPrSD2J7djHMrSd+LnHmtHXf1jJN94We9zsT+E4fKrPapNqeLx/sP31I?= =?us-ascii?Q?QPMVRG4z1SVvsOGkQ0l6xUcUc7jXXIyhmeiZMfWgfbTh8WNrdGzQeEz/UMbT?= =?us-ascii?Q?9gaLQ7jvbPIyvgH27qGcE7qfz6C791m03QRevrQDgqVC1xlooTszp8Y0SFC1?= =?us-ascii?Q?HDkHUOUKpJCbWGvALidHM3rXoiy3edSG6CLToR3Q5B2TtRUdCyPg127StRmT?= =?us-ascii?Q?wOg0eklQE1Uybm8PSB7BUZds18HTry+DkMEGW0tB9FyddYUGVFPekH4G/gFD?= =?us-ascii?Q?BGll0S+2mEJR4nWaK+6d9O1Uw9as5RegwBUsDhCSIvMIVDbX7Y510SHJM8F3?= =?us-ascii?Q?xuIbLtdgkqdZEHqPhLxHm6ot3pUThL2WbmkFOidwviDadp7s7PiYjT+EF977?= =?us-ascii?Q?P2KXLWrPuSXV2i0apnTWMgwavdf63VfJR1lh7T05lKPoYMR9s7bYnH18DzQD?= =?us-ascii?Q?gsq7rGYPtujkU1Vufk0pC+IJR53Wwag0yQVo7q6uX9cDXLPtCKrEzhrQqoA?= =?us-ascii?Q?=3D=3D?= X-Microsoft-Exchange-Diagnostics: 1;BY2PR0301MB0727;5:9idHwmVk/WIPQG5Hm/h21OMXO3yNxVMKW5n2dYHIA7uvgCjqhcxttluT5Psf0s+CSZdC1Hh8KSR0X7f5o49TrQ6F4mbrcuS42Ch2bTUTo8A2nr1+icJEzz0ezhQ9hCvkaEiu4WPXiHE5AqTKdqJ/hA==;24:79+Cd90p7Ed6MGIo9IrluWbQp7Zh/HMOXvVvJTUvA+wkSJ9SOPek9C9639l5rCXVG+r7v0OvOT/K1xjDwagNbJtqkmsUmXeNYfQtOFCa1zE=;20:QA990Rktk9If0YswPiV+pSQ4kf8AIGV46WaNnLuny3MHuFMSaWHOmIuCQy0f1lteJX5RklcLQAWolgNKQqN1Hw== X-MS-Exchange-CrossTenant-OriginalArrivalTime: 13 Aug 2015 18:12:20.2286 (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: BY2PR0301MB0727 X-Microsoft-Exchange-Diagnostics: 1;BY2PR0301MB0598;2:DeXA9NPUjXj8ZGqO8EdaNaAHed7gGuVCKQTvUjIt6j+QIqzTWgakuQwQWBznzEEOE7SK4JiwHMoHGNdXeN02BH7CacZvos3J20RjesvyNOHrkO2MneiWdAI5FpSQWeOA0cbOr4b6CmvMobqWlbxGAjMpRR0DuReF9k7VlGg0TVk=;3:VvL6FRdGr7eMR6TxxTocktNdhZF3cP7H7cwlQP7N159hdi96mNb4kW55lMgX6LJWcrNTp17CY9Wi08IVjNgHLQ5+WkmwJcvpLIp2Ma1nocsI/ksJH7vK4wcWjQF47lewWxl7FWJ3VgwtFOe1hI2zGEYPUmZBzsAEfALwW+19ZtJ4Gh0FCaQN/KNEAHAqwZv1kTF0F9l8RSj0EUojecmLMdojmcbCVNPvElh/RinX9Gg=;25:jrLTpOfnQppGFriq6qulfGZDTh1uApft5GSAY7tbZ68YYDX7oEv8IZEpBEqoLUwwlBaeW6wfYRO5HQVwWIKC18mnZJ2olQr8aypajaUwjTXwSZzpp9zmjEU9I4kJ7TQNvM99pEikHKzjuykQKBAS8BMxxix/vbhaukSFXmyDIZZ1ZFv3ZMZWz4l2gDQbhD5c0oGWvnm+PL8idItLRi4mlrbwrVIPMd6U1RMf3+mSmuRXAw5rNCqig9pqsFzqdtmhAmp1XPYKyKiaaCgFJjamqg==;23:7UqhFEVkGYVwpB1BLnq3nfn2MrsAE6+IwgAP6lCHwgbuxy5QV/8aSbYnz9w2XTCw8fhrmNmOf/tb2vncx0GpDReWf6hyE7opo6OwEB88yOk6yic77DdoYe9WJVAGfDCXg0+Z6yH3B81+NCF6lXJ69dCZZaZFnDuow6PJgme8DvqfBCfwlLJ4+Y0FyUIiV91toFguhw/4xJH2k7aQzNoZ968bhHdowq80l6kQtH7bK8fhO5XLH4mpjuwFHVyNYqZt X-OriginatorOrg: freescale.com Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 5761 Lines: 191 Add workqueue to add/remove host driver (outside interrupt context) upon each id change. Signed-off-by: Li Yang Signed-off-by: Ramneek Mehresh --- drivers/usb/host/ehci-fsl.c | 83 ++++++++++++++++++++++++++++++++++----------- drivers/usb/host/ehci-fsl.h | 20 +++++++++++ 2 files changed, 84 insertions(+), 19 deletions(-) diff --git a/drivers/usb/host/ehci-fsl.c b/drivers/usb/host/ehci-fsl.c index 5352e74..81e4bf5 100644 --- a/drivers/usb/host/ehci-fsl.c +++ b/drivers/usb/host/ehci-fsl.c @@ -44,6 +44,34 @@ static struct hc_driver __read_mostly fsl_ehci_hc_driver; +#if defined(CONFIG_FSL_USB2_OTG) || defined(CONFIG_FSL_USB2_OTG_MODULE) +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; + } +} +#endif + + /* configure so an HC device and id are always provided */ /* always called with process context; sleeping is OK */ @@ -136,11 +164,16 @@ static int fsl_ehci_drv_probe(struct platform_device *pdev) goto err2; device_wakeup_enable(hcd->self.controller); -#ifdef CONFIG_USB_OTG +#if defined(CONFIG_FSL_USB2_OTG) || defined(CONFIG_FSL_USB2_OTG_MODULE) 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); @@ -354,15 +387,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 @@ -510,24 +534,31 @@ 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; +#if defined(CONFIG_FSL_USB2_OTG) || defined(CONFIG_FSL_USB2_OTG_MODULE) + struct ehci_fsl *ehci_fsl = hcd_to_ehci_fsl(hcd); + struct usb_bus host = hcd->self; +#endif + if (of_device_is_compatible(dev->parent->of_node, "fsl,mpc5121-usb2-dr")) { return ehci_fsl_mpc512x_drv_suspend(dev); } +#if defined(CONFIG_FSL_USB2_OTG) || defined(CONFIG_FSL_USB2_OTG_MODULE) + if (host.is_otg) { + /* remove hcd */ + ehci_fsl->hcd_add = 0; + schedule_work(&ehci_fsl->change_hcd_work); + host.is_otg = 0; + return 0; + } +#endif + ehci_prepare_ports_for_controller_suspend(hcd_to_ehci(hcd), device_may_wakeup(dev)); if (!fsl_deep_sleep()) @@ -540,15 +571,29 @@ 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; +#if defined(CONFIG_FSL_USB2_OTG) || defined(CONFIG_FSL_USB2_OTG_MODULE) + struct ehci_fsl *ehci_fsl = hcd_to_ehci_fsl(hcd); + struct usb_bus host = hcd->self; +#endif if (of_device_is_compatible(dev->parent->of_node, "fsl,mpc5121-usb2-dr")) { return ehci_fsl_mpc512x_drv_resume(dev); } +#if defined(CONFIG_FSL_USB2_OTG) || defined(CONFIG_FSL_USB2_OTG_MODULE) + if (host.is_otg) { + /* add hcd */ + ehci_fsl->hcd_add = 1; + schedule_work(&ehci_fsl->change_hcd_work); + usb_hcd_resume_root_hub(hcd); + host.is_otg = 0; + return 0; + } +#endif + 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 dbd292e..3fd1fd0 100644 --- a/drivers/usb/host/ehci-fsl.h +++ b/drivers/usb/host/ehci-fsl.h @@ -62,4 +62,24 @@ #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; +#if defined(CONFIG_FSL_USB2_OTG) || defined(CONFIG_FSL_USB2_OTG_MODULE) + struct work_struct change_hcd_work; +#endif + /* + * 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/