Commit 7cff3f16 authored by Huacai Chen's avatar Huacai Chen Committed by Paul Burton

MIPS: Loongson: Add Loongson-3A R3.1 basic support

Loongson-3A R3.1 is the bugfix revision of Loongson-3A R3.

All Loongson-3 CPU family:

Code-name         Brand-name       PRId
Loongson-3A R1    Loongson-3A1000  0x6305
Loongson-3A R2    Loongson-3A2000  0x6308
Loongson-3A R3    Loongson-3A3000  0x6309
Loongson-3A R3.1  Loongson-3A3000  0x630d
Loongson-3B R1    Loongson-3B1000  0x6306
Loongson-3B R2    Loongson-3B1500  0x6307
Signed-off-by: default avatarHuacai Chen <chenhc@lemote.com>
Signed-off-by: default avatarPaul Burton <paul.burton@mips.com>
Patchwork: https://patchwork.linux-mips.org/patch/19263/
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: James Hogan <james.hogan@mips.com>
Cc: linux-mips@linux-mips.org
Cc: Fuxin Zhang <zhangfx@lemote.com>
Cc: Zhangjin Wu <wuzhangjin@gmail.com>
Cc: Huacai Chen <chenhuacai@gmail.com>
parent c6ea7e97
...@@ -225,31 +225,32 @@ ...@@ -225,31 +225,32 @@
* Definitions for 7:0 on legacy processors * Definitions for 7:0 on legacy processors
*/ */
#define PRID_REV_TX4927 0x0022 #define PRID_REV_TX4927 0x0022
#define PRID_REV_TX4937 0x0030 #define PRID_REV_TX4937 0x0030
#define PRID_REV_R4400 0x0040 #define PRID_REV_R4400 0x0040
#define PRID_REV_R3000A 0x0030 #define PRID_REV_R3000A 0x0030
#define PRID_REV_R3000 0x0020 #define PRID_REV_R3000 0x0020
#define PRID_REV_R2000A 0x0010 #define PRID_REV_R2000A 0x0010
#define PRID_REV_TX3912 0x0010 #define PRID_REV_TX3912 0x0010
#define PRID_REV_TX3922 0x0030 #define PRID_REV_TX3922 0x0030
#define PRID_REV_TX3927 0x0040 #define PRID_REV_TX3927 0x0040
#define PRID_REV_VR4111 0x0050 #define PRID_REV_VR4111 0x0050
#define PRID_REV_VR4181 0x0050 /* Same as VR4111 */ #define PRID_REV_VR4181 0x0050 /* Same as VR4111 */
#define PRID_REV_VR4121 0x0060 #define PRID_REV_VR4121 0x0060
#define PRID_REV_VR4122 0x0070 #define PRID_REV_VR4122 0x0070
#define PRID_REV_VR4181A 0x0070 /* Same as VR4122 */ #define PRID_REV_VR4181A 0x0070 /* Same as VR4122 */
#define PRID_REV_VR4130 0x0080 #define PRID_REV_VR4130 0x0080
#define PRID_REV_34K_V1_0_2 0x0022 #define PRID_REV_34K_V1_0_2 0x0022
#define PRID_REV_LOONGSON1B 0x0020 #define PRID_REV_LOONGSON1B 0x0020
#define PRID_REV_LOONGSON1C 0x0020 /* Same as Loongson-1B */ #define PRID_REV_LOONGSON1C 0x0020 /* Same as Loongson-1B */
#define PRID_REV_LOONGSON2E 0x0002 #define PRID_REV_LOONGSON2E 0x0002
#define PRID_REV_LOONGSON2F 0x0003 #define PRID_REV_LOONGSON2F 0x0003
#define PRID_REV_LOONGSON3A_R1 0x0005 #define PRID_REV_LOONGSON3A_R1 0x0005
#define PRID_REV_LOONGSON3B_R1 0x0006 #define PRID_REV_LOONGSON3B_R1 0x0006
#define PRID_REV_LOONGSON3B_R2 0x0007 #define PRID_REV_LOONGSON3B_R2 0x0007
#define PRID_REV_LOONGSON3A_R2 0x0008 #define PRID_REV_LOONGSON3A_R2 0x0008
#define PRID_REV_LOONGSON3A_R3 0x0009 #define PRID_REV_LOONGSON3A_R3_0 0x0009
#define PRID_REV_LOONGSON3A_R3_1 0x000d
/* /*
* Older processors used to encode processor version and revision in two * Older processors used to encode processor version and revision in two
......
...@@ -1849,7 +1849,8 @@ static inline void cpu_probe_loongson(struct cpuinfo_mips *c, unsigned int cpu) ...@@ -1849,7 +1849,8 @@ static inline void cpu_probe_loongson(struct cpuinfo_mips *c, unsigned int cpu)
set_elf_platform(cpu, "loongson3a"); set_elf_platform(cpu, "loongson3a");
set_isa(c, MIPS_CPU_ISA_M64R2); set_isa(c, MIPS_CPU_ISA_M64R2);
break; break;
case PRID_REV_LOONGSON3A_R3: case PRID_REV_LOONGSON3A_R3_0:
case PRID_REV_LOONGSON3A_R3_1:
c->cputype = CPU_LOONGSON3; c->cputype = CPU_LOONGSON3;
__cpu_name[cpu] = "ICT Loongson-3"; __cpu_name[cpu] = "ICT Loongson-3";
set_elf_platform(cpu, "loongson3a"); set_elf_platform(cpu, "loongson3a");
......
...@@ -198,7 +198,8 @@ void __init prom_init_env(void) ...@@ -198,7 +198,8 @@ void __init prom_init_env(void)
break; break;
case PRID_REV_LOONGSON3A_R1: case PRID_REV_LOONGSON3A_R1:
case PRID_REV_LOONGSON3A_R2: case PRID_REV_LOONGSON3A_R2:
case PRID_REV_LOONGSON3A_R3: case PRID_REV_LOONGSON3A_R3_0:
case PRID_REV_LOONGSON3A_R3_1:
cpu_clock_freq = 900000000; cpu_clock_freq = 900000000;
break; break;
case PRID_REV_LOONGSON3B_R1: case PRID_REV_LOONGSON3B_R1:
......
...@@ -682,7 +682,8 @@ void play_dead(void) ...@@ -682,7 +682,8 @@ void play_dead(void)
(void *)CKSEG1ADDR((unsigned long)loongson3a_r1_play_dead); (void *)CKSEG1ADDR((unsigned long)loongson3a_r1_play_dead);
break; break;
case PRID_REV_LOONGSON3A_R2: case PRID_REV_LOONGSON3A_R2:
case PRID_REV_LOONGSON3A_R3: case PRID_REV_LOONGSON3A_R3_0:
case PRID_REV_LOONGSON3A_R3_1:
play_dead_at_ckseg1 = play_dead_at_ckseg1 =
(void *)CKSEG1ADDR((unsigned long)loongson3a_r2r3_play_dead); (void *)CKSEG1ADDR((unsigned long)loongson3a_r2r3_play_dead);
break; break;
......
...@@ -30,7 +30,8 @@ int loongson3_cpu_temp(int cpu) ...@@ -30,7 +30,8 @@ int loongson3_cpu_temp(int cpu)
case PRID_REV_LOONGSON3B_R2: case PRID_REV_LOONGSON3B_R2:
reg = ((reg >> 8) & 0xff) - 100; reg = ((reg >> 8) & 0xff) - 100;
break; break;
case PRID_REV_LOONGSON3A_R3: case PRID_REV_LOONGSON3A_R3_0:
case PRID_REV_LOONGSON3A_R3_1:
reg = (reg & 0xffff)*731/0x4000 - 273; reg = (reg & 0xffff)*731/0x4000 - 273;
break; break;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment