2  * Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
 
   5  * This program is free software; you can redistribute it and/or
 
   6  * modify it under the terms of the GNU General Public License as
 
   7  * published by the Free Software Foundation.
 
   9  * This program is distributed in the hope that it would be useful,
 
  10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  12  * GNU General Public License for more details.
 
  14  * You should have received a copy of the GNU General Public License
 
  15  * along with this program; if not, write the Free Software Foundation,
 
  16  * Inc.,  51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 
  20 #include "xfs_types.h"
 
  24 #include "xfs_trans.h"
 
  29 #include "xfs_dmapi.h"
 
  30 #include "xfs_mount.h"
 
  31 #include "xfs_bmap_btree.h"
 
  32 #include "xfs_alloc_btree.h"
 
  33 #include "xfs_ialloc_btree.h"
 
  34 #include "xfs_dir_sf.h"
 
  35 #include "xfs_dir2_sf.h"
 
  36 #include "xfs_attr_sf.h"
 
  37 #include "xfs_dinode.h"
 
  38 #include "xfs_inode.h"
 
  39 #include "xfs_btree.h"
 
  40 #include "xfs_ialloc.h"
 
  41 #include "xfs_alloc.h"
 
  42 #include "xfs_error.h"
 
  44 STATIC void xfs_inobt_log_block(xfs_trans_t *, xfs_buf_t *, int);
 
  45 STATIC void xfs_inobt_log_keys(xfs_btree_cur_t *, xfs_buf_t *, int, int);
 
  46 STATIC void xfs_inobt_log_ptrs(xfs_btree_cur_t *, xfs_buf_t *, int, int);
 
  47 STATIC void xfs_inobt_log_recs(xfs_btree_cur_t *, xfs_buf_t *, int, int);
 
  48 STATIC int xfs_inobt_lshift(xfs_btree_cur_t *, int, int *);
 
  49 STATIC int xfs_inobt_newroot(xfs_btree_cur_t *, int *);
 
  50 STATIC int xfs_inobt_rshift(xfs_btree_cur_t *, int, int *);
 
  51 STATIC int xfs_inobt_split(xfs_btree_cur_t *, int, xfs_agblock_t *,
 
  52                 xfs_inobt_key_t *, xfs_btree_cur_t **, int *);
 
  53 STATIC int xfs_inobt_updkey(xfs_btree_cur_t *, xfs_inobt_key_t *, int);
 
  56  * Single level of the xfs_inobt_delete record deletion routine.
 
  57  * Delete record pointed to by cur/level.
 
  58  * Remove the record from its block then rebalance the tree.
 
  59  * Return 0 for error, 1 for done, 2 to go on to the next level.
 
  61 STATIC int                              /* error */
 
  63         xfs_btree_cur_t         *cur,   /* btree cursor */
 
  64         int                     level,  /* level removing record from */
 
  65         int                     *stat)  /* fail/done/go-on */
 
  67         xfs_buf_t               *agbp;  /* buffer for a.g. inode header */
 
  68         xfs_mount_t             *mp;    /* mount structure */
 
  69         xfs_agi_t               *agi;   /* allocation group inode header */
 
  70         xfs_inobt_block_t       *block; /* btree block record/key lives in */
 
  71         xfs_agblock_t           bno;    /* btree block number */
 
  72         xfs_buf_t               *bp;    /* buffer for block */
 
  73         int                     error;  /* error return value */
 
  74         int                     i;      /* loop index */
 
  75         xfs_inobt_key_t         key;    /* kp points here if block is level 0 */
 
  76         xfs_inobt_key_t         *kp = NULL;     /* pointer to btree keys */
 
  77         xfs_agblock_t           lbno;   /* left block's block number */
 
  78         xfs_buf_t               *lbp;   /* left block's buffer pointer */
 
  79         xfs_inobt_block_t       *left;  /* left btree block */
 
  80         xfs_inobt_key_t         *lkp;   /* left block key pointer */
 
  81         xfs_inobt_ptr_t         *lpp;   /* left block address pointer */
 
  82         int                     lrecs = 0;      /* number of records in left block */
 
  83         xfs_inobt_rec_t         *lrp;   /* left block record pointer */
 
  84         xfs_inobt_ptr_t         *pp = NULL;     /* pointer to btree addresses */
 
  85         int                     ptr;    /* index in btree block for this rec */
 
  86         xfs_agblock_t           rbno;   /* right block's block number */
 
  87         xfs_buf_t               *rbp;   /* right block's buffer pointer */
 
  88         xfs_inobt_block_t       *right; /* right btree block */
 
  89         xfs_inobt_key_t         *rkp;   /* right block key pointer */
 
  90         xfs_inobt_rec_t         *rp;    /* pointer to btree records */
 
  91         xfs_inobt_ptr_t         *rpp;   /* right block address pointer */
 
  92         int                     rrecs = 0;      /* number of records in right block */
 
  94         xfs_inobt_rec_t         *rrp;   /* right block record pointer */
 
  95         xfs_btree_cur_t         *tcur;  /* temporary btree cursor */
 
 100          * Get the index of the entry being deleted, check for nothing there.
 
 102         ptr = cur->bc_ptrs[level];
 
 109          * Get the buffer & block containing the record or key/ptr.
 
 111         bp = cur->bc_bufs[level];
 
 112         block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
 114         if ((error = xfs_btree_check_sblock(cur, block, level, bp)))
 
 118          * Fail if we're off the end of the block.
 
 121         numrecs = be16_to_cpu(block->bb_numrecs);
 
 127          * It's a nonleaf.  Excise the key and ptr being deleted, by
 
 128          * sliding the entries past them down one.
 
 129          * Log the changed areas of the block.
 
 132                 kp = XFS_INOBT_KEY_ADDR(block, 1, cur);
 
 133                 pp = XFS_INOBT_PTR_ADDR(block, 1, cur);
 
 135                 for (i = ptr; i < numrecs; i++) {
 
 136                         if ((error = xfs_btree_check_sptr(cur, be32_to_cpu(pp[i]), level)))
 
 141                         memmove(&kp[ptr - 1], &kp[ptr],
 
 142                                 (numrecs - ptr) * sizeof(*kp));
 
 143                         memmove(&pp[ptr - 1], &pp[ptr],
 
 144                                 (numrecs - ptr) * sizeof(*kp));
 
 145                         xfs_inobt_log_keys(cur, bp, ptr, numrecs - 1);
 
 146                         xfs_inobt_log_ptrs(cur, bp, ptr, numrecs - 1);
 
 150          * It's a leaf.  Excise the record being deleted, by sliding the
 
 151          * entries past it down one.  Log the changed areas of the block.
 
 154                 rp = XFS_INOBT_REC_ADDR(block, 1, cur);
 
 156                         memmove(&rp[ptr - 1], &rp[ptr],
 
 157                                 (numrecs - ptr) * sizeof(*rp));
 
 158                         xfs_inobt_log_recs(cur, bp, ptr, numrecs - 1);
 
 161                  * If it's the first record in the block, we'll need a key
 
 162                  * structure to pass up to the next level (updkey).
 
 165                         key.ir_startino = rp->ir_startino;
 
 170          * Decrement and log the number of entries in the block.
 
 173         block->bb_numrecs = cpu_to_be16(numrecs);
 
 174         xfs_inobt_log_block(cur->bc_tp, bp, XFS_BB_NUMRECS);
 
 176          * Is this the root level?  If so, we're almost done.
 
 178         if (level == cur->bc_nlevels - 1) {
 
 180                  * If this is the root level,
 
 181                  * and there's only one entry left,
 
 182                  * and it's NOT the leaf level,
 
 183                  * then we can get rid of this level.
 
 185                 if (numrecs == 1 && level > 0) {
 
 186                         agbp = cur->bc_private.i.agbp;
 
 187                         agi = XFS_BUF_TO_AGI(agbp);
 
 189                          * pp is still set to the first pointer in the block.
 
 190                          * Make it the new root of the btree.
 
 192                         bno = be32_to_cpu(agi->agi_root);
 
 194                         be32_add(&agi->agi_level, -1);
 
 198                         if ((error = xfs_free_extent(cur->bc_tp,
 
 199                                 XFS_AGB_TO_FSB(mp, cur->bc_private.i.agno, bno), 1)))
 
 201                         xfs_trans_binval(cur->bc_tp, bp);
 
 202                         xfs_ialloc_log_agi(cur->bc_tp, agbp,
 
 203                                 XFS_AGI_ROOT | XFS_AGI_LEVEL);
 
 205                          * Update the cursor so there's one fewer level.
 
 207                         cur->bc_bufs[level] = NULL;
 
 209                 } else if (level > 0 &&
 
 210                            (error = xfs_inobt_decrement(cur, level, &i)))
 
 216          * If we deleted the leftmost entry in the block, update the
 
 217          * key values above us in the tree.
 
 219         if (ptr == 1 && (error = xfs_inobt_updkey(cur, kp, level + 1)))
 
 222          * If the number of records remaining in the block is at least
 
 223          * the minimum, we're done.
 
 225         if (numrecs >= XFS_INOBT_BLOCK_MINRECS(level, cur)) {
 
 227                     (error = xfs_inobt_decrement(cur, level, &i)))
 
 233          * Otherwise, we have to move some records around to keep the
 
 234          * tree balanced.  Look at the left and right sibling blocks to
 
 235          * see if we can re-balance by moving only one record.
 
 237         rbno = be32_to_cpu(block->bb_rightsib);
 
 238         lbno = be32_to_cpu(block->bb_leftsib);
 
 240         ASSERT(rbno != NULLAGBLOCK || lbno != NULLAGBLOCK);
 
 242          * Duplicate the cursor so our btree manipulations here won't
 
 243          * disrupt the next level up.
 
 245         if ((error = xfs_btree_dup_cursor(cur, &tcur)))
 
 248          * If there's a right sibling, see if it's ok to shift an entry
 
 251         if (rbno != NULLAGBLOCK) {
 
 253                  * Move the temp cursor to the last entry in the next block.
 
 254                  * Actually any entry but the first would suffice.
 
 256                 i = xfs_btree_lastrec(tcur, level);
 
 257                 XFS_WANT_CORRUPTED_GOTO(i == 1, error0);
 
 258                 if ((error = xfs_inobt_increment(tcur, level, &i)))
 
 260                 XFS_WANT_CORRUPTED_GOTO(i == 1, error0);
 
 261                 i = xfs_btree_lastrec(tcur, level);
 
 262                 XFS_WANT_CORRUPTED_GOTO(i == 1, error0);
 
 264                  * Grab a pointer to the block.
 
 266                 rbp = tcur->bc_bufs[level];
 
 267                 right = XFS_BUF_TO_INOBT_BLOCK(rbp);
 
 269                 if ((error = xfs_btree_check_sblock(cur, right, level, rbp)))
 
 273                  * Grab the current block number, for future use.
 
 275                 bno = be32_to_cpu(right->bb_leftsib);
 
 277                  * If right block is full enough so that removing one entry
 
 278                  * won't make it too empty, and left-shifting an entry out
 
 279                  * of right to us works, we're done.
 
 281                 if (be16_to_cpu(right->bb_numrecs) - 1 >=
 
 282                      XFS_INOBT_BLOCK_MINRECS(level, cur)) {
 
 283                         if ((error = xfs_inobt_lshift(tcur, level, &i)))
 
 286                                 ASSERT(be16_to_cpu(block->bb_numrecs) >=
 
 287                                        XFS_INOBT_BLOCK_MINRECS(level, cur));
 
 288                                 xfs_btree_del_cursor(tcur,
 
 291                                     (error = xfs_inobt_decrement(cur, level,
 
 299                  * Otherwise, grab the number of records in right for
 
 300                  * future reference, and fix up the temp cursor to point
 
 301                  * to our block again (last record).
 
 303                 rrecs = be16_to_cpu(right->bb_numrecs);
 
 304                 if (lbno != NULLAGBLOCK) {
 
 305                         xfs_btree_firstrec(tcur, level);
 
 306                         if ((error = xfs_inobt_decrement(tcur, level, &i)))
 
 311          * If there's a left sibling, see if it's ok to shift an entry
 
 314         if (lbno != NULLAGBLOCK) {
 
 316                  * Move the temp cursor to the first entry in the
 
 319                 xfs_btree_firstrec(tcur, level);
 
 320                 if ((error = xfs_inobt_decrement(tcur, level, &i)))
 
 322                 xfs_btree_firstrec(tcur, level);
 
 324                  * Grab a pointer to the block.
 
 326                 lbp = tcur->bc_bufs[level];
 
 327                 left = XFS_BUF_TO_INOBT_BLOCK(lbp);
 
 329                 if ((error = xfs_btree_check_sblock(cur, left, level, lbp)))
 
 333                  * Grab the current block number, for future use.
 
 335                 bno = be32_to_cpu(left->bb_rightsib);
 
 337                  * If left block is full enough so that removing one entry
 
 338                  * won't make it too empty, and right-shifting an entry out
 
 339                  * of left to us works, we're done.
 
 341                 if (be16_to_cpu(left->bb_numrecs) - 1 >=
 
 342                      XFS_INOBT_BLOCK_MINRECS(level, cur)) {
 
 343                         if ((error = xfs_inobt_rshift(tcur, level, &i)))
 
 346                                 ASSERT(be16_to_cpu(block->bb_numrecs) >=
 
 347                                        XFS_INOBT_BLOCK_MINRECS(level, cur));
 
 348                                 xfs_btree_del_cursor(tcur,
 
 357                  * Otherwise, grab the number of records in right for
 
 360                 lrecs = be16_to_cpu(left->bb_numrecs);
 
 363          * Delete the temp cursor, we're done with it.
 
 365         xfs_btree_del_cursor(tcur, XFS_BTREE_NOERROR);
 
 367          * If here, we need to do a join to keep the tree balanced.
 
 369         ASSERT(bno != NULLAGBLOCK);
 
 371          * See if we can join with the left neighbor block.
 
 373         if (lbno != NULLAGBLOCK &&
 
 374             lrecs + numrecs <= XFS_INOBT_BLOCK_MAXRECS(level, cur)) {
 
 376                  * Set "right" to be the starting block,
 
 377                  * "left" to be the left neighbor.
 
 381                 rrecs = be16_to_cpu(right->bb_numrecs);
 
 383                 if ((error = xfs_btree_read_bufs(mp, cur->bc_tp,
 
 384                                 cur->bc_private.i.agno, lbno, 0, &lbp,
 
 387                 left = XFS_BUF_TO_INOBT_BLOCK(lbp);
 
 388                 lrecs = be16_to_cpu(left->bb_numrecs);
 
 389                 if ((error = xfs_btree_check_sblock(cur, left, level, lbp)))
 
 393          * If that won't work, see if we can join with the right neighbor block.
 
 395         else if (rbno != NULLAGBLOCK &&
 
 396                  rrecs + numrecs <= XFS_INOBT_BLOCK_MAXRECS(level, cur)) {
 
 398                  * Set "left" to be the starting block,
 
 399                  * "right" to be the right neighbor.
 
 403                 lrecs = be16_to_cpu(left->bb_numrecs);
 
 405                 if ((error = xfs_btree_read_bufs(mp, cur->bc_tp,
 
 406                                 cur->bc_private.i.agno, rbno, 0, &rbp,
 
 409                 right = XFS_BUF_TO_INOBT_BLOCK(rbp);
 
 410                 rrecs = be16_to_cpu(right->bb_numrecs);
 
 411                 if ((error = xfs_btree_check_sblock(cur, right, level, rbp)))
 
 415          * Otherwise, we can't fix the imbalance.
 
 416          * Just return.  This is probably a logic error, but it's not fatal.
 
 419                 if (level > 0 && (error = xfs_inobt_decrement(cur, level, &i)))
 
 425          * We're now going to join "left" and "right" by moving all the stuff
 
 426          * in "right" to "left" and deleting "right".
 
 430                  * It's a non-leaf.  Move keys and pointers.
 
 432                 lkp = XFS_INOBT_KEY_ADDR(left, lrecs + 1, cur);
 
 433                 lpp = XFS_INOBT_PTR_ADDR(left, lrecs + 1, cur);
 
 434                 rkp = XFS_INOBT_KEY_ADDR(right, 1, cur);
 
 435                 rpp = XFS_INOBT_PTR_ADDR(right, 1, cur);
 
 437                 for (i = 0; i < rrecs; i++) {
 
 438                         if ((error = xfs_btree_check_sptr(cur, be32_to_cpu(rpp[i]), level)))
 
 442                 memcpy(lkp, rkp, rrecs * sizeof(*lkp));
 
 443                 memcpy(lpp, rpp, rrecs * sizeof(*lpp));
 
 444                 xfs_inobt_log_keys(cur, lbp, lrecs + 1, lrecs + rrecs);
 
 445                 xfs_inobt_log_ptrs(cur, lbp, lrecs + 1, lrecs + rrecs);
 
 448                  * It's a leaf.  Move records.
 
 450                 lrp = XFS_INOBT_REC_ADDR(left, lrecs + 1, cur);
 
 451                 rrp = XFS_INOBT_REC_ADDR(right, 1, cur);
 
 452                 memcpy(lrp, rrp, rrecs * sizeof(*lrp));
 
 453                 xfs_inobt_log_recs(cur, lbp, lrecs + 1, lrecs + rrecs);
 
 456          * If we joined with the left neighbor, set the buffer in the
 
 457          * cursor to the left block, and fix up the index.
 
 460                 xfs_btree_setbuf(cur, level, lbp);
 
 461                 cur->bc_ptrs[level] += lrecs;
 
 464          * If we joined with the right neighbor and there's a level above
 
 465          * us, increment the cursor at that level.
 
 467         else if (level + 1 < cur->bc_nlevels &&
 
 468                  (error = xfs_alloc_increment(cur, level + 1, &i)))
 
 471          * Fix up the number of records in the surviving block.
 
 474         left->bb_numrecs = cpu_to_be16(lrecs);
 
 476          * Fix up the right block pointer in the surviving block, and log it.
 
 478         left->bb_rightsib = right->bb_rightsib;
 
 479         xfs_inobt_log_block(cur->bc_tp, lbp, XFS_BB_NUMRECS | XFS_BB_RIGHTSIB);
 
 481          * If there is a right sibling now, make it point to the
 
 484         if (be32_to_cpu(left->bb_rightsib) != NULLAGBLOCK) {
 
 485                 xfs_inobt_block_t       *rrblock;
 
 488                 if ((error = xfs_btree_read_bufs(mp, cur->bc_tp,
 
 489                                 cur->bc_private.i.agno, be32_to_cpu(left->bb_rightsib), 0,
 
 490                                 &rrbp, XFS_INO_BTREE_REF)))
 
 492                 rrblock = XFS_BUF_TO_INOBT_BLOCK(rrbp);
 
 493                 if ((error = xfs_btree_check_sblock(cur, rrblock, level, rrbp)))
 
 495                 rrblock->bb_leftsib = cpu_to_be32(lbno);
 
 496                 xfs_inobt_log_block(cur->bc_tp, rrbp, XFS_BB_LEFTSIB);
 
 499          * Free the deleting block.
 
 501         if ((error = xfs_free_extent(cur->bc_tp, XFS_AGB_TO_FSB(mp,
 
 502                                      cur->bc_private.i.agno, rbno), 1)))
 
 504         xfs_trans_binval(cur->bc_tp, rbp);
 
 506          * Readjust the ptr at this level if it's not a leaf, since it's
 
 507          * still pointing at the deletion point, which makes the cursor
 
 508          * inconsistent.  If this makes the ptr 0, the caller fixes it up.
 
 509          * We can't use decrement because it would change the next level up.
 
 512                 cur->bc_ptrs[level]--;
 
 514          * Return value means the next level up has something to do.
 
 520         xfs_btree_del_cursor(tcur, XFS_BTREE_ERROR);
 
 525  * Insert one record/level.  Return information to the caller
 
 526  * allowing the next level up to proceed if necessary.
 
 528 STATIC int                              /* error */
 
 530         xfs_btree_cur_t         *cur,   /* btree cursor */
 
 531         int                     level,  /* level to insert record at */
 
 532         xfs_agblock_t           *bnop,  /* i/o: block number inserted */
 
 533         xfs_inobt_rec_t         *recp,  /* i/o: record data inserted */
 
 534         xfs_btree_cur_t         **curp, /* output: new cursor replacing cur */
 
 535         int                     *stat)  /* success/failure */
 
 537         xfs_inobt_block_t       *block; /* btree block record/key lives in */
 
 538         xfs_buf_t               *bp;    /* buffer for block */
 
 539         int                     error;  /* error return value */
 
 540         int                     i;      /* loop index */
 
 541         xfs_inobt_key_t         key;    /* key value being inserted */
 
 542         xfs_inobt_key_t         *kp=NULL;       /* pointer to btree keys */
 
 543         xfs_agblock_t           nbno;   /* block number of allocated block */
 
 544         xfs_btree_cur_t         *ncur;  /* new cursor to be used at next lvl */
 
 545         xfs_inobt_key_t         nkey;   /* new key value, from split */
 
 546         xfs_inobt_rec_t         nrec;   /* new record value, for caller */
 
 548         int                     optr;   /* old ptr value */
 
 549         xfs_inobt_ptr_t         *pp;    /* pointer to btree addresses */
 
 550         int                     ptr;    /* index in btree block for this rec */
 
 551         xfs_inobt_rec_t         *rp=NULL;       /* pointer to btree records */
 
 554          * GCC doesn't understand the (arguably complex) control flow in
 
 555          * this function and complains about uninitialized structure fields
 
 558         memset(&nrec, 0, sizeof(nrec));
 
 561          * If we made it to the root level, allocate a new root block
 
 564         if (level >= cur->bc_nlevels) {
 
 565                 error = xfs_inobt_newroot(cur, &i);
 
 571          * Make a key out of the record data to be inserted, and save it.
 
 573         key.ir_startino = recp->ir_startino; /* INT_: direct copy */
 
 574         optr = ptr = cur->bc_ptrs[level];
 
 576          * If we're off the left edge, return failure.
 
 583          * Get pointers to the btree buffer and block.
 
 585         bp = cur->bc_bufs[level];
 
 586         block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
 587         numrecs = be16_to_cpu(block->bb_numrecs);
 
 589         if ((error = xfs_btree_check_sblock(cur, block, level, bp)))
 
 592          * Check that the new entry is being inserted in the right place.
 
 594         if (ptr <= numrecs) {
 
 596                         rp = XFS_INOBT_REC_ADDR(block, ptr, cur);
 
 597                         xfs_btree_check_rec(cur->bc_btnum, recp, rp);
 
 599                         kp = XFS_INOBT_KEY_ADDR(block, ptr, cur);
 
 600                         xfs_btree_check_key(cur->bc_btnum, &key, kp);
 
 605         ncur = (xfs_btree_cur_t *)0;
 
 607          * If the block is full, we can't insert the new entry until we
 
 608          * make the block un-full.
 
 610         if (numrecs == XFS_INOBT_BLOCK_MAXRECS(level, cur)) {
 
 612                  * First, try shifting an entry to the right neighbor.
 
 614                 if ((error = xfs_inobt_rshift(cur, level, &i)))
 
 620                  * Next, try shifting an entry to the left neighbor.
 
 623                         if ((error = xfs_inobt_lshift(cur, level, &i)))
 
 626                                 optr = ptr = cur->bc_ptrs[level];
 
 629                                  * Next, try splitting the current block
 
 630                                  * in half. If this works we have to
 
 631                                  * re-set our variables because
 
 632                                  * we could be in a different block now.
 
 634                                 if ((error = xfs_inobt_split(cur, level, &nbno,
 
 638                                         bp = cur->bc_bufs[level];
 
 639                                         block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
 641                                         if ((error = xfs_btree_check_sblock(cur,
 
 645                                         ptr = cur->bc_ptrs[level];
 
 646                                         nrec.ir_startino = nkey.ir_startino; /* INT_: direct copy */
 
 649                                          * Otherwise the insert fails.
 
 658          * At this point we know there's room for our new entry in the block
 
 661         numrecs = be16_to_cpu(block->bb_numrecs);
 
 664                  * It's a non-leaf entry.  Make a hole for the new data
 
 665                  * in the key and ptr regions of the block.
 
 667                 kp = XFS_INOBT_KEY_ADDR(block, 1, cur);
 
 668                 pp = XFS_INOBT_PTR_ADDR(block, 1, cur);
 
 670                 for (i = numrecs; i >= ptr; i--) {
 
 671                         if ((error = xfs_btree_check_sptr(cur, be32_to_cpu(pp[i - 1]), level)))
 
 675                 memmove(&kp[ptr], &kp[ptr - 1],
 
 676                         (numrecs - ptr + 1) * sizeof(*kp));
 
 677                 memmove(&pp[ptr], &pp[ptr - 1],
 
 678                         (numrecs - ptr + 1) * sizeof(*pp));
 
 680                  * Now stuff the new data in, bump numrecs and log the new data.
 
 683                 if ((error = xfs_btree_check_sptr(cur, *bnop, level)))
 
 686                 kp[ptr - 1] = key; /* INT_: struct copy */
 
 687                 pp[ptr - 1] = cpu_to_be32(*bnop);
 
 689                 block->bb_numrecs = cpu_to_be16(numrecs);
 
 690                 xfs_inobt_log_keys(cur, bp, ptr, numrecs);
 
 691                 xfs_inobt_log_ptrs(cur, bp, ptr, numrecs);
 
 694                  * It's a leaf entry.  Make a hole for the new record.
 
 696                 rp = XFS_INOBT_REC_ADDR(block, 1, cur);
 
 697                 memmove(&rp[ptr], &rp[ptr - 1],
 
 698                         (numrecs - ptr + 1) * sizeof(*rp));
 
 700                  * Now stuff the new record in, bump numrecs
 
 701                  * and log the new data.
 
 703                 rp[ptr - 1] = *recp; /* INT_: struct copy */
 
 705                 block->bb_numrecs = cpu_to_be16(numrecs);
 
 706                 xfs_inobt_log_recs(cur, bp, ptr, numrecs);
 
 709          * Log the new number of records in the btree header.
 
 711         xfs_inobt_log_block(cur->bc_tp, bp, XFS_BB_NUMRECS);
 
 714          * Check that the key/record is in the right place, now.
 
 718                         xfs_btree_check_rec(cur->bc_btnum, rp + ptr - 1,
 
 721                         xfs_btree_check_key(cur->bc_btnum, kp + ptr - 1,
 
 726          * If we inserted at the start of a block, update the parents' keys.
 
 728         if (optr == 1 && (error = xfs_inobt_updkey(cur, &key, level + 1)))
 
 731          * Return the new block number, if any.
 
 732          * If there is one, give back a record value and a cursor too.
 
 735         if (nbno != NULLAGBLOCK) {
 
 736                 *recp = nrec; /* INT_: struct copy */
 
 744  * Log header fields from a btree block.
 
 748         xfs_trans_t             *tp,    /* transaction pointer */
 
 749         xfs_buf_t               *bp,    /* buffer containing btree block */
 
 750         int                     fields) /* mask of fields: XFS_BB_... */
 
 752         int                     first;  /* first byte offset logged */
 
 753         int                     last;   /* last byte offset logged */
 
 754         static const short      offsets[] = {   /* table of offsets */
 
 755                 offsetof(xfs_inobt_block_t, bb_magic),
 
 756                 offsetof(xfs_inobt_block_t, bb_level),
 
 757                 offsetof(xfs_inobt_block_t, bb_numrecs),
 
 758                 offsetof(xfs_inobt_block_t, bb_leftsib),
 
 759                 offsetof(xfs_inobt_block_t, bb_rightsib),
 
 760                 sizeof(xfs_inobt_block_t)
 
 763         xfs_btree_offsets(fields, offsets, XFS_BB_NUM_BITS, &first, &last);
 
 764         xfs_trans_log_buf(tp, bp, first, last);
 
 768  * Log keys from a btree block (nonleaf).
 
 772         xfs_btree_cur_t         *cur,   /* btree cursor */
 
 773         xfs_buf_t               *bp,    /* buffer containing btree block */
 
 774         int                     kfirst, /* index of first key to log */
 
 775         int                     klast)  /* index of last key to log */
 
 777         xfs_inobt_block_t       *block; /* btree block to log from */
 
 778         int                     first;  /* first byte offset logged */
 
 779         xfs_inobt_key_t         *kp;    /* key pointer in btree block */
 
 780         int                     last;   /* last byte offset logged */
 
 782         block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
 783         kp = XFS_INOBT_KEY_ADDR(block, 1, cur);
 
 784         first = (int)((xfs_caddr_t)&kp[kfirst - 1] - (xfs_caddr_t)block);
 
 785         last = (int)(((xfs_caddr_t)&kp[klast] - 1) - (xfs_caddr_t)block);
 
 786         xfs_trans_log_buf(cur->bc_tp, bp, first, last);
 
 790  * Log block pointer fields from a btree block (nonleaf).
 
 794         xfs_btree_cur_t         *cur,   /* btree cursor */
 
 795         xfs_buf_t               *bp,    /* buffer containing btree block */
 
 796         int                     pfirst, /* index of first pointer to log */
 
 797         int                     plast)  /* index of last pointer to log */
 
 799         xfs_inobt_block_t       *block; /* btree block to log from */
 
 800         int                     first;  /* first byte offset logged */
 
 801         int                     last;   /* last byte offset logged */
 
 802         xfs_inobt_ptr_t         *pp;    /* block-pointer pointer in btree blk */
 
 804         block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
 805         pp = XFS_INOBT_PTR_ADDR(block, 1, cur);
 
 806         first = (int)((xfs_caddr_t)&pp[pfirst - 1] - (xfs_caddr_t)block);
 
 807         last = (int)(((xfs_caddr_t)&pp[plast] - 1) - (xfs_caddr_t)block);
 
 808         xfs_trans_log_buf(cur->bc_tp, bp, first, last);
 
 812  * Log records from a btree block (leaf).
 
 816         xfs_btree_cur_t         *cur,   /* btree cursor */
 
 817         xfs_buf_t               *bp,    /* buffer containing btree block */
 
 818         int                     rfirst, /* index of first record to log */
 
 819         int                     rlast)  /* index of last record to log */
 
 821         xfs_inobt_block_t       *block; /* btree block to log from */
 
 822         int                     first;  /* first byte offset logged */
 
 823         int                     last;   /* last byte offset logged */
 
 824         xfs_inobt_rec_t         *rp;    /* record pointer for btree block */
 
 826         block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
 827         rp = XFS_INOBT_REC_ADDR(block, 1, cur);
 
 828         first = (int)((xfs_caddr_t)&rp[rfirst - 1] - (xfs_caddr_t)block);
 
 829         last = (int)(((xfs_caddr_t)&rp[rlast] - 1) - (xfs_caddr_t)block);
 
 830         xfs_trans_log_buf(cur->bc_tp, bp, first, last);
 
 834  * Lookup the record.  The cursor is made to point to it, based on dir.
 
 835  * Return 0 if can't find any such record, 1 for success.
 
 837 STATIC int                              /* error */
 
 839         xfs_btree_cur_t         *cur,   /* btree cursor */
 
 840         xfs_lookup_t            dir,    /* <=, ==, or >= */
 
 841         int                     *stat)  /* success/failure */
 
 843         xfs_agblock_t           agbno;  /* a.g. relative btree block number */
 
 844         xfs_agnumber_t          agno;   /* allocation group number */
 
 845         xfs_inobt_block_t       *block=NULL;    /* current btree block */
 
 846         __int64_t               diff;   /* difference for the current key */
 
 847         int                     error;  /* error return value */
 
 848         int                     keyno=0;        /* current key number */
 
 849         int                     level;  /* level in the btree */
 
 850         xfs_mount_t             *mp;    /* file system mount point */
 
 853          * Get the allocation group header, and the root block number.
 
 857                 xfs_agi_t       *agi;   /* a.g. inode header */
 
 859                 agi = XFS_BUF_TO_AGI(cur->bc_private.i.agbp);
 
 860                 agno = be32_to_cpu(agi->agi_seqno);
 
 861                 agbno = be32_to_cpu(agi->agi_root);
 
 864          * Iterate over each level in the btree, starting at the root.
 
 865          * For each level above the leaves, find the key we need, based
 
 866          * on the lookup record, then follow the corresponding block
 
 867          * pointer down to the next level.
 
 869         for (level = cur->bc_nlevels - 1, diff = 1; level >= 0; level--) {
 
 870                 xfs_buf_t       *bp;    /* buffer pointer for btree block */
 
 871                 xfs_daddr_t     d;      /* disk address of btree block */
 
 874                  * Get the disk address we're looking for.
 
 876                 d = XFS_AGB_TO_DADDR(mp, agno, agbno);
 
 878                  * If the old buffer at this level is for a different block,
 
 879                  * throw it away, otherwise just use it.
 
 881                 bp = cur->bc_bufs[level];
 
 882                 if (bp && XFS_BUF_ADDR(bp) != d)
 
 886                          * Need to get a new buffer.  Read it, then
 
 887                          * set it in the cursor, releasing the old one.
 
 889                         if ((error = xfs_btree_read_bufs(mp, cur->bc_tp,
 
 890                                         agno, agbno, 0, &bp, XFS_INO_BTREE_REF)))
 
 892                         xfs_btree_setbuf(cur, level, bp);
 
 894                          * Point to the btree block, now that we have the buffer
 
 896                         block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
 897                         if ((error = xfs_btree_check_sblock(cur, block, level,
 
 901                         block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
 903                  * If we already had a key match at a higher level, we know
 
 904                  * we need to use the first entry in this block.
 
 909                  * Otherwise we need to search this block.  Do a binary search.
 
 912                         int             high;   /* high entry number */
 
 913                         xfs_inobt_key_t *kkbase=NULL;/* base of keys in block */
 
 914                         xfs_inobt_rec_t *krbase=NULL;/* base of records in block */
 
 915                         int             low;    /* low entry number */
 
 918                          * Get a pointer to keys or records.
 
 921                                 kkbase = XFS_INOBT_KEY_ADDR(block, 1, cur);
 
 923                                 krbase = XFS_INOBT_REC_ADDR(block, 1, cur);
 
 925                          * Set low and high entry numbers, 1-based.
 
 928                         if (!(high = be16_to_cpu(block->bb_numrecs))) {
 
 930                                  * If the block is empty, the tree must
 
 933                                 ASSERT(level == 0 && cur->bc_nlevels == 1);
 
 934                                 cur->bc_ptrs[0] = dir != XFS_LOOKUP_LE;
 
 939                          * Binary search the block.
 
 941                         while (low <= high) {
 
 942                                 xfs_agino_t     startino;       /* key value */
 
 945                                  * keyno is average of low and high.
 
 947                                 keyno = (low + high) >> 1;
 
 952                                         xfs_inobt_key_t *kkp;
 
 954                                         kkp = kkbase + keyno - 1;
 
 955                                         startino = INT_GET(kkp->ir_startino, ARCH_CONVERT);
 
 957                                         xfs_inobt_rec_t *krp;
 
 959                                         krp = krbase + keyno - 1;
 
 960                                         startino = INT_GET(krp->ir_startino, ARCH_CONVERT);
 
 963                                  * Compute difference to get next direction.
 
 966                                         startino - cur->bc_rec.i.ir_startino;
 
 968                                  * Less than, move right.
 
 973                                  * Greater than, move left.
 
 985                  * If there are more levels, set up for the next level
 
 986                  * by getting the block number and filling in the cursor.
 
 990                          * If we moved left, need the previous key number,
 
 991                          * unless there isn't one.
 
 993                         if (diff > 0 && --keyno < 1)
 
 995                         agbno = be32_to_cpu(*XFS_INOBT_PTR_ADDR(block, keyno, cur));
 
 997                         if ((error = xfs_btree_check_sptr(cur, agbno, level)))
 
1000                         cur->bc_ptrs[level] = keyno;
 
1004          * Done with the search.
 
1005          * See if we need to adjust the results.
 
1007         if (dir != XFS_LOOKUP_LE && diff < 0) {
 
1010                  * If ge search and we went off the end of the block, but it's
 
1011                  * not the last block, we're in the wrong block.
 
1013                 if (dir == XFS_LOOKUP_GE &&
 
1014                     keyno > be16_to_cpu(block->bb_numrecs) &&
 
1015                     be32_to_cpu(block->bb_rightsib) != NULLAGBLOCK) {
 
1018                         cur->bc_ptrs[0] = keyno;
 
1019                         if ((error = xfs_inobt_increment(cur, 0, &i)))
 
1026         else if (dir == XFS_LOOKUP_LE && diff > 0)
 
1028         cur->bc_ptrs[0] = keyno;
 
1030          * Return if we succeeded or not.
 
1032         if (keyno == 0 || keyno > be16_to_cpu(block->bb_numrecs))
 
1035                 *stat = ((dir != XFS_LOOKUP_EQ) || (diff == 0));
 
1040  * Move 1 record left from cur/level if possible.
 
1041  * Update cur to reflect the new path.
 
1043 STATIC int                              /* error */
 
1045         xfs_btree_cur_t         *cur,   /* btree cursor */
 
1046         int                     level,  /* level to shift record on */
 
1047         int                     *stat)  /* success/failure */
 
1049         int                     error;  /* error return value */
 
1051         int                     i;      /* loop index */
 
1053         xfs_inobt_key_t         key;    /* key value for leaf level upward */
 
1054         xfs_buf_t               *lbp;   /* buffer for left neighbor block */
 
1055         xfs_inobt_block_t       *left;  /* left neighbor btree block */
 
1056         xfs_inobt_key_t         *lkp=NULL;      /* key pointer for left block */
 
1057         xfs_inobt_ptr_t         *lpp;   /* address pointer for left block */
 
1058         xfs_inobt_rec_t         *lrp=NULL;      /* record pointer for left block */
 
1059         int                     nrec;   /* new number of left block entries */
 
1060         xfs_buf_t               *rbp;   /* buffer for right (current) block */
 
1061         xfs_inobt_block_t       *right; /* right (current) btree block */
 
1062         xfs_inobt_key_t         *rkp=NULL;      /* key pointer for right block */
 
1063         xfs_inobt_ptr_t         *rpp=NULL;      /* address pointer for right block */
 
1064         xfs_inobt_rec_t         *rrp=NULL;      /* record pointer for right block */
 
1067          * Set up variables for this block as "right".
 
1069         rbp = cur->bc_bufs[level];
 
1070         right = XFS_BUF_TO_INOBT_BLOCK(rbp);
 
1072         if ((error = xfs_btree_check_sblock(cur, right, level, rbp)))
 
1076          * If we've got no left sibling then we can't shift an entry left.
 
1078         if (be32_to_cpu(right->bb_leftsib) == NULLAGBLOCK) {
 
1083          * If the cursor entry is the one that would be moved, don't
 
1084          * do it... it's too complicated.
 
1086         if (cur->bc_ptrs[level] <= 1) {
 
1091          * Set up the left neighbor as "left".
 
1093         if ((error = xfs_btree_read_bufs(cur->bc_mp, cur->bc_tp,
 
1094                         cur->bc_private.i.agno, be32_to_cpu(right->bb_leftsib),
 
1095                         0, &lbp, XFS_INO_BTREE_REF)))
 
1097         left = XFS_BUF_TO_INOBT_BLOCK(lbp);
 
1098         if ((error = xfs_btree_check_sblock(cur, left, level, lbp)))
 
1101          * If it's full, it can't take another entry.
 
1103         if (be16_to_cpu(left->bb_numrecs) == XFS_INOBT_BLOCK_MAXRECS(level, cur)) {
 
1107         nrec = be16_to_cpu(left->bb_numrecs) + 1;
 
1109          * If non-leaf, copy a key and a ptr to the left block.
 
1112                 lkp = XFS_INOBT_KEY_ADDR(left, nrec, cur);
 
1113                 rkp = XFS_INOBT_KEY_ADDR(right, 1, cur);
 
1115                 xfs_inobt_log_keys(cur, lbp, nrec, nrec);
 
1116                 lpp = XFS_INOBT_PTR_ADDR(left, nrec, cur);
 
1117                 rpp = XFS_INOBT_PTR_ADDR(right, 1, cur);
 
1119                 if ((error = xfs_btree_check_sptr(cur, be32_to_cpu(*rpp), level)))
 
1122                 *lpp = *rpp; /* INT_: no-change copy */
 
1123                 xfs_inobt_log_ptrs(cur, lbp, nrec, nrec);
 
1126          * If leaf, copy a record to the left block.
 
1129                 lrp = XFS_INOBT_REC_ADDR(left, nrec, cur);
 
1130                 rrp = XFS_INOBT_REC_ADDR(right, 1, cur);
 
1132                 xfs_inobt_log_recs(cur, lbp, nrec, nrec);
 
1135          * Bump and log left's numrecs, decrement and log right's numrecs.
 
1137         be16_add(&left->bb_numrecs, 1);
 
1138         xfs_inobt_log_block(cur->bc_tp, lbp, XFS_BB_NUMRECS);
 
1141                 xfs_btree_check_key(cur->bc_btnum, lkp - 1, lkp);
 
1143                 xfs_btree_check_rec(cur->bc_btnum, lrp - 1, lrp);
 
1145         be16_add(&right->bb_numrecs, -1);
 
1146         xfs_inobt_log_block(cur->bc_tp, rbp, XFS_BB_NUMRECS);
 
1148          * Slide the contents of right down one entry.
 
1152                 for (i = 0; i < be16_to_cpu(right->bb_numrecs); i++) {
 
1153                         if ((error = xfs_btree_check_sptr(cur, be32_to_cpu(rpp[i + 1]),
 
1158                 memmove(rkp, rkp + 1, be16_to_cpu(right->bb_numrecs) * sizeof(*rkp));
 
1159                 memmove(rpp, rpp + 1, be16_to_cpu(right->bb_numrecs) * sizeof(*rpp));
 
1160                 xfs_inobt_log_keys(cur, rbp, 1, be16_to_cpu(right->bb_numrecs));
 
1161                 xfs_inobt_log_ptrs(cur, rbp, 1, be16_to_cpu(right->bb_numrecs));
 
1163                 memmove(rrp, rrp + 1, be16_to_cpu(right->bb_numrecs) * sizeof(*rrp));
 
1164                 xfs_inobt_log_recs(cur, rbp, 1, be16_to_cpu(right->bb_numrecs));
 
1165                 key.ir_startino = rrp->ir_startino; /* INT_: direct copy */
 
1169          * Update the parent key values of right.
 
1171         if ((error = xfs_inobt_updkey(cur, rkp, level + 1)))
 
1174          * Slide the cursor value left one.
 
1176         cur->bc_ptrs[level]--;
 
1182  * Allocate a new root block, fill it in.
 
1184 STATIC int                              /* error */
 
1186         xfs_btree_cur_t         *cur,   /* btree cursor */
 
1187         int                     *stat)  /* success/failure */
 
1189         xfs_agi_t               *agi;   /* a.g. inode header */
 
1190         xfs_alloc_arg_t         args;   /* allocation argument structure */
 
1191         xfs_inobt_block_t       *block; /* one half of the old root block */
 
1192         xfs_buf_t               *bp;    /* buffer containing block */
 
1193         int                     error;  /* error return value */
 
1194         xfs_inobt_key_t         *kp;    /* btree key pointer */
 
1195         xfs_agblock_t           lbno;   /* left block number */
 
1196         xfs_buf_t               *lbp;   /* left buffer pointer */
 
1197         xfs_inobt_block_t       *left;  /* left btree block */
 
1198         xfs_buf_t               *nbp;   /* new (root) buffer */
 
1199         xfs_inobt_block_t       *new;   /* new (root) btree block */
 
1200         int                     nptr;   /* new value for key index, 1 or 2 */
 
1201         xfs_inobt_ptr_t         *pp;    /* btree address pointer */
 
1202         xfs_agblock_t           rbno;   /* right block number */
 
1203         xfs_buf_t               *rbp;   /* right buffer pointer */
 
1204         xfs_inobt_block_t       *right; /* right btree block */
 
1205         xfs_inobt_rec_t         *rp;    /* btree record pointer */
 
1207         ASSERT(cur->bc_nlevels < XFS_IN_MAXLEVELS(cur->bc_mp));
 
1210          * Get a block & a buffer.
 
1212         agi = XFS_BUF_TO_AGI(cur->bc_private.i.agbp);
 
1213         args.tp = cur->bc_tp;
 
1214         args.mp = cur->bc_mp;
 
1215         args.fsbno = XFS_AGB_TO_FSB(args.mp, cur->bc_private.i.agno,
 
1216                 be32_to_cpu(agi->agi_root));
 
1217         args.mod = args.minleft = args.alignment = args.total = args.wasdel =
 
1218                 args.isfl = args.userdata = args.minalignslop = 0;
 
1219         args.minlen = args.maxlen = args.prod = 1;
 
1220         args.type = XFS_ALLOCTYPE_NEAR_BNO;
 
1221         if ((error = xfs_alloc_vextent(&args)))
 
1224          * None available, we fail.
 
1226         if (args.fsbno == NULLFSBLOCK) {
 
1230         ASSERT(args.len == 1);
 
1231         nbp = xfs_btree_get_bufs(args.mp, args.tp, args.agno, args.agbno, 0);
 
1232         new = XFS_BUF_TO_INOBT_BLOCK(nbp);
 
1234          * Set the root data in the a.g. inode structure.
 
1236         agi->agi_root = cpu_to_be32(args.agbno);
 
1237         be32_add(&agi->agi_level, 1);
 
1238         xfs_ialloc_log_agi(args.tp, cur->bc_private.i.agbp,
 
1239                 XFS_AGI_ROOT | XFS_AGI_LEVEL);
 
1241          * At the previous root level there are now two blocks: the old
 
1242          * root, and the new block generated when it was split.
 
1243          * We don't know which one the cursor is pointing at, so we
 
1244          * set up variables "left" and "right" for each case.
 
1246         bp = cur->bc_bufs[cur->bc_nlevels - 1];
 
1247         block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
1249         if ((error = xfs_btree_check_sblock(cur, block, cur->bc_nlevels - 1, bp)))
 
1252         if (be32_to_cpu(block->bb_rightsib) != NULLAGBLOCK) {
 
1254                  * Our block is left, pick up the right block.
 
1257                 lbno = XFS_DADDR_TO_AGBNO(args.mp, XFS_BUF_ADDR(lbp));
 
1259                 rbno = be32_to_cpu(left->bb_rightsib);
 
1260                 if ((error = xfs_btree_read_bufs(args.mp, args.tp, args.agno,
 
1261                                 rbno, 0, &rbp, XFS_INO_BTREE_REF)))
 
1264                 right = XFS_BUF_TO_INOBT_BLOCK(rbp);
 
1265                 if ((error = xfs_btree_check_sblock(cur, right,
 
1266                                 cur->bc_nlevels - 1, rbp)))
 
1271                  * Our block is right, pick up the left block.
 
1274                 rbno = XFS_DADDR_TO_AGBNO(args.mp, XFS_BUF_ADDR(rbp));
 
1276                 lbno = be32_to_cpu(right->bb_leftsib);
 
1277                 if ((error = xfs_btree_read_bufs(args.mp, args.tp, args.agno,
 
1278                                 lbno, 0, &lbp, XFS_INO_BTREE_REF)))
 
1281                 left = XFS_BUF_TO_INOBT_BLOCK(lbp);
 
1282                 if ((error = xfs_btree_check_sblock(cur, left,
 
1283                                 cur->bc_nlevels - 1, lbp)))
 
1288          * Fill in the new block's btree header and log it.
 
1290         new->bb_magic = cpu_to_be32(xfs_magics[cur->bc_btnum]);
 
1291         new->bb_level = cpu_to_be16(cur->bc_nlevels);
 
1292         new->bb_numrecs = cpu_to_be16(2);
 
1293         new->bb_leftsib = cpu_to_be32(NULLAGBLOCK);
 
1294         new->bb_rightsib = cpu_to_be32(NULLAGBLOCK);
 
1295         xfs_inobt_log_block(args.tp, nbp, XFS_BB_ALL_BITS);
 
1296         ASSERT(lbno != NULLAGBLOCK && rbno != NULLAGBLOCK);
 
1298          * Fill in the key data in the new root.
 
1300         kp = XFS_INOBT_KEY_ADDR(new, 1, cur);
 
1301         if (be16_to_cpu(left->bb_level) > 0) {
 
1302                 kp[0] = *XFS_INOBT_KEY_ADDR(left, 1, cur); /* INT_: struct copy */
 
1303                 kp[1] = *XFS_INOBT_KEY_ADDR(right, 1, cur); /* INT_: struct copy */
 
1305                 rp = XFS_INOBT_REC_ADDR(left, 1, cur);
 
1306                 INT_COPY(kp[0].ir_startino, rp->ir_startino, ARCH_CONVERT);
 
1307                 rp = XFS_INOBT_REC_ADDR(right, 1, cur);
 
1308                 INT_COPY(kp[1].ir_startino, rp->ir_startino, ARCH_CONVERT);
 
1310         xfs_inobt_log_keys(cur, nbp, 1, 2);
 
1312          * Fill in the pointer data in the new root.
 
1314         pp = XFS_INOBT_PTR_ADDR(new, 1, cur);
 
1315         pp[0] = cpu_to_be32(lbno);
 
1316         pp[1] = cpu_to_be32(rbno);
 
1317         xfs_inobt_log_ptrs(cur, nbp, 1, 2);
 
1319          * Fix up the cursor.
 
1321         xfs_btree_setbuf(cur, cur->bc_nlevels, nbp);
 
1322         cur->bc_ptrs[cur->bc_nlevels] = nptr;
 
1329  * Move 1 record right from cur/level if possible.
 
1330  * Update cur to reflect the new path.
 
1332 STATIC int                              /* error */
 
1334         xfs_btree_cur_t         *cur,   /* btree cursor */
 
1335         int                     level,  /* level to shift record on */
 
1336         int                     *stat)  /* success/failure */
 
1338         int                     error;  /* error return value */
 
1339         int                     i;      /* loop index */
 
1340         xfs_inobt_key_t         key;    /* key value for leaf level upward */
 
1341         xfs_buf_t               *lbp;   /* buffer for left (current) block */
 
1342         xfs_inobt_block_t       *left;  /* left (current) btree block */
 
1343         xfs_inobt_key_t         *lkp;   /* key pointer for left block */
 
1344         xfs_inobt_ptr_t         *lpp;   /* address pointer for left block */
 
1345         xfs_inobt_rec_t         *lrp;   /* record pointer for left block */
 
1346         xfs_buf_t               *rbp;   /* buffer for right neighbor block */
 
1347         xfs_inobt_block_t       *right; /* right neighbor btree block */
 
1348         xfs_inobt_key_t         *rkp;   /* key pointer for right block */
 
1349         xfs_inobt_ptr_t         *rpp;   /* address pointer for right block */
 
1350         xfs_inobt_rec_t         *rrp=NULL;      /* record pointer for right block */
 
1351         xfs_btree_cur_t         *tcur;  /* temporary cursor */
 
1354          * Set up variables for this block as "left".
 
1356         lbp = cur->bc_bufs[level];
 
1357         left = XFS_BUF_TO_INOBT_BLOCK(lbp);
 
1359         if ((error = xfs_btree_check_sblock(cur, left, level, lbp)))
 
1363          * If we've got no right sibling then we can't shift an entry right.
 
1365         if (be32_to_cpu(left->bb_rightsib) == NULLAGBLOCK) {
 
1370          * If the cursor entry is the one that would be moved, don't
 
1371          * do it... it's too complicated.
 
1373         if (cur->bc_ptrs[level] >= be16_to_cpu(left->bb_numrecs)) {
 
1378          * Set up the right neighbor as "right".
 
1380         if ((error = xfs_btree_read_bufs(cur->bc_mp, cur->bc_tp,
 
1381                         cur->bc_private.i.agno, be32_to_cpu(left->bb_rightsib),
 
1382                         0, &rbp, XFS_INO_BTREE_REF)))
 
1384         right = XFS_BUF_TO_INOBT_BLOCK(rbp);
 
1385         if ((error = xfs_btree_check_sblock(cur, right, level, rbp)))
 
1388          * If it's full, it can't take another entry.
 
1390         if (be16_to_cpu(right->bb_numrecs) == XFS_INOBT_BLOCK_MAXRECS(level, cur)) {
 
1395          * Make a hole at the start of the right neighbor block, then
 
1396          * copy the last left block entry to the hole.
 
1399                 lkp = XFS_INOBT_KEY_ADDR(left, be16_to_cpu(left->bb_numrecs), cur);
 
1400                 lpp = XFS_INOBT_PTR_ADDR(left, be16_to_cpu(left->bb_numrecs), cur);
 
1401                 rkp = XFS_INOBT_KEY_ADDR(right, 1, cur);
 
1402                 rpp = XFS_INOBT_PTR_ADDR(right, 1, cur);
 
1404                 for (i = be16_to_cpu(right->bb_numrecs) - 1; i >= 0; i--) {
 
1405                         if ((error = xfs_btree_check_sptr(cur, be32_to_cpu(rpp[i]), level)))
 
1409                 memmove(rkp + 1, rkp, be16_to_cpu(right->bb_numrecs) * sizeof(*rkp));
 
1410                 memmove(rpp + 1, rpp, be16_to_cpu(right->bb_numrecs) * sizeof(*rpp));
 
1412                 if ((error = xfs_btree_check_sptr(cur, be32_to_cpu(*lpp), level)))
 
1415                 *rkp = *lkp; /* INT_: no change copy */
 
1416                 *rpp = *lpp; /* INT_: no change copy */
 
1417                 xfs_inobt_log_keys(cur, rbp, 1, be16_to_cpu(right->bb_numrecs) + 1);
 
1418                 xfs_inobt_log_ptrs(cur, rbp, 1, be16_to_cpu(right->bb_numrecs) + 1);
 
1420                 lrp = XFS_INOBT_REC_ADDR(left, be16_to_cpu(left->bb_numrecs), cur);
 
1421                 rrp = XFS_INOBT_REC_ADDR(right, 1, cur);
 
1422                 memmove(rrp + 1, rrp, be16_to_cpu(right->bb_numrecs) * sizeof(*rrp));
 
1424                 xfs_inobt_log_recs(cur, rbp, 1, be16_to_cpu(right->bb_numrecs) + 1);
 
1425                 key.ir_startino = rrp->ir_startino; /* INT_: direct copy */
 
1429          * Decrement and log left's numrecs, bump and log right's numrecs.
 
1431         be16_add(&left->bb_numrecs, -1);
 
1432         xfs_inobt_log_block(cur->bc_tp, lbp, XFS_BB_NUMRECS);
 
1433         be16_add(&right->bb_numrecs, 1);
 
1436                 xfs_btree_check_key(cur->bc_btnum, rkp, rkp + 1);
 
1438                 xfs_btree_check_rec(cur->bc_btnum, rrp, rrp + 1);
 
1440         xfs_inobt_log_block(cur->bc_tp, rbp, XFS_BB_NUMRECS);
 
1442          * Using a temporary cursor, update the parent key values of the
 
1443          * block on the right.
 
1445         if ((error = xfs_btree_dup_cursor(cur, &tcur)))
 
1447         xfs_btree_lastrec(tcur, level);
 
1448         if ((error = xfs_inobt_increment(tcur, level, &i)) ||
 
1449             (error = xfs_inobt_updkey(tcur, rkp, level + 1))) {
 
1450                 xfs_btree_del_cursor(tcur, XFS_BTREE_ERROR);
 
1453         xfs_btree_del_cursor(tcur, XFS_BTREE_NOERROR);
 
1459  * Split cur/level block in half.
 
1460  * Return new block number and its first record (to be inserted into parent).
 
1462 STATIC int                              /* error */
 
1464         xfs_btree_cur_t         *cur,   /* btree cursor */
 
1465         int                     level,  /* level to split */
 
1466         xfs_agblock_t           *bnop,  /* output: block number allocated */
 
1467         xfs_inobt_key_t         *keyp,  /* output: first key of new block */
 
1468         xfs_btree_cur_t         **curp, /* output: new cursor */
 
1469         int                     *stat)  /* success/failure */
 
1471         xfs_alloc_arg_t         args;   /* allocation argument structure */
 
1472         int                     error;  /* error return value */
 
1473         int                     i;      /* loop index/record number */
 
1474         xfs_agblock_t           lbno;   /* left (current) block number */
 
1475         xfs_buf_t               *lbp;   /* buffer for left block */
 
1476         xfs_inobt_block_t       *left;  /* left (current) btree block */
 
1477         xfs_inobt_key_t         *lkp;   /* left btree key pointer */
 
1478         xfs_inobt_ptr_t         *lpp;   /* left btree address pointer */
 
1479         xfs_inobt_rec_t         *lrp;   /* left btree record pointer */
 
1480         xfs_buf_t               *rbp;   /* buffer for right block */
 
1481         xfs_inobt_block_t       *right; /* right (new) btree block */
 
1482         xfs_inobt_key_t         *rkp;   /* right btree key pointer */
 
1483         xfs_inobt_ptr_t         *rpp;   /* right btree address pointer */
 
1484         xfs_inobt_rec_t         *rrp;   /* right btree record pointer */
 
1487          * Set up left block (current one).
 
1489         lbp = cur->bc_bufs[level];
 
1490         args.tp = cur->bc_tp;
 
1491         args.mp = cur->bc_mp;
 
1492         lbno = XFS_DADDR_TO_AGBNO(args.mp, XFS_BUF_ADDR(lbp));
 
1494          * Allocate the new block.
 
1495          * If we can't do it, we're toast.  Give up.
 
1497         args.fsbno = XFS_AGB_TO_FSB(args.mp, cur->bc_private.i.agno, lbno);
 
1498         args.mod = args.minleft = args.alignment = args.total = args.wasdel =
 
1499                 args.isfl = args.userdata = args.minalignslop = 0;
 
1500         args.minlen = args.maxlen = args.prod = 1;
 
1501         args.type = XFS_ALLOCTYPE_NEAR_BNO;
 
1502         if ((error = xfs_alloc_vextent(&args)))
 
1504         if (args.fsbno == NULLFSBLOCK) {
 
1508         ASSERT(args.len == 1);
 
1509         rbp = xfs_btree_get_bufs(args.mp, args.tp, args.agno, args.agbno, 0);
 
1511          * Set up the new block as "right".
 
1513         right = XFS_BUF_TO_INOBT_BLOCK(rbp);
 
1515          * "Left" is the current (according to the cursor) block.
 
1517         left = XFS_BUF_TO_INOBT_BLOCK(lbp);
 
1519         if ((error = xfs_btree_check_sblock(cur, left, level, lbp)))
 
1523          * Fill in the btree header for the new block.
 
1525         right->bb_magic = cpu_to_be32(xfs_magics[cur->bc_btnum]);
 
1526         right->bb_level = left->bb_level;
 
1527         right->bb_numrecs = cpu_to_be16(be16_to_cpu(left->bb_numrecs) / 2);
 
1529          * Make sure that if there's an odd number of entries now, that
 
1530          * each new block will have the same number of entries.
 
1532         if ((be16_to_cpu(left->bb_numrecs) & 1) &&
 
1533             cur->bc_ptrs[level] <= be16_to_cpu(right->bb_numrecs) + 1)
 
1534                 be16_add(&right->bb_numrecs, 1);
 
1535         i = be16_to_cpu(left->bb_numrecs) - be16_to_cpu(right->bb_numrecs) + 1;
 
1537          * For non-leaf blocks, copy keys and addresses over to the new block.
 
1540                 lkp = XFS_INOBT_KEY_ADDR(left, i, cur);
 
1541                 lpp = XFS_INOBT_PTR_ADDR(left, i, cur);
 
1542                 rkp = XFS_INOBT_KEY_ADDR(right, 1, cur);
 
1543                 rpp = XFS_INOBT_PTR_ADDR(right, 1, cur);
 
1545                 for (i = 0; i < be16_to_cpu(right->bb_numrecs); i++) {
 
1546                         if ((error = xfs_btree_check_sptr(cur, be32_to_cpu(lpp[i]), level)))
 
1550                 memcpy(rkp, lkp, be16_to_cpu(right->bb_numrecs) * sizeof(*rkp));
 
1551                 memcpy(rpp, lpp, be16_to_cpu(right->bb_numrecs) * sizeof(*rpp));
 
1552                 xfs_inobt_log_keys(cur, rbp, 1, be16_to_cpu(right->bb_numrecs));
 
1553                 xfs_inobt_log_ptrs(cur, rbp, 1, be16_to_cpu(right->bb_numrecs));
 
1557          * For leaf blocks, copy records over to the new block.
 
1560                 lrp = XFS_INOBT_REC_ADDR(left, i, cur);
 
1561                 rrp = XFS_INOBT_REC_ADDR(right, 1, cur);
 
1562                 memcpy(rrp, lrp, be16_to_cpu(right->bb_numrecs) * sizeof(*rrp));
 
1563                 xfs_inobt_log_recs(cur, rbp, 1, be16_to_cpu(right->bb_numrecs));
 
1564                 keyp->ir_startino = rrp->ir_startino; /* INT_: direct copy */
 
1567          * Find the left block number by looking in the buffer.
 
1568          * Adjust numrecs, sibling pointers.
 
1570         be16_add(&left->bb_numrecs, -(be16_to_cpu(right->bb_numrecs)));
 
1571         right->bb_rightsib = left->bb_rightsib;
 
1572         left->bb_rightsib = cpu_to_be32(args.agbno);
 
1573         right->bb_leftsib = cpu_to_be32(lbno);
 
1574         xfs_inobt_log_block(args.tp, rbp, XFS_BB_ALL_BITS);
 
1575         xfs_inobt_log_block(args.tp, lbp, XFS_BB_NUMRECS | XFS_BB_RIGHTSIB);
 
1577          * If there's a block to the new block's right, make that block
 
1578          * point back to right instead of to left.
 
1580         if (be32_to_cpu(right->bb_rightsib) != NULLAGBLOCK) {
 
1581                 xfs_inobt_block_t       *rrblock;       /* rr btree block */
 
1582                 xfs_buf_t               *rrbp;          /* buffer for rrblock */
 
1584                 if ((error = xfs_btree_read_bufs(args.mp, args.tp, args.agno,
 
1585                                 be32_to_cpu(right->bb_rightsib), 0, &rrbp,
 
1586                                 XFS_INO_BTREE_REF)))
 
1588                 rrblock = XFS_BUF_TO_INOBT_BLOCK(rrbp);
 
1589                 if ((error = xfs_btree_check_sblock(cur, rrblock, level, rrbp)))
 
1591                 rrblock->bb_leftsib = cpu_to_be32(args.agbno);
 
1592                 xfs_inobt_log_block(args.tp, rrbp, XFS_BB_LEFTSIB);
 
1595          * If the cursor is really in the right block, move it there.
 
1596          * If it's just pointing past the last entry in left, then we'll
 
1597          * insert there, so don't change anything in that case.
 
1599         if (cur->bc_ptrs[level] > be16_to_cpu(left->bb_numrecs) + 1) {
 
1600                 xfs_btree_setbuf(cur, level, rbp);
 
1601                 cur->bc_ptrs[level] -= be16_to_cpu(left->bb_numrecs);
 
1604          * If there are more levels, we'll need another cursor which refers
 
1605          * the right block, no matter where this cursor was.
 
1607         if (level + 1 < cur->bc_nlevels) {
 
1608                 if ((error = xfs_btree_dup_cursor(cur, curp)))
 
1610                 (*curp)->bc_ptrs[level + 1]++;
 
1618  * Update keys at all levels from here to the root along the cursor's path.
 
1620 STATIC int                              /* error */
 
1622         xfs_btree_cur_t         *cur,   /* btree cursor */
 
1623         xfs_inobt_key_t         *keyp,  /* new key value to update to */
 
1624         int                     level)  /* starting level for update */
 
1626         int                     ptr;    /* index of key in block */
 
1629          * Go up the tree from this level toward the root.
 
1630          * At each level, update the key value to the value input.
 
1631          * Stop when we reach a level where the cursor isn't pointing
 
1632          * at the first entry in the block.
 
1634         for (ptr = 1; ptr == 1 && level < cur->bc_nlevels; level++) {
 
1635                 xfs_buf_t               *bp;    /* buffer for block */
 
1636                 xfs_inobt_block_t       *block; /* btree block */
 
1638                 int                     error;  /* error return value */
 
1640                 xfs_inobt_key_t         *kp;    /* ptr to btree block keys */
 
1642                 bp = cur->bc_bufs[level];
 
1643                 block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
1645                 if ((error = xfs_btree_check_sblock(cur, block, level, bp)))
 
1648                 ptr = cur->bc_ptrs[level];
 
1649                 kp = XFS_INOBT_KEY_ADDR(block, ptr, cur);
 
1651                 xfs_inobt_log_keys(cur, bp, ptr, ptr);
 
1657  * Externally visible routines.
 
1661  * Decrement cursor by one record at the level.
 
1662  * For nonzero levels the leaf-ward information is untouched.
 
1665 xfs_inobt_decrement(
 
1666         xfs_btree_cur_t         *cur,   /* btree cursor */
 
1667         int                     level,  /* level in btree, 0 is leaf */
 
1668         int                     *stat)  /* success/failure */
 
1670         xfs_inobt_block_t       *block; /* btree block */
 
1672         int                     lev;    /* btree level */
 
1674         ASSERT(level < cur->bc_nlevels);
 
1676          * Read-ahead to the left at this level.
 
1678         xfs_btree_readahead(cur, level, XFS_BTCUR_LEFTRA);
 
1680          * Decrement the ptr at this level.  If we're still in the block
 
1683         if (--cur->bc_ptrs[level] > 0) {
 
1688          * Get a pointer to the btree block.
 
1690         block = XFS_BUF_TO_INOBT_BLOCK(cur->bc_bufs[level]);
 
1692         if ((error = xfs_btree_check_sblock(cur, block, level,
 
1693                         cur->bc_bufs[level])))
 
1697          * If we just went off the left edge of the tree, return failure.
 
1699         if (be32_to_cpu(block->bb_leftsib) == NULLAGBLOCK) {
 
1704          * March up the tree decrementing pointers.
 
1705          * Stop when we don't go off the left edge of a block.
 
1707         for (lev = level + 1; lev < cur->bc_nlevels; lev++) {
 
1708                 if (--cur->bc_ptrs[lev] > 0)
 
1711                  * Read-ahead the left block, we're going to read it
 
1714                 xfs_btree_readahead(cur, lev, XFS_BTCUR_LEFTRA);
 
1717          * If we went off the root then we are seriously confused.
 
1719         ASSERT(lev < cur->bc_nlevels);
 
1721          * Now walk back down the tree, fixing up the cursor's buffer
 
1722          * pointers and key numbers.
 
1724         for (block = XFS_BUF_TO_INOBT_BLOCK(cur->bc_bufs[lev]); lev > level; ) {
 
1725                 xfs_agblock_t   agbno;  /* block number of btree block */
 
1726                 xfs_buf_t       *bp;    /* buffer containing btree block */
 
1728                 agbno = be32_to_cpu(*XFS_INOBT_PTR_ADDR(block, cur->bc_ptrs[lev], cur));
 
1729                 if ((error = xfs_btree_read_bufs(cur->bc_mp, cur->bc_tp,
 
1730                                 cur->bc_private.i.agno, agbno, 0, &bp,
 
1731                                 XFS_INO_BTREE_REF)))
 
1734                 xfs_btree_setbuf(cur, lev, bp);
 
1735                 block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
1736                 if ((error = xfs_btree_check_sblock(cur, block, lev, bp)))
 
1738                 cur->bc_ptrs[lev] = be16_to_cpu(block->bb_numrecs);
 
1745  * Delete the record pointed to by cur.
 
1746  * The cursor refers to the place where the record was (could be inserted)
 
1747  * when the operation returns.
 
1751         xfs_btree_cur_t *cur,           /* btree cursor */
 
1752         int             *stat)          /* success/failure */
 
1755         int             i;              /* result code */
 
1756         int             level;          /* btree level */
 
1759          * Go up the tree, starting at leaf level.
 
1760          * If 2 is returned then a join was done; go to the next level.
 
1761          * Otherwise we are done.
 
1763         for (level = 0, i = 2; i == 2; level++) {
 
1764                 if ((error = xfs_inobt_delrec(cur, level, &i)))
 
1768                 for (level = 1; level < cur->bc_nlevels; level++) {
 
1769                         if (cur->bc_ptrs[level] == 0) {
 
1770                                 if ((error = xfs_inobt_decrement(cur, level, &i)))
 
1782  * Get the data from the pointed-to record.
 
1786         xfs_btree_cur_t         *cur,   /* btree cursor */
 
1787         xfs_agino_t             *ino,   /* output: starting inode of chunk */
 
1788         __int32_t               *fcnt,  /* output: number of free inodes */
 
1789         xfs_inofree_t           *free,  /* output: free inode mask */
 
1790         int                     *stat)  /* output: success/failure */
 
1792         xfs_inobt_block_t       *block; /* btree block */
 
1793         xfs_buf_t               *bp;    /* buffer containing btree block */
 
1795         int                     error;  /* error return value */
 
1797         int                     ptr;    /* record number */
 
1798         xfs_inobt_rec_t         *rec;   /* record data */
 
1800         bp = cur->bc_bufs[0];
 
1801         ptr = cur->bc_ptrs[0];
 
1802         block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
1804         if ((error = xfs_btree_check_sblock(cur, block, 0, bp)))
 
1808          * Off the right end or left end, return failure.
 
1810         if (ptr > be16_to_cpu(block->bb_numrecs) || ptr <= 0) {
 
1815          * Point to the record and extract its data.
 
1817         rec = XFS_INOBT_REC_ADDR(block, ptr, cur);
 
1818         *ino = INT_GET(rec->ir_startino, ARCH_CONVERT);
 
1819         *fcnt = INT_GET(rec->ir_freecount, ARCH_CONVERT);
 
1820         *free = INT_GET(rec->ir_free, ARCH_CONVERT);
 
1826  * Increment cursor by one record at the level.
 
1827  * For nonzero levels the leaf-ward information is untouched.
 
1830 xfs_inobt_increment(
 
1831         xfs_btree_cur_t         *cur,   /* btree cursor */
 
1832         int                     level,  /* level in btree, 0 is leaf */
 
1833         int                     *stat)  /* success/failure */
 
1835         xfs_inobt_block_t       *block; /* btree block */
 
1836         xfs_buf_t               *bp;    /* buffer containing btree block */
 
1837         int                     error;  /* error return value */
 
1838         int                     lev;    /* btree level */
 
1840         ASSERT(level < cur->bc_nlevels);
 
1842          * Read-ahead to the right at this level.
 
1844         xfs_btree_readahead(cur, level, XFS_BTCUR_RIGHTRA);
 
1846          * Get a pointer to the btree block.
 
1848         bp = cur->bc_bufs[level];
 
1849         block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
1851         if ((error = xfs_btree_check_sblock(cur, block, level, bp)))
 
1855          * Increment the ptr at this level.  If we're still in the block
 
1858         if (++cur->bc_ptrs[level] <= be16_to_cpu(block->bb_numrecs)) {
 
1863          * If we just went off the right edge of the tree, return failure.
 
1865         if (be32_to_cpu(block->bb_rightsib) == NULLAGBLOCK) {
 
1870          * March up the tree incrementing pointers.
 
1871          * Stop when we don't go off the right edge of a block.
 
1873         for (lev = level + 1; lev < cur->bc_nlevels; lev++) {
 
1874                 bp = cur->bc_bufs[lev];
 
1875                 block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
1877                 if ((error = xfs_btree_check_sblock(cur, block, lev, bp)))
 
1880                 if (++cur->bc_ptrs[lev] <= be16_to_cpu(block->bb_numrecs))
 
1883                  * Read-ahead the right block, we're going to read it
 
1886                 xfs_btree_readahead(cur, lev, XFS_BTCUR_RIGHTRA);
 
1889          * If we went off the root then we are seriously confused.
 
1891         ASSERT(lev < cur->bc_nlevels);
 
1893          * Now walk back down the tree, fixing up the cursor's buffer
 
1894          * pointers and key numbers.
 
1896         for (bp = cur->bc_bufs[lev], block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
1898                 xfs_agblock_t   agbno;  /* block number of btree block */
 
1900                 agbno = be32_to_cpu(*XFS_INOBT_PTR_ADDR(block, cur->bc_ptrs[lev], cur));
 
1901                 if ((error = xfs_btree_read_bufs(cur->bc_mp, cur->bc_tp,
 
1902                                 cur->bc_private.i.agno, agbno, 0, &bp,
 
1903                                 XFS_INO_BTREE_REF)))
 
1906                 xfs_btree_setbuf(cur, lev, bp);
 
1907                 block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
1908                 if ((error = xfs_btree_check_sblock(cur, block, lev, bp)))
 
1910                 cur->bc_ptrs[lev] = 1;
 
1917  * Insert the current record at the point referenced by cur.
 
1918  * The cursor may be inconsistent on return if splits have been done.
 
1922         xfs_btree_cur_t *cur,           /* btree cursor */
 
1923         int             *stat)          /* success/failure */
 
1925         int             error;          /* error return value */
 
1926         int             i;              /* result value, 0 for failure */
 
1927         int             level;          /* current level number in btree */
 
1928         xfs_agblock_t   nbno;           /* new block number (split result) */
 
1929         xfs_btree_cur_t *ncur;          /* new cursor (split result) */
 
1930         xfs_inobt_rec_t nrec;           /* record being inserted this level */
 
1931         xfs_btree_cur_t *pcur;          /* previous level's cursor */
 
1935         INT_SET(nrec.ir_startino, ARCH_CONVERT, cur->bc_rec.i.ir_startino);
 
1936         INT_SET(nrec.ir_freecount, ARCH_CONVERT, cur->bc_rec.i.ir_freecount);
 
1937         INT_SET(nrec.ir_free, ARCH_CONVERT, cur->bc_rec.i.ir_free);
 
1938         ncur = (xfs_btree_cur_t *)0;
 
1941          * Loop going up the tree, starting at the leaf level.
 
1942          * Stop when we don't get a split block, that must mean that
 
1943          * the insert is finished with this level.
 
1947                  * Insert nrec/nbno into this level of the tree.
 
1948                  * Note if we fail, nbno will be null.
 
1950                 if ((error = xfs_inobt_insrec(pcur, level++, &nbno, &nrec, &ncur,
 
1953                                 xfs_btree_del_cursor(pcur, XFS_BTREE_ERROR);
 
1957                  * See if the cursor we just used is trash.
 
1958                  * Can't trash the caller's cursor, but otherwise we should
 
1959                  * if ncur is a new cursor or we're about to be done.
 
1961                 if (pcur != cur && (ncur || nbno == NULLAGBLOCK)) {
 
1962                         cur->bc_nlevels = pcur->bc_nlevels;
 
1963                         xfs_btree_del_cursor(pcur, XFS_BTREE_NOERROR);
 
1966                  * If we got a new cursor, switch to it.
 
1970                         ncur = (xfs_btree_cur_t *)0;
 
1972         } while (nbno != NULLAGBLOCK);
 
1978  * Lookup the record equal to ino in the btree given by cur.
 
1981 xfs_inobt_lookup_eq(
 
1982         xfs_btree_cur_t *cur,           /* btree cursor */
 
1983         xfs_agino_t     ino,            /* starting inode of chunk */
 
1984         __int32_t       fcnt,           /* free inode count */
 
1985         xfs_inofree_t   free,           /* free inode mask */
 
1986         int             *stat)          /* success/failure */
 
1988         cur->bc_rec.i.ir_startino = ino;
 
1989         cur->bc_rec.i.ir_freecount = fcnt;
 
1990         cur->bc_rec.i.ir_free = free;
 
1991         return xfs_inobt_lookup(cur, XFS_LOOKUP_EQ, stat);
 
1995  * Lookup the first record greater than or equal to ino
 
1996  * in the btree given by cur.
 
1999 xfs_inobt_lookup_ge(
 
2000         xfs_btree_cur_t *cur,           /* btree cursor */
 
2001         xfs_agino_t     ino,            /* starting inode of chunk */
 
2002         __int32_t       fcnt,           /* free inode count */
 
2003         xfs_inofree_t   free,           /* free inode mask */
 
2004         int             *stat)          /* success/failure */
 
2006         cur->bc_rec.i.ir_startino = ino;
 
2007         cur->bc_rec.i.ir_freecount = fcnt;
 
2008         cur->bc_rec.i.ir_free = free;
 
2009         return xfs_inobt_lookup(cur, XFS_LOOKUP_GE, stat);
 
2013  * Lookup the first record less than or equal to ino
 
2014  * in the btree given by cur.
 
2017 xfs_inobt_lookup_le(
 
2018         xfs_btree_cur_t *cur,           /* btree cursor */
 
2019         xfs_agino_t     ino,            /* starting inode of chunk */
 
2020         __int32_t       fcnt,           /* free inode count */
 
2021         xfs_inofree_t   free,           /* free inode mask */
 
2022         int             *stat)          /* success/failure */
 
2024         cur->bc_rec.i.ir_startino = ino;
 
2025         cur->bc_rec.i.ir_freecount = fcnt;
 
2026         cur->bc_rec.i.ir_free = free;
 
2027         return xfs_inobt_lookup(cur, XFS_LOOKUP_LE, stat);
 
2031  * Update the record referred to by cur, to the value given
 
2032  * by [ino, fcnt, free].
 
2033  * This either works (return 0) or gets an EFSCORRUPTED error.
 
2037         xfs_btree_cur_t         *cur,   /* btree cursor */
 
2038         xfs_agino_t             ino,    /* starting inode of chunk */
 
2039         __int32_t               fcnt,   /* free inode count */
 
2040         xfs_inofree_t           free)   /* free inode mask */
 
2042         xfs_inobt_block_t       *block; /* btree block to update */
 
2043         xfs_buf_t               *bp;    /* buffer containing btree block */
 
2044         int                     error;  /* error return value */
 
2045         int                     ptr;    /* current record number (updating) */
 
2046         xfs_inobt_rec_t         *rp;    /* pointer to updated record */
 
2049          * Pick up the current block.
 
2051         bp = cur->bc_bufs[0];
 
2052         block = XFS_BUF_TO_INOBT_BLOCK(bp);
 
2054         if ((error = xfs_btree_check_sblock(cur, block, 0, bp)))
 
2058          * Get the address of the rec to be updated.
 
2060         ptr = cur->bc_ptrs[0];
 
2061         rp = XFS_INOBT_REC_ADDR(block, ptr, cur);
 
2063          * Fill in the new contents and log them.
 
2065         INT_SET(rp->ir_startino, ARCH_CONVERT, ino);
 
2066         INT_SET(rp->ir_freecount, ARCH_CONVERT, fcnt);
 
2067         INT_SET(rp->ir_free, ARCH_CONVERT, free);
 
2068         xfs_inobt_log_recs(cur, bp, ptr, ptr);
 
2070          * Updating first record in leaf. Pass new key value up to our parent.
 
2073                 xfs_inobt_key_t key;    /* key containing [ino] */
 
2075                 INT_SET(key.ir_startino, ARCH_CONVERT, ino);
 
2076                 if ((error = xfs_inobt_updkey(cur, &key, 1)))