mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-12 12:16:04 +08:00
3666a04883
This commits the result of running gdb/copyright.py as per our Start of New Year procedure... gdb/ChangeLog Update copyright year range in copyright header of all GDB files.
95 lines
2.5 KiB
C
95 lines
2.5 KiB
C
/* This testcase is part of GDB, the GNU debugger.
|
|
|
|
Copyright 2017-2021 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/>. */
|
|
|
|
#include <pthread.h>
|
|
#include <unistd.h>
|
|
#include <memory.h>
|
|
|
|
#define NTHR 3
|
|
#define NBOGUSTHR 2
|
|
|
|
int thr_data[NTHR];
|
|
|
|
/* Thread handles for each thread plus some "bogus" threads. */
|
|
pthread_t thrs[NTHR + NBOGUSTHR];
|
|
|
|
/* The thread children will meet at this barrier. */
|
|
pthread_barrier_t c_barrier;
|
|
|
|
/* The main thread and child thread will meet at this barrier. */
|
|
pthread_barrier_t mc_barrier;
|
|
|
|
void
|
|
do_something (int n)
|
|
{
|
|
}
|
|
|
|
void *
|
|
do_work (void *data)
|
|
{
|
|
int num = * (int *) data;
|
|
|
|
/* As the child threads are created, they'll meet the main thread
|
|
at this barrier. We do this to ensure that threads end up in
|
|
GDB's thread list in the order in which they were created. Having
|
|
this ordering makes it easier to write the test. */
|
|
pthread_barrier_wait (&mc_barrier);
|
|
|
|
/* All of the child threads will meet at this barrier before proceeding.
|
|
This ensures that all threads will be active (not exited) and in
|
|
roughly the same state when the first one hits the breakpoint in
|
|
do_something(). */
|
|
pthread_barrier_wait (&c_barrier);
|
|
|
|
do_something (num);
|
|
|
|
pthread_exit (NULL);
|
|
}
|
|
|
|
void
|
|
after_mc_barrier (void)
|
|
{
|
|
}
|
|
|
|
int
|
|
main (int argc, char **argv)
|
|
{
|
|
int i;
|
|
|
|
pthread_barrier_init (&c_barrier, NULL, NTHR - 1);
|
|
pthread_barrier_init (&mc_barrier, NULL, 2);
|
|
|
|
thrs[0] = pthread_self ();
|
|
thr_data[0] = 1;
|
|
|
|
/* Create two bogus thread handles. */
|
|
memset (&thrs[NTHR], 0, sizeof (pthread_t));
|
|
memset (&thrs[NTHR + 1], 0xaa, sizeof (pthread_t));
|
|
|
|
for (i = 1; i < NTHR; i++)
|
|
{
|
|
thr_data[i] = i + 1;
|
|
|
|
pthread_create (&thrs[i], NULL, do_work, &thr_data[i]);
|
|
pthread_barrier_wait (&mc_barrier);
|
|
after_mc_barrier ();
|
|
}
|
|
|
|
for (i = 1; i < NTHR; i++)
|
|
pthread_join (thrs[i], NULL);
|
|
}
|