Lec1 424 002

Download as pdf or txt
Download as pdf or txt
You are on page 1of 57

CS162

Operating Systems and


Systems Programming
Lecture 1

What is an Operating System?

January 21st, 202


Prof. John Kubiatowic
http://cs162.eecs.Berkeley.edu

Acknowledgments: Lecture slides are from the Operating Systems course


taught by John Kubiatowicz at Berkeley, with few minor updates/changes.
When slides are obtained from other sources, a a reference will be noted on
the bottom of that slide, in which case a full list of references is provided on the
last slide.



0



Greatest Artifact of Human Civilization…

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 2


Internet Scale: Over 3.8 Billion Users!
% of world’s
population 3.8 B
ARPANet

Internet WWW 2.0 B 1/26/11


RFC 675 TCP/IP

HTTP 0.9

1969 1974 1990 2017

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 3


Operating Systems are at the Heart of it All!


• Provide abstractions to app
– File system
– Processes, threads
– VM, container
– Naming syste

• Manage resources
– Memory, CPU, storage,
• Achieves the above by implementing specific algorithms and techniques
– Schedulin
– Concurrenc
– Transaction
– Securit
– …..

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 4


Example: What’s in a Search Query?


DNS
Servers Datacenter

DN creat Search
request resul Index
page

Page
store
Load
balancer

Ad Server

• Complex interaction of multiple components in multiple


administrative domain
– Systems, services, protocols, …
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 5
S

Why take CE424?


• Some of you will actually design and build operating systems or
components of them
– Perhaps more now than eve
• Many of you will create systems that utilize the core concepts
in operating systems
– Whether you build software or hardwar
– The concepts and design patterns appear at many level
• All of you will build applications, etc. that utilize operating
system
– The better you understand their design and implementation, the
better use you’ll make of them.

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 6


s

Goals for Today


• What is an Operating System
– And – what is it not
• What makes Operating Systems so exciting
• Oh, and “How does this class operate?

Interactive is important
Ask Questions!

Slides courtesy of David Culler, Anthony D. Joseph, John Kubiatowicz, AJ Shankar,


George Necula, Alex Aiken, Eric Brewer, Ras Bodik, Ion Stoica, Doug Tygar, and David
Wagner.

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 7


?

What is an operating system?


• Special layer of software that provides application software access to
hardware resource
– Convenient abstraction of complex hardware device
– Protected access to shared resource
– Security and authenticatio
– Communication amongst logical entities

appl n
appln
appln
OS

Hardware

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 8


s

Operator …

Switchboard Operator

Computer Operators

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 9


CE323 – Machine Structures
ISA
Hardware Memory
Page Table
(TLB)
Processor Cache

OS

Ctrlr
Networks
storage

Displays
Inputs

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 10


What is an Operating System?


• Illusionis
– Provide clean, easy to use abstractions of physical
resource
» Infinite memory, dedicated machin
» Higher level objects: files, users, message
» Masking limitations, virtualization

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 11


s

OS Basics: “Virtual Machine” Boundary


Threads
Address Spaces Windows
Processes Files Sockets

Software OS Hardware Virtualization

Hardware Instruction Set


Architecture (ISA) Memory

Processor

Networks

storage

Displays

Inputs
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 12

OS Basics: Program ⇒ Process


Threads
Address Spaces Windows
Processes Files Sockets

Software OS Hardware Virtualization

Hardware ISA
Memory

Processor

OS

Networks
storage

Displays
Inputs
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 13
Defn: Process
• Address Spac
• One or more threads of contro
• Additional system state associated with i

