14 #include <soc/pci_devs.h>
50 for (slot = 0; slot < 0x20; slot++) {
51 for (func = 0; func < 8; func++) {
57 if (
val == 0xffffffff ||
val == 0x00000000 ||
58 val == 0x0000ffff ||
val == 0xffff0000)
113 slp_typ = acpi_sleep_from_pm1(reg32);
157 write32((
void *)(0xfed88000 + 0x0200),
read32((
void *)(0xfed88000 + 0x0200)));
191 em64t100_smm_state_save_area_t *
state;
195 for (node = 0; node < CONFIG_MAX_CPUS; node++) {
199 if (!(
state->io_misc_info & (1 << 0)))
203 if (
state->io_misc_info & (1 << 4))
211 if ((
state->rax & 0xff) != cmd)
230 ret = (
u32 *)&io_smi->rax;
231 sub_command = (
uint8_t)(*ret >> 8);
234 param = (
u32 *)&io_smi->rbx;
249 sub_command = (io_smi->rax >> 8) & 0xff;
252 reg_ebx = io_smi->rbx;
379 if (!(smi_sts & (1 << i)))
386 "SMI_STS[%d] occurred, but no handler available.\n", i);
static void write32(void *addr, uint32_t val)
static uint32_t read32(const void *addr)
static __always_inline void hlt(void)
uint16_t clear_pm1_status(void)
void enable_pm1_control(uint32_t mask)
uint32_t clear_alt_status(void)
void disable_smi(uint32_t mask)
void enable_smi(uint32_t mask)
uint32_t clear_gpe_status(void)
void disable_pm1_control(uint32_t mask)
void disable_all_gpe(void)
uint32_t clear_tco_status(void)
uint32_t clear_smi_status(void)
#define ELOG_TYPE_ACPI_ENTER
#define ELOG_TYPE_POWER_BUTTON
#define printk(level,...)
void __weak southbridge_smi_handler(void)
void __weak mainboard_smi_sleep(u8 slp_typ)
int __weak mainboard_smi_apmc(u8 data)
void __weak mainboard_smi_gpi(u32 gpi_sts)
void * smm_get_save_state(int cpu)
uint32_t smmstore_exec(uint8_t command, void *param)
u32 gsmi_exec(u8 command, u32 *param)
#define APM_CNT_ELOG_GSMI
#define APM_CNT_ACPI_DISABLE
#define APM_CNT_ACPI_ENABLE
static __always_inline u16 pci_read_config16(const struct device *dev, u16 reg)
static __always_inline u32 pci_read_config32(const struct device *dev, u16 reg)
static __always_inline u8 pci_read_config8(const struct device *dev, u16 reg)
static __always_inline void pci_write_config16(const struct device *dev, u16 reg, u16 val)
static int elog_gsmi_add_event(u8 event_type)
static int elog_gsmi_add_event_byte(u8 event_type, u8 data)
#define BIOS_DEBUG
BIOS_DEBUG - Verbose output.
#define BIOS_SPEW
BIOS_SPEW - Excessively verbose output.
#define PCI_HEADER_TYPE_CARDBUS
#define PCI_COMMAND_MASTER
#define PCI_HEADER_TYPE_BRIDGE
#define PCI_DEV(SEGBUS, DEV, FN)
int southbridge_io_trap_handler(int smif)
const smi_handler_t southbridge_smi[SMI_STS_BITS]
void southbridge_smi_set_eos(void)
void(* smi_handler_t)(void)
#define MMC1_D7_MMIO_OFFSET
#define MMC1_D5_MMIO_OFFSET
#define COMMUNITY_GPSOUTHEAST_BASE
#define MMC1_D6_MMIO_OFFSET
#define COMMUNITY_GPNORTH_BASE
#define HV_DDI2_DDC_SCL_MMIO_OFFSET
#define SDMMC1_D3_MMIO_OFFSET
#define CFIO_139_MMIO_OFFSET
#define SDMMC1_CMD_MMIO_OFFSET
#define SDMMC1_D0_MMIO_OFFSET
#define MMC1_D4_SD_WE_MMIO_OFFSET
#define SDMMC1_D2_MMIO_OFFSET
#define SDMMC1_D1_MMIO_OFFSET
#define PAD_CONTROL_REG0_TRISTATE
#define CFIO_140_MMIO_OFFSET
#define COMMUNITY_GPSOUTHWEST_BASE
#define HV_DDI2_DDC_SDA_MMIO_OFFSET
static void southbridge_smi_pm1(void)
static void southbridge_smi_store(void)
static em64t100_smm_state_save_area_t * smi_apmc_find_state_save(uint8_t cmd)
static void busmaster_disable_on_bus(int bus)
static void southbridge_smi_apmc(void)
static void southbridge_smi_periodic(void)
static void southbridge_smi_gpe0(void)
static void tristate_gpios(uint32_t val)
static void southbridge_smi_gsmi(void)
static void southbridge_smi_tco(void)
static void southbridge_smi_sleep(void)
typedef void(X86APIP X86EMU_intrFuncs)(int num)