mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-21 06:01:43 +00:00
u/sink: Make u_sink_create_format_converter support L8
Co-authored-by: Moses Turner <moses@collabora.com>
This commit is contained in:
parent
8e0d9198c4
commit
83c8b1da86
|
@ -170,6 +170,7 @@ u_sink_force_genlock_create(struct xrt_frame_context *xfctx,
|
||||||
struct xrt_frame_sink **out_left_xfs,
|
struct xrt_frame_sink **out_left_xfs,
|
||||||
struct xrt_frame_sink **out_right_xfs);
|
struct xrt_frame_sink **out_right_xfs);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
* Debugging sink,
|
* Debugging sink,
|
||||||
|
|
|
@ -232,6 +232,21 @@ from_YUYV422_to_R8G8B8(struct xrt_frame *dst_frame, uint32_t w, uint32_t h, size
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
from_YUYV422_to_L8(struct xrt_frame *dst_frame, uint32_t w, uint32_t h, size_t stride, const uint8_t *data)
|
||||||
|
{
|
||||||
|
SINK_TRACE_MARKER();
|
||||||
|
|
||||||
|
for (uint32_t y = 0; y < h; y++) {
|
||||||
|
const uint8_t *src = data + (y * stride);
|
||||||
|
uint8_t *dst = dst_frame->data + (y * dst_frame->stride);
|
||||||
|
|
||||||
|
for (uint32_t x = 0; x < w; x++) {
|
||||||
|
dst[x] = src[x * 2];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
from_UYVY422_to_R8G8B8(struct xrt_frame *dst_frame, uint32_t w, uint32_t h, size_t stride, const uint8_t *data)
|
from_UYVY422_to_R8G8B8(struct xrt_frame *dst_frame, uint32_t w, uint32_t h, size_t stride, const uint8_t *data)
|
||||||
{
|
{
|
||||||
|
@ -461,6 +476,32 @@ create_frame_with_format(struct xrt_frame *xf, enum xrt_format format, struct xr
|
||||||
return create_frame_with_format_of_size(xf, xf->width, xf->height, format, out_frame);
|
return create_frame_with_format_of_size(xf, xf->width, xf->height, format, out_frame);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
convert_frame_l8(struct xrt_frame_sink *xs, struct xrt_frame *xf)
|
||||||
|
{
|
||||||
|
SINK_TRACE_MARKER();
|
||||||
|
|
||||||
|
struct u_sink_converter *s = (struct u_sink_converter *)xs;
|
||||||
|
|
||||||
|
struct xrt_frame *converted = NULL;
|
||||||
|
|
||||||
|
switch (xf->format) {
|
||||||
|
case XRT_FORMAT_L8: s->downstream->push_frame(s->downstream, xf); return;
|
||||||
|
case XRT_FORMAT_YUYV422:
|
||||||
|
if (!create_frame_with_format(xf, XRT_FORMAT_L8, &converted)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
from_YUYV422_to_L8(converted, xf->width, xf->height, xf->stride, xf->data);
|
||||||
|
break;
|
||||||
|
default: U_LOG_E("Can not convert from '%s' to L8!", u_format_str(xf->format)); return;
|
||||||
|
}
|
||||||
|
|
||||||
|
s->downstream->push_frame(s->downstream, converted);
|
||||||
|
|
||||||
|
// Refcount in case it's being held downstream.
|
||||||
|
xrt_frame_reference(&converted, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
convert_frame_r8g8b8_or_l8(struct xrt_frame_sink *xs, struct xrt_frame *xf)
|
convert_frame_r8g8b8_or_l8(struct xrt_frame_sink *xs, struct xrt_frame *xf)
|
||||||
{
|
{
|
||||||
|
@ -801,13 +842,16 @@ destroy(struct xrt_frame_node *node)
|
||||||
|
|
||||||
void
|
void
|
||||||
u_sink_create_format_converter(struct xrt_frame_context *xfctx,
|
u_sink_create_format_converter(struct xrt_frame_context *xfctx,
|
||||||
enum xrt_format f,
|
enum xrt_format format,
|
||||||
struct xrt_frame_sink *downstream,
|
struct xrt_frame_sink *downstream,
|
||||||
struct xrt_frame_sink **out_xfs)
|
struct xrt_frame_sink **out_xfs)
|
||||||
{
|
{
|
||||||
if (f != XRT_FORMAT_R8G8B8) {
|
void (*func)(struct xrt_frame_sink *, struct xrt_frame *);
|
||||||
U_LOG_E("Format '%s' not supported", u_format_str(f));
|
|
||||||
return;
|
switch (format) {
|
||||||
|
case XRT_FORMAT_R8G8B8: func = convert_frame_r8g8b8; break;
|
||||||
|
case XRT_FORMAT_L8: func = convert_frame_l8; break;
|
||||||
|
default: U_LOG_E("Format '%s' not supported", u_format_str(format)); return;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef USE_TABLE
|
#ifdef USE_TABLE
|
||||||
|
@ -815,7 +859,7 @@ u_sink_create_format_converter(struct xrt_frame_context *xfctx,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
struct u_sink_converter *s = U_TYPED_CALLOC(struct u_sink_converter);
|
struct u_sink_converter *s = U_TYPED_CALLOC(struct u_sink_converter);
|
||||||
s->base.push_frame = convert_frame_r8g8b8;
|
s->base.push_frame = func;
|
||||||
s->node.break_apart = break_apart;
|
s->node.break_apart = break_apart;
|
||||||
s->node.destroy = destroy;
|
s->node.destroy = destroy;
|
||||||
s->downstream = downstream;
|
s->downstream = downstream;
|
||||||
|
|
Loading…
Reference in a new issue