Received: by 2002:a05:6a10:2785:0:0:0:0 with SMTP id ia5csp2145908pxb; Mon, 11 Jan 2021 02:02:13 -0800 (PST) X-Google-Smtp-Source: ABdhPJyS++2oJ2MfoRT3hbNHsN6CdG6OHdjMf3DkXcyWiNNubJjMK7zRLia+F7N5OOwZ650NySm3 X-Received: by 2002:a50:e719:: with SMTP id a25mr13499320edn.12.1610359332860; Mon, 11 Jan 2021 02:02:12 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1610359332; cv=none; d=google.com; s=arc-20160816; b=nCfvBaQ6FA5mVDuElA4sAE/ItuVQGRLOD/OQrym+chlPlrVFGm2DVB95hdstApdOOn m0z30nvTZx7/Uj7l27dvA0KuDwXhJnsjC6kYScGP0/YEdAod9uFS9wEHu4nrtQ06f/dc 2+CqGdNOGgqgznqNeEAlThW/VW34q7ix8SN7qu/fftHswpTdL/zCZ2KFd6h8SajLG1tN Xe2nSgGfYmppeIc3/DyY7yofaLLTrpNOrniQtS7IaKgmihPRPjOnYuY7gy4XZwS0q+Ix tGmnmlbmCL0NvB8WHDuL665mdStyZwZypSFIqlBo8FIn7aIKnA1rR4g22zKrAshHYDVC esdQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=XhYtFBppZszdNGbZ37IwhJX3BEYSr2pssEbtlokKd60=; b=NGdW1sNdaWq2DJz3oF24pZ0MCzPf+SFZBxw+DeLYTs1h9QYR59v9SVpEeudi01FGX8 TZOOZmvA09D+qR6CsaZRmCftGYttk730JUBxFg4yxRdpkMHJkxMWC6BNXTJq5P1hw7vP gFdGt1jH98e1puMUmyS/CPueBTpqxPiwhruMcpnQ6/zjae0UquvltLYMyxIgEg8BUk6i hGDPGNbUvrbreA83EipQk/aHtqbrpX5vefCmRJu2Bprt9iKGphn/V2ToNnDmNv8cMUkj bSeCtRYEB2hGxU40TePh7duGk39ReQ8WK9BfiVOFDX+XTHyPL4IqjJ50IeHxrhVRyGK/ gvEw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=Sumn3fI6; 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 qk27si6380771ejb.615.2021.01.11.02.01.49; Mon, 11 Jan 2021 02:02:12 -0800 (PST) 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=k20201202 header.b=Sumn3fI6; 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 S1728838AbhAKKAO (ORCPT + 99 others); Mon, 11 Jan 2021 05:00:14 -0500 Received: from mail.kernel.org ([198.145.29.99]:42154 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728773AbhAKKAN (ORCPT ); Mon, 11 Jan 2021 05:00:13 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 314E522288; Mon, 11 Jan 2021 09:59:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1610359173; bh=m+Ij2dBktkSThrVZO1cu0ZmecjHv4ArG21/Sjc4ELbE=; h=From:To:Cc:Subject:Date:From; b=Sumn3fI6nwDJfqbK511YBu2eJjBViZRlp2x2+Br8BXA8vvEPtthXbTMKZTgQQlpbW QNbRczwfo8k1oLrSoQd1gcY0nnwhglZLUamIOlEGItf0xhV5sBlYRHXNTG8EN2w+SZ 5tpiNVfLVODYF38SEKpNZCJJrNpWtvxwG25eBPYRSCOLpg+y5Y88aiviU+6z5bsAOs cjfjUsfD6RzcKhDUAoXoi5crKKssDFWYbqWSUWZzNgeraAr9f85/6+C87H2HcLna1s JgHKdOrVK0vF+rRyxM5z2mPsjsaG19cKWTQwydD5ZZvf8XHLSv3jE07FF3LbuDnVMi rroztWqR3y9YA== From: Jaegeuk Kim To: linux-kernel@vger.kernel.org, linux-scsi@vger.kernel.org, kernel-team@android.com Cc: cang@codeaurora.org, alim.akhtar@samsung.com, avri.altman@wdc.com, bvanassche@acm.org, martin.petersen@oracle.com, stanley.chu@mediatek.com, Jaegeuk Kim , Jaegeuk Kim Subject: [PATCH v3] scsi: ufs: WB is only available on LUN #0 to #7 Date: Mon, 11 Jan 2021 01:59:27 -0800 Message-Id: <20210111095927.1830311-1-jaegeuk@kernel.org> X-Mailer: git-send-email 2.30.0.284.gd98b1dd5eaa7-goog MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Jaegeuk Kim Kernel stack violation when getting unit_descriptor/wb_buf_alloc_units from rpmb lun. The reason is the unit descriptor length is different per LU. The lengh of Normal LU is 45, while the one of rpmb LU is 35. int ufshcd_read_desc_param(struct ufs_hba *hba, ...) { param_offset=41; param_size=4; buff_len=45; ... buff_len=35 by rpmb LU; if (is_kmalloc) { /* Make sure we don't copy more data than available */ if (param_offset + param_size > buff_len) param_size = buff_len - param_offset; --> param_size = 250; memcpy(param_read_buf, &desc_buf[param_offset], param_size); --> memcpy(param_read_buf, desc_buf+41, 250); [ 141.868974][ T9174] Kernel panic - not syncing: stack-protector: Kernel stack is corrupted in: wb_buf_alloc_units_show+0x11c/0x11c } } Signed-off-by: Jaegeuk Kim --- drivers/scsi/ufs/ufs-sysfs.c | 3 ++- drivers/scsi/ufs/ufs.h | 6 ++++-- drivers/scsi/ufs/ufshcd.c | 2 +- 3 files changed, 7 insertions(+), 4 deletions(-) diff --git a/drivers/scsi/ufs/ufs-sysfs.c b/drivers/scsi/ufs/ufs-sysfs.c index 08e72b7eef6a..50e90416262b 100644 --- a/drivers/scsi/ufs/ufs-sysfs.c +++ b/drivers/scsi/ufs/ufs-sysfs.c @@ -792,7 +792,8 @@ 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(&hba->dev_info, lun)) \ + if (!ufs_is_valid_unit_desc_lun(&hba->dev_info, lun, \ + _duname##_DESC_PARAM##_puname)) \ 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 14dfda735adf..580aa56965d0 100644 --- a/drivers/scsi/ufs/ufs.h +++ b/drivers/scsi/ufs/ufs.h @@ -552,13 +552,15 @@ struct ufs_dev_info { * @return: true if the lun has a matching unit descriptor, false otherwise */ static inline bool ufs_is_valid_unit_desc_lun(struct ufs_dev_info *dev_info, - u8 lun) + u8 lun, u8 param_offset) { if (!dev_info || !dev_info->max_lu_supported) { pr_err("Max General LU supported by UFS isn't initialized\n"); return false; } - + /* WB is available only for the logical unit from 0 to 7 */ + if (param_offset == UNIT_DESC_PARAM_WB_BUF_ALLOC_UNITS) + return lun < UFS_UPIU_MAX_WB_LUN_ID; return lun == UFS_UPIU_RPMB_WLUN || (lun < dev_info->max_lu_supported); } diff --git a/drivers/scsi/ufs/ufshcd.c b/drivers/scsi/ufs/ufshcd.c index 2a715f13fe1d..48cbd4f294dd 100644 --- a/drivers/scsi/ufs/ufshcd.c +++ b/drivers/scsi/ufs/ufshcd.c @@ -3425,7 +3425,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(&hba->dev_info, lun)) + if (!ufs_is_valid_unit_desc_lun(&hba->dev_info, lun, param_offset)) return -EOPNOTSUPP; return ufshcd_read_desc_param(hba, QUERY_DESC_IDN_UNIT, lun, -- 2.30.0.284.gd98b1dd5eaa7-goog