1ddeb0
diff -up cyrus-sasl-2.1.27/configure.ac.sizes cyrus-sasl-2.1.27/configure.ac
1ddeb0
--- cyrus-sasl-2.1.27/configure.ac.sizes	2015-11-18 09:46:24.000000000 +0100
1ddeb0
+++ cyrus-sasl-2.1.27/configure.ac	2015-11-20 15:11:20.474588247 +0100
1ddeb0
@@ -1312,6 +1312,10 @@ AC_HEADER_STDC
1ddeb0
 AC_HEADER_DIRENT
1ddeb0
 AC_HEADER_SYS_WAIT
1ddeb0
 AC_CHECK_HEADERS(crypt.h des.h dlfcn.h fcntl.h limits.h malloc.h paths.h strings.h sys/file.h sys/time.h syslog.h unistd.h inttypes.h sys/uio.h sys/param.h sysexits.h stdarg.h varargs.h krb5.h)
1ddeb0
+AC_CHECK_TYPES([long long, int8_t, uint8_t, int16_t, uint16_t, int32_t, uint32_t, int64_t, uint64_t],,,[
1ddeb0
+#ifdef HAVE_INTTYPES_H
1ddeb0
+#include <inttypes.h>
1ddeb0
+#endif])
1ddeb0
 
1ddeb0
 IPv6_CHECK_SS_FAMILY()
1ddeb0
 IPv6_CHECK_SA_LEN()
1ddeb0
diff -up cyrus-sasl-2.1.27/include/makemd5.c.sizes cyrus-sasl-2.1.27/include/makemd5.c
1ddeb0
--- cyrus-sasl-2.1.27/include/makemd5.c.sizes	2015-10-15 15:44:43.000000000 +0200
1ddeb0
+++ cyrus-sasl-2.1.27/include/makemd5.c	2015-11-20 15:11:20.477588240 +0100
1ddeb0
@@ -82,12 +82,19 @@
1ddeb0
  */
1ddeb0
 
1ddeb0
 
1ddeb0
+#ifdef HAVE_CONFIG_H
1ddeb0
+#include "../config.h"
1ddeb0
+#endif
1ddeb0
 
1ddeb0
 #include <stdio.h>
1ddeb0
 #include <string.h>
1ddeb0
 #include <stdlib.h>
1ddeb0
 #include <ctype.h>
1ddeb0
 
1ddeb0
+#ifdef HAVE_INTTYPES_H
1ddeb0
+#include <inttypes.h>
1ddeb0
+#endif
1ddeb0
+
1ddeb0
 
1ddeb0
 static void
1ddeb0
 my_strupr(char *s)
1ddeb0
@@ -122,6 +129,18 @@ my_strupr(char *s)
1ddeb0
 static void
1ddeb0
 try_signed(FILE *f, int len)
1ddeb0
 {
1ddeb0
+#ifdef HAVE_INT8_T
1ddeb0
+    BITSIZE(int8_t);
1ddeb0
+#endif
1ddeb0
+#ifdef HAVE_INT16_T
1ddeb0
+    BITSIZE(int16_t);
1ddeb0
+#endif
1ddeb0
+#ifdef HAVE_INT32_T
1ddeb0
+    BITSIZE(int32_t);
1ddeb0
+#endif
1ddeb0
+#ifdef HAVE_INT64_T
1ddeb0
+    BITSIZE(int64_t);
1ddeb0
+#endif
1ddeb0
     BITSIZE(signed char);
1ddeb0
     BITSIZE(short);
1ddeb0
     BITSIZE(int);
1ddeb0
@@ -135,6 +154,18 @@ try_signed(FILE *f, int len)
1ddeb0
 static void
1ddeb0
 try_unsigned(FILE *f, int len)
1ddeb0
 {
1ddeb0
+#ifdef HAVE_UINT8_T
1ddeb0
+    BITSIZE(uint8_t);
1ddeb0
+#endif
1ddeb0
+#ifdef HAVE_UINT16_T
1ddeb0
+    BITSIZE(uint16_t);
1ddeb0
+#endif
1ddeb0
+#ifdef HAVE_UINT32_T
1ddeb0
+    BITSIZE(uint32_t);
1ddeb0
+#endif
1ddeb0
+#ifdef HAVE_UINT64_T
1ddeb0
+    BITSIZE(uint64_t);
1ddeb0
+#endif
1ddeb0
     BITSIZE(unsigned char);
1ddeb0
     BITSIZE(unsigned short);
1ddeb0
     BITSIZE(unsigned int);
1ddeb0
@@ -165,6 +196,11 @@ static int print_pre(FILE *f)
1ddeb0
 	  "/* POINTER defines a generic pointer type */\n"
1ddeb0
 	  "typedef unsigned char *POINTER;\n"
1ddeb0
 	  "\n"
1ddeb0
+#ifdef HAVE_INTTYPES_H
1ddeb0
+	  "/* We try to define integer types for our use */\n"
1ddeb0
+	  "#include <inttypes.h>\n"
1ddeb0
+	  "\n"
1ddeb0
+#endif
1ddeb0
 	  );
1ddeb0
   return 1;
1ddeb0
 }
1ddeb0
@@ -212,31 +248,15 @@ int main(int argc, char **argv)
1ddeb0
 
1ddeb0
   print_pre(f);
1ddeb0
 
1ddeb0
-#ifndef HAVE_INT8_T
1ddeb0
     try_signed (f, 8);
1ddeb0
-#endif /* HAVE_INT8_T */
1ddeb0
-#ifndef HAVE_INT16_T
1ddeb0
     try_signed (f, 16);
1ddeb0
-#endif /* HAVE_INT16_T */
1ddeb0
-#ifndef HAVE_INT32_T
1ddeb0
     try_signed (f, 32);
1ddeb0
-#endif /* HAVE_INT32_T */
1ddeb0
-#ifndef HAVE_INT64_T
1ddeb0
     try_signed (f, 64);
1ddeb0
-#endif /* HAVE_INT64_T */
1ddeb0
 
1ddeb0
-#ifndef HAVE_U_INT8_T
1ddeb0
     try_unsigned (f, 8);
1ddeb0
-#endif /* HAVE_INT8_T */
1ddeb0
-#ifndef HAVE_U_INT16_T
1ddeb0
     try_unsigned (f, 16);
1ddeb0
-#endif /* HAVE_U_INT16_T */
1ddeb0
-#ifndef HAVE_U_INT32_T
1ddeb0
     try_unsigned (f, 32);
1ddeb0
-#endif /* HAVE_U_INT32_T */
1ddeb0
-#ifndef HAVE_U_INT64_T
1ddeb0
     try_unsigned (f, 64);
1ddeb0
-#endif /* HAVE_U_INT64_T */
1ddeb0
 
1ddeb0
     print_post(f);
1ddeb0