/* SPDX-License-Identifier: GPL-2.0+ */ /* * Copyright (C) 2018, Bin Meng <bmeng.cn@gmail.com> */ #ifndef __ASM_INTEL_ACPI_H__ #define __ASM_INTEL_ACPI_H__ struct acpi_cstate; struct acpi_ctx; struct acpi_tstate; struct udevice; /** * acpi_generate_cpu_header() - Start generating an ACPI CPU entry * * Generates the ACPI information for a CPU. After this, the caller should * generate_p_state_entries(), generate_t_state_entries and then * acpigen_pop_len() to close off this package. * * @ctx: ACPI context pointer * @core_id: CPU core number, as numbered by the SoC * @c_state_map: Information about each C state * @num_cstates: Number of entries in @c_state_map * Return: 0 if OK, -ve on error */ int acpi_generate_cpu_header(struct acpi_ctx *ctx, int core_id, const struct acpi_cstate *c_state_map, int num_cstates); /** * acpi_generate_cpu_package_final() - Write out the CPU PPKG entry * * This writes information about the CPUs in the package * * @ctx: ACPI context pointer * @cores_per_package: Number of CPU cores in each package in the SoC */ int acpi_generate_cpu_package_final(struct acpi_ctx *ctx, int cores_per_package); void generate_p_state_entries(struct acpi_ctx *ctx, int core, int cores_per_package); void generate_t_state_entries(struct acpi_ctx *ctx, int core, int cores_per_package, struct acpi_tstate *entry, int nentries); int southbridge_inject_dsdt(const struct udevice *dev, struct acpi_ctx *ctx); int intel_southbridge_write_acpi_tables(const struct udevice *dev, struct acpi_ctx *ctx); #endif /* __ASM_INTEL_ACPI_H__ */