How to send signal from child under certain condition?
up vote
0
down vote
favorite
I created a program. It is supposed to read signals from second terminal window and react depending on which signal and to which process it is sent. For example, my child process 1 should ignore all signals but SIGUSR1 and SIGXFSZ. When SIGUSR1 is called, it should print some information (which i did) and end. However, when SIGXFSZ is called, it should send the same signal to parrent process. How can I do that?
Should
if(sig == SIGXFSZ) {
kill(number, getppid()); //where number is number for SIGXFSZ signal
}
placed in sig_handler function work?
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <unistd.h>
void signals_handler(int signal){
psignal(signal,"nOtrzymalem sygnal");
printf("Numer sygnalu to: %dn", signal);
kill(getppid(), signal);
return;
}
void sig_handler (int sig){
signal(SIGUSR1, sig_handler);
sigset_t mask_set;
sigset_t old_set;
sigfillset(&mask_set);
sigdelset(&mask_set, SIGINT);
// sigdelset(&mask_set, SIGUSR1);
sigprocmask(SIG_SETMASK, &mask_set, &old_set);
// psignal(sig, "nOdebralem sygnal");
printf("Numer sygnału: %d. ^C mnie nie zamknie! %dn", sig, getppid());
printf("HEHHEHEHEHE");
for (;;)
pause(); //czy teraz zostanie przyjęty i obsłużony SIGUSR1?
sigprocmask(SIG_SETMASK, &old_set, NULL);
return;
}
int main(void) {
printf("PID: %dn", getpid());
/* zastawiamy "pulapke" na sygnal */
signal(SIGINT, signals_handler);
if(fork() == 0) { //forking
printf("PPID: %dn", getpid());
signal(SIGUSR1, sig_handler);
sleep(100);
exit(0);
}
if(fork() == 0) { //forking
printf("PPID: %dn", getpid());
signal(SIGUSR1, sig_handler);
sleep(100);
exit(0);
}
/* petla nieskonczona */
for(;;)
pause();
return 0;
}
c unix signals fork kill
add a comment |
up vote
0
down vote
favorite
I created a program. It is supposed to read signals from second terminal window and react depending on which signal and to which process it is sent. For example, my child process 1 should ignore all signals but SIGUSR1 and SIGXFSZ. When SIGUSR1 is called, it should print some information (which i did) and end. However, when SIGXFSZ is called, it should send the same signal to parrent process. How can I do that?
Should
if(sig == SIGXFSZ) {
kill(number, getppid()); //where number is number for SIGXFSZ signal
}
placed in sig_handler function work?
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <unistd.h>
void signals_handler(int signal){
psignal(signal,"nOtrzymalem sygnal");
printf("Numer sygnalu to: %dn", signal);
kill(getppid(), signal);
return;
}
void sig_handler (int sig){
signal(SIGUSR1, sig_handler);
sigset_t mask_set;
sigset_t old_set;
sigfillset(&mask_set);
sigdelset(&mask_set, SIGINT);
// sigdelset(&mask_set, SIGUSR1);
sigprocmask(SIG_SETMASK, &mask_set, &old_set);
// psignal(sig, "nOdebralem sygnal");
printf("Numer sygnału: %d. ^C mnie nie zamknie! %dn", sig, getppid());
printf("HEHHEHEHEHE");
for (;;)
pause(); //czy teraz zostanie przyjęty i obsłużony SIGUSR1?
sigprocmask(SIG_SETMASK, &old_set, NULL);
return;
}
int main(void) {
printf("PID: %dn", getpid());
/* zastawiamy "pulapke" na sygnal */
signal(SIGINT, signals_handler);
if(fork() == 0) { //forking
printf("PPID: %dn", getpid());
signal(SIGUSR1, sig_handler);
sleep(100);
exit(0);
}
if(fork() == 0) { //forking
printf("PPID: %dn", getpid());
signal(SIGUSR1, sig_handler);
sleep(100);
exit(0);
}
/* petla nieskonczona */
for(;;)
pause();
return 0;
}
c unix signals fork kill
It's not clear what you're after --signals_handler()
andkill(getppid(), signal)
will be run from the parent process, not from the children. The children will just printmnie nie zamknie
, etc on receivingSIGUSR1
.
– mosvy
Nov 22 at 9:32
add a comment |
up vote
0
down vote
favorite
up vote
0
down vote
favorite
I created a program. It is supposed to read signals from second terminal window and react depending on which signal and to which process it is sent. For example, my child process 1 should ignore all signals but SIGUSR1 and SIGXFSZ. When SIGUSR1 is called, it should print some information (which i did) and end. However, when SIGXFSZ is called, it should send the same signal to parrent process. How can I do that?
Should
if(sig == SIGXFSZ) {
kill(number, getppid()); //where number is number for SIGXFSZ signal
}
placed in sig_handler function work?
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <unistd.h>
void signals_handler(int signal){
psignal(signal,"nOtrzymalem sygnal");
printf("Numer sygnalu to: %dn", signal);
kill(getppid(), signal);
return;
}
void sig_handler (int sig){
signal(SIGUSR1, sig_handler);
sigset_t mask_set;
sigset_t old_set;
sigfillset(&mask_set);
sigdelset(&mask_set, SIGINT);
// sigdelset(&mask_set, SIGUSR1);
sigprocmask(SIG_SETMASK, &mask_set, &old_set);
// psignal(sig, "nOdebralem sygnal");
printf("Numer sygnału: %d. ^C mnie nie zamknie! %dn", sig, getppid());
printf("HEHHEHEHEHE");
for (;;)
pause(); //czy teraz zostanie przyjęty i obsłużony SIGUSR1?
sigprocmask(SIG_SETMASK, &old_set, NULL);
return;
}
int main(void) {
printf("PID: %dn", getpid());
/* zastawiamy "pulapke" na sygnal */
signal(SIGINT, signals_handler);
if(fork() == 0) { //forking
printf("PPID: %dn", getpid());
signal(SIGUSR1, sig_handler);
sleep(100);
exit(0);
}
if(fork() == 0) { //forking
printf("PPID: %dn", getpid());
signal(SIGUSR1, sig_handler);
sleep(100);
exit(0);
}
/* petla nieskonczona */
for(;;)
pause();
return 0;
}
c unix signals fork kill
I created a program. It is supposed to read signals from second terminal window and react depending on which signal and to which process it is sent. For example, my child process 1 should ignore all signals but SIGUSR1 and SIGXFSZ. When SIGUSR1 is called, it should print some information (which i did) and end. However, when SIGXFSZ is called, it should send the same signal to parrent process. How can I do that?
Should
if(sig == SIGXFSZ) {
kill(number, getppid()); //where number is number for SIGXFSZ signal
}
placed in sig_handler function work?
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <unistd.h>
void signals_handler(int signal){
psignal(signal,"nOtrzymalem sygnal");
printf("Numer sygnalu to: %dn", signal);
kill(getppid(), signal);
return;
}
void sig_handler (int sig){
signal(SIGUSR1, sig_handler);
sigset_t mask_set;
sigset_t old_set;
sigfillset(&mask_set);
sigdelset(&mask_set, SIGINT);
// sigdelset(&mask_set, SIGUSR1);
sigprocmask(SIG_SETMASK, &mask_set, &old_set);
// psignal(sig, "nOdebralem sygnal");
printf("Numer sygnału: %d. ^C mnie nie zamknie! %dn", sig, getppid());
printf("HEHHEHEHEHE");
for (;;)
pause(); //czy teraz zostanie przyjęty i obsłużony SIGUSR1?
sigprocmask(SIG_SETMASK, &old_set, NULL);
return;
}
int main(void) {
printf("PID: %dn", getpid());
/* zastawiamy "pulapke" na sygnal */
signal(SIGINT, signals_handler);
if(fork() == 0) { //forking
printf("PPID: %dn", getpid());
signal(SIGUSR1, sig_handler);
sleep(100);
exit(0);
}
if(fork() == 0) { //forking
printf("PPID: %dn", getpid());
signal(SIGUSR1, sig_handler);
sleep(100);
exit(0);
}
/* petla nieskonczona */
for(;;)
pause();
return 0;
}
c unix signals fork kill
c unix signals fork kill
asked Nov 21 at 18:15
Michał
12
12
It's not clear what you're after --signals_handler()
andkill(getppid(), signal)
will be run from the parent process, not from the children. The children will just printmnie nie zamknie
, etc on receivingSIGUSR1
.
– mosvy
Nov 22 at 9:32
add a comment |
It's not clear what you're after --signals_handler()
andkill(getppid(), signal)
will be run from the parent process, not from the children. The children will just printmnie nie zamknie
, etc on receivingSIGUSR1
.
– mosvy
Nov 22 at 9:32
It's not clear what you're after --
signals_handler()
and kill(getppid(), signal)
will be run from the parent process, not from the children. The children will just print mnie nie zamknie
, etc on receiving SIGUSR1
.– mosvy
Nov 22 at 9:32
It's not clear what you're after --
signals_handler()
and kill(getppid(), signal)
will be run from the parent process, not from the children. The children will just print mnie nie zamknie
, etc on receiving SIGUSR1
.– mosvy
Nov 22 at 9:32
add a comment |
active
oldest
votes
active
oldest
votes
active
oldest
votes
active
oldest
votes
active
oldest
votes
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53418270%2fhow-to-send-signal-from-child-under-certain-condition%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
It's not clear what you're after --
signals_handler()
andkill(getppid(), signal)
will be run from the parent process, not from the children. The children will just printmnie nie zamknie
, etc on receivingSIGUSR1
.– mosvy
Nov 22 at 9:32