aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYao Qi <yao@codesourcery.com>2013-08-26 22:09:12 +0800
committerYao Qi <yao@codesourcery.com>2013-11-28 12:53:26 +0800
commit8b5e6dc2178814b2506793473347073061310ba7 (patch)
treed431b750ba0124fbd88a9dc172fbd168c7b9722d
parenta6c8f227fe3097e0896204aa5a2d51358a30faf4 (diff)
downloadgdb-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/ChangeLog6
-rw-r--r--gdb/testsuite/gdb.perf/disassemble.exp57
-rw-r--r--gdb/testsuite/gdb.perf/disassemble.py38
-rw-r--r--gdb/testsuite/lib/gdb.exp26
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 {