From: Sam Protsenko <semen.protsenko@linaro.org>
To: "Łukasz Stelmach" <l.stelmach@samsung.com>,
"Krzysztof Kozlowski" <krzk+dt@kernel.org>,
"Rob Herring" <robh@kernel.org>,
"Conor Dooley" <conor+dt@kernel.org>
Cc: Anand Moon <linux.amoon@gmail.com>,
Olivia Mackall <olivia@selenic.com>,
Herbert Xu <herbert@gondor.apana.org.au>,
Alim Akhtar <alim.akhtar@samsung.com>,
linux-samsung-soc@vger.kernel.org, linux-crypto@vger.kernel.org,
devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org,
linux-kernel@vger.kernel.org
Subject: [PATCH v3 0/6] hwrng: exynos: Add support for Exynos850
Date: Thu, 20 Jun 2024 18:13:33 -0500 [thread overview]
Message-ID: <20240620231339.1574-1-semen.protsenko@linaro.org> (raw)
Exynos850 has True Random Number Generator (TRNG) block which is very
similar to Exynos5250 for which the driver already exists
(exynos-trng.c). There are two differences though:
1. Additional SSS PCLK clock has to be enabled to make TRNG registers
accessible.
2. All SSS registers (including TRNG area) are protected with
TrustZone and can only be accessed from EL3 monitor. So the
corresponding SMC calls have to be used instead to interact with
TRNG block.
This patch series enables TRNG support on Exynos850 SoC. It was tested
on the E850-96 board running Debian rootfs like this:
8<-------------------------------------------------------------->8
# cat /sys/devices/virtual/misc/hw_random/rng_current
12081400.rng
# dd if=/dev/hwrng bs=100000 count=1 > /dev/null
...
122KB/s
# apt install rng-tools5
# rngtest -c 1000 < /dev/hwrng
...
rngtest: starting FIPS tests...
rngtest: bits received from input: 20000032
rngtest: FIPS 140-2 successes: 1000
rngtest: FIPS 140-2 failures: 0
rngtest: FIPS 140-2(2001-10-10) Monobit: 0
rngtest: FIPS 140-2(2001-10-10) Poker: 0
rngtest: FIPS 140-2(2001-10-10) Runs: 0
rngtest: FIPS 140-2(2001-10-10) Long run: 0
rngtest: FIPS 140-2(2001-10-10) Continuous run: 0
rngtest: input channel speed: (min=941.855; avg=965.515;
max=968.236)Kibits/s
rngtest: FIPS tests speed: (min=49.542; avg=52.886;
max=53.577)Mibits/s
rngtest: Program run time: 20590194 microseconds
8<-------------------------------------------------------------->8
SMC commands added in this series require LDFW (Loadable Firmware) to be
loaded by the bootloader. In case of E850-96 board, at the moment only
the LittleKernel based bootloader [1] is able to load LDFW. It is
expected to be added into U-Boot port soon as well. See [2] for more
details.
[1] https://gitlab.com/Linaro/96boards/e850-96/lk
[2] https://docs.u-boot.org/en/latest/board/samsung/e850-96.html
Changes in v3:
- Rebased on top of the most recent linux-next
- Removed dts patch (7/7) from the series, as suggested by Krzysztof
- Addressed all review comments for v2 series
Changes in v2:
- Removed the patch for renaming the dt-bindings doc file
- Added the patch for using devm_clk_get_enabled() to get the clock
- Addressed all review comments for v1 series
Sam Protsenko (6):
dt-bindings: rng: Add Exynos850 support to exynos-trng
hwrng: exynos: Improve coding style
hwrng: exynos: Use devm_clk_get_enabled() to get the clock
hwrng: exynos: Implement bus clock control
hwrng: exynos: Add SMC based TRNG operation
hwrng: exynos: Enable Exynos850 support
.../bindings/rng/samsung,exynos5250-trng.yaml | 40 +++-
drivers/char/hw_random/exynos-trng.c | 225 +++++++++++++-----
2 files changed, 206 insertions(+), 59 deletions(-)
--
2.39.2
next reply other threads:[~2024-06-20 23:13 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-06-20 23:13 Sam Protsenko [this message]
2024-06-20 23:13 ` [PATCH v3 1/6] dt-bindings: rng: Add Exynos850 support to exynos-trng Sam Protsenko
2024-06-20 23:13 ` [PATCH v3 2/6] hwrng: exynos: Improve coding style Sam Protsenko
2024-06-20 23:13 ` [PATCH v3 3/6] hwrng: exynos: Use devm_clk_get_enabled() to get the clock Sam Protsenko
2024-06-20 23:13 ` [PATCH v3 4/6] hwrng: exynos: Implement bus clock control Sam Protsenko
2024-06-20 23:13 ` [PATCH v3 5/6] hwrng: exynos: Add SMC based TRNG operation Sam Protsenko
[not found] ` <CGME20240621190049eucas1p28ba502d86e2f9380315c06add645517c@eucas1p2.samsung.com>
2024-06-21 19:00 ` Lukasz Stelmach
2024-06-21 19:40 ` Sam Protsenko
[not found] ` <CGME20240621221113eucas1p25c2fbadceef48913c4a7b164e6d14890@eucas1p2.samsung.com>
2024-06-21 22:10 ` Lukasz Stelmach
2024-06-21 22:55 ` Sam Protsenko
2024-06-20 23:13 ` [PATCH v3 6/6] hwrng: exynos: Enable Exynos850 support Sam Protsenko
2024-06-28 1:52 ` [PATCH v3 0/6] hwrng: exynos: Add support for Exynos850 Herbert Xu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20240620231339.1574-1-semen.protsenko@linaro.org \
--to=semen.protsenko@linaro.org \
--cc=alim.akhtar@samsung.com \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=herbert@gondor.apana.org.au \
--cc=krzk+dt@kernel.org \
--cc=l.stelmach@samsung.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-crypto@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-samsung-soc@vger.kernel.org \
--cc=linux.amoon@gmail.com \
--cc=olivia@selenic.com \
--cc=robh@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).