Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
Fix locking problem in fmtmsg
  • Loading branch information
Ulrich Drepper committed Jan 16, 2012
1 parent e0a309c commit 400aa02
Show file tree
Hide file tree
Showing 4 changed files with 43 additions and 3 deletions.
8 changes: 8 additions & 0 deletions 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,
Expand Down
5 changes: 3 additions & 2 deletions stdlib/Makefile
@@ -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
Expand Down Expand Up @@ -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

Expand Down Expand Up @@ -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
Expand Down
28 changes: 28 additions & 0 deletions stdlib/bug-fmtmsg1.c
@@ -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"
5 changes: 4 additions & 1 deletion stdlib/fmtmsg.c
@@ -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.
Expand Down Expand Up @@ -280,6 +281,8 @@ init (void)

sevlevel_var = end + (*end == ':' ? 1 : 0);
}

__libc_lock_unlock (lock);
}
}

Expand Down

0 comments on commit 400aa02

Please sign in to comment.