

# **Final Project Documentation: Advanced Operating System Simulator**

Brysen Pfingsten, Nathaniel Savoury,  
David Fields

December 8, 2025

CSAS 3111 - Operating Systems  
Fall 2025  
Seton Hall University

# Contents

|          |                                                      |           |
|----------|------------------------------------------------------|-----------|
| <b>1</b> | <b>Introduction</b>                                  | <b>3</b>  |
| 1.1      | Problem Statement . . . . .                          | 3         |
| 1.2      | Outline . . . . .                                    | 3         |
| <b>2</b> | <b>Key Concepts and Features</b>                     | <b>3</b>  |
| 2.1      | Project 1 . . . . .                                  | 3         |
| 2.2      | Project 2 . . . . .                                  | 3         |
| 2.3      | Project 3 . . . . .                                  | 3         |
| 2.4      | Project 4 . . . . .                                  | 3         |
| <b>3</b> | <b>Module 1: Process Simulation</b>                  | <b>4</b>  |
| 3.1      | Problem Statement . . . . .                          | 4         |
| 3.2      | Implementation . . . . .                             | 4         |
| 3.2.1    | Core CPU Components and Registers . . . . .          | 4         |
| <b>4</b> | <b>Overview</b>                                      | <b>5</b>  |
| <b>5</b> | <b>Registers</b>                                     | <b>5</b>  |
| 5.1      | General-Purpose Registers . . . . .                  | 5         |
| 5.2      | Special Registers . . . . .                          | 5         |
| <b>6</b> | <b>Instruction Formats</b>                           | <b>5</b>  |
| 6.1      | R-Type Format . . . . .                              | 5         |
| 6.2      | I-Type Format . . . . .                              | 6         |
| 6.3      | J-Type Format . . . . .                              | 6         |
| <b>7</b> | <b>Instruction Encoding and Semantics</b>            | <b>6</b>  |
| 7.1      | Integer Arithmetic (R-Type) . . . . .                | 6         |
| 7.2      | Multiply and Divide (R-Type) . . . . .               | 6         |
| 7.3      | Logical and Bitwise (R-Type) . . . . .               | 6         |
| 7.4      | Shift Instructions (R-Type) . . . . .                | 7         |
| 7.5      | Immediate Arithmetic and Logical (I-Type) . . . . .  | 7         |
| 7.6      | Load and Store (I-Type) . . . . .                    | 7         |
| 7.7      | Branches (I-Type) . . . . .                          | 7         |
| 7.8      | Jumps (J-Type and R-Type) . . . . .                  | 8         |
| 7.9      | System and Exception Instructions . . . . .          | 8         |
| 7.10     | Exception Return (ERET) . . . . .                    | 8         |
| <b>8</b> | <b>Exception and Interrupt Model</b>                 | <b>8</b>  |
| 8.1      | Exception Types . . . . .                            | 8         |
| 8.2      | Exception Entry . . . . .                            | 9         |
| 8.3      | Exception Return . . . . .                           | 9         |
| 8.3.1    | Process Control Block . . . . .                      | 10        |
| 8.3.2    | Fetch-Decode-Execute Cycle . . . . .                 | 10        |
| <b>9</b> | <b>Module 2: Advanced Memory Management</b>          | <b>11</b> |
| 9.1      | Problem Statement . . . . .                          | 11        |
| 9.2      | Implementation . . . . .                             | 11        |
| 9.2.1    | Hierarchical Memory System . . . . .                 | 11        |
| 9.2.2    | Memory Table . . . . .                               | 11        |
| 9.2.3    | Dynamic Memory Allocation and Deallocation . . . . . | 11        |

