Message ID | 20241128170056565nPKSz2vsP8K8X2uk2iaDG@zte.com.cn (mailing list archive) |
---|---|
State | New |
Headers | show |
Series | brd: decrease the number of allocated pages which discarded | expand |
On Thu, Nov 28, 2024 at 5:01 PM <long.yunjian@zte.com.cn> wrote: > > From: Zhang Xianwei <zhang.xianwei8@zte.com.cn> > The number of allocated pages which discarded will not decrease. > Fix it. > > Fixes: 9ead7efc6f3f ("brd: implement discard support") > > Signed-off-by: Zhang Xianwei <zhang.xianwei8@zte.com.cn> > --- > drivers/block/brd.c | 4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) > > diff --git a/drivers/block/brd.c b/drivers/block/brd.c > index 5a95671d8151..292f127cae0a 100644 > --- a/drivers/block/brd.c > +++ b/drivers/block/brd.c > @@ -231,8 +231,10 @@ static void brd_do_discard(struct brd_device *brd, sector_t sector, u32 size) > xa_lock(&brd->brd_pages); > while (size >= PAGE_SIZE && aligned_sector < rd_size * 2) { > page = __xa_erase(&brd->brd_pages, aligned_sector >> PAGE_SECTORS_SHIFT); > - if (page) > + if (page) { > __free_page(page); > + brd->brd_nr_pages--; > + } Reviewed-by: Ming Lei <ming.lei@redhat.com>
diff --git a/drivers/block/brd.c b/drivers/block/brd.c index 5a95671d8151..292f127cae0a 100644 --- a/drivers/block/brd.c +++ b/drivers/block/brd.c @@ -231,8 +231,10 @@ static void brd_do_discard(struct brd_device *brd, sector_t sector, u32 size) xa_lock(&brd->brd_pages); while (size >= PAGE_SIZE && aligned_sector < rd_size * 2) { page = __xa_erase(&brd->brd_pages, aligned_sector >> PAGE_SECTORS_SHIFT); - if (page) + if (page) { __free_page(page); + brd->brd_nr_pages--; + } aligned_sector += PAGE_SECTORS; size -= PAGE_SIZE; }