1. 11 1月, 2022 3 次提交
    • T
      drm/i915: Use struct vma_resource instead of struct vma_snapshot · 60dc43d1
      Thomas Hellström 提交于
      There is always a struct vma_resource guaranteed to be alive when we
      access a corresponding struct vma_snapshot.
      
      So ditch the latter and instead of allocating vma_snapshots, reference
      the already existning vma_resource.
      
      This requires a couple of extra members in struct vma_resource but that's
      a small price to pay for the simplification.
      
      v2:
      - Fix a missing include and declaration (kernel test robot <lkp@intel.com>)
      Signed-off-by: NThomas Hellström <thomas.hellstrom@linux.intel.com>
      Reviewed-by: NMatthew Auld <matthew.auld@intel.com>
      Link: https://patchwork.freedesktop.org/patch/msgid/20220110172219.107131-7-thomas.hellstrom@linux.intel.com
      60dc43d1
    • T
      drm/i915: Use vma resources for async unbinding · 2f6b90da
      Thomas Hellström 提交于
      Implement async (non-blocking) unbinding by not syncing the vma before
      calling unbind on the vma_resource.
      Add the resulting unbind fence to the object's dma_resv from where it is
      picked up by the ttm migration code.
      Ideally these unbind fences should be coalesced with the migration blit
      fence to avoid stalling the migration blit waiting for unbind, as they
      can certainly go on in parallel, but since we don't yet have a
      reasonable data structure to use to coalesce fences and attach the
      resulting fence to a timeline, we defer that for now.
      
      Note that with async unbinding, even while the unbind waits for the
      preceding bind to complete before unbinding, the vma itself might have been
      destroyed in the process, clearing the vma pages. Therefore we can
      only allow async unbinding if we have a refcounted sg-list and keep a
      refcount on that for the vma resource pages to stay intact until
      binding occurs. If this condition is not met, a request for an async
      unbind is diverted to a sync unbind.
      
      v2:
      - Use a separate kmem_cache for vma resources for now to isolate their
        memory allocation and aid debugging.
      - Move the check for vm closed to the actual unbinding thread. Regardless
        of whether the vm is closed, we need the unbind fence to properly wait
        for capture.
      - Clear vma_res::vm on unbind and update its documentation.
      v4:
      - Take cache coloring into account when searching for vma resources
        pending unbind. (Matthew Auld)
      v5:
      - Fix timeout and error check in i915_vma_resource_bind_dep_await().
      - Avoid taking a reference on the object for async binding if
        async unbind capable.
      - Fix braces around a single-line if statement.
      v6:
      - Fix up the cache coloring adjustment. (Kernel test robot <lkp@intel.com>)
      - Don't allow async unbinding if the vma_res pages are not the same as
        the object pages. (Matthew Auld)
      v7:
      - s/unsigned long/u64/ in a number of places (Matthew Auld)
      Signed-off-by: NThomas Hellström <thomas.hellstrom@linux.intel.com>
      Reviewed-by: NMatthew Auld <matthew.auld@intel.com>
      Link: https://patchwork.freedesktop.org/patch/msgid/20220110172219.107131-5-thomas.hellstrom@linux.intel.com
      2f6b90da
    • T
      drm/i915: Use the vma resource as argument for gtt binding / unbinding · 39a2bd34
      Thomas Hellström 提交于
      When introducing asynchronous unbinding, the vma itself may no longer
      be alive when the actual binding or unbinding takes place.
      
      Update the gtt i915_vma_ops accordingly to take a struct i915_vma_resource
      instead of a struct i915_vma for the bind_vma() and unbind_vma() ops.
      Similarly change the insert_entries() op for struct i915_address_space.
      
      Replace a couple of i915_vma_snapshot members with their newly introduced
      i915_vma_resource counterparts, since they have the same lifetime.
      
      Also make sure to avoid changing the struct i915_vma_flags (in particular
      the bind flags) async. That should now only be done sync under the
      vm mutex.
      
      v2:
      - Update the vma_res::bound_flags when binding to the aliased ggtt
      v6:
      - Remove I915_VMA_ALLOC_BIT (Matthew Auld)
      - Change some members of struct i915_vma_resource from unsigned long to u64
        (Matthew Auld)
      v7:
      - Fix vma resource size parameters to be u64 rather than unsigned long
        (Matthew Auld)
      Signed-off-by: NThomas Hellström <thomas.hellstrom@linux.intel.com>
      Reviewed-by: NMatthew Auld <matthew.auld@intel.com>
      Link: https://patchwork.freedesktop.org/patch/msgid/20220110172219.107131-3-thomas.hellstrom@linux.intel.com
      39a2bd34
  2. 06 1月, 2022 2 次提交
  3. 24 12月, 2021 3 次提交
  4. 22 12月, 2021 2 次提交
  5. 21 12月, 2021 4 次提交
  6. 20 12月, 2021 1 次提交
  7. 18 12月, 2021 3 次提交
  8. 16 12月, 2021 7 次提交
  9. 14 12月, 2021 3 次提交
  10. 13 12月, 2021 1 次提交
  11. 11 12月, 2021 2 次提交
  12. 10 12月, 2021 5 次提交
  13. 09 12月, 2021 1 次提交
  14. 08 12月, 2021 3 次提交