Lecture: OS overview
Class structure
- relations to prereq
- 333: how to write applications that use the operating system
- this course: how to write an operating system
- goals
- understand low-level systems
- learn to work with systems software: reading code/manuals, debugging, etc.
- two OSes
- xv6 (exercises): a Unix-style OS on x86
- JOS (labs): an exokernel-style OS on x86
- structures
- lectures: basic/more modern concepts
- sections: help you with exercises/labs
- final exam: open book/notes/laptop; no Internet or other communication
- textbooks & Intel/AMD manuals
- see the course website on grades & policies
- the first xv6 exercise: start now!
- Lab 1 will be released soon
- systems research at UW
Overview
- the PC hardware
- example: IBM T42
- abstract model:
CPU, Memory, and I/O
- CPU interprets instructions: IP (Instruction Pointer) to memory
- memory stores instructions and data
- I/O to external world: memory-mapped I/O & port I/O
- in this class we use QEMU to emulate the PC
- concepts apply to non-x86 architectures
- how does printing “hello” work on this PC?
- example: a tiny hello “kernel” (tar and source code)
- run
make qemu
- VGA text buffer at physical memory address
0xb8000
- one byte for character, one byte for attribute
- memory-mapped I/O:
0xb8000
+ (row * 80 + column) * 2;
- talk to devices through memory address space
- will see more examples in later labs
- perhaps the lowest-level “hello world” you have seen so far
- what if we have two applications trying to print?
- what happens when you enter a URL in your browser?
- what’s an OS / why do we need an OS
- a reusable library
- a set of programming abstractions
- a mediator between applications/hardware
- concerns: safety, performance, scalability
- a brief history