Answered step by step
Verified Expert Solution
Link Copied!

Question

1 Approved Answer

Course Project: Notification - Based Inter - Process Communication Project description In this project, you are required to implement a new IPC method called Notification

Course Project: Notification-Based Inter-Process Communication
Project description
In this project, you are required to implement a new IPC method called Notification-Based IPC (NIPC). A NIPC instance is a system resource identified by a unique key. Any process that has the key may access the NIPC instance to send/receive messages. The procedure to use a NIPC instance is as follows:
A process opens a NIPC instance using its key.
A process subscribes under a specific type )>(0 to the opened NIPC instance to receive messages
A process may send messages to an opened NIPC instance using any of the following:
Broadcast: message is sent to all subscribed processes.
Multicast: message is sent to all subscribed processes of certain type.
Unicast: message is sent to a specific subscribed processes.
When a message is sent to the NIPC instance, all intended subscribers are notified. The notified process then have the choice of reading the message or ignoring it.
Implementation details
You are required to implement the following functions and submit a library named nipc. h(along with its . c file). Make sure you perform all necessary testing before submitting the code.
int nipc_create(key_t _key);
Description : This function creates a NIPC instance that has a key _key. If a NIPC instance with the same key exists, the function fails.
Return value : 0 on success, -1 on failures.
Errors : On failure, errno is set to an appropriate error value. You may define any errors you may need.
int nipc_get (key_t_ key)
Description : This function opens a NIPC instance whose key is _key.
Return value : If the instance exists, it returns a unique positive non-zero integer to identify the instance within the process. Otherwise, it returns -1.
Errors : On failure, errno is set to an appropriate error value. You may define any errors you may need.
int nipc_subscribe(int id, long type, void (handler*)(struct nipc_message*));
Description : This function subscribes the calling process to the opened NIPC instance identified by id under the specified type "type". The function handler is invoked upon any notification from the NIPC instance.
1
Return value : The function returns 0 on success, and -1 otherwise.
Errors : On failure, errno is set to an appropriate error value. You may define any errors you may need.
4. int nipc_send(int id, struct nipc_message msg, long type);
Description : This function sends the message msg to the NIPC instance identified by id. If type =0, the message is treated as a broadcast. If type >0, the message is treated as a unicast and type is the PID of the receiver. If type 0, the message is treated as a multicast to all receivers subscribed to type |type|. The function sends notifications and delivers the message to the intended receivers.
image text in transcribed

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

Database Concepts

Authors: David M. Kroenke, David J. Auer

7th edition

133544621, 133544626, 0-13-354462-1, 978-0133544626

More Books

Students also viewed these Databases questions

Question

What are the key events and dates in the dividend payment process?

Answered: 1 week ago

Question

What is organizational flattening? Why is it practiced?

Answered: 1 week ago