diff options
author | Mark Fasheh <mark.fasheh@oracle.com> | 2007-09-07 17:46:51 -0400 |
---|---|---|
committer | Mark Fasheh <mark.fasheh@oracle.com> | 2007-10-12 14:54:40 -0400 |
commit | 1afc32b952335f665327a1a9001ba1b44bb76fd9 (patch) | |
tree | c914afd0ef5d32b426c3cf65820de7599e570656 /fs/ocfs2/alloc.h | |
parent | 6798d35a31c413bbb3f83bbaa844bd2598168ccc (diff) |
ocfs2: Write support for inline data
This fixes up write, truncate, mmap, and RESVSP/UNRESVP to understand inline
inode data.
For the most part, the changes to the core write code can be relied on to do
the heavy lifting. Any code calling ocfs2_write_begin (including shared
writeable mmap) can count on it doing the right thing with respect to
growing inline data to an extent tree.
Size reducing truncates, including UNRESVP can simply zero that portion of
the inode block being removed. Size increasing truncatesm, including RESVP
have to be a little bit smarter and grow the inode to an extent tree if
necessary.
Signed-off-by: Mark Fasheh <mark.fasheh@oracle.com>
Reviewed-by: Joel Becker <joel.becker@oracle.com>
Diffstat (limited to 'fs/ocfs2/alloc.h')
-rw-r--r-- | fs/ocfs2/alloc.h | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/fs/ocfs2/alloc.h b/fs/ocfs2/alloc.h index 990df48ae8d..826e0a6cf5c 100644 --- a/fs/ocfs2/alloc.h +++ b/fs/ocfs2/alloc.h | |||
@@ -62,6 +62,10 @@ static inline int ocfs2_extend_meta_needed(struct ocfs2_dinode *fe) | |||
62 | return le16_to_cpu(fe->id2.i_list.l_tree_depth) + 2; | 62 | return le16_to_cpu(fe->id2.i_list.l_tree_depth) + 2; |
63 | } | 63 | } |
64 | 64 | ||
65 | void ocfs2_set_inode_data_inline(struct inode *inode, struct ocfs2_dinode *di); | ||
66 | int ocfs2_convert_inline_data_to_extents(struct inode *inode, | ||
67 | struct buffer_head *di_bh); | ||
68 | |||
65 | int ocfs2_truncate_log_init(struct ocfs2_super *osb); | 69 | int ocfs2_truncate_log_init(struct ocfs2_super *osb); |
66 | void ocfs2_truncate_log_shutdown(struct ocfs2_super *osb); | 70 | void ocfs2_truncate_log_shutdown(struct ocfs2_super *osb); |
67 | void ocfs2_schedule_truncate_log_flush(struct ocfs2_super *osb, | 71 | void ocfs2_schedule_truncate_log_flush(struct ocfs2_super *osb, |
@@ -115,6 +119,8 @@ int ocfs2_commit_truncate(struct ocfs2_super *osb, | |||
115 | struct inode *inode, | 119 | struct inode *inode, |
116 | struct buffer_head *fe_bh, | 120 | struct buffer_head *fe_bh, |
117 | struct ocfs2_truncate_context *tc); | 121 | struct ocfs2_truncate_context *tc); |
122 | int ocfs2_truncate_inline(struct inode *inode, struct buffer_head *di_bh, | ||
123 | unsigned int start, unsigned int end, int trunc); | ||
118 | 124 | ||
119 | int ocfs2_find_leaf(struct inode *inode, struct ocfs2_extent_list *root_el, | 125 | int ocfs2_find_leaf(struct inode *inode, struct ocfs2_extent_list *root_el, |
120 | u32 cpos, struct buffer_head **leaf_bh); | 126 | u32 cpos, struct buffer_head **leaf_bh); |