mirror of
https://github.com/torvalds/linux.git
synced 2024-11-13 23:51:39 +00:00
f56654c435
Add some thin wrappers around ocfs2_insert_extent() for each of the 3 different btree types, ocfs2_inode_insert_extent(), ocfs2_xattr_value_insert_extent() and ocfs2_xattr_tree_insert_extent(). The last is for the xattr index btree, which will be used in a followup patch. All the old callers in file.c etc will call ocfs2_dinode_insert_extent(), while the other two handle the xattr issue. And the init of extent tree are handled by these functions. When storing xattr value which is too large, we will allocate some clusters for it and here ocfs2_extent_list and ocfs2_extent_rec will also be used. In order to re-use the b-tree operation code, a new parameter named "private" is added into ocfs2_extent_tree and it is used to indicate the root of ocfs2_exent_list. The reason is that we can't deduce the root from the buffer_head now. It may be in an inode, an ocfs2_xattr_block or even worse, in any place in an ocfs2_xattr_bucket. Signed-off-by: Tao Ma <tao.ma@oracle.com> Signed-off-by: Mark Fasheh <mfasheh@suse.com>
61 lines
1.9 KiB
C
61 lines
1.9 KiB
C
/* -*- mode: c; c-basic-offset: 8; -*-
|
|
* vim: noexpandtab sw=8 ts=8 sts=0:
|
|
*
|
|
* extent_map.h
|
|
*
|
|
* In-memory file extent mappings for OCFS2.
|
|
*
|
|
* Copyright (C) 2004 Oracle. All rights reserved.
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public
|
|
* License, version 2, as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will 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.
|
|
*
|
|
* You should have received a copy of the GNU General Public
|
|
* License along with this program; if not, write to the
|
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
* Boston, MA 021110-1307, USA.
|
|
*/
|
|
|
|
#ifndef _EXTENT_MAP_H
|
|
#define _EXTENT_MAP_H
|
|
|
|
struct ocfs2_extent_map_item {
|
|
unsigned int ei_cpos;
|
|
unsigned int ei_phys;
|
|
unsigned int ei_clusters;
|
|
unsigned int ei_flags;
|
|
|
|
struct list_head ei_list;
|
|
};
|
|
|
|
#define OCFS2_MAX_EXTENT_MAP_ITEMS 3
|
|
struct ocfs2_extent_map {
|
|
unsigned int em_num_items;
|
|
struct list_head em_list;
|
|
};
|
|
|
|
void ocfs2_extent_map_init(struct inode *inode);
|
|
void ocfs2_extent_map_trunc(struct inode *inode, unsigned int cluster);
|
|
void ocfs2_extent_map_insert_rec(struct inode *inode,
|
|
struct ocfs2_extent_rec *rec);
|
|
|
|
int ocfs2_get_clusters(struct inode *inode, u32 v_cluster, u32 *p_cluster,
|
|
u32 *num_clusters, unsigned int *extent_flags);
|
|
int ocfs2_extent_map_get_blocks(struct inode *inode, u64 v_blkno, u64 *p_blkno,
|
|
u64 *ret_count, unsigned int *extent_flags);
|
|
|
|
int ocfs2_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo,
|
|
u64 map_start, u64 map_len);
|
|
|
|
int ocfs2_xattr_get_clusters(struct inode *inode, u32 v_cluster,
|
|
u32 *p_cluster, u32 *num_clusters,
|
|
struct ocfs2_extent_list *el);
|
|
|
|
#endif /* _EXTENT_MAP_H */
|