xfs: during btree split, save new block key & ptr for future insertion
authorDarrick J. Wong <darrick.wong@oracle.com>
Wed, 3 Aug 2016 01:02:39 +0000 (11:02 +1000)
committerDave Chinner <david@fromorbit.com>
Wed, 3 Aug 2016 01:02:39 +0000 (11:02 +1000)
commite5821e57af54abc36ea299bde6c101a804cfac27
tree3c5e2137fd2e92fb01b463a6e2b8c6bd46aa1db3
parent0d309791bdc0a92f1db5dfc171d884a6b8583702
xfs: during btree split, save new block key & ptr for future insertion

When a btree block has to be split, we pass the new block's ptr from
xfs_btree_split() back to xfs_btree_insert() via a pointer parameter;
however, we pass the block's key through the cursor's record.  It is a
little weird to "initialize" a record from a key since the non-key
attributes will have garbage values.

When we go to add support for interval queries, we have to be able to
pass the lowest and highest keys accessible via a pointer.  There's no
clean way to pass this back through the cursor's record field.
Therefore, pass the key directly back to xfs_btree_insert() the same
way that we pass the btree_ptr.

As a bonus, we no longer need init_rec_from_key and can drop it from the
codebase.

Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: Brian Foster <bfoster@redhat.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Dave Chinner <david@fromorbit.com>
fs/xfs/libxfs/xfs_alloc_btree.c
fs/xfs/libxfs/xfs_bmap_btree.c
fs/xfs/libxfs/xfs_btree.c
fs/xfs/libxfs/xfs_btree.h
fs/xfs/libxfs/xfs_ialloc_btree.c