Hey Brian,
On Thu, Oct 11, 2012 at 06:35:14PM -0400, Brian Foster wrote:
> On 10/11/2012 10:13 AM, Ben Myers wrote:
> > Hey Brian,
> >
> > On Fri, Oct 05, 2012 at 10:17:12AM -0400, Brian Foster wrote:
> >> The XFS_IOC_FREE_EOFBLOCKS ioctl allows users to invoke an EOFBLOCKS
> >> scan. The xfs_eofblocks structure is defined to support the command
> >> parameters (scan mode).
> >
> > It would help to have an xfstest to exercise this ioctl to pull in with this
> > series. Do you have any code that could be wrangled into a test case?
> >
>
> Yes, makes sense. I have some very basic test code I could put somewhere
> to invoke the ioctl(). One of the questions I've been meaning to ask is
> whether it would be relevant for that code to live in a common tool,
> such as adding a new command to xfs_io. Then perhaps create an xfstests
> test using that. Thoughts?
IMO you are right on the mark. xfs_io is a great place for this.
> FYI, I have a few other things on my plate at the moment so
> unfortunately it will be a bit before I can get back to XFS work... But
> I'm fine with the set pending until I can come up with some test
> coverage if that is preferable, of course.
I do think it is preferable to have a test case go in with the code where
possible. Since you don't mind waiting a bit, that seems to be the way to go.
The other option could be to look for a volunteer to work on the test. ;)
Regards,
Ben
> Brian
>
> > Regards,
> > Ben
> >
> >>
> >> Signed-off-by: Brian Foster <bfoster@xxxxxxxxxx>
> >> ---
> >> fs/xfs/xfs_fs.h | 15 +++++++++++++++
> >> fs/xfs/xfs_icache.c | 5 +++--
> >> fs/xfs/xfs_icache.h | 2 +-
> >> fs/xfs/xfs_ioctl.c | 16 ++++++++++++++++
> >> 4 files changed, 35 insertions(+), 3 deletions(-)
> >>
> >> diff --git a/fs/xfs/xfs_fs.h b/fs/xfs/xfs_fs.h
> >> index c13fed8..5f48b3e 100644
> >> --- a/fs/xfs/xfs_fs.h
> >> +++ b/fs/xfs/xfs_fs.h
> >> @@ -339,6 +339,20 @@ typedef struct xfs_error_injection {
> >>
> >>
> >> /*
> >> + * Speculative preallocation trimming.
> >> + */
> >> +#define XFS_EOFBLOCKS_VERSION 1
> >> +struct xfs_eofblocks {
> >> + __u32 eof_version;
> >> + __u32 eof_flags;
> >> + unsigned char pad[12];
> >> +};
> >> +
> >> +/* eof_flags values */
> >> +#define XFS_EOF_FLAGS_SYNC 0x01 /* sync/wait mode scan
> >> */
> >> +
> >> +
> >> +/*
> >> * The user-level Handle Request interface structure.
> >> */
> >> typedef struct xfs_fsop_handlereq {
> >> @@ -456,6 +470,7 @@ typedef struct xfs_handle {
> >> /* XFS_IOC_GETBIOSIZE ---- deprecated 47 */
> >> #define XFS_IOC_GETBMAPX _IOWR('X', 56, struct getbmap)
> >> #define XFS_IOC_ZERO_RANGE _IOW ('X', 57, struct xfs_flock64)
> >> +#define XFS_IOC_FREE_EOFBLOCKS _IOR ('X', 58, struct xfs_eofblocks)
> >>
> >> /*
> >> * ioctl commands that replace IRIX syssgi()'s
> >> diff --git a/fs/xfs/xfs_icache.c b/fs/xfs/xfs_icache.c
> >> index b02a3df..35efdda 100644
> >> --- a/fs/xfs/xfs_icache.c
> >> +++ b/fs/xfs/xfs_icache.c
> >> @@ -1206,11 +1206,12 @@ xfs_inode_free_eofblocks(
> >> int
> >> xfs_icache_free_eofblocks(
> >> struct xfs_mount *mp,
> >> - int flags)
> >> + int flags,
> >> + struct xfs_eofblocks *eofb)
> >> {
> >> ASSERT((flags & ~(SYNC_TRYLOCK|SYNC_WAIT)) == 0);
> >> return xfs_inode_ag_iterator_tag(mp, xfs_inode_free_eofblocks, flags,
> >> - NULL, XFS_ICI_EOFBLOCKS_TAG);
> >> + eofb, XFS_ICI_EOFBLOCKS_TAG);
> >> }
> >>
> >> void
> >> diff --git a/fs/xfs/xfs_icache.h b/fs/xfs/xfs_icache.h
> >> index abca9fb..b46716c 100644
> >> --- a/fs/xfs/xfs_icache.h
> >> +++ b/fs/xfs/xfs_icache.h
> >> @@ -37,7 +37,7 @@ void xfs_inode_set_reclaim_tag(struct xfs_inode *ip);
> >>
> >> void xfs_inode_set_eofblocks_tag(struct xfs_inode *ip);
> >> void xfs_inode_clear_eofblocks_tag(struct xfs_inode *ip);
> >> -int xfs_icache_free_eofblocks(struct xfs_mount *, int);
> >> +int xfs_icache_free_eofblocks(struct xfs_mount *, int, struct
> >> xfs_eofblocks *);
> >>
> >> int xfs_sync_inode_grab(struct xfs_inode *ip);
> >> int xfs_inode_ag_iterator(struct xfs_mount *mp,
> >> diff --git a/fs/xfs/xfs_ioctl.c b/fs/xfs/xfs_ioctl.c
> >> index 0e0232c..ad4352f 100644
> >> --- a/fs/xfs/xfs_ioctl.c
> >> +++ b/fs/xfs/xfs_ioctl.c
> >> @@ -42,6 +42,7 @@
> >> #include "xfs_inode_item.h"
> >> #include "xfs_export.h"
> >> #include "xfs_trace.h"
> >> +#include "xfs_icache.h"
> >>
> >> #include <linux/capability.h>
> >> #include <linux/dcache.h>
> >> @@ -1602,6 +1603,21 @@ xfs_file_ioctl(
> >> error = xfs_errortag_clearall(mp, 1);
> >> return -error;
> >>
> >> + case XFS_IOC_FREE_EOFBLOCKS: {
> >> + struct xfs_eofblocks eofb;
> >> + int flags;
> >> +
> >> + if (copy_from_user(&eofb, arg, sizeof(eofb)))
> >> + return -XFS_ERROR(EFAULT);
> >> +
> >> + if (eofb.eof_version != XFS_EOFBLOCKS_VERSION)
> >> + return -XFS_ERROR(EINVAL);
> >> +
> >> + flags = (eofb.eof_flags & XFS_EOF_FLAGS_SYNC) ? SYNC_WAIT :
> >> SYNC_TRYLOCK;
> >> + error = xfs_icache_free_eofblocks(mp, flags, &eofb);
> >> + return -error;
> >> + }
> >> +
> >> default:
> >> return -ENOTTY;
> >> }
> >> --
> >> 1.7.7.6
> >>
> >> _______________________________________________
> >> xfs mailing list
> >> xfs@xxxxxxxxxxx
> >> http://oss.sgi.com/mailman/listinfo/xfs
>
|