Re: [PATCH] __div64_32: implement division by multiplication for 32-bit arches
From: Vineet Gupta
Date: Wed Nov 04 2015 - 22:14:03 EST
On Thursday 05 November 2015 05:18 AM, Nicolas Pitre wrote:
> On Wed, 4 Nov 2015, Nicolas Pitre wrote:
>
>> On Fri, 30 Oct 2015, Måns Rullgård wrote:
>>
>>> Nicolas Pitre <nicolas.pitre@xxxxxxxxxx> writes:
>>>
>>>> I'm going to do it anyway given that I already have it for ARM. It'll
>>>> be opt-in, so if your arch doesn't provide it then the current C
>>>> implementation will be used by default.
>>> Great. I'll try it out on MIPS once you've posted the patch.
>> You should have seen the patches by now.
>>
>> I've put them along with a bunch of do_div() usage fixes here:
>>
>> http://git.linaro.org/people/nicolas.pitre/linux.git
> More precisely:
>
> http://git.linaro.org/people/nicolas.pitre/linux.git div64
Hi Nico,
While we are current on the topic I was wondering about another optimization in
this area.
The slowpath __div64_32() generates both quotient and remainder. The more general
use case in kernel only cares about quotient.
git grep "\sdo_div(" | wc -l
841
git grep "=\sdo_div(" | wc -l
116
Is it possible to optimize the code, if remainder was *not* needed explicitly. I
understand that the hand divide will still need some sort of running tally of
remainder but can the code be any better in this case. That way we can introduce
another API do_div_norem() and start proliferating it for the cases where
remainder is not used.
Thx,
-Vineet
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/