Received: by 2002:a05:6a10:eb17:0:0:0:0 with SMTP id hx23csp479458pxb; Wed, 8 Sep 2021 05:44:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyQ2sVrLmM2I6CrWrnVn6DuYbs+cWpS0uLzPs7rz8qEVxWLBUfmY3d5hV5mJnUq6dK+HDWZ X-Received: by 2002:a02:ce37:: with SMTP id v23mr3544449jar.81.1631105078915; Wed, 08 Sep 2021 05:44:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1631105078; cv=none; d=google.com; s=arc-20160816; b=HcJKzYn34tiNF1IwIDotqXSwJt8SLuraBVfX4IKCHjKrg68djrFp6Bl0JujDvySFu0 YLZ3U8wDAb9/0yuUlw1mFhR161N+jIX685ablHATwKCwT/4cBxw7462eqy8N3UDWrR6Q tj+/327f9SoOrCfoGpIHNURg4gaQ2MRIkTxLEuw3tVoNFXf7/J48NRSsvqftC9TUriXr 2Ssx9OhP1ZyaBfnDsj3Q4AkHN5qgb2QDQHQwDss96E/e2oGuslba6HydbW1Zt+S4d/TO Z7Vh7sNmv3CApyRPm5pjW+3LJaLFwMDvHYuxdUV0hYVw5PQDJjBtw4U9RVnXhLjnPAQQ 4ZSA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from; bh=CTpA/yEyEnP21QbFyqWWfHOmM+RxuZAtHCIXGQYaIl8=; b=hdLZnC+KnXXos6KJHah2vNkomnNtEVR9omGyCGWBmQa1deGUtTO81WDf95b0Tfrael +VV81AkobuzAc+Q/S6rwFKxWiiIrsJVCicUyF5OpBXAPqPS1IEUUmEZMXZkqsJ7ILUid cmJ03tDpPA8Pnob8gH+o8wI6WBGaaK0sVGDEzqv/J8ieg5oUVcCTNVUHfnEHbxr6HOVm Od7Tip1YmwrAELZDn2Fl7iuJK84HpKT+89lkDCVFre8ixhe83SZeLeoQEPGzo9JXupzZ seuSR+pyvGsuCfMKxG0q9t2LlU6vyOXWKWGy5oIvIlbMIu1yvHWq0guk1PzejD2Kxto+ XmlA== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 192si1575273ioc.91.2021.09.08.05.44.25; Wed, 08 Sep 2021 05:44:38 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1348868AbhIHLBq (ORCPT + 99 others); Wed, 8 Sep 2021 07:01:46 -0400 Received: from mga02.intel.com ([134.134.136.20]:34072 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233694AbhIHLBp (ORCPT ); Wed, 8 Sep 2021 07:01:45 -0400 X-IronPort-AV: E=McAfee;i="6200,9189,10100"; a="207682229" X-IronPort-AV: E=Sophos;i="5.85,277,1624345200"; d="scan'208";a="207682229" Received: from fmsmga008.fm.intel.com ([10.253.24.58]) by orsmga101.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 08 Sep 2021 04:00:37 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.85,277,1624345200"; d="scan'208";a="503516328" Received: from aubrey-ubuntu.sh.intel.com ([10.239.53.132]) by fmsmga008.fm.intel.com with ESMTP; 08 Sep 2021 04:00:35 -0700 From: Aubrey Li To: rjw@rjwysocki.net, pmenzel@molgen.mpg.de Cc: linux-acpi@vger.kernel.org, linux-kernel@vger.kernel.org, Aubrey Li , Aubrey Li Subject: [PATCH v2] ACPI/PRM: Find PRMT table before parse it Date: Wed, 8 Sep 2021 18:55:45 +0800 Message-Id: <1631098545-64372-1-git-send-email-aubrey.li@intel.com> X-Mailer: git-send-email 2.7.4 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Find and verify PRMT table before parse it, this eliminates a warning on machines without PRMT table. [ 7.197173] ACPI: PRMT not present Fixes: cefc7ca46235 ("ACPI: PRM: implement OperationRegion handler for the PlatformRtMechanism subtype") Signed-off-by: Aubrey Li Tested-by: Paul Menzel --- drivers/acpi/prmt.c | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/drivers/acpi/prmt.c b/drivers/acpi/prmt.c index 1f6007a..89c22bc 100644 --- a/drivers/acpi/prmt.c +++ b/drivers/acpi/prmt.c @@ -288,10 +288,18 @@ static acpi_status acpi_platformrt_space_handler(u32 function, void __init init_prmt(void) { + struct acpi_table_header *tbl; acpi_status status; - int mc = acpi_table_parse_entries(ACPI_SIG_PRMT, sizeof(struct acpi_table_prmt) + + int mc; + + status = acpi_get_table(ACPI_SIG_PRMT, 0, &tbl); + if (ACPI_FAILURE(status)) + return; + + mc = acpi_table_parse_entries(ACPI_SIG_PRMT, sizeof(struct acpi_table_prmt) + sizeof (struct acpi_table_prmt_header), 0, acpi_parse_prmt, 0); + acpi_put_table(tbl); /* * Return immediately if PRMT table is not present or no PRM module found. */ -- 2.7.4