diff mbox

Btrfs: use WARN_ON_ONCE instead for btrfs_invalidate_inodes

Message ID 1388389874-29141-1-git-send-email-bo.li.liu@oracle.com (mailing list archive)
State New, archived
Headers show

Commit Message

Liu Bo Dec. 30, 2013, 7:51 a.m. UTC
So after transaction is aborted, we need to cleanup inode resources by
calling btrfs_invalidate_inodes(), and btrfs_invalidate_inodes() hopes
roots' refs to be zero in old times and sets a WARN_ON(), however, this
is not always true within cleaning up transaction, so WARN_ON_ONCE() is
better, and we won't get another syslog message bomb.

Signed-off-by: Liu Bo <bo.li.liu@oracle.com>
---
 fs/btrfs/inode.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

Comments

Josef Bacik Jan. 5, 2014, 12:40 a.m. UTC | #1
On 12/30/2013 02:51 AM, Liu Bo wrote:
> So after transaction is aborted, we need to cleanup inode resources by
> calling btrfs_invalidate_inodes(), and btrfs_invalidate_inodes() hopes
> roots' refs to be zero in old times and sets a WARN_ON(), however, this
> is not always true within cleaning up transaction, so WARN_ON_ONCE() is
> better, and we won't get another syslog message bomb.
>
> Signed-off-by: Liu Bo <bo.li.liu@oracle.com>
> ---
>   fs/btrfs/inode.c | 2 +-
>   1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c
> index f1a7744..ef7f6af 100644
> --- a/fs/btrfs/inode.c
> +++ b/fs/btrfs/inode.c
> @@ -4761,7 +4761,7 @@ void btrfs_invalidate_inodes(struct btrfs_root *root)
>   	struct inode *inode;
>   	u64 objectid = 0;
>   
> -	WARN_ON(btrfs_root_refs(&root->root_item) != 0);
> +	WARN_ON_ONCE(btrfs_root_refs(&root->root_item) != 0);
>   
>   	spin_lock(&root->inode_lock);
>   again:

I'd rather just detect that we're cleaning up for an abort and not warn 
at all.  Thanks,

Josef
--
To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c
index f1a7744..ef7f6af 100644
--- a/fs/btrfs/inode.c
+++ b/fs/btrfs/inode.c
@@ -4761,7 +4761,7 @@  void btrfs_invalidate_inodes(struct btrfs_root *root)
 	struct inode *inode;
 	u64 objectid = 0;
 
-	WARN_ON(btrfs_root_refs(&root->root_item) != 0);
+	WARN_ON_ONCE(btrfs_root_refs(&root->root_item) != 0);
 
 	spin_lock(&root->inode_lock);
 again: