Message ID | 20240423205006.1785138-1-peter.griffin@linaro.org |
---|---|
Headers | show |
Series | HSI2, UFS & UFS phy support for Tensor GS101 | expand |
On Tue, Apr 23, 2024 at 09:49:55PM +0100, Peter Griffin wrote: > Add dedicated google,gs101-ufs compatible for Google Tensor gs101 > SoC. > > Signed-off-by: Peter Griffin <peter.griffin@linaro.org> > --- > .../bindings/ufs/samsung,exynos-ufs.yaml | 38 +++++++++++++++++-- > 1 file changed, 35 insertions(+), 3 deletions(-) > > diff --git a/Documentation/devicetree/bindings/ufs/samsung,exynos-ufs.yaml b/Documentation/devicetree/bindings/ufs/samsung,exynos-ufs.yaml > index b2b509b3944d..1179527d29d1 100644 > --- a/Documentation/devicetree/bindings/ufs/samsung,exynos-ufs.yaml > +++ b/Documentation/devicetree/bindings/ufs/samsung,exynos-ufs.yaml > @@ -12,12 +12,10 @@ maintainers: > description: | > Each Samsung UFS host controller instance should have its own node. > > -allOf: > - - $ref: ufs-common.yaml > - > properties: > compatible: > enum: > + - google,gs101-ufs > - samsung,exynos7-ufs > - samsung,exynosautov9-ufs > - samsung,exynosautov9-ufs-vh > @@ -38,14 +36,24 @@ properties: > - 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: ufs_aclk > + - const: ufs_pclk 'ufs_' is redundant. > + - const: sysreg > > phys: > maxItems: 1 > @@ -72,6 +80,30 @@ required: > - 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: > -- > 2.44.0.769.g3c40516874-goog >
On 23/04/2024 22:49, Peter Griffin wrote: > Hi James, Martin, Alim, Bart, Krzysztof, Vinod, all > > Firstly, many thanks to everyone who reviewed and tested v1. > > This series adds support for the High Speed Interface (HSI) 2 clock > management unit, UFS controller and UFS phy calibration/tuning for GS101 > found in Pixel 6. > > With this series applied, UFS is now functional on gs101. The SKhynix > HN8T05BZGKX015 can be enumerated, partitions mounted etc. This allows us to > move away from the initramfs rootfs we have been using for development so far. > > Merge Strategy > 1) UFS driver/bindings via UFS/SCSI tree (James / Martin / Alim) > 2) GS101 DTS/DTSI should go via Krzysztofs Exynos SoC tree > 3) Clock driver/bindings via Clock tree (Krzysztof / Stephen) > 4) PHY driver/bindings via PHY tree (Vinod) > > The v2 series has been rebased on next-20240422, as such all the phy parts > which were already queued by Vinod have been dropped. Two new phy patches > are added to address review feedback received after the patches were queued. > > The series is broadly split into the following parts: > 1) dt-bindings documentation updates > 2) gs101/oriole dts & dtsi updates > 3) Prepatory patches for ufs-exynos driver > 4) GS101 ufs-exynos support > 5) gs101 phy fixes > I asked to split, otherwise please explain why PHY and UFS depends on DTS and clk. Best regards, Krzysztof
Hi Krzysztof, On Thu, 25 Apr 2024 at 08:08, Krzysztof Kozlowski <krzk@kernel.org> wrote: > > On 23/04/2024 22:49, Peter Griffin wrote: > > Hi James, Martin, Alim, Bart, Krzysztof, Vinod, all > > > > Firstly, many thanks to everyone who reviewed and tested v1. > > > > This series adds support for the High Speed Interface (HSI) 2 clock > > management unit, UFS controller and UFS phy calibration/tuning for GS101 > > found in Pixel 6. > > > > With this series applied, UFS is now functional on gs101. The SKhynix > > HN8T05BZGKX015 can be enumerated, partitions mounted etc. This allows us to > > move away from the initramfs rootfs we have been using for development so far. > > > > Merge Strategy > > 1) UFS driver/bindings via UFS/SCSI tree (James / Martin / Alim) > > 2) GS101 DTS/DTSI should go via Krzysztofs Exynos SoC tree > > 3) Clock driver/bindings via Clock tree (Krzysztof / Stephen) > > 4) PHY driver/bindings via PHY tree (Vinod) > > > > The v2 series has been rebased on next-20240422, as such all the phy parts > > which were already queued by Vinod have been dropped. Two new phy patches > > are added to address review feedback received after the patches were queued. > > > > The series is broadly split into the following parts: > > 1) dt-bindings documentation updates > > 2) gs101/oriole dts & dtsi updates > > 3) Prepatory patches for ufs-exynos driver > > 4) GS101 ufs-exynos support > > 5) gs101 phy fixes > > > > I asked to split, otherwise please explain why PHY and UFS depends on > DTS and clk. Seems I misunderstood your feedback. I thought you just want me to make clear who was merging what from the series via which tree. But you want separate series? 1) ufs host dt bindings & driver 2) minor phy fixes series (most patches got applied already for phy) What do you want for cmu_hsi2 clocks and dts/dtsi? The device tree depends on the clock bindings to compile Thanks, Peter.
On 25/04/2024 12:31, Peter Griffin wrote: > Hi Krzysztof, > > On Thu, 25 Apr 2024 at 08:08, Krzysztof Kozlowski <krzk@kernel.org> wrote: >> >> On 23/04/2024 22:49, Peter Griffin wrote: >>> Hi James, Martin, Alim, Bart, Krzysztof, Vinod, all >>> >>> Firstly, many thanks to everyone who reviewed and tested v1. >>> >>> This series adds support for the High Speed Interface (HSI) 2 clock >>> management unit, UFS controller and UFS phy calibration/tuning for GS101 >>> found in Pixel 6. >>> >>> With this series applied, UFS is now functional on gs101. The SKhynix >>> HN8T05BZGKX015 can be enumerated, partitions mounted etc. This allows us to >>> move away from the initramfs rootfs we have been using for development so far. >>> >>> Merge Strategy >>> 1) UFS driver/bindings via UFS/SCSI tree (James / Martin / Alim) >>> 2) GS101 DTS/DTSI should go via Krzysztofs Exynos SoC tree >>> 3) Clock driver/bindings via Clock tree (Krzysztof / Stephen) >>> 4) PHY driver/bindings via PHY tree (Vinod) >>> >>> The v2 series has been rebased on next-20240422, as such all the phy parts >>> which were already queued by Vinod have been dropped. Two new phy patches >>> are added to address review feedback received after the patches were queued. >>> >>> The series is broadly split into the following parts: >>> 1) dt-bindings documentation updates >>> 2) gs101/oriole dts & dtsi updates >>> 3) Prepatory patches for ufs-exynos driver >>> 4) GS101 ufs-exynos support >>> 5) gs101 phy fixes >>> >> >> I asked to split, otherwise please explain why PHY and UFS depends on >> DTS and clk. > > Seems I misunderstood your feedback. I thought you just want me to > make clear who was merging what from the series via which tree. But > you want separate series? > > 1) ufs host dt bindings & driver > 2) minor phy fixes series (most patches got applied already for phy) > > What do you want for cmu_hsi2 clocks and dts/dtsi? The device tree > depends on the clock bindings to compile This is not specific to Samsung Soc, Qualcomm soc or any other arm-soc. Independent patches for different subsystems should not be put together in one patchset. You create false impression of dependencies, grow CC list, cause issues when applying (I cannot just apply entire set with one command, but need to run multiple commands (!!!), plus certain subsystems will reject your patchset because they take everything or nothing) and possible bisection issues (because patches which should be tested independently, are put together so testing does not uncover undocumented dependencies). Almost never combine independent patches which are targeted to entirely different subsystems. There are exceptions, but regular feature work is not one of them. Subsystem is everything in top level of drivers/ and drivers/soc/ (or kind of arch/arm64/boot/dts/, but that tricky because Tesla/Google/Exynos are one subsystem). Or whatever is there in MAINTAINERS file. I don't know, we keep repeating this over multiple times, so it could be added to some docs, but people do not read docs... 1. Drivers and driver bindings go to subsystems. 2. DTS and board compatibles go to soc. a. Any dependency on driver is a near-NAK. b. Any dependency on headers must be clearly expressed, because headers cannot be back-merged from subsystem tree to DTS tree. c. Any usage or usage of bindings from other sets must be clearly expressed (linked). 3. drivers/soc go to soc. Things from list above targeting the same maintainer tree, can be combined in one series, with dependencies expressed in patch changelogs or cover letter. Best regards, Krzysztof
On Tue, 2024-04-23 at 21:49 +0100, Peter Griffin wrote: > This has some configuration bits such as sharability that > are required by UFS. > > Signed-off-by: Peter Griffin <peter.griffin@linaro.org> Reviewed-by: André Draszik <andre.draszik@linaro.org>
On Wed, 2024-04-24 at 14:51 -0500, Rob Herring wrote: > On Tue, Apr 23, 2024 at 09:49:53PM +0100, Peter Griffin wrote: > > Add dt schema documentation and clock IDs for the High Speed Interface > > 2 (HSI2) clock management unit. This CMU feeds high speed interfaces > > such as PCIe and UFS. > > > > Signed-off-by: Peter Griffin <peter.griffin@linaro.org> > > Reviewed-by: André Draszik <andre.draszik@linaro.org> > > --- > > .../bindings/clock/google,gs101-clock.yaml | 30 ++++++++- > > include/dt-bindings/clock/google,gs101.h | 63 +++++++++++++++++++ > > 2 files changed, 91 insertions(+), 2 deletions(-) > > This collides with André's work adding HSI0. Perhaps combine the series > or even the patches and just send clocks as a series. Then it is clear > who should merge it. I'll add Peter's clock-related HSI2 patches into my HSI0 series, which will avoid more merge conflicts. Cheers, Andre'
Hi Rob, Thanks for the review. On Wed, 24 Apr 2024 at 20:53, Rob Herring <robh@kernel.org> wrote: > > On Tue, Apr 23, 2024 at 09:49:55PM +0100, Peter Griffin wrote: > > Add dedicated google,gs101-ufs compatible for Google Tensor gs101 > > SoC. > > > > Signed-off-by: Peter Griffin <peter.griffin@linaro.org> > > --- > > .../bindings/ufs/samsung,exynos-ufs.yaml | 38 +++++++++++++++++-- > > 1 file changed, 35 insertions(+), 3 deletions(-) > > > > diff --git a/Documentation/devicetree/bindings/ufs/samsung,exynos-ufs.yaml b/Documentation/devicetree/bindings/ufs/samsung,exynos-ufs.yaml > > index b2b509b3944d..1179527d29d1 100644 > > --- a/Documentation/devicetree/bindings/ufs/samsung,exynos-ufs.yaml > > +++ b/Documentation/devicetree/bindings/ufs/samsung,exynos-ufs.yaml > > @@ -12,12 +12,10 @@ maintainers: > > description: | > > Each Samsung UFS host controller instance should have its own node. > > > > -allOf: > > - - $ref: ufs-common.yaml > > - > > properties: > > compatible: > > enum: > > + - google,gs101-ufs > > - samsung,exynos7-ufs > > - samsung,exynosautov9-ufs > > - samsung,exynosautov9-ufs-vh > > @@ -38,14 +36,24 @@ properties: > > - 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: ufs_aclk > > + - const: ufs_pclk > > 'ufs_' is redundant. Will fix. Thanks, Peter.