prompt "CPU type"
        default CPU_R4X00
 
-config CPU_LOONGSON3
-       bool "Loongson 3 CPU"
-       depends on SYS_HAS_CPU_LOONGSON3
+config CPU_LOONGSON64
+       bool "Loongson GSx64 CPU"
+       depends on SYS_HAS_CPU_LOONGSON64
        select ARCH_HAS_PHYS_TO_DMA
        select CPU_SUPPORTS_64BIT_KERNEL
        select CPU_SUPPORTS_HIGHMEM
        select GPIOLIB
        select SWIOTLB
        help
-               The Loongson 3 processor implements the MIPS64R2 instruction
-               set with many extensions.
+               The Loongson GSx64 series of processor cores implements the
+               MIPS64R2 instruction set with many extensions.
 
-config LOONGSON3_ENHANCEMENT
-       bool "New Loongson 3 CPU Enhancements"
+config LOONGSON64_ENHANCEMENT
+       bool "New Loongson GSx64E CPU Enhancements"
        default n
        select CPU_MIPSR2
        select CPU_HAS_PREFETCH
-       depends on CPU_LOONGSON3
+       depends on CPU_LOONGSON64
        help
-         New Loongson 3 CPU (since Loongson-3A R2, as opposed to Loongson-3A
+         New Loongson GSx64E cores (since Loongson-3A R2, as opposed to Loongson-3A
          R1, Loongson-3B R1 and Loongson-3B R2) has many enhancements, such as
-         FTLB, L1-VCache, EI/DI/Wait/Prefetch instruction, DSP/DSPv2 ASE, User
+         FTLB, L1-VCache, EI/DI/Wait/Prefetch instruction, DSP/DSPr2 ASE, User
          Local register, Read-Inhibit/Execute-Inhibit, SFB (Store Fill Buffer),
          Fast TLB refill support, etc.
 
 config CPU_LOONGSON3_WORKAROUNDS
        bool "Old Loongson 3 LLSC Workarounds"
        default y if SMP
-       depends on CPU_LOONGSON3
+       depends on CPU_LOONGSON64
        help
          Loongson 3 processors have the llsc issues which require workarounds.
          Without workarounds the system may hang unexpectedly.
 config CPU_LOONGSON2E
        bool "Loongson 2E"
        depends on SYS_HAS_CPU_LOONGSON2E
-       select CPU_LOONGSON2
+       select CPU_LOONGSON2EF
        help
          The Loongson 2E processor implements the MIPS III instruction set
          with many extensions.
 config CPU_LOONGSON2F
        bool "Loongson 2F"
        depends on SYS_HAS_CPU_LOONGSON2F
-       select CPU_LOONGSON2
+       select CPU_LOONGSON2EF
        select GPIOLIB
        help
          The Loongson 2F processor implements the MIPS III instruction set
        bool
        select SYS_SUPPORTS_ZBOOT
 
-config CPU_LOONGSON2
+config CPU_LOONGSON2EF
        bool
        select CPU_SUPPORTS_32BIT_KERNEL
        select CPU_SUPPORTS_64BIT_KERNEL
        select SYS_SUPPORTS_HOTPLUG_CPU
        select CPU_HAS_RIXI
 
-config SYS_HAS_CPU_LOONGSON3
+config SYS_HAS_CPU_LOONGSON64
        bool
        select CPU_SUPPORTS_CPUFREQ
        select CPU_HAS_RIXI
 
 config PAGE_SIZE_4KB
        bool "4kB"
-       depends on !CPU_LOONGSON2 && !CPU_LOONGSON3
+       depends on !CPU_LOONGSON2EF && !CPU_LOONGSON64
        help
          This option select the standard 4kB Linux page size.  On some
          R3000-family processors this is the only available page size.  Using
 
 config ARCH_FLATMEM_ENABLE
        def_bool y
-       depends on !NUMA && !CPU_LOONGSON2
+       depends on !NUMA && !CPU_LOONGSON2EF
 
 config ARCH_SPARSEMEM_ENABLE
        bool
 
 config HW_PERF_EVENTS
        bool "Enable hardware performance counter support for perf events"
-       depends on PERF_EVENTS && !OPROFILE && (CPU_MIPS32 || CPU_MIPS64 || CPU_R10000 || CPU_SB1 || CPU_CAVIUM_OCTEON || CPU_XLP || CPU_LOONGSON3)
+       depends on PERF_EVENTS && !OPROFILE && (CPU_MIPS32 || CPU_MIPS64 || CPU_R10000 || CPU_SB1 || CPU_CAVIUM_OCTEON || CPU_XLP || CPU_LOONGSON64)
        default y
        help
          Enable hardware performance counter support for perf events. If
 
 #define cop2_present           1
 #define cop2_lazy_restore      0
 
-#elif defined(CONFIG_CPU_LOONGSON3)
+#elif defined(CONFIG_CPU_LOONGSON64)
 
 #define cop2_present           1
 #define cop2_lazy_restore      1
 
 static inline int __pure __get_cpu_type(const int cpu_type)
 {
        switch (cpu_type) {
-#if defined(CONFIG_SYS_HAS_CPU_LOONGSON2E) || \
-    defined(CONFIG_SYS_HAS_CPU_LOONGSON2F)
-       case CPU_LOONGSON2:
+#if defined(CONFIG_SYS_HAS_CPU_LOONGSON2EF)
+       case CPU_LOONGSON2EF:
 #endif
 
-#ifdef CONFIG_SYS_HAS_CPU_LOONGSON3
-       case CPU_LOONGSON3:
+#ifdef CONFIG_SYS_HAS_CPU_LOONGSON64
+       case CPU_LOONGSON64:
 #endif
 
 #if defined(CONFIG_SYS_HAS_CPU_LOONGSON1B) || \
 
        /*
         * MIPS64 class processors
         */
-       CPU_5KC, CPU_5KE, CPU_20KC, CPU_25KF, CPU_SB1, CPU_SB1A, CPU_LOONGSON2,
-       CPU_LOONGSON3, CPU_CAVIUM_OCTEON, CPU_CAVIUM_OCTEON_PLUS,
+       CPU_5KC, CPU_5KE, CPU_20KC, CPU_25KF, CPU_SB1, CPU_SB1A, CPU_LOONGSON2EF,
+       CPU_LOONGSON64, CPU_CAVIUM_OCTEON, CPU_CAVIUM_OCTEON_PLUS,
        CPU_CAVIUM_OCTEON2, CPU_CAVIUM_OCTEON3, CPU_XLR, CPU_XLP, CPU_I6500,
 
        CPU_QEMU_GENERIC,
 
  * TLB hazards
  */
 #if (defined(CONFIG_CPU_MIPSR2) || defined(CONFIG_CPU_MIPSR6)) && \
-       !defined(CONFIG_CPU_CAVIUM_OCTEON) && !defined(CONFIG_LOONGSON3_ENHANCEMENT)
+       !defined(CONFIG_CPU_CAVIUM_OCTEON) && !defined(CONFIG_LOONGSON64_ENHANCEMENT)
 
 /*
  * MIPSR2 defines ehb for hazard avoidance
 } while (0)
 
 #elif defined(CONFIG_MIPS_ALCHEMY) || defined(CONFIG_CPU_CAVIUM_OCTEON) || \
-       defined(CONFIG_CPU_LOONGSON2) || defined(CONFIG_LOONGSON3_ENHANCEMENT) || \
+       defined(CONFIG_CPU_LOONGSON2EF) || defined(CONFIG_LOONGSON64_ENHANCEMENT) || \
        defined(CONFIG_CPU_R10000) || defined(CONFIG_CPU_R5500) || defined(CONFIG_CPU_XLR)
 
 /*
 
 #undef __IS_KSEG1
 }
 
-#if defined(CONFIG_CPU_CAVIUM_OCTEON) || defined(CONFIG_CPU_LOONGSON3)
+#if defined(CONFIG_CPU_CAVIUM_OCTEON) || defined(CONFIG_CPU_LOONGSON64)
 #define war_io_reorder_wmb()           wmb()
 #else
 #define war_io_reorder_wmb()           barrier()
 
        "       .set    push                                            \n"
        "       .set    reorder                                         \n"
        "       .set    noat                                            \n"
-#if defined(CONFIG_CPU_LOONGSON3) || defined (CONFIG_CPU_LOONGSON1)
+#if defined(CONFIG_CPU_LOONGSON64) || defined (CONFIG_CPU_LOONGSON1)
        "       mfc0    %[flags], $12                                   \n"
        "       di                                                      \n"
 #else
 
 #define cpu_has_vtag_icache    0
 #define cpu_has_watch          1
 
-#ifdef CONFIG_CPU_LOONGSON3
+#ifdef CONFIG_CPU_LOONGSON64
 #define cpu_has_wsbh           1
 #define cpu_has_ic_fills_f_dc  1
 #define cpu_hwrena_impl_bits   0xc0000000
 
 
 #include <boot_param.h>
 
-#ifdef CONFIG_CPU_LOONGSON3
+#ifdef CONFIG_CPU_LOONGSON64
 
 /* cpu core interrupt numbers */
 #define MIPS_CPU_IRQ_BASE 56
 
  * Override macros used in arch/mips/kernel/head.S.
  */
        .macro  kernel_entry_setup
-#ifdef CONFIG_CPU_LOONGSON3
+#ifdef CONFIG_CPU_LOONGSON64
        .set    push
        .set    mips64
        /* Set LPA on LOONGSON3 config3 */
  * Do SMP slave processor setup.
  */
        .macro  smp_slave_setup
-#ifdef CONFIG_CPU_LOONGSON3
+#ifdef CONFIG_CPU_LOONGSON64
        .set    push
        .set    mips64
        /* Set LPA on LOONGSON3 config3 */
 
 #define LOONGSON_PCICFG_SIZE   0x00000800      /* 2K */
 #define LOONGSON_PCICFG_TOP    (LOONGSON_PCICFG_BASE+LOONGSON_PCICFG_SIZE-1)
 
-#ifdef CONFIG_CPU_LOONGSON3
+#ifdef CONFIG_CPU_LOONGSON64
 #define LOONGSON_PCIIO_BASE    loongson_sysconf.pci_io_base
 #else
 #define LOONGSON_PCIIO_BASE    0x1fd00000
 
 #else  /* loongson2f/32bit & loongson2e */
 
 /* this pci memory space is mapped by pcimap in pci.c */
-#ifdef CONFIG_CPU_LOONGSON3
+#ifdef CONFIG_CPU_LOONGSON64
 #define LOONGSON_PCI_MEM_START 0x40000000UL
 #define LOONGSON_PCI_MEM_END   0x7effffffUL
 #else
 
 #define MODULE_PROC_FAMILY "SB1 "
 #elif defined CONFIG_CPU_LOONGSON1
 #define MODULE_PROC_FAMILY "LOONGSON1 "
-#elif defined CONFIG_CPU_LOONGSON2
-#define MODULE_PROC_FAMILY "LOONGSON2 "
-#elif defined CONFIG_CPU_LOONGSON3
-#define MODULE_PROC_FAMILY "LOONGSON3 "
+#elif defined CONFIG_CPU_LOONGSON2EF
+#define MODULE_PROC_FAMILY "LOONGSON2EF "
+#elif defined CONFIG_CPU_LOONGSON64
+#define MODULE_PROC_FAMILY "LOONGSON64 "
 #elif defined CONFIG_CPU_CAVIUM_OCTEON
 #define MODULE_PROC_FAMILY "OCTEON "
 #elif defined CONFIG_CPU_XLR
 
 #define KSTK_ESP(tsk) (task_pt_regs(tsk)->regs[29])
 #define KSTK_STATUS(tsk) (task_pt_regs(tsk)->cp0_status)
 
-#ifdef CONFIG_CPU_LOONGSON3
+#ifdef CONFIG_CPU_LOONGSON64
 /*
  * Loongson-3's SFB (Store-Fill-Buffer) may buffer writes indefinitely when a
  * tight read loop is executed, because reads take priority over writes & the
 
 static inline void flush_icache_line(unsigned long addr)
 {
        switch (boot_cpu_type()) {
-       case CPU_LOONGSON2:
+       case CPU_LOONGSON2EF:
                cache_op(Hit_Invalidate_I_Loongson2, addr);
                break;
 
 static inline int protected_flush_icache_line(unsigned long addr)
 {
        switch (boot_cpu_type()) {
-       case CPU_LOONGSON2:
+       case CPU_LOONGSON2EF:
                return protected_cache_op(Hit_Invalidate_I_Loongson2, addr);
 
        default:
 
                if (!(flags & FTLB_EN))
                        return 1;
                return 0;
-       case CPU_LOONGSON3:
+       case CPU_LOONGSON64:
                /* Flush ITLB, DTLB, VTLB and FTLB */
                write_c0_diag(LOONGSON_DIAG_ITLB | LOONGSON_DIAG_DTLB |
                              LOONGSON_DIAG_VTLB | LOONGSON_DIAG_FTLB);
        case PRID_IMP_LOONGSON_64C:  /* Loongson-2/3 */
                switch (c->processor_id & PRID_REV_MASK) {
                case PRID_REV_LOONGSON2E:
-                       c->cputype = CPU_LOONGSON2;
+                       c->cputype = CPU_LOONGSON2EF;
                        __cpu_name[cpu] = "ICT Loongson-2";
                        set_elf_platform(cpu, "loongson2e");
                        set_isa(c, MIPS_CPU_ISA_III);
                        c->fpu_msk31 |= FPU_CSR_CONDX;
                        break;
                case PRID_REV_LOONGSON2F:
-                       c->cputype = CPU_LOONGSON2;
+                       c->cputype = CPU_LOONGSON2EF;
                        __cpu_name[cpu] = "ICT Loongson-2";
                        set_elf_platform(cpu, "loongson2f");
                        set_isa(c, MIPS_CPU_ISA_III);
                        c->fpu_msk31 |= FPU_CSR_CONDX;
                        break;
                case PRID_REV_LOONGSON3A_R1:
-                       c->cputype = CPU_LOONGSON3;
+                       c->cputype = CPU_LOONGSON64;
                        __cpu_name[cpu] = "ICT Loongson-3";
                        set_elf_platform(cpu, "loongson3a");
                        set_isa(c, MIPS_CPU_ISA_M64R1);
                        break;
                case PRID_REV_LOONGSON3B_R1:
                case PRID_REV_LOONGSON3B_R2:
-                       c->cputype = CPU_LOONGSON3;
+                       c->cputype = CPU_LOONGSON64;
                        __cpu_name[cpu] = "ICT Loongson-3";
                        set_elf_platform(cpu, "loongson3b");
                        set_isa(c, MIPS_CPU_ISA_M64R1);
                switch (c->processor_id & PRID_REV_MASK) {
                case PRID_REV_LOONGSON3A_R2_0:
                case PRID_REV_LOONGSON3A_R2_1:
-                       c->cputype = CPU_LOONGSON3;
+                       c->cputype = CPU_LOONGSON64;
                        __cpu_name[cpu] = "ICT Loongson-3";
                        set_elf_platform(cpu, "loongson3a");
                        set_isa(c, MIPS_CPU_ISA_M64R2);
                        break;
                case PRID_REV_LOONGSON3A_R3_0:
                case PRID_REV_LOONGSON3A_R3_1:
-                       c->cputype = CPU_LOONGSON3;
+                       c->cputype = CPU_LOONGSON64;
                        __cpu_name[cpu] = "ICT Loongson-3";
                        set_elf_platform(cpu, "loongson3a");
                        set_isa(c, MIPS_CPU_ISA_M64R2);
                        MIPS_ASE_LOONGSON_EXT | MIPS_ASE_LOONGSON_EXT2);
                break;
        case PRID_IMP_LOONGSON_64G:
-               c->cputype = CPU_LOONGSON3;
+               c->cputype = CPU_LOONGSON64;
                __cpu_name[cpu] = "ICT Loongson-3";
                set_elf_platform(cpu, "loongson3a");
                set_isa(c, MIPS_CPU_ISA_M64R2);
 
        case CPU_XLP:
                cpu_wait = r4k_wait;
                break;
-       case CPU_LOONGSON3:
+       case CPU_LOONGSON64:
                if ((c->processor_id & (PRID_IMP_MASK | PRID_REV_MASK)) >=
                                (PRID_IMP_LOONGSON_64C | PRID_REV_LOONGSON3A_R2_0))
                        cpu_wait = r4k_wait;
 
                        raw_event.cntr_mask =
                                raw_id > 127 ? CNTR_ODD : CNTR_EVEN;
                break;
-       case CPU_LOONGSON3:
+       case CPU_LOONGSON64:
                raw_event.cntr_mask = raw_id > 127 ? CNTR_ODD : CNTR_EVEN;
        break;
        }
                mipspmu.general_event_map = &mipsxxcore_event_map;
                mipspmu.cache_event_map = &mipsxxcore_cache_map;
                break;
-       case CPU_LOONGSON3:
+       case CPU_LOONGSON64:
                mipspmu.name = "mips/loongson3";
                mipspmu.general_event_map = &loongson3_event_map;
                mipspmu.cache_event_map = &loongson3_cache_map;
 
  * Initialize the bootmem allocator. It also setup initrd related data
  * if needed.
  */
-#if defined(CONFIG_SGI_IP27) || (defined(CONFIG_CPU_LOONGSON3) && defined(CONFIG_NUMA))
+#if defined(CONFIG_SGI_IP27) || (defined(CONFIG_CPU_LOONGSON64) && defined(CONFIG_NUMA))
 
 static void __init bootmem_init(void)
 {
 
        else {
                if (cpu_has_vtag_icache)
                        set_except_vector(EXCCODE_RI, handle_ri_rdhwr_tlbp);
-               else if (current_cpu_type() == CPU_LOONGSON3)
+               else if (current_cpu_type() == CPU_LOONGSON64)
                        set_except_vector(EXCCODE_RI, handle_ri_rdhwr_tlbp);
                else
                        set_except_vector(EXCCODE_RI, handle_ri_rdhwr);
 
 #endif
 
        /* odd buffer alignment? */
-#if defined(CONFIG_CPU_MIPSR2) || defined(CONFIG_CPU_LOONGSON3)
+#if defined(CONFIG_CPU_MIPSR2) || defined(CONFIG_CPU_LOONGSON64)
        .set    push
        .set    arch=mips32r2
        wsbh    v1, sum
        addu    sum, v1
 #endif
 
-#if defined(CONFIG_CPU_MIPSR2) || defined(CONFIG_CPU_LOONGSON3)
+#if defined(CONFIG_CPU_MIPSR2) || defined(CONFIG_CPU_LOONGSON64)
        .set    push
        .set    arch=mips32r2
        wsbh    v1, sum
 
        select I8259
        select IRQ_MIPS_CPU
        select NR_CPUS_DEFAULT_4
-       select SYS_HAS_CPU_LOONGSON3
+       select SYS_HAS_CPU_LOONGSON64
        select SYS_HAS_EARLY_PRINTK
        select SYS_SUPPORTS_SMP
        select SYS_SUPPORTS_HOTPLUG_CPU
 
 # All Loongson-3 family machines
 #
 
-obj-$(CONFIG_CPU_LOONGSON3)  += loongson-3/
+obj-$(CONFIG_CPU_LOONGSON64)  += loongson-3/
 
 #
 
 # Only gcc >= 4.4 have Loongson specific support
-cflags-$(CONFIG_CPU_LOONGSON2) += -Wa,--trap
+cflags-$(CONFIG_CPU_LOONGSON2EF)       += -Wa,--trap
 cflags-$(CONFIG_CPU_LOONGSON2E) += \
        $(call cc-option,-march=loongson2e,-march=r4600)
 cflags-$(CONFIG_CPU_LOONGSON2F) += \
   endif
 endif
 
-cflags-$(CONFIG_CPU_LOONGSON3) += -Wa,--trap
+cflags-$(CONFIG_CPU_LOONGSON64)        += -Wa,--trap
 
 #
 # Some versions of binutils, not currently mainline as of 2019/02/04, support
 # binutils does not merge support for the flag then we can revisit & remove
 # this later - for now it ensures vendor toolchains don't cause problems.
 #
-cflags-$(CONFIG_CPU_LOONGSON3) += $(call as-option,-Wa$(comma)-mno-fix-loongson3-llsc,)
+cflags-$(CONFIG_CPU_LOONGSON64)        += $(call as-option,-Wa$(comma)-mno-fix-loongson3-llsc,)
 
 #
 # binutils from v2.25 on and gcc starting from v4.9.0 treat -march=loongson3a
 #
 ifeq ($(call cc-ifversion, -ge, 0409, y), y)
   ifeq ($(call ld-ifversion, -ge, 225000000, y), y)
-    cflags-$(CONFIG_CPU_LOONGSON3)  += \
+    cflags-$(CONFIG_CPU_LOONGSON64)  += \
       $(call cc-option,-march=loongson3a -U_MIPS_ISA -D_MIPS_ISA=_MIPS_ISA_MIPS64)
   else
-    cflags-$(CONFIG_CPU_LOONGSON3)  += \
+    cflags-$(CONFIG_CPU_LOONGSON64)  += \
       $(call cc-option,-march=mips64r2,-mips64r2 -U_MIPS_ISA -D_MIPS_ISA=_MIPS_ISA_MIPS64)
   endif
 else
-    cflags-$(CONFIG_CPU_LOONGSON3)  += \
+    cflags-$(CONFIG_CPU_LOONGSON64)  += \
       $(call cc-option,-march=mips64r2,-mips64r2 -U_MIPS_ISA -D_MIPS_ISA=_MIPS_ISA_MIPS64)
 endif
 
 
 #endif
        register_pci_controller(&loongson_pci_controller);
 
-#ifdef CONFIG_CPU_LOONGSON3
+#ifdef CONFIG_CPU_LOONGSON64
        sbx00_acpi_init();
 #endif
 
 
                r4k_blast_icache_page = (void *)cache_noop;
        else if (ic_lsize == 16)
                r4k_blast_icache_page = blast_icache16_page;
-       else if (ic_lsize == 32 && current_cpu_type() == CPU_LOONGSON2)
+       else if (ic_lsize == 32 && current_cpu_type() == CPU_LOONGSON2EF)
                r4k_blast_icache_page = loongson2_blast_icache32_page;
        else if (ic_lsize == 32)
                r4k_blast_icache_page = blast_icache32_page;
                else if (TX49XX_ICACHE_INDEX_INV_WAR)
                        r4k_blast_icache_page_indexed =
                                tx49_blast_icache32_page_indexed;
-               else if (current_cpu_type() == CPU_LOONGSON2)
+               else if (current_cpu_type() == CPU_LOONGSON2EF)
                        r4k_blast_icache_page_indexed =
                                loongson2_blast_icache32_page_indexed;
                else
                        r4k_blast_icache = blast_r4600_v1_icache32;
                else if (TX49XX_ICACHE_INDEX_INV_WAR)
                        r4k_blast_icache = tx49_blast_icache32;
-               else if (current_cpu_type() == CPU_LOONGSON2)
+               else if (current_cpu_type() == CPU_LOONGSON2EF)
                        r4k_blast_icache = loongson2_blast_icache32;
                else
                        r4k_blast_icache = blast_icache32;
 {
        unsigned long sc_lsize = cpu_scache_line_size();
 
-       if (current_cpu_type() != CPU_LOONGSON3)
+       if (current_cpu_type() != CPU_LOONGSON64)
                r4k_blast_scache_node = (void *)cache_noop;
        else if (sc_lsize == 16)
                r4k_blast_scache_node = blast_scache16_node;
 static inline void local_r4k___flush_cache_all(void * args)
 {
        switch (current_cpu_type()) {
-       case CPU_LOONGSON2:
+       case CPU_LOONGSON2EF:
        case CPU_R4000SC:
        case CPU_R4000MC:
        case CPU_R4400SC:
                r4k_blast_scache();
                break;
 
-       case CPU_LOONGSON3:
+       case CPU_LOONGSON64:
                /* Use get_ebase_cpunum() for both NUMA=y/n */
                r4k_blast_scache_node(get_ebase_cpunum() >> 2);
                break;
                r4k_blast_icache();
        else {
                switch (boot_cpu_type()) {
-               case CPU_LOONGSON2:
+               case CPU_LOONGSON2EF:
                        protected_loongson2_blast_icache_range(start, end);
                        break;
 
        preempt_disable();
        if (cpu_has_inclusive_pcaches) {
                if (size >= scache_size) {
-                       if (current_cpu_type() != CPU_LOONGSON3)
+                       if (current_cpu_type() != CPU_LOONGSON64)
                                r4k_blast_scache();
                        else
                                r4k_blast_scache_node(pa_to_nid(addr));
        preempt_disable();
        if (cpu_has_inclusive_pcaches) {
                if (size >= scache_size) {
-                       if (current_cpu_type() != CPU_LOONGSON3)
+                       if (current_cpu_type() != CPU_LOONGSON64)
                                r4k_blast_scache();
                        else
                                r4k_blast_scache_node(pa_to_nid(addr));
                c->options |= MIPS_CPU_PREFETCH;
                break;
 
-       case CPU_LOONGSON2:
+       case CPU_LOONGSON2EF:
                icache_size = 1 << (12 + ((config & CONF_IC) >> 9));
                c->icache.linesz = 16 << ((config & CONF_IB) >> 5);
                if (prid & 0x3)
                c->dcache.waybit = 0;
                break;
 
-       case CPU_LOONGSON3:
+       case CPU_LOONGSON64:
                config1 = read_c0_config1();
                lsize = (config1 >> 19) & 7;
                if (lsize)
                c->dcache.flags &= ~MIPS_CACHE_ALIASES;
                break;
 
-       case CPU_LOONGSON2:
+       case CPU_LOONGSON2EF:
                /*
                 * LOONGSON2 has 4 way icache, but when using indexed cache op,
                 * one op will act on all 4 ways
        struct cpuinfo_mips *c = ¤t_cpu_data;
        unsigned int config2, lsize;
 
-       if (current_cpu_type() != CPU_LOONGSON3)
+       if (current_cpu_type() != CPU_LOONGSON64)
                return;
 
        config2 = read_c0_config2();
 #endif
                return;
 
-       case CPU_LOONGSON2:
+       case CPU_LOONGSON2EF:
                loongson2_sc_init();
                return;
 
-       case CPU_LOONGSON3:
+       case CPU_LOONGSON64:
                loongson3_sc_init();
                return;
 
                /* Optimization: an L2 flush implicitly flushes the L1 */
                current_cpu_data.options |= MIPS_CPU_INCLUSIVE_CACHES;
                break;
-       case CPU_LOONGSON3:
+       case CPU_LOONGSON64:
                /* Loongson-3 maintains cache coherency by hardware */
                __flush_cache_all       = cache_noop;
                __flush_cache_vmap      = cache_noop;
 
                        }
                        break;
 
-               case CPU_LOONGSON3:
+               case CPU_LOONGSON64:
                        /* Loongson-3 only support the Pref_Load/Pref_Store. */
                        pref_bias_clear_store = 128;
                        pref_bias_copy_load = 128;
 
 static inline void flush_micro_tlb(void)
 {
        switch (current_cpu_type()) {
-       case CPU_LOONGSON2:
+       case CPU_LOONGSON2EF:
                write_c0_diag(LOONGSON_DIAG_ITLB);
                break;
-       case CPU_LOONGSON3:
+       case CPU_LOONGSON64:
                write_c0_diag(LOONGSON_DIAG_ITLB | LOONGSON_DIAG_DTLB);
                break;
        default:
 
        case CPU_BMIPS4350:
        case CPU_BMIPS4380:
        case CPU_BMIPS5000:
-       case CPU_LOONGSON2:
-       case CPU_LOONGSON3:
+       case CPU_LOONGSON2EF:
+       case CPU_LOONGSON64:
        case CPU_R5500:
                if (m4kc_tlbp_war())
                        uasm_i_nop(p);
        switch (boot_cpu_type()) {
        default:
                if (sizeof(long) == 4) {
-       case CPU_LOONGSON2:
+       case CPU_LOONGSON2EF:
                /* Loongson2 ebase is different than r4k, we have more space */
                        if ((p - tlb_handler) > 64)
                                panic("TLB refill handler space exceeded");
 
 oprofile-$(CONFIG_CPU_R10000)          += op_model_mipsxx.o
 oprofile-$(CONFIG_CPU_SB1)             += op_model_mipsxx.o
 oprofile-$(CONFIG_CPU_XLR)             += op_model_mipsxx.o
-oprofile-$(CONFIG_CPU_LOONGSON2)       += op_model_loongson2.o
-oprofile-$(CONFIG_CPU_LOONGSON3)       += op_model_loongson3.o
+oprofile-$(CONFIG_CPU_LOONGSON2EF)     += op_model_loongson2.o
+oprofile-$(CONFIG_CPU_LOONGSON64)      += op_model_loongson3.o
 
                lmodel = &op_model_mipsxx_ops;
                break;
 
-       case CPU_LOONGSON2:
+       case CPU_LOONGSON2EF:
                lmodel = &op_model_loongson2_ops;
                break;
-       case CPU_LOONGSON3:
+       case CPU_LOONGSON64:
                lmodel = &op_model_loongson3_ops;
                break;
        };
 
 
 config GPIO_LOONGSON
        bool "Loongson-2/3 GPIO support"
-       depends on CPU_LOONGSON2 || CPU_LOONGSON3
+       depends on CPU_LOONGSON2EF || CPU_LOONGSON64
        help
          driver for GPIO functionality on Loongson-2F/3A/3B processors.
 
 
 #define STLS2F_N_GPIO          4
 #define STLS3A_N_GPIO          16
 
-#ifdef CONFIG_CPU_LOONGSON3
+#ifdef CONFIG_CPU_LOONGSON64
 #define LOONGSON_N_GPIO        STLS3A_N_GPIO
 #else
 #define LOONGSON_N_GPIO        STLS2F_N_GPIO
 
 {
 #if defined(CONFIG_PPC) && !defined(CONFIG_NOT_COHERENT_CACHE)
        return false;
-#elif defined(CONFIG_MIPS) && defined(CONFIG_CPU_LOONGSON3)
+#elif defined(CONFIG_MIPS) && defined(CONFIG_CPU_LOONGSON64)
        return false;
 #elif defined(CONFIG_ARM) || defined(CONFIG_ARM64)
        /*