Arthur Heymans has uploaded this change for review. ( https://review.coreboot.org/c/coreboot/+/37013 )
Change subject: soc/intel/baytrail: Use common SMM save state ops ......................................................................
soc/intel/baytrail: Use common SMM save state ops
Change-Id: Ia74a9956a22d550b5d864b38632add3d4d48b83d Signed-off-by: Arthur Heymans arthur@aheymans.xyz --- M src/soc/intel/baytrail/smihandler.c 1 file changed, 50 insertions(+), 38 deletions(-)
git pull ssh://review.coreboot.org:29418/coreboot refs/changes/13/37013/1
diff --git a/src/soc/intel/baytrail/smihandler.c b/src/soc/intel/baytrail/smihandler.c index 16e2d95..e19f9c6 100644 --- a/src/soc/intel/baytrail/smihandler.c +++ b/src/soc/intel/baytrail/smihandler.c @@ -20,7 +20,6 @@ #include <console/console.h> #include <cpu/x86/cache.h> #include <cpu/x86/smm.h> -#include <cpu/intel/em64t100_save_state.h> #include <device/pci_def.h> #include <elog.h> #include <halt.h> @@ -177,57 +176,65 @@ * core in case we are not running on the same core that * initiated the IO transaction. */ -static em64t100_smm_state_save_area_t *smi_apmc_find_state_save(uint8_t cmd) +static int smi_apmc_find_state_save_node(u8 cmd) { - em64t100_smm_state_save_area_t *state; + const struct smm_save_state_ops *ops = get_save_state_ops(); int node;
/* Check all nodes looking for the one that issued the IO */ for (node = 0; node < CONFIG_MAX_CPUS; node++) { - state = smm_get_save_state(node); - - /* Check for Synchronous IO (bit0==1) */ - if (!(state->io_misc_info & (1 << 0))) - continue; - - /* Make sure it was a write (bit4==0) */ - if (state->io_misc_info & (1 << 4)) - continue; - - /* Check for APMC IO port */ - if (((state->io_misc_info >> 16) & 0xff) != APM_CNT) - continue; - + uint32_t io_misc_info; + uint64_t rax; + if (ops->get_reg(node, RAX, &rax)) + continue; /* ??? */ /* Check AX against the requested command */ - if ((state->rax & 0xff) != cmd) + if ((rax & 0xff) != cmd) continue; + if (ops->get_io_misc_info(node, &io_misc_info)) {
- return state; + /* Check for Synchronous IO (bit0 == 1) */ + if (!(io_misc_info & (1 << 0))) + continue; + + /* Make sure it was a write (bit4 == 0) */ + if (io_misc_info & (1 << 4)) + continue; + + /* Check for APMC IO port */ + if (((io_misc_info >> 16) & 0xff) != APM_CNT) + continue; + } + + return node; }
- return NULL; + return -1; }
static void southbridge_smi_gsmi(void) { - u32 *ret, *param; - uint8_t sub_command; - em64t100_smm_state_save_area_t *io_smi = - smi_apmc_find_state_save(APM_CNT_ELOG_GSMI); + u32 ret, param; + u8 sub_command; + int node = smi_apmc_find_state_save_node(APM_CNT_ELOG_GSMI); + const struct smm_save_state_ops *ops = get_save_state_ops();
- if (!io_smi) + if (node < -1) return;
/* Command and return value in EAX */ - ret = (u32*)&io_smi->rax; - sub_command = (uint8_t)(*ret >> 8); + uint64_t reg; + if (ops->get_reg(node, RAX, ®)) + return; + sub_command = (u8)(reg >> 8);
/* Parameter buffer in EBX */ - param = (u32*)&io_smi->rbx; + if (ops->get_reg(node, RBX, ®)) + return; + param = reg & UINT32_MAX;
/* drivers/elog/gsmi.c */ - *ret = gsmi_exec(sub_command, param); -} + ret = gsmi_exec(sub_command, (u32 *)param); + ops->set_reg(node, RAX, reg);}
static void finalize(void) { @@ -301,8 +308,8 @@
static void southbridge_smi_apmc(void) { + const struct smm_save_state_ops *ops = get_save_state_ops(); uint8_t reg8; - em64t100_smm_state_save_area_t *state;
/* Emulate B2 register as the FADT / Linux expects it */
@@ -336,13 +343,18 @@ "SMI#: SMM structures already initialized!\n"); return; } - state = smi_apmc_find_state_save(reg8); - if (state) { - /* EBX in the state save contains the GNVS pointer */ - gnvs = (global_nvs_t *)((uint32_t)state->rbx); - smm_initialized = 1; - printk(BIOS_DEBUG, "SMI#: Setting GNVS to %p\n", gnvs); - } + int node = smi_apmc_find_state_save_node(APM_CNT_GNVS_UPDATE); + if (node < -1) + return; + + uint64_t rbx; + if (ops->get_reg(node, RBX, &rbx)) + return; + + /* EBX in the state save contains the GNVS pointer */ + gnvs = (global_nvs_t *)(u32)rbx; + smm_initialized = 1; + printk(BIOS_DEBUG, "SMI#: Setting GNVS to %p\n", gnvs); break; case APM_CNT_ELOG_GSMI: if (CONFIG(ELOG_GSMI))
build bot (Jenkins) has posted comments on this change. ( https://review.coreboot.org/c/coreboot/+/37013 )
Change subject: soc/intel/baytrail: Use common SMM save state ops ......................................................................
Patch Set 1:
(1 comment)
https://review.coreboot.org/c/coreboot/+/37013/1/src/soc/intel/baytrail/smih... File src/soc/intel/baytrail/smihandler.c:
https://review.coreboot.org/c/coreboot/+/37013/1/src/soc/intel/baytrail/smih... PS1, Line 237: ops->set_reg(node, RAX, reg);} space required after that ';' (ctx:VxV)
build bot (Jenkins) has posted comments on this change. ( https://review.coreboot.org/c/coreboot/+/37013 )
Change subject: soc/intel/baytrail: Use common SMM save state ops ......................................................................
Patch Set 2:
(1 comment)
https://review.coreboot.org/c/coreboot/+/37013/2/src/soc/intel/baytrail/smih... File src/soc/intel/baytrail/smihandler.c:
https://review.coreboot.org/c/coreboot/+/37013/2/src/soc/intel/baytrail/smih... PS2, Line 237: ops->set_reg(node, RAX, reg);} space required after that ';' (ctx:VxV)
build bot (Jenkins) has posted comments on this change. ( https://review.coreboot.org/c/coreboot/+/37013 )
Change subject: soc/intel/baytrail: Use common SMM save state ops ......................................................................
Patch Set 3:
(1 comment)
https://review.coreboot.org/c/coreboot/+/37013/3/src/soc/intel/baytrail/smih... File src/soc/intel/baytrail/smihandler.c:
https://review.coreboot.org/c/coreboot/+/37013/3/src/soc/intel/baytrail/smih... PS3, Line 237: ops->set_reg(node, RAX, reg);} space required after that ';' (ctx:VxV)
build bot (Jenkins) has posted comments on this change. ( https://review.coreboot.org/c/coreboot/+/37013 )
Change subject: soc/intel/baytrail: Use common SMM save state ops ......................................................................
Patch Set 4:
(1 comment)
https://review.coreboot.org/c/coreboot/+/37013/4/src/soc/intel/baytrail/smih... File src/soc/intel/baytrail/smihandler.c:
https://review.coreboot.org/c/coreboot/+/37013/4/src/soc/intel/baytrail/smih... PS4, Line 237: ops->set_reg(node, RAX, reg);} space required after that ';' (ctx:VxV)
Hello Patrick Rudolph, build bot (Jenkins),
I'd like you to reexamine a change. Please visit
https://review.coreboot.org/c/coreboot/+/37013
to look at the new patch set (#5).
Change subject: soc/intel/baytrail: Use common SMM save state ops ......................................................................
soc/intel/baytrail: Use common SMM save state ops
Change-Id: Ia74a9956a22d550b5d864b38632add3d4d48b83d Signed-off-by: Arthur Heymans arthur@aheymans.xyz --- M src/soc/intel/baytrail/smihandler.c 1 file changed, 50 insertions(+), 37 deletions(-)
git pull ssh://review.coreboot.org:29418/coreboot refs/changes/13/37013/5
Arthur Heymans has abandoned this change. ( https://review.coreboot.org/c/coreboot/+/37013 )
Change subject: soc/intel/baytrail: Use common SMM save state ops ......................................................................
Abandoned
superseded in common_smm_save_state