|                                                              |           |
|--------------------------------------------------------------|-----------|
| <b>10 Module 3: Process Scheduling and Context Switching</b> | <b>12</b> |
| 10.1 Problem Statement . . . . .                             | 12        |
| 10.2 Implementation . . . . .                                | 12        |
| 10.2.1 Process Control Block Enhancements . . . . .          | 12        |
| 10.2.2 Scheduling Algorithms . . . . .                       | 12        |
| 10.2.3 Context Switching . . . . .                           | 12        |
| 10.2.4 Integration with Fetch-Decode-Execute Cycle . . . . . | 12        |
| <b>11 Module 4: Interrupt Handling and Dispatcher</b>        | <b>13</b> |
| 11.1 Problem Statement . . . . .                             | 13        |
| 11.2 Implementation . . . . .                                | 13        |
| 11.2.1 Types of Interruption . . . . .                       | 13        |
| 11.2.2 Interrupt Vector Table . . . . .                      | 13        |
| 11.2.3 Context Switching . . . . .                           | 13        |
| <b>12 Module 5: Efficiency Analysis of Concurrency</b>       | <b>14</b> |
| 12.1 Problem Statement . . . . .                             | 14        |
| 12.2 Implementation . . . . .                                | 14        |
| 12.2.1 Performance Metrics Setup . . . . .                   | 14        |
| 12.2.2 Implementation of Time Tracking . . . . .             | 14        |
| 12.2.3 Data Comparison . . . . .                             | 14        |
| 12.2.4 Performance Comparison . . . . .                      | 14        |
| 12.2.5 Visualization and Reporting . . . . .                 | 14        |
| <b>13 The Simulation</b>                                     | <b>15</b> |
| <b>14 Testing and Debugging</b>                              | <b>16</b> |
| <b>15 Conclusion</b>                                         | <b>17</b> |
| <b>16 Appendix A: Screenshots</b>                            | <b>18</b> |

# **1 Introduction**

## **1.1 Problem Statement**

- Module 1: Process Simulation
- Module 2: Advanced Memory Management
- Module 3: Process Scheduling and Context Switching
- Module 4: Interrupt Handling and Dispatcher
- Module 5: Efficiency Analysis of Concurrency

## **1.2 Outline**

# **2 Key Concepts and Features**

## **2.1 Project 1**

## **2.2 Project 2**

## **2.3 Project 3**

Wasn't Assigned

## **2.4 Project 4**

Wasn't Assigned

### **3 Module 1: Process Simulation**

#### **3.1 Problem Statement**

#### **3.2 Implementation**

##### **3.2.1 Core CPU Components and Registers**

## 4 Overview

This document specifies a small, real 32-bit ISA based closely on the original MIPS I architecture. All instructions are 32 bits wide and follow one of three formats: R-type, I-type, or J-type. The ISA includes:

- 32 general-purpose registers (GPRs).
- Special registers: PC, HI, LO.
- Basic system control registers: Status, Cause, EPC.
- Integer arithmetic and logical operations.
- Multiply and divide.
- Shift operations.
- Load and store instructions for bytes, halfwords, and words.
- Branch and jump instructions.
- System call and exception/interrupt return.

## 5 Registers

### 5.1 General-Purpose Registers

There are 32 general-purpose registers, each 32 bits wide.

| Number    | Name   | Role / Convention                         |
|-----------|--------|-------------------------------------------|
| \$0       | zero   | Constant zero, reads as 0, writes ignored |
| \$1       | at     | Assembler temporary                       |
| \$2–\$3   | v0--v1 | Function return values                    |
| \$4–\$7   | a0--a3 | Function arguments                        |
| \$8–\$15  | t0--t7 | Temporaries (caller-saved)                |
| \$16–\$23 | s0--s7 | Saved registers (callee-saved)            |
| \$24–\$25 | t8--t9 | Temporaries                               |
| \$26–\$27 | k0--k1 | Reserved for kernel / OS use              |
| \$28      | gp     | Global pointer                            |
| \$29      | sp     | Stack pointer                             |
| \$30      | fp/s8  | Frame pointer or extra saved register     |
| \$31      | ra     | Return address for calls (JAL, JALR)      |

### 5.2 Special Registers

