From nobody Mon May 12 09:36:32 2025
Delivered-To: importer@patchew.org
Authentication-Results: mx.zohomail.com;
	dkim=pass;
	spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as
 permitted sender)
  smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org;
	dmarc=pass(p=none dis=none)  header.from=samsung.com
ARC-Seal: i=1; a=rsa-sha256; t=1738652462; cv=none;
	d=zohomail.com; s=zohoarc;
	b=MpsMnMnOmUTSldILUA4+p62RSsV7Ef0LANoUCpY1k3IL/rsSYeRbJmQSjab5k1NlUw/rXISTiZdcA22DEHiaUT5xJ+jL9ezUI0sIvYwjsDH6wXOz727EQWCC9cuZ0JjTZxwxP83fi3VfHmV5JYsqoZacJG1mvzwh9JlPWxP+v4M=
ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com;
 s=zohoarc;
	t=1738652462;
 h=Content-Type:Content-Transfer-Encoding:Cc:Cc:Date:Date:From:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:Subject:To:To:Message-Id:Reply-To;
	bh=7eYVIhQTCURr+8LboGawPPUEnkFdSlOJyIkhWcu6ITw=;
	b=Pn6/fqucyCXz0HjnCKDNuZhF4MCu8Rv/0Bqv2NH6Z06LOnlN/Zke5l6qETvIrbLzsCxF3YwyEG7Y01kxHvviiw9sQKb4U3uhCba9ecpY2Rs79o/ZGFcIaiGaq2h3tWpdErj2dQrzXHWE5nwdalzV26JT0Wn6tVF7LBqMt0/KGjk=
ARC-Authentication-Results: i=1; mx.zohomail.com;
	dkim=pass;
	spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as
 permitted sender)
  smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org;
	dmarc=pass header.from=<arpit1.kumar@samsung.com> (p=none dis=none)
Return-Path: <qemu-devel-bounces+importer=patchew.org@nongnu.org>
Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by
 mx.zohomail.com
	with SMTPS id 1738652462243303.3634337100689;
 Mon, 3 Feb 2025 23:01:02 -0800 (PST)
Received: from localhost ([::1] helo=lists1p.gnu.org)
	by lists.gnu.org with esmtp (Exim 4.90_1)
	(envelope-from <qemu-devel-bounces@nongnu.org>)
	id 1tfCvY-0001dR-LO; Tue, 04 Feb 2025 02:00:56 -0500
Received: from eggs.gnu.org ([2001:470:142:3::10])
 by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256)
 (Exim 4.90_1) (envelope-from <arpit1.kumar@samsung.com>)
 id 1tfCBQ-0001BJ-0f
 for qemu-devel@nongnu.org; Tue, 04 Feb 2025 01:13:16 -0500
Received: from mailout1.samsung.com ([203.254.224.24])
 by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256)
 (Exim 4.90_1) (envelope-from <arpit1.kumar@samsung.com>)
 id 1tfCBM-0002CM-Hi
 for qemu-devel@nongnu.org; Tue, 04 Feb 2025 01:13:15 -0500
Received: from epcas5p3.samsung.com (unknown [182.195.41.41])
 by mailout1.samsung.com (KnoxPortal) with ESMTP id
 20250204061304epoutp01fa2da3b00dd68c77adb0037b097ae1bf~g7JXE1IPJ2289422894epoutp01p
 for <qemu-devel@nongnu.org>; Tue,  4 Feb 2025 06:13:04 +0000 (GMT)
Received: from epsnrtp3.localdomain (unknown [182.195.42.164]) by
 epcas5p3.samsung.com (KnoxPortal) with ESMTP id
 20250204061303epcas5p3840ec0f71d38af2ce71803577354bb7a~g7JWsAmYj1750617506epcas5p3O;
 Tue,  4 Feb 2025 06:13:03 +0000 (GMT)
