[PATCH v2 2/2] rust: drm: Add GPUVM abstraction
Daniel Almeida
daniel.almeida at collabora.com
Wed May 14 20:11:50 UTC 2025
>
> The lock might be held already by the driver or by TTM when things are called
> from TTM callbacks.
>
> This is why GPUVM never takes locks by itself, but asserts that the correct lock
> is held.
>
> I think we really want to get proof by the driver by providing lock guard
> references.
>
>> See my comment about “[..] a new type for GEM objects which are known to be locked"
>> below.
>
> <snip>
>
>>>> +
>>>> + /// Obtains the [`GpuVmBo`] object that connects `obj` to this VM.
>>>> + ///
>>>> + /// This connection is unique, so an instane of [`GpuVmBo`] will be
>>>> + /// allocated for `obj` once, and that instance will be returned from that
>>>> + /// point forward.
>>>> + pub fn obtain_bo(&mut self, obj: &DriverObject<T>) -> Result<ARef<GpuVmBo<T>>> {
>>>> + // SAFETY: LockedGpuVm implies the right locks are held.
>>>
>>> No, this must be locked by the dma-resv or the GEM gpuva lock, not by the
>>> GPUVM lock that protects the interval tree.
>>
>> By “GEM gpuva lock” you’re referring to the custom lock which we
>> currently do not support, right?
>
> Yes.
>
>> This series currently rely on manual calls to dma_resv_{lock,unlock}, I wonder
>> if we should ditch that in favor of something written in Rust directly. This
>> would let us introduce a new type for GEM objects which are known to have
>> `resv` locked. WDYT?
>
> Not all functions that require the dma-resv lock to be held are called with a
> GEM object parameter, it could also be a struct drm_gpuvm_bo, struct drm_gpuva
> or struct drm_gpuvm, since they all carry GEM object pointers.
>
> For reference, you can look for "_held" in drivers/gpu/drm/drm_gpuvm.c.
>
Looking at Lyude’s (excellent) KMS series, one thing that comes to mind is
using Lock::from_raw() on the dma-resv lock. This will build a rust Mutex that
we can then assert to be locked (or fail with an Error otherwise).
See [0] for the specific patch whose idea I want to copy.
Can I get a +1 on this idea before pursuing it?
-- Daniel
[0] https://lore.kernel.org/rust-for-linux/20250305230406.567126-10-lyude@redhat.com/
More information about the dri-devel
mailing list