From patchwork Fri Feb 23 14:37:22 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shiju Jose X-Patchwork-Id: 13569157 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 90C02C54798 for ; Fri, 23 Feb 2024 14:38:09 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id C79156B0087; Fri, 23 Feb 2024 09:37:52 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id C2A956B0088; Fri, 23 Feb 2024 09:37:52 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id AA2F16B0089; Fri, 23 Feb 2024 09:37:52 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0010.hostedemail.com [216.40.44.10]) by kanga.kvack.org (Postfix) with ESMTP id 8551D6B0088 for ; Fri, 23 Feb 2024 09:37:52 -0500 (EST) Received: from smtpin17.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay02.hostedemail.com (Postfix) with ESMTP id 508AE1211C5 for ; Fri, 23 Feb 2024 14:37:52 +0000 (UTC) X-FDA: 81823322784.17.FE0A3B0 Received: from frasgout.his.huawei.com (frasgout.his.huawei.com [185.176.79.56]) by imf22.hostedemail.com (Postfix) with ESMTP id 816BAC0010 for ; Fri, 23 Feb 2024 14:37:50 +0000 (UTC) Authentication-Results: imf22.hostedemail.com; dkim=none; dmarc=pass (policy=quarantine) header.from=huawei.com; spf=pass (imf22.hostedemail.com: domain of shiju.jose@huawei.com designates 185.176.79.56 as permitted sender) smtp.mailfrom=shiju.jose@huawei.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1708699070; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=JIOCLLamCEHkn7MNShQK6YZeDCles9pjQDpQCPEpGUY=; b=xkqUNOTTHSlXvoryrzXlgqHqYZ9LTNRqc4TP+yQi0N2oeOKqg+XCXzM+2mt+4BQ/KIeLaC AsoA3FEil87nB0ch+IZzwHclfi9XfAKjIcygxfVozGYcopIULrvzwTyj68gJOxMnysjpMg 8TXBZ7lQ3hQfD8FQapGZXqmvYzchiN8= ARC-Authentication-Results: i=1; imf22.hostedemail.com; dkim=none; dmarc=pass (policy=quarantine) header.from=huawei.com; spf=pass (imf22.hostedemail.com: domain of shiju.jose@huawei.com designates 185.176.79.56 as permitted sender) smtp.mailfrom=shiju.jose@huawei.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1708699070; a=rsa-sha256; cv=none; b=PjUwncf17ZKkY+XUsdbefWJIlo9Y68UiIkO4wwKetHC47jheghpcffnD+zsb8CIhh5/IcM NdbWobkqith+RVmcMSwyzYqK7liBJ9RBa/8PsxH7Z+x/jDrp5emucegzMCX6tAWmDmIpzq GeKwnok61wROguQZx8h2LV1FIlCgXtU= Received: from mail.maildlp.com (unknown [172.18.186.216]) by frasgout.his.huawei.com (SkyGuard) with ESMTP id 4ThCDg2Jg0z6K5ts; Fri, 23 Feb 2024 22:33:39 +0800 (CST) Received: from lhrpeml500006.china.huawei.com (unknown [7.191.161.198]) by mail.maildlp.com (Postfix) with ESMTPS id A19ED140D26; Fri, 23 Feb 2024 22:37:48 +0800 (CST) Received: from SecurePC30232.china.huawei.com (10.122.247.234) by lhrpeml500006.china.huawei.com (7.191.161.198) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.1.2507.35; Fri, 23 Feb 2024 14:37:47 +0000 From: To: , , , , , , , , , CC: , , , , , , , , , , , , , , , , , , , , , , , , , , , , , Subject: [RFC PATCH v7 11/12] ACPI:RAS2: Add driver for ACPI RAS2 feature table (RAS2) Date: Fri, 23 Feb 2024 22:37:22 +0800 Message-ID: <20240223143723.1574-12-shiju.jose@huawei.com> X-Mailer: git-send-email 2.35.1.windows.2 In-Reply-To: <20240223143723.1574-1-shiju.jose@huawei.com> References: <20240223143723.1574-1-shiju.jose@huawei.com> MIME-Version: 1.0 X-Originating-IP: [10.122.247.234] X-ClientProxiedBy: lhrpeml500003.china.huawei.com (7.191.162.67) To lhrpeml500006.china.huawei.com (7.191.161.198) X-Rspam-User: X-Rspamd-Server: rspam12 X-Rspamd-Queue-Id: 816BAC0010 X-Stat-Signature: 1tsg4exgmk9o4nbgko6zkt6rb54ktmn7 X-HE-Tag: 1708699070-574308 X-HE-Meta: U2FsdGVkX1+M9MONLnp4W7Ibh7KkyHD8TofbDzjF7xzHZmhhjopATC7CCoFL4nDLFa+4QfBvtb0C90JgJ4bLN5XE5CG0oUzImZvmUh39a6Oo3KHhNYboA7KK2IrKrgm2sBX937qN2xoqJb0TpGOG/WAdqTb8RZdr1pNfvnh6Lii5kHAKq0/jdiFmRPRYlGCSHQy0V5ZBlyC/E+EpDctOtdpaQuBVdGUlc31R3fLUrldlLlj6Ee4hQE+fFpxXyxV8CcDPw+H/0mecy7hJyJRGlZnPSpYG2kXUQ6NS3ESggyCbf7t5aNAaAbHzlrmO8SXuIMGhH3Yf0qhnTuQrRSf+JoA+zlo3Ws/Cujhc1eMFJ6Jl5tc4Z7KeurT9nNmer56PC9AxP4QMnI3MeyFe3Hd3NNP48xoDAuMuMeQ26Mil6d9++pXF9E1wQDrUa7XHM8UGSjkOpAiPV5VS4OSUOrIogdFeb6K0ZC6/vvm0LnHeOaESR1noe2iTcHYFIqd8tdUyNJVRIRZU3MS0i5c+Wgl7qib3z5EtiZwupQS5qryVApgEmvjw9FR44xtyCpGcz0ejwlliBIRZcwkwk+lhuFcPey97EFbV8WR46NV9zVxdyTXFRGb7UZ2owJA2HP0xHo/ltOidCETPZqWk4f0eBG9dVq5mVegOZEGGC9uzFOxlC3wBPMyhXKxkfoLazFElT25JxfhKpUTFj3QduJcWQnHe6vF4WwUUs0gg0bDHVlLkmRMfd/ksCuy1/Mnl/jv5h3QwNH/s12wWz5h3SGvvoXLnYaDJ9YqwozTH2aTYU98krKmc7cCmbPcVcjmikgsUw/h6lKDl1RESk4l+brS99Jq6mMD6HoXBiJPF X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: From: Shiju Jose Add support for ACPI RAS2 feature table (RAS2) defined in the ACPI 6.5 Specification, section 5.2.21. This driver contains RAS2 Init, which extracts the RAS2 table. Driver adds platform device, for each memory feature, which binds to the RAS2 memory driver. Signed-off-by: Shiju Jose --- drivers/acpi/Makefile | 2 +- drivers/acpi/ras2_acpi.c | 97 ++++++++++++++++++++++++++++++++++++++++ 2 files changed, 98 insertions(+), 1 deletion(-) create mode 100755 drivers/acpi/ras2_acpi.c diff --git a/drivers/acpi/Makefile b/drivers/acpi/Makefile index b12fba9cff06..e3fd6feb3e54 100644 --- a/drivers/acpi/Makefile +++ b/drivers/acpi/Makefile @@ -105,7 +105,7 @@ obj-$(CONFIG_ACPI_CUSTOM_METHOD)+= custom_method.o obj-$(CONFIG_ACPI_BGRT) += bgrt.o obj-$(CONFIG_ACPI_CPPC_LIB) += cppc_acpi.o obj-$(CONFIG_ACPI_SPCR_TABLE) += spcr.o -obj-$(CONFIG_ACPI_RAS2) += ras2_acpi_common.o +obj-$(CONFIG_ACPI_RAS2) += ras2_acpi_common.o ras2_acpi.o obj-$(CONFIG_ACPI_DEBUGGER_USER) += acpi_dbg.o obj-$(CONFIG_ACPI_PPTT) += pptt.o obj-$(CONFIG_ACPI_PFRUT) += pfr_update.o pfr_telemetry.o diff --git a/drivers/acpi/ras2_acpi.c b/drivers/acpi/ras2_acpi.c new file mode 100755 index 000000000000..cd2e8f5ad253 --- /dev/null +++ b/drivers/acpi/ras2_acpi.c @@ -0,0 +1,97 @@ +// SPDX-License-Identifier: GPL-2.0-only +/* + * ras2_acpi.c - Implementation of ACPI RAS2 feature table processing + * functions. + * + * Copyright (c) 2023 HiSilicon Limited. + * + * Support for + * RAS2 - ACPI 6.5 Specification, section 5.2.21 + * + * Driver contains RAS2 init, which extracts the RAS2 table and + * registers the PCC channel for communicating with the ACPI compliant + * platform that contains RAS2 command support in hardware.Driver adds + * platform device which binds to the RAS2 memory driver. + */ + +#define pr_fmt(fmt) "ACPI RAS2: " fmt + +#include +#include +#include +#include +#include +#include + +#define RAS2_FEATURE_TYPE_MEMORY 0x00 + +static int __init ras2_acpi_init(void) +{ + u8 count; + acpi_status status; + acpi_size ras2_size; + int pcc_subspace_idx; + struct platform_device *pdev; + struct acpi_table_ras2 *pRas2Table; + struct acpi_ras2_pcc_desc *pcc_desc_list; + struct platform_device **pdev_list = NULL; + struct acpi_table_header *pAcpiTable = NULL; + + status = acpi_get_table("RAS2", 0, &pAcpiTable); + if (ACPI_FAILURE(status) || !pAcpiTable) { + pr_err("ACPI RAS2 driver failed to initialize, get table failed\n"); + return RAS2_FAILURE; + } + + ras2_size = pAcpiTable->length; + if (ras2_size < sizeof(struct acpi_table_ras2)) { + pr_err("ACPI RAS2 table present but broken (too short #1)\n"); + goto free_ras2_table; + } + + pRas2Table = (struct acpi_table_ras2 *)pAcpiTable; + + if (pRas2Table->num_pcc_descs <= 0) { + pr_err("ACPI RAS2 table does not contain PCC descriptors\n"); + goto free_ras2_table; + } + + pdev_list = kzalloc((pRas2Table->num_pcc_descs * sizeof(struct platform_device *)), + GFP_KERNEL); + if (!pdev_list) + goto free_ras2_table; + + pcc_desc_list = (struct acpi_ras2_pcc_desc *) + ((void *)pRas2Table + sizeof(struct acpi_table_ras2)); + count = 0; + while (count < pRas2Table->num_pcc_descs) { + if (pcc_desc_list->feature_type == RAS2_FEATURE_TYPE_MEMORY) { + pcc_subspace_idx = pcc_desc_list->channel_id; + /* Add the platform device and bind ras2 memory driver */ + pdev = ras2_add_platform_device("ras2", &pcc_subspace_idx, + sizeof(pcc_subspace_idx)); + if (!pdev) + goto free_ras2_pdev; + pdev_list[count] = pdev; + } + count++; + pcc_desc_list = pcc_desc_list + sizeof(struct acpi_ras2_pcc_desc); + } + + acpi_put_table(pAcpiTable); + return RAS2_SUCCESS; + +free_ras2_pdev: + count = 0; + while (count < pRas2Table->num_pcc_descs) { + if (pcc_desc_list->feature_type == + RAS2_FEATURE_TYPE_MEMORY) + platform_device_put(pdev_list[count++]); + } + kfree(pdev_list); + +free_ras2_table: + acpi_put_table(pAcpiTable); + return RAS2_FAILURE; +} +late_initcall(ras2_acpi_init)