Index: gdb.base/info-os.c =================================================================== RCS file: /cvs/src/src/gdb/testsuite/gdb.base/info-os.c,v retrieving revision 1.1 diff -u -p -r1.1 info-os.c --- gdb.base/info-os.c 11 May 2012 22:24:24 -0000 1.1 +++ gdb.base/info-os.c 3 Jul 2012 23:14:42 -0000 @@ -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. */ Index: gdb.base/info-os.exp =================================================================== RCS file: /cvs/src/src/gdb/testsuite/gdb.base/info-os.exp,v retrieving revision 1.2 diff -u -p -r1.2 info-os.exp --- gdb.base/info-os.exp 18 May 2012 17:51:30 -0000 1.2 +++ gdb.base/info-os.exp 3 Jul 2012 23:14:42 -0000 @@ -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" "$infer 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"