]> git.decadent.org.uk Git - nfs-utils.git/blobdiff - support/include/nfslib.h
From: Kevin Coffman <kwc@citi.umich.edu>
[nfs-utils.git] / support / include / nfslib.h
index d8be9263bce4e0505f75f8e03aa932dafe555d75..2fbd0f5a1d6ae2cbb606f492cc66edba6403610b 100644 (file)
@@ -23,6 +23,9 @@
 #ifndef _PATH_EXPORTS
 #define _PATH_EXPORTS          "/etc/exports"
 #endif
+#ifndef _PATH_IDMAPDCONF
+#define _PATH_IDMAPDCONF       "/etc/idmapd.conf"
+#endif
 #ifndef _PATH_XTAB
 #define _PATH_XTAB             NFS_STATEDIR "/xtab"
 #endif
@@ -43,6 +46,7 @@
 #endif
 #ifndef _PATH_PROC_EXPORTS
 #define        _PATH_PROC_EXPORTS      "/proc/fs/nfs/exports"
+#define        _PATH_PROC_EXPORTS_ALT  "/proc/fs/nfsd/exports"
 #endif
 
 enum cle_maptypes {
@@ -72,18 +76,21 @@ struct exportent {
        int             e_nsquids;
        int *           e_sqgids;
        int             e_nsqgids;
+       int             e_fsid;
+       char *          e_mountpoint;
 };
 
 struct rmtabent {
        char            r_client[NFSCLNT_IDMAX+1];
        char            r_path[NFS_MAXPATHLEN+1];
+       int             r_count;
 };
 
 /*
  * configuration file parsing
  */
 void                   setexportent(char *fname, char *type);
-struct exportent *     getexportent(void);
+struct exportent *     getexportent(int,int);
 void                   putexportent(struct exportent *xep);
 void                   endexportent(void);
 struct exportent *     mkexportent(char *hname, char *path, char *opts);
@@ -92,13 +99,13 @@ void                        dupexportent(struct exportent *dst,
 int                    updateexportent(struct exportent *eep, char *options);
 
 int                    setrmtabent(char *type);
-struct rmtabent *      getrmtabent(int log);
-void                   putrmtabent(struct rmtabent *xep);
+struct rmtabent *      getrmtabent(int log, long *pos);
+void                   putrmtabent(struct rmtabent *xep, long *pos);
 void                   endrmtabent(void);
 void                   rewindrmtabent(void);
 FILE *                 fsetrmtabent(char *fname, char *type);
-struct rmtabent *      fgetrmtabent(FILE *fp, int log);
-void                   fputrmtabent(FILE *fp, struct rmtabent *xep);
+struct rmtabent *      fgetrmtabent(FILE *fp, int log, long *pos);
+void                   fputrmtabent(FILE *fp, struct rmtabent *xep, long *pos);
 void                   fendrmtabent(FILE *fp);
 void                   frewindrmtabent(FILE *fp);
 
@@ -116,10 +123,24 @@ int                       nfsaddclient(struct nfsctl_client *clp);
 int                    nfsdelclient(struct nfsctl_client *clp);
 int                    nfsexport(struct nfsctl_export *exp);
 int                    nfsunexport(struct nfsctl_export *exp);
-struct knfs_fh *       getfh_old(struct sockaddr *addr, dev_t dev, ino_t ino);
-struct knfs_fh *       getfh(struct sockaddr *addr, const char *);
+struct nfs_fh_len *    getfh_old(struct sockaddr *addr, dev_t dev, ino_t ino);
+struct nfs_fh_len *    getfh(struct sockaddr *addr, const char *);
+struct nfs_fh_len *    getfh_size(struct sockaddr *addr, const char *, int size);
+
+void qword_print(FILE *f, char *str);
+void qword_printhex(FILE *f, char *str, int slen);
+void qword_printint(FILE *f, int num);
+void qword_eol(FILE *f);
+int readline(int fd, char **buf, int *lenp);
+int qword_get(char **bpp, char *dest, int bufsize);
+int qword_get_int(char **bpp, int *anint);
+void cache_flush(int force);
+int check_new_cache(void);
 
 /* lockd. */
 int                    lockdsvc();
 
+int                    svctcp_socket (u_long __number, int __reuse);
+int                    svcudp_socket (u_long __number, int __reuse);
+
 #endif /* NFSLIB_H */