• Qu Wenruo's avatar
    btrfs: determine stripe boundary at bio allocation time in btrfs_submit_compressed_read · f472c28f
    Qu Wenruo authored
    Currently btrfs_submit_compressed_read() will check
    btrfs_bio_fits_in_stripe() each time a new page is going to be added.
    Even if compressed extent is small, we don't really need to do that for
    every page.
    
    This patch will align the behavior to extent_io.c, by determining the
    stripe boundary when allocating a bio.
    
    Unlike extent_io.c, in compressed.c we don't need to bother things like
    different bio flags, thus no need to re-use bio_ctrl.
    
    Here we just manually introduce new local variable, next_stripe_start,
    and teach alloc_compressed_bio() to calculate the stripe boundary.
    
    Then each time we add some page range into the bio, we check if we
    reached the boundary.  And if reached, submit it.
    
    Also, since we have @cur_disk_byte to determine whether we're the last
    bio, we don't need a explicit last_bio: tag for error handling any more.
    
    And we can use @cur_disk_byte to track which range has been added to
    bio, we can also use @cur_disk_byte to calculate the wait condition, no
    need for @pending_bios.
    Signed-off-by: default avatarQu Wenruo <wqu@suse.com>
    Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
    f472c28f
compression.c 50 KB