mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-03 03:25:20 +00:00
nss: aiforaf: Decrease stack size by scoping off large buffers
The 'buf', 'sa' and 'hints' stack allocated helper variables are never used together. Decrease the stack memory usage by scoping them off into do-while blocks. In this instance we do not want to use dynamic allocation as this is the NSS module. Signed-off-by: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Kristina Hanicova <khanicov@redhat.com>
This commit is contained in:
parent
575e7fe963
commit
9e5f2fe402
@ -470,29 +470,35 @@ aiforaf(const char *name,
|
||||
struct addrinfo **aip)
|
||||
{
|
||||
struct hostent resolved;
|
||||
char buf[1024] = { 0 };
|
||||
int err;
|
||||
int herr;
|
||||
struct addrinfo hints;
|
||||
struct addrinfo *res0;
|
||||
struct addrinfo *res;
|
||||
char **addrList;
|
||||
|
||||
/* Note: The do-while blocks in this function are used to scope off large
|
||||
* stack allocated buffers, which are not needed at the same time */
|
||||
do {
|
||||
char buf[1024] = { 0 };
|
||||
int herr;
|
||||
|
||||
if (NSS_NAME(gethostbyname2)(name, af, &resolved,
|
||||
buf, sizeof(buf),
|
||||
&err, &herr) != NS_SUCCESS)
|
||||
return;
|
||||
} while (false);
|
||||
|
||||
addrList = resolved.h_addr_list;
|
||||
while (*addrList) {
|
||||
void *address = *addrList;
|
||||
char host[NI_MAXHOST];
|
||||
struct addrinfo *res0;
|
||||
struct addrinfo *res;
|
||||
|
||||
do {
|
||||
union {
|
||||
struct sockaddr sa;
|
||||
struct sockaddr_in sin;
|
||||
struct sockaddr_in6 sin6;
|
||||
} sa = { 0 };
|
||||
socklen_t salen;
|
||||
void *address = *addrList;
|
||||
char host[NI_MAXHOST];
|
||||
|
||||
if (resolved.h_addrtype == AF_INET) {
|
||||
sa.sin.sin_family = AF_INET;
|
||||
@ -508,20 +514,29 @@ aiforaf(const char *name,
|
||||
salen = sizeof(sa.sin6);
|
||||
}
|
||||
|
||||
if ((err = getnameinfo(&sa.sa, salen,
|
||||
err = getnameinfo(&sa.sa, salen,
|
||||
host, sizeof(host),
|
||||
NULL, 0,
|
||||
NI_NUMERICHOST | NI_NUMERICSERV)) != 0) {
|
||||
NI_NUMERICHOST | NI_NUMERICSERV);
|
||||
} while (false);
|
||||
|
||||
if (err != 0) {
|
||||
ERROR("Cannot convert socket address to string: %s",
|
||||
gai_strerror(err));
|
||||
continue;
|
||||
}
|
||||
|
||||
do {
|
||||
struct addrinfo hints;
|
||||
|
||||
hints = *pai;
|
||||
hints.ai_flags = AI_NUMERICHOST;
|
||||
hints.ai_family = af;
|
||||
|
||||
if (getaddrinfo(host, NULL, &hints, &res0)) {
|
||||
err = getaddrinfo(host, NULL, &hints, &res0);
|
||||
} while (false);
|
||||
|
||||
if (err != 0) {
|
||||
addrList++;
|
||||
continue;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user