1 /* $NetBSD: mount_irix6.c,v 1.1.1.3 2015/01/17 16:34:16 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/conf/mount/mount_irix6.c
39 *
40 */
41
42 /*
43 * IRIX Mount helper
44 */
45
46 #ifdef HAVE_CONFIG_H
47 # include <config.h>
48 #endif /* HAVE_CONFIG_H */
49 #include <am_defs.h>
50 #include <amu.h>
51
52
53 /*
54 * Map from conventional mount arguments
55 * to IRIX style arguments.
56 */
57 int
mount_irix(char * fsname,char * dir,int flags,MTYPE_TYPE type,voidp data)58 mount_irix(char *fsname, char *dir, int flags, MTYPE_TYPE type, voidp data)
59 {
60
61 #ifdef DEBUG
62 dlog("mount_irix: fsname %s, dir %s, type %s", fsname, dir, type);
63 #endif /* DEBUG */
64
65 #ifdef HAVE_FS_NFS3
66 if (STREQ(type, MOUNT_TYPE_NFS3))
67 return mount(fsname, dir, (MNT2_GEN_OPT_FSS | MNT2_GEN_OPT_DATA | flags),
68 type, (nfs_args_t *) data, sizeof(nfs_args_t));
69 #endif /* HAVE_FS_NFS3 */
70
71 #ifdef HAVE_FS_NFS
72 if (STREQ(type, MOUNT_TYPE_NFS))
73 return mount(fsname, dir, (MNT2_GEN_OPT_FSS | MNT2_GEN_OPT_DATA | flags),
74 type, (nfs_args_t *) data, sizeof(nfs_args_t));
75 #endif /* HAVE_FS_NFS */
76
77 #ifdef HAVE_FS_UFS
78 if (STREQ(type, MOUNT_TYPE_UFS))
79 return mount(fsname, dir, (MNT2_GEN_OPT_FSS | MNT2_GEN_OPT_DATA | flags),
80 type, (ufs_args_t *) data, sizeof(ufs_args_t));
81 #endif /* HAVE_FS_UFS */
82
83 #ifdef HAVE_FS_XFS
84 if (STREQ(type, MOUNT_TYPE_XFS))
85 return mount(fsname, dir, (MNT2_GEN_OPT_FSS | MNT2_GEN_OPT_DATA | flags),
86 type, (xfs_args_t *) data, sizeof(xfs_args_t));
87 #endif /* HAVE_FS_XFS */
88
89 #ifdef HAVE_FS_EFS
90 if (STREQ(type, MOUNT_TYPE_EFS))
91 return mount(fsname, dir, (MNT2_GEN_OPT_FSS | MNT2_GEN_OPT_DATA | flags),
92 type, (efs_args_t *) data, sizeof(efs_args_t));
93 #endif /* HAVE_FS_EFS */
94
95 #ifdef HAVE_FS_AUTOFS
96 if (STREQ(type, MOUNT_TYPE_AUTOFS))
97 return mount(fsname, dir, (MNT2_GEN_OPT_FSS | MNT2_GEN_OPT_DATA | flags),
98 type, (autofs_args_t *) data, sizeof(autofs_args_t));
99 #endif /* HAVE_FS_AUTOFS */
100
101 #ifdef HAVE_FS_LOFS
102 if (STREQ(type, MOUNT_TYPE_LOFS))
103 return mount(fsname, dir, (MNT2_GEN_OPT_FSS | MNT2_GEN_OPT_DATA | flags),
104 type, (char *) NULL, 0);
105 #endif /* HAVE_FS_LOFS */
106
107 return EINVAL;
108 }
109