diff options
Diffstat (limited to 'contrib/ntp/include/ntp_stdlib.h')
-rw-r--r-- | contrib/ntp/include/ntp_stdlib.h | 307 |
1 files changed, 307 insertions, 0 deletions
diff --git a/contrib/ntp/include/ntp_stdlib.h b/contrib/ntp/include/ntp_stdlib.h new file mode 100644 index 000000000000..6f667fbabed7 --- /dev/null +++ b/contrib/ntp/include/ntp_stdlib.h @@ -0,0 +1,307 @@ +/* + * ntp_stdlib.h - Prototypes for NTP lib. + */ +#ifndef NTP_STDLIB_H +#define NTP_STDLIB_H + +#include <sys/types.h> +#ifdef HAVE_SYS_SOCKET_H +#include <sys/socket.h> +#endif + +#include "declcond.h" /* ntpd uses ntpd/declcond.h, others include/ */ +#include "l_stdlib.h" +#include "lib_strbuf.h" +#include "ntp_md5.h" +#include "ntp_net.h" +#include "ntp_debug.h" +#include "ntp_malloc.h" +#include "lib_strbuf.h" +#include "ntp_string.h" +#include "ntp_syslog.h" +#include "ntp_keyacc.h" + +#ifndef PATH_MAX +# define PATH_MAX MAX_PATH +#endif + +#ifdef __GNUC__ +#define NTP_PRINTF(fmt, args) __attribute__((__format__(__printf__, fmt, args))) +#else +#define NTP_PRINTF(fmt, args) +#endif + +extern int mprintf(const char *, ...) NTP_PRINTF(1, 2); +extern int mfprintf(FILE *, const char *, ...) NTP_PRINTF(2, 3); +extern int mvfprintf(FILE *, const char *, va_list) NTP_PRINTF(2, 0); +extern int mvsnprintf(char *, size_t, const char *, va_list) + NTP_PRINTF(3, 0); +extern int msnprintf(char *, size_t, const char *, ...) + NTP_PRINTF(3, 4); +extern void msyslog(int, const char *, ...) NTP_PRINTF(2, 3); +extern void mvsyslog(int, const char *, va_list) NTP_PRINTF(2, 0); +extern void init_logging (const char *, u_int32, int); +extern int change_logfile (const char *, int); +extern void setup_logfile (const char *); +#ifndef errno_to_str /* Windows port defines this */ +extern void errno_to_str(int, char *, size_t); +#endif + +extern char * ntp_realpath(const char *fsname); + +extern int xvsbprintf(char **, char * const, char const *, va_list) + NTP_PRINTF(3, 0); +extern int xsbprintf(char **, char * const, char const *, ...) + NTP_PRINTF(3, 4); + +#define SAVE_ERRNO(stmt) \ + { \ + int preserved_errno; \ + \ + preserved_errno = socket_errno(); \ + { \ + stmt \ + } \ + errno = preserved_errno; \ + } + +typedef void (*ctrl_c_fn)(void); + +/* authkeys.c */ +#define AUTHPWD_MAXSECLEN 64 /* max. length of secret blob */ + +enum AuthPwdEnc { + AUTHPWD_UNSPEC, /* format unspecified, length used for discrimination */ + AUTHPWD_PLAIN, /* plain text, used as is */ + AUTHPWD_HEX /* hex-encoded string */ +}; + +extern void auth_delkeys (void); +extern int auth_havekey (keyid_t); +extern size_t authdecodepw (u_char *dst, size_t dstlen, const char *src, enum AuthPwdEnc); +extern int authdecrypt (keyid_t, u_int32 *, size_t, size_t); +extern size_t authencrypt (keyid_t, u_int32 *, size_t); +extern int authhavekey (keyid_t); +extern int authistrusted (keyid_t); +extern int authistrustedip (keyid_t, sockaddr_u *); +extern int authreadkeys (const char *); +extern void authtrust (keyid_t, u_long); +extern int authusekey (keyid_t, int, const u_char *); + +/* + * Based on the NTP timestamp, calculate the NTP timestamp of + * the corresponding calendar unit. Use the pivot time to unfold + * the NTP timestamp properly, or the current system time if the + * pivot pointer is NULL. + */ +extern u_int32 calyearstart (u_int32 ntptime, const time_t *pivot); +extern u_int32 calmonthstart (u_int32 ntptime, const time_t *pivot); +extern u_int32 calweekstart (u_int32 ntptime, const time_t *pivot); +extern u_int32 caldaystart (u_int32 ntptime, const time_t *pivot); + +extern const char *clockname (int); +extern int clocktime (int, int, int, int, int, u_int32, u_long *, u_int32 *); +extern int ntp_getopt (int, char **, const char *); +extern void init_auth (void); +extern void init_lib (void); +extern struct savekey *auth_findkey (keyid_t); +extern void auth_moremem (int); +extern void auth_prealloc_symkeys(int); +extern int ymd2yd (int, int, int); + +/* a_md5encrypt.c */ +extern size_t MD5authencrypt (int type, const u_char *key, size_t klen, + u_int32 *pkt, size_t length); +extern int MD5authdecrypt (int type, const u_char *key, size_t klen, + u_int32 *pkt, size_t length, size_t size, + keyid_t keyno); +extern u_int32 addr2refid (sockaddr_u *); + +/* authkeys.c */ +extern void MD5auth_setkey (keyid_t, int, const u_char *, size_t, + KeyAccT *c); + +/* emalloc.c */ +#ifndef EREALLOC_CALLSITE /* ntp_malloc.h defines */ +extern void * ereallocz (void *, size_t, size_t, int); +extern void * oreallocarrayxz (void *optr, size_t nmemb, size_t size, size_t extra); +#define erealloczsite(p, n, o, z, f, l) ereallocz((p), (n), (o), (z)) +#define emalloc(n) ereallocz(NULL, (n), 0, FALSE) +#define emalloc_zero(c) ereallocz(NULL, (c), 0, TRUE) +#define erealloc(p, c) ereallocz((p), (c), 0, FALSE) +#define erealloc_zero(p, n, o) ereallocz((p), (n), (o), TRUE) +#define ereallocarray(p, n, s) oreallocarrayxz((p), (n), (s), 0) +#define eallocarray(n, s) oreallocarrayxz(NULL, (n), (s), 0) +#define ereallocarrayxz(p, n, s, x) oreallocarrayxz((p), (n), (s), (x)) +#define eallocarrayxz(n, s, x) oreallocarrayxz(NULL, (n), (s), (x)) +extern char * estrdup_impl(const char *); +#define estrdup(s) estrdup_impl(s) +#else +extern void * ereallocz (void *, size_t, size_t, int, + const char *, int); +extern void * oreallocarrayxz (void *optr, size_t nmemb, size_t size, + size_t extra, const char *, int); +#define erealloczsite ereallocz +#define emalloc(c) ereallocz(NULL, (c), 0, FALSE, \ + __FILE__, __LINE__) +#define emalloc_zero(c) ereallocz(NULL, (c), 0, TRUE, \ + __FILE__, __LINE__) +#define erealloc(p, c) ereallocz((p), (c), 0, FALSE, \ + __FILE__, __LINE__) +#define erealloc_zero(p, n, o) ereallocz((p), (n), (o), TRUE, \ + __FILE__, __LINE__) +#define ereallocarray(p, n, s) oreallocarrayxz((p), (n), (s), 0, \ + __FILE__, __LINE__) +#define eallocarray(n, s) oreallocarrayxz(NULL, (n), (s), 0, \ + __FILE__, __LINE__) +#define ereallocarrayxz(p, n, s, x) oreallocarrayxz((p), (n), (s), (x), \ + __FILE__, __LINE__) +#define eallocarrayxz(n, s, x) oreallocarrayxz(NULL, (n), (s), (x), \ + __FILE__, __LINE__) +extern char * estrdup_impl(const char *, const char *, int); +#define estrdup(s) estrdup_impl((s), __FILE__, __LINE__) +#endif + + +extern int atoint (const char *, long *); +extern int atouint (const char *, u_long *); +extern int hextoint (const char *, u_long *); +extern const char * humanlogtime (void); +extern const char * humantime (time_t); +extern int is_ip_address (const char *, u_short, sockaddr_u *); +extern char * mfptoa (u_int32, u_int32, short); +extern char * mfptoms (u_int32, u_int32, short); +extern const char * modetoa (size_t); +extern const char * eventstr (int); +extern const char * ceventstr (int); +extern const char * res_match_flags(u_short); +extern const char * res_access_flags(u_int32); +#ifdef KERNEL_PLL +extern const char * k_st_flags (u_int32); +#endif +extern char * statustoa (int, int); +extern sockaddr_u * netof (sockaddr_u *); +extern char * numtoa (u_int32); +extern const char * socktoa (const sockaddr_u *); +extern const char * sockporttoa(const sockaddr_u *); +extern u_short sock_hash (const sockaddr_u *); +extern int sockaddr_masktoprefixlen(const sockaddr_u *); +extern const char * socktohost (const sockaddr_u *); +extern int octtoint (const char *, u_long *); +extern u_long ranp2 (int); +extern const char *refnumtoa (const sockaddr_u *); +extern const char *refid_str (u_int32, int); + +extern int decodenetnum (const char *, sockaddr_u *); + +extern const char * FindConfig (const char *); + +extern void signal_no_reset (int, RETSIGTYPE (*func)(int)); +extern void set_ctrl_c_hook (ctrl_c_fn); + +extern void getauthkeys (const char *); +extern void auth_agekeys (void); +extern void rereadkeys (void); + +/* + * Variable declarations for libntp. + */ + +/* authkeys.c */ +extern u_long authkeynotfound; /* keys not found */ +extern u_long authkeylookups; /* calls to lookup keys */ +extern u_long authnumkeys; /* number of active keys */ +extern u_long authkeyexpired; /* key lifetime expirations */ +extern u_long authkeyuncached; /* cache misses */ +extern u_long authencryptions; /* calls to encrypt */ +extern u_long authdecryptions; /* calls to decrypt */ + +extern int authnumfreekeys; + +/* + * The key cache. We cache the last key we looked at here. + */ +extern keyid_t cache_keyid; /* key identifier */ +extern int cache_type; /* key type */ +extern u_char * cache_secret; /* secret */ +extern size_t cache_secretsize; /* secret octets */ +extern u_short cache_flags; /* KEY_ bit flags */ + +/* getopt.c */ +extern char * ntp_optarg; /* global argument pointer */ +extern int ntp_optind; /* global argv index */ + +/* lib_strbuf.c */ +extern int ipv4_works; +extern int ipv6_works; + +/* machines.c */ +typedef void (*pset_tod_using)(const char *); +extern pset_tod_using set_tod_using; + +/* ssl_init.c */ +#ifdef OPENSSL +extern void ssl_init (void); +extern void ssl_check_version (void); +extern EVP_MD_CTX* digest_ctx; /* also ssl_init_done */ +#define INIT_SSL() \ + do { \ + if (NULL == digest_ctx) { \ + ssl_init(); \ + } \ + } while (FALSE) +#else /* !OPENSSL follows */ +#define ssl_check_version() do {} while (0) +#define INIT_SSL() do {} while (0) +#endif +extern int keytype_from_text (const char *text, + size_t *pdigest_len); +extern const char *keytype_name (int type); +extern char * getpass_keytype (int type); + +/* strl-obsd.c */ +#ifndef HAVE_STRLCPY /* + */ +/* + * Copy src to string dst of size siz. At most siz-1 characters + * will be copied. Always NUL terminates (unless siz == 0). + * Returns strlen(src); if retval >= siz, truncation occurred. + */ +extern size_t strlcpy(char *dst, const char *src, size_t siz); +#endif +#ifndef HAVE_STRLCAT /* + */ +/* + * Appends src to string dst of size siz (unlike strncat, siz is the + * full size of dst, not space left). At most siz-1 characters + * will be copied. Always NUL terminates (unless siz <= strlen(dst)). + * Returns strlen(src) + MIN(siz, strlen(initial dst)). + * If retval >= siz, truncation occurred. + */ +extern size_t strlcat(char *dst, const char *src, size_t siz); +#endif + + + +/* lib/isc/win32/strerror.c + * + * To minimize Windows-specific changes to the rest of the NTP code, + * particularly reference clocks, we hijack calls to strerror() to deal + * with our mixture of error codes from the C runtime (open, write) + * and Windows (sockets, serial ports). This is an ugly hack because + * both use the lowest values differently, but particularly for ntpd, + * it's not a problem. + */ +#ifdef NTP_REDEFINE_STRERROR +#define strerror(e) ntp_strerror(e) +extern char * ntp_strerror (int e); +#endif + +/* systime.c */ +extern double sys_tick; /* tick size or time to read */ +extern double measured_tick; /* non-overridable sys_tick */ +extern double sys_fuzz; /* min clock read latency */ +extern int trunc_os_clock; /* sys_tick > measured_tick */ + +/* version.c */ +extern const char *Version; /* version declaration */ + +#endif /* NTP_STDLIB_H */ |