Answered step by step
Verified Expert Solution
Link Copied!

Question

1 Approved Answer

**please do the following in c and make it compile and run. Thanks!!** In this assignment, you will create 4 processes . Each of these

**please do the following in c and make it compile and run. Thanks!!**

In this assignment, you will create 4 processes. Each of these processes will share a variable called "total". Each will increment the variable total by one to 100,000, 200,000, 300,000 and 500,000 respectively. Make sure that only the newly created child calls the function process#()

After all the children have finished, the parent process should release the shared memory and terminate. Use the "wait" function so that the parent knows precisely when each of the children finishes. The parent should print the process id of each child as the child finishes execution. Then it should release shared memory and print "End of Program".

You need to run program several times and analyze your observations (write report).

Sample output

From Process 1: counter = 270547.

From Process 2: counter = 347860.

From Process 3: counter = 400001.

From Process 4: counter = 500000.

Child with ID: 2412 has just exited.

Child with ID: 2411 has just exited.

Child with ID: 2413 has just exited.

Child with ID: 2415 has just exited.

End of Simulation.

The following are "clues" that can be used in the code, as a sort of skeleton:

Headers:

#include

#include

#include

#include

#include

#include

#include

global variable:

/* key number */

#define SHMKEY ((key_t) 1497)

typedef struct{

int value;

} shared_mem;

shared_mem *total;

and of in int main():

int shmid, pid1,pid2, pid3,pid4, ID,status;

char *shmadd;

shmadd = (char *) 0;

if ((shmid = shmget (SHMKEY, sizeof(int), IPC_CREAT | 0666)) < 0)

{

perror ("shmget");

exit (1); }

if ((total = (shared_mem *) shmat (shmid, shmadd, 0)) == (shared_mem *) -1) {

perror ("shmat");

exit (0);}

total->value = 0;

if ((pid1 = fork()) == 0)

process1();

//create additional processes

wait(&status) or waitpid(pid1, NULL, 0)

lif (shmdt(total) == -1) {

perror ("shmdt");

exit (-1); }

nshmctl(shmid, IPC_RMID, NULL);

Step by Step Solution

There are 3 Steps involved in it

Step: 1

blur-text-image

Get Instant Access to Expert-Tailored Solutions

See step-by-step solutions with expert insights and AI powered tools for academic success

Step: 2

blur-text-image

Step: 3

blur-text-image

Ace Your Homework with AI

Get the answers you need in no time with our AI-driven, step-by-step assistance

Get Started

Recommended Textbook for

Temporal Databases Research And Practice Lncs 1399

Authors: Opher Etzion ,Sushil Jajodia ,Suryanarayana Sripada

1st Edition

3540645195, 978-3540645191

More Books

Students also viewed these Databases questions

Question

1. Identify six different types of history.

Answered: 1 week ago

Question

Prepare a short profile of Henry words worth Longfellow?

Answered: 1 week ago

Question

What is RAM as far as telecommunication is concerned?

Answered: 1 week ago

Question

Question 1: What is reproductive system? Question 2: What is Semen?

Answered: 1 week ago

Question

Describe the sources of long term financing.

Answered: 1 week ago