soc/amd: factor out acpigen_write_alib_dptc to common code

Also drop unneeded intermediate cast to void * before casting the
address of the struct dptc_input type variables to uint8_t *.

Signed-off-by: Felix Held <felix-coreboot@felixheld.de>
Change-Id: Ie1e2aa1ec728a4e16d3a587d7400cdfc8962f443
Reviewed-on: https://review.coreboot.org/c/coreboot/+/54077
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Raul Rangel <rrangel@chromium.org>
This commit is contained in:
Felix Held
2021-05-12 01:42:37 +02:00
parent dd882f3812
commit 2d0bf34201
4 changed files with 33 additions and 45 deletions

View File

@ -195,29 +195,9 @@ static void acipgen_dptci(void)
config->sustained_power_limit_tablet_mode_mW, config->sustained_power_limit_tablet_mode_mW,
config->fast_ppt_limit_tablet_mode_mW, config->fast_ppt_limit_tablet_mode_mW,
config->slow_ppt_limit_tablet_mode_mW); config->slow_ppt_limit_tablet_mode_mW);
/* Scope (\_SB) */
acpigen_write_scope("\\_SB");
/* Method(DPTC, 0, Serialized) */ acpigen_write_alib_dptc((uint8_t *)&default_input, sizeof(default_input),
acpigen_write_method_serialized("DPTC", 0); (uint8_t *)&tablet_mode_input, sizeof(tablet_mode_input));
/* TODO: The code assumes that if DPTC gets called the following object exists */
/* If (LEqual ("\_SB.PCI0.LPCB.EC0.TBMD", 1)) */
acpigen_write_if_lequal_namestr_int("\\_SB.PCI0.LPCB.EC0.TBMD", 1);
acpigen_dptc_call_alib("TABB", (uint8_t *)(void *)&tablet_mode_input,
sizeof(tablet_mode_input));
/* Else */
acpigen_write_else();
acpigen_dptc_call_alib("DEFB", (uint8_t *)(void *)&default_input,
sizeof(default_input));
acpigen_pop_len(); /* Else */
acpigen_pop_len(); /* Method DPTC */
acpigen_pop_len(); /* Scope \_SB */
} }
static void root_complex_fill_ssdt(const struct device *device) static void root_complex_fill_ssdt(const struct device *device)

View File

@ -4,7 +4,7 @@
#include <amdblocks/alib.h> #include <amdblocks/alib.h>
#include <types.h> #include <types.h>
void acpigen_dptc_call_alib(const char *buf_name, uint8_t *buffer, size_t size) static void acpigen_dptc_call_alib(const char *buf_name, uint8_t *buffer, size_t size)
{ {
/* Name (buf_name, Buffer(size) {...} */ /* Name (buf_name, Buffer(size) {...} */
acpigen_write_name(buf_name); acpigen_write_name(buf_name);
@ -15,3 +15,29 @@ void acpigen_dptc_call_alib(const char *buf_name, uint8_t *buffer, size_t size)
acpigen_write_integer(ALIB_FUNCTION_DYNAMIC_POWER_THERMAL_CONFIG); acpigen_write_integer(ALIB_FUNCTION_DYNAMIC_POWER_THERMAL_CONFIG);
acpigen_emit_namestring(buf_name); acpigen_emit_namestring(buf_name);
} }
void acpigen_write_alib_dptc(uint8_t *default_param, size_t default_param_len,
uint8_t *tablet_param, size_t tablet_param_len)
{
/* Scope (\_SB) */
acpigen_write_scope("\\_SB");
/* Method(DPTC, 0, Serialized) */
acpigen_write_method_serialized("DPTC", 0);
/* TODO: The code assumes that if DPTC gets called the following object exists */
/* If (LEqual ("\_SB.PCI0.LPCB.EC0.TBMD", 1)) */
acpigen_write_if_lequal_namestr_int("\\_SB.PCI0.LPCB.EC0.TBMD", 1);
acpigen_dptc_call_alib("TABB", tablet_param, tablet_param_len);
/* Else */
acpigen_write_else();
acpigen_dptc_call_alib("DEFB", default_param, default_param_len);
acpigen_pop_len(); /* Else */
acpigen_pop_len(); /* Method DPTC */
acpigen_pop_len(); /* Scope \_SB */
}

View File

@ -21,7 +21,8 @@ struct alib_dptc_param {
uint32_t value; uint32_t value;
} __packed; } __packed;
void acpigen_dptc_call_alib(const char *buf_name, uint8_t *buffer, size_t size); void acpigen_write_alib_dptc(uint8_t *default_param, size_t default_param_len,
uint8_t *tablet_param, size_t tablet_param_len);
#endif /* !__ACPI__ */ #endif /* !__ACPI__ */

View File

@ -193,28 +193,9 @@ static void acipgen_dptci(void)
config->sustained_power_limit_tablet_mode_mW, config->sustained_power_limit_tablet_mode_mW,
config->fast_ppt_limit_tablet_mode_mW, config->fast_ppt_limit_tablet_mode_mW,
config->slow_ppt_limit_tablet_mode_mW); config->slow_ppt_limit_tablet_mode_mW);
/* Scope (\_SB) */
acpigen_write_scope("\\_SB");
/* Method(DPTC, 0, Serialized) */ acpigen_write_alib_dptc((uint8_t *)&default_input, sizeof(default_input),
acpigen_write_method_serialized("DPTC", 0); (uint8_t *)&tablet_mode_input, sizeof(tablet_mode_input));
/* If (LEqual ("\_SB.PCI0.LPCB.EC0.TBMD", 1)) */
acpigen_write_if_lequal_namestr_int("\\_SB.PCI0.LPCB.EC0.TBMD", 1);
acpigen_dptc_call_alib("TABB", (uint8_t *)(void *)&tablet_mode_input,
sizeof(tablet_mode_input));
/* Else */
acpigen_write_else();
acpigen_dptc_call_alib("DEFB", (uint8_t *)(void *)&default_input,
sizeof(default_input));
acpigen_pop_len(); /* Else */
acpigen_pop_len(); /* Method DPTC */
acpigen_pop_len(); /* Scope \_SB */
} }
static void root_complex_fill_ssdt(const struct device *device) static void root_complex_fill_ssdt(const struct device *device)