summaryrefslogtreecommitdiffstats
path: root/lldb/test/expression_command/timeout/wait-a-while.c
blob: f3475fc3ff2dc3101fa1d56575a6d6911d1267ca (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#include <stdio.h>
#include <unistd.h>
#include <sys/time.h>
#include <stdint.h>

int 
wait_a_while (useconds_t interval)
{
  int num_times = 0;
  int return_value = 1;

  struct timeval start_time;
  gettimeofday(&start_time, NULL);
  uint64_t target = start_time.tv_sec * 1000000 + start_time.tv_usec + interval;

  while (1)
    {
      num_times++;
      return_value = usleep (interval);
      if (return_value != 0)
        {
          struct timeval now;
          gettimeofday(&now, NULL);
          interval = target - now.tv_sec * 1000000 + now.tv_usec;
        }
      else
        break;
    }
  return num_times;
}

int
main (int argc, char **argv)
{
  printf ("stop here in main.\n");
  int num_times = wait_a_while (argc * 1000);
  printf ("Done, took %d times.\n", num_times);

  return 0;

}
OpenPOWER on IntegriCloud