[igt-dev] [PATCH i-g-t v9 01/16] Add PXP UAPI support in i915_drm.h
Teres Alexis, Alan Previn
alan.previn.teres.alexis at intel.com
Fri Sep 3 21:11:47 UTC 2021
oops - my bad - didnt realize we had that - will do.
While on this, would it make sense to permanently include lib/i915/i915_drm_local.h from include/drm-
uapi/i915_drm.h (but latter would always remain empty on upstream)?. This way, when kernel support is
added for UAPI changes, we move the definitions across but dont add and need remove the '#include
"lib/i915/i915_drm_local.h" from the other source files (requiring another change)?
...alan
On Fri, 2021-09-03 at 13:31 +0300, Petri Latvala wrote:
> On Thu, Sep 02, 2021 at 10:30:28AM -0700, Alan Previn wrote:
> > At the time of this commit, PXP hasnt been merged into
> > upstream kernel so this has no kernel tag reference yet
>
> Please use the newly added lib/i915/i915_drm_local.h for these
> additions then.
>
>
> --
> Petri Latvala
>
>
> > Signed-off-by: Alan Previn <alan.previn.teres.alexis at intel.com>
> > ---
> > include/drm-uapi/i915_drm.h | 53 +++++++++++++++++++++++++++++++++++++
> > 1 file changed, 53 insertions(+)
> >
> > diff --git a/include/drm-uapi/i915_drm.h b/include/drm-uapi/i915_drm.h
> > index b9632bb2..98149a7d 100644
> > --- a/include/drm-uapi/i915_drm.h
> > +++ b/include/drm-uapi/i915_drm.h
> > @@ -1815,6 +1815,25 @@ struct drm_i915_gem_context_param {
> > * attempted to use it, never re-use this context param number.
> > */
> > #define I915_CONTEXT_PARAM_RINGSIZE 0xc
> > +
> > +/*
> > + * I915_CONTEXT_PARAM_PROTECTED_CONTENT:
> > + *
> > + * Mark that the context makes use of protected content, which will result
> > + * in the context being invalidated when the protected content session is.
> > + * This flag can only be set at context creation time and, when set to true,
> > + * must be preceded by an explicit setting of I915_CONTEXT_PARAM_RECOVERABLE
> > + * to false. This flag can't be set to true in conjunction with setting the
> > + * I915_CONTEXT_PARAM_BANNABLE flag to false.
> > + *
> > + * Given the numerous restriction on this flag, there are several unique
> > + * failure cases:
> > + *
> > + * -ENODEV: feature not available
> > + * -EPERM: trying to mark a recoverable or not bannable context as protected
> > + * -EACCES: submitting an invalidated context for execution
> > + */
> > +#define I915_CONTEXT_PARAM_PROTECTED_CONTENT 0xd
> > /* Must be kept compact -- no holes and well documented */
> >
> > __u64 value;
> > @@ -2931,8 +2950,12 @@ struct drm_i915_gem_create_ext {
> > *
> > * For I915_GEM_CREATE_EXT_MEMORY_REGIONS usage see
> > * struct drm_i915_gem_create_ext_memory_regions.
> > + *
> > + * For I915_GEM_CREATE_EXT_PROTECTED_CONTENT usage see
> > + * struct drm_i915_gem_create_ext_protected_content.
> > */
> > #define I915_GEM_CREATE_EXT_MEMORY_REGIONS 0
> > +#define I915_GEM_CREATE_EXT_PROTECTED_CONTENT 1
> > __u64 extensions;
> > };
> >
> > @@ -2990,6 +3013,36 @@ struct drm_i915_gem_create_ext_memory_regions {
> > __u64 regions;
> > };
> >
> > +/**
> > + * struct drm_i915_gem_create_ext_protected_content - The
> > + * I915_OBJECT_PARAM_PROTECTED_CONTENT extension.
> > + *
> > + * If this extension is provided, buffer contents are expected to be
> > + * protected by PXP encryption and requires decryption for scan out
> > + * and processing. This is only possible on platforms that have PXP enabled,
> > + * on all other scenarios ysing this extension will cause the ioctl to fail
> > + * and return -ENODEV. The flags parameter is reserved for future expansion and
> > + * must currently be set to zero.
> > + *
> > + * The buffer contents are considered invalid after a PXP session teardown.
> > + *
> > + * The encryption is guaranteed to be processed correctly only if the object
> > + * is submitted with a context created using the
> > + * I915_CONTEXT_PARAM_PROTECTED_CONTENT flag. This will also enable extra checks
> > + * at submission time on the validity of the objects involved, which can lead to
> > + * the following errors being returned from the execbuf ioctl:
> > + *
> > + * -ENODEV: PXP session not currently active
> > + * -ENOEXEC: buffer has become invalid after a teardown event
> > + */
> > +struct drm_i915_gem_create_ext_protected_content {
> > + struct i915_user_extension base;
> > + __u32 flags;
> > +};
> > +
> > +/* ID of the protected content session managed by i915 when PXP is active */
> > +#define I915_PROTECTED_CONTENT_DEFAULT_SESSION 0xf
> > +
> > #if defined(__cplusplus)
> > }
> > #endif
> > --
> > 2.25.1
> >
More information about the igt-dev
mailing list