On 2020/5/15 12:14, Matthew Wilcox wrote:
> On Thu, May 07, 2020 at 03:50:56PM +0800, Zhen Lei wrote:
>> +++ b/mm/page_io.c
>> @@ -38,7 +38,7 @@ static struct bio *get_swap_bio(gfp_t gfp_flags,
>>  
>>              bio->bi_iter.bi_sector = map_swap_page(page, &bdev);
>>              bio_set_dev(bio, bdev);
>> -            bio->bi_iter.bi_sector <<= PAGE_SHIFT - 9;
>> +            bio->bi_iter.bi_sector *= PAGE_SECTORS;
>>              bio->bi_end_io = end_io;
> 
> This just doesn't look right.  Why is map_swap_page() returning a sector_t
> which isn't actually a sector_t?

I try to understand map_swap_page(). Here maybe a bug. Otherwise, it would be
better to add a temporary variable to cache the return value of 
map_swap_page(page, &bdev).

> 
> 
> .
> 

Reply via email to