[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH 2/2] Use memcpy/byteswap to translate CDB words


  • To: Tu Dinh <ngoc-tu.dinh@xxxxxxxxxx>, "win-pv-devel@xxxxxxxxxxxxxxxxxxxx" <win-pv-devel@xxxxxxxxxxxxxxxxxxxx>
  • From: Owen Smith <owen.smith@xxxxxxxxxx>
  • Date: Mon, 8 Jun 2026 06:47:48 +0000
  • Accept-language: en-GB, en-US
  • Arc-authentication-results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=citrix.com; dmarc=pass action=none header.from=citrix.com; dkim=pass header.d=citrix.com; arc=none
  • Arc-message-signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=rgXRGE4M+43eW1nVHRZcrimikoHfN7w5e1y4JTxMFsI=; b=cwwptAOVsECi/1eaO9ePYAHrpdIw3pid2W+bLRbB/fU6vZV4mLJ5r2MeIFPxRjtfT+WZpHlJAEN5yKe/yhf5eHP4EbPyoTqxMUw92qvo+++/KN7C3Hdvwb7oum5nMQvmafQmFnVkR0rX4tYoMkX+c2Ty6Oa/mvs5sh+qgCULFrd2QkUguEp9WqjDZB2Ee+YsZCurRN4z39p8hlCwP6vVihH7uem9EuZMXDuzKIZm7UEwzk86auWbI47lei8TBcqERAnvBxztzPSRdU1ijDtgb7X0JG8qNAW3j5aZBNCqZPO3kklp8SgzJuUx+ioi4r562InPhDPmPWivLlqj/g1pqw==
  • Arc-seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=jvAUOz2NyFT848wv6SKPMXwiiuqnYixNG+jpDCWEgX9MiFmmIc4kRZGZAwhTxv53Nc7P6KCbj07JrQqFM/6+AV2zv/JN38mnYUdOqeq46+SCsw64AKBMgwU0y8VpPu8RkyvkkH+iRSC44lOyz6Gp9vU8RdthMc+Cpc8lO9tmG1Zdm0oUgQusWhshR7M+E98/pSN1plRN+UHSAsUqal4PurAdth/jmeKr5mS97qE+5zLR/nb4pjeqjcRXluQ9shqfKU6Q7X7j+SqNQeaJ2iZheesMUvldKdmlt4hY4IFSDJlsU5Rh9AYKaBf2aUvuOQQ7M0S1jgp8a0XjJba3tRurMQ==
  • Authentication-results: eu.smtp.expurgate.cloud; dkim=pass header.s=selector1 header.d=citrix.com header.i="@citrix.com" header.h="From:Date:Subject:Message-ID:Content-Type:MIME-Version:x-ms-exchange-senderadcheck"
  • Authentication-results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=citrix.com;
  • Delivery-date: Mon, 08 Jun 2026 06:47:55 +0000
  • List-id: Developer list for the Windows PV Drivers subproject <win-pv-devel.lists.xenproject.org>
  • Msip_labels:
  • Thread-index: AQHc1unOb48VeSJmmU+ZoufZufjYuLY0d4V3
  • Thread-topic: [PATCH 2/2] Use memcpy/byteswap to translate CDB words

Reviewed-by: Owen Smith <owen.smith@xxxxxxxxxx>

________________________________________
From: Tu Dinh <ngoc-tu.dinh@xxxxxxxxxx>
Sent: 28 April 2026 9:33 AM
To: win-pv-devel@xxxxxxxxxxxxxxxxxxxx
Cc: Tu Dinh; Owen Smith
Subject: [PATCH 2/2] Use memcpy/byteswap to translate CDB words

MSVC cannot optimize manual byte concatenation.

Signed-off-by: Tu Dinh <ngoc-tu.dinh@xxxxxxxxxx>
---
 include/xencdb.h | 21 ++++++++++++++-------
 1 file changed, 14 insertions(+), 7 deletions(-)

diff --git a/include/xencdb.h b/include/xencdb.h
index 594e9fe..ae19f09 100644
--- a/include/xencdb.h
+++ b/include/xencdb.h
@@ -33,24 +33,31 @@
 #ifndef XENCDB_H
 #define XENCDB_H

+#include <intrin.h>
+
 #define XENCDB_SCSIOP_INVALID 0xFF

 FORCEINLINE USHORT Cdb_get_big_endian_word(const UCHAR src[2])
 {
-    return src[1] | ((USHORT)src[0] << 8);
+    USHORT      Result;
+
+    memcpy(&Result, src, 2);
+    return _byteswap_ushort(Result);
 }
 FORCEINLINE ULONG Cdb_get_big_endian_dword(const UCHAR src[4])
 {
-    return src[3] | ((ULONG)src[2] << 8) | ((ULONG)src[1] << 16) |
-            ((ULONG)src[0] << 24);
+    ULONG       Result;
+
+    memcpy(&Result, src, 4);
+    return _byteswap_ulong(Result);
 }

 FORCEINLINE ULONG64 Cdb_get_big_endian_qword(const UCHAR src[8])
 {
-    return src[7] | ((ULONG64)src[6] << 8) | ((ULONG64)src[5] << 16) |
-        ((ULONG64)src[4] << 24) | ((ULONG64)src[3] << 32) |
-        ((ULONG64)src[2] << 40) | ((ULONG64)src[1] << 48) |
-        ((ULONG64)src[0] << 56);
+    ULONG64     Result;
+
+    memcpy(&Result, src, 8);
+    return _byteswap_uint64(Result);
 }

 FORCEINLINE UCHAR Cdb_CheckLen6(UCHAR op)
--
2.53.0.windows.2



--
Ngoc Tu Dinh | Vates XCP-ng Developer

XCP-ng & Xen Orchestra - Vates solutions

web: https://vates.tech



 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.