Commit f0114bd8 authored by Luis Henriques's avatar Luis Henriques

Revert "(namespace) quota: Ensure qids map to the filesystem"

BugLink: https://bugs.launchpad.net/bugs/1644165

This reverts commit ec41f5ac.

The kernel fix for bug #1634964 breaks LXD userspace, in particular the
following commits:

ac7f3f73 (namespace) vfs: Don't modify inodes with a uid or gid unknown to the vfs
ca52383a (namespace) vfs: Don't create inodes with a uid or gid unknown to the vfs

LXD 2.0.6 will include changes to support these kernel changes, but it isn't
available yet on xenial, so for now we just revert these commits.
Signed-off-by: default avatarLuis Henriques <luis.henriques@canonical.com>
parent fe8e1cba
...@@ -834,9 +834,6 @@ struct dquot *dqget(struct super_block *sb, struct kqid qid) ...@@ -834,9 +834,6 @@ struct dquot *dqget(struct super_block *sb, struct kqid qid)
unsigned int hashent = hashfn(sb, qid); unsigned int hashent = hashfn(sb, qid);
struct dquot *dquot, *empty = NULL; struct dquot *dquot, *empty = NULL;
if (!qid_has_mapping(sb->s_user_ns, qid))
return ERR_PTR(-EINVAL);
if (!sb_has_quota_active(sb, qid.type)) if (!sb_has_quota_active(sb, qid.type))
return ERR_PTR(-ESRCH); return ERR_PTR(-ESRCH);
we_slept: we_slept:
......
...@@ -211,7 +211,7 @@ static int quota_getquota(struct super_block *sb, int type, qid_t id, ...@@ -211,7 +211,7 @@ static int quota_getquota(struct super_block *sb, int type, qid_t id,
if (!sb->s_qcop->get_dqblk) if (!sb->s_qcop->get_dqblk)
return -ENOSYS; return -ENOSYS;
qid = make_kqid(current_user_ns(), type, id); qid = make_kqid(current_user_ns(), type, id);
if (!qid_has_mapping(sb->s_user_ns, qid)) if (!qid_valid(qid))
return -EINVAL; return -EINVAL;
ret = sb->s_qcop->get_dqblk(sb, qid, &fdq); ret = sb->s_qcop->get_dqblk(sb, qid, &fdq);
if (ret) if (ret)
...@@ -260,7 +260,7 @@ static int quota_setquota(struct super_block *sb, int type, qid_t id, ...@@ -260,7 +260,7 @@ static int quota_setquota(struct super_block *sb, int type, qid_t id,
if (!sb->s_qcop->set_dqblk) if (!sb->s_qcop->set_dqblk)
return -ENOSYS; return -ENOSYS;
qid = make_kqid(current_user_ns(), type, id); qid = make_kqid(current_user_ns(), type, id);
if (!qid_has_mapping(sb->s_user_ns, qid)) if (!qid_valid(qid))
return -EINVAL; return -EINVAL;
copy_from_if_dqblk(&fdq, &idq); copy_from_if_dqblk(&fdq, &idq);
return sb->s_qcop->set_dqblk(sb, qid, &fdq); return sb->s_qcop->set_dqblk(sb, qid, &fdq);
...@@ -553,7 +553,7 @@ static int quota_setxquota(struct super_block *sb, int type, qid_t id, ...@@ -553,7 +553,7 @@ static int quota_setxquota(struct super_block *sb, int type, qid_t id,
if (!sb->s_qcop->set_dqblk) if (!sb->s_qcop->set_dqblk)
return -ENOSYS; return -ENOSYS;
qid = make_kqid(current_user_ns(), type, id); qid = make_kqid(current_user_ns(), type, id);
if (!qid_has_mapping(sb->s_user_ns, qid)) if (!qid_valid(qid))
return -EINVAL; return -EINVAL;
/* Are we actually setting timer / warning limits for all users? */ /* Are we actually setting timer / warning limits for all users? */
if (from_kqid(&init_user_ns, qid) == 0 && if (from_kqid(&init_user_ns, qid) == 0 &&
...@@ -614,7 +614,7 @@ static int quota_getxquota(struct super_block *sb, int type, qid_t id, ...@@ -614,7 +614,7 @@ static int quota_getxquota(struct super_block *sb, int type, qid_t id,
if (!sb->s_qcop->get_dqblk) if (!sb->s_qcop->get_dqblk)
return -ENOSYS; return -ENOSYS;
qid = make_kqid(current_user_ns(), type, id); qid = make_kqid(current_user_ns(), type, id);
if (!qid_has_mapping(sb->s_user_ns, qid)) if (!qid_valid(qid))
return -EINVAL; return -EINVAL;
ret = sb->s_qcop->get_dqblk(sb, qid, &qdq); ret = sb->s_qcop->get_dqblk(sb, qid, &qdq);
if (ret) if (ret)
......
...@@ -179,16 +179,6 @@ static inline struct kqid make_kqid_projid(kprojid_t projid) ...@@ -179,16 +179,6 @@ static inline struct kqid make_kqid_projid(kprojid_t projid)
return kqid; return kqid;
} }
/**
* qid_has_mapping - Report if a qid maps into a user namespace.
* @ns: The user namespace to see if a value maps into.
* @qid: The kernel internal quota identifier to test.
*/
static inline bool qid_has_mapping(struct user_namespace *ns, struct kqid qid)
{
return from_kqid(ns, qid) != (qid_t) -1;
}
extern spinlock_t dq_data_lock; extern spinlock_t dq_data_lock;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment