Nachos Projects Overview and Project 1 TA : 王映智 2007/10/24.

Slides:



Advertisements
Similar presentations
MODERN OPERATING SYSTEMS Third Edition ANDREW S. TANENBAUM Chapter 3 Memory Management Tanenbaum, Modern Operating Systems 3 e, (c) 2008 Prentice-Hall,
Advertisements

Introduction CSCI 444/544 Operating Systems Fall 2008.
Introduction to Operating Systems CS-2301 B-term Introduction to Operating Systems CS-2301, System Programming for Non-majors (Slides include materials.
CMPT 300: Operating Systems I Dr. Mohamed Hefeeda
Operating System Tracing the Nachos code in Java Instructor: Dr. Lee, Hahn-Ming. ( 李漢銘 教授 ) TA (Reporter): Mao, Ching-Hao 毛敬豪 Chen, Wei-Da 陳威達 2006/3/14.
1 School of Computing Science Simon Fraser University CMPT 300: Operating Systems I Dr. Mohamed Hefeeda.
CS-502 Fall 2006Project 1, Fork1 Programming Project 1 – Fork.
Operating System Tracing the nachos code in Java
Operating System - NachOS Project Introduction
Nachos Introduction CS Operating System 2007.
CS 162 Nachos Tutorial Image courtesy of Thomas Andersen:
Build an Operating System
Nachos Introduction CS Operating System 2005.
IntroductionCS-3013 C-term Programming Project #1 Forking Processes Due Thursday, January 24, 6:00 PM.
Chapter 6 - Implementing Processes, Threads and Resources Kris Hansen Shelby Davis Jeffery Brass 3/7/05 & 3/9/05 Kris Hansen Shelby Davis Jeffery Brass.
To run the program: To run the program: You need the OS: You need the OS:
Operating System Program 5 I/O System DMA Device Driver.
Microkernels, virtualization, exokernels Tutorial 1 – CSC469.
Welcome to the World of Nachos CPS 110 Spring 2004 Discussion Session 1.
1 Nachos Introduction Lecturer: Tei-Wei Kuo TA: Ya-Su Chen, Yuan-Hao chang Date: 2005/10/19.
Nachos Project 1 Start-up and System call
Nachos Projects Overview and Project 1 TA : 吳哲榮 2010/10/21.
Project 1, Command Shell CS-502 (EMC) Fall Programming Project #1 Command Shell CS-502, Operating Systems EMC, Fall 2009 (Slides include materials.
Nachos Assignment#1 System calls implementation. What are system calls? Enable you to interact with OS kernel. A switch from User Mode to Kernel Mode.
CS 444 Introduction to Operating Systems
Nachos Project Assignment 1 MultiprogrammingTA:mamafun.
Operating Systems Lecture 7 OS Potpourri Adapted from Operating Systems Lecture Notes, Copyright 1997 Martin C. Rinard. Zhiqing Liu School of Software.
Hardware process When the computer is powered up, it begins to execute fetch-execute cycle for the program that is stored in memory at the boot strap entry.
Race Conditions Defined 1. Every data structure defines invariant conditions. defines the space of possible legal states of the structure defines what.
Nachos Project Assignment 2 CPU scheduling
Nachos Overview 2011 级 OS 课程设计 2013 秋. to get your hands dirty Read and analyze Build observe.
Nachos Project 4 Lecturer: Hao-Hua Chu TA: Chun-Po Wang (Artoo) Date: 2008/10/25.
(a) What is the output generated by this program? In fact the output is not uniquely defined, i.e., it is not always the same. So please give three examples.
 Virtual machine systems: simulators for multiple copies of a machine on itself.  Virtual machine (VM): the simulated machine.  Virtual machine monitor.
Nachos Tutorial 马 融 03-ACM Honor Class Dept. of Computer Science and Engineering Shanghai Jiao Tong University 2007 / 11.
1 Operating Systems: Principles and Practice Cpr E 308.
Nachos Project 3.
1. Introduction to Nachos Shandong University 2014 秋.
Nachos Project Assignment 1 Multi-programming TA: Hung-Leng Chen.
We will focus on operating system concepts What does it do? How is it implemented? Apply to Windows, Linux, Unix, Solaris, Mac OS X. Will discuss differences.
Nachos Project Assignment 3
Nachos Overview Lecturer: Hao-Hua Chu TA: Chun-Po Wang (Artoo) Date: 2008/09/18 Material Provided by Yuan-Hao Chang, Yung-Feng Lu.
Nachos Lecture 2 Xiaorui Sun. Phase 2 You have got one machine (machine package) You have to implements the incomplete OS (userprog package) Run programs.
Lecture 26 Virtual Machine Monitors. Virtual Machines Goal: run an guest OS over an host OS Who has done this? Why might it be useful? Examples: Vmware,
Hardware process When the computer is powered up, it begins to execute fetch-execute cycle for the program that is stored in memory at the boot strap entry.
Nachos Overview and Project 1. Nachos Introduction Official website
1 Lecture 6 “Nachos” n nachos overview n directory structure n nachos emulated machine n nachos OS n nachos scheduler n nachos threads.
Operating Systems CMPSC 473 Introduction and Overview August 24, Lecture 1 Instructor: Bhuvan Urgaonkar.
Measuring Performance Based on slides by Henri Casanova.
CMPS Operating Systems Prof. Scott Brandt Computer Science Department University of California, Santa Cruz.
Exercise #1: Exploring Open-Source Operating Systems with Virtual Machines J. H. Wang Sep. 20, 2016.
Nachos Project Assignment 3 Memory Management
Outline Installing Gem5 SPEC2006 for Gem5 Configuring Gem5.
Virtual Machine Monitors
Bare metal OS project CSSE 332 Operating Systems
Process Management Process Concept Why only the global variables?
Lecture 24 Virtual Machine Monitors
Exercise #1: Exploring Open-Source Operating Systems with Virtual Machines J. H. Wang Sep. 19, 2017.
CS490 Windows Internals Quiz 2 09/27/2013.
Introduction to Operating Systems
OS Virtualization.
Introduction to Operating Systems
More examples How many processes does this piece of code create?
Exercise #1: Exploring Open-Source Operating Systems with Virtual Machines J. H. Wang Sep. 21, 2018.
Lecture Topics: 11/1 General Operating System Concepts Processes
Programming Project #1 Command Shell
Programming Project #1 Fork and Command Shell
System calls….. C-program->POSIX call
CSE 153 Design of Operating Systems Winter 2019
Nachos Project Assignment 2 CPU scheduling
Presentation transcript:

Nachos Projects Overview and Project 1 TA : 王映智 2007/10/24

Outline What’s Nachos? Why do we use Nachos? Nachos Project Overview Nachos installation Nachos Assignment 1 Reference

What ’ s Nachos? Nachos  Not Another Completely Heuristic Operating System Developed by Tom Anderson and his students at UC, Berkeley. 

What ’ s Nachos? Nachos is an instrumental software that allows students to study and modify a “real” operating system. The only difference between Nachos and a real operating system is that Nachos runs a Unix process, whereas a real operating system runs on a real machine.

What ’ s Nachos? Nachos simulates a MIPS machine (MIPS R2/3000) on the host system (Unix, Linux, etc.) Conceptually, Nachos has two modes of execution, namely, MIPS simulator and Nachos “kernel” Reference : nachos.ps

Why do we use Nachos? For understanding operating system concepts, nothing is better than building an operating system. Nachos is simpler than UNIX. Simulator makes debugging easier.  Deterministic

Nachos Project Overview The project for this course is to build an operating system for scratch. The project contains four phases, corresponding to each of the major pieces of a modern OS.  Multiprogramming  Thread management  File Systems and Virtual Memory  Networking

Nachos Installation Platforms you may use  Unix, Linux, Linux over VMware, or Cygwin. Environment  Checking g++ version g++ -v  Both g or g are ok. Get Nachos-4.0  os-4.0.tar.gz os-4.0.tar.gz wget

Nachos Installation Get Cross Compiler  hos/mips-decstation.linux-xgcc.tgz Move Cross Compiler to / mv./mips-decstation.linux-xgcc.tgz / Untar Cross Compiler cd / tar zxvf mips-decstation.linux-xgcc.tgz

Nachos Installation Untar Nachos tar zxvf nachos-4.0.tar.gz Make Nachos-4.0 cd./nachos-4.0/code make Test cd./userprog./nachos –e../test/test1./nachos –e../test/test2

Nachos Installation You should see the result of test1

Nachos Installation You should see the result of test2

Some Important Things Nachos arguments  Help./nachos –h  Debugging Mode./nachos –s  Execute files./nachos –e [file_name] Recompilation of modified nachos code cd nachos-4.0/code make clean (optional) make

Nachos Assignment 1 Abstract  The assignment is to support multiprogramming. We give some of the code you need, and you have to complete the system. Try execute two programs at the same time on Nachos cd./userprog./nachos –e../test/test1 –e../test/test2 you should see the following result.

Result of simultaneously execution Total threads number is 2 Thread../test/test1 is executing. Thread../test/test2 is executing. Print integer:9 Print integer:8 Print integer:7 Print integer:20 Print integer:21 Print integer:22 Print integer:23 Print integer:24 Print integer:6 Print integer:7 Print integer:8 Print integer:9 Print integer:10 Print integer:12 Print integer:13 Print integer:14 Print integer:15 Print integer:16 Print integer:17

Result of simultaneously execution Print integer:18 Print integer:19 Print integer:20 Print integer:17 Print integer:18 Print integer:19 Print integer:20 Print integer:21 Print integer:23 Print integer:24 Print integer:25 return value:0 Print integer:26 return value:0 No threads ready or runnable, and no pending interrupts. Assuming the program completed. Machine halting! Ticks: total 800, idle 67, system 120, user 613 Disk I/O: reads 0, writes 0 Console I/O: reads 0, writes 0 Paging: faults 0 Network I/O: packets received 0, sent 0 Why the output result of executing two program simultaneously differs from the result of executing two programs separately?

Why should you do? Trace Nachos  Read *.h and *.cc to understand the whole system and see how it is implemented.  You might use some documentations to help yourself understand the system. A Road Map Through Nachos  Trace for NachoOS-4.0 with GLOBAL 

Hints To know why the result is wrong, you may trace the following files.  nachos-4.0/code/userprog/addrspace.h  nachos-4.0/code/userprog/addrspace.cc  nachos-4.0/code/userprog/userkernel.cc  nachos-4.0/code/userprog/translate.h  nachos-4.0/code/userprog/translate.cc

Hints You have to modify the Nachos code to achieve the correct result. You may try to modify the following functions  nachos-4.0/code/userprog/addrspace.cc constructor destructor initRegister Load

Assignment Requirements Progress Report (11/7 on the class)  Prepare a presentation about the following topics: Your understanding about Nachos Your progress  Installation of Nachos  Knowing why the result is not congruent with expected  Your Plan for modifying Nachos Everything you consider important

Assignment Requirements Assignment Report (11/21 on the class)  Prepare a presentation about the following topics: Why the result is not congruent with expected How you modified Nachos to make it support multiprogramming – important code segments Everything you consider important

Hand in your reports. Please compress your code with tar.  source code only  tar zcvf r tar.gz nachos-4.0 your code and presentation files(report) to TA Deadline: 2007/11/21 23:59

Grading Policy Progress Report20% Correct Result30% Report50%

Reference Author’s Web Page  Thomas Narten's Nachos Roadmap  Other Reference   