mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 07:00:48 +00:00
438e23b61c
Add dedicated google,gs101-ufs compatible for Google Tensor gs101 SoC. Signed-off-by: Peter Griffin <peter.griffin@linaro.org> Link: https://lore.kernel.org/r/20240426122004.2249178-2-peter.griffin@linaro.org Reviewed-by: Rob Herring (Arm) <robh@kernel.org> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
131 lines
2.8 KiB
YAML
131 lines
2.8 KiB
YAML
# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
|
|
%YAML 1.2
|
|
---
|
|
$id: http://devicetree.org/schemas/ufs/samsung,exynos-ufs.yaml#
|
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
|
|
|
title: Samsung SoC series UFS host controller
|
|
|
|
maintainers:
|
|
- Alim Akhtar <alim.akhtar@samsung.com>
|
|
|
|
description: |
|
|
Each Samsung UFS host controller instance should have its own node.
|
|
|
|
properties:
|
|
compatible:
|
|
enum:
|
|
- google,gs101-ufs
|
|
- samsung,exynos7-ufs
|
|
- samsung,exynosautov9-ufs
|
|
- samsung,exynosautov9-ufs-vh
|
|
- tesla,fsd-ufs
|
|
|
|
reg:
|
|
items:
|
|
- description: HCI register
|
|
- description: vendor specific register
|
|
- description: unipro register
|
|
- description: UFS protector register
|
|
|
|
reg-names:
|
|
items:
|
|
- const: hci
|
|
- const: vs_hci
|
|
- const: unipro
|
|
- const: ufsp
|
|
|
|
clocks:
|
|
minItems: 2
|
|
items:
|
|
- description: ufs link core clock
|
|
- description: unipro main clock
|
|
- description: fmp clock
|
|
- description: ufs aclk clock
|
|
- description: ufs pclk clock
|
|
- description: sysreg clock
|
|
|
|
clock-names:
|
|
minItems: 2
|
|
items:
|
|
- const: core_clk
|
|
- const: sclk_unipro_main
|
|
- const: fmp
|
|
- const: aclk
|
|
- const: pclk
|
|
- const: sysreg
|
|
|
|
phys:
|
|
maxItems: 1
|
|
|
|
phy-names:
|
|
const: ufs-phy
|
|
|
|
samsung,sysreg:
|
|
$ref: /schemas/types.yaml#/definitions/phandle-array
|
|
items:
|
|
- items:
|
|
- description: phandle to FSYSx sysreg node
|
|
- description: offset of the control register for UFS io coherency setting
|
|
description:
|
|
Phandle and offset to the FSYSx sysreg for UFS io coherency setting.
|
|
|
|
dma-coherent: true
|
|
|
|
required:
|
|
- compatible
|
|
- reg
|
|
- phys
|
|
- phy-names
|
|
- clocks
|
|
- clock-names
|
|
|
|
allOf:
|
|
- $ref: ufs-common.yaml
|
|
- if:
|
|
properties:
|
|
compatible:
|
|
contains:
|
|
const: google,gs101-ufs
|
|
|
|
then:
|
|
properties:
|
|
clocks:
|
|
minItems: 6
|
|
|
|
clock-names:
|
|
minItems: 6
|
|
|
|
else:
|
|
properties:
|
|
clocks:
|
|
maxItems: 2
|
|
|
|
clock-names:
|
|
maxItems: 2
|
|
|
|
unevaluatedProperties: false
|
|
|
|
examples:
|
|
- |
|
|
#include <dt-bindings/interrupt-controller/arm-gic.h>
|
|
#include <dt-bindings/clock/exynos7-clk.h>
|
|
|
|
ufs: ufs@15570000 {
|
|
compatible = "samsung,exynos7-ufs";
|
|
reg = <0x15570000 0x100>,
|
|
<0x15570100 0x100>,
|
|
<0x15571000 0x200>,
|
|
<0x15572000 0x300>;
|
|
reg-names = "hci", "vs_hci", "unipro", "ufsp";
|
|
interrupts = <GIC_SPI 200 IRQ_TYPE_LEVEL_HIGH>;
|
|
clocks = <&clock_fsys1 ACLK_UFS20_LINK>,
|
|
<&clock_fsys1 SCLK_UFSUNIPRO20_USER>;
|
|
clock-names = "core_clk", "sclk_unipro_main";
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&ufs_rst_n &ufs_refclk_out>;
|
|
phys = <&ufs_phy>;
|
|
phy-names = "ufs-phy";
|
|
};
|
|
...
|