| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |  * ASPEED SoC family | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Andrew Jeffery <andrew@aj.id.au> | 
					
						
							|  |  |  |  * Jeremy Kerr <jk@ozlabs.org> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright 2016 IBM Corp. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This code is licensed under the GPL version 2 or later.  See | 
					
						
							|  |  |  |  * the COPYING file in the top-level directory. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "qemu/osdep.h"
 | 
					
						
							| 
									
										
											  
											
												include/qemu/osdep.h: Don't include qapi/error.h
Commit 57cb38b included qapi/error.h into qemu/osdep.h to get the
Error typedef.  Since then, we've moved to include qemu/osdep.h
everywhere.  Its file comment explains: "To avoid getting into
possible circular include dependencies, this file should not include
any other QEMU headers, with the exceptions of config-host.h,
compiler.h, os-posix.h and os-win32.h, all of which are doing a
similar job to this file and are under similar constraints."
qapi/error.h doesn't do a similar job, and it doesn't adhere to
similar constraints: it includes qapi-types.h.  That's in excess of
100KiB of crap most .c files don't actually need.
Add the typedef to qemu/typedefs.h, and include that instead of
qapi/error.h.  Include qapi/error.h in .c files that need it and don't
get it now.  Include qapi-types.h in qom/object.h for uint16List.
Update scripts/clean-includes accordingly.  Update it further to match
reality: replace config.h by config-target.h, add sysemu/os-posix.h,
sysemu/os-win32.h.  Update the list of includes in the qemu/osdep.h
comment quoted above similarly.
This reduces the number of objects depending on qapi/error.h from "all
of them" to less than a third.  Unfortunately, the number depending on
qapi-types.h shrinks only a little.  More work is needed for that one.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
[Fix compilation without the spice devel packages. - Paolo]
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
											
										 
											2016-03-14 09:01:28 +01:00
										 |  |  | #include "qapi/error.h"
 | 
					
						
							| 
									
										
										
										
											2016-01-19 21:51:44 +01:00
										 |  |  | #include "qemu-common.h"
 | 
					
						
							|  |  |  | #include "cpu.h"
 | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | #include "exec/address-spaces.h"
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | #include "hw/arm/aspeed_soc.h"
 | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | #include "hw/char/serial.h"
 | 
					
						
							| 
									
										
										
										
											2015-12-15 13:16:16 +01:00
										 |  |  | #include "qemu/log.h"
 | 
					
						
							| 
									
										
										
										
											2016-06-06 16:59:29 +01:00
										 |  |  | #include "hw/i2c/aspeed_i2c.h"
 | 
					
						
							| 
									
										
										
										
											2017-04-14 10:35:02 +02:00
										 |  |  | #include "net/net.h"
 | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | #define ASPEED_SOC_UART_5_BASE      0x00184000
 | 
					
						
							|  |  |  | #define ASPEED_SOC_IOMEM_SIZE       0x00200000
 | 
					
						
							|  |  |  | #define ASPEED_SOC_IOMEM_BASE       0x1E600000
 | 
					
						
							|  |  |  | #define ASPEED_SOC_FMC_BASE         0x1E620000
 | 
					
						
							|  |  |  | #define ASPEED_SOC_SPI_BASE         0x1E630000
 | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  | #define ASPEED_SOC_SPI2_BASE        0x1E631000
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | #define ASPEED_SOC_VIC_BASE         0x1E6C0000
 | 
					
						
							|  |  |  | #define ASPEED_SOC_SDMC_BASE        0x1E6E0000
 | 
					
						
							|  |  |  | #define ASPEED_SOC_SCU_BASE         0x1E6E2000
 | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:27 +00:00
										 |  |  | #define ASPEED_SOC_SRAM_BASE        0x1E720000
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | #define ASPEED_SOC_TIMER_BASE       0x1E782000
 | 
					
						
							| 
									
										
										
										
											2017-02-07 18:29:59 +00:00
										 |  |  | #define ASPEED_SOC_WDT_BASE         0x1E785000
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | #define ASPEED_SOC_I2C_BASE         0x1E78A000
 | 
					
						
							| 
									
										
										
										
											2017-04-14 10:35:02 +02:00
										 |  |  | #define ASPEED_SOC_ETH1_BASE        0x1E660000
 | 
					
						
							|  |  |  | #define ASPEED_SOC_ETH2_BASE        0x1E680000
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | static const int uart_irqs[] = { 9, 32, 33, 34, 10 }; | 
					
						
							|  |  |  | static const int timer_irqs[] = { 16, 17, 18, 35, 36, 37, 38, 39, }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | #define AST2400_SDRAM_BASE       0x40000000
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | #define AST2500_SDRAM_BASE       0x80000000
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  | static const hwaddr aspeed_soc_ast2400_spi_bases[] = { ASPEED_SOC_SPI_BASE }; | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  | static const char *aspeed_soc_ast2400_typenames[] = { "aspeed.smc.spi" }; | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  | static const hwaddr aspeed_soc_ast2500_spi_bases[] = { ASPEED_SOC_SPI_BASE, | 
					
						
							|  |  |  |                                                        ASPEED_SOC_SPI2_BASE}; | 
					
						
							|  |  |  | static const char *aspeed_soc_ast2500_typenames[] = { | 
					
						
							|  |  |  |     "aspeed.smc.ast2500-spi1", "aspeed.smc.ast2500-spi2" }; | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | static const AspeedSoCInfo aspeed_socs[] = { | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:27 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |         .name         = "ast2400-a0", | 
					
						
							| 
									
										
										
										
											2017-09-13 18:04:57 +02:00
										 |  |  |         .cpu_type     = ARM_CPU_TYPE_NAME("arm926"), | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:27 +00:00
										 |  |  |         .silicon_rev  = AST2400_A0_SILICON_REV, | 
					
						
							|  |  |  |         .sdram_base   = AST2400_SDRAM_BASE, | 
					
						
							|  |  |  |         .sram_size    = 0x8000, | 
					
						
							|  |  |  |         .spis_num     = 1, | 
					
						
							|  |  |  |         .spi_bases    = aspeed_soc_ast2400_spi_bases, | 
					
						
							|  |  |  |         .fmc_typename = "aspeed.smc.fmc", | 
					
						
							|  |  |  |         .spi_typename = aspeed_soc_ast2400_typenames, | 
					
						
							| 
									
										
										
										
											2017-07-11 11:21:26 +01:00
										 |  |  |         .wdts_num     = 2, | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:28 +00:00
										 |  |  |     }, { | 
					
						
							|  |  |  |         .name         = "ast2400-a1", | 
					
						
							| 
									
										
										
										
											2017-09-13 18:04:57 +02:00
										 |  |  |         .cpu_type     = ARM_CPU_TYPE_NAME("arm926"), | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:28 +00:00
										 |  |  |         .silicon_rev  = AST2400_A1_SILICON_REV, | 
					
						
							|  |  |  |         .sdram_base   = AST2400_SDRAM_BASE, | 
					
						
							|  |  |  |         .sram_size    = 0x8000, | 
					
						
							|  |  |  |         .spis_num     = 1, | 
					
						
							|  |  |  |         .spi_bases    = aspeed_soc_ast2400_spi_bases, | 
					
						
							|  |  |  |         .fmc_typename = "aspeed.smc.fmc", | 
					
						
							|  |  |  |         .spi_typename = aspeed_soc_ast2400_typenames, | 
					
						
							| 
									
										
										
										
											2017-07-11 11:21:26 +01:00
										 |  |  |         .wdts_num     = 2, | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:27 +00:00
										 |  |  |     }, { | 
					
						
							|  |  |  |         .name         = "ast2400", | 
					
						
							| 
									
										
										
										
											2017-09-13 18:04:57 +02:00
										 |  |  |         .cpu_type     = ARM_CPU_TYPE_NAME("arm926"), | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:27 +00:00
										 |  |  |         .silicon_rev  = AST2400_A0_SILICON_REV, | 
					
						
							|  |  |  |         .sdram_base   = AST2400_SDRAM_BASE, | 
					
						
							|  |  |  |         .sram_size    = 0x8000, | 
					
						
							|  |  |  |         .spis_num     = 1, | 
					
						
							|  |  |  |         .spi_bases    = aspeed_soc_ast2400_spi_bases, | 
					
						
							|  |  |  |         .fmc_typename = "aspeed.smc.fmc", | 
					
						
							|  |  |  |         .spi_typename = aspeed_soc_ast2400_typenames, | 
					
						
							| 
									
										
										
										
											2017-07-11 11:21:26 +01:00
										 |  |  |         .wdts_num     = 2, | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:27 +00:00
										 |  |  |     }, { | 
					
						
							|  |  |  |         .name         = "ast2500-a1", | 
					
						
							| 
									
										
										
										
											2017-09-13 18:04:57 +02:00
										 |  |  |         .cpu_type     = ARM_CPU_TYPE_NAME("arm1176"), | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:27 +00:00
										 |  |  |         .silicon_rev  = AST2500_A1_SILICON_REV, | 
					
						
							|  |  |  |         .sdram_base   = AST2500_SDRAM_BASE, | 
					
						
							|  |  |  |         .sram_size    = 0x9000, | 
					
						
							|  |  |  |         .spis_num     = 2, | 
					
						
							|  |  |  |         .spi_bases    = aspeed_soc_ast2500_spi_bases, | 
					
						
							|  |  |  |         .fmc_typename = "aspeed.smc.ast2500-fmc", | 
					
						
							|  |  |  |         .spi_typename = aspeed_soc_ast2500_typenames, | 
					
						
							| 
									
										
										
										
											2017-07-11 11:21:26 +01:00
										 |  |  |         .wdts_num     = 3, | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:27 +00:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * IO handlers: simply catch any reads/writes to IO addresses that aren't | 
					
						
							|  |  |  |  * handled by a device mapping. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | static uint64_t aspeed_soc_io_read(void *p, hwaddr offset, unsigned size) | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     qemu_log_mask(LOG_UNIMP, "%s: 0x%" HWADDR_PRIx " [%u]\n", | 
					
						
							|  |  |  |                   __func__, offset, size); | 
					
						
							|  |  |  |     return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | static void aspeed_soc_io_write(void *opaque, hwaddr offset, uint64_t value, | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  |                 unsigned size) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     qemu_log_mask(LOG_UNIMP, "%s: 0x%" HWADDR_PRIx " <- 0x%" PRIx64 " [%u]\n", | 
					
						
							|  |  |  |                   __func__, offset, value, size); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | static const MemoryRegionOps aspeed_soc_io_ops = { | 
					
						
							|  |  |  |     .read = aspeed_soc_io_read, | 
					
						
							|  |  |  |     .write = aspeed_soc_io_write, | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  |     .endianness = DEVICE_LITTLE_ENDIAN, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | static void aspeed_soc_init(Object *obj) | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     AspeedSoCState *s = ASPEED_SOC(obj); | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     AspeedSoCClass *sc = ASPEED_SOC_GET_CLASS(s); | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  |     int i; | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-13 18:04:57 +02:00
										 |  |  |     object_initialize(&s->cpu, sizeof(s->cpu), sc->info->cpu_type); | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:26 +00:00
										 |  |  |     object_property_add_child(obj, "cpu", OBJECT(&s->cpu), NULL); | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     object_initialize(&s->vic, sizeof(s->vic), TYPE_ASPEED_VIC); | 
					
						
							|  |  |  |     object_property_add_child(obj, "vic", OBJECT(&s->vic), NULL); | 
					
						
							|  |  |  |     qdev_set_parent_bus(DEVICE(&s->vic), sysbus_get_default()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     object_initialize(&s->timerctrl, sizeof(s->timerctrl), TYPE_ASPEED_TIMER); | 
					
						
							|  |  |  |     object_property_add_child(obj, "timerctrl", OBJECT(&s->timerctrl), NULL); | 
					
						
							|  |  |  |     qdev_set_parent_bus(DEVICE(&s->timerctrl), sysbus_get_default()); | 
					
						
							| 
									
										
										
										
											2016-06-06 16:59:29 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     object_initialize(&s->i2c, sizeof(s->i2c), TYPE_ASPEED_I2C); | 
					
						
							|  |  |  |     object_property_add_child(obj, "i2c", OBJECT(&s->i2c), NULL); | 
					
						
							|  |  |  |     qdev_set_parent_bus(DEVICE(&s->i2c), sysbus_get_default()); | 
					
						
							| 
									
										
										
										
											2016-06-27 15:37:33 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     object_initialize(&s->scu, sizeof(s->scu), TYPE_ASPEED_SCU); | 
					
						
							|  |  |  |     object_property_add_child(obj, "scu", OBJECT(&s->scu), NULL); | 
					
						
							|  |  |  |     qdev_set_parent_bus(DEVICE(&s->scu), sysbus_get_default()); | 
					
						
							|  |  |  |     qdev_prop_set_uint32(DEVICE(&s->scu), "silicon-rev", | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |                          sc->info->silicon_rev); | 
					
						
							| 
									
										
										
										
											2016-06-27 15:37:33 +01:00
										 |  |  |     object_property_add_alias(obj, "hw-strap1", OBJECT(&s->scu), | 
					
						
							|  |  |  |                               "hw-strap1", &error_abort); | 
					
						
							|  |  |  |     object_property_add_alias(obj, "hw-strap2", OBJECT(&s->scu), | 
					
						
							|  |  |  |                               "hw-strap2", &error_abort); | 
					
						
							| 
									
										
										
										
											2017-11-14 22:50:18 +10:30
										 |  |  |     object_property_add_alias(obj, "hw-prot-key", OBJECT(&s->scu), | 
					
						
							|  |  |  |                               "hw-prot-key", &error_abort); | 
					
						
							| 
									
										
										
										
											2016-07-04 13:06:37 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  |     object_initialize(&s->fmc, sizeof(s->fmc), sc->info->fmc_typename); | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  |     object_property_add_child(obj, "fmc", OBJECT(&s->fmc), NULL); | 
					
						
							|  |  |  |     qdev_set_parent_bus(DEVICE(&s->fmc), sysbus_get_default()); | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:29 +00:00
										 |  |  |     object_property_add_alias(obj, "num-cs", OBJECT(&s->fmc), "num-cs", | 
					
						
							|  |  |  |                               &error_abort); | 
					
						
							| 
									
										
										
										
											2016-07-04 13:06:37 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  |     for (i = 0; i < sc->info->spis_num; i++) { | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  |         object_initialize(&s->spi[i], sizeof(s->spi[i]), | 
					
						
							|  |  |  |                           sc->info->spi_typename[i]); | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:27 +00:00
										 |  |  |         object_property_add_child(obj, "spi[*]", OBJECT(&s->spi[i]), NULL); | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  |         qdev_set_parent_bus(DEVICE(&s->spi[i]), sysbus_get_default()); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-09-06 19:52:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     object_initialize(&s->sdmc, sizeof(s->sdmc), TYPE_ASPEED_SDMC); | 
					
						
							|  |  |  |     object_property_add_child(obj, "sdmc", OBJECT(&s->sdmc), NULL); | 
					
						
							|  |  |  |     qdev_set_parent_bus(DEVICE(&s->sdmc), sysbus_get_default()); | 
					
						
							|  |  |  |     qdev_prop_set_uint32(DEVICE(&s->sdmc), "silicon-rev", | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |                          sc->info->silicon_rev); | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:06 +01:00
										 |  |  |     object_property_add_alias(obj, "ram-size", OBJECT(&s->sdmc), | 
					
						
							|  |  |  |                               "ram-size", &error_abort); | 
					
						
							| 
									
										
										
										
											2017-02-07 18:29:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-11 11:21:26 +01:00
										 |  |  |     for (i = 0; i < sc->info->wdts_num; i++) { | 
					
						
							|  |  |  |         object_initialize(&s->wdt[i], sizeof(s->wdt[i]), TYPE_ASPEED_WDT); | 
					
						
							|  |  |  |         object_property_add_child(obj, "wdt[*]", OBJECT(&s->wdt[i]), NULL); | 
					
						
							|  |  |  |         qdev_set_parent_bus(DEVICE(&s->wdt[i]), sysbus_get_default()); | 
					
						
							| 
									
										
										
										
											2017-09-04 15:21:54 +01:00
										 |  |  |         qdev_prop_set_uint32(DEVICE(&s->wdt[i]), "silicon-rev", | 
					
						
							|  |  |  |                                     sc->info->silicon_rev); | 
					
						
							| 
									
										
										
										
											2017-07-11 11:21:26 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-04-14 10:35:02 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     object_initialize(&s->ftgmac100, sizeof(s->ftgmac100), TYPE_FTGMAC100); | 
					
						
							|  |  |  |     object_property_add_child(obj, "ftgmac100", OBJECT(&s->ftgmac100), NULL); | 
					
						
							|  |  |  |     qdev_set_parent_bus(DEVICE(&s->ftgmac100), sysbus_get_default()); | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | static void aspeed_soc_realize(DeviceState *dev, Error **errp) | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     int i; | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     AspeedSoCState *s = ASPEED_SOC(dev); | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  |     AspeedSoCClass *sc = ASPEED_SOC_GET_CLASS(s); | 
					
						
							| 
									
										
										
										
											2016-07-04 13:06:37 +01:00
										 |  |  |     Error *err = NULL, *local_err = NULL; | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* IO space */ | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     memory_region_init_io(&s->iomem, NULL, &aspeed_soc_io_ops, NULL, | 
					
						
							|  |  |  |             "aspeed_soc.io", ASPEED_SOC_IOMEM_SIZE); | 
					
						
							|  |  |  |     memory_region_add_subregion_overlap(get_system_memory(), | 
					
						
							|  |  |  |                                         ASPEED_SOC_IOMEM_BASE, &s->iomem, -1); | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:26 +00:00
										 |  |  |     /* CPU */ | 
					
						
							|  |  |  |     object_property_set_bool(OBJECT(&s->cpu), true, "realized", &err); | 
					
						
							|  |  |  |     if (err) { | 
					
						
							|  |  |  |         error_propagate(errp, err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:27 +00:00
										 |  |  |     /* SRAM */ | 
					
						
							| 
									
										
										
										
											2017-07-07 15:42:49 +01:00
										 |  |  |     memory_region_init_ram_nomigrate(&s->sram, OBJECT(dev), "aspeed.sram", | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:27 +00:00
										 |  |  |                            sc->info->sram_size, &err); | 
					
						
							|  |  |  |     if (err) { | 
					
						
							|  |  |  |         error_propagate(errp, err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     vmstate_register_ram_global(&s->sram); | 
					
						
							|  |  |  |     memory_region_add_subregion(get_system_memory(), ASPEED_SOC_SRAM_BASE, | 
					
						
							|  |  |  |                                 &s->sram); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  |     /* VIC */ | 
					
						
							|  |  |  |     object_property_set_bool(OBJECT(&s->vic), true, "realized", &err); | 
					
						
							|  |  |  |     if (err) { | 
					
						
							|  |  |  |         error_propagate(errp, err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     sysbus_mmio_map(SYS_BUS_DEVICE(&s->vic), 0, ASPEED_SOC_VIC_BASE); | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  |     sysbus_connect_irq(SYS_BUS_DEVICE(&s->vic), 0, | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:26 +00:00
										 |  |  |                        qdev_get_gpio_in(DEVICE(&s->cpu), ARM_CPU_IRQ)); | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  |     sysbus_connect_irq(SYS_BUS_DEVICE(&s->vic), 1, | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:26 +00:00
										 |  |  |                        qdev_get_gpio_in(DEVICE(&s->cpu), ARM_CPU_FIQ)); | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Timer */ | 
					
						
							|  |  |  |     object_property_set_bool(OBJECT(&s->timerctrl), true, "realized", &err); | 
					
						
							|  |  |  |     if (err) { | 
					
						
							|  |  |  |         error_propagate(errp, err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     sysbus_mmio_map(SYS_BUS_DEVICE(&s->timerctrl), 0, ASPEED_SOC_TIMER_BASE); | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  |     for (i = 0; i < ARRAY_SIZE(timer_irqs); i++) { | 
					
						
							|  |  |  |         qemu_irq irq = qdev_get_gpio_in(DEVICE(&s->vic), timer_irqs[i]); | 
					
						
							|  |  |  |         sysbus_connect_irq(SYS_BUS_DEVICE(&s->timerctrl), i, irq); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-27 15:37:33 +01:00
										 |  |  |     /* SCU */ | 
					
						
							|  |  |  |     object_property_set_bool(OBJECT(&s->scu), true, "realized", &err); | 
					
						
							|  |  |  |     if (err) { | 
					
						
							|  |  |  |         error_propagate(errp, err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     sysbus_mmio_map(SYS_BUS_DEVICE(&s->scu), 0, ASPEED_SOC_SCU_BASE); | 
					
						
							| 
									
										
										
										
											2016-06-27 15:37:33 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  |     /* UART - attach an 8250 to the IO space as our UART5 */ | 
					
						
							|  |  |  |     if (serial_hds[0]) { | 
					
						
							|  |  |  |         qemu_irq uart5 = qdev_get_gpio_in(DEVICE(&s->vic), uart_irqs[4]); | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |         serial_mm_init(&s->iomem, ASPEED_SOC_UART_5_BASE, 2, | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  |                        uart5, 38400, serial_hds[0], DEVICE_LITTLE_ENDIAN); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-06-06 16:59:29 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* I2C */ | 
					
						
							|  |  |  |     object_property_set_bool(OBJECT(&s->i2c), true, "realized", &err); | 
					
						
							|  |  |  |     if (err) { | 
					
						
							|  |  |  |         error_propagate(errp, err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     sysbus_mmio_map(SYS_BUS_DEVICE(&s->i2c), 0, ASPEED_SOC_I2C_BASE); | 
					
						
							| 
									
										
										
										
											2016-06-06 16:59:29 +01:00
										 |  |  |     sysbus_connect_irq(SYS_BUS_DEVICE(&s->i2c), 0, | 
					
						
							|  |  |  |                        qdev_get_gpio_in(DEVICE(&s->vic), 12)); | 
					
						
							| 
									
										
										
										
											2016-07-04 13:06:37 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-27 14:59:29 +00:00
										 |  |  |     /* FMC, The number of CS is set at the board level */ | 
					
						
							|  |  |  |     object_property_set_bool(OBJECT(&s->fmc), true, "realized", &err); | 
					
						
							| 
									
										
										
										
											2016-07-04 13:06:37 +01:00
										 |  |  |     if (err) { | 
					
						
							|  |  |  |         error_propagate(errp, err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  |     sysbus_mmio_map(SYS_BUS_DEVICE(&s->fmc), 0, ASPEED_SOC_FMC_BASE); | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  |     sysbus_mmio_map(SYS_BUS_DEVICE(&s->fmc), 1, | 
					
						
							|  |  |  |                     s->fmc.ctrl->flash_window_base); | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  |     sysbus_connect_irq(SYS_BUS_DEVICE(&s->fmc), 0, | 
					
						
							| 
									
										
										
										
											2016-07-04 13:06:37 +01:00
										 |  |  |                        qdev_get_gpio_in(DEVICE(&s->vic), 19)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* SPI */ | 
					
						
							| 
									
										
										
										
											2016-10-17 19:22:16 +01:00
										 |  |  |     for (i = 0; i < sc->info->spis_num; i++) { | 
					
						
							|  |  |  |         object_property_set_int(OBJECT(&s->spi[i]), 1, "num-cs", &err); | 
					
						
							|  |  |  |         object_property_set_bool(OBJECT(&s->spi[i]), true, "realized", | 
					
						
							|  |  |  |                                  &local_err); | 
					
						
							|  |  |  |         error_propagate(&err, local_err); | 
					
						
							|  |  |  |         if (err) { | 
					
						
							|  |  |  |             error_propagate(errp, err); | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         sysbus_mmio_map(SYS_BUS_DEVICE(&s->spi[i]), 0, sc->info->spi_bases[i]); | 
					
						
							|  |  |  |         sysbus_mmio_map(SYS_BUS_DEVICE(&s->spi[i]), 1, | 
					
						
							|  |  |  |                         s->spi[i].ctrl->flash_window_base); | 
					
						
							| 
									
										
										
										
											2016-07-04 13:06:37 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-09-06 19:52:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* SDMC - SDRAM Memory Controller */ | 
					
						
							|  |  |  |     object_property_set_bool(OBJECT(&s->sdmc), true, "realized", &err); | 
					
						
							|  |  |  |     if (err) { | 
					
						
							|  |  |  |         error_propagate(errp, err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     sysbus_mmio_map(SYS_BUS_DEVICE(&s->sdmc), 0, ASPEED_SOC_SDMC_BASE); | 
					
						
							| 
									
										
										
										
											2017-02-07 18:29:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Watch dog */ | 
					
						
							| 
									
										
										
										
											2017-07-11 11:21:26 +01:00
										 |  |  |     for (i = 0; i < sc->info->wdts_num; i++) { | 
					
						
							|  |  |  |         object_property_set_bool(OBJECT(&s->wdt[i]), true, "realized", &err); | 
					
						
							|  |  |  |         if (err) { | 
					
						
							|  |  |  |             error_propagate(errp, err); | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         sysbus_mmio_map(SYS_BUS_DEVICE(&s->wdt[i]), 0, | 
					
						
							|  |  |  |                         ASPEED_SOC_WDT_BASE + i * 0x20); | 
					
						
							| 
									
										
										
										
											2017-02-07 18:29:59 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-04-14 10:35:02 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Net */ | 
					
						
							|  |  |  |     qdev_set_nic_properties(DEVICE(&s->ftgmac100), &nd_table[0]); | 
					
						
							|  |  |  |     object_property_set_bool(OBJECT(&s->ftgmac100), true, "aspeed", &err); | 
					
						
							|  |  |  |     object_property_set_bool(OBJECT(&s->ftgmac100), true, "realized", | 
					
						
							|  |  |  |                              &local_err); | 
					
						
							|  |  |  |     error_propagate(&err, local_err); | 
					
						
							|  |  |  |     if (err) { | 
					
						
							|  |  |  |         error_propagate(errp, err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     sysbus_mmio_map(SYS_BUS_DEVICE(&s->ftgmac100), 0, ASPEED_SOC_ETH1_BASE); | 
					
						
							|  |  |  |     sysbus_connect_irq(SYS_BUS_DEVICE(&s->ftgmac100), 0, | 
					
						
							|  |  |  |                        qdev_get_gpio_in(DEVICE(&s->vic), 2)); | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | static void aspeed_soc_class_init(ObjectClass *oc, void *data) | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceClass *dc = DEVICE_CLASS(oc); | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     AspeedSoCClass *sc = ASPEED_SOC_CLASS(oc); | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     sc->info = (AspeedSoCInfo *) data; | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     dc->realize = aspeed_soc_realize; | 
					
						
							| 
									
										
										
										
											2017-09-04 15:21:55 +01:00
										 |  |  |     /* Reason: Uses serial_hds and nd_table in realize() directly */ | 
					
						
							|  |  |  |     dc->user_creatable = false; | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | static const TypeInfo aspeed_soc_type_info = { | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     .name           = TYPE_ASPEED_SOC, | 
					
						
							|  |  |  |     .parent         = TYPE_DEVICE, | 
					
						
							|  |  |  |     .instance_init  = aspeed_soc_init, | 
					
						
							|  |  |  |     .instance_size  = sizeof(AspeedSoCState), | 
					
						
							|  |  |  |     .class_size     = sizeof(AspeedSoCClass), | 
					
						
							|  |  |  |     .abstract       = true, | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | static void aspeed_soc_register_types(void) | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     int i; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     type_register_static(&aspeed_soc_type_info); | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  |     for (i = 0; i < ARRAY_SIZE(aspeed_socs); ++i) { | 
					
						
							|  |  |  |         TypeInfo ti = { | 
					
						
							|  |  |  |             .name       = aspeed_socs[i].name, | 
					
						
							|  |  |  |             .parent     = TYPE_ASPEED_SOC, | 
					
						
							|  |  |  |             .class_init = aspeed_soc_class_init, | 
					
						
							|  |  |  |             .class_data = (void *) &aspeed_socs[i], | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         type_register(&ti); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-03-16 17:06:00 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 18:13:05 +01:00
										 |  |  | type_init(aspeed_soc_register_types) |