/* These macros are return values from extractAddr. They do not represent
* any valid IP address and so can indicate a failure.
*/
-#define AFS_IPINVALID 0xffffffff /* invalid IP address */
-#define AFS_IPINVALIDIGNORE 0xfffffffe /* no input given to extractAddr */
+#define AFS_IPINVALID 0xffffffff /* invalid IP address */
+#define AFS_IPINVALIDIGNORE 0xfffffffe /* no input given to extractAddr */
/* logging defines
*/
+#ifndef AFS_NT40_ENV
+#include <sys/types.h>
+#include <sys/socket.h>
+#include <netinet/in.h>
+#include <arpa/inet.h> /* for inet_ntoa() */
+#endif
+
#include <stdio.h>
#include <stdarg.h>
+
extern int LogLevel;
+extern int mrafsStyleLogs;
#ifndef AFS_NT40_ENV
extern int serverLogSyslog;
extern int serverLogSyslogFacility;
+extern char *serverLogSyslogTag;
#endif
-extern void FSLog(const char *format, ...);
-#define ViceLog(level, str) if ((level) <= LogLevel) (FSLog str)
+extern void vFSLog(const char *format, va_list args);
+extern void SetLogThreadNumProgram(int (*func) (void) );
+
+/*@printflike@*/ extern void FSLog(const char *format, ...);
+#define ViceLog(level, str) do { if ((level) <= LogLevel) (FSLog str) } while (0)
+#define vViceLog(level, str) do { if ((level) <= LogLevel) (vFSLog str) } while (0)
extern int OpenLog(const char *filename);
extern int ReOpenLog(const char *fileName);
extern void SetupLogSignals(void);
+extern int
+afs_vsnprintf( /*@out@ */ char *p, size_t avail, const char *fmt,
+ va_list ap)
+ /*@requires maxSet(p) >= (avail-1)@ */
+ /*@modifies p@ */ ;
+
+ extern /*@printflike@ */ int
+ afs_snprintf( /*@out@ */ char *p, size_t avail,
+ const char *fmt, ...)
+ /*@requires maxSet(p) >= (avail-1)@ */
+ /*@modifies p@ */ ;
+
/* special version of ctime that clobbers a *different static variable, so
* that ViceLog can call ctime and not cause buffer confusion.
*/
-extern char *vctime(const time_t *atime);
+ extern char *vctime(const time_t * atime);
/* Need a thead safe ctime for pthread builds. Use std ctime for LWP */
#if defined(AFS_PTHREAD_ENV) && !defined(AFS_NT40_ENV)
-#ifdef AFS_SUN5_ENV
+#if defined(AFS_SUN5_ENV) && !defined(_POSIX_PTHREAD_SEMANTICS) && (_POSIX_C_SOURCE - 0 < 199506L)
#define afs_ctime(C, B, L) ctime_r(C, B, L)
#else
/* Cast is for platforms which do not prototype ctime_r */
#else /* AFS_PTHREAD_ENV && !AFS_NT40_ENV */
#define afs_ctime(C, B, S) \
((void)strncpy(B, ctime(C), (S-1)), (B)[S-1] = '\0', (B))
-#endif /* AFS_PTHREAD_ENV && !AFS_NT40_ENV */
+#endif /* AFS_PTHREAD_ENV && !AFS_NT40_ENV */
/* abort the current process. */
#endif /* _MFC_VER */
/* Initialize the windows sockets before calling networking routines. */
-extern int afs_winsockInit(void);
+ extern int afs_winsockInit(void);
+ extern void afs_winsockCleanup(void);
-struct timezone {
- int tz_minuteswest; /* of Greenwich */
- int tz_dsttime; /* type of dst correction to apply */
-};
+ struct timezone {
+ int tz_minuteswest; /* of Greenwich */
+ int tz_dsttime; /* type of dst correction to apply */
+ };
#define gettimeofday afs_gettimeofday
-int afs_gettimeofday(struct timeval *tv, struct timezone *tz);
+ int afs_gettimeofday(struct timeval *tv, struct timezone *tz);
/* Unbuffer output when Un*x would do line buffering. */
#define setlinebuf(S) setvbuf(S, NULL, _IONBF, 0)
/* regular expression parser for NT */
-extern char *re_comp(char *sp);
-extern int rc_exec(char *p);
+ extern char *re_comp(char *sp);
+ extern int rc_exec(char *p);
/* Abort on error, possibly trapping to debugger or dumping a trace. */
-void afs_NTAbort(void);
+ void afs_NTAbort(void);
#endif /* NT40 */
-typedef char b32_string_t[8];
+ typedef char b32_string_t[8];
/* b64_string_t is 8 bytes, in stds.h */
-typedef char lb64_string_t[12];
+ typedef char lb64_string_t[12];
#ifndef UKERNEL
#include "afs/ktime.h"