Added missing fixes on U_bsc1217765-Xi-allocate-enough-XkbActions-for-our-buttons.patch.
OBS-URL: https://build.opensuse.org/package/show/X11:XOrg/xwayland?expand=0&rev=66
This commit is contained in:
parent
d2072e0686
commit
52070dd5da
@ -14,37 +14,33 @@ CVE-2023-6377, ZDI-CAN-22412, ZDI-CAN-22413
|
|||||||
This vulnerability was discovered by:
|
This vulnerability was discovered by:
|
||||||
Jan-Niklas Sohn working with Trend Micro Zero Day Initiative
|
Jan-Niklas Sohn working with Trend Micro Zero Day Initiative
|
||||||
---
|
---
|
||||||
Xi/exevents.c | 8 ++++++--
|
Xi/exevents.c | 12 ++++++------
|
||||||
dix/devices.c | 11 +++++++++++
|
dix/devices.c | 10 ++++++++++
|
||||||
2 files changed, 17 insertions(+), 2 deletions(-)
|
2 files changed, 16 insertions(+), 6 deletions(-)
|
||||||
|
--- a/Xi/exevents.c
|
||||||
diff --git a/Xi/exevents.c b/Xi/exevents.c
|
+++ a/Xi/exevents.c
|
||||||
index dcd4efb3bc..f24de9eec4 100644
|
@@ -611,13 +611,13 @@ DeepCopyPointerClasses(DeviceIntPtr from, DeviceIntPtr to)
|
||||||
--- a/Xi/exevents.c
|
}
|
||||||
+++ b/Xi/exevents.c
|
|
||||||
@@ -612,12 +612,16 @@ DeepCopyPointerClasses(DeviceIntPtr from, DeviceIntPtr to)
|
|
||||||
|
|
||||||
if (from->button->xkb_acts) {
|
if (from->button->xkb_acts) {
|
||||||
if (!to->button->xkb_acts) {
|
- if (!to->button->xkb_acts) {
|
||||||
- to->button->xkb_acts = calloc(1, sizeof(XkbAction));
|
- to->button->xkb_acts = calloc(1, sizeof(XkbAction));
|
||||||
+ to->button->xkb_acts = calloc(from->button->numButtons, sizeof(XkbAction));
|
- if (!to->button->xkb_acts)
|
||||||
if (!to->button->xkb_acts)
|
- FatalError("[Xi] not enough memory for xkb_acts.\n");
|
||||||
FatalError("[Xi] not enough memory for xkb_acts.\n");
|
- }
|
||||||
+ } else {
|
+ size_t maxbuttons = max(to->button->numButtons, from->button->numButtons);
|
||||||
+ to->button->xkb_acts = xnfreallocarray(to->button->xkb_acts,
|
+ to->button->xkb_acts = xnfreallocarray(to->button->xkb_acts,
|
||||||
+ from->button->numButtons,
|
+ maxbuttons,
|
||||||
+ sizeof(XkbAction));
|
+ sizeof(XkbAction));
|
||||||
}
|
+ memset(to->button->xkb_acts, 0, maxbuttons * sizeof(XkbAction));
|
||||||
memcpy(to->button->xkb_acts, from->button->xkb_acts,
|
memcpy(to->button->xkb_acts, from->button->xkb_acts,
|
||||||
- sizeof(XkbAction));
|
- sizeof(XkbAction));
|
||||||
+ from->button->numButtons * sizeof(XkbAction));
|
+ from->button->numButtons * sizeof(XkbAction));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
free(to->button->xkb_acts);
|
free(to->button->xkb_acts);
|
||||||
diff --git a/dix/devices.c b/dix/devices.c
|
--- a/dix/devices.c
|
||||||
index 7150734a58..deb3010206 100644
|
+++ a/dix/devices.c
|
||||||
--- a/dix/devices.c
|
|
||||||
+++ b/dix/devices.c
|
|
||||||
@@ -2530,6 +2530,8 @@ RecalculateMasterButtons(DeviceIntPtr slave)
|
@@ -2530,6 +2530,8 @@ RecalculateMasterButtons(DeviceIntPtr slave)
|
||||||
|
|
||||||
if (master->button && master->button->numButtons != maxbuttons) {
|
if (master->button && master->button->numButtons != maxbuttons) {
|
||||||
@ -54,7 +50,7 @@ index 7150734a58..deb3010206 100644
|
|||||||
DeviceChangedEvent event = {
|
DeviceChangedEvent event = {
|
||||||
.header = ET_Internal,
|
.header = ET_Internal,
|
||||||
.type = ET_DeviceChanged,
|
.type = ET_DeviceChanged,
|
||||||
@@ -2540,6 +2542,15 @@ RecalculateMasterButtons(DeviceIntPtr slave)
|
@@ -2540,6 +2542,14 @@ RecalculateMasterButtons(DeviceIntPtr slave)
|
||||||
};
|
};
|
||||||
|
|
||||||
master->button->numButtons = maxbuttons;
|
master->button->numButtons = maxbuttons;
|
||||||
@ -66,10 +62,7 @@ index 7150734a58..deb3010206 100644
|
|||||||
+ 0,
|
+ 0,
|
||||||
+ (maxbuttons - last_num_buttons) * sizeof(XkbAction));
|
+ (maxbuttons - last_num_buttons) * sizeof(XkbAction));
|
||||||
+ }
|
+ }
|
||||||
+
|
|
||||||
|
|
||||||
memcpy(&event.buttons.names, master->button->labels, maxbuttons *
|
memcpy(&event.buttons.names, master->button->labels, maxbuttons *
|
||||||
sizeof(Atom));
|
sizeof(Atom));
|
||||||
--
|
--
|
||||||
2.43.0
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user