Update linux-kernel-device to handle ioc changes
Upstream they modified the ioctl code so we need to make similiar updates since we modify the API ourselves to always pass a pointer to file pointer around. This allows us to track per file handle state which is used by the zevent code.
This commit is contained in:
parent
101243ff1d
commit
67e8f48f1b
|
@ -104,8 +104,8 @@ static const char *userquota_perms[] = {
|
||||||
static int zfs_ioc_userspace_upgrade(struct file *filp, zfs_cmd_t *zc);
|
static int zfs_ioc_userspace_upgrade(struct file *filp, zfs_cmd_t *zc);
|
||||||
static int zfs_check_settable(struct file *filp, const char *name,
|
static int zfs_check_settable(struct file *filp, const char *name,
|
||||||
nvpair_t *property, cred_t *cr);
|
nvpair_t *property, cred_t *cr);
|
||||||
static int zfs_check_clearable(char *dataset, nvlist_t *props,
|
static int zfs_check_clearable(struct file *filp, char *dataset,
|
||||||
nvlist_t **errors);
|
nvlist_t *props, nvlist_t **errors);
|
||||||
static int zfs_fill_zplprops_root(uint64_t, nvlist_t *, nvlist_t *,
|
static int zfs_fill_zplprops_root(uint64_t, nvlist_t *, nvlist_t *,
|
||||||
boolean_t *);
|
boolean_t *);
|
||||||
int zfs_set_prop_nvlist(struct file *filp, const char *, zprop_source_t,
|
int zfs_set_prop_nvlist(struct file *filp, const char *, zprop_source_t,
|
||||||
|
@ -339,6 +339,7 @@ zfs_secpolicy_write_perms(const char *name, const char *perm, cred_t *cr)
|
||||||
static int
|
static int
|
||||||
zfs_set_slabel_policy(const char *name, char *strval, cred_t *cr)
|
zfs_set_slabel_policy(const char *name, char *strval, cred_t *cr)
|
||||||
{
|
{
|
||||||
|
#if 0
|
||||||
char ds_hexsl[MAXNAMELEN];
|
char ds_hexsl[MAXNAMELEN];
|
||||||
bslabel_t ds_sl, new_sl;
|
bslabel_t ds_sl, new_sl;
|
||||||
boolean_t new_default = FALSE;
|
boolean_t new_default = FALSE;
|
||||||
|
@ -426,6 +427,9 @@ out_check:
|
||||||
if (needed_priv != -1)
|
if (needed_priv != -1)
|
||||||
return (PRIV_POLICY(cr, needed_priv, B_FALSE, EPERM, NULL));
|
return (PRIV_POLICY(cr, needed_priv, B_FALSE, EPERM, NULL));
|
||||||
return (0);
|
return (0);
|
||||||
|
#else
|
||||||
|
return EPERM;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
@ -958,7 +962,7 @@ fit_error_list(zfs_cmd_t *zc, nvlist_t **errors)
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
int
|
||||||
put_nvlist(zfs_cmd_t *zc, nvlist_t *nvl)
|
put_nvlist(zfs_cmd_t *zc, nvlist_t *nvl)
|
||||||
{
|
{
|
||||||
char *packed = NULL;
|
char *packed = NULL;
|
||||||
|
@ -1009,6 +1013,7 @@ getzfsvfs(const char *dsname, zfsvfs_t **zfvp)
|
||||||
dmu_objset_rele(os, FTAG);
|
dmu_objset_rele(os, FTAG);
|
||||||
return (error);
|
return (error);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Find a zfsvfs_t for a mounted filesystem, or create our own, in which
|
* Find a zfsvfs_t for a mounted filesystem, or create our own, in which
|
||||||
|
@ -1017,6 +1022,7 @@ getzfsvfs(const char *dsname, zfsvfs_t **zfvp)
|
||||||
static int
|
static int
|
||||||
zfsvfs_hold(const char *name, void *tag, zfsvfs_t **zfvp)
|
zfsvfs_hold(const char *name, void *tag, zfsvfs_t **zfvp)
|
||||||
{
|
{
|
||||||
|
#ifdef HAVE_ZPL
|
||||||
int error = 0;
|
int error = 0;
|
||||||
|
|
||||||
if (getzfsvfs(name, zfvp) != 0)
|
if (getzfsvfs(name, zfvp) != 0)
|
||||||
|
@ -1034,11 +1040,15 @@ zfsvfs_hold(const char *name, void *tag, zfsvfs_t **zfvp)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return (error);
|
return (error);
|
||||||
|
#else
|
||||||
|
return ENOTSUP;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
zfsvfs_rele(zfsvfs_t *zfsvfs, void *tag)
|
zfsvfs_rele(zfsvfs_t *zfsvfs, void *tag)
|
||||||
{
|
{
|
||||||
|
#ifdef HAVE_ZPL
|
||||||
rrw_exit(&zfsvfs->z_teardown_lock, tag);
|
rrw_exit(&zfsvfs->z_teardown_lock, tag);
|
||||||
|
|
||||||
if (zfsvfs->z_vfs) {
|
if (zfsvfs->z_vfs) {
|
||||||
|
@ -1047,8 +1057,8 @@ zfsvfs_rele(zfsvfs_t *zfsvfs, void *tag)
|
||||||
dmu_objset_disown(zfsvfs->z_os, zfsvfs);
|
dmu_objset_disown(zfsvfs->z_os, zfsvfs);
|
||||||
zfsvfs_free(zfsvfs);
|
zfsvfs_free(zfsvfs);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
#endif /* HAVE_ZPL */
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
zfs_ioc_pool_create(struct file *filp, zfs_cmd_t *zc)
|
zfs_ioc_pool_create(struct file *filp, zfs_cmd_t *zc)
|
||||||
|
@ -1559,8 +1569,7 @@ zfs_ioc_vdev_split(struct file *filp, zfs_cmd_t *zc)
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
zfs_ioc_vdev_setpath(zfs_cmd_t *zc)
|
zfs_ioc_vdev_setpath(struct file *filp, zfs_cmd_t *zc)
|
||||||
>>>>>>> refs/top-bases/linux-kernel-device
|
|
||||||
{
|
{
|
||||||
spa_t *spa;
|
spa_t *spa;
|
||||||
char *path = zc->zc_value;
|
char *path = zc->zc_value;
|
||||||
|
@ -1888,6 +1897,7 @@ top:
|
||||||
static int
|
static int
|
||||||
zfs_prop_set_userquota(struct file *filp, const char *dsname, nvpair_t *pair)
|
zfs_prop_set_userquota(struct file *filp, const char *dsname, nvpair_t *pair)
|
||||||
{
|
{
|
||||||
|
#ifdef HAVE_ZPL
|
||||||
const char *propname = nvpair_name(pair);
|
const char *propname = nvpair_name(pair);
|
||||||
uint64_t *valary;
|
uint64_t *valary;
|
||||||
unsigned int vallen;
|
unsigned int vallen;
|
||||||
|
@ -1928,6 +1938,9 @@ zfs_prop_set_userquota(struct file *filp, const char *dsname, nvpair_t *pair)
|
||||||
}
|
}
|
||||||
|
|
||||||
return (err);
|
return (err);
|
||||||
|
#else
|
||||||
|
return ENOTSUP;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -1949,7 +1962,7 @@ zfs_prop_set_special(struct file *filp, const char *dsname,
|
||||||
|
|
||||||
if (prop == ZPROP_INVAL) {
|
if (prop == ZPROP_INVAL) {
|
||||||
if (zfs_prop_userquota(propname))
|
if (zfs_prop_userquota(propname))
|
||||||
return (zfs_prop_set_userquota(dsname, pair));
|
return (zfs_prop_set_userquota(filp, dsname, pair));
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1989,7 +2002,9 @@ zfs_prop_set_special(struct file *filp, const char *dsname,
|
||||||
if ((err = zfsvfs_hold(dsname, FTAG, &zfsvfs)) != 0)
|
if ((err = zfsvfs_hold(dsname, FTAG, &zfsvfs)) != 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
#ifdef HAVE_ZPL
|
||||||
err = zfs_set_version(zfsvfs, intval);
|
err = zfs_set_version(zfsvfs, intval);
|
||||||
|
#endif
|
||||||
zfsvfs_rele(zfsvfs, FTAG);
|
zfsvfs_rele(zfsvfs, FTAG);
|
||||||
|
|
||||||
if (err == 0 && intval >= ZPL_VERSION_USERSPACE) {
|
if (err == 0 && intval >= ZPL_VERSION_USERSPACE) {
|
||||||
|
@ -1997,7 +2012,7 @@ zfs_prop_set_special(struct file *filp, const char *dsname,
|
||||||
|
|
||||||
zc = kmem_zalloc(sizeof (zfs_cmd_t), KM_SLEEP);
|
zc = kmem_zalloc(sizeof (zfs_cmd_t), KM_SLEEP);
|
||||||
(void) strcpy(zc->zc_name, dsname);
|
(void) strcpy(zc->zc_name, dsname);
|
||||||
(void) zfs_ioc_userspace_upgrade(zc);
|
(void) zfs_ioc_userspace_upgrade(filp, zc);
|
||||||
kmem_free(zc, sizeof (zfs_cmd_t));
|
kmem_free(zc, sizeof (zfs_cmd_t));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -2097,10 +2112,10 @@ retry:
|
||||||
|
|
||||||
/* Validate permissions */
|
/* Validate permissions */
|
||||||
if (err == 0)
|
if (err == 0)
|
||||||
err = zfs_check_settable(dsname, pair, CRED());
|
err = zfs_check_settable(filp, dsname, pair, CRED());
|
||||||
|
|
||||||
if (err == 0) {
|
if (err == 0) {
|
||||||
err = zfs_prop_set_special(dsname, source, pair);
|
err = zfs_prop_set_special(filp, dsname, source, pair);
|
||||||
if (err == -1) {
|
if (err == -1) {
|
||||||
/*
|
/*
|
||||||
* For better performance we build up a list of
|
* For better performance we build up a list of
|
||||||
|
@ -2229,8 +2244,8 @@ props_skip(nvlist_t *props, nvlist_t *skipped, nvlist_t **newprops)
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
clear_received_props(objset_t *os, const char *fs, nvlist_t *props,
|
clear_received_props(struct file *filp, objset_t *os,
|
||||||
nvlist_t *skipped)
|
const char *fs, nvlist_t *props, nvlist_t *skipped)
|
||||||
{
|
{
|
||||||
int err = 0;
|
int err = 0;
|
||||||
nvlist_t *cleared_props = NULL;
|
nvlist_t *cleared_props = NULL;
|
||||||
|
@ -2242,7 +2257,7 @@ clear_received_props(objset_t *os, const char *fs, nvlist_t *props,
|
||||||
*/
|
*/
|
||||||
zprop_source_t flags = (ZPROP_SRC_NONE |
|
zprop_source_t flags = (ZPROP_SRC_NONE |
|
||||||
(dsl_prop_get_hasrecvd(os) ? ZPROP_SRC_RECEIVED : 0));
|
(dsl_prop_get_hasrecvd(os) ? ZPROP_SRC_RECEIVED : 0));
|
||||||
err = zfs_set_prop_nvlist(fs, flags, cleared_props, NULL);
|
err = zfs_set_prop_nvlist(filp, fs, flags, cleared_props, NULL);
|
||||||
}
|
}
|
||||||
nvlist_free(cleared_props);
|
nvlist_free(cleared_props);
|
||||||
return (err);
|
return (err);
|
||||||
|
@ -2355,7 +2370,7 @@ zfs_ioc_inherit_prop(struct file *filp, zfs_cmd_t *zc)
|
||||||
}
|
}
|
||||||
|
|
||||||
pair = nvlist_next_nvpair(dummy, NULL);
|
pair = nvlist_next_nvpair(dummy, NULL);
|
||||||
err = zfs_prop_set_special(zc->zc_name, source, pair);
|
err = zfs_prop_set_special(filp, zc->zc_name, source, pair);
|
||||||
nvlist_free(dummy);
|
nvlist_free(dummy);
|
||||||
if (err != -1)
|
if (err != -1)
|
||||||
return (err); /* special property already handled */
|
return (err); /* special property already handled */
|
||||||
|
@ -2521,6 +2536,7 @@ zfs_ioc_get_fsacl(struct file *filp, zfs_cmd_t *zc)
|
||||||
return (error);
|
return (error);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef HAVE_ZPL
|
||||||
/*
|
/*
|
||||||
* Search the vfs list for a specified resource. Returns a pointer to it
|
* Search the vfs list for a specified resource. Returns a pointer to it
|
||||||
* or NULL if no suitable entry is found. The caller of this routine
|
* or NULL if no suitable entry is found. The caller of this routine
|
||||||
|
@ -3379,9 +3395,7 @@ static int
|
||||||
zfs_ioc_recv(struct file *filp, zfs_cmd_t *zc)
|
zfs_ioc_recv(struct file *filp, zfs_cmd_t *zc)
|
||||||
{
|
{
|
||||||
file_t *fp;
|
file_t *fp;
|
||||||
#ifdef HAVE_ZPL
|
|
||||||
objset_t *os;
|
objset_t *os;
|
||||||
#endif /* HAVE_ZPL */
|
|
||||||
dmu_recv_cookie_t drc;
|
dmu_recv_cookie_t drc;
|
||||||
boolean_t force = (boolean_t)zc->zc_guid;
|
boolean_t force = (boolean_t)zc->zc_guid;
|
||||||
int fd;
|
int fd;
|
||||||
|
@ -3417,7 +3431,6 @@ zfs_ioc_recv(struct file *filp, zfs_cmd_t *zc)
|
||||||
return (EBADF);
|
return (EBADF);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef HAVE_ZPL
|
|
||||||
VERIFY(nvlist_alloc(&errors, NV_UNIQUE_NAME, KM_SLEEP) == 0);
|
VERIFY(nvlist_alloc(&errors, NV_UNIQUE_NAME, KM_SLEEP) == 0);
|
||||||
|
|
||||||
if (props && dmu_objset_hold(tofs, FTAG, &os) == 0) {
|
if (props && dmu_objset_hold(tofs, FTAG, &os) == 0) {
|
||||||
|
@ -3443,7 +3456,7 @@ zfs_ioc_recv(struct file *filp, zfs_cmd_t *zc)
|
||||||
*/
|
*/
|
||||||
if (!first_recvd_props)
|
if (!first_recvd_props)
|
||||||
props_reduce(props, origprops);
|
props_reduce(props, origprops);
|
||||||
if (zfs_check_clearable(tofs, origprops,
|
if (zfs_check_clearable(filp, tofs, origprops,
|
||||||
&errlist) != 0)
|
&errlist) != 0)
|
||||||
(void) nvlist_merge(errors, errlist, 0);
|
(void) nvlist_merge(errors, errlist, 0);
|
||||||
nvlist_free(errlist);
|
nvlist_free(errlist);
|
||||||
|
@ -3451,7 +3464,6 @@ zfs_ioc_recv(struct file *filp, zfs_cmd_t *zc)
|
||||||
|
|
||||||
dmu_objset_rele(os, FTAG);
|
dmu_objset_rele(os, FTAG);
|
||||||
}
|
}
|
||||||
#endif /* HAVE_ZPL */
|
|
||||||
|
|
||||||
if (zc->zc_string[0]) {
|
if (zc->zc_string[0]) {
|
||||||
error = dmu_objset_hold(zc->zc_string, FTAG, &origin);
|
error = dmu_objset_hold(zc->zc_string, FTAG, &origin);
|
||||||
|
@ -3480,7 +3492,7 @@ zfs_ioc_recv(struct file *filp, zfs_cmd_t *zc)
|
||||||
SPA_VERSION_RECVD_PROPS)
|
SPA_VERSION_RECVD_PROPS)
|
||||||
first_recvd_props = B_TRUE;
|
first_recvd_props = B_TRUE;
|
||||||
} else if (origprops != NULL) {
|
} else if (origprops != NULL) {
|
||||||
if (clear_received_props(os, tofs, origprops,
|
if (clear_received_props(filp,os,tofs,origprops,
|
||||||
first_recvd_props ? NULL : props) != 0)
|
first_recvd_props ? NULL : props) != 0)
|
||||||
zc->zc_obj |= ZPROP_ERR_NOCLEAR;
|
zc->zc_obj |= ZPROP_ERR_NOCLEAR;
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in New Issue