diff options
author | Peter Hutterer <peter.hutterer@who-t.net> | 2009-07-07 16:46:22 +1000 |
---|---|---|
committer | Peter Hutterer <peter.hutterer@who-t.net> | 2009-07-08 13:42:50 +1000 |
commit | 225071e2e67fb65a0258397212f9826c9b25e078 (patch) | |
tree | 2b39c830bc95f911f52092749b99e24f3a0d5c22 | |
parent | 55157345c261653160e0f55841dcb32910ae4106 (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.c | 38 | ||||
-rw-r--r-- | src/XIQueryDevice.c | 3 |
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); } |