Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1767575AbcKQLsB (ORCPT ); Thu, 17 Nov 2016 06:48:01 -0500 Received: from mail-co1nam03on0077.outbound.protection.outlook.com ([104.47.40.77]:1272 "EHLO NAM03-CO1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1754069AbcKQLoQ (ORCPT ); Thu, 17 Nov 2016 06:44:16 -0500 Authentication-Results: spf=none (sender IP is 192.88.168.50) smtp.mailfrom=lvd5587.freescale.com; vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=fail action=none header.from=nxp.com; X-IncomingTopHeaderMarker: OriginalChecksum:;UpperCasedChecksum:;SizeAsReceived:1022;Count:11 From: Sriram Dash To: , CC: , , , , , , Arnd Bergmann , Sriram Dash Subject: [PATCH v5 5/6] usb: dwc3: use bus->sysdev for DMA configuration Date: Thu, 17 Nov 2016 17:13:47 +0530 Message-ID: <1479383028-27701-6-git-send-email-sriram.dash@nxp.com> X-Mailer: git-send-email 1.7.7.4 In-Reply-To: <1479383028-27701-1-git-send-email-sriram.dash@nxp.com> References: <1479383028-27701-1-git-send-email-sriram.dash@nxp.com> X-IncomingHeaderCount: 11 X-EOPAttributedMessage: 0 X-Matching-Connectors: 131238566539346783;(91ab9b29-cfa4-454e-5278-08d120cd25b8);() X-Forefront-Antispam-Report: CIP:192.88.168.50;IPV:NLI;CTRY:US;EFV:NLI;SFV:NSPM;SFS:(10009020)(6009001)(6039001)(7916002)(2980300002)(428002)(336004)(199003)(189002)(305945005)(7846002)(626004)(8666005)(90966002)(356003)(50466002)(68736007)(87936001)(52956003)(960300001)(7416002)(48376002)(5660300001)(8676002)(36756003)(97736004)(4720700003)(46386002)(5003940100001)(106466001)(92566002)(81156014)(81166006)(45336002)(2906002)(4326007)(105586002)(33646002)(76176999)(5001770100001)(42882006)(50986999)(103686003)(42186005)(8936002)(101416001)(86372001)(47776003)(2950100002)(575784001)(6666003)(50226002)(189998001)(7059030);DIR:OUT;SFP:1101;SCL:1;SRVR:CY1PR0301MB0745;H:tx30smr01.am.freescale.net;FPR:;SPF:None;PTR:InfoDomainNonexistent;A:0;MX:1;LANG:en; X-Microsoft-Exchange-Diagnostics: 1;BL2FFO11FD044;1:MaI4o1zw91N0vh+VTnzSsKzUtuPJesIhzYmUWAuKtWxdziW883GXPOag9MAHJw45RCM7WOxdcvyipqIrU5lg0SfGpljsCa3v0FVvm4i8R8KSouJlRh21x7O4kvIYGP+p9M/gBdN5ZUpW0mouuuYRgl5cE6I7+bXLalZrYZroZoyDgAw5IW/rtO6vWzUMi2qRg68eLoMON4oHg0BQAv5rk6TMpxC+CN40yDT3CG3U8lcadoh1V4wdXWnauG/+Txx7n76hK/VcUOcjJRr1raKAb4djAa5hzT79geRBVnLyeVO289OzhFcasKBTMOkXmuLQ4mSTlEv0jF1Itk+lMxJhaY81v5/y7SGQjzCH470gA/bz+pb2vZBtE72+O0qv72BCJT84WFK8yVy/FJv4gjQFnHXgeOIt36X6SnZGX7jW6pAtJPH96NiqukguKD4/cIUVcgH7EGlPx2F/mSUyucru+4SzvDtIEkKsboNaBxAHiDsleylWnhnh1GtdLeBotaST3yZnuaDVfPUepQaaNp6vzH+ysfz28+1JmLDWY42zVBKIIbSNYMb16ZcLS1ohk7dIUB5MEBD6cgJ1ZU096MBQ/JkR6IkcOQg5+rc/PTj3LrNl02zqQO5RYrIQ+Cy+i+B5zbn9ItPHejcOOCdqGm0Kug== MIME-Version: 1.0 Content-Type: text/plain X-Microsoft-Exchange-Diagnostics: 1;CY1PR0301MB0745;2:HTF3Erx9J3LsukkPbMBIV/+0WX/bHCq/yqq8xtAZ36fKjS6R0ZbbdDtnnjhco+v5CN2fTlE8yefIHqlTP3RIxQWrLbeh20YWQUx24K85INCwFOkKuqG6FfKlWO3ItzRIRjoEf/UU1bH/pCMPKPzebllZwm1CJclTLuIuK8bmo3U=;3:jFMTt93qcRtVFyMoOEDRjjJ9m9309xxm82GYsDmTsbVccOmVjvyr2Wmjw7M34j9Kr2PfIX6WJisrtLCua98HgSXGuioRp6tT57ddBDMwcmsTXjkZyKHLOs8MjagHyjxS4vW0jUu0v/VRYT2YZ+LpfnqogyP1morA3hvtYXd/caUf/FZT9rwtCqHJ8sO/Rpmnbhov01zoNxg29YSflv2mjUdMAOBazcW4fWHAgvjc9Qfb1wgp471QY2dE4S2H119ZZe7UpNT0Mwygbbar/HVZhw==;25:4kR0+HSNE1ALKEiHBLTjOFJmobMfpgvNnPAU6A+vw7h9DOd/7INIwpwzvU4ZhOzxLsbGEuU4gbhE8RZDYgrNAM86z/qWDc2Cj5LqX73kAtGCYz4eKdSVekQMZlUAXjsErRbi6hqSZ7V5WhGwORmipSO912y6dGXCmo0WLQOaZkz0luP6s2DMk0sK/Zlx0ENLsytwfhe8FRFGLLBvc+jkqFbxZOOa0nUzsxj7ndsnfgH8vtiHEcVWpxp+h6xn88FW1I5l7FKGclCtNx2KjQ3aMbXbvP+ucJX/e3xgpKtm+Fk6KZ8bUJnK8cjfdKEJG3MAqysgbhNEDH/La8UYgKYFjnctNKBo7DzR+x30tm9Js7AsWmSnc6lpMOb0eeEVGvJu9Noib39ihs4cwraHNFyKvTtwpTmYHDIpqFZ6W65Mr2KgOTXyeuNuuLHJSZJ1VuSpHhBNPwCJxn/NwY22SlG45A== X-MS-Office365-Filtering-Correlation-Id: 85bf1e08-3b8e-4f17-61fe-08d40edf0ddd X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:(22001);SRVR:CY1PR0301MB0745; X-Microsoft-Exchange-Diagnostics: 1;CY1PR0301MB0745;31:meSQmSHgYaPTlNKp9bSPUNcH6g2PbtY/7sjJ+1R5+8eapOA7Kag3hbQ1zJpdV2EUGoPoQysP32IvNZCim3nflubQp092BIdcoC1t8jiazm6Yol63VctIXPmUDaMuNMXoMUZasEF0V0RjgM38LDjgKU2zqLCRl3cvG3DXM9lC8bb0fQSZwSEBgysJUWdkeaG5CkgxHMSx/t0EDZ/4YRz6/Py3D0oR37k6Do89G/FlWSkLR7awLx86Tl4YLfgzzJR0qgBot858ObIVg/E3xjEGjr33NaV8k0Kvd9RWtffUH58=;4:5T7riGhoBpfISUWjDFUz+5aEExV+kMZCvedsCb6v4Swy4nuWqdM4qRlXd1m1zntkpVU25s5aZtEy+N6UcQb5EEZOxwD6AO/qecwlb2d/IJBzsfEelxwm/w+iBFovWA3LmZYb0AM4GXJwai3oepqwa3Uc1AMo2R7Ktf19zvjLAQHAlzVu7I1WGruAXqDJHVdajR9g8wLKjPUTDb7jyqEm22hypXoxBkEL7o4McOhCYUv3cKKMXPqtVIG3cPGLUOP39sfWnTO5GzeYSR+eLbttu5PayO8SR5Tayd0rCXlko4KlcQ17D+ewsQYmX7PIXNA+uWDvKvugVakmvICm0xC6X8BRtFqwK2ZtZSoCsDZNFSwWT5FlB+2Fm9q3hE4p2xYKKuVGz911paTtcqHJ8ynIlf2i//SfZRBOuqr08k4C0micSznBCivtTFOyjwUQklTrXfPSFoOSFtKoQFI++nV5bvFDDtOw2S5ATpr+WPiLXMy63Uwu2hATMZQSjKLKxTXUOdFL0Q/vyLbhln9QINuSOzlogJqCZj+Qr6n/RzSD6FgI5THKdM6rWgrBfSWLhiw4ovb2DPd9tVql3iW1x8ncrQ== X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(185117386973197); X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(6095035)(601004)(2401047)(13024025)(13023025)(13015025)(13017025)(8121501046)(5005006)(13018025)(3002001)(10201501046)(6055026)(6096035);SRVR:CY1PR0301MB0745;BCL:0;PCL:0;RULEID:(400006);SRVR:CY1PR0301MB0745; X-Forefront-PRVS: 01294F875B X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1;CY1PR0301MB0745;23:RxH5KDHLGf36kx/qAcAp/ARp18XfHLTRiMLErYL?= =?us-ascii?Q?McGqJKaeE89/CINluv4h0jEbGX24dupH3ie2nRlmvyqBOHz9/+lz1J+w1m7P?= =?us-ascii?Q?JneXLHq+VRMpbqdBlwvGyVXASKATfQkTMu7pQilF8IwIrvwWZZQH2Eg+Ol5Q?= =?us-ascii?Q?xNwA+UDfp14J+3Tb5Xf1ktqIEypv+Y+d7RJJgTf/nBYu0jfJjsSNoXSdioMN?= =?us-ascii?Q?jJjx4jmZUyvSXUuC+SqgUx8l6WuGj7l+qrUuSMQ4+6cTnIlsxp4ozNdI1TJS?= =?us-ascii?Q?EdbS0ceSbFr0zXiEB87cS9TYWUktQgys6/Nr2kGxX/ZEaxqiI/5lEevLtmTe?= =?us-ascii?Q?v+1iT0R1w1IkVidLP96CmrghLJ4+Lr7lDQUMaKCMTU5A4gNFNYOzpiCe0O4e?= =?us-ascii?Q?b5BWZ1UX0Qeognw6TdM39iN/lBfsbS+VX48Z0k04+QT05UJS6Flc4w7Nfr7U?= =?us-ascii?Q?LKgJ6UBZZupcWe0gQ1UBITDIFPwMJ0JXH/REmPOIM+gwY8hz8IKJChSgUdwU?= =?us-ascii?Q?p2+FKeP4T1HlbTZfo1FiiP2o+x6MW7HiE7bcrGzIAKGmnRKCYXjgAeM5SGfe?= =?us-ascii?Q?3TdZUT22ADQNCIFNUjx8yvzWl1/peB++b7zy0RpBmnDMmjfKCSWqxQb9PZ9M?= =?us-ascii?Q?5ppJQttXHbnbP7nTDZyjzQfE4HlIX1Cr/vNhQiKBYP1CkRGlnM+22+gp5BaT?= =?us-ascii?Q?9sJLshh2JJtp3lEP/4hH96xPxAp9iJ+Exzlzl9UmPlZZ9t2Qr2Rr1IGGVoqh?= =?us-ascii?Q?MjqURC72syiUIPScifKIz9Ffhgqfmc5EaVGrqEraAh3Tsh7U1x77lkLDD7AM?= =?us-ascii?Q?TY5GKAODJhrOo42wFBLkrpTdyZVOI3xhjQqmWJg0QtZ+HjC8ok7LNP2NLGTw?= =?us-ascii?Q?T947zCsrMnFVMzalXUlv9ycuSWwfhC9W3M+uFlaIFmgD9trP8I7E8b60CwgB?= =?us-ascii?Q?kXw/fNgCVfM2j6fWYyqnIluRjTH4hB+uFuohnXLNMWrvFrCRZ09bCah17pGw?= =?us-ascii?Q?XAXiWOx1LFi9Ru67zF1OA2v0y72y3/fkpxKSJdl7JXxSTPfFK8nhD4AQih0y?= =?us-ascii?Q?0ATaz92POwZnGEQjQNXjvJHFNpudmAaVuA+zBxiuCV7QzD8TmGjbTsAdS2Bu?= =?us-ascii?Q?MXeX+xz48o1Nn6vaZK90rb691YxkMi8aJu/6Uo5L5/gp0j+yEIJ5pmp+PwU6?= =?us-ascii?Q?QQX1S5DbO6WuCdHJgcvJ2KolMEARF2EStgi6lWmP5RTyueu6Y6pHfGlqSd+f?= =?us-ascii?Q?A7rOSPdkAORjRsN2QPtM=3D?= X-Microsoft-Exchange-Diagnostics: 1;CY1PR0301MB0745;6:RjotA4Tce4fT0PJo9Rdhhs1dnCNgNfXEGXwy4wm3pb05lDV7teCE+GCA1oaEOOgnUCcinx5djqQAUPaKpNck5sVZGAHhoYe5c5gIwJ7WpIolyihfDWpM37tfhIFh1YcWUxNVq1Zx2F7emQUWFqghFCryHT+stJQHzYpC+dn1xk0Qlv8ZaK7+Aa2aP/Ci30Zcof7cmLI1R0Y2rXHy56lQO3yYHSMBcbS+ltYfjDW/NJlYAurmAdrTFHdrZYJXcSp2z5AbarIjONnNzWCsqm3VQPskuvNrzPOUL4oTndQn1MGktOdGjvF8qk0E9u5+TCFWGG2xGrVXkYCEqPgQfIbX1A==;5:Ei5SD6o3vLgUWryuZvq7oi6qmJCCnf/8gpi/5f7RpxG6PlsppEmNxqKZJlkp7i/wB6h6rK90toD3eRc/75STXNYIuIaL5d1XyiyANBrGbJeoBMRfscsNnlkw6KPfMcEE5Hny+PgMMi+K+BCMYLZ6xV72RUFwAzcfy1Bg7s90ugBvPXCZKORY90xVOfnqX56E;24:XPo+l5owVTwMF0JWyY3CFFXGLNPgazIIbtPCMyOfcs10l9tmjyRI+nbIReivjzvEbBTMKqLAy3ZmaqJrPkl/vBiP64ED37JTSt3gNqRwSss= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1;CY1PR0301MB0745;7:z2h6VRYJ/qF4hyEMEB7hkPwZs/Rkn1pn7k24hjrDAIAzdiQR4o1dpNzb3kOMqHI3oDLsq6itZRY5wAERB7buNLIYTp4hIRliI4LE7n+bDJuc0SHL3B/fai5eXAeyJfO25HAeyXKmNVVPx9DnZT7koyr4lkXP2d4e5P0bQhjlyoxudqlaSZvA8MB+f5OJwQRg2eQESUZ3Q3ALxcUwKfmKjGuU3iapLEHCzPqBU1Y6JQl9Bp30xcjBo7s4jgyOnI7UExzc3j6lszOyk10MomP5UgL0KwotzrPjA3oAo5hDnCHd2DDu7nqhdPuwSXTIqzzfhUkfy3m214WNmFNkIecpS+BLsDG1v4Ot2Gtrwx9EOAU= X-MS-Exchange-CrossTenant-OriginalArrivalTime: 17 Nov 2016 11:44:13.7474 (UTC) X-MS-Exchange-CrossTenant-Id: 5afe0b00-7697-4969-b663-5eab37d5f47e X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=5afe0b00-7697-4969-b663-5eab37d5f47e;Ip=[192.88.168.50];Helo=[tx30smr01.am.freescale.net] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: CY1PR0301MB0745 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 11746 Lines: 358 From: Arnd Bergmann The dma ops for dwc3 devices are not set properly. So, use a physical device sysdev, which will be inherited from parent, to set the hardware / firmware parameters like dma. Signed-off-by: Arnd Bergmann Signed-off-by: Sriram Dash Tested-by: Baolin Wang --- Changes in v5: - rebase to usb testing/next Changes in v4: - removed the ifdefs for pci - made the sysdev as a device property - phy create lookup take up the correct device. Changes in v3: - No update Changes in v2: - integrate dwc3 driver changes together drivers/usb/dwc3/core.c | 27 ++++++++++++++------------- drivers/usb/dwc3/core.h | 3 +++ drivers/usb/dwc3/dwc3-pci.c | 10 ++++++++++ drivers/usb/dwc3/ep0.c | 8 ++++---- drivers/usb/dwc3/gadget.c | 33 +++++++++++++++++---------------- drivers/usb/dwc3/host.c | 16 ++++++---------- 6 files changed, 54 insertions(+), 43 deletions(-) diff --git a/drivers/usb/dwc3/core.c b/drivers/usb/dwc3/core.c index e951448..e5fbab2 100644 --- a/drivers/usb/dwc3/core.c +++ b/drivers/usb/dwc3/core.c @@ -202,7 +202,7 @@ static void dwc3_frame_length_adjustment(struct dwc3 *dwc) static void dwc3_free_one_event_buffer(struct dwc3 *dwc, struct dwc3_event_buffer *evt) { - dma_free_coherent(dwc->dev, evt->length, evt->buf, evt->dma); + dma_free_coherent(dwc->sysdev, evt->length, evt->buf, evt->dma); } /** @@ -228,7 +228,7 @@ static struct dwc3_event_buffer *dwc3_alloc_one_event_buffer(struct dwc3 *dwc, if (!evt->cache) return ERR_PTR(-ENOMEM); - evt->buf = dma_alloc_coherent(dwc->dev, length, + evt->buf = dma_alloc_coherent(dwc->sysdev, length, &evt->dma, GFP_KERNEL); if (!evt->buf) return ERR_PTR(-ENOMEM); @@ -341,11 +341,11 @@ static int dwc3_setup_scratch_buffers(struct dwc3 *dwc) if (!WARN_ON(dwc->scratchbuf)) return 0; - scratch_addr = dma_map_single(dwc->dev, dwc->scratchbuf, + scratch_addr = dma_map_single(dwc->sysdev, dwc->scratchbuf, dwc->nr_scratch * DWC3_SCRATCHBUF_SIZE, DMA_BIDIRECTIONAL); - if (dma_mapping_error(dwc->dev, scratch_addr)) { - dev_err(dwc->dev, "failed to map scratch buffer\n"); + if (dma_mapping_error(dwc->sysdev, scratch_addr)) { + dev_err(dwc->sysdev, "failed to map scratch buffer\n"); ret = -EFAULT; goto err0; } @@ -369,7 +369,7 @@ static int dwc3_setup_scratch_buffers(struct dwc3 *dwc) return 0; err1: - dma_unmap_single(dwc->dev, dwc->scratch_addr, dwc->nr_scratch * + dma_unmap_single(dwc->sysdev, dwc->scratch_addr, dwc->nr_scratch * DWC3_SCRATCHBUF_SIZE, DMA_BIDIRECTIONAL); err0: @@ -388,7 +388,7 @@ static void dwc3_free_scratch_buffers(struct dwc3 *dwc) if (!WARN_ON(dwc->scratchbuf)) return; - dma_unmap_single(dwc->dev, dwc->scratch_addr, dwc->nr_scratch * + dma_unmap_single(dwc->sysdev, dwc->scratch_addr, dwc->nr_scratch * DWC3_SCRATCHBUF_SIZE, DMA_BIDIRECTIONAL); kfree(dwc->scratchbuf); } @@ -927,6 +927,13 @@ static void dwc3_get_properties(struct dwc3 *dwc) dwc->dr_mode = usb_get_dr_mode(dev); dwc->hsphy_mode = of_usb_get_phy_mode(dev->of_node); + dwc->sysdev_is_parent = device_property_read_bool(dev, + "linux,sysdev_is_parent"); + if (dwc->sysdev_is_parent) + dwc->sysdev = dwc->dev->parent; + else + dwc->sysdev = dwc->dev; + dwc->has_lpm_erratum = device_property_read_bool(dev, "snps,has-lpm-erratum"); device_property_read_u8(dev, "snps,lpm-nyet-threshold", @@ -1097,12 +1104,6 @@ static int dwc3_probe(struct platform_device *pdev) spin_lock_init(&dwc->lock); - if (!dev->dma_mask) { - dev->dma_mask = dev->parent->dma_mask; - dev->dma_parms = dev->parent->dma_parms; - dma_set_coherent_mask(dev, dev->parent->coherent_dma_mask); - } - pm_runtime_set_active(dev); pm_runtime_use_autosuspend(dev); pm_runtime_set_autosuspend_delay(dev, DWC3_DEFAULT_AUTOSUSPEND_DELAY); diff --git a/drivers/usb/dwc3/core.h b/drivers/usb/dwc3/core.h index ef81fa5..de5a857 100644 --- a/drivers/usb/dwc3/core.h +++ b/drivers/usb/dwc3/core.h @@ -819,6 +819,7 @@ struct dwc3_scratchpad_array { * @ep0_bounced: true when we used bounce buffer * @ep0_expect_in: true when we expect a DATA IN transfer * @has_hibernation: true when dwc3 was configured with Hibernation + * @sysdev_is_parent: true when dwc3 device has a parent driver * @has_lpm_erratum: true when core was configured with LPM Erratum. Note that * there's now way for software to detect this in runtime. * @is_utmi_l1_suspend: the core asserts output signal @@ -875,6 +876,7 @@ struct dwc3 { spinlock_t lock; struct device *dev; + struct device *sysdev; struct platform_device *xhci; struct resource xhci_resources[DWC3_XHCI_RESOURCES_NUM]; @@ -976,6 +978,7 @@ struct dwc3 { unsigned ep0_bounced:1; unsigned ep0_expect_in:1; unsigned has_hibernation:1; + unsigned sysdev_is_parent:1; unsigned has_lpm_erratum:1; unsigned is_utmi_l1_suspend:1; unsigned is_fpga:1; diff --git a/drivers/usb/dwc3/dwc3-pci.c b/drivers/usb/dwc3/dwc3-pci.c index 2b0e34d..2b73339 100644 --- a/drivers/usb/dwc3/dwc3-pci.c +++ b/drivers/usb/dwc3/dwc3-pci.c @@ -73,6 +73,16 @@ static int dwc3_pci_quirks(struct dwc3_pci *dwc) { struct platform_device *dwc3 = dwc->dwc3; struct pci_dev *pdev = dwc->pci; + int ret; + + struct property_entry sysdev_property[] = { + PROPERTY_ENTRY_BOOL("linux,sysdev_is_parent"), + { }, + }; + + ret = platform_device_add_properties(dwc3, sysdev_property); + if (ret) + return ret; if (pdev->vendor == PCI_VENDOR_ID_AMD && pdev->device == PCI_DEVICE_ID_AMD_NL_USB) { diff --git a/drivers/usb/dwc3/ep0.c b/drivers/usb/dwc3/ep0.c index 2b22ea7..2d7fb2d 100644 --- a/drivers/usb/dwc3/ep0.c +++ b/drivers/usb/dwc3/ep0.c @@ -1000,8 +1000,8 @@ static void __dwc3_ep0_do_control_data(struct dwc3 *dwc, u32 transfer_size = 0; u32 maxpacket; - ret = usb_gadget_map_request(&dwc->gadget, &req->request, - dep->number); + ret = usb_gadget_map_request_by_dev(dwc->sysdev, + &req->request, dep->number); if (ret) return; @@ -1026,8 +1026,8 @@ static void __dwc3_ep0_do_control_data(struct dwc3 *dwc, dwc->ep0_bounce_addr, transfer_size, DWC3_TRBCTL_CONTROL_DATA, false); } else { - ret = usb_gadget_map_request(&dwc->gadget, &req->request, - dep->number); + ret = usb_gadget_map_request_by_dev(dwc->sysdev, + &req->request, dep->number); if (ret) return; diff --git a/drivers/usb/dwc3/gadget.c b/drivers/usb/dwc3/gadget.c index e2416de..6785595 100644 --- a/drivers/usb/dwc3/gadget.c +++ b/drivers/usb/dwc3/gadget.c @@ -183,8 +183,8 @@ void dwc3_gadget_giveback(struct dwc3_ep *dep, struct dwc3_request *req, if (dwc->ep0_bounced && dep->number == 0) dwc->ep0_bounced = false; else - usb_gadget_unmap_request(&dwc->gadget, &req->request, - req->direction); + usb_gadget_unmap_request_by_dev(dwc->sysdev, + &req->request, req->direction); trace_dwc3_gadget_giveback(req); @@ -399,7 +399,7 @@ static int dwc3_alloc_trb_pool(struct dwc3_ep *dep) if (dep->trb_pool) return 0; - dep->trb_pool = dma_alloc_coherent(dwc->dev, + dep->trb_pool = dma_alloc_coherent(dwc->sysdev, sizeof(struct dwc3_trb) * DWC3_TRB_NUM, &dep->trb_pool_dma, GFP_KERNEL); if (!dep->trb_pool) { @@ -415,7 +415,7 @@ static void dwc3_free_trb_pool(struct dwc3_ep *dep) { struct dwc3 *dwc = dep->dwc; - dma_free_coherent(dwc->dev, sizeof(struct dwc3_trb) * DWC3_TRB_NUM, + dma_free_coherent(dwc->sysdev, sizeof(struct dwc3_trb) * DWC3_TRB_NUM, dep->trb_pool, dep->trb_pool_dma); dep->trb_pool = NULL; @@ -1171,8 +1171,8 @@ static int __dwc3_gadget_ep_queue(struct dwc3_ep *dep, struct dwc3_request *req) trace_dwc3_ep_queue(req); - ret = usb_gadget_map_request(&dwc->gadget, &req->request, - dep->direction); + ret = usb_gadget_map_request_by_dev(dwc->sysdev, &req->request, + dep->direction); if (ret) return ret; @@ -2977,7 +2977,7 @@ int dwc3_gadget_init(struct dwc3 *dwc) dwc->irq_gadget = irq; - dwc->ctrl_req = dma_alloc_coherent(dwc->dev, sizeof(*dwc->ctrl_req), + dwc->ctrl_req = dma_alloc_coherent(dwc->sysdev, sizeof(*dwc->ctrl_req), &dwc->ctrl_req_addr, GFP_KERNEL); if (!dwc->ctrl_req) { dev_err(dwc->dev, "failed to allocate ctrl request\n"); @@ -2985,8 +2985,9 @@ int dwc3_gadget_init(struct dwc3 *dwc) goto err0; } - dwc->ep0_trb = dma_alloc_coherent(dwc->dev, sizeof(*dwc->ep0_trb) * 2, - &dwc->ep0_trb_addr, GFP_KERNEL); + dwc->ep0_trb = dma_alloc_coherent(dwc->sysdev, + sizeof(*dwc->ep0_trb) * 2, + &dwc->ep0_trb_addr, GFP_KERNEL); if (!dwc->ep0_trb) { dev_err(dwc->dev, "failed to allocate ep0 trb\n"); ret = -ENOMEM; @@ -2999,7 +3000,7 @@ int dwc3_gadget_init(struct dwc3 *dwc) goto err2; } - dwc->ep0_bounce = dma_alloc_coherent(dwc->dev, + dwc->ep0_bounce = dma_alloc_coherent(dwc->sysdev, DWC3_EP0_BOUNCE_SIZE, &dwc->ep0_bounce_addr, GFP_KERNEL); if (!dwc->ep0_bounce) { @@ -3072,18 +3073,18 @@ int dwc3_gadget_init(struct dwc3 *dwc) err4: dwc3_gadget_free_endpoints(dwc); - dma_free_coherent(dwc->dev, DWC3_EP0_BOUNCE_SIZE, + dma_free_coherent(dwc->sysdev, DWC3_EP0_BOUNCE_SIZE, dwc->ep0_bounce, dwc->ep0_bounce_addr); err3: kfree(dwc->setup_buf); err2: - dma_free_coherent(dwc->dev, sizeof(*dwc->ep0_trb) * 2, + dma_free_coherent(dwc->sysdev, sizeof(*dwc->ep0_trb) * 2, dwc->ep0_trb, dwc->ep0_trb_addr); err1: - dma_free_coherent(dwc->dev, sizeof(*dwc->ctrl_req), + dma_free_coherent(dwc->sysdev, sizeof(*dwc->ctrl_req), dwc->ctrl_req, dwc->ctrl_req_addr); err0: @@ -3098,16 +3099,16 @@ void dwc3_gadget_exit(struct dwc3 *dwc) dwc3_gadget_free_endpoints(dwc); - dma_free_coherent(dwc->dev, DWC3_EP0_BOUNCE_SIZE, + dma_free_coherent(dwc->sysdev, DWC3_EP0_BOUNCE_SIZE, dwc->ep0_bounce, dwc->ep0_bounce_addr); kfree(dwc->setup_buf); kfree(dwc->zlp_buf); - dma_free_coherent(dwc->dev, sizeof(*dwc->ep0_trb) * 2, + dma_free_coherent(dwc->sysdev, sizeof(*dwc->ep0_trb) * 2, dwc->ep0_trb, dwc->ep0_trb_addr); - dma_free_coherent(dwc->dev, sizeof(*dwc->ctrl_req), + dma_free_coherent(dwc->sysdev, sizeof(*dwc->ctrl_req), dwc->ctrl_req, dwc->ctrl_req_addr); } diff --git a/drivers/usb/dwc3/host.c b/drivers/usb/dwc3/host.c index 8c2679e..487f0ff 100644 --- a/drivers/usb/dwc3/host.c +++ b/drivers/usb/dwc3/host.c @@ -84,11 +84,7 @@ int dwc3_host_init(struct dwc3 *dwc) return -ENOMEM; } - dma_set_coherent_mask(&xhci->dev, dwc->dev->coherent_dma_mask); - xhci->dev.parent = dwc->dev; - xhci->dev.dma_mask = dwc->dev->dma_mask; - xhci->dev.dma_parms = dwc->dev->dma_parms; dwc->xhci = xhci; @@ -111,9 +107,9 @@ int dwc3_host_init(struct dwc3 *dwc) } phy_create_lookup(dwc->usb2_generic_phy, "usb2-phy", - dev_name(&xhci->dev)); + dev_name(dwc->dev)); phy_create_lookup(dwc->usb3_generic_phy, "usb3-phy", - dev_name(&xhci->dev)); + dev_name(dwc->dev)); ret = platform_device_add(xhci); if (ret) { @@ -124,9 +120,9 @@ int dwc3_host_init(struct dwc3 *dwc) return 0; err2: phy_remove_lookup(dwc->usb2_generic_phy, "usb2-phy", - dev_name(&xhci->dev)); + dev_name(dwc->dev)); phy_remove_lookup(dwc->usb3_generic_phy, "usb3-phy", - dev_name(&xhci->dev)); + dev_name(dwc->dev)); err1: platform_device_put(xhci); return ret; @@ -135,8 +131,8 @@ int dwc3_host_init(struct dwc3 *dwc) void dwc3_host_exit(struct dwc3 *dwc) { phy_remove_lookup(dwc->usb2_generic_phy, "usb2-phy", - dev_name(&dwc->xhci->dev)); + dev_name(dwc->dev)); phy_remove_lookup(dwc->usb3_generic_phy, "usb3-phy", - dev_name(&dwc->xhci->dev)); + dev_name(dwc->dev)); platform_device_unregister(dwc->xhci); } -- 2.1.0