}
 }
 
+static void clear_extent_buffer_reading(struct extent_buffer *eb)
+{
+       clear_bit(EXTENT_BUFFER_READING, &eb->bflags);
+       smp_mb__after_atomic();
+       wake_up_bit(&eb->bflags, EXTENT_BUFFER_READING);
+}
+
 static void end_bbio_meta_read(struct btrfs_bio *bbio)
 {
        struct extent_buffer *eb = bbio->private;
                bio_offset += len;
        }
 
-       clear_bit(EXTENT_BUFFER_READING, &eb->bflags);
-       smp_mb__after_atomic();
-       wake_up_bit(&eb->bflags, EXTENT_BUFFER_READING);
+       clear_extent_buffer_reading(eb);
        free_extent_buffer(eb);
 
        bio_put(&bbio->bio);
         * will now be set, and we shouldn't read it in again.
         */
        if (unlikely(test_bit(EXTENT_BUFFER_UPTODATE, &eb->bflags))) {
-               clear_bit(EXTENT_BUFFER_READING, &eb->bflags);
-               smp_mb__after_atomic();
-               wake_up_bit(&eb->bflags, EXTENT_BUFFER_READING);
+               clear_extent_buffer_reading(eb);
                return 0;
        }