Copyright ©: Nahrstedt, Angrave, Abdelzaher1 University of Illinois at Urbana-Champaign Welcome to CS 241 Systems Programming University of Illinois at Urbana-Champaign Vikram Adve Tarek Abdelzaher
Copyright ©: Nahrstedt, Angrave, Abdelzaher 2 What’s my End Result? Before CS 241: After CS 241: Can design and code interesting applications: Simple Web servers Internet multiplayer games Chatrooms, instant messaging software
Copyright ©: Nahrstedt, Angrave, Abdelzaher 3 The Team Vikram Adve (Instructor) Office: 4235 SC Tel: (217) Tarek Abdelzaher (Instructor) Office: 4126 SC Tel: (217) TAs: Liping Chen, Imranul Hoque, Saurabh Nagnia, Wade Fagen
Copyright ©: Nahrstedt, Angrave, Abdelzaher 4 Newsgroups We encourage discussion on classroom issues Please subscribe to these newsgroups: class.cs241 (general discussion) class.cs241.announce (announcements)
Copyright ©: Nahrstedt, Angrave, Abdelzaher 5 The Textbook Introduction to Systems Concepts and Systems Programming University of Illinois Custom Edition Copyright © 2007 Pearson Custom Publishing ISBN Taken from: Operating Systems: Internals and Design Principles, Fifth Edition by William Stallings UNIX™ Systems Programming: Communication, Concurrency, and Threads by Kay A. Robbins and Steven Robbins Computer Systems: A Programmer's Perspective by Randal E. Bryant and David R. O'Hallaron
Copyright ©: Nahrstedt, Angrave, Abdelzaher 6 Your CS 241 “Mission” Come to class, MWF, 9-9:50am Please participate actively… Sign up for one discussion section per week (starting next week) Discussion section times will be announced at the end of this week Read textbook Reading assignments posted on webpage (none this week) Do 2 homeworks Code 6 Short programming assignments (in teams of 2) Short Machine Problems (SMPs) Code 2 Long programming assignments (in teams of 2) Long Machine Problems (LMPs) Take Midterm, Wednesday 3/16 Take Final (finals week)
Copyright ©: Nahrstedt, Angrave, Abdelzaher 7 Grading Final Exam: 30% Mid-term Exam: 20% Homework (two total): 10% Team Machine Problems (8 total): 30% 6 Short Machine Problems 3% 2 Long Machine Problems 6% Participation: 10% Class involvement Pop quizzes
Copyright ©: Nahrstedt, Angrave, Abdelzaher 8 Please… No late homework/MP submissions 1 week window for re-grades from return date
Copyright ©: Nahrstedt, Angrave, Abdelzaher 9 Introduction What is an operating system? What is it for? What is system programming?
Copyright ©: Nahrstedt, Angrave, Abdelzaher 10 Course Objectives Identify the basic components of an operating system, describe their purpose, and explain how they function. Write, compile, debug, and execute C programs that correctly use system interfaces provided by UNIX (or a UNIX- like operating system).
Copyright ©: Nahrstedt, Angrave, Abdelzaher 11 More Detailed Objectives Understand the Basics (week 1-2) Use UNIX system calls correctly from within C programs Make the OS do tasks (week 3-8) Create and manage processes and threads on UNIX. Exploit OS semaphores and mutexes Control OS scheduling policy parameters. Take advantage of OS signals and signal handlers. Set OS timers and clocks. Manage machine resources (week 9-12) Manage files and I/O on UNIX. Manage memory Exploit DMA Write networked applications (week 13-15) Use communication protocols (TCP/IP) and interfaces (Sockets) Write distributed multi-threaded apps that talk across a network.
Copyright ©: Nahrstedt, Angrave, Abdelzaher 12 Machine Problems SMP0Advanced C SMP1Programs and Processes SMP2Processes and Threads SMP3Synchronization SMP4Scheduling LMP1File Systems LMP2Memory Management SMP5Networking
Copyright ©: Nahrstedt, Angrave, Abdelzaher 13 Schedule See class webpage
Copyright ©: Nahrstedt, Angrave, Abdelzaher 14 Your to-do List Today: Visit the class webpage and check out all the info Familiarize yourself with newsgroups (see and subscribe to: class.cs241 and class.cs241.announcehttp://news.cs.uiuc.edu Find a reference to refresh your C programming skills (e.g., see tutorial below)
Copyright ©: Nahrstedt, Angrave, Abdelzaher 15 Your to-do List Soon: Sign up for a discussion section if you have not already (look out for an announcement at the end of this week) Discussion sections are on 0220 not 1111! Pair up for upcoming machine problems Read “How to study” Guide (see lecture notes on class webpage)How to study