* [PATCH 0/6] crypto: rockchip: add support for rk3588/rk3568
@ 2023-11-07 15:55 Corentin Labbe
  2023-11-07 15:55 ` [PATCH 1/6] dt-bindings: crypto: add support for rockchip,crypto-rk3588 Corentin Labbe
                   ` (5 more replies)
  0 siblings, 6 replies; 32+ messages in thread
From: Corentin Labbe @ 2023-11-07 15:55 UTC (permalink / raw)
  To: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette,
	p.zabel, robh+dt, sboyd
  Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto,
	linux-kernel, linux-rockchip, Corentin Labbe
Hello
This patch serie add support for the new crypto rockchip IP found on
rk3568 and rk3588.
It was tested with CONFIG_CRYPTO_MANAGER_EXTRA_TESTS=y
I would like to thanks all people which helped to test this driver
Regards
Corentin Labbe (6):
  dt-bindings: crypto: add support for rockchip,crypto-rk3588
  MAINTAINERS: add new dt-binding doc to the right entry
  ARM64: dts: rk3588: add crypto node
  ARM64: dts: rk356x: add crypto node
  reset: rockchip: secure reset must be used by SCMI
  crypto: rockchip: add rk3588 driver
 .../crypto/rockchip,rk3588-crypto.yaml        |  65 ++
 MAINTAINERS                                   |   1 +
 arch/arm64/boot/dts/rockchip/rk356x.dtsi      |  12 +
 arch/arm64/boot/dts/rockchip/rk3588s.dtsi     |  12 +
 drivers/clk/rockchip/rst-rk3588.c             |  42 -
 drivers/crypto/Kconfig                        |  29 +
 drivers/crypto/rockchip/Makefile              |   5 +
 drivers/crypto/rockchip/rk2_crypto.c          | 739 ++++++++++++++++++
 drivers/crypto/rockchip/rk2_crypto.h          | 246 ++++++
 drivers/crypto/rockchip/rk2_crypto_ahash.c    | 344 ++++++++
 drivers/crypto/rockchip/rk2_crypto_skcipher.c | 576 ++++++++++++++
 .../dt-bindings/reset/rockchip,rk3588-cru.h   |  68 +-
 12 files changed, 2063 insertions(+), 76 deletions(-)
 create mode 100644 Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml
 create mode 100644 drivers/crypto/rockchip/rk2_crypto.c
 create mode 100644 drivers/crypto/rockchip/rk2_crypto.h
 create mode 100644 drivers/crypto/rockchip/rk2_crypto_ahash.c
 create mode 100644 drivers/crypto/rockchip/rk2_crypto_skcipher.c
