From: zhangfx <zhangfx@lemote.com>
To: John Stultz <johnstul@us.ibm.com>
Cc: "Chen Jie" <chenj@lemote.com>,
"Yong Zhang" <yong.zhang0@gmail.com>,
linux-mips@linux-mips.org, LKML <linux-kernel@vger.kernel.org>,
tglx@linutronix.de, yanhua <yanh@lemote.com>,
项宇 <xiangy@lemote.com>, 孙海勇 <sunhy@lemote.com>
Subject: Re: [MIPS]clocks_calc_mult_shift() may gen a too big mult value
Date: Mon, 31 Oct 2011 21:59:11 +0800 [thread overview]
Message-ID: <4EAEA9AF.1060904@lemote.com> (raw)
In-Reply-To: <1320066197.2266.11.camel@js-netbook>
Dear Sirs,
>> Thanks for the suggestion. And sorry for I didn't notice the upstream
>> code has already hooked to clocksource_register_hz() in csrc-r4k.c
>> (We're using r4000 clock source)
>>
>> I'm afraid this still doesn't fix my case. Through
>> clocksource_register_hz()->__clocksource_register_scale()->__clocksource_updatefreq_scale,
>> I got a calculated maxsec = (0xffffffff - (0xffffffff>>5))/250000500 =
>> 16 # assume mips_hpt_frequency=250000500
>>
>> With this maxsec, I got a mult of 0xffffde72, still too big.
> Hrmm. Yong Zang is right to suggest clocksource_register_hz(), as the
> intention of that code is to try to avoid these sorts of issues.
>
> What is the corresponding shift value you're getting for the value
> above?
>
> Could you annotate clocks_calc_mult_shift() a little bit to see where
> things might be going wrong?
Let me give some real world data:
in one machine with 500MHz freq,
the calculated freq = 500084016, and clocks_calc_mult_shift() give
mult = 4294245725
shift = 30
but in the 1785th call to update_wall_time, due to error correction
algorithm, the mult become 4293964632,
in next update_wall_time, the ntp_error is 0x301c93b7927c, which lead to
an adj of 20, then mult is overflow:
mult = 4293964632 + (1<<20) = 45912
with this mult, if anyone call timekeeping_get_ns or others using mult,
the time concept will be extremely wrong, so some sleep will
(almost)never return => virtually hang
We are not abosulately sure that the error source is normal, but anyway
it is a possible for the code to overflow, and it will cause hang.
For this case, the timekeeping_bigadjust should be able to control adj
to a maximum of around 20 with the lookahead for any error. So if the
mult is chosen at shift = 29, then mult becomes 4294245725/2, it will
not be possible to be overflowed.
In short, choosing a mult close to 2^32 is dangerous. But I don't know
what's the best way to avoid it for general cases, because I don't know
how big error can be and the adj can be for different systems.
Regards
Yours
Fuxin Zhang
>
> thanks
> -john
>
>
next prev parent reply other threads:[~2011-10-31 13:59 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-10-31 9:00 [MIPS]clocks_calc_mult_shift() may gen a too big mult value Chen Jie
2011-10-31 9:20 ` Yong Zhang
2011-10-31 10:48 ` Chen Jie
2011-10-31 13:03 ` John Stultz
2011-10-31 13:59 ` zhangfx [this message]
2011-10-31 18:12 ` John Stultz
2011-10-31 18:30 ` David Daney
2011-10-31 19:51 ` John Stultz
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=4EAEA9AF.1060904@lemote.com \
--to=zhangfx@lemote.com \
--cc=chenj@lemote.com \
--cc=johnstul@us.ibm.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mips@linux-mips.org \
--cc=sunhy@lemote.com \
--cc=tglx@linutronix.de \
--cc=xiangy@lemote.com \
--cc=yanh@lemote.com \
--cc=yong.zhang0@gmail.com \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.