| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Allwinner R40/A40i/T3 System on Chip emulation | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (C) 2023 qianfan Zhao <qianfanguijin@163.com> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 2 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef HW_ARM_ALLWINNER_R40_H
 | 
					
						
							|  |  |  | #define HW_ARM_ALLWINNER_R40_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "qom/object.h"
 | 
					
						
							|  |  |  | #include "hw/timer/allwinner-a10-pit.h"
 | 
					
						
							| 
									
										
										
										
											2024-02-13 06:15:13 +01:00
										 |  |  | #include "hw/ide/ahci-sysbus.h"
 | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  | #include "hw/intc/arm_gic.h"
 | 
					
						
							|  |  |  | #include "hw/sd/allwinner-sdhost.h"
 | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  | #include "hw/misc/allwinner-r40-ccu.h"
 | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:32 +01:00
										 |  |  | #include "hw/misc/allwinner-r40-dramc.h"
 | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:33 +01:00
										 |  |  | #include "hw/misc/allwinner-sramc.h"
 | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:32 +01:00
										 |  |  | #include "hw/i2c/allwinner-i2c.h"
 | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:33 +01:00
										 |  |  | #include "hw/net/allwinner_emac.h"
 | 
					
						
							|  |  |  | #include "hw/net/allwinner-sun8i-emac.h"
 | 
					
						
							| 
									
										
										
										
											2024-01-15 10:27:55 -08:00
										 |  |  | #include "hw/usb/hcd-ohci.h"
 | 
					
						
							|  |  |  | #include "hw/usb/hcd-ehci.h"
 | 
					
						
							| 
									
										
										
										
											2024-01-15 10:27:57 -08:00
										 |  |  | #include "hw/watchdog/allwinner-wdt.h"
 | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  | #include "target/arm/cpu.h"
 | 
					
						
							|  |  |  | #include "sysemu/block-backend.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum { | 
					
						
							|  |  |  |     AW_R40_DEV_SRAM_A1, | 
					
						
							|  |  |  |     AW_R40_DEV_SRAM_A2, | 
					
						
							|  |  |  |     AW_R40_DEV_SRAM_A3, | 
					
						
							|  |  |  |     AW_R40_DEV_SRAM_A4, | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:33 +01:00
										 |  |  |     AW_R40_DEV_SRAMC, | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:33 +01:00
										 |  |  |     AW_R40_DEV_EMAC, | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  |     AW_R40_DEV_MMC0, | 
					
						
							|  |  |  |     AW_R40_DEV_MMC1, | 
					
						
							|  |  |  |     AW_R40_DEV_MMC2, | 
					
						
							|  |  |  |     AW_R40_DEV_MMC3, | 
					
						
							| 
									
										
										
										
											2024-01-15 10:27:56 -08:00
										 |  |  |     AW_R40_DEV_AHCI, | 
					
						
							| 
									
										
										
										
											2024-01-15 10:27:55 -08:00
										 |  |  |     AW_R40_DEV_EHCI1, | 
					
						
							|  |  |  |     AW_R40_DEV_OHCI1, | 
					
						
							|  |  |  |     AW_R40_DEV_EHCI2, | 
					
						
							|  |  |  |     AW_R40_DEV_OHCI2, | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  |     AW_R40_DEV_CCU, | 
					
						
							|  |  |  |     AW_R40_DEV_PIT, | 
					
						
							| 
									
										
										
										
											2024-01-15 10:27:57 -08:00
										 |  |  |     AW_R40_DEV_WDT, | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  |     AW_R40_DEV_UART0, | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:32 +01:00
										 |  |  |     AW_R40_DEV_UART1, | 
					
						
							|  |  |  |     AW_R40_DEV_UART2, | 
					
						
							|  |  |  |     AW_R40_DEV_UART3, | 
					
						
							|  |  |  |     AW_R40_DEV_UART4, | 
					
						
							|  |  |  |     AW_R40_DEV_UART5, | 
					
						
							|  |  |  |     AW_R40_DEV_UART6, | 
					
						
							|  |  |  |     AW_R40_DEV_UART7, | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:32 +01:00
										 |  |  |     AW_R40_DEV_TWI0, | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:33 +01:00
										 |  |  |     AW_R40_DEV_GMAC, | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  |     AW_R40_DEV_GIC_DIST, | 
					
						
							|  |  |  |     AW_R40_DEV_GIC_CPU, | 
					
						
							|  |  |  |     AW_R40_DEV_GIC_HYP, | 
					
						
							|  |  |  |     AW_R40_DEV_GIC_VCPU, | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:32 +01:00
										 |  |  |     AW_R40_DEV_SDRAM, | 
					
						
							|  |  |  |     AW_R40_DEV_DRAMCOM, | 
					
						
							|  |  |  |     AW_R40_DEV_DRAMCTL, | 
					
						
							|  |  |  |     AW_R40_DEV_DRAMPHY, | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define AW_R40_NUM_CPUS      (4)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Allwinner R40 object model | 
					
						
							|  |  |  |  * @{ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** Object type for the Allwinner R40 SoC */ | 
					
						
							|  |  |  | #define TYPE_AW_R40 "allwinner-r40"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** Convert input object to Allwinner R40 state object */ | 
					
						
							|  |  |  | OBJECT_DECLARE_SIMPLE_TYPE(AwR40State, AW_R40) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** @} */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Allwinner R40 object | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This struct contains the state of all the devices | 
					
						
							|  |  |  |  * which are currently emulated by the R40 SoC code. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #define AW_R40_NUM_MMCS         4
 | 
					
						
							| 
									
										
										
										
											2024-01-15 10:27:55 -08:00
										 |  |  | #define AW_R40_NUM_USB          2
 | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:32 +01:00
										 |  |  | #define AW_R40_NUM_UARTS        8
 | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | struct AwR40State { | 
					
						
							|  |  |  |     /*< private >*/ | 
					
						
							|  |  |  |     DeviceState parent_obj; | 
					
						
							|  |  |  |     /*< public >*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:32 +01:00
										 |  |  |     /** Physical base address for start of RAM */ | 
					
						
							|  |  |  |     hwaddr ram_addr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Total RAM size in megabytes */ | 
					
						
							|  |  |  |     uint32_t ram_size; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  |     ARMCPU cpus[AW_R40_NUM_CPUS]; | 
					
						
							|  |  |  |     const hwaddr *memmap; | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:33 +01:00
										 |  |  |     AwSRAMCState sramc; | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  |     AwA10PITState timer; | 
					
						
							| 
									
										
										
										
											2024-01-15 10:27:57 -08:00
										 |  |  |     AwWdtState wdt; | 
					
						
							| 
									
										
										
										
											2024-01-15 10:27:56 -08:00
										 |  |  |     AllwinnerAHCIState sata; | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  |     AwSdHostState mmc[AW_R40_NUM_MMCS]; | 
					
						
							| 
									
										
										
										
											2024-01-15 10:27:55 -08:00
										 |  |  |     EHCISysBusState ehci[AW_R40_NUM_USB]; | 
					
						
							|  |  |  |     OHCISysBusState ohci[AW_R40_NUM_USB]; | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  |     AwR40ClockCtlState ccu; | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:32 +01:00
										 |  |  |     AwR40DramCtlState dramc; | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:32 +01:00
										 |  |  |     AWI2CState i2c0; | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:33 +01:00
										 |  |  |     AwEmacState emac; | 
					
						
							|  |  |  |     AwSun8iEmacState gmac; | 
					
						
							| 
									
										
										
										
											2023-06-06 10:19:31 +01:00
										 |  |  |     GICState gic; | 
					
						
							|  |  |  |     MemoryRegion sram_a1; | 
					
						
							|  |  |  |     MemoryRegion sram_a2; | 
					
						
							|  |  |  |     MemoryRegion sram_a3; | 
					
						
							|  |  |  |     MemoryRegion sram_a4; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Emulate Boot ROM firmware setup functionality. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * A real Allwinner R40 SoC contains a Boot ROM | 
					
						
							|  |  |  |  * which is the first code that runs right after | 
					
						
							|  |  |  |  * the SoC is powered on. The Boot ROM is responsible | 
					
						
							|  |  |  |  * for loading user code (e.g. a bootloader) from any | 
					
						
							|  |  |  |  * of the supported external devices and writing the | 
					
						
							|  |  |  |  * downloaded code to internal SRAM. After loading the SoC | 
					
						
							|  |  |  |  * begins executing the code written to SRAM. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This function emulates the Boot ROM by copying 32 KiB | 
					
						
							|  |  |  |  * of data from the given block device and writes it to | 
					
						
							|  |  |  |  * the start of the first internal SRAM memory. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @s: Allwinner R40 state object pointer | 
					
						
							|  |  |  |  * @blk: Block backend device object pointer | 
					
						
							|  |  |  |  * @unit: the mmc control's unit | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | bool allwinner_r40_bootrom_setup(AwR40State *s, BlockBackend *blk, int unit); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* HW_ARM_ALLWINNER_R40_H */
 |