blob: 3b970c9fa409d5dd4f18cd1e97e1c1d9ed845229 [file] [log] [blame]
/* SPDX-License-Identifier: GPL-2.0-only */
#include <device/device.h>
#ifndef _IPMI_CHIP_H_
#define _IPMI_CHIP_H_
#include <stdint.h>
struct drivers_ipmi_config {
#if CONFIG(IPMI_KCS)
u8 bmc_i2c_address;
u8 have_nv_storage;
u8 nv_storage_device_address;
u8 have_gpe;
u8 gpe_interrupt;
u8 have_apic;
u32 apic_interrupt;
/* Device to use for GPIO operations */
DEVTREE_CONST struct device *gpio_dev;
/*
* Jumper GPIO for enabling / disabling BMC/IPMI
* If present, the jumper overrides the devicetree.
*/
u32 bmc_jumper_gpio;
/* "POST complete" GPIO and polarity */
u32 post_complete_gpio;
bool post_complete_invert;
unsigned int uid; /* Auto-filled by ipmi_ssdt() */
#endif
/*
* Wait for BMC to boot.
* This can be used if the BMC takes a long time to boot after PoR:
* AST2400 on Supermicro X11SSH: 34 s
*/
bool wait_for_bmc;
/*
* The timeout in seconds to wait for the IPMI service to be loaded.
* Will be used if wait_for_bmc is true.
*/
u16 bmc_boot_timeout;
};
#endif /* _IMPI_CHIP_H_ */