Welcome to CSE 506 Introduc)on & Review Don Porter 1 CSE 506: - - PowerPoint PPT Presentation

welcome to cse 506
SMART_READER_LITE
LIVE PREVIEW

Welcome to CSE 506 Introduc)on & Review Don Porter 1 CSE 506: - - PowerPoint PPT Presentation

CSE 506: Opera.ng Systems Welcome to CSE 506 Introduc)on & Review Don Porter 1 CSE 506: Opera.ng Systems Why Grad OS? Primary Goal: Demys)fy how computers work 2 CSE 506: Opera.ng Systems An example progression Undergrad OS:


slide-1
SLIDE 1

CSE 506: Opera.ng Systems

Welcome to CSE 506

Introduc)on & Review Don Porter

1

slide-2
SLIDE 2

CSE 506: Opera.ng Systems

Why Grad OS?

  • Primary Goal: Demys)fy how computers work

2

slide-3
SLIDE 3

CSE 506: Opera.ng Systems

An example progression

  • Undergrad OS:

– High-level understanding of paging – Theore)cal issues like fragmenta)on

  • Grad OS (506): Build a pager

– Solid understanding of how paging SW + HW work

  • Advanced Grad OS (624): Read novel research papers

– Do crea)ve things with paging: virtualiza)on, security, etc

3

slide-4
SLIDE 4

CSE 506: Opera.ng Systems

506: Learn by doing

  • You will write major chunks of your own OS

– Memory management, context switching, scheduler, file system, IPC, network driver, shell, etc. – Linux scheduler:

  • Difficult to understand just by reading source
  • Small modifica)ons require first understanding the code
  • Impossible to replace/reimplement

– No subs)tute for building it yourself!

4

slide-5
SLIDE 5

CSE 506: Opera.ng Systems

A logical view of hardware

CPU(s) RAM PCI-X Bus PCI Bus SATA BIOS North Bridge (Fast devices: e.g., GPU) South Bridge (“Slow” Devices: e.g., Disk, USB, Most network)

5

slide-6
SLIDE 6

CSE 506: Opera.ng Systems

Fewer Bridges

  • Newer system organiza)ons are moving more

devices to the North bridge, and consolida)ng more things on the CPU itself.

6

slide-7
SLIDE 7

CSE 506: Opera.ng Systems

A logical view of the OS

Memory Management CPU Scheduler User Kernel Hardware Binary Formats Consistency System Calls Interrupts Disk Net RCU File System Device Drivers Networking Sync Memory Allocators Threads

7

slide-8
SLIDE 8

CSE 506: Opera.ng Systems

Labs, cont.

  • This course is coding intensive

– You should know C, or be prepared to remediate quickly – You will learn basic, inline x86 assembly – You must learn on your own/with lab partner

  • The lab is difficult, but worthwhile

– You will want to commemorate, with a T-shirt, tajoo, etc.

8

slide-9
SLIDE 9

CSE 506: Opera.ng Systems

JOS

  • Developed at MIT, used at several top schools

– The “J” is for Josh Cates, not Java

  • In C and Assembly, boots on real PC hardware

– You get the skeleton code, fill in interes)ng pieces

  • Build the right intui)ons about real OSes

– but with much simpler code

9

slide-10
SLIDE 10

CSE 506: Opera.ng Systems

JOS 64

  • You will actually implement a 64-bit variant of JOS
  • Developed at Stony Brook!

– Primarily by Amit Arya and Abhinand Palicherla – Contribu)ons also by: Vivek Kulkarni, Varun Agarwal, Chia- Che Tsai, Tao Zhang, Sagar Trehan, Jiahong Huang…

  • Some of these final projects or just contribu)ons from a previous

506 course

  • See your name here next year if you add a par)cularly useful

feature!

10

slide-11
SLIDE 11

CSE 506: Opera.ng Systems

JOS Labs

Memory Management CPU Scheduler User Kernel Hardware Binary Formats Consistency System Calls Interrupts Disk Net RCU File System Device Drivers Networking Sync Memory Allocators Threads 2 3 4 5 6

11

slide-12
SLIDE 12

CSE 506: Opera.ng Systems

Lab 6

  • 3 Op)ons

1) Network device driver (guided assignment) 2) Make JOS a hypervisor (guided assignment) 3) Open-ended project

  • Add a significant feature to JOS
  • A research task on another system

12

slide-13
SLIDE 13

CSE 506: Opera.ng Systems

Challenge Problems

  • Each lab includes challenge problems, which you

may complete for bonus points (generally 5—10 points out of 100)

– Unwise to turn in a lab late to do challenge problems – Can complete challenge problems at any point in the semester---even on old labs

  • Indicate any challenge problems completed in

challenge.txt file

13

slide-14
SLIDE 14

CSE 506: Opera.ng Systems

CSE 522

  • This course can also count as your MS project course

(CSE 522)

  • Requirements: Same as 506, except:

– You must do the labs alone – You must complete 1 challenge problem in each lab

14

slide-15
SLIDE 15

CSE 506: Opera.ng Systems

No Textbook

  • You’re welcome
  • Several recommended texts

– Several free on SBU safari online site – Others on reserve at library – Required readings will mainly be papers you can print out

15

