void bvec_free_bs(struct bio_set *bs, struct bio_vec *bv, unsigned int idx) { BIO_BUG_ON(idx >= BIOVEC_NR_POOLS); if (idx == BIOVEC_MAX_IDX) mempool_free(bv, bs->bvec_pool); else { struct biovec_slab *bvs = bvec_slabs + idx; kmem_cache_free(bvs->slab, bv); } }
void bio_free(struct bio *bio, struct bio_set *bio_set) { if (bio->bi_io_vec) { const int pool_idx = BIO_POOL_IDX(bio); BIO_BUG_ON(pool_idx >= BIOVEC_NR_POOLS); mempool_free(bio->bi_io_vec, bio_set->bvec_pools[pool_idx]); } if (bio_integrity(bio)) bio_integrity_free(bio, bio_set); mempool_free(bio, bio_set->bio_pool); }
void bvec_free(mempool_t *pool, struct bio_vec *bv, unsigned int idx) { if (!idx) return; idx--; BIO_BUG_ON(idx >= BVEC_POOL_NR); if (idx == BVEC_POOL_MAX) { mempool_free(bv, pool); } else { struct biovec_slab *bvs = bvec_slabs + idx; kmem_cache_free(bvs->slab, bv); } }