Path: blob/master/drivers/acpi/apei/apei-internal.h
15109 views
/*1* apei-internal.h - ACPI Platform Error Interface internal2* definations.3*/45#ifndef APEI_INTERNAL_H6#define APEI_INTERNAL_H78#include <linux/cper.h>910struct apei_exec_context;1112typedef int (*apei_exec_ins_func_t)(struct apei_exec_context *ctx,13struct acpi_whea_header *entry);1415#define APEI_EXEC_INS_ACCESS_REGISTER 0x00011617struct apei_exec_ins_type {18u32 flags;19apei_exec_ins_func_t run;20};2122struct apei_exec_context {23u32 ip;24u64 value;25u64 var1;26u64 var2;27u64 src_base;28u64 dst_base;29struct apei_exec_ins_type *ins_table;30u32 instructions;31struct acpi_whea_header *action_table;32u32 entries;33};3435void apei_exec_ctx_init(struct apei_exec_context *ctx,36struct apei_exec_ins_type *ins_table,37u32 instructions,38struct acpi_whea_header *action_table,39u32 entries);4041static inline void apei_exec_ctx_set_input(struct apei_exec_context *ctx,42u64 input)43{44ctx->value = input;45}4647static inline u64 apei_exec_ctx_get_output(struct apei_exec_context *ctx)48{49return ctx->value;50}5152int apei_exec_run(struct apei_exec_context *ctx, u8 action);5354/* Common instruction implementation */5556/* IP has been set in instruction function */57#define APEI_EXEC_SET_IP 15859int __apei_exec_read_register(struct acpi_whea_header *entry, u64 *val);60int __apei_exec_write_register(struct acpi_whea_header *entry, u64 val);61int apei_exec_read_register(struct apei_exec_context *ctx,62struct acpi_whea_header *entry);63int apei_exec_read_register_value(struct apei_exec_context *ctx,64struct acpi_whea_header *entry);65int apei_exec_write_register(struct apei_exec_context *ctx,66struct acpi_whea_header *entry);67int apei_exec_write_register_value(struct apei_exec_context *ctx,68struct acpi_whea_header *entry);69int apei_exec_noop(struct apei_exec_context *ctx,70struct acpi_whea_header *entry);71int apei_exec_pre_map_gars(struct apei_exec_context *ctx);72int apei_exec_post_unmap_gars(struct apei_exec_context *ctx);7374struct apei_resources {75struct list_head iomem;76struct list_head ioport;77};7879static inline void apei_resources_init(struct apei_resources *resources)80{81INIT_LIST_HEAD(&resources->iomem);82INIT_LIST_HEAD(&resources->ioport);83}8485void apei_resources_fini(struct apei_resources *resources);86int apei_resources_sub(struct apei_resources *resources1,87struct apei_resources *resources2);88int apei_resources_request(struct apei_resources *resources,89const char *desc);90void apei_resources_release(struct apei_resources *resources);91int apei_exec_collect_resources(struct apei_exec_context *ctx,92struct apei_resources *resources);9394struct dentry;95struct dentry *apei_get_debugfs_dir(void);9697#define apei_estatus_for_each_section(estatus, section) \98for (section = (struct acpi_hest_generic_data *)(estatus + 1); \99(void *)section - (void *)estatus < estatus->data_length; \100section = (void *)(section+1) + section->error_data_length)101102static inline u32 apei_estatus_len(struct acpi_hest_generic_status *estatus)103{104if (estatus->raw_data_length)105return estatus->raw_data_offset + \106estatus->raw_data_length;107else108return sizeof(*estatus) + estatus->data_length;109}110111void apei_estatus_print(const char *pfx,112const struct acpi_hest_generic_status *estatus);113int apei_estatus_check_header(const struct acpi_hest_generic_status *estatus);114int apei_estatus_check(const struct acpi_hest_generic_status *estatus);115#endif116117118