[igt-dev] [PATCH i-g-t] lib/xe/xe_spin: Integrate igt_spin_new with Xe.

Ch, Sai Gowtham sai.gowtham.ch at intel.com
Thu May 11 10:02:25 UTC 2023



> -----Original Message-----
> From: Hogander, Jouni <jouni.hogander at intel.com>
> Sent: Thursday, May 11, 2023 12:14 PM
> To: Kempczynski, Zbigniew <zbigniew.kempczynski at intel.com>; Ch, Sai
> Gowtham <sai.gowtham.ch at intel.com>; igt-dev at lists.freedesktop.org
> Subject: Re: [igt-dev] [PATCH i-g-t] lib/xe/xe_spin: Integrate igt_spin_new with
> Xe.
> 
> Hello Sai, see my comments inline below:
> 
> On Wed, 2023-05-10 at 11:25 +0530, sai.gowtham.ch at intel.com wrote:
> > From: Sai Gowtham Ch <sai.gowtham.ch at intel.com>
> >
> > Extending the spin_create implementation and allocator handle support
> > in xe, where it submits dummy work loads to engine. This
> > Implementation is wrapped around vm_bind and unbind as we are supposed
> > to do it manually for xe.
> >
> > Cc: Bhanuprakash Modem <bhanuprakash.modem at intel.com>
> > Cc: Zbigniew Kempczyński <zbigniew.kempczynski at intel.com>
> > Signed-off-by: Sai Gowtham Ch <sai.gowtham.ch at intel.com>
> > ---
> >  lib/igt_dummyload.c | 24 ++++++++++++----
> >  lib/igt_dummyload.h | 10 +++++++
> >  lib/xe/xe_spin.c    | 67
> > +++++++++++++++++++++++++++++++++++++++++++++
> >  lib/xe/xe_spin.h    |  7 +++++
> >  4 files changed, 102 insertions(+), 6 deletions(-)
> >
> > diff --git a/lib/igt_dummyload.c b/lib/igt_dummyload.c index
> > 740a58f3..6e89b72d 100644
> > --- a/lib/igt_dummyload.c
> > +++ b/lib/igt_dummyload.c
> > @@ -46,6 +46,7 @@
> >  #include "intel_reg.h"
> >  #include "ioctl_wrappers.h"
> >  #include "sw_sync.h"
> > +#include "xe/xe_spin.h"
> >
> >  /**
> >   * SECTION:igt_dummyload
> > @@ -447,7 +448,10 @@ spin_create(int fd, const struct igt_spin_factory
> > *opts)
> >  igt_spin_t *
> >  __igt_spin_factory(int fd, const struct igt_spin_factory *opts)
> >  {
> > -       return spin_create(fd, opts);
> > +       if (is_xe_device(fd))
> > +               return xe_spin_create(fd, opts);
> > +       else
> > +               return spin_create(fd, opts);
> >  }
> >
> >  /**
> > @@ -467,6 +471,11 @@ igt_spin_factory(int fd, const struct
> > igt_spin_factory *opts)
> >  {
> >         igt_spin_t *spin;
> >
> > +       if (is_xe_device(fd)) {
> > +               spin = xe_spin_create(fd, opts);
> > +               return spin;
> > +       }
> > +
> >         if ((opts->flags & IGT_SPIN_POLL_RUN) && opts->engine !=
> > ALL_ENGINES) {
> >                 unsigned int class;
> >
> > @@ -647,11 +656,14 @@ void igt_spin_free(int fd, igt_spin_t *spin)
> >         if (!spin)
> >                 return;
> >
> > -       pthread_mutex_lock(&list_lock);
> > -       igt_list_del(&spin->link);
> > -       pthread_mutex_unlock(&list_lock);
> > -
> > -       __igt_spin_free(fd, spin);
> > +       if (is_xe_device(fd)) {
> > +               xe_spin_free(fd, spin);
> > +       } else {
> > +               pthread_mutex_lock(&list_lock);
> > +               igt_list_del(&spin->link);
> > +               pthread_mutex_unlock(&list_lock);
> > +               __igt_spin_free(fd, spin);
> > +       }
> >  }
> >
> >  void igt_terminate_spins(void)
> > diff --git a/lib/igt_dummyload.h b/lib/igt_dummyload.h index
> > b247ab02..c2900a8f 100644
> > --- a/lib/igt_dummyload.h
> > +++ b/lib/igt_dummyload.h
> > @@ -51,6 +51,7 @@ typedef struct igt_spin_factory {
> >         uint32_t dependency;
> >         uint64_t dependency_size;
> >         unsigned int engine;
> > +       struct drm_xe_engine_class_instance *hwe;
> >         unsigned int flags;
> >         int fence;
> >         uint64_t ahnd;
> > @@ -83,6 +84,15 @@ typedef struct igt_spin {
> >  #define SPIN_CLFLUSH (1 << 0)
> >
> >         struct igt_spin_factory opts;
> > +
> > +       uint32_t start;
> > +       uint32_t end;
> > +       size_t bo_size;
> > +       uint64_t address;
> > +       unsigned int engine;
> > +       uint32_t vm;
> > +       uint32_t syncobj;
> > +
> >  } igt_spin_t;
> >
> >
> > diff --git a/lib/xe/xe_spin.c b/lib/xe/xe_spin.c index
> > 856d0ba2..5f3a3b4f 100644
> > --- a/lib/xe/xe_spin.c
> > +++ b/lib/xe/xe_spin.c
> > @@ -15,6 +15,7 @@
> >  #include "intel_reg.h"
> >  #include "xe_ioctl.h"
> >  #include "xe_spin.h"
> > +#include "lib/igt_dummyload.h"
> >
> >  /**
> >   * xe_spin_init:
> > @@ -82,6 +83,72 @@ void xe_spin_end(struct xe_spin *spin)
> >         spin->end = 0;
> >  }
> >
> > +igt_spin_t *
> > +xe_spin_create(int fd, const struct igt_spin_factory *opt) {
> > +       size_t bo_size = xe_get_default_alignment(fd);
> > +       uint32_t bo;
> > +       uint64_t ahnd = opt->ahnd, addr;
> > +       struct igt_spin *spin;
> > +       struct xe_spin *xe_spin;
> > +       struct drm_xe_sync sync = {
> > +               .flags = DRM_XE_SYNC_SYNCOBJ | DRM_XE_SYNC_SIGNAL,
> > +       };
> > +       struct drm_xe_exec exec = {
> > +               .num_batch_buffer = 1,
> > +               .num_syncs = 1,
> > +               .syncs = to_user_pointer(&sync),
> > +       };
> > +
> > +       igt_assert(ahnd);
> > +       xe_spin = calloc(1, sizeof(struct xe_spin));
> > +       igt_assert(xe_spin);
> > +       spin = calloc(1, sizeof(struct igt_spin));
> > +       igt_assert(spin);
> > +
> > +       spin->vm = xe_vm_create(fd, 0, 0);
> > +       bo = xe_bo_create(fd, opt->hwe->gt_id, spin->vm, bo_size);
> > +       spin = xe_bo_map(fd, bo, 0x1000);
> 
> This looks a bit strange. You are allocating spin above and then setting the
> pointer here.
> 
> I tried your code again with my testcase. Still I'm seeing crashes/failures. Do you
> have some example testcase how this is supposed to be used?
Does your test using i915 or xe ?? if i915 then there is no change in the functionality it's the same existing code, because this change is specific to only xe. 

Because from this patch https://patchwork.freedesktop.org/series/116130/ it looks like you are using spinner for i915.

Thanks,
Gowtham
> 
> > +       spin->handle = bo;
> > +       if (opt->engine)
> > +               spin->engine = opt->engine;
> > +       else
> > +               spin->engine = xe_engine_create(fd, spin->vm, opt-
> > >hwe, 0);
> > +
> > +       spin->syncobj = syncobj_create(fd, 0);
> > +       addr = intel_allocator_alloc_with_strategy(ahnd, bo, bo_size,
> > 0, ALLOC_STRATEGY_LOW_TO_HIGH);
> > +       xe_vm_bind_sync(fd, spin->vm, bo, 0, addr, bo_size);
> > +
> > +       xe_spin_init(xe_spin, addr, true);
> > +       exec.engine_id = spin->engine;
> > +       exec.address = addr;
> > +       sync.handle = spin->syncobj;
> > +       igt_assert_eq(igt_ioctl(fd, DRM_IOCTL_XE_EXEC, &exec), 0);
> > +
> > +       spin->batch = xe_spin->batch;
> > +       spin->start = xe_spin->start;
> > +       spin->end = xe_spin->end;
> > +       spin->bo_size = bo_size;
> > +       spin->address = addr;
> > +       return spin;
> > +
> > +}
> > +
> > +void xe_spin_sync_wait(int fd, struct igt_spin *spin) {
> > +       igt_assert(syncobj_wait(fd, &spin->syncobj, 1, INT64_MAX, 0,
> > +                               NULL)); }
> > +
> > +void xe_spin_free(int fd, struct igt_spin *spin) {
> > +       xe_vm_unbind_sync(fd, spin->vm, 0, spin->address, spin-
> > >bo_size);
> > +       spin->end = 0;
> > +       syncobj_destroy(fd, spin->syncobj);
> > +       xe_engine_destroy(fd, spin->engine);
> > +       gem_close(fd, spin->handle);
> > +}
> > +
> >  void xe_cork_init(int fd, struct drm_xe_engine_class_instance *hwe,
> >                   struct xe_cork *cork)
> >  {
> > diff --git a/lib/xe/xe_spin.h b/lib/xe/xe_spin.h index
> > 73f9a026..48867eb8 100644
> > --- a/lib/xe/xe_spin.h
> > +++ b/lib/xe/xe_spin.h
> > @@ -13,19 +13,26 @@
> >  #include <stdbool.h>
> >
> >  #include "xe_query.h"
> > +#include "lib/igt_dummyload.h"
> >
> >  /* Mapped GPU object */
> > +
> >  struct xe_spin {
> >         uint32_t batch[16];
> >         uint64_t pad;
> >         uint32_t start;
> >         uint32_t end;
> > +
> >  };
> >
> > +igt_spin_t *
> > +xe_spin_create(int fd, const struct igt_spin_factory *opt);
> >  void xe_spin_init(struct xe_spin *spin, uint64_t addr, bool preempt);
> >  bool xe_spin_started(struct xe_spin *spin);
> > +void xe_spin_sync_wait(int fd, struct igt_spin *spin);
> >  void xe_spin_wait_started(struct xe_spin *spin);
> >  void xe_spin_end(struct xe_spin *spin);
> > +void xe_spin_free(int fd, struct igt_spin *spin);
> >
> >  struct xe_cork {
> >         struct xe_spin *spin;



More information about the igt-dev mailing list