transfer->base.level = level;
transfer->base.usage = usage;
transfer->base.box = *box;
- transfer->base.stride = bo->slices[level].stride;
- transfer->base.layer_stride = bo->cubemap_stride;
pipe_resource_reference(&transfer->base.resource, resource);
if (usage & PIPE_TRANSFER_MAP_DIRECTLY)
return NULL;
+ transfer->base.stride = box->width * bytes_per_pixel;
+ transfer->base.layer_stride = transfer->base.stride * box->height;
+
/* TODO: Reads */
- /* TODO: Only allocate "just" enough, shortening the stride */
- transfer->map = malloc(transfer->base.stride * box->height);
+ transfer->map = malloc(transfer->base.layer_stride * box->depth);
return transfer->map;
} else {
+ transfer->base.stride = bo->slices[level].stride;
+ transfer->base.layer_stride = bo->cubemap_stride;
+
return bo->cpu
+ bo->slices[level].offset
+ transfer->base.box.z * bo->cubemap_stride
trans->base.box.width,
trans->base.box.height,
util_format_get_blocksize(rsrc->base.format),
- bo->slices[level].stride,
u_minify(rsrc->base.width0, level),
trans->map,
bo->cpu
void
panfrost_texture_swizzle(unsigned off_x,
unsigned off_y,
- int width, int height, int bytes_per_pixel, int source_stride, int dest_width,
+ int width, int height, int bytes_per_pixel, int dest_width,
const uint8_t *pixels,
uint8_t *ldest)
{
/* Calculate maximum size, overestimating a bit */
int block_pitch = ALIGN(dest_width, 16) >> 4;
+ /* Strides must be tight, since we're only ever called indirectly */
+ int source_stride = width * bytes_per_pixel;
+
/* Use fast path if available */
- if (!(off_x || off_y)) {
+ if (!(off_x || off_y) && (width == dest_width)) {
if (bytes_per_pixel == 4 /* && (ALIGN(width, 16) == width) */) {
swizzle_bpp4_align16(width, height, source_stride >> 2, (block_pitch * 256 >> 4), (const uint32_t *) pixels, (uint32_t *) ldest);
return;
void
panfrost_texture_swizzle(unsigned off_x, unsigned off_y,
- int width, int height, int bytes_per_pixel, int source_stride, int dest_width,
+ int width, int height, int bytes_per_pixel, int dest_width,
const uint8_t *pixels,
uint8_t *ldest);