From 3e37fc8987985b065a5f9a3ed783608e062f7b28 Mon Sep 17 00:00:00 2001 From: Goldwyn Rodrigues Date: Thu, 17 Feb 2011 09:44:40 -0600 Subject: [PATCH] --- yaml --- r: 243031 b: refs/heads/master c: 272b62c1f0f6f742046e45b50b6fec98860208a0 h: refs/heads/master i: 243029: e6bad32281fe5fdc0576e9295028bd44706a5fb9 243027: 452a0cbba13c957238638021fde80e934e344d65 243023: f842b95e6dce0e57ad78be1fe5eda02b1ae6fc22 v: v3 --- [refs] | 2 +- trunk/fs/ocfs2/aops.c | 6 ++++++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index 42d9726f8f6b..f44628236875 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 99bdc3880c611c7f2061fbd5372ef81b40217e26 +refs/heads/master: 272b62c1f0f6f742046e45b50b6fec98860208a0 diff --git a/trunk/fs/ocfs2/aops.c b/trunk/fs/ocfs2/aops.c index 0d44b7701844..b5d7fb9ab1f3 100644 --- a/trunk/fs/ocfs2/aops.c +++ b/trunk/fs/ocfs2/aops.c @@ -1015,6 +1015,12 @@ static int ocfs2_prepare_page_for_write(struct inode *inode, u64 *p_blkno, ocfs2_figure_cluster_boundaries(OCFS2_SB(inode->i_sb), cpos, &cluster_start, &cluster_end); + /* treat the write as new if the a hole/lseek spanned across + * the page boundary. + */ + new = new | ((i_size_read(inode) <= page_offset(page)) && + (page_offset(page) <= user_pos)); + if (page == wc->w_target_page) { map_from = user_pos & (PAGE_CACHE_SIZE - 1); map_to = map_from + user_len;