summaryrefslogtreecommitdiffstats
path: root/arch/mips
diff options
context:
space:
mode:
Diffstat (limited to 'arch/mips')
-rw-r--r--arch/mips/mach-mtmips/ddr_cal.c28
1 files changed, 10 insertions, 18 deletions
diff --git a/arch/mips/mach-mtmips/ddr_cal.c b/arch/mips/mach-mtmips/ddr_cal.c
index 80a058d693..71a53c3c9c 100644
--- a/arch/mips/mach-mtmips/ddr_cal.c
+++ b/arch/mips/mach-mtmips/ddr_cal.c
@@ -74,39 +74,31 @@ static inline bool dqs_test_error(void __iomem *memc, u32 memsize, u32 dqsval,
static inline int dqs_find_max(void __iomem *memc, u32 memsize, int initval,
int maxval, int shift, u32 regval)
{
- int fieldval = initval;
+ int fieldval;
u32 dqsval;
- do {
+ for (fieldval = initval; fieldval <= maxval; fieldval++) {
dqsval = regval | (fieldval << shift);
-
if (dqs_test_error(memc, memsize, dqsval, 3))
- break;
-
- fieldval++;
- } while (fieldval <= maxval);
+ return max(fieldval - 1, initval);
+ }
- return fieldval;
+ return maxval;
}
static inline int dqs_find_min(void __iomem *memc, u32 memsize, int initval,
int minval, int shift, u32 regval)
{
- int fieldval = initval;
+ int fieldval;
u32 dqsval;
- while (fieldval > minval) {
+ for (fieldval = initval; fieldval >= minval; fieldval--) {
dqsval = regval | (fieldval << shift);
-
- if (dqs_test_error(memc, memsize, dqsval, 1)) {
- fieldval++;
- break;
- }
-
- fieldval--;
+ if (dqs_test_error(memc, memsize, dqsval, 1))
+ return min(fieldval + 1, initval);
}
- return fieldval;
+ return minval;
}
void ddr_calibrate(void __iomem *memc, u32 memsize, u32 bw)