Hi Stephen, On 11/07/2013 02:20 PM, Stephen Boyd wrote: > If we're running on a v7 ARM CPU, detect if the CPU supports the > sdiv/udiv instructions and replace the signed and unsigned > division library functions with an sdiv/udiv instruction.
[...] > +++ b/arch/arm/lib/div-v7.c > @@ -0,0 +1,58 @@ > +/* Copyright (c) 2013, The Linux Foundation. All rights reserved. > + * > + * This program is free software; you can redistribute it and/or modify > + * it under the terms of the GNU General Public License version 2 and > + * only version 2 as published by the Free Software Foundation. > + * > + * This program is distributed in the hope that it will be useful, > + * but WITHOUT ANY WARRANTY; without even the implied warranty of > + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the > + * GNU General Public License for more details. > + */ > + > +#include <linux/static_key.h> > + > +extern int ___aeabi_idiv(int, int); > +extern unsigned ___aeabi_uidiv(int, int); Why are the input parameters signed? > +extern struct static_key cpu_has_idiv; > + > +int __aeabi_idiv(int numerator, int denominator) > +{ > + if (static_key_false(&cpu_has_idiv)) { > + int ret; > + > + asm volatile ( > + ".arch_extension idiv\n" > + "sdiv %0, %1, %2" > + : "=&r" (ret) > + : "r" (numerator), "r" (denominator)); > + > + return ret; > + } > + > + return ___aeabi_idiv(numerator, denominator); > +} > + > +int __divsi3(int numerator, int denominator) > + __attribute__((alias("__aeabi_idiv"))); > + > +unsigned __aeabi_uidiv(int numerator, int denominator) Unsigned inputs? > +{ > + if (static_key_false(&cpu_has_idiv)) { > + int ret; > + > + asm volatile ( > + ".arch_extension idiv\n" > + "udiv %0, %1, %2" > + : "=&r" (ret) > + : "r" (numerator), "r" (denominator)); > + > + return ret; > + } > + > + return ___aeabi_uidiv(numerator, denominator); > +} > + > +unsigned __udivsi3(int numerator, int denominator) > + __attribute__((alias("__aeabi_uidiv"))); Unsigned inputs? [...] Thanks, Christopher -- Employee of Qualcomm Innovation Center, Inc. Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, hosted by the Linux Foundation. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/