Received: from epsmges5p3new.samsung.com (unknown [182.195.38.176]) by
 epsnrtp3.localdomain (Postfix) with ESMTP id 4YnCht2BdKz4x9Q7; Tue,  4 Feb
 2025 06:13:02 +0000 (GMT)
Received: from epcas5p4.samsung.com ( [182.195.41.42]) by
 epsmges5p3new.samsung.com (Symantec Messaging Gateway) with SMTP id
 5C.0E.19956.AEFA1A76; Tue,  4 Feb 2025 15:12:58 +0900 (KST)
Received: from epsmtrp1.samsung.com (unknown [182.195.40.13]) by
 epcas5p3.samsung.com (KnoxPortal) with ESMTPA id
 20250203060051epcas5p350b7b24d3b5fcff25bc30e1acccd8121~gnVan4Oz53204032040epcas5p3H;
 Mon,  3 Feb 2025 06:00:51 +0000 (GMT)
Received: from epsmgmc1p1new.samsung.com (unknown [182.195.42.40]) by
 epsmtrp1.samsung.com (KnoxPortal) with ESMTP id
 20250203060051epsmtrp1bfca7cc2e321ba22f951ef352dbf8259~gnVanBq-U2496624966epsmtrp1a;
 Mon,  3 Feb 2025 06:00:51 +0000 (GMT)
Received: from epsmtip2.samsung.com ( [182.195.34.31]) by
 epsmgmc1p1new.samsung.com (Symantec Messaging Gateway) with SMTP id
 81.EE.23488.39B50A76; Mon,  3 Feb 2025 15:00:51 +0900 (KST)
Received: from test-PowerEdge-R740xd.samsungds.net (unknown [107.99.41.79])
 by epsmtip2.samsung.com (KnoxPortal) with ESMTPA id
 20250203060050epsmtip2bb19ad36dfd182998c65f041ba376d93~gnVZMqGT42702127021epsmtip21;
 Mon,  3 Feb 2025 06:00:50 +0000 (GMT)
DKIM-Filter: OpenDKIM Filter v2.11.0 mailout1.samsung.com
 20250204061304epoutp01fa2da3b00dd68c77adb0037b097ae1bf~g7JXE1IPJ2289422894epoutp01p
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=samsung.com;
 s=mail20170921; t=1738649584;
 bh=7eYVIhQTCURr+8LboGawPPUEnkFdSlOJyIkhWcu6ITw=;
 h=From:To:Cc:Subject:Date:In-Reply-To:References:From;
 b=S8e3+24RyJkZ7SiY8hLHhDofgGAHjA0pq+AoIATrDcChRjdZ+OnYzH0mIhXRdJrT6
 +trs0MjhL02Yq1hjURTvRNNJ32kyT561264z0T1IGiZnwVoJehEqWcaEHLTqgC+fAQ
 OLLc4oH7NAGbAyl/glICp5bf7CI7ljGdwXXgCOCE=
X-AuditID: b6c32a4b-fd1f170000004df4-63-67a1afea1792
From: Arpit Kumar <arpit1.kumar@samsung.com>
To: qemu-devel@nongnu.org
Cc: gost.dev@samsung.com, linux-cxl@vger.kernel.org, nifan.cxl@gmail.com,
 dave@stgolabs.net, vishak.g@samsung.com, krish.reddy@samsung.com,
 a.manzanares@samsung.com, alok.rathore@samsung.com, Arpit Kumar
 <arpit1.kumar@samsung.com>
Subject: [PATCH 1/3] hw/cxl/cxl-mailbox-utils.c: Added support for Get Log
 Capabilities (Opcode 0402h)
