Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp120638pxb; Mon, 13 Sep 2021 14:42:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyNYdgsGULzGN495bn2odndFZqF9VuEbk9chbHqoej+j9yosR9GYSBX8zt73IiLO/HXmZfr X-Received: by 2002:aa7:d954:: with SMTP id l20mr15776484eds.149.1631569331223; Mon, 13 Sep 2021 14:42:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1631569331; cv=none; d=google.com; s=arc-20160816; b=G7XhgqVQe9IomFvt2Htk9z5cxdKalCJ4MRK359q0IRjkHegUFTECu2VZygFnFWmvew YIA3O30FCnavtl3g5LYQYmHNe8UDOgI2wPdgMPpjXyfSxOigyNiu3++031GEvJRUvHn5 N9OsflWTjntwNT6ZSOpGjCOJ71eLQsrd1hSqzOWO84oeKUJyS8m9GcN5XwVH/QvUzCI1 NJUn0FnveaDzZ9Q3FenuCL1FjZ3uXoVui7hSVYnbDnjgd2iIXt2ocSPqjr5ilDNpyon9 hRV+zvJCXbcgzFTZ4qWYUv6m0v12ZXFnjXaC8nGOEDfBnDF3N7OgTKSoFNSpop1EsPHN RJZA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=J6FoObhfTd4QjF685USssoGJ2WdFNUOQcQ0U1npOhYc=; b=zfycpWalVYA3uHJg9C3TJdw9OeDBvb8XhPO0EvWN/g2p3jKdzE5MpG8W8cXxB1a0Pa sMCDMbyVN/uDeAwZVkC+dpSYqEm4QORmDuQsC2gS2i9iTOL3ltYBBnvFsrWjcBhy9Ky0 n0Ge0r+7R4vcrxA1/TjUDGW6cDDWVmvzDEeL1MG6ProtHfUq0dpiajsEdr3fX6asCauK p4wWgXl4vQ0DMdwoNreAV7uBStpPIe20tOdO9nMOJ14NwA7PZ7by4XatLhHYZ7GpyZtg DaN1yfqTHcRMCRufu0ZeX9YGzYwBMz2fE0XPiD1PeFpagYXQ6SACnM3/DrlBXyUys6i1 G/+g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=0Kj8CkaH; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u4si11356954ejy.271.2021.09.13.14.41.33; Mon, 13 Sep 2021 14:42:11 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-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=@linuxfoundation.org header.s=korg header.b=0Kj8CkaH; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S244135AbhIMN6h (ORCPT + 99 others); Mon, 13 Sep 2021 09:58:37 -0400 Received: from mail.kernel.org ([198.145.29.99]:40482 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1343571AbhIMNzl (ORCPT ); Mon, 13 Sep 2021 09:55:41 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id B1956619F8; Mon, 13 Sep 2021 13:35:43 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1631540144; bh=MCmmZzKIb1SVr3uB1RR1VG1U5yuv75ou2xI1Lo7vArQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=0Kj8CkaHdn+JQHIv/uz059t8Q67Wg6af3h5SBCek4AXn0uSWXHs2gvB5knTEQo7tA Zbepg6fF1fTkiKrD6i+pOnR80S4hGVuape+Alfu+3iqOhLfmVEBrNVkkn3UBlRKaW7 I/RUxVNGw7BNVZorw4nG4KqMnpybdDq5EOZ+c6+w= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Nayna Jain , George Wilson , Nageswara R Sastry , Stefan Berger , Jarkko Sakkinen , Sasha Levin Subject: [PATCH 5.13 070/300] tpm: ibmvtpm: Avoid error message when process gets signal while waiting Date: Mon, 13 Sep 2021 15:12:11 +0200 Message-Id: <20210913131111.720666960@linuxfoundation.org> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210913131109.253835823@linuxfoundation.org> References: <20210913131109.253835823@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Stefan Berger [ Upstream commit 047d4226b0bca1cda5267dc68bc8291cce5364ac ] When rngd is run as root then lots of these types of message will appear in the kernel log if the TPM has been configured to provide random bytes: [ 7406.275163] tpm tpm0: tpm_transmit: tpm_recv: error -4 The issue is caused by the following call that is interrupted while waiting for the TPM's response. sig = wait_event_interruptible(ibmvtpm->wq, !ibmvtpm->tpm_processing_cmd); Rather than waiting for the response in the low level driver, have it use the polling loop in tpm_try_transmit() that uses a command's duration to poll until a result has been returned by the TPM, thus ending when the timeout has occurred but not responding to signals and ctrl-c anymore. To stay in this polling loop extend tpm_ibmvtpm_status() to return 'true' for as long as the vTPM is indicated as being busy in tpm_processing_cmd. Since the loop requires the TPM's timeouts, get them now using tpm_get_timeouts() after setting the TPM2 version flag on the chip. To recreat the resolved issue start rngd like this: sudo rngd -r /dev/hwrng -t sudo rngd -r /dev/tpm0 -t Link: https://bugzilla.redhat.com/show_bug.cgi?id=1981473 Fixes: 6674ff145eef ("tpm_ibmvtpm: properly handle interrupted packet receptions") Cc: Nayna Jain Cc: George Wilson Reported-by: Nageswara R Sastry Signed-off-by: Stefan Berger Tested-by: Nageswara R Sastry Reviewed-by: Jarkko Sakkinen Signed-off-by: Jarkko Sakkinen Signed-off-by: Sasha Levin --- drivers/char/tpm/tpm_ibmvtpm.c | 26 +++++++++++++++----------- drivers/char/tpm/tpm_ibmvtpm.h | 2 +- 2 files changed, 16 insertions(+), 12 deletions(-) diff --git a/drivers/char/tpm/tpm_ibmvtpm.c b/drivers/char/tpm/tpm_ibmvtpm.c index 903604769de9..3af4c07a9342 100644 --- a/drivers/char/tpm/tpm_ibmvtpm.c +++ b/drivers/char/tpm/tpm_ibmvtpm.c @@ -106,17 +106,12 @@ static int tpm_ibmvtpm_recv(struct tpm_chip *chip, u8 *buf, size_t count) { struct ibmvtpm_dev *ibmvtpm = dev_get_drvdata(&chip->dev); u16 len; - int sig; if (!ibmvtpm->rtce_buf) { dev_err(ibmvtpm->dev, "ibmvtpm device is not ready\n"); return 0; } - sig = wait_event_interruptible(ibmvtpm->wq, !ibmvtpm->tpm_processing_cmd); - if (sig) - return -EINTR; - len = ibmvtpm->res_len; if (count < len) { @@ -237,7 +232,7 @@ static int tpm_ibmvtpm_send(struct tpm_chip *chip, u8 *buf, size_t count) * set the processing flag before the Hcall, since we may get the * result (interrupt) before even being able to check rc. */ - ibmvtpm->tpm_processing_cmd = true; + ibmvtpm->tpm_processing_cmd = 1; again: rc = ibmvtpm_send_crq(ibmvtpm->vdev, @@ -255,7 +250,7 @@ again: goto again; } dev_err(ibmvtpm->dev, "tpm_ibmvtpm_send failed rc=%d\n", rc); - ibmvtpm->tpm_processing_cmd = false; + ibmvtpm->tpm_processing_cmd = 0; } spin_unlock(&ibmvtpm->rtce_lock); @@ -269,7 +264,9 @@ static void tpm_ibmvtpm_cancel(struct tpm_chip *chip) static u8 tpm_ibmvtpm_status(struct tpm_chip *chip) { - return 0; + struct ibmvtpm_dev *ibmvtpm = dev_get_drvdata(&chip->dev); + + return ibmvtpm->tpm_processing_cmd; } /** @@ -457,7 +454,7 @@ static const struct tpm_class_ops tpm_ibmvtpm = { .send = tpm_ibmvtpm_send, .cancel = tpm_ibmvtpm_cancel, .status = tpm_ibmvtpm_status, - .req_complete_mask = 0, + .req_complete_mask = 1, .req_complete_val = 0, .req_canceled = tpm_ibmvtpm_req_canceled, }; @@ -550,7 +547,7 @@ static void ibmvtpm_crq_process(struct ibmvtpm_crq *crq, case VTPM_TPM_COMMAND_RES: /* len of the data in rtce buffer */ ibmvtpm->res_len = be16_to_cpu(crq->len); - ibmvtpm->tpm_processing_cmd = false; + ibmvtpm->tpm_processing_cmd = 0; wake_up_interruptible(&ibmvtpm->wq); return; default: @@ -688,8 +685,15 @@ static int tpm_ibmvtpm_probe(struct vio_dev *vio_dev, goto init_irq_cleanup; } - if (!strcmp(id->compat, "IBM,vtpm20")) { + + if (!strcmp(id->compat, "IBM,vtpm20")) chip->flags |= TPM_CHIP_FLAG_TPM2; + + rc = tpm_get_timeouts(chip); + if (rc) + goto init_irq_cleanup; + + if (chip->flags & TPM_CHIP_FLAG_TPM2) { rc = tpm2_get_cc_attrs_tbl(chip); if (rc) goto init_irq_cleanup; diff --git a/drivers/char/tpm/tpm_ibmvtpm.h b/drivers/char/tpm/tpm_ibmvtpm.h index b92aa7d3e93e..51198b137461 100644 --- a/drivers/char/tpm/tpm_ibmvtpm.h +++ b/drivers/char/tpm/tpm_ibmvtpm.h @@ -41,7 +41,7 @@ struct ibmvtpm_dev { wait_queue_head_t wq; u16 res_len; u32 vtpm_version; - bool tpm_processing_cmd; + u8 tpm_processing_cmd; }; #define CRQ_RES_BUF_SIZE PAGE_SIZE -- 2.30.2