Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp2068534ybp; Thu, 10 Oct 2019 01:35:45 -0700 (PDT) X-Google-Smtp-Source: APXvYqxC9VKec5RTYWLsmKBn5VOsn/vGVgllTcQgBVfwl1rl7BbinmJxCJBsNUHLixoivbAw+JIN X-Received: by 2002:a17:906:8d6:: with SMTP id o22mr6864978eje.153.1570696545831; Thu, 10 Oct 2019 01:35:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1570696545; cv=none; d=google.com; s=arc-20160816; b=JimO8E8HXUAymn9re2yJIxd/fRN3HApJaHXAeN+OOp+VzwVUbzyvcDlhg6qVMzF+SY XEAR93+Dw53zRE7QjhZzKJ5mi7dAhZ0CkP3a9p8ZjS2QDE6HQcvIAGnaoFg9N/XmYbIW VaYKxFm4sKQV/MDHI2pceZnN/h8274IeRWUj8UcqHT8YKI0u23lbRl3vS3YqaWgpdRi3 3+g59kLNs6MEPDA1DcJe1gFFmQJASbP2gdSmqdP+jX9jnWUGNQphFU3KaJp8Zop3zQhR rNwA/X5q8Z91ShjXZM1e7PVXn/N8pWkGX/xpAiHoBAtqGAbir9+mIQMd4vuhtlkJDDZA 5g/A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=kGuezWxP+bReGMiBtuHKQ2OgxAKcjmQPRtrZdJJzMNo=; b=WQzn/v/wsfDU4dxImRSV7ZQXE6mJsdT0yLIzkV9BHLVooTKoOftGXZe0IAiv6WtA+7 0HeACPU17HAWVERTvKdoRTv1ynwq/F23+gRXx7mIkX9+Bb/xScpEi1RfLmn7G2pUziai X29L9/lxLBec+dmNh/lOpX2PgaCS6HFQA7sImJa5UvADLfy/b62owWVPXXW0i8uxUUK5 ORkZv1dPywF5GOwO0uR6YGzdZ13RhgtVu9PWqK8Rf2dgkkLuAJts6EMyXfxKhX054GL5 ztvPodNMAHXZBt0FMhu/54jbOsQbPynUQkmcEtNdC//NSqLkoG10bNzqrmNHmhPX3Hsk sIJQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=Ih5CqTgx; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id om23si2571535ejb.194.2019.10.10.01.35.22; Thu, 10 Oct 2019 01:35:45 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=Ih5CqTgx; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387434AbfJJIeF (ORCPT + 99 others); Thu, 10 Oct 2019 04:34:05 -0400 Received: from lelv0142.ext.ti.com ([198.47.23.249]:43238 "EHLO lelv0142.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387421AbfJJIeD (ORCPT ); Thu, 10 Oct 2019 04:34:03 -0400 Received: from lelv0266.itg.ti.com ([10.180.67.225]) by lelv0142.ext.ti.com (8.15.2/8.15.2) with ESMTP id x9A8Xnfc127748; Thu, 10 Oct 2019 03:33:49 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1570696429; bh=kGuezWxP+bReGMiBtuHKQ2OgxAKcjmQPRtrZdJJzMNo=; h=From:To:CC:Subject:Date:In-Reply-To:References; b=Ih5CqTgx+HkVx/we4i9HiOBhc+ckvjOFbZWKaWW4t+pyD0X7zddFmcYoJHANRDTxN EaT/B+dxU5hi0S5SwXvEvqbLWgXwwaon4QfQkM7vEscpM2jwcsnI3MLNyvWrMNANyd CWUJ6IpP7cGcQiOLPSfIuYkEzyFeP0V0aFr7MGzw= Received: from DFLE110.ent.ti.com (dfle110.ent.ti.com [10.64.6.31]) by lelv0266.itg.ti.com (8.15.2/8.15.2) with ESMTPS id x9A8Xnhx124258 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Thu, 10 Oct 2019 03:33:49 -0500 Received: from DFLE107.ent.ti.com (10.64.6.28) by DFLE110.ent.ti.com (10.64.6.31) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1713.5; Thu, 10 Oct 2019 03:33:48 -0500 Received: from lelv0326.itg.ti.com (10.180.67.84) by DFLE107.ent.ti.com (10.64.6.28) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1713.5 via Frontend Transport; Thu, 10 Oct 2019 03:33:45 -0500 Received: from a0132425.dhcp.ti.com (ileax41-snat.itg.ti.com [10.172.224.153]) by lelv0326.itg.ti.com (8.15.2/8.15.2) with ESMTP id x9A8XaSb019061; Thu, 10 Oct 2019 03:33:45 -0500 From: Vignesh Raghavendra To: Rob Herring , Mark Rutland , , Martin K Petersen CC: Alim Akhtar , Avri Altman , Pedro Sousa , Janek Kotas , , , , Vignesh Raghavendra , Subject: [PATCH v2 2/2] scsi: ufs: Add driver for TI wrapper for Cadence UFS IP Date: Thu, 10 Oct 2019 14:03:57 +0530 Message-ID: <20191010083357.28982-3-vigneshr@ti.com> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191010083357.28982-1-vigneshr@ti.com> References: <20191010083357.28982-1-vigneshr@ti.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org TI's J721e SoC has a Cadence UFS IP with a TI specific wrapper. This is a minimal driver to configure the wrapper. It releases the UFS slave device out of reset and sets up registers to indicate PHY reference clock input frequency before probing child Cadence UFS driver. Signed-off-by: Vignesh Raghavendra --- v2: No change drivers/scsi/ufs/Kconfig | 10 ++++ drivers/scsi/ufs/Makefile | 1 + drivers/scsi/ufs/ti-j721e-ufs.c | 90 +++++++++++++++++++++++++++++++++ 3 files changed, 101 insertions(+) create mode 100644 drivers/scsi/ufs/ti-j721e-ufs.c diff --git a/drivers/scsi/ufs/Kconfig b/drivers/scsi/ufs/Kconfig index 0b845ab7c3bf..d14c2243e02a 100644 --- a/drivers/scsi/ufs/Kconfig +++ b/drivers/scsi/ufs/Kconfig @@ -132,6 +132,16 @@ config SCSI_UFS_HISI Select this if you have UFS controller on Hisilicon chipset. If unsure, say N. +config SCSI_UFS_TI_J721E + tristate "TI glue layer for Cadence UFS Controller" + depends on OF && HAS_IOMEM && (ARCH_K3 || COMPILE_TEST) + help + This selects driver for TI glue layer for Cadence UFS Host + Controller IP. + + Selects this if you have TI platform with UFS controller. + If unsure, say N. + config SCSI_UFS_BSG bool "Universal Flash Storage BSG device node" depends on SCSI_UFSHCD diff --git a/drivers/scsi/ufs/Makefile b/drivers/scsi/ufs/Makefile index 2a9097939bcb..94c6c5d7334b 100644 --- a/drivers/scsi/ufs/Makefile +++ b/drivers/scsi/ufs/Makefile @@ -11,3 +11,4 @@ obj-$(CONFIG_SCSI_UFSHCD_PCI) += ufshcd-pci.o obj-$(CONFIG_SCSI_UFSHCD_PLATFORM) += ufshcd-pltfrm.o obj-$(CONFIG_SCSI_UFS_HISI) += ufs-hisi.o obj-$(CONFIG_SCSI_UFS_MEDIATEK) += ufs-mediatek.o +obj-$(CONFIG_SCSI_UFS_TI_J721E) += ti-j721e-ufs.o diff --git a/drivers/scsi/ufs/ti-j721e-ufs.c b/drivers/scsi/ufs/ti-j721e-ufs.c new file mode 100644 index 000000000000..a653bf1902f3 --- /dev/null +++ b/drivers/scsi/ufs/ti-j721e-ufs.c @@ -0,0 +1,90 @@ +// SPDX-License-Identifier: GPL-2.0 +// +// Copyright (C) 2019 Texas Instruments Incorporated - http://www.ti.com/ +// + +#include +#include +#include +#include +#include +#include +#include + +#define UFS_SS_CTRL 0x4 +#define UFS_SS_RST_N_PCS BIT(0) +#define UFS_SS_CLK_26MHZ BIT(4) + +static int ti_j721e_ufs_probe(struct platform_device *pdev) +{ + struct device *dev = &pdev->dev; + unsigned long clk_rate; + void __iomem *regbase; + struct clk *clk; + u32 reg = 0; + int ret; + + regbase = devm_platform_ioremap_resource(pdev, 0); + if (IS_ERR(regbase)) + return PTR_ERR(regbase); + + /* Select MPHY refclk frequency */ + clk = devm_clk_get(dev, NULL); + if (IS_ERR(clk)) { + dev_err(dev, "Cannot claim MPHY clock.\n"); + return PTR_ERR(clk); + } + clk_rate = clk_get_rate(clk); + if (clk_rate == 26000000) + reg |= UFS_SS_CLK_26MHZ; + devm_clk_put(dev, clk); + + pm_runtime_enable(dev); + ret = pm_runtime_get_sync(dev); + if (ret < 0) { + pm_runtime_put_noidle(dev); + return ret; + } + + /* Take UFS slave device out of reset */ + reg |= UFS_SS_RST_N_PCS; + writel(reg, regbase + UFS_SS_CTRL); + + ret = of_platform_populate(pdev->dev.of_node, NULL, NULL, + dev); + if (ret) { + dev_err(dev, "failed to populate child nodes %d\n", ret); + pm_runtime_put_sync(dev); + } + + return ret; +} + +static int ti_j721e_ufs_remove(struct platform_device *pdev) +{ + of_platform_depopulate(&pdev->dev); + pm_runtime_put_sync(&pdev->dev); + + return 0; +} + +static const struct of_device_id ti_j721e_ufs_of_match[] = { + { + .compatible = "ti,j721e-ufs", + }, + { }, +}; + +static struct platform_driver ti_j721e_ufs_driver = { + .probe = ti_j721e_ufs_probe, + .remove = ti_j721e_ufs_remove, + .driver = { + .name = "ti-j721e-ufs", + .of_match_table = ti_j721e_ufs_of_match, + }, +}; +module_platform_driver(ti_j721e_ufs_driver); + +MODULE_AUTHOR("Vignesh Raghavendra "); +MODULE_DESCRIPTION("TI UFS host controller glue driver"); +MODULE_LICENSE("GPL v2"); -- 2.23.0