Re: Invalid pg_hba.conf => Postgres crash - Mailing list pgsql-hackers

From Tom Lane
Subject Re: Invalid pg_hba.conf => Postgres crash
Date
Msg-id 13531.1082837599@sss.pgh.pa.us
Whole thread Raw
In response to Invalid pg_hba.conf => Postgres crash  (Gaetano Mendola <mendola@bigfoot.com>)
Responses Re: Invalid pg_hba.conf => Postgres crash
List pgsql-hackers
Gaetano Mendola <mendola@bigfoot.com> writes:
>   host   all    all    127.0.0.1    trust   sameuser     # HANG
> the future connections will hang leaving a postgres process
> running
> - Inserting the following line instead will crash postgres
>   host  all     127.0.0.1             trust   sameuser        # CRASH

I was able to reproduce the crash but not the hang.  Would you see if
the attached patch fixes both symptoms on your machine?
        regards, tom lane

Index: ip.c
===================================================================
RCS file: /cvsroot/pgsql-server/src/backend/libpq/ip.c,v
retrieving revision 1.23
diff -c -r1.23 ip.c
*** ip.c    12 Sep 2003 20:18:51 -0000    1.23
--- ip.c    24 Apr 2004 20:09:21 -0000
***************
*** 67,74 ****  */ int getaddrinfo_all(const char *hostname, const char *servname,
!                 const struct addrinfo * hintp, struct addrinfo ** result) { #ifdef HAVE_UNIX_SOCKETS     if (hintp !=
NULL&& hintp->ai_family == AF_UNIX)         return getaddrinfo_unix(servname, hintp, result);
 
--- 67,77 ----  */ int getaddrinfo_all(const char *hostname, const char *servname,
!                 const struct addrinfo *hintp, struct addrinfo **result) {
+     /* not all versions of getaddrinfo() zero *result on failure */
+     *result = NULL;
+  #ifdef HAVE_UNIX_SOCKETS     if (hintp != NULL && hintp->ai_family == AF_UNIX)         return
getaddrinfo_unix(servname,hintp, result);
 


pgsql-hackers by date:

Previous
From: Jordan Henderson
Date:
Subject: Re: What can we learn from MySQL?
Next
From: Alvaro Herrera
Date:
Subject: Re: Current CVS tip segfaulting