• Thread:
– locus of control (PC
– Its registers (processor state when running
– And its “stack” (SP
» As required by programming language runtime

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 14


For Example …

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 15


OS Basics: Context Switch
Threads
Address Spaces Windows
Processes Files Sockets

Software OS Hardware Virtualization

Hardware ISA
Memory

Processor

OS

Networks
storage

Displays
Inputs
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 16
What is an Operating System?
• Refere
– Manage sharing of resources, Protection, Isolatio
» Resource allocation, isolation, communicatio
• Illusionis
– Provide clean, easy to use abstractions of physical
resource
» Infinite memory, dedicated machin
» Higher level objects: files, users, message
» Masking limitations, virtualization

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 17


e

OS Basics: Scheduling, Protection


Threads
Address Spaces Windows
Processes Files Sockets

Software OS Hardware Virtualization

Hardware ISA
Memory

Processor Protection
Boundary
OS

Networks
storage

Displays
Inputs
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 18
What is an Operating System?
• Refere
– Manage sharing of resources, Protection, Isolatio
» Resource allocation, isolation, communicatio
• Illusionis
– Provide clean, easy to use abstractions of physical
resource
» Infinite memory, dedicated machin
» Higher level objects: files, users, message
» Masking limitations, virtualizatio
• Glu
– Common service
» Storage, Window system, Networkin
» Sharing, Authorizatio
» Look and feel

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 19


e

OS Basics: I/O
Threads
Address Spaces Windows
Processes Files Sockets

Software OS Hardware Virtualization

Hardware ISA
Memory

Processor Protection
Boundary
OS

Ctrlr
Networks
storage

Displays
Inputs
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 20
OS Basics: Creating Process/Loading Program
Threads
Address Spaces Windows
Processes Files Sockets

Software OS Hardware Virtualization

Hardware ISA
Memory

Processor Protection
Boundary
OS

Ctrlr
Networks
storage

Displays
Inputs
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 21
What makes Operating Systems
Exciting and Challenging?

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 22


Technology Trends: Moore’s Law

Moore’s Law

2X transistors/Chip Every 1.5 year


Gordon Moore (co-founder of Called “Moore’s Law
Intel) predicted in 1965 that the
transistor density of semiconductor Microprocessors have become
chips would double roughly every smaller, denser, and more
18 months powerful

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 23


Big Challenge: Slowdown in Joy’s law of Performance


10000 3X
From Hennessy and Patterson, Computer Architecture: A
Quantitative Approach, 4th edition, Sept. 15, 2006
??%/year

1000
Performance (vs. VAX-11/780)

52%/year

100

⇒ Sea change in chip design:


10
25%/year multiple “cores” or processors per
chip
1
1978 1980 1982 1984 1986 1988 1990 1992 1994 1996 1998 2000 2002 2004 2006

• VA : 25%/year 1978 to 1986


• RISC + x86 : 52%/year 1986 to 2002
• RISC + x86 : ??%/year 2002 to present
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 24
X
Another Challenge: Power Density

• Moore’s law extrapolatio


– Potential power density reaching amazing levels
• Flip side: battery life very importan
– Moore’s law yielded more functionality at equivalent
(or less) total energy consumption
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 25
n


ManyCore Chips: The future arrived in 2007
• Intel 80-core multicore chip (Feb 2007
– 80 simple cores
– Two FP-engines / core
– Mesh-like network
– 100 million transistors
– 65nm feature size
• Intel Single-Chip Cloud
Computer (August 2010)
– 24 “tiles” with two cores/tile
– 24-router mesh network
– 4 DDR3 memory controllers
– Hardware support for message-passing

• How to program these


– Use 2 CPUs for video/audio
– Use 1 for word processor, 1 for browser
– 76 for virus checking???
• Parallelism must be exploited at all level
• Amazon X1 instances (2016
– 128 virtual cores, 2 TB RAM
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 26
?


)

But then Moore’s Law Ended…

• Moore’s Law has (officially) ended -- Feb 201


– No longer getting 2 x transistors/chip every 18 months
– or even every 24 month
• May have only 2-3 smallest geometry fabrication plants left
– Intel and Samsung and/or TSM
– Vendors moving to 3D stacked chip
– More layers in old geometries

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 27


s

Storage Capacity Still Growing

HDD

(source: https://www.networkworld.com/article/3153244/data-center/solid-state-drives-are-now-larger-than-
hard-disk-drives-the-impact-for-your-data-center.html)
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 28
Network Capacity Still Increasing

(source: http://www.ospmag.com/issue/article/Time-Is-Not-Always-On-Our-Side )
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 29
Internet Scale: 1.06 Billion Hosts (Jan 2017)

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 30


Internet Scale: Over 3.8 Billion Users!

(source: http://www.internetworldstats.com/stats.htm)

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 31


Not Only PCs connected to the Internet
• In 2011, smartphone shipments exceeded PC shipments
1.53B in 2017
• 2011 shipments
– 487M smartphones
262.5M in 2017
– 414M PC clients
» 210M notebooks
» 112M desktops 164M in 2017
» 63M tablet
– 25M smart TVs 39.5M in 2017

• 4 billion phones in the world ! smartphones over


next few year
• Then…

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 32


s

People-to-Computer Ratio Over Time


Computers
Number
Per Person
crunching, Data
1:106 Storage, Massive
Inet Services
Mainframe
ML, …

Mini
1:103
Workstation
Productivity
PC Interactive
Laptop
1:1
PDA
Cell Streaming from/
to the physical
103:1 world

Mote!
years
The Internet of
Bell’s Law: new computer class per 10 years
Things!

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 33


,

Vast Range of Timescales


Jeff Dean: "Numbers Everyone Should Know"

Key Stroke / Clic


100 ms

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 34


k

Societal Scale Information Systems


(Or the “Internet of Things”?)
Massive Cluster

• The world is a large distributed syste


Gigabit Ethernet
– Microprocessors in everythin Clusters
– Vast infrastructure behind them Massive Cluster

Gigabit Ethernet Clusters

Internet Scalable, Reliable,


Connectivity Secure Services

Databases
Information Collection
Remote Storage
Online Games
Commerce

MEMS for
Sensor Nets
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 35


g

Infrastructure, Textbook & Readings


• Infrastructur
– Website: http://sharif.edu/~kharrazi/courses/40424-002
– Discord
• Textbook: Operating Systems: Principles and Practice
(2nd Edition) Anderson and Dahli
• Recommend: Operating Systems Concepts,
9th Edition Silbershatz, Galvin, Gagne
• Online supplement
– See course website
– Includes Appendices, sample problems, etc.
– Networking, Databases, Software Eng, Security
– Some Research Papers!

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 36




Syllabus
• OS Concepts: How to Navigate as a Systems Programmer
– Process, I/O, Networks and Virtual Machine
• Concurrenc
– Threads, scheduling, locks, deadlock, scalability, fairnes
• Address Spac
– Virtual memory, address translation, protection, sharin
• File System
– I/O devices, file objects, storage, naming, caching, performance, paging,
transactions, database
• Distributed System
– Protocols, N-Tiers, RPC, NFS, DHTs, Consistency, Scalability, multicas
• Reliability & Securit
– Fault tolerance, protection, securit
• Cloud Infrastructure

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 37


s

Learning by Doing
• Individual Homework: Learn Systems Programmin
1. Tools, Autograding, recall C, executabl
2. Simple Shel
3. Web serve
4. Memory Managemen
• Three Group Projects (Pintos in C
1. Threads & Scheduling
2. User-program
3. File Systems

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 38


r

Group Projects
• Project teams have 4 members
• Must work in groups in “the real world
• Communicate with colleagues (team members
• Communication problems are natura
• What have you done
• What answers you need from others
• Dividing up by Task is the worst approach. Work as a team
• You must document your work!!
• Communicate with supervisor (TAs
• What is the team’s plan
• What is each member’s responsibility
• Short progress reports are require
• Design Documents: High-level description for a manager!

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 39


?

Getting started
• Start homework 0 right away (hopefully Today!
– Vagrant virtualbox – VM environment for the cours
» Consistent, managed environment on your machin
– Get familiar with all the tool
– Submit to autograder via gi
• Early Dro
– Given the assignments, this is a highly rewarding but time consuming cours
– If you are not serious about taking, please drop early

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 40


p

Preparing Yourself for this Class


• The projects will require you to be very comfortable with programming
and debugging
– Pointers (including function pointers, void*
– Memory Management (malloc, free, stack vs heap
– Debugging with GD
• You will be working on a larger, more sophisticated code base than
anything you've likely seen in previous classes
• C programming reference (still in beta)
– https://cs162.eecs.berkeley.edu/ladder/

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 41


C

Grading
• 15% Midterm
• 20% Final
• 25% Homewor
• 40% Group HWs
• Group HWs gradin
• [10 pts] Initial desig
• [10 pts] Design revie
• [10 pts] Design documen
• [60 pts] Code (3 checkpoints
• [10 pts] Final desig
• Submission via git push to release branc
• Regular git push so TA sees your progress

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 42


CE424 Collaboration Policy

Explaining a concept to someone in another grou


Discussing algorithms/testing strategies with other group
Helping debug someone else’s code (in another group
Searching online for generic algorithms (e.g., hash table)

Sharing code or test cases with another grou


Copying OR reading another group’s code or test case
Copying OR reading online code or test cases from prior years

We compare all project submissions against prior year submissions


and online solutions and will take actions (described on the course
overview page) against offenders
More rules on the course website.

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 43


What is an Operating System?


• Refere
– Manage sharing of resources, Protection, Isolatio
» Resource allocation, isolation, communicatio
• Illusionis
– Provide clean, easy to use abstractions of physical
resource
» Infinite memory, dedicated machin
» Higher level objects: files, users, message
» Masking limitations, virtualizatio
• Glu
– Common service
» Storage, Window system, Networkin
» Sharing, Authorizatio
» Look and feel

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 44


e

Challenge: Complexity
• Applications consisting of
– … a variety of software modules that
– … run on a variety of devices (machines) tha
» … implement different hardware architecture
» … run competing application
» … fail in unexpected way
» … can be under a variety of attack

• Not feasible to test software for all possible environments and


combinations of components and device
– The question is not whether there are bugs but how serious are
the bugs!

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 45


s

The World Is Parallel: Intel SkyLake (2017)


• Up to 28 Cores, 56 Thread
– 694 mm² die size (estimated
• Many different instruction
– Security, Graphic
• Caches on chip
– L2: 28 Mi
– Shared L3: 38.5 MiB
(non-inclusive
– Directory-based cache coherenc
• Network
– On-chip Mesh Interconnec
– Fast off-chip network directly supports 8-
chips connecte
• DRAM/chip
– Up to 1.5 Ti
– DDR4 memory
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 46
B


t

HW Functionality comes with great complexity!


Intel Skylake-X
I/O Configuration

Proc

Caches
Busses

adapters
Memory

Controllers

Disks
I/O Devices: Displays
Networks
Keyboards
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 47
Increasing Software Complexity
Linux 2.2.0

Mars Curiosity Rover

Firefox

Android

Linux 3.1 (recent)

Windows 7

Microsoft Office 2013

Windows Vista

Facebook

Mac OS X "Tiger"

Modern Car

Mouse Base Pairs

0 30 60 90 120

Millions of Lines of Cod


(source https://informationisbeautiful.net/visualizations/million-lines-of-code/)

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 48


e

Example: Some Mars Rover (“Pathfinder”) Requirements


• Pathfinder hardware limitations/complexity
– 20Mhz processor, 128MB of DRAM, VxWorks OS
– cameras, scientific instruments, batteries,
solar panels, and locomotion equipment
– Many independent processes work together
• Can’t hit reset button very easily
– Must reboot itself if necessary
– Must always be able to receive commands from Earth
• Individual Programs must not interfer
– Suppose the MUT (Martian Universal Translator Module) buggy
– Better not crash antenna positioning software!
• Further, all software may crash occasionall
– Automatic restart with diagnostics sent to Earth
– Periodic checkpoint of results saved?
• Certain functions time critical
– Need to stop before hitting something
– Must track orbit of Earth for communication
• A lot of similarity with the Internet of Things
– Complexity, QoS, Inaccessbility, Power limitations … ?
1/21/20 Kubiatowicz CS162 © UCB Fall 2020 49
:


e

How do we tame complexity?


• Every piece of computer hardware differen
– Different CP
» Pentium, PowerPC, ColdFire, ARM, MIP
– Different amounts of memory, disk,
– Different types of device
» Mice, Keyboards, Sensors, Cameras, Fingerprint reader
– Different networking environmen
» Cable, DSL, Wireless, Firewalls,
• Questions
– Does the programmer need to write a single program that performs
many independent activities
– Does every program have to be altered for every piece of hardware
– Does a faulty program crash everything
– Does every program have access to all hardware?

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 50


:

OS Tool: Virtual Machine Abstraction


Application
Virtual Machine Interface
Operating System
Physical Machine Interface
Hardware
• Software Engineering Problem:
– Turn hardware/software quirks ⇒
what programmers want/nee
– Optimize for convenience, utilization, security, reliability, etc
• For any OS area (e.g. file systems, virtual memory, networking,
scheduling)
– What’s the hardware interface? (physical reality
– What’s the application interface? (nicer abstraction)

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 51


:


)

Virtual Machines
• Software emulation of an abstract machin
– Give programs illusion they own the machin
– Make it look like hardware has features you wan
• Two types of “Virtual Machine”
– Process VM: supports the execution of a single program; this
functionality typically provided by O
– System VM: supports the execution of an entire OS and its applications
(e.g., VMWare Fusion, Virtual box, Parallels Desktop, Xen)

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 52


s

Process VMs

• Programming simplicit
– Each process thinks it has all memory/CPU tim
– Each process thinks it owns all device
– Different devices appear to have same high level interfac
– Device interfaces more powerful than raw hardwar
» Bitmapped display ⇒ windowing syste
» Ethernet card ⇒ reliable, ordered, networking (TCP/IP
• Fault Isolatio
– Processes unable to directly impact other processe
– Bugs cannot crash whole machin
• Protection and Portabilit
– Java interface safe and stable across many platforms

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 53


n

System Virtual Machines: Layers of OSs


• Useful for OS developmen
– When OS crashes, restricted to one V
– Can aid testing programs on other OSs

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 54


t

What is an Operating System,… Really?


• Most Likely
– Memory Managemen
– I/O Managemen
– CPU Schedulin
– Communications? (Does Email belong in OS?
– Multitasking/multiprogramming
• What about
– File System
– Multimedia Support
– User Interface
– Internet Browser? ☺
• Is this only interesting to Academics??

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 55


?

Operating System Definition (Cont.)

• No universally accepted definitio


• “Everything a vendor ships when you order an operating
system” is good approximatio
– But varies wildl
• “The one program running at all times on the computer” is
the kernel
– Everything else is either a system program (ships with the
operating system) or an application program

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 56


“In conclusion…”
• Operating systems provide a virtual machine abstraction to handle
diverse hardwar
– Operating systems simplify application development by providing
standard service
• Operating systems coordinate resources and protect users from
each othe
– Operating systems can provide an array of fault containment, fault
tolerance, and fault recover

• CE424 combines things from many other areas of computer science


– Languages, data structures, hardware, and algorithm

1/21/20 Kubiatowicz CS162 © UCB Fall 2020 57


r

You might also like