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? 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 _______________________________________________ xfs mailing list xfs@xxxxxxxxxxx http://oss.sgi.com/mailman/listinfo/xfs