Received: by 2002:a05:6a10:c7c6:0:0:0:0 with SMTP id h6csp1653071pxy; Mon, 2 Aug 2021 07:08:14 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyF37moyWqOTf9L+T6E778HdSp9pWwsa0/BgrlQRsgbZCd8YRxnRDkxQR9xwBSy022nFzfh X-Received: by 2002:a6b:b2d7:: with SMTP id b206mr10945iof.155.1627913293865; Mon, 02 Aug 2021 07:08:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627913293; cv=none; d=google.com; s=arc-20160816; b=pnM+NIFtF6h8aVpk+XfK6AATCuPJCXR1L/PVAD9w6U5vv/IUceOqZT/VFvWK2xwROi TN5Jmnvw2PW2rH24fGNvmfXeo+Qjdbt3fDNdtudcwxw6y181sLBcx8t1uWQepxSgKgcc u2mQx3BkNLhkx2Ow8emqOy02l7+C4z5vTVMTskqzefoUDR9amkyH1utfp1R3NeRZ/uYm imPJ5sP5qxGykg4a+a04W7lvKZN+KKbJr1qV9sewI6bTYQIRmodoykLdLHzBzy0zbFH6 kQ+60rbXZVuPXPdkksRF5h1oDjiChSx7YOI6xTupVfTHQSC4jOKgJWMF92Dme9OYHDok kd8g== 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=egqTnwvXVL5ym92sHJrg5bfSug4lqZkszi9NgLYZCxE=; b=xL1sSoo9CdVNgYQFZiVcQnvZ0XZUobqEaCawyl0wgBvIRQEzbJfIxPmoR5kZw15m3c fmDJuKIrW6sYhKzkLAf7UrjHklZ7z0hufKjLXPpLLh+F6nRPrSC0SOeJCz54OVouEfZA wRmovvQLFnp09moKS6iKRSe9goKY8gK5k+1b2plDjgH089VG1DT/SBK/E6F2xBqEpF73 UJ8vwuZBZCWY2tTDUhYQ/cFN71oLVUbMcZGusSq1CY5H5hWVcxHWdKz7dXXmwfXZU4t+ 8Vnc1Ob3q7AhdFFSUoS/PTNqJAAzjef8b/eiDB22DMk/CRfqqN9U3seGPORIAuRwNbr5 nYIQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=gynrtgU8; 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 j1si12400404jak.102.2021.08.02.07.08.02; Mon, 02 Aug 2021 07:08:13 -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=gynrtgU8; 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 S236139AbhHBOFe (ORCPT + 99 others); Mon, 2 Aug 2021 10:05:34 -0400 Received: from mail.kernel.org ([198.145.29.99]:40886 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235163AbhHBN5e (ORCPT ); Mon, 2 Aug 2021 09:57:34 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id BEB0761156; Mon, 2 Aug 2021 13:54:55 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1627912496; bh=rhU+x3Q+q9wRUeuLNNUDEwueUlY9MyUsE1nn2CaTkp8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=gynrtgU8hbmcM5Wtg59eE9FFzcl8+wO5JMrZx8bllXiGK0ZeG26j2FiuyLgJMLEq0 vkKhaWwlFYEztcyZDaF2KnZfgzFz/jmhmbLnZBUIgIfVDJTJ1acU9NffiRJdqOim/e 4ASY5TLI8qL04iNlg/RQt/Y53omE3vScW7E2QufE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Srinivas Pandruvada , "Rafael J. Wysocki" Subject: [PATCH 5.13 007/104] ACPI: DPTF: Fix reading of attributes Date: Mon, 2 Aug 2021 15:44:04 +0200 Message-Id: <20210802134344.259414182@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210802134344.028226640@linuxfoundation.org> References: <20210802134344.028226640@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: Srinivas Pandruvada commit 41a8457f3f6f829be1f8f8fa7577a46b9b7223ef upstream. The current assumption that methods to read PCH FIVR attributes will return integer, is not correct. There is no good way to return integer as negative numbers are also valid. These read methods return a package of integers. The first integer returns status, which is 0 on success and any other value for failure. When the returned status is zero, then the second integer returns the actual value. This change fixes this issue by replacing acpi_evaluate_integer() with acpi_evaluate_object() and use acpi_extract_package() to extract results. Fixes: 2ce6324eadb01 ("ACPI: DPTF: Add PCH FIVR participant driver") Signed-off-by: Srinivas Pandruvada Cc: 5.10+ # 5.10+ Signed-off-by: Rafael J. Wysocki Signed-off-by: Greg Kroah-Hartman --- drivers/acpi/dptf/dptf_pch_fivr.c | 51 ++++++++++++++++++++++++++++++++------ 1 file changed, 43 insertions(+), 8 deletions(-) --- a/drivers/acpi/dptf/dptf_pch_fivr.c +++ b/drivers/acpi/dptf/dptf_pch_fivr.c @@ -9,6 +9,42 @@ #include #include +struct pch_fivr_resp { + u64 status; + u64 result; +}; + +static int pch_fivr_read(acpi_handle handle, char *method, struct pch_fivr_resp *fivr_resp) +{ + struct acpi_buffer resp = { sizeof(struct pch_fivr_resp), fivr_resp}; + struct acpi_buffer buffer = { ACPI_ALLOCATE_BUFFER, NULL }; + struct acpi_buffer format = { sizeof("NN"), "NN" }; + union acpi_object *obj; + acpi_status status; + int ret = -EFAULT; + + status = acpi_evaluate_object(handle, method, NULL, &buffer); + if (ACPI_FAILURE(status)) + return ret; + + obj = buffer.pointer; + if (!obj || obj->type != ACPI_TYPE_PACKAGE) + goto release_buffer; + + status = acpi_extract_package(obj, &format, &resp); + if (ACPI_FAILURE(status)) + goto release_buffer; + + if (fivr_resp->status) + goto release_buffer; + + ret = 0; + +release_buffer: + kfree(buffer.pointer); + return ret; +} + /* * Presentation of attributes which are defined for INT1045 * They are: @@ -23,15 +59,14 @@ static ssize_t name##_show(struct device char *buf)\ {\ struct acpi_device *acpi_dev = dev_get_drvdata(dev);\ - unsigned long long val;\ - acpi_status status;\ + struct pch_fivr_resp fivr_resp;\ + int status;\ +\ + status = pch_fivr_read(acpi_dev->handle, #method, &fivr_resp);\ + if (status)\ + return status;\ \ - status = acpi_evaluate_integer(acpi_dev->handle, #method,\ - NULL, &val);\ - if (ACPI_SUCCESS(status))\ - return sprintf(buf, "%d\n", (int)val);\ - else\ - return -EINVAL;\ + return sprintf(buf, "%llu\n", fivr_resp.result);\ } #define PCH_FIVR_STORE(name, method) \