aboutsummaryrefslogtreecommitdiff
path: root/conf/mtab/mtab_aix.c
diff options
context:
space:
mode:
Diffstat (limited to 'conf/mtab/mtab_aix.c')
-rw-r--r--conf/mtab/mtab_aix.c178
1 files changed, 178 insertions, 0 deletions
diff --git a/conf/mtab/mtab_aix.c b/conf/mtab/mtab_aix.c
new file mode 100644
index 000000000000..072adc74151d
--- /dev/null
+++ b/conf/mtab/mtab_aix.c
@@ -0,0 +1,178 @@
+/*
+ * Copyright (c) 1997-2014 Erez Zadok
+ * Copyright (c) 1990 Jan-Simon Pendry
+ * Copyright (c) 1990 Imperial College of Science, Technology & Medicine
+ * Copyright (c) 1990 The Regents of the University of California.
+ * All rights reserved.
+ *
+ * This code is derived from software contributed to Berkeley by
+ * Jan-Simon Pendry at Imperial College, London.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * 3. Neither the name of the University nor the names of its contributors
+ * may be used to endorse or promote products derived from this software
+ * without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ *
+ *
+ * File: am-utils/conf/mtab/mtab_aix.c
+ *
+ */
+
+/*
+ * AIX systems don't write their mount tables on a file. Instead, they
+ * use a (better) system where the kernel keeps this state, and you access
+ * the mount tables via a known interface.
+ */
+
+#ifdef HAVE_CONFIG_H
+# include <config.h>
+#endif /* HAVE_CONFIG_H */
+#include <am_defs.h>
+#include <amu.h>
+
+/*
+ * These were missing external definitions from old AIX's headers. They
+ * appear to be available in <sys/vmount.h> on AIX 5.3, and possibly
+ * earlier. Hence I commented this out.
+ */
+#ifndef HAVE_EXTERN_MNTCTL
+extern int mntctl(int cmd, int size, voidp buf);
+#endif /* not HAVE_EXTERN_MNTCTL */
+
+
+static mntent_t *
+mnt_dup(struct vmount *mp)
+{
+ mntent_t *new_mp = ALLOC(mntent_t);
+ char *ty;
+ char *fsname = xstrdup(vmt2dataptr(mp, VMT_OBJECT));
+
+ new_mp->mnt_dir = strdup(vmt2dataptr(mp, VMT_STUB));
+ new_mp->mnt_opts = strdup(vmt2dataptr(mp, VMT_ARGS));
+
+ switch (mp->vmt_gfstype) {
+
+ case MOUNT_TYPE_UFS:
+ ty = MNTTAB_TYPE_UFS;
+ new_mp->mnt_fsname = xstrdup(fsname);
+ break;
+
+ case MOUNT_TYPE_NFS:
+ ty = MNTTAB_TYPE_NFS;
+ new_mp->mnt_fsname = str3cat((char *) NULL,
+ vmt2dataptr(mp, VMT_HOSTNAME), ":",
+ fsname);
+ break;
+
+#ifdef HAVE_FS_NFS3
+ case MOUNT_TYPE_NFS3:
+ ty = MNTTAB_TYPE_NFS3;
+ new_mp->mnt_fsname = str3cat((char *) NULL,
+ vmt2dataptr(mp, VMT_HOSTNAME), ":",
+ fsname);
+ break;
+#endif /* HAVE_FS_NFS3 */
+
+ default:
+ ty = "unknown";
+ new_mp->mnt_fsname = xstrdup(fsname);
+ break;
+
+ }
+
+ new_mp->mnt_type = xstrdup(ty);
+ /* store the VFS ID for uvmount() */
+ new_mp->mnt_passno = mp->vmt_vfsnumber;
+ new_mp->mnt_freq = 0;
+
+ XFREE(fsname);
+
+ return new_mp;
+}
+
+
+/*
+ * Read a mount table into memory
+ */
+mntlist *
+read_mtab(char *fs, const char *mnttabname)
+{
+ mntlist **mpp, *mhp;
+ int i;
+ char *mntinfo = NULL, *cp;
+ struct vmount *vp;
+ int ret;
+ int maxtry = 10; /* maximum number of times to try mntctl */
+
+ /*
+ * Figure out size of mount table and allocate space for a copy. Then get
+ * mount table for real. We repeat this loop at most 10 times to minimze
+ * the chance of a race condition (something gets un/mounted in between
+ * calls to mntctl()
+ */
+ i = sizeof(int);
+ do {
+ if (mntinfo)
+ XFREE(mntinfo);
+ mntinfo = xmalloc(i);
+ ret = mntctl(MCTL_QUERY, i, mntinfo);
+ if (ret == 0)
+ i = *(int*) mntinfo;
+ if (--maxtry <= 0) {
+ plog(XLOG_ERROR, "mntctl: could not get a stable result");
+ ret = -1;
+ errno = EINVAL;
+ break;
+ }
+ } while (ret == 0);
+ if (ret < 0) {
+ plog(XLOG_ERROR, "mntctl: %m");
+ goto out;
+ }
+
+ mpp = &mhp;
+ for (i = 0, cp = mntinfo; i < ret; i++, cp += vp->vmt_length) {
+ vp = (struct vmount *) cp;
+
+ /*
+ * Allocate a new slot
+ */
+ *mpp = ALLOC(struct mntlist);
+
+ /*
+ * Copy the data returned by mntctl
+ */
+ (*mpp)->mnt = mnt_dup(vp);
+
+ /*
+ * Move to next pointer
+ */
+ mpp = &(*mpp)->mnext;
+ }
+
+ *mpp = NULL;
+
+out:
+ if (mntinfo)
+ XFREE(mntinfo);
+ return mhp;
+}