Igt-dev Archive on lore.kernel.org
 help / color / mirror / Atom feed
From: "Hogander, Jouni" <jouni.hogander@intel.com>
To: "Kempczynski, Zbigniew" <zbigniew.kempczynski@intel.com>,
	"Ch, Sai Gowtham" <sai.gowtham.ch@intel.com>,
	"igt-dev@lists.freedesktop.org" <igt-dev@lists.freedesktop.org>
Subject: Re: [igt-dev] [PATCH i-g-t] lib/xe/xe_spin: Integrate igt_spin_new with Xe.
Date: Mon, 8 May 2023 12:19:40 +0000	[thread overview]
Message-ID: <f17a5efb2a2943ea8b90def0b29f0bc92311001a.camel@intel.com> (raw)
In-Reply-To: <20230505053528.25967-1-sai.gowtham.ch@intel.com>

On Fri, 2023-05-05 at 11:05 +0530, sai.gowtham.ch@intel.com wrote:
> From: Sai Gowtham Ch <sai.gowtham.ch@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.

Hello Sai,

Do you have some example testcase demonstrating usage of this Xe
spinner? I've been trying to adapt my testcase here to work with Xe and
on top of your spinner patch:

https://patchwork.freedesktop.org/series/116130/

Without success. Seeing crash...

BR,

Jouni Högander

> 
> Cc: Zbigniew Kempczyński <zbigniew.kempczynski@intel.com>
> Signed-off-by: Sai Gowtham Ch <sai.gowtham.ch@intel.com>
> ---
>  lib/igt_dummyload.c | 28 ++++++++++++++------
>  lib/igt_dummyload.h |  8 ++++++
>  lib/xe/xe_spin.c    | 63
> +++++++++++++++++++++++++++++++++++++++++++++
>  lib/xe/xe_spin.h    |  7 +++++
>  4 files changed, 98 insertions(+), 8 deletions(-)
> 
> diff --git a/lib/igt_dummyload.c b/lib/igt_dummyload.c
> index 740a58f3..92507819 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);
>  }
>  
>  /**
> @@ -480,8 +484,13 @@ igt_spin_factory(int fd, const struct
> igt_spin_factory *opts)
>                 igt_require(!gem_engine_has_cmdparser(fd, &opts->ctx-
> >cfg,
>                                                       opts->engine));
>         }
> -
> -       spin = spin_create(fd, opts);
> +       if (is_xe_device(fd)) {
> +               spin = xe_spin_create(fd, opts);
> +               return spin;
> +       } else {
> +               spin = spin_create(fd, opts);
> +               return spin;
> +       }
>  
>         if (!(opts->flags & IGT_SPIN_INVALID_CS)) {
>                 /*
> @@ -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..7efbb464 100644
> --- a/lib/igt_dummyload.h
> +++ b/lib/igt_dummyload.h
> @@ -83,6 +83,14 @@ typedef struct igt_spin {
>  #define SPIN_CLFLUSH (1 << 0)
>  
>         struct igt_spin_factory opts;
> +       union {
> +               uint64_t pad;
> +               uint32_t start;
> +               uint32_t end;
> +               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..b79b5a0c 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,68 @@ 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)
> +{
> +       struct drm_xe_engine_class_instance *eci;
> +       size_t bo_size = xe_get_default_alignment(fd);
> +       uint32_t vm, bo, engine, syncobj;
> +       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);
> +
> +       bo = xe_bo_create(fd, eci->gt_id, vm, bo_size);
> +       spin = xe_bo_map(fd, bo, 0x1000);
> +       spin->handle = bo;
> +       spin->vm = xe_vm_create(fd, 0, 0);
> +       engine = xe_engine_create(fd, vm, eci, 0);
> +       spin->syncobj = syncobj_create(fd, 0);
> +
> +       if (ahnd)
> +               addr = intel_allocator_alloc_with_strategy(ahnd, bo,
> bo_size, 0, ALLOC_STRATEGY_LOW_TO_HIGH);
> +
> +       xe_vm_bind_sync(fd, vm, bo, 0, addr, bo_size);
> +
> +       xe_spin_init(xe_spin, addr, true);
> +       exec.engine_id = engine;
> +       exec.address = addr;
> +       sync.handle = 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;
> +       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)
> +{
> +       spin->end = 0;
> +       xe_vm_destroy(fd, spin->vm);
> +       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;


  parent reply	other threads:[~2023-05-08 12:19 UTC|newest]

Thread overview: 23+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-05-05  5:35 [igt-dev] [PATCH i-g-t] lib/xe/xe_spin: Integrate igt_spin_new with Xe sai.gowtham.ch
2023-05-05  6:15 ` [igt-dev] ✓ Fi.CI.BAT: success for lib/xe/xe_spin: Integrate igt_spin_new with Xe. (rev3) Patchwork
2023-05-05 11:23 ` [igt-dev] ✗ Fi.CI.IGT: failure " Patchwork
2023-05-08 12:19 ` Hogander, Jouni [this message]
2023-05-08 12:22   ` [igt-dev] [PATCH i-g-t] lib/xe/xe_spin: Integrate igt_spin_new with Xe Ch, Sai Gowtham
2023-05-08 19:55 ` Zbigniew Kempczyński
2023-05-09  6:36 ` Zbigniew Kempczyński
2023-06-08 14:10 ` Matthew Brost
2023-07-17  9:19   ` Zbigniew Kempczyński
  -- strict thread matches above, loose matches on Subject: below --
2023-05-10  5:55 sai.gowtham.ch
2023-05-11  5:08 ` Zbigniew Kempczyński
2023-05-11 10:03   ` Ch, Sai Gowtham
2023-05-11  6:43 ` Hogander, Jouni
2023-05-11 10:02   ` Ch, Sai Gowtham
2023-05-11 10:04     ` Hogander, Jouni
2023-04-26 20:16 sai.gowtham.ch
2023-04-27  5:40 ` Modem, Bhanuprakash
2023-04-27  5:49   ` Ch, Sai Gowtham
2023-04-27  7:09     ` Zbigniew Kempczyński
2023-04-24 11:54 sai.gowtham.ch
2023-04-25  3:36 ` Zbigniew Kempczyński
2023-04-25  7:07   ` Ch, Sai Gowtham
2023-04-25 10:48     ` Zbigniew Kempczyński

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=f17a5efb2a2943ea8b90def0b29f0bc92311001a.camel@intel.com \
    --to=jouni.hogander@intel.com \
    --cc=igt-dev@lists.freedesktop.org \
    --cc=sai.gowtham.ch@intel.com \
    --cc=zbigniew.kempczynski@intel.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox