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