Re: [PATCH V4 19/20] xfsprogs: Add support for upgrading to NREXT64 feature

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 08 Jan 2022 at 23:58, Darrick J. Wong wrote:
> On Sat, Jan 08, 2022 at 09:46:08PM +0530, Chandan Babu R wrote:
>> On 08 Jan 2022 at 00:33, Darrick J. Wong wrote:
>> > On Fri, Jan 07, 2022 at 09:47:10PM +0530, Chandan Babu R wrote:
>> >> On 05 Jan 2022 at 06:47, Darrick J. Wong wrote:
>> >> > On Tue, Dec 14, 2021 at 02:18:10PM +0530, Chandan Babu R wrote:
>> >> >> This commit adds support to xfs_repair to allow upgrading an existing
>> >> >> filesystem to support per-inode large extent counters.
>> >> >> 
>> >> >> Signed-off-by: Chandan Babu R <chandan.babu@xxxxxxxxxx>
>> >> >> ---
>> >> >>  repair/globals.c    |  1 +
>> >> >>  repair/globals.h    |  1 +
>> >> >>  repair/phase2.c     | 35 ++++++++++++++++++++++++++++++++++-
>> >> >>  repair/xfs_repair.c | 11 +++++++++++
>> >> >>  4 files changed, 47 insertions(+), 1 deletion(-)
>> >> >> 
>> >> >> diff --git a/repair/globals.c b/repair/globals.c
>> >> >> index d89507b1..2f29391a 100644
>> >> >> --- a/repair/globals.c
>> >> >> +++ b/repair/globals.c
>> >> >> @@ -53,6 +53,7 @@ bool	add_bigtime;		/* add support for timestamps up to 2486 */
>> >> >>  bool	add_finobt;		/* add free inode btrees */
>> >> >>  bool	add_reflink;		/* add reference count btrees */
>> >> >>  bool	add_rmapbt;		/* add reverse mapping btrees */
>> >> >> +bool	add_nrext64;
>> >> >>  
>> >> >>  /* misc status variables */
>> >> >>  
>> >> >> diff --git a/repair/globals.h b/repair/globals.h
>> >> >> index 53ff2532..af0bcb6b 100644
>> >> >> --- a/repair/globals.h
>> >> >> +++ b/repair/globals.h
>> >> >> @@ -94,6 +94,7 @@ extern bool	add_bigtime;		/* add support for timestamps up to 2486 */
>> >> >>  extern bool	add_finobt;		/* add free inode btrees */
>> >> >>  extern bool	add_reflink;		/* add reference count btrees */
>> >> >>  extern bool	add_rmapbt;		/* add reverse mapping btrees */
>> >> >> +extern bool	add_nrext64;
>> >> >>  
>> >> >>  /* misc status variables */
>> >> >>  
>> >> >> diff --git a/repair/phase2.c b/repair/phase2.c
>> >> >> index c811ed5d..c9db3281 100644
>> >> >> --- a/repair/phase2.c
>> >> >> +++ b/repair/phase2.c
>> >> >> @@ -191,6 +191,7 @@ check_new_v5_geometry(
>> >> >>  	struct xfs_perag	*pag;
>> >> >>  	xfs_agnumber_t		agno;
>> >> >>  	xfs_ino_t		rootino;
>> >> >> +	uint			old_bm_maxlevels[2];
>> >> >>  	int			min_logblocks;
>> >> >>  	int			error;
>> >> >>  
>> >> >> @@ -201,6 +202,12 @@ check_new_v5_geometry(
>> >> >>  	memcpy(&old_sb, &mp->m_sb, sizeof(struct xfs_sb));
>> >> >>  	memcpy(&mp->m_sb, new_sb, sizeof(struct xfs_sb));
>> >> >>  
>> >> >> +	old_bm_maxlevels[0] = mp->m_bm_maxlevels[0];
>> >> >> +	old_bm_maxlevels[1] = mp->m_bm_maxlevels[1];
>> >> >> +
>> >> >> +	xfs_bmap_compute_maxlevels(mp, XFS_DATA_FORK);
>> >> >> +	xfs_bmap_compute_maxlevels(mp, XFS_ATTR_FORK);
>> >> >
>> >> > Ahh... I see why you added my (evil) patch that allows upgrading a
>> >> > filesystem to reflink -- you need the check_new_v5_geometry function so
>> >> > that you can check if the log size is big enough to handle larger bmbt
>> >> > trees.
>> >> >
>> >> > Hmm, I guess I should work on separating this from the actual
>> >> > rmap/reflink/finobt upgrade code, since I have no idea if we /ever/ want
>> >> > to support that.
>> >> >
>> >> 
>> >> I can do that. I will include the trimmed down version of the patch before
>> >> posting the patchset once again.
>> >
>> > I separated that megapatch into smaller pieces yesterday, so I'll point
>> > you to it once it all goes through QA.
>> >
>> 
>> Ok. I will wait.
>
> Here's one patch to fix a bug I found in the upgrade code, because
> apparently we weren't resyncing the secondary superblocks
>
> https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfsprogs-dev.git/commit/?h=upgrade-older-features&id=e0f4bff35adcae98943ee95701c207c628940d8f
>
> And here's an updated version of xfs_repair infrastructure you need to
> add nrext64, without the extraneous code to add other features.  It also
> now recomputes m_features and the maxlevels values so you don't have to
> do that anymore.
>
> https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfsprogs-dev.git/commit/?h=upgrade-older-features&id=acaf9c0355ee09da035845f15b4e44ba2ec24a6e
>

Thank you!

I have rebased my xfsprogs patchset on top of the above commit. I have also
removed the commits associated with atomic swapext feature though.


-- 
chandan



[Index of Archives]     [XFS Filesystem Development (older mail)]     [Linux Filesystem Development]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux RAID]     [Linux SCSI]


  Powered by Linux