I/O Devices and Drivers Vivek Pai / Kai Li Princeton University.

Slides:



Advertisements
Similar presentations
I/O Systems & Mass-Storage Systems
Advertisements

CT213 – Computing system Organization
Device Drivers. Linux Device Drivers Linux supports three types of hardware device: character, block and network –character devices: R/W without buffering.
Chapter 13: I/O Systems Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Chapter 13: I/O Systems I/O Hardware Application I/O Interface.
04/14/2008CSCI 315 Operating Systems Design1 I/O Systems Notice: The slides for this lecture have been largely based on those accompanying the textbook.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 13: I/O Systems I/O Hardware Application I/O Interface Kernel I/O Subsystem.
I/O Devices and Drivers
Chapter 13: I/O Systems Silberschatz, Galvin and Gagne ©2005 Operating System Concepts – 7 th Edition, Jan 2, 2005 Chapter 13: I/O Systems I/O Hardware.
I/O Hardware n Incredible variety of I/O devices n Common concepts: – Port – connection point to the computer – Bus (daisy chain or shared direct access)
04/16/2010CSCI 315 Operating Systems Design1 I/O Systems Notice: The slides for this lecture have been largely based on those accompanying an earlier edition.
Home: Phones OFF Please Unix Kernel Parminder Singh Kang Home:
I/O Systems CS 3100 I/O Hardware1. I/O Hardware Incredible variety of I/O devices Common concepts ◦Port ◦Bus (daisy chain or shared direct access) ◦Controller.
Chapter 13: I/O Systems I/O Hardware Application I/O Interface
1 Today I/O Systems Storage. 2 I/O Devices Many different kinds of I/O devices Software that controls them: device drivers.
I/O Systems CSCI 444/544 Operating Systems Fall 2008.
Chapter 13: I/O Systems I/O Hardware Application I/O Interface
Copyright ©: Nahrstedt, Angrave, Abdelzaher
I/O Tanenbaum, ch. 5 p. 329 – 427 Silberschatz, ch. 13 p
I/O Systems ◦ Operating Systems ◦ CS550. Note:  Based on Operating Systems Concepts by Silberschatz, Galvin, and Gagne  Strongly recommended to read.
Device Management. Serial Port Serial Device Serial Device Memory CPU Printer Terminal Modem Mouse etc.
CHAPTER 13: I/O SYSTEMS Overview Overview I/O Hardware I/O Hardware I/O API I/O API I/O Subsystem I/O Subsystem Transforming I/O Requests to Hardware Operations.
Disk Access. DISK STRUCTURE Sector: Smallest unit of data transfer from/to disk; 512B 2/4/8 adjacent sectors transferred together: Blocks Read/write heads.
OPERATING SYSTEM OVERVIEW. Contents Basic hardware elements.
Segmentation & O/S Input/Output Chapter 4 & 5 Tuesday, April 3, 2007.
Chapter 13: I/O Systems Silberschatz, Galvin and Gagne ©2005 Operating System Concepts – 7 th Edition, Jan 2, 2005 Chapter 13: I/O Systems I/O Hardware.
Hardware Definitions –Port: Point of connection –Bus: Interface Daisy Chain (A=>B=>…=>X) Shared Direct Device Access –Controller: Device Electronics –Registers:
Silberschatz, Galvin and Gagne  Operating System Concepts I/O Hardware Incredible variety of I/O devices.
ITEC 502 컴퓨터 시스템 및 실습 Chapter 8-2: I/O Management (Review) Mi-Jung Choi DPNM Lab. Dept. of CSE, POSTECH.
Chapter 13: I/O Systems Silberschatz, Galvin and Gagne ©2005 AE4B33OSS Chapter 13: I/O Systems I/O Hardware Application I/O Interface Kernel I/O.
I/O Systems I/O Hardware Application I/O Interface
1 Lecture 20: I/O n I/O hardware n I/O structure n communication with controllers n device interrupts n device drivers n streams.
1 Module 12: I/O Systems n I/O hardware n Application I/O Interface n Kernel I/O Subsystem n Transforming I/O Requests to Hardware Operations n Performance.
© Janice Regan, CMPT 300, May CMPT 300 Introduction to Operating Systems Principles of I/0 hardware.
Hardware process When the computer is powered up, it begins to execute fetch-execute cycle for the program that is stored in memory at the boot strap entry.
Cosc 4740 Chapter 12 I/O Systems. I/O Hardware Incredible variety of I/O devices –Storage –Transmission –Human-interface.
Slide 5-1 Copyright © 2004 Pearson Education, Inc. Operating Systems: A Modern Perspective, Chapter 5.
UNIX Files File organization and a few primitives.
Chapter 13: I/O Systems. 13.2/34 Chapter 13: I/O Systems I/O Hardware Application I/O Interface Kernel I/O Subsystem Transforming I/O Requests to Hardware.
COS 318: Operating Systems I/O Device and Drivers.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 13: I/O Systems I/O Hardware Application I/O Interface Kernel I/O Subsystem.
Chapter 13: I/O Systems Silberschatz, Galvin and Gagne ©2005 Operating System Principles Chapter 13: I/O Systems I/O Hardware Application I/O Interface.
GLOBAL EDGE SOFTWERE LTD1 R EMOTE F ILE S HARING - Ardhanareesh Aradhyamath.
Chapter 13 – I/O Systems (Pgs ). Devices  Two conflicting properties A. Growing uniformity in interfaces (both h/w and s/w): e.g., USB, TWAIN.
Silberschatz, Galvin and Gagne  Operating System Concepts Six Step Process to Perform DMA Transfer.
XE33OSA Chapter 13: I/O Systems. 13.2XE33OSA Silberschatz, Galvin and Gagne ©2005 Chapter 13: I/O Systems I/O Hardware Application I/O Interface Kernel.
Silberschatz, Galvin and Gagne ©2009 Edited by Khoury, 2015 Operating System Concepts – 9 th Edition, Chapter 13: I/O Systems.
1 Lecture 1: Computer System Structures We go over the aspects of computer architecture relevant to OS design  overview  input and output (I/O) organization.
Hardware process When the computer is powered up, it begins to execute fetch-execute cycle for the program that is stored in memory at the boot strap entry.
Chapter 13: I/O Systems Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Chapter 13: I/O Systems Overview I/O Hardware Application.
Device Driver Concepts Digital UNIX Internals II Device Driver Concepts Chapter 13.
Silberschatz, Galvin, and Gagne  Applied Operating System Concepts Module 12: I/O Systems I/O hardwared Application I/O Interface Kernel I/O.
CMSC 421 Section 0202 I/O Systems Chapter 13: I/O Systems.
I/O Software CS 537 – Introduction to Operating Systems.
1 Device Controller I/O units typically consist of A mechanical component: the device itself An electronic component: the device controller or adapter.
Part IVI/O Systems Chapter 13: I/O Systems. I/O Hardware a typical PCI bus structure 2.
CSCI/CMPE 4334 Operating Systems Review: Exam 1 1.
Chapter 13: I/O Systems.
Module 12: I/O Systems I/O hardware Application I/O Interface
Chapter 13: I/O Systems Modified by Dr. Neerja Mhaskar for CS 3SH3.
Computer Architecture
Chapter 13: I/O Systems.
CSCI 315 Operating Systems Design
I/O Systems I/O Hardware Application I/O Interface
Operating System Concepts
13: I/O Systems I/O hardwared Application I/O Interface
CS703 - Advanced Operating Systems
Chapter 13: I/O Systems I/O Hardware Application I/O Interface
Chapter 13: I/O Systems I/O Hardware Application I/O Interface
Chapter 13: I/O Systems.
Module 12: I/O Systems I/O hardwared Application I/O Interface
Presentation transcript:

I/O Devices and Drivers Vivek Pai / Kai Li Princeton University

2 Gaining Flexibility Question: how do you make a file descriptor refer to non-files? Answer: treat it as an object System calls have a shared part of code Actual work done by calls to function ptrs Each type of object exports a structure of func ptrs that handle all file-related syscalls

3 Where Have We Seen This? Internals of read( ) system call descending down to fop_read method Other places where this might be good? Filesystems – want to support local, network, CD-ROM, legacy Other I/O Devices

4 Using “Virtual Nodes” struct vnode { u_long v_flag; /* vnode flags (see below) */ int v_usecount; /* reference count of users */ int v_writecount; /* reference count of writers */ int v_holdcnt; /* page & buffer references */ u_long v_id; /* capability identifier */ struct mount *v_mount; /* ptr to vfs we are in */ vop_t **v_op; /* vnode operations vector */ TAILQ_ENTRY(vnode) v_freelist; /* vnode freelist */ TAILQ_ENTRY(vnode) v_nmntvnodes; /* vnodes for mount point */ […] enum vtype v_type; /* vnode type */ […] struct vm_object *v_object; /* Place to store VM object */ […] enum vtagtype v_tag; /* type of underlying data */ void *v_data; /* private data for fs */ […] }

5 More Vnode Info enum vtype { VNON, VREG, VDIR, VBLK, VCHR, VLNK, VSOCK, VFIFO, VBAD }; enum vtagtype { VT_NON, VT_UFS, VT_NFS, VT_MFS, VT_PC, VT_LFS, VT_LOFS, VT_FDESC, VT_PORTAL, VT_NULL, VT_UMAP, VT_KERNFS, VT_PROCFS, VT_AFS, VT_ISOFS, VT_UNION, VT_MSDOSFS, VT_TFS, VT_VFS, VT_CODA, VT_NTFS, VT_HPFS, VT_NWFS, VT_SMBFS };

6 Definitions & General Method Overhead CPU time to initiate operation (cannot be overlapped) Latency Time to perform 1-byte I/O operation Bandwidth Rate of I/O transfer, once initiated General method Abstraction of byte transfers Batch transfers into block I/O for efficiency to prorate overhead and latency over a large unit

