2019-07-22 21:41:03 +00:00
|
|
|
// Copyright 2019, Collabora, Ltd.
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief Format helpers and block code.
|
|
|
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "util/u_format.h"
|
|
|
|
|
|
|
|
#include <assert.h>
|
|
|
|
|
|
|
|
|
|
|
|
const char *
|
|
|
|
u_format_str(enum xrt_format f)
|
|
|
|
{
|
|
|
|
switch (f) {
|
|
|
|
case XRT_FORMAT_R8G8B8X8: return "XRT_FORMAT_R8G8B8X8";
|
|
|
|
case XRT_FORMAT_R8G8B8A8: return "XRT_FORMAT_R8G8B8A8";
|
|
|
|
case XRT_FORMAT_R8G8B8: return "XRT_FORMAT_R8G8B8";
|
|
|
|
case XRT_FORMAT_BITMAP_8X1: return "XRT_FORMAT_BITMAP_8X1";
|
|
|
|
case XRT_FORMAT_BITMAP_8X8: return "XRT_FORMAT_BITMAP_8X8";
|
|
|
|
case XRT_FORMAT_YUV888: return "XRT_FORMAT_YUV888";
|
|
|
|
case XRT_FORMAT_YUV422: return "XRT_FORMAT_YUV422";
|
|
|
|
case XRT_FORMAT_MJPEG: return "XRT_FORMAT_MJPEG";
|
2019-07-24 23:51:44 +00:00
|
|
|
default:
|
|
|
|
assert(!"unsupported format");
|
|
|
|
return 0;
|
2019-07-22 21:41:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
u_format_is_blocks(enum xrt_format f)
|
|
|
|
{
|
|
|
|
switch (f) {
|
|
|
|
case XRT_FORMAT_R8G8B8X8:
|
|
|
|
case XRT_FORMAT_R8G8B8A8:
|
|
|
|
case XRT_FORMAT_R8G8B8:
|
|
|
|
case XRT_FORMAT_BITMAP_8X1:
|
|
|
|
case XRT_FORMAT_BITMAP_8X8:
|
|
|
|
case XRT_FORMAT_YUV888:
|
|
|
|
case XRT_FORMAT_YUV422:
|
|
|
|
// Yes
|
|
|
|
return true;
|
|
|
|
case XRT_FORMAT_MJPEG:
|
|
|
|
// Compressed
|
|
|
|
return false;
|
2019-07-24 23:51:44 +00:00
|
|
|
default:
|
|
|
|
assert(!"unsupported format");
|
|
|
|
return 0;
|
2019-07-22 21:41:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t
|
|
|
|
u_format_block_width(enum xrt_format f)
|
|
|
|
{
|
|
|
|
switch (f) {
|
|
|
|
case XRT_FORMAT_R8G8B8X8:
|
|
|
|
case XRT_FORMAT_R8G8B8A8:
|
|
|
|
case XRT_FORMAT_R8G8B8:
|
|
|
|
case XRT_FORMAT_YUV888:
|
|
|
|
// Regular one pixel per block formats.
|
|
|
|
return 1;
|
|
|
|
case XRT_FORMAT_YUV422:
|
|
|
|
// Two pixels per block.
|
|
|
|
return 2;
|
|
|
|
case XRT_FORMAT_BITMAP_8X8:
|
|
|
|
case XRT_FORMAT_BITMAP_8X1:
|
|
|
|
// Eight pixels per block.
|
|
|
|
return 8;
|
2019-07-24 23:51:44 +00:00
|
|
|
default:
|
|
|
|
assert(!"unsupported format");
|
|
|
|
return 0;
|
2019-07-22 21:41:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t
|
|
|
|
u_format_block_height(enum xrt_format f)
|
|
|
|
{
|
|
|
|
switch (f) {
|
|
|
|
case XRT_FORMAT_R8G8B8X8:
|
|
|
|
case XRT_FORMAT_R8G8B8A8:
|
|
|
|
case XRT_FORMAT_R8G8B8:
|
|
|
|
case XRT_FORMAT_BITMAP_8X1:
|
|
|
|
case XRT_FORMAT_YUV888:
|
|
|
|
case XRT_FORMAT_YUV422:
|
|
|
|
// One pixel high.
|
|
|
|
return 1;
|
|
|
|
case XRT_FORMAT_BITMAP_8X8:
|
|
|
|
// Eight pixels high.
|
|
|
|
return 8;
|
2019-07-24 23:51:44 +00:00
|
|
|
default:
|
|
|
|
assert(!"unsupported format");
|
|
|
|
return 0;
|
2019-07-22 21:41:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t
|
|
|
|
u_format_block_size(enum xrt_format f)
|
|
|
|
{
|
|
|
|
switch (f) {
|
|
|
|
case XRT_FORMAT_BITMAP_8X1: return 1;
|
|
|
|
|
|
|
|
case XRT_FORMAT_R8G8B8:
|
|
|
|
case XRT_FORMAT_YUV888:
|
|
|
|
// Weird 24bit pixel formats.
|
|
|
|
return 3;
|
|
|
|
case XRT_FORMAT_R8G8B8X8:
|
|
|
|
case XRT_FORMAT_R8G8B8A8:
|
|
|
|
case XRT_FORMAT_YUV422: // Four bytes per two pixels.
|
|
|
|
// 32bit pixel formats.
|
|
|
|
return 4;
|
|
|
|
case XRT_FORMAT_BITMAP_8X8: // 64 bits.
|
|
|
|
return 8;
|
2019-07-24 23:51:44 +00:00
|
|
|
default:
|
|
|
|
assert(!"unsupported format");
|
|
|
|
return 0;
|
2019-07-22 21:41:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
u_format_size_for_dimensions(enum xrt_format f,
|
|
|
|
uint32_t width,
|
|
|
|
uint32_t height,
|
|
|
|
size_t *out_stride,
|
|
|
|
size_t *out_size)
|
|
|
|
{
|
|
|
|
uint32_t sw = u_format_block_width(f);
|
|
|
|
uint32_t sh = u_format_block_height(f);
|
|
|
|
size_t block_size = u_format_block_size(f);
|
|
|
|
|
|
|
|
// Round up
|
|
|
|
uint32_t num_blocks_x = (width + (sw - 1)) / sw;
|
|
|
|
uint32_t num_blocks_y = (height + (sh - 1)) / sh;
|
|
|
|
|
|
|
|
// Add it all together
|
|
|
|
size_t stride = num_blocks_x * block_size;
|
|
|
|
size_t size = num_blocks_y * stride;
|
|
|
|
|
|
|
|
*out_stride = stride;
|
|
|
|
*out_size = size;
|
|
|
|
}
|