summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTor Lillqvist <tml@iki.fi>2010-09-09 15:44:12 +0300
committerTor Lillqvist <tml@iki.fi>2010-09-09 15:44:12 +0300
commite7483343275e6ac4c402b84d99635d1ef8ed86be (patch)
tree0593be7f772c55697f408f6e654d2505dc6ef852
parent7464a9ca0847c75f577f2200b9b2bab28bc01111 (diff)
downloadgtk+-e7483343275e6ac4c402b84d99635d1ef8ed86be.tar.gz
Avoid potential DLL hijacking in Wintab code
Load Wintab32.dll from an absolute path. A proper Wintab32.dll, if present, should be in the Windows system directory, so load it from there.
-rw-r--r--gdk/win32/gdkdevicemanager-win32.c25
1 files changed, 24 insertions, 1 deletions
diff --git a/gdk/win32/gdkdevicemanager-win32.c b/gdk/win32/gdkdevicemanager-win32.c
index e3696bbf6f..f0fddb1b53 100644
--- a/gdk/win32/gdkdevicemanager-win32.c
+++ b/gdk/win32/gdkdevicemanager-win32.c
@@ -33,6 +33,8 @@
#include <windows.h>
#include <wintab.h>
+#define WINTAB32_DLL "Wintab32.dll"
+
#define PACKETDATA (PK_CONTEXT | PK_CURSOR | PK_BUTTONS | PK_X | PK_Y | PK_NORMAL_PRESSURE | PK_ORIENTATION)
/* We want everything in absolute mode */
#define PACKETMODE (0)
@@ -376,6 +378,9 @@ _gdk_input_wintab_init_check (GdkDeviceManagerWin32 *device_manager)
gchar *devname_utf8, *csrname_utf8, *device_name;
BOOL defcontext_done;
HMODULE wintab32;
+ char *wintab32_dll_path;
+ char dummy;
+ int n, k;
if (wintab_initialized)
return;
@@ -387,7 +392,25 @@ _gdk_input_wintab_init_check (GdkDeviceManagerWin32 *device_manager)
if (_gdk_input_ignore_wintab)
return;
- if ((wintab32 = LoadLibrary ("wintab32.dll")) == NULL)
+ n = GetSystemDirectory (&dummy, 0);
+
+ if (n <= 0)
+ return;
+
+ wintab32_dll_path = g_malloc (n + 1 + strlen (WINTAB32_DLL));
+ k = GetSystemDirectory (wintab32_dll_path, n);
+
+ if (k == 0 || k > n)
+ {
+ g_free (wintab32_dll_path);
+ return;
+ }
+
+ if (!G_IS_DIR_SEPARATOR (wintab32_dll_path[strlen (wintab32_dll_path) -1]))
+ strcat (wintab32_dll_path, G_DIR_SEPARATOR_S);
+ strcat (wintab32_dll_path, WINTAB32_DLL);
+
+ if ((wintab32 = LoadLibrary (wintab32_dll_path)) == NULL)
return;
if ((p_WTInfoA = (t_WTInfoA) GetProcAddress (wintab32, "WTInfoA")) == NULL)