Date: Mon,  3 Feb 2025 11:29:48 +0530
Message-Id: <20250203055950.2126627-2-arpit1.kumar@samsung.com>
X-Mailer: git-send-email 2.34.1
In-Reply-To: <20250203055950.2126627-1-arpit1.kumar@samsung.com>
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
X-Brightmail-Tracker: 
 H4sIAAAAAAAAA+NgFprDJsWRmVeSWpSXmKPExsWy7bCmlu6r9QvTDXoPqltMP6xo8eX0HjaL
 3sVLWC1W31zDaHHzwE4mi4UblzFZnJ91isXi77a9jBbHe3ewALlz2B24PHbOusvu8eTaZiaP
 vi2rGD2mzq73+LxJLoA1KtsmIzUxJbVIITUvOT8lMy/dVsk7ON453tTMwFDX0NLCXEkhLzE3
 1VbJxSdA1y0zB+gmJYWyxJxSoFBAYnGxkr6dTVF+aUmqQkZ+cYmtUmpBSk6BSYFecWJucWle
 ul5eaomVoYGBkSlQYUJ2xuP9O5gKpulUzFi2k6mBcZVCFyMnh4SAicSq/x1sILaQwG5GiUtr
 dbsYuYDsT4wSFw6vZ4FwvjFK/PlzjamLkQOs48RHqPheRokz3RdYIZwGJolthyeBjWIT0JE4
 f3sumC0iICnxu+s0M0gRs8AbRokHVxcwgySEBTIkOu+3MoLYLAKqEquPHmIBsXkF7CUmvbzJ
 BnGfvMT+g2fB6jkFHCR+bL7JClEjKHFy5hOwemagmuats5kh6v+ySzz7Lw5hu0hc/9MOFReW
 eHV8CzuELSXxsr8Nys6W+DO/HWpXgcSinzOh4vYSraf6mUE+ZhbQlFi/Sx8iLCsx9dQ6Joi1
 fBK9v58wQcR5JXbMg7HVJNp3zIcaIyPx5tdiqPEeEvfmzGWGBNZkRomFL4+wTmBUmIXknVlI
 3pmFsHoBI/MqRsnUguLc9NRi0wLjvNRyeCQn5+duYgQnUy3vHYyPHnzQO8TIxMF4iFGCg1lJ
 hPf09gXpQrwpiZVVqUX58UWlOanFhxhNgeE9kVlKNDkfmM7zSuINTSwNTMzMzEwsjc0MlcR5
 m3e2pAsJpCeWpGanphakFsH0MXFwSjUw2aw/6LflyIobSxlcTt/atsaof83Ls5kWU3tWnrA8
 MEPlzXLe/ZlPrHX53AqVkt+0OwdHhO77rqs4beK78uKe7r+ncjcZfTHx1JdxfCudcdNc0eCj
 8wMnUb64sHibqAcam5aY/J13pnpq+uZVkVYvnv+2f8hRc+lVQfrFi8zv+Rawh247M6emLDTM
 Rn+rf8Lvu1kLmS7LVbgsfHHndWjU9Pj0/9zHk25lpCdOcZS/drL/wzWFz0Fy6kJz82bZnl58
 KX1JX/MH88Ntk0wmHxTLFbxvec3V+FGyuNur3Sx5ugJTd27Yr1C/8GHih7Md611UK0W31Hot
 +sD6IivrVSfHVr5fW9UUl77aEfe4PN9fR4mlOCPRUIu5qDgRAJ/DqJovBAAA
