xref: /csrg-svn/usr.sbin/amd/include/am.h (revision 47527)
144922Smckusick /*
2*47527Spendry  * $Id: am.h,v 5.2.1.5 91/03/17 17:38:03 jsp Alpha $
344922Smckusick  *
444922Smckusick  * Copyright (c) 1990 Jan-Simon Pendry
544922Smckusick  * Copyright (c) 1990 Imperial College of Science, Technology & Medicine
644922Smckusick  * Copyright (c) 1990 The Regents of the University of California.
744922Smckusick  * All rights reserved.
844922Smckusick  *
944922Smckusick  * This code is derived from software contributed to Berkeley by
1044922Smckusick  * Jan-Simon Pendry at Imperial College, London.
1144922Smckusick  *
1244922Smckusick  * %sccs.include.redist.c%
1344922Smckusick  *
14*47527Spendry  *	@(#)am.h	5.2 (Berkeley) 03/17/91
1544922Smckusick  */
1644922Smckusick 
17*47527Spendry #include "config.h"
1844922Smckusick 
1944922Smckusick /*
2044922Smckusick  * Global declarations
2144922Smckusick  */
2244922Smckusick #include <sys/param.h>
2344922Smckusick #include <sys/socket.h>
2444922Smckusick #include <rpc/rpc.h>
2544922Smckusick #include "nfs_prot.h"
2644922Smckusick #ifdef MNTENT_HDR
2744922Smckusick #include MNTENT_HDR
2844922Smckusick #endif /* MNTENT_HDR */
2944922Smckusick #include <assert.h>
3044922Smckusick 
3144922Smckusick #ifdef DEBUG_MEM
3244922Smckusick #include <malloc.h>
3344922Smckusick #endif /* DEBUG_MEM */
3444922Smckusick 
3544922Smckusick #ifndef MAXHOSTNAMELEN
3644922Smckusick #define MAXHOSTNAMELEN 64
3744922Smckusick #endif /* MAXHOSTNAMELEN */
3844922Smckusick 
3944922Smckusick #ifndef MNTTYPE_AUTO
4044922Smckusick #define MNTTYPE_AUTO "auto"
4144922Smckusick #endif /* MNTTYPE_AUTO */
4244922Smckusick 
4344922Smckusick #ifndef FALSE
4444922Smckusick #define FALSE 0
4544922Smckusick #define TRUE 1
4644922Smckusick #endif /* FALSE */
4744922Smckusick 
4844922Smckusick #ifndef ROOT_MAP
4944922Smckusick #define	ROOT_MAP "\"root\""
5044922Smckusick #endif /* ROOT_MAP */
5144922Smckusick 
5244922Smckusick /*
5344922Smckusick  * Flags from command line
5444922Smckusick  */
5544922Smckusick extern int print_pid;		/* Print pid to stdout */
5644922Smckusick extern int normalize_hosts;	/* Normalize host names before use */
5744922Smckusick extern int restart_existing_mounts;
5844922Smckusick #ifdef HAS_NIS_MAPS
5944922Smckusick extern char *domain;		/* NIS domain to use */
6044922Smckusick #endif /* HAS_NIS_MAPS */
6144922Smckusick extern int am_timeo;		/* Cache period */
6244922Smckusick extern int afs_timeo;		/* AFS timeout */
6344922Smckusick extern int afs_retrans;		/* AFS retrans */
6444922Smckusick extern int am_timeo_w;		/* Unmount timeout */
6544922Smckusick extern char *mtab;		/* Mount table */
6644922Smckusick 
6744922Smckusick typedef enum {
6844922Smckusick 	Start,
6944922Smckusick 	Run,
7044922Smckusick 	Finishing,
7144922Smckusick 	Quit,
7244922Smckusick 	Done
7344922Smckusick } serv_state;
7444922Smckusick 
7544922Smckusick extern serv_state amd_state;	/* Should we go now */
7644922Smckusick extern int immediate_abort;	/* Should close-down unmounts be retried */
7744922Smckusick extern time_t do_mapc_reload;	/* Flush & reload mount map cache */
7844922Smckusick 
7944922Smckusick /*
8044922Smckusick  * Useful constants
8144922Smckusick  */
8244922Smckusick extern char pid_fsname[];	/* kiska.southseas.nz:(pid%d) */
8344922Smckusick extern char hostd[];		/* "kiska.southseas.nz" */
8444922Smckusick extern char *hostdomain;	/* "southseas.nz" */
8544922Smckusick extern char *op_sys;		/* "sos4" */
8644922Smckusick extern char *arch;		/* "sun4" */
8744922Smckusick extern char *karch;		/* "sun4c" */
8844922Smckusick extern char *cluster;		/* "r+d-kluster" */
8944922Smckusick extern char *endian;		/* "big" */
9044922Smckusick extern char *auto_dir;		/* "/a" */
91*47527Spendry extern char copyright[];	/* Copyright info */
9244922Smckusick extern char version[];		/* Version info */
9344922Smckusick 
9444922Smckusick typedef struct am_ops am_ops;
9544922Smckusick typedef struct am_node am_node;
9644922Smckusick typedef struct am_opts am_opts;
9744922Smckusick typedef struct mntfs mntfs;
9844922Smckusick typedef struct fserver fserver;
9944922Smckusick typedef struct fsrvinfo fsrvinfo;
10044922Smckusick 
10144922Smckusick /*
102*47527Spendry  * Debug defns.
103*47527Spendry  */
104*47527Spendry #ifdef DEBUG
105*47527Spendry #define	DEBUG_MTAB	"./mtab"
106*47527Spendry 
107*47527Spendry extern int debug_flags;		/* Debug options */
108*47527Spendry 
109*47527Spendry #define	D_DAEMON	0x0001	/* Enter daemon mode */
110*47527Spendry #define	D_TRACE		0x0002	/* Do protocol trace */
111*47527Spendry #define	D_FULL		0x0004	/* Do full trace */
112*47527Spendry #define	D_MTAB		0x0008	/* Use local mtab */
113*47527Spendry #define	D_AMQ		0x0010	/* Register amq program */
114*47527Spendry #define	D_STR		0x0020	/* Debug string munging */
115*47527Spendry #define	D_MEM		0x0040	/* Trace memory allocations */
116*47527Spendry 
117*47527Spendry /*
118*47527Spendry  * Normally, don't enter daemon mode, and don't register amq
119*47527Spendry  */
120*47527Spendry #define	D_TEST	(~(D_DAEMON|D_MEM|D_STR))
121*47527Spendry #endif /* DEBUG */
122*47527Spendry 
123*47527Spendry /*
12444922Smckusick  * Global variables.
12544922Smckusick  */
12644922Smckusick extern unsigned short nfs_port;	/* Our NFS service port */
12744922Smckusick extern struct in_addr myipaddr;	/* (An) IP address of this host */
12844922Smckusick 
12944922Smckusick extern int foreground;		/* Foreground process */
13044922Smckusick extern time_t next_softclock;	/* Time to call softclock() */
13144922Smckusick extern int task_notify_todo;	/* Task notifier needs running */
13244922Smckusick #ifdef HAS_TFS
13344922Smckusick extern int nfs_server_code_available;
13444922Smckusick #endif /* HAS_TFS */
13544922Smckusick extern int last_used_map;	/* Last map being used for mounts */
13644922Smckusick extern AUTH *nfs_auth;		/* Dummy uthorisation for remote servers */
137*47527Spendry extern am_node **exported_ap;	/* List of nodes */
13844922Smckusick extern int first_free_map;	/* First free node */
139*47527Spendry extern am_node *root_node;	/* Node for "root" */
140*47527Spendry extern char *wire;		/* Name of primary connected network */
141*47527Spendry #define	NEXP_AP	(254)
142*47527Spendry #define NEXP_AP_MARGIN (128)
14344922Smckusick 
14444922Smckusick typedef int (*task_fun)P((voidp));
14544922Smckusick typedef void (*cb_fun)P((int, int, voidp));
14644922Smckusick typedef void (*fwd_fun)P((voidp, int, struct sockaddr_in *,
14744922Smckusick 				struct sockaddr_in *, voidp, int));
14844922Smckusick 
14944922Smckusick /*
15044922Smckusick  * String comparison macros
15144922Smckusick  */
15244922Smckusick #define STREQ(s1, s2) (strcmp((s1), (s2)) == 0)
15344922Smckusick #define FSTREQ(s1, s2) ((*(s1) == *(s2)) && STREQ((s1),(s2)))
15444922Smckusick 
15544922Smckusick /*
15644922Smckusick  * Linked list
15744922Smckusick  */
15844922Smckusick typedef struct qelem qelem;
15944922Smckusick struct qelem {
16044922Smckusick 	qelem *q_forw;
16144922Smckusick 	qelem *q_back;
16244922Smckusick };
16344922Smckusick #define	FIRST(ty, q)	((ty *) ((q)->q_forw))
16444922Smckusick #define	LAST(ty, q)	((ty *) ((q)->q_back))
16544922Smckusick #define	NEXT(ty, q)	((ty *) (((qelem *) q)->q_forw))
16644922Smckusick #define	PREV(ty, q)	((ty *) (((qelem *) q)->q_back))
16744922Smckusick #define	HEAD(ty, q)	((ty *) q)
16844922Smckusick #define	ITER(v, ty, q) \
16944922Smckusick 	for ((v) = FIRST(ty,(q)); (v) != HEAD(ty,(q)); (v) = NEXT(ty,(v)))
17044922Smckusick 
17144922Smckusick /*
17244922Smckusick  * List of mount table entries
17344922Smckusick  */
17444922Smckusick typedef struct mntlist mntlist;
17544922Smckusick struct mntlist {
17644922Smckusick 	struct mntlist *mnext;
17744922Smckusick 	struct mntent *mnt;
17844922Smckusick };
17944922Smckusick 
18044922Smckusick /*
18144922Smckusick  * Mount map
18244922Smckusick  */
18344922Smckusick typedef struct mnt_map mnt_map;
18444922Smckusick 
18544922Smckusick /*
18644922Smckusick  * Global routines
18744922Smckusick  */
188*47527Spendry extern int atoi P((Const char *)); /* C */
18944922Smckusick extern void am_mounted P((am_node*));
19044922Smckusick extern void am_unmounted P((am_node*));
19144922Smckusick extern int background(P_void);
19244922Smckusick extern int bind_resv_port P((int, unsigned short*));
19344922Smckusick extern int compute_mount_flags P((struct mntent *));
19444922Smckusick extern int softclock(P_void);
19544922Smckusick #ifdef DEBUG
19644922Smckusick extern int debug_option P((char*));
19744922Smckusick #endif /* DEBUG */
198*47527Spendry extern void deslashify P((char*));
19944922Smckusick /*extern void domain_strip P((char*, char*));*/
20044922Smckusick extern mntfs* dup_mntfs P((mntfs*));
20144922Smckusick extern fserver* dup_srvr P((fserver*));
20244922Smckusick extern int eval_fs_opts P((am_opts*, char*, char*, char*, char*, char*));
20344922Smckusick extern char* expand_key P((char*));
20444922Smckusick extern am_node* exported_ap_alloc(P_void);
20544922Smckusick extern am_node* find_ap P((char*));
206*47527Spendry extern am_node* find_mf P((mntfs*));
207*47527Spendry extern mntfs* find_mntfs P((am_ops*, am_opts*, char*, char*, char*, char*));
20844922Smckusick extern void flush_mntfs(P_void);
209*47527Spendry extern void flush_nfs_fhandle_cache P((fserver*));
210*47527Spendry extern void forcibly_timeout_mp P((am_node*));
21144922Smckusick extern FREE_RETURN_TYPE free P((voidp)); /* C */
21244922Smckusick extern void free_mntfs P((mntfs*));
21344922Smckusick extern void free_opts P((am_opts*));
21444922Smckusick extern void free_map P((am_node*));
21544922Smckusick extern void free_mntlist P((mntlist*));
216*47527Spendry extern void free_srvr P((fserver*));
21744922Smckusick extern int fwd_init(P_void);
21844922Smckusick extern int fwd_packet P((int, voidp, int, struct sockaddr_in *,
21944922Smckusick 		struct sockaddr_in *, voidp, fwd_fun));
22044922Smckusick extern void fwd_reply(P_void);
22144922Smckusick extern void get_args P((int, char*[]));
222*47527Spendry extern char *getwire P((void));
22344922Smckusick #ifdef NEED_MNTOPT_PARSER
22444922Smckusick extern char *hasmntopt P((struct mntent*, char*));
22544922Smckusick #endif /* NEED_MNTOPT_PARSER */
22644922Smckusick extern int hasmntval P((struct mntent*, char*));
22744922Smckusick extern void host_normalize P((char **));
228*47527Spendry extern char *inet_dquad P((char*, unsigned long));
22944922Smckusick extern void init_map P((am_node*, char*));
23044922Smckusick extern void insert_am P((am_node*, am_node*));
23144922Smckusick extern void ins_que P((qelem*, qelem*));
23244922Smckusick extern void make_root_node(P_void);
23344922Smckusick extern int make_rpc_packet P((char*, int, u_long, struct rpc_msg*, voidp, xdrproc_t, AUTH*));
23444922Smckusick extern void mapc_add_kv P((mnt_map*, char*, char*));
23544922Smckusick extern mnt_map* mapc_find P((char*, char*));
23644922Smckusick extern void mapc_free P((mnt_map*));
237*47527Spendry extern int mapc_keyiter P((mnt_map*, void (*)(char*,voidp), voidp));
23844922Smckusick extern int mapc_search P((mnt_map*, char*, char**));
23944922Smckusick extern void mapc_reload(P_void);
24044922Smckusick extern void mapc_showtypes P((FILE*));
24144922Smckusick extern int mkdirs P((char*, int));
242*47527Spendry extern void mk_fattr P((am_node*, enum ftype));
24344922Smckusick extern void mnt_free P((struct mntent*));
244*47527Spendry extern int mount_auto_node P((char*, voidp));
24544922Smckusick extern int mount_automounter P((int));
24644922Smckusick extern int mount_exported(P_void);
247*47527Spendry extern int mount_fs P((struct mntent*, int, caddr_t, int, MTYPE_TYPE));
24844922Smckusick extern int mount_node P((am_node*));
24944922Smckusick extern mntfs* new_mntfs(P_void);
25044922Smckusick extern void new_ttl P((am_node*));
25144922Smckusick extern am_node* next_map P((int*));
25244922Smckusick extern int nfs_srvr_port P((fserver*, u_short*, voidp));
253*47527Spendry extern void normalize_slash P((char*));
254*47527Spendry extern void ops_showfstypes P((FILE*));
25544922Smckusick extern int pickup_rpc_reply P((voidp, int, voidp, xdrproc_t));
25644922Smckusick extern mntlist* read_mtab P((char*));
257*47527Spendry extern mntfs* realloc_mntfs  P((mntfs*, am_ops*, am_opts*, char*, char*, char*, char*));
25844922Smckusick extern void rem_que P((qelem*));
25944922Smckusick extern void reschedule_timeout_mp(P_void);
26044922Smckusick extern void restart(P_void);
26144922Smckusick #ifdef UPDATE_MTAB
26244922Smckusick extern void rewrite_mtab P((mntlist *));
26344922Smckusick #endif /* UPDATE_MTAB */
26444922Smckusick extern void rmdirs P((char*));
26544922Smckusick extern am_node* root_ap P((char*, int));
266*47527Spendry extern int root_keyiter P((void (*)(char*,voidp), voidp));
26744922Smckusick extern void root_newmap P((char*, char*, char*));
26844922Smckusick extern void rpc_msg_init P((struct rpc_msg*, u_long, u_long, u_long));
26944922Smckusick extern void run_task P((task_fun, voidp, cb_fun, voidp));
27044922Smckusick extern void sched_task P((cb_fun, voidp, voidp));
271*47527Spendry extern void show_rcs_info P((Const char*, char*));
27244922Smckusick extern void sigchld P((int));
27344922Smckusick extern void srvrlog P((fserver*, char*));
27444922Smckusick extern char* str3cat P((char*, char*, char*, char*));
275*47527Spendry extern char* strcat P((char*, Const char*)); /* C */
276*47527Spendry extern int strcmp P((Const char*, Const char*)); /* C */
277*47527Spendry extern char* strdup P((Const char*));
278*47527Spendry extern int strlen P((Const char*)); /* C */
279*47527Spendry extern char* strnsave P((Const char*, int));
280*47527Spendry extern char* strrchr P((Const char*, int)); /* C */
28144922Smckusick extern char* strealloc P((char*, char *));
282*47527Spendry extern char** strsplit P((char*, int, int));
28344922Smckusick extern int switch_option P((char*));
284*47527Spendry extern int switch_to_logfile P((char*));
285*47527Spendry extern void do_task_notify(P_void);
28644922Smckusick extern int timeout P((unsigned int, void (*fn)(), voidp));
28744922Smckusick extern void timeout_mp(P_void);
28844922Smckusick extern void umount_exported(P_void);
289*47527Spendry extern int umount_fs P((char*));
29044922Smckusick /*extern int unmount_node P((am_node*));
29144922Smckusick extern int unmount_node_wrap P((voidp));*/
29244922Smckusick extern void unregister_amq(P_void);
29344922Smckusick extern void untimeout P((int));
29444922Smckusick extern int valid_key P((char*));
29544922Smckusick extern void wakeup P((voidp));
29644922Smckusick extern void wakeup_task P((int,int,voidp));
29744922Smckusick extern void wakeup_srvr P((fserver*));
29844922Smckusick extern void write_mntent P((struct mntent*));
299*47527Spendry #ifdef UPDATE_MTAB
300*47527Spendry extern void unlock_mntlist P((void));
301*47527Spendry #else
302*47527Spendry #define	unlock_mntlist()
303*47527Spendry #endif /* UPDATE_MTAB */
30444922Smckusick 
305*47527Spendry 
30644922Smckusick #define	ALLOC(ty)	((struct ty *) xmalloc(sizeof(struct ty)))
30744922Smckusick 
30844922Smckusick /*
30944922Smckusick  * Options
31044922Smckusick  */
31144922Smckusick struct am_opts {
31244922Smckusick 	char	*fs_glob;		/* Smashed copy of global options */
31344922Smckusick 	char	*fs_local;		/* Expanded copy of local options */
31444922Smckusick 	char	*fs_mtab;		/* Mount table entry */
31544922Smckusick 	/* Other options ... */
31644922Smckusick 	char	*opt_dev;
31744922Smckusick 	char	*opt_delay;
31844922Smckusick 	char	*opt_dir;
31944922Smckusick 	char	*opt_fs;
32044922Smckusick 	char	*opt_group;
32144922Smckusick 	char	*opt_mount;
32244922Smckusick 	char	*opt_opts;
32344922Smckusick 	char	*opt_pref;
32444922Smckusick 	char	*opt_cache;
32544922Smckusick 	char	*opt_rfs;
32644922Smckusick 	char	*opt_rhost;
32744922Smckusick 	char	*opt_sublink;
32844922Smckusick 	char	*opt_type;
32944922Smckusick 	char	*opt_unmount;
33044922Smckusick 	char	*opt_user;
33144922Smckusick };
33244922Smckusick 
33344922Smckusick /*
33444922Smckusick  * File Handle
33544922Smckusick  *
33644922Smckusick  * This is interpreted by indexing the exported array
33744922Smckusick  * by fhh_id.
33844922Smckusick  *
33944922Smckusick  * The whole structure is mapped onto a standard fhandle_t
34044922Smckusick  * when transmitted.
34144922Smckusick  */
34244922Smckusick struct am_fh {
34344922Smckusick 	int	fhh_pid;		/* process id */
34444922Smckusick 	int	fhh_id;			/* map id */
34544922Smckusick 	int	fhh_gen;		/* generation number */
34644922Smckusick };
34744922Smckusick 
34844922Smckusick extern am_node *fh_to_mp P((nfs_fh*));
34944922Smckusick extern am_node *fh_to_mp3 P((nfs_fh*,int*,int));
35044922Smckusick extern void mp_to_fh P((am_node*, nfs_fh*));
35144922Smckusick #define	fh_to_mp2(fhp, rp) fh_to_mp3(fhp, rp, VLOOK_CREATE)
352*47527Spendry extern int auto_fmount P((am_node *mp));
353*47527Spendry extern int auto_fumount P((am_node *mp));
35444922Smckusick 
355*47527Spendry #define	MAX_READDIR_ENTRIES	16
356*47527Spendry 
357*47527Spendry typedef char*	(*vfs_match)P((am_opts*));
35844922Smckusick typedef int	(*vfs_init)P((mntfs*));
35944922Smckusick typedef int	(*vmount_fs)P((am_node*));
360*47527Spendry typedef int	(*vfmount_fs)P((mntfs*));
36144922Smckusick typedef int	(*vumount_fs)P((am_node*));
362*47527Spendry typedef int	(*vfumount_fs)P((mntfs*));
36344922Smckusick typedef am_node*(*vlookuppn)P((am_node*, char*, int*, int));
364*47527Spendry typedef int	(*vreaddir)P((am_node*, nfscookie, dirlist*, entry*, int));
36544922Smckusick typedef am_node*(*vreadlink)P((am_node*, int*));
366*47527Spendry typedef void	(*vmounted)P((mntfs*));
36744922Smckusick typedef void	(*vumounted)P((am_node*));
36844922Smckusick typedef fserver*(*vffserver)P((mntfs*));
36944922Smckusick 
37044922Smckusick struct am_ops {
37144922Smckusick 	char		*fs_type;
37244922Smckusick 	vfs_match	fs_match;
37344922Smckusick 	vfs_init	fs_init;
37444922Smckusick 	vmount_fs	mount_fs;
375*47527Spendry 	vfmount_fs	fmount_fs;
37644922Smckusick 	vumount_fs	umount_fs;
377*47527Spendry 	vfumount_fs	fumount_fs;
37844922Smckusick 	vlookuppn	lookuppn;
37944922Smckusick 	vreaddir	readdir;
38044922Smckusick 	vreadlink	readlink;
38144922Smckusick 	vmounted	mounted;
38244922Smckusick 	vumounted	umounted;
38344922Smckusick 	vffserver	ffserver;
38444922Smckusick 	int		fs_flags;
38544922Smckusick };
38644922Smckusick extern am_node *efs_lookuppn P((am_node*, char*, int*, int));
387*47527Spendry extern int efs_readdir P((am_node*, nfscookie, dirlist*, entry*, int));
38844922Smckusick 
38944922Smckusick #define	VLOOK_CREATE	0x1
39044922Smckusick #define	VLOOK_DELETE	0x2
39144922Smckusick 
392*47527Spendry #define FS_DIRECTORY	0x0001		/* This looks like a dir, not a link */
39344922Smckusick #define	FS_MBACKGROUND	0x0002		/* Should background this mount */
39444922Smckusick #define	FS_NOTIMEOUT	0x0004		/* Don't bother with timeouts */
395*47527Spendry #define FS_MKMNT	0x0008		/* Need to make the mount point */
39644922Smckusick #define FS_UBACKGROUND	0x0010		/* Unmount in background */
39744922Smckusick #define	FS_BACKGROUND	(FS_MBACKGROUND|FS_UBACKGROUND)
39844922Smckusick #define	FS_DISCARD	0x0020		/* Discard immediately on last reference */
39944922Smckusick #define	FS_AMQINFO	0x0040		/* Amq is interested in this fs type */
40044922Smckusick 
40144922Smckusick #ifdef SUNOS4_COMPAT
40244922Smckusick extern am_ops *sunos4_match P((am_opts*, char*, char*, char*, char*, char*));
40344922Smckusick #endif /* SUNOS4_COMPAT */
40444922Smckusick extern am_ops *ops_match P((am_opts*, char*, char*, char*, char*, char*));
40544922Smckusick #include "fstype.h"
40644922Smckusick 
40744922Smckusick /*
40844922Smckusick  * Per-mountpoint statistics
40944922Smckusick  */
41044922Smckusick struct am_stats {
41144922Smckusick 	time_t	s_mtime;	/* Mount time */
41244922Smckusick 	u_short	s_uid;		/* Uid of mounter */
41344922Smckusick 	int	s_getattr;	/* Count of getattrs */
41444922Smckusick 	int	s_lookup;	/* Count of lookups */
41544922Smckusick 	int	s_readdir;	/* Count of readdirs */
41644922Smckusick 	int	s_readlink;	/* Count of readlinks */
41744922Smckusick 	int	s_statfs;	/* Count of statfs */
41844922Smckusick };
41944922Smckusick typedef struct am_stats am_stats;
42044922Smckusick 
42144922Smckusick /*
42244922Smckusick  * System statistics
42344922Smckusick  */
42444922Smckusick struct amd_stats {
42544922Smckusick 	int	d_drops;	/* Dropped requests */
42644922Smckusick 	int	d_stale;	/* Stale NFS handles */
42744922Smckusick 	int	d_mok;		/* Succesful mounts */
42844922Smckusick 	int	d_merr;		/* Failed mounts */
42944922Smckusick 	int	d_uerr;		/* Failed unmounts */
43044922Smckusick };
43144922Smckusick extern struct amd_stats amd_stats;
43244922Smckusick 
43344922Smckusick /*
43444922Smckusick  * List of fileservers
43544922Smckusick  */
43644922Smckusick struct fserver {
43744922Smckusick 	qelem		fs_q;		/* List of fileservers */
43844922Smckusick 	int		fs_refc;	/* Number of references to this node */
43944922Smckusick 	char		*fs_host;	/* Normalized hostname of server */
44044922Smckusick 	struct sockaddr_in *fs_ip;	/* Network address of server */
44144922Smckusick 	int		fs_cid;		/* Callout id */
44244922Smckusick 	int		fs_pinger;	/* Ping (keepalive) interval */
44344922Smckusick 	int		fs_flags;	/* Flags */
44444922Smckusick 	char		*fs_type;	/* File server type */
44544922Smckusick 	voidp		fs_private;	/* Private data */
44644922Smckusick 	void		(*fs_prfree)();	/* Free private data */
44744922Smckusick };
44844922Smckusick #define	FSF_VALID	0x0001		/* Valid information available */
44944922Smckusick #define	FSF_DOWN	0x0002		/* This fileserver is thought to be down */
45044922Smckusick #define	FSF_ERROR	0x0004		/* Permanent error has occured */
45144922Smckusick #define	FSF_WANT	0x0008		/* Want a wakeup call */
45244922Smckusick #define	FSF_PINGING	0x0010		/* Already doing pings */
45344922Smckusick #define	FSRV_ISDOWN(fs)	(((fs)->fs_flags & (FSF_DOWN|FSF_VALID)) == (FSF_DOWN|FSF_VALID))
45444922Smckusick #define	FSRV_ISUP(fs)	(((fs)->fs_flags & (FSF_DOWN|FSF_VALID)) == (FSF_VALID))
45544922Smckusick 
45644922Smckusick /*
45744922Smckusick  * List of mounted filesystems
45844922Smckusick  */
45944922Smckusick struct mntfs {
46044922Smckusick 	qelem		mf_q;		/* List of mounted filesystems */
46144922Smckusick 	am_ops		*mf_ops;	/* Operations on this mountpoint */
46244922Smckusick 	am_opts		*mf_fo;		/* File opts */
46344922Smckusick 	char		*mf_mount;	/* "/a/kiska/home/kiska" */
46444922Smckusick 	char		*mf_info;	/* Mount info */
465*47527Spendry 	char		*mf_auto;	/* Automount opts */
466*47527Spendry 	char		*mf_mopts;	/* FS mount opts */
46744922Smckusick 	fserver		*mf_server;	/* File server */
46844922Smckusick 	int		mf_flags;	/* Flags */
46944922Smckusick 	int		mf_error;	/* Error code from background mount */
47044922Smckusick 	int		mf_refc;	/* Number of references to this node */
47144922Smckusick 	int		mf_cid;		/* Callout id */
47244922Smckusick 	void		(*mf_prfree)();	/* Free private space */
47344922Smckusick 	voidp		mf_private;	/* Private - per-fs data */
47444922Smckusick };
47544922Smckusick 
47644922Smckusick #define	MFF_MOUNTED	0x0001		/* Node is mounted */
47744922Smckusick #define	MFF_MOUNTING	0x0002		/* Mount is in progress */
47844922Smckusick #define	MFF_UNMOUNTING	0x0004		/* Unmount is in progress */
47944922Smckusick #define	MFF_RESTART	0x0008		/* Restarted node */
48044922Smckusick #define MFF_MKMNT	0x0010		/* Delete this node's am_mount */
48144922Smckusick #define	MFF_ERROR	0x0020		/* This node failed to mount */
48244922Smckusick #define	MFF_LOGDOWN	0x0040		/* Logged that this mount is down */
48344922Smckusick #define	MFF_RSTKEEP	0x0080		/* Don't timeout this filesystem - restarted */
48444922Smckusick #define	MFF_WANTTIMO	0x0100		/* Need a timeout call when not busy */
48544922Smckusick 
48644922Smckusick /*
48744922Smckusick  * Map of auto-mount points.
48844922Smckusick  */
48944922Smckusick struct am_node {
49044922Smckusick 	int		am_mapno;	/* Map number */
49144922Smckusick 	mntfs		*am_mnt;	/* Mounted filesystem */
49244922Smckusick 	char		*am_name;	/* "kiska"
49344922Smckusick 					   Name of this node */
49444922Smckusick 	char		*am_path;	/* "/home/kiska"
49544922Smckusick 					   Path of this node's mount point */
49644922Smckusick 	char		*am_link;	/* "/a/kiska/home/kiska/this/that"
49744922Smckusick 					   Link to sub-directory */
49844922Smckusick 	am_node		*am_parent,	/* Parent of this node */
49944922Smckusick 			*am_ysib,	/* Younger sibling of this node */
50044922Smckusick 			*am_osib,	/* Older sibling of this node */
50144922Smckusick 			*am_child;	/* First child of this node */
502*47527Spendry 	struct attrstat	am_attr;	/* File attributes */
503*47527Spendry #define am_fattr	am_attr.attrstat_u.attributes
50444922Smckusick 	int		am_flags;	/* Boolean flags */
50544922Smckusick 	int		am_error;	/* Specific mount error */
50644922Smckusick 	time_t		am_ttl;		/* Time to live */
50744922Smckusick 	int		am_timeo_w;	/* Wait interval */
50844922Smckusick 	int		am_timeo;	/* Timeout interval */
50944922Smckusick 	unsigned int	am_gen;		/* Generation number */
51044922Smckusick 	char		*am_pref;	/* Mount info prefix */
51144922Smckusick 	am_stats	am_stats;	/* Statistics gathering */
51244922Smckusick };
51344922Smckusick 
51444922Smckusick #define	AMF_NOTIMEOUT	0x0001		/* This node never times out */
51544922Smckusick #define	AMF_ROOT	0x0002		/* This is a root node */
51644922Smckusick 
51744922Smckusick #define	ONE_HOUR	(60 * 60)	/* One hour in seconds */
51844922Smckusick 
51944922Smckusick /*
52044922Smckusick  * The following values can be tuned...
52144922Smckusick  */
52244922Smckusick #define	ALLOWED_MOUNT_TIME	40		/* 40s for a mount */
52344922Smckusick #define	AM_TTL			(5 * 60)	/* Default cache period */
52444922Smckusick #define	AM_TTL_W		(2 * 60)	/* Default unmount interval */
52544922Smckusick #define	AM_PINGER		30		/* NFS ping interval for live systems */
52644922Smckusick #define	AFS_TIMEO		8		/* Default afs timeout - .8s */
527*47527Spendry #define	AFS_RETRANS		((ALLOWED_MOUNT_TIME*10+5*afs_timeo)/afs_timeo * 2)
528*47527Spendry 						/* Default afs retrans - 1/10th seconds */
52944922Smckusick 
53044922Smckusick #define	RPC_XID_PORTMAP		0
53144922Smckusick #define	RPC_XID_MOUNTD		1
53244922Smckusick #define	RPC_XID_NFSPING		2
53344922Smckusick #define	RPC_XID_MASK		(0x0f)		/* 16 id's for now */
53444922Smckusick #define	MK_RPC_XID(type_id, uniq)	((type_id) | ((uniq) << 4))
535