Lab 8
Lab 8
Lab 8
General Specifications:
You are to create a Concurrent Counter Data Structure in Kernel Space. Without any locking
mechanism, the base implementation will be the following:
Your first task is to make use of Kernel Space Spinlock API to implement a simple locking
mechanism similar to the concept of a Monitor Data Structure to turn the unsafe Counter Data
Structure into a working Concurrent Counter Data Structure. A very important note for this part
of the exercise is to use the spin_trylock() (or equivalent) version for locking to prevent
your Operating System from freezing. Save your code as lab8_spinlock_lastname.c (e.g.
lab8_spinlock_alpano.c).
Once the concurrent version of the counter is implemented, you are to create two Kernel-level
Threads using KThread API. Each kernel thread must increment the counter five hundred
thousand (500,000) times. Make sure that the global counter’s value is correct after each thread
is finished incrementing it. Take note of the runtime of this kernel module. Afterwards, rerun the
module with the exact same functionality and increase the number of kernel threads by one (so,
1
you have a modified kernel module with three kernel threads). Note the runtime again. Repeat
the process for four threads and five threads. Save your code as lab8_threads_lastname.c (e.g.
lab8_threads_alpano.c).
As you will notice, the performance of the first Concurrent Counter Data Structure poorly scales
as you increase the number of threads. Your next task is to implement a Sloppy Counter Data
Structure using Kernel Space Mutex API. Create another kernel module that implements the
same counter data structure with Mutex API, and modify your implementation by adding an
array of local counters to the counter structure, and by adding a global counter member in the
structure. The number of local counters should be the same as the number of kernel threads. The
idea behind the sloppy counter you are going to make is the following:
1) The global counter and all the local counters will be initialized to zero
2) Each kernel thread will increment their local counters first (Note: This step will not
require locking since the local counters are local to each thread)
3) After a thread increments their local counter S times (S is an integer greater than 0),
the thread will acquire the mutex lock and update the global counter
4) The local counter is then reset to zero.
Upon proper implementation of the Concurrent Sloppy Counter Data Structure, you will need to
understand the effect of modifying the value of S and scaling the number of threads to the
performance of the sloppy counter. Save your code as lab8_mutex_lastname.c (e.g.
lab8_mutex_alpano.c).
All analysis will be discussed directly with the Lab Instructor or Student Assistants during the
checking period.
2
I will be running your c codes through a code checker so make sure you did not copy
your code from the internet or from other students.
Students who are caught cheating will be given a grade of 0 and will be filed a case in the
Student Disciplinary Council.
Grading System:
30% Primitive Concurrent Counter Data Structure with Spinlock API
20% Discussion and Implementation of Five-level Threads with Primitive Concurrent Counter
Data Structure with Spinlock API
30% Sloppy Concurrent Data Structure with Mutex API
20% Discussion and Implementation of Counter Performance in Sloppy Concurrent Data
Structure with Mutex API