All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 5.10.y] xfs: add bounds checking to xlog_recover_process_data
@ 2025-04-23  2:13 Zhi Yang
  2025-04-23  6:48 ` Greg KH
  2025-04-23 12:16 ` Sasha Levin
  0 siblings, 2 replies; 6+ messages in thread
From: Zhi Yang @ 2025-04-23  2:13 UTC (permalink / raw)
  To: stable, llfamsec
  Cc: zhe.he, xiangyu.chen, amir73il, djwong, dchinner, chandanbabu,
	linux-xfs, linux-kernel

From: lei lu <llfamsec@gmail.com>

commit fb63435b7c7dc112b1ae1baea5486e0a6e27b196 upstream.

There is a lack of verification of the space occupied by fixed members
of xlog_op_header in the xlog_recover_process_data.

We can create a crafted image to trigger an out of bounds read by
following these steps:
    1) Mount an image of xfs, and do some file operations to leave records
    2) Before umounting, copy the image for subsequent steps to simulate
       abnormal exit. Because umount will ensure that tail_blk and
       head_blk are the same, which will result in the inability to enter
       xlog_recover_process_data
    3) Write a tool to parse and modify the copied image in step 2
    4) Make the end of the xlog_op_header entries only 1 byte away from
       xlog_rec_header->h_size
    5) xlog_rec_header->h_num_logops++
    6) Modify xlog_rec_header->h_crc

Fix:
Add a check to make sure there is sufficient space to access fixed members
of xlog_op_header.

Signed-off-by: lei lu <llfamsec@gmail.com>
Reviewed-by: Dave Chinner <dchinner@redhat.com>
Reviewed-by: Darrick J. Wong <djwong@kernel.org>
Signed-off-by: Chandan Babu R <chandanbabu@kernel.org>
Signed-off-by: Zhi Yang <Zhi.Yang@windriver.com>
Signed-off-by: He Zhe <zhe.he@windriver.com>
---
Build test passed.
---
 fs/xfs/xfs_log_recover.c | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

diff --git a/fs/xfs/xfs_log_recover.c b/fs/xfs/xfs_log_recover.c
index e61f28ce3e44..eafe76f304ef 100644
--- a/fs/xfs/xfs_log_recover.c
+++ b/fs/xfs/xfs_log_recover.c
@@ -2419,7 +2419,10 @@ xlog_recover_process_data(
 
 		ohead = (struct xlog_op_header *)dp;
 		dp += sizeof(*ohead);
-		ASSERT(dp <= end);
+		if (dp > end) {
+			xfs_warn(log->l_mp, "%s: op header overrun", __func__);
+			return -EFSCORRUPTED;
+		}
 
 		/* errors will abort recovery */
 		error = xlog_recover_process_ophdr(log, rhash, rhead, ohead,
-- 
2.34.1


^ permalink raw reply related	[flat|nested] 6+ messages in thread

* Re: [PATCH 5.10.y] xfs: add bounds checking to xlog_recover_process_data
  2025-04-23  2:13 [PATCH 5.10.y] xfs: add bounds checking to xlog_recover_process_data Zhi Yang
@ 2025-04-23  6:48 ` Greg KH
       [not found]   ` <DM6PR11MB3324E74F9DF280B6E13914619FBA2@DM6PR11MB3324.namprd11.prod.outlook.com>
  2025-04-23 12:16 ` Sasha Levin
  1 sibling, 1 reply; 6+ messages in thread
From: Greg KH @ 2025-04-23  6:48 UTC (permalink / raw)
  To: Zhi Yang
  Cc: stable, llfamsec, zhe.he, xiangyu.chen, amir73il, djwong,
	dchinner, chandanbabu, linux-xfs, linux-kernel

On Wed, Apr 23, 2025 at 10:13:25AM +0800, Zhi Yang wrote:
> From: lei lu <llfamsec@gmail.com>
> 
> commit fb63435b7c7dc112b1ae1baea5486e0a6e27b196 upstream.

All xfs stable patches must be acked by the xfs stable maintainer for
inclusion.

thanks,

greg k-h

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [PATCH 5.10.y] xfs: add bounds checking to xlog_recover_process_data
       [not found]   ` <DM6PR11MB3324E74F9DF280B6E13914619FBA2@DM6PR11MB3324.namprd11.prod.outlook.com>
@ 2025-04-23  7:29     ` Greg KH
  0 siblings, 0 replies; 6+ messages in thread
From: Greg KH @ 2025-04-23  7:29 UTC (permalink / raw)
  To: Yang, Zhi
  Cc: cem@kernel.org, stable@vger.kernel.org, llfamsec@gmail.com,
	He, Zhe, Chen, Xiangyu, amir73il@gmail.com, djwong@kernel.org,
	dchinner@redhat.com, chandanbabu@kernel.org,
	linux-xfs@vger.kernel.org, linux-kernel@vger.kernel.org

On Wed, Apr 23, 2025 at 07:24:41AM +0000, Yang, Zhi wrote:
> Add xfs stable maintainer.

That provided no context at all.  Please do this properly.

^ permalink raw reply	[flat|nested] 6+ messages in thread

* [PATCH 5.10.y] xfs: add bounds checking to xlog_recover_process_data
@ 2025-04-23  7:45 Zhi Yang
  2025-04-23 12:16 ` Sasha Levin
  0 siblings, 1 reply; 6+ messages in thread
From: Zhi Yang @ 2025-04-23  7:45 UTC (permalink / raw)
  To: stable, llfamsec, cem
  Cc: zhe.he, xiangyu.chen, amir73il, djwong, dchinner, chandanbabu,
	linux-xfs, linux-kernel

From: lei lu <llfamsec@gmail.com>

commit fb63435b7c7dc112b1ae1baea5486e0a6e27b196 upstream.

There is a lack of verification of the space occupied by fixed members
of xlog_op_header in the xlog_recover_process_data.

We can create a crafted image to trigger an out of bounds read by
following these steps:
    1) Mount an image of xfs, and do some file operations to leave records
    2) Before umounting, copy the image for subsequent steps to simulate
       abnormal exit. Because umount will ensure that tail_blk and
       head_blk are the same, which will result in the inability to enter
       xlog_recover_process_data
    3) Write a tool to parse and modify the copied image in step 2
    4) Make the end of the xlog_op_header entries only 1 byte away from
       xlog_rec_header->h_size
    5) xlog_rec_header->h_num_logops++
    6) Modify xlog_rec_header->h_crc

