| 
									
										
										
										
											2019-02-21 18:17:46 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * ARM AMBA PrimeCell PL031 RTC | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 2007 CodeSourcery | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is free software; you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License version 2 as | 
					
						
							|  |  |  |  * published by the Free Software Foundation. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Contributions after 2012-01-13 are licensed under the terms of the | 
					
						
							|  |  |  |  * GNU GPL, version 2 or (at your option) any later version. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-04 01:03:52 +02:00
										 |  |  | #ifndef HW_RTC_PL031_H
 | 
					
						
							|  |  |  | #define HW_RTC_PL031_H
 | 
					
						
							| 
									
										
										
										
											2019-02-21 18:17:46 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "hw/sysbus.h"
 | 
					
						
							| 
									
										
										
										
											2019-10-04 01:03:52 +02:00
										 |  |  | #include "qemu/timer.h"
 | 
					
						
							| 
									
										
										
										
											2019-02-21 18:17:46 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define TYPE_PL031 "pl031"
 | 
					
						
							|  |  |  | #define PL031(obj) OBJECT_CHECK(PL031State, (obj), TYPE_PL031)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct PL031State { | 
					
						
							|  |  |  |     SysBusDevice parent_obj; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     MemoryRegion iomem; | 
					
						
							|  |  |  |     QEMUTimer *timer; | 
					
						
							|  |  |  |     qemu_irq irq; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /*
 | 
					
						
							|  |  |  |      * Needed to preserve the tick_count across migration, even if the | 
					
						
							|  |  |  |      * absolute value of the rtc_clock is different on the source and | 
					
						
							|  |  |  |      * destination. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     uint32_t tick_offset_vmstate; | 
					
						
							|  |  |  |     uint32_t tick_offset; | 
					
						
							| 
									
										
										
										
											2019-07-15 14:17:04 +01:00
										 |  |  |     bool tick_offset_migrated; | 
					
						
							|  |  |  |     bool migrate_tick_offset; | 
					
						
							| 
									
										
										
										
											2019-02-21 18:17:46 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     uint32_t mr; | 
					
						
							|  |  |  |     uint32_t lr; | 
					
						
							|  |  |  |     uint32_t cr; | 
					
						
							|  |  |  |     uint32_t im; | 
					
						
							|  |  |  |     uint32_t is; | 
					
						
							|  |  |  | } PL031State; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 |