Skip to content

Commit

Permalink
[XFS] pv 956241, author: nathans, rv: vapo - make ino validation checks
Browse files Browse the repository at this point in the history
consistent in bulkstat

SGI-PV: 956241
SGI-Modid: xfs-linux-melb:xfs-kern:26984a

Signed-off-by: Vlad Apostolov <[email protected]>
Signed-off-by: Tim Shimmin <[email protected]>
  • Loading branch information
Vlad Apostolov authored and Tim Shimmin committed Sep 28, 2006
1 parent 6216ff1 commit 6f1f216
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 10 deletions.
24 changes: 14 additions & 10 deletions fs/xfs/xfs_itable.c
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,16 @@
#include "xfs_error.h"
#include "xfs_btree.h"

int
xfs_internal_inum(
xfs_mount_t *mp,
xfs_ino_t ino)
{
return (ino == mp->m_sb.sb_rbmino || ino == mp->m_sb.sb_rsumino ||
(XFS_SB_VERSION_HASQUOTA(&mp->m_sb) &&
(ino == mp->m_sb.sb_uquotino || ino == mp->m_sb.sb_gquotino)));
}

STATIC int
xfs_bulkstat_one_iget(
xfs_mount_t *mp, /* mount point for filesystem */
Expand Down Expand Up @@ -213,17 +223,12 @@ xfs_bulkstat_one(
xfs_dinode_t *dip; /* dinode inode pointer */

dip = (xfs_dinode_t *)dibuff;
*stat = BULKSTAT_RV_NOTHING;

if (!buffer || ino == mp->m_sb.sb_rbmino || ino == mp->m_sb.sb_rsumino ||
(XFS_SB_VERSION_HASQUOTA(&mp->m_sb) &&
(ino == mp->m_sb.sb_uquotino || ino == mp->m_sb.sb_gquotino))) {
*stat = BULKSTAT_RV_NOTHING;
if (!buffer || xfs_internal_inum(mp, ino))
return XFS_ERROR(EINVAL);
}
if (ubsize < sizeof(*buf)) {
*stat = BULKSTAT_RV_NOTHING;
if (ubsize < sizeof(*buf))
return XFS_ERROR(ENOMEM);
}

buf = kmem_alloc(sizeof(*buf), KM_SLEEP);

Expand All @@ -239,8 +244,7 @@ xfs_bulkstat_one(
}

if (copy_to_user(buffer, buf, sizeof(*buf))) {
*stat = BULKSTAT_RV_NOTHING;
error = EFAULT;
error = EFAULT;
goto out_free;
}

Expand Down
5 changes: 5 additions & 0 deletions fs/xfs/xfs_itable.h
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,11 @@ xfs_bulkstat_one(
void *dibuff,
int *stat);

int
xfs_internal_inum(
xfs_mount_t *mp,
xfs_ino_t ino);

int /* error status */
xfs_inumbers(
xfs_mount_t *mp, /* mount point for filesystem */
Expand Down

0 comments on commit 6f1f216

Please sign in to comment.