Enable AMD64 SHA512 implementations for WIN64
[libgcrypt.git] / cipher / test-getrusage.c
1 #include <stdio.h>
2 #include <stdlib.h>
3 #include <sys/resource.h>
4
5 int
6 main (int argc, char **argv)
7 {
8   struct rusage buf;
9
10   if (argc > 1)
11     {
12       system (argv[1]);
13
14       if (getrusage (RUSAGE_CHILDREN, &buf ))
15         {
16           perror ("getrusage");
17           return 1;
18         }
19     }
20   else
21     {
22       if (getrusage (RUSAGE_SELF, &buf ))
23         {
24           perror ("getrusage");
25           return 1;
26         }
27     }
28
29   printf ("ru_utime   = %ld.%06ld\n",
30           buf.ru_utime.tv_sec, buf.ru_utime.tv_usec);
31   printf ("ru_stime   = %ld.%06ld\n",
32           buf.ru_stime.tv_sec, buf.ru_stime.tv_usec);
33   printf ("ru_maxrss  = %ld\n", buf.ru_maxrss   );
34   printf ("ru_ixrss   = %ld\n", buf.ru_ixrss    );
35   printf ("ru_idrss   = %ld\n", buf.ru_idrss    );
36   printf ("ru_isrss   = %ld\n", buf.ru_isrss    );
37   printf ("ru_minflt  = %ld\n", buf.ru_minflt   );
38   printf ("ru_majflt  = %ld\n", buf.ru_majflt   );
39   printf ("ru_nswap   = %ld\n", buf.ru_nswap    );
40   printf ("ru_inblock = %ld\n", buf.ru_inblock  );
41   printf ("ru_oublock = %ld\n", buf.ru_oublock  );
42   printf ("ru_msgsnd  = %ld\n", buf.ru_msgsnd   );
43   printf ("ru_msgrcv  = %ld\n", buf.ru_msgrcv   );
44   printf ("ru_nsignals= %ld\n", buf.ru_nsignals );
45   printf ("ru_nvcsw   = %ld\n", buf.ru_nvcsw    );
46   printf ("ru_nivcsw  = %ld\n", buf.ru_nivcsw   );
47
48   return 0;
49 }
50
51
52 /* Codesnippet for debugging in random.c. */
53 #if 0
54 static void
55 collect_rusage_stats (struct rusage *rb)
56 {
57   static int idx;
58   static struct rusage buf[100];
59
60   if (!rb)
61     {
62       int i;
63
64       fprintf (stderr, "ru_utime   ru_stime   ru_minflt  ru_nvcsw  ru_nivcsw\n");
65       for (i=0; i < idx; i++)
66         fprintf (stderr, "%ld.%06ld   %ld.%06ld %5ld       %5ld      %5ld\n",
67                  buf[i].ru_utime.tv_sec, buf[i].ru_utime.tv_usec,
68                  buf[i].ru_stime.tv_sec, buf[i].ru_stime.tv_usec,
69                  buf[i].ru_minflt,
70                  buf[i].ru_nvcsw,
71                  buf[i].ru_nivcsw);
72     }
73   else if (idx < DIM(buf))
74     {
75       buf[idx++] = *rb;
76     }
77 }
78 #endif
79 /*
80  void
81  _gcry_random_dump_stats()
82  {
83 @@ -233,8 +261,11 @@
84                   rndstats.naddbytes, rndstats.addbytes,
85         rndstats.mixkey, rndstats.ngetbytes1, rndstats.getbytes1,
86                     rndstats.ngetbytes2, rndstats.getbytes2 );
87 +
88 +    collect_rusage_stats (NULL);
89  }
90
91 ========
92
93      getrusage (RUSAGE_SELF, &buf );
94 +    collect_rusage_stats (&buf);
95      add_randomness( &buf, sizeof buf, 1 );
96      memset( &buf, 0, sizeof buf );
97    }
98
99 */