亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? file.c

?? <Linux1.0核心游記>電子書+書后源碼+Linux1.0源碼
?? C
字號:
/* *  linux/fs/xiafs/file.c * *  Copyright (C) Q. Frank Xia, 1993. *   *  Based on Linus' minix/file.c *  Copyright (C) Linus Torvalds, 1991, 1992. * *  This software may be redistributed per Linux Copyright. */#include <asm/segment.h>#include <asm/system.h>#include <linux/sched.h>#include <linux/fs.h>#include <linux/xia_fs.h>#include <linux/kernel.h>#include <linux/errno.h>#include <linux/fcntl.h>#include <linux/stat.h>#include <linux/locks.h>#include "xiafs_mac.h"#define	NBUF	32#define MIN(a,b) (((a)<(b))?(a):(b))#define MAX(a,b) (((a)>(b))?(a):(b))static int xiafs_file_read(struct inode *, struct file *, char *, int);static int xiafs_file_write(struct inode *, struct file *, char *, int);/* * We have mostly NULL's here: the current defaults are ok for * the xiafs filesystem. */static struct file_operations xiafs_file_operations = {    NULL,			/* lseek - default */    xiafs_file_read,		/* read */    xiafs_file_write,		/* write */    NULL,			/* readdir - bad */    NULL,			/* select - default */    NULL,			/* ioctl - default */    generic_mmap,      		/* mmap */    NULL,			/* no special open is needed */    NULL,			/* release */    xiafs_sync_file		/* fsync */};struct inode_operations xiafs_file_inode_operations = {    &xiafs_file_operations,	/* default file operations */    NULL,			/* create */    NULL,			/* lookup */    NULL,			/* link */    NULL,			/* unlink */    NULL,			/* symlink */    NULL,			/* mkdir */    NULL,			/* rmdir */    NULL,			/* mknod */    NULL,			/* rename */    NULL,			/* readlink */    NULL,			/* follow_link */    xiafs_bmap,			/* bmap */    xiafs_truncate,		/* truncate */    NULL			/* permission */};static int xiafs_file_read(struct inode * inode, struct file * filp, char * buf, int count){    int read, left, chars;    int zone_nr, zones, f_zones, offset;    int bhrequest, uptodate;    struct buffer_head ** bhb, ** bhe;    struct buffer_head * bhreq[NBUF];    struct buffer_head * buflist[NBUF];    if (!inode) {        printk("XIA-FS: inode = NULL (%s %d)\n", WHERE_ERR);	return -EINVAL;    }    if (!S_ISREG(inode->i_mode)) {        printk("XIA-FS: mode != regular (%s %d)\n", WHERE_ERR);	return -EINVAL;    }    offset = filp->f_pos;    left = inode->i_size - offset;    if (left > count)	left = count;    if (left <= 0)	return 0;    read = 0;    zone_nr = offset >> XIAFS_ZSIZE_BITS(inode->i_sb);    offset &= XIAFS_ZSIZE(inode->i_sb) -1 ;    f_zones =(inode->i_size+XIAFS_ZSIZE(inode->i_sb)-1)>>XIAFS_ZSIZE_BITS(inode->i_sb);    zones = (left+offset+XIAFS_ZSIZE(inode->i_sb)-1) >> XIAFS_ZSIZE_BITS(inode->i_sb);    bhb = bhe = buflist;    if (filp->f_reada) {        zones += read_ahead[MAJOR(inode->i_dev)] >> (1+XIAFS_ZSHIFT(inode->i_sb));	if (zone_nr + zones > f_zones)	    zones = f_zones - zone_nr;    }    /* We do this in a two stage process.  We first try and request       as many blocks as we can, then we wait for the first one to       complete, and then we try and wrap up as many as are actually       done.  This routine is rather generic, in that it can be used       in a filesystem by substituting the appropriate function in       for getblk.              This routine is optimized to make maximum use of the various       buffers and caches. */    do {        bhrequest = 0;	uptodate = 1;	while (zones--) {	    *bhb = xiafs_getblk(inode, zone_nr++, 0);	    if (*bhb && !(*bhb)->b_uptodate) {	        uptodate = 0;		bhreq[bhrequest++] = *bhb;	    }	    if (++bhb == &buflist[NBUF])	        bhb = buflist;	    	    /* If the block we have on hand is uptodate, go ahead	       and complete processing. */	    if (uptodate)	        break;	    if (bhb == bhe)	        break;	}	/* Now request them all */	if (bhrequest)	    ll_rw_block(READ, bhrequest, bhreq);	do { /* Finish off all I/O that has actually completed */	    if (*bhe) {	        wait_on_buffer(*bhe);		if (!(*bhe)->b_uptodate) {	/* read error? */		    brelse(*bhe);		    if (++bhe == &buflist[NBUF])		      bhe = buflist;		    left = 0;		    break;		}	    }	    if (left < XIAFS_ZSIZE(inode->i_sb) - offset)	        chars = left;	    else	        chars = XIAFS_ZSIZE(inode->i_sb) - offset;	    filp->f_pos += chars;	    left -= chars;	    read += chars;	    if (*bhe) {	        memcpy_tofs(buf,offset+(*bhe)->b_data,chars);		brelse(*bhe);		buf += chars;	    } else {	        while (chars-->0)		    put_fs_byte(0,buf++);	    }	    offset = 0;	    if (++bhe == &buflist[NBUF])	        bhe = buflist;	} while (left > 0 && bhe != bhb && (!*bhe || !(*bhe)->b_lock));    } while (left > 0);/* Release the read-ahead blocks */    while (bhe != bhb) {        brelse(*bhe);	if (++bhe == &buflist[NBUF])	    bhe = buflist;    };    if (!read)        return -EIO;    filp->f_reada = 1;    if (!IS_RDONLY (inode)) {	inode->i_atime = CURRENT_TIME;	inode->i_dirt = 1;    }    return read;}static int xiafs_file_write(struct inode * inode, struct file * filp, char * buf, int count){    off_t pos;    int written, c;    struct buffer_head * bh;    char * cp;    if (!inode) {        printk("XIA-FS: inode = NULL (%s %d)\n", WHERE_ERR);	return -EINVAL;    }    if (!S_ISREG(inode->i_mode)) {        printk("XIA-FS: mode != regular (%s %d)\n", WHERE_ERR);	return -EINVAL;    }/* * ok, append may not work when many processes are writing at the same time * but so what. That way leads to madness anyway. */    if (filp->f_flags & O_APPEND)        pos = inode->i_size;    else        pos = filp->f_pos;    written = 0;    while (written < count) {        bh = xiafs_getblk(inode, pos >> XIAFS_ZSIZE_BITS(inode->i_sb), 1);	if (!bh) {	    if (!written)	        written = -ENOSPC;	    break;	}	c = XIAFS_ZSIZE(inode->i_sb) - (pos & (XIAFS_ZSIZE(inode->i_sb) - 1));	if (c > count-written)	    c = count-written;	if (c != XIAFS_ZSIZE(inode->i_sb) && !bh->b_uptodate) {	    ll_rw_block(READ, 1, &bh);	    wait_on_buffer(bh);	    if (!bh->b_uptodate) {	        brelse(bh);		if (!written)		    written = -EIO;		break;	    }	}	cp = (pos & (XIAFS_ZSIZE(inode->i_sb)-1)) + bh->b_data;	pos += c;	if (pos > inode->i_size) {	    inode->i_size = pos;	    inode->i_dirt = 1;	}	written += c;	memcpy_fromfs(cp,buf,c);	buf += c;	bh->b_uptodate = 1;	bh->b_dirt = 1;	brelse(bh);    }    inode->i_mtime = inode->i_ctime = CURRENT_TIME;    filp->f_pos = pos;    inode->i_dirt = 1;    return written;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩av中文在线观看| 日韩一区二区麻豆国产| 日韩精品电影在线| 中文字幕精品在线不卡| 欧美久久一二区| av一本久道久久综合久久鬼色| 婷婷成人激情在线网| 国产精品免费观看视频| 91麻豆精品国产| 色妹子一区二区| 国产精品一区二区果冻传媒| 日韩国产欧美在线播放| 亚洲色图在线看| 亚洲精品在线观| 欧美日韩专区在线| 色综合夜色一区| 成人黄色在线网站| 麻豆91小视频| 日韩av一区二区在线影视| 亚洲精品一二三区| 一色屋精品亚洲香蕉网站| 久久精品在线免费观看| 日韩免费成人网| 91精品国产黑色紧身裤美女| 在线免费不卡电影| 色系网站成人免费| 94-欧美-setu| 99久久精品免费看国产| 成人性生交大片免费看中文网站| 另类人妖一区二区av| 日韩国产在线观看一区| 偷拍与自拍一区| 亚洲成人动漫在线观看| 亚洲一区二区成人在线观看| 久久久久久久电影| 久久午夜电影网| 久久久久久久久久久黄色| 欧美一区二区视频在线观看| 欧美日韩国产天堂| 在线视频你懂得一区| 一本色道a无线码一区v| 成人福利在线看| 成人永久看片免费视频天堂| 国产高清不卡一区| 在线观看91视频| 久久精品国产99国产| 亚洲人成影院在线观看| 日韩欧美国产三级| 欧美色精品在线视频| 欧美日韩三级一区| 日韩午夜在线播放| 久久综合成人精品亚洲另类欧美 | 亚洲欧洲日产国码二区| 亚洲国产精品高清| 日韩美女视频一区二区| 中文一区二区完整视频在线观看| 欧美国产精品一区| 亚洲欧洲精品天堂一级| 亚洲国产视频在线| 日韩国产精品久久久久久亚洲| 免费高清成人在线| 麻豆精品在线播放| 国产一区二区精品久久99| 香蕉久久夜色精品国产使用方法| 专区另类欧美日韩| 日本欧美在线看| 三级不卡在线观看| 亚洲国产aⅴ成人精品无吗| 欧美激情艳妇裸体舞| 国产日产亚洲精品系列| 亚洲欧美视频在线观看| 亚洲一区在线电影| 亚洲国产日韩a在线播放| 奇米色一区二区| 国产精品1区二区.| 激情图片小说一区| 紧缚捆绑精品一区二区| 高清不卡一区二区在线| 欧美亚洲综合在线| 精品乱码亚洲一区二区不卡| 亚洲国产精品成人综合色在线婷婷 | 精品久久久久一区| 中文字幕一区二区三区不卡在线 | 综合婷婷亚洲小说| 亚洲va欧美va人人爽午夜 | 风间由美一区二区三区在线观看| 91网址在线看| 日韩写真欧美这视频| 国产精品国产精品国产专区不蜜 | 久久久www成人免费无遮挡大片| 一区二区三区色| 韩国v欧美v亚洲v日本v| 97久久精品人人爽人人爽蜜臀 | 欧美一级国产精品| 中文字幕综合网| 国产一区二区主播在线| 欧美在线观看一区| 欧美韩国日本一区| 日韩成人免费电影| 99久久精品99国产精品| 欧美成人伊人久久综合网| 一区二区三区不卡视频在线观看| 婷婷综合在线观看| 欧美成人精品高清在线播放| 777a∨成人精品桃花网| 国产日产亚洲精品系列| 亚洲五月六月丁香激情| 国产a精品视频| 日韩欧美一区二区久久婷婷| 亚洲黄色录像片| 国产尤物一区二区在线| 欧美一区二区三区白人| 亚洲永久免费视频| av在线综合网| 久久久久久久久久看片| 加勒比av一区二区| 日韩视频123| 日韩精品色哟哟| 欧美日韩一级片网站| 一区二区三区视频在线看| 国产精选一区二区三区| 欧美日韩专区在线| 一区二区成人在线| 92精品国产成人观看免费| 亚洲国产成人午夜在线一区| 国产一区999| 精品99久久久久久| 男女男精品视频网| 欧美一区二区三级| 日韩av中文字幕一区二区三区| 国产一区二区三区在线观看免费 | 一区二区三区日韩欧美精品| 国产成人自拍网| 久久久久久日产精品| 精品一区二区在线免费观看| 欧美一区二区三区在线电影| 午夜激情综合网| 在线亚洲一区二区| 亚洲综合av网| 91福利社在线观看| 亚洲制服欧美中文字幕中文字幕| 91免费在线视频观看| 亚洲女同一区二区| 91国在线观看| 午夜欧美视频在线观看| 欧美精品1区2区3区| 首页国产欧美日韩丝袜| 91精品欧美福利在线观看| 日本va欧美va瓶| 精品美女一区二区| 国产成人精品免费在线| 国产精品乱子久久久久| 成人av影视在线观看| 亚洲伦理在线精品| 欧美视频完全免费看| 日日夜夜精品视频天天综合网| 欧美一区二区视频在线观看| 久久99久久99精品免视看婷婷| 久久嫩草精品久久久精品一| 国产黑丝在线一区二区三区| 国产精品国产三级国产aⅴ中文| 91在线看国产| 午夜久久电影网| 欧美成人a在线| 成人激情黄色小说| 亚洲国产精品久久人人爱蜜臀 | 国产精品白丝在线| 欧美在线高清视频| 久久精品99国产国产精| 国产欧美一区二区精品性色| 91香蕉视频mp4| 日本特黄久久久高潮| 国产日韩欧美制服另类| 色综合天天综合网天天看片| 丝袜诱惑制服诱惑色一区在线观看 | 欧美激情一区在线观看| 色哟哟精品一区| 捆绑变态av一区二区三区| 中文字幕国产精品一区二区| 欧美色图激情小说| 国产在线不卡视频| 一区二区三区免费看视频| 日韩一卡二卡三卡国产欧美| 国产精品一区二区三区网站| 国产精品热久久久久夜色精品三区| 91丨九色porny丨蝌蚪| 视频在线在亚洲| 国产婷婷精品av在线| 欧美日本一道本| 国产.精品.日韩.另类.中文.在线.播放 | 欧美在线观看一二区| 韩国在线一区二区| 一区二区三区四区不卡在线 | 精品剧情v国产在线观看在线| 91在线播放网址| 狠狠色丁香久久婷婷综合丁香| 亚洲人成伊人成综合网小说| www日韩大片| 欧美人伦禁忌dvd放荡欲情| 成人午夜激情片|