diff options
author | Stan Shebs <shebs@codesourcery.com> | 2012-05-11 22:24:24 +0000 |
---|---|---|
committer | Stan Shebs <shebs@codesourcery.com> | 2012-05-11 22:24:24 +0000 |
commit | 85d4a676956f3c83d6f03d6105ebf1a67bf5f494 (patch) | |
tree | 6cc105aa2d421de5ad8b64c22a094e63b9e19ef8 /gdb/testsuite/gdb.base/info-os.exp | |
parent | f24afd6d9f4a38630a3f2ee05a455da840d8aa92 (diff) | |
download | gdb-85d4a676956f3c83d6f03d6105ebf1a67bf5f494.zip gdb-85d4a676956f3c83d6f03d6105ebf1a67bf5f494.tar.gz gdb-85d4a676956f3c83d6f03d6105ebf1a67bf5f494.tar.bz2 |
2012-05-11 Stan Shebs <stan@codesourcery.com>
Kwok Cheung Yeung <kcy@codesourcery.com>
* NEWS: Describe new info os commands.
* common/linux-osdata.c (PID_T, TIME_T): Define.
(MAX_PID_T_STRLEN): New.
(linux_common_core_of_thread): Add comment. Change to use PID_T and
MAX_PID_T_STRLEN.
(command_from_pid): Add comment. Change to use PID_T.
(commandline_from_pid): Change to use PID_T.
(user_from_pid): Add comment.
(get_process_owner): Add comment. Change to use PID_T and
MAX_PID_T_STRLEN.
(get_number_of_cpu_cores): Add comment.
(get_cores_used_by_process): Add comment. Change to use PID_T and
MAX_PID_T_STRLEN.
(linux_xfer_osdata_processes): Change to use PID_T and
MAX_PID_T_STRLEN.
(compare_processes): New function.
(linux_xfer_osdata_processgroups): New function.
(linux_xfer_osdata_threads): Change to use PID_T.
(linux_xfer_osdata_fds): New function.
(format_socket_state, print_sockets): New functions.
(union socket_addr): New union.
(linux_xfer_osdata_isockets): New function.
(time_from_time_t, group_from_gid): New functions.
(linux_xfer_osdata_shm): New function.
(linux_xfer_osdata_sem): New function.
(linux_xfer_osdata_msg): New function.
(linux_xfer_osdata_modules): New function.
(osdata_table): Add new entries.
* common/buffer.c (buffer_xml_printf): Add support for long and
long long format specifiers.
* gdb.texinfo (Operating System Auxiliary Information): Document new
'info os' subcommands.
* gdb.base/info-os.exp: New file.
* gdb.base/info-os.c: New file.
Diffstat (limited to 'gdb/testsuite/gdb.base/info-os.exp')
-rw-r--r-- | gdb/testsuite/gdb.base/info-os.exp | 110 |
1 files changed, 110 insertions, 0 deletions
diff --git a/gdb/testsuite/gdb.base/info-os.exp b/gdb/testsuite/gdb.base/info-os.exp new file mode 100644 index 0000000..e1f7224 --- /dev/null +++ b/gdb/testsuite/gdb.base/info-os.exp @@ -0,0 +1,110 @@ +# Copyright 2011 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/>. + +set testfile "info-os" +set srcfile ${testfile}.c + +# This test is Linux-only. +if ![istarget *-*-linux*] then { + unsupported "info-os.exp" + return -1 +} + +# Support for XML-output is needed to run this test. +if [gdb_skip_xml_test] then { + unsupported "info-os.exp" + return -1 +} + +# Compile test program. +if { [prepare_for_testing ${testfile}.exp $testfile $srcfile {debug additional_flags=-lpthread}] } { + fail "cannot compile test program" + return -1 +} + +if ![runto_main] then { + fail "cannot run to main" + return -1; +} + +# Get PID of test program. +set inferior_pid -1 +set test "get inferior process ID" +gdb_test_multiple "call getpid()" $test { + -re ".* = ($decimal).*$gdb_prompt $" { + set inferior_pid $expect_out(1,string) + pass $test + } +} + +gdb_breakpoint ${srcfile}:[gdb_get_line_number "Set breakpoint here"] +gdb_continue_to_breakpoint "Set breakpoint here" + +# Get IDs of the IPC object instances. +set shmid -1 +set test "get shared memory ID" +gdb_test_multiple "print shmid" $test { + -re ".* = ($decimal).*$gdb_prompt $" { + set shmid $expect_out(1,string) + pass $test + } +} + +set semid -1 +set test "get semaphore ID" +gdb_test_multiple "print semid" $test { + -re ".* = ($decimal).*$gdb_prompt $" { + set semid $expect_out(1,string) + pass $test + } +} + +set msqid -1 +set test "get message queue ID" +gdb_test_multiple "print msqid" $test { + -re ".* = ($decimal).*$gdb_prompt $" { + set msqid $expect_out(1,string) + pass $test + } +} + +# Get port number of test socket. +set port -1 +set test "get socket port number" +gdb_test_multiple "print port" $test { + -re ".* = ($decimal).*$gdb_prompt $" { + set port $expect_out(1,string) + pass $test + } +} + +# Test output of the 'info os' commands against the expected results. +gdb_test "info os processes" ".*pid +user +command +cores.*$inferior_pid +\\S+ +\\S*info-os +\[0-9\]+.*" "get process list" +gdb_test "info os procgroups" ".*pgid +leader command +pid +command line.*$inferior_pid +info-os +$inferior_pid +\\S*info-os.*" "get process groups" +gdb_test "info os threads" ".*pid +command +tid +core.*$inferior_pid +info-os +\\d+ +\\d+.*" "get threads" +gdb_test "info os files" ".*pid +command +file descriptor +name.*$inferior_pid +info-os +\\d+ +/dev/null.*" "get file descriptors" +gdb_test "info os sockets" ".*local address +local port +remote address +remote port +state +user +family +protocol.*0\\.0\\.0\\.0 +$port +0\\.0\\.0\\.0 +0 +LISTEN +\\S+ +INET +STREAM.*" "get internet-domain sockets" +gdb_test "info os shm" ".*key +shmid +permissions +size +creator command +last op\\. command +num attached +user +group +creator user +creator group +last shmat\\(\\) time +last shmdt\\(\\) time +last shmctl\\(\\) time.*3925 +$shmid +666 +4096 +info-os +.*" "get shared-memory regions" +gdb_test "info os semaphores" ".*key +semid +permissions +num semaphores +user +group +creator user +creator group +last semop\\(\\) time +last semctl\\(\\) time.*7428 +$semid +666 +1 +.*" "get semaphores" +gdb_test "info os msg" ".*key +msqid +permissions +num used bytes +num messages +last msgsnd\\(\\) command +last msgrcv\\(\\) command +user +group +creator user +creator group +last msgsnd\\(\\) time +last msgrcv\\(\\) time +last msgctl\\(\\) time.*5294 +$msqid +666 +.*" "get message queues" + +# The SysV IPC primitives linger on after the creating process is killed +# unless they are destroyed explicitly, so allow the test program to tidy +# up after itself. Note that the test program attempts to delete and +# recreate the shared-memory region if it already exists, in case a +# previous run failed before having a chance to clean up. The tests for +# semaphores and message queues should still work with primitives from +# previous runs. +send_gdb "continue\n" |