From patchwork Thu May 16 09:57:11 2013 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Tomasz Figa X-Patchwork-Id: 2576101 Return-Path: X-Original-To: patchwork-linux-samsung-soc@patchwork.kernel.org Delivered-To: patchwork-process-083081@patchwork1.kernel.org Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by patchwork1.kernel.org (Postfix) with ESMTP id 10BB83FE1F for ; Thu, 16 May 2013 09:57:44 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752118Ab3EPJ5k (ORCPT ); Thu, 16 May 2013 05:57:40 -0400 Received: from mailout2.w1.samsung.com ([210.118.77.12]:53090 "EHLO mailout2.w1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752138Ab3EPJ5i (ORCPT ); Thu, 16 May 2013 05:57:38 -0400 Received: from eucpsbgm1.samsung.com (unknown [203.254.199.244]) by mailout2.w1.samsung.com (Oracle Communications Messaging Server 7u4-24.01(7.0.4.24.0) 64bit (built Nov 17 2011)) with ESMTP id <0MMV005WYYAWO240@mailout2.w1.samsung.com>; Thu, 16 May 2013 10:57:30 +0100 (BST) X-AuditID: cbfec7f4-b7fd76d0000035e1-17-5194ad8addca Received: from eusync2.samsung.com ( [203.254.199.212]) by eucpsbgm1.samsung.com (EUCPMTA) with SMTP id 11.AD.13793.A8DA4915; Thu, 16 May 2013 10:57:30 +0100 (BST) Received: from amdc1227.digital.local ([106.116.147.199]) by eusync2.samsung.com (Oracle Communications Messaging Server 7u4-23.01(7.0.4.23.0) 64bit (built Aug 10 2011)) with ESMTPA id <0MMV00J8RYBOHX80@eusync2.samsung.com>; Thu, 16 May 2013 10:57:30 +0100 (BST) From: Tomasz Figa To: linux-samsung-soc@vger.kernel.org Cc: linux-arm-kernel@lists.infradead.org, linux-usb@vger.kernel.org, balbi@ti.com, Praveen Paneri , Vivek Gautam , gregkh@linuxfoundation.org, kyungmin.park@samsung.com, Tomasz Figa Subject: [PATCH v2 6/6] usb: phy: samsung: Add support for USB 2.0 PHY on Exynos 4x12 Date: Thu, 16 May 2013 11:57:11 +0200 Message-id: <1368698231-24268-7-git-send-email-t.figa@samsung.com> X-Mailer: git-send-email 1.8.2.1 In-reply-to: <1368698231-24268-1-git-send-email-t.figa@samsung.com> References: <1368698231-24268-1-git-send-email-t.figa@samsung.com> X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFvrPJMWRmVeSWpSXmKPExsVy+t/xK7pda6cEGry8oWVx8H69RduVg+wW zYvXs1mcbXrDbrHp8TVWixnn9zFZLFrWymxxfksnk8X6Ga9ZHDg99s9dw+6xeUm9R9+WVYwe x29sZ/L4vEkugDWKyyYlNSezLLVI3y6BK+Pp5Wb2gm2iFaf7VjI3MH4X7GLk5JAQMJHYvPU4 M4QtJnHh3nq2LkYuDiGBpYwSa99MZYJw+pgkPre0MIFUsQmoSXxueMQGYosIqEp8blvADlLE LNDAJHF23VxGkISwQLjEnNd9rCA2C1DRganbwBp4BZwkNm35zQixTkHi+PZtYDangLPEkf0r wOqFgGoeX3vKMoGRdwEjwypG0dTS5ILipPRcQ73ixNzi0rx0veT83E2MkED7soNx8TGrQ4wC HIxKPLyW0ycHCrEmlhVX5h5ilOBgVhLhnZE6JVCINyWxsiq1KD++qDQntfgQIxMHp1QDo+mW +H1CnktezeBY8uXJoTP/7FMF/nsU7naYVmpRbl4zZUXMzTypGY8Oqrgn3Yrg6/u+LuVbsIbD Y4aARTMqGPdMebg9ebXgi860MJPtq5kYyloaQjbmdWSLXzWKdL61tL48376t45rW+nePPY7z 2Ux7PXn+Kt5fp69tKBb4YtDybeZkxrXNx5VYijMSDbWYi4oTAchdpwgSAgAA Sender: linux-samsung-soc-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-samsung-soc@vger.kernel.org This patch adds driver data for Exynos 4x12 USB 2.0 PHY. Signed-off-by: Tomasz Figa Signed-off-by: Kyungmin Park --- drivers/usb/phy/phy-samsung-usb.h | 1 + drivers/usb/phy/phy-samsung-usb2.c | 18 ++++++++++++++++++ 2 files changed, 19 insertions(+) diff --git a/drivers/usb/phy/phy-samsung-usb.h b/drivers/usb/phy/phy-samsung-usb.h index 31e2ec3..585d12f 100644 --- a/drivers/usb/phy/phy-samsung-usb.h +++ b/drivers/usb/phy/phy-samsung-usb.h @@ -241,6 +241,7 @@ enum samsung_cpu_type { TYPE_S3C64XX, TYPE_EXYNOS4210, + TYPE_EXYNOS4X12, TYPE_EXYNOS5250, }; diff --git a/drivers/usb/phy/phy-samsung-usb2.c b/drivers/usb/phy/phy-samsung-usb2.c index b81347b..381f8d4 100644 --- a/drivers/usb/phy/phy-samsung-usb2.c +++ b/drivers/usb/phy/phy-samsung-usb2.c @@ -177,6 +177,7 @@ static void samsung_usb2phy_enable(struct samsung_usbphy *sphy) rstcon |= RSTCON_SWRST; break; case TYPE_EXYNOS4210: + case TYPE_EXYNOS4X12: phypwr &= ~PHYPWR_NORMAL_MASK_PHY0; rstcon |= RSTCON_SWRST; default: @@ -240,6 +241,7 @@ static void samsung_usb2phy_disable(struct samsung_usbphy *sphy) phypwr |= PHYPWR_NORMAL_MASK; break; case TYPE_EXYNOS4210: + case TYPE_EXYNOS4X12: phypwr |= PHYPWR_NORMAL_MASK_PHY0; default: break; @@ -456,6 +458,16 @@ static const struct samsung_usbphy_drvdata usb2phy_exynos4 = { .phy_disable = samsung_usb2phy_disable, }; +static const struct samsung_usbphy_drvdata usb2phy_exynos4x12 = { + .cpu_type = TYPE_EXYNOS4X12, + .devphy_en_mask = EXYNOS_USBPHY_ENABLE, + .hostphy_en_mask = EXYNOS_USBPHY_ENABLE, + .rate_to_clksel = samsung_usbphy_rate_to_clksel_4x12, + .set_isolation = samsung_usbphy_set_isolation_4210, + .phy_enable = samsung_usb2phy_enable, + .phy_disable = samsung_usb2phy_disable, +}; + static struct samsung_usbphy_drvdata usb2phy_exynos5 = { .cpu_type = TYPE_EXYNOS5250, .hostphy_en_mask = EXYNOS_USBPHY_ENABLE, @@ -475,6 +487,9 @@ static const struct of_device_id samsung_usbphy_dt_match[] = { .compatible = "samsung,exynos4210-usb2phy", .data = &usb2phy_exynos4, }, { + .compatible = "samsung,exynos4x12-usb2phy", + .data = &usb2phy_exynos4x12, + }, { .compatible = "samsung,exynos5250-usb2phy", .data = &usb2phy_exynos5 }, @@ -491,6 +506,9 @@ static struct platform_device_id samsung_usbphy_driver_ids[] = { .name = "exynos4210-usb2phy", .driver_data = (unsigned long)&usb2phy_exynos4, }, { + .name = "exynos4x12-usb2phy", + .driver_data = (unsigned long)&usb2phy_exynos4x12, + }, { .name = "exynos5250-usb2phy", .driver_data = (unsigned long)&usb2phy_exynos5, },