Commit a59a4441 authored by unknown's avatar unknown

Backport of JimW's localhost patch to 4.1 tree.

Handle systems like default FC4 where 127.0.0.1 doesn't always map to 'localhost' first. 
(Bug #11822)


sql/hostname.cc:
  Short-circuit ip_to_hostname() lookup for INADDR_LOOPBACK to allways return 'localhost'.
sql/sql_parse.cc:
  Push special handling of 127.0.0.1 into ip_to_hostname().
parent cbb1da77
...@@ -130,15 +130,23 @@ void reset_host_errors(struct in_addr *in) ...@@ -130,15 +130,23 @@ void reset_host_errors(struct in_addr *in)
VOID(pthread_mutex_unlock(&hostname_cache->lock)); VOID(pthread_mutex_unlock(&hostname_cache->lock));
} }
/* Deal with systems that don't defined INADDR_LOOPBACK */
#ifndef INADDR_LOOPBACK
#define INADDR_LOOPBACK 0x7f000001UL
#endif
my_string ip_to_hostname(struct in_addr *in, uint *errors) my_string ip_to_hostname(struct in_addr *in, uint *errors)
{ {
uint i; uint i;
host_entry *entry; host_entry *entry;
DBUG_ENTER("ip_to_hostname"); DBUG_ENTER("ip_to_hostname");
*errors= 0;
/* We always treat the loopback address as "localhost". */
if (in->s_addr == htonl(INADDR_LOOPBACK))
DBUG_RETURN((char *)my_localhost);
/* Check first if we have name in cache */ /* Check first if we have name in cache */
*errors=0;
if (!(specialflag & SPECIAL_NO_HOST_CACHE)) if (!(specialflag & SPECIAL_NO_HOST_CACHE))
{ {
VOID(pthread_mutex_lock(&hostname_cache->lock)); VOID(pthread_mutex_lock(&hostname_cache->lock));
......
...@@ -696,29 +696,19 @@ static int check_connection(THD *thd) ...@@ -696,29 +696,19 @@ static int check_connection(THD *thd)
return (ER_OUT_OF_RESOURCES); return (ER_OUT_OF_RESOURCES);
thd->host_or_ip= thd->ip; thd->host_or_ip= thd->ip;
vio_in_addr(net->vio,&thd->remote.sin_addr); vio_in_addr(net->vio,&thd->remote.sin_addr);
#if !defined(HAVE_SYS_UN_H) || defined(HAVE_mit_thread) if (!(specialflag & SPECIAL_NO_RESOLVE))
/* Fast local hostname resolve for Win32 */
if (!strcmp(thd->ip,"127.0.0.1"))
{ {
thd->host= (char*) my_localhost; vio_in_addr(net->vio,&thd->remote.sin_addr);
thd->host_or_ip= my_localhost; thd->host=ip_to_hostname(&thd->remote.sin_addr,&connect_errors);
} /* Cut very long hostnames to avoid possible overflows */
else if (thd->host)
#endif
{
if (!(specialflag & SPECIAL_NO_RESOLVE))
{ {
vio_in_addr(net->vio,&thd->remote.sin_addr); if (thd->host != my_localhost)
thd->host=ip_to_hostname(&thd->remote.sin_addr,&connect_errors); thd->host[min(strlen(thd->host), HOSTNAME_LENGTH)]= 0;
/* Cut very long hostnames to avoid possible overflows */ thd->host_or_ip= thd->host;
if (thd->host)
{
thd->host[min(strlen(thd->host), HOSTNAME_LENGTH)]= 0;
thd->host_or_ip= thd->host;
}
if (connect_errors > max_connect_errors)
return(ER_HOST_IS_BLOCKED);
} }
if (connect_errors > max_connect_errors)
return(ER_HOST_IS_BLOCKED);
} }
DBUG_PRINT("info",("Host: %s ip: %s", DBUG_PRINT("info",("Host: %s ip: %s",
thd->host ? thd->host : "unknown host", thd->host ? thd->host : "unknown host",
......
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