[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20240514113847.1b2d6226@canb.auug.org.au>
Date: Tue, 14 May 2024 11:38:47 +1000
From: Stephen Rothwell <sfr@...b.auug.org.au>
To: David Sterba <dsterba@...e.cz>, Al Viro <viro@...iv.linux.org.uk>
Cc: Christian Brauner <brauner@...nel.org>, David Sterba <dsterba@...e.com>,
 Linux Kernel Mailing List <linux-kernel@...r.kernel.org>, Linux Next
 Mailing List <linux-next@...r.kernel.org>, "Matthew Wilcox (Oracle)"
 <willy@...radead.org>
Subject: Re: linux-next: manual merge of the vfs-brauner tree with the btrfs
 tree
Hi all,
On Fri, 3 May 2024 11:00:01 +1000 Stephen Rothwell <sfr@...b.auug.org.au> wrote:
>
> Today's linux-next merge of the vfs-brauner tree got a conflict in:
> 
>   fs/btrfs/disk-io.c
> 
> between commits:
> 
>   4a63bd0ffbd2 ("btrfs: convert super block writes to folio in wait_dev_supers()")
>   545799bb1bb9 ("btrfs: count super block write errors in device instead of tracking folio error state")
> 
> from the btrfs tree and commit:
> 
>   db3102368e1b ("use ->bd_mapping instead of ->bd_inode->i_mapping")
> 
> from the vfs-brauner tree.
> 
> I fixed it up (see below) and can carry the fix as necessary. This
> is now fixed as far as linux-next is concerned, but any non trivial
> conflicts should be mentioned to your upstream maintainer when your tree
> is submitted for merging.  You may also want to consider cooperating
> with the maintainer of the conflicting tree to minimise any particularly
> complex conflicts.
> 
> 
> diff --cc fs/btrfs/disk-io.c
> index e8aca9f0e692,f10e894b0bf5..000000000000
> --- a/fs/btrfs/disk-io.c
> +++ b/fs/btrfs/disk-io.c
> @@@ -3739,9 -3738,10 +3739,9 @@@ static int write_dev_supers(struct btrf
>   			    struct btrfs_super_block *sb, int max_mirrors)
>   {
>   	struct btrfs_fs_info *fs_info = device->fs_info;
> - 	struct address_space *mapping = device->bdev->bd_inode->i_mapping;
> + 	struct address_space *mapping = device->bdev->bd_mapping;
>   	SHASH_DESC_ON_STACK(shash, fs_info->csum_shash);
>   	int i;
>  -	int errors = 0;
>   	int ret;
>   	u64 bytenr, bytenr_orig;
>   
> @@@ -3857,21 -3855,30 +3857,21 @@@ static int wait_dev_supers(struct btrfs
>   		    device->commit_total_bytes)
>   			break;
>   
> - 		folio = filemap_get_folio(device->bdev->bd_inode->i_mapping,
>  -		page = find_get_page(device->bdev->bd_mapping,
>  -				     bytenr >> PAGE_SHIFT);
>  -		if (!page) {
>  -			errors++;
>  -			if (i == 0)
>  -				primary_failed = true;
> ++		folio = filemap_get_folio(device->bdev->bd_mapping,
>  +					  bytenr >> PAGE_SHIFT);
>  +		/* If the folio has been removed, then we know it completed. */
>  +		if (IS_ERR(folio))
>   			continue;
>  -		}
>  -		/* Page is submitted locked and unlocked once the IO completes */
>  -		wait_on_page_locked(page);
>  -		if (PageError(page)) {
>  -			errors++;
>  -			if (i == 0)
>  -				primary_failed = true;
>  -		}
>  +		ASSERT(folio_order(folio) == 0);
>   
>  -		/* Drop our reference */
>  -		put_page(page);
>  -
>  -		/* Drop the reference from the writing run */
>  -		put_page(page);
>  +		/* Folio will be unlocked once the write completes. */
>  +		folio_wait_locked(folio);
>  +		folio_put(folio);
>   	}
>   
>  -	/* log error, force error return */
>  +	errors += atomic_read(&device->sb_write_errors);
>  +	if (errors >= BTRFS_SUPER_PRIMARY_WRITE_ERROR)
>  +		primary_failed = true;
>   	if (primary_failed) {
>   		btrfs_err(device->fs_info, "error writing primary super block to device %llu",
>   			  device->devid);
This is now a conflict between the vfs tree and the btrfs tree.
-- 
Cheers,
Stephen Rothwell
Content of type "application/pgp-signature" skipped
Powered by blists - more mailing lists
 
