[RFC 06/13] drm/i915/svm: Page table mirroring support
Niranjan Vishwanathapura
niranjana.vishwanathapura at intel.com
Fri Nov 22 20:11:43 UTC 2019
On Fri, Nov 22, 2019 at 08:14:51PM +0000, Jason Gunthorpe wrote:
>On Fri, Nov 22, 2019 at 12:01:17PM -0800, Niranjan Vishwanathapura wrote:
>> On Fri, Nov 22, 2019 at 11:54:45AM -0800, Niranjana Vishwanathapura wrote:
>> > Use HMM page table mirroring support to build device page table.
>> > Implement the bind ioctl and bind the process address range in the
>> > specified context's ppgtt.
>> > Handle invalidation notifications by unbinding the address range.
>> >
>> > Cc: Joonas Lahtinen <joonas.lahtinen at linux.intel.com>
>> > Cc: Jon Bloomfield <jon.bloomfield at intel.com>
>> > Cc: Daniel Vetter <daniel.vetter at intel.com>
>> > Cc: Sudeep Dutt <sudeep.dutt at intel.com>
>> > Signed-off-by: Niranjana Vishwanathapura <niranjana.vishwanathapura at intel.com>
>> > +int i915_svm_bind_mm(struct i915_address_space *vm)
>> > +{
>> > + struct i915_svm *svm;
>> > + struct mm_struct *mm;
>> > + int ret = 0;
>> > +
>> > + mm = get_task_mm(current);
>> > + down_write(&mm->mmap_sem);
>> > + mutex_lock(&vm->svm_mutex);
>> > + if (vm->svm)
>> > + goto bind_out;
>> > +
>> > + svm = kzalloc(sizeof(*svm), GFP_KERNEL);
>> > + if (!svm) {
>> > + ret = -ENOMEM;
>> > + goto bind_out;
>> > + }
>> > + svm->mirror.ops = &i915_mirror_ops;
>> > + mutex_init(&svm->mutex);
>> > + kref_init(&svm->ref);
>> > + svm->mm = mm;
>> > + svm->vm = vm;
>> > +
>> > + ret = hmm_mirror_register(&svm->mirror, mm);
>>
>> I saw that these APIs have been removed.
>> I will update once it gets included in kernel release.
>
>I would like to see all the mmu notifier use in i916 updated to use
>the new APIs :)
>
>Please cc me when you post patches using the new APIs, I'd like to see
>how they are being used.
>
Ok, sure, will do.
Thanks,
Niranjana
>Regards,
>Jason
More information about the dri-devel
mailing list