aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStan Shebs <shebs@codesourcery.com>2012-07-03 23:17:13 +0000
committerStan Shebs <shebs@codesourcery.com>2012-07-03 23:17:13 +0000
commit855ba978e4031295402a2333ba06ac384f7feb7a (patch)
tree6397e3d4aa373d6e6e8a836dedd023e440c56d2d
parent836bf45453d96e2e4020982e1a44e22498d766fa (diff)
downloadgdb-855ba978e4031295402a2333ba06ac384f7feb7a.zip
gdb-855ba978e4031295402a2333ba06ac384f7feb7a.tar.gz
gdb-855ba978e4031295402a2333ba06ac384f7feb7a.tar.bz2
* gdb.base/info-os.c (main): Retry resource acquisition until an
available one is found. * gdb.base/info-os.exp: Collect resource keys from the program and use them in matching.
-rw-r--r--gdb/testsuite/ChangeLog7
-rw-r--r--gdb/testsuite/gdb.base/info-os.c58
-rw-r--r--gdb/testsuite/gdb.base/info-os.exp42
3 files changed, 84 insertions, 23 deletions
diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog
index 34351ff..e993c49 100644
--- a/gdb/testsuite/ChangeLog
+++ b/gdb/testsuite/ChangeLog
@@ -1,3 +1,10 @@
+2012-07-03 Stan Shebs <stan@codesourcery.com>
+
+ * gdb.base/info-os.c (main): Retry resource acquisition until an
+ available one is found.
+ * gdb.base/info-os.exp: Collect resource keys from the program
+ and use them in matching.
+
2012-07-02 Jan Kratochvil <jan.kratochvil@redhat.com>
* gdb.threads/gcore-thread.exp: Remove variable libthread_db_seen.
diff --git a/gdb/testsuite/gdb.base/info-os.c b/gdb/testsuite/gdb.base/info-os.c
index 2971671..1590a9b 100644
--- a/gdb/testsuite/gdb.base/info-os.c
+++ b/gdb/testsuite/gdb.base/info-os.c
@@ -1,6 +1,6 @@
/* This testcase is part of GDB, the GNU debugger.
- Copyright 2011 Free Software Foundation, Inc.
+ Copyright 2011, 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
@@ -36,6 +36,7 @@ int
main (void)
{
const int flags = IPC_CREAT | 0666;
+ key_t shmkey = 3925, semkey = 7428, msgkey = 5294;
int shmid, semid, msqid;
FILE *fd;
pthread_t thread;
@@ -43,22 +44,53 @@ main (void)
int sock;
unsigned short port;
socklen_t size;
- int status;
+ int status, try, retries = 1000;
- if ((shmid = shmget (3925, 4096, flags | IPC_EXCL)) < 0)
+ for (try = 0; try < retries; ++try)
{
- /* Attempt to delete the existing shared-memory region, then
- recreate it. */
- shmctl (shmget (3925, 4096, flags), IPC_RMID, NULL);
- if ((shmid = shmget (3925, 4096, flags | IPC_EXCL)) < 0)
- {
- printf ("Cannot create shared-memory region.\n");
- return 1;
- }
+ shmid = shmget (shmkey, 4096, flags | IPC_EXCL);
+ if (shmid >= 0)
+ break;
+
+ ++shmkey;
+ }
+
+ if (shmid < 0)
+ {
+ printf ("Cannot create shared-memory region after %d tries.\n", retries);
+ return 1;
+ }
+
+ for (try = 0; try < retries; ++try)
+ {
+ semid = semget (semkey, 1, flags | IPC_EXCL);
+ if (semid >= 0)
+ break;
+
+ ++semkey;
+ }
+
+ if (semid < 0)
+ {
+ printf ("Cannot create semaphore after %d tries.\n", retries);
+ return 1;
+ }
+
+ for (try = 0; try < retries; ++try)
+ {
+ msqid = msgget (msgkey, flags | IPC_EXCL);
+ if (msqid >= 0)
+ break;
+
+ ++msgkey;
+ }
+
+ if (msqid < 0)
+ {
+ printf ("Cannot create message queue after %d tries.\n", retries);
+ return 1;
}
- semid = semget (7428, 1, flags);
- msqid = msgget (5294, flags);
fd = fopen ("/dev/null", "r");
/* Lock the mutex to prevent the new thread from finishing immediately. */
diff --git a/gdb/testsuite/gdb.base/info-os.exp b/gdb/testsuite/gdb.base/info-os.exp
index 5696402..541f03b 100644
--- a/gdb/testsuite/gdb.base/info-os.exp
+++ b/gdb/testsuite/gdb.base/info-os.exp
@@ -1,4 +1,4 @@
-# Copyright 2011 Free Software Foundation, Inc.
+# Copyright 2011, 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
@@ -52,7 +52,15 @@ gdb_test_multiple "call getpid()" $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.
+# Get keys and IDs of the IPC object instances.
+set shmkey -1
+set test "get shared memory key"
+gdb_test_multiple "print shmkey" $test {
+ -re ".* = ($decimal).*$gdb_prompt $" {
+ set shmkey $expect_out(1,string)
+ pass $test
+ }
+}
set shmid -1
set test "get shared memory ID"
gdb_test_multiple "print shmid" $test {
@@ -62,6 +70,15 @@ gdb_test_multiple "print shmid" $test {
}
}
+set semkey -1
+set test "get semaphore key"
+gdb_test_multiple "print semkey" $test {
+ -re ".* = ($decimal).*$gdb_prompt $" {
+ set semkey $expect_out(1,string)
+ pass $test
+ }
+}
+
set semid -1
set test "get semaphore ID"
gdb_test_multiple "print semid" $test {
@@ -71,6 +88,15 @@ gdb_test_multiple "print semid" $test {
}
}
+set msgkey -1
+set test "get message queue key"
+gdb_test_multiple "print msgkey" $test {
+ -re ".* = ($decimal).*$gdb_prompt $" {
+ set msgkey $expect_out(1,string)
+ pass $test
+ }
+}
+
set msqid -1
set test "get message queue ID"
gdb_test_multiple "print msqid" $test {
@@ -138,20 +164,16 @@ expect_multiline "info os files" "$inferior_pid +info-os +\\d+ +/dev/null" "get
expect_multiline "info os sockets" "0\\.0\\.0\\.0 +$port +0\\.0\\.0\\.0 +0 +LISTEN +\\S+ +INET +STREAM" "get internet-domain sockets"
# key shmid perm size creator command last op command num attached user group creator user creator group last shmat() time last shmdt() time last shmctl() time
-expect_multiline "info os shm" "3925 +$shmid +666 +4096 +info-os .*" "get shared-memory regions"
+expect_multiline "info os shm" "$shmkey +$shmid +666 +4096 +info-os .*" "get shared-memory regions"
# key semid perm num semaphores user group creator user creator group last semop() time last semctl() time
-expect_multiline "info os semaphores" "7428 +$semid +666 +1 .*" "get semaphores"
+expect_multiline "info os semaphores" "$semkey +$semid +666 +1 .*" "get semaphores"
# key msqid perm 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
-expect_multiline "info os msg" "5294 +$msqid +666 .*" "get message queues"
+expect_multiline "info os msg" "$msgkey +$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.
+# up after itself.
send_gdb "continue\n"