| /* |
| * ASPEED SoC family |
| * |
| * Andrew Jeffery <andrew@aj.id.au> |
| * |
| * Copyright 2016 IBM Corp. |
| * |
| * This code is licensed under the GPL version 2 or later. See |
| * the COPYING file in the top-level directory. |
| */ |
| |
| #ifndef ASPEED_SOC_H |
| #define ASPEED_SOC_H |
| |
| #include "hw/cpu/a15mpcore.h" |
| #include "hw/intc/aspeed_vic.h" |
| #include "hw/misc/aspeed_scu.h" |
| #include "hw/misc/aspeed_sdmc.h" |
| #include "hw/misc/aspeed_xdma.h" |
| #include "hw/timer/aspeed_timer.h" |
| #include "hw/timer/aspeed_rtc.h" |
| #include "hw/i2c/aspeed_i2c.h" |
| #include "hw/ssi/aspeed_smc.h" |
| #include "hw/watchdog/wdt_aspeed.h" |
| #include "hw/net/ftgmac100.h" |
| #include "target/arm/cpu.h" |
| #include "hw/gpio/aspeed_gpio.h" |
| #include "hw/sd/aspeed_sdhci.h" |
| |
| #define ASPEED_SPIS_NUM 2 |
| #define ASPEED_WDTS_NUM 4 |
| #define ASPEED_CPUS_NUM 2 |
| #define ASPEED_MACS_NUM 4 |
| |
| typedef struct AspeedSoCState { |
| /*< private >*/ |
| DeviceState parent; |
| |
| /*< public >*/ |
| ARMCPU cpu[ASPEED_CPUS_NUM]; |
| uint32_t num_cpus; |
| A15MPPrivState a7mpcore; |
| MemoryRegion sram; |
| AspeedVICState vic; |
| AspeedRtcState rtc; |
| AspeedTimerCtrlState timerctrl; |
| AspeedI2CState i2c; |
| AspeedSCUState scu; |
| AspeedXDMAState xdma; |
| AspeedSMCState fmc; |
| AspeedSMCState spi[ASPEED_SPIS_NUM]; |
| AspeedSDMCState sdmc; |
| AspeedWDTState wdt[ASPEED_WDTS_NUM]; |
| FTGMAC100State ftgmac100[ASPEED_MACS_NUM]; |
| AspeedMiiState mii[ASPEED_MACS_NUM]; |
| AspeedGPIOState gpio; |
| AspeedGPIOState gpio_1_8v; |
| AspeedSDHCIState sdhci; |
| } AspeedSoCState; |
| |
| #define TYPE_ASPEED_SOC "aspeed-soc" |
| #define ASPEED_SOC(obj) OBJECT_CHECK(AspeedSoCState, (obj), TYPE_ASPEED_SOC) |
| |
| typedef struct AspeedSoCClass { |
| DeviceClass parent_class; |
| |
| const char *name; |
| const char *cpu_type; |
| uint32_t silicon_rev; |
| uint64_t sram_size; |
| int spis_num; |
| int wdts_num; |
| int macs_num; |
| const int *irqmap; |
| const hwaddr *memmap; |
| uint32_t num_cpus; |
| } AspeedSoCClass; |
| |
| #define ASPEED_SOC_CLASS(klass) \ |
| OBJECT_CLASS_CHECK(AspeedSoCClass, (klass), TYPE_ASPEED_SOC) |
| #define ASPEED_SOC_GET_CLASS(obj) \ |
| OBJECT_GET_CLASS(AspeedSoCClass, (obj), TYPE_ASPEED_SOC) |
| |
| enum { |
| ASPEED_IOMEM, |
| ASPEED_UART1, |
| ASPEED_UART2, |
| ASPEED_UART3, |
| ASPEED_UART4, |
| ASPEED_UART5, |
| ASPEED_VUART, |
| ASPEED_FMC, |
| ASPEED_SPI1, |
| ASPEED_SPI2, |
| ASPEED_VIC, |
| ASPEED_SDMC, |
| ASPEED_SCU, |
| ASPEED_ADC, |
| ASPEED_VIDEO, |
| ASPEED_SRAM, |
| ASPEED_SDHCI, |
| ASPEED_GPIO, |
| ASPEED_GPIO_1_8V, |
| ASPEED_RTC, |
| ASPEED_TIMER1, |
| ASPEED_TIMER2, |
| ASPEED_TIMER3, |
| ASPEED_TIMER4, |
| ASPEED_TIMER5, |
| ASPEED_TIMER6, |
| ASPEED_TIMER7, |
| ASPEED_TIMER8, |
| ASPEED_WDT, |
| ASPEED_PWM, |
| ASPEED_LPC, |
| ASPEED_IBT, |
| ASPEED_I2C, |
| ASPEED_ETH1, |
| ASPEED_ETH2, |
| ASPEED_ETH3, |
| ASPEED_ETH4, |
| ASPEED_MII1, |
| ASPEED_MII2, |
| ASPEED_MII3, |
| ASPEED_MII4, |
| ASPEED_SDRAM, |
| ASPEED_XDMA, |
| }; |
| |
| #endif /* ASPEED_SOC_H */ |