X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=src%2Fgallium%2Fdrivers%2Fsoftpipe%2Fsp_tile_cache.h;h=2c0bafad65155712b1525182730dbf8d7348b6c1;hb=44a46c09deb96040ec25903e58e1ffc297b841c9;hp=c8b03b3afb60dcd057ecd06e6ae6869655b5f8f3;hpb=877128505431adaf817dc8069172ebe4a1cdf5d8;p=mesa.git diff --git a/src/gallium/drivers/softpipe/sp_tile_cache.h b/src/gallium/drivers/softpipe/sp_tile_cache.h index c8b03b3afb6..2c0bafad651 100644 --- a/src/gallium/drivers/softpipe/sp_tile_cache.h +++ b/src/gallium/drivers/softpipe/sp_tile_cache.h @@ -54,7 +54,8 @@ union tile_address { unsigned x:TILE_ADDR_BITS; /* 16K / TILE_SIZE */ unsigned y:TILE_ADDR_BITS; /* 16K / TILE_SIZE */ unsigned invalid:1; - unsigned pad:15; + unsigned layer:8; + unsigned pad:7; } bits; unsigned value; }; @@ -82,12 +83,14 @@ struct softpipe_tile_cache { struct pipe_context *pipe; struct pipe_surface *surface; /**< the surface we're caching */ - struct pipe_transfer *transfer; - void *transfer_map; + struct pipe_transfer **transfer; + void **transfer_map; + int num_maps; union tile_address tile_addrs[NUM_ENTRIES]; struct softpipe_cached_tile *entries[NUM_ENTRIES]; - uint clear_flags[(MAX_WIDTH / TILE_SIZE) * (MAX_HEIGHT / TILE_SIZE) / 32]; + uint *clear_flags; + uint clear_flags_size; union pipe_color_union clear_color; /**< for color bufs */ uint64_t clear_val; /**< for z+stencil */ boolean depth_stencil; /**< Is the surface a depth/stencil format? */ @@ -125,26 +128,26 @@ sp_find_cached_tile(struct softpipe_tile_cache *tc, union tile_address addr ); -static INLINE union tile_address +static inline union tile_address tile_address( unsigned x, - unsigned y ) + unsigned y, unsigned layer ) { union tile_address addr; addr.value = 0; addr.bits.x = x / TILE_SIZE; addr.bits.y = y / TILE_SIZE; - + addr.bits.layer = layer; return addr; } /* Quickly retrieve tile if it matches last lookup. */ -static INLINE struct softpipe_cached_tile * +static inline struct softpipe_cached_tile * sp_get_cached_tile(struct softpipe_tile_cache *tc, - int x, int y ) + int x, int y, int layer ) { - union tile_address addr = tile_address( x, y ); + union tile_address addr = tile_address( x, y, layer ); if (tc->last_tile_addr.value == addr.value) return tc->last_tile;