Blackfin arch: cplb mananger: use a do...while loop rather than a for loop

use a do...while loop rather than a for loop to get slightly better
optimization and to avoid gcc "may be used uninitialized" warnings ...
we know that the [id]cplb_nr_bounds variables will never be 0, so this
is OK

Signed-off-by: Mike Frysinger <vapier.adi@gmail.com>
Signed-off-by: Bryan Wu <cooloney@kernel.org>
This commit is contained in:
Mike Frysinger 2009-02-04 16:49:45 +08:00 committed by Bryan Wu
parent bf324cb81a
commit d04dfc4c0e

View file

@ -163,12 +163,14 @@ MGR_ATTR static int icplb_miss(int cpu)
nr_icplb_supv_miss[cpu]++; nr_icplb_supv_miss[cpu]++;
base = 0; base = 0;
for (idx = 0; idx < icplb_nr_bounds; idx++) { idx = 0;
do {
eaddr = icplb_bounds[idx].eaddr; eaddr = icplb_bounds[idx].eaddr;
if (addr < eaddr) if (addr < eaddr)
break; break;
base = eaddr; base = eaddr;
} } while (++idx < icplb_nr_bounds);
if (unlikely(idx == icplb_nr_bounds)) if (unlikely(idx == icplb_nr_bounds))
return CPLB_NO_ADDR_MATCH; return CPLB_NO_ADDR_MATCH;
@ -208,12 +210,14 @@ MGR_ATTR static int dcplb_miss(int cpu)
nr_dcplb_supv_miss[cpu]++; nr_dcplb_supv_miss[cpu]++;
base = 0; base = 0;
for (idx = 0; idx < dcplb_nr_bounds; idx++) { idx = 0;
do {
eaddr = dcplb_bounds[idx].eaddr; eaddr = dcplb_bounds[idx].eaddr;
if (addr < eaddr) if (addr < eaddr)
break; break;
base = eaddr; base = eaddr;
} } while (++idx < dcplb_nr_bounds);
if (unlikely(idx == dcplb_nr_bounds)) if (unlikely(idx == dcplb_nr_bounds))
return CPLB_NO_ADDR_MATCH; return CPLB_NO_ADDR_MATCH;