Blame lib/mount.x

Packit Service a4b2a9
%/*
Packit Service a4b2a9
% * Sun RPC is a product of Sun Microsystems, Inc. and is provided for
Packit Service a4b2a9
% * unrestricted use provided that this legend is included on all tape
Packit Service a4b2a9
% * media and as a part of the software program in whole or part.  Users
Packit Service a4b2a9
% * may copy or modify Sun RPC without charge, but are not authorized
Packit Service a4b2a9
% * to license or distribute it to anyone else except as part of a product or
Packit Service a4b2a9
% * program developed by the user or with the express written consent of
Packit Service a4b2a9
% * Sun Microsystems, Inc.
Packit Service a4b2a9
% *
Packit Service a4b2a9
% * SUN RPC IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING THE
Packit Service a4b2a9
% * WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR
Packit Service a4b2a9
% * PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE.
Packit Service a4b2a9
% *
Packit Service a4b2a9
% * Sun RPC is provided with no support and without any obligation on the
Packit Service a4b2a9
% * part of Sun Microsystems, Inc. to assist in its use, correction,
Packit Service a4b2a9
% * modification or enhancement.
Packit Service a4b2a9
% *
Packit Service a4b2a9
% * SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE
Packit Service a4b2a9
% * INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY SUN RPC
Packit Service a4b2a9
% * OR ANY PART THEREOF.
Packit Service a4b2a9
% *
Packit Service a4b2a9
% * In no event will Sun Microsystems, Inc. be liable for any lost revenue
Packit Service a4b2a9
% * or profits or other special, indirect and consequential damages, even if
Packit Service a4b2a9
% * Sun has been advised of the possibility of such damages.
Packit Service a4b2a9
% *
Packit Service a4b2a9
% * Sun Microsystems, Inc.
Packit Service a4b2a9
% * 2550 Garcia Avenue
Packit Service a4b2a9
% * Mountain View, California  94043
Packit Service a4b2a9
% */
Packit Service a4b2a9
Packit Service a4b2a9
%/*
Packit Service a4b2a9
% * Copyright (c) 1985, 1990 by Sun Microsystems, Inc.
Packit Service a4b2a9
% */
Packit Service a4b2a9
%
Packit Service a4b2a9
%/* from @(#)mount.x	1.3 91/03/11 TIRPC 1.0 */
Packit Service a4b2a9
Packit Service a4b2a9
/*
Packit Service a4b2a9
 * Protocol description for the mount program
Packit Service a4b2a9
 */
Packit Service a4b2a9
Packit Service a4b2a9
#ifdef RPC_HDR
Packit Service a4b2a9
%#ifndef _rpcsvc_mount_h
Packit Service a4b2a9
%#define _rpcsvc_mount_h
Packit Service a4b2a9
%#include <memory.h>
Packit Service a4b2a9
#endif
Packit Service a4b2a9
Packit Service a4b2a9
const MNTPATHLEN = 1024;	/* maximum bytes in a pathname argument */
Packit Service a4b2a9
const MNTNAMLEN = 255;		/* maximum bytes in a name argument */
Packit Service a4b2a9
const FHSIZE = 32;		/* size in bytes of a file handle */
Packit Service a4b2a9
Packit Service a4b2a9
/*
Packit Service a4b2a9
 * The fhandle is the file handle that the server passes to the client.
Packit Service a4b2a9
 * All file operations are done using the file handles to refer to a file
Packit Service a4b2a9
 * or a directory. The file handle can contain whatever information the
Packit Service a4b2a9
 * server needs to distinguish an individual file.
Packit Service a4b2a9
 */
Packit Service a4b2a9
typedef opaque fhandle[FHSIZE];	
Packit Service a4b2a9
Packit Service a4b2a9
/*
Packit Service a4b2a9
 * If a status of zero is returned, the call completed successfully, and 
Packit Service a4b2a9
 * a file handle for the directory follows. A non-zero status indicates
Packit Service a4b2a9
 * some sort of error. The status corresponds with UNIX error numbers.
Packit Service a4b2a9
 */
Packit Service a4b2a9
union fhstatus switch (unsigned fhs_status) {
Packit Service a4b2a9
case 0:
Packit Service a4b2a9
	fhandle fhs_fhandle;
Packit Service a4b2a9
default:
Packit Service a4b2a9
	void;
Packit Service a4b2a9
};
Packit Service a4b2a9
Packit Service a4b2a9
/*
Packit Service a4b2a9
 * The type dirpath is the pathname of a directory
Packit Service a4b2a9
 */
Packit Service a4b2a9
typedef string dirpath<MNTPATHLEN>;
Packit Service a4b2a9
Packit Service a4b2a9
/*
Packit Service a4b2a9
 * The type name is used for arbitrary names (hostnames, groupnames)
Packit Service a4b2a9
 */
Packit Service a4b2a9
typedef string name<MNTNAMLEN>;
Packit Service a4b2a9
Packit Service a4b2a9
/*
Packit Service a4b2a9
 * A list of who has what mounted
Packit Service a4b2a9
 */
Packit Service a4b2a9
typedef struct mountbody *mountlist;
Packit Service a4b2a9
struct mountbody {
Packit Service a4b2a9
	name ml_hostname;
Packit Service a4b2a9
	dirpath ml_directory;
Packit Service a4b2a9
	mountlist ml_next;
Packit Service a4b2a9
};
Packit Service a4b2a9
Packit Service a4b2a9
/*
Packit Service a4b2a9
 * A list of netgroups
Packit Service a4b2a9
 */
Packit Service a4b2a9
typedef struct groupnode *groups;
Packit Service a4b2a9
struct groupnode {
Packit Service a4b2a9
	name gr_name;
Packit Service a4b2a9
	groups gr_next;
Packit Service a4b2a9
};
Packit Service a4b2a9
Packit Service a4b2a9
/*
Packit Service a4b2a9
 * A list of what is exported and to whom
Packit Service a4b2a9
 */
Packit Service a4b2a9
typedef struct exportnode *exports;
Packit Service a4b2a9
struct exportnode {
Packit Service a4b2a9
	dirpath ex_dir;
Packit Service a4b2a9
	groups ex_groups;
Packit Service a4b2a9
	exports ex_next;
Packit Service a4b2a9
};
Packit Service a4b2a9
Packit Service a4b2a9
/*
Packit Service a4b2a9
 * POSIX pathconf information
Packit Service a4b2a9
 */
Packit Service a4b2a9
struct ppathcnf {
Packit Service a4b2a9
	int	pc_link_max;	/* max links allowed */
Packit Service a4b2a9
	short	pc_max_canon;	/* max line len for a tty */
Packit Service a4b2a9
	short	pc_max_input;	/* input a tty can eat all at once */
Packit Service a4b2a9
	short	pc_name_max;	/* max file name length (dir entry) */
Packit Service a4b2a9
	short	pc_path_max;	/* max path name length (/x/y/x/.. ) */
Packit Service a4b2a9
	short	pc_pipe_buf;	/* size of a pipe (bytes) */
Packit Service a4b2a9
	u_char	pc_vdisable;	/* safe char to turn off c_cc[i] */
Packit Service a4b2a9
	char	pc_xxx;		/* alignment padding; cc_t == char */
Packit Service a4b2a9
	short	pc_mask[2];	/* validity and boolean bits */
Packit Service a4b2a9
};
Packit Service a4b2a9
Packit Service a4b2a9
/*
Packit Service a4b2a9
 * NFSv3 file handle
Packit Service a4b2a9
 */
Packit Service a4b2a9
const FHSIZE3 =	64;		/* max size of NFSv3 file handle in bytes */
Packit Service a4b2a9
typedef opaque		fhandle3<FHSIZE3>;
Packit Service a4b2a9
Packit Service a4b2a9
/*
Packit Service a4b2a9
 * NFSv3 mount status
Packit Service a4b2a9
 */
Packit Service a4b2a9
enum mountstat3 {
Packit Service a4b2a9
	MNT_OK			= 0,	/* no error */
Packit Service a4b2a9
	MNT3ERR_PERM		= 1,	/* not owner */
Packit Service a4b2a9
	MNT3ERR_NOENT		= 2,	/* no such file or directory */
Packit Service a4b2a9
	MNT3ERR_IO		= 5,	/* I/O error */
Packit Service a4b2a9
	MNT3ERR_ACCES		= 13,	/* Permission denied */
Packit Service a4b2a9
	MNT3ERR_NOTDIR		= 20,	/* Not a directory */
Packit Service a4b2a9
	MNT3ERR_INVAL		= 22,	/* Invalid argument */
Packit Service a4b2a9
	MNT3ERR_NAMETOOLONG	= 63,	/* File name too long */
Packit Service a4b2a9
	MNT3ERR_NOTSUPP		= 10004,/* Operation not supported */
Packit Service a4b2a9
	MNT3ERR_SERVERFAULT	= 10006	/* A failure on the server */
Packit Service a4b2a9
};
Packit Service a4b2a9
Packit Service a4b2a9
/*
Packit Service a4b2a9
 * NFSv3 mount result
Packit Service a4b2a9
 */
