> On May 4, 2022, at 12:39 AM, Cédric Le Goater <c...@kaod.org> wrote: > > On 5/4/22 00:59, Peter Delevoryas wrote: >> Add the 'fby35-bmc' machine type based on the kernel DTS[1] and userspace >> i2c setup scripts[2]. Undefined values are inherited from the AST2600-EVB. >> Reference images can be found in Facebook OpenBMC Github Release assets >> as "fby35.mtd". [3] >> You can boot the reference images as follows (fby35 uses dual-flash): >> qemu-system-arm -machine fby35-bmc \ >> -drive file=fby35.mtd,format=raw,if=mtd \ >> -drive file=fby35.mtd,format=raw,if=mtd \ >> -nographic >> [1] >> https://github.com/facebook/openbmc-linux/blob/412d5053258007117e94b1e36015aefc1301474b/arch/arm/boot/dts/aspeed-bmc-facebook-fby35.dts >> [2] >> https://github.com/facebook/openbmc/blob/e2294ff5d31dd65c248fe396a385286d6d5c463d/meta-facebook/meta-fby35/recipes-fby35/plat-utils/files/setup-dev.sh >> [3] https://github.com/facebook/openbmc/releases >> Signed-off-by: Peter Delevoryas <p...@fb.com> > > Reviewed-by: Cédric Le Goater <c...@kaod.org>
Thanks! > > a question below, > >> --- >> v2: Removed avocado test, updated commit message. >> hw/arm/aspeed.c | 63 +++++++++++++++++++++++++++++++++++++++++++++++++ >> 1 file changed, 63 insertions(+) >> diff --git a/hw/arm/aspeed.c b/hw/arm/aspeed.c >> index a74c13ab0f..725c169488 100644 >> --- a/hw/arm/aspeed.c >> +++ b/hw/arm/aspeed.c >> @@ -21,6 +21,7 @@ >> #include "hw/misc/led.h" >> #include "hw/qdev-properties.h" >> #include "sysemu/block-backend.h" >> +#include "sysemu/reset.h" >> #include "hw/loader.h" >> #include "qemu/error-report.h" >> #include "qemu/units.h" >> @@ -951,6 +952,35 @@ static void bletchley_bmc_i2c_init(AspeedMachineState >> *bmc) >> i2c_slave_create_simple(i2c[12], TYPE_PCA9552, 0x67); >> } >> +static void fby35_i2c_init(AspeedMachineState *bmc) >> +{ >> + AspeedSoCState *soc = &bmc->soc; >> + I2CBus *i2c[16]; >> + >> + for (int i = 0; i < 16; i++) { >> + i2c[i] = aspeed_i2c_get_bus(&soc->i2c, i); >> + } >> + >> + i2c_slave_create_simple(i2c[2], TYPE_LM75, 0x4f); >> + i2c_slave_create_simple(i2c[8], TYPE_TMP421, 0x1f); >> + /* Hotswap controller is actually supposed to be mp5920 or ltc4282. */ >> + i2c_slave_create_simple(i2c[11], "adm1272", 0x44); >> + i2c_slave_create_simple(i2c[12], TYPE_LM75, 0x4e); >> + i2c_slave_create_simple(i2c[12], TYPE_LM75, 0x4f); >> + >> + aspeed_eeprom_init(i2c[4], 0x51, 128 * KiB); >> + aspeed_eeprom_init(i2c[6], 0x51, 128 * KiB); >> + aspeed_eeprom_init(i2c[8], 0x50, 32 * KiB); >> + aspeed_eeprom_init(i2c[11], 0x51, 128 * KiB); >> + aspeed_eeprom_init(i2c[11], 0x54, 128 * KiB); >> + >> + /* >> + * TODO: There is a multi-master i2c connection to an AST1030 MiniBMC on >> + * buses 0, 1, 2, 3, and 9. Source address 0x10, target address 0x20 on >> + * each. >> + */ > > > Have you considered extending the emulation to include a AST1030 SoC > in a larger machine ? > > The AST1030 SoC is merged and I think that QEMU could run a cortex-m4 > CPU and a A7 CPU. A + R CPUs is supported (Xilinx boards). > As a matter of fact yes! I tested booting our OpenBIC Zephyr kernel last week with the 1030, that worked. I also used the experimental i2c multi-master patches from Klaus to make a i2c-netdev device that connects two separate QEMU instances through a socket and sends their i2c messages back and forth. I was able to test a basic MCTP transaction. I’m hoping to help however possible with merging Klaus’s changes, and then propose the i2c-netdev thing too. > Thanks, > > C. > > >> +} >> + >> static bool aspeed_get_mmio_exec(Object *obj, Error **errp) >> { >> return ASPEED_MACHINE(obj)->mmio_exec; >> @@ -1293,6 +1323,35 @@ static void >> aspeed_machine_bletchley_class_init(ObjectClass *oc, void *data) >> aspeed_soc_num_cpus(amc->soc_name); >> } >> +static void fby35_reset(MachineState *state) >> +{ >> + AspeedMachineState *bmc = ASPEED_MACHINE(state); >> + AspeedGPIOState *gpio = &bmc->soc.gpio; >> + >> + qemu_devices_reset(); >> + >> + /* Board ID */ >> + object_property_set_bool(OBJECT(gpio), "gpioV4", true, &error_fatal); >> + object_property_set_bool(OBJECT(gpio), "gpioV5", true, &error_fatal); >> + object_property_set_bool(OBJECT(gpio), "gpioV6", true, &error_fatal); >> + object_property_set_bool(OBJECT(gpio), "gpioV7", false, &error_fatal); >> +} >> + >> +static void aspeed_machine_fby35_class_init(ObjectClass *oc, void *data) >> +{ >> + MachineClass *mc = MACHINE_CLASS(oc); >> + AspeedMachineClass *amc = ASPEED_MACHINE_CLASS(oc); >> + >> + mc->desc = "Facebook fby35 BMC (Cortex-A7)"; >> + mc->reset = fby35_reset; >> + amc->fmc_model = "mx66l1g45g"; >> + amc->num_cs = 2; >> + amc->macs_mask = ASPEED_MAC3_ON; >> + amc->i2c_init = fby35_i2c_init; >> + /* FIXME: Replace this macro with something more general */ >> + mc->default_ram_size = FUJI_BMC_RAM_SIZE; >> +} >> + >> #define AST1030_INTERNAL_FLASH_SIZE (1024 * 1024) >> /* Main SYSCLK frequency in Hz (200MHz) */ >> #define SYSCLK_FRQ 200000000ULL >> @@ -1411,6 +1470,10 @@ static const TypeInfo aspeed_machine_types[] = { >> .name = MACHINE_TYPE_NAME("bletchley-bmc"), >> .parent = TYPE_ASPEED_MACHINE, >> .class_init = aspeed_machine_bletchley_class_init, >> + }, { >> + .name = MACHINE_TYPE_NAME("fby35-bmc"), >> + .parent = MACHINE_TYPE_NAME("ast2600-evb"), >> + .class_init = aspeed_machine_fby35_class_init, >> }, { >> .name = MACHINE_TYPE_NAME("ast1030-evb"), >> .parent = TYPE_ASPEED_MACHINE, >