7 Programmed I/O “Slow” Input Device Device Data registers Status register (ready, busy, interrupt, … ) A simple mouse design Put (X, Y) in data registers on a move Interrupt Perform an input On an interrupt reads values in X, Y registers sets ready bit wakes up a process/thread or execute a piece of code CPU Memory L2 Cache I/O Bus Interface XY

8 Programmed I/O Output Device Device Data registers Status registers (ready, busy, … ) Perform an output Polls the busy bit Writes the data to data register(s) Sets ready bit Controller sets busy bit and transfers data Controller clears the ready bit and busy bit

9 Direct Memory Access (DMA) Perform DMA from host CPU Device driver call (kernel mode) Wait until DMA device is free Initiate a DMA transaction (command, memory address, size) Block DMA interface DMA data to device (size--; address++) Interrupt on completion (size == 0) Interrupt handler (on completion) Wakeup the blocked process CPU Memory L2 Cache I/O Bus DMA Interface Free to move data during DMA

10 Device Drivers Rest of the operating system Device driver Device driver Device driver I/O System Device controller Device controller Device controller Device

11 Device Driver Design Issues Operating system and driver communication Commands and data between OS and device drivers Driver and hardware communication Commands and data between driver and hardware Driver operations Initialize devices Interpreting commands from OS Schedule multiple outstanding requests Manage data transfers Accept and process interrupts Maintain the integrity of driver and kernel data structures

12 Device Driver Interface Open( deviceNumber ) Initialization and allocate resources (buffers) Close( deviceNumber ) Cleanup, deallocate, and possibly turnoff Device driver types Block: fixed sized block data transfer Character: variable sized data transfer Terminal: character driver with terminal control Network: streams for networking

13 Block Device Interface read( deviceNumber, deviceAddr, bufferAddr ) transfer a block of data from “deviceAddr” to “bufferAddr” write( deviceNumber, deviceAddr, bufferAddr ) transfer a block of data from “bufferAddr” to “deviceAddr” seek( deviceNumber, deviceAddress ) move the head to the correct position usually not necessary

14 Character Device Interface read( deviceNumber, bufferAddr, size ) reads “size” bytes from a byte stream device to “bufferAddr” write( deviceNumber, bufferAddr, size ) write “size” bytes from “bufferSize” to a byte stream device

15 Unix Device Driver Interface Entry Points init( ): Initialize hardware start( ): Boot time initialization (require system services) open(dev, flag, id): initialization for read or write close(dev, flag, id): release resources after read and write halt( ): call before the system is shutdown intr(vector): called by the kernel on a hardware interrupt read/write calls: data transfer poll(pri): called by the kernel 25 to 100 times a second ioctl(dev, cmd, arg, mode): special request processing

16 What Was That Last One? The system call “ioctl” SYNOPSIS #include int ioctl(int d, unsigned long request,...); DESCRIPTION The ioctl() function manipulates the underlying device parameters of special files. In particular, many operating characteristics of character special files (e.g. terminals) may be controlled with ioctl() requests. The argument d must be an open file descriptor.

17 Any Counterparts? “fcntl” – operations on files Duplicating file descriptors Get/set/clear “close-on-exec” flag Get/set/clear flags – nonblocking, appending, direct (no-cache), async signal notification, locking & unlocking Also available as dup( ), dup2( ), lockf( ), flock( ) and others

18 Any Other Non-Orthogonality Sending data, credentials, file descriptors over sockets SYNOPSIS ssize_t send(int s, const void *msg, size_t len, int flags); ssize_t sendto(int s, const void *msg, size_t len, int flags, const struct sockaddr *to, socklen_t tolen); ssize_t sendmsg(int s, const struct msghdr *msg, int flags); DESCRIPTION Send(), sendto(), and sendmsg() are used to transmit a message to another socket. Send() may be used only when the socket is in a connected state, while sendto() and sendmsg() may be used at any time.

19 Why Buffering Speed mismatch between producer and consumer Character device and block device, for example Adapt different data transfer sizes Packets vs. streams Support copy semantics Deal with address translation I/O devices see physical memory, but programs use virtual memory Spooling Avoid deadlock problems Caching Avoid I/O operations

20 Asynchronous I/O Why do we want asynchronous I/O? Life is simple if all I/O is synchronous How to implement asynchronous I/O? On a read copy data from a system buffer if the data is there Otherwise, initiate I/O How does process find out about completion? On a write copy to a system buffer, initiate the write and return

21 Other Design Issues Build device drivers statically dynamically How to download device driver dynamically? load drivers into kernel memory install entry points and maintain related data structures initialize the device drivers

22 Dynamic Binding with An Indirect Table Open( 1, … ); Driver-kernel interface Driver for device 0 … open(…) { } read(…) { } Driver for device 1 … open(…) { } read(…) { } Indirect table Other Kernel services Interrupt handlers

23 Dynamic Binding Download drivers by users (may require a reboot) Allocate a piece of kernel memory Put device driver into the memory Bind device driver with the device Pros: flexible and support ISVs and IHVs Cons: security holes