1 commit de4ec145ea88253dc469ee81f094fa73de36b773
2 Author: Lars-Peter Clausen <lars@metafoo.de>
3 Date: Sun Feb 1 16:54:55 2009 +0100
5 Call xf86DeleteInput in UnInit or if something goes wrong in the Init procedure.
6 If xf86DeleteInput is not called the server will end up with corrupted memory.
8 diff --git a/src/tslib.c b/src/tslib.c
9 index ad43abb..3eba078 100644
12 @@ -271,6 +271,7 @@ xf86TslibUninit(InputDriverPtr drv, InputInfoPtr pInfo, int flags)
14 xf86TslibControlProc(pInfo->dev, DEVICE_OFF);
15 xfree(pInfo->private);
16 + xf86DeleteInput(pInfo, 0);
20 @@ -347,15 +348,17 @@ xf86TslibInit(InputDriverPtr drv, IDevPtr dev, int flags)
21 s = xf86SetStrOption(pInfo->options, "Device", NULL);
23 priv->ts = ts_open(s, 0);
27 ErrorF("ts_open failed (device=%s)\n",s);
28 + xf86DeleteInput(pInfo, 0);
34 if (ts_config(priv->ts)) {
35 ErrorF("ts_config failed\n");
36 + xf86DeleteInput(pInfo, 0);