Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp2552728ybl; Mon, 20 Jan 2020 05:11:36 -0800 (PST) X-Google-Smtp-Source: APXvYqy9/glxjuTb4Sx+uaTeB0+CqZo8aP9vRzWCKVWDFM74+wBWSUG0ibEl9D807iGi6uH7pmrv X-Received: by 2002:a9d:74d8:: with SMTP id a24mr16601517otl.100.1579525895786; Mon, 20 Jan 2020 05:11:35 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579525895; cv=none; d=google.com; s=arc-20160816; b=iwxae1RWlvIhSZMm+BqNvAYI2EF6hdMATBFnFjVd1DiCCDcVyGMjnG6sFFow0v/RNh N7lgpCAot0Kbrpu45Rd4oKl09lq9a8wef/9ambRR9hqVbQVwBrR0imdxp65feMjoX93b /bToFTVtHjrJiMS3qpoEx6R9IX5JNkK1X3HBhpOg9K1wLKyDtcPdud5Pxpu8d80cDhkD +OW4Mw1l4eAlKCFDX4mTuvYwqnxtl0r6ZW4edbMTKJQ2y4g1w3cYm05o9fIRMUiJXvpT mxeAXAmSsi15VFic9KtI/gmAK+z9CyQSKmMOi0msY60AHmM1UJ1aHsggQrnGdzUucLIW uw7g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature; bh=ygaQ/46D8dGQ52VSi/XMDPuo6obEX8tZiKmv9YWb3M4=; b=mHtk6k0axIvZ5f1FPNbRrZw7sKHF1mboX2uNuz1mDp53uOtO6Ge+CCtzU1oOyGQIGs k+DSonRtdGDwH/obZTkF/p4b/huOjzEpjq0vBvq8lNfGIuhV9HXR2Rq9uj66Bj3f3k7F 3WhA0GEqfAJPqiEHPErS6pJwglPRXLs38jXgZvcH0CbPvjjdhaF8vSstrFbxlPbk+JCL jUn+wMkaiHaQzDh6e5RBGsuLwFQU0JfVdYeA1ynsEGVMbeaN+FyPVlhD3T7AiD6VRC8j iU7SMqH4k7pR7HoJJVJEG4FcKmrxdaBH493UWV+oIJph2pkGlQy19v/vHFdy90Aawvqi XDUg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=pACO54zR; 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 h7si20728246otk.86.2020.01.20.05.11.23; Mon, 20 Jan 2020 05:11:35 -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=pACO54zR; 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 S1729163AbgATNKK (ORCPT + 99 others); Mon, 20 Jan 2020 08:10:10 -0500 Received: from mail-wm1-f66.google.com ([209.85.128.66]:40598 "EHLO mail-wm1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726619AbgATNKK (ORCPT ); Mon, 20 Jan 2020 08:10:10 -0500 Received: by mail-wm1-f66.google.com with SMTP id t14so14618076wmi.5; Mon, 20 Jan 2020 05:10:09 -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:in-reply-to:references; bh=ygaQ/46D8dGQ52VSi/XMDPuo6obEX8tZiKmv9YWb3M4=; b=pACO54zR5xoMJzdsrylDNfbu+eXZKS2kWL9dsFO9X+u04NOGXS6afl5nSE0mb/GmGp QzEWMQJvUSzfZ8hTl+8W759mk+KdF7c89eQQXAohBYwTxUtTYEc/b0Bzw455P/letpcD ROgkrVFrYOjevFTw2TT6IsRl+dlg+dprBqitnZKuxucoo0BW8LqHi04yXPigBpkTLnm5 b3gOlVIBI1PgX/hyNmkyBuNgRS61YYUjQbIgVl3RkUYGiHffazKD3lhfKJJcQ4BDhx6c biJ6ywfLjmcUAttSMDyzu7vM2BH9PHpxRISUJBSoTxouEsyYaUEnHa9t/gQZn4jkH7x+ sXIw== 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:in-reply-to :references; bh=ygaQ/46D8dGQ52VSi/XMDPuo6obEX8tZiKmv9YWb3M4=; b=flzW8aFpXfvPdRPUqEOrc1urPmwAARhfeiwmXxvNDtyso/nJlTBePHKwd9LHdLVDIZ Jhkdnar3s5U02c6NIcfTvgDHJMssBhUFhoZLTwqrILeuCqmHBs5HAuUOmDAkkI6viwns YT2bUxcHa2H+Ywsj2ru8xMzNUQVfh+xQfQEgx/T9EMhbnwd8pCsBNbJNrbVhAgazDz7D DOPo39Le6PPyvVGgzLdxbkL6UcpzAv9K8/iRVe5xyRjoip0/0MJqd0xdigx+ebCD2Bqg joEZYT/BpwoNQyY6CnHT/FLcaudxwxLAm9fPzZXgXEgNlC8FBehekLEXoeCLFjizSF4Z RTPQ== X-Gm-Message-State: APjAAAV2OP2QCfmUhI1lcnY9roV4B7jcHO2Dm/a0A51ZxSUFacC/rgeY ToJHp5Hy3QmUVgKj6B9x6Gk= X-Received: by 2002:a1c:49c2:: with SMTP id w185mr18277857wma.138.1579525808359; Mon, 20 Jan 2020 05:10:08 -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.10.04 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 20 Jan 2020 05:10:07 -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 Subject: [PATCH v4 8/8] scsi: ufs: Use UFS device indicated maximum LU number Date: Mon, 20 Jan 2020 14:08:20 +0100 Message-Id: <20200120130820.1737-9-huobean@gmail.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200120130820.1737-1-huobean@gmail.com> References: <20200120130820.1737-1-huobean@gmail.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Bean Huo According to Jedec standard UFS 3.0 and UFS 2.1 Spec, Maximum number of logical units supported by the UFS device is indicated by parameter bMaxNumberLU in Geometry Descriptor. This patch is to delete current hard code macro definition of UFS_UPIU_MAX_GENERAL_LUN, and switch to use device indicated number instead. Reviewed-by: Asutosh Das Reviewed-by: Alim Akhtar Signed-off-by: Bean Huo --- drivers/scsi/ufs/ufs-sysfs.c | 2 +- drivers/scsi/ufs/ufs.h | 12 +++++++++--- drivers/scsi/ufs/ufshcd.c | 4 ++-- 3 files changed, 12 insertions(+), 6 deletions(-) diff --git a/drivers/scsi/ufs/ufs-sysfs.c b/drivers/scsi/ufs/ufs-sysfs.c index 720be3f64be7..dbdf8b01abed 100644 --- a/drivers/scsi/ufs/ufs-sysfs.c +++ b/drivers/scsi/ufs/ufs-sysfs.c @@ -713,7 +713,7 @@ static ssize_t _pname##_show(struct device *dev, \ struct scsi_device *sdev = to_scsi_device(dev); \ struct ufs_hba *hba = shost_priv(sdev->host); \ u8 lun = ufshcd_scsi_to_upiu_lun(sdev->lun); \ - if (!ufs_is_valid_unit_desc_lun(lun)) \ + if (!ufs_is_valid_unit_desc_lun(&hba->dev_info, lun)) \ return -EINVAL; \ return ufs_sysfs_read_desc_param(hba, QUERY_DESC_IDN_##_duname, \ lun, _duname##_DESC_PARAM##_puname, buf, _size); \ diff --git a/drivers/scsi/ufs/ufs.h b/drivers/scsi/ufs/ufs.h index c982bcc94662..dde2eb02f76f 100644 --- a/drivers/scsi/ufs/ufs.h +++ b/drivers/scsi/ufs/ufs.h @@ -63,7 +63,6 @@ #define UFS_UPIU_MAX_UNIT_NUM_ID 0x7F #define UFS_MAX_LUNS (SCSI_W_LUN_BASE + UFS_UPIU_MAX_UNIT_NUM_ID) #define UFS_UPIU_WLUN_ID (1 << 7) -#define UFS_UPIU_MAX_GENERAL_LUN 8 /* Well known logical unit id in LUN field of UPIU */ enum { @@ -539,12 +538,19 @@ struct ufs_dev_info { /** * ufs_is_valid_unit_desc_lun - checks if the given LUN has a unit descriptor + * @dev_info: pointer of instance of struct ufs_dev_info * @lun: LU number to check * @return: true if the lun has a matching unit descriptor, false otherwise */ -static inline bool ufs_is_valid_unit_desc_lun(u8 lun) +static inline bool ufs_is_valid_unit_desc_lun(struct ufs_dev_info *dev_info, + u8 lun) { - return lun == UFS_UPIU_RPMB_WLUN || (lun < UFS_UPIU_MAX_GENERAL_LUN); + if (!dev_info || !dev_info->max_lu_supported) { + pr_err("Max General LU supported by UFS isn't initilized\n"); + return false; + } + + return lun == UFS_UPIU_RPMB_WLUN || (lun < dev_info->max_lu_supported); } #endif /* End of Header */ diff --git a/drivers/scsi/ufs/ufshcd.c b/drivers/scsi/ufs/ufshcd.c index 1d2812ad8742..d7f2465447e0 100644 --- a/drivers/scsi/ufs/ufshcd.c +++ b/drivers/scsi/ufs/ufshcd.c @@ -3270,7 +3270,7 @@ static inline int ufshcd_read_unit_desc_param(struct ufs_hba *hba, * Unit descriptors are only available for general purpose LUs (LUN id * from 0 to 7) and RPMB Well known LU. */ - if (!ufs_is_valid_unit_desc_lun(lun)) + if (!ufs_is_valid_unit_desc_lun(&hba->dev_info, lun)) return -EOPNOTSUPP; return ufshcd_read_desc_param(hba, QUERY_DESC_IDN_UNIT, lun, @@ -4525,7 +4525,7 @@ static int ufshcd_get_lu_wp(struct ufs_hba *hba, * protected so skip reading bLUWriteProtect parameter for * it. For other W-LUs, UNIT DESCRIPTOR is not available. */ - else if (lun >= UFS_UPIU_MAX_GENERAL_LUN) + else if (lun >= hba->dev_info.max_lu_supported) ret = -ENOTSUPP; else ret = ufshcd_read_unit_desc_param(hba, -- 2.17.1