Embed
Email

unix-ch05-02

Document Sample

Shared by: yagnesh darji
Categories
Tags
Stats
views:
154
posted:
9/3/2009
language:
English
pages:
45
System Calls For The File Systems

2001. 3. 23 윤미현 Miya@realtime.ssu.ac.kr Real-Time Computing Lab. Soongsil Univ.



File System Call

System calls for accessing existing files

open, read, write, lseek, close



System calls to create new files

creat, mknod



System calls that manipulate the inode or that maneuver through the file system

http://realtime.ssu.ac.kr/



chdir, chroot, chown, chmod, stat, fstat



Advanced system calls

pipe, dup : the implementation of pipes mount, umount : extend the file system tree visible to users link, unlink : change the structure of the file system hierarchy



2



File System Calls and Relation to Other Algorithms

File System Calls

Return File Desc open creat dup pipe close Use of namei open creat chdir chroot chown chmod stat link unlink mknod mount umount Assign inodes File Attributes File I/O File Sys Structure Tree Manipulation



creat mknod link unlink



chown chmod stat



read write lseek



mount umount



chdir chown



Lower Level File System Algorithms namei iget iput ialloc ifree alloc free bmap



Buffer allocation algorithms getblk brelse bread breada bwirte



http://realtime.ssu.ac.kr/



3



Open

First step a process must take to access the data in a file Syntax

fd = open(pathname, flags, modes)

• pathname : file name



• flags : type of open (ex. reading, writing)

• fd : the user file descriptor , integer

http://realtime.ssu.ac.kr/



• modes : file permissions if the file is being created



4



Algorithm for Opening a File

Namei를 이용하여 file name -> inode로 변환



File permission을 체크하고 file table entry 할당

Pointer : inode Field : byte offset ( 0 or write-append mode )



User file descriptor table에 entry 할당

http://realtime.ssu.ac.kr/



5



Open Example (1)

User file descriptor table

0 1 2 3 4 5 6 7



File table



inode table



count Read 1 ... count Rd-Wrt 1 ... count Write 1 ...



count (/etc/passwd) 2 ... count (local) 1

...

http://realtime.ssu.ac.kr/



... ...



fd1 = open(“/etc/passwd”, O_RDONLY); fd2 = open(“local”, O_RDWR); fd3 = open(“/etc/passwd”, O_WRONLY);



7



Open Example (2)

User file descriptor table (proc A)

0 1 2 3 4 5



File table inode table



count Read 1 ... ... count Rd-Wrt 1 ... count Read 1 ... count Write 1 ... count Read 1



count (/etc/passwd) 3 ... count (local) 1



...

count (private) 1 ...

http://realtime.ssu.ac.kr/



(proc B)

0 1 2 3 4 5



...



fd1= open(“/etc/passwd”, O_RDONLY); fd2 = open(“private”, O_RDONLY);



8



READ

Syntax

number = read(fd, buffer, count);

• fd : file descriptor returned by open

• buffer : address of a data structure that will contain data • count : number of bytes the user want to read • number : number of bytes actually read



U –area

mode : indicates read or write offset : byte offset in file address : target address to copy data, in user or kernel memory

http://realtime.ssu.ac.kr/



count : count of bytes to read or write



flag : indicates if address is in user or kernel memory



9



Algorithm for Reading a File

Get file table entry from user file descriptor



Set parameters in u area

Get inode from file table and lock inode Repeat loop until user request is satisfied

Converting the file byte offset to a block number Reading the block from disk to a system buffer Copying data from the buffer to the user process Releasing the buffer Updating I/O parameters in the u area

http://realtime.ssu.ac.kr/



10



Algorithm read Input : user file descriptor address of buffer in user process number of bytes to read Output : count of bytes copied into user space {

get file table entry from user file descriptor; check file accessibility; set parameters in u area for user address, byte count, I/O to user; get inode from file table; lock inode; set byte offset in u area from file table offset; while (count not satisfied) { convert file offset to disk block (algorithm bmap); calculate offset into block, number of bytes to read ; if (number of bytes to read is 0) /* trying to read end of file */ break; /* out of loop */ read block (algorithm breada if with read ahead, algorithm bread otherwise); copy data from system buffer to user address; update u area field for file byte offset, read count, address to write into user space; release buffer; /* locked in bread */ } unlock inode; update file table offset for next read; return(total number of bytes read);



}



11



http://realtime.ssu.ac.kr/



Sample Program for Reading a File

#include main()



{

int fd; char lilbuf[20], bigbuf[1024]; fd = open(“/etc/passwd”, O_RDONLY);



read(fd, lilbuf, 20);

read(fd, bigbuf, 1024); read(fd, lilbuf, 20); }

http://realtime.ssu.ac.kr/



 the example shows how advantageous it is for I/O requests to



start on file system block boundaries and to be multiples of the block size



12



WRITE

Syntax

number = write(fd, buffer, count);



Algorithm

If the file does not contain a block that corresponds to the byte offset to be written, the kernel allocate a new block The inode is locked Update the file size entry in the inode



Delayed write

Use to write the data to disk caching



13



http://realtime.ssu.ac.kr/



LSEEK

Use to position the I/O and allow random access to a file



Syntax

position = lseek(fd, offset, reference);

• fd : file descriptor identifying the file • offset : byte offset



• reference

– 1 : current position of the read/write offset – 2 : end of the file

http://realtime.ssu.ac.kr/



– 0 : beginning of the file



• position : byte offset where the next read or write will start



Adjust the offset value in the file table



14



CLOSE

Close an open file when it no longer wants to access it Syntax

close(fd);

• fd : file descriptor for the open file



Algorithm

File descriptor, file table entry , inode table entry

• reference count = 1 • if other processes still reference the inode

http://realtime.ssu.ac.kr/



• reference count > 1



• inode reference count = 0



No process can keep a file open after it terminates



15



CLOSE Example

User file descriptor table (proc A)

0 1 2 3 4 5



File table inode table



count Read 1 ... ... count Rd-Wrt 1 ... count Read 0 ... count Write 1 ... count Read 0



count (/etc/passwd) 2 ... count (local) 1 ...

http://realtime.ssu.ac.kr/



(proc B)

0 1 2 3 4 5



count (private) 0 ...



NULL NULL

...



16



File Creation

Syntax

fd = creat(pathname, modes);



Create a file

Create a new file, if no such file previously existed Truncate the file to suitable file access permissions, if the file already existed

http://realtime.ssu.ac.kr/



17



File Creation Algorithm

Search the file name to create Note the empty directory slot and save the offset No empty slot, the offset of end of the directory 기억 Check write permission Given name exist before the creat

Truncate the file, freeing all data blocks



Not existed

http://realtime.ssu.ac.kr/



Inode 할당, write new file name and inode number Release the inode of the parent directory Write the newly allocated inode to disk Write the directory with the new name to disk



18



Algorithm creat Input : file name permission settings Output : file descriptor

{ Get inode for file name (algorithm namei); if (file already exists) { if (not permitted access) { release inode (algorithm iput); return(error); } } else /* file does not exist yet */ { assign free inode from file system (algorithm ialloc); create new directory entry in parent directory: include new file name and newly assgined inode number; } allocate file table entry for inode, initialize count; if (file did exist at time of create) free all file blocks (algorithm free); unlock(inode); return(user file descriptor);



19



}



http://realtime.ssu.ac.kr/



Creation of Special Files

Creates special files in the systems, including named pipes, device files, and directories Syntax

mknod(pathname, type and permissions, dev)

• pathname : name of the node to be created

http://realtime.ssu.ac.kr/



• type and permissions : node type (ex, directory) and access permission • dev : major and minor device number for block and character special files



20



Creation of Special Files Algorithm

Searches the file systems for the file name to create The file not yet exist

Assign a new inode on the disk write the new file name and inode number into parent directory Write the major and minor device numbers into the inode

http://realtime.ssu.ac.kr/



Set the file type field in inode (pipe, directory, special file)



21



Algorithm make new node Input : node (file name) file type permissions major, minor device number (for block, character special files) Output : none { if (new node not named pipe and user not super user) return (error); get inode of parent of new node (algorithm namei); if(new node already exists) { release parent inode (algorithm iput); return (error); } assign free inode from file system for new node (algorithm ialloc); create new directory entry in parent directory : include new node name and newly assigned inode number; release parent directory inode (algorithm iput); if (new node is block or character special file) write major, minor numbers into inode structure; release new node inode (algorithm iput); }



22



http://realtime.ssu.ac.kr/



Change Directory and Change Root

Syntax

chdir (pathname);

• pathname : the new current directory of the process



chroot (pathname);

• pathname : subsequently treats as the process‟s root directory



meaning

chroot : changes their notion of the file system root

http://realtime.ssu.ac.kr/



chdir : changes the current directory of a process



23



Change Owner and Change Mode

Syntax

chown(pathname, owner, group)

chmod(pathname, mode)



Change the owner or mode of a file Operation on the inode (not on the file)

http://realtime.ssu.ac.kr/



24



Stat and Fstat

Syntax

stat (pathname, statbuffer);



fstat (fd, statbuffer);

• statbuffer : address of a data structure that will contain the status information of the file on completion • Pathname : file name



Returning information File type, file owner, access permissions, file size, number of links, inode number, file access times



25



http://realtime.ssu.ac.kr/



Query the status of files



Pipes

pipe

Transfer of data between processes in a FIFO



Synchronization of process execution

Traditionally use to store the data



named pipe vs. unnamed pipe

open system call / pipe system call

pipe를 call한 process의 descendant만이 access 공유 가능 (트리) Permanent / transient

http://realtime.ssu.ac.kr/



모든 process가 access 가능 (file permission에 따라)



26



Pipe System Call

Creation of a pipe Syntax

pipe (fdptr);

• fdptr : two file descriptors for reading and writing the pipe



Algorithm

Assign an inode for a pipe from the pipe device

• Pipe device : a file system from which the kernel can assign inodes and data block for pipes

http://realtime.ssu.ac.kr/



Allocate two file table entries for the read and write descriptor Update the information in the in-core inode

• Count : 1 • Inode reference count : 2



Record byte offsets in the inode -> FIFO access



27



Algorithm pipe

Input : none Output : read file descriptor write file descriptor



{

assign new inode from pipe device (algorithm ialloc); allocate file table entry for reading, another for writing; initialize file table entries to point to new inode;



allocate user file descriptor for reading, another for writing,

set inode reference count to 2; initialize count of inode readers, writers to 1;

http://realtime.ssu.ac.kr/



initialize to point to respective file table entries;



}



28



Named Pipe

Semantics are the same as those of unnamed pipe



차이점

Have a directory entry and be accessed by a path name



Open a named pipe for reading and a writing exist No delay option 사용



29



http://realtime.ssu.ac.kr/



A process that opens the named pipe for reading will sleep until another process opens the named pipe for writing



Reading and Writing Pipes

Process access data from a pipe in FIFO manner Pipe device에 data를 저장하고 write시 필요하면 block을 할 당 받음 Difference :

Use only the direct blocks of the inode for greater efficiency



Circular queue

http://realtime.ssu.ac.kr/



to maintain Read and write pointers internally to preserve the FIFO order Read pointer Write pointer



0



1



2



3



4



5



6



7



8



9



Direct blocks of inode



30



Reading and Writing Pipes

Four cases

Writing a pipe that has room for the data being written

• write할 때 마다 pipe size 증가



Reading from a pipe that contains enough data to satisfy the read

• Check the pipe is empty • Not empty – as to read regular file • Read 후에 읽은 byte에 따라 pipe size 감소



Reading from a pipe that does not contain enough data to satisfy the read

• Pipe empty -> sleep



Writing a pipe that does not have room for the data being written

• Kernel marks the inode -> sleep



31



http://realtime.ssu.ac.kr/



Closing Pipes

Same procedure for closing a regular file Decrements the number of pipe readers or writers according to file descriptor type



32



http://realtime.ssu.ac.kr/



Pipes Example

char string[] = “hello”; main() {

char buf[1024]; char *cp1, *cp2; int fds[2]; cp1 = string; cp2 = buf; while (*cp1) *cp2++ = *cp1++; pipe(fds); for (;;) { write(fds[1], buf, 6); read(fds[0], buf, 6); }

http://realtime.ssu.ac.kr/



}



33



DUP

Syntax

newfd = dup(fd);

• fd : file descriptor being duped • newfd : new file descriptor that references the file



dup

file descriptor를 user file descriptor의 첫번째 free slot에 copy dup는 file descriptor를 복사하므로 file table entry의 count 증 가

http://realtime.ssu.ac.kr/



새로운 file descriptor를 return



34



DUP Example

#include main() {

int i, j; char buf1[512], buf2[512]; i = open(“/etc/passwd”, O_RDONLY); j = dup(i); read(j, buf2, sizeof(buf2)); close(i);

http://realtime.ssu.ac.kr/



read(i, buf1, sizeof(buf1));



read(j, buf2, sizeof(buf2));



}



35



DUP Example

User file descriptor table File table Inode table



0



1

2 3 4 5 6 ... count 2 ... count 1 ... count 1 ...



count (/etc/passwd) 2 ... count (local) 1



...



36



http://realtime.ssu.ac.kr/



Mounting File System

Syntax

Mount (special pathname, directory pathname, options);

• special pathname : the disk section containing the file system to be mounted • directory pathname : in the existing hierarchy where the file system will be mounted (called the mounted point) • option : „read-only‟



Mount

http://realtime.ssu.ac.kr/



connects the file system in a specified section of a disk to the existing file system hierarchy



Mount table

device number, Pointer to a buffer, Pointer to the root inode, Pointer to the inode of the directory



37



File System Tree Before and After Mount

/



Root file system bin cc date



etc

passwd getty



usr



/



mount(“/dev/dsk1”, “/usr”, 0) awk



bin banner



include

stdio.h



src

uts



38



http://realtime.ssu.ac.kr/



/dev/dsk1 file system



Crossing Mount Points in File Path Name

Crossing from the mounted-on file system to the mounted file system (root -> leaf node)

Crossing from the mounted file system to the mounted-on file system

http://realtime.ssu.ac.kr/



Example

% mount /dev/disk1 /usr % cd /usr/src/uts % cd ../../.. 위-> 아래 아래-> 위



39



Unmounting File System

Syntax

umount(special filename);

• Special filename : file system to be unmounted



Algorithm

Un-mounting전에 inode table을 검색하여 사용중인 field가 없는지 확인

• reference count가 양수 • 어떤 프로세스의 current directory인 경우



• 현재 수행중인 shared text를 가진 경우

• close되지 않은 open file들

http://realtime.ssu.ac.kr/



buffer pool이 “delayed write” 블록을 포함할 수도 있으므로 이들을 flush umount 하고자 하는 device의 inode를 access mount table에서 mounted file system의 root inode를 release



free mount table entry



40



Link

Syntax

link(source file name, target file name);

• source file name : name of an existing file • target file name : new name the file will have after completion of the link call



link

http://realtime.ssu.ac.kr/



Links a file to a new name in the file system directory structure, creating a new directory entry for an existing inode



41



Link Example

/ usr src include



link(“/usr/src/uts/sys”, “/usr/include/sys”)

link(“/usr/include/realfile.h”, “/usr/src/uts/sys/testfile.h”)



uts

sys



sys



realfile.h



inode.h



testfile.h



42



http://realtime.ssu.ac.kr/



Link Algorithm

Get inode for existing file name



Increment link count on inode

Update the disk copy of the inode and unlock the inode Search for the target file

File is present : link call fail , decrement the link count Otherwise : note the location of empty slot

http://realtime.ssu.ac.kr/



43



Algorithm link Input : existing file name new file name Output : none { get inode for existing file name (algorithm namei); if (too many links on file or linking directory without super user permission) { release inode (algorithm iput); return (error); } increment link count on inode; update disk copy of inode; unlock inode; get parent inode for directory to contain new file name (algorithm namei); if (new file name already exists or existing file, new file on different file systems) { undo update done above; return (error); } create new directory entry in parent directory of new file name: include new file name, inode number of existing file name; release parent directory inode (algorithm iput); release inode of existing file (algorithm iput); }



44



http://realtime.ssu.ac.kr/



Unlink

Syntax

unlink(pathname);

• Pathname : name of the file to be unlinked from the directory hierarchy



unlink

Removes a directory entry for a file

http://realtime.ssu.ac.kr/



No file is accessible by that name until another directory entry with that name is created

• unlink(“myfile”); • fd = open(“myfile”, O_RDONLY);



45



Algorithm unlink Input : file name Output : none { get parent inode of file to be unlinked (algorithm namei); /* if unlinking the current directory …*/ if (last component of file name is “.”) increment inode reference count; else get inode of file to be unlinked (algorithm iget); if (file is directory but user is not super user) { release inodes (algorithm iput); return (error); } if (shared text file and link count currently 1) remove from region table; write parent directory: zero inode number of unlinked file; release inode parent directory (algorithm iput); decrement file link count; release file inode (algorithm iput); /* iput checks if link count is 0: if so, * releases file blocks (algorithm free) and * frees inode (algorithm ifree); */ }



46



http://realtime.ssu.ac.kr/




Other docs by yagnesh darji
unix-ch02-01
Views: 67  |  Downloads: 6
unix-ch10-04
Views: 78  |  Downloads: 5
ASP_NET_XP_01
Views: 64  |  Downloads: 1
unix-ch03-01
Views: 156  |  Downloads: 3
unix-ch09-03
Views: 35  |  Downloads: 3
unix-ch10-01
Views: 390  |  Downloads: 24
bach
Views: 130  |  Downloads: 3
unix-ch02-03
Views: 92  |  Downloads: 2
Project Slides
Views: 28  |  Downloads: 0
unix-ch06-03
Views: 380  |  Downloads: 24
By registering with docstoc.com you agree to our
privacy policy

You are almost ready to download!

You are almost ready to download!