<!DOCTYPE html>
<html>
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  </head>
  <body>
    <br>
    <div class="moz-cite-prefix">14/09/23 12:45, Anastasia Belova пишет:<br>
    </div>
    <blockquote type="cite"
      cite="mid:20230914094555.25657-1-abelova@astralinux.ru">
      <pre wrap="" class="moz-quote-pre">count_bitmap_extents was deleted in version 5.11, but
there is possible mistake in versions 5.6-5.10.

Region size should be calculated by subtracting
the end from the beginning.</pre>
    </blockquote>
    Do I understand correctly that bytes should decrease and<br>
    (rs - re) is always negative and should be replaced by (re - rs)? <br>
    <blockquote type="cite"
      cite="mid:20230914094555.25657-1-abelova@astralinux.ru">
      <pre wrap="" class="moz-quote-pre">

Found by Linux Verification Center (linuxtesting.org) with SVACE.

Fixes: dfb79ddb130e ("btrfs: track discardable extents for async discard")
Signed-off-by: Anastasia Belova <a class="moz-txt-link-rfc2396E" href="mailto:abelova@astralinux.ru"><abelova@astralinux.ru></a>
---
 fs/btrfs/free-space-cache.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/fs/btrfs/free-space-cache.c b/fs/btrfs/free-space-cache.c
index 4989c60b1df9..a34e266a0969 100644
--- a/fs/btrfs/free-space-cache.c
+++ b/fs/btrfs/free-space-cache.c
@@ -1930,7 +1930,7 @@ static int count_bitmap_extents(struct btrfs_free_space_ctl *ctl,
 
        bitmap_for_each_set_region(bitmap_info->bitmap, rs, re, 0,
                                   BITS_PER_BITMAP) {
-               bytes -= (rs - re) * ctl->unit;
+               bytes -= (re - rs) * ctl->unit;
                count++;
 
                if (!bytes)
</pre>
    </blockquote>
    Anastasia<br>
  </body>
</html>