Re: Bug in arch/i386/lib/delay.c file, delay_loop function

From: Martin Mares
Date: Sun Jun 01 2008 - 13:36:16 EST


Hi!

> when trying to understand how Bogomips are implemented I have found
> bug in arch/i386/lib/delay.c file, delay_loop function
[...]

> The function fails for loops > 2^31+1. It because SF is set when dec
> returns numbers > 2^31
>
> The fix is to use jnz instruction instead of jns (and add one decl
> instruction to the end to have exactly the same number of loops as in
> original version):

It is a long time since I have hacked that file, but you should definitely
make sure that the function is never called with a zero argument. In such
case, the original version made just a single pass, but your version
makes 2^32 of them.

Have a nice fortnight
--
Martin `MJ' Mares <mj@xxxxxx> http://mj.ucw.cz/
Faculty of Math and Physics, Charles University, Prague, Czech Rep., Earth
Homo homini lupus, frater fratri lupior, bohemus bohemo lupissimus.
--
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/