Received: by 2002:ac0:98c7:0:0:0:0:0 with SMTP id g7-v6csp2466747imd; Fri, 2 Nov 2018 11:54:53 -0700 (PDT) X-Google-Smtp-Source: AJdET5eWuPnsIzcQribW6GhwBzPAB7RahYrV/1xnKdfJraeL6Le81VJxkmwIH0f7Kyu42DofaByT X-Received: by 2002:a62:fc95:: with SMTP id e143-v6mr12573378pfh.132.1541184892918; Fri, 02 Nov 2018 11:54:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1541184892; cv=none; d=google.com; s=arc-20160816; b=hgZyC0ma8veuljsPoPhHP5aDvagQfkZb3ZbBcBEdQe2b3c/3w3q2bQDyKt5BmZwoy5 QcTN/Ao3dlxRV8uE9ePFY/O96WZMM9rIiooJqL3GoU6uNdhPtApwTBRgGPaYIFNt253F 4B9oAuG9vUzdUj5gCFT4ab1OLzKeF/HNHXgPdJjyl4n8UEHFpycJJR8PgRv62epfWu43 FY8E0OvYF+kGhQe/xYDpFrNOte1n3hcOBhBcCQCPggA2Bz8jcO2qN59fC4h0V+T5gaFS MEOTTfZVEft9DHGRQHqnQb2uzJzb7Hlc0A/MR/MXaxGWP8LolkzmPumZQID8sm6oKPzV fFVg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=aXBcqKYmKiFOP4hGzWL1BqXp2nCoTvqkbknq4N8+AiM=; b=QYZFWBD6jR65xL5SgywCqA8UAKTK8n8CuHELHm0uP7cNhskGs2Ppn+GPiL7NPxS1r/ auOFifCyLhahwmwsA7JtPA3NwDiJn4nkDNKfz8E7YRI5mv07oZpFpaXzArplnwlJeazr YzokEgpsChXhNgf/zwAou5PD8blSeXUDd8OZpPaWWSjZv2RAn8DS/Sr0Afk3O0YwNh5t VffuiGHL/TXTFwtNueAnDkH0d0wLwSsGYXz8aSTAdptoykbYjA2LOD1A+iRLsYcjpoe7 3rcudSn5mSzDOHLm1Ty0MM3Y1N6WXRC+Sjvsw1cVaTcy/QASkJ5m/bqwxnOzBo84rmB4 kG+w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=JTVKULUb; 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 x5si111214pga.440.2018.11.02.11.54.38; Fri, 02 Nov 2018 11:54:52 -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; dkim=pass header.i=@kernel.org header.s=default header.b=JTVKULUb; 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 S1730995AbeKCECZ (ORCPT + 99 others); Sat, 3 Nov 2018 00:02:25 -0400 Received: from mail.kernel.org ([198.145.29.99]:58234 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729463AbeKCECY (ORCPT ); Sat, 3 Nov 2018 00:02:24 -0400 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 4F3762084A; Fri, 2 Nov 2018 18:54:08 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1541184849; bh=d2wfP5XDUckkHtQ9opQ7PGX7gS25PfLfhTWwTxOHbWs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=JTVKULUbG3VNUpqCwgjPAUAIXH36Rdqs8Wfwk5NezOzR9WX52z+/UXLHoIaAMd3TH Cs18lFMXy4nAVBYRN2eeWDPVTGIdjDmqUaG/7jLAdl5bdoGcl8AzZddurpigoipnwQ jpga4fNSa2qP0t2iy1JHJbhbM89uLp9CYkC4YCVc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Nayna Jain , Mimi Zohar , Jarkko Sakkinen , Sasha Levin Subject: [PATCH 4.14 075/143] tpm: move the delay_msec increment after sleep in tpm_transmit() Date: Fri, 2 Nov 2018 19:34:20 +0100 Message-Id: <20181102182903.439770268@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181102182857.064326086@linuxfoundation.org> References: <20181102182857.064326086@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.14-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit 92980756979a9c51be0275f395f4e89c42cf199a ] Commit e2fb992d82c6 ("tpm: add retry logic") introduced a new loop to handle the TPM2_RC_RETRY error. The loop retries the command after sleeping for the specified time, which is incremented exponentially in every iteration. Unfortunately, the loop doubles the time before sleeping, causing the initial sleep to be doubled. This patch fixes the initial sleep time. Fixes: commit e2fb992d82c6 ("tpm: add retry logic") Signed-off-by: Nayna Jain Reviewed-by: Mimi Zohar Tested-by: Jarkko Sakkinen Reviewed-by: Jarkko Sakkinen Signed-off-by: Jarkko Sakkinen Signed-off-by: Sasha Levin --- drivers/char/tpm/tpm-interface.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/drivers/char/tpm/tpm-interface.c b/drivers/char/tpm/tpm-interface.c index a2070ab86c82..89d5915b1a3f 100644 --- a/drivers/char/tpm/tpm-interface.c +++ b/drivers/char/tpm/tpm-interface.c @@ -611,12 +611,13 @@ ssize_t tpm_transmit(struct tpm_chip *chip, struct tpm_space *space, rc = be32_to_cpu(header->return_code); if (rc != TPM2_RC_RETRY) break; - delay_msec *= 2; + if (delay_msec > TPM2_DURATION_LONG) { dev_err(&chip->dev, "TPM is in retry loop\n"); break; } tpm_msleep(delay_msec); + delay_msec *= 2; memcpy(buf, save, save_size); } return ret; -- 2.17.1