/******************************************************************************* * The BYTE UNIX Benchmarks - Release 3 * Module: context1.c SID: 3.3 5/15/91 19:30:18 * ******************************************************************************* * Bug reports, patches, comments, suggestions should be sent to: * * Ben Smith, Rick Grehan or Tom Yager * ben@bytepb.byte.com rick_g@bytepb.byte.com tyager@bytepb.byte.com * ******************************************************************************* * Modification Log: * $Header: context1.c,v 3.4 87/06/22 14:22:59 kjmcdonell Beta $ * August 28, 1990 - changed timing routines--now returns total number of * iterations in specified time period * October 22, 1997 - code cleanup to remove ANSI C compiler warnings * Andy Kahn * ******************************************************************************/ char SCCSid[] = "@(#) @(#)context1.c:3.3 -- 5/15/91 19:30:18"; /* * Context switching via synchronized unbuffered pipe i/o * */ #ifdef MINIX #include #endif #ifdef LINUX #include #endif #include #include #include #include "timeit.c" unsigned long iter; #ifdef MINIX pid_t child; #endif void report(int sig) { fprintf(stderr, "COUNT|%lu|1|lps\n", iter); #ifdef MINIX kill(child, SIGKILL); #endif exit(0); } int main(int argc, char *argv[]) { int duration; unsigned long check; int p1[2], p2[2]; if (argc != 2) { fprintf(stderr, "Usage: context duration\n"); exit(1); } duration = atoi(argv[1]); /* set up alarm call */ iter = 0; wake_me(duration, report); if (pipe(p1) || pipe(p2)) { perror("pipe create failed"); exit(1); } #ifndef MINIX if (fork()) { /* parent process */ #else if ((child = fork())) { #endif /* master, write p1 & read p2 */ close(p1[0]); close(p2[1]); while (1) { if (write(p1[1], (char *)&iter, sizeof(iter)) != sizeof(iter)) { if ((errno != 0) && (errno != EINTR)) perror("master write failed"); exit(1); } if (read(p2[0], (char *)&check, sizeof(check)) != sizeof(check)) { if ((errno != 0) && (errno != EINTR)) perror("master read failed"); exit(1); } if (check != iter) { fprintf(stderr, "Master sync error: expect %lu, got %lu\n", iter, check); exit(2); } iter++; } } else { /* child process */ unsigned long iter1; iter1 = 0; /* slave, read p1 & write p2 */ close(p1[1]); close(p2[0]); while (1) { if (read(p1[0], (char *)&check, sizeof(check)) != sizeof(check)) { if ((errno != 0) && (errno != EINTR)) perror("slave read failed"); exit(1); } if (check != iter1) { fprintf(stderr, "Slave sync error: expect %lu, got %lu\n", iter, check); exit(2); } if (write(p2[1], (char *)&iter1, sizeof(iter1)) != sizeof(check)) { if ((errno != 0) && (errno != EINTR)) perror("slave write failed"); exit(1); } iter1++; } } }