# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. */
-#
-# test running programs
-#
+# Test the 'section NAME ADDRESS' command.
-# This test exists solely to exercise the "section" command for
-# code-coverage on HP-UX. (So far as I can tell, the "section"
-# command isn't needed on HP-UX, but probably is for embedded
-# apps.)
-#
-if ![istarget "hppa*-*-hpux*"] then {
- return
+if { [prepare_for_testing "failed to prepare" "sect-cmd" \
+ {break.c break1.c} {debug nowarnings}] } {
+ return -1
}
-
-set testfile "sect-cmd"
set srcfile break.c
set srcfile1 break1.c
-set binfile ${objdir}/${subdir}/${testfile}
-if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}0.o" object {debug nowarnings}] != "" } {
- untested "failed to compile"
- return -1
+if ![runto_main] then {
+ fail "couldn't run to main"
+ return
}
-if { [gdb_compile "${srcdir}/${subdir}/${srcfile1}" "${binfile}1.o" object {debug nowarnings}] != "" } {
- untested "failed to compile"
- return -1
-}
+# Get the address of an executable section. This test was originally
+# written for (and only run on) hppa targets. For PA32 programs using
+# the SOM file format the code section is (apparently) called $CODE$,
+# hence why the patterns here include that as a choice.
+#
+set address1 ""
+set address2 ""
+set section_name ""
-if { [gdb_compile "${binfile}0.o ${binfile}1.o" "${binfile}" executable {debug nowarnings}] != "" } {
- untested "failed to compile"
- return -1
+gdb_test_multiple "info files" "" {
+ -re -wrap "\\s+($hex) - ($hex) is (\\\$CODE\\\$|\\.text\\S*) in .*" {
+ set address1 $expect_out(1,string)
+ set address2 $expect_out(2,string)
+ set section_name $expect_out(3,string)
+ pass $gdb_test_name
+ }
}
-gdb_exit
-gdb_start
-gdb_reinitialize_dir $srcdir/$subdir
-gdb_load ${binfile}
-
-if ![runto_main] then { fail "section command tests suppressed" }
-
-# Get the $CODE$ section's starting address.
+# If we don't have the details we need then we can't continue.
#
-# (Note that this works for PA32 programs, which use the SOM file
-# format. PA64 uses ELF, and when support for that is added, it's
-# not clear that there'll be a section named "$CODE$" in such
-# programs.)
-#
-
-set address1 ""
-set address2 ""
-send_gdb "info files\n"
-gdb_expect {
- -re ".*(0x\[0-9a-fA-F\]*) - (0x\[0-9a-fA-F\]*) is .(CODE|text).*$gdb_prompt $"\
- {pass "info files"
- set address1 $expect_out(1,string)
- set address2 $expect_out(2,string)}
- -re "$gdb_prompt $"\
- {fail "info files"}
- timeout {fail "(timeout) info files"}
+if { $address1 == "" || $address2 == "" || $section_name == "" } {
+ unresolved "failed to find required section details"
+ return
}
# Reset the section to that same starting address, which should be
# harmless (i.e., we just want to exercise the section command).
#
-if [istarget "hppa2.0w-*-*"] then {
- send_gdb "section \.text $address1\n"
- gdb_expect {
- -re ".*$address1 \- $address2 is .text.*$gdb_prompt $"\
- {pass "set section command"}
- -re "$gdb_prompt $"\
- {fail "set section command"}
- timeout {fail "(timeout) set section command"}
- }
-} else {
- send_gdb "section \$CODE\$ $address1\n"
- gdb_expect {
- -re ".*$address1 \- $address2 is .CODE..*$gdb_prompt $"\
- {pass "set section command"}
- -re "$gdb_prompt $"\
- {fail "set section command"}
- timeout {fail "(timeout) set section command"}
- }
-}
+set saw_section_address_line false
+gdb_test_multiple "section $section_name $address1" \
+ "set section $section_name to original address" {
+ -re ".*$address1 \- $address2 is $section_name.*" {
+ set saw_section_address_line true
+ exp_continue
+ }
+ -re "Section \[^\r\n\]+ not found\r\n" {
+ fail "$gdb_test_name, saw not found marker"
+ exp_continue
+ }
+ -re "$gdb_prompt $" {
+ gdb_assert { $saw_section_address_line } $gdb_test_name
+ }
+ }
# Verify that GDB responds gracefully to a non-existent section name.
#
-send_gdb "section FOOBARBAZ 0x1234\n"
-gdb_expect {
- -re "Section FOOBARBAZ not found\r\n$gdb_prompt $"\
- {pass "non-existent section disallowed"}
- -re "$gdb_prompt $"\
- {fail "non-existent section disallowed"}
- timeout {fail "(timeout) non-existent section disallowed"}
+gdb_test_multiple "section FOOBARBAZ 0x1234" "" {
+ -re -wrap "Section FOOBARBAZ not found" {
+ pass $gdb_test_name
+ }
}
# We "happen to know" that GDB uses a fixed size character buffer to
# characters in length. Verify that GDB gracefully handles section
# names longer than that. (The section is also non-existent.)
#
-send_gdb "section A234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123 0x1234\n"
-gdb_expect {
- -re "Section A23456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789 not found\r\n$gdb_prompt $"\
- {pass "non-existent too-long section disallowed"}
- -re "$gdb_prompt $"\
- {fail "non-existent too-long section disallowed"}
- timeout {fail "(timeout) non-existent too-long section disallowed"}
-}
-
-gdb_exit
-return 0
+gdb_test_multiple "section A234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123 0x1234" \
+ "non-existent too-long section disallowed" {
+ -re -wrap "Section A23456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789 not found" {
+ pass $gdb_test_name
+ }
+ }