# For example, "isa_rev>=1" selects a MIPS32 or MIPS64 processor,
# "isa=4" selects a MIPS IV processor, and so on.
#
-# If certain processor-specific extensions are not applicable to the
-# test you can list them as !CPU in the isa or isa_rev options. For
-# example, isa=64!octeon enforces MIPS64 while avoiding octeon. You
-# can also use ! without an ISA value. For example
-# isa=!octeon!loongson2e disables octeon and loongson2e if otherwise
-# you would compile for one of them.
-#
# There are also the following special pseudo-options:
#
# isa=loongson
# addressing=absolute
# force absolute addresses to be used
#
+# forbid_cpu=REGEXP
+# forbid processors that match the given regexp; choose a
+# generic ISA instead.
+#
#
# In summary:
#
# "-mips32r2" or "-mips64r2".
#
# (6) If you need to disable processor-specific extensions use
-# isa=!CPU instead of forcing a generic ISA.
+# forbid_cpu=REGEXP instead of forcing a generic ISA.
#
#
# Terminology
dump_pattern "-dp"
endianness "-E(L|B)|-me(l|b)"
float "-m(hard|soft)-float"
+ forbid_cpu "forbid_cpu=.*"
fp "-mfp(32|64)"
gp "-mgp(32|64)"
long "-mlong(32|64)"
}
}
+ # See whether forbid_cpu forces us to choose a new architecture.
+ set arch [mips_option mips_base_options arch]
+ set force_generic_isa_p [expr {
+ [regexp "forbid_cpu=(.*)" [mips_option options forbid_cpu] dummy spec]
+ && [regexp -- "^-march=$spec\$" $arch]
+ }]
+
# Interpret the special "isa" and "isa_rev" options. If we have
# a choice of a 32-bit or a 64-bit architecture, prefer to keep
# the -mgp setting the same.
set spec [mips_option options arch]
if { [regexp {^[^-]} $spec] } {
- set arch [mips_option mips_base_options arch]
if { [string equal $spec "isa=loongson"] } {
if { ![regexp {^-march=loongson} $arch] } {
set arch "-march=loongson2f"
}
} else {
- # With ! and = the ISA value is optional.
- if { ![regexp {^(isa(?:|_rev))(=|<=|>=)([0-9]*)((?:![^!]+)*)$} \
- $spec dummy prop relation value nocpus]
- || ($value eq ""
- && ($relation ne "="
- || $nocpus eq ""))} {
+ if { ![regexp {^(isa(?:|_rev))(=|<=|>=)([0-9]*)$} \
+ $spec dummy prop relation value nocpus] } {
error "Unrecognized isa specification: $spec"
}
- if { $value ne "" } {
- set current [mips_arch_info $arch $prop]
- if { ($current < $value && ![string equal $relation "<="])
- || ($current > $value && ![string equal $relation ">="])
- || ([mips_have_test_option_p options "-mgp64"]
- && [mips_32bit_arch_p $arch]) } {
- # The current setting is out of range; it cannot
- # possibly be used. Find a replacement that can.
- if { [string equal $prop "isa"] } {
- set arch "-mips$value"
- } elseif { $value == 0 } {
- set arch "-mips4"
+ set current [mips_arch_info $arch $prop]
+ if { $force_generic_isa_p
+ || ($current < $value && ![string equal $relation "<="])
+ || ($current > $value && ![string equal $relation ">="])
+ || ([mips_have_test_option_p options "-mgp64"]
+ && [mips_32bit_arch_p $arch]) } {
+ # The current setting is out of range; it cannot
+ # possibly be used. Find a replacement that can.
+ if { [string equal $prop "isa"] } {
+ set arch "-mips$value"
+ } elseif { $value == 0 } {
+ set arch "-mips4"
+ } else {
+ if { [mips_have_option_p options "-mgp32"] } {
+ set arch "-mips32"
} else {
- if { [mips_have_option_p options "-mgp32"] } {
- set arch "-mips32"
- } else {
- set arch "-mips64"
- }
- if { $value > 1 } {
- append arch "r$value"
- }
+ set arch "-mips64"
}
- }
- }
- # If we haven't switched to a generic ISA based on the
- # isa* value, do it here if the processor-specific
- # extension is not allowed.
- if { $nocpus ne ""
- && $arch eq [mips_option mips_base_options arch] } {
- set cpu [regsub -- {-march=} $arch ""]
- if { [regexp "!$cpu!" "$nocpus!"] } {
- set isa_rev [mips_arch_info $arch isa_rev]
- set arch "-mips[mips_arch_info $arch isa]"
- if { $isa_rev > 1 } {
- append arch "r$isa_rev"
+ if { $value > 1 } {
+ append arch "r$value"
}
}
}
} else {
mips_make_test_option options "-mips64r$isa_rev"
}
+ # Otherwise, if the current choice of architecture is unacceptable,
+ # choose the equivalent generic architecture.
+ } elseif { $force_generic_isa_p } {
+ set arch "-mips[mips_arch_info $arch isa]"
+ if { $isa_rev > 1 } {
+ append arch "r$isa_rev"
+ }
+ mips_make_test_option options $arch
}
unset arch
unset isa
# Add all options to the dg variable.
set options(explicit_p,addressing) 0
+ set options(explicit_p,forbid_cpu) 0
foreach { group regexp } $mips_option_groups {
if { $options(explicit_p,$group) } {
append extra_tool_flags " " $options(option,$group)