]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
Backport r246730
authorMartin Liska <mliska@suse.cz>
Mon, 29 May 2017 09:09:07 +0000 (11:09 +0200)
committerMartin Liska <marxin@gcc.gnu.org>
Mon, 29 May 2017 09:09:07 +0000 (09:09 +0000)
2017-05-29  Martin Liska  <mliska@suse.cz>

Backport from mainline
2017-04-06  Martin Liska  <mliska@suse.cz>

PR sanitizer/80166
* gcc.dg/asan/pr80166.c: New test.
2017-05-29  Martin Liska  <mliska@suse.cz>

Backport from mainline
2017-04-06  Martin Liska  <mliska@suse.cz>

PR sanitizer/80166
* sanitizer_common/sanitizer_common_interceptors.inc (INTERCEPTOR):
Cherry-pick upstream r299036.

From-SVN: r248560

gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/asan/pr80166.c [new file with mode: 0644]
libsanitizer/ChangeLog
libsanitizer/sanitizer_common/sanitizer_common_interceptors.inc

index 28d6920aae9c56533ceef813e4ca7c9856a6b99e..a213ab59f4b1d808880822525cb5e721cc426af9 100644 (file)
@@ -1,3 +1,11 @@
+2017-05-29  Martin Liska  <mliska@suse.cz>
+
+       Backport from mainline
+       2017-04-06  Martin Liska  <mliska@suse.cz>
+
+       PR sanitizer/80166
+       * gcc.dg/asan/pr80166.c: New test.
+
 2017-05-29  Martin Liska  <mliska@suse.cz>
 
        Backport from mainline
diff --git a/gcc/testsuite/gcc.dg/asan/pr80166.c b/gcc/testsuite/gcc.dg/asan/pr80166.c
new file mode 100644 (file)
index 0000000..629dd23
--- /dev/null
@@ -0,0 +1,24 @@
+/* PR sanitizer/80166 */
+/* { dg-do run } */
+
+#include <sys/types.h>
+#include <unistd.h>
+
+int
+main (int argc, char **argv)
+{
+  gid_t groups;
+  int r = getgroups (0, &groups);
+  if (r < 0)
+    __builtin_abort ();
+
+  r = getgroups (-1, &groups);
+  if (r != -1)
+    __builtin_abort ();
+
+  r = getgroups (-1, NULL);
+  if (r != -1)
+    __builtin_abort ();
+
+  return 0;
+}
index 00af6a47885f5a49a0095fa07460417a66cbf8c8..cf0bb56e5fee050e7a2a8884f4e61308ddff4b9c 100644 (file)
@@ -1,3 +1,12 @@
+2017-05-29  Martin Liska  <mliska@suse.cz>
+
+       Backport from mainline
+       2017-04-06  Martin Liska  <mliska@suse.cz>
+
+       PR sanitizer/80166
+       * sanitizer_common/sanitizer_common_interceptors.inc (INTERCEPTOR):
+       Cherry-pick upstream r299036.
+
 2017-02-17  Andreas Tobler  <andreast@gcc.gnu.org>
 
        Backported from mainline
index 10f321838e82b097194b65a45372c79b0022f4e6..5a30498ff053c2bc80edabd0b4af23ff25a19372 100644 (file)
@@ -2733,7 +2733,8 @@ INTERCEPTOR(int, getgroups, int size, u32 *lst) {
   // its metadata. See
   // https://code.google.com/p/address-sanitizer/issues/detail?id=321.
   int res = REAL(getgroups)(size, lst);
-  if (res && lst) COMMON_INTERCEPTOR_WRITE_RANGE(ctx, lst, res * sizeof(*lst));
+  if (res >= 0 && lst && size > 0)
+    COMMON_INTERCEPTOR_WRITE_RANGE(ctx, lst, res * sizeof(*lst));
   return res;
 }
 #define INIT_GETGROUPS COMMON_INTERCEPT_FUNCTION(getgroups);