X-Git-Url: https://git.exim.org/exim.git/blobdiff_plain/e08d09e542c8cefad1e5740610644bb2c5b79d76..ddf1b11a732e293cd242c80bc63d459dda595bf4:/src/OS/os.h-Linux diff --git a/src/OS/os.h-Linux b/src/OS/os.h-Linux index 14441e684..6400e798e 100644 --- a/src/OS/os.h-Linux +++ b/src/OS/os.h-Linux @@ -1,7 +1,12 @@ -/* $Cambridge: exim/src/OS/os.h-Linux,v 1.6 2007/10/04 13:23:05 tom Exp $ */ - /* Exim: OS-specific C header file for Linux */ +/* Some old systems we've received bug-reports for have a which +does not pull in . Best to just pull it in now and have done +with the issue. */ + +#include + + #define CRYPT_H #define GLIBC_IP_OPTIONS #define HAVE_MMAP @@ -10,10 +15,10 @@ #define NO_IP_VAR_H #define SIG_IGN_WORKS -/* When using the experimental Domainkeys/DKIM extensions, setting -HAVE_LINUX_SENDFILE can increase performance on outgoing mail a bit. -Note: With older glibc versions this setting will conflict with the -_FILE_OFFSET_BITS=64 setting defined as part of the Linux CFLAGS. */ +/* When using the DKIM, setting HAVE_LINUX_SENDFILE can increase +performance on outgoing mail a bit. Note: With older glibc versions +this setting will conflict with the _FILE_OFFSET_BITS=64 setting +defined as part of the Linux CFLAGS. */ /* #define HAVE_LINUX_SENDFILE */ @@ -39,9 +44,6 @@ storage" as quickly as Exim thinks they are. */ #define NEED_SYNC_DIRECTORY -/* Other OS have "const" in here */ -#define ICONV_ARG2_TYPE char ** - #define os_find_running_interfaces os_find_running_interfaces_linux /* Need a prototype for the Linux-specific function. The structure hasn't @@ -52,9 +54,20 @@ extern struct ip_address_item *os_find_running_interfaces_linux(void); #endif /* __linux__ */ -/* End */ +/* Some folks running "unusual" setups with very old libc environments have +found that _GNU_SOURCE=1 before is not sufficient to define some +constants needed for 64-bit arithmetic. If you encounter build errors based +on LLONG_MIN being undefined and various other escape hatches have not helped, +then change the 0 to 1 in the next block. */ -/* Fudge added because this Linux doesn't appear to have a definition -for ip_options in /usr/include/linux/ip.h. */ +#if 0 +# define LLONG_MIN LONG_LONG_MIN +# define LLONG_MAX LONG_LONG_MAX +#endif + +#if _POSIX_C_SOURCE >= 200809L || _ATFILE_SOUCE +# define EXIM_HAVE_OPENAT +#endif -#define ip_options options + +/* End */