2004-03-09 Ulrich Drepper <drepper@redhat.com>
+ * iconv/gconv_db.c: Don't define lock as static. Rename to
+ __gconv_lock and export from the file.
+ * iconv/gconv_int.h: Declare __gconv_lock.
+ * libio/iofclose.c [_LIBC] (_IO_new_fclose): Lock gconv lock
+ before __gconv_release_step calls.
+ Patch by Shunichi Sagawa <s-sagawa@jp.fujitsu.com>.
+
+ * iconv/gconv_simple.c (internal_ucs4_loop): Fix typo in last change.
+
+ * iconv/gconv_db.c
+
* posix/Makefile (tests): Add tst-vfork1.
* posix/tst-vfork1.c: New file.
/* Provide access to the collection of available transformation modules.
- Copyright (C) 1997,98,99,2000,2001,2002,2003 Free Software Foundation, Inc.
+ Copyright (C) 1997-2003, 2004 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
struct gconv_module *__gconv_modules_db;
/* We modify global data. */
-__libc_lock_define_initialized (static, lock)
+__libc_lock_define_initialized (, __gconv_lock)
/* Provide access to module database. */
__libc_once (once, __gconv_read_conf);
/* Acquire the lock. */
- __libc_lock_lock (lock);
+ __libc_lock_lock (__gconv_lock);
result = __gconv_lookup_cache (toset, fromset, handle, nsteps, flags);
if (result != __GCONV_NODB)
{
/* We have a cache and could resolve the request, successful or not. */
- __libc_lock_unlock (lock);
+ __libc_lock_unlock (__gconv_lock);
return result;
}
/* If we don't have a module database return with an error. */
if (__gconv_modules_db == NULL)
{
- __libc_lock_unlock (lock);
+ __libc_lock_unlock (__gconv_lock);
return __GCONV_NOCONV;
}
&& strcmp (toset_expand, fromset_expand) == 0)))))
{
/* Both character sets are the same. */
- __libc_lock_unlock (lock);
+ __libc_lock_unlock (__gconv_lock);
return __GCONV_NOCONV;
}
handle, nsteps);
/* Release the lock. */
- __libc_lock_unlock (lock);
+ __libc_lock_unlock (__gconv_lock);
/* The following code is necessary since `find_derivation' will return
GCONV_OK even when no derivation was found but the same request
size_t cnt;
/* Acquire the lock. */
- __libc_lock_lock (lock);
+ __libc_lock_lock (__gconv_lock);
#ifndef STATIC_GCONV
cnt = nsteps;
__gconv_release_cache (steps, nsteps);
/* Release the lock. */
- __libc_lock_unlock (lock);
+ __libc_lock_unlock (__gconv_lock);
return result;
}
-/* Copyright (C) 1997-2002, 2003 Free Software Foundation, Inc.
+/* Copyright (C) 1997-2002, 2003, 2004 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
#include "gconv.h"
#include <stdlib.h> /* For alloca used in macro below. */
+#include <bits/libc-lock.h>
__BEGIN_DECLS
/* Value of the GCONV_PATH environment variable. */
extern const char *__gconv_path_envvar attribute_hidden;
+/* Lock for the conversion database content. */
+__libc_lock_define (extern, __gconv_lock);
+
/* The gconv functions expects the name to be in upper case and complete,
including the trailing slashes if necessary. */
-/* Copyright (C) 1993,1995,1997-2001,2002,2003 Free Software Foundation, Inc.
+/* Copyright (C) 1993,1995,1997-2003,2004 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
the conversion functions. */
struct _IO_codecvt *cc = fp->_codecvt;
+ __libc_lock_lock (__gconv_lock);
__gconv_release_step (cc->__cd_in.__cd.__steps);
__gconv_release_step (cc->__cd_out.__cd.__steps);
+ __libc_lock_unlock (__gconv_lock);
#endif
}
else