- **PC** (Program Counter): 32-bit address of the current instruction.
- **HI, LO**: 32-bit registers used to hold results of multiply and divide.
- **Status**: System status register (holds interrupt enable and mode bits).
- **Cause**: Encodes reason for last exception or interrupt.
- **EPC** (Exception Program Counter): Holds the address to return to after an exception, used by ERET.

## 6 Instruction Formats

All instructions are 32 bits. Bit 31 is the most significant bit (MSB).

### 6.1 R-Type Format

| 31–26  | 25–21  | 20–16  | 15–11  | 10–6   | 5–0    |
|--------|--------|--------|--------|--------|--------|
| opcode | rs     | rt     | rd     | shamt  | funct  |
| 6 bits | 5 bits | 5 bits | 5 bits | 5 bits | 6 bits |

For all R-type instructions:

$$\text{opcode} = 0.$$

## 6.2 I-Type Format

|        | 31–26  | 25–21  | 20–16     | 15–0    |
|--------|--------|--------|-----------|---------|
| opcode | rs     | rt     | immediate |         |
|        | 6 bits | 5 bits | 5 bits    | 16 bits |

The 16-bit immediate is sign-extended or zero-extended depending on the instruction.

## 6.3 J-Type Format

|        | 31–26  | 25–0    |
|--------|--------|---------|
| opcode | target |         |
|        | 6 bits | 26 bits |

The effective jump address is formed as:

$$\text{PC}_{\text{next}} = (\text{PC}_{\text{current}}[31:28] \ll 28) | (\text{target} \ll 2).$$

## 7 Instruction Encoding and Semantics

This section lists the instructions in the ISA, along with their encoding and semantic meaning. All arithmetic is on 32-bit two's complement integers unless otherwise stated. For brevity, we use the following notation:

- $\text{GPR}[i]$ : contents of general-purpose register  $i$ .
- PC: program counter.
- HI, LO: special multiply/divide registers.
- $\text{Mem}[a]$ : memory access at byte address  $a$ .
- $\text{sext}_n(x)$ : sign extension of  $x$  from  $n$  bits to 32 bits.
- $\text{zext}_n(x)$ : zero extension of  $x$  from  $n$  bits to 32 bits.

### 7.1 Integer Arithmetic (R-Type)

All of these have `opcode` = 0.

| Mnemonic | Format | Encoding                  | Description         | Semantics                                          |
|----------|--------|---------------------------|---------------------|----------------------------------------------------|
| ADD      | R      | <code>funct</code> = 0x20 | Add (signed)        | $\text{GPR}[rd] = \text{GPR}[rs] + \text{GPR}[rt]$ |
| ADDU     | R      | <code>funct</code> = 0x21 | Add (unsigned)      | Same as ADD but ignore signed overflow             |
| SUB      | R      | <code>funct</code> = 0x22 | Subtract (signed)   | $\text{GPR}[rd] = \text{GPR}[rs] - \text{GPR}[rt]$ |
| SUBU     | R      | <code>funct</code> = 0x23 | Subtract (unsigned) | Same as SUB but ignore signed overflow             |

### 7.2 Multiply and Divide (R-Type)

