From mboxrd@z Thu Jan 1 00:00:00 1970 From: Ard Biesheuvel Subject: Re: [PATCH crypto-next 07/23] block: cryptoloop: Remove VLA usage of skcipher Date: Tue, 25 Sep 2018 11:25:57 +0200 Message-ID: References: <20180919021100.3380-1-keescook@chromium.org> <20180919021100.3380-8-keescook@chromium.org> Mime-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Cc: Herbert Xu , Jens Axboe , linux-block@vger.kernel.org, Eric Biggers , "open list:HARDWARE RANDOM NUMBER GENERATOR CORE" , Linux Kernel Mailing List To: Kees Cook Return-path: In-Reply-To: Sender: linux-kernel-owner@vger.kernel.org List-Id: linux-crypto.vger.kernel.org On Mon, 24 Sep 2018 at 19:53, Kees Cook wrote: > > On Mon, Sep 24, 2018 at 4:52 AM, Ard Biesheuvel > wrote: > > On Wed, 19 Sep 2018 at 04:11, Kees Cook wrote: > >> @@ -119,7 +119,7 @@ cryptoloop_transfer(struct loop_device *lo, int cmd, > >> unsigned in_offs, out_offs; > >> int err; > >> > >> - skcipher_request_set_tfm(req, tfm); > >> + skcipher_request_set_sync_tfm(req, tfm); > >> skcipher_request_set_callback(req, CRYPTO_TFM_REQ_MAY_SLEEP, > >> NULL, NULL); > >> > > > > Does this work? > > Everything is a direct wrapper for existing types and functions, so I > wouldn't expect any functional change. I haven't been able to test > this particular interface, though. cryptoloop is very deprecated, > isn't it? > Ah yes, I managed to confuse myself there. This looks all fine to me. In any case, this is another example where we may decide to fix the code rather than retain the request allocation on the stack (but that is Jens's call ultimately, I suppose) diff --git a/drivers/block/cryptoloop.c b/drivers/block/cryptoloop.c index 7033a4beda66..5ed2167219ba 100644 --- a/drivers/block/cryptoloop.c +++ b/drivers/block/cryptoloop.c @@ -110,7 +110,7 @@ cryptoloop_transfer(struct loop_device *lo, int cmd, int size, sector_t IV) { struct crypto_skcipher *tfm = lo->key_data; - SKCIPHER_REQUEST_ON_STACK(req, tfm); + struct skcipher_request *req; struct scatterlist sg_out; struct scatterlist sg_in; @@ -119,7 +119,10 @@ cryptoloop_transfer(struct loop_device *lo, int cmd, unsigned in_offs, out_offs; int err; - skcipher_request_set_tfm(req, tfm); + req = skcipher_request_alloc(tfm, GFP_NOIO); + if (!req) + return -ENOMEM; + skcipher_request_set_callback(req, CRYPTO_TFM_REQ_MAY_SLEEP, NULL, NULL); or if we stick with the current change to sync: Acked-by: Ard Biesheuvel