mips.py: add mips32r2 and mips64r2 builder classes
authorMatt Turner <mattst88@gmail.com>
Wed, 17 Aug 2011 04:09:58 +0000 (00:09 -0400)
committerMatt Turner <mattst88@gmail.com>
Wed, 17 Aug 2011 04:09:58 +0000 (00:09 -0400)
modules/catalyst/arch/mips.py

index 4b0555128bd50181de6fd0886886bdbe2f69bbbb..f042af41d53126c2407f76217dbcefa9a40ab171 100644 (file)
@@ -41,6 +41,12 @@ class arch_mips32(generic_mips):
                generic_mips.__init__(self,myspec)
                self.settings["CFLAGS"]="-O2 -march=mips32 -mabi=32 -pipe"
 
+class arch_mips32r2(generic_mips):
+       "Builder class for MIPS 32r2 [Big-endian]"
+       def __init__(self,myspec):
+               generic_mips.__init__(self,myspec)
+               self.settings["CFLAGS"]="-O2 -march=mips32r2 -mabi=32 -pipe"
+
 class arch_mips3(generic_mips):
        "Builder class for MIPS III [Big-endian]"
        def __init__(self,myspec):
@@ -113,6 +119,30 @@ class arch_mips64_multilib(generic_mips64):
                generic_mips64.__init__(self,myspec)
                self.settings["CFLAGS"]="-O2 -march=mips64 -pipe"
 
+class arch_mips64r2(generic_mips):
+       "Builder class for MIPS 64r2 [Big-endian]"
+       def __init__(self,myspec):
+               generic_mips.__init__(self,myspec)
+               self.settings["CFLAGS"]="-O2 -march=mips64r2 -mabi=32 -pipe"
+
+class arch_mips64r2_n32(generic_mips64):
+       "Builder class for MIPS 64r2 [Big-endian N32]"
+       def __init__(self,myspec):
+               generic_mips64.__init__(self,myspec)
+               self.settings["CFLAGS"]="-O2 -march=mips64r2 -mabi=n32 -pipe"
+
+class arch_mips64r2_n64(generic_mips64):
+       "Builder class for MIPS 64r2 [Big-endian N64]"
+       def __init__(self,myspec):
+               generic_mips64.__init__(self,myspec)
+               self.settings["CFLAGS"]="-O2 -march=mips64r2 -mabi=64 -pipe"
+
+class arch_mips64r2_multilib(generic_mips64):
+       "Builder class for MIPS 64r2 [Big-endian multilib]"
+       def __init__(self,myspec):
+               generic_mips64.__init__(self,myspec)
+               self.settings["CFLAGS"]="-O2 -march=mips64r2 -pipe"
+
 class arch_mipsel1(generic_mipsel):
        "Builder class for all MIPS I [Little-endian]"
        def __init__(self,myspec):
@@ -125,6 +155,12 @@ class arch_mips32el(generic_mipsel):
                generic_mipsel.__init__(self,myspec)
                self.settings["CFLAGS"]="-O2 -march=mips32 -mabi=32 -pipe"
 
+class arch_mips32r2el(generic_mipsel):
+       "Builder class for all MIPS 32r2 [Little-endian]"
+       def __init__(self,myspec):
+               generic_mipsel.__init__(self,myspec)
+               self.settings["CFLAGS"]="-O2 -march=mips32r2 -mabi=32 -pipe"
+
 class arch_mipsel3(generic_mipsel):
        "Builder class for all MIPS III [Little-endian]"
        def __init__(self,myspec):
@@ -221,6 +257,30 @@ class arch_mips64el_multilib(generic_mips64el):
                generic_mips64el.__init__(self,myspec)
                self.settings["CFLAGS"]="-O2 -march=mips64 -pipe"
 
+class arch_mips64r2el(generic_mipsel):
+       "Builder class for all MIPS 64r2 [Little-endian]"
+       def __init__(self,myspec):
+               generic_mipsel.__init__(self,myspec)
+               self.settings["CFLAGS"]="-O2 -march=mips64r2 -mabi=32 -pipe"
+
+class arch_mips64r2el_n32(generic_mips64el):
+       "Builder class for all MIPS 64r2 [Little-endian N32]"
+       def __init__(self,myspec):
+               generic_mips64el.__init__(self,myspec)
+               self.settings["CFLAGS"]="-O2 -march=mips64r2 -mabi=n32 -pipe"
+
+class arch_mips64r2el_n64(generic_mips64el):
+       "Builder class for MIPS 64r2 [Little-endian N64]"
+       def __init__(self,myspec):
+               generic_mips64el.__init__(self,myspec)
+               self.settings["CFLAGS"]="-O2 -march=mips64r2 -mabi=64 -pipe"
+
+class arch_mips64r2el_multilib(generic_mips64el):
+       "Builder class for MIPS 64r2 [Little-endian multilib]"
+       def __init__(self,myspec):
+               generic_mips64el.__init__(self,myspec)
+               self.settings["CFLAGS"]="-O2 -march=mips64r2 -pipe"
+
 class arch_cobalt(generic_mipsel):
        "Builder class for all cobalt [Little-endian]"
        def __init__(self,myspec):
@@ -241,6 +301,7 @@ _subarch_map = {
        "mips"                  : arch_mips1,
        "mips1"                 : arch_mips1,
        "mips32"                : arch_mips32,
+       "mips32r2"              : arch_mips32r2,
        "mips3"                 : arch_mips3,
        "mips3_n32"             : arch_mips3_n32,
        "mips3_n64"             : arch_mips3_n64,
@@ -253,9 +314,14 @@ _subarch_map = {
        "mips64_n32"    : arch_mips64_n32,
        "mips64_n64"    : arch_mips64_n64,
        "mips64_multilib"       : arch_mips64_multilib,
+       "mips64r2"              : arch_mips64r2,
+       "mips64r2_n32"  : arch_mips64r2_n32,
+       "mips64r2_n64"  : arch_mips64r2_n64,
+       "mips64r2_multilib"     : arch_mips64r2_multilib,
        "mipsel"                : arch_mipsel1,
        "mipsel1"               : arch_mipsel1,
        "mips32el"              : arch_mips32el,
+       "mips32r2el"            : arch_mips32r2el,
        "mipsel3"               : arch_mipsel3,
        "mipsel3_n32"   : arch_mipsel3_n32,
        "mipsel3_n64"   : arch_mipsel3_n64,
@@ -268,6 +334,10 @@ _subarch_map = {
        "mips64el_n32"  : arch_mips64el_n32,
        "mips64el_n64"  : arch_mips64el_n64,
        "mips64el_multilib"     : arch_mips64el_multilib,
+       "mips64r2el"            : arch_mips64r2el,
+       "mips64r2el_n32"        : arch_mips64r2el_n32,
+       "mips64r2el_n64"        : arch_mips64r2el_n64,
+       "mips64r2el_multilib"   : arch_mips64r2el_multilib,
        "loongson2e"            : arch_loongson2e,
        "loongson2e_n32"        : arch_loongson2e_n32,
        "loongson2f"            : arch_loongson2f,