| Mnemonic | Format | Encoding                                                         | Description       | Semantics                                                                                               |
|----------|--------|------------------------------------------------------------------|-------------------|---------------------------------------------------------------------------------------------------------|
| MULT     | R      | <code>funct</code> = 0x18                                        | Signed multiply   | $\{\text{HI}, \text{LO}\} = \text{sext}_{64}(\text{GPR}[rs]) \times \text{sext}_{64}(\text{GPR}[rt])$   |
| MULTU    | R      | <code>funct</code> = 0x19                                        | Unsigned multiply | $\{\text{HI}, \text{LO}\} = \text{zext}_{64}(\text{GPR}[rs]) \times \text{zext}_{64}(\text{GPR}[rt])$   |
| DIV      | R      | <code>funct</code> = 0x1A                                        | Signed divide     | $\text{LO} = \text{GPR}[rs]/\text{GPR}[rt]$ , $\text{HI} = \text{GPR}[rs] \bmod \text{GPR}[rt]$         |
| DIVU     | R      | <code>funct</code> = 0x1B                                        | Unsigned divide   | $\text{LO} = \text{GPR}[rs]_u/\text{GPR}[rt]_u$ , $\text{HI} = \text{GPR}[rs]_u \bmod \text{GPR}[rt]_u$ |
| MFHI     | R      | <code>funct</code> = 0x10, <code>rs</code> = <code>rt</code> = 0 | Move from HI      | $\text{GPR}[rd] = \text{HI}$                                                                            |
| MFLO     | R      | <code>funct</code> = 0x12, <code>rs</code> = <code>rt</code> = 0 | Move from LO      | $\text{GPR}[rd] = \text{LO}$                                                                            |
| MTHI     | R      | <code>funct</code> = 0x11, <code>rt</code> = <code>rd</code> = 0 | Move to HI        | $\text{HI} = \text{GPR}[rs]$                                                                            |
| MTLO     | R      | <code>funct</code> = 0x13, <code>rt</code> = <code>rd</code> = 0 | Move to LO        | $\text{LO} = \text{GPR}[rs]$                                                                            |

### 7.3 Logical and Bitwise (R-Type)

| Mnemonic | Format | Encoding                  | Description | Semantics                              |
|----------|--------|---------------------------|-------------|----------------------------------------|
| AND      | R      | <code>funct = 0x24</code> | Bitwise AND | $GPR[rd] = GPR[rs] \wedge GPR[rt]$     |
| OR       | R      | <code>funct = 0x25</code> | Bitwise OR  | $GPR[rd] = GPR[rs] \vee GPR[rt]$       |
| XOR      | R      | <code>funct = 0x26</code> | Bitwise XOR | $GPR[rd] = GPR[rs] \oplus GPR[rt]$     |
| NOR      | R      | <code>funct = 0x27</code> | Bitwise NOR | $GPR[rd] = \neg(GPR[rs] \vee GPR[rt])$ |

## 7.4 Shift Instructions (R-Type)

| Mnemonic | Format | Encoding                  | Description                        | Semantics                                           |
|----------|--------|---------------------------|------------------------------------|-----------------------------------------------------|
| SLL      | R      | <code>funct = 0x00</code> | Shift left logical (immediate)     | $GPR[rd] = GPR[rt] \ll \text{shamt}$                |
| SRL      | R      | <code>funct = 0x02</code> | Shift right logical (immediate)    | $GPR[rd] = GPR[rt] \gg \text{shamt}$ (logical)      |
| SRA      | R      | <code>funct = 0x03</code> | Shift right arithmetic (immediate) | Arithmetic right shift, preserving sign bit         |
| SLLV     | R      | <code>funct = 0x04</code> | Shift left logical (variable)      | $GPR[rd] = GPR[rt] \ll (GPR[rs] \& 0x1F)$           |
| SRLV     | R      | <code>funct = 0x06</code> | Shift right logical (variable)     | $GPR[rd] = GPR[rt] \gg (GPR[rs] \& 0x1F)$ (logical) |
| SRAV     | R      | <code>funct = 0x07</code> | Shift right arithmetic (variable)  | Arithmetic right shift by low 5 bits of GPR[rs]     |

## 7.5 Immediate Arithmetic and Logical (I-Type)

| Mnemonic | Format | Opcode | Description                        | Semantics                                                |
|----------|--------|--------|------------------------------------|----------------------------------------------------------|
| ADDI     | I      | 0x08   | Add immediate (signed)             | $GPR[rt] = GPR[rs] + \text{sext}_{16}(\text{imm})$       |
| ADDIU    | I      | 0x09   | Add immediate (unsigned)           | Same as ADDI but ignore signed overflow                  |
| ANDI     | I      | 0x0C   | And immediate                      | $GPR[rt] = GPR[rs] \wedge \text{zext}_{16}(\text{imm})$  |
| ORI      | I      | 0x0D   | Or immediate                       | $GPR[rt] = GPR[rs] \vee \text{zext}_{16}(\text{imm})$    |
| XORI     | I      | 0x0E   | Xor immediate                      | $GPR[rt] = GPR[rs] \oplus \text{zext}_{16}(\text{imm})$  |
| SLTI     | I      | 0x0A   | Set less than immediate (signed)   | $GPR[rt] = (GPR[rs] < \text{sext}_{16}(\text{imm}))?1:0$ |
| SLTIU    | I      | 0x0B   | Set less than immediate (unsigned) | Unsigned comparison version of SLTI                      |
| LUI      | I      | 0x0F   | Load upper immediate               | $GPR[rt] = \text{imm} \ll 16$                            |

