Received: by 10.213.65.68 with SMTP id h4csp657470imn; Fri, 6 Apr 2018 06:53:50 -0700 (PDT) X-Google-Smtp-Source: AIpwx4+0rwq7HTOHHC7ZkQIZ8oh0g9F4lv5/U46harhGtdTxpPZt9dHaguK57jjCf2mRgSOeUOog X-Received: by 10.101.100.132 with SMTP id e4mr17916804pgv.240.1523022830641; Fri, 06 Apr 2018 06:53:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1523022830; cv=none; d=google.com; s=arc-20160816; b=LETPlWE8uBm7KChGDF0LPusI2M3zBiQ7+wta2Hfwl50EaBx65iX1npJJusdcFqjVOg 66sOdgwIUg3jEEFa41VK2gUAlnVODge3l3GUztvMib65zRvEENvsmgkspTUNY31N0V9f hEt4+L7y5Ci+KNprQQ+4g7HKUY//Vi0Ww8tS4CzjTHZdPNfzAuAQ6u6YBBXyQDmW1vU0 XsCdNUiMFe4ZEk5sEtTfmj4dJfSj74rsjS+cY49NCXW4TgB4yJurR1ttuOXTwuGOZPE9 0heJrJoHB3CYat2a9B4hwJmIy5jHd/q3dFmL8nMphjcrcLXyO1mmHt/apJxpvwDxRvVD n5Zg== 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=ISbMUtkF+BGSG3utcJs6vExTs3qFshXOJKZMJzmsakU=; b=xDBw5NjBfuFww5F0CuGzKqnr96dPyBSduRMaZR6LwB+XiVhm8vkvaUrw14+L2Myj1O jgPMjusTIxgyKTFVOF7eZVJ/ogi2efBtYp8PcXwnHeaLrdvgep7TKJ7hQ5yU9A31O9+/ U8aa3WhLL5dohOUnN3nV7po4NymjsZ3k0gClVPg+rDM6oAHiuHh6O7bm4twAGYgekBEC x8eeuyIfxFzrWwxXmMazQRl3SMhZUYcdJ2+wJRRHxsCuWBuxSuGyMvOIxiY44iSjGDVJ kRdmJquSHZqvPX2nFDaqif8nGMkbJxMIrSnU4Py8JDE4lWlDA3iyhXE6Iv2DZEeH0xWS AZyg== 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 u7-v6si8364322plz.562.2018.04.06.06.53.36; Fri, 06 Apr 2018 06:53: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 S1756767AbeDFNwS (ORCPT + 99 others); Fri, 6 Apr 2018 09:52:18 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:37760 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756930AbeDFNod (ORCPT ); Fri, 6 Apr 2018 09:44:33 -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 38996E0D; Fri, 6 Apr 2018 13:44:33 +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.16 16/31] crypto: ahash - Fix early termination in hash walk Date: Fri, 6 Apr 2018 15:24:41 +0200 Message-Id: <20180406084343.212737588@linuxfoundation.org> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180406084340.999820380@linuxfoundation.org> References: <20180406084340.999820380@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.16-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 @@ -92,13 +92,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)