Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (c) 2000-2001,2005 Silicon Graphics, Inc. |
| 3 | * All Rights Reserved. |
| 4 | * |
| 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. |
| 8 | * |
| 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. |
| 13 | * |
| 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 |
| 17 | */ |
| 18 | #ifndef __XFS_DIR2_PRIV_H__ |
| 19 | #define __XFS_DIR2_PRIV_H__ |
| 20 | |
Dave Chinner | 0cb9776 | 2013-08-12 20:50:09 +1000 | [diff] [blame] | 21 | struct dir_context; |
| 22 | |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 23 | /* |
| 24 | * Directory offset/block conversion functions. |
| 25 | * |
| 26 | * DB blocks here are logical directory block numbers, not filesystem blocks. |
| 27 | */ |
| 28 | |
| 29 | /* |
| 30 | * Convert dataptr to byte in file space |
| 31 | */ |
| 32 | static inline xfs_dir2_off_t |
| 33 | xfs_dir2_dataptr_to_byte(xfs_dir2_dataptr_t dp) |
| 34 | { |
| 35 | return (xfs_dir2_off_t)dp << XFS_DIR2_DATA_ALIGN_LOG; |
| 36 | } |
| 37 | |
| 38 | /* |
| 39 | * Convert byte in file space to dataptr. It had better be aligned. |
| 40 | */ |
| 41 | static inline xfs_dir2_dataptr_t |
| 42 | xfs_dir2_byte_to_dataptr(xfs_dir2_off_t by) |
| 43 | { |
| 44 | return (xfs_dir2_dataptr_t)(by >> XFS_DIR2_DATA_ALIGN_LOG); |
| 45 | } |
| 46 | |
| 47 | /* |
| 48 | * Convert byte in space to (DB) block |
| 49 | */ |
| 50 | static inline xfs_dir2_db_t |
Dave Chinner | 3002803 | 2014-06-06 15:08:18 +1000 | [diff] [blame] | 51 | xfs_dir2_byte_to_db(struct xfs_da_geometry *geo, xfs_dir2_off_t by) |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 52 | { |
Dave Chinner | 3002803 | 2014-06-06 15:08:18 +1000 | [diff] [blame] | 53 | return (xfs_dir2_db_t)(by >> geo->blklog); |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 54 | } |
| 55 | |
| 56 | /* |
| 57 | * Convert dataptr to a block number |
| 58 | */ |
| 59 | static inline xfs_dir2_db_t |
Dave Chinner | 3002803 | 2014-06-06 15:08:18 +1000 | [diff] [blame] | 60 | xfs_dir2_dataptr_to_db(struct xfs_da_geometry *geo, xfs_dir2_dataptr_t dp) |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 61 | { |
Dave Chinner | 3002803 | 2014-06-06 15:08:18 +1000 | [diff] [blame] | 62 | return xfs_dir2_byte_to_db(geo, xfs_dir2_dataptr_to_byte(dp)); |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 63 | } |
| 64 | |
| 65 | /* |
| 66 | * Convert byte in space to offset in a block |
| 67 | */ |
| 68 | static inline xfs_dir2_data_aoff_t |
Dave Chinner | 9b3b552 | 2014-06-06 15:06:53 +1000 | [diff] [blame] | 69 | xfs_dir2_byte_to_off(struct xfs_da_geometry *geo, xfs_dir2_off_t by) |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 70 | { |
Dave Chinner | 9b3b552 | 2014-06-06 15:06:53 +1000 | [diff] [blame] | 71 | return (xfs_dir2_data_aoff_t)(by & (geo->blksize - 1)); |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 72 | } |
| 73 | |
| 74 | /* |
| 75 | * Convert dataptr to a byte offset in a block |
| 76 | */ |
| 77 | static inline xfs_dir2_data_aoff_t |
Dave Chinner | 3002803 | 2014-06-06 15:08:18 +1000 | [diff] [blame] | 78 | xfs_dir2_dataptr_to_off(struct xfs_da_geometry *geo, xfs_dir2_dataptr_t dp) |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 79 | { |
Dave Chinner | 3002803 | 2014-06-06 15:08:18 +1000 | [diff] [blame] | 80 | return xfs_dir2_byte_to_off(geo, xfs_dir2_dataptr_to_byte(dp)); |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 81 | } |
| 82 | |
| 83 | /* |
| 84 | * Convert block and offset to byte in space |
| 85 | */ |
| 86 | static inline xfs_dir2_off_t |
Dave Chinner | 9b3b552 | 2014-06-06 15:06:53 +1000 | [diff] [blame] | 87 | xfs_dir2_db_off_to_byte(struct xfs_da_geometry *geo, xfs_dir2_db_t db, |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 88 | xfs_dir2_data_aoff_t o) |
| 89 | { |
Dave Chinner | 9b3b552 | 2014-06-06 15:06:53 +1000 | [diff] [blame] | 90 | return ((xfs_dir2_off_t)db << geo->blklog) + o; |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 91 | } |
| 92 | |
| 93 | /* |
| 94 | * Convert block (DB) to block (dablk) |
| 95 | */ |
| 96 | static inline xfs_dablk_t |
Dave Chinner | 2998ab1d | 2014-06-06 15:07:53 +1000 | [diff] [blame] | 97 | xfs_dir2_db_to_da(struct xfs_da_geometry *geo, xfs_dir2_db_t db) |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 98 | { |
Dave Chinner | 2998ab1d | 2014-06-06 15:07:53 +1000 | [diff] [blame] | 99 | return (xfs_dablk_t)(db << (geo->blklog - geo->fsblog)); |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 100 | } |
| 101 | |
| 102 | /* |
| 103 | * Convert byte in space to (DA) block |
| 104 | */ |
| 105 | static inline xfs_dablk_t |
Dave Chinner | 3002803 | 2014-06-06 15:08:18 +1000 | [diff] [blame] | 106 | xfs_dir2_byte_to_da(struct xfs_da_geometry *geo, xfs_dir2_off_t by) |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 107 | { |
Dave Chinner | 3002803 | 2014-06-06 15:08:18 +1000 | [diff] [blame] | 108 | return xfs_dir2_db_to_da(geo, xfs_dir2_byte_to_db(geo, by)); |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 109 | } |
| 110 | |
| 111 | /* |
| 112 | * Convert block and offset to dataptr |
| 113 | */ |
| 114 | static inline xfs_dir2_dataptr_t |
Dave Chinner | 3002803 | 2014-06-06 15:08:18 +1000 | [diff] [blame] | 115 | xfs_dir2_db_off_to_dataptr(struct xfs_da_geometry *geo, xfs_dir2_db_t db, |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 116 | xfs_dir2_data_aoff_t o) |
| 117 | { |
Dave Chinner | 3002803 | 2014-06-06 15:08:18 +1000 | [diff] [blame] | 118 | return xfs_dir2_byte_to_dataptr(xfs_dir2_db_off_to_byte(geo, db, o)); |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 119 | } |
| 120 | |
| 121 | /* |
| 122 | * Convert block (dablk) to block (DB) |
| 123 | */ |
| 124 | static inline xfs_dir2_db_t |
Dave Chinner | 2998ab1d | 2014-06-06 15:07:53 +1000 | [diff] [blame] | 125 | xfs_dir2_da_to_db(struct xfs_da_geometry *geo, xfs_dablk_t da) |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 126 | { |
Dave Chinner | 2998ab1d | 2014-06-06 15:07:53 +1000 | [diff] [blame] | 127 | return (xfs_dir2_db_t)(da >> (geo->blklog - geo->fsblog)); |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 128 | } |
| 129 | |
| 130 | /* |
| 131 | * Convert block (dablk) to byte offset in space |
| 132 | */ |
| 133 | static inline xfs_dir2_off_t |
Dave Chinner | 2998ab1d | 2014-06-06 15:07:53 +1000 | [diff] [blame] | 134 | xfs_dir2_da_to_byte(struct xfs_da_geometry *geo, xfs_dablk_t da) |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 135 | { |
Dave Chinner | 2998ab1d | 2014-06-06 15:07:53 +1000 | [diff] [blame] | 136 | return xfs_dir2_db_off_to_byte(geo, xfs_dir2_da_to_db(geo, da), 0); |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 137 | } |
| 138 | |
| 139 | /* |
| 140 | * Directory tail pointer accessor functions. Based on block geometry. |
| 141 | */ |
| 142 | static inline struct xfs_dir2_block_tail * |
Dave Chinner | 8f66193 | 2014-06-06 15:15:59 +1000 | [diff] [blame] | 143 | xfs_dir2_block_tail_p(struct xfs_da_geometry *geo, struct xfs_dir2_data_hdr *hdr) |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 144 | { |
| 145 | return ((struct xfs_dir2_block_tail *) |
Dave Chinner | 8f66193 | 2014-06-06 15:15:59 +1000 | [diff] [blame] | 146 | ((char *)hdr + geo->blksize)) - 1; |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 147 | } |
| 148 | |
| 149 | static inline struct xfs_dir2_leaf_tail * |
Dave Chinner | 8f66193 | 2014-06-06 15:15:59 +1000 | [diff] [blame] | 150 | xfs_dir2_leaf_tail_p(struct xfs_da_geometry *geo, struct xfs_dir2_leaf *lp) |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 151 | { |
| 152 | return (struct xfs_dir2_leaf_tail *) |
Dave Chinner | 8f66193 | 2014-06-06 15:15:59 +1000 | [diff] [blame] | 153 | ((char *)lp + geo->blksize - |
Dave Chinner | 892e3f3 | 2014-06-06 15:04:05 +1000 | [diff] [blame] | 154 | sizeof(struct xfs_dir2_leaf_tail)); |
| 155 | } |
| 156 | |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 157 | /* xfs_dir2.c */ |
| 158 | extern int xfs_dir_ino_validate(struct xfs_mount *mp, xfs_ino_t ino); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 159 | extern int xfs_dir2_grow_inode(struct xfs_da_args *args, int space, |
| 160 | xfs_dir2_db_t *dbp); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 161 | extern int xfs_dir_cilookup_result(struct xfs_da_args *args, |
| 162 | const unsigned char *name, int len); |
| 163 | |
Dave Chinner | 0cb9776 | 2013-08-12 20:50:09 +1000 | [diff] [blame] | 164 | #define S_SHIFT 12 |
| 165 | extern const unsigned char xfs_mode_to_ftype[]; |
| 166 | |
| 167 | extern unsigned char xfs_dir3_get_dtype(struct xfs_mount *mp, |
| 168 | __uint8_t filetype); |
| 169 | |
| 170 | |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 171 | /* xfs_dir2_block.c */ |
Dave Chinner | 4a8af27 | 2013-08-12 20:49:36 +1000 | [diff] [blame] | 172 | extern int xfs_dir3_block_read(struct xfs_trans *tp, struct xfs_inode *dp, |
| 173 | struct xfs_buf **bpp); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 174 | extern int xfs_dir2_block_addname(struct xfs_da_args *args); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 175 | extern int xfs_dir2_block_lookup(struct xfs_da_args *args); |
| 176 | extern int xfs_dir2_block_removename(struct xfs_da_args *args); |
| 177 | extern int xfs_dir2_block_replace(struct xfs_da_args *args); |
| 178 | extern int xfs_dir2_leaf_to_block(struct xfs_da_args *args, |
Dave Chinner | 1d9025e | 2012-06-22 18:50:14 +1000 | [diff] [blame] | 179 | struct xfs_buf *lbp, struct xfs_buf *dbp); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 180 | |
| 181 | /* xfs_dir2_data.c */ |
| 182 | #ifdef DEBUG |
Dave Chinner | 33363fe | 2013-04-03 16:11:22 +1100 | [diff] [blame] | 183 | #define xfs_dir3_data_check(dp,bp) __xfs_dir3_data_check(dp, bp); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 184 | #else |
Dave Chinner | 33363fe | 2013-04-03 16:11:22 +1100 | [diff] [blame] | 185 | #define xfs_dir3_data_check(dp,bp) |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 186 | #endif |
Dave Chinner | 1813dd6 | 2012-11-14 17:54:40 +1100 | [diff] [blame] | 187 | |
Dave Chinner | 33363fe | 2013-04-03 16:11:22 +1100 | [diff] [blame] | 188 | extern int __xfs_dir3_data_check(struct xfs_inode *dp, struct xfs_buf *bp); |
| 189 | extern int xfs_dir3_data_read(struct xfs_trans *tp, struct xfs_inode *dp, |
Dave Chinner | e481357 | 2012-11-12 22:54:14 +1100 | [diff] [blame] | 190 | xfs_dablk_t bno, xfs_daddr_t mapped_bno, struct xfs_buf **bpp); |
Eric Sandeen | 9df2dd0 | 2014-04-14 19:01:59 +1000 | [diff] [blame] | 191 | extern int xfs_dir3_data_readahead(struct xfs_inode *dp, xfs_dablk_t bno, |
| 192 | xfs_daddr_t mapped_bno); |
Dave Chinner | 82025d7 | 2012-11-12 22:54:12 +1100 | [diff] [blame] | 193 | |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 194 | extern struct xfs_dir2_data_free * |
| 195 | xfs_dir2_data_freeinsert(struct xfs_dir2_data_hdr *hdr, |
Dave Chinner | 2ca9877 | 2013-10-29 22:11:49 +1100 | [diff] [blame] | 196 | struct xfs_dir2_data_free *bf, struct xfs_dir2_data_unused *dup, |
| 197 | int *loghead); |
Dave Chinner | f5f3d9b | 2013-04-03 16:11:20 +1100 | [diff] [blame] | 198 | extern int xfs_dir3_data_init(struct xfs_da_args *args, xfs_dir2_db_t blkno, |
Dave Chinner | 1d9025e | 2012-06-22 18:50:14 +1000 | [diff] [blame] | 199 | struct xfs_buf **bpp); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 200 | |
| 201 | /* xfs_dir2_leaf.c */ |
Dave Chinner | 24df33b | 2013-04-12 07:30:21 +1000 | [diff] [blame] | 202 | extern int xfs_dir3_leafn_read(struct xfs_trans *tp, struct xfs_inode *dp, |
Dave Chinner | e6f7667 | 2012-11-12 22:54:15 +1100 | [diff] [blame] | 203 | xfs_dablk_t fbno, xfs_daddr_t mappedbno, struct xfs_buf **bpp); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 204 | extern int xfs_dir2_block_to_leaf(struct xfs_da_args *args, |
Dave Chinner | 1d9025e | 2012-06-22 18:50:14 +1000 | [diff] [blame] | 205 | struct xfs_buf *dbp); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 206 | extern int xfs_dir2_leaf_addname(struct xfs_da_args *args); |
Dave Chinner | 24df33b | 2013-04-12 07:30:21 +1000 | [diff] [blame] | 207 | extern void xfs_dir3_leaf_compact(struct xfs_da_args *args, |
| 208 | struct xfs_dir3_icleaf_hdr *leafhdr, struct xfs_buf *bp); |
| 209 | extern void xfs_dir3_leaf_compact_x1(struct xfs_dir3_icleaf_hdr *leafhdr, |
| 210 | struct xfs_dir2_leaf_entry *ents, int *indexp, |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 211 | int *lowstalep, int *highstalep, int *lowlogp, int *highlogp); |
Dave Chinner | 24df33b | 2013-04-12 07:30:21 +1000 | [diff] [blame] | 212 | extern int xfs_dir3_leaf_get_buf(struct xfs_da_args *args, xfs_dir2_db_t bno, |
| 213 | struct xfs_buf **bpp, __uint16_t magic); |
Dave Chinner | bc85178 | 2014-06-06 15:20:54 +1000 | [diff] [blame] | 214 | extern void xfs_dir3_leaf_log_ents(struct xfs_da_args *args, |
Dave Chinner | 4141956 | 2013-10-29 22:11:50 +1100 | [diff] [blame] | 215 | struct xfs_buf *bp, int first, int last); |
Dave Chinner | bc85178 | 2014-06-06 15:20:54 +1000 | [diff] [blame] | 216 | extern void xfs_dir3_leaf_log_header(struct xfs_da_args *args, |
Dave Chinner | 1d9025e | 2012-06-22 18:50:14 +1000 | [diff] [blame] | 217 | struct xfs_buf *bp); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 218 | extern int xfs_dir2_leaf_lookup(struct xfs_da_args *args); |
| 219 | extern int xfs_dir2_leaf_removename(struct xfs_da_args *args); |
| 220 | extern int xfs_dir2_leaf_replace(struct xfs_da_args *args); |
| 221 | extern int xfs_dir2_leaf_search_hash(struct xfs_da_args *args, |
Dave Chinner | 1d9025e | 2012-06-22 18:50:14 +1000 | [diff] [blame] | 222 | struct xfs_buf *lbp); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 223 | extern int xfs_dir2_leaf_trim_data(struct xfs_da_args *args, |
Dave Chinner | 1d9025e | 2012-06-22 18:50:14 +1000 | [diff] [blame] | 224 | struct xfs_buf *lbp, xfs_dir2_db_t db); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 225 | extern struct xfs_dir2_leaf_entry * |
Dave Chinner | 24df33b | 2013-04-12 07:30:21 +1000 | [diff] [blame] | 226 | xfs_dir3_leaf_find_entry(struct xfs_dir3_icleaf_hdr *leafhdr, |
| 227 | struct xfs_dir2_leaf_entry *ents, int index, int compact, |
| 228 | int lowstale, int highstale, int *lfloglow, int *lfloghigh); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 229 | extern int xfs_dir2_node_to_leaf(struct xfs_da_state *state); |
| 230 | |
Dave Chinner | 4141956 | 2013-10-29 22:11:50 +1100 | [diff] [blame] | 231 | extern bool xfs_dir3_leaf_check_int(struct xfs_mount *mp, struct xfs_inode *dp, |
Dave Chinner | 24df33b | 2013-04-12 07:30:21 +1000 | [diff] [blame] | 232 | struct xfs_dir3_icleaf_hdr *hdr, struct xfs_dir2_leaf *leaf); |
| 233 | |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 234 | /* xfs_dir2_node.c */ |
| 235 | extern int xfs_dir2_leaf_to_node(struct xfs_da_args *args, |
Dave Chinner | 1d9025e | 2012-06-22 18:50:14 +1000 | [diff] [blame] | 236 | struct xfs_buf *lbp); |
Dave Chinner | 4141956 | 2013-10-29 22:11:50 +1100 | [diff] [blame] | 237 | extern xfs_dahash_t xfs_dir2_leafn_lasthash(struct xfs_inode *dp, |
| 238 | struct xfs_buf *bp, int *count); |
Dave Chinner | 1d9025e | 2012-06-22 18:50:14 +1000 | [diff] [blame] | 239 | extern int xfs_dir2_leafn_lookup_int(struct xfs_buf *bp, |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 240 | struct xfs_da_args *args, int *indexp, |
| 241 | struct xfs_da_state *state); |
Dave Chinner | 4141956 | 2013-10-29 22:11:50 +1100 | [diff] [blame] | 242 | extern int xfs_dir2_leafn_order(struct xfs_inode *dp, struct xfs_buf *leaf1_bp, |
Dave Chinner | 1d9025e | 2012-06-22 18:50:14 +1000 | [diff] [blame] | 243 | struct xfs_buf *leaf2_bp); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 244 | extern int xfs_dir2_leafn_split(struct xfs_da_state *state, |
| 245 | struct xfs_da_state_blk *oldblk, struct xfs_da_state_blk *newblk); |
| 246 | extern int xfs_dir2_leafn_toosmall(struct xfs_da_state *state, int *action); |
| 247 | extern void xfs_dir2_leafn_unbalance(struct xfs_da_state *state, |
| 248 | struct xfs_da_state_blk *drop_blk, |
| 249 | struct xfs_da_state_blk *save_blk); |
| 250 | extern int xfs_dir2_node_addname(struct xfs_da_args *args); |
| 251 | extern int xfs_dir2_node_lookup(struct xfs_da_args *args); |
| 252 | extern int xfs_dir2_node_removename(struct xfs_da_args *args); |
| 253 | extern int xfs_dir2_node_replace(struct xfs_da_args *args); |
| 254 | extern int xfs_dir2_node_trim_free(struct xfs_da_args *args, xfs_fileoff_t fo, |
| 255 | int *rvalp); |
Dave Chinner | 2025207 | 2012-11-12 22:54:13 +1100 | [diff] [blame] | 256 | extern int xfs_dir2_free_read(struct xfs_trans *tp, struct xfs_inode *dp, |
| 257 | xfs_dablk_t fbno, struct xfs_buf **bpp); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 258 | |
| 259 | /* xfs_dir2_sf.c */ |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 260 | extern int xfs_dir2_block_sfsize(struct xfs_inode *dp, |
| 261 | struct xfs_dir2_data_hdr *block, struct xfs_dir2_sf_hdr *sfhp); |
Dave Chinner | 1d9025e | 2012-06-22 18:50:14 +1000 | [diff] [blame] | 262 | extern int xfs_dir2_block_to_sf(struct xfs_da_args *args, struct xfs_buf *bp, |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 263 | int size, xfs_dir2_sf_hdr_t *sfhp); |
| 264 | extern int xfs_dir2_sf_addname(struct xfs_da_args *args); |
| 265 | extern int xfs_dir2_sf_create(struct xfs_da_args *args, xfs_ino_t pino); |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 266 | extern int xfs_dir2_sf_lookup(struct xfs_da_args *args); |
| 267 | extern int xfs_dir2_sf_removename(struct xfs_da_args *args); |
| 268 | extern int xfs_dir2_sf_replace(struct xfs_da_args *args); |
| 269 | |
Dave Chinner | c24b5df | 2013-08-12 20:49:45 +1000 | [diff] [blame] | 270 | /* xfs_dir2_readdir.c */ |
| 271 | extern int xfs_readdir(struct xfs_inode *dp, struct dir_context *ctx, |
| 272 | size_t bufsize); |
| 273 | |
Christoph Hellwig | 5792664 | 2011-07-13 13:43:48 +0200 | [diff] [blame] | 274 | #endif /* __XFS_DIR2_PRIV_H__ */ |