Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp824957pxk; Mon, 31 Aug 2020 02:01:19 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxiXuIbcBLAId6pcf70ob4/Of3IAMRKbnm70q7x9CoxjYzo4gkbHlFCHCJeZjaDCC8XEZjl X-Received: by 2002:a17:906:a0c5:: with SMTP id bh5mr198859ejb.120.1598864479118; Mon, 31 Aug 2020 02:01:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1598864479; cv=none; d=google.com; s=arc-20160816; b=Kat80g9SVqUqWSywZi8ZTx9zDiovMQS+AAbBvbyxSKrxex2ooDBdOonZ463YXnFx5l hZifmfvwM1R8+3RyVh0bBSZ7h77Ms5Z6jv84F66mHnXaiaq2ogQICNif+oR+bs+p0z4Z TF1wmXITeFMGrUiYmRx6qoLbQ8kKvWv0YcrF6ac72sGIpvPprfiFW5EFB116k0pR4m4r DlV8ib1aRlahGpuScPZ3wsTbzavAFce7JvqVhVkrHBVgd9nQclcIgzjr6k/nsKF5Njvz FqqtDfGO6QA9RuTujQ/aVAvqO1+7KW2/fqgN6ymgbORD515gCVlY0DuB/K4eZsPyM1h7 Y8Fg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=ZhwJDiB0wujhbM0V3cS+AtqxGm5g5Q0onTWlUuFfb08=; b=GfFviVdSP0kwVLfg1PEMYDJT5pXslbojGCRVNHuFahxOlHt2NHkTyAZa5bGsIU16lN y248rr6lJ9tPuQuUHVV1sjSthv//q/JnqFqYSMgBDlLtt3njgh1DAoPaAGbytKq+wOBU xbt6RncWH7NT+SurJrxdoSR1A0Nigz0A2SXQ5rOFlMsEnueV7c3CA6bIwddvpquZew6e 9ZCocJ7hSONHKXuiGcL0ip9+6UKeY+u97XIhC4BYMvaUKi94pcunqeoS8kPjUfbSiqdJ /nQAYi8LMefzR4Cno7/SMBD9+prlZk7xL9nXOxBaDGSJ0ahYSqDY/oC70T2JtCpIFbGL URfw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=0dFj3J2L; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r4si4586082eju.333.2020.08.31.02.00.53; Mon, 31 Aug 2020 02:01:19 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=0dFj3J2L; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728092AbgHaI6S (ORCPT + 99 others); Mon, 31 Aug 2020 04:58:18 -0400 Received: from mail.kernel.org ([198.145.29.99]:56340 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726102AbgHaI6O (ORCPT ); Mon, 31 Aug 2020 04:58:14 -0400 Received: from localhost (unknown [122.171.38.130]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id D4A2F206F0; Mon, 31 Aug 2020 08:58:11 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1598864292; bh=DtuiTyTPlbNpTA2byzKBYpsv3Gb5wq32dSg4ovUNU+4=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=0dFj3J2LKxL4IKMiAgun2F2EsEzVjMpoVMd0xm6me12vdtgd2QhwGCw49ka9ICVno j2CmTsxpqb5qoNJDOezZtnhYOxhm0UhZZrd6JisPoJtKjtnRsgFpBAhMhJ97cPaniw PLbcIONjw9uo+eWjJ0+TBA13ymfNQTDDoTRM8MSg= Date: Mon, 31 Aug 2020 14:28:08 +0530 From: Vinod Koul To: Lubomir Rintel Cc: Kishon Vijay Abraham I , Rob Herring , linux-kernel@vger.kernel.org, devicetree@vger.kernel.org Subject: Re: [RESEND PATCH v3 3/3] phy: Add USB HSIC PHY driver for Marvell MMP3 SoC Message-ID: <20200831085808.GH2639@vkoul-mobl> References: <20200817223400.403505-1-lkundrak@v3.sk> <20200817223400.403505-4-lkundrak@v3.sk> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200817223400.403505-4-lkundrak@v3.sk> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 18-08-20, 00:34, Lubomir Rintel wrote: > Add PHY driver for the HSICs found on Marvell MMP3 SoC. The driver is > rather straightforward -- the PHY essentially just needs to be enabled. > > Signed-off-by: Lubomir Rintel > > --- > Changes since v1: > - Explicitely cast drvdata pointer to make sparse happy > > drivers/phy/marvell/Kconfig | 12 +++++ > drivers/phy/marvell/Makefile | 1 + > drivers/phy/marvell/phy-mmp3-hsic.c | 82 +++++++++++++++++++++++++++++ > 3 files changed, 95 insertions(+) > create mode 100644 drivers/phy/marvell/phy-mmp3-hsic.c > > diff --git a/drivers/phy/marvell/Kconfig b/drivers/phy/marvell/Kconfig > index 8f6273c837ec3..6c96f2bf52665 100644 > --- a/drivers/phy/marvell/Kconfig > +++ b/drivers/phy/marvell/Kconfig > @@ -116,3 +116,15 @@ config PHY_MMP3_USB > The PHY driver will be used by Marvell udc/ehci/otg driver. > > To compile this driver as a module, choose M here. > + > +config PHY_MMP3_HSIC > + tristate "Marvell MMP3 USB HSIC PHY Driver" > + depends on MACH_MMP3_DT || COMPILE_TEST > + select GENERIC_PHY > + help > + Enable this to support Marvell MMP3 USB HSIC PHY driver for > + Marvell MMP3 SoC. This driver will be used my the Marvell EHCI > + driver to initialize the interface to internal USB HSIC > + components on MMP3-based boards. > + > + To compile this driver as a module, choose M here. > diff --git a/drivers/phy/marvell/Makefile b/drivers/phy/marvell/Makefile > index 5a106b1549f41..7f296ef028292 100644 > --- a/drivers/phy/marvell/Makefile > +++ b/drivers/phy/marvell/Makefile > @@ -3,6 +3,7 @@ obj-$(CONFIG_ARMADA375_USBCLUSTER_PHY) += phy-armada375-usb2.o > obj-$(CONFIG_PHY_BERLIN_SATA) += phy-berlin-sata.o > obj-$(CONFIG_PHY_BERLIN_USB) += phy-berlin-usb.o > obj-$(CONFIG_PHY_MMP3_USB) += phy-mmp3-usb.o > +obj-$(CONFIG_PHY_MMP3_HSIC) += phy-mmp3-hsic.o > obj-$(CONFIG_PHY_MVEBU_A3700_COMPHY) += phy-mvebu-a3700-comphy.o > obj-$(CONFIG_PHY_MVEBU_A3700_UTMI) += phy-mvebu-a3700-utmi.o > obj-$(CONFIG_PHY_MVEBU_A38X_COMPHY) += phy-armada38x-comphy.o > diff --git a/drivers/phy/marvell/phy-mmp3-hsic.c b/drivers/phy/marvell/phy-mmp3-hsic.c > new file mode 100644 > index 0000000000000..47c1e8894939f > --- /dev/null > +++ b/drivers/phy/marvell/phy-mmp3-hsic.c > @@ -0,0 +1,82 @@ > +// SPDX-License-Identifier: GPL-2.0+ > +/* > + * Copyright (C) 2020 Lubomir Rintel > + */ > + > +#include > +#include > +#include > +#include > +#include > + > +#define HSIC_CTRL 0x08 > +#define HSIC_ENABLE BIT(7) > +#define PLL_BYPASS BIT(4) > + > +static int mmp3_hsic_phy_init(struct phy *phy) > +{ > + void __iomem *base = (void __iomem *)phy_get_drvdata(phy); you are casting away from void * and casting to another void *, something doesn't look correct! > + u32 hsic_ctrl; > + > + hsic_ctrl = readl_relaxed(base + HSIC_CTRL); > + hsic_ctrl |= HSIC_ENABLE; > + hsic_ctrl |= PLL_BYPASS; > + writel_relaxed(hsic_ctrl, base + HSIC_CTRL); > + > + return 0; > +} > + > +static const struct phy_ops mmp3_hsic_phy_ops = { > + .init = mmp3_hsic_phy_init, > + .owner = THIS_MODULE, > +}; > + > +static const struct of_device_id mmp3_hsic_phy_of_match[] = { > + { .compatible = "marvell,mmp3-hsic-phy", }, > + { }, > +}; > +MODULE_DEVICE_TABLE(of, mmp3_hsic_phy_of_match); > + > +static int mmp3_hsic_phy_probe(struct platform_device *pdev) > +{ > + struct device *dev = &pdev->dev; > + struct phy_provider *provider; > + struct resource *resource; > + void __iomem *base; > + struct phy *phy; > + > + resource = platform_get_resource(pdev, IORESOURCE_MEM, 0); > + base = devm_ioremap_resource(dev, resource); > + if (IS_ERR(base)) { > + dev_err(dev, "failed to remap PHY regs\n"); > + return PTR_ERR(base); > + } > + > + phy = devm_phy_create(dev, NULL, &mmp3_hsic_phy_ops); > + if (IS_ERR(phy)) { > + dev_err(dev, "failed to create PHY\n"); > + return PTR_ERR(phy); > + } > + > + phy_set_drvdata(phy, (void *)base); again skip the cast > + provider = devm_of_phy_provider_register(dev, of_phy_simple_xlate); > + if (IS_ERR(provider)) { > + dev_err(dev, "failed to register PHY provider\n"); > + return PTR_ERR(provider); > + } > + > + return 0; > +} > + > +static struct platform_driver mmp3_hsic_phy_driver = { > + .probe = mmp3_hsic_phy_probe, > + .driver = { > + .name = "mmp3-hsic-phy", > + .of_match_table = mmp3_hsic_phy_of_match, > + }, > +}; > +module_platform_driver(mmp3_hsic_phy_driver); > + > +MODULE_AUTHOR("Lubomir Rintel "); > +MODULE_DESCRIPTION("Marvell MMP3 USB HSIC PHY Driver"); > +MODULE_LICENSE("GPL"); > -- > 2.26.2 -- ~Vinod