diff options
Diffstat (limited to 'gui-wm/sommelier/files/sommelier-0.12-enforce-16k-alignment.patch')
-rw-r--r-- | gui-wm/sommelier/files/sommelier-0.12-enforce-16k-alignment.patch | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/gui-wm/sommelier/files/sommelier-0.12-enforce-16k-alignment.patch b/gui-wm/sommelier/files/sommelier-0.12-enforce-16k-alignment.patch new file mode 100644 index 0000000..7795fa5 --- /dev/null +++ b/gui-wm/sommelier/files/sommelier-0.12-enforce-16k-alignment.patch @@ -0,0 +1,58 @@ +Upstream: no + +From 10056fbb3f09d448a00748fea48dc6c630948d90 Mon Sep 17 00:00:00 2001 +From: Johannes Nixdorf <johannes@nixdorf.dev> +Date: Wed, 29 May 2024 21:20:53 +0200 +Subject: [PATCH] Import the 16k alignment patch hidden in the copr sources + +--- + sommelier-seat.cc | 4 +++- + virtualization/virtgpu_channel.cc | 4 +++- + 2 files changed, 6 insertions(+), 2 deletions(-) + +diff --git a/sommelier-seat.cc b/sommelier-seat.cc +index 3a056ca00ea8..c8dc85fcacb1 100644 +--- a/sommelier-seat.cc ++++ b/sommelier-seat.cc +@@ -286,6 +286,8 @@ static void sl_host_keyboard_release(struct wl_client* client, + static const struct wl_keyboard_interface sl_keyboard_implementation = { + sl_host_keyboard_release}; + ++#define ALIGN_POT(x, pot_align) (((x) + (pot_align) - 1) & ~((pot_align) - 1)) ++ + static void sl_keyboard_keymap(void* data, + struct wl_keyboard* keyboard, + uint32_t format, +@@ -297,7 +299,7 @@ static void sl_keyboard_keymap(void* data, + wl_keyboard_send_keymap(host->resource, format, fd, size); + + if (format == WL_KEYBOARD_KEYMAP_FORMAT_XKB_V1) { +- void* data = mmap(nullptr, size, PROT_READ, MAP_SHARED, fd, 0); ++ void* data = mmap(nullptr, ALIGN_POT(size, 16384), PROT_READ, MAP_SHARED, fd, 0); + + assert(data != MAP_FAILED); + +diff --git a/virtualization/virtgpu_channel.cc b/virtualization/virtgpu_channel.cc +index ff4c07cffbf4..fcfbb8c7707c 100644 +--- a/virtualization/virtgpu_channel.cc ++++ b/virtualization/virtgpu_channel.cc +@@ -617,13 +617,15 @@ int32_t VirtGpuChannel::channel_poll() { + return 0; + } + ++#define ALIGN_POT(x, pot_align) (((x) + (pot_align) - 1) & ~((pot_align) - 1)) ++ + int32_t VirtGpuChannel::create_host_blob(uint64_t blob_id, + uint64_t size, + int& out_fd) { + int32_t ret; + struct drm_virtgpu_resource_create_blob drm_rc_blob = {}; + +- drm_rc_blob.size = size; ++ drm_rc_blob.size = ALIGN_POT(size, 16384); + drm_rc_blob.blob_mem = VIRTGPU_BLOB_MEM_HOST3D; + drm_rc_blob.blob_flags = + VIRTGPU_BLOB_FLAG_USE_MAPPABLE | VIRTGPU_BLOB_FLAG_USE_SHAREABLE; +-- +2.45.1 + |