1 /* -*- mode: c; c-basic-offset: 8; -*-
 
   2  * vim: noexpandtab sw=8 ts=8 sts=0:
 
   6  * Defines sub allocator api
 
   8  * Copyright (C) 2003, 2004 Oracle.  All rights reserved.
 
  10  * This program is free software; you can redistribute it and/or
 
  11  * modify it under the terms of the GNU General Public
 
  12  * License as published by the Free Software Foundation; either
 
  13  * version 2 of the License, or (at your option) any later version.
 
  15  * This program is distributed in the hope that it will be useful,
 
  16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 
  18  * General Public License for more details.
 
  20  * You should have received a copy of the GNU General Public
 
  21  * License along with this program; if not, write to the
 
  22  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
 
  23  * Boston, MA 021110-1307, USA.
 
  26 #ifndef _CHAINALLOC_H_
 
  27 #define _CHAINALLOC_H_
 
  29 typedef int (group_search_t)(struct inode *,
 
  31                              u32,                       /* bits_wanted */
 
  35                              u16 *);                    /* *bits_found */
 
  37 struct ocfs2_alloc_context {
 
  38         struct inode *ac_inode;    /* which bitmap are we allocating from? */
 
  39         struct buffer_head *ac_bh; /* file entry bh */
 
  40         u32    ac_alloc_slot;   /* which slot are we allocating from? */
 
  43 #define OCFS2_AC_USE_LOCAL 1
 
  44 #define OCFS2_AC_USE_MAIN  2
 
  45 #define OCFS2_AC_USE_INODE 3
 
  46 #define OCFS2_AC_USE_META  4
 
  49         /* these are used by the chain search */
 
  51         int    ac_allow_chain_relink;
 
  52         group_search_t *ac_group_search;
 
  55         u64    ac_max_block;  /* Highest block number to allocate. 0 is
 
  56                                  is the same as ~0 - unlimited */
 
  59 void ocfs2_free_alloc_context(struct ocfs2_alloc_context *ac);
 
  60 static inline int ocfs2_alloc_context_bits_left(struct ocfs2_alloc_context *ac)
 
  62         return ac->ac_bits_wanted - ac->ac_bits_given;
 
  66  * Please note that the caller must make sure that root_el is the root
 
  67  * of extent tree. So for an inode, it should be &fe->id2.i_list. Otherwise
 
  68  * the result may be wrong.
 
  70 int ocfs2_reserve_new_metadata(struct ocfs2_super *osb,
 
  71                                struct ocfs2_extent_list *root_el,
 
  72                                struct ocfs2_alloc_context **ac);
 
  73 int ocfs2_reserve_new_metadata_blocks(struct ocfs2_super *osb,
 
  75                                       struct ocfs2_alloc_context **ac);
 
  76 int ocfs2_reserve_new_inode(struct ocfs2_super *osb,
 
  77                             struct ocfs2_alloc_context **ac);
 
  78 int ocfs2_reserve_clusters(struct ocfs2_super *osb,
 
  80                            struct ocfs2_alloc_context **ac);
 
  82 int ocfs2_claim_metadata(struct ocfs2_super *osb,
 
  84                          struct ocfs2_alloc_context *ac,
 
  86                          u16 *suballoc_bit_start,
 
  89 int ocfs2_claim_new_inode(struct ocfs2_super *osb,
 
  92                           struct buffer_head *parent_fe_bh,
 
  93                           struct ocfs2_alloc_context *ac,
 
  96 int ocfs2_claim_clusters(struct ocfs2_super *osb,
 
  98                          struct ocfs2_alloc_context *ac,
 
 103  * Use this variant of ocfs2_claim_clusters to specify a maxiumum
 
 104  * number of clusters smaller than the allocation reserved.
 
 106 int __ocfs2_claim_clusters(struct ocfs2_super *osb,
 
 108                            struct ocfs2_alloc_context *ac,
 
 114 int ocfs2_free_suballoc_bits(handle_t *handle,
 
 115                              struct inode *alloc_inode,
 
 116                              struct buffer_head *alloc_bh,
 
 117                              unsigned int start_bit,
 
 120 int ocfs2_free_dinode(handle_t *handle,
 
 121                       struct inode *inode_alloc_inode,
 
 122                       struct buffer_head *inode_alloc_bh,
 
 123                       struct ocfs2_dinode *di);
 
 124 int ocfs2_free_clusters(handle_t *handle,
 
 125                         struct inode *bitmap_inode,
 
 126                         struct buffer_head *bitmap_bh,
 
 128                         unsigned int num_clusters);
 
 130 static inline u64 ocfs2_which_suballoc_group(u64 block, unsigned int bit)
 
 132         u64 group = block - (u64) bit;
 
 137 static inline u32 ocfs2_cluster_from_desc(struct ocfs2_super *osb,
 
 140         /* This should work for all block group descriptors as only
 
 141          * the 1st group descriptor of the cluster bitmap is
 
 144         if (bg_blkno == osb->first_cluster_group_blkno)
 
 147         /* the rest of the block groups are located at the beginning
 
 148          * of their 1st cluster, so a direct translation just
 
 150         return ocfs2_blocks_to_clusters(osb->sb, bg_blkno);
 
 153 static inline int ocfs2_is_cluster_bitmap(struct inode *inode)
 
 155         struct ocfs2_super *osb = OCFS2_SB(inode->i_sb);
 
 156         return osb->bitmap_blkno == OCFS2_I(inode)->ip_blkno;
 
 159 /* This is for local alloc ONLY. Others should use the task-specific
 
 161 int ocfs2_reserve_cluster_bitmap_bits(struct ocfs2_super *osb,
 
 162                                       struct ocfs2_alloc_context *ac);
 
 163 void ocfs2_free_ac_resource(struct ocfs2_alloc_context *ac);
 
 165 /* given a cluster offset, calculate which block group it belongs to
 
 166  * and return that block offset. */
 
 167 u64 ocfs2_which_cluster_group(struct inode *inode, u32 cluster);
 
 170  * By default, ocfs2_read_group_descriptor() calls ocfs2_error() when it
 
 171  * finds a problem.  A caller that wants to check a group descriptor
 
 172  * without going readonly should read the block with ocfs2_read_block[s]()
 
 173  * and then checking it with this function.  This is only resize, really.
 
 174  * Everyone else should be using ocfs2_read_group_descriptor().
 
 176 int ocfs2_check_group_descriptor(struct super_block *sb,
 
 177                                  struct ocfs2_dinode *di,
 
 178                                  struct buffer_head *bh);
 
 180  * Read a group descriptor block into *bh.  If *bh is NULL, a bh will be
 
 181  * allocated.  This is a cached read.  The descriptor will be validated with
 
 182  * ocfs2_validate_group_descriptor().
 
 184 int ocfs2_read_group_descriptor(struct inode *inode, struct ocfs2_dinode *di,
 
 185                                 u64 gd_blkno, struct buffer_head **bh);
 
 187 int ocfs2_lock_allocators(struct inode *inode, struct ocfs2_extent_tree *et,
 
 188                           u32 clusters_to_add, u32 extents_to_split,
 
 189                           struct ocfs2_alloc_context **data_ac,
 
 190                           struct ocfs2_alloc_context **meta_ac);
 
 192 int ocfs2_test_inode_bit(struct ocfs2_super *osb, u64 blkno, int *res);
 
 193 #endif /* _CHAINALLOC_H_ */