mirror of
				https://git.proxmox.com/git/pve-kernel
				synced 2025-10-25 23:01:17 +00:00 
			
		
		
		
	 e64f4bfb14
			
		
	
	
		e64f4bfb14
		
	
	
	
	
		
			
			Fixes rare read corruption issues using the in kernel ceph client. On incomplete read requests, the clean tail flag should make sure to zero fill the remaining bytes for the subrequest. If the iov iterator is not at the correct position, e.g., because the subreq->transferred was not yet updated, this can however zero fill downloaded data, corrupting the read content. Link to issue: https://bugzilla.proxmox.com/show_bug.cgi?id=5683 Link to upstream issue: https://bugzilla.kernel.org/show_bug.cgi?id=219237 Signed-off-by: Christian Ebner <c.ebner@proxmox.com> [ TL: mention an specific example for subreq misalignment ] Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
		
			
				
	
	
		
			32 lines
		
	
	
		
			1003 B
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			32 lines
		
	
	
		
			1003 B
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From cd27abf0c555f39b12c05f9f6a8cb59ff25dfe45 Mon Sep 17 00:00:00 2001
 | |
| From: Christian Ebner <c.ebner@proxmox.com>
 | |
| Date: Wed, 2 Oct 2024 15:24:31 +0200
 | |
| Subject: [PATCH] netfs: reset subreq iov iter before tail clean
 | |
| 
 | |
| Make sure the iter is at the correct location when cleaning up tail
 | |
| bytes for incomplete read subrequests.
 | |
| 
 | |
| Fixes: 92b6cc5d ("netfs: Add iov_iters to (sub)requests to describe various buffers")
 | |
| Closes: https://bugzilla.kernel.org/show_bug.cgi?id=219237
 | |
| 
 | |
| Signed-off-by: Christian Ebner <c.ebner@proxmox.com>
 | |
| ---
 | |
|  fs/netfs/io.c | 1 +
 | |
|  1 file changed, 1 insertion(+)
 | |
| 
 | |
| diff --git a/fs/netfs/io.c b/fs/netfs/io.c
 | |
| index d6ada4eba744..500119285346 100644
 | |
| --- a/fs/netfs/io.c
 | |
| +++ b/fs/netfs/io.c
 | |
| @@ -528,6 +528,7 @@ void netfs_subreq_terminated(struct netfs_io_subrequest *subreq,
 | |
|  
 | |
|  incomplete:
 | |
|  	if (test_bit(NETFS_SREQ_CLEAR_TAIL, &subreq->flags)) {
 | |
| +		netfs_reset_subreq_iter(rreq, subreq);
 | |
|  		netfs_clear_unread(subreq);
 | |
|  		subreq->transferred = subreq->len;
 | |
|  		goto complete;
 | |
| -- 
 | |
| 2.39.5
 | |
| 
 |