From patchwork Sun Nov 20 19:49:28 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Bean Huo X-Patchwork-Id: 23441 Return-Path: Delivered-To: ouuuleilei@gmail.com Received: by 2002:adf:f944:0:0:0:0:0 with SMTP id q4csp1245537wrr; Sun, 20 Nov 2022 11:52:22 -0800 (PST) X-Google-Smtp-Source: AA0mqf5SsG1ry9lahczA6BeFj5WxpdPMehh6fZhM86HvNJWieaL3H2uOnjBVH9QhLa+j7tNHElIA X-Received: by 2002:a05:6402:40c:b0:461:c894:f6b5 with SMTP id q12-20020a056402040c00b00461c894f6b5mr13809494edv.52.1668973942443; Sun, 20 Nov 2022 11:52:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1668973942; cv=none; d=google.com; s=arc-20160816; b=OF+vNUBW6jFZnHtQtSs4NIbSdEKpX5OWjh5iiggJd7zBItJYnNgOroFEekQsR2IOTb vXk+pPJedrHd4PWuKYwuMrUD2ZKED/r/9H2afQT9e80HhxaMiH+vfhE51bnOqemwKjr2 Nlazxid34cIv+E2IsSXncoRHYs0Jmh93IKmFH+WrMvLsZkILCquRzB/rNUl7qmDHgA7T lavhDkTkqxOT1tKK7vKaz1NKNMyZBs6WnpdPc6Fh4Scg963WmCx/UfNry1U6R9X10B5/ 2Sis9HEE6SbYfW6uT1Gb/BCrz4O3XMurrf0mA3Ant4rRTB8gKt1HxlS8tIHSMeWQuxml D58w== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=E8p70nvSesLfndCY1xjueUyWPXUe3zm6EYO0Xs9t1IM=; b=nTRle8rbd54M2bxyHjGbEusrs6ihMsv6NsVEGTYJuHwKvPrw06s8uqAS+jC40E6YNq 3V3+jmPD1sxehhyFNtQk+Q8jevoiqEiy3CCjxImWYIVgBzBPWtsXMaYcXGK3a2gw2qni bSGwkKlbMolc/Kh0xOIhmq5OhTHSmds0YrqC79CzXkMNGjr2cMJeHNPcxegoEsOELf+z 4lNIA/4yHS2flBJ+E39wyj411qFblkl7dsBQYAkMPqV09Zkquadf0OBDU6pNJQcn6c1Z vUs/FYcR6OG44KbiZEECb8bvp94GTnyEv4Gzx9gtBeGq5uKiUmQ4LvOMSmnr6T6IDel8 YUqg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@iokpp.de header.s=strato-dkim-0002 header.b=qbKXNCHN; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id gs40-20020a1709072d2800b0077b21283d09si8799019ejc.349.2022.11.20.11.51.52; Sun, 20 Nov 2022 11:52:22 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@iokpp.de header.s=strato-dkim-0002 header.b=qbKXNCHN; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229754AbiKTTtx (ORCPT + 99 others); Sun, 20 Nov 2022 14:49:53 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47332 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229709AbiKTTtq (ORCPT ); Sun, 20 Nov 2022 14:49:46 -0500 Received: from mo4-p03-ob.smtp.rzone.de (mo4-p03-ob.smtp.rzone.de [85.215.255.102]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3FFDA2E9CB; Sun, 20 Nov 2022 11:49:43 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; t=1668973779; s=strato-dkim-0002; d=iokpp.de; h=References:In-Reply-To:Message-Id:Date:Subject:Cc:To:From:Cc:Date: From:Subject:Sender; bh=E8p70nvSesLfndCY1xjueUyWPXUe3zm6EYO0Xs9t1IM=; b=qbKXNCHNXRdYe4oeC27WQZ5hSrEU1zXkl1Fyt7BrDKvVaGS+1VTQGQ+AIa4qw/Oi+L 6HLKIfP1ONvUkPkBP3ZFQ6WLoeyXvfgcpBimPWzZkPDOZw1hfj3lAK5JPcA+5NsGIijk Ii+4blj1I3d+OuRZxL0rPi5/yPddAWY/mN6/eIljQzeitC7FqYoJwxuu8SRp9oQodv1E L1VPVNpNLgZHEc5gMRVv23eSPfn1AE9mfUD7aIR0DNiijf120hskGg4EVG2jdtthbWVa XYXjDHoorCFtfalJ835iMqgKTJrlEa5GvX6nUOmCTYsrC4Gj2uWcUg0lkG2YCAbkzQml 8i/A== Authentication-Results: strato.com; dkim=none X-RZG-AUTH: ":LmkFe0i9dN8c2t4QQyGBB/NDXvjDB6pBSedrgBzPc9DUyubU4DD1QLj68UeUr1+U1RvWtIfZ/7Q8ZGqEBlwxF4QH61wYa9UK/y81Dg==" X-RZG-CLASS-ID: mo02 Received: from blinux.speedport.ip by smtp.strato.de (RZmta 48.2.1 AUTH) with ESMTPSA id z9cfbfyAKJndWNZ (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256 bits)) (Client did not present a certificate); Sun, 20 Nov 2022 20:49:39 +0100 (CET) From: Bean Huo To: alim.akhtar@samsung.com, avri.altman@wdc.com, jejb@linux.ibm.com, martin.petersen@oracle.com, stanley.chu@mediatek.com, beanhuo@micron.com, bvanassche@acm.org, tomas.winkler@intel.com, daejun7.park@samsung.com, quic_cang@quicinc.com, quic_nguyenb@quicinc.com, quic_xiaosenh@quicinc.com, quic_richardp@quicinc.com, quic_asutoshd@quicinc.com, hare@suse.de Cc: linux-scsi@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v1 4/6] ufs: core: Advanced RPMB detection Date: Sun, 20 Nov 2022 20:49:28 +0100 Message-Id: <20221120194930.90283-5-beanhuo@iokpp.de> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20221120194930.90283-1-beanhuo@iokpp.de> References: <20221120194930.90283-1-beanhuo@iokpp.de> MIME-Version: 1.0 X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_PASS,SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1750046020529872752?= X-GMAIL-MSGID: =?utf-8?q?1750046020529872752?= From: Bean Huo Check UFS Advanced RPMB LU enablement during ufshcd_lu_init(). Signed-off-by: Bean Huo --- drivers/ufs/core/ufshcd.c | 6 ++++++ include/ufs/ufs.h | 24 ++++++++++++++++++++++++ 2 files changed, 30 insertions(+) diff --git a/drivers/ufs/core/ufshcd.c b/drivers/ufs/core/ufshcd.c index 1b252e6cf93f..311172578fd8 100644 --- a/drivers/ufs/core/ufshcd.c +++ b/drivers/ufs/core/ufshcd.c @@ -4956,6 +4956,12 @@ static void ufshcd_lu_init(struct ufs_hba *hba, struct scsi_device *sdev) desc_buf[UNIT_DESC_PARAM_LU_WR_PROTECT] == UFS_LU_POWER_ON_WP) hba->dev_info.is_lu_power_on_wp = true; + /* In case of RPMB LU, check if advanced RPMB mode is enabled */ + if (desc_buf[UNIT_DESC_PARAM_UNIT_INDEX] == UFS_UPIU_RPMB_WLUN && + desc_buf[RPMB_UNIT_DESC_PARAM_REGION_EN] & BIT(4)) + hba->dev_info.b_advanced_rpmb_en = true; + + kfree(desc_buf); set_qdepth: /* diff --git a/include/ufs/ufs.h b/include/ufs/ufs.h index 1bba3fead2ce..17e401df674c 100644 --- a/include/ufs/ufs.h +++ b/include/ufs/ufs.h @@ -212,6 +212,28 @@ enum unit_desc_param { UNIT_DESC_PARAM_WB_BUF_ALLOC_UNITS = 0x29, }; +/* RPMB Unit descriptor parameters offsets in bytes*/ +enum rpmb_unit_desc_param { + RPMB_UNIT_DESC_PARAM_LEN = 0x0, + RPMB_UNIT_DESC_PARAM_TYPE = 0x1, + RPMB_UNIT_DESC_PARAM_UNIT_INDEX = 0x2, + RPMB_UNIT_DESC_PARAM_LU_ENABLE = 0x3, + RPMB_UNIT_DESC_PARAM_BOOT_LUN_ID = 0x4, + RPMB_UNIT_DESC_PARAM_LU_WR_PROTECT = 0x5, + RPMB_UNIT_DESC_PARAM_LU_Q_DEPTH = 0x6, + RPMB_UNIT_DESC_PARAM_PSA_SENSITIVE = 0x7, + RPMB_UNIT_DESC_PARAM_MEM_TYPE = 0x8, + RPMB_UNIT_DESC_PARAM_REGION_EN = 0x9, + RPMB_UNIT_DESC_PARAM_LOGICAL_BLK_SIZE = 0xA, + RPMB_UNIT_DESC_PARAM_LOGICAL_BLK_COUNT = 0xB, + RPMB_UNIT_DESC_PARAM_REGION0_SIZE = 0x13, + RPMB_UNIT_DESC_PARAM_REGION1_SIZE = 0x14, + RPMB_UNIT_DESC_PARAM_REGION2_SIZE = 0x15, + RPMB_UNIT_DESC_PARAM_REGION3_SIZE = 0x16, + RPMB_UNIT_DESC_PARAM_PROVISIONING_TYPE = 0x17, + RPMB_UNIT_DESC_PARAM_PHY_MEM_RSRC_CNT = 0x18, +}; + /* Device descriptor parameters offsets in bytes*/ enum device_desc_param { DEVICE_DESC_PARAM_LEN = 0x0, @@ -601,6 +623,8 @@ struct ufs_dev_info { bool b_rpm_dev_flush_capable; u8 b_presrv_uspc_en; + + bool b_advanced_rpmb_en; }; /*