123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 |
- /* -*- mode:c; c-file-style:"k&r"; c-basic-offset: 4; tab-width:4; indent-tabs-mode:nil; mode:auto-fill; fill-column:78; -*- */
- /* vim: set ts=4 sw=4 et tw=78 fo=cqt wm=0: */
- #include <stdlib.h>
- #include <stdio.h>
- #include <unistd.h>
- #include <sys/wait.h>
- #include <signal.h>
- #include <sys/time.h>
- int firstpid;
- int secondpid;
- #define NTRIES 10000
- int count = 0;
- void sighand1 (int signum, siginfo_t * sinfo, void * ucontext)
- {
- count++;
- printf("firstpid receive a SIGUSR from %d (count = %d)\n",
- sinfo->si_pid, count);
- kill(secondpid, SIGUSR1);
- }
- void sighand2 (int signum, siginfo_t * sinfo, void * ucontext)
- {
- count++;
- printf("secondpid receive a SIGUSR from %d (count = %d)\n",
- sinfo->si_pid, count);
- kill(firstpid, SIGUSR1);
- }
- int main(int argc, char ** argv)
- {
- int pipes[2];
- pipe(pipes);
- firstpid = fork();
- if (firstpid < 0) {
- printf("fork failed\n");
- return -1;
- }
- if (firstpid == 0) {
- close(pipes[1]);
- struct timeval start_time;
- gettimeofday(&start_time, NULL);
- signal(SIGUSR1, (void *) sighand1);
- read(pipes[0], &secondpid, sizeof(int));
- kill(secondpid, SIGUSR1);
- while (count < NTRIES - 1)
- sleep(1);
- struct timeval finish_time;
- gettimeofday(&finish_time, NULL);
- printf("time spent: %lu microsecond\n",
- (finish_time.tv_sec * 1000000L + finish_time.tv_usec)
- - (start_time.tv_sec * 1000000L + start_time.tv_usec));
- return 0;
- }
- close(pipes[0]);
- secondpid = fork();
- if (secondpid < 0) {
- printf("fork failed\n");
- return -1;
- }
- if (secondpid == 0) {
- struct timeval start_time;
- gettimeofday(&start_time, NULL);
- signal(SIGUSR1, (void *) sighand2);
- secondpid = getpid();
- write(pipes[1], &secondpid, sizeof(int));
- while (count < NTRIES)
- sleep(1);
- struct timeval finish_time;
- gettimeofday(&finish_time, NULL);
- printf("time spent: %lu microsecond\n",
- (finish_time.tv_sec * 1000000L + finish_time.tv_usec)
- - (start_time.tv_sec * 1000000L + start_time.tv_usec));
- return 0;
- }
- waitpid(-1, NULL, 0);
- waitpid(-1, NULL, 0);
- return 0;
- }
|