From: Daniel Axtens <dja@axtens.net>
To: Mathieu Malaterre <malat@debian.org>, Jakub Drnec <jaydee@email.cz>
Cc: linuxppc-dev <linuxppc-dev@lists.ozlabs.org>
Subject: Re: PROBLEM: monotonic clock going backwards on ppc64
Date: Thu, 28 Feb 2019 22:17:46 +1100 [thread overview]
Message-ID: <87va1417s5.fsf@dja-thinkpad.axtens.net> (raw)
In-Reply-To: <CA+7wUswyzc5SGjjb+WS4QpopyL0qoGYj0WF1jNaTfsC5ZsMpdw@mail.gmail.com>
Mathieu Malaterre <malat@debian.org> writes:
> On Tue, Feb 26, 2019 at 9:36 PM Jakub Drnec <jaydee@email.cz> wrote:
>>
>> Hi all,
>>
>> I think I observed a potential problem, is this the correct place to report it? (CC me, not on list)
>>
>> [1.] One line summary: monotonic clock can be made to decrease on ppc64
>> [2.] Full description:
>> Setting the realtime clock can sometimes make the monotonic clock go back by over a hundred years.
>> Decreasing the realtime clock across the y2k38 threshold is one reliable way to reproduce.
>> Allegedly this can also happen just by running ntpd, I have not managed to reproduce that other
>> than booting with rtc at >2038 and then running ntp.
>
> Isn't it the expected behavior. Here is what I see for powermac:
>
> $ git show 22db552b50fa
> ...
> This changes the logic to cast to an unsigned 32-bit number first for
> the Macintosh time and then convert that to the Unix time, which then
> gives us a time in the documented 1904..2040 year range. I decided not
> to use the longer 1970..2106 range that other drivers use, for
> consistency with the literal interpretation of the register, but that
> could be easily changed if we decide we want to support any Mac after
> 2040.
> ...
>
My interpretation of that commit is that it relates to the kernel
reading the hardware RTC on a powermac, but this issue relates to
userspace fetching the time from the vDSO. I'm also not running on a
powermac, so my hardware should be able to deal with times > 2040...
Regards,
Daniel
>> When this happens, anything with timers (e.g. openjdk) breaks rather badly.
>>
>> [3.] Keywords: gettimeofday, ppc64, vdso
>> [4.] Kernel information
>> [4.1.] Kernel version: any (tested on 4.19)
>> [4.2.] Kernel .config file: any
>> [5.] Most recent kernel version which did not have the bug: not a regression
>> [6.] Output of Oops..: not applicable
>> [7.] Example program which triggers the problem
>> --- testcase.c
>> #include <stdio.h>
>> #include <time.h>
>> #include <stdlib.h>
>> #include <unistd.h>
>>
>> long get_time() {
>> struct timespec tp;
>> if (clock_gettime(CLOCK_MONOTONIC, &tp) != 0) {
>> perror("clock_gettime failed");
>> exit(1);
>> }
>> long result = tp.tv_sec + tp.tv_nsec / 1000000000;
>> return result;
>> }
>>
>> int main() {
>> printf("monitoring monotonic clock...\n");
>> long last = get_time();
>> while(1) {
>> long now = get_time();
>> if (now < last) {
>> printf("clock went backwards by %ld seconds!\n",
>> last - now);
>> }
>> last = now;
>> sleep(1);
>> }
>> return 0;
>> }
>> ---
>> when running
>> # date -s 2040-1-1
>> # date -s 2037-1-1
>> program outputs: clock went backwards by 4294967295 seconds!
>>
>> [8.] Environment: any ppc64, currently reproducing on qemu-system-ppc64le running debian unstable
>> [X.] Other notes, patches, fixes, workarounds:
>> The problem seems to be in vDSO code in arch/powerpc/kernel/vdso64/gettimeofday.S.
>> (possibly because some values used in the calculation are only 32 bit?)
>> Slightly silly workaround:
>> nuke the "cmpwi cr1,r3,CLOCK_MONOTONIC" in __kernel_clock_gettime
>> Now it always goes through the syscall fallback which does not have the same problem.
>>
>> Regards,
>> Jakub Drnec
next prev parent reply other threads:[~2019-02-28 11:19 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-02-26 16:13 PROBLEM: monotonic clock going backwards on ppc64 Jakub Drnec
2019-02-28 6:48 ` Daniel Axtens
2019-02-28 7:04 ` Mathieu Malaterre
2019-02-28 11:17 ` Daniel Axtens [this message]
2019-03-01 13:33 ` Jakub Drnec
2019-03-01 13:24 ` Michael Ellerman
2019-03-01 23:59 ` Thomas Gleixner
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87va1417s5.fsf@dja-thinkpad.axtens.net \
--to=dja@axtens.net \
--cc=jaydee@email.cz \
--cc=linuxppc-dev@lists.ozlabs.org \
--cc=malat@debian.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox