hwrng: st - keep clock enabled while hwrng is registered
authorMartin Kaiser <martin@kaiser.cx>
Fri, 16 Jun 2023 08:58:13 +0000 (09:58 +0100)
committerHerbert Xu <herbert@gondor.apana.org.au>
Fri, 23 Jun 2023 08:15:37 +0000 (16:15 +0800)
commit501e197a02d4aef157f53ba3a0b9049c3e52fedc
treea8e0c0b8ae3776914b3ee0eb784636a5e73411b4
parentafa9d00ee0fda2387ad598d0b106e96a7ed360ae
hwrng: st - keep clock enabled while hwrng is registered

The st-rng driver uses devres to register itself with the hwrng core,
the driver will be unregistered from hwrng when its device goes out of
scope. This happens after the driver's remove function is called.

However, st-rng's clock is disabled in the remove function. There's a
short timeframe where st-rng is still registered with the hwrng core
although its clock is disabled. I suppose the clock must be active to
access the hardware and serve requests from the hwrng core.

Switch to devm_clk_get_enabled and let devres disable the clock and
unregister the hwrng. This avoids the race condition.

Fixes: 3e75241be808 ("hwrng: drivers - Use device-managed registration API")
Signed-off-by: Martin Kaiser <martin@kaiser.cx>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
drivers/char/hw_random/st-rng.c