 3b004a1654
			
		
	
	
		3b004a1654
		
	
	
	
	
		
			
			Exposing the IRQ number 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)
            lost_tick_policy = "discard"
After:
          dev: mc146818rtc, id ""
            gpio-out "" 1
            base_year = 0 (0x0)
            irq = 8 (0x8)
            lost_tick_policy = "discard"
The reason the IRQ number didn's show up before is that this device does not
call isa_init_irq().
Signed-off-by: Bernhard Beschow <shentey@gmail.com>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Message-Id: <20220301220037.76555-2-shentey@gmail.com>
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Message-Id: <20220307134353.1950-9-philippe.mathieu.daude@gmail.com>
Reviewed-by: Bernhard Beschow <shentey@gmail.com>
		
	
			
		
			
				
	
	
		
			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;
 | |
|     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
 | |
| #define RTC_ISA_BASE 0x70
 | |
| 
 | |
| 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 /* MC146818RTC_H */
 |