diff options
author | Chris Wilson <chris@chris-wilson.co.uk> | 2011-02-01 10:53:57 +0000 |
---|---|---|
committer | Chris Wilson <chris@chris-wilson.co.uk> | 2011-02-01 10:56:46 +0000 |
commit | 371f87f2d825900484e34a8ec78272b9e62cbc02 (patch) | |
tree | 7dea0d2304d2027c13ccf945fb1811cf999d27f0 /lib/intel_batchbuffer.h | |
parent | 5fc09c82d40113a7ebf67b7dbc374c181d9fafe3 (diff) |
Exercise the whole aperture with tiled blits
After full-gtt, gem_tiled_blits doesn't allocate enough to force
eviction. So query the total aperture and accommodate.
Also introduce a similar test that utilizes fences rather than
use the BLT to perform the tiling and detiling.
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'lib/intel_batchbuffer.h')
-rw-r--r-- | lib/intel_batchbuffer.h | 29 |
1 files changed, 3 insertions, 26 deletions
diff --git a/lib/intel_batchbuffer.h b/lib/intel_batchbuffer.h index 84f75761..a8271766 100644 --- a/lib/intel_batchbuffer.h +++ b/lib/intel_batchbuffer.h @@ -15,18 +15,8 @@ struct intel_batchbuffer drm_intel_bo *bo; - uint8_t *buffer; - - uint8_t *map; + uint8_t buffer[BATCH_SZ]; uint8_t *ptr; - - /* debug stuff */ - struct { - uint8_t *start_ptr; - unsigned int total; - } emit; - - unsigned int size; }; struct intel_batchbuffer *intel_batchbuffer_alloc(drm_intel_bufmgr *bufmgr, @@ -56,14 +46,13 @@ void intel_batchbuffer_emit_reloc(struct intel_batchbuffer *batch, static inline int intel_batchbuffer_space(struct intel_batchbuffer *batch) { - return (batch->size - BATCH_RESERVED) - (batch->ptr - batch->map); + return (BATCH_SZ - BATCH_RESERVED) - (batch->ptr - batch->buffer); } static inline void intel_batchbuffer_emit_dword(struct intel_batchbuffer *batch, uint32_t dword) { - assert(batch->map); assert(intel_batchbuffer_space(batch) >= 4); *(uint32_t *) (batch->ptr) = dword; batch->ptr += 4; @@ -73,7 +62,7 @@ static inline void intel_batchbuffer_require_space(struct intel_batchbuffer *batch, unsigned int sz) { - assert(sz < batch->size - 8); + assert(sz < BATCH_SZ - 8); if (intel_batchbuffer_space(batch) < sz) intel_batchbuffer_flush(batch); } @@ -84,9 +73,6 @@ intel_batchbuffer_require_space(struct intel_batchbuffer *batch, #define BEGIN_BATCH(n) do { \ intel_batchbuffer_require_space(batch, (n)*4); \ - assert(batch->emit.start_ptr == NULL); \ - batch->emit.total = (n) * 4; \ - batch->emit.start_ptr = batch->ptr; \ } while (0) #define OUT_BATCH(d) intel_batchbuffer_emit_dword(batch, d) @@ -98,15 +84,6 @@ intel_batchbuffer_require_space(struct intel_batchbuffer *batch, } while (0) #define ADVANCE_BATCH() do { \ - unsigned int _n = batch->ptr - batch->emit.start_ptr; \ - assert(batch->emit.start_ptr != NULL); \ - if (_n != batch->emit.total) { \ - fprintf(stderr, \ - "ADVANCE_BATCH: %d of %d dwords emitted\n", \ - _n, batch->emit.total); \ - abort(); \ - } \ - batch->emit.start_ptr = NULL; \ } while(0) |