Commit 627caa30 authored by Sergei Golubchik's avatar Sergei Golubchik

fix the error message when getaddrinfo() fails. on windows "*" doesn't mean "any address"

parent 75f0f170
...@@ -2366,6 +2366,7 @@ static MYSQL_SOCKET activate_tcp_port(uint port) ...@@ -2366,6 +2366,7 @@ static MYSQL_SOCKET activate_tcp_port(uint port)
int error; int error;
int arg; int arg;
char port_buf[NI_MAXSERV]; char port_buf[NI_MAXSERV];
const char *real_bind_addr_str;
MYSQL_SOCKET ip_sock= MYSQL_INVALID_SOCKET; MYSQL_SOCKET ip_sock= MYSQL_INVALID_SOCKET;
DBUG_ENTER("activate_tcp_port"); DBUG_ENTER("activate_tcp_port");
DBUG_PRINT("general",("IP Socket is %d",port)); DBUG_PRINT("general",("IP Socket is %d",port));
...@@ -2374,13 +2375,19 @@ static MYSQL_SOCKET activate_tcp_port(uint port) ...@@ -2374,13 +2375,19 @@ static MYSQL_SOCKET activate_tcp_port(uint port)
hints.ai_flags= AI_PASSIVE; hints.ai_flags= AI_PASSIVE;
hints.ai_socktype= SOCK_STREAM; hints.ai_socktype= SOCK_STREAM;
hints.ai_family= AF_UNSPEC; hints.ai_family= AF_UNSPEC;
if (my_bind_addr_str && strcmp(my_bind_addr_str, "*") == 0)
real_bind_addr_str= NULL; // windows doesn't seem to support * here
else
real_bind_addr_str= my_bind_addr_str;
my_snprintf(port_buf, NI_MAXSERV, "%d", port); my_snprintf(port_buf, NI_MAXSERV, "%d", port);
error= getaddrinfo(my_bind_addr_str, port_buf, &hints, &ai); error= getaddrinfo(real_bind_addr_str, port_buf, &hints, &ai);
if (error != 0) if (error != 0)
{ {
DBUG_PRINT("error",("Got error: %d from getaddrinfo()", error)); DBUG_PRINT("error",("Got error: %d from getaddrinfo()", error));
sql_perror(ER_DEFAULT(ER_IPSOCK_ERROR)); /* purecov: tested */
sql_print_error("%s: %s", ER_DEFAULT(ER_IPSOCK_ERROR), gai_strerror(error));
unireg_abort(1); /* purecov: tested */ unireg_abort(1); /* purecov: tested */
} }
...@@ -2389,8 +2396,7 @@ static MYSQL_SOCKET activate_tcp_port(uint port) ...@@ -2389,8 +2396,7 @@ static MYSQL_SOCKET activate_tcp_port(uint port)
because we later switch off IPV6_V6ONLY, so ipv6 wildcard because we later switch off IPV6_V6ONLY, so ipv6 wildcard
addresses will work for ipv4 too addresses will work for ipv4 too
*/ */
if ((my_bind_addr_str == NULL || strcmp(my_bind_addr_str, "*") == 0) if (!real_bind_addr_str && ai->ai_family == AF_INET && ai->ai_next
&& ai->ai_family == AF_INET && ai->ai_next
&& ai->ai_next->ai_family == AF_INET6) && ai->ai_next->ai_family == AF_INET6)
{ {
a= ai; a= ai;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment