Received: by 10.213.65.68 with SMTP id h4csp746503imn; Fri, 6 Apr 2018 08:12:59 -0700 (PDT) X-Google-Smtp-Source: AIpwx4+cdIoV4cUNCKAnhUDhQRbqU4BXCyCsA+ZWrBz/rsJm/wXeJBiAtrIVyx+tB7QZv+V0bcH7 X-Received: by 10.98.76.68 with SMTP id z65mr20941746pfa.181.1523027579225; Fri, 06 Apr 2018 08:12:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1523027579; cv=none; d=google.com; s=arc-20160816; b=h/CyXl9A0GATxDOe8AiHWeoc72bkceG1gx8ESCTmbZUvGt4yDjSX4SKU1VkBul3uLw 5q6IIrcAQZZgB/G04exfX1Vtd9kO+tREo6ALAgNeZNrd5719AWxxTSbst3TBfxR5WLxZ uNZCrqUBrSDiOWPaG9Milh+HWg9buzprrdP6/EhYze4FueYwiVGoBwCpRTsOhqQdR/Rn Wa5rl7unj3X5p3sHzXkQDX4vOR6+oqS0jlmlmVJF3EPcCq1cA4cNhM4um4SccED+R8ST 2dwlTTPhLId1/rnE0XLI0tMXEFZFRvWxy8esvJOLyaahJUi88Ujo70exwFAEYrBIOnvZ OUEQ== 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=vhvkFuhGYSfQKCV92RN5vC0o6kptA0ynbsgZYMpP7+0=; b=cu0zprSsf27VFkc/cE3sr1Gln69TBZX4Jwta3rfhS0r5bfrpQEFA5nERgfnTyma7Qt ngAfpsOy87UPMWginVppIUJGJB4gD4D8uUS5e4wK/Fe3H7QwyePBFj32De8XqofAf16/ HRqSZh6JT7fklOXzaCVK4lMqJhfTc1NjuTeErLR1Fvr8EKiUwRsyZt1q0Xjdwj77mvks ISP6ZmqAeOMMBa3tx1PycaT/EJJkqR+riLdvf4F18lm+LWodp1DfhadTY1Zg4IVqoaqn Vz+i7c15S99ofzz8etuR81nHH3JKhnHpwDY4EKpeojq2rtsburoLpz975gB1sG/gIDfd d2IQ== 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 p4si7018964pgv.545.2018.04.06.08.12.45; Fri, 06 Apr 2018 08:12:59 -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 S1754597AbeDFN3V (ORCPT + 99 others); Fri, 6 Apr 2018 09:29:21 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:55688 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754591AbeDFN3S (ORCPT ); Fri, 6 Apr 2018 09:29:18 -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 290E7D08; Fri, 6 Apr 2018 13:29:18 +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 3.18 81/93] crypto: ahash - Fix early termination in hash walk Date: Fri, 6 Apr 2018 15:23:50 +0200 Message-Id: <20180406084228.698842439@linuxfoundation.org> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180406084224.918716300@linuxfoundation.org> References: <20180406084224.918716300@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 3.18-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 @@ -90,13 +90,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)