mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-15 04:30:33 +03:00
3fb1fcdea1
By design the zfs utility is supposed to handle mounting and unmounting a zfs filesystem. We could allow zfs to do this directly. There are system calls available to mount/umount a filesystem. And there are library calls available to manipulate /etc/mtab. But there are a couple very good reasons not to take this appraoch... for now. Instead of directly calling the system and library calls to (u)mount the filesystem we fork and exec a (u)mount process. The principle reason for this is to delegate the responsibility for locking and updating /etc/mtab to (u)mount(8). This ensures maximum portability and ensures the right locking scheme for your version of (u)mount will be used. If we didn't do this we would have to resort to an autoconf test to determine what locking mechanism is used. The downside to using mount(8) instead of mount(2) is that we lose the exact errno which was returned by the kernel. The return code from mount(8) provides some insight in to what went wrong but it not quite as good. For the moment this is translated as a best guess in to a errno for the higher layers of zfs. In the long term a shared library called libmount is under development which provides a common API to address the locking and errno issues. Once the standard mount utility has been updated to use this library we can then leverage it. Until then this is the only safe solution. http://www.kernel.org/pub/linux/utils/util-linux/libmount-docs/index.html
87 lines
2.3 KiB
C
87 lines
2.3 KiB
C
/*
|
|
* CDDL HEADER START
|
|
*
|
|
* The contents of this file are subject to the terms of the
|
|
* Common Development and Distribution License, Version 1.0 only
|
|
* (the "License"). You may not use this file except in compliance
|
|
* with the License.
|
|
*
|
|
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
|
|
* or http://www.opensolaris.org/os/licensing.
|
|
* See the License for the specific language governing permissions
|
|
* and limitations under the License.
|
|
*
|
|
* When distributing Covered Code, include this CDDL HEADER in each
|
|
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
|
|
* If applicable, add the following below this CDDL HEADER, with the
|
|
* fields enclosed by brackets "[]" replaced with your own identifying
|
|
* information: Portions Copyright [yyyy] [name of copyright owner]
|
|
*
|
|
* CDDL HEADER END
|
|
*/
|
|
/* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T*/
|
|
/* All Rights Reserved */
|
|
/*
|
|
* Copyright 2004 Sun Microsystems, Inc. All rights reserved.
|
|
* Use is subject to license terms.
|
|
*/
|
|
/* Copyright 2006 Ricardo Correia */
|
|
|
|
#ifndef _SYS_MNTTAB_H
|
|
#define _SYS_MNTTAB_H
|
|
|
|
#include <stdio.h>
|
|
#include <mntent.h>
|
|
#include <sys/types.h>
|
|
|
|
#ifdef MNTTAB
|
|
#undef MNTTAB
|
|
#endif /* MNTTAB */
|
|
|
|
#define MNTTAB "/etc/mtab"
|
|
#define MNT_LINE_MAX 1024
|
|
|
|
#define MNT_TOOLONG 1 /* entry exceeds MNT_LINE_MAX */
|
|
#define MNT_TOOMANY 2 /* too many fields in line */
|
|
#define MNT_TOOFEW 3 /* too few fields in line */
|
|
|
|
struct mnttab {
|
|
char *mnt_special;
|
|
char *mnt_mountp;
|
|
char *mnt_fstype;
|
|
char *mnt_mntopts;
|
|
};
|
|
|
|
/*
|
|
* NOTE: fields in extmnttab should match struct mnttab till new fields
|
|
* are encountered, this allows hasmntopt to work properly when its arg is
|
|
* a pointer to an extmnttab struct cast to a mnttab struct pointer.
|
|
*/
|
|
|
|
struct extmnttab {
|
|
char *mnt_special;
|
|
char *mnt_mountp;
|
|
char *mnt_fstype;
|
|
char *mnt_mntopts;
|
|
uint_t mnt_major;
|
|
uint_t mnt_minor;
|
|
};
|
|
|
|
extern int getmntany(FILE *fp, struct mnttab *mp, struct mnttab *mpref);
|
|
extern int _sol_getmntent(FILE *fp, struct mnttab *mp);
|
|
extern int getextmntent(FILE *fp, struct extmnttab *mp, int len);
|
|
|
|
static inline char *_sol_hasmntopt(struct mnttab *mnt, char *opt)
|
|
{
|
|
struct mntent mnt_new;
|
|
|
|
mnt_new.mnt_opts = mnt->mnt_mntopts;
|
|
|
|
return hasmntopt(&mnt_new, opt);
|
|
}
|
|
|
|
#define hasmntopt _sol_hasmntopt
|
|
#define getmntent _sol_getmntent
|
|
|
|
#endif
|