Hello Ralf, I made a patch for vr41xx of 2.4. Although the old register name is using CPU as the base, it is not dependent on CPU in practice. This patch corrects the name depending on the CPU name. Please apply this patch. Yoichi diff -urN -X dontdiff linux-orig/arch/mips/vr41xx/common/bcu.c linux/arch/mips/vr41xx/common/bcu.c --- linux-orig/arch/mips/vr41xx/common/bcu.c Wed Dec 3 01:37:03 2003 +++ linux/arch/mips/vr41xx/common/bcu.c Sun Jan 11 22:08:37 2004 @@ -45,8 +45,8 @@ #include <asm/cpu.h> #include <asm/io.h> -#define VR4111_CLKSPEEDREG KSEG1ADDR(0x0b000014) -#define VR4122_CLKSPEEDREG KSEG1ADDR(0x0f000014) +#define CLKSPEEDREG_TYPE1 KSEG1ADDR(0x0b000014) +#define CLKSPEEDREG_TYPE2 KSEG1ADDR(0x0f000014) #define CLKSP(x) ((x) & 0x001f) #define CLKSP_VR4133(x) ((x) & 0x0007) @@ -77,10 +77,10 @@ { switch (current_cpu_data.cputype) { case CPU_VR4111: - case CPU_VR4121: return readw(VR4111_CLKSPEEDREG); + case CPU_VR4121: return readw(CLKSPEEDREG_TYPE1); case CPU_VR4122: case CPU_VR4131: - case CPU_VR4133: return readw(VR4122_CLKSPEEDREG); + case CPU_VR4133: return readw(CLKSPEEDREG_TYPE2); default: printk(KERN_INFO "Unexpected CPU of NEC VR4100 series\n"); break; diff -urN -X dontdiff linux-orig/arch/mips/vr41xx/common/cmu.c linux/arch/mips/vr41xx/common/cmu.c --- linux-orig/arch/mips/vr41xx/common/cmu.c Fri Oct 31 11:28:40 2003 +++ linux/arch/mips/vr41xx/common/cmu.c Sun Jan 11 22:08:37 2004 @@ -46,33 +46,33 @@ #include <asm/io.h> #include <asm/vr41xx/vr41xx.h> -#define VR4111_CMUCLKMSK KSEG1ADDR(0x0b000060) -#define VR4122_CMUCLKMSK KSEG1ADDR(0x0f000060) - #define MSKPIU 0x0001 - #define MSKSIU 0x0002 - #define MSKAIU 0x0004 - #define MSKKIU 0x0008 - #define MSKFIR 0x0010 - #define MSKDSIU 0x0820 - #define MSKCSI 0x0040 - #define MSKPCIU 0x0080 - #define MSKSSIU 0x0100 - #define MSKSHSP 0x0200 - #define MSKFFIR 0x0400 - #define MSKSCSI 0x1000 - #define MSKPPCIU 0x2000 -#define VR4133_CMUCLKMSK2 KSEG1ADDR(0x0f000064) - #define MSKCEU 0x0001 - #define MSKMAC0 0x0002 - #define MSKMAC1 0x0004 +#define CMUCLKMSK_TYPE1 KSEG1ADDR(0x0b000060) +#define CMUCLKMSK_TYPE2 KSEG1ADDR(0x0f000060) + #define MSKPIU 0x0001 + #define MSKSIU 0x0002 + #define MSKAIU 0x0004 + #define MSKKIU 0x0008 + #define MSKFIR 0x0010 + #define MSKDSIU 0x0820 + #define MSKCSI 0x0040 + #define MSKPCIU 0x0080 + #define MSKSSIU 0x0100 + #define MSKSHSP 0x0200 + #define MSKFFIR 0x0400 + #define MSKSCSI 0x1000 + #define MSKPPCIU 0x2000 +#define CMUCLKMSK2 KSEG1ADDR(0x0f000064) + #define MSKCEU 0x0001 + #define MSKMAC0 0x0002 + #define MSKMAC1 0x0004 static u32 vr41xx_cmu_base; static u16 cmuclkmsk, cmuclkmsk2; #define read_cmuclkmsk() readw(vr41xx_cmu_base) -#define read_cmuclkmsk2() readw(VR4133_CMUCLKMSK2) +#define read_cmuclkmsk2() readw(CMUCLKMSK2) #define write_cmuclkmsk() writew(cmuclkmsk, vr41xx_cmu_base) -#define write_cmuclkmsk2() writew(cmuclkmsk2, VR4133_CMUCLKMSK2) +#define write_cmuclkmsk2() writew(cmuclkmsk2, CMUCLKMSK2) void vr41xx_clock_supply(unsigned int clock) { @@ -205,14 +205,14 @@ switch (current_cpu_data.cputype) { case CPU_VR4111: case CPU_VR4121: - vr41xx_cmu_base = VR4111_CMUCLKMSK; + vr41xx_cmu_base = CMUCLKMSK_TYPE1; break; case CPU_VR4122: case CPU_VR4131: - vr41xx_cmu_base = VR4122_CMUCLKMSK; + vr41xx_cmu_base = CMUCLKMSK_TYPE2; break; case CPU_VR4133: - vr41xx_cmu_base = VR4122_CMUCLKMSK; + vr41xx_cmu_base = CMUCLKMSK_TYPE2; cmuclkmsk2 = read_cmuclkmsk2(); break; default: diff -urN -X dontdiff linux-orig/arch/mips/vr41xx/common/giu.c linux/arch/mips/vr41xx/common/giu.c --- linux-orig/arch/mips/vr41xx/common/giu.c Thu Dec 18 00:58:12 2003 +++ linux/arch/mips/vr41xx/common/giu.c Sun Jan 11 22:08:37 2004 @@ -48,8 +48,8 @@ #include <asm/io.h> #include <asm/vr41xx/vr41xx.h> -#define VR4111_GIUIOSELL KSEG1ADDR(0x0b000100) -#define VR4122_GIUIOSELL KSEG1ADDR(0x0f000140) +#define GIUIOSELL_TYPE1 KSEG1ADDR(0x0b000100) +#define GIUIOSELL_TYPE2 KSEG1ADDR(0x0f000140) #define GIUIOSELL 0x00 #define GIUIOSELH 0x02 @@ -280,12 +280,12 @@ switch (current_cpu_data.cputype) { case CPU_VR4111: case CPU_VR4121: - giu_base = VR4111_GIUIOSELL; + giu_base = GIUIOSELL_TYPE1; break; case CPU_VR4122: case CPU_VR4131: case CPU_VR4133: - giu_base = VR4122_GIUIOSELL; + giu_base = GIUIOSELL_TYPE2; break; default: panic("GIU: Unexpected CPU of NEC VR4100 series"); diff -urN -X dontdiff linux-orig/arch/mips/vr41xx/common/icu.c linux/arch/mips/vr41xx/common/icu.c --- linux-orig/arch/mips/vr41xx/common/icu.c Thu Dec 18 00:58:12 2003 +++ linux/arch/mips/vr41xx/common/icu.c Sun Jan 11 22:08:37 2004 @@ -67,11 +67,11 @@ static unsigned char sysint2_assign[16] = { 2, 0, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; -#define VR4111_SYSINT1REG KSEG1ADDR(0x0b000080) -#define VR4111_SYSINT2REG KSEG1ADDR(0x0b000200) +#define SYSINT1REG_TYPE1 KSEG1ADDR(0x0b000080) +#define SYSINT2REG_TYPE1 KSEG1ADDR(0x0b000200) -#define VR4122_SYSINT1REG KSEG1ADDR(0x0f000080) -#define VR4122_SYSINT2REG KSEG1ADDR(0x0f0000a0) +#define SYSINT1REG_TYPE2 KSEG1ADDR(0x0f000080) +#define SYSINT2REG_TYPE2 KSEG1ADDR(0x0f0000a0) #define SYSINT1REG 0x00 #define INTASSIGN0 0x04 @@ -292,14 +292,14 @@ switch (current_cpu_data.cputype) { case CPU_VR4111: case CPU_VR4121: - icu1_base = VR4111_SYSINT1REG; - icu2_base = VR4111_SYSINT2REG; + icu1_base = SYSINT1REG_TYPE1; + icu2_base = SYSINT2REG_TYPE1; break; case CPU_VR4122: case CPU_VR4131: case CPU_VR4133: - icu1_base = VR4122_SYSINT1REG; - icu2_base = VR4122_SYSINT2REG; + icu1_base = SYSINT1REG_TYPE2; + icu2_base = SYSINT2REG_TYPE2; break; default: panic("Unexpected CPU of NEC VR4100 series"); diff -urN -X dontdiff linux-orig/arch/mips/vr41xx/common/rtc.c linux/arch/mips/vr41xx/common/rtc.c --- linux-orig/arch/mips/vr41xx/common/rtc.c Tue Dec 2 04:31:49 2003 +++ linux/arch/mips/vr41xx/common/rtc.c Sun Jan 11 22:08:37 2004 @@ -40,11 +40,11 @@ #define REMAINDER_PER_SEC (CLOCK_TICK_RATE - (CYCLES_PER_JIFFY * HZ)) #define CYCLES_PER_100USEC ((CLOCK_TICK_RATE + (10000 / 2)) / 10000) -#define VR4111_ETIMELREG KSEG1ADDR(0x0b0000c0) -#define VR4111_TCLKLREG KSEG1ADDR(0x0b0001c0) +#define ETIMELREG_TYPE1 KSEG1ADDR(0x0b0000c0) +#define TCLKLREG_TYPE1 KSEG1ADDR(0x0b0001c0) -#define VR4122_ETIMELREG KSEG1ADDR(0x0f000100) -#define VR4122_TCLKLREG KSEG1ADDR(0x0f000120) +#define ETIMELREG_TYPE2 KSEG1ADDR(0x0f000100) +#define TCLKLREG_TYPE2 KSEG1ADDR(0x0f000120) /* RTC 1 registers */ #define ETIMELREG 0x00 @@ -265,14 +265,14 @@ switch (current_cpu_data.cputype) { case CPU_VR4111: case CPU_VR4121: - rtc1_base = VR4111_ETIMELREG; - rtc2_base = VR4111_TCLKLREG; + rtc1_base = ETIMELREG_TYPE1; + rtc2_base = TCLKLREG_TYPE1; break; case CPU_VR4122: case CPU_VR4131: case CPU_VR4133: - rtc1_base = VR4122_ETIMELREG; - rtc2_base = VR4122_TCLKLREG; + rtc1_base = ETIMELREG_TYPE2; + rtc2_base = TCLKLREG_TYPE2; break; default: panic("Unexpected CPU of NEC VR4100 series"); diff -urN -X dontdiff linux-orig/arch/mips/vr41xx/common/serial.c linux/arch/mips/vr41xx/common/serial.c --- linux-orig/arch/mips/vr41xx/common/serial.c Fri Oct 31 11:28:41 2003 +++ linux/arch/mips/vr41xx/common/serial.c Sun Jan 11 22:08:37 2004 @@ -49,12 +49,12 @@ #include <asm/vr41xx/vr41xx.h> /* VR4111 and VR4121 SIU Registers */ -#define VR4111_SIURB KSEG1ADDR(0x0c000000) -#define VR4111_SIUIRSEL KSEG1ADDR(0x0c000008) +#define SIURB_TYPE1 KSEG1ADDR(0x0c000000) +#define SIUIRSEL_TYPE1 KSEG1ADDR(0x0c000008) -/* VR4122 and VR4131 SIU Registers */ -#define VR4122_SIURB KSEG1ADDR(0x0f000800) -#define VR4122_SIUIRSEL KSEG1ADDR(0x0f000808) +/* VR4122, VR4131 and VR4133 SIU Registers */ +#define SIURB_TYPE2 KSEG1ADDR(0x0f000800) +#define SIUIRSEL_TYPE2 KSEG1ADDR(0x0f000808) #define USE_RS232C 0x00 #define USE_IRDA 0x01 @@ -101,12 +101,12 @@ switch (current_cpu_data.cputype) { case CPU_VR4111: case CPU_VR4121: - writew(val, VR4111_SIUIRSEL); + writew(val, SIUIRSEL_TYPE1); break; case CPU_VR4122: case CPU_VR4131: case CPU_VR4133: - writew(val, VR4122_SIUIRSEL); + writew(val, SIUIRSEL_TYPE2); break; default: printk(KERN_INFO "Unexpected CPU of NEC VR4100 series\n"); @@ -129,12 +129,12 @@ switch (current_cpu_data.cputype) { case CPU_VR4111: case CPU_VR4121: - s.iomem_base = (unsigned char *)VR4111_SIURB; + s.iomem_base = (unsigned char *)SIURB_TYPE1; break; case CPU_VR4122: case CPU_VR4131: case CPU_VR4133: - s.iomem_base = (unsigned char *)VR4122_SIURB; + s.iomem_base = (unsigned char *)SIURB_TYPE2; break; default: panic("Unexpected CPU of NEC VR4100 series");