aboutsummaryrefslogtreecommitdiff
path: root/render/drm_format_set.c
diff options
context:
space:
mode:
authorAlexander Orzechowski <alex@ozal.ski>2023-05-04 19:24:44 -0400
committerSimon Ser <contact@emersion.fr>2023-05-11 18:24:43 +0200
commit90d08f8f1c40e2a302d62052435ff2abdb08a854 (patch)
treea3accd6bbb593af732b5f1207e92bd407470992b /render/drm_format_set.c
parent340700cb7085aff743f929845604ef95feb5820e (diff)
wlr_drm_format: Rework wlr_drm_format_intersect
Now it takes a reference to a destination format
Diffstat (limited to 'render/drm_format_set.c')
-rw-r--r--render/drm_format_set.c37
1 files changed, 19 insertions, 18 deletions
diff --git a/render/drm_format_set.c b/render/drm_format_set.c
index ee9b1b2c..b669074d 100644
--- a/render/drm_format_set.c
+++ b/render/drm_format_set.c
@@ -183,7 +183,7 @@ bool wlr_drm_format_set_copy(struct wlr_drm_format_set *dst, const struct wlr_dr
return true;
}
-struct wlr_drm_format *wlr_drm_format_intersect(
+bool wlr_drm_format_intersect(struct wlr_drm_format *dst,
const struct wlr_drm_format *a, const struct wlr_drm_format *b) {
assert(a->format == b->format);
@@ -210,20 +210,9 @@ struct wlr_drm_format *wlr_drm_format_intersect(
}
}
- // If the intersection is empty, then the formats aren't compatible with
- // each other.
- if (fmt.len == 0) {
- wlr_drm_format_finish(&fmt);
- return NULL;
- }
-
- struct wlr_drm_format *format = calloc(1, sizeof(*format));
- if (!format) {
- wlr_drm_format_finish(&fmt);
- return NULL;
- }
- *format = fmt;
- return format;
+ wlr_drm_format_finish(dst);
+ *dst = fmt;
+ return true;
}
bool wlr_drm_format_set_intersect(struct wlr_drm_format_set *dst,
@@ -242,12 +231,24 @@ bool wlr_drm_format_set_intersect(struct wlr_drm_format_set *dst,
// When the two formats have no common modifier, keep
// intersecting the rest of the formats: they may be compatible
// with each other
- struct wlr_drm_format *format =
- wlr_drm_format_intersect(a->formats[i], b->formats[j]);
- if (format != NULL) {
+ struct wlr_drm_format *format = calloc(1, sizeof(*format));
+ if (!format) {
+ wlr_drm_format_set_finish(&out);
+ return false;
+ }
+
+ if (!wlr_drm_format_intersect(format, a->formats[i], b->formats[j])) {
+ wlr_drm_format_set_finish(&out);
+ return false;
+ }
+
+ if (format->len == 0) {
+ wlr_drm_format_finish(format);
+ } else {
out.formats[out.len] = format;
out.len++;
}
+
break;
}
}