Packit Service a4b2a9
struct mountres3_ok {
Packit Service a4b2a9
	fhandle3	fhandle;
Packit Service a4b2a9
	int		auth_flavors<>;
Packit Service a4b2a9
};
Packit Service a4b2a9
Packit Service a4b2a9
union mountres3 switch (mountstat3 fhs_status) {
Packit Service a4b2a9
case MNT_OK:
Packit Service a4b2a9
	mountres3_ok	mountinfo; /* File handle and supported flavors */
Packit Service a4b2a9
default:
Packit Service a4b2a9
	void;
Packit Service a4b2a9
};
Packit Service a4b2a9
Packit Service a4b2a9
program MOUNTPROG {
Packit Service a4b2a9
	/*
Packit Service a4b2a9
	 * Version one of the mount protocol communicates with version two
Packit Service a4b2a9
	 * of the NFS protocol. The only connecting point is the fhandle 
Packit Service a4b2a9
	 * structure, which is the same for both protocols.
Packit Service a4b2a9
	 */
Packit Service a4b2a9
	version MOUNTVERS {
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Does no work. It is made available in all RPC services
Packit Service a4b2a9
		 * to allow server reponse testing and timing
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		void
Packit Service a4b2a9
		MOUNTPROC_NULL(void) = 0;
Packit Service a4b2a9
Packit Service a4b2a9
		/*	
Packit Service a4b2a9
		 * If fhs_status is 0, then fhs_fhandle contains the
Packit Service a4b2a9
	 	 * file handle for the directory. This file handle may
Packit Service a4b2a9
		 * be used in the NFS protocol. This procedure also adds
Packit Service a4b2a9
		 * a new entry to the mount list for this client mounting
Packit Service a4b2a9
		 * the directory.
Packit Service a4b2a9
		 * Unix authentication required.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		fhstatus 
Packit Service a4b2a9
		MOUNTPROC_MNT(dirpath) = 1;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Returns the list of remotely mounted filesystems. The 
Packit Service a4b2a9
		 * mountlist contains one entry for each hostname and 
Packit Service a4b2a9
		 * directory pair.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		mountlist
Packit Service a4b2a9
		MOUNTPROC_DUMP(void) = 2;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Removes the mount list entry for the directory
Packit Service a4b2a9
		 * Unix authentication required.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		void
Packit Service a4b2a9
		MOUNTPROC_UMNT(dirpath) = 3;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Removes all of the mount list entries for this client
Packit Service a4b2a9
		 * Unix authentication required.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		void
Packit Service a4b2a9
		MOUNTPROC_UMNTALL(void) = 4;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Returns a list of all the exported filesystems, and which
Packit Service a4b2a9
		 * machines are allowed to import it.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		exports
Packit Service a4b2a9
		MOUNTPROC_EXPORT(void)  = 5;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Identical to MOUNTPROC_EXPORT above
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		exports
Packit Service a4b2a9
		MOUNTPROC_EXPORTALL(void) = 6;
Packit Service a4b2a9
	} = 1;
Packit Service a4b2a9
Packit Service a4b2a9
	/*
Packit Service a4b2a9
	 * Version two of the mount protocol communicates with version two
Packit Service a4b2a9
	 * of the NFS protocol.
Packit Service a4b2a9
	 * The only difference from version one is the addition of a POSIX
Packit Service a4b2a9
	 * pathconf call.
Packit Service a4b2a9
	 */
Packit Service a4b2a9
	version MOUNTVERS_POSIX {
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Does no work. It is made available in all RPC services
Packit Service a4b2a9
		 * to allow server reponse testing and timing
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		void
Packit Service a4b2a9
		MOUNTPROC_NULL(void) = 0;
Packit Service a4b2a9
Packit Service a4b2a9
		/*	
Packit Service a4b2a9
		 * If fhs_status is 0, then fhs_fhandle contains the
Packit Service a4b2a9
	 	 * file handle for the directory. This file handle may
Packit Service a4b2a9
		 * be used in the NFS protocol. This procedure also adds
Packit Service a4b2a9
		 * a new entry to the mount list for this client mounting
Packit Service a4b2a9
		 * the directory.
Packit Service a4b2a9
		 * Unix authentication required.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		fhstatus 
Packit Service a4b2a9
		MOUNTPROC_MNT(dirpath) = 1;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Returns the list of remotely mounted filesystems. The 
Packit Service a4b2a9
		 * mountlist contains one entry for each hostname and 
Packit Service a4b2a9
		 * directory pair.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		mountlist
Packit Service a4b2a9
		MOUNTPROC_DUMP(void) = 2;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Removes the mount list entry for the directory
Packit Service a4b2a9
		 * Unix authentication required.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		void
Packit Service a4b2a9
		MOUNTPROC_UMNT(dirpath) = 3;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Removes all of the mount list entries for this client
Packit Service a4b2a9
		 * Unix authentication required.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		void
Packit Service a4b2a9
		MOUNTPROC_UMNTALL(void) = 4;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Returns a list of all the exported filesystems, and which
Packit Service a4b2a9
		 * machines are allowed to import it.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		exports
Packit Service a4b2a9
		MOUNTPROC_EXPORT(void)  = 5;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Identical to MOUNTPROC_EXPORT above
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		exports
Packit Service a4b2a9
		MOUNTPROC_EXPORTALL(void) = 6;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * POSIX pathconf info (Sun hack)
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		ppathcnf
Packit Service a4b2a9
		MOUNTPROC_PATHCONF(dirpath) = 7;
Packit Service a4b2a9
	} = 2;
Packit Service a4b2a9
Packit Service a4b2a9
	/*
Packit Service a4b2a9
	 * Version 3 of the protocol is for NFSv3
Packit Service a4b2a9
	 */
Packit Service a4b2a9
	version MOUNTVERS_NFSV3 {
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Does no work. It is made available in all RPC services
Packit Service a4b2a9
		 * to allow server reponse testing and timing
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		void
Packit Service a4b2a9
		MOUNTPROC3_NULL(void) = 0;
Packit Service a4b2a9
Packit Service a4b2a9
		/*	
Packit Service a4b2a9
		 * If fhs_status is 0, then fhs_fhandle contains the
Packit Service a4b2a9
	 	 * file handle for the directory. This file handle may
Packit Service a4b2a9
		 * be used in the NFS protocol. This procedure also adds
Packit Service a4b2a9
		 * a new entry to the mount list for this client mounting
Packit Service a4b2a9
		 * the directory.
Packit Service a4b2a9
		 * Unix authentication required.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		mountres3 
Packit Service a4b2a9
		MOUNTPROC3_MNT(dirpath) = 1;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Returns the list of remotely mounted filesystems. The 
Packit Service a4b2a9
		 * mountlist contains one entry for each hostname and 
Packit Service a4b2a9
		 * directory pair.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		mountlist
Packit Service a4b2a9
		MOUNTPROC3_DUMP(void) = 2;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Removes the mount list entry for the directory
Packit Service a4b2a9
		 * Unix authentication required.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		void
Packit Service a4b2a9
		MOUNTPROC3_UMNT(dirpath) = 3;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Removes all of the mount list entries for this client
Packit Service a4b2a9
		 * Unix authentication required.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		void
Packit Service a4b2a9
		MOUNTPROC3_UMNTALL(void) = 4;
Packit Service a4b2a9
Packit Service a4b2a9
		/*
Packit Service a4b2a9
		 * Returns a list of all the exported filesystems, and which
Packit Service a4b2a9
		 * machines are allowed to import it.
Packit Service a4b2a9
		 */
Packit Service a4b2a9
		exports
Packit Service a4b2a9
		MOUNTPROC3_EXPORT(void)  = 5;
Packit Service a4b2a9
	} = 3;
Packit Service a4b2a9
} = 100005;
Packit Service a4b2a9
Packit Service a4b2a9
#ifdef RPC_HDR
Packit Service a4b2a9
%#endif /*!_rpcsvc_mount_h*/
Packit Service a4b2a9
#endif