X-Brightmail-Tracker: 
 H4sIAAAAAAAAA+NgFrrCLMWRmVeSWpSXmKPExsWy7bCSvO7k6AXpBlO/q1hMP6xo8eX0HjaL
 3sVLWC1W31zDaHHzwE4mi4UblzFZnJ91isXi77a9jBbHe3ewALlz2B24PHbOusvu8eTaZiaP
 vi2rGD2mzq73+LxJLoA1issmJTUnsyy1SN8ugSvj8f4dTAXTdCpmLNvJ1MC4SqGLkYNDQsBE
 4sRHli5GLg4hgd2MErs2bWTsYuQEistIXJz5mAXCFpZY+e85O0TRP0aJf5v+s4Ek2AR0JM7f
 ngtmiwhISvzuOs0MUsQs8I1RYs6tF6wgCWGBNInOGRfZQWwWAVWJ1UcPgU3lFbCXmPTyJhvE
 BnmJ/QfPMoPYnAIOEj823wTrFQKqOd9+hAmiXlDi5MwnYL3MQPXNW2czT2AUmIUkNQtJagEj
 0ypGydSC4tz03GTDAsO81HK94sTc4tK8dL3k/NxNjOCA19LYwfjuW5P+IUYmDsZDjBIczEoi
 vByH56QL8aYkVlalFuXHF5XmpBYfYpTmYFES511pGJEuJJCeWJKanZpakFoEk2Xi4JRqYAp3
 YdZpcF0yqe3VdN+/h1XVjl75e/F5iF7shBVzvBgyk75t+D+7nnOthlDQYt/Q0w47j/XfW9qy
 xGDFu6D9kco3YkTiLWU+mRXoKIhM405aej7r3KbbIp8+cp1ue1dSrZP9vULPsFVKr+5ofkG0
 n9vZdQ0bF2XPfqXIuWSVxfz/Aol3pn0Pb2dnMpzQM8+C8ZeFWfiP35dYRKPOiW9ufh9q6rno
 085z5w+6V3mzXr7w29b3vuuSE77skdJT4l/EabToW0hHz3t1KZSj79FDw1txwulinjYnHCI+
 XPWYaLXwNmuUjm+HYzmTsf/93KoKD36WWefXOy59y3ExX1BFOGl/wL3mG9Xas9pTBS79UmIp
 zkg01GIuKk4EAK65lk/nAgAA
X-CMS-MailID: 20250203060051epcas5p350b7b24d3b5fcff25bc30e1acccd8121
X-Msg-Generator: CA
Content-Type: text/plain; charset="utf-8"
X-Sendblock-Type: REQ_APPROVE
CMS-TYPE: 105P
DLP-Filter: Pass
X-CFilter-Loop: Reflected
X-CMS-RootMailID: 20250203060051epcas5p350b7b24d3b5fcff25bc30e1acccd8121
References: <20250203055950.2126627-1-arpit1.kumar@samsung.com>
 <CGME20250203060051epcas5p350b7b24d3b5fcff25bc30e1acccd8121@epcas5p3.samsung.com>
Received-SPF: pass (zohomail.com: domain of gnu.org designates 209.51.188.17
 as permitted sender) client-ip=209.51.188.17;
 envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org;
 helo=lists.gnu.org;
Received-SPF: pass client-ip=203.254.224.24;
 envelope-from=arpit1.kumar@samsung.com; helo=mailout1.samsung.com
