remove div_long_long_rem
x86 is the only arch right now, which provides an optimized for div_long_long_rem and it has the downside that one has to be very careful that the divide doesn't overflow. The API is a little akward, as the arguments for the unsigned divide are signed. The signed version also doesn't handle a negative divisor and produces worse code on 64bit archs. There is little incentive to keep this API alive, so this converts the few users to the new API. Signed-off-by: Roman Zippel <zippel@linux-m68k.org> Cc: Ralf Baechle <ralf@linux-mips.org> Cc: Ingo Molnar <mingo@elte.hu> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: john stultz <johnstul@us.ibm.com> Cc: Christoph Lameter <clameter@sgi.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
committed by
Linus Torvalds
parent
6f6d6a1a6a
commit
f8bd2258e2
@@ -234,7 +234,7 @@ static inline void notify_cmos_timer(void) { }
|
||||
*/
|
||||
int do_adjtimex(struct timex *txc)
|
||||
{
|
||||
long mtemp, save_adjust, rem;
|
||||
long mtemp, save_adjust;
|
||||
s64 freq_adj;
|
||||
int result;
|
||||
|
||||
@@ -345,9 +345,7 @@ int do_adjtimex(struct timex *txc)
|
||||
freq_adj += time_freq;
|
||||
freq_adj = min(freq_adj, (s64)MAXFREQ_NSEC);
|
||||
time_freq = max(freq_adj, (s64)-MAXFREQ_NSEC);
|
||||
time_offset = div_long_long_rem_signed(time_offset,
|
||||
NTP_INTERVAL_FREQ,
|
||||
&rem);
|
||||
time_offset = div_s64(time_offset, NTP_INTERVAL_FREQ);
|
||||
time_offset <<= SHIFT_UPDATE;
|
||||
} /* STA_PLL */
|
||||
} /* txc->modes & ADJ_OFFSET */
|
||||
|
Reference in New Issue
Block a user