forked from rpms/kernel
		
	arm64: qcom: add patch for ACPI UFS storage
This commit is contained in:
		
							parent
							
								
									639ea3fb7e
								
							
						
					
					
						commit
						0d2c8ee000
					
				
							
								
								
									
										83
									
								
								arm64-ufs-qcom-Add-support-for-platforms-booting-ACPI.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								arm64-ufs-qcom-Add-support-for-platforms-booting-ACPI.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,83 @@ | ||||
| From 9ceb22fbffbad710db2c91ed32e4e73503f13301 Mon Sep 17 00:00:00 2001 | ||||
| From: Peter Robinson <pbrobinson@gmail.com> | ||||
| Date: Tue, 25 Jun 2019 19:12:10 +0100 | ||||
| Subject: [PATCH] scsi: ufs-qcom: Add support for platforms booting ACPI | ||||
| 
 | ||||
| New Qualcomm AArch64 based laptops are now available which use UFS | ||||
| as their primary data storage medium.  These devices are supplied | ||||
| with ACPI support out of the box.  This patch ensures the Qualcomm | ||||
| UFS driver will be bound when the "QCOM24A5" H/W device is | ||||
| advertised as present. | ||||
| 
 | ||||
| Signed-off-by: Lee Jones <lee.jones@linaro.org> | ||||
| Reviewed-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> | ||||
| Signed-off-by: Peter Robinson <pbrobinson@gmail.com> | ||||
| ---
 | ||||
|  drivers/scsi/ufs/ufs-qcom.c | 23 ++++++++++++++++++++--- | ||||
|  1 file changed, 20 insertions(+), 3 deletions(-) | ||||
| 
 | ||||
| diff --git a/drivers/scsi/ufs/ufs-qcom.c b/drivers/scsi/ufs/ufs-qcom.c
 | ||||
| index b4d1b5c22987..ee4b1da1e223 100644
 | ||||
| --- a/drivers/scsi/ufs/ufs-qcom.c
 | ||||
| +++ b/drivers/scsi/ufs/ufs-qcom.c
 | ||||
| @@ -3,6 +3,7 @@
 | ||||
|   * Copyright (c) 2013-2016, Linux Foundation. All rights reserved. | ||||
|   */ | ||||
|   | ||||
| +#include <linux/acpi.h>
 | ||||
|  #include <linux/time.h> | ||||
|  #include <linux/of.h> | ||||
|  #include <linux/platform_device.h> | ||||
| @@ -161,6 +162,9 @@ static int ufs_qcom_init_lane_clks(struct ufs_qcom_host *host)
 | ||||
|  	int err = 0; | ||||
|  	struct device *dev = host->hba->dev; | ||||
|   | ||||
| +	if (has_acpi_companion(dev))
 | ||||
| +		return 0;
 | ||||
| +
 | ||||
|  	err = ufs_qcom_host_clk_get(dev, "rx_lane0_sync_clk", | ||||
|  					&host->rx_l0_sync_clk, false); | ||||
|  	if (err) | ||||
| @@ -1127,9 +1131,13 @@ static int ufs_qcom_init(struct ufs_hba *hba)
 | ||||
|  			__func__, err); | ||||
|  		goto out_variant_clear; | ||||
|  	} else if (IS_ERR(host->generic_phy)) { | ||||
| -		err = PTR_ERR(host->generic_phy);
 | ||||
| -		dev_err(dev, "%s: PHY get failed %d\n", __func__, err);
 | ||||
| -		goto out_variant_clear;
 | ||||
| +		if (has_acpi_companion(dev)) {
 | ||||
| +			host->generic_phy = NULL;
 | ||||
| +		} else {
 | ||||
| +			err = PTR_ERR(host->generic_phy);
 | ||||
| +			dev_err(dev, "%s: PHY get failed %d\n", __func__, err);
 | ||||
| +			goto out_variant_clear;
 | ||||
| +		}
 | ||||
|  	} | ||||
|   | ||||
|  	err = ufs_qcom_bus_register(host); | ||||
| @@ -1599,6 +1607,14 @@ static const struct of_device_id ufs_qcom_of_match[] = {
 | ||||
|  }; | ||||
|  MODULE_DEVICE_TABLE(of, ufs_qcom_of_match); | ||||
|   | ||||
| +#ifdef CONFIG_ACPI
 | ||||
| +static const struct acpi_device_id ufs_qcom_acpi_match[] = {
 | ||||
| +	{ "QCOM24A5" },
 | ||||
| +	{ },
 | ||||
| +};
 | ||||
| +MODULE_DEVICE_TABLE(acpi, ufs_qcom_acpi_match);
 | ||||
| +#endif
 | ||||
| +
 | ||||
|  static const struct dev_pm_ops ufs_qcom_pm_ops = { | ||||
|  	.suspend	= ufshcd_pltfrm_suspend, | ||||
|  	.resume		= ufshcd_pltfrm_resume, | ||||
| @@ -1615,6 +1631,7 @@ static struct platform_driver ufs_qcom_pltform = {
 | ||||
|  		.name	= "ufshcd-qcom", | ||||
|  		.pm	= &ufs_qcom_pm_ops, | ||||
|  		.of_match_table = of_match_ptr(ufs_qcom_of_match), | ||||
| +		.acpi_match_table = ACPI_PTR(ufs_qcom_acpi_match),
 | ||||
|  	}, | ||||
|  }; | ||||
|  module_platform_driver(ufs_qcom_pltform); | ||||
| -- 
 | ||||
| 2.21.0 | ||||
| 
 | ||||
| @ -568,7 +568,7 @@ Patch350: arm64-qcom-pinctrl-support-for-ACPI.patch | ||||
| Patch351: arm64-acpi-ignore-5.1-fadts-reported-as-5.0.patch | ||||
| Patch352: arm64-acpi-make-ac-and-battery-drivers-available-on-non-x86.patch | ||||
| Patch353: arm64-qcom-DWC3-USB-Add-support-for-ACPI-based-AArch64-Laptops.patch | ||||
| 
 | ||||
| Patch354: arm64-ufs-qcom-Add-support-for-platforms-booting-ACPI.patch | ||||
| 
 | ||||
| # 400 - IBM (ppc/s390x) patches | ||||
| 
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user