EBK COMPUTER SYSTEMS
EBK COMPUTER SYSTEMS
3rd Edition
ISBN: 8220101459107
Author: O'HALLARON
Publisher: YUZU
Question
Book Icon
Chapter 12, Problem 12.20HW
Program Plan Intro

Readers-Writers problem:

  • The readers-writers interactions would happen frequently in real systems.
  • It has some variations; each is centered on priority of writers and readers.
  • The details for “first readers-writers problem” is displayed below:
    • This problem favors readers.
    • It needs that no reader must be kept waiting lest a writer has already been granted approval to use object.
    • There should be no reader waiting due to waiting of writer.
  • The  details for  “second readers-writers problem” is displayed below:
    • This problem favors writers.
    • It requires that after a writer is set to write, it performs write as fast as possible.
    • A reader arriving after writer should wait, even if writer is also waiting.
  • The “w” semaphore controls access to critical sections that access shared object.
  • The “mutex” semaphore would protect admittance to shared variable “readcnt”.
  • It counts number of readers currently in critical section.
  • A writer locks “w” mutex each time it would enter critical section and unlocks it each time it leaves.
  • This guarantees that there exists at most one writer in critical section at any time point.
  • The first reader who enter critical section locks “w” and last reader to leave critical section unlocks it.
  • The “w” mutex is ignored by readers who enter and leave while other readers are present.
  • A correct solution to either of readers-writers problem could result in starvation.
  • A thread is been blocked indefinitely and is failed from making progress.

Expert Solution & Answer
Check Mark

Explanation of Solution

C code for readers-writers problem:

//Include libraries

#include <stdio.h>

#include "csapp.h"

//Define constants

#define WrteLmt 100000

#define Pple 20

#define N 5

//Declare variable

static int readtms;

//Declare variable

static int writetms;

//Declare semaphore variable

sem_t mtx;

//Declare semaphore variable

sem_t rdrcnt;

//Declare reader method

void *reader(void *vargp)

{

//Loop

while (1)

{

//P operation

P(&rdrcnt);

//P operation

P(&mtx);

//Increment variable

readtms++;

//V operation

V(&mtx);

//V operation

V(&rdrcnt);

}

}

//Declare writer method

void *writer(void *vargp)

{

//Loop

while (1)

{

//P operation

P(&mtx);

//Increment value

writetms++;

//If condition satisfies

if (writetms == WrteLmt)

{

//Display

printf("read/write: %d/%d\n", readtms, writetms);

//Exit

exit(0);

}

//V operation

V(&mtx);

}

}

//Declare init method

void init(void)

{

//Declare variables

readtms = 0;

//Declare variables

writetms = 0;

//Call method

Sem_init(&mtx, 0, 1);

//Call method

Sem_init(&rdrcnt, 0, N);

}

//Define main

int main(int argc, char* argv[])

{

//Declare variable

int li;

//Declare thread variable

pthread_t lTd;

//Call method

init();

//Loop

for (li = 0; li < Pple; li++)

{

//If condition satisfies

if (li%2 == 0)

//Call method

Pthread_create(&lTd, NULL, reader, NULL);

//If condition does not satisfies

else

//Call method

Pthread_create(&lTd, NULL, writer, NULL);

}

//Call method

Pthread_exit(NULL);

//Exit

exit(0);

}

Explanation:

  • The reader method decrements the reader count and semaphore initially.
  • The reading operation is performed after that.
  • The reader count and semaphore values are incremented after the operation.
  • The writer method decrements the semaphore variable initially.
  • The write operation is then performed.
  • If count reaches limit of writers, then display count.
  • The semaphore values are incremented after the operation.
Sample Output

read/write: 142746/100000

Want to see more full solutions like this?

Subscribe now to access step-by-step solutions to millions of textbook problems written by subject matter experts!
Knowledge Booster
Background pattern image
Recommended textbooks for you
Text book image
Computer Networking: A Top-Down Approach (7th Edi...
Computer Engineering
ISBN:9780133594140
Author:James Kurose, Keith Ross
Publisher:PEARSON
Text book image
Computer Organization and Design MIPS Edition, Fi...
Computer Engineering
ISBN:9780124077263
Author:David A. Patterson, John L. Hennessy
Publisher:Elsevier Science
Text book image
Network+ Guide to Networks (MindTap Course List)
Computer Engineering
ISBN:9781337569330
Author:Jill West, Tamara Dean, Jean Andrews
Publisher:Cengage Learning
Text book image
Concepts of Database Management
Computer Engineering
ISBN:9781337093422
Author:Joy L. Starks, Philip J. Pratt, Mary Z. Last
Publisher:Cengage Learning
Text book image
Prelude to Programming
Computer Engineering
ISBN:9780133750423
Author:VENIT, Stewart
Publisher:Pearson Education
Text book image
Sc Business Data Communications and Networking, T...
Computer Engineering
ISBN:9781119368830
Author:FITZGERALD
Publisher:WILEY