| 
									
										
										
										
											2018-08-24 13:17:42 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * ARM IoTKit system control element | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 2018 Linaro Limited | 
					
						
							|  |  |  |  * Written by Peter Maydell | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  This program is free software; you can redistribute it and/or modify | 
					
						
							|  |  |  |  *  it under the terms of the GNU General Public License version 2 or | 
					
						
							|  |  |  |  *  (at your option) any later version. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * This is a model of the "system control element" which is part of the | 
					
						
							|  |  |  |  * Arm IoTKit and documented in | 
					
						
							| 
									
										
										
										
											2021-02-15 11:51:38 +00:00
										 |  |  |  * https://developer.arm.com/documentation/ecm0601256/latest
 | 
					
						
							| 
									
										
										
										
											2018-08-24 13:17:42 +01:00
										 |  |  |  * Specifically, it implements the "system information block" and | 
					
						
							|  |  |  |  * "system control register" blocks. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * QEMU interface: | 
					
						
							| 
									
										
										
										
											2021-02-19 14:45:38 +00:00
										 |  |  |  *  + QOM property "sse-version": indicates which SSE version this is part of | 
					
						
							|  |  |  |  *    (used to identify whether to provide SSE-200-only registers, etc) | 
					
						
							| 
									
										
										
										
											2018-08-24 13:17:42 +01:00
										 |  |  |  *  + sysbus MMIO region 0: the system information register bank | 
					
						
							|  |  |  |  *  + sysbus MMIO region 1: the system control register bank | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef HW_MISC_IOTKIT_SYSCTL_H
 | 
					
						
							|  |  |  | #define HW_MISC_IOTKIT_SYSCTL_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "hw/sysbus.h"
 | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | #include "qom/object.h"
 | 
					
						
							| 
									
										
										
										
											2018-08-24 13:17:42 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define TYPE_IOTKIT_SYSCTL "iotkit-sysctl"
 | 
					
						
							| 
									
										
										
										
											2020-09-16 14:25:19 -04:00
										 |  |  | OBJECT_DECLARE_SIMPLE_TYPE(IoTKitSysCtl, IOTKIT_SYSCTL) | 
					
						
							| 
									
										
										
										
											2018-08-24 13:17:42 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | struct IoTKitSysCtl { | 
					
						
							| 
									
										
										
										
											2018-08-24 13:17:42 +01:00
										 |  |  |     /*< private >*/ | 
					
						
							|  |  |  |     SysBusDevice parent_obj; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /*< public >*/ | 
					
						
							|  |  |  |     MemoryRegion iomem; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     uint32_t secure_debug; | 
					
						
							|  |  |  |     uint32_t reset_syndrome; | 
					
						
							|  |  |  |     uint32_t reset_mask; | 
					
						
							|  |  |  |     uint32_t gretreg; | 
					
						
							| 
									
										
										
										
											2019-02-28 10:55:16 +00:00
										 |  |  |     uint32_t initsvtor0; | 
					
						
							| 
									
										
										
										
											2018-08-24 13:17:42 +01:00
										 |  |  |     uint32_t cpuwait; | 
					
						
							|  |  |  |     uint32_t wicctrl; | 
					
						
							| 
									
										
										
										
											2019-02-28 10:55:16 +00:00
										 |  |  |     uint32_t scsecctrl; | 
					
						
							|  |  |  |     uint32_t fclk_div; | 
					
						
							|  |  |  |     uint32_t sysclk_div; | 
					
						
							|  |  |  |     uint32_t clock_force; | 
					
						
							|  |  |  |     uint32_t initsvtor1; | 
					
						
							|  |  |  |     uint32_t nmi_enable; | 
					
						
							|  |  |  |     uint32_t ewctrl; | 
					
						
							| 
									
										
										
										
											2021-02-19 14:45:49 +00:00
										 |  |  |     uint32_t pwrctrl; | 
					
						
							| 
									
										
										
										
											2019-02-28 10:55:16 +00:00
										 |  |  |     uint32_t pdcm_pd_sys_sense; | 
					
						
							|  |  |  |     uint32_t pdcm_pd_sram0_sense; | 
					
						
							|  |  |  |     uint32_t pdcm_pd_sram1_sense; | 
					
						
							|  |  |  |     uint32_t pdcm_pd_sram2_sense; | 
					
						
							|  |  |  |     uint32_t pdcm_pd_sram3_sense; | 
					
						
							| 
									
										
										
										
											2021-02-19 14:45:50 +00:00
										 |  |  |     uint32_t pdcm_pd_cpu0_sense; | 
					
						
							|  |  |  |     uint32_t pdcm_pd_vmr0_sense; | 
					
						
							|  |  |  |     uint32_t pdcm_pd_vmr1_sense; | 
					
						
							| 
									
										
										
										
											2019-02-28 10:55:16 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Properties */ | 
					
						
							| 
									
										
										
										
											2021-02-19 14:45:38 +00:00
										 |  |  |     uint32_t sse_version; | 
					
						
							| 
									
										
										
										
											2019-02-28 10:55:16 +00:00
										 |  |  |     uint32_t cpuwait_rst; | 
					
						
							|  |  |  |     uint32_t initsvtor0_rst; | 
					
						
							|  |  |  |     uint32_t initsvtor1_rst; | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2018-08-24 13:17:42 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif
 |