libbe(3): restructure be_mount, skip canmount check for BE dataset
Further cleanup after r349380; loader and kernel will both ignore canmount on the root dataset as well, so we should not be so strict about it when mounting it. be_mount is restructured to make it more clear that depth==0 is special, and to not try fetching these properties that we won't care about. MFC after: 3 days
This commit is contained in:
parent
419110374a
commit
3afb4dc28a
@ -89,25 +89,31 @@ be_mount_iter(zfs_handle_t *zfs_hdl, void *data)
|
|||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (zfs_prop_get_int(zfs_hdl, ZFS_PROP_CANMOUNT) == ZFS_CANMOUNT_OFF)
|
/*
|
||||||
return (0);
|
* canmount and mountpoint are both ignored for the BE dataset, because
|
||||||
|
* the rest of the system (kernel and loader) will effectively do the
|
||||||
if (zfs_prop_get(zfs_hdl, ZFS_PROP_MOUNTPOINT, zfs_mnt, BE_MAXPATHLEN,
|
* same.
|
||||||
NULL, NULL, 0, 1))
|
*/
|
||||||
return (1);
|
if (info->depth == 0) {
|
||||||
|
|
||||||
if (strcmp("none", zfs_mnt) == 0 || info->depth == 0) {
|
|
||||||
/*
|
|
||||||
* mountpoint=none; we'll mount it at info->mountpoint assuming
|
|
||||||
* we're at the root. If we're not at the root, we're likely
|
|
||||||
* at some intermediate dataset (e.g. zroot/var) that will have
|
|
||||||
* children that may need to be mounted.
|
|
||||||
*/
|
|
||||||
if (info->depth > 0)
|
|
||||||
goto skipmount;
|
|
||||||
|
|
||||||
snprintf(tmp, BE_MAXPATHLEN, "%s", info->mountpoint);
|
snprintf(tmp, BE_MAXPATHLEN, "%s", info->mountpoint);
|
||||||
} else {
|
} else {
|
||||||
|
if (zfs_prop_get_int(zfs_hdl, ZFS_PROP_CANMOUNT) ==
|
||||||
|
ZFS_CANMOUNT_OFF)
|
||||||
|
return (0);
|
||||||
|
|
||||||
|
if (zfs_prop_get(zfs_hdl, ZFS_PROP_MOUNTPOINT, zfs_mnt,
|
||||||
|
BE_MAXPATHLEN, NULL, NULL, 0, 1))
|
||||||
|
return (1);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We've encountered mountpoint=none at some intermediate
|
||||||
|
* dataset (e.g. zroot/var) that will have children that may
|
||||||
|
* need to be mounted. Skip mounting it, but iterate through
|
||||||
|
* the children.
|
||||||
|
*/
|
||||||
|
if (strcmp("none", zfs_mnt) == 0)
|
||||||
|
goto skipmount;
|
||||||
|
|
||||||
mountpoint = be_mountpoint_augmented(info->lbh, zfs_mnt);
|
mountpoint = be_mountpoint_augmented(info->lbh, zfs_mnt);
|
||||||
snprintf(tmp, BE_MAXPATHLEN, "%s%s", info->mountpoint,
|
snprintf(tmp, BE_MAXPATHLEN, "%s%s", info->mountpoint,
|
||||||
mountpoint);
|
mountpoint);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user