diff options
| author | Jesse Barnes <jbarnes@virtuousgeek.org> | 2009-09-15 11:02:58 -0700 | 
|---|---|---|
| committer | Eric Anholt <eric@anholt.net> | 2010-03-02 10:10:50 -0800 | 
| commit | b50964027bef249a0cc3d511de05c2464e0a1e22 (patch) | |
| tree | 922ef89b71b606f50087e7a41d7efd799f473c0c /include | |
| parent | 9a37455b35d746d694760cfe8850a8bf856d73c9 (diff) | |
libdrm/intel: execbuf2 support
This patch to libdrm adds support for the new execbuf2 ioctl.  If
detected, it will be used instead of the old ioctl.  By using the new
drm_intel_bufmgr_gem_enable_fenced_relocs(), you can indicate that any
time a fence register is actually required for a relocation target you
will call drm_intel_bo_emit_reloc_fence instead of
drm_intel_bo_emit_reloc, which will reduce fence register pressure.
Signed-off-by: Eric Anholt <eric@anholt.net>
Diffstat (limited to 'include')
| -rw-r--r-- | include/drm/i915_drm.h | 56 | 
1 files changed, 55 insertions, 1 deletions
| diff --git a/include/drm/i915_drm.h b/include/drm/i915_drm.h index 75b0e1d5..c8cb3a67 100644 --- a/include/drm/i915_drm.h +++ b/include/drm/i915_drm.h @@ -188,6 +188,7 @@ typedef struct _drm_i915_sarea {  #define DRM_I915_GEM_MADVISE	0x26  #define DRM_I915_OVERLAY_PUT_IMAGE	0x27  #define DRM_I915_OVERLAY_ATTRS	0x28 +#define DRM_I915_GEM_EXECBUFFER2	0x29  #define DRM_IOCTL_I915_INIT		DRM_IOW( DRM_COMMAND_BASE + DRM_I915_INIT, drm_i915_init_t)  #define DRM_IOCTL_I915_FLUSH		DRM_IO ( DRM_COMMAND_BASE + DRM_I915_FLUSH) @@ -207,6 +208,7 @@ typedef struct _drm_i915_sarea {  #define DRM_IOCTL_I915_VBLANK_SWAP	DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_VBLANK_SWAP, drm_i915_vblank_swap_t)  #define DRM_IOCTL_I915_GEM_INIT		DRM_IOW(DRM_COMMAND_BASE + DRM_I915_GEM_INIT, struct drm_i915_gem_init)  #define DRM_IOCTL_I915_GEM_EXECBUFFER	DRM_IOW(DRM_COMMAND_BASE + DRM_I915_GEM_EXECBUFFER, struct drm_i915_gem_execbuffer) +#define DRM_IOCTL_I915_GEM_EXECBUFFER2	DRM_IOW(DRM_COMMAND_BASE + DRM_I915_GEM_EXECBUFFER2, struct drm_i915_gem_execbuffer2)  #define DRM_IOCTL_I915_GEM_PIN		DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_GEM_PIN, struct drm_i915_gem_pin)  #define DRM_IOCTL_I915_GEM_UNPIN	DRM_IOW(DRM_COMMAND_BASE + DRM_I915_GEM_UNPIN, struct drm_i915_gem_unpin)  #define DRM_IOCTL_I915_GEM_BUSY		DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_GEM_BUSY, struct drm_i915_gem_busy) @@ -271,7 +273,8 @@ typedef struct drm_i915_irq_wait {  #define I915_PARAM_HAS_GEM               5  #define I915_PARAM_NUM_FENCES_AVAIL      6  #define I915_PARAM_HAS_OVERLAY           7 -#define I915_PARAM_HAS_PAGEFLIPPING      8 +#define I915_PARAM_HAS_PAGEFLIPPING	 8 +#define I915_PARAM_HAS_EXECBUF2          9  typedef struct drm_i915_getparam {  	int param; @@ -567,6 +570,57 @@ struct drm_i915_gem_execbuffer {  	__u64 cliprects_ptr;  }; +struct drm_i915_gem_exec_object2 { +	/** +	 * User's handle for a buffer to be bound into the GTT for this +	 * operation. +	 */ +	__u32 handle; + +	/** Number of relocations to be performed on this buffer */ +	__u32 relocation_count; +	/** +	 * Pointer to array of struct drm_i915_gem_relocation_entry containing +	 * the relocations to be performed in this buffer. +	 */ +	__u64 relocs_ptr; + +	/** Required alignment in graphics aperture */ +	__u64 alignment; + +	/** +	 * Returned value of the updated offset of the object, for future +	 * presumed_offset writes. +	 */ +	__u64 offset; + +#define EXEC_OBJECT_NEEDS_FENCE (1<<0) +	__u64 flags; +	__u64 rsvd1; +	__u64 rsvd2; +}; + +struct drm_i915_gem_execbuffer2 { +	/** +	 * List of gem_exec_object2 structs +	 */ +	__u64 buffers_ptr; +	__u32 buffer_count; + +	/** Offset in the batchbuffer to start execution from. */ +	__u32 batch_start_offset; +	/** Bytes used in batchbuffer from batch_start_offset */ +	__u32 batch_len; +	__u32 DR1; +	__u32 DR4; +	__u32 num_cliprects; +	/** This is a struct drm_clip_rect *cliprects */ +	__u64 cliprects_ptr; +	__u64 flags; /* currently unused */ +	__u64 rsvd1; +	__u64 rsvd2; +}; +  struct drm_i915_gem_pin {  	/** Handle of the buffer to be pinned. */  	__u32 handle; | 
