diff options
author | Trent Piepho <tpiepho@freescale.com> | 2008-09-22 19:03:56 +0200 |
---|---|---|
committer | Jeff Garzik <jgarzik@redhat.com> | 2008-09-25 02:48:56 +0200 |
commit | baac03d9bb7b8aa3c33a2dbf5f459ea6ce8abaf4 (patch) | |
tree | 018e47dc43acfff4a63d3974c981340ba729cac2 /ipc/ipcns_notifier.c | |
parent | e1000e: remove failed request for sw/fw/hw flag (diff) | |
download | linux-baac03d9bb7b8aa3c33a2dbf5f459ea6ce8abaf4.tar.xz linux-baac03d9bb7b8aa3c33a2dbf5f459ea6ce8abaf4.zip |
gianfar: Fix error in mdio reset timeout
The loop with the timeout used "while (... && timeout--)", which means
than when the timeout occurs, "timeout" will be -1 after the loop has
exited. The code that checks if the looped exited because of a timeout
used "if (timeout <= 0)". Seems ok, except timeout is unsigned, and
(unsigned)-1 isn't less than zero!
Using "--timeout" in the loop fixes this problem, as now "timeout" will be
0 when the loop times out.
This also fixes a bug in the existing code, where it will erroneously think
a timeout occurred if the condition the loop was waiting for is satisfied
on the final iteration before a timeout.
Signed-off-by: Trent Piepho <tpiepho@freescale.com>
Acked-by: Andy Fleming <afleming@freescale.com>
Signed-off-by: Jeff Garzik <jgarzik@redhat.com>
Diffstat (limited to 'ipc/ipcns_notifier.c')
0 files changed, 0 insertions, 0 deletions