## 7.6 Load and Store (I-Type)

Effective address:

$$EA = GPR[rs] + \text{sext}_{16}(\text{imm}).$$

Memory is typically treated as byte-addressed, little-endian.

| Mnemonic | Format | Opcode | Description              | Semantics                                      |
|----------|--------|--------|--------------------------|------------------------------------------------|
| LW       | I      | 0x23   | Load word                | $GPR[rt] = \text{Mem32}[EA]$                   |
| SW       | I      | 0x2B   | Store word               | $\text{Mem32}[EA] = GPR[rt]$                   |
| LB       | I      | 0x20   | Load byte (signed)       | $GPR[rt] = \text{sext}_8(\text{Mem8}[EA])$     |
| LBU      | I      | 0x24   | Load byte (unsigned)     | $GPR[rt] = \text{zext}_8(\text{Mem8}[EA])$     |
| LH       | I      | 0x21   | Load halfword (signed)   | $GPR[rt] = \text{sext}_{16}(\text{Mem16}[EA])$ |
| LHU      | I      | 0x25   | Load halfword (unsigned) | $GPR[rt] = \text{zext}_{16}(\text{Mem16}[EA])$ |
| SB       | I      | 0x28   | Store byte               | $\text{Mem8}[EA] = GPR[rt] \& 0xFF$            |
| SH       | I      | 0x29   | Store halfword           | $\text{Mem16}[EA] = GPR[rt] \& 0xFFFF$         |

## 7.7 Branches (I-Type)

The branch target address is computed relative to the address of the instruction *following* the branch. Let  $PC_{\text{next}}$  be the PC after fetching the branch (i.e.,  $PC + 4$ ). Then:

$$\text{Target} = PC_{\text{next}} + (\text{sext}_{16}(\text{imm}) \ll 2).$$

| Mnemonic | Format | Opcode | Description         | Semantics                                                |
|----------|--------|--------|---------------------|----------------------------------------------------------|
| BEQ      | I      | 0x04   | Branch if equal     | If GPR[ <i>rs</i> ] = GPR[ <i>rt</i> ], then PC = Target |
| BNE      | I      | 0x05   | Branch if not equal | If GPR[ <i>rs</i> ] ≠ GPR[ <i>rt</i> ], then PC = Target |

## 7.8 Jumps (J-Type and R-Type)

| Mnemonic | Format | Opcode/Funct  | Description            | Semantics                                                     |
|----------|--------|---------------|------------------------|---------------------------------------------------------------|
| J        | J      | opcode = 0x02 | Jump                   | PC = (PC <sub>current</sub> [31:28] << 28)   (target << 2)    |
| JAL      | J      | opcode = 0x03 | Jump and link          | GPR[31] = PC <sub>next</sub> ; then same as J                 |
| JR       | R      | funct = 0x08  | Jump register          | PC = GPR[ <i>rs</i> ]                                         |
| JALR     | R      | funct = 0x09  | Jump and link register | GPR[ <i>rd</i> ] = PC <sub>next</sub> ; PC = GPR[ <i>rs</i> ] |

## 7.9 System and Exception Instructions

For system and exception-related instructions, we describe them in prose rather than putting lists inside table cells (which can cause LaTeX errors).

### SYSCALL

Encoded as an R-type instruction with `opcode` = 0 and `funct` = 0x0C. When executed, this instruction triggers a software exception. The simulator should:

