Programming Project 3:
Due Date: ______________________________
Duration: One
week
In this project you will
gain additional familiarity writing programs involving concurrency
control. You will implement a couple
of classical IPC problems to become more comfortable with Semaphores, Mutexes, Condition Variables, and the Monitor approach.
Start by creating a
directory for the files youÕll need for this project:
~YourUserName/cs333/p3
Then download all the files
from:
http://www.cs.pdx.edu/~harry/Blitz/OSProject/p3/
Even though some of the
files have the same names, be sure to get new copies for each project. In general some files may be modified.
Please keep your old files
from previous projects separate and donÕt modify them once you submit
them. This is a good rule for all
programming projects in all classes.
If there is ever any question about whether code was completed on time,
we can always go back and look at the Unix Òfile modification dateÓ
information.
For this project, you should
get the following files:
makefile
DISK
System.h
System.c
Runtime.s
Switch.s
List.h
List.c
Thread.h
Thread.c
Synch.h
Synch.c
Main.h
The file Synch.c contains our solution
for project 2. You may use either
our version of this file, or the version of Synch.c you created.
We have also included the
file
Proj2Sol.pdf
which contains my solution
code for Producer-Consumer and Dining Philosophers. If you had difficulty with it, you can take a look at the
solution code.
You will modify and submit
the following files:
Main.h
Main.c
An older edition of the Tanenbaum textbook describes the ÒSleeping BarberÓ problem
and gives a solution in ÒCÓ. (This
material can also be found in a separate file called SleepingBarberProblem.pdf in the
p3 directory.)
Translate this into a
working KPL program. YouÕll also
need to create some code to print out what happens when you run the program.
What will you do for the Òcut_hairÓ and the Òget_haircutÓ
methods? YouÕll need at least one
print statement in each routine, but be careful: they both should run at
more-or-less the same time.
One barber is okay, but how
many customers will you model?
Will you just throw a bunch of customers at the barbershop all at
once? This might not test your
code very well.
How long will the haircut
last? You can implement waiting
with a busy loop, such as
for
i = 1 to 100
.. want to yield here?...
endFor
The goals are:
(1) Practice creating a KPL class from
scratch
(3) Gain experience with semaphores, mutex locks, and thread synchronization
Here is the problem
scenario: groups of customers come in to a Ògaming parlorÓ to play games. They go to the front desk to obtain one
or more dice, which are used by the group while they are playing their game,
and then returned to the front desk.
The front desk is in charge of lending out the dice and collecting them
after each game is finished.
The gaming parlor owns only
8 dice, which are available at the front desk before the first group comes in.
The customers can play the
following games. Listed after each
game in parentheses is the number of dice required to play that game.
Backgammon
(4)
Risk
(5)
Monopoly
(2)
Pictionary
(1)
You should model the front
desk as a monitor with the following entry methods:
Request (numberOfDice:
int)
Return (numberOfDice:
int)
Model each group of
customers as a thread. When a
group is ready to play, it must obtain the necessary number of dice. If the required number of dice is not
available, then the group (i.e., the thread) must wait. You might use a condition variable that
Òmore dice have become available.Ó
You should model the
following eight different groups.
Each group plays one game, as shown below, but each group plays its game
5 times. Each group must return
their dice after each game and then re-acquire the dice before playing again.
A
– Backgammon
B
– Backgammon
C
– Risk
D
– Risk
E
– Monopoly
F
– Monopoly
G
– Pictionary
H
– Pictionary
To simulate playing the
game, simply call the Yield method.
This problem is a
generalization of the problem of resource allocation where (1) there are a
number of resources (dice) but each is identical; (2) every requesting process
needs a one or more units of the resource, (3) each requesting thread knows how
many units it will need before requesting any units and that info is included
in the request, (4) all units are returned before any further requests are
made.
If deadlock occurs, the
program will freeze up and some requests for dice will go unsatisfied
forever. This is a disaster! Regardless of the order in which the
groups make their requests, your solution should be structured such that
deadlock can never occur.
Your solution must not be
subject to any race conditions. In
other words, regardless of the order in which the groups make their requests
and return their dice, each die must never be allocated to more than one group
at a time. It should never be the
case that groups are allowed to proceed when there are too few dice. Likewise, if a group has returned its
dice, other groups which are waiting must be allowed to proceed once enough
dice have become available.
Starvation can occur if it
is possible that one thread can be delayed infinitely by other threadsÕ
requests. If the game parlor
problem is extended to assume that each group will continue to play game after
game forever, then starvation might be possible, if you are not careful in your
solution. If some group X comes in
requesting a lot of dice, it will be made to wait until enough dice are
available. If it is possible that
other groups can come in, request a small number of dice, and have their
requests granted, then group X might get delayed forever, since there are never
enough dice at the front desk at once to satisfy group XÕs needs. In other words, it might be possible
for starvation of X to occur. In
your solution starvation should not be possible. (Of course, with each group limited to playing only 5 games,
all the outstanding dice will always get returned eventually and starvation can
never occur, but your solution should also avoid starvation in the presence of
a never-ending sequence of Request
and Return operations.)
Please submit hardcopy of
the following files:
Main.h
Main.c
Also hand in hardcopy
showing your output for both tasks.
For the Sleeping Barber
problem, I am not providing any testing material; youÕll have to devise some
tests on your own. Please hand in
something showing how you have tested your code.
In LARGE BLOCK LETTERS,
write your full name on the first page.
PLEASE STAPLE ALL PAGES!
In this course, the code you
submit will be graded on both correctness
and style. Correctness means that the code must work right and not
contain bugs. Style means that the
code must be neat, well commented, well organized, and easy to read.
In style, your code should
match the code we are distributing to you. The indentation should be the same and the degree of
commenting should be the same.