[질문] 도저히 원인을 모르겟네요.
글쓴이: ddangkyoung / 작성시간: 화, 2009/06/02 - 9:53오후
간단히 fork를 수행해서 sigtrap이라는 새로운 자식프로세스를 생성한후
sleep(1)으로 1초간 자면
그사이 자식프로세스가 자신의 PID와 매 tick을 1초간 출력하고
자식프로세스에게 kill 명령으로 SIGCONT와 SIGTSTP 시그널을 보내면
그것을 단순히 출력하도록 만들어져있습니다.
그런데 SIGCONT와 SIGTSTP 시그널이 출력이 안되네요.
첨부한것이 예시 파일입니다.
#include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <string.h> #include <errno.h> #include <sys/wait.h> #include <sys/types.h> #include <signal.h> #include <stdio.h> int main(int argc, char *argv[]) { int processID; int pid = fork(); int check = 10; while(check >0) { if(pid == 0) { execlp("/mnt/hgfs/huguo/test","test", "6", NULL); } else if(pid >0) { printf("%d\n",pid); processID= pid; kill(processID,SIGCONT)); sleep(1); kill(processID,SIGTSTP); } else { perror("fork error : "); exit(0); } } return 0; }
아래는 자식프로세스의 코드입니다.
/* OS Exercises - project 2 sigtrap - report system signals applied to process usage: sigtrap [n] [n] is time for process to exist - default 20 seconds program ticks away reporting process id and tick count every second. the program traps and reports the following signals: SIGINT, SIGQUIT, SIGHUP, SIGTERM, SIGABRT, SIGCONT, SIGTSTP program can not trap SIGSTOP or SIGKILL to help identify specific processes, the program uses the process id to select one of 32 colour combinations for the display to an ASCC terminal. output is to stdout (set in #define), reset to BLACK and NORMAL and flushed after every printf. ******************************************************************** version: 1.0 date: December 2003 author: Dr Ian G Graham, <a href="mailto:ian.graham@griffith.edu.au" rel="nofollow">ian.graham@griffith.edu.au</a> history: derived from original simple sleep process (Exercise 1) *******************************************************************/ #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <signal.h> #include <ctype.h> #include <sys/types.h> #include <sys/time.h> #include <sys/times.h> #include <limits.h> #include <sys/resource.h> #ifndef TRUE #define TRUE 1 #endif #ifndef FALSE #define FALSE 0 #endif static void SignalHandler(int); void PrintUsage(char*); // for error exit & info char *StripPath(char*); // strip path from filename #define DEFAULT_TIME 20 #define DEFAULT_OP stdout #define DEFAULT_NAME "sigtrap" #define BLACK "\033[30m" // foreground colours #define RED "\033[31m" #define GREEN "\033[32m" #define YELLOW "\033[33m" #define BLUE "\033[34m" #define MAGENTA "\033[35m" #define CYAN "\033[36m" #define WHITE "\033[37m" #define ON_BLACK "\033[40m" // background colours #define ON_RED "\033[41m" #define ON_GREEN "\033[42m" #define ON_YELLOW "\033[43m" #define ON_BLUE "\033[44m" #define ON_MAGENTA "\033[45m" #define ON_CYAN "\033[46m" #define ON_WHITE "\033[47m" #define NORMAL "\033[0m" // not bold/underline/flashing/... char * colours [] = { BLACK ON_WHITE, CYAN ON_RED, GREEN ON_MAGENTA, BLUE ON_YELLOW, BLACK ON_CYAN, WHITE ON_RED, BLUE ON_GREEN, YELLOW ON_MAGENTA, BLACK ON_GREEN, YELLOW ON_RED, BLUE ON_CYAN, MAGENTA ON_WHITE, BLACK ON_YELLOW, GREEN ON_RED, BLUE ON_WHITE, CYAN ON_MAGENTA, WHITE ON_BLACK, RED ON_CYAN, MAGENTA ON_GREEN, YELLOW ON_BLUE, CYAN ON_BLACK, RED ON_WHITE, GREEN ON_BLUE, MAGENTA ON_YELLOW, GREEN ON_BLACK, RED ON_YELLOW, CYAN ON_BLUE, WHITE ON_MAGENTA, YELLOW ON_BLACK, RED ON_GREEN, WHITE ON_BLUE, MAGENTA ON_CYAN }; #define N_COLOUR 32 char * colour; // choice of colour for this process FILE * output;// = DEFAULT_OP; static int signal_SIGINT = FALSE; // flags set by signal handler static int signal_SIGQUIT = FALSE; // (all response done in main process static int signal_SIGHUP = FALSE; // rather than in interrupt routine) static int signal_SIGTERM = FALSE; static int signal_SIGABRT = FALSE; static int signal_SIGCONT = FALSE; static int signal_SIGTSTP = FALSE; /*******************************************************************/ int main(int argc, char *argv[]) { output = stdout; pid_t pid = getpid(); // get process id int i, cycle, rc; long clktck = sysconf(_SC_CLK_TCK); struct tms t; clock_t starttick, stoptick; sigset_t mask; colour = colours[pid % N_COLOUR]; // select colour for this process if (argc > 2 || (argc == 2 && !isdigit((int)argv[1][0]))) PrintUsage(argv[0]); fprintf(output,"%s%7d; START" BLACK NORMAL "\n", colour, (int) pid); fflush(output); signal (SIGINT, SignalHandler); // hook up signal handler signal (SIGQUIT, SignalHandler); signal (SIGHUP, SignalHandler); signal (SIGTERM, SignalHandler); signal (SIGABRT, SignalHandler); // signal (SIGCONT, SignalHandler); // do this intrinsically after return from SIGTSTP // due to Darwin/BSD inconsistent SIGCONT behaviour signal (SIGTSTP, SignalHandler); rc = setpriority(PRIO_PROCESS, 0, 20); // be nice, lower priority by 20 cycle = argc < 2 ? DEFAULT_TIME : atoi(argv[1]); // get tick count if (cycle <= 0) cycle = 1; for (i = 0; i < cycle;) { // tick if (signal_SIGCONT) { signal_SIGCONT = FALSE; fprintf(output,"%s%7d; SIGCONT" BLACK NORMAL "\n", colour, (int) pid); fflush(output); } starttick = times (&t); // use timer to ascertain whether 'tick' should be rc = sleep(1); // reported stoptick = times (&t); if (rc == 0 || (stoptick-starttick) > clktck/2) fprintf(output,"%s%7d; tick %d" BLACK NORMAL "\n", colour, (int) pid, ++i); if (signal_SIGINT) { fprintf(output,"%s%7d; SIGINT" BLACK NORMAL "\n", colour, (int) pid); exit(0); } if (signal_SIGQUIT) { fprintf(output,"%s%7d; SIGQUIT" BLACK NORMAL "\n", colour, (int) pid); exit(0); } if (signal_SIGHUP) { fprintf(output,"%s%7d; SIGHUP" BLACK NORMAL "\n", colour, (int) pid); exit(0); } if (signal_SIGTSTP) { signal_SIGTSTP = FALSE; fprintf(output,"%s%7d; SIGTSTP" BLACK NORMAL "\n", colour, (int) pid); fflush(output); sigemptyset (&mask); // unblock SIGSTP if necessary (BSD/OS X) sigaddset (&mask, SIGTSTP); sigprocmask (SIG_UNBLOCK, &mask, NULL); signal(SIGTSTP, SIG_DFL); // reset trap to default raise (SIGTSTP); // now suspend ourselves signal(SIGTSTP, SignalHandler); // reset trap on return from suspension signal_SIGCONT = TRUE; // set flag here rather than trap signal } if (signal_SIGABRT) { fprintf(output,"%s%7d; SIGABRT" BLACK NORMAL "\n", colour, (int) pid); fflush(output); signal (SIGABRT, SIG_DFL); raise (SIGABRT); } if (signal_SIGTERM) { fprintf(output,"%s%7d; SIGTERM" BLACK NORMAL "\n", colour, (int) pid); exit(0); } fflush(output); } exit(0); } /****************************************************************** static void SignalHandler(int sig) trap and report the following signals: SIGINT, SIGQUIT, SIGHUP, SIGTERM, SIGABRT, SIGCONT, SIGTSTP program can not trap SIGSTOP or SIGKILL . Note minimal time in signal handler *******************************************************************/ static void SignalHandler(int sig) // trap signals from shell/system { switch (sig) { case SIGINT: signal_SIGINT = TRUE; break; case SIGQUIT: signal_SIGQUIT = TRUE; break; case SIGHUP: signal_SIGHUP = TRUE; break; case SIGCONT: signal_SIGCONT = TRUE; break; case SIGTSTP: signal_SIGTSTP = TRUE; break; case SIGABRT: signal_SIGABRT = TRUE; break; case SIGTERM: signal_SIGTERM = TRUE; break; } } /******************************************************************* void PrintUsage(char * pgmName) print program usage pgmName - program name if NULL defaults to DEFAULT_NAME *******************************************************************/ void PrintUsage(char * pgmName) { char * actualName; if (!(actualName = StripPath(pgmName))) actualName = DEFAULT_NAME; printf("\n" " program: %s - trap and report process control signals\n\n" " usage:\n\n" " %s [seconds]\n\n" " where [seconds] is the lifetime of the program - default = 20s.\n\n" " the program sleeps for a second, reports process id and tick count\n" " before sleeping again. any process control signals: SIGINT, SIGQUIT\n" " SIGHUP, SIGTERM, SIGABRT, SIGCONT, SIGTSTP, are trapped and\n" " reported before being actioned.\n\n", actualName, actualName ); exit(127); } /******************************************************************* char * StripPath(char * pathname); strip path from file name pathname - file name, with or without leading path returns pointer to file name part of pathname if NULL or pathname is a directory ending in a '/' returns NULL *******************************************************************/ char * StripPath(char * pathname) { char * filename = pathname; if (filename && *filename) { // non-zero length string filename = strrchr(filename, '/'); // look for last '/' if (filename) // found it if (*(++filename)) // AND file name exists return filename; else return NULL; else return pathname; // no '/' but non-zero length string } // original must be file name only return NULL; }
File attachments:
첨부 | 파일 크기 |
---|---|
test.jpg | 11.53 KB |
Forums:
댓글 달기