/* * Copyright © 2018 Rob Clark * Copyright © 2018 Google, Inc. * SPDX-License-Identifier: MIT * * Authors: * Rob Clark */ #include #include #include "freedreno_layout.h" void fdl_layout_buffer(struct fdl_layout *layout, uint32_t size) { layout->width0 = size; layout->height0 = 1; layout->depth0 = 1; layout->cpp = 1; layout->cpp_shift = 0; layout->size = size; layout->format = PIPE_FORMAT_R8_UINT; layout->nr_samples = 1; } const char * fdl_tile_mode_desc(const struct fdl_layout *layout, int level) { if (fdl_ubwc_enabled(layout, level)) return "UBWC"; else if (fdl_tile_mode(layout, level) == 0) /* TILE6_LINEAR and friends */ return "linear"; else return "tiled"; } void fdl_dump_layout(struct fdl_layout *layout) { for (uint32_t level = 0; level < ARRAY_SIZE(layout->slices) && layout->slices[level].size0; level++) { struct fdl_slice *slice = &layout->slices[level]; struct fdl_slice *ubwc_slice = &layout->ubwc_slices[level]; fprintf( stderr, "%s: %ux%ux%u@%ux%u:\t%2u: stride=%4u, size=%6u,%6u, " "aligned_height=%3u, offset=0x%x,0x%x, layersz %5" PRIu64 ",%5" PRIu64 " %s\n", util_format_name(layout->format), u_minify(layout->width0, level), u_minify(layout->height0, level), u_minify(layout->depth0, level), layout->cpp, layout->nr_samples, level, fdl_pitch(layout, level), slice->size0, ubwc_slice->size0, slice->size0 / fdl_pitch(layout, level), slice->offset, ubwc_slice->offset, layout->layer_size, layout->ubwc_layer_size, fdl_tile_mode_desc(layout, level)); } }