Received: by 10.213.65.68 with SMTP id h4csp637385imn; Fri, 6 Apr 2018 06:33:50 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/zU5AbG9uP8erRFHsUGSoUowMl8+soucModK+vSN5Rse/afgJK8C5KzZfA4tzgnNhIyduR X-Received: by 10.98.11.149 with SMTP id 21mr20305188pfl.64.1523021630075; Fri, 06 Apr 2018 06:33:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1523021630; cv=none; d=google.com; s=arc-20160816; b=BRvj70XgU7Gp4yRsULjppExLp3AWg7i0TXGhSisG0QRSZi6t1xEHekBjgajmLqiIU6 FKQCj4S1wSIwXrYZkBKXPlPeFUfXo+sAAO3QynQYIBmkaHBG/mD9X5md6VQ6WqLjHxV/ fglFxdtOhO6bwS9lLxe3DWYdgEM0uxTvSYcw2UfA8U9XwcLZjMhHGOLNDnDHpdUtA9n2 V9r+RLjXOuEeznxeFrNm9PmFteEvJMjNOZnZr3ZXBnFuj9qSUZxap1rcrt/sN+s1o2Jg SZ3EXzSX3QRt8zAqaDugNU/7tFSc+8pLfbFhrlwNH3k8zpqb54lipWWJhazmS7R0VlbE 7Oeg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=MFBPdmWKuq1aKeho5Qq7333KGeZl3UBBWKGFjFoCZJA=; b=J2XdbDCbsppPXrq5nvXaK2FCgP6Cqwf3oWlL5mOQ1x2nrLRTwJDBlxE25sChJYjIop JCrC23h+a9Dy9gIfqTCAOIVd9L3dDnzEk5dPajlHC5Nt4+/0MeZCz0Y4RXmgCDWwjMpj gfjMNFfe0G2ygjONS6uHe/RwrEN3XPNfdIgQIk54tJ1r4Y27xzJkIcwVPb5+AT5/GHct hA2/aswifMc/cHDd8fhZn5bu7rOsQIcPsi7318XcG9hfdOy46vAD5HbiW/HclcDaaJA6 OrkGlrRUzPwsN68n1FSqoC+5fHX5rhsXMERtl+NlEX4rUikvj05Zfpsd+vc81dPfohnp YWUg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f14si2807731pgn.597.2018.04.06.06.33.35; Fri, 06 Apr 2018 06:33:50 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755357AbeDFNc2 (ORCPT + 99 others); Fri, 6 Apr 2018 09:32:28 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:57536 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755346AbeDFNc0 (ORCPT ); Fri, 6 Apr 2018 09:32:26 -0400 Received: from localhost (LFbn-1-12247-202.w90-92.abo.wanadoo.fr [90.92.61.202]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id 68F548A5; Fri, 6 Apr 2018 13:32:25 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Eli Cooper , Herbert Xu Subject: [PATCH 4.4 51/72] crypto: ahash - Fix early termination in hash walk Date: Fri, 6 Apr 2018 15:23:52 +0200 Message-Id: <20180406084309.497760494@linuxfoundation.org> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180406084305.210085169@linuxfoundation.org> References: <20180406084305.210085169@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.4-stable review patch. If anyone has any objections, please let me know. ------------------ From: Herbert Xu commit 900a081f6912a8985dc15380ec912752cb66025a upstream. When we have an unaligned SG list entry where there is no leftover aligned data, the hash walk code will incorrectly return zero as if the entire SG list has been processed. This patch fixes it by moving onto the next page instead. Reported-by: Eli Cooper Cc: Signed-off-by: Herbert Xu Signed-off-by: Greg Kroah-Hartman --- crypto/ahash.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) --- a/crypto/ahash.c +++ b/crypto/ahash.c @@ -91,13 +91,14 @@ int crypto_hash_walk_done(struct crypto_ if (nbytes && walk->offset & alignmask && !err) { walk->offset = ALIGN(walk->offset, alignmask + 1); - walk->data += walk->offset; - nbytes = min(nbytes, ((unsigned int)(PAGE_SIZE)) - walk->offset); walk->entrylen -= nbytes; - return nbytes; + if (nbytes) { + walk->data += walk->offset; + return nbytes; + } } if (walk->flags & CRYPTO_ALG_ASYNC)