Commit a990f7a8 authored by Darrick J. Wong's avatar Darrick J. Wong

xfs: improve ondisk dquot flags checking

Create an XFS_DQTYPE_ANY mask for ondisk dquots flags, and use that to
ensure that we never accept any garbage flags when we're loading dquots.
While we're at it, restructure the quota type flag checking to use the
proper masking.

Note that I plan to add y2038 support soon, which will require a new
xfs_dqtype_t flag for extended timestamp support, hence all the work to
make the type masking work correctly.
Signed-off-by: default avatarDarrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: default avatarDave Chinner <dchinner@redhat.com>
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
parent 1a7ed271
...@@ -39,6 +39,8 @@ xfs_dquot_verify( ...@@ -39,6 +39,8 @@ xfs_dquot_verify(
struct xfs_disk_dquot *ddq, struct xfs_disk_dquot *ddq,
xfs_dqid_t id) /* used only during quotacheck */ xfs_dqid_t id) /* used only during quotacheck */
{ {
__u8 ddq_type;
/* /*
* We can encounter an uninitialized dquot buffer for 2 reasons: * We can encounter an uninitialized dquot buffer for 2 reasons:
* 1. If we crash while deleting the quotainode(s), and those blks got * 1. If we crash while deleting the quotainode(s), and those blks got
...@@ -59,9 +61,12 @@ xfs_dquot_verify( ...@@ -59,9 +61,12 @@ xfs_dquot_verify(
if (ddq->d_version != XFS_DQUOT_VERSION) if (ddq->d_version != XFS_DQUOT_VERSION)
return __this_address; return __this_address;
if (ddq->d_flags != XFS_DQTYPE_USER && if (ddq->d_flags & ~XFS_DQTYPE_ANY)
ddq->d_flags != XFS_DQTYPE_PROJ && return __this_address;
ddq->d_flags != XFS_DQTYPE_GROUP) ddq_type = ddq->d_flags & XFS_DQTYPE_REC_MASK;
if (ddq_type != XFS_DQTYPE_USER &&
ddq_type != XFS_DQTYPE_PROJ &&
ddq_type != XFS_DQTYPE_GROUP)
return __this_address; return __this_address;
if (id != -1 && id != be32_to_cpu(ddq->d_id)) if (id != -1 && id != be32_to_cpu(ddq->d_id))
......
...@@ -1158,6 +1158,8 @@ static inline void xfs_dinode_put_rdev(struct xfs_dinode *dip, xfs_dev_t rdev) ...@@ -1158,6 +1158,8 @@ static inline void xfs_dinode_put_rdev(struct xfs_dinode *dip, xfs_dev_t rdev)
XFS_DQTYPE_PROJ | \ XFS_DQTYPE_PROJ | \
XFS_DQTYPE_GROUP) XFS_DQTYPE_GROUP)
#define XFS_DQTYPE_ANY (XFS_DQTYPE_REC_MASK)
/* /*
* This is the main portion of the on-disk representation of quota information * This is the main portion of the on-disk representation of quota information
* for a user. We pad this with some more expansion room to construct the on * for a user. We pad this with some more expansion room to construct the on
......
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