+2010-10-31 Richard Henderson <rth@redhat.com>
+
+ * lib/target-supports.exp
+ (check_effective_target_automatic_stack_alignment): True for
+ x86 but not windows.
+ * g++.dg/torture/stackalign/stackalign.exp: Use it to protect
+ use of the preferred-stack-boundary arguments.
+ * gcc.dg/torture/stackalign/stackalign.exp: Likewise.
+
2010-10-31 H.J. Lu <hongjiu.lu@intel.com>
PR target/46142
# This harness is for tests that should be run at all optimisation levels.
load_lib g++-dg.exp
-
-# Only run on targets which support automatic stack alignment.
-if { ![check_effective_target_automatic_stack_alignment] } then {
- return
-}
-
+dg-init
set additional_flags ""
-if { [istarget i?86*-*-*] || [istarget x86_64-*-*] } then {
+
+# If automatic stack alignment is supported, force it on.
+if { [check_effective_target_automatic_stack_alignment] } then {
lappend additional_flags "-mstackrealign"
lappend additional_flags "-mpreferred-stack-boundary=5"
}
-dg-init
gcc-dg-runtest [lsort [glob $srcdir/$subdir/*.C]] $additional_flags
if { [check_effective_target_fpic] } then {
lappend additional_flags "-fpic"
load_lib gcc-dg.exp
-# Only run on targets which support automatic stack alignment.
-if { ![check_effective_target_automatic_stack_alignment] } then {
- return
-}
-
set additional_flags ""
-if { [istarget i?86*-*-*] || [istarget x86_64-*-*] } then {
+if { [check_effective_target_automatic_stack_alignment] } then {
lappend additional_flags "-mstackrealign"
lappend additional_flags "-mpreferred-stack-boundary=5"
+}
+if { [istarget i?86*-*-*] || [istarget x86_64-*-*] } then {
lappend additional_flags "-mno-mmx"
}
gcc-dg-runtest [lsort [glob $srcdir/$subdir/*.c]] $pic_additional_flags
}
-if { [istarget i?86*-*-*] || [istarget x86_64-*-*] } then {
+if { [check_effective_target_automatic_stack_alignment] } then {
lappend additional_flags "-mforce-drap"
gcc-dg-runtest [lsort [glob $srcdir/$subdir/*.c]] $additional_flags
if { [check_effective_target_fpic] } then {
# Return 1 if the target supports automatic stack alignment.
proc check_effective_target_automatic_stack_alignment { } {
- # Not "stack alignment" per se, but proper stack alignment of decls.
- return 1;
+ # Ordinarily x86 supports automatic stack alignment ...
+ if { [istarget i?86*-*-*] || [istarget x86_64-*-*] } then {
+ if { [istarget *-*-mingw*] || [istarget *-*-cygwin*] } {
+ # ... except Win64 SEH doesn't. Succeed for Win32 though.
+ return [check_effective_target_ilp32];
+ }
+ return 1;
+ }
+ return 0;
}
# Return 1 if avx instructions can be compiled.