1. Save the appropriate instruction address into EPC (either the address of the syscall or the next instruction, depending on your chosen convention).
2. Set **Cause** to a code representing a system call exception.
3. Update **Status** to indicate kernel mode and (optionally) disable further interrupts.
4. Set PC to the configured exception vector address (e.g. 0x80000180).

### BREAK

Encoded as an R-type instruction with `opcode` = 0 and `funct` = 0x0D. When executed, this triggers a breakpoint exception, which is handled similarly to SYSCALL, but with a different **Cause** code to distinguish it (e.g. for debugging or traps).

## 7.10 Exception Return (ERET)

In real MIPS this is encoded as a coprocessor 0 instruction. For this ISA we define:

- `opcode` = 0x10 (COP0),
- `rs` = 0x10,
- bits 5–0 (`funct`) = 0x18,
- all other fields zero.

Decoding is implemented as a special case: “if opcode is 0x10 and `funct` = 0x18, execute ERET.”

### Semantics.

- $\text{PC} \leftarrow \text{EPC}$ .
- Restore user/kernel mode and interrupt enable bits in **Status** as appropriate.

## 8 Exception and Interrupt Model

### 8.1 Exception Types

Typical exception causes include:

- System call (SYSCALL).
- Breakpoint (BREAK).

- Arithmetic overflow (e.g., ADD with overflow).
- Invalid instruction.
- Address error on load/store.
- External interrupt (e.g., timer, I/O).

The simulator sets **Cause** to an integer code representing one of these reasons.

## 8.2 Exception Entry

On an exception or interrupt, the CPU performs:

1. Save the faulting instruction address or the following address into EPC.
2. Set **Cause** to the appropriate exception code.
3. Modify **Status** to:
  - switch to kernel mode,
  - optionally disable further interrupts.
4. Set PC to a fixed exception vector address, e.g. 0x80000180.

The kernel's exception handler at that address can then inspect **Cause**, EPC, and general registers to decide what to do.

## 8.3 Exception Return

When the kernel is finished handling the exception or interrupt, it executes **ERET**, which:

- restores PC from EPC,
- restores user/kernel mode (and possibly interrupt enable) from **Status**.

### **8.3.1 Process Control Block**

### **8.3.2 Fetch-Decode-Execute Cycle**

## **9 Module 2: Advanced Memory Management**

### **9.1 Problem Statement**

### **9.2 Implementation**

#### **9.2.1 Hierarchical Memory System**

#### **9.2.2 Memory Table**

#### **9.2.3 Dynamic Memory Allocation and Deallocation**

## 10 Module 3: Process Scheduling and Context Switching

### 10.1 Problem Statement

alla

### 10.2 Implementation

akda

#### 10.2.1 Process Control Block Enhancements

lsok

#### 10.2.2 Scheduling Algorithms

ls

##### Round-Robin

ls

##### Priority-Based Scheduling

lsf

##### Shortest Time Remaining

lsf

##### Highest Response Ratio Next

lsv

##### First Come First Serve

kfs

##### Shortest Process Next

skf

##### Feedback Scheduling

jsnf

#### 10.2.3 Context Switching

snfj

#### 10.2.4 Integration with Fetch-Decode-Execute Cycle

jnsf

## **11 Module 4: Interrupt Handling and Dispatcher**

### **11.1 Problem Statement**

### **11.2 Implementation**

#### **11.2.1 Types of Interruption**

#### **11.2.2 Interrupt Vector Table**

#### **11.2.3 Context Switching**

## **12 Module 5: Efficiency Analysis of Concurrency**

### **12.1 Problem Statement**

### **12.2 Implementation**

#### **12.2.1 Performance Metrics Setup**

#### **12.2.2 Implementation of Time Tracking**

#### **12.2.3 Data Comparison**

#### **12.2.4 Performance Comparison**

#### **12.2.5 Visualization and Reporting**

## 13 The Simulation

## 14 Testing and Debugging

## 15 Conclusion

## 16 Appendix A: Screenshots