diff options
| author | Chris Wilson <chris@chris-wilson.co.uk> | 2019-09-25 14:43:14 +0100 | 
|---|---|---|
| committer | Chris Wilson <chris@chris-wilson.co.uk> | 2019-10-29 22:02:28 +0000 | 
| commit | 12d9f8a52ce9223bb84cd818ea6fb40205410fd3 (patch) | |
| tree | 70f170d39c8ccbcb97308002c480c80b2825983d /include | |
| parent | 3703563d9a6ba06204dd6981d6cbd25aeb0e2c53 (diff) | |
i915_drm.h sync
Update to commit a0e047156cde ("drm/i915/gem: Make context persistence
optional") for I915_CONTEXT_PARAM_PERSISTENCE
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Acked-by: Andi Shyti <andi.shyti@intel.com>
Diffstat (limited to 'include')
| -rw-r--r-- | include/drm-uapi/i915_drm.h | 129 | 
1 files changed, 126 insertions, 3 deletions
| diff --git a/include/drm-uapi/i915_drm.h b/include/drm-uapi/i915_drm.h index 761517f1..ab899abb 100644 --- a/include/drm-uapi/i915_drm.h +++ b/include/drm-uapi/i915_drm.h @@ -521,6 +521,7 @@ typedef struct drm_i915_irq_wait {  #define   I915_SCHEDULER_CAP_PRIORITY	(1ul << 1)  #define   I915_SCHEDULER_CAP_PREEMPTION	(1ul << 2)  #define   I915_SCHEDULER_CAP_SEMAPHORES	(1ul << 3) +#define   I915_SCHEDULER_CAP_ENGINE_BUSY_STATS	(1ul << 4)  #define I915_PARAM_HUC_STATUS		 42 @@ -610,6 +611,13 @@ typedef struct drm_i915_irq_wait {   * See I915_EXEC_FENCE_OUT and I915_EXEC_FENCE_SUBMIT.   */  #define I915_PARAM_HAS_EXEC_SUBMIT_FENCE 53 + +/* + * Revision of the i915-perf uAPI. The value returned helps determine what + * i915-perf features are available. See drm_i915_perf_property_id. + */ +#define I915_PARAM_PERF_REVISION	54 +  /* Must be kept compact -- no holes and well documented */  typedef struct drm_i915_getparam { @@ -1564,6 +1572,21 @@ struct drm_i915_gem_context_param {   *   i915_context_engines_bond (I915_CONTEXT_ENGINES_EXT_BOND)   */  #define I915_CONTEXT_PARAM_ENGINES	0xa + +/* + * I915_CONTEXT_PARAM_PERSISTENCE: + * + * Allow the context and active rendering to survive the process until + * completion. Persistence allows fire-and-forget clients to queue up a + * bunch of work, hand the output over to a display server and then quit. + * If the context is marked as not persistent, upon closing (either via + * an explicit DRM_I915_GEM_CONTEXT_DESTROY or implicitly from file closure + * or process termination), the context and any outstanding requests will be + * cancelled (and exported fences for cancelled requests marked as -EIO). + * + * By default, new contexts allow persistence. + */ +#define I915_CONTEXT_PARAM_PERSISTENCE	0xb  /* Must be kept compact -- no holes and well documented */  	__u64 value; @@ -1843,23 +1866,31 @@ enum drm_i915_perf_property_id {  	 * Open the stream for a specific context handle (as used with  	 * execbuffer2). A stream opened for a specific context this way  	 * won't typically require root privileges. +	 * +	 * This property is available in perf revision 1.  	 */  	DRM_I915_PERF_PROP_CTX_HANDLE = 1,  	/**  	 * A value of 1 requests the inclusion of raw OA unit reports as  	 * part of stream samples. +	 * +	 * This property is available in perf revision 1.  	 */  	DRM_I915_PERF_PROP_SAMPLE_OA,  	/**  	 * The value specifies which set of OA unit metrics should be  	 * be configured, defining the contents of any OA unit reports. +	 * +	 * This property is available in perf revision 1.  	 */  	DRM_I915_PERF_PROP_OA_METRICS_SET,  	/**  	 * The value specifies the size and layout of OA unit reports. +	 * +	 * This property is available in perf revision 1.  	 */  	DRM_I915_PERF_PROP_OA_FORMAT, @@ -1869,9 +1900,22 @@ enum drm_i915_perf_property_id {  	 * from this exponent as follows:  	 *  	 *   80ns * 2^(period_exponent + 1) +	 * +	 * This property is available in perf revision 1.  	 */  	DRM_I915_PERF_PROP_OA_EXPONENT, +	/** +	 * Specifying this property is only valid when specify a context to +	 * filter with DRM_I915_PERF_PROP_CTX_HANDLE. Specifying this property +	 * will hold preemption of the particular context we want to gather +	 * performance data about. The execbuf2 submissions must include a +	 * drm_i915_gem_execbuffer_ext_perf parameter for this to apply. +	 * +	 * This property is available in perf revision 3. +	 */ +	DRM_I915_PERF_PROP_HOLD_PREEMPTION, +  	DRM_I915_PERF_PROP_MAX /* non-ABI */  }; @@ -1900,6 +1944,8 @@ struct drm_i915_perf_open_param {   * to close and re-open a stream with the same configuration.   *   * It's undefined whether any pending data for the stream will be lost. + * + * This ioctl is available in perf revision 1.   */  #define I915_PERF_IOCTL_ENABLE	_IO('i', 0x0) @@ -1907,10 +1953,25 @@ struct drm_i915_perf_open_param {   * Disable data capture for a stream.   *   * It is an error to try and read a stream that is disabled. + * + * This ioctl is available in perf revision 1.   */  #define I915_PERF_IOCTL_DISABLE	_IO('i', 0x1)  /** + * Change metrics_set captured by a stream. + * + * If the stream is bound to a specific context, the configuration change + * will performed __inline__ with that context such that it takes effect before + * the next execbuf submission. + * + * Returns the previously bound metrics set id, or a negative error code. + * + * This ioctl is available in perf revision 2. + */ +#define I915_PERF_IOCTL_CONFIG	_IO('i', 0x2) + +/**   * Common to all i915 perf records   */  struct drm_i915_perf_record_header { @@ -1983,6 +2044,7 @@ struct drm_i915_query_item {  	__u64 query_id;  #define DRM_I915_QUERY_TOPOLOGY_INFO    1  #define DRM_I915_QUERY_ENGINE_INFO	2 +#define DRM_I915_QUERY_PERF_CONFIG      3  /* Must be kept compact -- no holes and well documented */  	/* @@ -1994,9 +2056,18 @@ struct drm_i915_query_item {  	__s32 length;  	/* -	 * Unused for now. Must be cleared to zero. +	 * When query_id == DRM_I915_QUERY_TOPOLOGY_INFO, must be 0. +	 * +	 * When query_id == DRM_I915_QUERY_PERF_CONFIG, must be one of the +	 * following : +	 *         - DRM_I915_QUERY_PERF_CONFIG_LIST +	 *         - DRM_I915_QUERY_PERF_CONFIG_DATA_FOR_UUID +	 *         - DRM_I915_QUERY_PERF_CONFIG_FOR_UUID  	 */  	__u32 flags; +#define DRM_I915_QUERY_PERF_CONFIG_LIST          1 +#define DRM_I915_QUERY_PERF_CONFIG_DATA_FOR_UUID 2 +#define DRM_I915_QUERY_PERF_CONFIG_DATA_FOR_ID   3  	/*  	 * Data will be written at the location pointed by data_ptr when the @@ -2032,8 +2103,10 @@ struct drm_i915_query {   *           (data[X / 8] >> (X % 8)) & 1   *   * - the subslice mask for each slice with one bit per subslice telling - *   whether a subslice is available. The availability of subslice Y in slice - *   X can be queried with the following formula : + *   whether a subslice is available. Gen12 has dual-subslices, which are + *   similar to two gen11 subslices. For gen12, this array represents dual- + *   subslices. The availability of subslice Y in slice X can be queried + *   with the following formula :   *   *           (data[subslice_offset +   *                 X * subslice_stride + @@ -2122,6 +2195,56 @@ struct drm_i915_query_engine_info {  	struct drm_i915_engine_info engines[];  }; +/* + * Data written by the kernel with query DRM_I915_QUERY_PERF_CONFIG. + */ +struct drm_i915_query_perf_config { +	union { +		/* +		 * When query_item.flags == DRM_I915_QUERY_PERF_CONFIG_LIST, i915 sets +		 * this fields to the number of configurations available. +		 */ +		__u64 n_configs; + +		/* +		 * When query_id == DRM_I915_QUERY_PERF_CONFIG_DATA_FOR_ID, +		 * i915 will use the value in this field as configuration +		 * identifier to decide what data to write into config_ptr. +		 */ +		__u64 config; + +		/* +		 * When query_id == DRM_I915_QUERY_PERF_CONFIG_DATA_FOR_UUID, +		 * i915 will use the value in this field as configuration +		 * identifier to decide what data to write into config_ptr. +		 * +		 * String formatted like "%08x-%04x-%04x-%04x-%012x" +		 */ +		char uuid[36]; +	}; + +	/* +	 * Unused for now. Must be cleared to zero. +	 */ +	__u32 flags; + +	/* +	 * When query_item.flags == DRM_I915_QUERY_PERF_CONFIG_LIST, i915 will +	 * write an array of __u64 of configuration identifiers. +	 * +	 * When query_item.flags == DRM_I915_QUERY_PERF_CONFIG_DATA, i915 will +	 * write a struct drm_i915_perf_oa_config. If the following fields of +	 * drm_i915_perf_oa_config are set not set to 0, i915 will write into +	 * the associated pointers the values of submitted when the +	 * configuration was created : +	 * +	 *         - n_mux_regs +	 *         - n_boolean_regs +	 *         - n_flex_regs +	 */ +	__u8 data[]; +}; +  #if defined(__cplusplus)  }  #endif | 
