EAI_NODATA deprecated, not always defined
authorKen Raeburn <raeburn@mit.edu>
Mon, 9 Apr 2007 20:58:13 +0000 (20:58 +0000)
committerKen Raeburn <raeburn@mit.edu>
Mon, 9 Apr 2007 20:58:13 +0000 (20:58 +0000)
Brian Kantor reports (on the kerberos@mit list today) that krb5-1.6
doesn't build on FreeBSD 6.1 because they've done away with
EAI_NODATA, which was removed from the getaddrinfo API in RFC 3943.

This patch conditionalizes two tests for EAI_NODATA on the macro being
defined, and also adds handling for EAI_OVERFLOW, a new error code
added in RFC 3943.

ticket: new
tags: pullup
target_version: 1.6.1

git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@19410 dc483132-0cff-0310-8789-dd5450dbe970

src/lib/krb5/os/hst_realm.c
src/lib/krb5/os/locate_kdc.c

index e6601644189a60539eb5fa46540537afbeb2da70..7e24b8d6de050c9d80602cd025d0c59e4b15e8b8 100644 (file)
@@ -302,12 +302,16 @@ krb5int_translate_gai_error (int num)
        return EAFNOSUPPORT;
     case EAI_MEMORY:
        return ENOMEM;
-#if EAI_NODATA != EAI_NONAME
+#if defined(EAI_NODATA) && EAI_NODATA != EAI_NONAME
     case EAI_NODATA:
        return KRB5_EAI_NODATA;
 #endif
     case EAI_NONAME:
        return KRB5_EAI_NONAME;
+#if defined(EAI_OVERFLOW)
+    case EAI_OVERFLOW:
+       return EINVAL;          /* XXX */
+#endif
     case EAI_SERVICE:
        return KRB5_EAI_SERVICE;
     case EAI_SOCKTYPE:
index a59fc63b35a42f43e99a4a3ddc399f4ac3b0b734..566213d35fb174dc71fe7507da69d7eda1beb911 100644 (file)
@@ -157,13 +157,18 @@ static int translate_ai_error (int err)
 #ifdef EAI_ADDRFAMILY
     case EAI_ADDRFAMILY:
 #endif
-#if EAI_NODATA != EAI_NONAME
+#if defined(EAI_NODATA) && EAI_NODATA != EAI_NONAME
     case EAI_NODATA:
 #endif
     case EAI_NONAME:
        /* Name not known or no address data, but no error.  Do
           nothing more.  */
        return 0;
+#ifdef EAI_OVERFLOW
+    case EAI_OVERFLOW:
+       /* An argument buffer overflowed.  */
+       return EINVAL;          /* XXX */
+#endif
 #ifdef EAI_SYSTEM
     case EAI_SYSTEM:
        /* System error, obviously.  */