sh: Handle SH-4 FPU variants with broken CVR values.
authorPaul Mundt <lethal@linux-sh.org>
Tue, 19 Jan 2010 18:38:56 +0000 (03:38 +0900)
committerPaul Mundt <lethal@linux-sh.org>
Tue, 19 Jan 2010 18:38:56 +0000 (03:38 +0900)
Usually we can look to the CVR to work out whether we have an FPU or not.
Unfortunately not all parts comply with this, so just set the flag
manually for all SH-4 parts and clear it on the only SH-4 that doesn't
have one (SH4-501).

Signed-off-by: Paul Mundt <lethal@linux-sh.org>
arch/sh/kernel/cpu/sh4/probe.c

index 21371f8cf010676409689f223af36835fda10eb0..cc02b3145cca8012ec7d34e2e804fa243b667aed 100644 (file)
@@ -71,11 +71,11 @@ int __init detect_cpu_and_cache_system(void)
                boot_cpu_data.dcache.ways = 4;
        } else {
                /* And some SH-4 defaults.. */
-               boot_cpu_data.flags |= CPU_HAS_PTEA;
+               boot_cpu_data.flags |= CPU_HAS_PTEA | CPU_HAS_FPU;
                boot_cpu_data.family = CPU_FAMILY_SH4;
        }
 
-       /* FPU detection works for everyone */
+       /* FPU detection works for almost everyone */
        if ((cvr & 0x20000000))
                boot_cpu_data.flags |= CPU_HAS_FPU;
 
@@ -161,6 +161,7 @@ int __init detect_cpu_and_cache_system(void)
                break;
        case 0x700:
                boot_cpu_data.type = CPU_SH4_501;
+               boot_cpu_data.flags &= ~CPU_HAS_FPU;
                boot_cpu_data.icache.ways = 2;
                boot_cpu_data.dcache.ways = 2;
                break;