slide-16
SLIDE 16

CSE 506: Opera.ng Systems

Lectures

  • Compare and contrast JOS with real-world OSes

– Mostly Linux, some Windows or OS X, FreeBSD, etc.

  • Supplement background on hardware programming

– Common educa)onal gap between OS and architecture

16

slide-17
SLIDE 17

CSE 506: Opera.ng Systems

My Lecture Style

  • I like par)cipa)on and ques)ons
  • I can explain any concept in many ways, and explain

missing background on the fly

– …but I can’t read your mind---I need to know if you don’t understand something!

17

slide-18
SLIDE 18

CSE 506: Opera.ng Systems

SBU Capture

  • Experiment: TLT will be recording the projec)on and

audio (no video of me, sadly)

– Recordings will be automa)cally posted to BlackBoard – Intended to help you study – Especially helpful for people without strong English

  • This is best effort

– No guarantee all lectures will be recorded

  • This is no subs.tute for lecture aBendance

– Can’t ask ques)ons

  • If aBendance suffers, I will stop recording lectures

18

slide-19
SLIDE 19

CSE 506: Opera.ng Systems

Guest Lectures

  • Senior graduate students will give some lectures to

gain teaching experience

– Including today!

  • Professor Porter will review and cri)que guest

lectures (in person or recorded) with guests

  • Please:

– Ask ques)ons if something is unclear: in class or on piazza – Give Prof. Porter comments on guests (and his lectures)--- posi)ve and nega)ve

19

slide-20
SLIDE 20

CSE 506: Opera.ng Systems

Prerequisites

  • Undergrad OS

– In some cases, industry experience is ok – Worth brushing up if it has been a while – In-class quiz, due before you leave

  • If you can’t answer 50% of these ques)ons, consider ugrad OS
  • C programming
  • Basic Unix command-line proficiency
  • See me if you have already done the JOS lab, or

similar

20

slide-21
SLIDE 21

CSE 506: Opera.ng Systems

Piazza

  • This is the primary announcement medium
  • And for discussions about course work

– Do not post code here or other solu)ons – Goal: Everyone can learn from general ques)ons

  • Material discussed on piazza can be an exam

ques)on

  • Details for piazza forum are on the course website

21

slide-22
SLIDE 22

CSE 506: Opera.ng Systems

Other administra)ve notes

  • Read syllabus completely
  • 2 exams cover: lectures, labs, mailing list
  • Every student will get a VM for lab work

– You may use your own computer, staff can’t support it

  • All staff email goes to cs506ta@cs.stonybrook.edu

– Except private issues for instructor only

22

slide-23
SLIDE 23

CSE 506: Opera.ng Systems

VM Assignments

  • Your VM is cse506-USER, where USER is your ne)d
  • Each VM is hosted on the server esx1sc---esx4sc

– You should receive an email with your server and ini)al password

  • The account is cse506
  • Once it is powered on, it will listen for ssh on port

130

  • Change the password immediately
  • Also, checkpoint your VM before you change things

23

slide-24
SLIDE 24

CSE 506: Opera.ng Systems

Lab Partners

  • Can work alone, but bejer with help

– Some excellent students earned A’s working alone – Many good students earned B’s working alone – No need to be a hero

  • Choose your own partners

– Lab mailing list good for finding them

  • Same for en)re course

– Changes only with instructor permission

24

slide-25
SLIDE 25

CSE 506: Opera.ng Systems

To Do

  • Email me your partner selec)on
  • We will then create the git repository you will use to

turn in your assignments

  • In the mean)me, clone the read-only, hjp

repository to get started

  • Please do this well in advance of the deadline

25

slide-26
SLIDE 26

CSE 506: Opera.ng Systems

Academic Integrity

  • I take chea)ng very seriously. It can end your career.
  • In a gray area, it is your job to stay on right side of

line

  • Never show your code to anyone except your

partner and course staff

  • Never look at anyone else’s code (incl. other

universi)es)

  • Do not discuss code; do not debug each other’s code
  • Acknowledge students that give you good ideas

26

slide-27
SLIDE 27

CSE 506: Opera.ng Systems

Integrity Homework

  • Exercises applying course policies and ethics to

several situa)ons

  • Due in class 2/11

27

slide-28
SLIDE 28

CSE 506: Opera.ng Systems

Lateness

  • Each group gets 72 late hours

– List how many you use in slack.txt – Each day axer these are gone costs a full lejer grade on the assignment

  • It is your responsibility to use these to manage:

– Holidays, weddings, research deadlines, conference travel, Buffy marathons, release of the next Zelda game, etc.

  • 3 Excep)ons: illness (need doctor’s note), death in

immediate family, accommoda)on for disability

28

slide-29
SLIDE 29

CSE 506: Opera.ng Systems

Lab 1 assigned (soon)

  • Due Friday, 2/19 at 11:59 pm, eastern.
  • Instruc)ons on website
  • Quick demo

29

slide-30
SLIDE 30

CSE 506: Opera.ng Systems

Gezng help

  • TA’s (TBD) will keep office hours
  • Instructor keeps office hours

– Note that “by appointment” means more )me available on demand

30

slide-31
SLIDE 31

CSE 506: Opera.ng Systems

Ques)ons?

31