1. 17 Mar, 2006 8 commits
    • Nathan Scott's avatar
      [XFS] Flush and invalidate dirty pages at the start of a direct read also, · 9cea2364
      Nathan Scott authored
      else we can hit a delalloc-extents-via-direct-io BUG.
      
      SGI-PV: 949916
      SGI-Modid: xfs-linux-melb:xfs-kern:25483a
      Signed-off-by: default avatarNathan Scott <nathans@sgi.com>
      9cea2364
    • Nathan Scott's avatar
      [XFS] Merge Yingpings fix for a vn_count assert failure during QA - · ce9d37c2
      Nathan Scott authored
      another ENOSPC condition.
      
      SGI-PV: 950784
      SGI-Modid: xfs-linux-melb:xfs-kern:25482a
      Signed-off-by: default avatarNathan Scott <nathans@sgi.com>
      ce9d37c2
    • Nathan Scott's avatar
      [XFS] Make couple names consitent, be more defensive on releasepage (and · 238f4c54
      Nathan Scott authored
      prep for nobh, someday, maybe).
      
      SGI-PV: 904196
      SGI-Modid: xfs-linux-melb:xfs-kern:25481a
      Signed-off-by: default avatarNathan Scott <nathans@sgi.com>
      238f4c54
    • Nathan Scott's avatar
      [XFS] Cleanup references to i_sem. · a13828b1
      Nathan Scott authored
      SGI-PV: 904196
      SGI-Modid: xfs-linux-melb:xfs-kern:25480a
      Signed-off-by: default avatarNathan Scott <nathans@sgi.com>
      a13828b1
    • Nathan Scott's avatar
      [XFS] Fix an infinite loop issue in bulkstat when a corrupt inode is · b12dd342
      Nathan Scott authored
      detected.  Thanks to Roger Willcocks.
      
      SGI-PV: 951054
      SGI-Modid: xfs-linux-melb:xfs-kern:25477a
      Signed-off-by: default avatarNathan Scott <nathans@sgi.com>
      b12dd342
    • Nathan Scott's avatar
      [XFS] Correct the dquot reservation component for the link transation. · 2ddd5928
      Nathan Scott authored
      SGI-PV: 904196
      SGI-Modid: xfs-linux-melb:xfs-kern:25476a
      Signed-off-by: default avatarNathan Scott <nathans@sgi.com>
      2ddd5928
    • Nathan Scott's avatar
      [XFS] Complete transition away from linvfs naming convention, finally. · ec86dc02
      Nathan Scott authored
      SGI-PV: 947038
      SGI-Modid: xfs-linux-melb:xfs-kern:25474a
      Signed-off-by: default avatarNathan Scott <nathans@sgi.com>
      ec86dc02
    • Mandy Kirkconnell's avatar
      [XFS] There are a few problems with the new · 8867bc9b
      Mandy Kirkconnell authored
      xfs_bmap_search_multi_extents() wrapper function that I introduced in mod
      xfs-linux:xfs-kern:207393a. The function was added as a wrapper around
      xfs_bmap_do_search_extents() to avoid breaking the top-of-tree CXFS
      interface.  The idea of the function was basically to extract the target
      extent buffer (if muli- level extent allocation mode), then call
      xfs_bmap_do_search_extents() with either a pointer to the first extent in
      the target buffer or a pointer to the first extent in the file, depending
      on which extent mode was being used.  However, in addition to locating the
      target extent record for block bno, xfs_bmap_do_search_extents() also sets
      four parameters needed by the caller: *lastx, *eofp, *gotp, *prevp. 
      Passing only the target extent buffer to xfs_bmap_do_search_extents()
      causes *eofp to be set incorrectly if the extent is at the end of the
      target list but there are actually more extents in the next er_extbuf.
      Likewise, if the extent is the first one in the buffer but NOT the first
      in the file, *prevp is incorrectly set to NULL.  Adding the needed
      functionality to xfs_bmap_search_multi_extents() to re-set any incorrectly
      set fields is redundant and makes the call to xfs_bmap_do_search_extents()
      not make much sense when multi-level extent allocation mode is being used.
       This mod basically extracts the two functional components from
      xfs_bmap_do_search_extents(), with the intent of obsoleting/removing
      xfs_bmap_do_search_extents() after the CXFS mult-level in-core extent
      changes are checked in.  The two components are:  1) The binary search to
      locate the target extent record, and 2) Setting the four parameters needed
      by the caller (*lastx, *eofp, *gotp, *prevp).  Component 1: I created a
      new function in xfs_inode.c called xfs_iext_bno_to_ext(), which executes
      the binary search to find the target extent record.
      xfs_bmap_search_multi_extents() has been modified to call
      xfs_iext_bno_to_ext() rather than xfs_bmap_do_search_extents().  Component
      2: The parameter setting functionality has been added to
      xfs_bmap_search_multi_extents(), eliminating the need for
      xfs_bmap_do_search_extents().  These changes make the removal of
      xfs_bmap_do_search_extents() trival once the CXFS changes are in place. 
      They also allow us to maintain the current XFS interface, using the new
      search function introduced in mod xfs-linux:xfs-kern:207393a.
      
      SGI-PV: 928864
      SGI-Modid: xfs-linux-melb:xfs-kern:207866a
      Signed-off-by: default avatarMandy Kirkconnell <alkirkco@sgi.com>
      Signed-off-by: default avatarNathan Scott <nathans@sgi.com>
      8867bc9b
  2. 14 Mar, 2006 32 commits