1 /* $NetBSD: am_utils.h,v 1.2 2015/10/14 16:00:17 christos Exp $ */ 2 3 /* 4 * Copyright (c) 1997-2014 Erez Zadok 5 * Copyright (c) 1990 Jan-Simon Pendry 6 * Copyright (c) 1990 Imperial College of Science, Technology & Medicine 7 * Copyright (c) 1990 The Regents of the University of California. 8 * All rights reserved. 9 * 10 * This code is derived from software contributed to Berkeley by 11 * Jan-Simon Pendry at Imperial College, London. 12 * 13 * Redistribution and use in source and binary forms, with or without 14 * modification, are permitted provided that the following conditions 15 * are met: 16 * 1. Redistributions of source code must retain the above copyright 17 * notice, this list of conditions and the following disclaimer. 18 * 2. Redistributions in binary form must reproduce the above copyright 19 * notice, this list of conditions and the following disclaimer in the 20 * documentation and/or other materials provided with the distribution. 21 * 3. Neither the name of the University nor the names of its contributors 22 * may be used to endorse or promote products derived from this software 23 * without specific prior written permission. 24 * 25 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 26 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 27 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 28 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 29 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 30 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 31 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 32 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 33 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 34 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 35 * SUCH DAMAGE. 36 * 37 * 38 * File: am-utils/include/am_utils.h 39 * 40 */ 41 42 /* 43 * Definitions that are specific to the am-utils package. 44 */ 45 46 #ifndef _AM_UTILS_H 47 #define _AM_UTILS_H 48 49 50 #include "aux_conf.h" 51 52 /**************************************************************************/ 53 /*** MACROS ***/ 54 /**************************************************************************/ 55 56 #if !defined(__syslog_attribute__) && !defined(__syslog__) 57 #define __syslog__ __printf__ 58 #endif 59 60 /* 61 * General macros. 62 */ 63 #ifndef FALSE 64 # define FALSE 0 65 #endif /* not FALSE */ 66 #ifndef TRUE 67 # define TRUE 1 68 #endif /* not TRUE */ 69 #ifndef MAX 70 # define MAX(a, b) ((a) > (b) ? (a) : (b)) 71 #endif /* not MAX */ 72 #ifndef MIN 73 # define MIN(a, b) ((a) < (b) ? (a) : (b)) 74 #endif /* not MIN */ 75 76 #define ONE_HOUR (60 * 60) /* One hour in seconds */ 77 78 #ifndef MAXHOSTNAMELEN 79 # ifdef HOSTNAMESZ 80 # define MAXHOSTNAMELEN HOSTNAMESZ 81 # else /* not HOSTNAMESZ */ 82 # define MAXHOSTNAMELEN 256 83 # endif /* not HOSTNAMESZ */ 84 #endif /* not MAXHOSTNAMELEN */ 85 86 /* 87 * for hlfsd, and amd for detecting uid/gid 88 */ 89 #ifndef INVALIDID 90 /* this is also defined in include/am_utils.h */ 91 # define INVALIDID (((unsigned short) ~0) - 3) 92 #endif /* not INVALIDID */ 93 94 /* 95 * String comparison macros 96 */ 97 #define STREQ(s1, s2) (strcmp((s1), (s2)) == 0) 98 #define STRCEQ(s1, s2) (strcasecmp((s1), (s2)) == 0) 99 #define NSTREQ(s1, s2, n) (strncmp((s1), (s2), (n)) == 0) 100 #define NSTRCEQ(s1, s2, n) (strncasecmp((s1), (s2), (n)) == 0) 101 #define FSTREQ(s1, s2) ((*(s1) == *(s2)) && STREQ((s1),(s2))) 102 103 /* 104 * Logging options/flags 105 */ 106 #define XLOG_FATAL 0x0001 107 #define XLOG_ERROR 0x0002 108 #define XLOG_USER 0x0004 109 #define XLOG_WARNING 0x0008 110 #define XLOG_INFO 0x0010 111 #define XLOG_DEBUG 0x0020 112 #define XLOG_MAP 0x0040 113 #define XLOG_STATS 0x0080 114 /* log option compositions */ 115 #define XLOG_MASK 0x00ff /* mask for all flags */ 116 #define XLOG_MANDATORY (XLOG_FATAL|XLOG_ERROR) /* cannot turn these off */ 117 #define XLOG_ALL (XLOG_FATAL|XLOG_ERROR|XLOG_USER|XLOG_WARNING|XLOG_INFO|XLOG_MAP|XLOG_STATS) 118 /* default: fatal + error + user + warning + info */ 119 #define XLOG_DEFAULT (XLOG_MASK & (XLOG_ALL & ~XLOG_MAP & ~XLOG_STATS)) 120 121 /* default: no logging options */ 122 123 #define NO_SUBNET "notknown" /* default subnet name for no subnet */ 124 #define NEXP_AP (1022) /* gdmr: was 254 */ 125 #define NEXP_AP_MARGIN (128) /* ???? not used */ 126 127 /* 128 * Linked list macros 129 */ 130 #define AM_FIRST(ty, q) ((ty *) ((q)->q_forw)) 131 #define AM_LAST(ty, q) ((ty *) ((q)->q_back)) 132 #define NEXT(ty, q) ((ty *) (((qelem *) q)->q_forw)) 133 #define PREV(ty, q) ((ty *) (((qelem *) q)->q_back)) 134 #define HEAD(ty, q) ((ty *) q) 135 #define ITER(v, ty, q) \ 136 for ((v) = AM_FIRST(ty,(q)); (v) != HEAD(ty,(q)); (v) = NEXT(ty,(v))) 137 138 /* allocate anything of type ty */ 139 #define ALLOC(ty) ((ty *) xmalloc(sizeof(ty))) 140 #define CALLOC(ty) ((ty *) xzalloc(sizeof(ty))) 141 /* simply allocate b bytes */ 142 #define SALLOC(b) xmalloc((b)) 143 144 /* 145 * Systems which have the mount table in a file need to read it before 146 * they can perform an unmount() system call. 147 */ 148 #define UMOUNT_FS(dir, mtb_name, unmount_flags) umount_fs(dir, mtb_name, unmount_flags) 149 /* next two are imported via $srcdir/conf/umount/umount_*.c */ 150 extern int umount_fs(char *mntdir, const char *mnttabname, u_int unmount_flags); 151 #ifdef MNT2_GEN_OPT_FORCE 152 extern int umount2_fs(const char *mntdir, u_int unmount_flags); 153 #endif /* MNT2_GEN_OPT_FORCE */ 154 155 /* unmount-related flags (special handling of autofs, forced/lazy, etc.) */ 156 #define AMU_UMOUNT_FORCE 0x1 157 #define AMU_UMOUNT_DETACH 0x2 158 #define AMU_UMOUNT_AUTOFS 0x4 159 160 /* 161 * The following values can be tuned... 162 */ 163 #define ALLOWED_MOUNT_TIME 40 /* 40s for a mount */ 164 165 /* 166 * RPC-related macros. 167 */ 168 #define RPC_XID_PORTMAP 0 169 #define RPC_XID_MOUNTD 1 170 #define RPC_XID_NFSPING 2 171 #define RPC_XID_WEBNFS 3 172 #define RPC_XID_MASK (0x0f) /* 16 id's for now */ 173 #define MK_RPC_XID(type_id, uniq) ((type_id) | ((uniq) << 4)) 174 175 /* 176 * What level of AMD are we backward compatible with? 177 * This only applies to externally visible characteristics. 178 * Rev.Minor.Branch.Patch (2 digits each) 179 */ 180 #define AMD_COMPAT 5000000 /* 5.0 */ 181 182 183 /**************************************************************************/ 184 /*** STRUCTURES AND TYPEDEFS ***/ 185 /**************************************************************************/ 186 187 /* some typedefs must come first */ 188 typedef char *amq_string; 189 typedef struct _qelem qelem; 190 typedef struct mntlist mntlist; 191 192 /* 193 * Linked list 194 * (the name 'struct qelem' conflicts with linux's unistd.h) 195 */ 196 struct _qelem { 197 qelem *q_forw; 198 qelem *q_back; 199 }; 200 201 /* 202 * Option tables 203 */ 204 struct opt_tab { 205 char *opt; 206 int flag; 207 }; 208 209 /* 210 * Server states 211 */ 212 typedef enum { 213 Start, 214 Run, 215 Finishing, 216 Quit, 217 Done 218 } serv_state; 219 220 221 /* 222 * List of mount table entries 223 */ 224 struct mntlist { 225 struct mntlist *mnext; 226 mntent_t *mnt; 227 }; 228 229 /* 230 * Mount map 231 */ 232 typedef struct mnt_map mnt_map; 233 234 235 /**************************************************************************/ 236 /*** EXTERNALS ***/ 237 /**************************************************************************/ 238 239 /* 240 * Useful constants 241 */ 242 extern char *mnttab_file_name; /* Mount table */ 243 extern char *cpu; /* "CPU type" */ 244 extern char *endian; /* "big" */ 245 extern char *hostdomain; /* "southseas.nz" */ 246 extern char copyright[]; /* Copyright info */ 247 extern char version[]; /* Version info */ 248 249 /* 250 * Global variables. 251 */ 252 extern AUTH *nfs_auth; /* Dummy authorization for remote servers */ 253 extern FILE *logfp; /* Log file */ 254 extern SVCXPRT *nfsxprt; 255 extern char *PrimNetName; /* Name of primary connected network */ 256 extern char *PrimNetNum; /* Name of primary connected network */ 257 extern char *SubsNetName; /* Name of subsidiary connected network */ 258 extern char *SubsNetNum; /* Name of subsidiary connected network */ 259 260 extern void am_set_progname(char *pn); /* "amd" */ 261 extern const char *am_get_progname(void); /* "amd" */ 262 extern void am_set_hostname(char *hn); 263 extern const char *am_get_hostname(void); 264 extern pid_t am_set_mypid(void); 265 extern pid_t am_mypid; 266 267 extern int foreground; /* Foreground process */ 268 extern int orig_umask; /* umask() on startup */ 269 extern serv_state amd_state; /* Should we go now */ 270 extern struct in_addr myipaddr; /* (An) IP address of this host */ 271 extern struct opt_tab xlog_opt[]; 272 extern u_short nfs_port; /* Our NFS service port */ 273 274 /* 275 * Global routines 276 */ 277 extern CLIENT *get_mount_client(char *unused_host, struct sockaddr_in *sin, struct timeval *tv, int *sock, u_long mnt_version); 278 extern RETSIGTYPE sigchld(int); 279 extern bool_t xdr_amq_string(XDR *xdrs, amq_string *objp); 280 extern bool_t xdr_dirpath(XDR *xdrs, dirpath *objp); 281 extern char **strsplit(char *, int, int); 282 extern char *expand_selectors(char *); 283 extern char *get_version_string(void); 284 extern char *inet_dquad(char *, size_t, u_long); 285 extern char *print_wires(void); 286 extern char *str3cat(char *, char *, char *, char *); 287 extern char *strvcat(const char *, ...); 288 extern char *strealloc(char *, char *); 289 extern char *strip_selectors(char *, char *); 290 extern char *strnsave(const char *, int); 291 extern int amu_close(int fd); 292 extern int bind_resv_port(int, u_short *); 293 extern int cmdoption(char *, struct opt_tab *, u_int *); 294 extern int compute_automounter_mount_flags(mntent_t *); 295 extern int compute_mount_flags(mntent_t *); 296 extern void discard_nfs_args(void *, u_long); 297 extern u_long get_amd_program_number(void); 298 extern int getcreds(struct svc_req *, uid_t *, gid_t *, SVCXPRT *); 299 extern int hasmntval(mntent_t *, char *); 300 extern unsigned int hasmntvalerr(mntent_t *, char *, int *); 301 extern char *hasmntstr(mntent_t *, char *); 302 extern char *hasmnteq(mntent_t *, char *); 303 extern char *haseq(char *); 304 extern int is_network_member(const char *net); 305 extern int is_interface_local(u_long); 306 extern int islocalnet(u_long); 307 extern int make_rpc_packet(char *, int, u_long, struct rpc_msg *, voidp, XDRPROC_T_TYPE, AUTH *); 308 extern int mkdirs(char *, int); 309 extern int mount_fs(mntent_t *, int, caddr_t, int, MTYPE_TYPE, u_long, const char *, const char *, int); 310 extern void nfs_program_2(struct svc_req *rqstp, SVCXPRT *transp); 311 extern void nfs_program_3(struct svc_req *rqstp, SVCXPRT *transp); 312 #define get_nfs_dispatcher_version(a) \ 313 ((a) == nfs_program_2 ? NFS_VERSION : NFS_VERSION3) 314 extern int pickup_rpc_reply(voidp, int, voidp, XDRPROC_T_TYPE); 315 extern int switch_option(char *); 316 extern int switch_to_logfile(char *logfile, int orig_umask, int truncate_log); 317 extern mntlist *read_mtab(char *, const char *); 318 #ifndef HAVE_TRANSPORT_TYPE_TLI 319 extern struct sockaddr_in *amu_svc_getcaller(SVCXPRT *xprt); 320 #endif /* not HAVE_TRANSPORT_TYPE_TLI */ 321 extern time_t time(time_t *); 322 extern void amu_get_myaddress(struct in_addr *iap, const char *preferred_localhost); 323 extern void amu_release_controlling_tty(void); 324 extern void compute_automounter_nfs_args(nfs_args_t *nap, mntent_t *mntp); 325 extern void discard_mntlist(mntlist *mp); 326 extern void free_mntlist(mntlist *); 327 extern void getwire(char **name1, char **number1); 328 extern void going_down(int); 329 extern void mnt_free(mntent_t *); 330 extern void plog(int, const char *,...) 331 __attribute__ ((__format__ (__syslog__, 2, 3))); 332 extern void rmdirs(char *); 333 extern void rpc_msg_init(struct rpc_msg *, u_long, u_long, u_long); 334 extern void set_amd_program_number(u_long program); 335 extern void show_opts(int ch, struct opt_tab *); 336 extern void unregister_amq(void); 337 extern voidp xmalloc(int); 338 extern voidp xrealloc(voidp, int); 339 extern voidp xzalloc(int); 340 extern char *xstrdup(const char *); 341 extern int check_pmap_up(char *host, struct sockaddr_in* sin); 342 extern u_long get_nfs_version(char *host, struct sockaddr_in *sin, u_long nfs_version, const char *proto, u_long def); 343 extern int nfs_valid_version(u_long vers); 344 extern long get_server_pid(void); 345 extern void setup_sighandler(int signum, void (*handler)(int)); 346 extern time_t clocktime(nfstime *nt); 347 348 #if defined(DEBUG) && (defined(HAVE_C99_VARARGS_MACROS) || defined(HAVE_GCC_VARARGS_MACROS)) 349 # ifdef HAVE_C99_VARARGS_MACROS 350 #define xsnprintf(str,size,fmt,...) _xsnprintf(__FILE__,__LINE__,(str),(size),(fmt),__VA_ARGS__) 351 # endif /* HAVE_C99_VARARGS_MACROS */ 352 # ifdef HAVE_GCC_VARARGS_MACROS 353 #define xsnprintf(str,size,fmt,args...) _xsnprintf(__FILE__,__LINE__,(str),(size),(fmt),args) 354 # endif /* HAVE_GCC_VARARGS_MACROS */ 355 extern int _xsnprintf(const char *filename, int lineno, char *str, size_t size, const char *format, ...); 356 #define xvsnprintf(str,size,fmt,ap) _xvsnprintf(__FILE__,__LINE__,(str),(size),(fmt),(ap)) 357 extern int _xvsnprintf(const char *filename, int lineno, char *str, size_t size, const char *format, va_list ap); 358 #else /* not DEBUG or no C99/GCC-style vararg cpp macros supported */ 359 extern int xsnprintf(char *str, size_t size, const char *format, ...); 360 extern int xvsnprintf(char *str, size_t size, const char *format, va_list ap); 361 #endif /* not DEBUG or no C99/GCC-style vararg cpp macros supported */ 362 363 #ifdef DEBUG 364 extern void _xstrlcat(const char *filename, int lineno, char *dst, const char *src, size_t len); 365 # define xstrlcat(d,s,l) _xstrlcat(__FILE__,__LINE__,(d),(s),(l)) 366 extern void _xstrlcpy(const char *filename, int lineno, char *dst, const char *src, size_t len); 367 # define xstrlcpy(d,s,l) _xstrlcpy(__FILE__,__LINE__,(d),(s),(l)) 368 #else /* not DEBUG */ 369 extern void xstrlcat(char *dst, const char *src, size_t len); 370 extern void xstrlcpy(char *dst, const char *src, size_t len); 371 #endif /* not DEBUG */ 372 373 #ifdef MOUNT_TABLE_ON_FILE 374 extern void rewrite_mtab(mntlist *, const char *); 375 extern void unlock_mntlist(void); 376 extern void write_mntent(mntent_t *, const char *); 377 #endif /* MOUNT_TABLE_ON_FILE */ 378 379 #if defined(HAVE_SYSLOG_H) || defined(HAVE_SYS_SYSLOG_H) 380 extern int syslogging; 381 #endif /* defined(HAVE_SYSLOG_H) || defined(HAVE_SYS_SYSLOG_H) */ 382 383 extern void compute_nfs_args(void *nap, mntent_t *mntp, int genflags, struct netconfig *nfsncp, struct sockaddr_in *ip_addr, u_long nfs_version, char *nfs_proto, am_nfs_handle_t *fhp, char *host_name, char *fs_name); 384 extern void destroy_nfs_args(void *nap, u_long nfs_version); 385 extern int create_amq_service(int *udp_soAMQp, SVCXPRT **udp_amqpp, struct netconfig **udp_amqncpp, int *tcp_soAMQp, SVCXPRT **tcp_amqpp, struct netconfig **tcp_amqncpp, u_short preferred_amq_port); 386 extern int create_nfs_service(int *soNFSp, u_short *nfs_portp, SVCXPRT **nfs_xprtp, void (*dispatch_fxn)(struct svc_req *rqstp, SVCXPRT *transp), u_long nfs_version); 387 extern int amu_svc_register(SVCXPRT *, u_long, u_long, void (*)(struct svc_req *, SVCXPRT *), u_long, struct netconfig *); 388 389 #ifdef HAVE_TRANSPORT_TYPE_TLI 390 391 extern int get_knetconfig(struct knetconfig **kncpp, struct netconfig *in_ncp, char *nc_protoname); 392 extern struct netconfig *nfsncp; 393 extern void free_knetconfig(struct knetconfig *kncp); 394 395 #endif /* HAVE_TRANSPORT_TYPE_TLI */ 396 397 #ifdef HAVE_FS_AUTOFS 398 extern int register_autofs_service(char *autofs_conftype, void (*autofs_dispatch)(struct svc_req *rqstp, SVCXPRT *xprt)); 399 extern int unregister_autofs_service(char *autofs_conftype); 400 #endif /* HAVE_FS_AUTOFS */ 401 402 403 #ifndef HAVE_STRUCT_FHSTATUS_FHS_FH 404 # define fhs_fh fhstatus_u.fhs_fhandle 405 #endif /* not HAVE_STRUCT_FHSTATUS_FHS_FH */ 406 407 408 /* 409 * Network File System: the old faithful generation NFS V.2 410 */ 411 #ifndef NFS_VERSION2 412 # define NFS_VERSION2 ((u_int) 2) 413 #endif /* not NFS_VERSION2 */ 414 415 /* 416 * Network File System: the not so new anymore generation NFS V.3 417 */ 418 #ifdef HAVE_FS_NFS3 419 # ifndef NFS_VERSION3 420 # define NFS_VERSION3 ((u_int) 3) 421 # endif /* not NFS_VERSION3 */ 422 #endif /* HAVE_FS_NFS3 */ 423 424 /* 425 * Network File System: the new generation NFS V.4 426 */ 427 #ifdef HAVE_FS_NFS4 428 # ifndef NFS_VERSION4 429 # define NFS_VERSION4 ((u_int) 4) 430 # endif /* not NFS_VERSION4 */ 431 #endif /* HAVE_FS_NFS4 */ 432 433 /**************************************************************************/ 434 /*** DEBUGGING ***/ 435 /**************************************************************************/ 436 437 /* 438 * DEBUGGING: 439 */ 440 441 #ifdef DEBUG 442 443 # define D_DAEMON 0x0001 /* Enter daemon mode */ 444 # define D_TRACE 0x0002 /* Do protocol trace */ 445 # define D_FULL 0x0004 /* Do full trace */ 446 # define D_MTAB 0x0008 /* Use local mtab */ 447 # define D_AMQ 0x0010 /* Register amq program */ 448 # define D_STR 0x0020 /* Debug string munging */ 449 # ifdef DEBUG_MEM 450 # define D_MEM 0x0040 /* Trace memory allocations */ 451 # else /* not DEBUG_MEM */ 452 # define D_MEM 0x0000 /* Dummy */ 453 # endif /* not DEBUG_MEM */ 454 # define D_FORK 0x0080 /* Fork server (hlfsd only) */ 455 # define D_INFO 0x0100 /* info service specific debugging (hesiod, nis, etc) */ 456 # define D_HRTIME 0x0200 /* Print high resolution time stamps */ 457 # define D_XDRTRACE 0x0400 /* Trace xdr routines */ 458 # define D_READDIR 0x0800 /* Show browsable_dir progress */ 459 /* debug option compositions */ 460 # define D_MASK 0x0fff /* mask of known flags */ 461 # define D_BASIC (D_TRACE|D_FULL|D_STR|D_MEM|D_INFO|D_XDRTRACE|D_READDIR) 462 # define D_CONTROL (D_DAEMON|D_AMQ|D_FORK) 463 /* immutable flags: cannot be changed via "amq -D" */ 464 # define D_IMMUTABLE (D_MTAB | D_CONTROL) 465 # define D_ALL (D_BASIC | D_CONTROL) 466 # define D_DEFAULT (D_MASK & D_ALL & ~D_XDRTRACE) 467 /* test mode: nodaemon, noamq, nofork, (local) mtab */ 468 # define D_TEST (D_BASIC | D_MTAB) 469 470 # define amuDebug(x) (debug_flags & (x)) 471 # define dlog if (amuDebug(D_FULL)) dplog 472 473 /* my favorite debugging tool -Erez */ 474 #define EZKDBG plog(XLOG_INFO,"EZK:%s:%s:%d\n",__FILE__,__FUNCTION__,__LINE__) 475 476 # ifdef DEBUG_MEM 477 /* 478 * If debugging memory, then call a special freeing function that logs 479 * more info, and resets the pointer to NULL so it cannot be used again. 480 */ 481 # define XFREE(x) dxfree(__FILE__,__LINE__,x) 482 extern void dxfree(char *file, int line, voidp ptr); 483 extern void malloc_verify(void); 484 # else /* not DEBUG_MEM */ 485 /* 486 * If regular debugging, then free the pointer and reset to NULL. 487 * This should remain so for as long as am-utils is in alpha/beta testing. 488 */ 489 # define XFREE(x) do { free((voidp)x); x = NULL;} while (0) 490 # endif /* not DEBUG_MEM */ 491 492 /* functions that depend solely on debugging */ 493 extern void print_nfs_args(const void *, u_long nfs_version); 494 extern int debug_option (char *opt); 495 extern void dplog(const char *fmt, ...) 496 __attribute__ ((__format__ (__syslog__, 1, 2))); 497 498 #else /* not DEBUG */ 499 500 /* set dummy flags to zero */ 501 # define D_DAEMON 0x0001 /* Enter daemon mode */ 502 # define D_TRACE 0x0000 /* dummy: Do protocol trace */ 503 # define D_FULL 0x0000 /* dummy: Do full trace */ 504 # define D_MTAB 0x0000 /* dummy: Use local mtab */ 505 # define D_AMQ 0x0010 /* Register amq program */ 506 # define D_STR 0x0000 /* dummy: Debug string munging */ 507 # define D_MEM 0x0000 /* dummy: Trace memory allocations */ 508 # define D_FORK 0x0080 /* Fork server (hlfsd only) */ 509 # define D_INFO 0x0000 /* dummy: info service debugging */ 510 # define D_HRTIME 0x0000 /* dummy: hi-res time stamps */ 511 # define D_XDRTRACE 0x0000 /* dummy: Trace xdr routines */ 512 # define D_READDIR 0x0000 /* dummy: browsable_dir progress */ 513 # define D_CONTROL (D_DAEMON|D_AMQ|D_FORK) 514 # define amuDebug(x) (debug_flags & (x)) 515 /* 516 * If not debugging, then also reset the pointer. 517 * It's safer -- and besides, free() should do that anyway. 518 */ 519 # define XFREE(x) do { free((voidp)x); x = NULL;} while (0) 520 521 # if defined(HAVE_GCC_VARARGS_MACROS) 522 # define dlog(fmt...) 523 # elif defined(HAVE_C99_VARARGS_MACROS) 524 # define dlog(...) 525 # else /* no c99 varargs */ 526 /* this define means that we CCP leaves code behind the (list,of,args) */ 527 # define dlog 528 # endif /* no c99 varargs */ 529 530 # define print_nfs_args(nap, nfs_version) 531 # define debug_option(x) (1) 532 533 #endif /* not DEBUG */ 534 535 extern u_int debug_flags; /* Debug options */ 536 extern struct opt_tab dbg_opt[]; 537 538 /**************************************************************************/ 539 /*** MISC (stuff left to autoconfiscate) ***/ 540 /**************************************************************************/ 541 542 #endif /* not _AM_UTILS_H */ 543