Project 4: Concurrency

WARNING

This is certainly the most difficult project thus far. Start early!

Questions about the project? Send them to 537-help-2014@cs.wisc.edu .

Overview

There are two parts to this project:

  • Scalable Web Server: to be done on the galapagos lab, so you can learn more about programming in C on a typical UNIX-based platform (Linux)
  • Kernel Threads: to be done in our xv6 hacking environment.

Click on the above links to learn more about what you should do. READ EACH CAREFULLY!

Notes

This project can be done with a single partner. Copying code (from other groups) is considered cheating. Read this for more info on what is OK and what is not!

Handing It In

The handin directory is ~cs537-SECTION/handin/login/p4 where login is your login and SECTION is your section (i.e., 1 or 2).

For the C/Linux part of this project, you should turn in all your source, including the makefile.

For the xv6 part of the project, copy all of your source files (but not .o files, please, or binaries!) into the xv6/ subdirectory of your p4 directory. A simple way to do this is to copy everything into the destination directory directory, then type make to make sure it builds, and then type make clean to remove unneeded files.

Finally, please put a README file in P4/linux directory and P4/xv6 directory. Your README should strictly follow the same format as ~cs537-2/public/README. We automatically parse your README for login information, so if you change the format, you will not receive points correctly. Include both partner's names and CS logins to receive credit; please put the README in BOTH partners' directories; put the code in just one.