login
Login
/
Register
Search
Search this site:
Forums
News
Blogs
Features
Site
Home
»
Mailing list archives
»
linux-kernel
»
2008
»
May
»
8
Re: [PATCH] common implementation of iterative div/mod
view
thread
Previous message: [
thread
] [
date
] [
author
]
Next message: [
thread
] [
date
] [
author
]
[view in full thread]
From: Jeremy Fitzhardinge
Subject:
Re: [PATCH] common implementation of iterative div/mod
Date: Thursday, May 8, 2008 - 3:00 pm
Andrew Morton wrote:
quoted text
> On Thu, 08 May 2008 16:16:41 +0100 > Jeremy Fitzhardinge <jeremy@goop.org> wrote: > > >> We have a few instances of the open-coded iterative div/mod loop, used >> when we don't expcet the dividend to be much bigger than the divisor. >>
If you get a chance, could you fix the tpyo.
quoted text
>> Unfortunately modern gcc's have the tendency to strength "reduce" this >> into a full mod operation, which isn't necessarily any faster, and >> even if it were, doesn't exist if gcc implements it in libgcc. >> >> The workaround is to put a dummy asm statement in the loop to prevent >> gcc from performing the transformation. >> >> This patch creates a single implementation of this loop, and uses it >> to replace the open-coded versions I know about. >> > > Fair enough. I'll plan on feeding this into 2.6.26 soon. > > >> #endif /* BITS_PER_LONG == 32 */ >> + >> +/* >> + * Iterative div/mod for use when dividend is not expected to be much >> + * bigger than divisor. >> + */ >> +unsigned iter_div_u64_rem(u64 dividend, u32 divisor, u64 *remainder) >> +{ >> + unsigned ret = 0; >> + >> + while(dividend >= divisor) { >> + /* The following asm() prevents the compiler from >> + optimising this loop into a modulo operation. */ >> + asm("" : "+rm"(dividend)); >> + >> + dividend -= divisor; >> + ret++; >> + } >> + >> + *remainder = dividend; >> + >> + return ret; >> +} >> +EXPORT_SYMBOL(iter_div_u64_rem); >> >> > > I think it would be better to do s/unsigned/u32/ here. It's cosmetic, but > all this sort of code is pretty formal about the sizes of the types which > it uses, and it sure needs to be. >
OK. J --
unsubscribe notice
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to
majordomo@vger.kernel.org
More majordomo info at
http://vger.kernel.org/majordomo-info.html
Please read the FAQ at
http://www.tux.org/lkml/
Previous message: [
thread
] [
date
] [
author
]
Next message: [
thread
] [
date
] [
author
]
Messages in current thread:
Re: undefined reference to __udivdi3 (gcc-4.3)
, Robert Hancock
, (Sun May 4, 10:35 am)
Re: undefined reference to __udivdi3 (gcc-4.3)
, Segher Boessenkool
, (Sun May 4, 3:19 pm)
Re: undefined reference to __udivdi3 (gcc-4.3)
, Jeremy Fitzhardinge
, (Wed May 7, 2:29 am)
[PATCH] common implementation of iterative div/mod
, Jeremy Fitzhardinge
, (Thu May 8, 8:16 am)
Re: [PATCH] common implementation of iterative div/mod
, Andrew Morton
, (Thu May 8, 1:26 pm)
Re: [PATCH] common implementation of iterative div/mod
, Segher Boessenkool
, (Thu May 8, 1:52 pm)
Re: [PATCH] common implementation of iterative div/mod
, Jeremy Fitzhardinge
, (Thu May 8, 2:57 pm)
Re: [PATCH] common implementation of iterative div/mod
, Jeremy Fitzhardinge
, (Thu May 8, 3:00 pm)
Re: [PATCH] common implementation of iterative div/mod
, Christian Kujau
, (Fri May 9, 4:45 am)
Re: [PATCH] common implementation of iterative div/mod
, Andrew Morton
, (Tue May 13, 11:46 pm)
Re: [PATCH] common implementation of iterative div/mod
, Jeremy Fitzhardinge
, (Wed May 14, 12:33 am)
Re: [PATCH] common implementation of iterative div/mod
, Andi Kleen
, (Wed May 14, 1:33 am)
Re: [PATCH] common implementation of iterative div/mod
, Jeremy Fitzhardinge
, (Wed May 14, 2:55 am)
Re: [PATCH] common implementation of iterative div/mod
, Andi Kleen
, (Wed May 14, 3:50 am)
Re: [PATCH] common implementation of iterative div/mod
, Jeremy Fitzhardinge
, (Wed May 14, 3:52 am)
Re: [PATCH] common implementation of iterative div/mod
, Andi Kleen
, (Wed May 14, 4:21 am)
Re: [PATCH] common implementation of iterative div/mod
, Jeremy Fitzhardinge
, (Wed May 14, 5:58 am)
Navigation
Mailing list archives
Recent posts
Popular discussions
linux-kernel
:
Fortier,Vincent [Montreal]
2.6.21.5 june 30th to july 1st date hang?
Jeff Dike
[ PATCH 2/6 ] UML - Formatting fixes around os_{read_write}_file callers
Liam Girdwood
[PATCH 07/13] regulator: regulator test harness
Oleg Nesterov
Re: Getting the new RxRPC patches upstream
Stefan Seyfried
Re: 2.6.19-rc5: grub is much slower resuming from suspend-to-disk than in 2.6.18
linux-netdev
:
Arnaud Ebalard
Re: [REGRESSION,BISECTED] MIPv6 support broken by f4f914b58019f0
Jan Engelhardt
Re: [PATCH iptables] extension: add xt_cpu match
Jarek Poplawski
Re: [PATCH] pkt_sched: Destroy gen estimators under rtnl_lock().
Sebastian Andrzej Siewior
[PATCH 8/8] net/emergency: remove locking from reycling pool if emergncy pools are...
David Miller
Re: [PATCH] qlcnic: dont assume NET_IP_ALIGN is 2
git
:
Jakub Narebski
Re: git on MacOSX and files with decomposed utf-8 file names
Brandon Casey
Re: Thunderbird and patches (was Re: [PATCH v2] Enable setting attach as the def...
Christian Couder
[PATCH 1/3] rev-parse: add test script for "--verify"
Ramkumar Ramachandra
Re: [GSoC update] git-remote-svn: The final one
Junio C Hamano
Re: git-rm isn't the inverse action of git-add
openbsd-misc
:
Joachim Schipper
Re: UVC Webcams
Florin Andrei
SOLVED [was: firewall is very slow, something's wrong]
Todd Alan Smith
Re: Microsoft gets the Most Secure Operating Systems award
Neal Hogan
Re: Need Advice: Thinkpad T60 or T61?
Sam Fourman Jr.
Re: Real men don't attack straw men
git-commits-head
:
Linux Kernel Mailing List
ACPI: Disable ARB_DISABLE on platforms where it is not needed
Linux Kernel Mailing List
m68knommu: add read_barrier_depends() and irqs_disabled_flags()
Linux Kernel Mailing List
[MTD] Add mtd panic_write function pointer
Linux Kernel Mailing List
[ARM] pxa: remove duplicate select statements from Kconfig
Linux Kernel Mailing List
mlx4_core: Don't read reserved fields in mlx4_QUERY_ADAPTER()
Colocation donated by:
Syndicate