17ec681f3Smrg/*
27ec681f3Smrg * Copyright (C) 2018 Rob Clark <robclark@freedesktop.org>
37ec681f3Smrg * Copyright © 2018 Google, Inc.
47ec681f3Smrg *
57ec681f3Smrg * Permission is hereby granted, free of charge, to any person obtaining a
67ec681f3Smrg * copy of this software and associated documentation files (the "Software"),
77ec681f3Smrg * to deal in the Software without restriction, including without limitation
87ec681f3Smrg * the rights to use, copy, modify, merge, publish, distribute, sublicense,
97ec681f3Smrg * and/or sell copies of the Software, and to permit persons to whom the
107ec681f3Smrg * Software is furnished to do so, subject to the following conditions:
117ec681f3Smrg *
127ec681f3Smrg * The above copyright notice and this permission notice (including the next
137ec681f3Smrg * paragraph) shall be included in all copies or substantial portions of the
147ec681f3Smrg * Software.
157ec681f3Smrg *
167ec681f3Smrg * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
177ec681f3Smrg * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
187ec681f3Smrg * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
197ec681f3Smrg * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
207ec681f3Smrg * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
217ec681f3Smrg * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
227ec681f3Smrg * SOFTWARE.
237ec681f3Smrg *
247ec681f3Smrg * Authors:
257ec681f3Smrg *    Rob Clark <robclark@freedesktop.org>
267ec681f3Smrg */
277ec681f3Smrg
287ec681f3Smrg#include <stdio.h>
297ec681f3Smrg
307ec681f3Smrg#include "freedreno_layout.h"
317ec681f3Smrg
327ec681f3Smrgvoid
337ec681f3Smrgfdl_layout_buffer(struct fdl_layout *layout, uint32_t size)
347ec681f3Smrg{
357ec681f3Smrg   layout->width0 = size;
367ec681f3Smrg   layout->height0 = 1;
377ec681f3Smrg   layout->depth0 = 1;
387ec681f3Smrg   layout->cpp = 1;
397ec681f3Smrg   layout->cpp_shift = 0;
407ec681f3Smrg   layout->size = size;
417ec681f3Smrg   layout->format = PIPE_FORMAT_R8_UINT;
427ec681f3Smrg   layout->nr_samples = 1;
437ec681f3Smrg}
447ec681f3Smrg
457ec681f3Smrgconst char *
467ec681f3Smrgfdl_tile_mode_desc(const struct fdl_layout *layout, int level)
477ec681f3Smrg{
487ec681f3Smrg   if (fdl_ubwc_enabled(layout, level))
497ec681f3Smrg      return "UBWC";
507ec681f3Smrg   else if (fdl_tile_mode(layout, level) == 0) /* TILE6_LINEAR and friends */
517ec681f3Smrg      return "linear";
527ec681f3Smrg   else
537ec681f3Smrg      return "tiled";
547ec681f3Smrg}
557ec681f3Smrg
567ec681f3Smrgvoid
577ec681f3Smrgfdl_dump_layout(struct fdl_layout *layout)
587ec681f3Smrg{
597ec681f3Smrg   for (uint32_t level = 0;
607ec681f3Smrg        level < ARRAY_SIZE(layout->slices) && layout->slices[level].size0;
617ec681f3Smrg        level++) {
627ec681f3Smrg      struct fdl_slice *slice = &layout->slices[level];
637ec681f3Smrg      struct fdl_slice *ubwc_slice = &layout->ubwc_slices[level];
647ec681f3Smrg
657ec681f3Smrg      fprintf(
667ec681f3Smrg         stderr,
677ec681f3Smrg         "%s: %ux%ux%u@%ux%u:\t%2u: stride=%4u, size=%6u,%6u, "
687ec681f3Smrg         "aligned_height=%3u, offset=0x%x,0x%x, layersz %5u,%5u %s\n",
697ec681f3Smrg         util_format_name(layout->format), u_minify(layout->width0, level),
707ec681f3Smrg         u_minify(layout->height0, level), u_minify(layout->depth0, level),
717ec681f3Smrg         layout->cpp, layout->nr_samples, level, fdl_pitch(layout, level),
727ec681f3Smrg         slice->size0, ubwc_slice->size0,
737ec681f3Smrg         slice->size0 / fdl_pitch(layout, level), slice->offset,
747ec681f3Smrg         ubwc_slice->offset, layout->layer_size, layout->ubwc_layer_size,
757ec681f3Smrg         fdl_tile_mode_desc(layout, level));
767ec681f3Smrg   }
777ec681f3Smrg}
78