X-Spam_score_int: -43
X-Spam_score: -4.4
X-Spam_bar: ----
X-Spam_report: (-4.4 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.001,
 DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1,
 RCVD_IN_DNSWL_MED=-2.3, RCVD_IN_MSPIKE_H3=0.001, RCVD_IN_MSPIKE_WL=0.001,
 RCVD_IN_VALIDITY_RPBL_BLOCKED=0.001, RCVD_IN_VALIDITY_SAFE_BLOCKED=0.001,
 SPF_HELO_PASS=-0.001, SPF_PASS=-0.001 autolearn=ham autolearn_force=no
X-Spam_action: no action
X-Mailman-Approved-At: Tue, 04 Feb 2025 02:00:23 -0500
X-BeenThere: qemu-devel@nongnu.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: <qemu-devel.nongnu.org>
List-Unsubscribe: <https://lists.nongnu.org/mailman/options/qemu-devel>,
 <mailto:qemu-devel-request@nongnu.org?subject=unsubscribe>
List-Archive: <https://lists.nongnu.org/archive/html/qemu-devel>
List-Post: <mailto:qemu-devel@nongnu.org>
List-Help: <mailto:qemu-devel-request@nongnu.org?subject=help>
List-Subscribe: <https://lists.nongnu.org/mailman/listinfo/qemu-devel>,
 <mailto:qemu-devel-request@nongnu.org?subject=subscribe>
Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org
Sender: qemu-devel-bounces+importer=patchew.org@nongnu.org
X-ZohoMail-DKIM: pass (identity @samsung.com)
X-ZM-MESSAGEID: 1738652465337019100

Signed-off-by: Arpit Kumar <arpit1.kumar@samsung.com>
Reviewed-by: Alok Rathore <alok.rathore@samsung.com>
Reviewed-by: Krishna Kanth Reddy <krish.reddy@samsung.com>
---
 hw/cxl/cxl-mailbox-utils.c   | 55 ++++++++++++++++++++++++++++++++++++
 include/hw/cxl/cxl_device.h  | 31 ++++++++++++++++++++
 include/hw/cxl/cxl_mailbox.h |  5 ++++
 3 files changed, 91 insertions(+)

diff --git a/hw/cxl/cxl-mailbox-utils.c b/hw/cxl/cxl-mailbox-utils.c
index 9c7ea5bc35..3d66a425a9 100644
--- a/hw/cxl/cxl-mailbox-utils.c
+++ b/hw/cxl/cxl-mailbox-utils.c
@@ -76,6 +76,7 @@ enum {
     LOGS        =3D 0x04,
         #define GET_SUPPORTED 0x0
         #define GET_LOG       0x1
+        #define GET_LOG_CAPABILITIES   0x2
     FEATURES    =3D 0x05,
         #define GET_SUPPORTED 0x0
         #define GET_FEATURE   0x1
@@ -1075,6 +1076,45 @@ static CXLRetCode cmd_logs_get_log(const struct cxl_=
cmd *cmd,
     return CXL_MBOX_SUCCESS;
 }
=20
+static int32_t valid_log_check(QemuUUID *uuid, CXLCCI *cci)
+{
+    int32_t id =3D -1;
+    for (int i =3D CEL; i < MAX_LOG_TYPE; i++) {
+        if (qemu_uuid_is_equal(uuid,
+            &cci->supported_log_cap[i].uuid)) {
+            id =3D i;
+            break;
+        }
+    }
+    return id;
+}
+
+/* CXL r3.1 Section 8.2.9.5.3: Get Log Capabilities (Opcode 0402h) */
+static CXLRetCode cmd_logs_get_log_capabilities(const struct cxl_cmd *cmd,
+                                                uint8_t *payload_in,
+                                                size_t len_in,
+                                                uint8_t *payload_out,
+                                                size_t *len_out,
+                                                CXLCCI *cci)
+{
+    int32_t cap_id;
+    struct {
+        QemuUUID uuid;
+    } QEMU_PACKED QEMU_ALIGNED(8) * get_log_capabilities_in =3D (void *)pa=
yload_in;
+
+    CXLParamFlags *get_log_capabilities_out =3D (void *)payload_out;
+
+    cap_id =3D valid_log_check(&get_log_capabilities_in->uuid, cci);
+    if (cap_id =3D=3D -1) {
+        return CXL_MBOX_INVALID_LOG;
+    }
+
+    memcpy(get_log_capabilities_out, &cci->supported_log_cap[cap_id].param=
_flags.pflags,
+           sizeof(CXLParamFlags));
+    *len_out =3D sizeof(*get_log_capabilities_out);
+    return CXL_MBOX_SUCCESS;
+}
+
 /* CXL r3.1 section 8.2.9.6: Features */
 /*
  * Get Supported Features output payload
@@ -2840,6 +2880,8 @@ static const struct cxl_cmd cxl_cmd_set[256][256] =3D=
 {
     [LOGS][GET_SUPPORTED] =3D { "LOGS_GET_SUPPORTED", cmd_logs_get_support=
ed,
                               0, 0 },
     [LOGS][GET_LOG] =3D { "LOGS_GET_LOG", cmd_logs_get_log, 0x18, 0 },
+    [LOGS][GET_LOG_CAPABILITIES] =3D { "LOGS_GET_LOG_CAPABILITIES",
+                                     cmd_logs_get_log_capabilities, 0x10, =
0 },
     [FEATURES][GET_SUPPORTED] =3D { "FEATURES_GET_SUPPORTED",
                                   cmd_features_get_supported, 0x8, 0 },
     [FEATURES][GET_FEATURE] =3D { "FEATURES_GET_FEATURE",
@@ -3084,10 +3126,23 @@ static void cxl_rebuild_cel(CXLCCI *cci)
     }
 }
=20
+static const struct CXLLogCapabilities cxl_get_log_cap[MAX_LOG_TYPE] =3D {
+    [CEL] =3D {.param_flags.pflags =3D CXL_LOG_CAP_CLEAR | CXL_LOG_CAP_POP=
ULATE,
+             .uuid =3D cel_uuid},
+};
+
+static void cxl_init_get_log(CXLCCI *cci)
+{
+    for (int set =3D CEL; set < MAX_LOG_TYPE; set++) {
+        cci->supported_log_cap[set] =3D cxl_get_log_cap[set];
+    }
+}
+
 void cxl_init_cci(CXLCCI *cci, size_t payload_max)
 {
     cci->payload_max =3D payload_max;
     cxl_rebuild_cel(cci);
+    cxl_init_get_log(cci);
=20
     cci->bg.complete_pct =3D 0;
     cci->bg.starttime =3D 0;
diff --git a/include/hw/cxl/cxl_device.h b/include/hw/cxl/cxl_device.h
index a64739be25..e7cb99a1d2 100644
--- a/include/hw/cxl/cxl_device.h
+++ b/include/hw/cxl/cxl_device.h
@@ -164,6 +164,18 @@ typedef enum {
     CXL_MBOX_MAX =3D 0x20
 } CXLRetCode;
=20
+/* types of logs */
+enum Logs {
+    CEL,
+    VDL,
+    CSDL,
+    ECSL,
+    MTCL,
+    MTRSL,
+    MTRLL,
+    MAX_LOG_TYPE
+};
+
 typedef struct CXLCCI CXLCCI;
 typedef struct cxl_device_state CXLDeviceState;
 struct cxl_cmd;
@@ -194,6 +206,22 @@ typedef struct CXLEventLog {
     QSIMPLEQ_HEAD(, CXLEvent) events;
 } CXLEventLog;
=20
+typedef struct CXLParamFlags {
+    union {
+        uint32_t clear_log_supported:1;
+        uint32_t populate_log_supported:1;
+        uint32_t auto_populate_supported:1;
+        uint32_t persistent_across_cold_reset:1;
+        uint32_t reserved:28;
+        uint32_t pflags;
+    };
+} CXLParamFlags;
+
+typedef struct CXLLogCapabilities {
+    CXLParamFlags param_flags;
+    QemuUUID uuid;
+} CXLLogCapabilities;
+
 typedef struct CXLCCI {
     struct cxl_cmd cxl_cmd_set[256][256];
     struct cel_log {
@@ -202,6 +230,9 @@ typedef struct CXLCCI {
     } cel_log[1 << 16];
     size_t cel_size;
=20
+    /* get log capabilities */
+    CXLLogCapabilities supported_log_cap[MAX_LOG_TYPE];
+
     /* background command handling (times in ms) */
     struct {
         uint16_t opcode;
diff --git a/include/hw/cxl/cxl_mailbox.h b/include/hw/cxl/cxl_mailbox.h
index 9008402d1c..f3502c3f68 100644
--- a/include/hw/cxl/cxl_mailbox.h
+++ b/include/hw/cxl/cxl_mailbox.h
@@ -16,4 +16,9 @@
 #define CXL_MBOX_BACKGROUND_OPERATION (1 << 6)
 #define CXL_MBOX_BACKGROUND_OPERATION_ABORT (1 << 7)
=20
+#define CXL_LOG_CAP_CLEAR 1
+#define CXL_LOG_CAP_POPULATE (1 << 1)
+#define CXL_LOG_CAP_AUTO_POPULATE (1 << 2)
+#define CXL_LOG_CAP_PERSISTENT_COLD_RESET (1 << 3)
+
 #endif
--=20
2.34.1