

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

Brysen Pfingsten, Nathaniel Savoury,  
David Fields

November 11, 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        |
| 3.2.2    | Process Control Block . . . . .                           | 4        |
| 3.2.3    | Fetch-Decode-Execute Cycle . . . . .                      | 4        |
| <b>4</b> | <b>Module 2: Advanced Memory Management</b>               | <b>5</b> |
| 4.1      | Problem Statement . . . . .                               | 5        |
| 4.2      | Implementation . . . . .                                  | 5        |
| 4.2.1    | Hierarchical Memory System . . . . .                      | 5        |
| 4.2.2    | Memory Table . . . . .                                    | 5        |
| 4.2.3    | Dynamic Memory Allocation and Deallocation . . . . .      | 5        |
| <b>5</b> | <b>Module 3: Process Scheduling and Context Switching</b> | <b>6</b> |
| 5.1      | Problem Statement . . . . .                               | 6        |
| 5.2      | Implementation . . . . .                                  | 6        |
| 5.2.1    | Process Control Block Enhancements . . . . .              | 6        |
| 5.2.2    | Scheduling Algorithms . . . . .                           | 6        |
| 5.2.3    | Context Switching . . . . .                               | 6        |
| 5.2.4    | Integration with Fetch-Decode-Execute Cycle . . . . .     | 6        |
| <b>6</b> | <b>Module 4: Interrupt Handling and Dispatcher</b>        | <b>7</b> |
| 6.1      | Problem Statement . . . . .                               | 7        |
| 6.2      | Implementation . . . . .                                  | 7        |
| 6.2.1    | Types of Interruption . . . . .                           | 7        |
| 6.2.2    | Interrupt Vector Table . . . . .                          | 7        |
| 6.2.3    | Context Switching . . . . .                               | 7        |

|                                                       |           |
|-------------------------------------------------------|-----------|
| <b>7 Module 5: Efficiency Analysis of Concurrency</b> | <b>8</b>  |
| 7.1 Problem Statement . . . . .                       | 8         |
| 7.2 Implementation . . . . .                          | 8         |
| 7.2.1 Performance Metrics Setup . . . . .             | 8         |
| 7.2.2 Implementation of Time Tracking . . . . .       | 8         |
| 7.2.3 Data Comparison . . . . .                       | 8         |
| 7.2.4 Performance Comparison . . . . .                | 8         |
| 7.2.5 Visualization and Reporting . . . . .           | 8         |
| <b>8 The Simulation</b>                               | <b>9</b>  |
| <b>9 Testing and Debugging</b>                        | <b>10</b> |
| <b>10 Conclusion</b>                                  | <b>11</b> |
| <b>11 Appendix A: Screenshots</b>                     | <b>12</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**

##### **3.2.2 Process Control Block**

##### **3.2.3 Fetch-Decode-Execute Cycle**

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

### **4.1 Problem Statement**

### **4.2 Implementation**

#### **4.2.1 Hierarchical Memory System**

#### **4.2.2 Memory Table**

#### **4.2.3 Dynamic Memory Allocation and Deallocation**

## **5 Module 3: Process Scheduling and Context Switching**

### **5.1 Problem Statement**

### **5.2 Implementation**

#### **5.2.1 Process Control Block Enhancements**

#### **5.2.2 Scheduling Algorithms**

**Round-Robin**

**Priority-Based Scheduling**

**Shortest Time Remaining**

**Highest Response Ratio Next**

**First Come First Serve**

**Shortest Process Next**

**Feedback Scheduling**

#### **5.2.3 Context Switching**

#### **5.2.4 Integration with Fetch-Decode-Execute Cycle**

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

### **6.1 Problem Statement**

### **6.2 Implementation**

#### **6.2.1 Types of Interruption**

#### **6.2.2 Interrupt Vector Table**

#### **6.2.3 Context Switching**

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

### **7.1 Problem Statement**

### **7.2 Implementation**

#### **7.2.1 Performance Metrics Setup**

#### **7.2.2 Implementation of Time Tracking**

#### **7.2.3 Data Comparison**

#### **7.2.4 Performance Comparison**

#### **7.2.5 Visualization and Reporting**

## **8 The Simulation**

## **9 Testing and Debugging**

## **10 Conclusion**

## 11 Appendix A: Screenshots