diff options
author | Yao Qi <yao@codesourcery.com> | 2013-08-26 22:09:12 +0800 |
---|---|---|
committer | Yao Qi <yao@codesourcery.com> | 2013-11-28 12:53:26 +0800 |
commit | 8b5e6dc2178814b2506793473347073061310ba7 (patch) | |
tree | d431b750ba0124fbd88a9dc172fbd168c7b9722d | |
parent | a6c8f227fe3097e0896204aa5a2d51358a30faf4 (diff) | |
download | gdb-8b5e6dc2178814b2506793473347073061310ba7.zip gdb-8b5e6dc2178814b2506793473347073061310ba7.tar.gz gdb-8b5e6dc2178814b2506793473347073061310ba7.tar.bz2 |
GDB perf test on disassemble
This patch adds a test case to test the performance of GDB doing
disassembly.
gdb/testsuite/
2013-11-28 Yao Qi <yao@codesourcery.com>
* lib/gdb.exp (with_gdb_prompt): New proc.
* gdb.perf/disassemble.exp: New.
* gdb.perf/disassemble.py: New.
-rw-r--r-- | gdb/testsuite/ChangeLog | 6 | ||||
-rw-r--r-- | gdb/testsuite/gdb.perf/disassemble.exp | 57 | ||||
-rw-r--r-- | gdb/testsuite/gdb.perf/disassemble.py | 38 | ||||
-rw-r--r-- | gdb/testsuite/lib/gdb.exp | 26 |
4 files changed, 127 insertions, 0 deletions
diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog index a778544..8697d63 100644 --- a/gdb/testsuite/ChangeLog +++ b/gdb/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2013-11-28 Yao Qi <yao@codesourcery.com> + + * lib/gdb.exp (with_gdb_prompt): New proc. + * gdb.perf/disassemble.exp: New. + * gdb.perf/disassemble.py: New. + 2013-11-26 Luis Machado <lgustavo@codesourcery.com> * gdb.base/callfuncs.c (main): Assign malloc's return value diff --git a/gdb/testsuite/gdb.perf/disassemble.exp b/gdb/testsuite/gdb.perf/disassemble.exp new file mode 100644 index 0000000..8f07a59 --- /dev/null +++ b/gdb/testsuite/gdb.perf/disassemble.exp @@ -0,0 +1,57 @@ +# Copyright (C) 2013 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, see <http://www.gnu.org/licenses/>. + +# This test case is to test the speed of GDB when it is doing disassemble +# some large functions in GDB. +load_lib perftest.exp + +if [skip_perf_tests] { + return 0 +} + +global GDB + +standard_testfile .c +# Overwrite $binfile +set binfile $GDB + +PerfTest::assemble { + # Don't have compilation step. + return 0 +} { + global srcdir subdir + global binfile + + gdb_exit + gdb_start + gdb_reinitialize_dir $srcdir/$subdir + + # When GDB is debugging GDB, the prompt is changed to "(top-gdb) ". + # In order to avoid the confusion of pattern matching, set the + # gdb_prompt to '(top-gdb)' temporarily. + with_gdb_prompt "\\(top-gdb\\)" { + gdb_load ${binfile} + } + + # The prompt of both parent GDB and child GDB is '(gdb)', but + # child GDB's prompt doesn't confuse pattern matching because but + # we only run to main function of child GDB, so child GDB's + # prompt can't be printed out. + if ![runto_main] { + return -1 + } +} { + gdb_test "python Disassemble\(\).run()" +} diff --git a/gdb/testsuite/gdb.perf/disassemble.py b/gdb/testsuite/gdb.perf/disassemble.py new file mode 100644 index 0000000..da8079e --- /dev/null +++ b/gdb/testsuite/gdb.perf/disassemble.py @@ -0,0 +1,38 @@ +# Copyright (C) 2013 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, see <http://www.gnu.org/licenses/>. + +from perftest import perftest + +class Disassemble(perftest.TestCaseWithBasicMeasurements): + def __init__(self): + super (Disassemble, self).__init__ ("disassemble") + + def warm_up(self): + do_test_command = "disassemble ada_evaluate_subexp" + gdb.execute (do_test_command, False, True) + + def _do_test(self, c): + for func in ["evaluate_subexp_standard", "handle_inferior_event", "c_parse_internal"]: + do_test_command = "disassemble %s" % func + for _ in range(c+1): + gdb.execute (do_test_command, False, True) + + def execute_test(self): + for i in range(3): + # Flush code cache. + gdb.execute("set code-cache off"); + gdb.execute("set code-cache on"); + self.measure.measure(lambda: self._do_test(i), i) + diff --git a/gdb/testsuite/lib/gdb.exp b/gdb/testsuite/lib/gdb.exp index b8b21ab..2c1cf29 100644 --- a/gdb/testsuite/lib/gdb.exp +++ b/gdb/testsuite/lib/gdb.exp @@ -1716,6 +1716,32 @@ proc with_test_prefix { prefix body } { } } +# Run tests in BODY with GDB prompt and variable $gdb_prompt set to +# PROMPT. When BODY is finished, restore GDB prompt and variable +# $gdb_prompt. +# Returns the result of BODY. + +proc with_gdb_prompt { prompt body } { + global gdb_prompt + + set saved $gdb_prompt + + set gdb_prompt $prompt + gdb_test_no_output "set prompt $prompt " "" + + set code [catch {uplevel 1 $body} result] + + set gdb_prompt $saved + gdb_test_no_output "set prompt $saved " "" + + if {$code == 1} { + global errorInfo errorCode + return -code $code -errorinfo $errorInfo -errorcode $errorCode $result + } else { + return -code $code $result + } +} + # Return 1 if _Complex types are supported, otherwise, return 0. gdb_caching_proc support_complex_tests { |