Re: [PATCH] raid1: fix incorrect page freeing in alloc_behind_master_bio

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

 



On 05.06.23 09:21, Christoph Hellwig wrote:
> free_page takes the virtual address of the memory to be freed, and
> does so as an unsigned long just to make things confusing.  Use
> put_page instead, which actually works on the page pointer.
> 
> Note that this is a reason why this should have used __bio_add_page
> instead for this impossible to hit case..
> 
> Fixes: 2f9848178cfa ("md: raid1: use __bio_add_page for adding single page to bio")
> Signed-off-by: Christoph Hellwig <hch@xxxxxx>
> ---
>  drivers/md/raid1.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/drivers/md/raid1.c b/drivers/md/raid1.c
> index ff89839455ec11..3570da63969b58 100644
> --- a/drivers/md/raid1.c
> +++ b/drivers/md/raid1.c
> @@ -1148,7 +1148,7 @@ static void alloc_behind_master_bio(struct r1bio *r1_bio,
>  			goto free_pages;
>  
>  		if (!bio_add_page(behind_bio, page, len, 0)) {
> -			free_page(page);
> +			put_page(page);
>  			goto free_pages;
>  		}
>  

That should already be fixed in Jens' tree.




[Index of Archives]     [Linux RAID Wiki]     [ATA RAID]     [Linux SCSI Target Infrastructure]     [Linux Block]     [Linux IDE]     [Linux SCSI]     [Linux Hams]     [Device Mapper]     [Device Mapper Cryptographics]     [Kernel]     [Linux Admin]     [Linux Net]     [GFS]     [RPM]     [git]     [Yosemite Forum]


  Powered by Linux