|
|
ce426f |
commit 45c30c61c9001867c1891f5862764f084e53f348
|
|
|
ce426f |
Author: Ondřej Bílka <neleai@seznam.cz>
|
|
|
ce426f |
Date: Sun Oct 20 08:25:25 2013 +0200
|
|
|
ce426f |
|
|
|
ce426f |
Replace alloca in __tzfile_read by malloc. Fixes bug 15670
|
|
|
ce426f |
|
|
|
ce426f |
diff --git a/time/tzfile.c b/time/tzfile.c
|
|
|
ce426f |
index 9dd5130..3ea3051 100644
|
|
|
ce426f |
--- a/time/tzfile.c
|
|
|
ce426f |
+++ b/time/tzfile.c
|
|
|
ce426f |
@@ -114,6 +114,7 @@ __tzfile_read (const char *file, size_t extra, char **extrap)
|
|
|
ce426f |
int was_using_tzfile = __use_tzfile;
|
|
|
ce426f |
int trans_width = 4;
|
|
|
ce426f |
size_t tzspec_len;
|
|
|
ce426f |
+ char *new = NULL;
|
|
|
ce426f |
|
|
|
ce426f |
if (sizeof (time_t) != 4 && sizeof (time_t) != 8)
|
|
|
ce426f |
abort ();
|
|
|
ce426f |
@@ -145,22 +146,12 @@ __tzfile_read (const char *file, size_t extra, char **extrap)
|
|
|
ce426f |
if (*file != '/')
|
|
|
ce426f |
{
|
|
|
ce426f |
const char *tzdir;
|
|
|
ce426f |
- unsigned int len, tzdir_len;
|
|
|
ce426f |
- char *new, *tmp;
|
|
|
ce426f |
|
|
|
ce426f |
tzdir = getenv ("TZDIR");
|
|
|
ce426f |
if (tzdir == NULL || *tzdir == '\0')
|
|
|
ce426f |
- {
|
|
|
ce426f |
- tzdir = default_tzdir;
|
|
|
ce426f |
- tzdir_len = sizeof (default_tzdir) - 1;
|
|
|
ce426f |
- }
|
|
|
ce426f |
- else
|
|
|
ce426f |
- tzdir_len = strlen (tzdir);
|
|
|
ce426f |
- len = strlen (file) + 1;
|
|
|
ce426f |
- new = (char *) __alloca (tzdir_len + 1 + len);
|
|
|
ce426f |
- tmp = __mempcpy (new, tzdir, tzdir_len);
|
|
|
ce426f |
- *tmp++ = '/';
|
|
|
ce426f |
- memcpy (tmp, file, len);
|
|
|
ce426f |
+ tzdir = default_tzdir;
|
|
|
ce426f |
+ if (__asprintf (&new, "%s/%s", tzdir, file) == -1)
|
|
|
ce426f |
+ goto ret_free_transitions;
|
|
|
ce426f |
file = new;
|
|
|
ce426f |
}
|
|
|
ce426f |
|
|
|
ce426f |
@@ -170,11 +161,7 @@ __tzfile_read (const char *file, size_t extra, char **extrap)
|
|
|
ce426f |
&& stat64 (file, &st) == 0
|
|
|
ce426f |
&& tzfile_ino == st.st_ino && tzfile_dev == st.st_dev
|
|
|
ce426f |
&& tzfile_mtime == st.st_mtime)
|
|
|
ce426f |
- {
|
|
|
ce426f |
- /* Nothing to do. */
|
|
|
ce426f |
- __use_tzfile = 1;
|
|
|
ce426f |
- return;
|
|
|
ce426f |
- }
|
|
|
ce426f |
+ goto done; /* Nothing to do. */
|
|
|
ce426f |
|
|
|
ce426f |
/* Note the file is opened with cancellation in the I/O functions
|
|
|
ce426f |
disabled and if available FD_CLOEXEC set. */
|
|
|
ce426f |
@@ -527,12 +514,15 @@ __tzfile_read (const char *file, size_t extra, char **extrap)
|
|
|
ce426f |
__daylight = rule_stdoff != rule_dstoff;
|
|
|
ce426f |
__timezone = -rule_stdoff;
|
|
|
ce426f |
|
|
|
ce426f |
+ done:
|
|
|
ce426f |
__use_tzfile = 1;
|
|
|
ce426f |
+ free (new);
|
|
|
ce426f |
return;
|
|
|
ce426f |
|
|
|
ce426f |
lose:
|
|
|
ce426f |
fclose (f);
|
|
|
ce426f |
ret_free_transitions:
|
|
|
ce426f |
+ free (new);
|
|
|
ce426f |
free ((void *) transitions);
|
|
|
ce426f |
transitions = NULL;
|
|
|
ce426f |
}
|