classic systems
play

CLASSIC SYSTEMS: Key developer of the B programming lanuage, Unix, - PDF document

8/29/2012 The UNIX Time-Sharing System Dennis Ritchie and Ken Thompson Background of authors at Bell Labs Both won Turing Awards in 1983 Dennis Ritchie Key developer of The C Programming Lanuage , Unix, and Multics Ken


  1. 8/29/2012 The UNIX Time-Sharing System Dennis Ritchie and Ken Thompson  Background of authors at Bell Labs  Both won Turing Awards in 1983  Dennis Ritchie  Key developer of The C Programming Lanuage , Unix, and Multics  Ken Thompson CLASSIC SYSTEMS:  Key developer of the B programming lanuage, Unix, Multics, and Plan 9 UNIX AND MACH  Also QED, ed, UTF-8 Ken Birman CS6410 Unix slides based on Hakim’s Fall 2011 materials Mach slides based on materials on the CMU website The UNIX Time-Sharing System The UNIX Time-Sharing System Dennis Ritchie and Ken Thompson Dennis Ritchie and Ken Thompson  Classic system and paper  described almost entirely in 10 pages  Key idea  elegant combination: a few concepts that fit together well  Instead of a perfect specialized API for each kind of device or abstraction, the API is deliberately small System features Version 3 Unix  Time-sharing system  1969: Version 1 ran PDP-7  Hierarchical file system  1971: Version 3 Ran on PDP-11’s  Device-independent I/O  Costing as little as $40k!  Shell-based, tty user interface  < 50 KB  Filter-based, record-less processing paradigm  2 man-years to write  Major early innovations: “fork” system call for  Written in C process creation, file I/O via a single subsystem, pipes, I/O redirection to support chains PDP-7 PDP-11 1

  2. 8/29/2012 File System Uniform I/O Model  Ordinary files (uninterpreted)  open, close, read, write, seek  Uniform calls eliminates differences between devices  Directories (protected ordinary files)  Two categories of files: character (or byte) stream and  Special files (I/O) block I/O, typically 512 bytes per block  other system calls  close, status, chmod, mkdir, ln  One way to “talk to the device” more directly  ioctl, a grab-bag of special functionality  lowest level data type is raw bytes, not “records” Directories Special Files  root directory  Uniform I/O model  path names  Each device associated with at least one file  But read or write of file results in activation of device  rooted tree  current working directory  Advantage: Uniform naming and protection model  back link to parent  File and device I/O are as similar as possible  multiple links to ordinary files  File and device names have the same syntax and meaning, can pass as arguments to programs  Same protection mechanism as regular files Removable File System Protection  Tree-structured  User-world, RWX bits  Mount ’ed on an ordinary file  set-user-id bit  Mount replaces a leaf of the hierarchy tree (the  super user is just special user id ordinary file) by a whole new subtree (the hierarchy stored on the removable volume)  After mount, virtually no distinction between files on permanent media or removable media 2

  3. 8/29/2012 File System Implementation I-node Table  System table of i-numbers (i-list)  short, unique name that points at file info.  i-nodes  allows simple & efficient fsck  path names  cannot handle accounting issues (directory is just a special file!)  mount table File name Inode# Inode  buffered data  write-behind Many devices fit the block model Processes and images  Disks  text, data & stack segments  Drums  process swapping  Tape drives  pid = fork()  USB storage  pipes  exec(file, arg1, ..., argn)  Early version of the ethernet interface was  pid = wait() presented as a kind of block device (seek disabled)  exit(status)  But many devices used IOCTL operations heavily Easy to create pipelines The Shell  A “pipe” is a process-to-process data stream, could  cmd arg1 ... argn be implemented via bounded buffers, TCP , etc  stdio & I/O redirection  One process can write on a connection that another  filters & pipes reads, allowing chains of commands  multi-tasking from a single shell  shell is just a program % cat *.txt | grep foo | wc  Trivial to implement in shell  In combination with an easily programmable shell  Redirection, background processes, cmd files, etc scripting model, very powerful! 3

  4. 8/29/2012 Traps Perspective  Hardware interrupts  Not designed to meet predefined objective  Software signals  Goal: create a comfortable environment to explore machine and operating system  Trap to system routine  Other goals  Programmer convenience  Elegance of design  Self-maintaining Perspective Even so, Unix has staying power!  But had many problems too. Here are a few:  Today’s Linux systems are far more comprehensive yet the core simplicity of Unix API remains a very  File names too short and file system damaged on crash powerful force  Didn’t plan for threads and never supported them well  “Select” system call and handling of “signals” was ugly and out of character w.r.t. other features  Struggle to keep things simple has helped keep  Hard to add dynamic libraries (poor handling of O/S developers from making the system processes with lots of “segments”) specialized in every way, hard to understand  Shared memory and mapped files fit model poorly  ...in effect, the initial simplicity was at least partly  Even with modern extensions, Unix has a simplicity because of some serious limitations! that contrasts with Windows .NET API...  -Kernel trend Microkernel vs. Monolithic Systems  Even at outset we wanted to support many versions of Unix in one “box” and later, Windows and IBM operating systems too  A question of cost, but also of developer preference  Each platform has its merits  Led to a research push: build a micro-kernel, then host the desired O/S as a customization layer on it  NOT the same as a virtual machine architecture!  In a  -Kernel, the hosted O/S is an “application”, whereas a VM mimics hardware and runs the real O/S Source: http://en.wikipedia.org/wiki/File:OS-structure.svg 4

  5. 8/29/2012 Mach History Design Principles Maintain BSD Compatibility  CMU Accent operating system  Simple programmer interface PLUS  No ability to execute UNIX applications  Easy portability  Single Hardware architecture  Diverse architectures.  BSD Unix system + Accent concepts  Extensive library of  Varying network speed utilities/applications  Simple kernel  Mach  Combine utilities via pipes  Distributed operation OpenStep GNU Hurd  Integrated memory Professor at Rochester, then CMU. Now management and IPC XNU OSF/1 Microsoft VP Research Mac OS X Darwin  Heterogeneous systems System Components Memory Management and IPC  Memory Management using IPC: message text region  Memory object represented by port(s) threads port  IPC messages are sent to those ports to request operation on task the object  Memory objects can be remote  kernel caches the contents Task   Thread Port   IPC using memory-management techniques: Port set port set   Pass message by moving pointers to shared memory objects  Message Memory object data region  Virtual-memory remapping to transfer large contents  (virtual copy or copy-on-write) secondary storage memory object Mach innovations Process Management Basic Structure  Extremely sophisticated use of VM hardware  Tasks/Threads  Extensive sharing of pages with various read/write  Synchronization primitives: mode settings depending on situation  Mach IPC:  Processes exchanging messages at rendezvous points  Unlike a Unix process, Mach “task” had an assemblage  Wait/signal associated with semaphores can be implemented using of segments and pages constructed very dynamically IPC  Most abstractions were mapped to these basic VM  High priority event-notification used to deliver exceptions, signals  Thread-level synchronization using thread start/stop calls ideas, which also support all forms of Mach IPC 5

Download Presentation
Download Policy: The content available on the website is offered to you 'AS IS' for your personal information and use only. It cannot be commercialized, licensed, or distributed on other websites without prior consent from the author. To download a presentation, simply click this link. If you encounter any difficulties during the download process, it's possible that the publisher has removed the file from their server.

Recommend


More recommend