[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20231017184844.2350750-1-avadhut.naik@amd.com>
Date: Tue, 17 Oct 2023 13:48:40 -0500
From: Avadhut Naik <avadhut.naik@....com>
To: <rafael@...nel.org>, <lenb@...nel.org>,
<linux-acpi@...r.kernel.org>
CC: <yazen.ghannam@....com>, <alexey.kardashevskiy@....com>,
<gregkh@...uxfoundation.org>, <linux-fsdevel@...r.kernel.org>,
<linux-kernel@...r.kernel.org>, <avadnaik@....com>
Subject: [PATCH v5 0/4] Add support for Vendor Defined Error Types in Einj Module
This patchset adds support for Vendor Defined Error types in the einj
module by exporting a binary blob file in module's debugfs directory.
Userspace tools can write OEM Defined Structures into the blob file as
part of injecting Vendor defined errors. Similarly, the very tools can
also read from the blob file for information, if any, provided by the
firmware after error injection.
The first patch refactors available_error_type_show() function to ensure
all errors supported by the platform are output through einj module's
available_error_type file in debugfs.
The second patch adds a write callback for binary blobs created through
debugfs_create_blob() API.
The third patch fixes the permissions of panicinfo file in debugfs to
ensure it remains read-only
The fourth patch adds the required support i.e. establishing the memory
mapping and exporting it through debugfs blob file for Vendor-defined
Error types.
Changes in v2:
- Split the v1 patch, as was recommended, to have a separate patch for
changes in debugfs.
- Refactored available_error_type_show() function into a separate patch.
- Changed file permissions to octal format to remove checkpatch warnings.
Changes in v3:
- Use BIT macro for generating error masks instead of hex values since
ACPI spec uses bit numbers.
- Handle the corner case of acpi_os_map_iomem() returning NULL through
a local variable to a store the size of OEM defined data structure.
Changes in v4:
- Fix permissions for panicinfo file in debugfs.
- Replace acpi_os_map_iomem() and acpi_os_unmap_iomem() calls with
acpi_os_map_memory() and acpi_os_unmap_memory() respectively to avert
sparse warnings as suggested by Alexey.
Changes in v5:
- Change permissions of the "oem_error" file, being created in einj
module's debugfs directory, from "w" to "rw" since system firmware
in some cases might provide some information through OEM-defined
structure for tools to consume.
- Remove Reviewed-by: Alexey Kardashevskiy <aik@....com> from the
fourth patch since permissions of the oem_error file have changed.
- Add Reviewed-by: Greg Kroah-Hartman <gregkh@...uxfoundation.org> for
second and third patch.
- Rebase on top of tip master.
Avadhut Naik (4):
ACPI: APEI: EINJ: Refactor available_error_type_show()
fs: debugfs: Add write functionality to debugfs blobs
platform/chrome: cros_ec_debugfs: Fix permissions for panicinfo
ACPI: APEI: EINJ: Add support for vendor defined error types
drivers/acpi/apei/einj.c | 67 ++++++++++++++++-------
drivers/platform/chrome/cros_ec_debugfs.c | 2 +-
fs/debugfs/file.c | 28 ++++++++--
3 files changed, 70 insertions(+), 27 deletions(-)
--
2.34.1
Powered by blists - more mailing lists