Hi Huacai, Yes, this is my new address. However I haven't been involved in kernel/QEMU community for a while now. The patch itself looks OK to me, if you made sure the RTC device emulation on the QEMU side is now also inspecting the TIMER_IRQ_ENABLED setting. OK I see now that you have committed upstream to QEMU the Goldfish RTC device, good job with that. https://github.com/qemu/qemu/blame/971b2a1e5b1a8cc8f597ac5d7016908f9fa880de/hw/rtc/goldfish_rtc.c You can add my "reviewed-by". Glad to see that the "goldfish" project is still alive out there. Kind regards, Miodrag -----Original Message----- From: Huacai Chen <chenhuacai@xxxxxxxxx> Sent: Thursday, July 9, 2020 11:40 AM To: Alessandro Zummo <a.zummo@xxxxxxxxxxxx>; Alexandre Belloni <alexandre.belloni@xxxxxxxxxxx>; Miodrag Dinic <Miodrag.Dinic@xxxxxxxxxx> Cc: linux-rtc@xxxxxxxxxxxxxxx; Fuxin Zhang <zhangfx@xxxxxxxxxx>; Jiaxun Yang <jiaxun.yang@xxxxxxxxxxx> Subject: Re: [PATCH] rtc: goldfish: Enable interrupt in set_alarm() when necessary Hi, Midorag, Maybe miodrag.dinic@xxxxxxxxxx is your new email address? Please review this patch. And Alessandro, Alexandre, could you please help to review this patch? Huacai On Fri, Jul 3, 2020 at 11:00 AM Huacai Chen <chenhuacai@xxxxxxxxx> wrote: > > Ping? > > On Sat, Jun 20, 2020 at 8:03 PM Huacai Chen <chenhc@xxxxxxxxxx> wrote: > > > > When use goldfish rtc, the "hwclock" command fails with "select() to > > /dev/rtc to wait for clock tick timed out". This is because "hwclock" > > need the set_alarm() hook to enable interrupt when alrm->enabled is > > true. This operation is missing in goldfish rtc (but other rtc > > drivers, such as cmos rtc, enable interrupt here), so add it. > > > > Signed-off-by: Huacai Chen <chenhc@xxxxxxxxxx> > > Signed-off-by: Jiaxun Yang <jiaxun.yang@xxxxxxxxxxx> > > --- > > drivers/rtc/rtc-goldfish.c | 1 + > > 1 file changed, 1 insertion(+) > > > > diff --git a/drivers/rtc/rtc-goldfish.c b/drivers/rtc/rtc-goldfish.c > > index 1a3420e..d5083b0 100644 > > --- a/drivers/rtc/rtc-goldfish.c > > +++ b/drivers/rtc/rtc-goldfish.c > > @@ -73,6 +73,7 @@ static int goldfish_rtc_set_alarm(struct device *dev, > > rtc_alarm64 = rtc_tm_to_time64(&alrm->time) * NSEC_PER_SEC; > > writel((rtc_alarm64 >> 32), base + TIMER_ALARM_HIGH); > > writel(rtc_alarm64, base + TIMER_ALARM_LOW); > > + writel(1, base + TIMER_IRQ_ENABLED); > > } else { > > /* > > * if this function was called with enabled=0 > > -- > > 2.7.0 > >