Re: [PATCH V6 04/15] rust: device: Add few helpers
From: Viresh Kumar
Date: Thu Jan 09 2025 - 01:36:20 EST
On 08-01-25, 14:42, Danilo Krummrich wrote:
> I think that's really what is needed, otherwise it'll never work with the
> guarantees the Rust `Device` abstraction provides.
> The patch below is still not valid I think. It assumes that a CPU device never
> becomes invalid, but that isn't true.
>
> There's a hotplug path [1] where the device is unregistered.
Right, though the device pointer always points to valid memory as the struct cpu
is never freed. Isn't that enough for a pointer passed over FFI ? All the
from_cpu() method returns is a reference, which will be used for a short period
only (yes it is about the possibility of something going wrong in that period
only and we need to ensure it doesn't break in such corner cases).
FWIW, the cpufreq framework is registered with CPU hotplug layer, and so
whenever a CPU disappears, the cpufreq core will stop using its device pointer
before the CPU is removed. So technically we shouldn't land in a situation where
the CPU is unregistered and cpufreq core is still using the CPU's device
pointer.
--
viresh