| # Copyright 2012 |
| # Free Software Foundation, Inc. |
| |
| # This program is free software; you can redistribute it and/or modify |
| # it under the terms of the GNU General Public License as published by |
| # the Free Software Foundation; either version 3 of the License, or |
| # (at your option) any later version. |
| # |
| # This program is distributed in the hope that it will be useful, |
| # but WITHOUT ANY WARRANTY; without even the implied warranty of |
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| # GNU General Public License for more details. |
| # |
| # You should have received a copy of the GNU General Public License |
| # along with this program; if not, write to the Free Software |
| # Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. |
| |
| # |
| # Some generic xtensa tests |
| # |
| if [istarget xtensa*-*-*] then { |
| gas_test_error "j_too_far.s" "" "Check for jump out of range error" |
| |
| set testname "j_too_far.s: error line number reporting" |
| gas_start "j_too_far.s" "" |
| set x1 0 |
| while 1 { |
| expect { |
| -re ":4: Error:.*out of range" { set x1 1 } |
| timeout { perror "timeout\n"; break } |
| eof { break } |
| } |
| } |
| gas_finish |
| if [all_ones $x1] then { pass $testname } else { fail $testname } |
| |
| |
| gas_test "entry_misalign.s" "" "" "Xtensa Entry misalignment" |
| set testname "entry_misalign.s: Force entry misalignment" |
| objdump_start_no_subdir "a.out" "-d -j .text" |
| set x1 0 |
| while 1 { |
| expect { |
| -re "^.*2:.*entry" { set x1 1 } |
| timeout { perror "timeout\n"; break } |
| eof { break } |
| } |
| } |
| objdump_finish |
| if [all_ones $x1] then { pass $testname } else { fail $testname } |
| |
| |
| gas_test "entry_misalign2.s" "" "" "Xtensa Entry misalignment(2)" |
| set testname "entry_misalign2.s: Force entry misalignment(2)" |
| objdump_start_no_subdir "a.out" "-d -j .text" |
| set x1 0 |
| while 1 { |
| expect { |
| -re "^.*2:.*entry" { set x1 1 } |
| timeout { perror "timeout\n"; break } |
| eof { break } |
| } |
| } |
| objdump_finish |
| if [all_ones $x1] then { pass $testname } else { fail $testname } |
| |
| gas_test_error "entry_align.s" "" "Xtensa entry alignment error" |
| |
| gas_test "loop_misalign.s" "" "" "Xtensa Loop misalignment" |
| set testname "loop_misalign.s: Force loop misalignment" |
| objdump_start_no_subdir "a.out" "-d -j .text" |
| set x1 0 |
| while 1 { |
| expect { |
| -re "^.*0:.*loop" { set x1 1 } |
| timeout { perror "timeout\n"; break } |
| eof { break } |
| } |
| } |
| objdump_finish |
| if [all_ones $x1] then { pass $testname } else { fail $testname } |
| |
| |
| gas_test "loop_align.s" "" "" "Xtensa autoalign loop" |
| set testname "loop_align.s: autoalign loop" |
| objdump_start_no_subdir "a.out" "-d -j .text" |
| set x1 0 |
| while 1 { |
| expect { |
| -re "^.*2:.*loop" { set x1 1 } |
| timeout { perror "timeout\n"; break } |
| eof { break } |
| } |
| } |
| objdump_finish |
| if [all_ones $x1] then { pass $testname } else { fail $testname } |
| |
| run_dump_test "short_branch_offset" |
| run_dump_test "pcrel" |
| run_dump_test "weak-call" |
| run_dump_test "jlong" |
| } |
| |
| if [info exists errorInfo] then { |
| unset errorInfo |
| } |