| 
									
										
										
										
											2018-03-02 10:45:39 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * ARM MPS2 FPGAIO emulation | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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 FPGAIO register block in the AN505
 | 
					
						
							|  |  |  |  * FPGA image for the MPS2 dev board; it is documented in the | 
					
						
							|  |  |  |  * application note: | 
					
						
							| 
									
										
										
										
											2021-02-15 11:51:38 +00:00
										 |  |  |  * https://developer.arm.com/documentation/dai0505/latest/
 | 
					
						
							| 
									
										
										
										
											2018-03-02 10:45:39 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * QEMU interface: | 
					
						
							|  |  |  |  *  + sysbus MMIO region 0: the register bank | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef MPS2_FPGAIO_H
 | 
					
						
							|  |  |  | #define MPS2_FPGAIO_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "hw/sysbus.h"
 | 
					
						
							| 
									
										
										
										
											2020-06-15 21:17:19 +02:00
										 |  |  | #include "hw/misc/led.h"
 | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | #include "qom/object.h"
 | 
					
						
							| 
									
										
										
										
											2018-03-02 10:45:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define TYPE_MPS2_FPGAIO "mps2-fpgaio"
 | 
					
						
							| 
									
										
										
										
											2020-09-16 14:25:19 -04:00
										 |  |  | OBJECT_DECLARE_SIMPLE_TYPE(MPS2FPGAIO, MPS2_FPGAIO) | 
					
						
							| 
									
										
										
										
											2018-03-02 10:45:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-15 11:51:19 +00:00
										 |  |  | #define MPS2FPGAIO_MAX_LEDS 32
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | struct MPS2FPGAIO { | 
					
						
							| 
									
										
										
										
											2018-03-02 10:45:39 +00:00
										 |  |  |     /*< private >*/ | 
					
						
							|  |  |  |     SysBusDevice parent_obj; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /*< public >*/ | 
					
						
							|  |  |  |     MemoryRegion iomem; | 
					
						
							| 
									
										
										
										
											2021-02-15 11:51:19 +00:00
										 |  |  |     LEDState *led[MPS2FPGAIO_MAX_LEDS]; | 
					
						
							|  |  |  |     uint32_t num_leds; | 
					
						
							| 
									
										
										
										
											2021-02-15 11:51:20 +00:00
										 |  |  |     bool has_switches; | 
					
						
							| 
									
										
										
										
											2021-02-19 14:46:11 +00:00
										 |  |  |     bool has_dbgctrl; | 
					
						
							| 
									
										
										
										
											2018-03-02 10:45:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     uint32_t led0; | 
					
						
							|  |  |  |     uint32_t prescale; | 
					
						
							|  |  |  |     uint32_t misc; | 
					
						
							| 
									
										
										
										
											2021-02-19 14:46:11 +00:00
										 |  |  |     uint32_t dbgctrl; | 
					
						
							| 
									
										
										
										
											2018-03-02 10:45:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-24 13:17:40 +01:00
										 |  |  |     /* QEMU_CLOCK_VIRTUAL time at which counter and pscntr were last synced */ | 
					
						
							|  |  |  |     int64_t pscntr_sync_ticks; | 
					
						
							|  |  |  |     /* Values of COUNTER and PSCNTR at time pscntr_sync_ticks */ | 
					
						
							|  |  |  |     uint32_t counter; | 
					
						
							|  |  |  |     uint32_t pscntr; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-02 10:45:39 +00:00
										 |  |  |     uint32_t prescale_clk; | 
					
						
							| 
									
										
										
										
											2018-08-24 13:17:40 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* These hold the CLOCK_VIRTUAL ns tick when the CLK1HZ/CLK100HZ was zero */ | 
					
						
							|  |  |  |     int64_t clk1hz_tick_offset; | 
					
						
							|  |  |  |     int64_t clk100hz_tick_offset; | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2018-03-02 10:45:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif
 |