 5b21b331be
			
		
	
	
		5b21b331be
		
	
	
	
	
		
			
			Exposing the io_base offset as a QOM property not only allows it to be
configurable but also to be displayed in HMP:
Before:
(qemu) info qtree
       ...
          dev: mc146818rtc, id ""
            gpio-out "" 1
            base_year = 0 (0x0)
            irq = 8 (0x8)
            lost_tick_policy = "discard"
After:
          dev: mc146818rtc, id ""
            gpio-out "" 1
            base_year = 0 (0x0)
            iobase = 112 (0x70)
            irq = 8 (0x8)
            lost_tick_policy = "discard"
Signed-off-by: Bernhard Beschow <shentey@gmail.com>
Reviewed-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Message-Id: <20220529184006.10712-4-shentey@gmail.com>
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
		
	
			
		
			
				
	
	
		
			60 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * QEMU MC146818 RTC emulation
 | |
|  *
 | |
|  * Copyright (c) 2003-2004 Fabrice Bellard
 | |
|  *
 | |
|  * SPDX-License-Identifier: MIT
 | |
|  */
 | |
| 
 | |
| #ifndef HW_RTC_MC146818RTC_H
 | |
| #define HW_RTC_MC146818RTC_H
 | |
| 
 | |
| #include "qapi/qapi-types-machine.h"
 | |
| #include "qemu/queue.h"
 | |
| #include "qemu/timer.h"
 | |
| #include "hw/isa/isa.h"
 | |
| #include "qom/object.h"
 | |
| 
 | |
| #define TYPE_MC146818_RTC "mc146818rtc"
 | |
| OBJECT_DECLARE_SIMPLE_TYPE(RTCState, MC146818_RTC)
 | |
| 
 | |
| struct RTCState {
 | |
|     ISADevice parent_obj;
 | |
| 
 | |
|     MemoryRegion io;
 | |
|     MemoryRegion coalesced_io;
 | |
|     uint8_t cmos_data[128];
 | |
|     uint8_t cmos_index;
 | |
|     uint8_t isairq;
 | |
|     uint16_t io_base;
 | |
|     int32_t base_year;
 | |
|     uint64_t base_rtc;
 | |
|     uint64_t last_update;
 | |
|     int64_t offset;
 | |
|     qemu_irq irq;
 | |
|     int it_shift;
 | |
|     /* periodic timer */
 | |
|     QEMUTimer *periodic_timer;
 | |
|     int64_t next_periodic_time;
 | |
|     /* update-ended timer */
 | |
|     QEMUTimer *update_timer;
 | |
|     uint64_t next_alarm_time;
 | |
|     uint16_t irq_reinject_on_ack_count;
 | |
|     uint32_t irq_coalesced;
 | |
|     uint32_t period;
 | |
|     QEMUTimer *coalesced_timer;
 | |
|     Notifier clock_reset_notifier;
 | |
|     LostTickPolicy lost_tick_policy;
 | |
|     Notifier suspend_notifier;
 | |
|     QLIST_ENTRY(RTCState) link;
 | |
| };
 | |
| 
 | |
| #define RTC_ISA_IRQ 8
 | |
| 
 | |
| ISADevice *mc146818_rtc_init(ISABus *bus, int base_year,
 | |
|                              qemu_irq intercept_irq);
 | |
| void rtc_set_memory(ISADevice *dev, int addr, int val);
 | |
| int rtc_get_memory(ISADevice *dev, int addr);
 | |
| 
 | |
| #endif /* HW_RTC_MC146818RTC_H */
 |