forked from rpms/glibc
getaddrinfo: Fix occasionally empty result due to nscd cache order (RHEL-16643)
Resolves: RHEL-16643
This commit is contained in:
parent
178dfa8115
commit
b02eb10bf8
211
glibc-RHEL-16643-1.patch
Normal file
211
glibc-RHEL-16643-1.patch
Normal file
@ -0,0 +1,211 @@
|
|||||||
|
commit 06890c7ba553e82393413c59bb3131db5815a337
|
||||||
|
Author: Siddhesh Poyarekar <siddhesh@sourceware.org>
|
||||||
|
Date: Tue Jul 27 22:49:53 2021 +0530
|
||||||
|
|
||||||
|
gaiconf_init: Refactor some bits for readability
|
||||||
|
|
||||||
|
Split out line processing for `label`, `precedence` and `scopev4` into
|
||||||
|
separate functions instead of the gotos.
|
||||||
|
|
||||||
|
Signed-off-by: Siddhesh Poyarekar <siddhesh@sourceware.org>
|
||||||
|
Reviewed-by: DJ Delorie <dj@redhat.com>
|
||||||
|
|
||||||
|
diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c
|
||||||
|
index d6046a707f1d742a..3bf9a8bae16a5b02 100644
|
||||||
|
--- a/sysdeps/posix/getaddrinfo.c
|
||||||
|
+++ b/sysdeps/posix/getaddrinfo.c
|
||||||
|
@@ -1858,6 +1858,66 @@ scopecmp (const void *p1, const void *p2)
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
+static bool
|
||||||
|
+add_prefixlist (struct prefixlist **listp, size_t *lenp, bool *nullbitsp,
|
||||||
|
+ char *val1, char *val2, char **pos)
|
||||||
|
+{
|
||||||
|
+ struct in6_addr prefix;
|
||||||
|
+ unsigned long int bits;
|
||||||
|
+ unsigned long int val;
|
||||||
|
+ char *endp;
|
||||||
|
+
|
||||||
|
+ bits = 128;
|
||||||
|
+ __set_errno (0);
|
||||||
|
+ char *cp = strchr (val1, '/');
|
||||||
|
+ if (cp != NULL)
|
||||||
|
+ *cp++ = '\0';
|
||||||
|
+ *pos = cp;
|
||||||
|
+ if (inet_pton (AF_INET6, val1, &prefix)
|
||||||
|
+ && (cp == NULL
|
||||||
|
+ || (bits = strtoul (cp, &endp, 10)) != ULONG_MAX
|
||||||
|
+ || errno != ERANGE)
|
||||||
|
+ && *endp == '\0'
|
||||||
|
+ && bits <= 128
|
||||||
|
+ && ((val = strtoul (val2, &endp, 10)) != ULONG_MAX
|
||||||
|
+ || errno != ERANGE)
|
||||||
|
+ && *endp == '\0'
|
||||||
|
+ && val <= INT_MAX)
|
||||||
|
+ {
|
||||||
|
+ struct prefixlist *newp = malloc (sizeof (*newp));
|
||||||
|
+ if (newp == NULL)
|
||||||
|
+ return false;
|
||||||
|
+
|
||||||
|
+ memcpy (&newp->entry.prefix, &prefix, sizeof (prefix));
|
||||||
|
+ newp->entry.bits = bits;
|
||||||
|
+ newp->entry.val = val;
|
||||||
|
+ newp->next = *listp;
|
||||||
|
+ *listp = newp;
|
||||||
|
+ ++*lenp;
|
||||||
|
+ *nullbitsp |= bits == 0;
|
||||||
|
+ }
|
||||||
|
+ return true;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static bool
|
||||||
|
+add_scopelist (struct scopelist **listp, size_t *lenp, bool *nullbitsp,
|
||||||
|
+ const struct in6_addr *prefixp, unsigned long int bits,
|
||||||
|
+ unsigned long int val)
|
||||||
|
+{
|
||||||
|
+ struct scopelist *newp = malloc (sizeof (*newp));
|
||||||
|
+ if (newp == NULL)
|
||||||
|
+ return false;
|
||||||
|
+
|
||||||
|
+ newp->entry.netmask = htonl (bits != 96 ? (0xffffffff << (128 - bits)) : 0);
|
||||||
|
+ newp->entry.addr32 = (prefixp->s6_addr32[3] & newp->entry.netmask);
|
||||||
|
+ newp->entry.scope = val;
|
||||||
|
+ newp->next = *listp;
|
||||||
|
+ *listp = newp;
|
||||||
|
+ ++*lenp;
|
||||||
|
+ *nullbitsp |= bits == 96;
|
||||||
|
+
|
||||||
|
+ return true;
|
||||||
|
+}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gaiconf_init (void)
|
||||||
|
@@ -1933,55 +1993,17 @@ gaiconf_init (void)
|
||||||
|
/* Ignore the rest of the line. */
|
||||||
|
*cp = '\0';
|
||||||
|
|
||||||
|
- struct prefixlist **listp;
|
||||||
|
- size_t *lenp;
|
||||||
|
- bool *nullbitsp;
|
||||||
|
switch (cmdlen)
|
||||||
|
{
|
||||||
|
case 5:
|
||||||
|
if (strcmp (cmd, "label") == 0)
|
||||||
|
{
|
||||||
|
- struct in6_addr prefix;
|
||||||
|
- unsigned long int bits;
|
||||||
|
- unsigned long int val;
|
||||||
|
- char *endp;
|
||||||
|
-
|
||||||
|
- listp = &labellist;
|
||||||
|
- lenp = &nlabellist;
|
||||||
|
- nullbitsp = &labellist_nullbits;
|
||||||
|
-
|
||||||
|
- new_elem:
|
||||||
|
- bits = 128;
|
||||||
|
- __set_errno (0);
|
||||||
|
- cp = strchr (val1, '/');
|
||||||
|
- if (cp != NULL)
|
||||||
|
- *cp++ = '\0';
|
||||||
|
- if (inet_pton (AF_INET6, val1, &prefix)
|
||||||
|
- && (cp == NULL
|
||||||
|
- || (bits = strtoul (cp, &endp, 10)) != ULONG_MAX
|
||||||
|
- || errno != ERANGE)
|
||||||
|
- && *endp == '\0'
|
||||||
|
- && bits <= 128
|
||||||
|
- && ((val = strtoul (val2, &endp, 10)) != ULONG_MAX
|
||||||
|
- || errno != ERANGE)
|
||||||
|
- && *endp == '\0'
|
||||||
|
- && val <= INT_MAX)
|
||||||
|
+ if (!add_prefixlist (&labellist, &nlabellist,
|
||||||
|
+ &labellist_nullbits, val1, val2, &cp))
|
||||||
|
{
|
||||||
|
- struct prefixlist *newp = malloc (sizeof (*newp));
|
||||||
|
- if (newp == NULL)
|
||||||
|
- {
|
||||||
|
- free (line);
|
||||||
|
- fclose (fp);
|
||||||
|
- goto no_file;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- memcpy (&newp->entry.prefix, &prefix, sizeof (prefix));
|
||||||
|
- newp->entry.bits = bits;
|
||||||
|
- newp->entry.val = val;
|
||||||
|
- newp->next = *listp;
|
||||||
|
- *listp = newp;
|
||||||
|
- ++*lenp;
|
||||||
|
- *nullbitsp |= bits == 0;
|
||||||
|
+ free (line);
|
||||||
|
+ fclose (fp);
|
||||||
|
+ goto no_file;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
@@ -2023,27 +2045,14 @@ gaiconf_init (void)
|
||||||
|
&& *endp == '\0'
|
||||||
|
&& val <= INT_MAX)
|
||||||
|
{
|
||||||
|
- struct scopelist *newp;
|
||||||
|
- new_scope:
|
||||||
|
- newp = malloc (sizeof (*newp));
|
||||||
|
- if (newp == NULL)
|
||||||
|
+ if (!add_scopelist (&scopelist, &nscopelist,
|
||||||
|
+ &scopelist_nullbits, &prefix,
|
||||||
|
+ bits, val))
|
||||||
|
{
|
||||||
|
free (line);
|
||||||
|
fclose (fp);
|
||||||
|
goto no_file;
|
||||||
|
}
|
||||||
|
-
|
||||||
|
- newp->entry.netmask = htonl (bits != 96
|
||||||
|
- ? (0xffffffff
|
||||||
|
- << (128 - bits))
|
||||||
|
- : 0);
|
||||||
|
- newp->entry.addr32 = (prefix.s6_addr32[3]
|
||||||
|
- & newp->entry.netmask);
|
||||||
|
- newp->entry.scope = val;
|
||||||
|
- newp->next = scopelist;
|
||||||
|
- scopelist = newp;
|
||||||
|
- ++nscopelist;
|
||||||
|
- scopelist_nullbits |= bits == 96;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (inet_pton (AF_INET, val1, &prefix.s6_addr32[3])
|
||||||
|
@@ -2057,8 +2066,14 @@ gaiconf_init (void)
|
||||||
|
&& *endp == '\0'
|
||||||
|
&& val <= INT_MAX)
|
||||||
|
{
|
||||||
|
- bits += 96;
|
||||||
|
- goto new_scope;
|
||||||
|
+ if (!add_scopelist (&scopelist, &nscopelist,
|
||||||
|
+ &scopelist_nullbits, &prefix,
|
||||||
|
+ bits + 96, val))
|
||||||
|
+ {
|
||||||
|
+ free (line);
|
||||||
|
+ fclose (fp);
|
||||||
|
+ goto no_file;
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
@@ -2066,10 +2081,14 @@ gaiconf_init (void)
|
||||||
|
case 10:
|
||||||
|
if (strcmp (cmd, "precedence") == 0)
|
||||||
|
{
|
||||||
|
- listp = &precedencelist;
|
||||||
|
- lenp = &nprecedencelist;
|
||||||
|
- nullbitsp = &precedencelist_nullbits;
|
||||||
|
- goto new_elem;
|
||||||
|
+ if (!add_prefixlist (&precedencelist, &nprecedencelist,
|
||||||
|
+ &precedencelist_nullbits, val1, val2,
|
||||||
|
+ &cp))
|
||||||
|
+ {
|
||||||
|
+ free (line);
|
||||||
|
+ fclose (fp);
|
||||||
|
+ goto no_file;
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
584
glibc-RHEL-16643-2.patch
Normal file
584
glibc-RHEL-16643-2.patch
Normal file
@ -0,0 +1,584 @@
|
|||||||
|
commit bc0d18d873abf2cda6842ad8bb4df2a31dc0fbac
|
||||||
|
Author: Siddhesh Poyarekar <siddhesh@sourceware.org>
|
||||||
|
Date: Tue Aug 3 21:29:23 2021 +0530
|
||||||
|
|
||||||
|
gai_init: Avoid jumping from if condition to its else counterpart
|
||||||
|
|
||||||
|
Clean up another antipattern where code flows from an if condition to
|
||||||
|
its else counterpart with a goto.
|
||||||
|
|
||||||
|
Most of the change in this patch is whitespace-only; a `git diff -b`
|
||||||
|
ought to show the actual logic changes.
|
||||||
|
|
||||||
|
Signed-off-by: Siddhesh Poyarekar <siddhesh@sourceware.org>
|
||||||
|
Reviewed-by: DJ Delorie <dj@redhat.com>
|
||||||
|
|
||||||
|
diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c
|
||||||
|
index 3bf9a8bae16a5b02..1635a09837351068 100644
|
||||||
|
--- a/sysdeps/posix/getaddrinfo.c
|
||||||
|
+++ b/sysdeps/posix/getaddrinfo.c
|
||||||
|
@@ -1933,142 +1933,122 @@ gaiconf_init (void)
|
||||||
|
bool scopelist_nullbits = false;
|
||||||
|
|
||||||
|
FILE *fp = fopen (GAICONF_FNAME, "rce");
|
||||||
|
- if (fp != NULL)
|
||||||
|
+ if (fp == NULL)
|
||||||
|
+ goto no_file;
|
||||||
|
+
|
||||||
|
+ struct __stat64_t64 st;
|
||||||
|
+ if (__fstat64_time64 (fileno (fp), &st) != 0)
|
||||||
|
{
|
||||||
|
- struct __stat64_t64 st;
|
||||||
|
- if (__fstat64_time64 (fileno (fp), &st) != 0)
|
||||||
|
- {
|
||||||
|
- fclose (fp);
|
||||||
|
- goto no_file;
|
||||||
|
- }
|
||||||
|
+ fclose (fp);
|
||||||
|
+ goto no_file;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
- char *line = NULL;
|
||||||
|
- size_t linelen = 0;
|
||||||
|
+ char *line = NULL;
|
||||||
|
+ size_t linelen = 0;
|
||||||
|
|
||||||
|
- __fsetlocking (fp, FSETLOCKING_BYCALLER);
|
||||||
|
+ __fsetlocking (fp, FSETLOCKING_BYCALLER);
|
||||||
|
|
||||||
|
- while (!feof_unlocked (fp))
|
||||||
|
- {
|
||||||
|
- ssize_t n = __getline (&line, &linelen, fp);
|
||||||
|
- if (n <= 0)
|
||||||
|
- break;
|
||||||
|
+ while (!feof_unlocked (fp))
|
||||||
|
+ {
|
||||||
|
+ ssize_t n = __getline (&line, &linelen, fp);
|
||||||
|
+ if (n <= 0)
|
||||||
|
+ break;
|
||||||
|
|
||||||
|
- /* Handle comments. No escaping possible so this is easy. */
|
||||||
|
- char *cp = strchr (line, '#');
|
||||||
|
- if (cp != NULL)
|
||||||
|
- *cp = '\0';
|
||||||
|
+ /* Handle comments. No escaping possible so this is easy. */
|
||||||
|
+ char *cp = strchr (line, '#');
|
||||||
|
+ if (cp != NULL)
|
||||||
|
+ *cp = '\0';
|
||||||
|
|
||||||
|
- cp = line;
|
||||||
|
- while (isspace (*cp))
|
||||||
|
- ++cp;
|
||||||
|
+ cp = line;
|
||||||
|
+ while (isspace (*cp))
|
||||||
|
+ ++cp;
|
||||||
|
|
||||||
|
- char *cmd = cp;
|
||||||
|
- while (*cp != '\0' && !isspace (*cp))
|
||||||
|
- ++cp;
|
||||||
|
- size_t cmdlen = cp - cmd;
|
||||||
|
+ char *cmd = cp;
|
||||||
|
+ while (*cp != '\0' && !isspace (*cp))
|
||||||
|
+ ++cp;
|
||||||
|
+ size_t cmdlen = cp - cmd;
|
||||||
|
|
||||||
|
- if (*cp != '\0')
|
||||||
|
- *cp++ = '\0';
|
||||||
|
- while (isspace (*cp))
|
||||||
|
- ++cp;
|
||||||
|
+ if (*cp != '\0')
|
||||||
|
+ *cp++ = '\0';
|
||||||
|
+ while (isspace (*cp))
|
||||||
|
+ ++cp;
|
||||||
|
|
||||||
|
- char *val1 = cp;
|
||||||
|
- while (*cp != '\0' && !isspace (*cp))
|
||||||
|
- ++cp;
|
||||||
|
- size_t val1len = cp - cmd;
|
||||||
|
+ char *val1 = cp;
|
||||||
|
+ while (*cp != '\0' && !isspace (*cp))
|
||||||
|
+ ++cp;
|
||||||
|
+ size_t val1len = cp - cmd;
|
||||||
|
|
||||||
|
- /* We always need at least two values. */
|
||||||
|
- if (val1len == 0)
|
||||||
|
- continue;
|
||||||
|
+ /* We always need at least two values. */
|
||||||
|
+ if (val1len == 0)
|
||||||
|
+ continue;
|
||||||
|
|
||||||
|
- if (*cp != '\0')
|
||||||
|
- *cp++ = '\0';
|
||||||
|
- while (isspace (*cp))
|
||||||
|
- ++cp;
|
||||||
|
+ if (*cp != '\0')
|
||||||
|
+ *cp++ = '\0';
|
||||||
|
+ while (isspace (*cp))
|
||||||
|
+ ++cp;
|
||||||
|
|
||||||
|
- char *val2 = cp;
|
||||||
|
- while (*cp != '\0' && !isspace (*cp))
|
||||||
|
- ++cp;
|
||||||
|
+ char *val2 = cp;
|
||||||
|
+ while (*cp != '\0' && !isspace (*cp))
|
||||||
|
+ ++cp;
|
||||||
|
|
||||||
|
- /* Ignore the rest of the line. */
|
||||||
|
- *cp = '\0';
|
||||||
|
+ /* Ignore the rest of the line. */
|
||||||
|
+ *cp = '\0';
|
||||||
|
|
||||||
|
- switch (cmdlen)
|
||||||
|
+ switch (cmdlen)
|
||||||
|
+ {
|
||||||
|
+ case 5:
|
||||||
|
+ if (strcmp (cmd, "label") == 0)
|
||||||
|
{
|
||||||
|
- case 5:
|
||||||
|
- if (strcmp (cmd, "label") == 0)
|
||||||
|
+ if (!add_prefixlist (&labellist, &nlabellist,
|
||||||
|
+ &labellist_nullbits, val1, val2, &cp))
|
||||||
|
{
|
||||||
|
- if (!add_prefixlist (&labellist, &nlabellist,
|
||||||
|
- &labellist_nullbits, val1, val2, &cp))
|
||||||
|
- {
|
||||||
|
- free (line);
|
||||||
|
- fclose (fp);
|
||||||
|
- goto no_file;
|
||||||
|
- }
|
||||||
|
+ free (line);
|
||||||
|
+ fclose (fp);
|
||||||
|
+ goto no_file;
|
||||||
|
}
|
||||||
|
- break;
|
||||||
|
+ }
|
||||||
|
+ break;
|
||||||
|
|
||||||
|
- case 6:
|
||||||
|
- if (strcmp (cmd, "reload") == 0)
|
||||||
|
- {
|
||||||
|
- gaiconf_reload_flag = strcmp (val1, "yes") == 0;
|
||||||
|
- if (gaiconf_reload_flag)
|
||||||
|
- gaiconf_reload_flag_ever_set = 1;
|
||||||
|
- }
|
||||||
|
- break;
|
||||||
|
+ case 6:
|
||||||
|
+ if (strcmp (cmd, "reload") == 0)
|
||||||
|
+ {
|
||||||
|
+ gaiconf_reload_flag = strcmp (val1, "yes") == 0;
|
||||||
|
+ if (gaiconf_reload_flag)
|
||||||
|
+ gaiconf_reload_flag_ever_set = 1;
|
||||||
|
+ }
|
||||||
|
+ break;
|
||||||
|
|
||||||
|
- case 7:
|
||||||
|
- if (strcmp (cmd, "scopev4") == 0)
|
||||||
|
+ case 7:
|
||||||
|
+ if (strcmp (cmd, "scopev4") == 0)
|
||||||
|
+ {
|
||||||
|
+ struct in6_addr prefix;
|
||||||
|
+ unsigned long int bits;
|
||||||
|
+ unsigned long int val;
|
||||||
|
+ char *endp;
|
||||||
|
+
|
||||||
|
+ bits = 32;
|
||||||
|
+ __set_errno (0);
|
||||||
|
+ cp = strchr (val1, '/');
|
||||||
|
+ if (cp != NULL)
|
||||||
|
+ *cp++ = '\0';
|
||||||
|
+ if (inet_pton (AF_INET6, val1, &prefix))
|
||||||
|
{
|
||||||
|
- struct in6_addr prefix;
|
||||||
|
- unsigned long int bits;
|
||||||
|
- unsigned long int val;
|
||||||
|
- char *endp;
|
||||||
|
-
|
||||||
|
- bits = 32;
|
||||||
|
- __set_errno (0);
|
||||||
|
- cp = strchr (val1, '/');
|
||||||
|
- if (cp != NULL)
|
||||||
|
- *cp++ = '\0';
|
||||||
|
- if (inet_pton (AF_INET6, val1, &prefix))
|
||||||
|
- {
|
||||||
|
- bits = 128;
|
||||||
|
- if (IN6_IS_ADDR_V4MAPPED (&prefix)
|
||||||
|
- && (cp == NULL
|
||||||
|
- || (bits = strtoul (cp, &endp, 10)) != ULONG_MAX
|
||||||
|
- || errno != ERANGE)
|
||||||
|
- && *endp == '\0'
|
||||||
|
- && bits >= 96
|
||||||
|
- && bits <= 128
|
||||||
|
- && ((val = strtoul (val2, &endp, 10)) != ULONG_MAX
|
||||||
|
- || errno != ERANGE)
|
||||||
|
- && *endp == '\0'
|
||||||
|
- && val <= INT_MAX)
|
||||||
|
- {
|
||||||
|
- if (!add_scopelist (&scopelist, &nscopelist,
|
||||||
|
- &scopelist_nullbits, &prefix,
|
||||||
|
- bits, val))
|
||||||
|
- {
|
||||||
|
- free (line);
|
||||||
|
- fclose (fp);
|
||||||
|
- goto no_file;
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
- else if (inet_pton (AF_INET, val1, &prefix.s6_addr32[3])
|
||||||
|
- && (cp == NULL
|
||||||
|
- || (bits = strtoul (cp, &endp, 10)) != ULONG_MAX
|
||||||
|
- || errno != ERANGE)
|
||||||
|
- && *endp == '\0'
|
||||||
|
- && bits <= 32
|
||||||
|
- && ((val = strtoul (val2, &endp, 10)) != ULONG_MAX
|
||||||
|
- || errno != ERANGE)
|
||||||
|
- && *endp == '\0'
|
||||||
|
- && val <= INT_MAX)
|
||||||
|
+ bits = 128;
|
||||||
|
+ if (IN6_IS_ADDR_V4MAPPED (&prefix)
|
||||||
|
+ && (cp == NULL
|
||||||
|
+ || (bits = strtoul (cp, &endp, 10)) != ULONG_MAX
|
||||||
|
+ || errno != ERANGE)
|
||||||
|
+ && *endp == '\0'
|
||||||
|
+ && bits >= 96
|
||||||
|
+ && bits <= 128
|
||||||
|
+ && ((val = strtoul (val2, &endp, 10)) != ULONG_MAX
|
||||||
|
+ || errno != ERANGE)
|
||||||
|
+ && *endp == '\0'
|
||||||
|
+ && val <= INT_MAX)
|
||||||
|
{
|
||||||
|
if (!add_scopelist (&scopelist, &nscopelist,
|
||||||
|
&scopelist_nullbits, &prefix,
|
||||||
|
- bits + 96, val))
|
||||||
|
+ bits, val))
|
||||||
|
{
|
||||||
|
free (line);
|
||||||
|
fclose (fp);
|
||||||
|
@@ -2076,173 +2056,191 @@ gaiconf_init (void)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
- break;
|
||||||
|
-
|
||||||
|
- case 10:
|
||||||
|
- if (strcmp (cmd, "precedence") == 0)
|
||||||
|
+ else if (inet_pton (AF_INET, val1, &prefix.s6_addr32[3])
|
||||||
|
+ && (cp == NULL
|
||||||
|
+ || (bits = strtoul (cp, &endp, 10)) != ULONG_MAX
|
||||||
|
+ || errno != ERANGE)
|
||||||
|
+ && *endp == '\0'
|
||||||
|
+ && bits <= 32
|
||||||
|
+ && ((val = strtoul (val2, &endp, 10)) != ULONG_MAX
|
||||||
|
+ || errno != ERANGE)
|
||||||
|
+ && *endp == '\0'
|
||||||
|
+ && val <= INT_MAX)
|
||||||
|
{
|
||||||
|
- if (!add_prefixlist (&precedencelist, &nprecedencelist,
|
||||||
|
- &precedencelist_nullbits, val1, val2,
|
||||||
|
- &cp))
|
||||||
|
+ if (!add_scopelist (&scopelist, &nscopelist,
|
||||||
|
+ &scopelist_nullbits, &prefix,
|
||||||
|
+ bits + 96, val))
|
||||||
|
{
|
||||||
|
free (line);
|
||||||
|
fclose (fp);
|
||||||
|
goto no_file;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
- break;
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- free (line);
|
||||||
|
-
|
||||||
|
- fclose (fp);
|
||||||
|
-
|
||||||
|
- /* Create the array for the labels. */
|
||||||
|
- struct prefixentry *new_labels;
|
||||||
|
- if (nlabellist > 0)
|
||||||
|
- {
|
||||||
|
- if (!labellist_nullbits)
|
||||||
|
- ++nlabellist;
|
||||||
|
- new_labels = malloc (nlabellist * sizeof (*new_labels));
|
||||||
|
- if (new_labels == NULL)
|
||||||
|
- goto no_file;
|
||||||
|
-
|
||||||
|
- int i = nlabellist;
|
||||||
|
- if (!labellist_nullbits)
|
||||||
|
- {
|
||||||
|
- --i;
|
||||||
|
- memset (&new_labels[i].prefix, '\0', sizeof (struct in6_addr));
|
||||||
|
- new_labels[i].bits = 0;
|
||||||
|
- new_labels[i].val = 1;
|
||||||
|
}
|
||||||
|
+ break;
|
||||||
|
|
||||||
|
- struct prefixlist *l = labellist;
|
||||||
|
- while (i-- > 0)
|
||||||
|
+ case 10:
|
||||||
|
+ if (strcmp (cmd, "precedence") == 0)
|
||||||
|
{
|
||||||
|
- new_labels[i] = l->entry;
|
||||||
|
- l = l->next;
|
||||||
|
+ if (!add_prefixlist (&precedencelist, &nprecedencelist,
|
||||||
|
+ &precedencelist_nullbits, val1, val2,
|
||||||
|
+ &cp))
|
||||||
|
+ {
|
||||||
|
+ free (line);
|
||||||
|
+ fclose (fp);
|
||||||
|
+ goto no_file;
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
- free_prefixlist (labellist);
|
||||||
|
- labellist = NULL;
|
||||||
|
-
|
||||||
|
- /* Sort the entries so that the most specific ones are at
|
||||||
|
- the beginning. */
|
||||||
|
- qsort (new_labels, nlabellist, sizeof (*new_labels), prefixcmp);
|
||||||
|
+ break;
|
||||||
|
}
|
||||||
|
- else
|
||||||
|
- new_labels = (struct prefixentry *) default_labels;
|
||||||
|
-
|
||||||
|
- struct prefixentry *new_precedence;
|
||||||
|
- if (nprecedencelist > 0)
|
||||||
|
- {
|
||||||
|
- if (!precedencelist_nullbits)
|
||||||
|
- ++nprecedencelist;
|
||||||
|
- new_precedence = malloc (nprecedencelist * sizeof (*new_precedence));
|
||||||
|
- if (new_precedence == NULL)
|
||||||
|
- {
|
||||||
|
- if (new_labels != default_labels)
|
||||||
|
- free (new_labels);
|
||||||
|
- goto no_file;
|
||||||
|
- }
|
||||||
|
+ }
|
||||||
|
|
||||||
|
- int i = nprecedencelist;
|
||||||
|
- if (!precedencelist_nullbits)
|
||||||
|
- {
|
||||||
|
- --i;
|
||||||
|
- memset (&new_precedence[i].prefix, '\0',
|
||||||
|
- sizeof (struct in6_addr));
|
||||||
|
- new_precedence[i].bits = 0;
|
||||||
|
- new_precedence[i].val = 40;
|
||||||
|
- }
|
||||||
|
+ free (line);
|
||||||
|
|
||||||
|
- struct prefixlist *l = precedencelist;
|
||||||
|
- while (i-- > 0)
|
||||||
|
- {
|
||||||
|
- new_precedence[i] = l->entry;
|
||||||
|
- l = l->next;
|
||||||
|
- }
|
||||||
|
- free_prefixlist (precedencelist);
|
||||||
|
- precedencelist = NULL;
|
||||||
|
+ fclose (fp);
|
||||||
|
|
||||||
|
- /* Sort the entries so that the most specific ones are at
|
||||||
|
- the beginning. */
|
||||||
|
- qsort (new_precedence, nprecedencelist, sizeof (*new_precedence),
|
||||||
|
- prefixcmp);
|
||||||
|
+ /* Create the array for the labels. */
|
||||||
|
+ struct prefixentry *new_labels;
|
||||||
|
+ if (nlabellist > 0)
|
||||||
|
+ {
|
||||||
|
+ if (!labellist_nullbits)
|
||||||
|
+ ++nlabellist;
|
||||||
|
+ new_labels = malloc (nlabellist * sizeof (*new_labels));
|
||||||
|
+ if (new_labels == NULL)
|
||||||
|
+ goto no_file;
|
||||||
|
+
|
||||||
|
+ int i = nlabellist;
|
||||||
|
+ if (!labellist_nullbits)
|
||||||
|
+ {
|
||||||
|
+ --i;
|
||||||
|
+ memset (&new_labels[i].prefix, '\0', sizeof (struct in6_addr));
|
||||||
|
+ new_labels[i].bits = 0;
|
||||||
|
+ new_labels[i].val = 1;
|
||||||
|
}
|
||||||
|
- else
|
||||||
|
- new_precedence = (struct prefixentry *) default_precedence;
|
||||||
|
|
||||||
|
- struct scopeentry *new_scopes;
|
||||||
|
- if (nscopelist > 0)
|
||||||
|
+ struct prefixlist *l = labellist;
|
||||||
|
+ while (i-- > 0)
|
||||||
|
{
|
||||||
|
- if (!scopelist_nullbits)
|
||||||
|
- ++nscopelist;
|
||||||
|
- new_scopes = malloc (nscopelist * sizeof (*new_scopes));
|
||||||
|
- if (new_scopes == NULL)
|
||||||
|
- {
|
||||||
|
- if (new_labels != default_labels)
|
||||||
|
- free (new_labels);
|
||||||
|
- if (new_precedence != default_precedence)
|
||||||
|
- free (new_precedence);
|
||||||
|
- goto no_file;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- int i = nscopelist;
|
||||||
|
- if (!scopelist_nullbits)
|
||||||
|
- {
|
||||||
|
- --i;
|
||||||
|
- new_scopes[i].addr32 = 0;
|
||||||
|
- new_scopes[i].netmask = 0;
|
||||||
|
- new_scopes[i].scope = 14;
|
||||||
|
- }
|
||||||
|
+ new_labels[i] = l->entry;
|
||||||
|
+ l = l->next;
|
||||||
|
+ }
|
||||||
|
+ free_prefixlist (labellist);
|
||||||
|
+ labellist = NULL;
|
||||||
|
|
||||||
|
- struct scopelist *l = scopelist;
|
||||||
|
- while (i-- > 0)
|
||||||
|
- {
|
||||||
|
- new_scopes[i] = l->entry;
|
||||||
|
- l = l->next;
|
||||||
|
- }
|
||||||
|
- free_scopelist (scopelist);
|
||||||
|
+ /* Sort the entries so that the most specific ones are at
|
||||||
|
+ the beginning. */
|
||||||
|
+ qsort (new_labels, nlabellist, sizeof (*new_labels), prefixcmp);
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ new_labels = (struct prefixentry *) default_labels;
|
||||||
|
|
||||||
|
- /* Sort the entries so that the most specific ones are at
|
||||||
|
- the beginning. */
|
||||||
|
- qsort (new_scopes, nscopelist, sizeof (*new_scopes),
|
||||||
|
- scopecmp);
|
||||||
|
+ struct prefixentry *new_precedence;
|
||||||
|
+ if (nprecedencelist > 0)
|
||||||
|
+ {
|
||||||
|
+ if (!precedencelist_nullbits)
|
||||||
|
+ ++nprecedencelist;
|
||||||
|
+ new_precedence = malloc (nprecedencelist * sizeof (*new_precedence));
|
||||||
|
+ if (new_precedence == NULL)
|
||||||
|
+ {
|
||||||
|
+ if (new_labels != default_labels)
|
||||||
|
+ free (new_labels);
|
||||||
|
+ goto no_file;
|
||||||
|
}
|
||||||
|
- else
|
||||||
|
- new_scopes = (struct scopeentry *) default_scopes;
|
||||||
|
-
|
||||||
|
- /* Now we are ready to replace the values. */
|
||||||
|
- const struct prefixentry *old = labels;
|
||||||
|
- labels = new_labels;
|
||||||
|
- if (old != default_labels)
|
||||||
|
- free ((void *) old);
|
||||||
|
|
||||||
|
- old = precedence;
|
||||||
|
- precedence = new_precedence;
|
||||||
|
- if (old != default_precedence)
|
||||||
|
- free ((void *) old);
|
||||||
|
+ int i = nprecedencelist;
|
||||||
|
+ if (!precedencelist_nullbits)
|
||||||
|
+ {
|
||||||
|
+ --i;
|
||||||
|
+ memset (&new_precedence[i].prefix, '\0',
|
||||||
|
+ sizeof (struct in6_addr));
|
||||||
|
+ new_precedence[i].bits = 0;
|
||||||
|
+ new_precedence[i].val = 40;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
- const struct scopeentry *oldscope = scopes;
|
||||||
|
- scopes = new_scopes;
|
||||||
|
- if (oldscope != default_scopes)
|
||||||
|
- free ((void *) oldscope);
|
||||||
|
+ struct prefixlist *l = precedencelist;
|
||||||
|
+ while (i-- > 0)
|
||||||
|
+ {
|
||||||
|
+ new_precedence[i] = l->entry;
|
||||||
|
+ l = l->next;
|
||||||
|
+ }
|
||||||
|
+ free_prefixlist (precedencelist);
|
||||||
|
+ precedencelist = NULL;
|
||||||
|
|
||||||
|
- save_gaiconf_mtime (&st);
|
||||||
|
+ /* Sort the entries so that the most specific ones are at
|
||||||
|
+ the beginning. */
|
||||||
|
+ qsort (new_precedence, nprecedencelist, sizeof (*new_precedence),
|
||||||
|
+ prefixcmp);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
+ new_precedence = (struct prefixentry *) default_precedence;
|
||||||
|
+
|
||||||
|
+ struct scopeentry *new_scopes;
|
||||||
|
+ if (nscopelist > 0)
|
||||||
|
{
|
||||||
|
- no_file:
|
||||||
|
- free_prefixlist (labellist);
|
||||||
|
- free_prefixlist (precedencelist);
|
||||||
|
+ if (!scopelist_nullbits)
|
||||||
|
+ ++nscopelist;
|
||||||
|
+ new_scopes = malloc (nscopelist * sizeof (*new_scopes));
|
||||||
|
+ if (new_scopes == NULL)
|
||||||
|
+ {
|
||||||
|
+ if (new_labels != default_labels)
|
||||||
|
+ free (new_labels);
|
||||||
|
+ if (new_precedence != default_precedence)
|
||||||
|
+ free (new_precedence);
|
||||||
|
+ goto no_file;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ int i = nscopelist;
|
||||||
|
+ if (!scopelist_nullbits)
|
||||||
|
+ {
|
||||||
|
+ --i;
|
||||||
|
+ new_scopes[i].addr32 = 0;
|
||||||
|
+ new_scopes[i].netmask = 0;
|
||||||
|
+ new_scopes[i].scope = 14;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ struct scopelist *l = scopelist;
|
||||||
|
+ while (i-- > 0)
|
||||||
|
+ {
|
||||||
|
+ new_scopes[i] = l->entry;
|
||||||
|
+ l = l->next;
|
||||||
|
+ }
|
||||||
|
free_scopelist (scopelist);
|
||||||
|
|
||||||
|
- /* If we previously read the file but it is gone now, free the
|
||||||
|
- old data and use the builtin one. Leave the reload flag
|
||||||
|
- alone. */
|
||||||
|
- fini ();
|
||||||
|
+ /* Sort the entries so that the most specific ones are at
|
||||||
|
+ the beginning. */
|
||||||
|
+ qsort (new_scopes, nscopelist, sizeof (*new_scopes),
|
||||||
|
+ scopecmp);
|
||||||
|
}
|
||||||
|
+ else
|
||||||
|
+ new_scopes = (struct scopeentry *) default_scopes;
|
||||||
|
+
|
||||||
|
+ /* Now we are ready to replace the values. */
|
||||||
|
+ const struct prefixentry *old = labels;
|
||||||
|
+ labels = new_labels;
|
||||||
|
+ if (old != default_labels)
|
||||||
|
+ free ((void *) old);
|
||||||
|
+
|
||||||
|
+ old = precedence;
|
||||||
|
+ precedence = new_precedence;
|
||||||
|
+ if (old != default_precedence)
|
||||||
|
+ free ((void *) old);
|
||||||
|
+
|
||||||
|
+ const struct scopeentry *oldscope = scopes;
|
||||||
|
+ scopes = new_scopes;
|
||||||
|
+ if (oldscope != default_scopes)
|
||||||
|
+ free ((void *) oldscope);
|
||||||
|
+
|
||||||
|
+ save_gaiconf_mtime (&st);
|
||||||
|
+ return;
|
||||||
|
+
|
||||||
|
+no_file:
|
||||||
|
+ free_prefixlist (labellist);
|
||||||
|
+ free_prefixlist (precedencelist);
|
||||||
|
+ free_scopelist (scopelist);
|
||||||
|
+
|
||||||
|
+ /* If we previously read the file but it is gone now, free the old data and
|
||||||
|
+ use the builtin one. Leave the reload flag alone. */
|
||||||
|
+ fini ();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
90
glibc-RHEL-16643-3.patch
Normal file
90
glibc-RHEL-16643-3.patch
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
commit d3f2c2c8b57bdf9d963db8fa2372d6c1b86a337e
|
||||||
|
Author: Siddhesh Poyarekar <siddhesh@sourceware.org>
|
||||||
|
Date: Tue Mar 22 22:40:05 2022 +0530
|
||||||
|
|
||||||
|
getaddrinfo: Refactor code for readability
|
||||||
|
|
||||||
|
The close_retry goto jump is confusing and clumsy to read, so refactor
|
||||||
|
the code a bit to make it easier to follow.
|
||||||
|
|
||||||
|
Signed-off-by: Siddhesh Poyarekar <siddhesh@sourceware.org>
|
||||||
|
Reviewed-by: DJ Delorie <dj@redhat.com>
|
||||||
|
|
||||||
|
diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c
|
||||||
|
index 1635a09837351068..5e9bd17eb949974c 100644
|
||||||
|
--- a/sysdeps/posix/getaddrinfo.c
|
||||||
|
+++ b/sysdeps/posix/getaddrinfo.c
|
||||||
|
@@ -2253,6 +2253,36 @@ gaiconf_reload (void)
|
||||||
|
gaiconf_init ();
|
||||||
|
}
|
||||||
|
|
||||||
|
+static bool
|
||||||
|
+try_connect (int *fdp, int *afp, struct sockaddr_in6 *source_addrp,
|
||||||
|
+ const struct sockaddr *addr, socklen_t addrlen, int family)
|
||||||
|
+{
|
||||||
|
+ int fd = *fdp;
|
||||||
|
+ int af = *afp;
|
||||||
|
+ socklen_t sl = sizeof (*source_addrp);
|
||||||
|
+
|
||||||
|
+ while (true)
|
||||||
|
+ {
|
||||||
|
+ if (fd != -1 && __connect (fd, addr, addrlen) == 0
|
||||||
|
+ && __getsockname (fd, (struct sockaddr *) source_addrp, &sl) == 0)
|
||||||
|
+ return true;
|
||||||
|
+
|
||||||
|
+ if (errno == EAFNOSUPPORT && af == AF_INET6 && family == AF_INET)
|
||||||
|
+ {
|
||||||
|
+ /* This could mean IPv6 sockets are IPv6-only. */
|
||||||
|
+ if (fd != -1)
|
||||||
|
+ __close_nocancel_nostatus (fd);
|
||||||
|
+ *afp = af = AF_INET;
|
||||||
|
+ *fdp = fd = __socket (AF_INET, SOCK_DGRAM | SOCK_CLOEXEC,
|
||||||
|
+ IPPROTO_IP);
|
||||||
|
+ continue;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return false;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ __builtin_unreachable ();
|
||||||
|
+}
|
||||||
|
|
||||||
|
int
|
||||||
|
getaddrinfo (const char *name, const char *service,
|
||||||
|
@@ -2443,7 +2473,6 @@ getaddrinfo (const char *name, const char *service,
|
||||||
|
if (fd == -1 || (af == AF_INET && q->ai_family == AF_INET6))
|
||||||
|
{
|
||||||
|
if (fd != -1)
|
||||||
|
- close_retry:
|
||||||
|
__close_nocancel_nostatus (fd);
|
||||||
|
af = q->ai_family;
|
||||||
|
fd = __socket (af, SOCK_DGRAM | SOCK_CLOEXEC, IPPROTO_IP);
|
||||||
|
@@ -2455,14 +2484,10 @@ getaddrinfo (const char *name, const char *service,
|
||||||
|
__connect (fd, &sa, sizeof (sa));
|
||||||
|
}
|
||||||
|
|
||||||
|
- socklen_t sl = sizeof (results[i].source_addr);
|
||||||
|
- if (fd != -1
|
||||||
|
- && __connect (fd, q->ai_addr, q->ai_addrlen) == 0
|
||||||
|
- && __getsockname (fd,
|
||||||
|
- (struct sockaddr *) &results[i].source_addr,
|
||||||
|
- &sl) == 0)
|
||||||
|
+ if (try_connect (&fd, &af, &results[i].source_addr, q->ai_addr,
|
||||||
|
+ q->ai_addrlen, q->ai_family))
|
||||||
|
{
|
||||||
|
- results[i].source_addr_len = sl;
|
||||||
|
+ results[i].source_addr_len = sizeof (results[i].source_addr);
|
||||||
|
results[i].got_source_addr = true;
|
||||||
|
|
||||||
|
if (in6ai != NULL)
|
||||||
|
@@ -2527,10 +2552,6 @@ getaddrinfo (const char *name, const char *service,
|
||||||
|
results[i].source_addr_len = sizeof (struct sockaddr_in);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
- else if (errno == EAFNOSUPPORT && af == AF_INET6
|
||||||
|
- && q->ai_family == AF_INET)
|
||||||
|
- /* This could mean IPv6 sockets are IPv6-only. */
|
||||||
|
- goto close_retry;
|
||||||
|
else
|
||||||
|
/* Just make sure that if we have to process the same
|
||||||
|
address again we do not copy any memory. */
|
32
glibc-RHEL-16643-4.patch
Normal file
32
glibc-RHEL-16643-4.patch
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
commit c9226c03da0276593a0918eaa9a14835183343e8
|
||||||
|
Author: Jörg Sonnenberger <joerg@bec.de>
|
||||||
|
Date: Mon Sep 26 13:59:16 2022 -0400
|
||||||
|
|
||||||
|
get_nscd_addresses: Fix subscript typos [BZ #29605]
|
||||||
|
|
||||||
|
Fix the subscript on air->family, which was accidentally set to COUNT
|
||||||
|
when it should have remained as I.
|
||||||
|
|
||||||
|
Resolves: BZ #29605
|
||||||
|
|
||||||
|
Reviewed-by: Siddhesh Poyarekar <siddhesh@sourceware.org>
|
||||||
|
|
||||||
|
diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c
|
||||||
|
index 5e9bd17eb949974c..40a32a3de30cb294 100644
|
||||||
|
--- a/sysdeps/posix/getaddrinfo.c
|
||||||
|
+++ b/sysdeps/posix/getaddrinfo.c
|
||||||
|
@@ -549,11 +549,11 @@ get_nscd_addresses (const char *name, const struct addrinfo *req,
|
||||||
|
at[count].addr[2] = htonl (0xffff);
|
||||||
|
}
|
||||||
|
else if (req->ai_family == AF_UNSPEC
|
||||||
|
- || air->family[count] == req->ai_family)
|
||||||
|
+ || air->family[i] == req->ai_family)
|
||||||
|
{
|
||||||
|
- at[count].family = air->family[count];
|
||||||
|
+ at[count].family = air->family[i];
|
||||||
|
memcpy (at[count].addr, addrs, size);
|
||||||
|
- if (air->family[count] == AF_INET6)
|
||||||
|
+ if (air->family[i] == AF_INET6)
|
||||||
|
res->got_ipv6 = true;
|
||||||
|
}
|
||||||
|
at[count].next = at + count + 1;
|
25
glibc-RHEL-16643-5.patch
Normal file
25
glibc-RHEL-16643-5.patch
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
commit 3bf7bab88b0da01d4f5ef20afbbb45203185501e
|
||||||
|
Author: Siddhesh Poyarekar <siddhesh@sourceware.org>
|
||||||
|
Date: Tue Sep 5 17:04:05 2023 -0400
|
||||||
|
|
||||||
|
getcanonname: Fix a typo
|
||||||
|
|
||||||
|
This code is generally unused in practice since there don't seem to be
|
||||||
|
any NSS modules that only implement _nss_MOD_gethostbyname2_r and not
|
||||||
|
_nss_MOD_gethostbyname3_r.
|
||||||
|
|
||||||
|
Signed-off-by: Siddhesh Poyarekar <siddhesh@sourceware.org>
|
||||||
|
|
||||||
|
diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c
|
||||||
|
index 40a32a3de30cb294..e9f47aea358a3351 100644
|
||||||
|
--- a/sysdeps/posix/getaddrinfo.c
|
||||||
|
+++ b/sysdeps/posix/getaddrinfo.c
|
||||||
|
@@ -346,7 +346,7 @@ getcanonname (nss_action_list nip, const char *hname, const char *name)
|
||||||
|
string. */
|
||||||
|
s = (char *) name;
|
||||||
|
}
|
||||||
|
- return __strdup (name);
|
||||||
|
+ return __strdup (s);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Process looked up canonical name and if necessary, decode to IDNA. Result
|
23
glibc-RHEL-16643-6.patch
Normal file
23
glibc-RHEL-16643-6.patch
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
commit 61bac1a9d2ab80ebcbc51484722e6ea43414bec7
|
||||||
|
Author: Florian Weimer <fweimer@redhat.com>
|
||||||
|
Date: Wed Dec 20 16:14:33 2023 +0100
|
||||||
|
|
||||||
|
nss: Remove unused allocation from get_nscd_addresses in getaddrinfo
|
||||||
|
|
||||||
|
No bug because this is not visible if glibc is built with
|
||||||
|
optimization. Otherwise this would be a critical resource leak.
|
||||||
|
|
||||||
|
Reviewed-by: Carlos O'Donell <carlos@redhat.com>
|
||||||
|
|
||||||
|
diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c
|
||||||
|
index e9f47aea358a3351..321a6679d46494a3 100644
|
||||||
|
--- a/sysdeps/posix/getaddrinfo.c
|
||||||
|
+++ b/sysdeps/posix/getaddrinfo.c
|
||||||
|
@@ -514,7 +514,6 @@ get_nscd_addresses (const char *name, const struct addrinfo *req,
|
||||||
|
int result = 0;
|
||||||
|
char *addrs = air->addrs;
|
||||||
|
|
||||||
|
- struct gaih_addrtuple *addrfree = calloc (air->naddrs, sizeof (*addrfree));
|
||||||
|
struct gaih_addrtuple *at = calloc (air->naddrs, sizeof (*at));
|
||||||
|
if (at == NULL)
|
||||||
|
{
|
11
glibc.spec
11
glibc.spec
@ -155,7 +155,7 @@ end \
|
|||||||
Summary: The GNU libc libraries
|
Summary: The GNU libc libraries
|
||||||
Name: glibc
|
Name: glibc
|
||||||
Version: %{glibcversion}
|
Version: %{glibcversion}
|
||||||
Release: 97%{?dist}
|
Release: 98%{?dist}
|
||||||
|
|
||||||
# In general, GPLv2+ is used by programs, LGPLv2+ is used for
|
# In general, GPLv2+ is used by programs, LGPLv2+ is used for
|
||||||
# libraries.
|
# libraries.
|
||||||
@ -800,6 +800,12 @@ Patch563: glibc-RHEL-17319-4.patch
|
|||||||
Patch564: glibc-RHEL-17465-1.patch
|
Patch564: glibc-RHEL-17465-1.patch
|
||||||
Patch565: glibc-RHEL-17465-2.patch
|
Patch565: glibc-RHEL-17465-2.patch
|
||||||
Patch566: glibc-RHEL-19862.patch
|
Patch566: glibc-RHEL-19862.patch
|
||||||
|
Patch567: glibc-RHEL-16643-1.patch
|
||||||
|
Patch568: glibc-RHEL-16643-2.patch
|
||||||
|
Patch569: glibc-RHEL-16643-3.patch
|
||||||
|
Patch570: glibc-RHEL-16643-4.patch
|
||||||
|
Patch571: glibc-RHEL-16643-5.patch
|
||||||
|
Patch572: glibc-RHEL-16643-6.patch
|
||||||
|
|
||||||
##############################################################################
|
##############################################################################
|
||||||
# Continued list of core "glibc" package information:
|
# Continued list of core "glibc" package information:
|
||||||
@ -2958,6 +2964,9 @@ update_gconv_modules_cache ()
|
|||||||
%endif
|
%endif
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Mon Jan 8 2024 Arjun Shankar <arjun@redhat.com> - 2.34-98
|
||||||
|
- getaddrinfo: Fix occasionally empty result due to nscd cache order (RHEL-16643)
|
||||||
|
|
||||||
* Tue Jan 2 2024 Florian Weimer <fweimer@redhat.com> - 2.34-97
|
* Tue Jan 2 2024 Florian Weimer <fweimer@redhat.com> - 2.34-97
|
||||||
- Re-enable output buffering for wide stdio streams (RHEL-19862)
|
- Re-enable output buffering for wide stdio streams (RHEL-19862)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user