Fix typos.
[kopensolaris-gnu/glibc.git] / locale / findlocale.c
index c027968..e2fdd06 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 1996, 1997 Free Software Foundation, Inc.
+/* Copyright (C) 1996, 1997, 1998 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@gnu.ai.mit.edu>, 1996.
 
@@ -20,6 +20,7 @@
 #include <locale.h>
 #include <stdlib.h>
 #include <string.h>
+#include <unistd.h>
 #include <sys/mman.h>
 
 #include "localeinfo.h"
@@ -51,7 +52,11 @@ _nl_find_locale (const char *locale_path, size_t locale_path_len,
   const char *revision;
   struct loaded_l10nfile *locale_file;
 
-  if ((*name)[0] == '\0')
+  if ((*name)[0] == '\0'
+      /* In SUID binaries we must not allow people to access files
+        outside the dedicated locale directories.  */
+      || (__libc_enable_secure
+         && memchr (*name, '/', _nl_find_language (*name) - *name) != NULL))
     {
       /* The user decides which locale to use by setting environment
         variables.  */
@@ -176,7 +181,7 @@ _nl_find_locale (const char *locale_path, size_t locale_path_len,
 
   /* Increment the usage count.  */
   if (((struct locale_data *) locale_file->data)->usage_count
-      != MAX_USAGE_COUNT)
+      < MAX_USAGE_COUNT)
     ++((struct locale_data *) locale_file->data)->usage_count;
 
   return (struct locale_data *) locale_file->data;
@@ -213,7 +218,7 @@ _nl_remove_locale (int locale, struct locale_data *data)
             permanent.  */
          if (__munmap ((caddr_t) data->filedata, data->filesize) != 0)
            {
-             data->usage_count = MAX_USAGE_COUNT;
+             data->usage_count = UNDELETABLE;
              return;
            }
        }
@@ -225,3 +230,26 @@ _nl_remove_locale (int locale, struct locale_data *data)
       free (data);
     }
 }
+
+static void __attribute__ ((unused))
+free_mem (void)
+{
+  int locale;
+
+  for (locale = 0; locale < LC_ALL; ++locale)
+    {
+      struct loaded_l10nfile *runp = locale_file_list[locale];
+
+      while (runp != NULL)
+       {
+         struct loaded_l10nfile *here = runp;
+         struct locale_data *data = (struct locale_data *) runp->data;
+
+         if (data != NULL && data->usage_count != UNDELETABLE)
+           _nl_unload_locale (data);
+         runp = runp->next;
+         free (here);
+       }
+    }
+}
+text_set_element (__libc_subfreeres, free_mem);