4 * Copyright (c) 1997-2009 Erez Zadok
5 * Copyright (c) 1989 Jan-Simon Pendry
6 * Copyright (c) 1989 Imperial College of Science, Technology & Medicine
7 * Copyright (c) 1989 The Regents of the University of California.
10 * This code is derived from software contributed to Berkeley by
11 * Jan-Simon Pendry at Imperial College, London.
13 * Redistribution and use in source and binary forms, with or without
14 * modification, are permitted provided that the following conditions
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. All advertising materials mentioning features or use of this software
22 * must display the following acknowledgment:
23 * This product includes software developed by the University of
24 * California, Berkeley and its contributors.
25 * 4. Neither the name of the University nor the names of its contributors
26 * may be used to endorse or promote products derived from this software
27 * without specific prior written permission.
29 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
30 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
31 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
32 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
33 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
34 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
35 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
36 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
37 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
38 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
42 * File: am-utils/amd/amfs_error.c
48 * This is used as a last resort catchall if
49 * nothing else worked. EFS just returns lots
50 * of error codes, except for unmount which
51 * always works of course.
56 #endif /* HAVE_CONFIG_H */
60 static char *amfs_error_match(am_opts
*fo
);
61 static int amfs_error_mount(am_node
*am
, mntfs
*mf
);
62 static int amfs_error_umount(am_node
*am
, mntfs
*mf
);
68 am_ops amfs_error_ops
=
72 0, /* amfs_error_init */
75 amfs_error_lookup_child
,
76 amfs_error_mount_child
,
78 0, /* amfs_error_readlink */
79 0, /* amfs_error_mounted */
80 0, /* amfs_error_umounted */
81 amfs_generic_find_srvr
,
82 0, /* amfs_error_get_wchan */
83 FS_DISCARD
, /* nfs_fs_flags */
85 AUTOFS_ERROR_FS_FLAGS
,
86 #endif /* HAVE_FS_AUTOFS */
92 * EFS file system always matches
95 amfs_error_match(am_opts
*fo
)
97 return strdup("(error-hook)");
102 amfs_error_mount(am_node
*am
, mntfs
*mf
)
109 amfs_error_umount(am_node
*am
, mntfs
*mf
)
119 * EFS interface to RPC lookup() routine.
120 * Should never get here in the automounter.
121 * If we do then just give an error.
124 amfs_error_lookup_child(am_node
*mp
, char *fname
, int *error_return
, int op
)
126 *error_return
= ESTALE
;
132 * EFS interface to RPC lookup() routine.
133 * Should never get here in the automounter.
134 * If we do then just give an error.
137 amfs_error_mount_child(am_node
*ap
, int *error_return
)
139 *error_return
= ESTALE
;
145 * EFS interface to RPC readdir() routine.
146 * Should never get here in the automounter.
147 * If we do then just give an error.
150 amfs_error_readdir(am_node
*mp
, nfscookie cookie
, nfsdirlist
*dp
, nfsentry
*ep
, u_int count
)