Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp2551067ybl; Mon, 20 Jan 2020 05:09:57 -0800 (PST) X-Google-Smtp-Source: APXvYqx1lOy/3e+fQMOPZxC/CdNSaR/UO5lWA4TmrMwLsymFCUN/d/1v4w/qmvAP6yISDDqfr0tO X-Received: by 2002:a05:6808:2d2:: with SMTP id a18mr12896162oid.120.1579525797685; Mon, 20 Jan 2020 05:09:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579525797; cv=none; d=google.com; s=arc-20160816; b=NjXCsR50Uf6OnBSBDvPwLOzbSZB5EMnE62BMGkrhydJ8fdFTaV975mwLIa1gbqMW7E XteTNAmaRZvGZGgqf5OwKde2JVgaYkXm6G9bZBSIKvfNWx+Ql0qAqbWUSx9Vlmks5x9o /OcJhJDSS2eX4kg1w7gaN1XBNbCT+TJF97T1zE2wRYgDW+3qIBfvEEsl8xDIDV9Yytpg dsz9CisgBF6sY/zRk199HQroRdT3Yzdp/JPYMlOdn9deup82E4Gz+n7JFoNqfAJKZxSL I244SoIR9YBNgqbMTKfC5BfSXH0Iab3YCD9Wv3/s/DlXWhyAEj6jB/jsoT7ciW4R9q0V cdaw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=z0UrFTfKrgLfX01/rLl/IRCgo7e5VdzQ1WnFgxsg8f4=; b=NhAghN9svzNOceLuqU5BDuEZLlx7YF53lOQy2A30u6DAAx8jAtQLwliTZmhb0dP23x ws6O42AK6dEfOPiioNzLcDx4HlS9MPB8CbADbagchzTM17cHRqkMYlJuy6XVHn0eF3lJ yAdIvIDrEh9C61+Htx8CmLQwxj9k2DmIVKZ8JQX94OidNjCw+oUWXNbZDcgPmMnC1y++ gRQMlRVNF0F01xm/ePz8t7efD21C0HFWt4pTOU8GcPcxFr11t/pDYWdYTzu5o7S/+Nz+ mS0iYrIpGjoM3U5atCdwTYD/zyWxbUIXeZ3GiMeU6iMinO4Nazxdzj1jYOe3vpTiqxru 4pKQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=aW+jYWBi; 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=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id s3si19535457otr.57.2020.01.20.05.09.45; Mon, 20 Jan 2020 05:09:57 -0800 (PST) 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=@gmail.com header.s=20161025 header.b=aW+jYWBi; 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=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728992AbgATNIp (ORCPT + 99 others); Mon, 20 Jan 2020 08:08:45 -0500 Received: from mail-wr1-f67.google.com ([209.85.221.67]:45134 "EHLO mail-wr1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726798AbgATNIo (ORCPT ); Mon, 20 Jan 2020 08:08:44 -0500 Received: by mail-wr1-f67.google.com with SMTP id j42so29454404wrj.12; Mon, 20 Jan 2020 05:08:43 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=z0UrFTfKrgLfX01/rLl/IRCgo7e5VdzQ1WnFgxsg8f4=; b=aW+jYWBiw3d/3RR6GlTjxdSJhejziaCQfj5civ8JE3jtjVDgVQO/NmoJcXeP1EfiTa 6mGAnFURVF6Qs2xy/JugSFjQMGmgh7igyxCIvFkJXulZWi7zvtk36NGY3kytHfW6uJ/P l3YPCWJzYG679ds52lFFnSzJynedJi2/ULee0b4aLgRNdM7Duw8WDpSmG34QOcjC6Ucc vULKWM+q4qoyqjY1rGzxZTIyVwF+r+e0pDfgHYDe/TNWE7LsxUU7NHhKrGRzjkCqOHF3 ZFipCEYXKzbSR9e+vNB8SeHWzQSvqyv6HhVZLplY6Na+1m81P1OMfFkfY5hG8i1GR5Z2 htaQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=z0UrFTfKrgLfX01/rLl/IRCgo7e5VdzQ1WnFgxsg8f4=; b=qR6s6TYslMIFb5psEEC9dykgZMAZF/V0nzb2JtZ2lZ8dAEnBt2xohMktdzxPd3HPev tiMKzVE8mDnc6D7AnQ8wpkt97PumHaru3HuMG5vklYlKbAMSvSuH0yiBBDMekOLsoRjM bENIGtqmcZv3/qN9RkP9f7H0aRKDdtbz5SL9i7aKpjiXyhT+Gl17HPc+QRbtiW6VDHX1 /CiynPIscei9XOKvzLxzccuhUpkDSwKdEyO1OeX9WJoC/qaL6uz8qUKFbbfusDfSPNBF msJVPfuQ4HpwumU4ruXf83nwOf3oSBpFvJIAzejtBXKpWOBKzqOWK+MDRnynn5iWthtB vZpw== X-Gm-Message-State: APjAAAUCbAw7woiV1/Bl8IAgAEVn87VaMcrCjTJqAq5yYB+w7ua94inw Be7mmrF/JRH6g2D9ohvHcpA= X-Received: by 2002:adf:ec41:: with SMTP id w1mr17925790wrn.212.1579525722126; Mon, 20 Jan 2020 05:08:42 -0800 (PST) Received: from ubuntu-G3.micron.com ([165.225.86.138]) by smtp.gmail.com with ESMTPSA id p18sm23065386wmb.8.2020.01.20.05.08.36 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 20 Jan 2020 05:08:41 -0800 (PST) From: Bean Huo To: alim.akhtar@samsung.com, avri.altman@wdc.com, asutoshd@codeaurora.org, jejb@linux.ibm.com, martin.petersen@oracle.com, stanley.chu@mediatek.com, beanhuo@micron.com, bvanassche@acm.org, tomas.winkler@intel.com, cang@codeaurora.org Cc: linux-scsi@vger.kernel.org, linux-kernel@vger.kernel.org, Bean Huo Subject: [PATCH v4 0/8] Use UFS device indicated maximum LU number Date: Mon, 20 Jan 2020 14:08:12 +0100 Message-Id: <20200120130820.1737-1-huobean@gmail.com> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This series of patches is to simplify UFS driver initialization flow and add a new parameter max_lu_supported used to specify how many LUs supported by the UFS device. This series of patches being tested on my two platforms, Qualcomm SOC based and Hisilicon SOC based platforms. v1-v2: 1. Split ufshcd_probe_hba() based on its called flow 2. Delete two unnecessary functions 3. Add a fixup patch v2-v3: 1. Combine patches 7/9 and 8/9 of v2 to patch 7/8 of v3 2. Change patches 1/8 and 5/8 subject 3. Change the name of two functions in patch 7/8 v3-v4: 1. Change patch 4/8 subject 2. Change new added function name from ufshcd_init_params() to ufshcd_device_params_init() 3. Change new added function name from ufshcd_init_device_geo_params() to ufshcd_device_geo_params_init() 4. Fix two compilation errors in patch 2/8: 1) Missed an operator "&" in function ufs_mtk_apply_dev_quirks() when getting address of the dev_info. 2) Incorrectly changed hba->dev_quirks to dev_info->dev_quirks in function ufs_qcom_apply_dev_quirks(). Bean Huo (8): scsi: ufs: Fix ufshcd_probe_hba() reture value in case ufshcd_scsi_add_wlus() fails scsi: ufs: Delete struct ufs_dev_desc scsi: ufs: Split ufshcd_probe_hba() based on its called flow scsi: ufs: Move ufshcd_get_max_pwr_mode() to ufshcd_device_params_init() scsi: ufs: Inline two functions into their callers scsi: ufs: Delete is_init_prefetch from struct ufs_hba scsi: ufs: Add max_lu_supported in struct ufs_dev_info scsi: ufs: Use UFS device indicated maximum LU number drivers/scsi/ufs/ufs-mediatek.c | 7 +- drivers/scsi/ufs/ufs-qcom.c | 3 +- drivers/scsi/ufs/ufs-sysfs.c | 2 +- drivers/scsi/ufs/ufs.h | 25 ++- drivers/scsi/ufs/ufs_quirks.h | 9 +- drivers/scsi/ufs/ufshcd.c | 276 +++++++++++++++++++------------- drivers/scsi/ufs/ufshcd.h | 9 +- 7 files changed, 194 insertions(+), 137 deletions(-) -- 2.17.1