diff options
author | Eric Biggers <[email protected]> | 2020-09-15 20:53:13 -0700 |
---|---|---|
committer | Jens Axboe <[email protected]> | 2020-10-05 10:47:43 -0600 |
commit | 07560151db960d26b425410d6fd778e6757a5da2 (patch) | |
tree | 2d8582959d8765348d923e745a187983f6c01aaf /net/unix/unix_bpf.c | |
parent | 10ed16662da9e28a33b6c991c36c6b323b03dd5b (diff) |
block: make bio_crypt_clone() able to fail
bio_crypt_clone() assumes its gfp_mask argument always includes
__GFP_DIRECT_RECLAIM, so that the mempool_alloc() will always succeed.
However, bio_crypt_clone() might be called with GFP_ATOMIC via
setup_clone() in drivers/md/dm-rq.c, or with GFP_NOWAIT via
kcryptd_io_read() in drivers/md/dm-crypt.c.
Neither case is currently reachable with a bio that actually has an
encryption context. However, it's fragile to rely on this. Just make
bio_crypt_clone() able to fail, analogous to bio_integrity_clone().
Reported-by: Miaohe Lin <[email protected]>
Signed-off-by: Eric Biggers <[email protected]>
Reviewed-by: Mike Snitzer <[email protected]>
Reviewed-by: Satya Tangirala <[email protected]>
Cc: Satya Tangirala <[email protected]>
Signed-off-by: Jens Axboe <[email protected]>
Diffstat (limited to 'net/unix/unix_bpf.c')
0 files changed, 0 insertions, 0 deletions