public inbox for linux-arm-kernel@lists.infradead.org 
 help / color / mirror / Atom feed
From: Can Guo <can.guo@oss•qualcomm.com>
To: bvanassche@acm•org, beanhuo@micron•com, peter.wang@mediatek•com,
	martin.petersen@oracle•com, mani@kernel•org
Cc: linux-scsi@vger•kernel.org, Can Guo <can.guo@oss•qualcomm.com>,
	Alim Akhtar <alim.akhtar@samsung•com>,
	Avri Altman <avri.altman@wdc•com>, Rob Herring <robh@kernel•org>,
	Krzysztof Kozlowski <krzk+dt@kernel•org>,
	Conor Dooley <conor+dt@kernel•org>,
	Matthias Brugger <matthias.bgg@gmail•com>,
	AngeloGioacchino Del Regno
	<angelogioacchino.delregno@collabora•com>,
	Zhaoming Luo <zhml@posteo•com>,
	Ram Kumar Dwivedi <quic_rdwivedi@quicinc•com>,
	devicetree@vger•kernel.org (open list:OPEN FIRMWARE AND
	FLATTENED DEVICE TREE BINDINGS),
	linux-kernel@vger•kernel.org (open list),
	linux-arm-kernel@lists•infradead.org (moderated
	list:ARM/Mediatek SoC support:Keyword:mediatek),
	linux-mediatek@lists•infradead.org (moderated list:ARM/Mediatek
	SoC support:Keyword:mediatek)
Subject: [PATCH v6 1/2] dt-bindings: ufs: Document static TX Equalization settings properties
Date: Fri, 29 May 2026 04:33:37 -0700	[thread overview]
Message-ID: <20260529113338.984301-2-can.guo@oss.qualcomm.com> (raw)
In-Reply-To: <20260529113338.984301-1-can.guo@oss.qualcomm.com>

UFS v5.0/UFSHCI v5.0 add HS-G6 support (46.6 Gbps/lane) via UniPro v3.0
and M-PHY v6.0. In these specs, TX Equalization is defined for all High
Speed Gears (not only HS-G6) to compensate channel loss and improve signal
integrity at high speed operation.

For HS-G6, M-PHY uses PAM4 1b1b line coding, Pre-Coding may also be
required depending on channel characteristics.

Add vendor-neutral DT properties:

- patternProperties for txeq-preshoot-g[1-6] and txeq-deemphasis-g[1-6]
- fixed property tx-precode-enable-g6

Each property is a uint32 array of per-lane tuples:
<Host_Lane0 Device_Lane0>, [<Host_Lane1 Device_Lane1>]

Accept 2 or 4 values (x1/x2 lane configs). PreShoot and DeEmphasis values
are 0..7. Precode enable values are 0/1 and only applicable to HS-G6.

Acked-by: Manivannan Sadhasivam <mani@kernel•org>
Reviewed-by: Bean Huo <beanhuo@micron•com>
Reviewed-by: Peter Wang <peter.wang@mediatek•com>
Signed-off-by: Can Guo <can.guo@oss•qualcomm.com>
---
 .../devicetree/bindings/ufs/ufs-common.yaml   | 45 +++++++++++++++++++
 1 file changed, 45 insertions(+)

diff --git a/Documentation/devicetree/bindings/ufs/ufs-common.yaml b/Documentation/devicetree/bindings/ufs/ufs-common.yaml
index ed97f5682509..d90cf25adfa5 100644
--- a/Documentation/devicetree/bindings/ufs/ufs-common.yaml
+++ b/Documentation/devicetree/bindings/ufs/ufs-common.yaml
@@ -105,6 +105,51 @@ properties:
       Restricts the UFS controller to rate-a or rate-b for both TX and
       RX directions.
 
+  tx-precode-enable-g6:
+    $ref: /schemas/types.yaml#/definitions/uint32-array
+    oneOf:
+      - minItems: 2
+        maxItems: 2
+      - minItems: 4
+        maxItems: 4
+    items:
+      enum: [0, 1]
+    description: |
+      Static TX Precode enable values for HS-G6 only.
+      Values are specified as per-lane tuples:
+      <Host_Lane0 Device_Lane0>, [<Host_Lane1 Device_Lane1>].
+
+patternProperties:
+  "^txeq-preshoot-g[1-6]$":
+    $ref: /schemas/types.yaml#/definitions/uint32-array
+    oneOf:
+      - minItems: 2
+        maxItems: 2
+      - minItems: 4
+        maxItems: 4
+    items:
+      minimum: 0
+      maximum: 7
+    description: |
+      Static TX Equalization PreShoot values for High Speed Gears.
+      Values are specified as per-lane tuples:
+      <Host_Lane0 Device_Lane0>, [<Host_Lane1 Device_Lane1>].
+
+  "^txeq-deemphasis-g[1-6]$":
+    $ref: /schemas/types.yaml#/definitions/uint32-array
+    oneOf:
+      - minItems: 2
+        maxItems: 2
+      - minItems: 4
+        maxItems: 4
+    items:
+      minimum: 0
+      maximum: 7
+    description: |
+      Static TX Equalization DeEmphasis values for High Speed Gears.
+      Values are specified as per-lane tuples:
+      <Host_Lane0 Device_Lane0>, [<Host_Lane1 Device_Lane1>].
+
 dependencies:
   freq-table-hz: [ clocks ]
   operating-points-v2: [ clocks, clock-names ]
-- 
2.34.1



       reply	other threads:[~2026-05-29 11:34 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <20260529113338.984301-1-can.guo@oss.qualcomm.com>
2026-05-29 11:33 ` Can Guo [this message]
2026-05-29 16:58   ` [PATCH v6 1/2] dt-bindings: ufs: Document static TX Equalization settings properties Krzysztof Kozlowski
2026-05-30 12:45     ` Can Guo
2026-05-30 13:57       ` Can Guo
2026-05-30 17:33       ` Krzysztof Kozlowski
2026-05-31  1:41         ` Can Guo
2026-05-31  4:48           ` Can Guo

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20260529113338.984301-2-can.guo@oss.qualcomm.com \
    --to=can.guo@oss$(echo .)qualcomm.com \
    --cc=alim.akhtar@samsung$(echo .)com \
    --cc=angelogioacchino.delregno@collabora$(echo .)com \
    --cc=avri.altman@wdc$(echo .)com \
    --cc=beanhuo@micron$(echo .)com \
    --cc=bvanassche@acm$(echo .)org \
    --cc=conor+dt@kernel$(echo .)org \
    --cc=devicetree@vger$(echo .)kernel.org \
    --cc=krzk+dt@kernel$(echo .)org \
    --cc=linux-arm-kernel@lists$(echo .)infradead.org \
    --cc=linux-kernel@vger$(echo .)kernel.org \
    --cc=linux-mediatek@lists$(echo .)infradead.org \
    --cc=linux-scsi@vger$(echo .)kernel.org \
    --cc=mani@kernel$(echo .)org \
    --cc=martin.petersen@oracle$(echo .)com \
    --cc=matthias.bgg@gmail$(echo .)com \
    --cc=peter.wang@mediatek$(echo .)com \
    --cc=quic_rdwivedi@quicinc$(echo .)com \
    --cc=robh@kernel$(echo .)org \
    --cc=zhml@posteo$(echo .)com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox