[GIT PULL] XFS update for 3.13-rc1

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Linus,

Please pull these XFS updates for 3.13-rc1.  It's kind of a random
assortment.  There is more rearrangement to make libxfs sync with the
kernel, the differences between v2 and v3 were abstracted into an ops
vector, xfs_inactive was reworked, along with the preallocation and hole
punch codepaths.  Plenty of bugfixes, and cleanups too.

Thanks,
	Ben

The following changes since commit 272b98c6455f00884f0350f775c5342358ebb73f:

  Linux 3.12-rc1 (2013-09-16 16:17:51 -0400)

are available in the git repository at:

  git://oss.sgi.com/xfs/xfs.git tags/xfs-for-linus-v3.13-rc1

for you to fetch changes up to 359d992bcd398273637cd9edde10afca953783c4:

  xfs: simplify kmem_{zone_}zalloc (2013-11-06 16:31:27 -0600)

----------------------------------------------------------------
xfs: update for v3.13-rc1

For 3.13-rc1 we have an eclectic assortment of bugfixes, cleanups, and
refactoring.  Bugfixes that stand out are the fix for the AGF/AGI
deadlock, incore extent list fixes, verifier fixes for v4 superblocks
and growfs, and memory leaks.  There are some asserts, warnings, and
strings that were cleaned up.  There was further rearrangement of code
to make libxfs and the kernel sync up more easily, differences between
v2 and v3 directory code were abstracted using an ops vector,
xfs_inactive was reworked, and the preallocation/hole punching code was
refactored.

- simplify kmem_zone_zalloc
- add traces for AGF/AGI read ops
- add additional AIL traces
- fix xfs_remove AGF vs AGI deadlock
- fix the extent count of new incore extent page in the indirection array
- don't fail bad secondary superblocks verification on v4 filesystems
  due to unzeroed bits after v4 fields
- fix possible NULL dereference in xlog_verify_iclog
- remove redundant assert in xfs_dir2_leafn_split
- prevent stack overflows from page cache allocation
- fix some sparse warnings
- fix directory block format verifier to check the leaf entry count
- abstract the differences in dir2/dir3 via an ops vector
- continue process of reorganization to make libxfs/kernel code merges easier
- refactor the preallocation and hole punching code
- fix for growfs and verifiers
- remove unnecessary scary corruption error when probing non-xfs filesystems
- remove extra newlines from strings passed to printk
- prevent deadlock trying to cover an active log
- rework xfs_inactive()
- add the inode directory type support to XFS_IOC_FSGEOM
- cleanup (remove) usage of is_bad_inode
- fix miscalculation in xfs_iext_realloc_direct which results in oversized
  direct extent list
- remove unnecessary count arg to xfs_iomap_write_allocate
- fix memory leak in xlog_recover_add_to_trans
- check superblock instead of block magic to determine if dtype field
  is present
- fix lockdep annotation due to project quotas
- fix regression in xfs_node_toosmall which can lead to incorrect directory
  btree node collapse
- make log recovery verify filesystem uuid of recovering blocks
- fix XFS_IOC_FREE_EOFBLOCKS definition
- remove invalid assert in xfs_inode_free
- fix for AIL lock regression

----------------------------------------------------------------
Ben Myers (1):
      xfs: remove usage of is_bad_inode

Brian Foster (4):
      xfs: push down inactive transaction mgmt for remote symlinks
      xfs: push down inactive transaction mgmt for truncate
      xfs: push down inactive transaction mgmt for ifree
      xfs: clean up xfs_inactive() error handling, kill VN_INACTIVE_[NO]CACHE

Christoph Hellwig (5):
      xfs: always take the iolock around xfs_setattr_size
      xfs: remove the unused XFS_ATTR_NONBLOCK flag
      xfs: always hold the iolock when calling xfs_change_file_space
      xfs: simplify the fallocate path
      xfs: fold xfs_change_file_space into xfs_ioc_space

Dave Chinner (30):
      xfs: lock the AIL before removing the buffer item
      xfs: asserting lock not held during freeing not valid
      xfs: fix XFS_IOC_FREE_EOFBLOCKS definition
      xfs: log recovery lsn ordering needs uuid check
      xfs: lockdep needs to know about 3 dquot-deep nesting
      xfs: dirent dtype presence is dependent on directory magic numbers
      xfs: prevent deadlock trying to cover an active log
      xfs: create a shared header file for format-related information
      xfs: unify directory/attribute format definitions
      xfs: split dquot buffer operations out
      xfs: remove unused transaction callback variables
      xfs: decouple log and transaction headers
      xfs: decouple inode and bmap btree header files
      xfs: split xfs_rtalloc.c for userspace sanity
      xfs: abstract the differences in dir2/dir3 via an ops vector
      xfs: vectorise remaining shortform dir2 ops
      xfs: vectorise directory data operations
      xfs: vectorise directory data operations part 2
      xfs: vectorise directory leaf operations
      xfs: vectorise DA btree operations
      xfs: vectorise encoding/decoding directory headers
      xfs: convert directory vector functions to constants
      xfs: convert directory vector functions to constants
      xfs: make dir2 ftype offset pointers explicit
      xfs: validity check the directory block leaf entry count
      xfs: fix static and extern sparse warnings
      xfs: prevent stack overflows from page cache allocation
      xfs: xfs_remove deadlocks due to inverted AGF vs AGI lock ordering
      xfs: trace AIL manipulations
      xfs: add tracepoints to AGF/AGI read operations

Denis Efremov (1):
      xfs:xfs_dir2_node.c: pointer use before check for null

Eric Sandeen (4):
      xfs: remove newlines from strings passed to __xfs_printk
      xfs: don't emit corruption noise on fs probes
      xfs: don't break from growfs ag update loop on error
      xfs: be more forgiving of a v4 secondary sb w/ junk in v5 fields

Geyslan G. Bem (1):
      xfs: fix possible NULL dereference in xlog_verify_iclog

Gu Zheng (1):
      xfs: simplify kmem_{zone_}zalloc

Jie Liu (3):
      xfs: get rid of count from xfs_iomap_write_allocate()
      xfs: fix the wrong new_size/rnew_size at xfs_iext_realloc_direct()
      xfs: fix the extent count when allocating an new indirection array entry

Mark Tinguely (2):
      xfs: fix node forward in xfs_node_toosmall
      xfs: add the inode directory type support to XFS_IOC_FSGEOM

Thierry Reding (1):
      xfs: Use kmem_free() instead of free()

tinguely@xxxxxxx (1):
      xfs: fix memory leak in xlog_recover_add_to_trans

 fs/xfs/Makefile                               |    8 +-
 fs/xfs/kmem.c                                 |   22 -
 fs/xfs/kmem.h                                 |   21 +-
 fs/xfs/xfs_acl.c                              |    8 +-
 fs/xfs/xfs_ag.h                               |    4 -
 fs/xfs/xfs_alloc.c                            |   19 +-
 fs/xfs/xfs_alloc.h                            |    3 -
 fs/xfs/xfs_alloc_btree.c                      |   14 +-
 fs/xfs/xfs_alloc_btree.h                      |   35 -
 fs/xfs/xfs_aops.c                             |   16 +-
 fs/xfs/xfs_attr.c                             |   12 +-
 fs/xfs/xfs_attr_inactive.c                    |   21 +-
 fs/xfs/xfs_attr_leaf.c                        |   29 +-
 fs/xfs/xfs_attr_leaf.h                        |  232 ----
 fs/xfs/xfs_attr_list.c                        |   32 +-
 fs/xfs/xfs_attr_remote.c                      |   14 +-
 fs/xfs/xfs_attr_remote.h                      |   29 -
 fs/xfs/xfs_bit.c                              |    4 +-
 fs/xfs/xfs_bmap.c                             |   22 +-
 fs/xfs/xfs_bmap_btree.c                       |   13 +-
 fs/xfs/xfs_bmap_btree.h                       |  105 --
 fs/xfs/xfs_bmap_util.c                        |  293 +---
 fs/xfs/xfs_bmap_util.h                        |    9 +-
 fs/xfs/xfs_btree.c                            |   12 +-
 fs/xfs/xfs_btree.h                            |   79 +-
 fs/xfs/xfs_buf.c                              |   11 +-
 fs/xfs/xfs_buf_item.c                         |   10 +-
 fs/xfs/xfs_buf_item.h                         |    4 -
 fs/xfs/xfs_da_btree.c                         |  267 ++--
 fs/xfs/xfs_da_btree.h                         |  143 +-
 fs/xfs/xfs_da_format.c                        |  907 ++++++++++++
 fs/xfs/{xfs_dir2_format.h => xfs_da_format.h} |  692 ++++-----
 fs/xfs/xfs_dir2.c                             |   20 +-
 fs/xfs/xfs_dir2.h                             |  106 +-
 fs/xfs/xfs_dir2_block.c                       |  109 +-
 fs/xfs/xfs_dir2_data.c                        |  161 ++-
 fs/xfs/xfs_dir2_leaf.c                        |  243 ++--
 fs/xfs/xfs_dir2_node.c                        |  351 +++--
 fs/xfs/xfs_dir2_priv.h                        |   20 +-
 fs/xfs/xfs_dir2_readdir.c                     |   42 +-
 fs/xfs/xfs_dir2_sf.c                          |  216 +--
 fs/xfs/xfs_discard.c                          |   11 +-
 fs/xfs/xfs_dquot.c                            |  152 +-
 fs/xfs/xfs_dquot.h                            |    2 -
 fs/xfs/xfs_dquot_buf.c                        |  288 ++++
 fs/xfs/xfs_dquot_item.c                       |   14 +-
 fs/xfs/xfs_error.c                            |   11 +-
 fs/xfs/xfs_export.c                           |   12 +-
 fs/xfs/xfs_extent_busy.c                      |   11 +-
 fs/xfs/xfs_extent_busy.h                      |    4 +
 fs/xfs/xfs_extfree_item.c                     |    8 +-
 fs/xfs/xfs_file.c                             |   92 +-
 fs/xfs/xfs_filestream.c                       |   12 +-
 fs/xfs/xfs_format.h                           |  263 +++-
 fs/xfs/xfs_fs.h                               |    6 +-
 fs/xfs/xfs_fsops.c                            |   45 +-
 fs/xfs/xfs_ialloc.c                           |   20 +-
 fs/xfs/xfs_ialloc.h                           |    5 +-
 fs/xfs/xfs_ialloc_btree.c                     |   13 +-
 fs/xfs/xfs_ialloc_btree.h                     |   51 -
 fs/xfs/xfs_icache.c                           |   29 +-
 fs/xfs/xfs_icreate_item.c                     |    7 +-
 fs/xfs/xfs_inode.c                            |  338 +++--
 fs/xfs/xfs_inode.h                            |    6 +-
 fs/xfs/xfs_inode_buf.c                        |   10 +-
 fs/xfs/xfs_inode_buf.h                        |    3 -
 fs/xfs/xfs_inode_fork.c                       |   40 +-
 fs/xfs/xfs_inode_fork.h                       |    1 +
 fs/xfs/xfs_inode_item.c                       |   12 +-
 fs/xfs/xfs_ioctl.c                            |  146 +-
 fs/xfs/xfs_ioctl32.c                          |    7 +-
 fs/xfs/xfs_iomap.c                            |   23 +-
 fs/xfs/xfs_iomap.h                            |    8 +-
 fs/xfs/xfs_iops.c                             |   70 +-
 fs/xfs/xfs_iops.h                             |    8 +-
 fs/xfs/xfs_itable.c                           |   15 +-
 fs/xfs/xfs_log.c                              |   75 +-
 fs/xfs/xfs_log.h                              |   10 +-
 fs/xfs/xfs_log_cil.c                          |   26 +-
 fs/xfs/xfs_log_format.h                       |  177 ---
 fs/xfs/xfs_log_priv.h                         |   17 +-
 fs/xfs/xfs_log_recover.c                      |  245 ++--
 fs/xfs/xfs_log_rlimit.c                       |    9 +-
 fs/xfs/xfs_message.c                          |    5 +-
 fs/xfs/xfs_mount.c                            |   21 +-
 fs/xfs/xfs_mount.h                            |    3 +
 fs/xfs/xfs_qm.c                               |   39 +-
 fs/xfs/xfs_qm.h                               |    2 -
 fs/xfs/xfs_qm_bhv.c                           |   12 +-
 fs/xfs/xfs_qm_syscalls.c                      |   28 +-
 fs/xfs/xfs_quota.h                            |    4 -
 fs/xfs/xfs_quota_defs.h                       |    4 +
 fs/xfs/xfs_quotaops.c                         |    5 +-
 fs/xfs/xfs_rtalloc.c                          | 1848 ++++++-------------------
 fs/xfs/xfs_rtalloc.h                          |   24 +
 fs/xfs/xfs_rtbitmap.c                         |  974 +++++++++++++
 fs/xfs/xfs_sb.c                               |   46 +-
 fs/xfs/xfs_sb.h                               |    3 -
 fs/xfs/xfs_shared.h                           |  244 ++++
 fs/xfs/xfs_super.c                            |   38 +-
 fs/xfs/xfs_symlink.c                          |  102 +-
 fs/xfs/xfs_symlink.h                          |    2 +-
 fs/xfs/xfs_symlink_remote.c                   |    6 +-
 fs/xfs/xfs_trace.c                            |   16 +-
 fs/xfs/xfs_trace.h                            |   84 +-
 fs/xfs/xfs_trans.c                            |   23 +-
 fs/xfs/xfs_trans.h                            |   20 +-
 fs/xfs/xfs_trans_ail.c                        |   10 +-
 fs/xfs/xfs_trans_buf.c                        |   12 +-
 fs/xfs/xfs_trans_dquot.c                      |   15 +-
 fs/xfs/xfs_trans_extfree.c                    |    7 +-
 fs/xfs/xfs_trans_inode.c                      |   13 +-
 fs/xfs/xfs_trans_priv.h                       |    1 -
 fs/xfs/xfs_trans_resv.c                       |   18 +-
 fs/xfs/xfs_vnode.h                            |    8 -
 fs/xfs/xfs_xattr.c                            |    8 +-
 116 files changed, 5441 insertions(+), 4864 deletions(-)
 create mode 100644 fs/xfs/xfs_da_format.c
 rename fs/xfs/{xfs_dir2_format.h => xfs_da_format.h} (60%)
 create mode 100644 fs/xfs/xfs_dquot_buf.c
 create mode 100644 fs/xfs/xfs_rtbitmap.c
 create mode 100644 fs/xfs/xfs_shared.h

_______________________________________________
xfs mailing list
xfs@xxxxxxxxxxx
http://oss.sgi.com/mailman/listinfo/xfs




[Index of Archives]     [Linux XFS Devel]     [Linux Filesystem Development]     [Filesystem Testing]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux