2014-04-02 14:57:45 +08:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <fcntl.h>
|
2014-08-14 01:44:53 +08:00
|
|
|
|
|
|
|
#include <chrono>
|
|
|
|
#include <thread>
|
2014-04-02 14:57:45 +08:00
|
|
|
|
2014-10-27 06:08:56 +08:00
|
|
|
#if defined(__linux__)
|
|
|
|
#include <sys/prctl.h>
|
|
|
|
#endif
|
|
|
|
|
2014-04-02 14:57:45 +08:00
|
|
|
void *start(void *data)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
size_t idx = (size_t)data;
|
|
|
|
for (i=0; i<30; i++)
|
|
|
|
{
|
|
|
|
if ( idx == 0 )
|
2014-08-14 01:44:53 +08:00
|
|
|
std::this_thread::sleep_for(std::chrono::microseconds(1));
|
2014-11-04 07:10:56 +08:00
|
|
|
std::this_thread::sleep_for(std::chrono::seconds(1)); // Set breakpoint here
|
2014-04-02 14:57:45 +08:00
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, char const *argv[])
|
|
|
|
{
|
2014-10-27 06:08:56 +08:00
|
|
|
#if defined(__linux__)
|
|
|
|
// Immediately enable any ptracer so that we can allow the stub attach
|
|
|
|
// operation to succeed. Some Linux kernels are locked down so that
|
|
|
|
// only an ancestor process can be a ptracer of a process. This disables that
|
|
|
|
// restriction. Without it, attach-related stub tests will fail.
|
|
|
|
#if defined(PR_SET_PTRACER) && defined(PR_SET_PTRACER_ANY)
|
|
|
|
// For now we execute on best effort basis. If this fails for
|
|
|
|
// some reason, so be it.
|
|
|
|
const int prctl_result = prctl(PR_SET_PTRACER, PR_SET_PTRACER_ANY, 0, 0, 0);
|
|
|
|
static_cast<void> (prctl_result);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
2014-04-02 14:57:45 +08:00
|
|
|
static const size_t nthreads = 16;
|
2014-08-14 01:44:53 +08:00
|
|
|
std::thread threads[nthreads];
|
2014-04-02 14:57:45 +08:00
|
|
|
size_t i;
|
|
|
|
|
|
|
|
for (i=0; i<nthreads; i++)
|
2014-08-14 01:44:53 +08:00
|
|
|
threads[i] = std::move(std::thread(start, (void*)i));
|
2014-04-02 14:57:45 +08:00
|
|
|
|
|
|
|
for (i=0; i<nthreads; i++)
|
2014-08-14 01:44:53 +08:00
|
|
|
threads[i].join();
|
2014-04-02 14:57:45 +08:00
|
|
|
}
|