+1998-01-31 20:52 Ulrich Drepper <drepper@cygnus.com>
+
+ * nscd/grpcache.c (cache_grpinit): Let calloc do the multiplication.
+
+ * nscd/pwdcache.c (cache_pwdinit): Use thread attribute to detach
+ thread and no pthread_detach.
+
+ * nscd/nscd.c: Rewrite to use argp instead of getopt.
+
1998-01-31 Phil Blundell <philb@gnu.org>
* configure.in: Add --without-cvs option to suppress automatic
checkin of regenerated files.
- * config.make: Likewise.
+ * config.make.in: Likewise.
* Makefile: Respect with-cvs setting.
* Makerules: Likewise.
were used on my Linux libc5 based system. Why?
2.10. I have set up /etc/nis.conf, and the Linux libc 5 with NYS
works great. But the glibc NIS+ doesn't seem to work.
-2.11. After installing glibc name resolving doesn't work properly.
-2.12. I have /usr/include/net and /usr/include/scsi as symlinks
+2.11. I have killed ypbind to stop using NIS, but glibc will
+ continue using NIS.
+2.12. After installing glibc name resolving doesn't work properly.
+2.13. I have /usr/include/net and /usr/include/scsi as symlinks
into my Linux source tree. Is that wrong?
-2.13. Programs like `logname', `top', `uptime' `users', `w' and
+2.14. Programs like `logname', `top', `uptime' `users', `w' and
`who', show incorrect information about the (number of)
users on my system. Why?
-2.14. After upgrading to glibc 2.1 with symbol versioning I get
+2.15. After upgrading to glibc 2.1 with symbol versioning I get
errors about undefined symbols. What went wrong?
-2.15. When I start the program XXX after upgrading the library
+2.16. When I start the program XXX after upgrading the library
I get
XXX: Symbol `_sys_errlist' has different size in shared
object, consider re-linking
http://www-vt.uni-paderborn.de/~kukuk/linux/nisplus.html).
-2.11. After installing glibc name resolving doesn't work properly.
+2.11. I have killed ypbind to stop using NIS, but glibc will
+ continue using NIS.
+
+{TK} For faster NIS lookups, glibc uses the /var/yp/binding/ files
+from ypbind. ypbind 3.3 and older versions don't always remove these
+files, so glibc will use them furthermore. Other BSD versions seem to
+work correct. Until ypbind 3.4 is released, you can find a patch at
+ftp://ftp.kernel.org/pub/linux/utils/net/NIS/ypbind-3.3-glibc2.diff.
+
+
+2.12. After installing glibc name resolving doesn't work properly.
{AJ} You probably should read the manual section describing
nsswitch.conf (just type `info libc "NSS Configuration File"').
The NSS configuration file is usually the culprit.
-2.12. I have /usr/include/net and /usr/include/scsi as symlinks
+2.13. I have /usr/include/net and /usr/include/scsi as symlinks
into my Linux source tree. Is that wrong?
{PB} This was necessary for libc5, but is not correct when using
/usr/include/asm and /usr/include/linux should remain as they were.
-2.13. Programs like `logname', `top', `uptime' `users', `w' and
+2.14. Programs like `logname', `top', `uptime' `users', `w' and
`who', show incorrect information about the (number of)
users on my system. Why?
{MK} See question 3.2.
-2.14. After upgrading to glibc 2.1 with symbol versioning I get
+2.15. After upgrading to glibc 2.1 with symbol versioning I get
errors about undefined symbols. What went wrong?
{AJ} The problem is caused either by wrong program code or tools. In
with symbol versioning.
-2.15. When I start the program XXX after upgrading the library
+2.16. When I start the program XXX after upgrading the library
I get
XXX: Symbol `_sys_errlist' has different size in shared
object, consider re-linking
it with nisinit from the nis-tools package (available at
http://www-vt.uni-paderborn.de/~kukuk/linux/nisplus.html).
+?? I have killed ypbind to stop using NIS, but glibc will
+ continue using NIS.
+
+{TK} For faster NIS lookups, glibc uses the /var/yp/binding/ files
+from ypbind. ypbind 3.3 and older versions don't always remove these
+files, so glibc will use them furthermore. Other BSD versions seem to
+work correct. Until ypbind 3.4 is released, you can find a patch at
+ftp://ftp.kernel.org/pub/linux/utils/net/NIS/ypbind-3.3-glibc2.diff.
+
?? After installing glibc name resolving doesn't work properly.
{AJ} You probably should read the manual section describing
.PHONY: all
all: lib others
\f
+ifeq ($(with-cvs),yes)
define autoconf-it
@-rm -f $@.new
autoconf $(ACFLAGS) $< > $@.new
mv -f $@.new $@
test ! -d CVS || cvs $(CVSOPTS) commit -m'Regenerated: autoconf $(ACFLAGS) $<' $@
endef
+else
+define autoconf-it
+@-rm -f $@.new
+autoconf $(ACFLAGS) $< > $@.new
+chmod a-w,a+x $@.new
+mv -f $@.new $@
+endef
+endif
configure: configure.in aclocal.m4; $(autoconf-it)
%/configure: %/configure.in aclocal.m4; $(autoconf-it)
# So I don't edit them by mistake.
chmod a-w $@-tmp
mv -f $@-tmp $@
+ifeq ($(with-cvs),yes)
test ! -d CVS || cvs $(CVSOPTS) commit -m'Updated from $^' $@
endif
endif
+endif
elf = @elf@
have-initfini = @libc_cv_have_initfini@
need-nopic-initfini = @nopic_initfini@
+with-cvs = @with_cvs@
versioning = @VERSIONING@
AC_ARG_WITH(elf, dnl
--with-elf if using the ELF object format,
elf=$withval, elf=no)
+AC_ARG_WITH(cvs, dnl
+[ --without-cvs if CVS should not be used],
+ with_cvs=$withval, with_cvs=yes)
+AC_SUBST(with_cvs)
AC_ARG_ENABLE(libio, dnl
[ --enable-libio build in GNU libio instead of GNU stdio],
### platforms.
###
if test -z "$enable_hacker_mode"; then
- case "$host_os" in
- linux* | gnu*)
+ case "$machine-$host_os" in
+ *-linux* | *-gnu* | arm*-none*)
;;
*)
echo "*** The GNU C library is currently not available for this platform."
pthread_attr_t attr;
pthread_t thread;
- grptbl = calloc (1, modulo * sizeof (grphash));
+ grptbl = calloc (modulo, sizeof (grphash));
if (grptbl == NULL)
return -1;
- calloc (1, modulo * sizeof (grphash));
+ calloc (modulo, sizeof (grphash));
if (gidtbl == NULL)
return -1;
- negtbl = calloc (1, modulo * sizeof (neghash));
+ negtbl = calloc (modulo, sizeof (neghash));
if (negtbl == NULL)
return -1;
/* nscd - Name Service Cache Daemon. Caches passwd and group. */
+#include <argp.h>
#include <errno.h>
-#include <getopt.h>
+#include <error.h>
#include <libintl.h>
#include <locale.h>
#include <pthread.h>
int do_shutdown = 0;
int disabled_passwd = 0;
int disabled_group = 0;
+int go_background = 1;
+const char *conffile = _PATH_NSCDCONF;
static void termination_handler (int signum);
static int check_pid (const char *file);
static int write_pid (const char *file);
-static void usage (int status) __attribute__ ((noreturn));
static void handle_requests (void);
+/* Name and version of program. */
+static void print_version (FILE *stream, struct argp_state *state);
+void (*argp_program_version_hook) (FILE *, struct argp_state *) = print_version;
+
+/* Definitions of arguments for argp functions. */
+static const struct argp_option options[] =
+{
+ { "config-file", 'f', N_("NAME"), 0,
+ N_("Read configuration data from NAME") },
+ { "debug", 'd', NULL, 0,
+ N_("Do not fork and display messages on the current tty") },
+ { "shutdown", 'K', NULL, 0, N_("Shut the server down") },
+ { NULL, 0, NULL, 0, NULL }
+};
+
+/* Short description of program. */
+static const char doc[] = N_("Name Switch Cache Daemon.");
+
+/* Prototype for option handler. */
+static error_t parse_opt __P ((int key, char *arg, struct argp_state *state));
+
+/* Data structure to communicate with argp functions. */
+static struct argp argp =
+{
+ options, parse_opt, NULL, doc,
+};
+
int
main (int argc, char **argv)
{
- int go_background = 1;
- const char *conffile = _PATH_NSCDCONF;
+ int remaining;
/* Set locale via LC_ALL. */
setlocale (LC_ALL, "");
/* Set the text message domain. */
textdomain (PACKAGE);
- while (1)
+ /* Parse and process arguments. */
+ argp_parse (&argp, argc, argv, 0, &remaining, NULL);
+
+ if (remaining != 0)
{
- int c;
- int option_index = 0;
- static struct option long_options[] = {
- { "debug", no_argument, NULL, 'd' },
- { "help", no_argument, NULL, 'h' },
- { "version", no_argument, NULL, 'V' },
- { "shutdown", no_argument, NULL, 'K' },
- {NULL, 0, NULL, '\0'}
- };
-
- c = getopt_long (argc, argv, "df:ghKV", long_options, &option_index);
- if (c == (-1))
- break;
- switch (c)
- {
- case 'd':
- debug_flag = 1;
- go_background = 0;
- break;
- case 'f':
- conffile = optarg;
- break;
- case 'h':
- usage (EXIT_SUCCESS);
- break;
- case 'K':
- if (getuid () != 0)
- {
- printf (_("Only root is allowed to use this option!\n\n"));
- usage (EXIT_FAILURE);
- }
- {
- int sock = __nscd_open_socket ();
- request_header req;
- ssize_t nbytes;
-
- if (sock == -1)
- exit (EXIT_FAILURE);
-
- req.version = NSCD_VERSION;
- req.type = SHUTDOWN;
- req.key_len = 0;
- nbytes = write (sock, &req, sizeof (request_header));
- close (sock);
- if (nbytes != req.key_len)
- exit (EXIT_FAILURE);
- else
- exit (EXIT_SUCCESS);
- }
- case 'g':
- print_stat ();
- exit (EXIT_SUCCESS);
- case 'V':
- printf ("nscd (GNU %s) %s\n", PACKAGE, VERSION);
- printf (_("\
-Copyright (C) %s Free Software Foundation, Inc.\n\
-This is free software; see the source for copying conditions. There is NO\n\
-warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\
-"), "1998");
- printf (_("Written by %s.\n"), "Thorsten Kukuk");
- exit (EXIT_SUCCESS);
- default:
- usage (EXIT_FAILURE);
- }
+ error (0, 0, gettext ("wrong number of arguments"));
+ argp_help (&argp, stdout, ARGP_HELP_SEE, program_invocation_short_name);
+ exit (EXIT_FAILURE);
}
signal (SIGINT, termination_handler);
return 0;
}
+
+/* Handle program arguments. */
+static error_t
+parse_opt (int key, char *arg, struct argp_state *state)
+{
+ switch (key)
+ {
+ case 'd':
+ debug_flag = 1;
+ go_background = 0;
+ break;
+ case 'f':
+ conffile = arg;
+ break;
+ case 'K':
+ if (getuid () != 0)
+ {
+ printf (_("Only root is allowed to use this option!\n\n"));
+ exit (EXIT_FAILURE);
+ }
+ {
+ int sock = __nscd_open_socket ();
+ request_header req;
+ ssize_t nbytes;
+
+ if (sock == -1)
+ exit (EXIT_FAILURE);
+
+ req.version = NSCD_VERSION;
+ req.type = SHUTDOWN;
+ req.key_len = 0;
+ nbytes = write (sock, &req, sizeof (request_header));
+ close (sock);
+ if (nbytes != req.key_len)
+ exit (EXIT_FAILURE);
+ else
+ exit (EXIT_SUCCESS);
+ }
+ case 'g':
+ print_stat ();
+ exit (EXIT_SUCCESS);
+ default:
+ return ARGP_ERR_UNKNOWN;
+ }
+ return 0;
+}
+
+/* Print the version information. */
+static void
+print_version (FILE *stream, struct argp_state *state)
+{
+ fprintf (stream, "nscd (GNU %s) %s\n", PACKAGE, VERSION);
+ fprintf (stream, gettext ("\
+Copyright (C) %s Free Software Foundation, Inc.\n\
+This is free software; see the source for copying conditions. There is NO\n\
+warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\
+"), "1998");
+ fprintf (stream, gettext ("Written by %s.\n"), "Thorsten Kukuk");
+}
+
+
/* Create a socket connected to a name. */
int
__nscd_open_socket (void)
exit (EXIT_SUCCESS);
}
-/* Display usage information and exit. */
-static void
-usage (int status)
-{
- if (status != EXIT_SUCCESS)
- fprintf (stderr, _("Try `%s --help' for more information.\n"),
- program_invocation_name);
- else
- {
- printf (_("\
-Usage: %s [OPTION]...\n\
- -d, --debug do not fork and display messages on the current tty\n\
- -h, --help display this help and exit\n\
- -V, --version output version information and exit\n\
- -f configuration-file read configuration data from the specified file.\n\
- -K, --shutdown shut the server down.\n\
- -g Prints configuration and statistics to stdout.\n"),
- program_invocation_name);
- fputs (_("\
-Report bugs using the `glibcbug' script to <bugs@gnu.org>.\n"),
- stdout);
- }
- exit (status);
-}
-
/* Returns 1 if the process in pid file FILE is running, 0 if not. */
static int
check_pid (const char *file)
int
cache_pwdinit ()
{
+ pthread_attr_t attr;
pthread_t thread;
pwdtbl = calloc (modulo, sizeof (pwdhash));
if (negtbl == NULL)
return -1;
- pthread_create (&thread, NULL, pwdtable_update, (void *)NULL);
- pthread_detach (thread);
- pthread_create (&thread, NULL, negtable_update, (void *)NULL);
- pthread_detach (thread);
+ pthread_attr_init (&attr);
+ pthread_attr_setdetachstate (&attr, PTHREAD_CREATE_DETACHED);
+
+ pthread_create (&thread, NULL, pwdtable_update, &attr);
+ pthread_create (&thread, NULL, negtable_update, &attr);
+
+ pthread_attr_destroy (&attr);
+
return 0;
}
The files
zic.c zdump.c ialloc.c scheck.c tzfile.h
private.h tzselect.ksh checktab.awk
-come from the tzcode1997h package by Arthur David Olson et.al.
+come from the tzcode1998b package by Arthur David Olson et.al.
The files
africa antarctica asia australasia europe
northamerica southamerica pacificnew etcetera factory
backward systemv solar87 solar88 solar89
iso3166.tab zone.tab leapseconds yearistype
-come from the tzdata1997j package by Arthur David Olson et.al.
+come from the tzdata1998b package by Arthur David Olson et.al.
These packages may be found at ftp://elsie.nci.nih.gov/pub/. Commentary
should be addressed to tz@elsie.nci.nih.gov.