2005-04-16 15:20:36 -07:00
/*
2005-11-02 14:58:39 +11:00
* Copyright ( c ) 2000 , 2002 , 2005 Silicon Graphics , Inc .
2013-04-24 18:58:02 +10:00
* Copyright ( c ) 2013 Red Hat , Inc .
2005-11-02 14:58:39 +11:00
* All Rights Reserved .
2005-04-16 15:20:36 -07:00
*
2005-11-02 14:58:39 +11:00
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License as
2005-04-16 15:20:36 -07:00
* published by the Free Software Foundation .
*
2005-11-02 14:58:39 +11:00
* This program is distributed in the hope that it would be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
2005-04-16 15:20:36 -07:00
*
2005-11-02 14:58:39 +11:00
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write the Free Software Foundation ,
* Inc . , 51 Franklin St , Fifth Floor , Boston , MA 02110 - 1301 USA
2005-04-16 15:20:36 -07:00
*/
# ifndef __XFS_DA_BTREE_H__
# define __XFS_DA_BTREE_H__
struct xfs_bmap_free ;
struct xfs_inode ;
struct xfs_trans ;
struct zone ;
2013-10-29 22:11:46 +11:00
struct xfs_dir_ops ;
2005-04-16 15:20:36 -07:00
/*========================================================================
* Btree searching and modification structure definitions .
* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */
2008-05-21 16:41:01 +10:00
/*
* Search comparison results
*/
enum xfs_dacmp {
XFS_CMP_DIFFERENT , /* names are completely different */
XFS_CMP_EXACT , /* names are exactly the same */
XFS_CMP_CASE /* names are same but differ in case */
} ;
2005-04-16 15:20:36 -07:00
/*
* Structure to ease passing around component names .
*/
typedef struct xfs_da_args {
2009-02-09 08:37:39 +01:00
const __uint8_t * name ; /* string (maybe not NULL terminated) */
2005-04-16 15:20:36 -07:00
int namelen ; /* length of string (maybe no NULL) */
2013-08-12 20:50:09 +10:00
__uint8_t filetype ; /* filetype of inode for directories */
2009-02-09 08:37:39 +01:00
__uint8_t * value ; /* set of bytes (maybe contain NULLs) */
2005-04-16 15:20:36 -07:00
int valuelen ; /* length of value */
int flags ; /* argument flags (eg: ATTR_NOCREATE) */
xfs_dahash_t hashval ; /* hash value of name */
xfs_ino_t inumber ; /* input/output inode number */
struct xfs_inode * dp ; /* directory inode to manipulate */
xfs_fsblock_t * firstblock ; /* ptr to firstblock for bmap calls */
struct xfs_bmap_free * flist ; /* ptr to freelist for bmap_finish */
struct xfs_trans * trans ; /* current trans (changes over time) */
xfs_extlen_t total ; /* total blocks needed, for 1st bmap */
int whichfork ; /* data or attribute fork */
xfs_dablk_t blkno ; /* blkno of attr leaf of interest */
int index ; /* index of attr of interest in blk */
xfs_dablk_t rmtblkno ; /* remote attr value starting blkno */
int rmtblkcnt ; /* remote attr value block count */
xfs_dablk_t blkno2 ; /* blkno of 2nd attr leaf of interest */
int index2 ; /* index of 2nd attr in blk */
xfs_dablk_t rmtblkno2 ; /* remote attr value starting blkno */
int rmtblkcnt2 ; /* remote attr value block count */
2008-05-21 16:42:05 +10:00
int op_flags ; /* operation flags */
2008-05-21 16:41:01 +10:00
enum xfs_dacmp cmpresult ; /* name compare result for lookups */
2005-04-16 15:20:36 -07:00
} xfs_da_args_t ;
2008-05-21 16:42:05 +10:00
/*
* Operation flags :
*/
# define XFS_DA_OP_JUSTCHECK 0x0001 /* check for ok with no space */
# define XFS_DA_OP_RENAME 0x0002 /* this is an atomic rename op */
# define XFS_DA_OP_ADDNAME 0x0004 /* this is an add operation */
# define XFS_DA_OP_OKNOENT 0x0008 /* lookup/add op, ENOENT ok, else die */
2008-05-21 16:58:22 +10:00
# define XFS_DA_OP_CILOOKUP 0x0010 /* lookup to return CI name if found */
2008-05-21 16:42:05 +10:00
2009-12-14 23:14:59 +00:00
# define XFS_DA_OP_FLAGS \
{ XFS_DA_OP_JUSTCHECK , " JUSTCHECK " } , \
{ XFS_DA_OP_RENAME , " RENAME " } , \
{ XFS_DA_OP_ADDNAME , " ADDNAME " } , \
{ XFS_DA_OP_OKNOENT , " OKNOENT " } , \
{ XFS_DA_OP_CILOOKUP , " CILOOKUP " }
2005-04-16 15:20:36 -07:00
/*
* Storage for holding state during Btree searches and split / join ops .
*
* Only need space for 5 intermediate nodes . With a minimum of 62 - way
* fanout to the Btree , we can support over 900 million directory blocks ,
* which is slightly more than enough .
*/
typedef struct xfs_da_state_blk {
2012-06-22 18:50:14 +10:00
struct xfs_buf * bp ; /* buffer containing block */
2005-04-16 15:20:36 -07:00
xfs_dablk_t blkno ; /* filesystem blkno of buffer */
xfs_daddr_t disk_blkno ; /* on-disk blkno (in BBs) of buffer */
int index ; /* relevant index into block */
xfs_dahash_t hashval ; /* last hash value in block */
int magic ; /* blk's magic number, ie: blk type */
} xfs_da_state_blk_t ;
typedef struct xfs_da_state_path {
int active ; /* number of active levels */
xfs_da_state_blk_t blk [ XFS_DA_NODE_MAXDEPTH ] ;
} xfs_da_state_path_t ;
typedef struct xfs_da_state {
xfs_da_args_t * args ; /* filename arguments */
struct xfs_mount * mp ; /* filesystem mount point */
unsigned int blocksize ; /* logical block size */
unsigned int node_ents ; /* how many entries in danode */
xfs_da_state_path_t path ; /* search/split paths */
xfs_da_state_path_t altpath ; /* alternate path for join */
unsigned char inleaf ; /* insert into 1->lf, 0->splf */
unsigned char extravalid ; /* T/F: extrablk is in use */
unsigned char extraafter ; /* T/F: extrablk is after new */
2009-03-29 09:55:42 +02:00
xfs_da_state_blk_t extrablk ; /* for double-splits on leaves */
2005-04-16 15:20:36 -07:00
/* for dirv2 extrablk is data */
} xfs_da_state_t ;
/*
* Utility macros to aid in logging changed structure fields .
*/
# define XFS_DA_LOGOFF(BASE, ADDR) ((char *)(ADDR) - (char *)(BASE))
# define XFS_DA_LOGRANGE(BASE, ADDR, SIZE) \
( uint ) ( XFS_DA_LOGOFF ( BASE , ADDR ) ) , \
( uint ) ( XFS_DA_LOGOFF ( BASE , ADDR ) + ( SIZE ) - 1 )
2008-05-21 16:41:01 +10:00
/*
* Name ops for directory and / or attr name operations
*/
struct xfs_nameops {
xfs_dahash_t ( * hashname ) ( struct xfs_name * ) ;
2010-01-20 10:47:17 +11:00
enum xfs_dacmp ( * compname ) ( struct xfs_da_args * ,
const unsigned char * , int ) ;
2008-05-21 16:41:01 +10:00
} ;
2005-04-16 15:20:36 -07:00
/*========================================================================
2008-10-30 17:05:38 +11:00
* Function prototypes .
2005-04-16 15:20:36 -07:00
* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */
/*
* Routines used for growing the Btree .
*/
2013-04-24 18:58:02 +10:00
int xfs_da3_node_create ( struct xfs_da_args * args , xfs_dablk_t blkno ,
int level , struct xfs_buf * * bpp , int whichfork ) ;
int xfs_da3_split ( xfs_da_state_t * state ) ;
2005-04-16 15:20:36 -07:00
/*
* Routines used for shrinking the Btree .
*/
2013-04-24 18:58:02 +10:00
int xfs_da3_join ( xfs_da_state_t * state ) ;
void xfs_da3_fixhashpath ( struct xfs_da_state * state ,
struct xfs_da_state_path * path_to_to_fix ) ;
2005-04-16 15:20:36 -07:00
/*
* Routines used for finding things in the Btree .
*/
2013-04-24 18:58:02 +10:00
int xfs_da3_node_lookup_int ( xfs_da_state_t * state , int * result ) ;
int xfs_da3_path_shift ( xfs_da_state_t * state , xfs_da_state_path_t * path ,
2005-04-16 15:20:36 -07:00
int forward , int release , int * result ) ;
/*
* Utility routines .
*/
2013-04-24 18:58:02 +10:00
int xfs_da3_blk_link ( xfs_da_state_t * state , xfs_da_state_blk_t * old_blk ,
2005-04-16 15:20:36 -07:00
xfs_da_state_blk_t * new_blk ) ;
2013-04-24 18:58:02 +10:00
int xfs_da3_node_read ( struct xfs_trans * tp , struct xfs_inode * dp ,
2012-11-12 22:54:17 +11:00
xfs_dablk_t bno , xfs_daddr_t mappedbno ,
struct xfs_buf * * bpp , int which_fork ) ;
2005-04-16 15:20:36 -07:00
/*
* Utility routines .
*/
int xfs_da_grow_inode ( xfs_da_args_t * args , xfs_dablk_t * new_blkno ) ;
2011-07-13 13:43:49 +02:00
int xfs_da_grow_inode_int ( struct xfs_da_args * args , xfs_fileoff_t * bno ,
int count ) ;
2005-04-16 15:20:36 -07:00
int xfs_da_get_buf ( struct xfs_trans * trans , struct xfs_inode * dp ,
xfs_dablk_t bno , xfs_daddr_t mappedbno ,
2012-06-22 18:50:14 +10:00
struct xfs_buf * * bp , int whichfork ) ;
2005-04-16 15:20:36 -07:00
int xfs_da_read_buf ( struct xfs_trans * trans , struct xfs_inode * dp ,
xfs_dablk_t bno , xfs_daddr_t mappedbno ,
2012-11-12 22:54:10 +11:00
struct xfs_buf * * bpp , int whichfork ,
2012-11-14 17:54:40 +11:00
const struct xfs_buf_ops * ops ) ;
2005-04-16 15:20:36 -07:00
xfs_daddr_t xfs_da_reada_buf ( struct xfs_trans * trans , struct xfs_inode * dp ,
2012-11-12 22:54:18 +11:00
xfs_dablk_t bno , xfs_daddr_t mapped_bno ,
2012-11-14 17:54:40 +11:00
int whichfork , const struct xfs_buf_ops * ops ) ;
2005-04-16 15:20:36 -07:00
int xfs_da_shrink_inode ( xfs_da_args_t * args , xfs_dablk_t dead_blkno ,
2012-06-22 18:50:14 +10:00
struct xfs_buf * dead_buf ) ;
2005-04-16 15:20:36 -07:00
2009-02-09 08:37:39 +01:00
uint xfs_da_hashname ( const __uint8_t * name_string , int name_length ) ;
2008-05-21 16:41:01 +10:00
enum xfs_dacmp xfs_da_compname ( struct xfs_da_args * args ,
2010-01-20 10:47:17 +11:00
const unsigned char * name , int len ) ;
2008-05-21 16:41:01 +10:00
2005-04-16 15:20:36 -07:00
xfs_da_state_t * xfs_da_state_alloc ( void ) ;
void xfs_da_state_free ( xfs_da_state_t * state ) ;
extern struct kmem_zone * xfs_da_state_zone ;
2009-03-04 19:33:48 +01:00
extern const struct xfs_nameops xfs_default_nameops ;
2005-04-16 15:20:36 -07:00
# endif /* __XFS_DA_BTREE_H__ */