summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTobias Stoeckmann <tobias@stoeckmann.org>2024-09-12 22:05:52 +0200
committerSimon Ser <contact@emersion.fr>2025-06-08 20:56:31 +0200
commit65ce8920e2162a9a703bddbdf167e48f504ca2d4 (patch)
treebcf7a6229291396e8cae62f3806adc181b215ce3
parentcursor: Gracefully handle out of memory condition (diff)
downloadwayland-65ce8920e2162a9a703bddbdf167e48f504ca2d4.tar
wayland-65ce8920e2162a9a703bddbdf167e48f504ca2d4.tar.gz
wayland-65ce8920e2162a9a703bddbdf167e48f504ca2d4.tar.bz2
wayland-65ce8920e2162a9a703bddbdf167e48f504ca2d4.tar.lz
wayland-65ce8920e2162a9a703bddbdf167e48f504ca2d4.tar.xz
wayland-65ce8920e2162a9a703bddbdf167e48f504ca2d4.tar.zst
wayland-65ce8920e2162a9a703bddbdf167e48f504ca2d4.zip
cursor: Gracefully handle huge cursor files
If cursor files require more than INT_MAX bytes, it is possible to trigger out of boundary writes. Since these sizes are most likely not desired anyway, gracefully handle these situations like out of memory errors. Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org> (cherry picked from commit 5c2f31d8d6e5f24962300f4608a0d6f887ca3bea)
-rw-r--r--cursor/wayland-cursor.c14
1 files changed, 12 insertions, 2 deletions
diff --git a/cursor/wayland-cursor.c b/cursor/wayland-cursor.c
index 636f516..f3fef15 100644
--- a/cursor/wayland-cursor.c
+++ b/cursor/wayland-cursor.c
@@ -27,6 +27,7 @@
#include "xcursor.h"
#include "wayland-cursor.h"
#include "wayland-client.h"
+#include <limits.h>
#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
@@ -284,7 +285,8 @@ wl_cursor_create_from_xcursor_images(struct xcursor_images *images,
{
struct cursor *cursor;
struct cursor_image *image;
- int i, size;
+ size_t size;
+ int i;
cursor = malloc(sizeof *cursor);
if (!cursor)
@@ -314,7 +316,12 @@ wl_cursor_create_from_xcursor_images(struct xcursor_images *images,
image->image.hotspot_y = images->images[i]->yhot;
image->image.delay = images->images[i]->delay;
- size = image->image.width * image->image.height * 4;
+ size = (size_t) image->image.width * image->image.height * 4;
+ if (size > INT_MAX) {
+ free(image);
+ break;
+ }
+
image->offset = shm_pool_allocate(theme->pool, size);
if (image->offset < 0) {
free(image);
@@ -389,6 +396,9 @@ wl_cursor_theme_load(const char *name, int size, struct wl_shm *shm)
if (!theme)
return NULL;
+ if (size < 0 || (size > 0 && INT_MAX / size / 4 < size))
+ return NULL;
+
if (!name)
name = "default";