Initial message queue communication.
authorRafał Długołęcki <rafal@dlugolecki.net.pl>
Sat, 21 Jun 2014 10:38:00 +0000 (12:38 +0200)
committerRafał Długołęcki <rafal@dlugolecki.net.pl>
Sat, 21 Jun 2014 10:38:00 +0000 (12:38 +0200)
src/process1.c
src/process2.c
src/process3.c

index b28563f4102faf831cf12deecd2ff440eb3b0216..41e0ea4729508bc71bcdb70f7cf423ace48942f3 100644 (file)
@@ -46,6 +46,19 @@ struct message {
 
 struct message * processes = NULL;
 
+/**
+ * Message queue variables
+ */
+key_t qkey;
+int qid_input;
+
+int qid_output1;
+int qid_output2;
+
+struct queue_message {
+       int signo;
+};
+
 /**
  * Handler for signals.
  */
@@ -53,9 +66,13 @@ void sig_handler(int signo)
 {
        fprintf(stderr, "[%s] Received %s!\n", "process1", strsignal(signo));
        if (signo == SIGUSR1) {
+               fprintf(stderr, "[%s] > Notified!\n", "process3");
        }
        else if (signo == SIGTERM) {
                int i = 0;
+               struct queue_message msg;
+               msg.signo = signo;
+
                fprintf(stderr, "[%s] > Releasing resources\n", "process1");
                close(write_pipe);
                unlink(write_pipe);
@@ -65,7 +82,13 @@ void sig_handler(int signo)
                        buffer = NULL;
                }
                for (; i < 3; i++) {
-                       fprintf(stderr, "[%s] Process %d, PID: %d\n", "process3", i, processes->pids[i]);
+                       pid_t pid = processes->pids[i];
+                       fprintf(stderr, "[%s] Process %d, PID: %d\n", "process3", i, pid);
+                       // Bleh
+                       if (i != 0) {
+                               msgsnd(pid, &msg, sizeof(msg));
+                               kill(pid, SIGUSR1);
+                       }
                }
                exit(0);
        }
@@ -127,6 +150,18 @@ int main(void) {
        processes = (struct message *)shmat(shmid, NULL, 0);
        processes->pids[0] = getpid();
 
+       fprintf(stderr, "[%s] Shared pid: %d\n", "process1", getpid());
+
+       sleep(1);
+       /**
+        * Register message queue to communicate with other processes
+        */
+       qkey = getpid();
+       qid_input = msgget(qkey, IPC_CREAT | 0666);
+       
+       qid_output1 = msgget(processes->pids[1], IPC_CREAT | 0666);
+       qid_output2 = msgget(processes->pids[2], IPC_CREAT | 0666);
+       
        mkfifo(write_pipe, 0666);
 
        file_descriptor = open(write_pipe, O_WRONLY);
index 2417fe88638fd27bdc543a5d764bca6847540b87..d8c294bf6f20673ebe76684ecb8c09ca7f8dda48 100644 (file)
@@ -49,6 +49,18 @@ struct message {
 
 struct message * processes = NULL;
 
+/**
+ * Message queue variables
+ */
+key_t qkey;
+int qid_input;
+
+int qid_output1;
+int qid_output2;
+
+struct queue_message {
+       int signo;
+};
 
 /**
  * Handler for signals.
@@ -57,15 +69,25 @@ void sig_handler(int signo)
 {
        fprintf(stderr, "[%s] Received %s!\n", "process2", strsignal(signo));
        if (signo == SIGUSR1) {
+               fprintf(stderr, "[%s] > Notified!\n", "process2");
        }
        else if (signo == SIGTERM) {
                int i = 0;
+               struct queue_message msg;
+               msg.signo = signo;
+
                fprintf(stderr, "[%s] > Releasing resources\n", "process2");
                close(read_descriptor);
                close(write_descriptor);
                unlink(write_descriptor);
                for (; i < 3; i++) {
-                       fprintf(stderr, "[%s] Process %d, PID: %d\n", "process3", i, processes->pids[i]);
+                       pid_t pid = processes->pids[i];
+                       fprintf(stderr, "[%s] Process %d, PID: %d\n", "process2", i, pid);
+                       // Bleh
+                       if (i != 1) {
+                               msgsnd(pid, &msg, sizeof(msg));
+                               kill(pid, SIGUSR1);
+                       }
                }
                exit(0);
        }
@@ -130,6 +152,18 @@ int main(void) {
        processes = (struct message *)shmat(shmid, NULL, 0);
        processes->pids[1] = getpid();
 
+       fprintf(stderr, "[%s] Shared pid: %d\n", "process2", getpid());
+
+       sleep(1);
+       /**
+        * Register message queue to communicate with other processes
+        */
+       qkey = getpid();
+       qid_input = msgget(qkey, IPC_CREAT | 0666);
+       
+       qid_output1 = msgget(processes->pids[1], IPC_CREAT | 0666);
+       qid_output2 = msgget(processes->pids[2], IPC_CREAT | 0666);
+
        /* Reading from process1 */
        read_descriptor = open(read_pipe, O_RDONLY);
 
index b1b997212be53430306b69232a3c88bd7d2f3b14..54bb6587370a53648f0aecbc63a6e2b299ec5176 100644 (file)
@@ -40,6 +40,18 @@ struct message {
 
 struct message * processes = NULL;
 
+/**
+ * Message queue variables
+ */
+key_t qkey;
+int qid_input;
+
+int qid_output1;
+int qid_output2;
+
+struct queue_message {
+       int signo;
+};
 
 /**
  * Handler for signals.
@@ -48,13 +60,23 @@ void sig_handler(int signo)
 {
        fprintf(stderr, "[%s] Received %s!\n", "process3", strsignal(signo));
        if (signo == SIGUSR1) {
+               fprintf(stderr, "[%s] > Notified!\n", "process3");
        }
        else if (signo == SIGTERM) {
                int i = 0;
+               struct queue_message msg;
+               msg.signo = signo;
+
                fprintf(stderr, "[%s] > Releasing resources\n", "process3");
                close(read_descriptor);
                for (; i < 3; i++) {
-                       fprintf(stderr, "[%s] Process %d, PID: %d\n", "process3", i, processes->pids[i]);
+                       pid_t pid = processes->pids[i];
+                       fprintf(stderr, "[%s] Process %d, PID: %d\n", "process3", i, pid);
+                       // Bleh
+                       if (i != 2) {
+                               msgsnd(pid, &msg, sizeof(msg));
+                               kill(pid, SIGUSR1);
+                       }
                }
                exit(0);
        }
@@ -107,6 +129,18 @@ int main(void) {
        processes = (struct message *)shmat(shmid, NULL, 0);
        processes->pids[2] = getpid();
 
+       fprintf(stderr, "[%s] Shared pid: %d\n", "process3", getpid());
+
+       sleep(1);
+       /**
+        * Register message queue to communicate with other processes
+        */
+       qkey = getpid();
+       qid_input = msgget(qkey, IPC_CREAT | 0666);
+       
+       qid_output1 = msgget(processes->pids[1], IPC_CREAT | 0666);
+       qid_output2 = msgget(processes->pids[2], IPC_CREAT | 0666);
+
        /* Reading from process2 */
        read_descriptor = open(read_pipe, O_RDONLY);