From patchwork Wed Jul 15 22:49:11 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Adrian Alonso X-Patchwork-Id: 496024 Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org Received: from theia.denx.de (theia.denx.de [85.214.87.163]) by ozlabs.org (Postfix) with ESMTP id 78BAE14029D for ; Thu, 16 Jul 2015 10:34:13 +1000 (AEST) Received: from localhost (localhost [127.0.0.1]) by theia.denx.de (Postfix) with ESMTP id 5EDED4B765; Thu, 16 Jul 2015 02:34:04 +0200 (CEST) Received: from theia.denx.de ([127.0.0.1]) by localhost (theia.denx.de [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id ToPlc1Ji6TbO; Thu, 16 Jul 2015 02:34:04 +0200 (CEST) Received: from theia.denx.de (localhost [127.0.0.1]) by theia.denx.de (Postfix) with ESMTP id 4AD0C4B76A; Thu, 16 Jul 2015 02:33:48 +0200 (CEST) Received: from localhost (localhost [127.0.0.1]) by theia.denx.de (Postfix) with ESMTP id EBE7D4B616 for ; Thu, 16 Jul 2015 01:08:14 +0200 (CEST) Received: from theia.denx.de ([127.0.0.1]) by localhost (theia.denx.de [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id iu9OHhQWFg0q for ; Thu, 16 Jul 2015 01:08:14 +0200 (CEST) X-Greylist: delayed 970 seconds by postgrey-1.34 at theia; Thu, 16 Jul 2015 01:08:11 CEST X-policyd-weight: NOT_IN_SBL_XBL_SPAMHAUS=-1.5 NOT_IN_SPAMCOP=-1.5 NOT_IN_BL_NJABL=-1.5 (only DNSBL check requested) Received: from na01-bn1-obe.outbound.protection.outlook.com (mail-bn1bon0148.outbound.protection.outlook.com [157.56.111.148]) by theia.denx.de (Postfix) with ESMTPS id 283FA4B615 for ; Thu, 16 Jul 2015 01:08:11 +0200 (CEST) Received: from BN3PR0301CA0057.namprd03.prod.outlook.com (10.160.152.153) by BY1PR0301MB1223.namprd03.prod.outlook.com (10.161.203.19) with Microsoft SMTP Server (TLS) id 15.1.213.14; Wed, 15 Jul 2015 22:50:29 +0000 Received: from BL2FFO11OLC016.protection.gbl (2a01:111:f400:7c09::108) by BN3PR0301CA0057.outlook.office365.com (2a01:111:e400:401e::25) with Microsoft SMTP Server (TLS) id 15.1.219.17 via Frontend Transport; Wed, 15 Jul 2015 22:50:28 +0000 Authentication-Results: spf=fail (sender IP is 192.88.158.2) smtp.mailfrom=freescale.com; freescale.mail.onmicrosoft.com; dkim=none (message not signed) header.d=none; Received-SPF: Fail (protection.outlook.com: domain of freescale.com does not designate 192.88.158.2 as permitted sender) receiver=protection.outlook.com; client-ip=192.88.158.2; helo=az84smr01.freescale.net; Received: from az84smr01.freescale.net (192.88.158.2) by BL2FFO11OLC016.mail.protection.outlook.com (10.173.160.82) with Microsoft SMTP Server (TLS) id 15.1.213.8 via Frontend Transport; Wed, 15 Jul 2015 22:50:27 +0000 Received: from bluefly.am.freescale.net (bluefly.am.freescale.net [10.81.17.130]) by az84smr01.freescale.net (8.14.3/8.14.0) with ESMTP id t6FMoOQZ030445; Wed, 15 Jul 2015 15:50:25 -0700 From: Adrian Alonso To: , Date: Wed, 15 Jul 2015 17:49:11 -0500 Message-ID: <1437000559-3208-3-git-send-email-aalonso@freescale.com> X-Mailer: git-send-email 2.1.4 In-Reply-To: <1437000559-3208-1-git-send-email-aalonso@freescale.com> References: <1437000559-3208-1-git-send-email-aalonso@freescale.com> X-EOPAttributedMessage: 0 X-Microsoft-Exchange-Diagnostics: 1; BL2FFO11OLC016; 1:LIkX4Bhe3ojLpAX5nf0SPgx4sN675xtbA0USFNpMvNr8UyUNTAUWiPC6mUMlkMwidy7d6p9BSDsXr9CtJOW1Shnnbu+YnXwpaBuh/G6wuR/Ox7IKpg8G16M7d2bTpkafxJ5kqzQ0jzdGGkTmAlMMj47xXX+LueLxYad+40FCTMzXsAMjFLpOp1U/p7e8dVPIH/0BZbFUSiqe+6Q0PO0NFXYsDPCGjY4UiRUasKmef0Bin1RI1E+s0wdvdGZxRHLZkGsyQldG3ICkTd21e6zp9/dtQyhPjXaVr+l/5kuOmmg/IxmFB1N62MpdwHIfYCZuyquegHabaea2yPqxhp2HFgJfvO6HXbGNy8wAQzApxKGvy9Fa7URQiWBeFPxSy3yQNIJlmNwSQVZIQIZeS2+0pyqGgf57Spge6Xu/gF3R5c1XnNTG7LD3Pg2LLeeNdUlY X-Forefront-Antispam-Report: CIP:192.88.158.2; CTRY:US; IPV:NLI; EFV:NLI; SFV:NSPM; SFS:(10019020)(6009001)(2980300002)(339900001)(189002)(199003)(48376002)(107886002)(50986999)(92566002)(5001960100002)(106466001)(77156002)(77096005)(189998001)(50226001)(104016003)(47776003)(5003940100001)(5001770100001)(105606002)(6806004)(2950100001)(229853001)(50466002)(76176999)(62966003)(33646002)(87936001)(86362001)(36756003)(19580395003)(19580405001)(85426001)(46102003)(4001430100001); DIR:OUT; SFP:1102; SCL:1; SRVR:BY1PR0301MB1223; H:az84smr01.freescale.net; FPR:; SPF:Fail; MLV:sfv; MX:1; A:1; LANG:en; MIME-Version: 1.0 X-Microsoft-Exchange-Diagnostics: 1; BY1PR0301MB1223; 2:QTBToVenxZp+nbPgz8SrqkbKOPxgQPnOO2API0SJKll/mOhdry++nQEA6hE14LFS; 3:jxQurGWFf/kU1Y7JkXnooPdwoJF52AwMyftRRuTjg3aC2mgZjIhetGFMQA3CEGStvyMvb0Z4Ihi5datool3+tsrzFemlN4Ki4sPDWuKFBc/sW3ciVzeT3YiJ5l8FrZbar8WYGXOoK8BZRjj/JvfIHg93BHB+yar0EKiGToV6yqTVdS8ZULYDVFhT0pQQD9LxD0T6434xIfoJhLrJLljl2NVYebdggIsOCmMpHcNKM4I=; 25:ACvw6u65H8b2TtdWSIgy2s3Eoy5USozpCquKbnf0zryTQ5jhY7DU7rrdNcBOf90VoitrrbGqFQPGmfyvIjfzaVgOcZignXTS+UxpwZ/qMdBl0GqQI0/7qIaT3FnsyUd9B2YT5C4lp0vXsf730oeN4RxRCgdhBOMXkvuipaxYCcALkal8N1egTno4Ps1BbV9GUEZpIxpGlE0pCF4wztDyIfZoTGd0H3DLFRShCylYrd0yZvomY0ebUWxYF1w2VAri; 20:PBN5iayDXve/TINo1p1G+vIGHyg2/aBRo+4eccOy0NRVnb+xakgUlJZ1gGgNyvVJOfamxjaWRtN0B+khBD7nZtWdj3kLN4puPQbvnBax/trNO0JrkhGQgBtCdzlxxJp+2+xZQEXgPOOgWN6a9DKEnw6KllkXemlH8TYOfFEGDcOmmdwotSuyztMVMFFTRoo0FyljLUQfV2GuDE6kor4qrXz7lU2csbDNdLU5oZHwZd+XYltCrOS2qNXCLA9WFtv05zbT4qIbPdsvfd0L4NM+R7o0qdv3O3bFmhq8+UQU+MtJEA2h1hs47ITJJ1TfPnksRLuWgp2CitlqmKHGXF4XfMlr1XJPUCs5rNNbnYbFn9I= X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:BY1PR0301MB1223; BY1PR0301MB1223: X-MS-Exchange-Organization-RulesExecuted 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:BY1PR0301MB1223; BCL:0; PCL:0; RULEID:; SRVR:BY1PR0301MB1223; X-Microsoft-Exchange-Diagnostics: 1; BY1PR0301MB1223; 4:9LUf+s8fVEjyXp+qrcqBXzKmXOA2EJusKOHnAIBBkqLhaWbNouVZSl77EvMK8Hm8oUiW+r9glLRXaYtTme+SCVGY2gylaYnfRAH6945gazaNOC+KH7HCxusbgxLmaf8gxBeWliTCBWtAFKgZRsAPWeeweuCLzBaZ1QoC6trU7DKd44ku6cQzp6G5HeAsxmFM/hLLsIi48TSfMZvuCcXuWmw/atKyTX1Da3N7Kim8arhXMJhz133bCNrhYeH+3/CPKbwYpe2cmYvFovMj+ZWvQLap3JcbyZh0P9gET83mLRg= X-Forefront-PRVS: 0638FD5066 X-Microsoft-Exchange-Diagnostics: 1; BY1PR0301MB1223; 23:Sn6DNlUG8AmkCabJjm33r+tFndZ1bI2xmIJYEi8hwmC2z4GgDTa0mG0XKzIR/mffcwxWCsMcrpwEmWIowYVveheg7G9zIrdpA2NyQQPWiF6y2npbs+Lanq316qV0vJfTFljzsNGWNXy+EB8KPnUOaOJu/d5WKbtKflBZO/PD8fWzrdKKny6jiujrEJlu+V8SIj7DbUWK4HYY2BMpTWxepVVkw0ghMjgwz46+fGR1Fnri/Ygx89gX+i9KjgHnMWSB0bFNF2ne7xKPop7TiFBT0XoT+//vHgeSY1k8vyOzc55CI3dGlrRZ7DfQwxi9aAST6uxS/YiyW6O7WZy662Ys8RhqqjaCuhWteSvd9sKG8LJEPNhcOpioges03jqZcc6Co+68SbLPDcRJyuxnVIOVw5e04YUametlOuqbe7kvAMzj2y6dePWA2vjjJDmc9inHDTcmR1J1ONPW0uTcmeCsywORLO7HCPQJWzSUbtIWJaOCMIq+YJKatMiofV/NYUbyXdJ6HcZ0gfd+sc8I4LVc64Bd/dkSZRi5TjRjQsTgBaQsIaxiy0UtOD71l0UJ6SvzxnnCraS0i4uC86sEpNkE3hbZ/rxDvWpYVcNNq2r7Ivn5SkZK3HXExdIVCEwIYF1leG1IIQ/tDK8DYG1NL6EGRErMzcfXQmGfAAQRC2cFIHWGJdEg5/DFwLfXEh++P+1lmRDNK1gf1NPxTFNO2BAGD//zEhz+xoXzeHeRMlMFaif1ohc/JSseUbRXEXjn2hwguBUUcoXxaS372pdbfWMQypdDqJ/4UvWc+lxX7NwkCW5M4E6HXR8103Z166HB1U1hOdiMhhvVB3OdwwHvuULvkiOO0umfznFYZ656/KdjRxeXAr2kEU57UeZ9vBm4shygwJZL2vWNV6BGjvTQW2TtOptLkT3rgKnCnK0d+7QrZZ6MGn6CC5eHWtYbD/TEhjkm X-Microsoft-Exchange-Diagnostics: 1; BY1PR0301MB1223; 5:3vG7jI3G5f8zT5CAISSrD1FMI0PVSGQNca4as2ovHi9o0T+Ilr2R+v+pleYeC87icgZZHDiIIAY7DwOIH74+Ibe/Adzeiz0WWn92k+bIDqPXaF0U1xLggFMFfC+nxg/9HP/rFmsfSm/dFJL1WvMxYw==; 24:uhhVdhgu2iu74YliKrXaZMYj3yVW+iHKkIkh/1OJgfqd+3rSFhGYbhuTfJ/WtB7msPA3T2c1tYjsFHeAeHu3SY8D8gGStawrnvXDuHXLHVk=; 20:wGPtLSN+DNm5O8hwQoHJzZ2wc/Y4b/tWcnXxQrBf11tg/sG74JyLmRrDY7luIGSmXpNdRYOLgk9FvqImZEmMBQ== X-OriginatorOrg: freescale.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 15 Jul 2015 22:50:27.2708 (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.158.2]; Helo=[az84smr01.freescale.net] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BY1PR0301MB1223 X-Mailman-Approved-At: Thu, 16 Jul 2015 02:33:38 +0200 Cc: Fabio.Estevam@freescale.com, otavio@ossystems.com.br Subject: [U-Boot] [PATCH 03/11] imx: usb: ehci-mx7 add usb driver for i.MX7D X-BeenThere: u-boot@lists.denx.de X-Mailman-Version: 2.1.15 Precedence: list List-Id: U-Boot discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: u-boot-bounces@lists.denx.de Sender: "U-Boot" * Add support for usb driver for i.MX7D SoC Signed-off-by: Adrian Alonso Signed-off-by: Ye.Li Signed-off-by: Peng Fan --- drivers/usb/host/Makefile | 1 + drivers/usb/host/ehci-mx7.c | 103 ++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 104 insertions(+) create mode 100644 drivers/usb/host/ehci-mx7.c diff --git a/drivers/usb/host/Makefile b/drivers/usb/host/Makefile index 4d35d3e..7267160 100644 --- a/drivers/usb/host/Makefile +++ b/drivers/usb/host/Makefile @@ -36,6 +36,7 @@ obj-$(CONFIG_USB_EHCI_MXC) += ehci-mxc.o obj-$(CONFIG_USB_EHCI_MXS) += ehci-mxs.o obj-$(CONFIG_USB_EHCI_MX5) += ehci-mx5.o obj-$(CONFIG_USB_EHCI_MX6) += ehci-mx6.o +obj-$(CONFIG_USB_EHCI_MX7) += ehci-mx7.o obj-$(CONFIG_USB_EHCI_OMAP) += ehci-omap.o obj-$(CONFIG_USB_EHCI_PPC4XX) += ehci-ppc4xx.o obj-$(CONFIG_USB_EHCI_MARVELL) += ehci-marvell.o diff --git a/drivers/usb/host/ehci-mx7.c b/drivers/usb/host/ehci-mx7.c new file mode 100644 index 0000000..7429d62 --- /dev/null +++ b/drivers/usb/host/ehci-mx7.c @@ -0,0 +1,103 @@ +/* + * Copyright (c) 2009 Daniel Mack + * Copyright (C) 2010-2015 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier: GPL-2.0+ + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "ehci.h" + +#define USB_NC_OFFSET 0x200 + +#define UCTRL_PM (1 << 9) /* OTG Power Mask */ +#define UCTRL_OVER_CUR_POL (1 << 8) /* OTG Polarity of Overcurrent */ +#define UCTRL_OVER_CUR_DIS (1 << 7) /* Disable OTG Overcurrent Detection */ + +/* USBCMD */ +#define UCMD_RUN_STOP (1 << 0) /* controller run/stop */ +#define UCMD_RESET (1 << 1) /* controller reset */ + +/* Base address for this IP block is 0x02184800 */ +struct usbnc_regs { + u32 ctrl1; + u32 ctrl2; + u32 reserve1[11]; + u32 phy_ctrl2; + u32 reserve2[6]; + u32 adp_cfg1; + u32 reserve3; + u32 adp_status; +}; + +static void usb_oc_config(int index) +{ + struct usbnc_regs *usbnc = (struct usbnc_regs *)(USB_BASE_ADDR + + (0x10000 * index) + USB_NC_OFFSET); + void __iomem *ctrl = (void __iomem *)(&usbnc->ctrl1); + u32 val; + + val = __raw_readl(ctrl); + val |= UCTRL_OVER_CUR_POL; + __raw_writel(val, ctrl); + + val = __raw_readl(ctrl); + val |= (UCTRL_OVER_CUR_DIS | UCTRL_PM); + __raw_writel(val, ctrl); +} + +int __weak board_ehci_hcd_init(int port) +{ + return 0; +} + +int __weak board_ehci_power(int port, int on) +{ + return 0; +} + +int ehci_hcd_init(int index, enum usb_init_type init, + struct ehci_hccr **hccr, struct ehci_hcor **hcor) +{ + struct usb_ehci *ehci = (struct usb_ehci *)(USB_BASE_ADDR + + (0x10000 * index)); + + if (index > 3) + return -EINVAL; + enable_usboh3_clk(1); + mdelay(1); + + /* Do board specific initialization */ + board_ehci_hcd_init(index); + + usb_oc_config(index); + + *hccr = (struct ehci_hccr *)((uint32_t)&ehci->caplength); + *hcor = (struct ehci_hcor *)((uint32_t)*hccr + + HC_LENGTH(ehci_readl(&(*hccr)->cr_capbase))); + + board_ehci_power(index, (init == USB_INIT_DEVICE) ? 0 : 1); + if (init == USB_INIT_DEVICE) + return 0; + setbits_le32(&ehci->usbmode, CM_HOST); + __raw_writel(CONFIG_MXC_USB_PORTSC, &ehci->portsc); + setbits_le32(&ehci->portsc, USB_EN); + + mdelay(10); + + return 0; +} + +int ehci_hcd_stop(int index) +{ + return 0; +}