[PATCH v2] xfs: check the remaining length of extent after roundup

Jinliang Zheng posted 1 patch 2 weeks, 2 days ago
fs/xfs/libxfs/xfs_alloc.c | 5 ++++-
1 file changed, 4 insertions(+), 1 deletion(-)
[PATCH v2] xfs: check the remaining length of extent after roundup
Posted by Jinliang Zheng 2 weeks, 2 days ago
In xfs_alloc_compute_diff(), ensure that the remaining length of extent
still meets the wantlen requirements after newbno1 is rounded.

Signed-off-by: Jinliang Zheng <alexjlzheng@tencent.com>
---
Changelog:

V2: Fix the error logic

V1: https://lore.kernel.org/linux-xfs/20241107070300.13535-1-alexjlzheng@tencent.com/#R
---
 fs/xfs/libxfs/xfs_alloc.c | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

diff --git a/fs/xfs/libxfs/xfs_alloc.c b/fs/xfs/libxfs/xfs_alloc.c
index 22bdbb3e9980..1d4cc75b7318 100644
--- a/fs/xfs/libxfs/xfs_alloc.c
+++ b/fs/xfs/libxfs/xfs_alloc.c
@@ -393,7 +393,8 @@ xfs_alloc_compute_diff(
 	 * grows in the short term.
 	 */
 	if (freebno >= wantbno || (userdata && freeend < wantend)) {
-		if ((newbno1 = roundup(freebno, alignment)) >= freeend)
+		newbno1 = roundup(freebno, alignment);
+		if (newbno1 >= freeend || newbno1 > freeend - wantlen)
 			newbno1 = NULLAGBLOCK;
 	} else if (freeend >= wantend && alignment > 1) {
 		newbno1 = roundup(wantbno, alignment);
@@ -414,6 +415,8 @@ xfs_alloc_compute_diff(
 				newbno1 = newbno2;
 		} else if (newbno2 != NULLAGBLOCK)
 			newbno1 = newbno2;
+		if (newbno1 > freeend - wantlen)
+			newbno1 = NULLAGBLOCK;
 	} else if (freeend >= wantend) {
 		newbno1 = wantbno;
 	} else if (alignment > 1) {
-- 
2.41.1
Re: [PATCH v2] xfs: check the remaining length of extent after roundup
Posted by Darrick J. Wong 2 weeks, 2 days ago
On Thu, Nov 07, 2024 at 04:40:44PM +0800, Jinliang Zheng wrote:
> In xfs_alloc_compute_diff(), ensure that the remaining length of extent
> still meets the wantlen requirements after newbno1 is rounded.

What problem are you observing?

--D

> Signed-off-by: Jinliang Zheng <alexjlzheng@tencent.com>
> ---
> Changelog:
> 
> V2: Fix the error logic
> 
> V1: https://lore.kernel.org/linux-xfs/20241107070300.13535-1-alexjlzheng@tencent.com/#R
> ---
>  fs/xfs/libxfs/xfs_alloc.c | 5 ++++-
>  1 file changed, 4 insertions(+), 1 deletion(-)
> 
> diff --git a/fs/xfs/libxfs/xfs_alloc.c b/fs/xfs/libxfs/xfs_alloc.c
> index 22bdbb3e9980..1d4cc75b7318 100644
> --- a/fs/xfs/libxfs/xfs_alloc.c
> +++ b/fs/xfs/libxfs/xfs_alloc.c
> @@ -393,7 +393,8 @@ xfs_alloc_compute_diff(
>  	 * grows in the short term.
>  	 */
>  	if (freebno >= wantbno || (userdata && freeend < wantend)) {
> -		if ((newbno1 = roundup(freebno, alignment)) >= freeend)
> +		newbno1 = roundup(freebno, alignment);
> +		if (newbno1 >= freeend || newbno1 > freeend - wantlen)
>  			newbno1 = NULLAGBLOCK;
>  	} else if (freeend >= wantend && alignment > 1) {
>  		newbno1 = roundup(wantbno, alignment);
> @@ -414,6 +415,8 @@ xfs_alloc_compute_diff(
>  				newbno1 = newbno2;
>  		} else if (newbno2 != NULLAGBLOCK)
>  			newbno1 = newbno2;
> +		if (newbno1 > freeend - wantlen)
> +			newbno1 = NULLAGBLOCK;
>  	} else if (freeend >= wantend) {
>  		newbno1 = wantbno;
>  	} else if (alignment > 1) {
> -- 
> 2.41.1
> 
>
Re: [PATCH v2] xfs: check the remaining length of extent after roundup
Posted by Jinliang Zheng 2 weeks, 1 day ago
On Thu, 7 Nov 2024 12:05:39 -0800, Darrick J. Wong wrote:
> On Thu, Nov 07, 2024 at 04:40:44PM +0800, Jinliang Zheng wrote:
> > In xfs_alloc_compute_diff(), ensure that the remaining length of extent
> > still meets the wantlen requirements after newbno1 is rounded.
> 
> What problem are you observing?
> 
> --D

Thank you for your reply. :)

In fact, I haven't encountered any issues with this in production.

My starting point is I was wondering what will happen if
xfs_alloc_compute_diff()'s changes to bnew cause the extent's remaining
length to be less than args->len?

I wonder if this will happen? Am I missing some code to ensure this doesn't
happen?

If it will happen, I think we'd better check it out here; if it doesn't,
please ignore this patch.

Thank you again.
Jinliang Zheng :)

> 
> > Signed-off-by: Jinliang Zheng <alexjlzheng@tencent.com>
> > ---
> > Changelog:
> > 
> > V2: Fix the error logic
> > 
> > V1: https://lore.kernel.org/linux-xfs/20241107070300.13535-1-alexjlzheng@tencent.com/#R
> > ---
> >  fs/xfs/libxfs/xfs_alloc.c | 5 ++++-
> >  1 file changed, 4 insertions(+), 1 deletion(-)
> > 
> > diff --git a/fs/xfs/libxfs/xfs_alloc.c b/fs/xfs/libxfs/xfs_alloc.c
> > index 22bdbb3e9980..1d4cc75b7318 100644
> > --- a/fs/xfs/libxfs/xfs_alloc.c
> > +++ b/fs/xfs/libxfs/xfs_alloc.c
> > @@ -393,7 +393,8 @@ xfs_alloc_compute_diff(
> >  	 * grows in the short term.
> >  	 */
> >  	if (freebno >= wantbno || (userdata && freeend < wantend)) {
> > -		if ((newbno1 = roundup(freebno, alignment)) >= freeend)
> > +		newbno1 = roundup(freebno, alignment);
> > +		if (newbno1 >= freeend || newbno1 > freeend - wantlen)
> >  			newbno1 = NULLAGBLOCK;
> >  	} else if (freeend >= wantend && alignment > 1) {
> >  		newbno1 = roundup(wantbno, alignment);
> > @@ -414,6 +415,8 @@ xfs_alloc_compute_diff(
> >  				newbno1 = newbno2;
> >  		} else if (newbno2 != NULLAGBLOCK)
> >  			newbno1 = newbno2;
> > +		if (newbno1 > freeend - wantlen)
> > +			newbno1 = NULLAGBLOCK;
> >  	} else if (freeend >= wantend) {
> >  		newbno1 = wantbno;
> >  	} else if (alignment > 1) {
> > -- 
> > 2.41.1
> > 
> >