about summary refs log tree commit diff
path: root/misc/fstab.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>1998-02-26 11:20:59 +0000
committerUlrich Drepper <drepper@redhat.com>1998-02-26 11:20:59 +0000
commitd111572f2f7c595060b9bafcadba98d5391d464c (patch)
tree6ede0af6714c7586d9f52caa90118ef6af4b21e0 /misc/fstab.c
parent14e9dd679a43ef9eb90adc0764152045caab6146 (diff)
downloadglibc-d111572f2f7c595060b9bafcadba98d5391d464c.tar.gz
glibc-d111572f2f7c595060b9bafcadba98d5391d464c.tar.xz
glibc-d111572f2f7c595060b9bafcadba98d5391d464c.zip
Update.
1998-02-26  Ulrich Drepper  <drepper@cygnus.com>

	* nis/ypclnt.c (yp_master): Check result of strdup.
	Patch by Thorsten Kukuk.

1998-02-26  Thorsten Kukuk  <kukuk@vt.uni-paderborn.de>

	* nis/ypclnt.c: Give clnt handle after error checking free, change
	return codes to fix problems with rpc.nisd in YP mode on Ultra's.

1998-02-26 09:00  Ulrich Drepper  <drepper@cygnus.com>

	* misc/fstab.c: Partly rewritten to use dynamically allocated buffer.
	Patch by Joe Keane <jgk@jgk.org>.

	* misc/fstab.h (struct fstab): Change fs_type member to be const.
	* misc/fstab.c: Remove casts in fs_type assignments.

1998-02-26  Andreas Jaeger  <aj@arthur.rhein-neckar.de>

	* sysdeps/i386/fpu/bits/fenv.h: Correct typo.  ISO C 9X defines
	FE_TOWARDZERO and not FE_TOWARDSZERO.  Reported by H.J. Lu.
	* sysdeps/sparc/sparc64/fpu/bits/fenv.h: Likewise.
	* sysdeps/sparc/sparc32/fpu/bits/fenv.h: Likewise.
	* sysdeps/powerpc/bits/fenv.h: Likewise.
	* sysdeps/m68k/fpu/bits/fenv.h: Likewise.
	* sysdeps/generic/bits/fenv.h: Likewise.
	* sysdeps/alpha/fpu/bits/fenv.h: Likewise.
	* sysdeps/i386/fpu/fesetenv.c (fesetenv): Likewise.
	* sysdeps/powerpc/test-arith.c (main): Likewise.

1998-02-25  Ulrich Drepper  <drepper@cygnus.com>

	* sysdeps/i386/fpu/bits/mathinline.h: Also fix i386 versions of
	the comparison macros.

1998-02-21 20:14  H.J. Lu  <hjl@gnu.org>

	* sysdeps/libm-ieee754/s_log2.c (ln2): Added.
	(__log2): Fixed return values.
	* sysdeps/libm-ieee754/s_log2f.c: Likewise.

1998-02-25  Ulrich Drepper  <drepper@cygnus.com>

	* math/math.h (isunordered): Rename local variables to ensure
	correct code.  Reported by HJ Lu.

1998-02-25 10:34  Ulrich Drepper  <drepper@cygnus.com>

	* sysdpes/i386/fpu/bits/mathinline.h (isgreater, isgreaterequal,
	isless, islessequal, islessgreater, isunordered): Fix syntax for
	fucompip instruction.
	(isless, islessequal): Fix logic.

1998-02-21  Andreas Jaeger  <aj@arthur.rhein-neckar.de>

	* math/libm-test.c (sqrt_test): Add test for sqrt(2).
	(comparisons_test): New tests for comparison macros.
Diffstat (limited to 'misc/fstab.c')
-rw-r--r--misc/fstab.c195
1 files changed, 136 insertions, 59 deletions
diff --git a/misc/fstab.c b/misc/fstab.c
index 8b87a1f1f0..d241051ec9 100644
--- a/misc/fstab.c
+++ b/misc/fstab.c
@@ -1,4 +1,4 @@
-/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
+/* Copyright (C) 1995, 1996, 1997, 1998 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
@@ -19,98 +19,175 @@
 #include <fstab.h>
 #include <mntent.h>
 #include <stdio.h>
+#include <stdlib.h>
+#include <bits/libc-lock.h>
 
-static FILE *fstab;
-static struct mntent mntres;
-static char buffer[8192];
+#define BUFFER_SIZE 0x1fc0
 
-
-static FILE *
-fstab_stream (void)
+struct fstab_state
 {
-  if (! fstab)
-    fstab = setmntent (_PATH_FSTAB, "r");
-  return fstab;
-}
+  FILE *fs_fp;
+  char *fs_buffer;
+  struct mntent fs_mntres;
+  struct fstab fs_ret;
+};
+
+static struct fstab_state *fstab_init (int opt_rewind);
+static struct mntent *fstab_fetch (struct fstab_state *state);
+static struct fstab *fstab_convert (struct fstab_state *state);
+
+static struct fstab_state fstab_state;
+
 
 int
 setfsent (void)
 {
-  if (fstab)
-    {
-      rewind (fstab);
-      return 1;
-    }
-  else
-    fstab = setmntent (_PATH_FSTAB, "r");
-  return fstab ? 0 : 1;
+  return fstab_init (1) != NULL;
 }
 
-static struct fstab *
-internal_function
-mnt2fs (struct mntent *m)
-{
-  static struct fstab f;
-
-  if (m == NULL)
-    return NULL;
-
-  f.fs_spec = m->mnt_fsname;
-  f.fs_file = m->mnt_dir;
-  f.fs_vfstype = m->mnt_type;
-  f.fs_mntops = m->mnt_opts;
-  f.fs_type = (hasmntopt (m, FSTAB_RW) ? (char *) FSTAB_RW :
-	       hasmntopt (m, FSTAB_RQ) ? (char *) FSTAB_RQ :
-	       hasmntopt (m, FSTAB_RO) ? (char *) FSTAB_RO :
-	       hasmntopt (m, FSTAB_SW) ? (char *) FSTAB_SW :
-	       hasmntopt (m, FSTAB_XX) ? (char *) FSTAB_XX :
-	       (char *) "??");
-  f.fs_freq = m->mnt_freq;
-  f.fs_passno = m->mnt_passno;
-  return &f;
-}
 
 struct fstab *
 getfsent (void)
 {
-  FILE *s = fstab_stream ();
+  struct fstab_state *state;
 
-  if (! s)
+  state = fstab_init (0);
+  if (state == NULL)
     return NULL;
-
-  return mnt2fs (__getmntent_r (s, &mntres, buffer, sizeof buffer));
+  if (fstab_fetch (state) == NULL)
+    return NULL;
+  return fstab_convert (state);
 }
 
+
 struct fstab *
 getfsspec (name)
-     register const char *name;
+     const char *name;
 {
+  struct fstab_state *state;
   struct mntent *m;
-  if (setfsent ())
-    while (m = __getmntent_r (fstab, &mntres, buffer, sizeof buffer))
-      if (!strcmp (m->mnt_fsname, name))
-	return mnt2fs (m);
+
+  state = fstab_init (1);
+  if (state == NULL)
+    return NULL;
+  while ((m = fstab_fetch (state)) != NULL)
+    if (strcmp (m->mnt_fsname, name) == 0)
+      return fstab_convert (state);
   return NULL;
 }
 
+
 struct fstab *
 getfsfile (name)
-     register const char *name;
+     const char *name;
 {
+  struct fstab_state *state;
   struct mntent *m;
-  if (setfsent ())
-    while (m = __getmntent_r (fstab, &mntres, buffer, sizeof buffer))
-      if (!strcmp (m->mnt_dir, name))
-	return mnt2fs (m);
+
+  state = fstab_init (1);
+  if (state == NULL)
+    return NULL;
+  while ((m = fstab_fetch (state)) != NULL)
+    if (strcmp (m->mnt_dir, name) == 0)
+      return fstab_convert (state);
   return NULL;
 }
 
+
 void
 endfsent ()
 {
-  if (fstab)
+  struct fstab_state *state;
+
+  state = &fstab_state;
+  if (state->fs_fp != NULL)
     {
-      (void) endmntent (fstab);
-      fstab = NULL;
+      (void) endmntent (state->fs_fp);
+      state->fs_fp = NULL;
     }
 }
+
+
+static struct fstab_state *
+fstab_init (int opt_rewind)
+{
+  struct fstab_state *state;
+  char *buffer;
+  FILE *fp;
+
+  state = &fstab_state;
+
+  buffer = state->fs_buffer;
+  if (buffer == NULL)
+    {
+      buffer = (char *) malloc (BUFFER_SIZE);
+      if (buffer == NULL)
+	return NULL;
+      state->fs_buffer = buffer;
+    }
+
+  fp = state->fs_fp;
+  if (fp != NULL)
+    {
+      if (opt_rewind)
+	rewind (fp);
+    }
+  else
+    {
+      fp = setmntent (_PATH_FSTAB, "r");
+      if (fp == NULL)
+	return NULL;
+      state->fs_fp = fp;
+    }
+
+  return state;
+}
+
+
+static struct mntent *
+fstab_fetch (struct fstab_state *state)
+{
+  return __getmntent_r (state->fs_fp, &state->fs_mntres,
+			state->fs_buffer, BUFFER_SIZE);
+}
+
+
+static struct fstab *
+fstab_convert (struct fstab_state *state)
+{
+  struct mntent *m;
+  struct fstab *f;
+
+  m = &state->fs_mntres;
+  f = &state->fs_ret;
+
+  f->fs_spec = m->mnt_fsname;
+  f->fs_file = m->mnt_dir;
+  f->fs_vfstype = m->mnt_type;
+  f->fs_mntops = m->mnt_opts;
+  f->fs_type = (hasmntopt (m, FSTAB_RW) ? FSTAB_RW :
+		hasmntopt (m, FSTAB_RQ) ? FSTAB_RQ :
+		hasmntopt (m, FSTAB_RO) ? FSTAB_RO :
+		hasmntopt (m, FSTAB_SW) ? FSTAB_SW :
+		hasmntopt (m, FSTAB_XX) ? FSTAB_XX :
+		"??");
+  f->fs_freq = m->mnt_freq;
+  f->fs_passno = m->mnt_passno;
+  return f;
+}
+
+
+/* Make sure the memory is freed if the programs ends while in
+   memory-debugging mode and something actually was allocated.  */
+static void
+__attribute__ ((unused))
+fstab_free (void)
+{
+  char *buffer;
+
+  buffer = fstab_state.fs_buffer;
+  if (buffer != NULL)
+    free ((void *) buffer);
+}
+
+text_set_element (__libc_subfreeres, fstab_free);