[Beignet] [PATCH] intel: Export pooled EU and min no. of eus in a pool.
Yang, Rong R
rong.r.yang at intel.com
Fri Jul 15 05:36:23 UTC 2016
OK, I have send a new version patch.
> -----Original Message-----
> From: Chris Wilson [mailto:chris at chris-wilson.co.uk]
> Sent: Thursday, July 14, 2016 3:10
> To: Arun Siluvery <arun.siluvery at linux.intel.com>
> Cc: Yang, Rong R <rong.r.yang at intel.com>; beignet at lists.freedesktop.org;
> dri-devel at lists.freedesktop.org; Daniel Vetter <daniel at ffwll.ch>; Tvrtko
> Ursulin <tvrtko.ursulin at linux.intel.com>; martin.peres at linux.intel.com
> Subject: Re: [Beignet] [PATCH] intel: Export pooled EU and min no. of eus in a
> pool.
>
> On Wed, Jul 13, 2016 at 11:44:09AM +0100, Arun Siluvery wrote:
> > On 06/07/2016 05:51, Yang Rong wrote:
> > >Update kernel interface with new I915_GETPARAM ioctl entries for
> > >pooled EU and min no. of eus in a pool. Add a wrapping function for
> > >each parameter. Userspace drivers need these values when decide the
> > >thread count. This kernel enabled pooled eu by default for BXT and
> > >for fused down 2x6 parts it is advised to turn it off.
> > >
> > >But there is another HW issue in these parts (fused down 2x6 parts)
> > >before C0 that requires Pooled EU to be enabled as a workaround. In
> > >this case the pool configuration changes depending upon which
> > >subslice is disabled and the no. of eus in a pool is different, So
> > >userspace need to know min no. of eus in a pool.
> > >
> > >Signed-off-by: Yang Rong <rong.r.yang at intel.com>
> > >---
> >
> > Could you check this and give comments/ACK to merge this to libdrm?
> > Kernel changes are merged in drm-intel.
> >
> > regards
> > Arun
> >
> > > include/drm/i915_drm.h | 2 ++
> > > intel/intel_bufmgr.h | 3 +++
> > > intel/intel_bufmgr_gem.c | 32 ++++++++++++++++++++++++++++++++
> > > 3 files changed, 37 insertions(+)
> > >
> > >diff --git a/include/drm/i915_drm.h b/include/drm/i915_drm.h index
> > >c4ce6b2..eb611a7 100644
> > >--- a/include/drm/i915_drm.h
> > >+++ b/include/drm/i915_drm.h
> > >@@ -357,6 +357,8 @@ typedef struct drm_i915_irq_wait {
> > > #define I915_PARAM_HAS_GPU_RESET 35
> > > #define I915_PARAM_HAS_RESOURCE_STREAMER 36
> > > #define I915_PARAM_HAS_EXEC_SOFTPIN 37
> > >+#define I915_PARAM_HAS_POOLED_EU 38
> > >+#define I915_PARAM_MIN_EU_IN_POOL 39
> > >
> > > typedef struct drm_i915_getparam {
> > > __s32 param;
> > >diff --git a/intel/intel_bufmgr.h b/intel/intel_bufmgr.h index
> > >a1abbcd..8370694 100644
> > >--- a/intel/intel_bufmgr.h
> > >+++ b/intel/intel_bufmgr.h
> > >@@ -273,6 +273,9 @@ int drm_intel_get_reset_stats(drm_intel_context
> > >*ctx,
> > > int drm_intel_get_subslice_total(int fd, unsigned int
> > >*subslice_total);
> > > int drm_intel_get_eu_total(int fd, unsigned int *eu_total);
> > >
> > >+int drm_intel_get_pooled_eu(int fd, unsigned int *has_pooled_eu);
> > >+int drm_intel_get_min_eu_in_pool(int fd, unsigned int *min_eu);
>
> Do we export more than 2 billion eu? Or more than 2 billion states for the
> bool has_pooled_eu?
>
> Could we not just use
>
> int drm_intel_get_pooled_eu(int fd);
>
> ret < 0 => error occurred / unknown
> ret == 0 => no
> ret > 0 => yes
>
> and same for get_min_eu.
>
> > >+
> > > /** @{ Compatibility defines to keep old code building despite the
> symbol rename
> > > * from dri_* to drm_intel_*
> > > */
> > >diff --git a/intel/intel_bufmgr_gem.c b/intel/intel_bufmgr_gem.c
> > >index 0a4012b..b8bb654 100644
> > >--- a/intel/intel_bufmgr_gem.c
> > >+++ b/intel/intel_bufmgr_gem.c
> > >@@ -3237,6 +3237,38 @@ drm_intel_get_eu_total(int fd, unsigned int
> *eu_total)
> > > return 0;
> > > }
> > >
> > >+int
> > >+drm_intel_get_pooled_eu(int fd, unsigned int *has_pooled_eu) {
> > >+ drm_i915_getparam_t gp;
> > >+ int ret;
> > >+
> > >+ memclear(gp);
> > >+ gp.value = (int*)has_pooled_eu;
> > >+ gp.param = I915_PARAM_HAS_POOLED_EU;
> > >+ ret = drmIoctl(fd, DRM_IOCTL_I915_GETPARAM, &gp);
> > >+ if (ret)
>
> save a few electrons....
>
> int drm_intel_get_pooled_eu(int fd)
> {
> drm_i915_getparam_t gp;
> int ret;
>
> memclear(gp);
> gp.param = I915_PARAM_HAS_POOLED_EU;
> gp.value = &ret;
> if (drmIoctl(fd, DRM_IOCTL_I915_GETPARAM, &gp))
> return -errno;
>
> return ret;
> }
>
> (save a few more by calling this int __getparam(int fd, unsigned name)) -
> Chris
>
> --
> Chris Wilson, Intel Open Source Technology Centre
More information about the Beignet
mailing list