summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Hutterer <peter.hutterer@who-t.net>2009-07-07 16:46:22 +1000
committerPeter Hutterer <peter.hutterer@who-t.net>2009-07-08 13:42:50 +1000
commit225071e2e67fb65a0258397212f9826c9b25e078 (patch)
tree2b39c830bc95f911f52092749b99e24f3a0d5c22
parent55157345c261653160e0f55841dcb32910ae4106 (diff)
Split copy_classes and size_classes to avoid memory leak
The switch to cookie events introduced a memory leak in XIDeviceChangedEvents. Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
-rw-r--r--src/XExtInt.c38
-rw-r--r--src/XIQueryDevice.c3
2 files changed, 26 insertions, 15 deletions
diff --git a/src/XExtInt.c b/src/XExtInt.c
index 8851f65..0724e4a 100644
--- a/src/XExtInt.c
+++ b/src/XExtInt.c
@@ -101,6 +101,7 @@ extern int _XiGetDevicePresenceNotifyEvent(
);
int copy_classes(XIDeviceInfo *to, xXIAnyInfo* from, int nclasses);
+int size_classes(xXIAnyInfo* from, int nclasses);
int sizeDeviceClassType(int type, int num_elements);
@@ -1322,22 +1323,13 @@ wireToDeviceEvent(xXIDeviceEvent *in, XGenericEventCookie* cookie)
return 1;
}
-/* Copy classes from any into to->classes and return the number of bytes
- * copied. Memory layout of to->classes is
- * [clsptr][clsptr][clsptr][classinfo][classinfo]...
- * |________|___________^
- * |______________________^
- */
int
-copy_classes(XIDeviceInfo* to, xXIAnyInfo* from, int nclasses)
+size_classes(xXIAnyInfo* from, int nclasses)
{
- XIAnyClassInfo *any_lib;
+ int len, i;
xXIAnyInfo *any_wire;
- void *ptr_lib;
char *ptr_wire;
- int i, len;
- /* size them up first */
len = nclasses * sizeof(XIAnyClassInfo*); /* len for to->classes */
ptr_wire = (char*)from;
for (i = 0; i < nclasses; i++)
@@ -1363,7 +1355,24 @@ copy_classes(XIDeviceInfo* to, xXIAnyInfo* from, int nclasses)
ptr_wire += any_wire->length * 4;
}
- to->classes = Xmalloc(len);
+ return len;
+}
+
+/* Copy classes from any into to->classes and return the number of bytes
+ * copied. Memory layout of to->classes is
+ * [clsptr][clsptr][clsptr][classinfo][classinfo]...
+ * |________|___________^
+ * |______________________^
+ */
+int
+copy_classes(XIDeviceInfo* to, xXIAnyInfo* from, int nclasses)
+{
+ XIAnyClassInfo *any_lib;
+ xXIAnyInfo *any_wire;
+ void *ptr_lib;
+ char *ptr_wire;
+ int i, len;
+
if (!to->classes)
return -1;
@@ -1455,7 +1464,7 @@ wireToDeviceChangedEvent(xXIDeviceChangedEvent *in, XGenericEventCookie *cookie)
XIDeviceInfo info;
int len;
- len = copy_classes(&info, (xXIAnyInfo*)&in[1], in->num_classes);
+ len = size_classes((xXIAnyInfo*)&in[1], in->num_classes);
cookie->data = out = malloc(sizeof(XIDeviceChangedEvent) + len);
@@ -1469,7 +1478,8 @@ wireToDeviceChangedEvent(xXIDeviceChangedEvent *in, XGenericEventCookie *cookie)
out->num_classes = in->num_classes;
out->classes = (XIAnyClassInfo**)&out[1];
- memcpy(out->classes, info.classes, len);
+
+ copy_classes(&info, (xXIAnyInfo*)&in[1], in->num_classes);
return 1;
}
diff --git a/src/XIQueryDevice.c b/src/XIQueryDevice.c
index ec4e601..34c38cb 100644
--- a/src/XIQueryDevice.c
+++ b/src/XIQueryDevice.c
@@ -30,7 +30,7 @@
#include "XIint.h"
extern int copy_classes(XIDeviceInfo* to, xXIAnyInfo* from, int nclasses);
-extern int sizeDeviceClassType(int type, int num_elements);
+extern int size_classes(xXIAnyInfo* from, int nclasses);
XIDeviceInfo*
XIQueryDevice(Display *dpy, int deviceid, int *ndevices_return)
@@ -86,6 +86,7 @@ XIQueryDevice(Display *dpy, int deviceid, int *ndevices_return)
strncpy(lib->name, ptr, wire->name_len);
ptr += ((wire->name_len + 3)/4) * 4;
+ lib->classes = Xmalloc(size_classes((xXIAnyInfo*)ptr, lib->num_classes));
ptr += copy_classes(lib, (xXIAnyInfo*)ptr, lib->num_classes);
}