From nobody Thu Apr 2 09:13:05 2026 Received: from CH5PR02CU005.outbound.protection.outlook.com (mail-northcentralusazon11012022.outbound.protection.outlook.com [40.107.200.22]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 60C0C372B2C; Mon, 30 Mar 2026 09:42:32 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.200.22 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774863753; cv=fail; b=VoLbFIpKxTLhwRvxm6B6fy0yVMWahLyX8hwbCS6aXAl7pii2iiTBiGz4oTFAVSrbTHXdPiqpk1amP0IIORTpXrPV96d9eB3xo7xuKiwztm7LPjqDD4MviGNI/oaor2DmjLnKhRzgVmLD6JSWio+hkg3IEUvAEoaNij+5Jcn+CS8= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774863753; c=relaxed/simple; bh=+upANx41izA72ECEjvgxQLbzO+CYN/J4Xd+7f2f/V8E=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=RfWRmJidqXcZgcg6FIjKtW/scJzVgjr0ZLzbtH0zceOnwhJUpcrJ3jZUhNRS4Z/UfDldQuesG8qvMYke01TWNAJ5XXveSV1x4ApEn/Ftw1fDr+U0TsP5wWeGvGVVcb18biVP4K4ScxxESpwZF7tn8HQ+FQ4QdQ9wvr2PWqgGKJw= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=nvidia.com; spf=fail smtp.mailfrom=nvidia.com; dkim=pass (2048-bit key) header.d=Nvidia.com header.i=@Nvidia.com header.b=QFI+YTI/; arc=fail smtp.client-ip=40.107.200.22 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=nvidia.com Authentication-Results: smtp.subspace.kernel.org; spf=fail smtp.mailfrom=nvidia.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=Nvidia.com header.i=@Nvidia.com header.b="QFI+YTI/" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=Z1cRtMKT6c8H7nGGrywVFUyaTqY2WJc8CcTgMoZzwGl5qsTGXNrdrdgDTsd/5+VgDII1C3uLkxguAbNVDCTXDkxrZyh5K5UzkYnqDIgKO/Z9GufseeXnsw2TycjIrnuSqjWMjFXuLUpkFM+krJRdin/KdAU7cNiuXR6RALA55T5qbwe57HwlK1c/zvweOYGbX2HzitOL2pb6COubU5T9LZOhVHS/L9/QkeKveCGptVA2/BBKM/hn4smQjReKAV82svT4VxtBLTzQamQDK4sJrFHVB+OQBP46AdlWQrrS9abHsH4o261jItufZ/rgJudGvc8GB5Y1Ndx2EF1S8YJxTw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=QzgBZZk2BUzgMSm6mtr2EFsW3aRbvon+I8dMYcf+gWk=; b=E0puEb/tQGWnjM7iandTvnrRq+TR+i0L2qJTK6z0QPTygHtcpsWaZnheyK00Pb5NVgPZwJivOeaFxSnK7o+NJdWLAizKaOlbCKhs76Iq8JhpjzVl5hGimKsKf8H6iFY/j0MjcAM0NbBTtJT1Lp7dhYnoybtxW9GZiWTJPaREP+1nLqlvETYzeP7YRwByQmp+L26Y/JWe1PQ+Rzc7J+jsuIdz13YfBA5U/ELgZPfH7QqBph0AGAo9knUeQAczTew1B8VL+/5Hel21jfw8SWQJqV0zI8RKtERGELwwxtbkAaK0BbFmHhfj8UJ9jp74KUfGpiDvQgVYoj/hsyHn+gMMzQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=nvidia.com; dmarc=pass action=none header.from=nvidia.com; dkim=pass header.d=nvidia.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=QzgBZZk2BUzgMSm6mtr2EFsW3aRbvon+I8dMYcf+gWk=; b=QFI+YTI/vQQItaYbygZvitkw2b7FXo4AeRKlDDY8q/m07fThR2zrNCFpKWTPx8qOC0hy+J7h16sv/iSQhwmORFsUk0HafYDbwoUdz35ZiyMTfWAaST+yjRAa6+IEKi9EH9lts6AgQMc4nZaa6bi4lME6iFPmtkw8q6D556MxIG2NpS1QnZVWKjFcDZ1zclXJ3fpxc8jQF2ode2HYYdnXqzLW/+DiNh2QI70FS0ejtKTaCxWAlxntWW9s6lYW2KhY9kCTH+EJnGLyy5rbS+ajGp3+Q0BVtDzZjaBVJGDMrxY9RpV7SJKzBWvCXLgRXNfi/MGlT2A7UNseD0dp9Surrw== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=nvidia.com; Received: from PH7PR12MB7914.namprd12.prod.outlook.com (2603:10b6:510:27d::13) by DS0PR12MB8246.namprd12.prod.outlook.com (2603:10b6:8:de::19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9769.15; Mon, 30 Mar 2026 09:42:24 +0000 Received: from PH7PR12MB7914.namprd12.prod.outlook.com ([fe80::d390:582:5536:40ad]) by PH7PR12MB7914.namprd12.prod.outlook.com ([fe80::d390:582:5536:40ad%5]) with mapi id 15.20.9769.014; Mon, 30 Mar 2026 09:42:24 +0000 From: Kai-Heng Feng To: rafael@kernel.org Cc: jonathan.cameron@huawei.com, helgaas@kernel.org, guohanjun@huawei.com, linux-kernel@vger.kernel.org, linux-acpi@vger.kernel.org, linux-pci@vger.kernel.org, acpica-devel@lists.linux.dev, linux-hardening@vger.kernel.org, Kai-Heng Feng , Shiju Jose , Tony Luck , Borislav Petkov , Mauro Carvalho Chehab , Shuai Xue , Len Brown , Robert Moore , "Fabio M. De Francesco" , Breno Leitao , Jason Tian Subject: [PATCH v3 1/3] ACPI: APEI: GHES: Add devm_ghes_register_vendor_record_notifier() Date: Mon, 30 Mar 2026 17:41:55 +0800 Message-ID: <20260330094203.38022-2-kaihengf@nvidia.com> X-Mailer: git-send-email 2.50.1 In-Reply-To: <20260330094203.38022-1-kaihengf@nvidia.com> References: <20260330094203.38022-1-kaihengf@nvidia.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: TPYP295CA0001.TWNP295.PROD.OUTLOOK.COM (2603:1096:7d0:9::18) To PH7PR12MB7914.namprd12.prod.outlook.com (2603:10b6:510:27d::13) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PH7PR12MB7914:EE_|DS0PR12MB8246:EE_ X-MS-Office365-Filtering-Correlation-Id: 391ddfab-0d0e-47be-e89e-08de8e40a5a5 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|1800799024|7416014|376014|56012099003|18002099003|22082099003; X-Microsoft-Antispam-Message-Info: nXqfpL9zFbZ3dJVwQbo4z+K/AkIStsDYiRWml1+eKwSUmqIsddGoAMoYS178y2LbSMFLdWQHfpueD+ZZF9wNW/mGfw4Li8SZFRlR7OzArO1j7y6iun8v7Rzf926bDXYIKwFqCkPw3amv9lXDU9hjktnFb2UnTIFQNzxqPV+HEmtkv3GrQ6beNOjO7E+U/w/0mKknf9JYwc+PHmQdumRVEiwhOlRkSSbtyLW72qNn1wasSVeJVTHNmvHj8tkmVdCERIjwbd1r5Zr48XUDSiPJM1dpu0ldWFs/CJMps0M5cHpp6cCtO8AHNfNOsB+OYQvBM4i4BX/Yga0HiS2Wgqvnc/CDArAA+ptaA7B39k+QSrqwzGUdGE2+MzxGPVpL0tuYb95V42PeFrY6fdtzZPUz3AsfDa5NuYhshs6jM7sXYo/DTaxSdV9uATqceIAUvum64Bf2asRCKXxpFoto+VhTYeT2l0apa45hR+5H3otIvTZ87vPr/mcEHtffTB8CLA29wy8HRUGXi7rWpemipEdcatlQlIaJMBah43+hQAFm2S6E8WfnafKCIH9QZ9L9SCWjqsOj/5CZu9SgXyg0UnISWrWE5SmD83vB4IRvMlKzaY43tPyvMPCnTLRQ00kkRLeRFKnkk1BuBeQMJUMULSCTMVacYplzuKjdeaqfwm+FbnDsRRPlzabNFG4PD2v1kOSXz9QsiVaV7me8IBqE0MCvErBvQgz2FMYRQYKMn13gN/E= X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PH7PR12MB7914.namprd12.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(366016)(1800799024)(7416014)(376014)(56012099003)(18002099003)(22082099003);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?us-ascii?Q?xXWx4Gmx0s0HQeLU4zFzVGiH816ahgLjR8yUhfi1odRiJbGsBZJLPCBP81JL?= =?us-ascii?Q?S31577s3v/foV7TF6fMCXHMCE6LyqdEkdStg+1tzph62ik7ztsIN7vEoSzTu?= =?us-ascii?Q?rHwPZcTqcuJAyvMOjuJ4HxNWnxC2KbJJVnZp5jelBYOVb+v4KWRPELopuH2E?= =?us-ascii?Q?jWV+vvfxk7ulSSGDPrapzGkPuiTu1UwDQj/DpEoy1f+RNSPZpsTOLSSWtVpZ?= =?us-ascii?Q?QpVJWW7X27csDAtTkM4GkpIJIllOcQnpFRRGKeU5CsofnaRk34CaPMO9ToeK?= =?us-ascii?Q?VCdcagd/EapQyKIvq3HIcx7AkAEqzlduUXM4EKo+q6qLdkAwCFdfgGxIFENX?= =?us-ascii?Q?hYyJSvFksForF3egssBJowKgfd4z8dAFLui1cWnmoZS0INOWXOih5aR1OSCn?= =?us-ascii?Q?4oyiZA6+HnruPy4pIXnp/IdpzJ/37ZgttkIGvLYS3tr6itQ1P+BKBG5pYLsD?= =?us-ascii?Q?I3CFS/0IKt6L1eqMQ37Sq4LeN6sU7ZB0uh1YrjJp2YImb0zP5LmWEALluJ3F?= =?us-ascii?Q?8SUeHcR6HccTt6+5Uz50rURrNSDr17zPbH7xF3kvm8dTmwnGxgA4pFqREXox?= =?us-ascii?Q?0V5TWfHi42bi6XpObzNpMdiYjsgj5MIlv6EfpbWX42ga3trJingc7DVB/xYi?= =?us-ascii?Q?rBghRGU/4Y8kdIxfaGCoXewo+9XH8klGs+KHHWsGBuxCvF8sapfhOHVJME9w?= =?us-ascii?Q?hikMDZmbcWWa9RK8ELD8Cz9MykYav14nI5aFo37RAuvZ38iTlgr0s0TRCOjJ?= =?us-ascii?Q?A2hAMtEA0GO3S13Hv41KVkPsQTh29kX5EyGnCClcP731LVsPZpopsPnqKJEH?= =?us-ascii?Q?SA7PFj126oLM0nOVAqAkPGioWh9KlGkBjikW8DNfbODqJb3ZGXkYoG9e7ppg?= =?us-ascii?Q?U7Q8HYhzpfNOBZ2bdPPN3oISWkSnOF+HR9LPmQL98pVtpg+aJmnK8mPMpF0X?= =?us-ascii?Q?Smy8b5pROf1ezRPek9yAQF8xAURGuXDye6aYQIsAG2J294buDsBX81B2tcY7?= =?us-ascii?Q?3GGSKVrEzIhsA6xVflAtMnMDJK81Jh9BgirfI7xu+Sk3wU5gdc8P4uRAHAma?= =?us-ascii?Q?5HEcs8RwD2vy2QDusDZAeyhKP5i2nHJ3i8XDfjPBnyO7BX76b4HgnyVUrtOE?= =?us-ascii?Q?yNsuu2QBbr64Mu6RFfexlCMehUQWquEtvFDrZ9zZ7bKE1BTNudQJKeLLgClr?= =?us-ascii?Q?v6TWj9cSdPd7+Nh2TCSTucb9fu5nqjq1FHnq2sVu0Ui+WKGKjsdCDD3HsOch?= =?us-ascii?Q?R2httQSTP9mXfQOpR4SWhycID5U8aQVNf/Opkxx12T5QueOjz+hdybjLlo+9?= =?us-ascii?Q?Rgi972M+C/VxTiH+xts8Q5+kRBpWLeyyEdktkf5jBRx4szCKC/0mN3+dKRaZ?= =?us-ascii?Q?JCWs+2rg1hFGNTd/nAavKh35YV0AitHzt6nTD53dG9sAU8lvvrODZbqj+8Y0?= =?us-ascii?Q?mDBZWOV7q6f2nlkjE6KzUxqFFFHBI+LHRMnQNjjG1TauBfpHnqOen/9Pjxlg?= =?us-ascii?Q?/W+xWp/hHTn2j+ykpgPiw0g0t2Utdhz6bMFf88Z9RBB8HzjJGFL9tkyKAGzd?= =?us-ascii?Q?jINFbWLc54UCIJOd7o+ZazOobb6EWVJCdIOzzBRj5r1BKQVR5RpJhjCZoMo/?= =?us-ascii?Q?yleIzxunPS+QefLziEHAVBjgoIwNPHUtcaiFo5s6j9NQqxVM3oworLbwBzY2?= =?us-ascii?Q?2v4zwHW45u+3eVI93ojJfWwHV/DQ3eZbDl7uAC9XXpJdd5c9AkNJ22IPXujj?= =?us-ascii?Q?nusWGd3tjA=3D=3D?= X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-Network-Message-Id: 391ddfab-0d0e-47be-e89e-08de8e40a5a5 X-MS-Exchange-CrossTenant-AuthSource: PH7PR12MB7914.namprd12.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 30 Mar 2026 09:42:24.3445 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: msss23uoJi63RiNVaNQdr6+hMefJ3cFF0Vy8CaipJGB6e36+OdtqhebuunwxbwkN4IcZNiXTpZYCn989JUkv3Q== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DS0PR12MB8246 Content-Type: text/plain; charset="utf-8" Add a device-managed wrapper around ghes_register_vendor_record_notifier() so drivers can avoid manual cleanup on device removal or probe failure. Cc: Shiju Jose Cc: Jonathan Cameron Signed-off-by: Kai-Heng Feng Reviewed-by: Breno Leitao Reviewed-by: Shiju Jose Reviewed-by: Shuai Xue --- v3: - Change patch title - Move documentation to header file. v2: - New patch. drivers/acpi/apei/ghes.c | 18 ++++++++++++++++++ include/acpi/ghes.h | 11 +++++++++++ 2 files changed, 29 insertions(+) diff --git a/drivers/acpi/apei/ghes.c b/drivers/acpi/apei/ghes.c index 8acd2742bb27..3236a3ce79d6 100644 --- a/drivers/acpi/apei/ghes.c +++ b/drivers/acpi/apei/ghes.c @@ -689,6 +689,24 @@ void ghes_unregister_vendor_record_notifier(struct not= ifier_block *nb) } EXPORT_SYMBOL_GPL(ghes_unregister_vendor_record_notifier); =20 +static void ghes_vendor_record_notifier_destroy(void *nb) +{ + ghes_unregister_vendor_record_notifier(nb); +} + +int devm_ghes_register_vendor_record_notifier(struct device *dev, + struct notifier_block *nb) +{ + int ret; + + ret =3D ghes_register_vendor_record_notifier(nb); + if (ret) + return ret; + + return devm_add_action_or_reset(dev, ghes_vendor_record_notifier_destroy,= nb); +} +EXPORT_SYMBOL_GPL(devm_ghes_register_vendor_record_notifier); + static void ghes_vendor_record_work_func(struct work_struct *work) { struct ghes_vendor_record_entry *entry; diff --git a/include/acpi/ghes.h b/include/acpi/ghes.h index 7bea522c0657..8d7e5caef3f1 100644 --- a/include/acpi/ghes.h +++ b/include/acpi/ghes.h @@ -71,6 +71,17 @@ int ghes_register_vendor_record_notifier(struct notifier= _block *nb); */ void ghes_unregister_vendor_record_notifier(struct notifier_block *nb); =20 +/** + * devm_ghes_register_vendor_record_notifier - device-managed vendor + * record notifier registration. + * @dev: device that owns the notifier lifetime + * @nb: pointer to the notifier_block structure of the vendor record handl= er + * + * Return: 0 on success, negative errno on failure. + */ +int devm_ghes_register_vendor_record_notifier(struct device *dev, + struct notifier_block *nb); + struct list_head *ghes_get_devices(void); =20 void ghes_estatus_pool_region_free(unsigned long addr, u32 size); --=20 2.50.1 (Apple Git-155) From nobody Thu Apr 2 09:13:05 2026 Received: from SN4PR2101CU001.outbound.protection.outlook.com (mail-southcentralusazon11012002.outbound.protection.outlook.com [40.93.195.2]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 850803B5843; Mon, 30 Mar 2026 09:42:35 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.93.195.2 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774863756; cv=fail; b=fluC5m1RuuH4t5krVnF97ZZENK+X4xHLyd+doFde4P7i8E7WVXA/Z91ky0TwW4gJ1FxvCKo81xMiM3oY4zbvHBd/j8k92lS+K82u0HF/q9C0IFNqAGb8QyHeh/wt5w0vkvJHfO+Z8/9+cOZ0OdlYwLv+nOFda38KvtttMG13PcE= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774863756; c=relaxed/simple; bh=3DdNfduovS/XZ0aFQdZcOCtyRKiP3+e3bA+u8vGlb4g=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=VJlh15vfzTZ8Cz/mDAHHnr4MpPXvjP41WuX5zVOMfszNuB/9YFJXSDz/Pjq4f9xjtXhdxZBe7K0+Cvi7k39JohqlBA0YDiCMjCkKbQprY4cRc0qBsXv59k50F6JmuDXSHnJujcuqNciXf0IZbmzs0++2zgLqAH9e1QzoJ9PTxks= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=nvidia.com; spf=fail smtp.mailfrom=nvidia.com; dkim=pass (2048-bit key) header.d=Nvidia.com header.i=@Nvidia.com header.b=IFSe1/xP; arc=fail smtp.client-ip=40.93.195.2 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=nvidia.com Authentication-Results: smtp.subspace.kernel.org; spf=fail smtp.mailfrom=nvidia.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=Nvidia.com header.i=@Nvidia.com header.b="IFSe1/xP" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=UJbxyYuIwsdVVqJtU9Mp2wRHf6nhyOcJGK6TeCgXwvmGduZb6OiLDGfoJ3Qzk6vxMs9BLGEpWh5+xvwB65Aa0//vO55VkH8DaLd4LXtuTVdH7KWXzgokLZXp9HCdn0tcINm53LFHB9IRSZvBTMmeVx6vPUrWby3AkIzd/305ezXCYlJoS0FBIT5ve4JLcRbMCk17xVE/aJko71gNvgIuqnifoq1AvevJptOBymOhPNO03qrs6k3rR0TY+nk1uodfsfOpnPLJp61C9FJfT23pEiPHFhbTnZTY35ZxsZfx44hxTlre/CiY96Y3ZbuEeg0n8SbkiLT1vJfdk5dLMfX9KA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=tT5EAPvYUYcGHy1V/++7+iiZbh6/09CSEK8EMczoeCM=; b=kt67PiLmapHtOGYtDqVCpX7t2RAKG1K2FsoYrgDtG4e792zaDxG2i8KdD00FUKe/wdqhPlJXoeXenQumDjbUwavu+tyZnpPcHAyWjLI2hhL6RQj9vjkiYnHy4pIAe0NFznQPViFkANaL55iTtioOAtkn470JJSd/kU6f4qwvcZ8V+WqL+Deu66f9Daji/U886cI8lM8B7Vv/e2hXztRCDz+VHFOrk3ICQ88uej5+W+urcJh2HeHC+VNBiArwQkW8cM7vUZmTrrzR3esZDpJgmQx64TKhKyFZ2qh6WsfuHjZdpRsExAaxe2kT8QROk7JGFVIZIjA72Bxqn1ADNQfZpg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=nvidia.com; dmarc=pass action=none header.from=nvidia.com; dkim=pass header.d=nvidia.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=tT5EAPvYUYcGHy1V/++7+iiZbh6/09CSEK8EMczoeCM=; b=IFSe1/xPx2OBPF96HrmT6kY5NaP1lD8M4HEHP/xV1owE3uJEA3YgavIMct9OzhEKAZzF2bkrXD6Z97wG3hQzMqO0LqyVq1ojJqEsrnYr9012b+masaASOXI+exxvvX9CZXQmKPYHZWl5r5I7S8x2j2l6xna1wKPp3xMULHe5f4uc0449DsyY8X61Oewwk26vKypOz6RP34N/46cSLcmg8dqmtSGrtn193AZ8LI36sq/+kMjtaxrzxvI8nRkF4tilvI8eDiDgEVDkKiKqPFZZeqJl2bjyx0KRsGpTtLelBAUPbxEE+1q2gTuwrToGWZcVrKPSrlkVgV5nw4KozwPdBg== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=nvidia.com; Received: from PH7PR12MB7914.namprd12.prod.outlook.com (2603:10b6:510:27d::13) by DS0PR12MB8246.namprd12.prod.outlook.com (2603:10b6:8:de::19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9769.15; Mon, 30 Mar 2026 09:42:29 +0000 Received: from PH7PR12MB7914.namprd12.prod.outlook.com ([fe80::d390:582:5536:40ad]) by PH7PR12MB7914.namprd12.prod.outlook.com ([fe80::d390:582:5536:40ad%5]) with mapi id 15.20.9769.014; Mon, 30 Mar 2026 09:42:28 +0000 From: Kai-Heng Feng To: rafael@kernel.org Cc: jonathan.cameron@huawei.com, helgaas@kernel.org, guohanjun@huawei.com, linux-kernel@vger.kernel.org, linux-acpi@vger.kernel.org, linux-pci@vger.kernel.org, acpica-devel@lists.linux.dev, linux-hardening@vger.kernel.org, Kai-Heng Feng , Shiju Jose , Lorenzo Pieralisi , =?UTF-8?q?Krzysztof=20Wilczy=C5=84ski?= , Manivannan Sadhasivam , Rob Herring , Bjorn Helgaas Subject: [PATCH v3 2/3] PCI: hisi: Use devm_ghes_register_vendor_record_notifier() Date: Mon, 30 Mar 2026 17:41:56 +0800 Message-ID: <20260330094203.38022-3-kaihengf@nvidia.com> X-Mailer: git-send-email 2.50.1 In-Reply-To: <20260330094203.38022-1-kaihengf@nvidia.com> References: <20260330094203.38022-1-kaihengf@nvidia.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: TPYP295CA0012.TWNP295.PROD.OUTLOOK.COM (2603:1096:7d0:9::17) To PH7PR12MB7914.namprd12.prod.outlook.com (2603:10b6:510:27d::13) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PH7PR12MB7914:EE_|DS0PR12MB8246:EE_ X-MS-Office365-Filtering-Correlation-Id: b0b7b472-3b5d-4a58-6663-08de8e40a7d6 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|1800799024|7416014|376014|56012099003|18002099003|22082099003; X-Microsoft-Antispam-Message-Info: ruXstUKN/mCCyI99/9d+InUcL0FSarxXCuL0iHdRkILU9zLe9TBMuFNDCOYdX2VgEmBASmBoMZsRfaFG4NkYmurqUdO2WD0ol3owcz6gZHzyiDtFXNVlaKwDkm1zUYI+A4PuOgn4nwAoIqwtfDu7ZMlI7HKZ2/1vqCAUG8NaAb/88xQrn7ZNy8vJPSCQnwBC8PTdx4gX8bbKECJSESYn8McD4f2yrcCjo5dCSox5EfXkglmM/MQgpkx7OBq7hbZHThsw4zPnSoVeWvIXWZdGFeJNdo8AtnsQn3PWklYP+lh/RySYUK35qyZV1eEqQirNlVD6fqyw5MIM8gOxUYr4MiGeJWp6+nFfDCANoM4id+XZU1bK1Q1GQLK9TD3wTVwB4IXlYIc77qx5Udc9BNK2KYFMsV/3VfCuzRN7P6CfbXQDsRQbtK1LGAVByI+F8bj17ZHb66Ltx22LNL0pQDqqk1olHXAJz5t5JhJpE/7UBcz89//BaIEARSjN4ijnGlwvtNgWe0EKgomDSKn8kdeLEARvTtVhu1YMTpTcr6Ux6jjbHa4majTN1eLDQarOooZqSvZFk2WY0wqdw6ynN8J+YUeZQG/+/GIebbNsGr36onLBeE0iDo8WEVcG0MaFPl8Ab7n01sL7fnokaISmY5YJwcCbBys/uYLJdK3OTit4oxyfflyuHnHhnvE0umfw/zr0pHzwa5kDe/1F1b6YmbkkZcn0Pe4VzUk57HVcNQxCm9w= X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PH7PR12MB7914.namprd12.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(366016)(1800799024)(7416014)(376014)(56012099003)(18002099003)(22082099003);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?us-ascii?Q?1pBG89EziJv1i3cZTSkhBzfGXHU4BnwIK67Y4ekFKHyFOieH7J4EGh1+qyzo?= =?us-ascii?Q?6tAssPAgHPKy/4d//E1fVD7wNekzw/xo6BF+crN9chEMn8UKVY4CvSmAtD9S?= =?us-ascii?Q?Yh9TRZR+f7cyhdoLkxpT8fGMorjXwCn5DhNz5bDZexufvx8QnGnWmOmQqROX?= =?us-ascii?Q?JBg62P1R3c7YVq5cUNJXBGoXU2ffQB0FdzeSpN1CINGI90rdf4dMbCvhD3ed?= =?us-ascii?Q?voL7EvW/M3cadbX4XYO8R1vyDfZbb9G6QBwL8mR4VraPaL8VCmsH4Gqz5rNC?= =?us-ascii?Q?ZUb5FU4NPMNBtWFbHg11gykTRRzlrKyt8eA09Wqh+fAUjpl3l4MsrpwGgsZz?= =?us-ascii?Q?W82UyiqDxPu6ZbTdebJgjYQq48BaZ+ne23CMBiHLd7gYYCu4Md2tpIgoHOJZ?= =?us-ascii?Q?257A6ePd9bQzsgzJspCabeMZzq8LjbeGxKZtal2D5si81OC7HY6hgfknoaCc?= =?us-ascii?Q?VZjTNk25aJAeMIuzYywi1YPuKOdraAQxvWIIkaSHUk3CIBk8fhM3ltaF91OB?= =?us-ascii?Q?Y1kz2+8oiuvskKlKNRZYbeVMm61Xcb6mJl9MCrAn6mkKLDSlnC8wLfJpyDqF?= =?us-ascii?Q?A4tZPoQgbapukUrWtpj9Y+Q+GPMP1tl1T9habXjj/nL1thjuk3YHsFx99wjN?= =?us-ascii?Q?hDyjX6P2XIlRCqTexgjyKtGbjtRdIpD6EzYO8kYOwW/W53ar5hPzts7i8jb1?= =?us-ascii?Q?MhPipJbdZXaMbDuMl/od0iqTDYPmJmKeh0orv6xUuksxcpdocFDG4nvkPrI+?= =?us-ascii?Q?hZil/AchxeNcTmSeXi6uPRmc4AvYshPqW/2ggPsRcK67sK1RXM8XLAG7r5/F?= =?us-ascii?Q?DmwRwB8KftcnJZjUO8/eAAPMpCgQvUi8BqZKpyzAVozmucdxKziHWXypcOWn?= =?us-ascii?Q?rvPqwPHjAJKv/UOYP8QmUXFsv5tPauueMC3mUheyX63qXaXZzmGYIDyVlXk1?= =?us-ascii?Q?JY6Z15MbbLFfVr2gCru3vMyhPVYK//b9QGHwqlKqQbO17pHfF4LkQc7VePNh?= =?us-ascii?Q?4CFFp+H+qwqpXk372UIn4SLVZRWHZbQUpTYHpQS2BlB9iFyD6q5GmhOZcPUK?= =?us-ascii?Q?7wrXg3mw3EjHuONm3d9BUlvxQwQQciVXfo3bV4WnlvwQtbWN3kebgCtH0NwG?= =?us-ascii?Q?CKVJtwAXDvos1HE1KAfcW+d8WGnovYjIsoAJwZU1Vfl8eVeigSV/GXaQsFbO?= =?us-ascii?Q?fJYOl7RHfO1Dd1wVqr2BBva/KpwCxhs40ZJvuBZC1mOFF0BeM0L+jdaI52Ci?= =?us-ascii?Q?JRppJfyc+uyC+YS9zVorKgI4ee1Eg4U/5bcwZc6pP2V6L42ghA/ea+6w5EH4?= =?us-ascii?Q?OCsdRB42kNXfDnsIkKFH/hFnOuoxsDhpWqaeMqwyvMOqXLhlKbx4oqUGw9aM?= =?us-ascii?Q?oZGOPfTaNeXO+qaTd5P3iqXi13icvrymu/HPpuetrCPAMY8zcutv8P5vo27A?= =?us-ascii?Q?ZO2GstEm2+CPZg9iMnEfTLMso/Kp/SIdu9cTGRUtjGaGSB0qsxpFSwM8otZX?= =?us-ascii?Q?FXwMCkvW5MwssL6ajPuQTC6ZsKcrD3+aLm2BKjdXSDNTEXQx8p0qy2DrK8t/?= =?us-ascii?Q?mP2bR/F3lrZGOpQuOmP8mMhDUWo+0ouRBr2cGkwfvTTQUyuFHh5BMrBGXihT?= =?us-ascii?Q?6c5XOY5rnUxzkh4T2tQrei0zA2X8GwUeJq72PA9wOcmNYoSun9ZpET7ZCIqA?= =?us-ascii?Q?+6BnpeMCD2ADEH3MZQyPcwnLCklgBhQsbVg/NcuIX7hGcdWU9+eQZ5K24xoX?= =?us-ascii?Q?u5PgvLqvTg=3D=3D?= X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-Network-Message-Id: b0b7b472-3b5d-4a58-6663-08de8e40a7d6 X-MS-Exchange-CrossTenant-AuthSource: PH7PR12MB7914.namprd12.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 30 Mar 2026 09:42:28.0592 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: IlzuuD5yFY6nrTLmmttyyoniff9jM3Iji+bKc8JVsdNv2VTO+Q2wRWu0nzgo9s931tMna4SZs0b3NdpcPo0THQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DS0PR12MB8246 Content-Type: text/plain; charset="utf-8" Switch to the device-managed variant so the notifier is automatically unregistered on device removal, allowing the open-coded remove callback to be dropped entirely. Cc: Shiju Jose Cc: Jonathan Cameron Signed-off-by: Kai-Heng Feng Acked-by: Manivannan Sadhasivam Reviewed-by: Shiju Jose --- v3: - No change. v2: - New patch. drivers/pci/controller/pcie-hisi-error.c | 12 +----------- 1 file changed, 1 insertion(+), 11 deletions(-) diff --git a/drivers/pci/controller/pcie-hisi-error.c b/drivers/pci/control= ler/pcie-hisi-error.c index aaf1ed2b6e59..36be86d827a8 100644 --- a/drivers/pci/controller/pcie-hisi-error.c +++ b/drivers/pci/controller/pcie-hisi-error.c @@ -287,25 +287,16 @@ static int hisi_pcie_error_handler_probe(struct platf= orm_device *pdev) =20 priv->nb.notifier_call =3D hisi_pcie_notify_error; priv->dev =3D &pdev->dev; - ret =3D ghes_register_vendor_record_notifier(&priv->nb); + ret =3D devm_ghes_register_vendor_record_notifier(&pdev->dev, &priv->nb); if (ret) { dev_err(&pdev->dev, "Failed to register hisi pcie controller error handler with apei\n"); return ret; } =20 - platform_set_drvdata(pdev, priv); - return 0; } =20 -static void hisi_pcie_error_handler_remove(struct platform_device *pdev) -{ - struct hisi_pcie_error_private *priv =3D platform_get_drvdata(pdev); - - ghes_unregister_vendor_record_notifier(&priv->nb); -} - static const struct acpi_device_id hisi_pcie_acpi_match[] =3D { { "HISI0361", 0 }, { } @@ -317,7 +308,6 @@ static struct platform_driver hisi_pcie_error_handler_d= river =3D { .acpi_match_table =3D hisi_pcie_acpi_match, }, .probe =3D hisi_pcie_error_handler_probe, - .remove =3D hisi_pcie_error_handler_remove, }; module_platform_driver(hisi_pcie_error_handler_driver); =20 --=20 2.50.1 (Apple Git-155) From nobody Thu Apr 2 09:13:05 2026 Received: from CH5PR02CU005.outbound.protection.outlook.com (mail-northcentralusazon11012071.outbound.protection.outlook.com [40.107.200.71]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 694891C8634; Mon, 30 Mar 2026 09:42:44 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.200.71 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774863766; cv=fail; b=HeWviAExRu1ByPqEt75jla2qKHyVPHUlKlg5iKWOGTvQlZSscOg2Hq/zFsQYPFaPF+XnE5HXb5jzcW17a3FmpI5e3J2TRIWtu639clf+geD3AEjRtA4Tg9StAvyFOEIadZu5XLWD9w5iFSUZMXkViexczLcxuXBfBnv69C0eRM8= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774863766; c=relaxed/simple; bh=EyvVatIVXyXeSNCM6/prcte6RRawCAJS/aS2n47enuE=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=Lm8e1xG3zbaNj3MlWv16/2zDOWu0r+VUJK/byfweXr0IJaeHp9/srbnCQKozMs5AGmZJ4loNYO69x8K3HKNtE+dUySk+Mp/ZjYG3l9bPFe8Y+8MDQ+HiitdWN4Qe/NGsM5FWN/rOpZ0yTsW7UcbWXy1Nwj1La0WD5XC4oOHFB3U= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=nvidia.com; spf=fail smtp.mailfrom=nvidia.com; dkim=pass (2048-bit key) header.d=Nvidia.com header.i=@Nvidia.com header.b=JvItaTnO; arc=fail smtp.client-ip=40.107.200.71 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=nvidia.com Authentication-Results: smtp.subspace.kernel.org; spf=fail smtp.mailfrom=nvidia.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=Nvidia.com header.i=@Nvidia.com header.b="JvItaTnO" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=HlVgq3k2QFTRwYJ5lxEumqZytirX0EvAKtoGenja50je0su95DktM3kpkaQNrRCeW8Qu+uaG248G1X53HCBtRw8JUvuL7yHDZgtA72bljzDZW+SmQW16l3jY2RJQDWRYhY/Lu86x7SOU57rDocMED2OofEkIwHTS6HvJvWVOvSnWQ0O//OnlbzE6riOvbXgtzXkx5K3dLL8VIRz7M7HHUc6nZ0xeb7WI0TewRAwRZ/IWF0Vfar2dM183OLyfuSz0mK/DiWG7G2Ob/heVF8Av1rI4Mqg0vQ+RQ9+Etbl21YKftqgyw/pExK4EgLfLx7Eyd0Wy79at/PKjnREdSE/xVA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=05puQeVSG8BXZrIx5PxIEjjWtrnc9cX6CzV/3nzePCs=; b=NwpLc+a6ZEMwhZRd5txT64h9GXD8Q4bkT63jV72K/1S0pW5ZXJrBU7a4+e6SqQ7kY9+0nahCYdwgh/8tro3P2MUz6zn5c9CLxYyYhGGuwriXtejqdEKglIOYygjArRyF/nPZND+1g0EnpcMjqNS42Y0Ar5oUE9oqEDzIZyPkW8LebJldNVn1Ozj4ri8HevdD3DnZgF+GLg5Qt7aVyGJQ/KAYwuqiLr58Rux2ZQ2UUdHLEOAsiI7KIRrDX5D74PlAItW4SDG3ckMxaMtV6UcAgywQieyQFHXHRsRysAvse7lZAK2kVMPX0CnBzhMaNyKIpQGT61ojT6nVgFxRRlftUg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=nvidia.com; dmarc=pass action=none header.from=nvidia.com; dkim=pass header.d=nvidia.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=05puQeVSG8BXZrIx5PxIEjjWtrnc9cX6CzV/3nzePCs=; b=JvItaTnOuR/tTnyO77z0+AZbmiUzR/tb2tgifKcTftDmrPGNffDQXaqMZBRBMpfGFmSaillWXnC5aenZk71wQEsmwj59Kn8mXy8YGn7Ir6ra+xJEJcCkgtkZIktLMx+cE8oPzi0cjG7w0T9X2utjDm4M2SGt8qYvLH1EF2keor1w398UFy0qub4Xtk1ri0bH+D2XY9x6l6STdV5G8a9q82XyShoIWCyJ7NXCFpsXpx4IFD0GbzONRDIQIJJP8GumbFMe8Kl78hT+47JqXI90GktO5m3unyHMLgEYe0PU0zZjoOe9qxrK3RtczxTlT3mk6Ry1j3bIp5GMNJ01/cmqew== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=nvidia.com; Received: from PH7PR12MB7914.namprd12.prod.outlook.com (2603:10b6:510:27d::13) by DS0PR12MB8246.namprd12.prod.outlook.com (2603:10b6:8:de::19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9769.15; Mon, 30 Mar 2026 09:42:38 +0000 Received: from PH7PR12MB7914.namprd12.prod.outlook.com ([fe80::d390:582:5536:40ad]) by PH7PR12MB7914.namprd12.prod.outlook.com ([fe80::d390:582:5536:40ad%5]) with mapi id 15.20.9769.014; Mon, 30 Mar 2026 09:42:38 +0000 From: Kai-Heng Feng To: rafael@kernel.org Cc: jonathan.cameron@huawei.com, helgaas@kernel.org, guohanjun@huawei.com, linux-kernel@vger.kernel.org, linux-acpi@vger.kernel.org, linux-pci@vger.kernel.org, acpica-devel@lists.linux.dev, linux-hardening@vger.kernel.org, Kai-Heng Feng , Shiju Jose , Tony Luck , Borislav Petkov , Mauro Carvalho Chehab , Shuai Xue , Len Brown , Kees Cook , "Gustavo A. R. Silva" , Gavin Shan , Huang Yiwei , Nathan Chancellor , Dave Jiang , "Fabio M. De Francesco" Subject: [PATCH v3 3/3] ACPI: APEI: GHES: Add NVIDIA vendor CPER record handler Date: Mon, 30 Mar 2026 17:41:57 +0800 Message-ID: <20260330094203.38022-4-kaihengf@nvidia.com> X-Mailer: git-send-email 2.50.1 In-Reply-To: <20260330094203.38022-1-kaihengf@nvidia.com> References: <20260330094203.38022-1-kaihengf@nvidia.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: TPYP295CA0006.TWNP295.PROD.OUTLOOK.COM (2603:1096:7d0:9::16) To PH7PR12MB7914.namprd12.prod.outlook.com (2603:10b6:510:27d::13) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PH7PR12MB7914:EE_|DS0PR12MB8246:EE_ X-MS-Office365-Filtering-Correlation-Id: 64da0bea-24a7-481c-71b8-08de8e40ade2 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|1800799024|7416014|376014|56012099003|18002099003|22082099003; X-Microsoft-Antispam-Message-Info: ue/Zpe2fRPFbNq700TCIVuM5fIJcHOqlVSOy76sHMCBdSl5D9VUUfSgmH2Y1SRoEPwcAQ8tOtDhFkYkLIuG7q00jG6UbRUYd4FqbUtqAYnUDrQt8jwmjPWfbxxrk48PomoBTcInJYtLcMLcwAaszf8mTsEUAyDewnDOt8Aj78EqYmdFG7vNA4YJ+8oOuy3DQVY0rCLDSGufK+ed6iT2f1RMPpq15RplV7vVY6QWpiXLvIZ5XzAlnfaSJTog4V/7GAMujsZMXBcUDe72y7nlC3NO1Ko9tGal4j8XPAjwRgNso4ZOfSViOVxATL7sDTpuvtxwR/8NRkNyhLwMYFSlvwR7oBuqsX6ZENxbUj8QbEpR8YkGRKyrANgsMVjmLEBnL9x15OjS9EhnP/TMCmCf1o6D65CV5E9xto/roUsDEn3H2eoFBcmM5uJK6gNZFKF/pZSJ6rFrR8pnzy/S+rZ11WsTGIBGKW1PVwRjBk3KhoB8pgGTwXfUmzYlBKKfnJcivskFztGMKWhsJUXUaYTeLTVtxruAlj/UgD8l00nzm/6iezZS7Qdq5dh3LzyCEEvwNtfr7Q9S/umfSzDBOWTzflRJum2QENxaVGhOU4A3TTGo06nB/2D0xDlE0hA8J6rn+rS02acPypB5P9O441BDgrkkf5+AnCluUy16j4Cx706v7U9CsGuad27fFgBfrkRyyt8fSP64TujJqybDWFDNs88C+qlAk5tTIJGgBWcOolat075MOlQspk96rWCI0BHb7 X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PH7PR12MB7914.namprd12.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(366016)(1800799024)(7416014)(376014)(56012099003)(18002099003)(22082099003);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?us-ascii?Q?3bVwh53oCCBdEP797WYrzrtoFWpbAo+H0fOq9oJUqPWm3TK8cxpg7bGC5/pT?= =?us-ascii?Q?gBRU0qATarZQBMVjuwzSMwS5khbfakqBm/FzLqXWmji0hqZ9lJzAtki4OiBI?= =?us-ascii?Q?0zuJrpvtgDXvefz9MCdq97Ad1eTrxd6A2pOejDCTnrcJN2hTZC9HGJzUHH8P?= =?us-ascii?Q?nmDdOeDfQXcftgZ2migibgskOtUkiMEPQ111KeC6BZ3ES4Q37awYQTo/R/IY?= =?us-ascii?Q?qWTmUamFB8Vd0kLwUV93vh5ZlEdZblPGIEgLSqL3yEh2mRQKxdzlv2K7Qgmv?= =?us-ascii?Q?RilWyOJMUe7syBviLIjFZJcXeOq/C1CT4J0BaMNEo07xTeGSLcR1C2rsJ+FG?= =?us-ascii?Q?Z7w1SCmDCktSelql6tZWhviUuaNrs7JBHuooIwdUWHWT2OFl+1Ps3g1Aqnq+?= =?us-ascii?Q?Tgzzfm2s2ipm09eNdnR0Nw9OBOQZWb9BqbE0hz8ntChpLuNiQJA7NFPLaWcc?= =?us-ascii?Q?nEQ2w4P+iSrtKTuxqmpWDXa4B11GKZvHaz/0YPT9z0IkfalatImgtO70+EOD?= =?us-ascii?Q?wLHv/tYDW/0eYaoJ7d+0vBv+L1RUpfBQBSf7sMOvUh3mkQqH695RLVLlYm58?= =?us-ascii?Q?F+DwWyYxuXWdjDmfa/Ucipp4PfeK9avM8KWSybAxx7G+Uiz+7kVNJo7Kkfm3?= =?us-ascii?Q?KDfP413L9GiaEbgiPPUGnRDlqkdFXtDFOzJ3eCdyDzJ2G6qm5rVDQuQu9uuX?= =?us-ascii?Q?G+/aDRRnkBhyksDclWrG35VEg15XFVsBOfFTsvFwrIIKZDQLkRmcETnS5CKF?= =?us-ascii?Q?wL+IEcQVSRnYjRBB4LfFof+Q/xTbCUozI1UJyGGFlks3WfRyN++55GW4af9H?= =?us-ascii?Q?KHcTgq1SvSkFdpGmboZPzUidWa6vYOSKReLbBLCEPa+Tvgsa1DZctdZXwQra?= =?us-ascii?Q?odt+ROSf1ZfPtbwOtOu06HkFxwW/cd5xKtrLLps0G1ASVozQqMIqlYgio9yT?= =?us-ascii?Q?cFgVzCx+TwGxMSF4jhJJG8Y6W8V3Jw9YPyJUjzwg6BQfH8cC488PTR6hVGRN?= =?us-ascii?Q?FJEkIshf595p4nvoLgojYBU7E+2dXt9kvtxi+IrV0MBd3AyAR31OAZRwea8d?= =?us-ascii?Q?vKSLEoBVTB6gPV81uOxGZDfkpTVQ15s25UTHrZoMoKz+Xfe0HmFEPf3C/MqK?= =?us-ascii?Q?P7EaETqLZ0Bf2ffv8quDEpzhsF4wiH5tWQV5uJSzf3XxIG2V/tUe7LDqylbl?= =?us-ascii?Q?prHvSFeBHDB7uUdpDEmZUxFzX/+qP4Usr9iX0j0nVijQQ6RuCXyLHzzoppLJ?= =?us-ascii?Q?Sp9hHGGKlUvTNe2lJaHvjkzFP6sY5RF9SPt4ShmWixAKvCdWB72SmuWMKLCl?= =?us-ascii?Q?4dYpJ55ejS24ZV6EvxK1HbqyUewSrHIq1C67JVS/CtEzwG7pdodsiQlDNm32?= =?us-ascii?Q?9yrRyEogJdBAC/UZcHjT/gsZLc9Cr3jCcZgD4Du3emDomvB5E0I7nc3UO1/0?= =?us-ascii?Q?JD+wzZTVq5aHMsY4hDBNLXmdS/h+Oxe2DvzI8oDIvghzwCwMD82+mVqs7Ak7?= =?us-ascii?Q?Y3iFwTC2XueowkTyaeMNbZuJfjy0mycxft0czqfMmDZve55PtFsO2M+iEkpH?= =?us-ascii?Q?1T2jGSWNhggriiiJbq3NB+vHxsF0H0Ey/VPNWZ8UlsEMTBO+0cLUyY5/3iQH?= =?us-ascii?Q?qxcIcWjN44KlQNhlGd360XrDnhYQbolC06/UM0oIg6B6X/0h+FG5miX6TZH+?= =?us-ascii?Q?ltEXjQS2jklh65Kuo9x4a5xsUFTBFtFqeSQ8xIgiIBtyXOjfscs/20/KsUQ9?= =?us-ascii?Q?1EYAv6IkWg=3D=3D?= X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-Network-Message-Id: 64da0bea-24a7-481c-71b8-08de8e40ade2 X-MS-Exchange-CrossTenant-AuthSource: PH7PR12MB7914.namprd12.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 30 Mar 2026 09:42:38.1835 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: jv6LdTnYO3mxet3FMMBGcbBUy+EXPJAFT5mQtVtQr0CXfw7XhKq4O41lqs53AkK4Ke/FIa2gbLTMexuAn50Ncg== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DS0PR12MB8246 Content-Type: text/plain; charset="utf-8" Add support for decoding NVIDIA-specific CPER sections delivered via the APEI GHES vendor record notifier chain. NVIDIA hardware generates vendor-specific CPER sections containing error signatures and diagnostic register dumps. This implementation registers a notifier_block with the GHES vendor record notifier and decodes these sections, printing error details via dev_info(). The driver binds to ACPI device NVDA2012, present on NVIDIA server platforms. The NVIDIA CPER section contains a fixed header with error metadata (signature, error type, severity, socket) followed by variable-length register address-value pairs for hardware diagnostics. This work is based on libcper [0]. Example output: nvidia-ghes NVDA2012:00: NVIDIA CPER section, error_data_length: 544 nvidia-ghes NVDA2012:00: signature: CMET-INFO nvidia-ghes NVDA2012:00: error_type: 0 nvidia-ghes NVDA2012:00: error_instance: 0 nvidia-ghes NVDA2012:00: severity: 3 nvidia-ghes NVDA2012:00: socket: 0 nvidia-ghes NVDA2012:00: number_regs: 32 nvidia-ghes NVDA2012:00: instance_base: 0x0000000000000000 nvidia-ghes NVDA2012:00: register[0]: address=3D0x8000000100000000 value=3D= 0x0000000100000000 [0] https://github.com/openbmc/libcper/commit/683e055061ce Cc: Shiju Jose Reviewed-by: Jonathan Cameron Signed-off-by: Kai-Heng Feng --- v3: - NVIDIA_GHES to GHES_NVIDIA. - Better error handling in probe() - "int i" in for loop. v2: - Use right headers. - Use embedded struct and __counted_by. - Drop __packed. - Remove unecessary casts.=20 - Use * in sizeof(). - Use devm_kmalloc() and struct assignment. - Use dev_err_probe and new devm helper. MAINTAINERS | 6 ++ drivers/acpi/apei/Kconfig | 14 +++ drivers/acpi/apei/Makefile | 1 + drivers/acpi/apei/ghes-nvidia.c | 149 ++++++++++++++++++++++++++++++++ 4 files changed, 170 insertions(+) create mode 100644 drivers/acpi/apei/ghes-nvidia.c diff --git a/MAINTAINERS b/MAINTAINERS index c3fe46d7c4bc..94608f8e247e 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -18919,6 +18919,12 @@ S: Maintained F: drivers/video/fbdev/nvidia/ F: drivers/video/fbdev/riva/ =20 +NVIDIA GHES VENDOR CPER RECORD HANDLER +M: Kai-Heng Feng +L: linux-acpi@vger.kernel.org +S: Maintained +F: drivers/acpi/apei/nvidia-ghes.c + NVIDIA VRS RTC DRIVER M: Shubhi Garg L: linux-tegra@vger.kernel.org diff --git a/drivers/acpi/apei/Kconfig b/drivers/acpi/apei/Kconfig index 070c07d68dfb..428458c623f0 100644 --- a/drivers/acpi/apei/Kconfig +++ b/drivers/acpi/apei/Kconfig @@ -74,6 +74,20 @@ config ACPI_APEI_EINJ_CXL =20 If unsure say 'n' =20 +config ACPI_APEI_GHES_NVIDIA + tristate "NVIDIA GHES vendor record handler" + depends on ACPI_APEI_GHES + help + Support for decoding NVIDIA-specific CPER sections delivered via + the APEI GHES vendor record notifier chain. Registers a handler + for the NVIDIA section GUID and logs error signatures, severity, + socket, and diagnostic register address-value pairs. + + Enable on NVIDIA server platforms (e.g. DGX, HGX) that expose + ACPI device NVDA2012 in their firmware tables. + + If unsure, say N. + config ACPI_APEI_ERST_DEBUG tristate "APEI Error Record Serialization Table (ERST) Debug Support" depends on ACPI_APEI diff --git a/drivers/acpi/apei/Makefile b/drivers/acpi/apei/Makefile index 1a0b85923cd4..66588d6be56f 100644 --- a/drivers/acpi/apei/Makefile +++ b/drivers/acpi/apei/Makefile @@ -10,5 +10,6 @@ obj-$(CONFIG_ACPI_APEI_EINJ) +=3D einj.o einj-y :=3D einj-core.o einj-$(CONFIG_ACPI_APEI_EINJ_CXL) +=3D einj-cxl.o obj-$(CONFIG_ACPI_APEI_ERST_DEBUG) +=3D erst-dbg.o +obj-$(CONFIG_ACPI_APEI_GHES_NVIDIA) +=3D ghes-nvidia.o =20 apei-y :=3D apei-base.o hest.o erst.o bert.o diff --git a/drivers/acpi/apei/ghes-nvidia.c b/drivers/acpi/apei/ghes-nvidi= a.c new file mode 100644 index 000000000000..597275d81de8 --- /dev/null +++ b/drivers/acpi/apei/ghes-nvidia.c @@ -0,0 +1,149 @@ +// SPDX-License-Identifier: GPL-2.0-only +/* + * NVIDIA GHES vendor record handler + * + * Copyright (c) 2026, NVIDIA CORPORATION & AFFILIATES. All rights reserve= d. + */ + +#include +#include +#include +#include +#include +#include + +static const guid_t nvidia_sec_guid =3D + GUID_INIT(0x6d5244f2, 0x2712, 0x11ec, + 0xbe, 0xa7, 0xcb, 0x3f, 0xdb, 0x95, 0xc7, 0x86); + +struct cper_sec_nvidia { + char signature[16]; + __le16 error_type; + __le16 error_instance; + u8 severity; + u8 socket; + u8 number_regs; + u8 reserved; + __le64 instance_base; + struct { + __le64 addr; + __le64 val; + } regs[] __counted_by(number_regs); +}; + +struct nvidia_ghes_private { + struct notifier_block nb; + struct device *dev; +}; + +static void nvidia_ghes_print_error(struct device *dev, + const struct cper_sec_nvidia *nvidia_err, + size_t error_data_length, bool fatal) +{ + const char *level =3D fatal ? KERN_ERR : KERN_INFO; + size_t min_size; + + dev_printk(level, dev, "signature: %.16s\n", nvidia_err->signature); + dev_printk(level, dev, "error_type: %u\n", le16_to_cpu(nvidia_err->error_= type)); + dev_printk(level, dev, "error_instance: %u\n", le16_to_cpu(nvidia_err->er= ror_instance)); + dev_printk(level, dev, "severity: %u\n", nvidia_err->severity); + dev_printk(level, dev, "socket: %u\n", nvidia_err->socket); + dev_printk(level, dev, "number_regs: %u\n", nvidia_err->number_regs); + dev_printk(level, dev, "instance_base: 0x%016llx\n", + le64_to_cpu(nvidia_err->instance_base)); + + if (nvidia_err->number_regs =3D=3D 0) + return; + + /* + * Validate that all registers fit within error_data_length. + * Each register pair is two little-endian u64s. + */ + min_size =3D struct_size(nvidia_err, regs, nvidia_err->number_regs); + if (error_data_length < min_size) { + dev_err(dev, "Invalid number_regs %u (section size %zu, need %zu)\n", + nvidia_err->number_regs, error_data_length, min_size); + return; + } + + for (int i =3D 0; i < nvidia_err->number_regs; i++) + dev_printk(level, dev, "register[%d]: address=3D0x%016llx value=3D0x%016= llx\n", + i, le64_to_cpu(nvidia_err->regs[i].addr), + le64_to_cpu(nvidia_err->regs[i].val)); +} + +static int nvidia_ghes_notify(struct notifier_block *nb, + unsigned long event, void *data) +{ + struct acpi_hest_generic_data *gdata =3D data; + struct nvidia_ghes_private *priv; + const struct cper_sec_nvidia *nvidia_err; + guid_t sec_guid; + + import_guid(&sec_guid, gdata->section_type); + if (!guid_equal(&sec_guid, &nvidia_sec_guid)) + return NOTIFY_DONE; + + priv =3D container_of(nb, struct nvidia_ghes_private, nb); + + if (acpi_hest_get_error_length(gdata) < sizeof(*nvidia_err)) { + dev_err(priv->dev, "Section too small (%d < %zu)\n", + acpi_hest_get_error_length(gdata), sizeof(*nvidia_err)); + return NOTIFY_OK; + } + + nvidia_err =3D acpi_hest_get_payload(gdata); + + if (event >=3D GHES_SEV_RECOVERABLE) + dev_err(priv->dev, "NVIDIA CPER section, error_data_length: %u\n", + acpi_hest_get_error_length(gdata)); + else + dev_info(priv->dev, "NVIDIA CPER section, error_data_length: %u\n", + acpi_hest_get_error_length(gdata)); + + nvidia_ghes_print_error(priv->dev, nvidia_err, acpi_hest_get_error_length= (gdata), + event >=3D GHES_SEV_RECOVERABLE); + + return NOTIFY_OK; +} + +static int nvidia_ghes_probe(struct platform_device *pdev) +{ + struct nvidia_ghes_private *priv; + int ret; + + priv =3D devm_kmalloc(&pdev->dev, sizeof(*priv), GFP_KERNEL); + if (!priv) + return -ENOMEM; + + *priv =3D (struct nvidia_ghes_private) { + .nb.notifier_call =3D nvidia_ghes_notify, + .dev =3D &pdev->dev, + }; + + ret =3D devm_ghes_register_vendor_record_notifier(&pdev->dev, &priv->nb); + if (ret) + return dev_err_probe(&pdev->dev, ret, + "Failed to register NVIDIA GHES vendor record notifier\n"); + + return 0; +} + +static const struct acpi_device_id nvidia_ghes_acpi_match[] =3D { + { "NVDA2012" }, + { } +}; +MODULE_DEVICE_TABLE(acpi, nvidia_ghes_acpi_match); + +static struct platform_driver nvidia_ghes_driver =3D { + .driver =3D { + .name =3D "nvidia-ghes", + .acpi_match_table =3D nvidia_ghes_acpi_match, + }, + .probe =3D nvidia_ghes_probe, +}; +module_platform_driver(nvidia_ghes_driver); + +MODULE_AUTHOR("Kai-Heng Feng "); +MODULE_DESCRIPTION("NVIDIA GHES vendor CPER record handler"); +MODULE_LICENSE("GPL"); --=20 2.50.1 (Apple Git-155)