Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp1373225pxb; Fri, 20 Aug 2021 04:16:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw/Pprl/HmZEcoF/CiEr/gr3Q/SHjAnLCbAsPlp6y8pEafJwZLV+Uc2bsD8iieJYLe5onx0 X-Received: by 2002:a05:6402:40c8:: with SMTP id z8mr1788026edb.86.1629458170818; Fri, 20 Aug 2021 04:16:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629458170; cv=none; d=google.com; s=arc-20160816; b=HiJA/+4FYQtyp1xRzUegAvMr7OzAdtFNFyG3DUP0SSzCkxv36O+UTVOZCTvrNz8lAS ndjxRMqXw8lEZwz5dDvfW/6EEl+8zXaqpqhnDpV0hKVjIWw2q68RuTsBUztxBJBjp05u 2nU8XbJh0BCUgTkqNus9Tl9kaI0dek8FOe428qYCL/uarRYvwrXksqTLXlLXaJ/gYzsk 6fAYnXIZaJiMrPisWrBK6SAIAd3LkF/DFuP59B9cLv7HCp3oOXi9pX2iQvCGo+e+wuW6 jQ4JhjjVtxJpFmNloTXN0dwSp2q9m0vaI8fMo3MwxQTip76bC49GAoaX0zC2uMfxcStF MSLw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=0LuM4NAWL3OSyeqfsPO9vtmO3ggPTJQ/MqwcXxXRWos=; b=NAyWvDUWlquXex+v6halLSWmBg5OX5E3YGZ67IBHijDgcsU7+KtZOxeRETUhE3YD7j M/sGIMo3F0jNUDHp25PJKb/VXsYpy/v0gNwOVLXT/0r6cn0wFD5Iwu3the6SwGJ/KMOJ FRKA0s5Omw/SLqcuk9GqBCj4qvW0fBBWO786p9Zu3L9R7Teh4ShuV8fU1tC0DLylvHa8 gQ7RjQ2f9Qo3lE+uUU21lJ+ivxpH131cJv5iF9y/pt0Y+ZxlB9PArOwq0GHctwjkJ/P1 ycgVn7dlBwmeNBFSRRkMLS92barX7gmOiC+9gviT0EzQhqjby0zav5GPo/puxE5F6Nhd 3tyQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=L32IgBvS; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bx23si5932453edb.189.2021.08.20.04.15.06; Fri, 20 Aug 2021 04:16:10 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=L32IgBvS; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237148AbhHTLPm (ORCPT + 99 others); Fri, 20 Aug 2021 07:15:42 -0400 Received: from mail.kernel.org ([198.145.29.99]:42002 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231852AbhHTLPl (ORCPT ); Fri, 20 Aug 2021 07:15:41 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id E00946108B; Fri, 20 Aug 2021 11:15:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1629458103; bh=JP1kImrQsAE3QCEh5iekGAPOx3Dc6A8nBuPEECbeP8Y=; h=References:In-Reply-To:From:Date:Subject:To:Cc:From; b=L32IgBvSAK0hAtatDRv/3WqmNUlPKO7q2df1NxthhaH9xYqShfPjx8gb5H5OuB5bX l4bOi+nXO+s/21kZt0h4mXMm1RGEIx6N6swUTOijgqhvqymwjRi2ZNlS4+IhFq27vv VwmHsVivP816sIkbTDOOd/frkuxyiSKYWwtj3eOouq41bON5moe7KC+hZ9yHH6JWrI 0lZrg0NYtU361vSY0EJL3vOmvSgttITcTRU745H0FsAX1TuWI2/vb0ji8urOtG2/5H Sbkz7OEmWUkw8HuROvk9dPvG/MWO6FIjqpjsi9NVf6DlRr/ZNvgZ7zkHd5hZDpvvFR Sti0b6/3FUBRw== Received: by mail-ot1-f44.google.com with SMTP id w22-20020a056830411600b0048bcf4c6bd9so12636525ott.8; Fri, 20 Aug 2021 04:15:03 -0700 (PDT) X-Gm-Message-State: AOAM532RaWhjIn0vip4+xEbTtuQgP0QzLYi89Z3XwovPu+ecRTWL5s4V PtZcjUidUhnfnTGNUq9TDWwRfKd4RC2OWg3jgcw= X-Received: by 2002:aca:ea54:: with SMTP id i81mr2575045oih.174.1629458103236; Fri, 20 Aug 2021 04:15:03 -0700 (PDT) MIME-Version: 1.0 References: <20210809141027.860850-1-chouhan.shreyansh630@gmail.com> <20210820083111.GA28484@gondor.apana.org.au> In-Reply-To: <20210820083111.GA28484@gondor.apana.org.au> From: Ard Biesheuvel Date: Fri, 20 Aug 2021 13:14:52 +0200 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH] crypto: xts_crypt() return if walk.nbytes is 0 To: Herbert Xu Cc: Shreyansh Chouhan , "David S. Miller" , Thomas Gleixner , Ingo Molnar , Borislav Petkov , X86 ML , "H. Peter Anvin" , Linux Crypto Mailing List , Linux Kernel Mailing List , syzbot+20191dc583eff8602d2d@syzkaller.appspotmail.com Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-crypto@vger.kernel.org On Fri, 20 Aug 2021 at 10:31, Herbert Xu wrote: > > On Mon, Aug 09, 2021 at 07:40:27PM +0530, Shreyansh Chouhan wrote: > > xts_crypt() code doesn't call kernel_fpu_end() after calling > > kernel_fpu_begin() if walk.nbytes is 0. The correct behavior should be > > not calling kernel_fpu_begin() if walk.nbytes is 0. > > > > Reported-by: syzbot+20191dc583eff8602d2d@syzkaller.appspotmail.com > > Signed-off-by: Shreyansh Chouhan > > --- > > arch/x86/crypto/aesni-intel_glue.c | 2 +- > > 1 file changed, 1 insertion(+), 1 deletion(-) > > > > diff --git a/arch/x86/crypto/aesni-intel_glue.c b/arch/x86/crypto/aesni-intel_glue.c > > index 388643ca2177..ec6eac57c493 100644 > > --- a/arch/x86/crypto/aesni-intel_glue.c > > +++ b/arch/x86/crypto/aesni-intel_glue.c > > @@ -849,7 +849,7 @@ static int xts_crypt(struct skcipher_request *req, bool encrypt) > > return -EINVAL; > > > > err = skcipher_walk_virt(&walk, req, false); > > - if (err) > > + if (err || !walk.nbytes) > > return err; > > The err check is now redundant because when there is an error > nbytes is always zero. > In spite of that, I have a slight preference for this version, given that it makes it obvious that we bail on two separate conditions: - an error has occurred - no error has occurred but the resulting walk is empty Testing walk.nbytes only needlessly obfuscates the code, as we need to return 'err' in the end anyway.