-- 
2.41.0
^ permalink raw reply	[flat|nested] 32+ messages in thread* [PATCH 1/6] dt-bindings: crypto: add support for rockchip,crypto-rk3588 2023-11-07 15:55 [PATCH 0/6] crypto: rockchip: add support for rk3588/rk3568 Corentin Labbe @ 2023-11-07 15:55 ` Corentin Labbe 2023-11-07 16:40 ` Krzysztof Kozlowski 2023-11-07 15:55 ` [PATCH 2/6] MAINTAINERS: add new dt-binding doc to the right entry Corentin Labbe ` (4 subsequent siblings) 5 siblings, 1 reply; 32+ messages in thread From: Corentin Labbe @ 2023-11-07 15:55 UTC (permalink / raw) To: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip, Corentin Labbe Add device tree binding documentation for the Rockchip cryptographic offloader V2. Signed-off-by: Corentin Labbe <clabbe@baylibre.com> --- .../crypto/rockchip,rk3588-crypto.yaml | 65 +++++++++++++++++++ 1 file changed, 65 insertions(+) create mode 100644 Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml diff --git a/Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml b/Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml new file mode 100644 index 000000000000..07024cf4fb0e --- /dev/null +++ b/Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml @@ -0,0 +1,65 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/crypto/rockchip,rk3588-crypto.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Rockchip cryptographic offloader V2 + +maintainers: + - Corentin Labbe <clabbe@baylibre.com> + +properties: + compatible: + enum: + - rockchip,rk3568-crypto + - rockchip,rk3588-crypto + + reg: + maxItems: 1 + + interrupts: + maxItems: 1 + + clocks: + minItems: 3 + + clock-names: + items: + - const: core + - const: a + - const: h + + resets: + minItems: 1 + + reset-names: + items: + - const: core + +required: + - compatible + - reg + - interrupts + - clocks + - clock-names + - resets + - reset-names + +additionalProperties: false + +examples: + - | + #include <dt-bindings/interrupt-controller/arm-gic.h> + #include <dt-bindings/clock/rockchip,rk3588-cru.h> + #include <dt-bindings/reset/rockchip,rk3588-cru.h> + crypto@fe370000 { + compatible = "rockchip,rk3588-crypto"; + reg = <0xfe370000 0x4000>; + interrupts = <GIC_SPI 209 IRQ_TYPE_LEVEL_HIGH 0>; + clocks = <&scmi_clk SCMI_CRYPTO_CORE>, <&scmi_clk SCMI_ACLK_SECURE_NS>, + <&scmi_clk SCMI_HCLK_SECURE_NS>; + clock-names = "core", "a", "h"; + resets = <&scmi_reset SRST_CRYPTO_CORE>; + reset-names = "core"; + }; -- 2.41.0 ^ permalink raw reply related [flat|nested] 32+ messages in thread
* Re: [PATCH 1/6] dt-bindings: crypto: add support for rockchip,crypto-rk3588 2023-11-07 15:55 ` [PATCH 1/6] dt-bindings: crypto: add support for rockchip,crypto-rk3588 Corentin Labbe @ 2023-11-07 16:40 ` Krzysztof Kozlowski 2023-11-20 12:37 ` Corentin LABBE 0 siblings, 1 reply; 32+ messages in thread From: Krzysztof Kozlowski @ 2023-11-07 16:40 UTC (permalink / raw) To: Corentin Labbe, davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip On 07/11/2023 16:55, Corentin Labbe wrote: > Add device tree binding documentation for the Rockchip cryptographic > offloader V2. > > Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > --- > .../crypto/rockchip,rk3588-crypto.yaml | 65 +++++++++++++++++++ > 1 file changed, 65 insertions(+) > create mode 100644 Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml > > diff --git a/Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml b/Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml > new file mode 100644 > index 000000000000..07024cf4fb0e > --- /dev/null > +++ b/Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml > @@ -0,0 +1,65 @@ > +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) > +%YAML 1.2 > +--- > +$id: http://devicetree.org/schemas/crypto/rockchip,rk3588-crypto.yaml# > +$schema: http://devicetree.org/meta-schemas/core.yaml# > + > +title: Rockchip cryptographic offloader V2 v2? Where is any documentation of this versioning? From where does it come from? > + > +maintainers: > + - Corentin Labbe <clabbe@baylibre.com> > + > +properties: > + compatible: > + enum: > + - rockchip,rk3568-crypto > + - rockchip,rk3588-crypto > + > + reg: > + maxItems: 1 > + > + interrupts: > + maxItems: 1 > + > + clocks: > + minItems: 3 You also must describe the items instead. Where do you see any binding using minItems alone? > + > + clock-names: > + items: > + - const: core > + - const: a > + - const: h > + > + resets: > + minItems: 1 No, maxItems. > + > + reset-names: > + items: > + - const: core Drop reset-names, not really needed and not useful. > + > +required: > + - compatible > + - reg > + - interrupts > + - clocks > + - clock-names > + - resets > + - reset-names Best regards, Krzysztof ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 1/6] dt-bindings: crypto: add support for rockchip,crypto-rk3588 2023-11-07 16:40 ` Krzysztof Kozlowski @ 2023-11-20 12:37 ` Corentin LABBE 2023-11-21 9:04 ` Krzysztof Kozlowski 0 siblings, 1 reply; 32+ messages in thread From: Corentin LABBE @ 2023-11-20 12:37 UTC (permalink / raw) To: Krzysztof Kozlowski Cc: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip Le Tue, Nov 07, 2023 at 05:40:24PM +0100, Krzysztof Kozlowski a écrit : > On 07/11/2023 16:55, Corentin Labbe wrote: > > Add device tree binding documentation for the Rockchip cryptographic > > offloader V2. > > > > Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > > --- > > .../crypto/rockchip,rk3588-crypto.yaml | 65 +++++++++++++++++++ > > 1 file changed, 65 insertions(+) > > create mode 100644 Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml > > > > diff --git a/Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml b/Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml > > new file mode 100644 > > index 000000000000..07024cf4fb0e > > --- /dev/null > > +++ b/Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml > > @@ -0,0 +1,65 @@ > > +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) > > +%YAML 1.2 > > +--- > > +$id: http://devicetree.org/schemas/crypto/rockchip,rk3588-crypto.yaml# > > +$schema: http://devicetree.org/meta-schemas/core.yaml# > > + > > +title: Rockchip cryptographic offloader V2 > > v2? Where is any documentation of this versioning? From where does it > come from? > Hello Datasheet/TRM has no naming or codename. But vendor source call it crypto v2, so I kept the name. > > + > > +maintainers: > > + - Corentin Labbe <clabbe@baylibre.com> > > + > > +properties: > > + compatible: > > + enum: > > + - rockchip,rk3568-crypto > > + - rockchip,rk3588-crypto > > + > > + reg: > > + maxItems: 1 > > + > > + interrupts: > > + maxItems: 1 > > + > > + clocks: > > + minItems: 3 > > You also must describe the items instead. > > Where do you see any binding using minItems alone? > > > + > > + clock-names: > > + items: > > + - const: core > > + - const: a > > + - const: h > > + > > + resets: > > + minItems: 1 > > No, maxItems. > > > + > > + reset-names: > > + items: > > + - const: core > > Drop reset-names, not really needed and not useful. > > > + > > +required: > > + - compatible > > + - reg > > + - interrupts > > + - clocks > > + - clock-names > > + - resets > > + - reset-names > > I will fix all thoses problems. Thanks for review. Regards ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 1/6] dt-bindings: crypto: add support for rockchip,crypto-rk3588 2023-11-20 12:37 ` Corentin LABBE @ 2023-11-21 9:04 ` Krzysztof Kozlowski 0 siblings, 0 replies; 32+ messages in thread From: Krzysztof Kozlowski @ 2023-11-21 9:04 UTC (permalink / raw) To: Corentin LABBE Cc: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip On 20/11/2023 13:37, Corentin LABBE wrote: >>> diff --git a/Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml b/Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml >>> new file mode 100644 >>> index 000000000000..07024cf4fb0e >>> --- /dev/null >>> +++ b/Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml >>> @@ -0,0 +1,65 @@ >>> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) >>> +%YAML 1.2 >>> +--- >>> +$id: http://devicetree.org/schemas/crypto/rockchip,rk3588-crypto.yaml# >>> +$schema: http://devicetree.org/meta-schemas/core.yaml# >>> + >>> +title: Rockchip cryptographic offloader V2 >> >> v2? Where is any documentation of this versioning? From where does it >> come from? >> > > Hello > > Datasheet/TRM has no naming or codename. > But vendor source call it crypto v2, so I kept the name. I would suggest using information from datasheet/manual or just SoC name, so: Rockchip RK3588 Cryptographic Offloader How can you be sure that downstream source used v2 for hardware, not driver? Poor-quality downstream source is rarely a source of proper solution... Best regards, Krzysztof ^ permalink raw reply [flat|nested] 32+ messages in thread
* [PATCH 2/6] MAINTAINERS: add new dt-binding doc to the right entry 2023-11-07 15:55 [PATCH 0/6] crypto: rockchip: add support for rk3588/rk3568 Corentin Labbe 2023-11-07 15:55 ` [PATCH 1/6] dt-bindings: crypto: add support for rockchip,crypto-rk3588 Corentin Labbe @ 2023-11-07 15:55 ` Corentin Labbe 2023-11-07 16:20 ` Krzysztof Kozlowski 2023-11-07 15:55 ` [PATCH 3/6] ARM64: dts: rk3588: add crypto node Corentin Labbe ` (3 subsequent siblings) 5 siblings, 1 reply; 32+ messages in thread From: Corentin Labbe @ 2023-11-07 15:55 UTC (permalink / raw) To: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip, Corentin Labbe Rockchip crypto driver have a new file to be added. Signed-off-by: Corentin Labbe <clabbe@baylibre.com> --- MAINTAINERS | 1 + 1 file changed, 1 insertion(+) diff --git a/MAINTAINERS b/MAINTAINERS index 8a43b16aecaa..f9ae35a13e70 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -18697,6 +18697,7 @@ M: Corentin Labbe <clabbe@baylibre.com> L: linux-crypto@vger.kernel.org S: Maintained F: Documentation/devicetree/bindings/crypto/rockchip,rk3288-crypto.yaml +F: Documentation/devicetree/bindings/crypto/rockchip,rk3588-crypto.yaml F: drivers/crypto/rockchip/ ROCKCHIP I2S TDM DRIVER -- 2.41.0 ^ permalink raw reply related [flat|nested] 32+ messages in thread
* Re: [PATCH 2/6] MAINTAINERS: add new dt-binding doc to the right entry 2023-11-07 15:55 ` [PATCH 2/6] MAINTAINERS: add new dt-binding doc to the right entry Corentin Labbe @ 2023-11-07 16:20 ` Krzysztof Kozlowski 2023-11-20 12:37 ` Corentin LABBE 0 siblings, 1 reply; 32+ messages in thread From: Krzysztof Kozlowski @ 2023-11-07 16:20 UTC (permalink / raw) To: Corentin Labbe, davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip On 07/11/2023 16:55, Corentin Labbe wrote: > Rockchip crypto driver have a new file to be added. > It does not have sense patch to be separate commit. It's not like you add new entry. New file is introduced in a patch? Then this patch touches maintainers. Best regards, Krzysztof ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 2/6] MAINTAINERS: add new dt-binding doc to the right entry 2023-11-07 16:20 ` Krzysztof Kozlowski @ 2023-11-20 12:37 ` Corentin LABBE 0 siblings, 0 replies; 32+ messages in thread From: Corentin LABBE @ 2023-11-20 12:37 UTC (permalink / raw) To: Krzysztof Kozlowski Cc: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip Le Tue, Nov 07, 2023 at 05:20:46PM +0100, Krzysztof Kozlowski a écrit : > On 07/11/2023 16:55, Corentin Labbe wrote: > > Rockchip crypto driver have a new file to be added. > > > > It does not have sense patch to be separate commit. It's not like you > add new entry. New file is introduced in a patch? Then this patch > touches maintainers. > > Best regards, > Krzysztof > I will do it Regards ^ permalink raw reply [flat|nested] 32+ messages in thread
* [PATCH 3/6] ARM64: dts: rk3588: add crypto node 2023-11-07 15:55 [PATCH 0/6] crypto: rockchip: add support for rk3588/rk3568 Corentin Labbe 2023-11-07 15:55 ` [PATCH 1/6] dt-bindings: crypto: add support for rockchip,crypto-rk3588 Corentin Labbe 2023-11-07 15:55 ` [PATCH 2/6] MAINTAINERS: add new dt-binding doc to the right entry Corentin Labbe @ 2023-11-07 15:55 ` Corentin Labbe 2023-11-07 15:59 ` Heiko Stübner 2023-11-07 16:20 ` Krzysztof Kozlowski 2023-11-07 15:55 ` [PATCH 4/6] ARM64: dts: rk356x: " Corentin Labbe ` (2 subsequent siblings) 5 siblings, 2 replies; 32+ messages in thread From: Corentin Labbe @ 2023-11-07 15:55 UTC (permalink / raw) To: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip, Corentin Labbe The rk3588 has a crypto IP handled by the rk3588 crypto driver so adds a node for it. Signed-off-by: Corentin Labbe <clabbe@baylibre.com> --- arch/arm64/boot/dts/rockchip/rk3588s.dtsi | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/arch/arm64/boot/dts/rockchip/rk3588s.dtsi b/arch/arm64/boot/dts/rockchip/rk3588s.dtsi index 7064c0e9179f..a2ba5ebec38d 100644 --- a/arch/arm64/boot/dts/rockchip/rk3588s.dtsi +++ b/arch/arm64/boot/dts/rockchip/rk3588s.dtsi @@ -1523,6 +1523,18 @@ sdhci: mmc@fe2e0000 { status = "disabled"; }; + crypto: crypto@fe370000 { + compatible = "rockchip,rk3588-crypto"; + reg = <0x0 0xfe370000 0x0 0x2000>; + interrupts = <GIC_SPI 209 IRQ_TYPE_LEVEL_HIGH 0>; + clocks = <&scmi_clk SCMI_CRYPTO_CORE>, <&scmi_clk SCMI_ACLK_SECURE_NS>, + <&scmi_clk SCMI_HCLK_SECURE_NS>; + clock-names = "core", "aclk", "hclk"; + resets = <&scmi_reset SRST_CRYPTO_CORE>; + reset-names = "core"; + status = "okay"; + }; + i2s0_8ch: i2s@fe470000 { compatible = "rockchip,rk3588-i2s-tdm"; reg = <0x0 0xfe470000 0x0 0x1000>; -- 2.41.0 ^ permalink raw reply related [flat|nested] 32+ messages in thread
* Re: [PATCH 3/6] ARM64: dts: rk3588: add crypto node 2023-11-07 15:55 ` [PATCH 3/6] ARM64: dts: rk3588: add crypto node Corentin Labbe @ 2023-11-07 15:59 ` Heiko Stübner 2023-11-20 12:38 ` Corentin LABBE 2023-11-07 16:20 ` Krzysztof Kozlowski 1 sibling, 1 reply; 32+ messages in thread From: Heiko Stübner @ 2023-11-07 15:59 UTC (permalink / raw) To: davem, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, Corentin Labbe Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip, Corentin Labbe Hi, Am Dienstag, 7. November 2023, 16:55:29 CET schrieb Corentin Labbe: > The rk3588 has a crypto IP handled by the rk3588 crypto driver so adds a > node for it. please follow other commits in the subject line, i.e.: "arm64: dts: rockchip: add rk3588 crypto node" Thanks Heiko > > Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > --- > arch/arm64/boot/dts/rockchip/rk3588s.dtsi | 12 ++++++++++++ > 1 file changed, 12 insertions(+) > > diff --git a/arch/arm64/boot/dts/rockchip/rk3588s.dtsi b/arch/arm64/boot/dts/rockchip/rk3588s.dtsi > index 7064c0e9179f..a2ba5ebec38d 100644 > --- a/arch/arm64/boot/dts/rockchip/rk3588s.dtsi > +++ b/arch/arm64/boot/dts/rockchip/rk3588s.dtsi > @@ -1523,6 +1523,18 @@ sdhci: mmc@fe2e0000 { > status = "disabled"; > }; > > + crypto: crypto@fe370000 { > + compatible = "rockchip,rk3588-crypto"; > + reg = <0x0 0xfe370000 0x0 0x2000>; > + interrupts = <GIC_SPI 209 IRQ_TYPE_LEVEL_HIGH 0>; > + clocks = <&scmi_clk SCMI_CRYPTO_CORE>, <&scmi_clk SCMI_ACLK_SECURE_NS>, > + <&scmi_clk SCMI_HCLK_SECURE_NS>; > + clock-names = "core", "aclk", "hclk"; > + resets = <&scmi_reset SRST_CRYPTO_CORE>; > + reset-names = "core"; > + status = "okay"; > + }; > + > i2s0_8ch: i2s@fe470000 { > compatible = "rockchip,rk3588-i2s-tdm"; > reg = <0x0 0xfe470000 0x0 0x1000>; > ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 3/6] ARM64: dts: rk3588: add crypto node 2023-11-07 15:59 ` Heiko Stübner @ 2023-11-20 12:38 ` Corentin LABBE 0 siblings, 0 replies; 32+ messages in thread From: Corentin LABBE @ 2023-11-20 12:38 UTC (permalink / raw) To: Heiko Stübner Cc: davem, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip Le Tue, Nov 07, 2023 at 04:59:42PM +0100, Heiko Stübner a écrit : > Hi, > > Am Dienstag, 7. November 2023, 16:55:29 CET schrieb Corentin Labbe: > > The rk3588 has a crypto IP handled by the rk3588 crypto driver so adds a > > node for it. > > please follow other commits in the subject line, i.e.: > > "arm64: dts: rockchip: add rk3588 crypto node" > > > Thanks > Heiko > I will do it Thanks. ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 3/6] ARM64: dts: rk3588: add crypto node 2023-11-07 15:55 ` [PATCH 3/6] ARM64: dts: rk3588: add crypto node Corentin Labbe 2023-11-07 15:59 ` Heiko Stübner @ 2023-11-07 16:20 ` Krzysztof Kozlowski 2023-11-20 12:38 ` Corentin LABBE 1 sibling, 1 reply; 32+ messages in thread From: Krzysztof Kozlowski @ 2023-11-07 16:20 UTC (permalink / raw) To: Corentin Labbe, davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip On 07/11/2023 16:55, Corentin Labbe wrote: > The rk3588 has a crypto IP handled by the rk3588 crypto driver so adds a > node for it. > > Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > --- > arch/arm64/boot/dts/rockchip/rk3588s.dtsi | 12 ++++++++++++ > 1 file changed, 12 insertions(+) > > diff --git a/arch/arm64/boot/dts/rockchip/rk3588s.dtsi b/arch/arm64/boot/dts/rockchip/rk3588s.dtsi > index 7064c0e9179f..a2ba5ebec38d 100644 > --- a/arch/arm64/boot/dts/rockchip/rk3588s.dtsi > +++ b/arch/arm64/boot/dts/rockchip/rk3588s.dtsi > @@ -1523,6 +1523,18 @@ sdhci: mmc@fe2e0000 { > status = "disabled"; > }; > > + crypto: crypto@fe370000 { > + compatible = "rockchip,rk3588-crypto"; > + reg = <0x0 0xfe370000 0x0 0x2000>; > + interrupts = <GIC_SPI 209 IRQ_TYPE_LEVEL_HIGH 0>; > + clocks = <&scmi_clk SCMI_CRYPTO_CORE>, <&scmi_clk SCMI_ACLK_SECURE_NS>, > + <&scmi_clk SCMI_HCLK_SECURE_NS>; > + clock-names = "core", "aclk", "hclk"; > + resets = <&scmi_reset SRST_CRYPTO_CORE>; > + reset-names = "core"; > + status = "okay"; Drop. Best regards, Krzysztof ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 3/6] ARM64: dts: rk3588: add crypto node 2023-11-07 16:20 ` Krzysztof Kozlowski @ 2023-11-20 12:38 ` Corentin LABBE 0 siblings, 0 replies; 32+ messages in thread From: Corentin LABBE @ 2023-11-20 12:38 UTC (permalink / raw) To: Krzysztof Kozlowski Cc: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip Le Tue, Nov 07, 2023 at 05:20:59PM +0100, Krzysztof Kozlowski a écrit : > On 07/11/2023 16:55, Corentin Labbe wrote: > > The rk3588 has a crypto IP handled by the rk3588 crypto driver so adds a > > node for it. > > > > Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > > --- > > arch/arm64/boot/dts/rockchip/rk3588s.dtsi | 12 ++++++++++++ > > 1 file changed, 12 insertions(+) > > > > diff --git a/arch/arm64/boot/dts/rockchip/rk3588s.dtsi b/arch/arm64/boot/dts/rockchip/rk3588s.dtsi > > index 7064c0e9179f..a2ba5ebec38d 100644 > > --- a/arch/arm64/boot/dts/rockchip/rk3588s.dtsi > > +++ b/arch/arm64/boot/dts/rockchip/rk3588s.dtsi > > @@ -1523,6 +1523,18 @@ sdhci: mmc@fe2e0000 { > > status = "disabled"; > > }; > > > > + crypto: crypto@fe370000 { > > + compatible = "rockchip,rk3588-crypto"; > > + reg = <0x0 0xfe370000 0x0 0x2000>; > > + interrupts = <GIC_SPI 209 IRQ_TYPE_LEVEL_HIGH 0>; > > + clocks = <&scmi_clk SCMI_CRYPTO_CORE>, <&scmi_clk SCMI_ACLK_SECURE_NS>, > > + <&scmi_clk SCMI_HCLK_SECURE_NS>; > > + clock-names = "core", "aclk", "hclk"; > > + resets = <&scmi_reset SRST_CRYPTO_CORE>; > > + reset-names = "core"; > > + status = "okay"; > > Drop. > > Best regards, > Krzysztof > I will do it Thanks. ^ permalink raw reply [flat|nested] 32+ messages in thread
* [PATCH 4/6] ARM64: dts: rk356x: add crypto node 2023-11-07 15:55 [PATCH 0/6] crypto: rockchip: add support for rk3588/rk3568 Corentin Labbe ` (2 preceding siblings ...) 2023-11-07 15:55 ` [PATCH 3/6] ARM64: dts: rk3588: add crypto node Corentin Labbe @ 2023-11-07 15:55 ` Corentin Labbe 2023-11-07 16:00 ` Heiko Stübner 2023-11-07 16:21 ` Krzysztof Kozlowski 2023-11-07 15:55 ` [PATCH 5/6] reset: rockchip: secure reset must be used by SCMI Corentin Labbe 2023-11-07 15:55 ` [PATCH 6/6] crypto: rockchip: add rk3588 driver Corentin Labbe 5 siblings, 2 replies; 32+ messages in thread From: Corentin Labbe @ 2023-11-07 15:55 UTC (permalink / raw) To: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip, Corentin Labbe Both RK3566 and RK3568 have a crypto IP handled by the rk3588 crypto driver so adds a node for it. Tested-by: Ricardo Pardini <ricardo@pardini.net> Signed-off-by: Corentin Labbe <clabbe@baylibre.com> --- arch/arm64/boot/dts/rockchip/rk356x.dtsi | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/arch/arm64/boot/dts/rockchip/rk356x.dtsi b/arch/arm64/boot/dts/rockchip/rk356x.dtsi index 0964761e3ce9..c94a1b535c32 100644 --- a/arch/arm64/boot/dts/rockchip/rk356x.dtsi +++ b/arch/arm64/boot/dts/rockchip/rk356x.dtsi @@ -1070,6 +1070,18 @@ sdhci: mmc@fe310000 { status = "disabled"; }; + crypto: crypto@fe380000 { + compatible = "rockchip,rk3568-crypto"; + reg = <0x0 0xfe380000 0x0 0x2000>; + interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>; + clocks = <&cru ACLK_CRYPTO_NS>, <&cru HCLK_CRYPTO_NS>, + <&cru CLK_CRYPTO_NS_CORE>; + clock-names = "aclk", "hclk", "core"; + resets = <&cru SRST_CRYPTO_NS_CORE>; + reset-names = "core"; + status = "okay"; + }; + i2s0_8ch: i2s@fe400000 { compatible = "rockchip,rk3568-i2s-tdm"; reg = <0x0 0xfe400000 0x0 0x1000>; -- 2.41.0 ^ permalink raw reply related [flat|nested] 32+ messages in thread
* Re: [PATCH 4/6] ARM64: dts: rk356x: add crypto node 2023-11-07 15:55 ` [PATCH 4/6] ARM64: dts: rk356x: " Corentin Labbe @ 2023-11-07 16:00 ` Heiko Stübner 2023-11-07 16:21 ` Krzysztof Kozlowski 1 sibling, 0 replies; 32+ messages in thread From: Heiko Stübner @ 2023-11-07 16:00 UTC (permalink / raw) To: davem, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, Corentin Labbe Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip, Corentin Labbe Am Dienstag, 7. November 2023, 16:55:30 CET schrieb Corentin Labbe: > Both RK3566 and RK3568 have a crypto IP handled by the rk3588 crypto driver so adds a > node for it. please follow other commits in the subject line, i.e.: "arm64: dts: rockchip: add rk356x crypto node" Thanks Heiko > > Tested-by: Ricardo Pardini <ricardo@pardini.net> > Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > --- > arch/arm64/boot/dts/rockchip/rk356x.dtsi | 12 ++++++++++++ > 1 file changed, 12 insertions(+) > > diff --git a/arch/arm64/boot/dts/rockchip/rk356x.dtsi b/arch/arm64/boot/dts/rockchip/rk356x.dtsi > index 0964761e3ce9..c94a1b535c32 100644 > --- a/arch/arm64/boot/dts/rockchip/rk356x.dtsi > +++ b/arch/arm64/boot/dts/rockchip/rk356x.dtsi > @@ -1070,6 +1070,18 @@ sdhci: mmc@fe310000 { > status = "disabled"; > }; > > + crypto: crypto@fe380000 { > + compatible = "rockchip,rk3568-crypto"; > + reg = <0x0 0xfe380000 0x0 0x2000>; > + interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>; > + clocks = <&cru ACLK_CRYPTO_NS>, <&cru HCLK_CRYPTO_NS>, > + <&cru CLK_CRYPTO_NS_CORE>; > + clock-names = "aclk", "hclk", "core"; > + resets = <&cru SRST_CRYPTO_NS_CORE>; > + reset-names = "core"; > + status = "okay"; > + }; > + > i2s0_8ch: i2s@fe400000 { > compatible = "rockchip,rk3568-i2s-tdm"; > reg = <0x0 0xfe400000 0x0 0x1000>; > ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 4/6] ARM64: dts: rk356x: add crypto node 2023-11-07 15:55 ` [PATCH 4/6] ARM64: dts: rk356x: " Corentin Labbe 2023-11-07 16:00 ` Heiko Stübner @ 2023-11-07 16:21 ` Krzysztof Kozlowski 1 sibling, 0 replies; 32+ messages in thread From: Krzysztof Kozlowski @ 2023-11-07 16:21 UTC (permalink / raw) To: Corentin Labbe, davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip On 07/11/2023 16:55, Corentin Labbe wrote: > Both RK3566 and RK3568 have a crypto IP handled by the rk3588 crypto driver so adds a > node for it. > > Tested-by: Ricardo Pardini <ricardo@pardini.net> > Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > --- > arch/arm64/boot/dts/rockchip/rk356x.dtsi | 12 ++++++++++++ > 1 file changed, 12 insertions(+) > > diff --git a/arch/arm64/boot/dts/rockchip/rk356x.dtsi b/arch/arm64/boot/dts/rockchip/rk356x.dtsi > index 0964761e3ce9..c94a1b535c32 100644 > --- a/arch/arm64/boot/dts/rockchip/rk356x.dtsi > +++ b/arch/arm64/boot/dts/rockchip/rk356x.dtsi > @@ -1070,6 +1070,18 @@ sdhci: mmc@fe310000 { > status = "disabled"; > }; > > + crypto: crypto@fe380000 { > + compatible = "rockchip,rk3568-crypto"; > + reg = <0x0 0xfe380000 0x0 0x2000>; > + interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>; > + clocks = <&cru ACLK_CRYPTO_NS>, <&cru HCLK_CRYPTO_NS>, > + <&cru CLK_CRYPTO_NS_CORE>; > + clock-names = "aclk", "hclk", "core"; > + resets = <&cru SRST_CRYPTO_NS_CORE>; > + reset-names = "core"; > + status = "okay"; Drop Best regards, Krzysztof ^ permalink raw reply [flat|nested] 32+ messages in thread
* [PATCH 5/6] reset: rockchip: secure reset must be used by SCMI 2023-11-07 15:55 [PATCH 0/6] crypto: rockchip: add support for rk3588/rk3568 Corentin Labbe ` (3 preceding siblings ...) 2023-11-07 15:55 ` [PATCH 4/6] ARM64: dts: rk356x: " Corentin Labbe @ 2023-11-07 15:55 ` Corentin Labbe 2023-11-07 16:21 ` Krzysztof Kozlowski 2023-11-07 15:55 ` [PATCH 6/6] crypto: rockchip: add rk3588 driver Corentin Labbe 5 siblings, 1 reply; 32+ messages in thread From: Corentin Labbe @ 2023-11-07 15:55 UTC (permalink / raw) To: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip, Corentin Labbe While working on the rk3588 crypto driver, I loose lot of time understanding why resetting the IP failed. This is due to RK3588_SECURECRU_RESET_OFFSET being in the secure world, so impossible to operate on it from the kernel. All resets in this block must be handled via SCMI call. Signed-off-by: Corentin Labbe <clabbe@baylibre.com> --- drivers/clk/rockchip/rst-rk3588.c | 42 ------------ .../dt-bindings/reset/rockchip,rk3588-cru.h | 68 +++++++++---------- 2 files changed, 34 insertions(+), 76 deletions(-) diff --git a/drivers/clk/rockchip/rst-rk3588.c b/drivers/clk/rockchip/rst-rk3588.c index e855bb8d5413..6556d9d3c7ab 100644 --- a/drivers/clk/rockchip/rst-rk3588.c +++ b/drivers/clk/rockchip/rst-rk3588.c @@ -16,9 +16,6 @@ /* 0xFD7C8000 + 0x0A00 */ #define RK3588_PHPTOPCRU_RESET_OFFSET(id, reg, bit) [id] = (0x8000*4 + reg * 16 + bit) -/* 0xFD7D0000 + 0x0A00 */ -#define RK3588_SECURECRU_RESET_OFFSET(id, reg, bit) [id] = (0x10000*4 + reg * 16 + bit) - /* 0xFD7F0000 + 0x0A00 */ #define RK3588_PMU1CRU_RESET_OFFSET(id, reg, bit) [id] = (0x30000*4 + reg * 16 + bit) @@ -806,45 +803,6 @@ static const int rk3588_register_offset[] = { RK3588_PMU1CRU_RESET_OFFSET(SRST_P_PMU0IOC, 5, 4), RK3588_PMU1CRU_RESET_OFFSET(SRST_P_GPIO0, 5, 5), RK3588_PMU1CRU_RESET_OFFSET(SRST_GPIO0, 5, 6), - - /* SECURECRU_SOFTRST_CON00 */ - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_NS_BIU, 0, 10), - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_NS_BIU, 0, 11), - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_S_BIU, 0, 12), - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_S_BIU, 0, 13), - RK3588_SECURECRU_RESET_OFFSET(SRST_P_SECURE_S_BIU, 0, 14), - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_CORE, 0, 15), - - /* SECURECRU_SOFTRST_CON01 */ - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_PKA, 1, 0), - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_RNG, 1, 1), - RK3588_SECURECRU_RESET_OFFSET(SRST_A_CRYPTO, 1, 2), - RK3588_SECURECRU_RESET_OFFSET(SRST_H_CRYPTO, 1, 3), - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_CORE, 1, 9), - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_RNG, 1, 10), - RK3588_SECURECRU_RESET_OFFSET(SRST_A_KEYLADDER, 1, 11), - RK3588_SECURECRU_RESET_OFFSET(SRST_H_KEYLADDER, 1, 12), - RK3588_SECURECRU_RESET_OFFSET(SRST_P_OTPC_S, 1, 13), - RK3588_SECURECRU_RESET_OFFSET(SRST_OTPC_S, 1, 14), - RK3588_SECURECRU_RESET_OFFSET(SRST_WDT_S, 1, 15), - - /* SECURECRU_SOFTRST_CON02 */ - RK3588_SECURECRU_RESET_OFFSET(SRST_T_WDT_S, 2, 0), - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM, 2, 1), - RK3588_SECURECRU_RESET_OFFSET(SRST_A_DCF, 2, 2), - RK3588_SECURECRU_RESET_OFFSET(SRST_P_DCF, 2, 3), - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM_NS, 2, 5), - RK3588_SECURECRU_RESET_OFFSET(SRST_P_KEYLADDER, 2, 14), - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_S, 2, 15), - - /* SECURECRU_SOFTRST_CON03 */ - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_NS, 3, 0), - RK3588_SECURECRU_RESET_OFFSET(SRST_D_SDMMC_BUFFER, 3, 1), - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC, 3, 2), - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC_BUFFER, 3, 3), - RK3588_SECURECRU_RESET_OFFSET(SRST_SDMMC, 3, 4), - RK3588_SECURECRU_RESET_OFFSET(SRST_P_TRNG_CHK, 3, 5), - RK3588_SECURECRU_RESET_OFFSET(SRST_TRNG_S, 3, 6), }; void rk3588_rst_init(struct device_node *np, void __iomem *reg_base) diff --git a/include/dt-bindings/reset/rockchip,rk3588-cru.h b/include/dt-bindings/reset/rockchip,rk3588-cru.h index d4264db2a07f..c0d08ae78cd5 100644 --- a/include/dt-bindings/reset/rockchip,rk3588-cru.h +++ b/include/dt-bindings/reset/rockchip,rk3588-cru.h @@ -716,39 +716,39 @@ #define SRST_P_GPIO0 627 #define SRST_GPIO0 628 -#define SRST_A_SECURE_NS_BIU 629 -#define SRST_H_SECURE_NS_BIU 630 -#define SRST_A_SECURE_S_BIU 631 -#define SRST_H_SECURE_S_BIU 632 -#define SRST_P_SECURE_S_BIU 633 -#define SRST_CRYPTO_CORE 634 - -#define SRST_CRYPTO_PKA 635 -#define SRST_CRYPTO_RNG 636 -#define SRST_A_CRYPTO 637 -#define SRST_H_CRYPTO 638 -#define SRST_KEYLADDER_CORE 639 -#define SRST_KEYLADDER_RNG 640 -#define SRST_A_KEYLADDER 641 -#define SRST_H_KEYLADDER 642 -#define SRST_P_OTPC_S 643 -#define SRST_OTPC_S 644 -#define SRST_WDT_S 645 - -#define SRST_T_WDT_S 646 -#define SRST_H_BOOTROM 647 -#define SRST_A_DCF 648 -#define SRST_P_DCF 649 -#define SRST_H_BOOTROM_NS 650 -#define SRST_P_KEYLADDER 651 -#define SRST_H_TRNG_S 652 - -#define SRST_H_TRNG_NS 653 -#define SRST_D_SDMMC_BUFFER 654 -#define SRST_H_SDMMC 655 -#define SRST_H_SDMMC_BUFFER 656 -#define SRST_SDMMC 657 -#define SRST_P_TRNG_CHK 658 -#define SRST_TRNG_S 659 +#define SRST_A_SECURE_NS_BIU 10 +#define SRST_H_SECURE_NS_BIU 11 +#define SRST_A_SECURE_S_BIU 12 +#define SRST_H_SECURE_S_BIU 13 +#define SRST_P_SECURE_S_BIU 14 +#define SRST_CRYPTO_CORE 15 + +#define SRST_CRYPTO_PKA 16 +#define SRST_CRYPTO_RNG 17 +#define SRST_A_CRYPTO 18 +#define SRST_H_CRYPTO 19 +#define SRST_KEYLADDER_CORE 25 +#define SRST_KEYLADDER_RNG 26 +#define SRST_A_KEYLADDER 27 +#define SRST_H_KEYLADDER 28 +#define SRST_P_OTPC_S 29 +#define SRST_OTPC_S 30 +#define SRST_WDT_S 31 + +#define SRST_T_WDT_S 32 +#define SRST_H_BOOTROM 33 +#define SRST_A_DCF 34 +#define SRST_P_DCF 35 +#define SRST_H_BOOTROM_NS 37 +#define SRST_P_KEYLADDER 46 +#define SRST_H_TRNG_S 47 + +#define SRST_H_TRNG_NS 48 +#define SRST_D_SDMMC_BUFFER 49 +#define SRST_H_SDMMC 50 +#define SRST_H_SDMMC_BUFFER 51 +#define SRST_SDMMC 52 +#define SRST_P_TRNG_CHK 53 +#define SRST_TRNG_S 54 #endif -- 2.41.0 ^ permalink raw reply related [flat|nested] 32+ messages in thread
* Re: [PATCH 5/6] reset: rockchip: secure reset must be used by SCMI 2023-11-07 15:55 ` [PATCH 5/6] reset: rockchip: secure reset must be used by SCMI Corentin Labbe @ 2023-11-07 16:21 ` Krzysztof Kozlowski 2023-11-07 17:35 ` Heiko Stübner 0 siblings, 1 reply; 32+ messages in thread From: Krzysztof Kozlowski @ 2023-11-07 16:21 UTC (permalink / raw) To: Corentin Labbe, davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip On 07/11/2023 16:55, Corentin Labbe wrote: > While working on the rk3588 crypto driver, I loose lot of time > understanding why resetting the IP failed. > This is due to RK3588_SECURECRU_RESET_OFFSET being in the secure world, > so impossible to operate on it from the kernel. > All resets in this block must be handled via SCMI call. > > Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > --- > drivers/clk/rockchip/rst-rk3588.c | 42 ------------ > .../dt-bindings/reset/rockchip,rk3588-cru.h | 68 +++++++++---------- Please run scripts/checkpatch.pl and fix reported warnings. Some warnings can be ignored, but the code here looks like it needs a fix. Feel free to get in touch if the warning is not clear. > 2 files changed, 34 insertions(+), 76 deletions(-) > > diff --git a/drivers/clk/rockchip/rst-rk3588.c b/drivers/clk/rockchip/rst-rk3588.c > index e855bb8d5413..6556d9d3c7ab 100644 > --- a/drivers/clk/rockchip/rst-rk3588.c > +++ b/drivers/clk/rockchip/rst-rk3588.c > @@ -16,9 +16,6 @@ > /* 0xFD7C8000 + 0x0A00 */ > #define RK3588_PHPTOPCRU_RESET_OFFSET(id, reg, bit) [id] = (0x8000*4 + reg * 16 + bit) > > -/* 0xFD7D0000 + 0x0A00 */ > -#define RK3588_SECURECRU_RESET_OFFSET(id, reg, bit) [id] = (0x10000*4 + reg * 16 + bit) > - > /* 0xFD7F0000 + 0x0A00 */ > #define RK3588_PMU1CRU_RESET_OFFSET(id, reg, bit) [id] = (0x30000*4 + reg * 16 + bit) > > @@ -806,45 +803,6 @@ static const int rk3588_register_offset[] = { > RK3588_PMU1CRU_RESET_OFFSET(SRST_P_PMU0IOC, 5, 4), > RK3588_PMU1CRU_RESET_OFFSET(SRST_P_GPIO0, 5, 5), > RK3588_PMU1CRU_RESET_OFFSET(SRST_GPIO0, 5, 6), > - > - /* SECURECRU_SOFTRST_CON00 */ > - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_NS_BIU, 0, 10), > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_NS_BIU, 0, 11), > - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_S_BIU, 0, 12), > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_S_BIU, 0, 13), > - RK3588_SECURECRU_RESET_OFFSET(SRST_P_SECURE_S_BIU, 0, 14), > - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_CORE, 0, 15), > - > - /* SECURECRU_SOFTRST_CON01 */ > - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_PKA, 1, 0), > - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_RNG, 1, 1), > - RK3588_SECURECRU_RESET_OFFSET(SRST_A_CRYPTO, 1, 2), > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_CRYPTO, 1, 3), > - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_CORE, 1, 9), > - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_RNG, 1, 10), > - RK3588_SECURECRU_RESET_OFFSET(SRST_A_KEYLADDER, 1, 11), > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_KEYLADDER, 1, 12), > - RK3588_SECURECRU_RESET_OFFSET(SRST_P_OTPC_S, 1, 13), > - RK3588_SECURECRU_RESET_OFFSET(SRST_OTPC_S, 1, 14), > - RK3588_SECURECRU_RESET_OFFSET(SRST_WDT_S, 1, 15), > - > - /* SECURECRU_SOFTRST_CON02 */ > - RK3588_SECURECRU_RESET_OFFSET(SRST_T_WDT_S, 2, 0), > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM, 2, 1), > - RK3588_SECURECRU_RESET_OFFSET(SRST_A_DCF, 2, 2), > - RK3588_SECURECRU_RESET_OFFSET(SRST_P_DCF, 2, 3), > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM_NS, 2, 5), > - RK3588_SECURECRU_RESET_OFFSET(SRST_P_KEYLADDER, 2, 14), > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_S, 2, 15), > - > - /* SECURECRU_SOFTRST_CON03 */ > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_NS, 3, 0), > - RK3588_SECURECRU_RESET_OFFSET(SRST_D_SDMMC_BUFFER, 3, 1), > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC, 3, 2), > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC_BUFFER, 3, 3), > - RK3588_SECURECRU_RESET_OFFSET(SRST_SDMMC, 3, 4), > - RK3588_SECURECRU_RESET_OFFSET(SRST_P_TRNG_CHK, 3, 5), > - RK3588_SECURECRU_RESET_OFFSET(SRST_TRNG_S, 3, 6), > }; > > void rk3588_rst_init(struct device_node *np, void __iomem *reg_base) > diff --git a/include/dt-bindings/reset/rockchip,rk3588-cru.h b/include/dt-bindings/reset/rockchip,rk3588-cru.h > index d4264db2a07f..c0d08ae78cd5 100644 > --- a/include/dt-bindings/reset/rockchip,rk3588-cru.h > +++ b/include/dt-bindings/reset/rockchip,rk3588-cru.h > @@ -716,39 +716,39 @@ > #define SRST_P_GPIO0 627 > #define SRST_GPIO0 628 > > -#define SRST_A_SECURE_NS_BIU 629 > -#define SRST_H_SECURE_NS_BIU 630 > -#define SRST_A_SECURE_S_BIU 631 > -#define SRST_H_SECURE_S_BIU 632 > -#define SRST_P_SECURE_S_BIU 633 > -#define SRST_CRYPTO_CORE 634 > - > -#define SRST_CRYPTO_PKA 635 > -#define SRST_CRYPTO_RNG 636 > -#define SRST_A_CRYPTO 637 > -#define SRST_H_CRYPTO 638 > -#define SRST_KEYLADDER_CORE 639 > -#define SRST_KEYLADDER_RNG 640 > -#define SRST_A_KEYLADDER 641 > -#define SRST_H_KEYLADDER 642 > -#define SRST_P_OTPC_S 643 > -#define SRST_OTPC_S 644 > -#define SRST_WDT_S 645 > - > -#define SRST_T_WDT_S 646 > -#define SRST_H_BOOTROM 647 > -#define SRST_A_DCF 648 > -#define SRST_P_DCF 649 > -#define SRST_H_BOOTROM_NS 650 > -#define SRST_P_KEYLADDER 651 > -#define SRST_H_TRNG_S 652 > - > -#define SRST_H_TRNG_NS 653 > -#define SRST_D_SDMMC_BUFFER 654 > -#define SRST_H_SDMMC 655 > -#define SRST_H_SDMMC_BUFFER 656 > -#define SRST_SDMMC 657 > -#define SRST_P_TRNG_CHK 658 > -#define SRST_TRNG_S 659 > +#define SRST_A_SECURE_NS_BIU 10 NAK. You just broke all users. Best regards, Krzysztof ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 5/6] reset: rockchip: secure reset must be used by SCMI 2023-11-07 16:21 ` Krzysztof Kozlowski @ 2023-11-07 17:35 ` Heiko Stübner 2023-11-07 17:45 ` Krzysztof Kozlowski 0 siblings, 1 reply; 32+ messages in thread From: Heiko Stübner @ 2023-11-07 17:35 UTC (permalink / raw) To: Corentin Labbe, davem, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, Krzysztof Kozlowski Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip Am Dienstag, 7. November 2023, 17:21:41 CET schrieb Krzysztof Kozlowski: > On 07/11/2023 16:55, Corentin Labbe wrote: > > While working on the rk3588 crypto driver, I loose lot of time > > understanding why resetting the IP failed. > > This is due to RK3588_SECURECRU_RESET_OFFSET being in the secure world, > > so impossible to operate on it from the kernel. > > All resets in this block must be handled via SCMI call. > > > > Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > > --- > > drivers/clk/rockchip/rst-rk3588.c | 42 ------------ > > .../dt-bindings/reset/rockchip,rk3588-cru.h | 68 +++++++++---------- > > Please run scripts/checkpatch.pl and fix reported warnings. Some > warnings can be ignored, but the code here looks like it needs a fix. > Feel free to get in touch if the warning is not clear. > > > 2 files changed, 34 insertions(+), 76 deletions(-) > > > > diff --git a/drivers/clk/rockchip/rst-rk3588.c b/drivers/clk/rockchip/rst-rk3588.c > > index e855bb8d5413..6556d9d3c7ab 100644 > > --- a/drivers/clk/rockchip/rst-rk3588.c > > +++ b/drivers/clk/rockchip/rst-rk3588.c > > @@ -16,9 +16,6 @@ > > /* 0xFD7C8000 + 0x0A00 */ > > #define RK3588_PHPTOPCRU_RESET_OFFSET(id, reg, bit) [id] = (0x8000*4 + reg * 16 + bit) > > > > -/* 0xFD7D0000 + 0x0A00 */ > > -#define RK3588_SECURECRU_RESET_OFFSET(id, reg, bit) [id] = (0x10000*4 + reg * 16 + bit) > > - > > /* 0xFD7F0000 + 0x0A00 */ > > #define RK3588_PMU1CRU_RESET_OFFSET(id, reg, bit) [id] = (0x30000*4 + reg * 16 + bit) > > > > @@ -806,45 +803,6 @@ static const int rk3588_register_offset[] = { > > RK3588_PMU1CRU_RESET_OFFSET(SRST_P_PMU0IOC, 5, 4), > > RK3588_PMU1CRU_RESET_OFFSET(SRST_P_GPIO0, 5, 5), > > RK3588_PMU1CRU_RESET_OFFSET(SRST_GPIO0, 5, 6), > > - > > - /* SECURECRU_SOFTRST_CON00 */ > > - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_NS_BIU, 0, 10), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_NS_BIU, 0, 11), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_S_BIU, 0, 12), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_S_BIU, 0, 13), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_P_SECURE_S_BIU, 0, 14), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_CORE, 0, 15), > > - > > - /* SECURECRU_SOFTRST_CON01 */ > > - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_PKA, 1, 0), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_RNG, 1, 1), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_A_CRYPTO, 1, 2), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_CRYPTO, 1, 3), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_CORE, 1, 9), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_RNG, 1, 10), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_A_KEYLADDER, 1, 11), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_KEYLADDER, 1, 12), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_P_OTPC_S, 1, 13), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_OTPC_S, 1, 14), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_WDT_S, 1, 15), > > - > > - /* SECURECRU_SOFTRST_CON02 */ > > - RK3588_SECURECRU_RESET_OFFSET(SRST_T_WDT_S, 2, 0), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM, 2, 1), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_A_DCF, 2, 2), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_P_DCF, 2, 3), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM_NS, 2, 5), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_P_KEYLADDER, 2, 14), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_S, 2, 15), > > - > > - /* SECURECRU_SOFTRST_CON03 */ > > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_NS, 3, 0), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_D_SDMMC_BUFFER, 3, 1), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC, 3, 2), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC_BUFFER, 3, 3), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_SDMMC, 3, 4), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_P_TRNG_CHK, 3, 5), > > - RK3588_SECURECRU_RESET_OFFSET(SRST_TRNG_S, 3, 6), > > }; > > > > void rk3588_rst_init(struct device_node *np, void __iomem *reg_base) > > diff --git a/include/dt-bindings/reset/rockchip,rk3588-cru.h b/include/dt-bindings/reset/rockchip,rk3588-cru.h > > index d4264db2a07f..c0d08ae78cd5 100644 > > --- a/include/dt-bindings/reset/rockchip,rk3588-cru.h > > +++ b/include/dt-bindings/reset/rockchip,rk3588-cru.h > > @@ -716,39 +716,39 @@ > > #define SRST_P_GPIO0 627 > > #define SRST_GPIO0 628 > > > > -#define SRST_A_SECURE_NS_BIU 629 > > -#define SRST_H_SECURE_NS_BIU 630 > > -#define SRST_A_SECURE_S_BIU 631 > > -#define SRST_H_SECURE_S_BIU 632 > > -#define SRST_P_SECURE_S_BIU 633 > > -#define SRST_CRYPTO_CORE 634 > > - > > -#define SRST_CRYPTO_PKA 635 > > -#define SRST_CRYPTO_RNG 636 > > -#define SRST_A_CRYPTO 637 > > -#define SRST_H_CRYPTO 638 > > -#define SRST_KEYLADDER_CORE 639 > > -#define SRST_KEYLADDER_RNG 640 > > -#define SRST_A_KEYLADDER 641 > > -#define SRST_H_KEYLADDER 642 > > -#define SRST_P_OTPC_S 643 > > -#define SRST_OTPC_S 644 > > -#define SRST_WDT_S 645 > > - > > -#define SRST_T_WDT_S 646 > > -#define SRST_H_BOOTROM 647 > > -#define SRST_A_DCF 648 > > -#define SRST_P_DCF 649 > > -#define SRST_H_BOOTROM_NS 650 > > -#define SRST_P_KEYLADDER 651 > > -#define SRST_H_TRNG_S 652 > > - > > -#define SRST_H_TRNG_NS 653 > > -#define SRST_D_SDMMC_BUFFER 654 > > -#define SRST_H_SDMMC 655 > > -#define SRST_H_SDMMC_BUFFER 656 > > -#define SRST_SDMMC 657 > > -#define SRST_P_TRNG_CHK 658 > > -#define SRST_TRNG_S 659 > > +#define SRST_A_SECURE_NS_BIU 10 > > NAK. You just broke all users. If I'm reading the commit message correctly, all resets in that area couldn't have any users to begin with, as the registers controlling them are in the secure space, and need a higher exception level So if anything is trying to handle these resets, would end up with some security exception right now. Though I guess we might want to use different names and not reuse the existing ones. scmi clocks use a SCMI_CLK_* id scheme, so maybe SCMI_SRST_* ? ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 5/6] reset: rockchip: secure reset must be used by SCMI 2023-11-07 17:35 ` Heiko Stübner @ 2023-11-07 17:45 ` Krzysztof Kozlowski 2023-11-11 20:51 ` Sebastian Reichel 0 siblings, 1 reply; 32+ messages in thread From: Krzysztof Kozlowski @ 2023-11-07 17:45 UTC (permalink / raw) To: Heiko Stübner, Corentin Labbe, davem, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip On 07/11/2023 18:35, Heiko Stübner wrote: > Am Dienstag, 7. November 2023, 17:21:41 CET schrieb Krzysztof Kozlowski: >> On 07/11/2023 16:55, Corentin Labbe wrote: >>> While working on the rk3588 crypto driver, I loose lot of time >>> understanding why resetting the IP failed. >>> This is due to RK3588_SECURECRU_RESET_OFFSET being in the secure world, >>> so impossible to operate on it from the kernel. >>> All resets in this block must be handled via SCMI call. >>> >>> Signed-off-by: Corentin Labbe <clabbe@baylibre.com> >>> --- >>> drivers/clk/rockchip/rst-rk3588.c | 42 ------------ >>> .../dt-bindings/reset/rockchip,rk3588-cru.h | 68 +++++++++---------- >> >> Please run scripts/checkpatch.pl and fix reported warnings. Some >> warnings can be ignored, but the code here looks like it needs a fix. >> Feel free to get in touch if the warning is not clear. >> >>> 2 files changed, 34 insertions(+), 76 deletions(-) >>> >>> diff --git a/drivers/clk/rockchip/rst-rk3588.c b/drivers/clk/rockchip/rst-rk3588.c >>> index e855bb8d5413..6556d9d3c7ab 100644 >>> --- a/drivers/clk/rockchip/rst-rk3588.c >>> +++ b/drivers/clk/rockchip/rst-rk3588.c >>> @@ -16,9 +16,6 @@ >>> /* 0xFD7C8000 + 0x0A00 */ >>> #define RK3588_PHPTOPCRU_RESET_OFFSET(id, reg, bit) [id] = (0x8000*4 + reg * 16 + bit) >>> >>> -/* 0xFD7D0000 + 0x0A00 */ >>> -#define RK3588_SECURECRU_RESET_OFFSET(id, reg, bit) [id] = (0x10000*4 + reg * 16 + bit) >>> - >>> /* 0xFD7F0000 + 0x0A00 */ >>> #define RK3588_PMU1CRU_RESET_OFFSET(id, reg, bit) [id] = (0x30000*4 + reg * 16 + bit) >>> >>> @@ -806,45 +803,6 @@ static const int rk3588_register_offset[] = { >>> RK3588_PMU1CRU_RESET_OFFSET(SRST_P_PMU0IOC, 5, 4), >>> RK3588_PMU1CRU_RESET_OFFSET(SRST_P_GPIO0, 5, 5), >>> RK3588_PMU1CRU_RESET_OFFSET(SRST_GPIO0, 5, 6), >>> - >>> - /* SECURECRU_SOFTRST_CON00 */ >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_NS_BIU, 0, 10), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_NS_BIU, 0, 11), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_S_BIU, 0, 12), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_S_BIU, 0, 13), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_SECURE_S_BIU, 0, 14), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_CORE, 0, 15), >>> - >>> - /* SECURECRU_SOFTRST_CON01 */ >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_PKA, 1, 0), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_RNG, 1, 1), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_CRYPTO, 1, 2), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_CRYPTO, 1, 3), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_CORE, 1, 9), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_RNG, 1, 10), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_KEYLADDER, 1, 11), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_KEYLADDER, 1, 12), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_OTPC_S, 1, 13), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_OTPC_S, 1, 14), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_WDT_S, 1, 15), >>> - >>> - /* SECURECRU_SOFTRST_CON02 */ >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_T_WDT_S, 2, 0), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM, 2, 1), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_DCF, 2, 2), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_DCF, 2, 3), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM_NS, 2, 5), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_KEYLADDER, 2, 14), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_S, 2, 15), >>> - >>> - /* SECURECRU_SOFTRST_CON03 */ >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_NS, 3, 0), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_D_SDMMC_BUFFER, 3, 1), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC, 3, 2), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC_BUFFER, 3, 3), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_SDMMC, 3, 4), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_TRNG_CHK, 3, 5), >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_TRNG_S, 3, 6), >>> }; >>> >>> void rk3588_rst_init(struct device_node *np, void __iomem *reg_base) >>> diff --git a/include/dt-bindings/reset/rockchip,rk3588-cru.h b/include/dt-bindings/reset/rockchip,rk3588-cru.h >>> index d4264db2a07f..c0d08ae78cd5 100644 >>> --- a/include/dt-bindings/reset/rockchip,rk3588-cru.h >>> +++ b/include/dt-bindings/reset/rockchip,rk3588-cru.h >>> @@ -716,39 +716,39 @@ >>> #define SRST_P_GPIO0 627 >>> #define SRST_GPIO0 628 >>> >>> -#define SRST_A_SECURE_NS_BIU 629 >>> -#define SRST_H_SECURE_NS_BIU 630 >>> -#define SRST_A_SECURE_S_BIU 631 >>> -#define SRST_H_SECURE_S_BIU 632 >>> -#define SRST_P_SECURE_S_BIU 633 >>> -#define SRST_CRYPTO_CORE 634 >>> - >>> -#define SRST_CRYPTO_PKA 635 >>> -#define SRST_CRYPTO_RNG 636 >>> -#define SRST_A_CRYPTO 637 >>> -#define SRST_H_CRYPTO 638 >>> -#define SRST_KEYLADDER_CORE 639 >>> -#define SRST_KEYLADDER_RNG 640 >>> -#define SRST_A_KEYLADDER 641 >>> -#define SRST_H_KEYLADDER 642 >>> -#define SRST_P_OTPC_S 643 >>> -#define SRST_OTPC_S 644 >>> -#define SRST_WDT_S 645 >>> - >>> -#define SRST_T_WDT_S 646 >>> -#define SRST_H_BOOTROM 647 >>> -#define SRST_A_DCF 648 >>> -#define SRST_P_DCF 649 >>> -#define SRST_H_BOOTROM_NS 650 >>> -#define SRST_P_KEYLADDER 651 >>> -#define SRST_H_TRNG_S 652 >>> - >>> -#define SRST_H_TRNG_NS 653 >>> -#define SRST_D_SDMMC_BUFFER 654 >>> -#define SRST_H_SDMMC 655 >>> -#define SRST_H_SDMMC_BUFFER 656 >>> -#define SRST_SDMMC 657 >>> -#define SRST_P_TRNG_CHK 658 >>> -#define SRST_TRNG_S 659 >>> +#define SRST_A_SECURE_NS_BIU 10 >> >> NAK. You just broke all users. > > If I'm reading the commit message correctly, all resets in that area > couldn't have any users to begin with, as the registers controlling them > are in the secure space, and need a higher exception level > > So if anything is trying to handle these resets, would end up with some > security exception right now. > > Though I guess we might want to use different names and not reuse the > existing ones. scmi clocks use a SCMI_CLK_* id scheme, so maybe SCMI_SRST_* ? I don't quite get what the patch wants to achieve. Why dropping driver support for given reset ID is connected with changing the value of binding for given reset? What is the point of this define SRST_A_SECURE_NS_BIU 10? Best regards, Krzysztof ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 5/6] reset: rockchip: secure reset must be used by SCMI 2023-11-07 17:45 ` Krzysztof Kozlowski @ 2023-11-11 20:51 ` Sebastian Reichel 2023-11-11 21:28 ` Krzysztof Kozlowski 0 siblings, 1 reply; 32+ messages in thread From: Sebastian Reichel @ 2023-11-11 20:51 UTC (permalink / raw) To: Krzysztof Kozlowski Cc: Heiko Stübner, Corentin Labbe, davem, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip [-- Attachment #1: Type: text/plain, Size: 7179 bytes --] Hi, On Tue, Nov 07, 2023 at 06:45:03PM +0100, Krzysztof Kozlowski wrote: > On 07/11/2023 18:35, Heiko Stübner wrote: > > Am Dienstag, 7. November 2023, 17:21:41 CET schrieb Krzysztof Kozlowski: > >> On 07/11/2023 16:55, Corentin Labbe wrote: > >>> While working on the rk3588 crypto driver, I loose lot of time > >>> understanding why resetting the IP failed. > >>> This is due to RK3588_SECURECRU_RESET_OFFSET being in the secure world, > >>> so impossible to operate on it from the kernel. > >>> All resets in this block must be handled via SCMI call. > >>> > >>> Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > >>> --- > >>> drivers/clk/rockchip/rst-rk3588.c | 42 ------------ > >>> .../dt-bindings/reset/rockchip,rk3588-cru.h | 68 +++++++++---------- > >> > >> Please run scripts/checkpatch.pl and fix reported warnings. Some > >> warnings can be ignored, but the code here looks like it needs a fix. > >> Feel free to get in touch if the warning is not clear. > >> > >>> 2 files changed, 34 insertions(+), 76 deletions(-) > >>> > >>> diff --git a/drivers/clk/rockchip/rst-rk3588.c b/drivers/clk/rockchip/rst-rk3588.c > >>> index e855bb8d5413..6556d9d3c7ab 100644 > >>> --- a/drivers/clk/rockchip/rst-rk3588.c > >>> +++ b/drivers/clk/rockchip/rst-rk3588.c > >>> @@ -16,9 +16,6 @@ > >>> /* 0xFD7C8000 + 0x0A00 */ > >>> #define RK3588_PHPTOPCRU_RESET_OFFSET(id, reg, bit) [id] = (0x8000*4 + reg * 16 + bit) > >>> > >>> -/* 0xFD7D0000 + 0x0A00 */ > >>> -#define RK3588_SECURECRU_RESET_OFFSET(id, reg, bit) [id] = (0x10000*4 + reg * 16 + bit) > >>> - > >>> /* 0xFD7F0000 + 0x0A00 */ > >>> #define RK3588_PMU1CRU_RESET_OFFSET(id, reg, bit) [id] = (0x30000*4 + reg * 16 + bit) > >>> > >>> @@ -806,45 +803,6 @@ static const int rk3588_register_offset[] = { > >>> RK3588_PMU1CRU_RESET_OFFSET(SRST_P_PMU0IOC, 5, 4), > >>> RK3588_PMU1CRU_RESET_OFFSET(SRST_P_GPIO0, 5, 5), > >>> RK3588_PMU1CRU_RESET_OFFSET(SRST_GPIO0, 5, 6), > >>> - > >>> - /* SECURECRU_SOFTRST_CON00 */ > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_NS_BIU, 0, 10), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_NS_BIU, 0, 11), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_S_BIU, 0, 12), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_S_BIU, 0, 13), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_SECURE_S_BIU, 0, 14), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_CORE, 0, 15), > >>> - > >>> - /* SECURECRU_SOFTRST_CON01 */ > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_PKA, 1, 0), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_RNG, 1, 1), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_CRYPTO, 1, 2), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_CRYPTO, 1, 3), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_CORE, 1, 9), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_RNG, 1, 10), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_KEYLADDER, 1, 11), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_KEYLADDER, 1, 12), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_OTPC_S, 1, 13), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_OTPC_S, 1, 14), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_WDT_S, 1, 15), > >>> - > >>> - /* SECURECRU_SOFTRST_CON02 */ > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_T_WDT_S, 2, 0), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM, 2, 1), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_DCF, 2, 2), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_DCF, 2, 3), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM_NS, 2, 5), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_KEYLADDER, 2, 14), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_S, 2, 15), > >>> - > >>> - /* SECURECRU_SOFTRST_CON03 */ > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_NS, 3, 0), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_D_SDMMC_BUFFER, 3, 1), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC, 3, 2), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC_BUFFER, 3, 3), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_SDMMC, 3, 4), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_TRNG_CHK, 3, 5), > >>> - RK3588_SECURECRU_RESET_OFFSET(SRST_TRNG_S, 3, 6), > >>> }; > >>> > >>> void rk3588_rst_init(struct device_node *np, void __iomem *reg_base) > >>> diff --git a/include/dt-bindings/reset/rockchip,rk3588-cru.h b/include/dt-bindings/reset/rockchip,rk3588-cru.h > >>> index d4264db2a07f..c0d08ae78cd5 100644 > >>> --- a/include/dt-bindings/reset/rockchip,rk3588-cru.h > >>> +++ b/include/dt-bindings/reset/rockchip,rk3588-cru.h > >>> @@ -716,39 +716,39 @@ > >>> #define SRST_P_GPIO0 627 > >>> #define SRST_GPIO0 628 > >>> > >>> -#define SRST_A_SECURE_NS_BIU 629 > >>> -#define SRST_H_SECURE_NS_BIU 630 > >>> -#define SRST_A_SECURE_S_BIU 631 > >>> -#define SRST_H_SECURE_S_BIU 632 > >>> -#define SRST_P_SECURE_S_BIU 633 > >>> -#define SRST_CRYPTO_CORE 634 > >>> - > >>> -#define SRST_CRYPTO_PKA 635 > >>> -#define SRST_CRYPTO_RNG 636 > >>> -#define SRST_A_CRYPTO 637 > >>> -#define SRST_H_CRYPTO 638 > >>> -#define SRST_KEYLADDER_CORE 639 > >>> -#define SRST_KEYLADDER_RNG 640 > >>> -#define SRST_A_KEYLADDER 641 > >>> -#define SRST_H_KEYLADDER 642 > >>> -#define SRST_P_OTPC_S 643 > >>> -#define SRST_OTPC_S 644 > >>> -#define SRST_WDT_S 645 > >>> - > >>> -#define SRST_T_WDT_S 646 > >>> -#define SRST_H_BOOTROM 647 > >>> -#define SRST_A_DCF 648 > >>> -#define SRST_P_DCF 649 > >>> -#define SRST_H_BOOTROM_NS 650 > >>> -#define SRST_P_KEYLADDER 651 > >>> -#define SRST_H_TRNG_S 652 > >>> - > >>> -#define SRST_H_TRNG_NS 653 > >>> -#define SRST_D_SDMMC_BUFFER 654 > >>> -#define SRST_H_SDMMC 655 > >>> -#define SRST_H_SDMMC_BUFFER 656 > >>> -#define SRST_SDMMC 657 > >>> -#define SRST_P_TRNG_CHK 658 > >>> -#define SRST_TRNG_S 659 > >>> +#define SRST_A_SECURE_NS_BIU 10 > >> > >> NAK. You just broke all users. > > > > If I'm reading the commit message correctly, all resets in that area > > couldn't have any users to begin with, as the registers controlling them > > are in the secure space, and need a higher exception level > > > > So if anything is trying to handle these resets, would end up with some > > security exception right now. > > > > Though I guess we might want to use different names and not reuse the > > existing ones. scmi clocks use a SCMI_CLK_* id scheme, so maybe SCMI_SRST_* ? > > I don't quite get what the patch wants to achieve. Why dropping driver > support for given reset ID is connected with changing the value of > binding for given reset? > > What is the point of this define SRST_A_SECURE_NS_BIU 10? This is about two different reset controllers. The IDs defined here are used by the operating system to access the correct registers. The kernel has a LUT from the ID to a register addresses, which is something you asked for during upstreaming. The ID defined by Corentin is for reset control via SCMI firmware, which has different number scheme than Linux. To me the suggestion from Heiko looks sensible (i.e. create a new ID scheme and keep the current one unchanged). Greetings, -- Sebastian [-- Attachment #2: signature.asc --] [-- Type: application/pgp-signature, Size: 833 bytes --] ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 5/6] reset: rockchip: secure reset must be used by SCMI 2023-11-11 20:51 ` Sebastian Reichel @ 2023-11-11 21:28 ` Krzysztof Kozlowski 2023-11-12 20:26 ` Sebastian Reichel 0 siblings, 1 reply; 32+ messages in thread From: Krzysztof Kozlowski @ 2023-11-11 21:28 UTC (permalink / raw) To: Sebastian Reichel Cc: Heiko Stübner, Corentin Labbe, davem, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip On 11/11/2023 21:51, Sebastian Reichel wrote: > Hi, > > On Tue, Nov 07, 2023 at 06:45:03PM +0100, Krzysztof Kozlowski wrote: >> On 07/11/2023 18:35, Heiko Stübner wrote: >>> Am Dienstag, 7. November 2023, 17:21:41 CET schrieb Krzysztof Kozlowski: >>>> On 07/11/2023 16:55, Corentin Labbe wrote: >>>>> While working on the rk3588 crypto driver, I loose lot of time >>>>> understanding why resetting the IP failed. >>>>> This is due to RK3588_SECURECRU_RESET_OFFSET being in the secure world, >>>>> so impossible to operate on it from the kernel. >>>>> All resets in this block must be handled via SCMI call. >>>>> >>>>> Signed-off-by: Corentin Labbe <clabbe@baylibre.com> >>>>> --- >>>>> drivers/clk/rockchip/rst-rk3588.c | 42 ------------ >>>>> .../dt-bindings/reset/rockchip,rk3588-cru.h | 68 +++++++++---------- >>>> >>>> Please run scripts/checkpatch.pl and fix reported warnings. Some >>>> warnings can be ignored, but the code here looks like it needs a fix. >>>> Feel free to get in touch if the warning is not clear. >>>> >>>>> 2 files changed, 34 insertions(+), 76 deletions(-) >>>>> >>>>> diff --git a/drivers/clk/rockchip/rst-rk3588.c b/drivers/clk/rockchip/rst-rk3588.c >>>>> index e855bb8d5413..6556d9d3c7ab 100644 >>>>> --- a/drivers/clk/rockchip/rst-rk3588.c >>>>> +++ b/drivers/clk/rockchip/rst-rk3588.c >>>>> @@ -16,9 +16,6 @@ >>>>> /* 0xFD7C8000 + 0x0A00 */ >>>>> #define RK3588_PHPTOPCRU_RESET_OFFSET(id, reg, bit) [id] = (0x8000*4 + reg * 16 + bit) >>>>> >>>>> -/* 0xFD7D0000 + 0x0A00 */ >>>>> -#define RK3588_SECURECRU_RESET_OFFSET(id, reg, bit) [id] = (0x10000*4 + reg * 16 + bit) >>>>> - >>>>> /* 0xFD7F0000 + 0x0A00 */ >>>>> #define RK3588_PMU1CRU_RESET_OFFSET(id, reg, bit) [id] = (0x30000*4 + reg * 16 + bit) >>>>> >>>>> @@ -806,45 +803,6 @@ static const int rk3588_register_offset[] = { >>>>> RK3588_PMU1CRU_RESET_OFFSET(SRST_P_PMU0IOC, 5, 4), >>>>> RK3588_PMU1CRU_RESET_OFFSET(SRST_P_GPIO0, 5, 5), >>>>> RK3588_PMU1CRU_RESET_OFFSET(SRST_GPIO0, 5, 6), >>>>> - >>>>> - /* SECURECRU_SOFTRST_CON00 */ >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_NS_BIU, 0, 10), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_NS_BIU, 0, 11), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_S_BIU, 0, 12), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_S_BIU, 0, 13), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_SECURE_S_BIU, 0, 14), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_CORE, 0, 15), >>>>> - >>>>> - /* SECURECRU_SOFTRST_CON01 */ >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_PKA, 1, 0), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_RNG, 1, 1), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_CRYPTO, 1, 2), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_CRYPTO, 1, 3), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_CORE, 1, 9), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_RNG, 1, 10), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_KEYLADDER, 1, 11), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_KEYLADDER, 1, 12), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_OTPC_S, 1, 13), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_OTPC_S, 1, 14), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_WDT_S, 1, 15), >>>>> - >>>>> - /* SECURECRU_SOFTRST_CON02 */ >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_T_WDT_S, 2, 0), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM, 2, 1), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_DCF, 2, 2), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_DCF, 2, 3), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM_NS, 2, 5), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_KEYLADDER, 2, 14), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_S, 2, 15), >>>>> - >>>>> - /* SECURECRU_SOFTRST_CON03 */ >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_NS, 3, 0), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_D_SDMMC_BUFFER, 3, 1), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC, 3, 2), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC_BUFFER, 3, 3), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_SDMMC, 3, 4), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_TRNG_CHK, 3, 5), >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_TRNG_S, 3, 6), >>>>> }; >>>>> >>>>> void rk3588_rst_init(struct device_node *np, void __iomem *reg_base) >>>>> diff --git a/include/dt-bindings/reset/rockchip,rk3588-cru.h b/include/dt-bindings/reset/rockchip,rk3588-cru.h >>>>> index d4264db2a07f..c0d08ae78cd5 100644 >>>>> --- a/include/dt-bindings/reset/rockchip,rk3588-cru.h >>>>> +++ b/include/dt-bindings/reset/rockchip,rk3588-cru.h >>>>> @@ -716,39 +716,39 @@ >>>>> #define SRST_P_GPIO0 627 >>>>> #define SRST_GPIO0 628 >>>>> >>>>> -#define SRST_A_SECURE_NS_BIU 629 >>>>> -#define SRST_H_SECURE_NS_BIU 630 >>>>> -#define SRST_A_SECURE_S_BIU 631 >>>>> -#define SRST_H_SECURE_S_BIU 632 >>>>> -#define SRST_P_SECURE_S_BIU 633 >>>>> -#define SRST_CRYPTO_CORE 634 >>>>> - >>>>> -#define SRST_CRYPTO_PKA 635 >>>>> -#define SRST_CRYPTO_RNG 636 >>>>> -#define SRST_A_CRYPTO 637 >>>>> -#define SRST_H_CRYPTO 638 >>>>> -#define SRST_KEYLADDER_CORE 639 >>>>> -#define SRST_KEYLADDER_RNG 640 >>>>> -#define SRST_A_KEYLADDER 641 >>>>> -#define SRST_H_KEYLADDER 642 >>>>> -#define SRST_P_OTPC_S 643 >>>>> -#define SRST_OTPC_S 644 >>>>> -#define SRST_WDT_S 645 >>>>> - >>>>> -#define SRST_T_WDT_S 646 >>>>> -#define SRST_H_BOOTROM 647 >>>>> -#define SRST_A_DCF 648 >>>>> -#define SRST_P_DCF 649 >>>>> -#define SRST_H_BOOTROM_NS 650 >>>>> -#define SRST_P_KEYLADDER 651 >>>>> -#define SRST_H_TRNG_S 652 >>>>> - >>>>> -#define SRST_H_TRNG_NS 653 >>>>> -#define SRST_D_SDMMC_BUFFER 654 >>>>> -#define SRST_H_SDMMC 655 >>>>> -#define SRST_H_SDMMC_BUFFER 656 >>>>> -#define SRST_SDMMC 657 >>>>> -#define SRST_P_TRNG_CHK 658 >>>>> -#define SRST_TRNG_S 659 >>>>> +#define SRST_A_SECURE_NS_BIU 10 >>>> >>>> NAK. You just broke all users. >>> >>> If I'm reading the commit message correctly, all resets in that area >>> couldn't have any users to begin with, as the registers controlling them >>> are in the secure space, and need a higher exception level >>> >>> So if anything is trying to handle these resets, would end up with some >>> security exception right now. >>> >>> Though I guess we might want to use different names and not reuse the >>> existing ones. scmi clocks use a SCMI_CLK_* id scheme, so maybe SCMI_SRST_* ? >> >> I don't quite get what the patch wants to achieve. Why dropping driver >> support for given reset ID is connected with changing the value of >> binding for given reset? >> >> What is the point of this define SRST_A_SECURE_NS_BIU 10? > > This is about two different reset controllers. The IDs defined here > are used by the operating system to access the correct registers. > The kernel has a LUT from the ID to a register addresses, which is > something you asked for during upstreaming. > > The ID defined by Corentin is for reset control via SCMI firmware, > which has different number scheme than Linux. To me the suggestion > from Heiko looks sensible (i.e. create a new ID scheme and keep the > current one unchanged). So the binding is not for Linux but for FW? This should be explained in the commit msg. Best regards, Krzysztof ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 5/6] reset: rockchip: secure reset must be used by SCMI 2023-11-11 21:28 ` Krzysztof Kozlowski @ 2023-11-12 20:26 ` Sebastian Reichel 2023-11-20 12:42 ` Corentin LABBE 0 siblings, 1 reply; 32+ messages in thread From: Sebastian Reichel @ 2023-11-12 20:26 UTC (permalink / raw) To: Krzysztof Kozlowski Cc: Heiko Stübner, Corentin Labbe, davem, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip Hi, On Sat, Nov 11, 2023 at 10:28:59PM +0100, Krzysztof Kozlowski wrote: > On 11/11/2023 21:51, Sebastian Reichel wrote: > > Hi, > > > > On Tue, Nov 07, 2023 at 06:45:03PM +0100, Krzysztof Kozlowski wrote: > >> On 07/11/2023 18:35, Heiko Stübner wrote: > >>> Am Dienstag, 7. November 2023, 17:21:41 CET schrieb Krzysztof Kozlowski: > >>>> On 07/11/2023 16:55, Corentin Labbe wrote: > >>>>> While working on the rk3588 crypto driver, I loose lot of time > >>>>> understanding why resetting the IP failed. > >>>>> This is due to RK3588_SECURECRU_RESET_OFFSET being in the secure world, > >>>>> so impossible to operate on it from the kernel. > >>>>> All resets in this block must be handled via SCMI call. > >>>>> > >>>>> Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > >>>>> --- > >>>>> drivers/clk/rockchip/rst-rk3588.c | 42 ------------ > >>>>> .../dt-bindings/reset/rockchip,rk3588-cru.h | 68 +++++++++---------- > >>>> > >>>> Please run scripts/checkpatch.pl and fix reported warnings. Some > >>>> warnings can be ignored, but the code here looks like it needs a fix. > >>>> Feel free to get in touch if the warning is not clear. > >>>> > >>>>> 2 files changed, 34 insertions(+), 76 deletions(-) > >>>>> > >>>>> diff --git a/drivers/clk/rockchip/rst-rk3588.c b/drivers/clk/rockchip/rst-rk3588.c > >>>>> index e855bb8d5413..6556d9d3c7ab 100644 > >>>>> --- a/drivers/clk/rockchip/rst-rk3588.c > >>>>> +++ b/drivers/clk/rockchip/rst-rk3588.c > >>>>> @@ -16,9 +16,6 @@ > >>>>> /* 0xFD7C8000 + 0x0A00 */ > >>>>> #define RK3588_PHPTOPCRU_RESET_OFFSET(id, reg, bit) [id] = (0x8000*4 + reg * 16 + bit) > >>>>> > >>>>> -/* 0xFD7D0000 + 0x0A00 */ > >>>>> -#define RK3588_SECURECRU_RESET_OFFSET(id, reg, bit) [id] = (0x10000*4 + reg * 16 + bit) > >>>>> - > >>>>> /* 0xFD7F0000 + 0x0A00 */ > >>>>> #define RK3588_PMU1CRU_RESET_OFFSET(id, reg, bit) [id] = (0x30000*4 + reg * 16 + bit) > >>>>> > >>>>> @@ -806,45 +803,6 @@ static const int rk3588_register_offset[] = { > >>>>> RK3588_PMU1CRU_RESET_OFFSET(SRST_P_PMU0IOC, 5, 4), > >>>>> RK3588_PMU1CRU_RESET_OFFSET(SRST_P_GPIO0, 5, 5), > >>>>> RK3588_PMU1CRU_RESET_OFFSET(SRST_GPIO0, 5, 6), > >>>>> - > >>>>> - /* SECURECRU_SOFTRST_CON00 */ > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_NS_BIU, 0, 10), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_NS_BIU, 0, 11), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_S_BIU, 0, 12), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_S_BIU, 0, 13), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_SECURE_S_BIU, 0, 14), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_CORE, 0, 15), > >>>>> - > >>>>> - /* SECURECRU_SOFTRST_CON01 */ > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_PKA, 1, 0), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_RNG, 1, 1), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_CRYPTO, 1, 2), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_CRYPTO, 1, 3), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_CORE, 1, 9), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_RNG, 1, 10), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_KEYLADDER, 1, 11), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_KEYLADDER, 1, 12), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_OTPC_S, 1, 13), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_OTPC_S, 1, 14), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_WDT_S, 1, 15), > >>>>> - > >>>>> - /* SECURECRU_SOFTRST_CON02 */ > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_T_WDT_S, 2, 0), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM, 2, 1), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_DCF, 2, 2), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_DCF, 2, 3), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM_NS, 2, 5), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_KEYLADDER, 2, 14), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_S, 2, 15), > >>>>> - > >>>>> - /* SECURECRU_SOFTRST_CON03 */ > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_NS, 3, 0), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_D_SDMMC_BUFFER, 3, 1), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC, 3, 2), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC_BUFFER, 3, 3), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_SDMMC, 3, 4), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_TRNG_CHK, 3, 5), > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_TRNG_S, 3, 6), > >>>>> }; > >>>>> > >>>>> void rk3588_rst_init(struct device_node *np, void __iomem *reg_base) > >>>>> diff --git a/include/dt-bindings/reset/rockchip,rk3588-cru.h b/include/dt-bindings/reset/rockchip,rk3588-cru.h > >>>>> index d4264db2a07f..c0d08ae78cd5 100644 > >>>>> --- a/include/dt-bindings/reset/rockchip,rk3588-cru.h > >>>>> +++ b/include/dt-bindings/reset/rockchip,rk3588-cru.h > >>>>> @@ -716,39 +716,39 @@ > >>>>> #define SRST_P_GPIO0 627 > >>>>> #define SRST_GPIO0 628 > >>>>> > >>>>> -#define SRST_A_SECURE_NS_BIU 629 > >>>>> -#define SRST_H_SECURE_NS_BIU 630 > >>>>> -#define SRST_A_SECURE_S_BIU 631 > >>>>> -#define SRST_H_SECURE_S_BIU 632 > >>>>> -#define SRST_P_SECURE_S_BIU 633 > >>>>> -#define SRST_CRYPTO_CORE 634 > >>>>> - > >>>>> -#define SRST_CRYPTO_PKA 635 > >>>>> -#define SRST_CRYPTO_RNG 636 > >>>>> -#define SRST_A_CRYPTO 637 > >>>>> -#define SRST_H_CRYPTO 638 > >>>>> -#define SRST_KEYLADDER_CORE 639 > >>>>> -#define SRST_KEYLADDER_RNG 640 > >>>>> -#define SRST_A_KEYLADDER 641 > >>>>> -#define SRST_H_KEYLADDER 642 > >>>>> -#define SRST_P_OTPC_S 643 > >>>>> -#define SRST_OTPC_S 644 > >>>>> -#define SRST_WDT_S 645 > >>>>> - > >>>>> -#define SRST_T_WDT_S 646 > >>>>> -#define SRST_H_BOOTROM 647 > >>>>> -#define SRST_A_DCF 648 > >>>>> -#define SRST_P_DCF 649 > >>>>> -#define SRST_H_BOOTROM_NS 650 > >>>>> -#define SRST_P_KEYLADDER 651 > >>>>> -#define SRST_H_TRNG_S 652 > >>>>> - > >>>>> -#define SRST_H_TRNG_NS 653 > >>>>> -#define SRST_D_SDMMC_BUFFER 654 > >>>>> -#define SRST_H_SDMMC 655 > >>>>> -#define SRST_H_SDMMC_BUFFER 656 > >>>>> -#define SRST_SDMMC 657 > >>>>> -#define SRST_P_TRNG_CHK 658 > >>>>> -#define SRST_TRNG_S 659 > >>>>> +#define SRST_A_SECURE_NS_BIU 10 > >>>> > >>>> NAK. You just broke all users. > >>> > >>> If I'm reading the commit message correctly, all resets in that area > >>> couldn't have any users to begin with, as the registers controlling them > >>> are in the secure space, and need a higher exception level > >>> > >>> So if anything is trying to handle these resets, would end up with some > >>> security exception right now. > >>> > >>> Though I guess we might want to use different names and not reuse the > >>> existing ones. scmi clocks use a SCMI_CLK_* id scheme, so maybe SCMI_SRST_* ? > >> > >> I don't quite get what the patch wants to achieve. Why dropping driver > >> support for given reset ID is connected with changing the value of > >> binding for given reset? > >> > >> What is the point of this define SRST_A_SECURE_NS_BIU 10? > > > > This is about two different reset controllers. The IDs defined here > > are used by the operating system to access the correct registers. > > The kernel has a LUT from the ID to a register addresses, which is > > something you asked for during upstreaming. > > > > The ID defined by Corentin is for reset control via SCMI firmware, > > which has different number scheme than Linux. To me the suggestion > > from Heiko looks sensible (i.e. create a new ID scheme and keep the > > current one unchanged). > > So the binding is not for Linux but for FW? This should be explained in > the commit msg. No. The current binding describes reset IDs, which are mapped by the Linux driver to register offsets in the CRU (clock-reset-unit). But accessing the crypto reset line directly from Linux (which usually does not run in secure state) will fail. Accessing it from correct security context with the current binding is fine though. Considering we are sharing the bindings with e.g. U-Boot, I suggest to keep the currently defined IDs. But Corentin tries to get this running on Linux. For that he needs to ask the (SCMI) firmware running in secure state to please take care of the reset. The firmware is using different reset IDs (apparently the ones used by downstream Linux, which are derived from register offset). In DT the difference looks like this (check the different phandles): #define SRST_A_SECURE_NS_BIU 629 crypto-old { // existing binding from Linux perspective // reset via direct CRU access // NOTE: permission denied resets = <&cru SRST_A_SECURE_NS_BIU>; }; #define SCMI_RST_A_SECURE_NS_BIU 10 crypto-new { // new binding from Linux perspective // reset via SCMI firmware request resets = <&scmi SCMI_RST_A_SECURE_NS_BIU>; }; Instead of introducing SCMI_RST_A_SECURE_NS_BIU, Corentin currently just redefines SRST_A_SECURE_NS_BIU. This is quite misleading. If somebody does '<&cru SRST_A_SECURE_NS_BIU>' with the '10' value for SCMI, it instead resets SRST_A_TOP_M300_BIU. So my suggestion is to go with the suggestion from Heiko and introduce SCMI_RST_A_SECURE_NS_BIU (or something similar). That also matches how the SCMI clks on RK3588 and some other platforms. See e.g.: of include/dt-bindings/clock/rockchip,rk3588-cru.h. Greetings, -- Sebastian ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 5/6] reset: rockchip: secure reset must be used by SCMI 2023-11-12 20:26 ` Sebastian Reichel @ 2023-11-20 12:42 ` Corentin LABBE 0 siblings, 0 replies; 32+ messages in thread From: Corentin LABBE @ 2023-11-20 12:42 UTC (permalink / raw) To: Sebastian Reichel Cc: Krzysztof Kozlowski, Heiko Stübner, davem, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip Le Sun, Nov 12, 2023 at 09:26:39PM +0100, Sebastian Reichel a écrit : > Hi, > > On Sat, Nov 11, 2023 at 10:28:59PM +0100, Krzysztof Kozlowski wrote: > > On 11/11/2023 21:51, Sebastian Reichel wrote: > > > Hi, > > > > > > On Tue, Nov 07, 2023 at 06:45:03PM +0100, Krzysztof Kozlowski wrote: > > >> On 07/11/2023 18:35, Heiko Stübner wrote: > > >>> Am Dienstag, 7. November 2023, 17:21:41 CET schrieb Krzysztof Kozlowski: > > >>>> On 07/11/2023 16:55, Corentin Labbe wrote: > > >>>>> While working on the rk3588 crypto driver, I loose lot of time > > >>>>> understanding why resetting the IP failed. > > >>>>> This is due to RK3588_SECURECRU_RESET_OFFSET being in the secure world, > > >>>>> so impossible to operate on it from the kernel. > > >>>>> All resets in this block must be handled via SCMI call. > > >>>>> > > >>>>> Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > > >>>>> --- > > >>>>> drivers/clk/rockchip/rst-rk3588.c | 42 ------------ > > >>>>> .../dt-bindings/reset/rockchip,rk3588-cru.h | 68 +++++++++---------- > > >>>> > > >>>> Please run scripts/checkpatch.pl and fix reported warnings. Some > > >>>> warnings can be ignored, but the code here looks like it needs a fix. > > >>>> Feel free to get in touch if the warning is not clear. > > >>>> > > >>>>> 2 files changed, 34 insertions(+), 76 deletions(-) > > >>>>> > > >>>>> diff --git a/drivers/clk/rockchip/rst-rk3588.c b/drivers/clk/rockchip/rst-rk3588.c > > >>>>> index e855bb8d5413..6556d9d3c7ab 100644 > > >>>>> --- a/drivers/clk/rockchip/rst-rk3588.c > > >>>>> +++ b/drivers/clk/rockchip/rst-rk3588.c > > >>>>> @@ -16,9 +16,6 @@ > > >>>>> /* 0xFD7C8000 + 0x0A00 */ > > >>>>> #define RK3588_PHPTOPCRU_RESET_OFFSET(id, reg, bit) [id] = (0x8000*4 + reg * 16 + bit) > > >>>>> > > >>>>> -/* 0xFD7D0000 + 0x0A00 */ > > >>>>> -#define RK3588_SECURECRU_RESET_OFFSET(id, reg, bit) [id] = (0x10000*4 + reg * 16 + bit) > > >>>>> - > > >>>>> /* 0xFD7F0000 + 0x0A00 */ > > >>>>> #define RK3588_PMU1CRU_RESET_OFFSET(id, reg, bit) [id] = (0x30000*4 + reg * 16 + bit) > > >>>>> > > >>>>> @@ -806,45 +803,6 @@ static const int rk3588_register_offset[] = { > > >>>>> RK3588_PMU1CRU_RESET_OFFSET(SRST_P_PMU0IOC, 5, 4), > > >>>>> RK3588_PMU1CRU_RESET_OFFSET(SRST_P_GPIO0, 5, 5), > > >>>>> RK3588_PMU1CRU_RESET_OFFSET(SRST_GPIO0, 5, 6), > > >>>>> - > > >>>>> - /* SECURECRU_SOFTRST_CON00 */ > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_NS_BIU, 0, 10), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_NS_BIU, 0, 11), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_SECURE_S_BIU, 0, 12), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SECURE_S_BIU, 0, 13), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_SECURE_S_BIU, 0, 14), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_CORE, 0, 15), > > >>>>> - > > >>>>> - /* SECURECRU_SOFTRST_CON01 */ > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_PKA, 1, 0), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_CRYPTO_RNG, 1, 1), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_CRYPTO, 1, 2), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_CRYPTO, 1, 3), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_CORE, 1, 9), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_KEYLADDER_RNG, 1, 10), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_KEYLADDER, 1, 11), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_KEYLADDER, 1, 12), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_OTPC_S, 1, 13), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_OTPC_S, 1, 14), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_WDT_S, 1, 15), > > >>>>> - > > >>>>> - /* SECURECRU_SOFTRST_CON02 */ > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_T_WDT_S, 2, 0), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM, 2, 1), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_A_DCF, 2, 2), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_DCF, 2, 3), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_BOOTROM_NS, 2, 5), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_KEYLADDER, 2, 14), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_S, 2, 15), > > >>>>> - > > >>>>> - /* SECURECRU_SOFTRST_CON03 */ > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_TRNG_NS, 3, 0), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_D_SDMMC_BUFFER, 3, 1), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC, 3, 2), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_H_SDMMC_BUFFER, 3, 3), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_SDMMC, 3, 4), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_P_TRNG_CHK, 3, 5), > > >>>>> - RK3588_SECURECRU_RESET_OFFSET(SRST_TRNG_S, 3, 6), > > >>>>> }; > > >>>>> > > >>>>> void rk3588_rst_init(struct device_node *np, void __iomem *reg_base) > > >>>>> diff --git a/include/dt-bindings/reset/rockchip,rk3588-cru.h b/include/dt-bindings/reset/rockchip,rk3588-cru.h > > >>>>> index d4264db2a07f..c0d08ae78cd5 100644 > > >>>>> --- a/include/dt-bindings/reset/rockchip,rk3588-cru.h > > >>>>> +++ b/include/dt-bindings/reset/rockchip,rk3588-cru.h > > >>>>> @@ -716,39 +716,39 @@ > > >>>>> #define SRST_P_GPIO0 627 > > >>>>> #define SRST_GPIO0 628 > > >>>>> > > >>>>> -#define SRST_A_SECURE_NS_BIU 629 > > >>>>> -#define SRST_H_SECURE_NS_BIU 630 > > >>>>> -#define SRST_A_SECURE_S_BIU 631 > > >>>>> -#define SRST_H_SECURE_S_BIU 632 > > >>>>> -#define SRST_P_SECURE_S_BIU 633 > > >>>>> -#define SRST_CRYPTO_CORE 634 > > >>>>> - > > >>>>> -#define SRST_CRYPTO_PKA 635 > > >>>>> -#define SRST_CRYPTO_RNG 636 > > >>>>> -#define SRST_A_CRYPTO 637 > > >>>>> -#define SRST_H_CRYPTO 638 > > >>>>> -#define SRST_KEYLADDER_CORE 639 > > >>>>> -#define SRST_KEYLADDER_RNG 640 > > >>>>> -#define SRST_A_KEYLADDER 641 > > >>>>> -#define SRST_H_KEYLADDER 642 > > >>>>> -#define SRST_P_OTPC_S 643 > > >>>>> -#define SRST_OTPC_S 644 > > >>>>> -#define SRST_WDT_S 645 > > >>>>> - > > >>>>> -#define SRST_T_WDT_S 646 > > >>>>> -#define SRST_H_BOOTROM 647 > > >>>>> -#define SRST_A_DCF 648 > > >>>>> -#define SRST_P_DCF 649 > > >>>>> -#define SRST_H_BOOTROM_NS 650 > > >>>>> -#define SRST_P_KEYLADDER 651 > > >>>>> -#define SRST_H_TRNG_S 652 > > >>>>> - > > >>>>> -#define SRST_H_TRNG_NS 653 > > >>>>> -#define SRST_D_SDMMC_BUFFER 654 > > >>>>> -#define SRST_H_SDMMC 655 > > >>>>> -#define SRST_H_SDMMC_BUFFER 656 > > >>>>> -#define SRST_SDMMC 657 > > >>>>> -#define SRST_P_TRNG_CHK 658 > > >>>>> -#define SRST_TRNG_S 659 > > >>>>> +#define SRST_A_SECURE_NS_BIU 10 > > >>>> > > >>>> NAK. You just broke all users. > > >>> > > >>> If I'm reading the commit message correctly, all resets in that area > > >>> couldn't have any users to begin with, as the registers controlling them > > >>> are in the secure space, and need a higher exception level > > >>> > > >>> So if anything is trying to handle these resets, would end up with some > > >>> security exception right now. > > >>> > > >>> Though I guess we might want to use different names and not reuse the > > >>> existing ones. scmi clocks use a SCMI_CLK_* id scheme, so maybe SCMI_SRST_* ? > > >> > > >> I don't quite get what the patch wants to achieve. Why dropping driver > > >> support for given reset ID is connected with changing the value of > > >> binding for given reset? > > >> > > >> What is the point of this define SRST_A_SECURE_NS_BIU 10? > > > > > > This is about two different reset controllers. The IDs defined here > > > are used by the operating system to access the correct registers. > > > The kernel has a LUT from the ID to a register addresses, which is > > > something you asked for during upstreaming. > > > > > > The ID defined by Corentin is for reset control via SCMI firmware, > > > which has different number scheme than Linux. To me the suggestion > > > from Heiko looks sensible (i.e. create a new ID scheme and keep the > > > current one unchanged). > > > > So the binding is not for Linux but for FW? This should be explained in > > the commit msg. > > No. > > The current binding describes reset IDs, which are mapped by the > Linux driver to register offsets in the CRU (clock-reset-unit). > But accessing the crypto reset line directly from Linux (which > usually does not run in secure state) will fail. Accessing it > from correct security context with the current binding is fine > though. Considering we are sharing the bindings with e.g. > U-Boot, I suggest to keep the currently defined IDs. > > But Corentin tries to get this running on Linux. For that he > needs to ask the (SCMI) firmware running in secure state to > please take care of the reset. The firmware is using different > reset IDs (apparently the ones used by downstream Linux, which > are derived from register offset). > > In DT the difference looks like this (check the different phandles): > > #define SRST_A_SECURE_NS_BIU 629 > crypto-old { > // existing binding from Linux perspective > // reset via direct CRU access > // NOTE: permission denied > resets = <&cru SRST_A_SECURE_NS_BIU>; > }; > > #define SCMI_RST_A_SECURE_NS_BIU 10 > crypto-new { > // new binding from Linux perspective > // reset via SCMI firmware request > resets = <&scmi SCMI_RST_A_SECURE_NS_BIU>; > }; > > Instead of introducing SCMI_RST_A_SECURE_NS_BIU, Corentin > currently just redefines SRST_A_SECURE_NS_BIU. This is quite > misleading. If somebody does '<&cru SRST_A_SECURE_NS_BIU>' > with the '10' value for SCMI, it instead resets > SRST_A_TOP_M300_BIU. > > So my suggestion is to go with the suggestion from Heiko and > introduce SCMI_RST_A_SECURE_NS_BIU (or something similar). > That also matches how the SCMI clks on RK3588 and some other > platforms. See e.g.: > > of include/dt-bindings/clock/rockchip,rk3588-cru.h. > > Greetings, > > -- Sebastian Thanks for yours suggestions, I will do it that way. Regards ^ permalink raw reply [flat|nested] 32+ messages in thread
* [PATCH 6/6] crypto: rockchip: add rk3588 driver 2023-11-07 15:55 [PATCH 0/6] crypto: rockchip: add support for rk3588/rk3568 Corentin Labbe ` (4 preceding siblings ...) 2023-11-07 15:55 ` [PATCH 5/6] reset: rockchip: secure reset must be used by SCMI Corentin Labbe @ 2023-11-07 15:55 ` Corentin Labbe 2023-11-07 16:35 ` Krzysztof Kozlowski 2023-11-12 14:04 ` Aw: " Frank Wunderlich 5 siblings, 2 replies; 32+ messages in thread From: Corentin Labbe @ 2023-11-07 15:55 UTC (permalink / raw) To: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip, Corentin Labbe RK3588 have a new crypto IP, this patch adds basic support for it. Only hashes and cipher are handled for the moment. Signed-off-by: Corentin Labbe <clabbe@baylibre.com> --- drivers/crypto/Kconfig | 29 + drivers/crypto/rockchip/Makefile | 5 + drivers/crypto/rockchip/rk2_crypto.c | 739 ++++++++++++++++++ drivers/crypto/rockchip/rk2_crypto.h | 246 ++++++ drivers/crypto/rockchip/rk2_crypto_ahash.c | 344 ++++++++ drivers/crypto/rockchip/rk2_crypto_skcipher.c | 576 ++++++++++++++ 6 files changed, 1939 insertions(+) create mode 100644 drivers/crypto/rockchip/rk2_crypto.c create mode 100644 drivers/crypto/rockchip/rk2_crypto.h create mode 100644 drivers/crypto/rockchip/rk2_crypto_ahash.c create mode 100644 drivers/crypto/rockchip/rk2_crypto_skcipher.c diff --git a/drivers/crypto/Kconfig b/drivers/crypto/Kconfig index 79c3bb9c99c3..b6a2027b1f9a 100644 --- a/drivers/crypto/Kconfig +++ b/drivers/crypto/Kconfig @@ -660,6 +660,35 @@ config CRYPTO_DEV_ROCKCHIP_DEBUG the number of requests per algorithm and other internal stats. +config CRYPTO_DEV_ROCKCHIP2 + tristate "Rockchip's cryptographic offloader V2" + depends on OF && ARCH_ROCKCHIP + depends on PM + select CRYPTO_ECB + select CRYPTO_CBC + select CRYPTO_AES + select CRYPTO_MD5 + select CRYPTO_SHA1 + select CRYPTO_SHA256 + select CRYPTO_SHA512 + select CRYPTO_SM3_GENERIC + select CRYPTO_HASH + select CRYPTO_SKCIPHER + select CRYPTO_ENGINE + + help + This driver interfaces with the hardware crypto offloader present + on RK3566, RK3568 and RK3588. + +config CRYPTO_DEV_ROCKCHIP2_DEBUG + bool "Enable Rockchip V2 crypto stats" + depends on CRYPTO_DEV_ROCKCHIP2 + depends on DEBUG_FS + help + Say y to enable Rockchip crypto debug stats. + This will create /sys/kernel/debug/rk3588_crypto/stats for displaying + the number of requests per algorithm and other internal stats. + config CRYPTO_DEV_ZYNQMP_AES tristate "Support for Xilinx ZynqMP AES hw accelerator" depends on ZYNQMP_FIRMWARE || COMPILE_TEST diff --git a/drivers/crypto/rockchip/Makefile b/drivers/crypto/rockchip/Makefile index 785277aca71e..452a12ff6538 100644 --- a/drivers/crypto/rockchip/Makefile +++ b/drivers/crypto/rockchip/Makefile @@ -3,3 +3,8 @@ obj-$(CONFIG_CRYPTO_DEV_ROCKCHIP) += rk_crypto.o rk_crypto-objs := rk3288_crypto.o \ rk3288_crypto_skcipher.o \ rk3288_crypto_ahash.o + +obj-$(CONFIG_CRYPTO_DEV_ROCKCHIP2) += rk_crypto2.o +rk_crypto2-objs := rk2_crypto.o \ + rk2_crypto_skcipher.o \ + rk2_crypto_ahash.o diff --git a/drivers/crypto/rockchip/rk2_crypto.c b/drivers/crypto/rockchip/rk2_crypto.c new file mode 100644 index 000000000000..f3b8d27924da --- /dev/null +++ b/drivers/crypto/rockchip/rk2_crypto.c @@ -0,0 +1,739 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * hardware cryptographic offloader for RK3568/RK3588 SoC + * + * Copyright (c) 2022-2023, Corentin Labbe <clabbe@baylibre.com> + */ + +#include "rk2_crypto.h" +#include <linux/clk.h> +#include <linux/crypto.h> +#include <linux/dma-mapping.h> +#include <linux/module.h> +#include <linux/platform_device.h> +#include <linux/of.h> +#include <linux/of_device.h> +#include <linux/reset.h> + +static struct rockchip_ip rocklist = { + .dev_list = LIST_HEAD_INIT(rocklist.dev_list), + .lock = __SPIN_LOCK_UNLOCKED(rocklist.lock), +}; + +struct rk2_crypto_dev *get_rk2_crypto(void) +{ + struct rk2_crypto_dev *first; + + spin_lock(&rocklist.lock); + first = list_first_entry_or_null(&rocklist.dev_list, + struct rk2_crypto_dev, list); + list_rotate_left(&rocklist.dev_list); + spin_unlock(&rocklist.lock); + return first; +} + +static const struct rk2_variant rk3568_variant = { + .num_clks = 3, +}; + +static const struct rk2_variant rk3588_variant = { + .num_clks = 3, +}; + +static int rk2_crypto_get_clks(struct rk2_crypto_dev *dev) +{ + int i, j, err; + unsigned long cr; + + dev->num_clks = devm_clk_bulk_get_all(dev->dev, &dev->clks); + if (dev->num_clks < dev->variant->num_clks) { + dev_err(dev->dev, "Missing clocks, got %d instead of %d\n", + dev->num_clks, dev->variant->num_clks); + return -EINVAL; + } + + for (i = 0; i < dev->num_clks; i++) { + cr = clk_get_rate(dev->clks[i].clk); + for (j = 0; j < ARRAY_SIZE(dev->variant->rkclks); j++) { + if (dev->variant->rkclks[j].max == 0) + continue; + if (strcmp(dev->variant->rkclks[j].name, dev->clks[i].id)) + continue; + if (cr > dev->variant->rkclks[j].max) { + err = clk_set_rate(dev->clks[i].clk, + dev->variant->rkclks[j].max); + if (err) + dev_err(dev->dev, "Fail downclocking %s from %lu to %lu\n", + dev->variant->rkclks[j].name, cr, + dev->variant->rkclks[j].max); + else + dev_info(dev->dev, "Downclocking %s from %lu to %lu\n", + dev->variant->rkclks[j].name, cr, + dev->variant->rkclks[j].max); + } + } + } + return 0; +} + +static int rk2_crypto_enable_clk(struct rk2_crypto_dev *dev) +{ + int err; + + err = clk_bulk_prepare_enable(dev->num_clks, dev->clks); + if (err) + dev_err(dev->dev, "Could not enable clock clks\n"); + + return err; +} + +static void rk2_crypto_disable_clk(struct rk2_crypto_dev *dev) +{ + clk_bulk_disable_unprepare(dev->num_clks, dev->clks); +} + +/* + * Power management strategy: The device is suspended until a request + * is handled. For avoiding suspend/resume yoyo, the autosuspend is set to 2s. + */ +static int rk2_crypto_pm_suspend(struct device *dev) +{ + struct rk2_crypto_dev *rkdev = dev_get_drvdata(dev); + + rk2_crypto_disable_clk(rkdev); + reset_control_assert(rkdev->rst); + + return 0; +} + +static int rk2_crypto_pm_resume(struct device *dev) +{ + struct rk2_crypto_dev *rkdev = dev_get_drvdata(dev); + int ret; + + ret = rk2_crypto_enable_clk(rkdev); + if (ret) + return ret; + + reset_control_deassert(rkdev->rst); + return 0; +} + +static const struct dev_pm_ops rk2_crypto_pm_ops = { + SET_RUNTIME_PM_OPS(rk2_crypto_pm_suspend, rk2_crypto_pm_resume, NULL) +}; + +static int rk2_crypto_pm_init(struct rk2_crypto_dev *rkdev) +{ + int err; + + pm_runtime_use_autosuspend(rkdev->dev); + pm_runtime_set_autosuspend_delay(rkdev->dev, 2000); + + err = pm_runtime_set_suspended(rkdev->dev); + if (err) + return err; + pm_runtime_enable(rkdev->dev); + return err; +} + +static void rk2_crypto_pm_exit(struct rk2_crypto_dev *rkdev) +{ + pm_runtime_disable(rkdev->dev); +} + +static irqreturn_t rk2_crypto_irq_handle(int irq, void *dev_id) +{ + struct rk2_crypto_dev *rkc = platform_get_drvdata(dev_id); + u32 v; + + v = readl(rkc->reg + RK2_CRYPTO_DMA_INT_ST); + writel(v, rkc->reg + RK2_CRYPTO_DMA_INT_ST); + + rkc->status = 1; + if (v & 0xF8) { + dev_warn(rkc->dev, "DMA Error\n"); + rkc->status = 0; + } + complete(&rkc->complete); + + return IRQ_HANDLED; +} + +static struct rk2_crypto_template rk2_crypto_algs[] = { + { + .type = CRYPTO_ALG_TYPE_SKCIPHER, + .rk2_mode = RK2_CRYPTO_AES_ECB, + .alg.skcipher.base = { + .base.cra_name = "ecb(aes)", + .base.cra_driver_name = "ecb-aes-rk2", + .base.cra_priority = 300, + .base.cra_flags = CRYPTO_ALG_ASYNC | CRYPTO_ALG_NEED_FALLBACK, + .base.cra_blocksize = AES_BLOCK_SIZE, + .base.cra_ctxsize = sizeof(struct rk2_cipher_ctx), + .base.cra_alignmask = 0x0f, + .base.cra_module = THIS_MODULE, + + .init = rk2_cipher_tfm_init, + .exit = rk2_cipher_tfm_exit, + .min_keysize = AES_MIN_KEY_SIZE, + .max_keysize = AES_MAX_KEY_SIZE, + .setkey = rk2_aes_setkey, + .encrypt = rk2_skcipher_encrypt, + .decrypt = rk2_skcipher_decrypt, + }, + .alg.skcipher.op = { + .do_one_request = rk2_cipher_run, + }, + }, + { + .type = CRYPTO_ALG_TYPE_SKCIPHER, + .rk2_mode = RK2_CRYPTO_AES_CBC, + .alg.skcipher.base = { + .base.cra_name = "cbc(aes)", + .base.cra_driver_name = "cbc-aes-rk2", + .base.cra_priority = 300, + .base.cra_flags = CRYPTO_ALG_ASYNC | CRYPTO_ALG_NEED_FALLBACK, + .base.cra_blocksize = AES_BLOCK_SIZE, + .base.cra_ctxsize = sizeof(struct rk2_cipher_ctx), + .base.cra_alignmask = 0x0f, + .base.cra_module = THIS_MODULE, + + .init = rk2_cipher_tfm_init, + .exit = rk2_cipher_tfm_exit, + .min_keysize = AES_MIN_KEY_SIZE, + .max_keysize = AES_MAX_KEY_SIZE, + .ivsize = AES_BLOCK_SIZE, + .setkey = rk2_aes_setkey, + .encrypt = rk2_skcipher_encrypt, + .decrypt = rk2_skcipher_decrypt, + }, + .alg.skcipher.op = { + .do_one_request = rk2_cipher_run, + }, + }, + { + .type = CRYPTO_ALG_TYPE_SKCIPHER, + .rk2_mode = RK2_CRYPTO_AES_XTS, + .is_xts = true, + .alg.skcipher.base = { + .base.cra_name = "xts(aes)", + .base.cra_driver_name = "xts-aes-rk2", + .base.cra_priority = 300, + .base.cra_flags = CRYPTO_ALG_ASYNC | CRYPTO_ALG_NEED_FALLBACK, + .base.cra_blocksize = AES_BLOCK_SIZE, + .base.cra_ctxsize = sizeof(struct rk2_cipher_ctx), + .base.cra_alignmask = 0x0f, + .base.cra_module = THIS_MODULE, + + .init = rk2_cipher_tfm_init, + .exit = rk2_cipher_tfm_exit, + .min_keysize = AES_MIN_KEY_SIZE * 2, + .max_keysize = AES_MAX_KEY_SIZE * 2, + .ivsize = AES_BLOCK_SIZE, + .setkey = rk2_aes_xts_setkey, + .encrypt = rk2_skcipher_encrypt, + .decrypt = rk2_skcipher_decrypt, + }, + .alg.skcipher.op = { + .do_one_request = rk2_cipher_run, + }, + }, + { + .type = CRYPTO_ALG_TYPE_AHASH, + .rk2_mode = RK2_CRYPTO_MD5, + .alg.hash.base = { + .init = rk2_ahash_init, + .update = rk2_ahash_update, + .final = rk2_ahash_final, + .finup = rk2_ahash_finup, + .export = rk2_ahash_export, + .import = rk2_ahash_import, + .digest = rk2_ahash_digest, + .init_tfm = rk2_hash_init_tfm, + .exit_tfm = rk2_hash_exit_tfm, + .halg = { + .digestsize = MD5_DIGEST_SIZE, + .statesize = sizeof(struct md5_state), + .base = { + .cra_name = "md5", + .cra_driver_name = "rk2-md5", + .cra_priority = 300, + .cra_flags = CRYPTO_ALG_ASYNC | + CRYPTO_ALG_NEED_FALLBACK, + .cra_blocksize = MD5_HMAC_BLOCK_SIZE, + .cra_ctxsize = sizeof(struct rk2_ahash_ctx), + .cra_module = THIS_MODULE, + } + } + }, + .alg.hash.op = { + .do_one_request = rk2_hash_run, + }, + + }, + { + .type = CRYPTO_ALG_TYPE_AHASH, + .rk2_mode = RK2_CRYPTO_SHA1, + .alg.hash.base = { + .init = rk2_ahash_init, + .update = rk2_ahash_update, + .final = rk2_ahash_final, + .finup = rk2_ahash_finup, + .export = rk2_ahash_export, + .import = rk2_ahash_import, + .digest = rk2_ahash_digest, + .init_tfm = rk2_hash_init_tfm, + .exit_tfm = rk2_hash_exit_tfm, + .halg = { + .digestsize = SHA1_DIGEST_SIZE, + .statesize = sizeof(struct sha1_state), + .base = { + .cra_name = "sha1", + .cra_driver_name = "rk2-sha1", + .cra_priority = 300, + .cra_flags = CRYPTO_ALG_ASYNC | + CRYPTO_ALG_NEED_FALLBACK, + .cra_blocksize = SHA1_BLOCK_SIZE, + .cra_ctxsize = sizeof(struct rk2_ahash_ctx), + .cra_module = THIS_MODULE, + } + } + }, + .alg.hash.op = { + .do_one_request = rk2_hash_run, + }, + }, + { + .type = CRYPTO_ALG_TYPE_AHASH, + .rk2_mode = RK2_CRYPTO_SHA256, + .alg.hash.base = { + .init = rk2_ahash_init, + .update = rk2_ahash_update, + .final = rk2_ahash_final, + .finup = rk2_ahash_finup, + .export = rk2_ahash_export, + .import = rk2_ahash_import, + .digest = rk2_ahash_digest, + .init_tfm = rk2_hash_init_tfm, + .exit_tfm = rk2_hash_exit_tfm, + .halg = { + .digestsize = SHA256_DIGEST_SIZE, + .statesize = sizeof(struct sha256_state), + .base = { + .cra_name = "sha256", + .cra_driver_name = "rk2-sha256", + .cra_priority = 300, + .cra_flags = CRYPTO_ALG_ASYNC | + CRYPTO_ALG_NEED_FALLBACK, + .cra_blocksize = SHA256_BLOCK_SIZE, + .cra_ctxsize = sizeof(struct rk2_ahash_ctx), + .cra_module = THIS_MODULE, + } + } + }, + .alg.hash.op = { + .do_one_request = rk2_hash_run, + }, + }, + { + .type = CRYPTO_ALG_TYPE_AHASH, + .rk2_mode = RK2_CRYPTO_SHA384, + .alg.hash.base = { + .init = rk2_ahash_init, + .update = rk2_ahash_update, + .final = rk2_ahash_final, + .finup = rk2_ahash_finup, + .export = rk2_ahash_export, + .import = rk2_ahash_import, + .digest = rk2_ahash_digest, + .init_tfm = rk2_hash_init_tfm, + .exit_tfm = rk2_hash_exit_tfm, + .halg = { + .digestsize = SHA384_DIGEST_SIZE, + .statesize = sizeof(struct sha512_state), + .base = { + .cra_name = "sha384", + .cra_driver_name = "rk2-sha384", + .cra_priority = 300, + .cra_flags = CRYPTO_ALG_ASYNC | + CRYPTO_ALG_NEED_FALLBACK, + .cra_blocksize = SHA384_BLOCK_SIZE, + .cra_ctxsize = sizeof(struct rk2_ahash_ctx), + .cra_module = THIS_MODULE, + } + } + }, + .alg.hash.op = { + .do_one_request = rk2_hash_run, + }, + }, + { + .type = CRYPTO_ALG_TYPE_AHASH, + .rk2_mode = RK2_CRYPTO_SHA512, + .alg.hash.base = { + .init = rk2_ahash_init, + .update = rk2_ahash_update, + .final = rk2_ahash_final, + .finup = rk2_ahash_finup, + .export = rk2_ahash_export, + .import = rk2_ahash_import, + .digest = rk2_ahash_digest, + .init_tfm = rk2_hash_init_tfm, + .exit_tfm = rk2_hash_exit_tfm, + .halg = { + .digestsize = SHA512_DIGEST_SIZE, + .statesize = sizeof(struct sha512_state), + .base = { + .cra_name = "sha512", + .cra_driver_name = "rk2-sha512", + .cra_priority = 300, + .cra_flags = CRYPTO_ALG_ASYNC | + CRYPTO_ALG_NEED_FALLBACK, + .cra_blocksize = SHA512_BLOCK_SIZE, + .cra_ctxsize = sizeof(struct rk2_ahash_ctx), + .cra_module = THIS_MODULE, + } + } + }, + .alg.hash.op = { + .do_one_request = rk2_hash_run, + }, + }, + { + .type = CRYPTO_ALG_TYPE_AHASH, + .rk2_mode = RK2_CRYPTO_SM3, + .alg.hash.base = { + .init = rk2_ahash_init, + .update = rk2_ahash_update, + .final = rk2_ahash_final, + .finup = rk2_ahash_finup, + .export = rk2_ahash_export, + .import = rk2_ahash_import, + .digest = rk2_ahash_digest, + .init_tfm = rk2_hash_init_tfm, + .exit_tfm = rk2_hash_exit_tfm, + .halg = { + .digestsize = SM3_DIGEST_SIZE, + .statesize = sizeof(struct sm3_state), + .base = { + .cra_name = "sm3", + .cra_driver_name = "rk2-sm3", + .cra_priority = 300, + .cra_flags = CRYPTO_ALG_ASYNC | + CRYPTO_ALG_NEED_FALLBACK, + .cra_blocksize = SM3_BLOCK_SIZE, + .cra_ctxsize = sizeof(struct rk2_ahash_ctx), + .cra_module = THIS_MODULE, + } + } + }, + .alg.hash.op = { + .do_one_request = rk2_hash_run, + }, + }, +}; + +#ifdef CONFIG_CRYPTO_DEV_ROCKCHIP2_DEBUG +static int rk2_crypto_debugfs_stats_show(struct seq_file *seq, void *v) +{ + struct rk2_crypto_dev *rkc; + unsigned int i; + + spin_lock(&rocklist.lock); + list_for_each_entry(rkc, &rocklist.dev_list, list) { + seq_printf(seq, "%s %s requests: %lu\n", + dev_driver_string(rkc->dev), dev_name(rkc->dev), + rkc->nreq); + } + spin_unlock(&rocklist.lock); + + for (i = 0; i < ARRAY_SIZE(rk2_crypto_algs); i++) { + if (!rk2_crypto_algs[i].dev) + continue; + switch (rk2_crypto_algs[i].type) { + case CRYPTO_ALG_TYPE_SKCIPHER: + seq_printf(seq, "%s %s reqs=%lu fallback=%lu\n", + rk2_crypto_algs[i].alg.skcipher.base.base.cra_driver_name, + rk2_crypto_algs[i].alg.skcipher.base.base.cra_name, + rk2_crypto_algs[i].stat_req, rk2_crypto_algs[i].stat_fb); + seq_printf(seq, "\tfallback due to length: %lu\n", + rk2_crypto_algs[i].stat_fb_len); + seq_printf(seq, "\tfallback due to alignment: %lu\n", + rk2_crypto_algs[i].stat_fb_align); + seq_printf(seq, "\tfallback due to SGs: %lu\n", + rk2_crypto_algs[i].stat_fb_sgdiff); + break; + case CRYPTO_ALG_TYPE_AHASH: + seq_printf(seq, "%s %s reqs=%lu fallback=%lu\n", + rk2_crypto_algs[i].alg.hash.base.halg.base.cra_driver_name, + rk2_crypto_algs[i].alg.hash.base.halg.base.cra_name, + rk2_crypto_algs[i].stat_req, rk2_crypto_algs[i].stat_fb); + break; + } + } + return 0; +} + +static int rk2_crypto_debugfs_info_show(struct seq_file *seq, void *d) +{ + struct rk2_crypto_dev *rkc; + u32 v; + + spin_lock(&rocklist.lock); + list_for_each_entry(rkc, &rocklist.dev_list, list) { + v = readl(rkc->reg + RK2_CRYPTO_CLK_CTL); + seq_printf(seq, "CRYPTO_CLK_CTL %x\n", v); + v = readl(rkc->reg + RK2_CRYPTO_RST_CTL); + seq_printf(seq, "CRYPTO_RST_CTL %x\n", v); + + v = readl(rkc->reg + CRYPTO_AES_VERSION); + seq_printf(seq, "CRYPTO_AES_VERSION %x\n", v); + if (v & BIT(17)) + seq_puts(seq, "AES 192\n"); + + v = readl(rkc->reg + CRYPTO_DES_VERSION); + seq_printf(seq, "CRYPTO_DES_VERSION %x\n", v); + v = readl(rkc->reg + CRYPTO_SM4_VERSION); + seq_printf(seq, "CRYPTO_SM4_VERSION %x\n", v); + v = readl(rkc->reg + CRYPTO_HASH_VERSION); + seq_printf(seq, "CRYPTO_HASH_VERSION %x\n", v); + v = readl(rkc->reg + CRYPTO_HMAC_VERSION); + seq_printf(seq, "CRYPTO_HMAC_VERSION %x\n", v); + v = readl(rkc->reg + CRYPTO_RNG_VERSION); + seq_printf(seq, "CRYPTO_RNG_VERSION %x\n", v); + v = readl(rkc->reg + CRYPTO_PKA_VERSION); + seq_printf(seq, "CRYPTO_PKA_VERSION %x\n", v); + v = readl(rkc->reg + CRYPTO_CRYPTO_VERSION); + seq_printf(seq, "CRYPTO_CRYPTO_VERSION %x\n", v); + } + spin_unlock(&rocklist.lock); + + return 0; +} + +DEFINE_SHOW_ATTRIBUTE(rk2_crypto_debugfs_stats); +DEFINE_SHOW_ATTRIBUTE(rk2_crypto_debugfs_info); + +#endif + +static void register_debugfs(struct rk2_crypto_dev *crypto_dev) +{ +#ifdef CONFIG_CRYPTO_DEV_ROCKCHIP2_DEBUG + /* Ignore error of debugfs */ + rocklist.dbgfs_dir = debugfs_create_dir("rk2_crypto", NULL); + rocklist.dbgfs_stats = debugfs_create_file("stats", 0440, + rocklist.dbgfs_dir, + &rocklist, + &rk2_crypto_debugfs_stats_fops); + rocklist.dbgfs_stats = debugfs_create_file("info", 0440, + rocklist.dbgfs_dir, + &rocklist, + &rk2_crypto_debugfs_info_fops); +#endif +} + +static int rk2_crypto_register(struct rk2_crypto_dev *rkc) +{ + unsigned int i, k; + int err = 0; + + for (i = 0; i < ARRAY_SIZE(rk2_crypto_algs); i++) { + rk2_crypto_algs[i].dev = rkc; + switch (rk2_crypto_algs[i].type) { + case CRYPTO_ALG_TYPE_SKCIPHER: + dev_info(rkc->dev, "Register %s as %s\n", + rk2_crypto_algs[i].alg.skcipher.base.base.cra_name, + rk2_crypto_algs[i].alg.skcipher.base.base.cra_driver_name); + err = crypto_engine_register_skcipher(&rk2_crypto_algs[i].alg.skcipher); + break; + case CRYPTO_ALG_TYPE_AHASH: + dev_info(rkc->dev, "Register %s as %s %d\n", + rk2_crypto_algs[i].alg.hash.base.halg.base.cra_name, + rk2_crypto_algs[i].alg.hash.base.halg.base.cra_driver_name, i); + err = crypto_engine_register_ahash(&rk2_crypto_algs[i].alg.hash); + break; + default: + dev_err(rkc->dev, "unknown algorithm\n"); + } + if (err) + goto err_cipher_algs; + } + return 0; + +err_cipher_algs: + for (k = 0; k < i; k++) { + if (rk2_crypto_algs[k].type == CRYPTO_ALG_TYPE_SKCIPHER) + crypto_engine_unregister_skcipher(&rk2_crypto_algs[k].alg.skcipher); + else + crypto_engine_unregister_ahash(&rk2_crypto_algs[k].alg.hash); + } + return err; +} + +static void rk2_crypto_unregister(void) +{ + unsigned int i; + + for (i = 0; i < ARRAY_SIZE(rk2_crypto_algs); i++) { + if (rk2_crypto_algs[i].type == CRYPTO_ALG_TYPE_SKCIPHER) + crypto_engine_unregister_skcipher(&rk2_crypto_algs[i].alg.skcipher); + else + crypto_engine_unregister_ahash(&rk2_crypto_algs[i].alg.hash); + } +} + +static const struct of_device_id crypto_of_id_table[] = { + { .compatible = "rockchip,rk3568-crypto", + .data = &rk3568_variant, + }, + { .compatible = "rockchip,rk3588-crypto", + .data = &rk3588_variant, + }, + {} +}; +MODULE_DEVICE_TABLE(of, crypto_of_id_table); + +static int rk2_crypto_probe(struct platform_device *pdev) +{ + struct device *dev = &pdev->dev; + struct rk2_crypto_dev *rkc, *first; + int err = 0; + + rkc = devm_kzalloc(&pdev->dev, sizeof(*rkc), GFP_KERNEL); + if (!rkc) { + err = -ENOMEM; + goto err_crypto; + } + + rkc->dev = &pdev->dev; + platform_set_drvdata(pdev, rkc); + + rkc->variant = of_device_get_match_data(&pdev->dev); + if (!rkc->variant) { + dev_err(&pdev->dev, "Missing variant\n"); + return -EINVAL; + } + + rkc->rst = devm_reset_control_array_get_exclusive(dev); + if (IS_ERR(rkc->rst)) { + err = PTR_ERR(rkc->rst); + dev_err(&pdev->dev, "Fail to get resets err=%d\n", err); + goto err_crypto; + } + + rkc->tl = dma_alloc_coherent(rkc->dev, + sizeof(struct rk2_crypto_lli) * MAX_LLI, + &rkc->t_phy, GFP_KERNEL); + if (!rkc->tl) { + dev_err(rkc->dev, "Cannot get DMA memory for task\n"); + err = -ENOMEM; + goto err_crypto; + } + + reset_control_assert(rkc->rst); + usleep_range(10, 20); + reset_control_deassert(rkc->rst); + + rkc->reg = devm_platform_ioremap_resource(pdev, 0); + if (IS_ERR(rkc->reg)) { + err = PTR_ERR(rkc->reg); + dev_err(&pdev->dev, "Fail to get resources\n"); + goto err_crypto; + } + + err = rk2_crypto_get_clks(rkc); + if (err) + goto err_crypto; + + rkc->irq = platform_get_irq(pdev, 0); + if (rkc->irq < 0) { + dev_err(&pdev->dev, "control Interrupt is not available.\n"); + err = rkc->irq; + goto err_crypto; + } + + err = devm_request_irq(&pdev->dev, rkc->irq, + rk2_crypto_irq_handle, IRQF_SHARED, + "rk-crypto", pdev); + + if (err) { + dev_err(&pdev->dev, "irq request failed.\n"); + goto err_crypto; + } + + rkc->engine = crypto_engine_alloc_init(&pdev->dev, true); + crypto_engine_start(rkc->engine); + init_completion(&rkc->complete); + + err = rk2_crypto_pm_init(rkc); + if (err) + goto err_pm; + + err = pm_runtime_resume_and_get(&pdev->dev); + + spin_lock(&rocklist.lock); + first = list_first_entry_or_null(&rocklist.dev_list, + struct rk2_crypto_dev, list); + list_add_tail(&rkc->list, &rocklist.dev_list); + spin_unlock(&rocklist.lock); + + if (!first) { + dev_info(dev, "Registers crypto algos\n"); + err = rk2_crypto_register(rkc); + if (err) { + dev_err(dev, "Fail to register crypto algorithms"); + goto err_register_alg; + } + + register_debugfs(rkc); + } + + return 0; + +err_register_alg: + rk2_crypto_pm_exit(rkc); +err_pm: + crypto_engine_exit(rkc->engine); +err_crypto: + dev_err(dev, "Crypto Accelerator not successfully registered\n"); + return err; +} + +static int rk2_crypto_remove(struct platform_device *pdev) +{ + struct rk2_crypto_dev *rkc = platform_get_drvdata(pdev); + struct rk2_crypto_dev *first; + + spin_lock_bh(&rocklist.lock); + list_del(&rkc->list); + first = list_first_entry_or_null(&rocklist.dev_list, + struct rk2_crypto_dev, list); + spin_unlock_bh(&rocklist.lock); + + if (!first) { +#ifdef CONFIG_CRYPTO_DEV_ROCKCHIP2_DEBUG + debugfs_remove_recursive(rocklist.dbgfs_dir); +#endif + rk2_crypto_unregister(); + } + rk2_crypto_pm_exit(rkc); + crypto_engine_exit(rkc->engine); + return 0; +} + +static struct platform_driver crypto_driver = { + .probe = rk2_crypto_probe, + .remove = rk2_crypto_remove, + .driver = { + .name = "rk2-crypto", + .pm = &rk2_crypto_pm_ops, + .of_match_table = crypto_of_id_table, + }, +}; + +module_platform_driver(crypto_driver); + +MODULE_DESCRIPTION("Rockchip Crypto Engine cryptographic offloader"); +MODULE_LICENSE("GPL"); +MODULE_AUTHOR("Corentin Labbe <clabbe@baylibre.com>"); diff --git a/drivers/crypto/rockchip/rk2_crypto.h b/drivers/crypto/rockchip/rk2_crypto.h new file mode 100644 index 000000000000..59cd8be59f70 --- /dev/null +++ b/drivers/crypto/rockchip/rk2_crypto.h @@ -0,0 +1,246 @@ +/* SPDX-License-Identifier: GPL-2.0 */ + +#include <crypto/aes.h> +#include <crypto/xts.h> +#include <crypto/engine.h> +#include <crypto/internal/des.h> +#include <crypto/internal/hash.h> +#include <crypto/internal/skcipher.h> +#include <crypto/algapi.h> +#include <crypto/md5.h> +#include <crypto/sha1.h> +#include <crypto/sha2.h> +#include <crypto/sm3.h> +#include <linux/dma-mapping.h> +#include <linux/interrupt.h> +#include <linux/debugfs.h> +#include <linux/delay.h> +#include <linux/pm_runtime.h> +#include <linux/scatterlist.h> +#include <linux/hw_random.h> + +#define RK2_CRYPTO_CLK_CTL 0x0000 +#define RK2_CRYPTO_RST_CTL 0x0004 + +#define RK2_CRYPTO_DMA_INT_EN 0x0008 +/* values for RK2_CRYPTO_DMA_INT_EN */ +#define RK2_CRYPTO_DMA_INT_LISTDONE BIT(0) + +#define RK2_CRYPTO_DMA_INT_ST 0x000C +/* values in RK2_CRYPTO_DMA_INT_ST are the same than in RK2_CRYPTO_DMA_INT_EN */ + +#define RK2_CRYPTO_DMA_CTL 0x0010 +#define RK2_CRYPTO_DMA_CTL_START BIT(0) + +#define RK2_CRYPTO_DMA_LLI_ADDR 0x0014 +#define RK2_CRYPTO_DMA_ST 0x0018 +#define RK2_CRYPTO_DMA_STATE 0x001C +#define RK2_CRYPTO_DMA_LLI_RADDR 0x0020 +#define RK2_CRYPTO_DMA_SRC_RADDR 0x0024 +#define RK2_CRYPTO_DMA_DST_WADDR 0x0028 +#define RK2_CRYPTO_DMA_ITEM_ID 0x002C + +#define RK2_CRYPTO_FIFO_CTL 0x0040 + +#define RK2_CRYPTO_BC_CTL 0x0044 +#define RK2_CRYPTO_AES (0 << 8) +#define RK2_CRYPTO_MODE_ECB (0 << 4) +#define RK2_CRYPTO_MODE_CBC (1 << 4) +#define RK2_CRYPTO_XTS (6 << 4) + +#define RK2_CRYPTO_HASH_CTL 0x0048 +#define RK2_CRYPTO_HW_PAD BIT(2) +#define RK2_CRYPTO_SHA1 (0 << 4) +#define RK2_CRYPTO_MD5 (1 << 4) +#define RK2_CRYPTO_SHA224 (3 << 4) +#define RK2_CRYPTO_SHA256 (2 << 4) +#define RK2_CRYPTO_SHA384 (9 << 4) +#define RK2_CRYPTO_SHA512 (8 << 4) +#define RK2_CRYPTO_SM3 (4 << 4) + +#define RK2_CRYPTO_AES_ECB (RK2_CRYPTO_AES | RK2_CRYPTO_MODE_ECB) +#define RK2_CRYPTO_AES_CBC (RK2_CRYPTO_AES | RK2_CRYPTO_MODE_CBC) +#define RK2_CRYPTO_AES_XTS (RK2_CRYPTO_AES | RK2_CRYPTO_XTS) +#define RK2_CRYPTO_AES_CTR_MODE 3 +#define RK2_CRYPTO_AES_128BIT_key (0 << 2) +#define RK2_CRYPTO_AES_192BIT_key (1 << 2) +#define RK2_CRYPTO_AES_256BIT_key (2 << 2) + +#define RK2_CRYPTO_DEC BIT(1) +#define RK2_CRYPTO_ENABLE BIT(0) + +#define RK2_CRYPTO_CIPHER_ST 0x004C +#define RK2_CRYPTO_CIPHER_STATE 0x0050 + +#define RK2_CRYPTO_CH0_IV_0 0x0100 + +#define RK2_CRYPTO_KEY0 0x0180 +#define RK2_CRYPTO_KEY1 0x0184 +#define RK2_CRYPTO_KEY2 0x0188 +#define RK2_CRYPTO_KEY3 0x018C +#define RK2_CRYPTO_KEY4 0x0190 +#define RK2_CRYPTO_KEY5 0x0194 +#define RK2_CRYPTO_KEY6 0x0198 +#define RK2_CRYPTO_KEY7 0x019C +#define RK2_CRYPTO_CH4_KEY0 0x01c0 + +#define RK2_CRYPTO_CH0_PC_LEN_0 0x0280 + +#define RK2_CRYPTO_CH0_IV_LEN 0x0300 + +#define RK2_CRYPTO_HASH_DOUT_0 0x03A0 +#define RK2_CRYPTO_HASH_VALID 0x03E4 + +#define RK2_CRYPTO_TRNG_CTL 0x0400 +#define RK2_CRYPTO_TRNG_START BIT(0) +#define RK2_CRYPTO_TRNG_ENABLE BIT(1) +#define RK2_CRYPTO_TRNG_256 (0x3 << 4) +#define RK2_CRYPTO_TRNG_SAMPLE_CNT 0x0404 +#define RK2_CRYPTO_TRNG_DOUT 0x0410 + +#define CRYPTO_AES_VERSION 0x0680 +#define CRYPTO_DES_VERSION 0x0684 +#define CRYPTO_SM4_VERSION 0x0688 +#define CRYPTO_HASH_VERSION 0x068C +#define CRYPTO_HMAC_VERSION 0x0690 +#define CRYPTO_RNG_VERSION 0x0694 +#define CRYPTO_PKA_VERSION 0x0698 +#define CRYPTO_CRYPTO_VERSION 0x06F0 + +#define RK2_LLI_DMA_CTRL_SRC_INT BIT(10) +#define RK2_LLI_DMA_CTRL_DST_INT BIT(9) +#define RK2_LLI_DMA_CTRL_LIST_INT BIT(8) +#define RK2_LLI_DMA_CTRL_LAST BIT(0) + +#define RK2_LLI_STRING_LAST BIT(2) +#define RK2_LLI_STRING_FIRST BIT(1) +#define RK2_LLI_CIPHER_START BIT(0) + +#define RK2_MAX_CLKS 4 + +#define MAX_LLI 20 + +struct rk2_crypto_lli { + __le32 src_addr; + __le32 src_len; + __le32 dst_addr; + __le32 dst_len; + __le32 user; + __le32 iv; + __le32 dma_ctrl; + __le32 next; +}; + +/* + * struct rockchip_ip - struct for managing a list of RK crypto instance + * @dev_list: Used for doing a list of rk2_crypto_dev + * @lock: Control access to dev_list + * @dbgfs_dir: Debugfs dentry for statistic directory + * @dbgfs_stats: Debugfs dentry for statistic counters + */ +struct rockchip_ip { + struct list_head dev_list; + spinlock_t lock; /* Control access to dev_list */ + struct dentry *dbgfs_dir; + struct dentry *dbgfs_stats; +}; + +struct rk2_clks { + const char *name; + unsigned long max; +}; + +struct rk2_variant { + int num_clks; + struct rk2_clks rkclks[RK2_MAX_CLKS]; +}; + +struct rk2_crypto_dev { + struct list_head list; + struct device *dev; + struct clk_bulk_data *clks; + int num_clks; + struct reset_control *rst; + void __iomem *reg; + int irq; + const struct rk2_variant *variant; + unsigned long nreq; + struct crypto_engine *engine; + struct completion complete; + int status; + struct rk2_crypto_lli *tl; + dma_addr_t t_phy; +}; + +/* the private variable of hash */ +struct rk2_ahash_ctx { + /* for fallback */ + struct crypto_ahash *fallback_tfm; +}; + +/* the private variable of hash for fallback */ +struct rk2_ahash_rctx { + struct rk2_crypto_dev *dev; + struct ahash_request fallback_req; + u32 mode; + int nrsgs; +}; + +/* the private variable of cipher */ +struct rk2_cipher_ctx { + unsigned int keylen; + u8 key[AES_MAX_KEY_SIZE * 2]; + u8 iv[AES_BLOCK_SIZE]; + struct crypto_skcipher *fallback_tfm; +}; + +struct rk2_cipher_rctx { + struct rk2_crypto_dev *dev; + u8 backup_iv[AES_BLOCK_SIZE]; + u32 mode; + struct skcipher_request fallback_req; // keep at the end +}; + +struct rk2_crypto_template { + u32 type; + u32 rk2_mode; + bool is_xts; + struct rk2_crypto_dev *dev; + union { + struct skcipher_engine_alg skcipher; + struct ahash_engine_alg hash; + } alg; + unsigned long stat_req; + unsigned long stat_fb; + unsigned long stat_fb_len; + unsigned long stat_fb_sglen; + unsigned long stat_fb_align; + unsigned long stat_fb_sgdiff; +}; + +struct rk2_crypto_dev *get_rk2_crypto(void); +int rk2_cipher_run(struct crypto_engine *engine, void *async_req); +int rk2_hash_run(struct crypto_engine *engine, void *breq); + +int rk2_cipher_tfm_init(struct crypto_skcipher *tfm); +void rk2_cipher_tfm_exit(struct crypto_skcipher *tfm); +int rk2_aes_setkey(struct crypto_skcipher *cipher, const u8 *key, + unsigned int keylen); +int rk2_aes_xts_setkey(struct crypto_skcipher *cipher, const u8 *key, + unsigned int keylen); +int rk2_skcipher_encrypt(struct skcipher_request *req); +int rk2_skcipher_decrypt(struct skcipher_request *req); +int rk2_aes_ecb_encrypt(struct skcipher_request *req); +int rk2_aes_ecb_decrypt(struct skcipher_request *req); +int rk2_aes_cbc_encrypt(struct skcipher_request *req); +int rk2_aes_cbc_decrypt(struct skcipher_request *req); + +int rk2_ahash_init(struct ahash_request *req); +int rk2_ahash_update(struct ahash_request *req); +int rk2_ahash_final(struct ahash_request *req); +int rk2_ahash_finup(struct ahash_request *req); +int rk2_ahash_import(struct ahash_request *req, const void *in); +int rk2_ahash_export(struct ahash_request *req, void *out); +int rk2_ahash_digest(struct ahash_request *req); +int rk2_hash_init_tfm(struct crypto_ahash *tfm); +void rk2_hash_exit_tfm(struct crypto_ahash *tfm); diff --git a/drivers/crypto/rockchip/rk2_crypto_ahash.c b/drivers/crypto/rockchip/rk2_crypto_ahash.c new file mode 100644 index 000000000000..75b8d9893447 --- /dev/null +++ b/drivers/crypto/rockchip/rk2_crypto_ahash.c @@ -0,0 +1,344 @@ +// SPDX-License-Identifier: GPL-2.0-only +/* + * Crypto offloader support for Rockchip RK3568/RK3588 + * + * Copyright (c) 2022-2023 Corentin Labbe <clabbe@baylibre.com> + */ +#include <asm/unaligned.h> +#include <linux/iopoll.h> +#include "rk2_crypto.h" + +static bool rk2_ahash_need_fallback(struct ahash_request *areq) +{ + struct crypto_ahash *tfm = crypto_ahash_reqtfm(areq); + struct ahash_alg *alg = crypto_ahash_alg(tfm); + struct rk2_crypto_template *algt = container_of(alg, struct rk2_crypto_template, alg.hash.base); + struct scatterlist *sg; + + sg = areq->src; + while (sg) { + if (!IS_ALIGNED(sg->offset, sizeof(u32))) { + algt->stat_fb_align++; + return true; + } + if (sg->length % 4) { + algt->stat_fb_sglen++; + return true; + } + sg = sg_next(sg); + } + return false; +} + +static int rk2_ahash_digest_fb(struct ahash_request *areq) +{ + struct rk2_ahash_rctx *rctx = ahash_request_ctx(areq); + struct crypto_ahash *tfm = crypto_ahash_reqtfm(areq); + struct rk2_ahash_ctx *tfmctx = crypto_ahash_ctx(tfm); + struct ahash_alg *alg = crypto_ahash_alg(tfm); + struct rk2_crypto_template *algt = container_of(alg, struct rk2_crypto_template, alg.hash.base); + + algt->stat_fb++; + + ahash_request_set_tfm(&rctx->fallback_req, tfmctx->fallback_tfm); + rctx->fallback_req.base.flags = areq->base.flags & + CRYPTO_TFM_REQ_MAY_SLEEP; + + rctx->fallback_req.nbytes = areq->nbytes; + rctx->fallback_req.src = areq->src; + rctx->fallback_req.result = areq->result; + + return crypto_ahash_digest(&rctx->fallback_req); +} + +static int zero_message_process(struct ahash_request *req) +{ + struct crypto_ahash *tfm = crypto_ahash_reqtfm(req); + struct ahash_alg *alg = crypto_ahash_alg(tfm); + struct rk2_crypto_template *algt = container_of(alg, struct rk2_crypto_template, alg.hash.base); + int digestsize = crypto_ahash_digestsize(tfm); + + switch (algt->rk2_mode) { + case RK2_CRYPTO_SHA1: + memcpy(req->result, sha1_zero_message_hash, digestsize); + break; + case RK2_CRYPTO_SHA256: + memcpy(req->result, sha256_zero_message_hash, digestsize); + break; + case RK2_CRYPTO_SHA384: + memcpy(req->result, sha384_zero_message_hash, digestsize); + break; + case RK2_CRYPTO_SHA512: + memcpy(req->result, sha512_zero_message_hash, digestsize); + break; + case RK2_CRYPTO_MD5: + memcpy(req->result, md5_zero_message_hash, digestsize); + break; + case RK2_CRYPTO_SM3: + memcpy(req->result, sm3_zero_message_hash, digestsize); + break; + default: + return -EINVAL; + } + + return 0; +} + +int rk2_ahash_init(struct ahash_request *req) +{ + struct rk2_ahash_rctx *rctx = ahash_request_ctx(req); + struct crypto_ahash *tfm = crypto_ahash_reqtfm(req); + struct rk2_ahash_ctx *ctx = crypto_ahash_ctx(tfm); + + ahash_request_set_tfm(&rctx->fallback_req, ctx->fallback_tfm); + rctx->fallback_req.base.flags = req->base.flags & + CRYPTO_TFM_REQ_MAY_SLEEP; + + return crypto_ahash_init(&rctx->fallback_req); +} + +int rk2_ahash_update(struct ahash_request *req) +{ + struct rk2_ahash_rctx *rctx = ahash_request_ctx(req); + struct crypto_ahash *tfm = crypto_ahash_reqtfm(req); + struct rk2_ahash_ctx *ctx = crypto_ahash_ctx(tfm); + + ahash_request_set_tfm(&rctx->fallback_req, ctx->fallback_tfm); + rctx->fallback_req.base.flags = req->base.flags & + CRYPTO_TFM_REQ_MAY_SLEEP; + rctx->fallback_req.nbytes = req->nbytes; + rctx->fallback_req.src = req->src; + + return crypto_ahash_update(&rctx->fallback_req); +} + +int rk2_ahash_final(struct ahash_request *req) +{ + struct rk2_ahash_rctx *rctx = ahash_request_ctx(req); + struct crypto_ahash *tfm = crypto_ahash_reqtfm(req); + struct rk2_ahash_ctx *ctx = crypto_ahash_ctx(tfm); + + ahash_request_set_tfm(&rctx->fallback_req, ctx->fallback_tfm); + rctx->fallback_req.base.flags = req->base.flags & + CRYPTO_TFM_REQ_MAY_SLEEP; + rctx->fallback_req.result = req->result; + + return crypto_ahash_final(&rctx->fallback_req); +} + +int rk2_ahash_finup(struct ahash_request *req) +{ + struct rk2_ahash_rctx *rctx = ahash_request_ctx(req); + struct crypto_ahash *tfm = crypto_ahash_reqtfm(req); + struct rk2_ahash_ctx *ctx = crypto_ahash_ctx(tfm); + + ahash_request_set_tfm(&rctx->fallback_req, ctx->fallback_tfm); + rctx->fallback_req.base.flags = req->base.flags & + CRYPTO_TFM_REQ_MAY_SLEEP; + + rctx->fallback_req.nbytes = req->nbytes; + rctx->fallback_req.src = req->src; + rctx->fallback_req.result = req->result; + + return crypto_ahash_finup(&rctx->fallback_req); +} + +int rk2_ahash_import(struct ahash_request *req, const void *in) +{ + struct rk2_ahash_rctx *rctx = ahash_request_ctx(req); + struct crypto_ahash *tfm = crypto_ahash_reqtfm(req); + struct rk2_ahash_ctx *ctx = crypto_ahash_ctx(tfm); + + ahash_request_set_tfm(&rctx->fallback_req, ctx->fallback_tfm); + rctx->fallback_req.base.flags = req->base.flags & + CRYPTO_TFM_REQ_MAY_SLEEP; + + return crypto_ahash_import(&rctx->fallback_req, in); +} + +int rk2_ahash_export(struct ahash_request *req, void *out) +{ + struct rk2_ahash_rctx *rctx = ahash_request_ctx(req); + struct crypto_ahash *tfm = crypto_ahash_reqtfm(req); + struct rk2_ahash_ctx *ctx = crypto_ahash_ctx(tfm); + + ahash_request_set_tfm(&rctx->fallback_req, ctx->fallback_tfm); + rctx->fallback_req.base.flags = req->base.flags & + CRYPTO_TFM_REQ_MAY_SLEEP; + + return crypto_ahash_export(&rctx->fallback_req, out); +} + +int rk2_ahash_digest(struct ahash_request *req) +{ + struct rk2_ahash_rctx *rctx = ahash_request_ctx(req); + struct rk2_crypto_dev *dev; + struct crypto_engine *engine; + + if (rk2_ahash_need_fallback(req)) + return rk2_ahash_digest_fb(req); + + if (!req->nbytes) + return zero_message_process(req); + + dev = get_rk2_crypto(); + + rctx->dev = dev; + engine = dev->engine; + + return crypto_transfer_hash_request_to_engine(engine, req); +} + +static int rk2_hash_prepare(struct crypto_engine *engine, void *breq) +{ + struct ahash_request *areq = container_of(breq, struct ahash_request, base); + struct rk2_ahash_rctx *rctx = ahash_request_ctx(areq); + struct rk2_crypto_dev *rkc = rctx->dev; + int ret; + + ret = dma_map_sg(rkc->dev, areq->src, sg_nents(areq->src), DMA_TO_DEVICE); + if (ret <= 0) + return -EINVAL; + + rctx->nrsgs = ret; + + return 0; +} + +static void rk2_hash_unprepare(struct crypto_engine *engine, void *breq) +{ + struct ahash_request *areq = container_of(breq, struct ahash_request, base); + struct rk2_ahash_rctx *rctx = ahash_request_ctx(areq); + struct rk2_crypto_dev *rkc = rctx->dev; + + dma_unmap_sg(rkc->dev, areq->src, rctx->nrsgs, DMA_TO_DEVICE); +} + +int rk2_hash_run(struct crypto_engine *engine, void *breq) +{ + struct ahash_request *areq = container_of(breq, struct ahash_request, base); + struct crypto_ahash *tfm = crypto_ahash_reqtfm(areq); + struct rk2_ahash_rctx *rctx = ahash_request_ctx(areq); + struct ahash_alg *alg = crypto_ahash_alg(tfm); + struct rk2_crypto_template *algt = container_of(alg, struct rk2_crypto_template, alg.hash.base); + struct scatterlist *sgs = areq->src; + struct rk2_crypto_dev *rkc = rctx->dev; + struct rk2_crypto_lli *dd = &rkc->tl[0]; + int ddi = 0; + int err = 0; + unsigned int len = areq->nbytes; + unsigned int todo; + u32 v; + int i; + + err = rk2_hash_prepare(engine, breq); + + err = pm_runtime_resume_and_get(rkc->dev); + if (err) + return err; + + dev_dbg(rkc->dev, "%s %s len=%d\n", __func__, + crypto_tfm_alg_name(areq->base.tfm), areq->nbytes); + + algt->stat_req++; + rkc->nreq++; + + rctx->mode = algt->rk2_mode; + rctx->mode |= 0xffff0000; + rctx->mode |= RK2_CRYPTO_ENABLE | RK2_CRYPTO_HW_PAD; + writel(rctx->mode, rkc->reg + RK2_CRYPTO_HASH_CTL); + + while (sgs && len > 0) { + dd = &rkc->tl[ddi]; + + todo = min(sg_dma_len(sgs), len); + dd->src_addr = sg_dma_address(sgs); + dd->src_len = todo; + dd->dst_addr = 0; + dd->dst_len = 0; + dd->dma_ctrl = ddi << 24; + dd->iv = 0; + dd->next = rkc->t_phy + sizeof(struct rk2_crypto_lli) * (ddi + 1); + + if (ddi == 0) + dd->user = RK2_LLI_CIPHER_START | RK2_LLI_STRING_FIRST; + else + dd->user = 0; + + len -= todo; + dd->dma_ctrl |= RK2_LLI_DMA_CTRL_SRC_INT; + if (len == 0) { + dd->user |= RK2_LLI_STRING_LAST; + dd->dma_ctrl |= RK2_LLI_DMA_CTRL_LAST; + } + dev_dbg(rkc->dev, "HASH SG %d sglen=%d user=%x dma=%x mode=%x len=%d todo=%d phy=%llx\n", + ddi, sgs->length, dd->user, dd->dma_ctrl, rctx->mode, len, todo, rkc->t_phy); + + sgs = sg_next(sgs); + ddi++; + } + dd->next = 1; + writel(RK2_CRYPTO_DMA_INT_LISTDONE | 0x7F, rkc->reg + RK2_CRYPTO_DMA_INT_EN); + + writel(rkc->t_phy, rkc->reg + RK2_CRYPTO_DMA_LLI_ADDR); + + reinit_completion(&rkc->complete); + rkc->status = 0; + + writel(RK2_CRYPTO_DMA_CTL_START | RK2_CRYPTO_DMA_CTL_START << 16, rkc->reg + RK2_CRYPTO_DMA_CTL); + + wait_for_completion_interruptible_timeout(&rkc->complete, + msecs_to_jiffies(2000)); + if (!rkc->status) { + dev_err(rkc->dev, "DMA timeout\n"); + err = -EFAULT; + goto theend; + } + + readl_poll_timeout_atomic(rkc->reg + RK2_CRYPTO_HASH_VALID, v, v == 1, + 10, 1000); + + for (i = 0; i < crypto_ahash_digestsize(tfm) / 4; i++) { + v = readl(rkc->reg + RK2_CRYPTO_HASH_DOUT_0 + i * 4); + put_unaligned_le32(be32_to_cpu(v), areq->result + i * 4); + } + +theend: + pm_runtime_put_autosuspend(rkc->dev); + + rk2_hash_unprepare(engine, breq); + + local_bh_disable(); + crypto_finalize_hash_request(engine, breq, err); + local_bh_enable(); + + return 0; +} + +int rk2_hash_init_tfm(struct crypto_ahash *tfm) +{ + struct rk2_ahash_ctx *tctx = crypto_ahash_ctx(tfm); + const char *alg_name = crypto_ahash_alg_name(tfm); + struct ahash_alg *alg = crypto_ahash_alg(tfm); + struct rk2_crypto_template *algt = container_of(alg, struct rk2_crypto_template, alg.hash.base); + + /* for fallback */ + tctx->fallback_tfm = crypto_alloc_ahash(alg_name, 0, + CRYPTO_ALG_NEED_FALLBACK); + if (IS_ERR(tctx->fallback_tfm)) { + dev_err(algt->dev->dev, "Could not load fallback driver.\n"); + return PTR_ERR(tctx->fallback_tfm); + } + + crypto_ahash_set_reqsize(tfm, + sizeof(struct rk2_ahash_rctx) + + crypto_ahash_reqsize(tctx->fallback_tfm)); + return 0; +} + +void rk2_hash_exit_tfm(struct crypto_ahash *tfm) +{ + struct rk2_ahash_ctx *tctx = crypto_ahash_ctx(tfm); + + crypto_free_ahash(tctx->fallback_tfm); +} diff --git a/drivers/crypto/rockchip/rk2_crypto_skcipher.c b/drivers/crypto/rockchip/rk2_crypto_skcipher.c new file mode 100644 index 000000000000..3e8e44d84b47 --- /dev/null +++ b/drivers/crypto/rockchip/rk2_crypto_skcipher.c @@ -0,0 +1,576 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * hardware cryptographic offloader for RK3568/RK3588 SoC + * + * Copyright (c) 2022-2023 Corentin Labbe <clabbe@baylibre.com> + */ +#include <crypto/scatterwalk.h> +#include "rk2_crypto.h" + +static void rk2_print(struct rk2_crypto_dev *rkc) +{ + u32 v; + + v = readl(rkc->reg + RK2_CRYPTO_DMA_ST); + dev_info(rkc->dev, "DMA_ST %x\n", v); + switch (v) { + case 0: + dev_info(rkc->dev, "DMA_ST: DMA IDLE\n"); + break; + case 1: + dev_info(rkc->dev, "DMA_ST: DMA BUSY\n"); + break; + default: + dev_err(rkc->dev, "DMA_ST: invalid value\n"); + } + + v = readl(rkc->reg + RK2_CRYPTO_DMA_STATE); + dev_info(rkc->dev, "DMA_STATE %x\n", v); + + switch (v & 0x3) { + case 0: + dev_info(rkc->dev, "DMA_STATE: DMA DST IDLE\n"); + break; + case 1: + dev_info(rkc->dev, "DMA_STATE: DMA DST LOAD\n"); + break; + case 2: + dev_info(rkc->dev, "DMA_STATE: DMA DST WORK\n"); + break; + default: + dev_err(rkc->dev, "DMA DST invalid\n"); + break; + } + switch (v & 0xC) { + case 0: + dev_info(rkc->dev, "DMA_STATE: DMA SRC IDLE\n"); + break; + case 1: + dev_info(rkc->dev, "DMA_STATE: DMA SRC LOAD\n"); + break; + case 2: + dev_info(rkc->dev, "DMA_STATE: DMA SRC WORK\n"); + break; + default: + dev_err(rkc->dev, "DMA_STATE: DMA SRC invalid\n"); + break; + } + switch (v & 0x30) { + case 0: + dev_info(rkc->dev, "DMA_STATE: DMA LLI IDLE\n"); + break; + case 1: + dev_info(rkc->dev, "DMA_STATE: DMA LLI LOAD\n"); + break; + case 2: + dev_info(rkc->dev, "DMA LLI WORK\n"); + break; + default: + dev_err(rkc->dev, "DMA LLI invalid\n"); + break; + } + + v = readl(rkc->reg + RK2_CRYPTO_DMA_LLI_RADDR); + dev_info(rkc->dev, "DMA_LLI_RADDR %x\n", v); + v = readl(rkc->reg + RK2_CRYPTO_DMA_SRC_RADDR); + dev_info(rkc->dev, "DMA_SRC_RADDR %x\n", v); + v = readl(rkc->reg + RK2_CRYPTO_DMA_DST_WADDR); + dev_info(rkc->dev, "DMA_LLI_WADDR %x\n", v); + v = readl(rkc->reg + RK2_CRYPTO_DMA_ITEM_ID); + dev_info(rkc->dev, "DMA_LLI_ITEMID %x\n", v); + + v = readl(rkc->reg + RK2_CRYPTO_CIPHER_ST); + dev_info(rkc->dev, "CIPHER_ST %x\n", v); + if (v & BIT(0)) + dev_info(rkc->dev, "CIPHER_ST: BLOCK CIPHER BUSY\n"); + else + dev_info(rkc->dev, "CIPHER_ST: BLOCK CIPHER IDLE\n"); + if (v & BIT(2)) + dev_info(rkc->dev, "CIPHER_ST: HASH BUSY\n"); + else + dev_info(rkc->dev, "CIPHER_ST: HASH IDLE\n"); + if (v & BIT(2)) + dev_info(rkc->dev, "CIPHER_ST: OTP KEY VALID\n"); + else + dev_info(rkc->dev, "CIPHER_ST: OTP KEY INVALID\n"); + + v = readl(rkc->reg + RK2_CRYPTO_CIPHER_STATE); + dev_info(rkc->dev, "CIPHER_STATE %x\n", v); + switch (v & 0x3) { + case 0: + dev_info(rkc->dev, "serial: IDLE state\n"); + break; + case 1: + dev_info(rkc->dev, "serial: PRE state\n"); + break; + case 2: + dev_info(rkc->dev, "serial: BULK state\n"); + break; + default: + dev_info(rkc->dev, "serial: reserved state\n"); + break; + } + switch (v & 0xC) { + case 0: + dev_info(rkc->dev, "mac_state: IDLE state\n"); + break; + case 1: + dev_info(rkc->dev, "mac_state: PRE state\n"); + break; + case 2: + dev_info(rkc->dev, "mac_state: BULK state\n"); + break; + default: + dev_info(rkc->dev, "mac_state: reserved state\n"); + break; + } + switch (v & 0x30) { + case 0: + dev_info(rkc->dev, "parallel_state: IDLE state\n"); + break; + case 1: + dev_info(rkc->dev, "parallel_state: PRE state\n"); + break; + case 2: + dev_info(rkc->dev, "parallel_state: BULK state\n"); + break; + default: + dev_info(rkc->dev, "parallel_state: reserved state\n"); + break; + } + switch (v & 0xC0) { + case 0: + dev_info(rkc->dev, "ccm_state: IDLE state\n"); + break; + case 1: + dev_info(rkc->dev, "ccm_state: PRE state\n"); + break; + case 2: + dev_info(rkc->dev, "ccm_state: NA state\n"); + break; + default: + dev_info(rkc->dev, "ccm_state: reserved state\n"); + break; + } + switch (v & 0xF00) { + case 0: + dev_info(rkc->dev, "gcm_state: IDLE state\n"); + break; + case 1: + dev_info(rkc->dev, "gcm_state: PRE state\n"); + break; + case 2: + dev_info(rkc->dev, "gcm_state: NA state\n"); + break; + case 3: + dev_info(rkc->dev, "gcm_state: PC state\n"); + break; + } + switch (v & 0xC00) { + case 0x1: + dev_info(rkc->dev, "hash_state: IDLE state\n"); + break; + case 0x2: + dev_info(rkc->dev, "hash_state: IPAD state\n"); + break; + case 0x4: + dev_info(rkc->dev, "hash_state: TEXT state\n"); + break; + case 0x8: + dev_info(rkc->dev, "hash_state: OPAD state\n"); + break; + case 0x10: + dev_info(rkc->dev, "hash_state: OPAD EXT state\n"); + break; + default: + dev_info(rkc->dev, "hash_state: invalid state\n"); + break; + } + + v = readl(rkc->reg + RK2_CRYPTO_DMA_INT_ST); + dev_info(rkc->dev, "RK2_CRYPTO_DMA_INT_ST %x\n", v); +} + +static int rk2_cipher_need_fallback(struct skcipher_request *req) +{ + struct crypto_skcipher *tfm = crypto_skcipher_reqtfm(req); + struct skcipher_alg *alg = crypto_skcipher_alg(tfm); + struct rk2_crypto_template *algt = container_of(alg, struct rk2_crypto_template, alg.skcipher.base); + struct scatterlist *sgs, *sgd; + unsigned int stodo, dtodo, len; + unsigned int bs = crypto_skcipher_blocksize(tfm); + + if (!req->cryptlen) + return true; + + if (algt->is_xts) { + if (sg_nents_for_len(req->src, req->cryptlen) > 1) + return true; + if (sg_nents_for_len(req->dst, req->cryptlen) > 1) + return true; + } + + len = req->cryptlen; + sgs = req->src; + sgd = req->dst; + while (sgs && sgd) { + if (!IS_ALIGNED(sgs->offset, sizeof(u32))) { + algt->stat_fb_align++; + return true; + } + if (!IS_ALIGNED(sgd->offset, sizeof(u32))) { + algt->stat_fb_align++; + return true; + } + stodo = min(len, sgs->length); + if (stodo % bs) { + algt->stat_fb_len++; + return true; + } + dtodo = min(len, sgd->length); + if (dtodo % bs) { + algt->stat_fb_len++; + return true; + } + if (stodo != dtodo) { + algt->stat_fb_sgdiff++; + return true; + } + len -= stodo; + sgs = sg_next(sgs); + sgd = sg_next(sgd); + } + return false; +} + +static int rk2_cipher_fallback(struct skcipher_request *areq) +{ + struct crypto_skcipher *tfm = crypto_skcipher_reqtfm(areq); + struct rk2_cipher_ctx *op = crypto_skcipher_ctx(tfm); + struct rk2_cipher_rctx *rctx = skcipher_request_ctx(areq); + struct skcipher_alg *alg = crypto_skcipher_alg(tfm); + struct rk2_crypto_template *algt = container_of(alg, struct rk2_crypto_template, alg.skcipher.base); + int err; + + algt->stat_fb++; + + skcipher_request_set_tfm(&rctx->fallback_req, op->fallback_tfm); + skcipher_request_set_callback(&rctx->fallback_req, areq->base.flags, + areq->base.complete, areq->base.data); + skcipher_request_set_crypt(&rctx->fallback_req, areq->src, areq->dst, + areq->cryptlen, areq->iv); + if (rctx->mode & RK2_CRYPTO_DEC) + err = crypto_skcipher_decrypt(&rctx->fallback_req); + else + err = crypto_skcipher_encrypt(&rctx->fallback_req); + return err; +} + +static int rk2_cipher_handle_req(struct skcipher_request *req) +{ + struct rk2_cipher_rctx *rctx = skcipher_request_ctx(req); + struct crypto_skcipher *tfm = crypto_skcipher_reqtfm(req); + struct rk2_cipher_ctx *ctx = crypto_skcipher_ctx(tfm); + struct rk2_crypto_dev *rkc; + struct crypto_engine *engine; + + if (ctx->keylen == AES_KEYSIZE_192 * 2) + return rk2_cipher_fallback(req); + + if (rk2_cipher_need_fallback(req)) + return rk2_cipher_fallback(req); + + rkc = get_rk2_crypto(); + + engine = rkc->engine; + rctx->dev = rkc; + + return crypto_transfer_skcipher_request_to_engine(engine, req); +} + +int rk2_aes_xts_setkey(struct crypto_skcipher *cipher, const u8 *key, + unsigned int keylen) +{ + struct crypto_tfm *tfm = crypto_skcipher_tfm(cipher); + struct rk2_cipher_ctx *ctx = crypto_tfm_ctx(tfm); + int err; + + err = xts_verify_key(cipher, key, keylen); + if (err) + return err; + + ctx->keylen = keylen; + memcpy(ctx->key, key, keylen); + + return crypto_skcipher_setkey(ctx->fallback_tfm, key, keylen); +} + +int rk2_aes_setkey(struct crypto_skcipher *cipher, const u8 *key, + unsigned int keylen) +{ + struct crypto_tfm *tfm = crypto_skcipher_tfm(cipher); + struct rk2_cipher_ctx *ctx = crypto_tfm_ctx(tfm); + + if (keylen != AES_KEYSIZE_128 && keylen != AES_KEYSIZE_192 && + keylen != AES_KEYSIZE_256) + return -EINVAL; + ctx->keylen = keylen; + memcpy(ctx->key, key, keylen); + + return crypto_skcipher_setkey(ctx->fallback_tfm, key, keylen); +} + +int rk2_skcipher_encrypt(struct skcipher_request *req) +{ + struct rk2_cipher_rctx *rctx = skcipher_request_ctx(req); + struct crypto_skcipher *tfm = crypto_skcipher_reqtfm(req); + struct skcipher_alg *alg = crypto_skcipher_alg(tfm); + struct rk2_crypto_template *algt = container_of(alg, struct rk2_crypto_template, alg.skcipher.base); + + rctx->mode = algt->rk2_mode; + return rk2_cipher_handle_req(req); +} + +int rk2_skcipher_decrypt(struct skcipher_request *req) +{ + struct rk2_cipher_rctx *rctx = skcipher_request_ctx(req); + struct crypto_skcipher *tfm = crypto_skcipher_reqtfm(req); + struct skcipher_alg *alg = crypto_skcipher_alg(tfm); + struct rk2_crypto_template *algt = container_of(alg, struct rk2_crypto_template, alg.skcipher.base); + + rctx->mode = algt->rk2_mode | RK2_CRYPTO_DEC; + return rk2_cipher_handle_req(req); +} + +int rk2_cipher_run(struct crypto_engine *engine, void *async_req) +{ + struct skcipher_request *areq = container_of(async_req, struct skcipher_request, base); + struct crypto_skcipher *tfm = crypto_skcipher_reqtfm(areq); + struct rk2_cipher_rctx *rctx = skcipher_request_ctx(areq); + struct rk2_cipher_ctx *ctx = crypto_skcipher_ctx(tfm); + struct scatterlist *sgs, *sgd; + int err = 0; + int ivsize = crypto_skcipher_ivsize(tfm); + unsigned int len = areq->cryptlen; + unsigned int todo; + struct skcipher_alg *alg = crypto_skcipher_alg(tfm); + struct rk2_crypto_template *algt = container_of(alg, struct rk2_crypto_template, alg.skcipher.base); + struct rk2_crypto_dev *rkc = rctx->dev; + struct rk2_crypto_lli *dd = &rkc->tl[0]; + u32 m, v; + u32 *rkey = (u32 *)ctx->key; + u32 *riv = (u32 *)areq->iv; + int i; + unsigned int offset; + + algt->stat_req++; + rkc->nreq++; + + m = rctx->mode | RK2_CRYPTO_ENABLE; + if (algt->is_xts) { + switch (ctx->keylen) { + case AES_KEYSIZE_128 * 2: + m |= RK2_CRYPTO_AES_128BIT_key; + break; + case AES_KEYSIZE_256 * 2: + m |= RK2_CRYPTO_AES_256BIT_key; + break; + default: + dev_err(rkc->dev, "Invalid key length %u\n", ctx->keylen); + return -EINVAL; + } + } else { + switch (ctx->keylen) { + case AES_KEYSIZE_128: + m |= RK2_CRYPTO_AES_128BIT_key; + break; + case AES_KEYSIZE_192: + m |= RK2_CRYPTO_AES_192BIT_key; + break; + case AES_KEYSIZE_256: + m |= RK2_CRYPTO_AES_256BIT_key; + break; + default: + dev_err(rkc->dev, "Invalid key length %u\n", ctx->keylen); + return -EINVAL; + } + } + + err = pm_runtime_resume_and_get(rkc->dev); + if (err) + return err; + + /* the upper bits are a write enable mask, so we need to write 1 to all + * upper 16 bits to allow write to the 16 lower bits + */ + m |= 0xffff0000; + + dev_dbg(rkc->dev, "%s %s len=%u keylen=%u mode=%x\n", __func__, + crypto_tfm_alg_name(areq->base.tfm), + areq->cryptlen, ctx->keylen, m); + sgs = areq->src; + sgd = areq->dst; + + while (sgs && sgd && len) { + ivsize = crypto_skcipher_ivsize(tfm); + if (areq->iv && crypto_skcipher_ivsize(tfm) > 0) { + if (rctx->mode & RK2_CRYPTO_DEC) { + offset = sgs->length - ivsize; + scatterwalk_map_and_copy(rctx->backup_iv, sgs, + offset, ivsize, 0); + } + } + + dev_dbg(rkc->dev, "SG len=%u mode=%x ivsize=%u\n", sgs->length, m, ivsize); + + if (sgs == sgd) { + err = dma_map_sg(rkc->dev, sgs, 1, DMA_BIDIRECTIONAL); + if (err != 1) { + dev_err(rkc->dev, "Invalid sg number %d\n", err); + err = -EINVAL; + goto theend; + } + } else { + err = dma_map_sg(rkc->dev, sgs, 1, DMA_TO_DEVICE); + if (err != 1) { + dev_err(rkc->dev, "Invalid sg number %d\n", err); + err = -EINVAL; + goto theend; + } + err = dma_map_sg(rkc->dev, sgd, 1, DMA_FROM_DEVICE); + if (err != 1) { + dev_err(rkc->dev, "Invalid sg number %d\n", err); + err = -EINVAL; + dma_unmap_sg(rkc->dev, sgs, 1, DMA_TO_DEVICE); + goto theend; + } + } + err = 0; + writel(m, rkc->reg + RK2_CRYPTO_BC_CTL); + + if (algt->is_xts) { + for (i = 0; i < ctx->keylen / 8; i++) { + v = cpu_to_be32(rkey[i]); + writel(v, rkc->reg + RK2_CRYPTO_KEY0 + i * 4); + } + for (i = 0; i < (ctx->keylen / 8); i++) { + v = cpu_to_be32(rkey[i + ctx->keylen / 8]); + writel(v, rkc->reg + RK2_CRYPTO_CH4_KEY0 + i * 4); + } + } else { + for (i = 0; i < ctx->keylen / 4; i++) { + v = cpu_to_be32(rkey[i]); + writel(v, rkc->reg + RK2_CRYPTO_KEY0 + i * 4); + } + } + + if (ivsize) { + for (i = 0; i < ivsize / 4; i++) + writel(cpu_to_be32(riv[i]), + rkc->reg + RK2_CRYPTO_CH0_IV_0 + i * 4); + writel(ivsize, rkc->reg + RK2_CRYPTO_CH0_IV_LEN); + } + if (!sgs->length) { + sgs = sg_next(sgs); + sgd = sg_next(sgd); + continue; + } + + /* The hw support multiple descriptor, so why this driver use + * only one descriptor ? + * Using one descriptor per SG seems the way to do and it works + * but only when doing encryption. + * With decryption it always fail on second descriptor. + * Probably the HW dont know how to use IV. + */ + todo = min(sg_dma_len(sgs), len); + len -= todo; + dd->src_addr = sg_dma_address(sgs); + dd->src_len = todo; + dd->dst_addr = sg_dma_address(sgd); + dd->dst_len = todo; + dd->iv = 0; + dd->next = 1; + + dd->user = RK2_LLI_CIPHER_START | RK2_LLI_STRING_FIRST | RK2_LLI_STRING_LAST; + dd->dma_ctrl |= RK2_LLI_DMA_CTRL_DST_INT | RK2_LLI_DMA_CTRL_LAST; + + writel(RK2_CRYPTO_DMA_INT_LISTDONE | 0x7F, rkc->reg + RK2_CRYPTO_DMA_INT_EN); + + /*writel(0x00030000, rkc->reg + RK2_CRYPTO_FIFO_CTL);*/ + writel(rkc->t_phy, rkc->reg + RK2_CRYPTO_DMA_LLI_ADDR); + + reinit_completion(&rkc->complete); + rkc->status = 0; + + writel(RK2_CRYPTO_DMA_CTL_START | 1 << 16, rkc->reg + RK2_CRYPTO_DMA_CTL); + + wait_for_completion_interruptible_timeout(&rkc->complete, + msecs_to_jiffies(10000)); + if (sgs == sgd) { + dma_unmap_sg(rkc->dev, sgs, 1, DMA_BIDIRECTIONAL); + } else { + dma_unmap_sg(rkc->dev, sgs, 1, DMA_TO_DEVICE); + dma_unmap_sg(rkc->dev, sgd, 1, DMA_FROM_DEVICE); + } + + if (!rkc->status) { + dev_err(rkc->dev, "DMA timeout\n"); + rk2_print(rkc); + err = -EFAULT; + goto theend; + } + if (areq->iv && ivsize > 0) { + offset = sgd->length - ivsize; + if (rctx->mode & RK2_CRYPTO_DEC) { + memcpy(areq->iv, rctx->backup_iv, ivsize); + memzero_explicit(rctx->backup_iv, ivsize); + } else { + scatterwalk_map_and_copy(areq->iv, sgd, offset, + ivsize, 0); + } + } + sgs = sg_next(sgs); + sgd = sg_next(sgd); + } +theend: + writel(0xffff0000, rkc->reg + RK2_CRYPTO_BC_CTL); + pm_runtime_put_autosuspend(rkc->dev); + + local_bh_disable(); + crypto_finalize_skcipher_request(engine, areq, err); + local_bh_enable(); + return 0; +} + +int rk2_cipher_tfm_init(struct crypto_skcipher *tfm) +{ + struct rk2_cipher_ctx *ctx = crypto_skcipher_ctx(tfm); + const char *name = crypto_tfm_alg_name(&tfm->base); + struct skcipher_alg *alg = crypto_skcipher_alg(tfm); + struct rk2_crypto_template *algt = container_of(alg, struct rk2_crypto_template, alg.skcipher.base); + + ctx->fallback_tfm = crypto_alloc_skcipher(name, 0, CRYPTO_ALG_NEED_FALLBACK); + if (IS_ERR(ctx->fallback_tfm)) { + dev_err(algt->dev->dev, "ERROR: Cannot allocate fallback for %s %ld\n", + name, PTR_ERR(ctx->fallback_tfm)); + return PTR_ERR(ctx->fallback_tfm); + } + + dev_info(algt->dev->dev, "Fallback for %s is %s\n", + crypto_tfm_alg_driver_name(&tfm->base), + crypto_tfm_alg_driver_name(crypto_skcipher_tfm(ctx->fallback_tfm))); + + tfm->reqsize = sizeof(struct rk2_cipher_rctx) + + crypto_skcipher_reqsize(ctx->fallback_tfm); + + return 0; +} + +void rk2_cipher_tfm_exit(struct crypto_skcipher *tfm) +{ + struct rk2_cipher_ctx *ctx = crypto_skcipher_ctx(tfm); + + memzero_explicit(ctx->key, ctx->keylen); + crypto_free_skcipher(ctx->fallback_tfm); +} -- 2.41.0 ^ permalink raw reply related [flat|nested] 32+ messages in thread
* Re: [PATCH 6/6] crypto: rockchip: add rk3588 driver 2023-11-07 15:55 ` [PATCH 6/6] crypto: rockchip: add rk3588 driver Corentin Labbe @ 2023-11-07 16:35 ` Krzysztof Kozlowski 2023-11-07 16:42 ` Krzysztof Kozlowski 2023-11-12 14:04 ` Aw: " Frank Wunderlich 1 sibling, 1 reply; 32+ messages in thread From: Krzysztof Kozlowski @ 2023-11-07 16:35 UTC (permalink / raw) To: Corentin Labbe, davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip On 07/11/2023 16:55, Corentin Labbe wrote: > RK3588 have a new crypto IP, this patch adds basic support for it. > Only hashes and cipher are handled for the moment. > > Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > --- > drivers/crypto/Kconfig | 29 + > drivers/crypto/rockchip/Makefile | 5 + > drivers/crypto/rockchip/rk2_crypto.c | 739 ++++++++++++++++++ > drivers/crypto/rockchip/rk2_crypto.h | 246 ++++++ > drivers/crypto/rockchip/rk2_crypto_ahash.c | 344 ++++++++ > drivers/crypto/rockchip/rk2_crypto_skcipher.c | 576 ++++++++++++++ > 6 files changed, 1939 insertions(+) > create mode 100644 drivers/crypto/rockchip/rk2_crypto.c > create mode 100644 drivers/crypto/rockchip/rk2_crypto.h > create mode 100644 drivers/crypto/rockchip/rk2_crypto_ahash.c > create mode 100644 drivers/crypto/rockchip/rk2_crypto_skcipher.c > > diff --git a/drivers/crypto/Kconfig b/drivers/crypto/Kconfig > index 79c3bb9c99c3..b6a2027b1f9a 100644 > --- a/drivers/crypto/Kconfig > +++ b/drivers/crypto/Kconfig > @@ -660,6 +660,35 @@ config CRYPTO_DEV_ROCKCHIP_DEBUG > the number of requests per algorithm and other internal stats. > > > +config CRYPTO_DEV_ROCKCHIP2 > + tristate "Rockchip's cryptographic offloader V2" > + depends on OF && ARCH_ROCKCHIP > + depends on PM > + select CRYPTO_ECB > + select CRYPTO_CBC > + select CRYPTO_AES > + select CRYPTO_MD5 > + select CRYPTO_SHA1 > + select CRYPTO_SHA256 > + select CRYPTO_SHA512 > + select CRYPTO_SM3_GENERIC > + select CRYPTO_HASH > + select CRYPTO_SKCIPHER > + select CRYPTO_ENGINE > + > + help > + This driver interfaces with the hardware crypto offloader present > + on RK3566, RK3568 and RK3588. > + > +config CRYPTO_DEV_ROCKCHIP2_DEBUG > + bool "Enable Rockchip V2 crypto stats" > + depends on CRYPTO_DEV_ROCKCHIP2 > + depends on DEBUG_FS > + help > + Say y to enable Rockchip crypto debug stats. > + This will create /sys/kernel/debug/rk3588_crypto/stats for displaying > + the number of requests per algorithm and other internal stats. > + > config CRYPTO_DEV_ZYNQMP_AES > tristate "Support for Xilinx ZynqMP AES hw accelerator" > depends on ZYNQMP_FIRMWARE || COMPILE_TEST > diff --git a/drivers/crypto/rockchip/Makefile b/drivers/crypto/rockchip/Makefile > index 785277aca71e..452a12ff6538 100644 > --- a/drivers/crypto/rockchip/Makefile > +++ b/drivers/crypto/rockchip/Makefile > @@ -3,3 +3,8 @@ obj-$(CONFIG_CRYPTO_DEV_ROCKCHIP) += rk_crypto.o > rk_crypto-objs := rk3288_crypto.o \ > rk3288_crypto_skcipher.o \ > rk3288_crypto_ahash.o > + > +obj-$(CONFIG_CRYPTO_DEV_ROCKCHIP2) += rk_crypto2.o > +rk_crypto2-objs := rk2_crypto.o \ > + rk2_crypto_skcipher.o \ > + rk2_crypto_ahash.o > diff --git a/drivers/crypto/rockchip/rk2_crypto.c b/drivers/crypto/rockchip/rk2_crypto.c > new file mode 100644 > index 000000000000..f3b8d27924da > --- /dev/null > +++ b/drivers/crypto/rockchip/rk2_crypto.c > @@ -0,0 +1,739 @@ > +// SPDX-License-Identifier: GPL-2.0 > +/* > + * hardware cryptographic offloader for RK3568/RK3588 SoC > + * > + * Copyright (c) 2022-2023, Corentin Labbe <clabbe@baylibre.com> > + */ > + > +#include "rk2_crypto.h" > +#include <linux/clk.h> > +#include <linux/crypto.h> > +#include <linux/dma-mapping.h> > +#include <linux/module.h> > +#include <linux/platform_device.h> > +#include <linux/of.h> > +#include <linux/of_device.h> > +#include <linux/reset.h> > + > +static struct rockchip_ip rocklist = { > + .dev_list = LIST_HEAD_INIT(rocklist.dev_list), > + .lock = __SPIN_LOCK_UNLOCKED(rocklist.lock), Drop it, not needed. > +}; > + Exposed interfaces need kerneldoc. > +struct rk2_crypto_dev *get_rk2_crypto(void) > +{ > + struct rk2_crypto_dev *first; > + > + spin_lock(&rocklist.lock); > + first = list_first_entry_or_null(&rocklist.dev_list, > + struct rk2_crypto_dev, list); > + list_rotate_left(&rocklist.dev_list); > + spin_unlock(&rocklist.lock); > + return first; This is some spaghetti... Why do need a global list of devices to pass to crypto callbacks? The context is for that. This does not scale. Drop entire function. > +} > + > +static const struct rk2_variant rk3568_variant = { > + .num_clks = 3, > +}; > + > +static const struct rk2_variant rk3588_variant = { > + .num_clks = 3, > +}; > + > +static int rk2_crypto_get_clks(struct rk2_crypto_dev *dev) > +{ > + int i, j, err; > + unsigned long cr; > + > + dev->num_clks = devm_clk_bulk_get_all(dev->dev, &dev->clks); > + if (dev->num_clks < dev->variant->num_clks) { > + dev_err(dev->dev, "Missing clocks, got %d instead of %d\n", > + dev->num_clks, dev->variant->num_clks); > + return -EINVAL; > + } > + > + for (i = 0; i < dev->num_clks; i++) { > + cr = clk_get_rate(dev->clks[i].clk); > + for (j = 0; j < ARRAY_SIZE(dev->variant->rkclks); j++) { > + if (dev->variant->rkclks[j].max == 0) > + continue; > + if (strcmp(dev->variant->rkclks[j].name, dev->clks[i].id)) > + continue; > + if (cr > dev->variant->rkclks[j].max) { > + err = clk_set_rate(dev->clks[i].clk, > + dev->variant->rkclks[j].max); > + if (err) > + dev_err(dev->dev, "Fail downclocking %s from %lu to %lu\n", > + dev->variant->rkclks[j].name, cr, > + dev->variant->rkclks[j].max); > + else > + dev_info(dev->dev, "Downclocking %s from %lu to %lu\n", > + dev->variant->rkclks[j].name, cr, > + dev->variant->rkclks[j].max); > + } > + } > + } > + return 0; > +} > + > +static int rk2_crypto_enable_clk(struct rk2_crypto_dev *dev) > +{ > + int err; > + > + err = clk_bulk_prepare_enable(dev->num_clks, dev->clks); > + if (err) > + dev_err(dev->dev, "Could not enable clock clks\n"); Why do you create abstract wrappers over single call? > + > + return err; > +} > + > +static void rk2_crypto_disable_clk(struct rk2_crypto_dev *dev) > +{ > + clk_bulk_disable_unprepare(dev->num_clks, dev->clks); What is the benefit of this? I know that downstream code likes abstraction layers. You are supposed to remove all of them when upstreaming. > +} > + > +/* > + * Power management strategy: The device is suspended until a request > + * is handled. For avoiding suspend/resume yoyo, the autosuspend is set to 2s. > + */ > +static int rk2_crypto_pm_suspend(struct device *dev) > +{ ... > + } > +} > + > +static const struct of_device_id crypto_of_id_table[] = { > + { .compatible = "rockchip,rk3568-crypto", > + .data = &rk3568_variant, > + }, > + { .compatible = "rockchip,rk3588-crypto", > + .data = &rk3588_variant, > + }, > + {} > +}; > +MODULE_DEVICE_TABLE(of, crypto_of_id_table); > + > +static int rk2_crypto_probe(struct platform_device *pdev) > +{ > + struct device *dev = &pdev->dev; > + struct rk2_crypto_dev *rkc, *first; > + int err = 0; > + > + rkc = devm_kzalloc(&pdev->dev, sizeof(*rkc), GFP_KERNEL); > + if (!rkc) { > + err = -ENOMEM; return -ENOMEM > + goto err_crypto; > + } > + > + rkc->dev = &pdev->dev; > + platform_set_drvdata(pdev, rkc); > + > + rkc->variant = of_device_get_match_data(&pdev->dev); > + if (!rkc->variant) { > + dev_err(&pdev->dev, "Missing variant\n"); How is this possible? > + return -EINVAL; > + } > + > + rkc->rst = devm_reset_control_array_get_exclusive(dev); > + if (IS_ERR(rkc->rst)) { > + err = PTR_ERR(rkc->rst); > + dev_err(&pdev->dev, "Fail to get resets err=%d\n", err); Nope, this is just wrong. You do not have any cleanup path. And regardless of cleanup path, why do you print "Accelerator not successfully registered? It's an error! Syntax is: return dev_err_probe > + goto err_crypto; > + } > + > + rkc->tl = dma_alloc_coherent(rkc->dev, > + sizeof(struct rk2_crypto_lli) * MAX_LLI, > + &rkc->t_phy, GFP_KERNEL); > + if (!rkc->tl) { > + dev_err(rkc->dev, "Cannot get DMA memory for task\n"); Run coccinelle. > + err = -ENOMEM; Nope, return dev_err_probe > + goto err_crypto; > + } > + > + reset_control_assert(rkc->rst); > + usleep_range(10, 20); > + reset_control_deassert(rkc->rst); > + > + rkc->reg = devm_platform_ioremap_resource(pdev, 0); > + if (IS_ERR(rkc->reg)) { > + err = PTR_ERR(rkc->reg); > + dev_err(&pdev->dev, "Fail to get resources\n"); > + goto err_crypto; > + } > + > + err = rk2_crypto_get_clks(rkc); > + if (err) > + goto err_crypto; > + > + rkc->irq = platform_get_irq(pdev, 0); > + if (rkc->irq < 0) { > + dev_err(&pdev->dev, "control Interrupt is not available.\n"); > + err = rkc->irq; > + goto err_crypto; > + } > + > + err = devm_request_irq(&pdev->dev, rkc->irq, > + rk2_crypto_irq_handle, IRQF_SHARED, > + "rk-crypto", pdev); > + > + if (err) { > + dev_err(&pdev->dev, "irq request failed.\n"); > + goto err_crypto; > + } > + > + rkc->engine = crypto_engine_alloc_init(&pdev->dev, true); > + crypto_engine_start(rkc->engine); > + init_completion(&rkc->complete); > + > + err = rk2_crypto_pm_init(rkc); > + if (err) > + goto err_pm; > + > + err = pm_runtime_resume_and_get(&pdev->dev); > + > + spin_lock(&rocklist.lock); > + first = list_first_entry_or_null(&rocklist.dev_list, > + struct rk2_crypto_dev, list); > + list_add_tail(&rkc->list, &rocklist.dev_list); > + spin_unlock(&rocklist.lock); > + > + if (!first) { > + dev_info(dev, "Registers crypto algos\n"); > + err = rk2_crypto_register(rkc); > + if (err) { > + dev_err(dev, "Fail to register crypto algorithms"); > + goto err_register_alg; > + } > + > + register_debugfs(rkc); > + } > + > + return 0; > + > +err_register_alg: > + rk2_crypto_pm_exit(rkc); > +err_pm: > + crypto_engine_exit(rkc->engine); > +err_crypto: > + dev_err(dev, "Crypto Accelerator not successfully registered\n"); Drop useless probe success messages. > + return err; > +} > + > +static int rk2_crypto_remove(struct platform_device *pdev) > +{ > + struct rk2_crypto_dev *rkc = platform_get_drvdata(pdev); > + struct rk2_crypto_dev *first; > + > + spin_lock_bh(&rocklist.lock); > + list_del(&rkc->list); > + first = list_first_entry_or_null(&rocklist.dev_list, > + struct rk2_crypto_dev, list); > + spin_unlock_bh(&rocklist.lock); > + > + if (!first) { > +#ifdef CONFIG_CRYPTO_DEV_ROCKCHIP2_DEBUG > + debugfs_remove_recursive(rocklist.dbgfs_dir); > +#endif > + rk2_crypto_unregister(); > + } > + rk2_crypto_pm_exit(rkc); > + crypto_engine_exit(rkc->engine); > + return 0; > +} > + > +static struct platform_driver crypto_driver = { > + .probe = rk2_crypto_probe, > + .remove = rk2_crypto_remove, > + .driver = { > + .name = "rk2-crypto", > + .pm = &rk2_crypto_pm_ops, > + .of_match_table = crypto_of_id_table, > + }, > +}; > + > +module_platform_driver(crypto_driver); > + > +MODULE_DESCRIPTION("Rockchip Crypto Engine cryptographic offloader"); > +MODULE_LICENSE("GPL"); > +MODULE_AUTHOR("Corentin Labbe <clabbe@baylibre.com>"); > diff --git a/drivers/crypto/rockchip/rk2_crypto.h b/drivers/crypto/rockchip/rk2_crypto.h > new file mode 100644 > index 000000000000..59cd8be59f70 > --- /dev/null > +++ b/drivers/crypto/rockchip/rk2_crypto.h > @@ -0,0 +1,246 @@ > +/* SPDX-License-Identifier: GPL-2.0 */ > + > +#include <crypto/aes.h> > +#include <crypto/xts.h> > +#include <crypto/engine.h> > +#include <crypto/internal/des.h> > +#include <crypto/internal/hash.h> > +#include <crypto/internal/skcipher.h> > +#include <crypto/algapi.h> > +#include <crypto/md5.h> > +#include <crypto/sha1.h> > +#include <crypto/sha2.h> > +#include <crypto/sm3.h> > +#include <linux/dma-mapping.h> > +#include <linux/interrupt.h> > +#include <linux/debugfs.h> > +#include <linux/delay.h> > +#include <linux/pm_runtime.h> > +#include <linux/scatterlist.h> > +#include <linux/hw_random.h> Nope. This is some insane list of unneeded headers. You include here only the headers which this header uses. I see just few. > + > +#define RK2_CRYPTO_CLK_CTL 0x0000 > +#define RK2_CRYPTO_RST_CTL 0x0004 > + > +#define RK2_CRYPTO_DMA_INT_EN 0x0008 > +/* values for RK2_CRYPTO_DMA_INT_EN */ > +#define RK2_CRYPTO_DMA_INT_LISTDONE BIT(0) > + > +#define RK2_CRYPTO_DMA_INT_ST 0x000C > +/* values in RK2_CRYPTO_DMA_INT_ST are the same than in RK2_CRYPTO_DMA_INT_EN */ > + > +#define RK2_CRYPTO_DMA_CTL 0x0010 > +#define RK2_CRYPTO_DMA_CTL_START BIT(0) > + > +#define RK2_CRYPTO_DMA_LLI_ADDR 0x0014 > +#define RK2_CRYPTO_DMA_ST 0x0018 > +#define RK2_CRYPTO_DMA_STATE 0x001C > +#define RK2_CRYPTO_DMA_LLI_RADDR 0x0020 > +#define RK2_CRYPTO_DMA_SRC_RADDR 0x0024 > +#define RK2_CRYPTO_DMA_DST_WADDR 0x0028 > +#define RK2_CRYPTO_DMA_ITEM_ID 0x002C > + > +#define RK2_CRYPTO_FIFO_CTL 0x0040 > + > +#define RK2_CRYPTO_BC_CTL 0x0044 > +#define RK2_CRYPTO_AES (0 << 8) > +#define RK2_CRYPTO_MODE_ECB (0 << 4) > +#define RK2_CRYPTO_MODE_CBC (1 << 4) > +#define RK2_CRYPTO_XTS (6 << 4) > + > +#define RK2_CRYPTO_HASH_CTL 0x0048 > +#define RK2_CRYPTO_HW_PAD BIT(2) > +#define RK2_CRYPTO_SHA1 (0 << 4) > +#define RK2_CRYPTO_MD5 (1 << 4) > +#define RK2_CRYPTO_SHA224 (3 << 4) > +#define RK2_CRYPTO_SHA256 (2 << 4) > +#define RK2_CRYPTO_SHA384 (9 << 4) > +#define RK2_CRYPTO_SHA512 (8 << 4) > +#define RK2_CRYPTO_SM3 (4 << 4) > + > +#define RK2_CRYPTO_AES_ECB (RK2_CRYPTO_AES | RK2_CRYPTO_MODE_ECB) > +#define RK2_CRYPTO_AES_CBC (RK2_CRYPTO_AES | RK2_CRYPTO_MODE_CBC) > +#define RK2_CRYPTO_AES_XTS (RK2_CRYPTO_AES | RK2_CRYPTO_XTS) > +#define RK2_CRYPTO_AES_CTR_MODE 3 > +#define RK2_CRYPTO_AES_128BIT_key (0 << 2) > +#define RK2_CRYPTO_AES_192BIT_key (1 << 2) > +#define RK2_CRYPTO_AES_256BIT_key (2 << 2) > + > +#define RK2_CRYPTO_DEC BIT(1) > +#define RK2_CRYPTO_ENABLE BIT(0) > + > +#define RK2_CRYPTO_CIPHER_ST 0x004C > +#define RK2_CRYPTO_CIPHER_STATE 0x0050 > + > +#define RK2_CRYPTO_CH0_IV_0 0x0100 > + > +#define RK2_CRYPTO_KEY0 0x0180 > +#define RK2_CRYPTO_KEY1 0x0184 > +#define RK2_CRYPTO_KEY2 0x0188 > +#define RK2_CRYPTO_KEY3 0x018C > +#define RK2_CRYPTO_KEY4 0x0190 > +#define RK2_CRYPTO_KEY5 0x0194 > +#define RK2_CRYPTO_KEY6 0x0198 > +#define RK2_CRYPTO_KEY7 0x019C > +#define RK2_CRYPTO_CH4_KEY0 0x01c0 > + > +#define RK2_CRYPTO_CH0_PC_LEN_0 0x0280 > + > +#define RK2_CRYPTO_CH0_IV_LEN 0x0300 > + > +#define RK2_CRYPTO_HASH_DOUT_0 0x03A0 > +#define RK2_CRYPTO_HASH_VALID 0x03E4 > + > +#define RK2_CRYPTO_TRNG_CTL 0x0400 > +#define RK2_CRYPTO_TRNG_START BIT(0) > +#define RK2_CRYPTO_TRNG_ENABLE BIT(1) > +#define RK2_CRYPTO_TRNG_256 (0x3 << 4) > +#define RK2_CRYPTO_TRNG_SAMPLE_CNT 0x0404 > +#define RK2_CRYPTO_TRNG_DOUT 0x0410 > + > +#define CRYPTO_AES_VERSION 0x0680 > +#define CRYPTO_DES_VERSION 0x0684 > +#define CRYPTO_SM4_VERSION 0x0688 > +#define CRYPTO_HASH_VERSION 0x068C > +#define CRYPTO_HMAC_VERSION 0x0690 > +#define CRYPTO_RNG_VERSION 0x0694 > +#define CRYPTO_PKA_VERSION 0x0698 > +#define CRYPTO_CRYPTO_VERSION 0x06F0 > + > +#define RK2_LLI_DMA_CTRL_SRC_INT BIT(10) > +#define RK2_LLI_DMA_CTRL_DST_INT BIT(9) > +#define RK2_LLI_DMA_CTRL_LIST_INT BIT(8) > +#define RK2_LLI_DMA_CTRL_LAST BIT(0) > + > +#define RK2_LLI_STRING_LAST BIT(2) > +#define RK2_LLI_STRING_FIRST BIT(1) > +#define RK2_LLI_CIPHER_START BIT(0) > + > +#define RK2_MAX_CLKS 4 > + > +#define MAX_LLI 20 > + > +struct rk2_crypto_lli { > + __le32 src_addr; > + __le32 src_len; > + __le32 dst_addr; > + __le32 dst_len; > + __le32 user; > + __le32 iv; > + __le32 dma_ctrl; > + __le32 next; > +}; > + > +/* > + * struct rockchip_ip - struct for managing a list of RK crypto instance > + * @dev_list: Used for doing a list of rk2_crypto_dev > + * @lock: Control access to dev_list > + * @dbgfs_dir: Debugfs dentry for statistic directory > + * @dbgfs_stats: Debugfs dentry for statistic counters > + */ > +struct rockchip_ip { > + struct list_head dev_list; > + spinlock_t lock; /* Control access to dev_list */ > + struct dentry *dbgfs_dir; > + struct dentry *dbgfs_stats; > +}; > + > +struct rk2_clks { > + const char *name; > + unsigned long max; > +}; > + > +struct rk2_variant { > + int num_clks; > + struct rk2_clks rkclks[RK2_MAX_CLKS]; > +}; > + > +struct rk2_crypto_dev { > + struct list_head list; > + struct device *dev; > + struct clk_bulk_data *clks; > + int num_clks; > + struct reset_control *rst; > + void __iomem *reg; > + int irq; > + const struct rk2_variant *variant; > + unsigned long nreq; > + struct crypto_engine *engine; > + struct completion complete; > + int status; > + struct rk2_crypto_lli *tl; > + dma_addr_t t_phy; > +}; > + > +/* the private variable of hash */ > +struct rk2_ahash_ctx { > + /* for fallback */ > + struct crypto_ahash *fallback_tfm; > +}; > + > +/* the private variable of hash for fallback */ > +struct rk2_ahash_rctx { > + struct rk2_crypto_dev *dev; > + struct ahash_request fallback_req; > + u32 mode; > + int nrsgs; > +}; > + > +/* the private variable of cipher */ > +struct rk2_cipher_ctx { > + unsigned int keylen; > + u8 key[AES_MAX_KEY_SIZE * 2]; > + u8 iv[AES_BLOCK_SIZE]; > + struct crypto_skcipher *fallback_tfm; > +}; > + > +struct rk2_cipher_rctx { > + struct rk2_crypto_dev *dev; > + u8 backup_iv[AES_BLOCK_SIZE]; > + u32 mode; > + struct skcipher_request fallback_req; // keep at the end > +}; > + > +struct rk2_crypto_template { > + u32 type; > + u32 rk2_mode; > + bool is_xts; > + struct rk2_crypto_dev *dev; Your indentation is a mess. > + union { > + struct skcipher_engine_alg skcipher; > + struct ahash_engine_alg hash; > + } alg; > + unsigned long stat_req; > + unsigned long stat_fb; > + unsigned long stat_fb_len; > + unsigned long stat_fb_sglen; > + unsigned long stat_fb_align; > + unsigned long stat_fb_sgdiff; > +}; > + > +struct rk2_crypto_dev *get_rk2_crypto(void); > +int rk2_cipher_run(struct crypto_engine *engine, void *async_req); > +int rk2_hash_run(struct crypto_engine *engine, void *breq); > + > +int rk2_cipher_tfm_init(struct crypto_skcipher *tfm); > +void rk2_cipher_tfm_exit(struct crypto_skcipher *tfm); > +int rk2_aes_setkey(struct crypto_skcipher *cipher, const u8 *key, > + unsigned int keylen); > +int rk2_aes_xts_setkey(struct crypto_skcipher *cipher, const u8 *key, > + unsigned int keylen); > +int rk2_skcipher_encrypt(struct skcipher_request *req); > +int rk2_skcipher_decrypt(struct skcipher_request *req); > +int rk2_aes_ecb_encrypt(struct skcipher_request *req); > +int rk2_aes_ecb_decrypt(struct skcipher_request *req); > +int rk2_aes_cbc_encrypt(struct skcipher_request *req); > +int rk2_aes_cbc_decrypt(struct skcipher_request *req); > + > +int rk2_ahash_init(struct ahash_request *req); > +int rk2_ahash_update(struct ahash_request *req); > +int rk2_ahash_final(struct ahash_request *req); > +int rk2_ahash_finup(struct ahash_request *req); > +int rk2_ahash_import(struct ahash_request *req, const void *in); > +int rk2_ahash_export(struct ahash_request *req, void *out); > +int rk2_ahash_digest(struct ahash_request *req); > +int rk2_hash_init_tfm(struct crypto_ahash *tfm); > +void rk2_hash_exit_tfm(struct crypto_ahash *tfm); Missing guards. > diff --git a/drivers/crypto/rockchip/rk2_crypto_ahash.c b/drivers/crypto/rockchip/rk2_crypto_ahash.c > new file mode 100644 > index 000000000000..75b8d9893447 > --- /dev/null > +++ b/drivers/crypto/rockchip/rk2_crypto_ahash.c > @@ -0,0 +1,344 @@ > +// SPDX-License-Identifier: GPL-2.0-only > +/* > + * Crypto offloader support for Rockchip RK3568/RK3588 > + * > + * Copyright (c) 2022-2023 Corentin Labbe <clabbe@baylibre.com> > + */ > +#include <asm/unaligned.h> > +#include <linux/iopoll.h> There is no way this file needs only two headers. Each unit must include everything it uses. > +#include "rk2_crypto.h" So here you stuffed all the includes... no. > + > +int rk2_hash_run(struct crypto_engine *engine, void *breq) > +{ > + struct ahash_request *areq = container_of(breq, struct ahash_request, base); > + struct crypto_ahash *tfm = crypto_ahash_reqtfm(areq); > + struct rk2_ahash_rctx *rctx = ahash_request_ctx(areq); > + struct ahash_alg *alg = crypto_ahash_alg(tfm); > + struct rk2_crypto_template *algt = container_of(alg, struct rk2_crypto_template, alg.hash.base); > + struct scatterlist *sgs = areq->src; > + struct rk2_crypto_dev *rkc = rctx->dev; > + struct rk2_crypto_lli *dd = &rkc->tl[0]; > + int ddi = 0; > + int err = 0; > + unsigned int len = areq->nbytes; > + unsigned int todo; > + u32 v; > + int i; > + > + err = rk2_hash_prepare(engine, breq); > + > + err = pm_runtime_resume_and_get(rkc->dev); > + if (err) > + return err; > + > + dev_dbg(rkc->dev, "%s %s len=%d\n", __func__, > + crypto_tfm_alg_name(areq->base.tfm), areq->nbytes); > + > + algt->stat_req++; > + rkc->nreq++; > + > + rctx->mode = algt->rk2_mode; > + rctx->mode |= 0xffff0000; > + rctx->mode |= RK2_CRYPTO_ENABLE | RK2_CRYPTO_HW_PAD; > + writel(rctx->mode, rkc->reg + RK2_CRYPTO_HASH_CTL); > + > + while (sgs && len > 0) { > + dd = &rkc->tl[ddi]; > + > + todo = min(sg_dma_len(sgs), len); > + dd->src_addr = sg_dma_address(sgs); > + dd->src_len = todo; > + dd->dst_addr = 0; > + dd->dst_len = 0; > + dd->dma_ctrl = ddi << 24; > + dd->iv = 0; > + dd->next = rkc->t_phy + sizeof(struct rk2_crypto_lli) * (ddi + 1); > + > + if (ddi == 0) > + dd->user = RK2_LLI_CIPHER_START | RK2_LLI_STRING_FIRST; > + else > + dd->user = 0; > + > + len -= todo; > + dd->dma_ctrl |= RK2_LLI_DMA_CTRL_SRC_INT; > + if (len == 0) { > + dd->user |= RK2_LLI_STRING_LAST; > + dd->dma_ctrl |= RK2_LLI_DMA_CTRL_LAST; > + } > + dev_dbg(rkc->dev, "HASH SG %d sglen=%d user=%x dma=%x mode=%x len=%d todo=%d phy=%llx\n", > + ddi, sgs->length, dd->user, dd->dma_ctrl, rctx->mode, len, todo, rkc->t_phy); > + > + sgs = sg_next(sgs); > + ddi++; > + } > + dd->next = 1; > + writel(RK2_CRYPTO_DMA_INT_LISTDONE | 0x7F, rkc->reg + RK2_CRYPTO_DMA_INT_EN); > + > + writel(rkc->t_phy, rkc->reg + RK2_CRYPTO_DMA_LLI_ADDR); > + > + reinit_completion(&rkc->complete); > + rkc->status = 0; > + > + writel(RK2_CRYPTO_DMA_CTL_START | RK2_CRYPTO_DMA_CTL_START << 16, rkc->reg + RK2_CRYPTO_DMA_CTL); Wrap your code according to Coding Style document (so 80). > + > + wait_for_completion_interruptible_timeout(&rkc->complete, > + msecs_to_jiffies(2000)); > + if (!rkc->status) { > + dev_err(rkc->dev, "DMA timeout\n"); > + err = -EFAULT; > + goto theend; Please use something closer to Linux. goto exit; goto out; Best regards, Krzysztof ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 6/6] crypto: rockchip: add rk3588 driver 2023-11-07 16:35 ` Krzysztof Kozlowski @ 2023-11-07 16:42 ` Krzysztof Kozlowski 2023-11-07 16:56 ` Krzysztof Kozlowski 0 siblings, 1 reply; 32+ messages in thread From: Krzysztof Kozlowski @ 2023-11-07 16:42 UTC (permalink / raw) To: Corentin Labbe, davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip On 07/11/2023 17:35, Krzysztof Kozlowski wrote: > On 07/11/2023 16:55, Corentin Labbe wrote: >> RK3588 have a new crypto IP, this patch adds basic support for it. >> Only hashes and cipher are handled for the moment. >> >> Signed-off-by: Corentin Labbe <clabbe@baylibre.com> >> --- >> drivers/crypto/Kconfig | 29 + >> drivers/crypto/rockchip/Makefile | 5 + >> drivers/crypto/rockchip/rk2_crypto.c | 739 ++++++++++++++++++ >> drivers/crypto/rockchip/rk2_crypto.h | 246 ++++++ >> drivers/crypto/rockchip/rk2_crypto_ahash.c | 344 ++++++++ >> drivers/crypto/rockchip/rk2_crypto_skcipher.c | 576 ++++++++++++++ >> 6 files changed, 1939 insertions(+) >> create mode 100644 drivers/crypto/rockchip/rk2_crypto.c >> create mode 100644 drivers/crypto/rockchip/rk2_crypto.h >> create mode 100644 drivers/crypto/rockchip/rk2_crypto_ahash.c >> create mode 100644 drivers/crypto/rockchip/rk2_crypto_skcipher.c >> >> diff --git a/drivers/crypto/Kconfig b/drivers/crypto/Kconfig >> index 79c3bb9c99c3..b6a2027b1f9a 100644 >> --- a/drivers/crypto/Kconfig >> +++ b/drivers/crypto/Kconfig >> @@ -660,6 +660,35 @@ config CRYPTO_DEV_ROCKCHIP_DEBUG >> the number of requests per algorithm and other internal stats. >> >> >> +config CRYPTO_DEV_ROCKCHIP2 >> + tristate "Rockchip's cryptographic offloader V2" >> + depends on OF && ARCH_ROCKCHIP >> + depends on PM >> + select CRYPTO_ECB >> + select CRYPTO_CBC >> + select CRYPTO_AES >> + select CRYPTO_MD5 >> + select CRYPTO_SHA1 >> + select CRYPTO_SHA256 >> + select CRYPTO_SHA512 >> + select CRYPTO_SM3_GENERIC >> + select CRYPTO_HASH >> + select CRYPTO_SKCIPHER >> + select CRYPTO_ENGINE >> + >> + help >> + This driver interfaces with the hardware crypto offloader present >> + on RK3566, RK3568 and RK3588. >> + >> +config CRYPTO_DEV_ROCKCHIP2_DEBUG >> + bool "Enable Rockchip V2 crypto stats" >> + depends on CRYPTO_DEV_ROCKCHIP2 >> + depends on DEBUG_FS >> + help >> + Say y to enable Rockchip crypto debug stats. >> + This will create /sys/kernel/debug/rk3588_crypto/stats for displaying >> + the number of requests per algorithm and other internal stats. >> + >> config CRYPTO_DEV_ZYNQMP_AES >> tristate "Support for Xilinx ZynqMP AES hw accelerator" >> depends on ZYNQMP_FIRMWARE || COMPILE_TEST >> diff --git a/drivers/crypto/rockchip/Makefile b/drivers/crypto/rockchip/Makefile >> index 785277aca71e..452a12ff6538 100644 >> --- a/drivers/crypto/rockchip/Makefile >> +++ b/drivers/crypto/rockchip/Makefile >> @@ -3,3 +3,8 @@ obj-$(CONFIG_CRYPTO_DEV_ROCKCHIP) += rk_crypto.o >> rk_crypto-objs := rk3288_crypto.o \ >> rk3288_crypto_skcipher.o \ >> rk3288_crypto_ahash.o >> + >> +obj-$(CONFIG_CRYPTO_DEV_ROCKCHIP2) += rk_crypto2.o >> +rk_crypto2-objs := rk2_crypto.o \ >> + rk2_crypto_skcipher.o \ >> + rk2_crypto_ahash.o >> diff --git a/drivers/crypto/rockchip/rk2_crypto.c b/drivers/crypto/rockchip/rk2_crypto.c >> new file mode 100644 >> index 000000000000..f3b8d27924da >> --- /dev/null >> +++ b/drivers/crypto/rockchip/rk2_crypto.c >> @@ -0,0 +1,739 @@ >> +// SPDX-License-Identifier: GPL-2.0 >> +/* >> + * hardware cryptographic offloader for RK3568/RK3588 SoC >> + * >> + * Copyright (c) 2022-2023, Corentin Labbe <clabbe@baylibre.com> >> + */ >> + >> +#include "rk2_crypto.h" >> +#include <linux/clk.h> >> +#include <linux/crypto.h> >> +#include <linux/dma-mapping.h> >> +#include <linux/module.h> >> +#include <linux/platform_device.h> >> +#include <linux/of.h> >> +#include <linux/of_device.h> >> +#include <linux/reset.h> >> + >> +static struct rockchip_ip rocklist = { >> + .dev_list = LIST_HEAD_INIT(rocklist.dev_list), >> + .lock = __SPIN_LOCK_UNLOCKED(rocklist.lock), > > Drop it, not needed. To clarify: I mean entire structure. Best regards, Krzysztof ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: [PATCH 6/6] crypto: rockchip: add rk3588 driver 2023-11-07 16:42 ` Krzysztof Kozlowski @ 2023-11-07 16:56 ` Krzysztof Kozlowski 0 siblings, 0 replies; 32+ messages in thread From: Krzysztof Kozlowski @ 2023-11-07 16:56 UTC (permalink / raw) To: Corentin Labbe, davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd Cc: ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip On 07/11/2023 17:42, Krzysztof Kozlowski wrote: > On 07/11/2023 17:35, Krzysztof Kozlowski wrote: >> On 07/11/2023 16:55, Corentin Labbe wrote: >>> RK3588 have a new crypto IP, this patch adds basic support for it. >>> Only hashes and cipher are handled for the moment. >>> >>> Signed-off-by: Corentin Labbe <clabbe@baylibre.com> >>> --- >>> drivers/crypto/Kconfig | 29 + >>> drivers/crypto/rockchip/Makefile | 5 + >>> drivers/crypto/rockchip/rk2_crypto.c | 739 ++++++++++++++++++ >>> drivers/crypto/rockchip/rk2_crypto.h | 246 ++++++ >>> drivers/crypto/rockchip/rk2_crypto_ahash.c | 344 ++++++++ >>> drivers/crypto/rockchip/rk2_crypto_skcipher.c | 576 ++++++++++++++ >>> 6 files changed, 1939 insertions(+) >>> create mode 100644 drivers/crypto/rockchip/rk2_crypto.c >>> create mode 100644 drivers/crypto/rockchip/rk2_crypto.h >>> create mode 100644 drivers/crypto/rockchip/rk2_crypto_ahash.c >>> create mode 100644 drivers/crypto/rockchip/rk2_crypto_skcipher.c >>> >>> diff --git a/drivers/crypto/Kconfig b/drivers/crypto/Kconfig >>> index 79c3bb9c99c3..b6a2027b1f9a 100644 >>> --- a/drivers/crypto/Kconfig >>> +++ b/drivers/crypto/Kconfig >>> @@ -660,6 +660,35 @@ config CRYPTO_DEV_ROCKCHIP_DEBUG >>> the number of requests per algorithm and other internal stats. >>> >>> >>> +config CRYPTO_DEV_ROCKCHIP2 >>> + tristate "Rockchip's cryptographic offloader V2" >>> + depends on OF && ARCH_ROCKCHIP >>> + depends on PM >>> + select CRYPTO_ECB >>> + select CRYPTO_CBC >>> + select CRYPTO_AES >>> + select CRYPTO_MD5 >>> + select CRYPTO_SHA1 >>> + select CRYPTO_SHA256 >>> + select CRYPTO_SHA512 >>> + select CRYPTO_SM3_GENERIC >>> + select CRYPTO_HASH >>> + select CRYPTO_SKCIPHER >>> + select CRYPTO_ENGINE >>> + >>> + help >>> + This driver interfaces with the hardware crypto offloader present >>> + on RK3566, RK3568 and RK3588. >>> + >>> +config CRYPTO_DEV_ROCKCHIP2_DEBUG >>> + bool "Enable Rockchip V2 crypto stats" >>> + depends on CRYPTO_DEV_ROCKCHIP2 >>> + depends on DEBUG_FS >>> + help >>> + Say y to enable Rockchip crypto debug stats. >>> + This will create /sys/kernel/debug/rk3588_crypto/stats for displaying >>> + the number of requests per algorithm and other internal stats. >>> + >>> config CRYPTO_DEV_ZYNQMP_AES >>> tristate "Support for Xilinx ZynqMP AES hw accelerator" >>> depends on ZYNQMP_FIRMWARE || COMPILE_TEST >>> diff --git a/drivers/crypto/rockchip/Makefile b/drivers/crypto/rockchip/Makefile >>> index 785277aca71e..452a12ff6538 100644 >>> --- a/drivers/crypto/rockchip/Makefile >>> +++ b/drivers/crypto/rockchip/Makefile >>> @@ -3,3 +3,8 @@ obj-$(CONFIG_CRYPTO_DEV_ROCKCHIP) += rk_crypto.o >>> rk_crypto-objs := rk3288_crypto.o \ >>> rk3288_crypto_skcipher.o \ >>> rk3288_crypto_ahash.o >>> + >>> +obj-$(CONFIG_CRYPTO_DEV_ROCKCHIP2) += rk_crypto2.o >>> +rk_crypto2-objs := rk2_crypto.o \ >>> + rk2_crypto_skcipher.o \ >>> + rk2_crypto_ahash.o >>> diff --git a/drivers/crypto/rockchip/rk2_crypto.c b/drivers/crypto/rockchip/rk2_crypto.c >>> new file mode 100644 >>> index 000000000000..f3b8d27924da >>> --- /dev/null >>> +++ b/drivers/crypto/rockchip/rk2_crypto.c >>> @@ -0,0 +1,739 @@ >>> +// SPDX-License-Identifier: GPL-2.0 >>> +/* >>> + * hardware cryptographic offloader for RK3568/RK3588 SoC >>> + * >>> + * Copyright (c) 2022-2023, Corentin Labbe <clabbe@baylibre.com> >>> + */ >>> + >>> +#include "rk2_crypto.h" >>> +#include <linux/clk.h> >>> +#include <linux/crypto.h> >>> +#include <linux/dma-mapping.h> >>> +#include <linux/module.h> >>> +#include <linux/platform_device.h> >>> +#include <linux/of.h> >>> +#include <linux/of_device.h> >>> +#include <linux/reset.h> >>> + >>> +static struct rockchip_ip rocklist = { >>> + .dev_list = LIST_HEAD_INIT(rocklist.dev_list), >>> + .lock = __SPIN_LOCK_UNLOCKED(rocklist.lock), >> >> Drop it, not needed. > > To clarify: I mean entire structure. ... and I think I was wrong - skcipher_engine_alg and other parts still do not handle device context, so indeed you might need global list. Best regards, Krzysztof ^ permalink raw reply [flat|nested] 32+ messages in thread
* Aw: [PATCH 6/6] crypto: rockchip: add rk3588 driver 2023-11-07 15:55 ` [PATCH 6/6] crypto: rockchip: add rk3588 driver Corentin Labbe 2023-11-07 16:35 ` Krzysztof Kozlowski @ 2023-11-12 14:04 ` Frank Wunderlich 2023-11-20 12:48 ` Corentin LABBE 1 sibling, 1 reply; 32+ messages in thread From: Frank Wunderlich @ 2023-11-12 14:04 UTC (permalink / raw) To: Corentin Labbe Cc: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip, Corentin Labbe Hi Corentin thanks for working on it > Gesendet: Dienstag, 07. November 2023 um 16:55 Uhr > Von: "Corentin Labbe" <clabbe@baylibre.com> > An: davem@davemloft.net, heiko@sntech.de, herbert@gondor.apana.org.au, krzysztof.kozlowski+dt@linaro.org, mturquette@baylibre.com, p.zabel@pengutronix.de, robh+dt@kernel.org, sboyd@kernel.org > Cc: ricardo@pardini.net, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-clk@vger.kernel.org, linux-crypto@vger.kernel.org, linux-kernel@vger.kernel.org, linux-rockchip@lists.infradead.org, "Corentin Labbe" <clabbe@baylibre.com> > Betreff: [PATCH 6/6] crypto: rockchip: add rk3588 driver > > RK3588 have a new crypto IP, this patch adds basic support for it. > Only hashes and cipher are handled for the moment. > > Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > --- > drivers/crypto/Kconfig | 29 + > drivers/crypto/rockchip/Makefile | 5 + > drivers/crypto/rockchip/rk2_crypto.c | 739 ++++++++++++++++++ > drivers/crypto/rockchip/rk2_crypto.h | 246 ++++++ > drivers/crypto/rockchip/rk2_crypto_ahash.c | 344 ++++++++ > drivers/crypto/rockchip/rk2_crypto_skcipher.c | 576 ++++++++++++++ > 6 files changed, 1939 insertions(+) > create mode 100644 drivers/crypto/rockchip/rk2_crypto.c > create mode 100644 drivers/crypto/rockchip/rk2_crypto.h > create mode 100644 drivers/crypto/rockchip/rk2_crypto_ahash.c > create mode 100644 drivers/crypto/rockchip/rk2_crypto_skcipher.c > > diff --git a/drivers/crypto/Kconfig b/drivers/crypto/Kconfig > index 79c3bb9c99c3..b6a2027b1f9a 100644 > --- a/drivers/crypto/Kconfig > +++ b/drivers/crypto/Kconfig > @@ -660,6 +660,35 @@ config CRYPTO_DEV_ROCKCHIP_DEBUG > the number of requests per algorithm and other internal stats. > > > +config CRYPTO_DEV_ROCKCHIP2 > + tristate "Rockchip's cryptographic offloader V2" > + depends on OF && ARCH_ROCKCHIP > + depends on PM it should depend on CONFIG_CRYPTO_DEV_ROCKCHIP as rockchip folder is not included without it drivers/crypto/Makefile obj-$(CONFIG_CRYPTO_DEV_ROCKCHIP) += rockchip/ > + select CRYPTO_ECB > + select CRYPTO_CBC > + select CRYPTO_AES > + select CRYPTO_MD5 > + select CRYPTO_SHA1 > + select CRYPTO_SHA256 > + select CRYPTO_SHA512 > + select CRYPTO_SM3_GENERIC > + select CRYPTO_HASH > + select CRYPTO_SKCIPHER > + select CRYPTO_ENGINE > + > + help > + This driver interfaces with the hardware crypto offloader present > + on RK3566, RK3568 and RK3588. > + > +config CRYPTO_DEV_ROCKCHIP2_DEBUG > + bool "Enable Rockchip V2 crypto stats" > + depends on CRYPTO_DEV_ROCKCHIP2 > + depends on DEBUG_FS > + help > + Say y to enable Rockchip crypto debug stats. > + This will create /sys/kernel/debug/rk3588_crypto/stats for displaying > + the number of requests per algorithm and other internal stats. > + > config CRYPTO_DEV_ZYNQMP_AES > tristate "Support for Xilinx ZynqMP AES hw accelerator" > depends on ZYNQMP_FIRMWARE || COMPILE_TEST > diff --git a/drivers/crypto/rockchip/Makefile b/drivers/crypto/rockchip/Makefile > index 785277aca71e..452a12ff6538 100644 else i did some tests, but it does not seem that the offloader is used (requests stay at initial value after the bootup test) i wonder about the last 3 lines in dmesg (fallback), seems i miss something for these. root@bpi-r2pro:~# dmesg | grep crypto [ 0.150643] alg: extra crypto tests enabled. This is intended for developer use only. [ 2.718110] rk2-crypto fe380000.crypto: will run requests pump with realtime priority [ 2.720605] rk2-crypto fe380000.crypto: Registers crypto algos [ 2.721910] rk2-crypto fe380000.crypto: Register ecb(aes) as ecb-aes-rk2 [ 2.724435] rk2-crypto fe380000.crypto: Register cbc(aes) as cbc-aes-rk2 [ 2.725072] rk2-crypto fe380000.crypto: Register xts(aes) as xts-aes-rk2 [ 2.725731] rk2-crypto fe380000.crypto: Register md5 as rk2-md5 3 [ 2.726310] rk2-crypto fe380000.crypto: Register sha1 as rk2-sha1 4 [ 2.726901] rk2-crypto fe380000.crypto: Register sha256 as rk2-sha256 5 [ 2.727521] rk2-crypto fe380000.crypto: Register sha384 as rk2-sha384 6 [ 2.728142] rk2-crypto fe380000.crypto: Register sha512 as rk2-sha512 7 [ 2.728763] rk2-crypto fe380000.crypto: Register sm3 as rk2-sm3 8 [ 3.502442] rk2-crypto fe380000.crypto: Fallback for xts-aes-rk2 is xts-aes-ce [ 3.770678] rk2-crypto fe380000.crypto: Fallback for cbc-aes-rk2 is cbc-aes-ce [ 3.939055] rk2-crypto fe380000.crypto: Fallback for ecb-aes-rk2 is ecb-aes-ce root@bpi-r2pro:~# cat /sys/kernel/debug/rk2_crypto/stats rk2-crypto fe380000.crypto requests: 581 ecb-aes-rk2 ecb(aes) reqs=132 fallback=1994 fallback due to length: 342 fallback due to alignment: 1648 fallback due to SGs: 0 cbc-aes-rk2 cbc(aes) reqs=156 fallback=2182 fallback due to length: 329 fallback due to alignment: 1841 fallback due to SGs: 6 xts-aes-rk2 xts(aes) reqs=137 fallback=2143 fallback due to length: 116 fallback due to alignment: 739 fallback due to SGs: 0 rk2-md5 md5 reqs=14 fallback=739 rk2-sha1 sha1 reqs=28 fallback=716 rk2-sha256 sha256 reqs=25 fallback=654 rk2-sha384 sha384 reqs=32 fallback=656 rk2-sha512 sha512 reqs=34 fallback=638 rk2-sm3 sm3 reqs=23 fallback=712 root@bpi-r2pro:~# kcapi-rng -b 512 > rng.bin root@bpi-r2pro:~# cat /sys/kernel/debug/rk2_crypto/stats rk2-crypto fe380000.crypto requests: 581 ecb-aes-rk2 ecb(aes) reqs=132 fallback=1994 fallback due to length: 342 fallback due to alignment: 1648 fallback due to SGs: 0 cbc-aes-rk2 cbc(aes) reqs=156 fallback=2182 fallback due to length: 329 fallback due to alignment: 1841 fallback due to SGs: 6 xts-aes-rk2 xts(aes) reqs=137 fallback=2143 fallback due to length: 116 fallback due to alignment: 739 fallback due to SGs: 0 rk2-md5 md5 reqs=14 fallback=739 rk2-sha1 sha1 reqs=28 fallback=716 rk2-sha256 sha256 reqs=25 fallback=654 rk2-sha384 sha384 reqs=32 fallback=656 rk2-sha512 sha512 reqs=34 fallback=638 rk2-sm3 sm3 reqs=23 fallback=712 root@bpi-r2pro:~# if needed this is my current defconfig/tree: https://github.com/frank-w/BPI-Router-Linux/blob/6.6-r2pro2/arch/arm64/configs/quartz64_defconfig#L924 regards Frank ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: Aw: [PATCH 6/6] crypto: rockchip: add rk3588 driver 2023-11-12 14:04 ` Aw: " Frank Wunderlich @ 2023-11-20 12:48 ` Corentin LABBE 2023-11-24 15:05 ` Aw: " Frank Wunderlich 0 siblings, 1 reply; 32+ messages in thread From: Corentin LABBE @ 2023-11-20 12:48 UTC (permalink / raw) To: Frank Wunderlich Cc: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip Le Sun, Nov 12, 2023 at 03:04:28PM +0100, Frank Wunderlich a écrit : > Hi Corentin > > thanks for working on it > > > Gesendet: Dienstag, 07. November 2023 um 16:55 Uhr > > Von: "Corentin Labbe" <clabbe@baylibre.com> > > An: davem@davemloft.net, heiko@sntech.de, herbert@gondor.apana.org.au, krzysztof.kozlowski+dt@linaro.org, mturquette@baylibre.com, p.zabel@pengutronix.de, robh+dt@kernel.org, sboyd@kernel.org > > Cc: ricardo@pardini.net, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-clk@vger.kernel.org, linux-crypto@vger.kernel.org, linux-kernel@vger.kernel.org, linux-rockchip@lists.infradead.org, "Corentin Labbe" <clabbe@baylibre.com> > > Betreff: [PATCH 6/6] crypto: rockchip: add rk3588 driver > > > > RK3588 have a new crypto IP, this patch adds basic support for it. > > Only hashes and cipher are handled for the moment. > > > > Signed-off-by: Corentin Labbe <clabbe@baylibre.com> > > --- > > drivers/crypto/Kconfig | 29 + > > drivers/crypto/rockchip/Makefile | 5 + > > drivers/crypto/rockchip/rk2_crypto.c | 739 ++++++++++++++++++ > > drivers/crypto/rockchip/rk2_crypto.h | 246 ++++++ > > drivers/crypto/rockchip/rk2_crypto_ahash.c | 344 ++++++++ > > drivers/crypto/rockchip/rk2_crypto_skcipher.c | 576 ++++++++++++++ > > 6 files changed, 1939 insertions(+) > > create mode 100644 drivers/crypto/rockchip/rk2_crypto.c > > create mode 100644 drivers/crypto/rockchip/rk2_crypto.h > > create mode 100644 drivers/crypto/rockchip/rk2_crypto_ahash.c > > create mode 100644 drivers/crypto/rockchip/rk2_crypto_skcipher.c > > > > diff --git a/drivers/crypto/Kconfig b/drivers/crypto/Kconfig > > index 79c3bb9c99c3..b6a2027b1f9a 100644 > > --- a/drivers/crypto/Kconfig > > +++ b/drivers/crypto/Kconfig > > @@ -660,6 +660,35 @@ config CRYPTO_DEV_ROCKCHIP_DEBUG > > the number of requests per algorithm and other internal stats. > > > > > > +config CRYPTO_DEV_ROCKCHIP2 > > + tristate "Rockchip's cryptographic offloader V2" > > + depends on OF && ARCH_ROCKCHIP > > + depends on PM > > it should depend on CONFIG_CRYPTO_DEV_ROCKCHIP as rockchip folder is not included without it > > drivers/crypto/Makefile > obj-$(CONFIG_CRYPTO_DEV_ROCKCHIP) += rockchip/ > Hello I will move all rockchip kconfig in the rockchip directory like I did for Allwinner, this will fix this. > > + select CRYPTO_ECB > > + select CRYPTO_CBC > > + select CRYPTO_AES > > + select CRYPTO_MD5 > > + select CRYPTO_SHA1 > > + select CRYPTO_SHA256 > > + select CRYPTO_SHA512 > > + select CRYPTO_SM3_GENERIC > > + select CRYPTO_HASH > > + select CRYPTO_SKCIPHER > > + select CRYPTO_ENGINE > > + > > + help > > + This driver interfaces with the hardware crypto offloader present > > + on RK3566, RK3568 and RK3588. > > + > > +config CRYPTO_DEV_ROCKCHIP2_DEBUG > > + bool "Enable Rockchip V2 crypto stats" > > + depends on CRYPTO_DEV_ROCKCHIP2 > > + depends on DEBUG_FS > > + help > > + Say y to enable Rockchip crypto debug stats. > > + This will create /sys/kernel/debug/rk3588_crypto/stats for displaying > > + the number of requests per algorithm and other internal stats. > > + > > config CRYPTO_DEV_ZYNQMP_AES > > tristate "Support for Xilinx ZynqMP AES hw accelerator" > > depends on ZYNQMP_FIRMWARE || COMPILE_TEST > > diff --git a/drivers/crypto/rockchip/Makefile b/drivers/crypto/rockchip/Makefile > > index 785277aca71e..452a12ff6538 100644 > > else i did some tests, but it does not seem that the offloader is used (requests stay at initial value after the bootup test) > > i wonder about the last 3 lines in dmesg (fallback), seems i miss something for these. > > root@bpi-r2pro:~# dmesg | grep crypto > [ 0.150643] alg: extra crypto tests enabled. This is intended for developer use only. > [ 2.718110] rk2-crypto fe380000.crypto: will run requests pump with realtime priority > [ 2.720605] rk2-crypto fe380000.crypto: Registers crypto algos > [ 2.721910] rk2-crypto fe380000.crypto: Register ecb(aes) as ecb-aes-rk2 > [ 2.724435] rk2-crypto fe380000.crypto: Register cbc(aes) as cbc-aes-rk2 > [ 2.725072] rk2-crypto fe380000.crypto: Register xts(aes) as xts-aes-rk2 > [ 2.725731] rk2-crypto fe380000.crypto: Register md5 as rk2-md5 3 > [ 2.726310] rk2-crypto fe380000.crypto: Register sha1 as rk2-sha1 4 > [ 2.726901] rk2-crypto fe380000.crypto: Register sha256 as rk2-sha256 5 > [ 2.727521] rk2-crypto fe380000.crypto: Register sha384 as rk2-sha384 6 > [ 2.728142] rk2-crypto fe380000.crypto: Register sha512 as rk2-sha512 7 > [ 2.728763] rk2-crypto fe380000.crypto: Register sm3 as rk2-sm3 8 > [ 3.502442] rk2-crypto fe380000.crypto: Fallback for xts-aes-rk2 is xts-aes-ce > [ 3.770678] rk2-crypto fe380000.crypto: Fallback for cbc-aes-rk2 is cbc-aes-ce > [ 3.939055] rk2-crypto fe380000.crypto: Fallback for ecb-aes-rk2 is ecb-aes-ce > > root@bpi-r2pro:~# cat /sys/kernel/debug/rk2_crypto/stats > rk2-crypto fe380000.crypto requests: 581 > ecb-aes-rk2 ecb(aes) reqs=132 fallback=1994 > fallback due to length: 342 > fallback due to alignment: 1648 > fallback due to SGs: 0 > cbc-aes-rk2 cbc(aes) reqs=156 fallback=2182 > fallback due to length: 329 > fallback due to alignment: 1841 > fallback due to SGs: 6 > xts-aes-rk2 xts(aes) reqs=137 fallback=2143 > fallback due to length: 116 > fallback due to alignment: 739 > fallback due to SGs: 0 > rk2-md5 md5 reqs=14 fallback=739 > rk2-sha1 sha1 reqs=28 fallback=716 > rk2-sha256 sha256 reqs=25 fallback=654 > rk2-sha384 sha384 reqs=32 fallback=656 > rk2-sha512 sha512 reqs=34 fallback=638 > rk2-sm3 sm3 reqs=23 fallback=712 > root@bpi-r2pro:~# kcapi-rng -b 512 > rng.bin > root@bpi-r2pro:~# cat /sys/kernel/debug/rk2_crypto/stats > rk2-crypto fe380000.crypto requests: 581 > ecb-aes-rk2 ecb(aes) reqs=132 fallback=1994 > fallback due to length: 342 > fallback due to alignment: 1648 > fallback due to SGs: 0 > cbc-aes-rk2 cbc(aes) reqs=156 fallback=2182 > fallback due to length: 329 > fallback due to alignment: 1841 > fallback due to SGs: 6 > xts-aes-rk2 xts(aes) reqs=137 fallback=2143 > fallback due to length: 116 > fallback due to alignment: 739 > fallback due to SGs: 0 > rk2-md5 md5 reqs=14 fallback=739 > rk2-sha1 sha1 reqs=28 fallback=716 > rk2-sha256 sha256 reqs=25 fallback=654 > rk2-sha384 sha384 reqs=32 fallback=656 > rk2-sha512 sha512 reqs=34 fallback=638 > rk2-sm3 sm3 reqs=23 fallback=712 > root@bpi-r2pro:~# > > if needed this is my current defconfig/tree: > > https://github.com/frank-w/BPI-Router-Linux/blob/6.6-r2pro2/arch/arm64/configs/quartz64_defconfig#L924 > You are using kcapi-rng but the driver do not support RNG yet. (and probably never if I continue to fail having good results with it). So it is normal values does not change. Thanks for your test Regards ^ permalink raw reply [flat|nested] 32+ messages in thread
* Aw: Re: [PATCH 6/6] crypto: rockchip: add rk3588 driver 2023-11-20 12:48 ` Corentin LABBE @ 2023-11-24 15:05 ` Frank Wunderlich 2023-11-27 11:47 ` Corentin LABBE 0 siblings, 1 reply; 32+ messages in thread From: Frank Wunderlich @ 2023-11-24 15:05 UTC (permalink / raw) To: Corentin LABBE Cc: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip Hi > Gesendet: Montag, 20. November 2023 um 13:48 Uhr > Von: "Corentin LABBE" <clabbe@baylibre.com> > You are using kcapi-rng but the driver do not support RNG yet. (and probably never if I continue to fail having good results with it). > So it is normal values does not change. which functions does the driver support atm? or how can i test correctly (and which kernel options i need for this)? regards Frank ^ permalink raw reply [flat|nested] 32+ messages in thread
* Re: Aw: Re: [PATCH 6/6] crypto: rockchip: add rk3588 driver 2023-11-24 15:05 ` Aw: " Frank Wunderlich @ 2023-11-27 11:47 ` Corentin LABBE 0 siblings, 0 replies; 32+ messages in thread From: Corentin LABBE @ 2023-11-27 11:47 UTC (permalink / raw) To: Frank Wunderlich Cc: davem, heiko, herbert, krzysztof.kozlowski+dt, mturquette, p.zabel, robh+dt, sboyd, ricardo, devicetree, linux-arm-kernel, linux-clk, linux-crypto, linux-kernel, linux-rockchip Le Fri, Nov 24, 2023 at 04:05:01PM +0100, Frank Wunderlich a écrit : > Hi > > > Gesendet: Montag, 20. November 2023 um 13:48 Uhr > > Von: "Corentin LABBE" <clabbe@baylibre.com> > > > You are using kcapi-rng but the driver do not support RNG yet. (and probably never if I continue to fail having good results with it). > > So it is normal values does not change. > > which functions does the driver support atm? or how can i test correctly > (and which kernel options i need for this)? > > regards Frank Hello The driver handle AES(ECB CBC XTS) and hashes (MD5 SHAxxx and SM3) For testing you need: CONFIG_CRYPTO_MANAGER_DISABLES_TESTS is not set CONFIG_CRYPTO_MANAGER_EXTRA_TESTS=y Note that I have already got several report of random hashes tests failling, but I am near to have a reproducer. Regards ^ permalink raw reply [flat|nested] 32+ messages in thread
end of thread, other threads:[~2023-11-27 11:47 UTC | newest] Thread overview: 32+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2023-11-07 15:55 [PATCH 0/6] crypto: rockchip: add support for rk3588/rk3568 Corentin Labbe 2023-11-07 15:55 ` [PATCH 1/6] dt-bindings: crypto: add support for rockchip,crypto-rk3588 Corentin Labbe 2023-11-07 16:40 ` Krzysztof Kozlowski 2023-11-20 12:37 ` Corentin LABBE 2023-11-21 9:04 ` Krzysztof Kozlowski 2023-11-07 15:55 ` [PATCH 2/6] MAINTAINERS: add new dt-binding doc to the right entry Corentin Labbe 2023-11-07 16:20 ` Krzysztof Kozlowski 2023-11-20 12:37 ` Corentin LABBE 2023-11-07 15:55 ` [PATCH 3/6] ARM64: dts: rk3588: add crypto node Corentin Labbe 2023-11-07 15:59 ` Heiko Stübner 2023-11-20 12:38 ` Corentin LABBE 2023-11-07 16:20 ` Krzysztof Kozlowski 2023-11-20 12:38 ` Corentin LABBE 2023-11-07 15:55 ` [PATCH 4/6] ARM64: dts: rk356x: " Corentin Labbe 2023-11-07 16:00 ` Heiko Stübner 2023-11-07 16:21 ` Krzysztof Kozlowski 2023-11-07 15:55 ` [PATCH 5/6] reset: rockchip: secure reset must be used by SCMI Corentin Labbe 2023-11-07 16:21 ` Krzysztof Kozlowski 2023-11-07 17:35 ` Heiko Stübner 2023-11-07 17:45 ` Krzysztof Kozlowski 2023-11-11 20:51 ` Sebastian Reichel 2023-11-11 21:28 ` Krzysztof Kozlowski 2023-11-12 20:26 ` Sebastian Reichel 2023-11-20 12:42 ` Corentin LABBE 2023-11-07 15:55 ` [PATCH 6/6] crypto: rockchip: add rk3588 driver Corentin Labbe 2023-11-07 16:35 ` Krzysztof Kozlowski 2023-11-07 16:42 ` Krzysztof Kozlowski 2023-11-07 16:56 ` Krzysztof Kozlowski 2023-11-12 14:04 ` Aw: " Frank Wunderlich 2023-11-20 12:48 ` Corentin LABBE 2023-11-24 15:05 ` Aw: " Frank Wunderlich 2023-11-27 11:47 ` Corentin LABBE
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).