]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Fix locking problem in fmtmsg
authorUlrich Drepper <drepper@gmail.com>
Mon, 16 Jan 2012 14:03:20 +0000 (09:03 -0500)
committerUlrich Drepper <drepper@gmail.com>
Mon, 16 Jan 2012 14:03:20 +0000 (09:03 -0500)
ChangeLog
stdlib/Makefile
stdlib/bug-fmtmsg1.c [new file with mode: 0644]
stdlib/fmtmsg.c

index 00faba1ffa61b124c1e38dabbf1dc4688ae071ac..3f06b9a800ef6cd1fd20889fea42e613025c8d2a 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+2012-01-16  Ulrich Drepper  <drepper@gmail.com>
+
+       * stdlib/Makefile (tests): Add bug-fmtmsg1.
+       * stdlib/bug-fmtmsg1.c: New file.
+
+       * stdlib/fmtmsg.c (init): Add missing unlock.
+       Patch by Peng Haitao <penght@cn.fujitsu.com>.
+
 2012-01-12  Marek Polacek  <polacek@redhat.com>
 
        * libio/bits/stdio2.h: Do not define gets for ISO C11, ISO C++11,
index 04c6ac5cae0f4fcf1cb37f4c921a2e71cc51897e..f9bba3a55de4f56969bd438bdc8bdfdaa61124dd 100644 (file)
@@ -1,4 +1,4 @@
-# Copyright (C) 1991-2009, 2011 Free Software Foundation, Inc.
+# Copyright (C) 1991-2009, 2011, 2012 Free Software Foundation, Inc.
 # This file is part of the GNU C Library.
 
 # The GNU C Library is free software; you can redistribute it and/or
@@ -71,7 +71,7 @@ tests         := tst-strtol tst-strtod testmb testrand testsort testdiv   \
                   tst-atof1 tst-atof2 tst-strtod2 tst-strtod3 tst-rand48-2 \
                   tst-makecontext tst-strtod4 tst-strtod5 tst-qsort2       \
                   tst-makecontext2 tst-strtod6 tst-unsetenv1               \
-                  tst-makecontext3 bug-getcontext
+                  tst-makecontext3 bug-getcontext bug-fmtmsg1
 
 include ../Makeconfig
 
@@ -121,6 +121,7 @@ tst-strtod3-ENV = LOCPATH=$(common-objpfx)localedata
 tst-strtod4-ENV = LOCPATH=$(common-objpfx)localedata
 tst-strtod5-ENV = LOCPATH=$(common-objpfx)localedata
 testmb2-ENV = LOCPATH=$(common-objpfx)localedata
+bug-fmtmsg1-ENV = SEV_LEVEL=foo,11,newsev
 
 # Run a test on the header files we use.
 tests: $(objpfx)isomac.out
diff --git a/stdlib/bug-fmtmsg1.c b/stdlib/bug-fmtmsg1.c
new file mode 100644 (file)
index 0000000..04bfaea
--- /dev/null
@@ -0,0 +1,28 @@
+#include <fmtmsg.h>
+#include <stdio.h>
+
+
+static int
+do_test (void)
+{
+  /* Ugly, but fmtmsg would otherwise print to stderr which we do not
+     want.  */
+  fclose (stderr);
+  stderr = stdout;
+
+  int e1;
+  e1 = fmtmsg (MM_PRINT, "label:part", MM_WARNING, "text", "action", "tag");
+
+  int e2;
+  e2 = fmtmsg (MM_PRINT, "label2:part2", 11, "text2", "action2", "tag2");
+
+  addseverity (10, "additional severity");
+
+  int e3;
+  e3 = fmtmsg (MM_PRINT, "label3:part3", 10, "text3", "action3", "tag3");
+
+  return e1 != 0 || e2 != 0 || e3 != 0;
+}
+
+#define TEST_FUNCTION do_test ()
+#include "../test-skeleton.c"
index 8ee06bfd06efc40dabe04c9ca5a91416b8f1267f..d187bb21b0cb2976ebe2dc8278f50afa4dc3127e 100644 (file)
@@ -1,4 +1,5 @@
-/* Copyright (C) 1997,1999-2003,2005,2006,2011 Free Software Foundation, Inc.
+/* Copyright (C) 1997,1999-2003,2005,2006,2011,2012
+   Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -280,6 +281,8 @@ init (void)
 
          sevlevel_var = end + (*end == ':' ? 1 : 0);
        }
+
+      __libc_lock_unlock (lock);
     }
 }