Received: by 10.223.164.202 with SMTP id h10csp2541297wrb; Mon, 27 Nov 2017 19:36:02 -0800 (PST) X-Google-Smtp-Source: AGs4zMZLIyUPFnwSfiWR93mpG/PtZofWNo542dfPdcqueDvC7mLGmKlapF1zWsIVvocphziIdLRd X-Received: by 10.99.95.12 with SMTP id t12mr29169862pgb.40.1511840162813; Mon, 27 Nov 2017 19:36:02 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1511840162; cv=none; d=google.com; s=arc-20160816; b=n837l0DLGyLWEQ8GeUuRhUx4j2pQAPm3n41yzWL5+GePcI0LsFVwDZR5T9EAm20sgB 797d084jUREe5tdhn2eKI/06mm5SGUl+3lUMHKYkZTKyYV1doFKEr3SvhNg5Iq9HRrOu cf5yR+vG9kF7YYG+PqClvtwwWgQ1N1mrxcCG4oW4iTdrL87zUy9NcWdPUyEom9Zh3Lsn Xd9cgFkqEX/dRN0xpetPUo9F/IRrj6A1jwSNvR9mVvUREqZkttF5wGbULHw5lrjgL1/U PzGYxK+++4v9t/Cz+dGdvffzAVE6SGnhnHIYf4WLsFeh6CcA6uDbzin4Kqj7N9+uNR3c oAEg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-disposition :content-transfer-encoding:mime-version:in-reply-to:references :subject:cc:to:from:date:message-id:arc-authentication-results; bh=a0130QuBud/6UoLyS6ucREO0Jcb1JrdOZlopnSlrs9g=; b=RiYrqtkLcSF+iha0vQJLZ2SvfSxJ6Nz38lA/pUCaNkM2AiNdSKDczbR+vtR2UYGYH9 VkUZre/Bs/pLfp3CukC6WD7DDot7Bj01NttyNlCKoamBBsZM29ycOCjcPGMiHdCKLo0i k71xSKP0OIEt3KOHTUfJ4EJbgozpEtsQgztTeyCRw9BxYAfM0PPW8gxi/ZjW64gw3R/c u9CZWntHTPl0NozlI7yjC7BwmtUosbRJ0xkNrcTjyVkarakRnSSMWQjNRrra6PNIy2IY ux5w0CjZxI+ChziDp9Hr1dpUJw9fIiO/oeNXUXxOkdTNQ+igt78xha601rS91AedSZKx 7S0Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b4si26253196pfa.345.2017.11.27.19.35.51; Mon, 27 Nov 2017 19:36:02 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752743AbdK1DfO convert rfc822-to-8bit (ORCPT + 77 others); Mon, 27 Nov 2017 22:35:14 -0500 Received: from prv-mh.provo.novell.com ([137.65.248.74]:58265 "EHLO prv-mh.provo.novell.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751569AbdK1DfN (ORCPT ); Mon, 27 Nov 2017 22:35:13 -0500 Received: from INET-PRV-MTA by prv-mh.provo.novell.com with Novell_GroupWise; Mon, 27 Nov 2017 20:35:12 -0700 Message-Id: <5A1D49E5020000F90009AC66@prv-mh.provo.novell.com> X-Mailer: Novell GroupWise Internet Agent 14.2.2 Date: Mon, 27 Nov 2017 20:35:01 -0700 From: "Gang He" To: , , , "Goldwyn Rodrigues" , Cc: , Subject: Re: [Ocfs2-devel] [PATCH 2/3] ocfs2: add ocfs2_overwrite_io function References: <1511775987-841-1-git-send-email-ghe@suse.com> <1511775987-841-3-git-send-email-ghe@suse.com> <123f1322-d453-4aca-ac95-63d6f90fd8a2@gmail.com> In-Reply-To: <123f1322-d453-4aca-ac95-63d6f90fd8a2@gmail.com> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 8BIT Content-Disposition: inline Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hello Joseph, >>> > Hi Gang, > > On 17/11/27 17:46, Gang He wrote: >> Add ocfs2_overwrite_io function, which is used to judge if >> overwrite allocated blocks, otherwise, the write will bring extra >> block allocation overhead. >> >> Signed-off-by: Gang He >> --- >> fs/ocfs2/extent_map.c | 67 > +++++++++++++++++++++++++++++++++++++++++++++++++++ >> fs/ocfs2/extent_map.h | 3 +++ >> 2 files changed, 70 insertions(+) >> >> diff --git a/fs/ocfs2/extent_map.c b/fs/ocfs2/extent_map.c >> index e4719e0..98bf325 100644 >> --- a/fs/ocfs2/extent_map.c >> +++ b/fs/ocfs2/extent_map.c >> @@ -832,6 +832,73 @@ int ocfs2_fiemap(struct inode *inode, struct > fiemap_extent_info *fieinfo, >> return ret; >> } >> >> +/* Is IO overwriting allocated blocks? */ >> +int ocfs2_overwrite_io(struct inode *inode, u64 map_start, u64 map_len, >> + int wait) >> +{ >> + int ret = 0, is_last; >> + u32 mapping_end, cpos; >> + struct ocfs2_super *osb = OCFS2_SB(inode->i_sb); >> + struct buffer_head *di_bh = NULL; >> + struct ocfs2_extent_rec rec; >> + >> + if (wait) >> + ret = ocfs2_inode_lock(inode, &di_bh, 0); >> + else >> + ret = ocfs2_try_inode_lock(inode, &di_bh, 0); >> + if (ret) >> + goto out; >> + >> + if (wait) >> + down_read(&OCFS2_I(inode)->ip_alloc_sem); >> + else { >> + if (!down_read_trylock(&OCFS2_I(inode)->ip_alloc_sem)) { >> + ret = -EAGAIN; >> + goto out_unlock1; >> + } >> + } >> + >> + if ((OCFS2_I(inode)->ip_dyn_features & OCFS2_INLINE_DATA_FL) && >> + ((map_start + map_len) <= i_size_read(inode))) >> + goto out_unlock2; >> + >> + cpos = map_start >> osb->s_clustersize_bits; >> + mapping_end = ocfs2_clusters_for_bytes(inode->i_sb, >> + map_start + map_len); >> + is_last = 0; >> + while (cpos < mapping_end && !is_last) { >> + ret = ocfs2_get_clusters_nocache(inode, di_bh, cpos, >> + NULL, &rec, &is_last); >> + if (ret) { >> + mlog_errno(ret); >> + goto out_unlock2; >> + } >> + >> + if (rec.e_blkno == 0ULL) >> + break; >> + >> + if (rec.e_flags & OCFS2_EXT_REFCOUNTED) >> + break; >> + >> + cpos = le32_to_cpu(rec.e_cpos) + >> + le16_to_cpu(rec.e_leaf_clusters); >> + } >> + >> + if (cpos < mapping_end) >> + ret = 1; >> + >> +out_unlock2: >> + brelse(di_bh); >> + >> + up_read(&OCFS2_I(inode)->ip_alloc_sem); >> + >> +out_unlock1: > Should brelse(di_bh) be here? If the code jumps to out_unlock1 directly, the di_bh pointer should be NULL, it is not necessary to release. > >> + ocfs2_inode_unlock(inode, 0); >> + >> +out: >> + return (ret ? 0 : 1); > I don't think EAGAIN and other error code can be handled the same. We > have to distinguish them. Ok, I think we can add one line log to report the error in case the error is not EAGAIN. > > Thanks, > Joseph > >> +} >> + >> int ocfs2_seek_data_hole_offset(struct file *file, loff_t *offset, int > whence) >> { >> struct inode *inode = file->f_mapping->host; >> diff --git a/fs/ocfs2/extent_map.h b/fs/ocfs2/extent_map.h >> index 67ea57d..fd9e86a 100644 >> --- a/fs/ocfs2/extent_map.h >> +++ b/fs/ocfs2/extent_map.h >> @@ -53,6 +53,9 @@ int ocfs2_extent_map_get_blocks(struct inode *inode, u64 > v_blkno, u64 *p_blkno, >> int ocfs2_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo, >> u64 map_start, u64 map_len); >> >> +int ocfs2_overwrite_io(struct inode *inode, u64 map_start, u64 map_len, >> + int wait); >> + >> int ocfs2_seek_data_hole_offset(struct file *file, loff_t *offset, int > origin); >> >> int ocfs2_xattr_get_clusters(struct inode *inode, u32 v_cluster, >> From 1585276495646822586@xxx Tue Nov 28 02:51:18 +0000 2017 X-GM-THRID: 1585212205986077742 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread