Contents. NOTICE & Programming Assignment #1. QnA about last exercise. File IO exercise
|
|
- Virgil Cunningham
- 5 years ago
- Views:
Transcription
1 File I/O Examples Prof. Jin-Soo TA - Dong-Yun Lee(dylee@csl.skku.edu) Computer Systems Laboratory Sungkyunkwan University
2 Contents NOTICE & Programming Assignment #1 QnA about last exercise File IO exercise 2
3 Notice We will use sys server for assignment Both source code and report You can directly check your score via server You can change the final version of your code Be careful that your final version is right version There should be some restriction at server Maximum number of upload? etc 3
4 Programming Assignment #1 Let s check together PA #1 Some news.. 1. Input filename is *.txt (bible name is without.txt ) ex) genesis.txt, daniel.txt, etc.. 2. GNU make tools Your code should be compiled with the following cmd. $ make all 3. IndexPrinter : print the word with lowercase ex) the (O) The (X) 4
5 Report Report format : [ 학번 ].pdf I like simple, neat, clean, graphical, understandable, easy, and short report About your own data structure and functions 5
6 QnA For PA #1 6
7 Exercise Review (1) const qualifier void foo1(const char *s1) { s1[0] = a ; } void foo2(const char *s1) { s1 = hey ; } void foo3(const char *s1) { char *s = s1; } void foo4(const char *s1) { char *s = s1; s[0] = e ; } void foo5 (char * const s1) { s1[0] = a ; } void foo6(char * const s1) { s1 = hey ; } 7
8 Exercise Review (2) 8
9 Exercise Review (3) Why below code do not work correctly? Explain it correctly You can use anything for the answer int main(void) { char c; } while(read(0, &c, 1)!= 0) write(1, &c, 1); exit(0); 9
10 Remind 6 System calls open() close() read() write() lseek() stat() / fstat() 10
11 Example #1 (1) char filename[] = "hello-dos.txt"; int fd; char buffer[16]; off_t pos = 0; // long long; fd = open(filename, O_RDWR O_CREAT, 0755); read(fd, buffer, 6); read(fd, buffer+6, 2); File state (FD: 3) path: "hello-dos.txt" position: 0 size: 20 lseek(fd, -2, SEEK_CUR); buffer[0] = '\n'; write(fd, buffer, 1); lseek(fd, 8, SEEK_SET); strcpy(buffer, "How"); write(fd, buffer, 3); close(fd); H e l l o. \r \n W h o a r e y o u? EOF fd = open(filename, O_WRONLY O_CREAT O_EXCL, 0755); if (fd < 0) printf("errno : %d, error code - EEXIST : %d\n", errno, EEXIST); 11
12 Example #1 (2) char filename[] = "hello-dos.txt"; int fd; char buffer[16]; off_t pos = 0; // long long; fd = open(filename, O_RDWR O_CREAT, 0755); read(fd, buffer, 6); // "Hello." read(fd, buffer+6, 2); File state (FD: 3) path: "hello-dos.txt" position: 6 size: 20 lseek(fd, -2, SEEK_CUR); buffer[0] = '\n'; write(fd, buffer, 1); lseek(fd, 8, SEEK_SET); strcpy(buffer, "How"); write(fd, buffer, 3); close(fd); H e l l o. \r \n W h o a r e y o u? EOF fd = open(filename, O_WRONLY O_CREAT O_EXCL, 0755); if (fd < 0) printf("errno : %d, error code - EEXIST : %d\n", errno, EEXIST); 12
13 Example #1 (3) char filename[] = "hello-dos.txt"; int fd; char buffer[16]; off_t pos = 0; // long long; fd = open(filename, O_RDWR O_CREAT, 0755); read(fd, buffer, 6); read(fd, buffer+6, 2); // "Hello.\r\n" File state (FD: 3) path: "hello-dos.txt" position: 8 size: 20 lseek(fd, -2, SEEK_CUR); buffer[0] = '\n'; write(fd, buffer, 1); lseek(fd, 8, SEEK_SET); strcpy(buffer, "How"); write(fd, buffer, 3); close(fd); H e l l o. \r \n W h o a r e y o u? EOF fd = open(filename, O_WRONLY O_CREAT O_EXCL, 0755); if (fd < 0) printf("errno : %d, error code - EEXIST : %d\n", errno, EEXIST); 13
14 Example #1 (4) char filename[] = "hello-dos.txt"; int fd; char buffer[16]; off_t pos = 0; // long long; fd = open(filename, O_RDWR O_CREAT, 0755); read(fd, buffer, 6); read(fd, buffer+6, 2); File state (FD: 3) path: "hello-dos.txt" position: 6 size: 20 lseek(fd, -2, SEEK_CUR); buffer[0] = '\n'; write(fd, buffer, 1); lseek(fd, 8, SEEK_SET); strcpy(buffer, "How"); write(fd, buffer, 3); close(fd); H e l l o. \r \n W h o a r e y o u? EOF fd = open(filename, O_WRONLY O_CREAT O_EXCL, 0755); if (fd < 0) printf("errno : %d, error code - EEXIST : %d\n", errno, EEXIST); 14
15 Example #1 (5) char filename[] = "hello-dos.txt"; int fd; char buffer[16]; off_t pos = 0; // long long; fd = open(filename, O_RDWR O_CREAT, 0755); read(fd, buffer, 6); read(fd, buffer+6, 2); File state (FD: 3) path: "hello-dos.txt" position: 7 size: 20 lseek(fd, -2, SEEK_CUR); buffer[0] = '\n'; write(fd, buffer, 1); lseek(fd, 8, SEEK_SET); strcpy(buffer, "How"); write(fd, buffer, 3); close(fd); H e l l o. \n \n W h o a r e y o u? EOF fd = open(filename, O_WRONLY O_CREAT O_EXCL, 0755); if (fd < 0) printf("errno : %d, error code - EEXIST : %d\n", errno, EEXIST); 15
16 Example #1 (6) char filename[] = "hello-dos.txt"; int fd; char buffer[16]; off_t pos = 0; // long long; fd = open(filename, O_RDWR O_CREAT, 0755); read(fd, buffer, 6); read(fd, buffer+6, 2); File state (FD: 3) path: "hello-dos.txt" position: 8 size: 20 lseek(fd, -2, SEEK_CUR); buffer[0] = '\n'; write(fd, buffer, 1); lseek(fd, 8, SEEK_SET); strcpy(buffer, "How"); write(fd, buffer, 3); close(fd); H e l l o. \n \n W h o a r e y o u? EOF fd = open(filename, O_WRONLY O_CREAT O_EXCL, 0755); if (fd < 0) printf("errno : %d, error code - EEXIST : %d\n", errno, EEXIST); 16
17 Example #1 (7) char filename[] = "hello-dos.txt"; int fd; char buffer[16]; off_t pos = 0; // long long; fd = open(filename, O_RDWR O_CREAT, 0755); read(fd, buffer, 6); read(fd, buffer+6, 2); File state (FD: 3) path: "hello-dos.txt" position: 11 size: 20 lseek(fd, -2, SEEK_CUR); buffer[0] = '\n'; write(fd, buffer, 1); lseek(fd, 8, SEEK_SET); strcpy(buffer, "How"); write(fd, buffer, 3); close(fd); H e l l o. \n \n H o w a r e y o u? EOF fd = open(filename, O_WRONLY O_CREAT O_EXCL, 0755); if (fd < 0) printf("errno : %d, error code - EEXIST : %d\n", errno, EEXIST); 17
18 Example #1 (8) char filename[] = "hello-dos.txt"; int fd; char buffer[16]; off_t pos = 0; // long long; File state (FD: 3) :CLOSED fd = open(filename, O_RDWR O_CREAT, 0755); read(fd, buffer, 6); read(fd, buffer+6, 2); lseek(fd, -2, SEEK_CUR); buffer[0] = '\n'; write(fd, buffer, 1); lseek(fd, 8, SEEK_SET); strcpy(buffer, "How"); write(fd, buffer, 3); close(fd); fd = open(filename, O_WRONLY O_CREAT O_EXCL, 0755); if (fd < 0) printf("errno : %d, error code - EEXIST : %d\n", errno, EEXIST); 18
19 Example #1 (9) char filename[] = "hello-dos.txt"; int fd; char buffer[16]; off_t pos = 0; // long long; fd = open(filename, O_RDWR O_CREAT, 0755); read(fd, buffer, 6); read(fd, buffer+6, 2); lseek(fd, -2, SEEK_CUR); buffer[0] = '\n'; write(fd, buffer, 1); lseek(fd, 8, SEEK_SET); strcpy(buffer, "How"); write(fd, buffer, 3); close(fd); fd = open(filename, O_WRONLY O_CREAT O_EXCL, 0755); if (fd < 0) printf("errno : %d, error code - EEXIST : %d\n", errno, EEXIST); 19
20 Example #2 (1) File state (FD: 3) char filename[] = "hello-dos.txt"; int fd; char buffer[16]; off_t pos = 0; fd = open(filename, O_WRONLY); lseek(fd, 1, SEEK_END); strcpy(buffer, "!\n"); write(fd, buffer, 2); close(fd); path: "hello-dos.txt" type: Regular mode: Write only position: 0 size: 20 H e l l o. \r \n W h o a r e y o u? EOF 20
21 Example #2 (2) File state (FD: 3) char filename[] = "hello-dos.txt"; int fd; char buffer[16]; off_t pos = 0; fd = open(filename, O_WRONLY); lseek(fd, 1, SEEK_END); strcpy(buffer, "!\n"); write(fd, buffer, 2); close(fd); path: "hello-dos.txt" type: Regular mode: Write only position: 21 size: 20 H e l l o. \r \n W h o a r e y o u? EOF 21
22 Example #2 (3) File state (FD: 3) char filename[] = "hello-dos.txt"; int fd; char buffer[16]; off_t pos = 0; fd = open(filename, O_WRONLY); lseek(fd, 1, SEEK_END); strcpy(buffer, "!\n"); write(fd, buffer, 2); close(fd); path: "hello-dos.txt" type: Regular mode: Write only position: 23 size: 23 H e l l o. \r \n W h o a r e y o u? \0! \n EOF Data hole 22
23 Example #2 (4) char filename[] = "hello-dos.txt"; int fd; char buffer[16]; off_t pos = 0; File state (FD: 3) :CLOSED fd = open(filename, O_WRONLY); lseek(fd, 1, SEEK_END); strcpy(buffer, "!\n"); write(fd, buffer, 2); close(fd); 23
24 File Metadata Data about data, in this case file data. Maintained by kernel, accessed by users with the stat and fstat functions. /* Metadata returned by the stat and fstat functions */ struct stat { dev_t st_dev; /* device */ ino_t st_ino; /* inode */ mode_t st_mode; /* protection and file type */ nlink_t st_nlink; /* number of hard links */ uid_t st_uid; /* user ID of owner */ gid_t st_gid; /* group ID of owner */ dev_t st_rdev; /* device type (if inode device) */ off_t st_size; /* total size, in bytes */ unsigned long st_blksize; /* blocksize for filesystem I/O */ unsigned long st_blocks; /* number of blocks allocated */ time_t st_atime; /* time of last file access */ time_t st_mtime; /* time of last file modification */ time_t st_ctime; /* time of last inode change */ }; /* statbuf.h included by sys/stat.h */ 24
25 Accessing File Metadata /* statcheck.c - Querying and manipulating a file s meta data */ int main (int argc, char **argv) { struct stat st; char *type, *readok; stat(argv[1], &st); if (S_ISREG(st.st_mode)) /* file type */ type = "regular"; else if (S_ISDIR(st.st_mode)) type = "directory"; else type = "other"; if ((st.st_mode & S_IRUSR)) /* OK to read? */ readok = "yes"; else readok = "no"; bass>./statcheck statcheck.c type: regular, read: yes bass> chmod 000 statcheck.c bass>./statcheck statcheck.c type: regular, read: no } printf("type: %s, read: %s\n", type, readok); exit(0); 25
26 Lab 2. Exercise (1) Make the following program Unix Dos Newline <LF> <CR> <LF> <TAB> char 8 consecutive <space> -> <TAB> <TAB> -> 4 consecutive <space> If input file is Unix format, convert it to the dosformat If input file is Dos format, convert it to the Unixformat 26
27 Lab 2. Exercise (2) Make the following program Unix Dos Newline <LF> <CR> <LF> <TAB> char 8 consecutive <space> -> <TAB> <TAB> -> 4 consecutive <space> 27
28 Lab 2. Exercise (3) Make the following program Unix Dos Newline <LF> <CR> <LF> <TAB> char 8 consecutive <space> -> <TAB> <TAB> -> 4 consecutive <space>./convert [input_file] You should name the output file as [input_file].out You cannot use fopen, fread, fwrite and fclose Instead, use open, read, write and close Test file is uploaded at project page 28
All the scoring jobs will be done by script
File I/O Prof. Jin-Soo Kim( jinsookim@skku.edu) TA Sanghoon Han(sanghoon.han@csl.skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu Announcement (1) All the scoring jobs
More informationAll the scoring jobs will be done by script
File I/O Prof. Jinkyu Jeong( jinkyu@skku.edu) TA-Seokha Shin(seokha.shin@csl.skku.edu) TA-Jinhong Kim( jinhong.kim@csl.skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu
More informationContents. Programming Assignment 0 review & NOTICE. File IO & File IO exercise. What will be next project?
File I/O Prof. Jin-Soo Kim(jinsookim@skku.edu) TA - Dong-Yun Lee(dylee@csl.skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu Contents Programming Assignment 0 review & NOTICE
More informationContents. NOTICE & Programming Assignment 0 review. What will be next project? File IO & File IO exercise
File I/O Prof. Jin-Soo Kim( jinsookim@skku.edu) TA Dong-Yun Lee(dylee@csl.skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu Contents NOTICE & Programming Assignment 0 review
More informationFile I/O. Dong-kun Shin Embedded Software Laboratory Sungkyunkwan University Embedded Software Lab.
1 File I/O Dong-kun Shin Embedded Software Laboratory Sungkyunkwan University http://nyx.skku.ac.kr Unix files 2 A Unix file is a sequence of m bytes: B 0, B 1,..., B k,..., B m-1 All I/O devices are represented
More informationHyo-bong Son Computer Systems Laboratory Sungkyunkwan University
File I/O Hyo-bong Son (proshb@csl.skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu Unix Files A Unix file is a sequence of m bytes: B 0, B 1,..., B k,..., B m-1 All I/O
More informationFile I/O. Jin-Soo Kim Computer Systems Laboratory Sungkyunkwan University
File I/O Jin-Soo Kim (jinsookim@skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu Unix Files A Unix file is a sequence of m bytes: B 0, B 1,..., B k,..., B m-1 All I/O devices
More informationCS 201. Files and I/O. Gerson Robboy Portland State University
CS 201 Files and I/O Gerson Robboy Portland State University A Typical Hardware System CPU chip register file ALU system bus memory bus bus interface I/O bridge main memory USB controller graphics adapter
More informationSystem-Level I/O. Topics Unix I/O Robust reading and writing Reading file metadata Sharing files I/O redirection Standard I/O
System-Level I/O Topics Unix I/O Robust reading and writing Reading file metadata Sharing files I/O redirection Standard I/O A Typical Hardware System CPU chip register file ALU system bus memory bus bus
More informationSystem- Level I/O. Andrew Case. Slides adapted from Jinyang Li, Randy Bryant and Dave O Hallaron
System- Level I/O Andrew Case Slides adapted from Jinyang Li, Randy Bryant and Dave O Hallaron 1 Unix I/O and Files UNIX abstracts many things into files (just a series of bytes) All I/O devices are represented
More informationThe course that gives CMU its Zip! I/O Nov 15, 2001
15-213 The course that gives CMU its Zip! I/O Nov 15, 2001 Topics Files Unix I/O Standard I/O A typical hardware system CPU chip register file ALU system bus memory bus bus interface I/O bridge main memory
More informationUNIX System Calls. Sys Calls versus Library Func
UNIX System Calls Entry points to the kernel Provide services to the processes One feature that cannot be changed Definitions are in C For most system calls a function with the same name exists in the
More informationOperating System Labs. Yuanbin Wu
Operating System Labs Yuanbin Wu CS@ECNU Operating System Labs Project 3 Oral test Handin your slides Time Project 4 Due: 6 Dec Code Experiment report Operating System Labs Overview of file system File
More informationI/O OPERATIONS. UNIX Programming 2014 Fall by Euiseong Seo
I/O OPERATIONS UNIX Programming 2014 Fall by Euiseong Seo Files Files that contain a stream of bytes are called regular files Regular files can be any of followings ASCII text Data Executable code Shell
More informationSystem-Level I/O Nov 14, 2002
15-213 The course that gives CMU its Zip! System-Level I/O Nov 14, 2002 Topics Unix I/O Robust reading and writing Reading file metadata Sharing files I/O redirection Standard I/O class24.ppt A Typical
More informationI/O OPERATIONS. UNIX Programming 2014 Fall by Euiseong Seo
I/O OPERATIONS UNIX Programming 2014 Fall by Euiseong Seo Files Files that contain a stream of bytes are called regular files Regular files can be any of followings ASCII text Data Executable code Shell
More informationLecture 23: System-Level I/O
CSCI-UA.0201-001/2 Computer Systems Organization Lecture 23: System-Level I/O Mohamed Zahran (aka Z) mzahran@cs.nyu.edu http://www.mzahran.com Some slides adapted (and slightly modified) from: Clark Barrett
More informationA Typical Hardware System The course that gives CMU its Zip! System-Level I/O Nov 14, 2002
class24.ppt 15-213 The course that gives CMU its Zip! System-Level I/O Nov 14, 2002 Topics Unix I/O Robust reading and writing Reading file metadata Sharing files I/O redirection Standard I/O A Typical
More informationImportant Dates. October 27 th Homework 2 Due. October 29 th Midterm
CSE333 SECTION 5 Important Dates October 27 th Homework 2 Due October 29 th Midterm String API vs. Byte API Recall: Strings are character arrays terminated by \0 The String API (functions that start with
More informationOperating System Labs. Yuanbin Wu
Operating System Labs Yuanbin Wu CS@ECNU Operating System Labs Project 4 (multi-thread & lock): Due: 10 Dec Code & experiment report 18 Dec. Oral test of project 4, 9:30am Lectures: Q&A Project 5: Due:
More informationMemory Mapped I/O. Michael Jantz. Prasad Kulkarni. EECS 678 Memory Mapped I/O Lab 1
Memory Mapped I/O Michael Jantz Prasad Kulkarni EECS 678 Memory Mapped I/O Lab 1 Introduction This lab discusses various techniques user level programmers can use to control how their process' logical
More informationFiles and Directories Filesystems from a user s perspective
Files and Directories Filesystems from a user s perspective Unix Filesystems Seminar Alexander Holupirek Database and Information Systems Group Department of Computer & Information Science University of
More informationstructs as arguments
Structs A collection of related data items struct record { char name[maxname]; int count; ; /* The semicolon is important! It terminates the declaration. */ struct record rec1; /*allocates space for the
More informationSystem-Level I/O March 31, 2005
15-213 The course that gives CMU its Zip! System-Level I/O March 31, 2005 Topics Unix I/O Robust reading and writing Reading file metadata Sharing files I/O redirection Standard I/O 21-io.ppt Unix I/O
More informationCSC 271 Software I: Utilities and Internals
CSC 271 Software I: Utilities and Internals Lecture 13 : An Introduction to File I/O in Linux File Descriptors All system calls for I/O operations refer to open files using a file descriptor (a nonnegative
More informationFile Input and Output (I/O)
File Input and Output (I/O) Brad Karp UCL Computer Science CS 3007 15 th March 2018 (lecture notes derived from material from Phil Gibbons, Dave O Hallaron, and Randy Bryant) 1 Today UNIX I/O Metadata,
More informationwhich maintain a name to inode mapping which is convenient for people to use. All le objects are
UNIX Directory Organization UNIX directories are simple (generally ASCII) les which maain a name to inode mapping which is convenient for people to use. All le objects are represented by one or more names
More information39. File and Directories
39. File and Directories Oerating System: Three Easy Pieces AOS@UC 1 Persistent Storage Kee a data intact even if there is a ower loss. w Hard disk drive w Solid-state storage device Two key abstractions
More informationSystem- Level I/O. CS 485 Systems Programming Fall Instructor: James Griffioen
System- Level I/O CS 485 Systems Programming Fall 2015 Instructor: James Griffioen Adapted from slides by R. Bryant and D. O Hallaron (hip://csapp.cs.cmu.edu/public/instructors.html) 1 Today Unix I/O Metadata,
More informationSystem-Level I/O. William J. Taffe Plymouth State University. Using the Slides of Randall E. Bryant Carnegie Mellon University
System-Level I/O William J. Taffe Plymouth State University Using the Slides of Randall E. Bryant Carnegie Mellon University Topics Unix I/O Robust reading and writing Reading file metadata Sharing files
More informationIntroduction to Computer Systems , fall th Lecture, Oct. 19 th
Introduction to Computer Systems 15-213, fall 2009 15 th Lecture, Oct. 19 th Instructors: Majd Sakr and Khaled Harras Today System level I/O Unix I/O Standard I/O RIO (robust I/O) package Conclusions and
More informationFile Systems. q Files and directories q Sharing and protection q File & directory implementation
File Systems q Files and directories q Sharing and protection q File & directory implementation Files and file systems Most computer applications need to Store large amounts of data; larger than their
More informationDesign Choices 2 / 29
File Systems One of the most visible pieces of the OS Contributes significantly to usability (or the lack thereof) 1 / 29 Design Choices 2 / 29 Files and File Systems What s a file? You all know what a
More informationCS , Spring Sample Exam 3
Andrew login ID: Full Name: CS 15-123, Spring 2010 Sample Exam 3 Mon. April 6, 2009 Instructions: Make sure that your exam is not missing any sheets, then write your full name and Andrew login ID on the
More informationAdvanced Systems Security: Ordinary Operating Systems
Systems and Internet Infrastructure Security Network and Security Research Center Department of Computer Science and Engineering Pennsylvania State University, University Park PA Advanced Systems Security:
More informationFile Systems. Today. Next. Files and directories File & directory implementation Sharing and protection. File system management & examples
File Systems Today Files and directories File & directory implementation Sharing and protection Next File system management & examples Files and file systems Most computer applications need to: Store large
More informationSystem-Level I/O : Introduction to Computer Systems 16 th Lecture, March 23, Instructors: Franz Franchetti & Seth Copen Goldstein
System-Level I/O 15-213: Introduction to Computer Systems 16 th Lecture, March 23, 2017 Instructors: Franz Franchetti & Seth Copen Goldstein 1 Today: Unix I/O and C Standard I/O Two sets: system-level
More informationFile System (FS) Highlights
CSCI 503: Operating Systems File System (Chapters 16 and 17) Fengguang Song Department of Computer & Information Science IUPUI File System (FS) Highlights File system is the most visible part of OS From
More information17: Filesystem Examples: CD-ROM, MS-DOS, Unix
17: Filesystem Examples: CD-ROM, MS-DOS, Unix Mark Handley CD Filesystems ISO 9660 Rock Ridge Extensions Joliet Extensions 1 ISO 9660: CD-ROM Filesystem CD is divided into logical blocks of 2352 bytes.
More informationSystem Calls and I/O Appendix. Copyright : University of Illinois CS 241 Staff 1
System Calls and I/O Appendix Copyright : University of Illinois CS 241 Staff 1 More System Calls Directory and File System Management s = mkdir(name, mode) Create a new directory s = rmdir(name) s = link(name,
More informationFoundations of Computer Systems
18-600 Foundations of Computer Systems Lecture 17: System Level I/O John P. Shen & Zhiyi Yu (with Chris Inacio of SEI) October 31, 2016 Required Reading Assignment: Chapter 10 of CS:APP (3 rd edition)
More informationQ & A (1) Where were string literals stored? Virtual Address. SSE2033: System Software Experiment 2 Spring 2016 Jin-Soo Kim
Processes Prof. Jin-Soo Kim(jinsookim@skku.edu) TA - Dong-Yun Lee (dylee@csl.skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu Q & A (1) Where were string literals stored?
More informationCSci 4061 Introduction to Operating Systems. File Systems: Basics
CSci 4061 Introduction to Operating Systems File Systems: Basics File as Abstraction Naming a File creat/open ( path/name, ); Links: files with multiple names Each name is an alias #include
More informationAutomated Test Generation in System-Level
Automated Test Generation in System-Level Pros + Can be easy to generate system TCs due to clear interface specification + No false alarm (i.e., no assert violation caused by infeasible execution scenario)
More informationUnix programming interface for file I/O operations and pipes
Unix programming interface for file I/O operations and pipes M1 MOSIG Operating System Design Renaud Lachaize Acknowledgments Many ideas and slides in these lectures were inspired by or even borrowed from
More informationContents. PA1 review and introduction to PA2. IPC (Inter-Process Communication) Exercise. I/O redirection Pipes FIFOs
Pipes and FIFOs Prof. Jin-Soo Kim( jinsookim@skku.edu) TA Dong-Yun Lee(dylee@csl.skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu Contents PA1 review and introduction to
More informationSystem Calls. Library Functions Vs. System Calls. Library Functions Vs. System Calls
System Calls Library Functions Vs. System Calls A library function: Ordinary function that resides in a library external to the calling program. A call to a library function is just like any other function
More informationRicardo Rocha. Department of Computer Science Faculty of Sciences University of Porto
Ricardo Rocha Department of Computer Science Faculty of Sciences University of Porto For more information please consult Advanced Programming in the UNIX Environment, 3rd Edition, W. Richard Stevens and
More informationChapter 4 - Files and Directories. Information about files and directories Management of files and directories
Chapter 4 - Files and Directories Information about files and directories Management of files and directories File Systems Unix File Systems UFS - original FS FFS - Berkeley ext/ext2/ext3/ext4 - Linux
More informationOperating System Labs. Yuanbin Wu
Operating System Labs Yuanbin Wu cs@ecnu Annoucement Next Monday (28 Sept): We will have a lecture @ 4-302, 15:00-16:30 DON'T GO TO THE LABORATORY BUILDING! TA email update: ecnucchuang@163.com ecnucchuang@126.com
More informationOPERATING SYSTEMS: Lesson 2: Operating System Services
OPERATING SYSTEMS: Lesson 2: Operating System Services Jesús Carretero Pérez David Expósito Singh José Daniel García Sánchez Francisco Javier García Blas Florin Isaila 1 Goals To understand what an operating
More informationMemento: Time Travel for the Web
Old Dominion University ODU Digital Commons Computer Science Presentations Computer Science 11-10-2010 Herbert Van de Sompel Michael L. Nelson Old Dominion University, mnelson@odu.edu Robert Sanderson
More informationCSE 333 SECTION 3. POSIX I/O Functions
CSE 333 SECTION 3 POSIX I/O Functions Administrivia Questions (?) HW1 Due Tonight Exercise 7 due Monday (out later today) POSIX Portable Operating System Interface Family of standards specified by the
More informationPreview. System Call. System Call. System Call. System Call. Library Functions 9/20/2018. System Call
Preview File Descriptors for a Process for Managing Files write read open close lseek A system call is a request for the operating system to do something on behalf of the user's program. The system calls
More informationCS631 - Advanced Programming in the UNIX Environment
CS631 - Advanced Programming in the UNIX Environment Slide 1 CS631 - Advanced Programming in the UNIX Environment Files and Directories Department of Computer Science Stevens Institute of Technology Jan
More informationELEC-C7310 Sovellusohjelmointi Lecture 3: Filesystem
ELEC-C7310 Sovellusohjelmointi Lecture 3: Filesystem Risto Järvinen September 21, 2015 Lecture contents Filesystem concept. System call API. Buffered I/O API. Filesystem conventions. Additional stuff.
More informationSystem- Level I/O /18-243: Introduc3on to Computer Systems 16 th Lecture, Mar. 15, Instructors: Gregory Kesden and Anthony Rowe
System- Level I/O 15-213/18-243: Introduc3on to Computer Systems 16 th Lecture, Mar. 15, 2010 Instructors: Gregory Kesden and Anthony Rowe 1 Today Unix I/O RIO (robust I/O) package Metadata, sharing, and
More informationLecture files in /home/hwang/cs375/lecture05 on csserver.
Lecture 5 Lecture files in /home/hwang/cs375/lecture05 on csserver. cp -r /home/hwang/cs375/lecture05. scp -r user@csserver.evansville.edu:/home/hwang/cs375/lecture05. Project 1 posted, due next Thursday
More informationLinux Forensics. Newbug Tseng Oct
Linux Forensics Newbug Tseng Oct. 2004. Contents Are u ready Go Real World Exploit Attack Detect Are u ready Linux File Permission OWNER 4 2 1 GROUP 4 2 1 OTHER 4 2 1 R R R W SUID on exection 4000 X W
More informationUNIX System Programming
File I/O 경희대학교컴퓨터공학과 조진성 UNIX System Programming File in UNIX n Unified interface for all I/Os in UNIX ü Regular(normal) files in file system ü Special files for devices terminal, keyboard, mouse, tape,
More informationRicardo Rocha. Department of Computer Science Faculty of Sciences University of Porto
Ricardo Rocha Department of Computer Science Faculty of Sciences University of Porto For more information please consult Advanced Programming in the UNIX Environment, 3rd Edition, W. Richard Stevens and
More informationLecture 21 Systems Programming in C
Lecture 21 Systems Programming in C A C program can invoke UNIX system calls directly. A system call can be defined as a request to the operating system to do something on behalf of the program. During
More informationOperating Systems CMPSCI 377 Spring Mark Corner University of Massachusetts Amherst
Operating Systems CMPSCI 377 Spring 2017 Mark Corner University of Massachusetts Amherst Clicker Question #1 For a sequential workload, the limiting factor for a disk system is likely: (A) The speed of
More informationFiles and Directories Filesystems from a user s perspective
Files and Directories Filesystems from a user s perspective Unix Filesystems Seminar Alexander Holupirek Database and Information Systems Group Department of Computer & Information Science University of
More informationUNIVERSITY OF ENGINEERING AND TECHNOLOGY, TAXILA FACULTY OF TELECOMMUNICATION AND INFORMATION ENGINEERING SOFTWARE ENGINEERING DEPARTMENT
OPERATING SYSTEM LAB #06 & 07 System Calls In UNIX System Call: A system call is just what its name implies a request for the operating system to do something on behalf of the user s program. Process related
More informationHEC POSIX I/O API Extensions Rob Ross Mathematics and Computer Science Division Argonne National Laboratory
HEC POSIX I/O API Extensions Rob Ross Mathematics and Computer Science Division Argonne National Laboratory rross@mcs.anl.gov (Thanks to Gary Grider for providing much of the material for this talk!) POSIX
More informationMaster Calcul Scientifique - Mise à niveau en Informatique Written exam : 3 hours
Université de Lille 1 Année Universitaire 2015-2016 Master Calcul Scientifique - Mise à niveau en Informatique Written exam : 3 hours Write your code nicely (indentation, use of explicit names... ), and
More informationContents. IPC (Inter-Process Communication) Representation of open files in kernel I/O redirection Anonymous Pipe Named Pipe (FIFO)
Pipes and FIFOs Prof. Jin-Soo Kim( jinsookim@skku.edu) TA JinHong Kim( jinhong.kim@csl.skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu Contents IPC (Inter-Process Communication)
More informationSystem Calls and I/O. CS 241 January 27, Copyright : University of Illinois CS 241 Staff 1
System Calls and I/O CS 241 January 27, 2012 Copyright : University of Illinois CS 241 Staff 1 This lecture Goals Get you familiar with necessary basic system & I/O calls to do programming Things covered
More informationThesis, antithesis, synthesis
Identity Page 1 Thesis, antithesis, synthesis Thursday, December 01, 2011 4:00 PM Thesis, antithesis, synthesis We began the course by considering the system programmer's point of view. Mid-course, we
More informationCSE 333 SECTION 3. POSIX I/O Functions
CSE 333 SECTION 3 POSIX I/O Functions Administrivia Questions (?) HW1 Due Tonight HW2 Due Thursday, July 19 th Midterm on Monday, July 23 th 10:50-11:50 in TBD (And regular exercises in between) POSIX
More informationPreview. lseek System Calls. A File Copy 9/18/2017. An opened file offset can be explicitly positioned by calling lseek system call.
Preview lseek System Calls lseek() System call File copy dup() and dup2() System Cal Command Line Argument sat, fsat, lsat system Call ID s for a process File Access permission access System Call umask
More informationFile Types in Unix. Regular files which include text files (formatted) and binary (unformatted)
File Management Files can be viewed as either: a sequence of bytes with no structure imposed by the operating system. or a structured collection of information with some structure imposed by the operating
More informationFiles and Directories
Contents 1. Preface/Introduction 2. Standardization and Implementation 3. File I/O 4. Standard I/O Library 5. Files and Directories 6. System Data Files and Information 7. Environment of a Unix Process
More informationCSI 402 Lecture 11 (Unix Discussion on Files continued) 11 1 / 19
CSI 402 Lecture 11 (Unix Discussion on Files continued) 11 1 / 19 User and Group IDs Ref: Chapter 3 of [HGS]. Each user is given an ID (integer) called uid. (Most system programs use uid instead of the
More informationThe link() System Call. Preview. The link() System Call. The link() System Call. The unlink() System Call 9/25/2017
Preview The link() System Call link(), unlink() System Call remove(), rename() System Call Symbolic link to directory Symbolic link to a executable file symlink() System Call File Times utime() System
More informationLecture 3. Introduction to Unix Systems Programming: Unix File I/O System Calls
Lecture 3 Introduction to Unix Systems Programming: Unix File I/O System Calls 1 Unix File I/O 2 Unix System Calls System calls are low level functions the operating system makes available to applications
More informationINTRODUCTION TO UNIX FILE SYSTEM:
INTRODUCTION TO UNIX FILE SYSTEM: The internal representation of a file is given by an inode, which contains a description of the disk layout of the file data and other information such as the file owner,
More informationNaked C Lecture 6. File Operations and System Calls
Naked C Lecture 6 File Operations and System Calls 20 August 2012 Libc and Linking Libc is the standard C library Provides most of the basic functionality that we've been using String functions, fork,
More informationUnix File and I/O. Outline. Storing Information. File Systems. (USP Chapters 4 and 5) Instructor: Dr. Tongping Liu
Outline Unix File and I/O (USP Chapters 4 and 5) Instructor: Dr. Tongping Liu Basics of File Systems Directory and Unix File System: inode UNIX I/O System Calls: open, close, read, write, ioctl File Representations:
More information프로세스간통신 (Interprocess communication) i 숙명여대창병모
프로세스간통신 (Interprocess communication) i 숙명여대창병모 Contents 1. Pipes 2. FIFOs 숙대창병모 2 파이프 (Pipe) IPC using Pipes IPC using regular files unrelated processes can share fixed size life-time lack of synchronization
More informationFile Systems. CS 450: Operating Systems Sean Wallace Computer Science. Science
File Systems Science Computer Science CS 450: Operating Systems Sean Wallace What is a file? Some logical collection of data Format/interpretation is (typically) of little concern to
More informationComputer Science & Engineering Department I. I. T. Kharagpur
Computer Science & Engineering Department I. I. T. Kharagpur Operating System: CS33007 3rd Year CSE: 5th Semester (Autumn 2006-2007) Lecture III (Linux System Calls II) Goutam Biswas Date: 1st-7th August,
More informationOperating Systems. Processes
Operating Systems Processes 1 Process Concept Process a program in execution; process execution progress in sequential fashion Program vs. Process Program is passive entity stored on disk (executable file),
More informationCSCI 4500/8506 Operating Systems Some UNIX System Calls, Library, and PThreads Functions
CSCI 4500/8506 Operating Systems Some UNIX System Calls, Library, and PThreads Functions Described below is a subset of UNIX system calls, library functions, and Pthreads (that is, POSIX Threads) functions.
More informationOperating System Labs. Yuanbin Wu
Operating System Labs Yuanbin Wu cs@ecnu Announcement Project 1 due 21:00, Oct. 8 Operating System Labs Introduction of I/O operations Project 1 Sorting Operating System Labs Manipulate I/O System call
More informationSection 3: File I/O, JSON, Generics. Meghan Cowan
Section 3: File I/O, JSON, Generics Meghan Cowan POSIX Family of standards specified by the IEEE Maintains compatibility across variants of Unix-like OS Defines API and standards for basic I/O: file, terminal
More informationCS 471 Operating Systems. Yue Cheng. George Mason University Fall 2017
CS 471 Operating Systems Yue Cheng George Mason University Fall 2017 Review: RAID 2 RAID o Idea: Build an awesome disk from small, cheap disks o Metrics: Capacity, performance, reliability 3 RAID o Idea:
More informationCSC209F Midterm (L0101) Fall 1999 University of Toronto Department of Computer Science
CSC209F Midterm (L0101) Fall 1999 University of Toronto Department of Computer Science Date: October 26, 1999 Time: 1:10 pm Duration: 50 minutes Notes: 1. This is a closed book test, no aids are allowed.
More informationFile I/0. Advanced Programming in the UNIX Environment
File I/0 Advanced Programming in the UNIX Environment File Descriptors Created and managed by the UNIX kernel. Created using open or creat system call. Used to refer to an open file UNIX System shells
More informationCS 3113 Introduction to Operating Systems Midterm October 11, 2018
General instructions: CS 3113 Introduction to Operating Systems Midterm October 11, 2018 Please wait to open this exam booklet until you are told to do so. This examination booklet has 10 pages. You also
More informationCS 3113 Introduction to Operating Systems Midterm October 11, 2018
General instructions: CS 3113 Introduction to Operating Systems Midterm October 11, 2018 Please wait to open this exam booklet until you are told to do so. This examination booklet has 10 pages. You also
More informationCSE 410: Systems Programming
CSE 410: Systems Programming Input and Output Ethan Blanton Department of Computer Science and Engineering University at Buffalo I/O Kernel Services We have seen some text I/O using the C Standard Library.
More informationUNIX I/O. Computer Systems: A Programmer's Perspective, Randal E. Bryant and David R. O'Hallaron Prentice Hall, 3 rd edition, 2016, Chapter 10
Reference: Advanced Programming in the UNIX Environment, Third Edition, W. Richard Stevens and Stephen A. Rago, Addison-Wesley Professional Computing Series, 2013. Chapter 3 Computer Systems: A Programmer's
More informationPipes and FIFOs. Woo-Yeong Jeong Computer Systems Laboratory Sungkyunkwan University
Pipes and FIFOs Woo-Yeong Jeong (wooyeong@csl.skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu Open Files in Kernel How the Unix kernel represents open files? Two descriptors
More informationSystems Programming. COSC Software Tools. Systems Programming. High-Level vs. Low-Level. High-Level vs. Low-Level.
Systems Programming COSC 2031 - Software Tools Systems Programming (K+R Ch. 7, G+A Ch. 12) The interfaces we use to work with the operating system In this case: Unix Programming at a lower-level Systems
More informationFile Systems. Jinkyu Jeong Computer Systems Laboratory Sungkyunkwan University
File Systems Jinkyu Jeong (jinkyu@skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu SSE3044: Operating Systems, Fall 2016, Jinkyu Jeong (jinkyu@skku.edu) File System Layers
More informationOutline. OS Interface to Devices. System Input/Output. CSCI 4061 Introduction to Operating Systems. System I/O and Files. Instructor: Abhishek Chandra
Outline CSCI 6 Introduction to Operating Systems System I/O and Files File I/O operations File Descriptors and redirection Pipes and FIFOs Instructor: Abhishek Chandra 2 System Input/Output Hardware devices:
More informationPhysical Files and Logical Files. Opening Files. Chap 2. Fundamental File Processing Operations. File Structures. Physical file.
File Structures Physical Files and Logical Files Chap 2. Fundamental File Processing Operations Things you have to learn Physical files and logical files File processing operations: create, open, close,
More informationInterlude: Files and Directories
39 Interlude: Files and Directories Thus far we have seen the development of two key operating system abstractions: the process, which is a virtualization of the CPU, and the address space, which is a
More information