[Mesa-dev] [PATCH 1/2] panfrost: Sync UAPI header from kernel
Alyssa Rosenzweig
alyssa.rosenzweig at collabora.com
Fri Aug 9 20:45:13 UTC 2019
Patch #1 is R-b
On Fri, Aug 09, 2019 at 01:53:12PM -0600, Rob Herring wrote:
> Sync the panfrost_drm.h UAPI header with the latest from the kernel.
> This adds madvise ioctl and GPU feature params.
>
> Signed-off-by: Rob Herring <robh at kernel.org>
> ---
> include/drm-uapi/panfrost_drm.h | 61 +++++++++++++++++++++++++++++++++
> 1 file changed, 61 insertions(+)
>
> diff --git a/include/drm-uapi/panfrost_drm.h b/include/drm-uapi/panfrost_drm.h
> index 9150dd75aad8..ec19db1eead8 100644
> --- a/include/drm-uapi/panfrost_drm.h
> +++ b/include/drm-uapi/panfrost_drm.h
> @@ -20,6 +20,7 @@ extern "C" {
> #define DRM_PANFROST_GET_BO_OFFSET 0x05
> #define DRM_PANFROST_PERFCNT_ENABLE 0x06
> #define DRM_PANFROST_PERFCNT_DUMP 0x07
> +#define DRM_PANFROST_MADVISE 0x08
>
> #define DRM_IOCTL_PANFROST_SUBMIT DRM_IOW(DRM_COMMAND_BASE + DRM_PANFROST_SUBMIT, struct drm_panfrost_submit)
> #define DRM_IOCTL_PANFROST_WAIT_BO DRM_IOW(DRM_COMMAND_BASE + DRM_PANFROST_WAIT_BO, struct drm_panfrost_wait_bo)
> @@ -27,6 +28,7 @@ extern "C" {
> #define DRM_IOCTL_PANFROST_MMAP_BO DRM_IOWR(DRM_COMMAND_BASE + DRM_PANFROST_MMAP_BO, struct drm_panfrost_mmap_bo)
> #define DRM_IOCTL_PANFROST_GET_PARAM DRM_IOWR(DRM_COMMAND_BASE + DRM_PANFROST_GET_PARAM, struct drm_panfrost_get_param)
> #define DRM_IOCTL_PANFROST_GET_BO_OFFSET DRM_IOWR(DRM_COMMAND_BASE + DRM_PANFROST_GET_BO_OFFSET, struct drm_panfrost_get_bo_offset)
> +#define DRM_IOCTL_PANFROST_MADVISE DRM_IOWR(DRM_COMMAND_BASE + DRM_PANFROST_MADVISE, struct drm_panfrost_madvise)
>
> /*
> * Unstable ioctl(s): only exposed when the unsafe unstable_ioctls module
> @@ -130,6 +132,45 @@ struct drm_panfrost_mmap_bo {
>
> enum drm_panfrost_param {
> DRM_PANFROST_PARAM_GPU_PROD_ID,
> + DRM_PANFROST_PARAM_GPU_REVISION,
> + DRM_PANFROST_PARAM_SHADER_PRESENT,
> + DRM_PANFROST_PARAM_TILER_PRESENT,
> + DRM_PANFROST_PARAM_L2_PRESENT,
> + DRM_PANFROST_PARAM_STACK_PRESENT,
> + DRM_PANFROST_PARAM_AS_PRESENT,
> + DRM_PANFROST_PARAM_JS_PRESENT,
> + DRM_PANFROST_PARAM_L2_FEATURES,
> + DRM_PANFROST_PARAM_CORE_FEATURES,
> + DRM_PANFROST_PARAM_TILER_FEATURES,
> + DRM_PANFROST_PARAM_MEM_FEATURES,
> + DRM_PANFROST_PARAM_MMU_FEATURES,
> + DRM_PANFROST_PARAM_THREAD_FEATURES,
> + DRM_PANFROST_PARAM_MAX_THREADS,
> + DRM_PANFROST_PARAM_THREAD_MAX_WORKGROUP_SZ,
> + DRM_PANFROST_PARAM_THREAD_MAX_BARRIER_SZ,
> + DRM_PANFROST_PARAM_COHERENCY_FEATURES,
> + DRM_PANFROST_PARAM_TEXTURE_FEATURES0,
> + DRM_PANFROST_PARAM_TEXTURE_FEATURES1,
> + DRM_PANFROST_PARAM_TEXTURE_FEATURES2,
> + DRM_PANFROST_PARAM_TEXTURE_FEATURES3,
> + DRM_PANFROST_PARAM_JS_FEATURES0,
> + DRM_PANFROST_PARAM_JS_FEATURES1,
> + DRM_PANFROST_PARAM_JS_FEATURES2,
> + DRM_PANFROST_PARAM_JS_FEATURES3,
> + DRM_PANFROST_PARAM_JS_FEATURES4,
> + DRM_PANFROST_PARAM_JS_FEATURES5,
> + DRM_PANFROST_PARAM_JS_FEATURES6,
> + DRM_PANFROST_PARAM_JS_FEATURES7,
> + DRM_PANFROST_PARAM_JS_FEATURES8,
> + DRM_PANFROST_PARAM_JS_FEATURES9,
> + DRM_PANFROST_PARAM_JS_FEATURES10,
> + DRM_PANFROST_PARAM_JS_FEATURES11,
> + DRM_PANFROST_PARAM_JS_FEATURES12,
> + DRM_PANFROST_PARAM_JS_FEATURES13,
> + DRM_PANFROST_PARAM_JS_FEATURES14,
> + DRM_PANFROST_PARAM_JS_FEATURES15,
> + DRM_PANFROST_PARAM_NR_CORE_GROUPS,
> + DRM_PANFROST_PARAM_THREAD_TLS_ALLOC,
> };
>
> struct drm_panfrost_get_param {
> @@ -162,6 +203,26 @@ struct drm_panfrost_perfcnt_dump {
> __u64 buf_ptr;
> };
>
> +/* madvise provides a way to tell the kernel in case a buffers contents
> + * can be discarded under memory pressure, which is useful for userspace
> + * bo cache where we want to optimistically hold on to buffer allocate
> + * and potential mmap, but allow the pages to be discarded under memory
> + * pressure.
> + *
> + * Typical usage would involve madvise(DONTNEED) when buffer enters BO
> + * cache, and madvise(WILLNEED) if trying to recycle buffer from BO cache.
> + * In the WILLNEED case, 'retained' indicates to userspace whether the
> + * backing pages still exist.
> + */
> +#define PANFROST_MADV_WILLNEED 0 /* backing pages are needed, status returned in 'retained' */
> +#define PANFROST_MADV_DONTNEED 1 /* backing pages not needed */
> +
> +struct drm_panfrost_madvise {
> + __u32 handle; /* in, GEM handle */
> + __u32 madv; /* in, PANFROST_MADV_x */
> + __u32 retained; /* out, whether backing store still exists */
> +};
> +
> #if defined(__cplusplus)
> }
> #endif
> --
> 2.20.1
>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: not available
URL: <https://lists.freedesktop.org/archives/mesa-dev/attachments/20190809/8f588e05/attachment.sig>
More information about the mesa-dev
mailing list