[완료] sigprocmask() 함수에 관한 질문입니다.
글쓴이: beggarstar / 작성시간: 화, 2009/03/24 - 5:43오후
리눅스 환경에서 시스템프로그래밍을 공부 하고 있습니다.
시그널 부분에서 sigprocmask() 함수 동작이 이해가 되지 않아 질문 드립니다.
아래 코드는 조인시 위키/시스템프로그래밍/시그널/SignalHow 에서 참조했습니다.
#include ... void sig_int( int signo ); void sig_usr( int signo ); int main() { int i = 0; struct sigaction intsig, usrsig; usrsig.sa_handler = sig_usr; usrsig.sa_flags = 0; sigemptyset( &usrsig.sa_mask ); intsig.sa_handler = sig_int; intsig.sa_flags = 0; sigemptyset( &intsig.sa_mask ); if ( sigaction( SIGINT, &intsig, 0 ) == -1 ) { printf( "signal(SIGALRM) error" ); return -1; } if ( sigaction( SIGUSR2, &usrsig, 0 ) == -1 ) { printf( "signal(SIGUSR2) error" ); return -1; } while( 1 ) { printf( "%d\n", i ); i++; sleep( 1 ); } } void sig_int( int signo ) { sigset_t sigset, oldset; sigfillset( &sigset ); // 새로들어오는 모든 시그널에 대해서 block 한다. if ( sigprocmask( SIG_BLOCK, &sigset, &oldset ) < 0 ) { printf( "sigprocmask %d error \n", signo ); } fprintf( stderr, "SIGINT !!!!\n" ); sleep( 5 ); } void sig_usr( int signo ) { printf( "SIG_USR2\n" ); }
위 코드는 SIGINT 시그널에 대한 핸들러 처리 중에 sigprocmask() 함수를 이용함으로서 다른 모든 시그널을 BLOCK 해
핸들러 실행의 원자성을 보장하는 예제 입니다.
핸들러 안에서 sigprocmask( SIG_BLOCK, &sigset, &oldset ) 실행을 통해 시그널들을 BLOCK하고 핸들러가 리턴하면 BLOCK 된 시그널들이 다시 UNBLOCK 되 대기중이던 다른 시그널에 대한 처리를 하게 됩니다.
즉 sigprocmask() 함수를 통해 블럭된 시그널은 핸들러가 리턴 되는 순간 언블럭 되는데 이 부분을 이해 할 수가 없군요
sigprocmask( SIG_UNBLOCK, ... ) 이런 문구를 코드 어느 부분이든 넣어야 동작하지 않을까 하고 생각했는데 제 오산이더군요...
정리하면, 핸들러가 리턴 되는 순간 sigprocmask()로 블럭 됐던 시그널들이 전부 언블럭 되는데 이와 관련된 언블럭 동작 조건( 혹시 핸들러 동작중 변경된 시그널 설정은 핸들러 리턴과 동시에 원상 복귀 되는지? )이 궁금합니다.
Forums:
http://www.cs.utah.edu/dept/o
http://www.cs.utah.edu/dept/old/texinfo/glibc-manual-0.02/library_21.html#SEC373
답변감사합니다.
In any case, when the handler returns, the system restores the mask that was in place before the handler was entered.
댓글 달기