Hi, Quick answers to your very good questions below: On 17/01/2020 21:50:34+0100, Aleksandar Markovic wrote: > Alexandre (and Arnd too, or any other person knowledgeable in the area), > > I just need to clarify a couple of details with you, please. > > Firstly, here is what man page rtc(4) says: > > "The /dev/rtc (or /dev/rtc0, /dev/rtc1, etc.) device can be opened > only once (until it is closed) and it is read-only. On read(2) and > select(2) the calling process is blocked until the next interrupt from > that RTC is received. Following the interrupt, the process can read a > long integer, of which the least significant byte contains a bit mask > encoding the types of interrupt that occurred, while the remaining 3 > bytes contain the number of interrupts since the last read(2)." > > So, it looks read() will always return only 4 bytes of useful info > (regardless of host being 32-bit/64-bit). > > My questions are: > > - Is the description in man page genuinely accurate? > It is accurate. It is a mask of: #define RTC_IRQF 0x80 /* Any of the following is active */ #define RTC_PF 0x40 /* Periodic interrupt */ #define RTC_AF 0x20 /* Alarm interrupt */ #define RTC_UF 0x10 /* Update interrupt for 1Hz RTC */ Which will most likely be RTC_IRQF | RTC_AF. > - To me (but I am really an outsider to using RTC in applications), > this feature (blocking read()/select()) even looks very nice and > convenient, in all fairness. But I would like to ask you: Is this > feature used rarely or frequently by other libraries/tools/etc.? In > other words, is the feature "obscure" or "crucial" part of RTC kernel > support? Or, something in between? > Nobody is actually using the return value. > - Does MC146818 support this feature? > This feature is implemented in the RTC core so it is supported by all RTCs that have alarms. Internally, the value is an unsigned long and it is casted properly by put_user in rtc_dev_read: https://elixir.bootlin.com/linux/v5.4/source/drivers/rtc/dev.c#L178 -- Alexandre Belloni, Bootlin Embedded Linux and Kernel engineering https://bootlin.com