Merge branch 'xfs-misc-fixes-for-3.20-2' into for-next
This commit is contained in:
commit
6bcf0939ff
9 changed files with 44 additions and 67 deletions
|
@ -348,16 +348,13 @@ The following sysctls are available for the XFS filesystem:
|
||||||
Deprecated Sysctls
|
Deprecated Sysctls
|
||||||
==================
|
==================
|
||||||
|
|
||||||
fs.xfs.xfsbufd_centisecs (Min: 50 Default: 100 Max: 3000)
|
None at present.
|
||||||
Dirty metadata is now tracked by the log subsystem and
|
|
||||||
flushing is driven by log space and idling demands. The
|
|
||||||
xfsbufd no longer exists, so this syctl does nothing.
|
|
||||||
|
|
||||||
Due for removal in 3.14.
|
|
||||||
|
|
||||||
fs.xfs.age_buffer_centisecs (Min: 100 Default: 1500 Max: 720000)
|
Removed Sysctls
|
||||||
Dirty metadata is now tracked by the log subsystem and
|
===============
|
||||||
flushing is driven by log space and idling demands. The
|
|
||||||
xfsbufd no longer exists, so this syctl does nothing.
|
|
||||||
|
|
||||||
Due for removal in 3.14.
|
Name Removed
|
||||||
|
---- -------
|
||||||
|
fs.xfs.xfsbufd_centisec v3.20
|
||||||
|
fs.xfs.age_buffer_centisecs v3.20
|
||||||
|
|
|
@ -27,6 +27,37 @@ struct xfs_trans;
|
||||||
|
|
||||||
extern kmem_zone_t *xfs_bmap_free_item_zone;
|
extern kmem_zone_t *xfs_bmap_free_item_zone;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Argument structure for xfs_bmap_alloc.
|
||||||
|
*/
|
||||||
|
struct xfs_bmalloca {
|
||||||
|
xfs_fsblock_t *firstblock; /* i/o first block allocated */
|
||||||
|
struct xfs_bmap_free *flist; /* bmap freelist */
|
||||||
|
struct xfs_trans *tp; /* transaction pointer */
|
||||||
|
struct xfs_inode *ip; /* incore inode pointer */
|
||||||
|
struct xfs_bmbt_irec prev; /* extent before the new one */
|
||||||
|
struct xfs_bmbt_irec got; /* extent after, or delayed */
|
||||||
|
|
||||||
|
xfs_fileoff_t offset; /* offset in file filling in */
|
||||||
|
xfs_extlen_t length; /* i/o length asked/allocated */
|
||||||
|
xfs_fsblock_t blkno; /* starting block of new extent */
|
||||||
|
|
||||||
|
struct xfs_btree_cur *cur; /* btree cursor */
|
||||||
|
xfs_extnum_t idx; /* current extent index */
|
||||||
|
int nallocs;/* number of extents alloc'd */
|
||||||
|
int logflags;/* flags for transaction logging */
|
||||||
|
|
||||||
|
xfs_extlen_t total; /* total blocks needed for xaction */
|
||||||
|
xfs_extlen_t minlen; /* minimum allocation size (blocks) */
|
||||||
|
xfs_extlen_t minleft; /* amount must be left after alloc */
|
||||||
|
bool eof; /* set if allocating past last extent */
|
||||||
|
bool wasdel; /* replacing a delayed allocation */
|
||||||
|
bool userdata;/* set if is user data */
|
||||||
|
bool aeof; /* allocated space at eof */
|
||||||
|
bool conv; /* overwriting unwritten extents */
|
||||||
|
int flags;
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* List of extents to be free "later".
|
* List of extents to be free "later".
|
||||||
* The list is kept sorted on xbf_startblock.
|
* The list is kept sorted on xbf_startblock.
|
||||||
|
@ -149,6 +180,8 @@ void xfs_bmap_local_to_extents_empty(struct xfs_inode *ip, int whichfork);
|
||||||
void xfs_bmap_add_free(xfs_fsblock_t bno, xfs_filblks_t len,
|
void xfs_bmap_add_free(xfs_fsblock_t bno, xfs_filblks_t len,
|
||||||
struct xfs_bmap_free *flist, struct xfs_mount *mp);
|
struct xfs_bmap_free *flist, struct xfs_mount *mp);
|
||||||
void xfs_bmap_cancel(struct xfs_bmap_free *flist);
|
void xfs_bmap_cancel(struct xfs_bmap_free *flist);
|
||||||
|
int xfs_bmap_finish(struct xfs_trans **tp, struct xfs_bmap_free *flist,
|
||||||
|
int *committed);
|
||||||
void xfs_bmap_compute_maxlevels(struct xfs_mount *mp, int whichfork);
|
void xfs_bmap_compute_maxlevels(struct xfs_mount *mp, int whichfork);
|
||||||
int xfs_bmap_first_unused(struct xfs_trans *tp, struct xfs_inode *ip,
|
int xfs_bmap_first_unused(struct xfs_trans *tp, struct xfs_inode *ip,
|
||||||
xfs_extlen_t len, xfs_fileoff_t *unused, int whichfork);
|
xfs_extlen_t len, xfs_fileoff_t *unused, int whichfork);
|
||||||
|
|
|
@ -26,43 +26,8 @@ struct xfs_ifork;
|
||||||
struct xfs_inode;
|
struct xfs_inode;
|
||||||
struct xfs_mount;
|
struct xfs_mount;
|
||||||
struct xfs_trans;
|
struct xfs_trans;
|
||||||
|
struct xfs_bmalloca;
|
||||||
|
|
||||||
/*
|
|
||||||
* Argument structure for xfs_bmap_alloc.
|
|
||||||
*/
|
|
||||||
struct xfs_bmalloca {
|
|
||||||
xfs_fsblock_t *firstblock; /* i/o first block allocated */
|
|
||||||
struct xfs_bmap_free *flist; /* bmap freelist */
|
|
||||||
struct xfs_trans *tp; /* transaction pointer */
|
|
||||||
struct xfs_inode *ip; /* incore inode pointer */
|
|
||||||
struct xfs_bmbt_irec prev; /* extent before the new one */
|
|
||||||
struct xfs_bmbt_irec got; /* extent after, or delayed */
|
|
||||||
|
|
||||||
xfs_fileoff_t offset; /* offset in file filling in */
|
|
||||||
xfs_extlen_t length; /* i/o length asked/allocated */
|
|
||||||
xfs_fsblock_t blkno; /* starting block of new extent */
|
|
||||||
|
|
||||||
struct xfs_btree_cur *cur; /* btree cursor */
|
|
||||||
xfs_extnum_t idx; /* current extent index */
|
|
||||||
int nallocs;/* number of extents alloc'd */
|
|
||||||
int logflags;/* flags for transaction logging */
|
|
||||||
|
|
||||||
xfs_extlen_t total; /* total blocks needed for xaction */
|
|
||||||
xfs_extlen_t minlen; /* minimum allocation size (blocks) */
|
|
||||||
xfs_extlen_t minleft; /* amount must be left after alloc */
|
|
||||||
bool eof; /* set if allocating past last extent */
|
|
||||||
bool wasdel; /* replacing a delayed allocation */
|
|
||||||
bool userdata;/* set if is user data */
|
|
||||||
bool aeof; /* allocated space at eof */
|
|
||||||
bool conv; /* overwriting unwritten extents */
|
|
||||||
int flags;
|
|
||||||
struct completion *done;
|
|
||||||
struct work_struct work;
|
|
||||||
int result;
|
|
||||||
};
|
|
||||||
|
|
||||||
int xfs_bmap_finish(struct xfs_trans **tp, struct xfs_bmap_free *flist,
|
|
||||||
int *committed);
|
|
||||||
int xfs_bmap_rtalloc(struct xfs_bmalloca *ap);
|
int xfs_bmap_rtalloc(struct xfs_bmalloca *ap);
|
||||||
int xfs_bmap_eof(struct xfs_inode *ip, xfs_fileoff_t endoff,
|
int xfs_bmap_eof(struct xfs_inode *ip, xfs_fileoff_t endoff,
|
||||||
int whichfork, int *eof);
|
int whichfork, int *eof);
|
||||||
|
|
|
@ -86,7 +86,7 @@ static inline void xfs_dqflock(xfs_dquot_t *dqp)
|
||||||
wait_for_completion(&dqp->q_flush);
|
wait_for_completion(&dqp->q_flush);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int xfs_dqflock_nowait(xfs_dquot_t *dqp)
|
static inline bool xfs_dqflock_nowait(xfs_dquot_t *dqp)
|
||||||
{
|
{
|
||||||
return try_wait_for_completion(&dqp->q_flush);
|
return try_wait_for_completion(&dqp->q_flush);
|
||||||
}
|
}
|
||||||
|
|
|
@ -802,7 +802,7 @@ int
|
||||||
xfs_iomap_write_unwritten(
|
xfs_iomap_write_unwritten(
|
||||||
xfs_inode_t *ip,
|
xfs_inode_t *ip,
|
||||||
xfs_off_t offset,
|
xfs_off_t offset,
|
||||||
size_t count)
|
xfs_off_t count)
|
||||||
{
|
{
|
||||||
xfs_mount_t *mp = ip->i_mount;
|
xfs_mount_t *mp = ip->i_mount;
|
||||||
xfs_fileoff_t offset_fsb;
|
xfs_fileoff_t offset_fsb;
|
||||||
|
|
|
@ -27,6 +27,6 @@ int xfs_iomap_write_delay(struct xfs_inode *, xfs_off_t, size_t,
|
||||||
struct xfs_bmbt_irec *);
|
struct xfs_bmbt_irec *);
|
||||||
int xfs_iomap_write_allocate(struct xfs_inode *, xfs_off_t,
|
int xfs_iomap_write_allocate(struct xfs_inode *, xfs_off_t,
|
||||||
struct xfs_bmbt_irec *);
|
struct xfs_bmbt_irec *);
|
||||||
int xfs_iomap_write_unwritten(struct xfs_inode *, xfs_off_t, size_t);
|
int xfs_iomap_write_unwritten(struct xfs_inode *, xfs_off_t, xfs_off_t);
|
||||||
|
|
||||||
#endif /* __XFS_IOMAP_H__*/
|
#endif /* __XFS_IOMAP_H__*/
|
||||||
|
|
|
@ -148,24 +148,6 @@ static struct ctl_table xfs_table[] = {
|
||||||
.extra1 = &xfs_params.inherit_noatim.min,
|
.extra1 = &xfs_params.inherit_noatim.min,
|
||||||
.extra2 = &xfs_params.inherit_noatim.max
|
.extra2 = &xfs_params.inherit_noatim.max
|
||||||
},
|
},
|
||||||
{
|
|
||||||
.procname = "xfsbufd_centisecs",
|
|
||||||
.data = &xfs_params.xfs_buf_timer.val,
|
|
||||||
.maxlen = sizeof(int),
|
|
||||||
.mode = 0644,
|
|
||||||
.proc_handler = proc_dointvec_minmax,
|
|
||||||
.extra1 = &xfs_params.xfs_buf_timer.min,
|
|
||||||
.extra2 = &xfs_params.xfs_buf_timer.max
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.procname = "age_buffer_centisecs",
|
|
||||||
.data = &xfs_params.xfs_buf_age.val,
|
|
||||||
.maxlen = sizeof(int),
|
|
||||||
.mode = 0644,
|
|
||||||
.proc_handler = proc_dointvec_minmax,
|
|
||||||
.extra1 = &xfs_params.xfs_buf_age.min,
|
|
||||||
.extra2 = &xfs_params.xfs_buf_age.max
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
.procname = "inherit_nosymlinks",
|
.procname = "inherit_nosymlinks",
|
||||||
.data = &xfs_params.inherit_nosym.val,
|
.data = &xfs_params.inherit_nosym.val,
|
||||||
|
|
Loading…
Add table
Reference in a new issue