mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2026-05-25 11:47:43 +03:00
ZVOLs should not be allowed to have children
zfs create, receive and rename can bypass this hierarchy rule. Update both userland and kernel module to prevent this issue and use pyzfs unit tests to exercise the ioctls directly. Note: this commit slightly changes zfs_ioc_create() ABI. This allow to differentiate a generic error (EINVAL) from the specific case where we tried to create a dataset below a ZVOL (ZFS_ERR_WRONG_PARENT). Reviewed-by: Paul Dagnelie <pcd@delphix.com> Reviewed-by: Matt Ahrens <mahrens@delphix.com> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Tom Caputi <tcaputi@datto.com> Signed-off-by: loli10K <ezomori.nozomu@gmail.com>
This commit is contained in:
@@ -33,7 +33,7 @@
|
||||
* Copyright (c) 2014 Integros [integros.com]
|
||||
* Copyright 2016 Toomas Soome <tsoome@me.com>
|
||||
* Copyright (c) 2016 Actifio, Inc. All rights reserved.
|
||||
* Copyright (c) 2017, loli10K <ezomori.nozomu@gmail.com>. All rights reserved.
|
||||
* Copyright (c) 2018, loli10K <ezomori.nozomu@gmail.com>. All rights reserved.
|
||||
* Copyright (c) 2017 Datto Inc. All rights reserved.
|
||||
* Copyright 2017 RackTop Systems.
|
||||
* Copyright (c) 2017 Open-E, Inc. All Rights Reserved.
|
||||
@@ -3082,8 +3082,9 @@ zfs_fill_zplprops_impl(objset_t *os, uint64_t zplver,
|
||||
|
||||
ASSERT(zplprops != NULL);
|
||||
|
||||
/* parent dataset must be a filesystem */
|
||||
if (os != NULL && os->os_phys->os_type != DMU_OST_ZFS)
|
||||
return (SET_ERROR(EINVAL));
|
||||
return (SET_ERROR(ZFS_ERR_WRONG_PARENT));
|
||||
|
||||
/*
|
||||
* Pull out creator prop choices, if any.
|
||||
@@ -3162,15 +3163,11 @@ zfs_fill_zplprops(const char *dataset, nvlist_t *createprops,
|
||||
uint64_t zplver = ZPL_VERSION;
|
||||
objset_t *os = NULL;
|
||||
char parentname[ZFS_MAX_DATASET_NAME_LEN];
|
||||
char *cp;
|
||||
spa_t *spa;
|
||||
uint64_t spa_vers;
|
||||
int error;
|
||||
|
||||
(void) strlcpy(parentname, dataset, sizeof (parentname));
|
||||
cp = strrchr(parentname, '/');
|
||||
ASSERT(cp != NULL);
|
||||
cp[0] = '\0';
|
||||
zfs_get_parent(dataset, parentname, sizeof (parentname));
|
||||
|
||||
if ((error = spa_open(dataset, &spa, FTAG)) != 0)
|
||||
return (error);
|
||||
|
||||
Reference in New Issue
Block a user