Each thread should call the following function before and after using the shared queue:
void may_relinquish() /* call this to randomly do context switching */ { if (random() & 3) thread_relinquish(); }
Part B: After your program outputs the message saying that the 30th item has been dequeued, the tread manager terminates the entire program; most likely, unless you went to extraordinary effort, the termination is abnormal. If it is abnormal, explain why. If it is not abnormal, explain the extraordinary effort you had to make to make the program terminate normally.
http://homepage.cs.uiowa.edu/~dwjones/arch/hawk/overview.html#mmuFor this problem, assume that you have high level language routines to read and write the Trap Memory Address Register and the MMU Data Register.
Part A Give fairly detailed descriptions of the data structures needed for implementing virtual memory on the Hawk machine, focusing on the fields present in the page and frame tables and particularly focusing on the differences between the software data structures and the corresponding structures imposed by the MMU hardware.
Part B Write high level pseudocode for a page-fault trap service routine on the Hawk machine, assuming that all the low level details like saving and restoring CPU registers are done for you. Focus on the distinction between soft page faults (to update the TLB) and real page faults, and gloss over the actual details of handling real page faults.