2018-09-05 01:46:30 +03:00
/* SPDX-License-Identifier: GPL-2.0+ */
2009-04-07 06:01:24 +04:00
/*
* btree . h - NILFS B - tree .
*
* Copyright ( C ) 2005 - 2008 Nippon Telegraph and Telephone Corporation .
*
2016-05-24 02:23:09 +03:00
* Written by Koji Sato .
2009-04-07 06:01:24 +04:00
*/
# ifndef _NILFS_BTREE_H
# define _NILFS_BTREE_H
# include <linux/types.h>
# include <linux/buffer_head.h>
# include <linux/list.h>
2016-08-03 00:05:30 +03:00
# include <linux/nilfs2_ondisk.h> /* nilfs_btree_node */
2009-04-07 06:01:24 +04:00
# include "btnode.h"
# include "bmap.h"
2010-04-05 20:54:11 +04:00
/**
* struct nilfs_btree_path - A path on which B - tree operations are executed
* @ bp_bh : buffer head of node block
* @ bp_sib_bh : buffer head of sibling node block
* @ bp_index : index of child node
* @ bp_oldreq : ptr end request for old ptr
* @ bp_newreq : ptr alloc request for new ptr
* @ bp_op : rebalance operation
*/
struct nilfs_btree_path {
struct buffer_head * bp_bh ;
struct buffer_head * bp_sib_bh ;
int bp_index ;
union nilfs_bmap_ptr_req bp_oldreq ;
union nilfs_bmap_ptr_req bp_newreq ;
struct nilfs_btnode_chkey_ctxt bp_ctxt ;
2010-07-10 14:09:49 +04:00
void ( * bp_op ) ( struct nilfs_bmap * , struct nilfs_btree_path * ,
2010-04-05 20:54:11 +04:00
int , __u64 * , __u64 * ) ;
} ;
2009-04-07 06:01:24 +04:00
# define NILFS_BTREE_ROOT_SIZE NILFS_BMAP_SIZE
# define NILFS_BTREE_ROOT_NCHILDREN_MAX \
( ( NILFS_BTREE_ROOT_SIZE - sizeof ( struct nilfs_btree_node ) ) / \
( sizeof ( __le64 /* dkey */ ) + sizeof ( __le64 /* dptr */ ) ) )
# define NILFS_BTREE_ROOT_NCHILDREN_MIN 0
# define NILFS_BTREE_NODE_EXTRA_PAD_SIZE (sizeof(__le64))
# define NILFS_BTREE_NODE_NCHILDREN_MAX(nodesize) \
( ( ( nodesize ) - sizeof ( struct nilfs_btree_node ) - \
NILFS_BTREE_NODE_EXTRA_PAD_SIZE ) / \
( sizeof ( __le64 /* dkey */ ) + sizeof ( __le64 /* dptr */ ) ) )
# define NILFS_BTREE_NODE_NCHILDREN_MIN(nodesize) \
( ( NILFS_BTREE_NODE_NCHILDREN_MAX ( nodesize ) - 1 ) / 2 + 1 )
# define NILFS_BTREE_KEY_MIN ((__u64)0)
# define NILFS_BTREE_KEY_MAX (~(__u64)0)
2010-04-05 20:54:11 +04:00
extern struct kmem_cache * nilfs_btree_path_cache ;
2009-04-07 06:01:24 +04:00
2009-05-23 19:09:44 +04:00
int nilfs_btree_init ( struct nilfs_bmap * ) ;
2009-04-07 06:01:24 +04:00
int nilfs_btree_convert_and_insert ( struct nilfs_bmap * , __u64 , __u64 ,
2009-05-23 19:09:44 +04:00
const __u64 * , const __u64 * , int ) ;
2009-04-07 06:01:24 +04:00
void nilfs_btree_init_gc ( struct nilfs_bmap * ) ;
2010-07-16 18:52:40 +04:00
int nilfs_btree_broken_node_block ( struct buffer_head * bh ) ;
2009-04-07 06:01:24 +04:00
# endif /* _NILFS_BTREE_H */