| 
									
										
										
										
											2018-08-24 13:17:43 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * ARM IoTKit system information block | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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 information block" 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:43 +01:00
										 |  |  |  * QEMU interface: | 
					
						
							| 
									
										
										
										
											2019-02-01 14:55:42 +00:00
										 |  |  |  *  + QOM property "SYS_VERSION": value to use for SYS_VERSION register | 
					
						
							|  |  |  |  *  + QOM property "SYS_CONFIG": value to use for SYS_CONFIG register | 
					
						
							| 
									
										
										
										
											2018-08-24 13:17:43 +01:00
										 |  |  |  *  + sysbus MMIO region 0: the system information register bank | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef HW_MISC_IOTKIT_SYSINFO_H
 | 
					
						
							|  |  |  | #define HW_MISC_IOTKIT_SYSINFO_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "hw/sysbus.h"
 | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | #include "qom/object.h"
 | 
					
						
							| 
									
										
										
										
											2018-08-24 13:17:43 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define TYPE_IOTKIT_SYSINFO "iotkit-sysinfo"
 | 
					
						
							| 
									
										
										
										
											2020-09-16 14:25:19 -04:00
										 |  |  | OBJECT_DECLARE_SIMPLE_TYPE(IoTKitSysInfo, IOTKIT_SYSINFO) | 
					
						
							| 
									
										
										
										
											2018-08-24 13:17:43 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | struct IoTKitSysInfo { | 
					
						
							| 
									
										
										
										
											2018-08-24 13:17:43 +01:00
										 |  |  |     /*< private >*/ | 
					
						
							|  |  |  |     SysBusDevice parent_obj; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /*< public >*/ | 
					
						
							|  |  |  |     MemoryRegion iomem; | 
					
						
							| 
									
										
										
										
											2019-02-01 14:55:42 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Properties */ | 
					
						
							|  |  |  |     uint32_t sys_version; | 
					
						
							|  |  |  |     uint32_t sys_config; | 
					
						
							| 
									
										
										
										
											2021-02-19 14:45:41 +00:00
										 |  |  |     uint32_t sse_version; | 
					
						
							| 
									
										
										
										
											2021-02-19 14:45:43 +00:00
										 |  |  |     uint32_t iidr; | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2018-08-24 13:17:43 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif
 |