Fix:
Add a check to make sure there is sufficient space to access fixed members
of xlog_op_header.

Signed-off-by: lei lu <llfamsec@gmail.com>
Reviewed-by: Dave Chinner <dchinner@redhat.com>
Reviewed-by: Darrick J. Wong <djwong@kernel.org>
Signed-off-by: Chandan Babu R <chandanbabu@kernel.org>
Signed-off-by: Zhi Yang <Zhi.Yang@windriver.com>
Signed-off-by: He Zhe <zhe.he@windriver.com>
---
Build test passed.
---
 fs/xfs/xfs_log_recover.c | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

diff --git a/fs/xfs/xfs_log_recover.c b/fs/xfs/xfs_log_recover.c
index e61f28ce3e44..eafe76f304ef 100644
--- a/fs/xfs/xfs_log_recover.c
+++ b/fs/xfs/xfs_log_recover.c
@@ -2419,7 +2419,10 @@ xlog_recover_process_data(
 
 		ohead = (struct xlog_op_header *)dp;
 		dp += sizeof(*ohead);
-		ASSERT(dp <= end);
+		if (dp > end) {
+			xfs_warn(log->l_mp, "%s: op header overrun", __func__);
+			return -EFSCORRUPTED;
+		}
 
 		/* errors will abort recovery */
 		error = xlog_recover_process_ophdr(log, rhash, rhead, ohead,
-- 
2.34.1


^ permalink raw reply related	[flat|nested] 6+ messages in thread

* Re: [PATCH 5.10.y] xfs: add bounds checking to xlog_recover_process_data
  2025-04-23  2:13 [PATCH 5.10.y] xfs: add bounds checking to xlog_recover_process_data Zhi Yang
  2025-04-23  6:48 ` Greg KH
@ 2025-04-23 12:16 ` Sasha Levin
  1 sibling, 0 replies; 6+ messages in thread
From: Sasha Levin @ 2025-04-23 12:16 UTC (permalink / raw)
  To: stable; +Cc: Zhi Yang, Sasha Levin

[ Sasha's backport helper bot ]

Hi,

✅ All tests passed successfully. No issues detected.
No action required from the submitter.

The upstream commit SHA1 provided is correct: fb63435b7c7dc112b1ae1baea5486e0a6e27b196

WARNING: Author mismatch between patch and upstream commit:
Backport author: Zhi Yang<Zhi.Yang@eng.windriver.com>
Commit author: lei lu<llfamsec@gmail.com>

Status in newer kernel trees:
6.14.y | Present (exact SHA1)
6.12.y | Present (exact SHA1)
6.6.y | Present (different SHA1: 7cd9f0a33e73)
6.1.y | Present (different SHA1: d1e3efe78336)
5.15.y | Not found

Note: The patch differs from the upstream commit:
---
1:  fb63435b7c7dc ! 1:  cf9831ea2bc08 xfs: add bounds checking to xlog_recover_process_data
    @@ Metadata
      ## Commit message ##
         xfs: add bounds checking to xlog_recover_process_data
     
    +    commit fb63435b7c7dc112b1ae1baea5486e0a6e27b196 upstream.
    +
         There is a lack of verification of the space occupied by fixed members
         of xlog_op_header in the xlog_recover_process_data.
     
    @@ Commit message
         Reviewed-by: Dave Chinner <dchinner@redhat.com>
         Reviewed-by: Darrick J. Wong <djwong@kernel.org>
         Signed-off-by: Chandan Babu R <chandanbabu@kernel.org>
    +    Signed-off-by: Zhi Yang <Zhi.Yang@windriver.com>
    +    Signed-off-by: He Zhe <zhe.he@windriver.com>
     
      ## fs/xfs/xfs_log_recover.c ##
     @@ fs/xfs/xfs_log_recover.c: xlog_recover_process_data(
---

Results of testing on various branches:

| Branch                    | Patch Apply | Build Test |
|---------------------------|-------------|------------|
| stable/linux-5.10.y       |  Success    |  Success   |

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [PATCH 5.10.y] xfs: add bounds checking to xlog_recover_process_data
  2025-04-23  7:45 Zhi Yang
@ 2025-04-23 12:16 ` Sasha Levin
  0 siblings, 0 replies; 6+ messages in thread
From: Sasha Levin @ 2025-04-23 12:16 UTC (permalink / raw)
  To: stable; +Cc: Zhi Yang, Sasha Levin

[ Sasha's backport helper bot ]

Hi,

✅ All tests passed successfully. No issues detected.
No action required from the submitter.

The upstream commit SHA1 provided is correct: fb63435b7c7dc112b1ae1baea5486e0a6e27b196

WARNING: Author mismatch between patch and upstream commit:
Backport author: Zhi Yang<Zhi.Yang@eng.windriver.com>
Commit author: lei lu<llfamsec@gmail.com>

Status in newer kernel trees:
6.14.y | Present (exact SHA1)
6.12.y | Present (exact SHA1)
6.6.y | Present (different SHA1: 7cd9f0a33e73)
6.1.y | Present (different SHA1: d1e3efe78336)
5.15.y | Not found

Note: The patch differs from the upstream commit:
---
1:  fb63435b7c7dc ! 1:  12b817c219a30 xfs: add bounds checking to xlog_recover_process_data
    @@ Metadata
      ## Commit message ##
         xfs: add bounds checking to xlog_recover_process_data
     
    +    commit fb63435b7c7dc112b1ae1baea5486e0a6e27b196 upstream.
    +
         There is a lack of verification of the space occupied by fixed members
         of xlog_op_header in the xlog_recover_process_data.
     
    @@ Commit message
         Reviewed-by: Dave Chinner <dchinner@redhat.com>
         Reviewed-by: Darrick J. Wong <djwong@kernel.org>
         Signed-off-by: Chandan Babu R <chandanbabu@kernel.org>
    +    Signed-off-by: Zhi Yang <Zhi.Yang@windriver.com>
    +    Signed-off-by: He Zhe <zhe.he@windriver.com>
     
      ## fs/xfs/xfs_log_recover.c ##
     @@ fs/xfs/xfs_log_recover.c: xlog_recover_process_data(
---

Results of testing on various branches:

| Branch                    | Patch Apply | Build Test |
|---------------------------|-------------|------------|
| stable/linux-5.10.y       |  Success    |  Success   |

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2025-04-23 12:16 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-04-23  2:13 [PATCH 5.10.y] xfs: add bounds checking to xlog_recover_process_data Zhi Yang
2025-04-23  6:48 ` Greg KH
     [not found]   ` <DM6PR11MB3324E74F9DF280B6E13914619FBA2@DM6PR11MB3324.namprd11.prod.outlook.com>
2025-04-23  7:29     ` Greg KH
2025-04-23 12:16 ` Sasha Levin
  -- strict thread matches above, loose matches on Subject: below --
2025-04-23  7:45 Zhi Yang
2025-04-23 12:16 ` Sasha Levin

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.