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

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

?? inode.c

?? LINUX1.0源代碼,代碼條理清晰
?? C
字號:
/*
 *  linux/fs/nfs/inode.c
 *
 *  Copyright (C) 1992  Rick Sladkey
 *
 *  nfs inode and superblock handling functions
 */

#include <asm/system.h>
#include <asm/segment.h>

#include <linux/sched.h>
#include <linux/nfs_fs.h>
#include <linux/kernel.h>
#include <linux/mm.h>
#include <linux/string.h>
#include <linux/stat.h>
#include <linux/errno.h>
#include <linux/locks.h>

extern int close_fp(struct file *filp, unsigned int fd);

static int nfs_notify_change(int, struct inode *);
static void nfs_put_inode(struct inode *);
static void nfs_put_super(struct super_block *);
static void nfs_statfs(struct super_block *, struct statfs *);

static struct super_operations nfs_sops = { 
	NULL,			/* read inode */
	nfs_notify_change,	/* notify change */
	NULL,			/* write inode */
	nfs_put_inode,		/* put inode */
	nfs_put_super,		/* put superblock */
	NULL,			/* write superblock */
	nfs_statfs,		/* stat filesystem */
	NULL
};

static void nfs_put_inode(struct inode * inode)
{
	clear_inode(inode);
}

void nfs_put_super(struct super_block *sb)
{
        /* No locks should be open on this, so 0 should be safe as a fd. */
	close_fp(sb->u.nfs_sb.s_server.file, 0);
	lock_super(sb);
	sb->s_dev = 0;
	unlock_super(sb);
}

/*
 * The way this works is that the mount process passes a structure
 * in the data argument which contains an open socket to the NFS
 * server and the root file handle obtained from the server's mount
 * daemon.  We stash theses away in the private superblock fields.
 * Later we can add other mount parameters like caching values.
 */

struct super_block *nfs_read_super(struct super_block *sb, void *raw_data,
				   int silent)
{
	struct nfs_mount_data *data = (struct nfs_mount_data *) raw_data;
	struct nfs_server *server;
	unsigned int fd;
	struct file *filp;
	dev_t dev = sb->s_dev;

	if (!data) {
		printk("nfs_read_super: missing data argument\n");
		sb->s_dev = 0;
		return NULL;
	}
	fd = data->fd;
	if (data->version != NFS_MOUNT_VERSION) {
		printk("nfs warning: mount version %s than kernel\n",
			data->version < NFS_MOUNT_VERSION ? "older" : "newer");
	}
	if (fd >= NR_OPEN || !(filp = current->filp[fd])) {
		printk("nfs_read_super: invalid file descriptor\n");
		sb->s_dev = 0;
		return NULL;
	}
	if (!S_ISSOCK(filp->f_inode->i_mode)) {
		printk("nfs_read_super: not a socket\n");
		sb->s_dev = 0;
		return NULL;
	}
	filp->f_count++;
	lock_super(sb);
	sb->s_blocksize = 1024; /* XXX */
	sb->s_blocksize_bits = 10;
	sb->s_magic = NFS_SUPER_MAGIC;
	sb->s_dev = dev;
	sb->s_op = &nfs_sops;
	server = &sb->u.nfs_sb.s_server;
	server->file = filp;
	server->lock = 0;
	server->wait = NULL;
	server->flags = data->flags;
	server->rsize = data->rsize;
	if (server->rsize <= 0)
		server->rsize = NFS_DEF_FILE_IO_BUFFER_SIZE;
	else if (server->rsize >= NFS_MAX_FILE_IO_BUFFER_SIZE)
		server->rsize = NFS_MAX_FILE_IO_BUFFER_SIZE;
	server->wsize = data->wsize;
	if (server->wsize <= 0)
		server->wsize = NFS_DEF_FILE_IO_BUFFER_SIZE;
	else if (server->wsize >= NFS_MAX_FILE_IO_BUFFER_SIZE)
		server->wsize = NFS_MAX_FILE_IO_BUFFER_SIZE;
	server->timeo = data->timeo*HZ/10;
	server->retrans = data->retrans;
	server->acregmin = data->acregmin*HZ;
	server->acregmax = data->acregmax*HZ;
	server->acdirmin = data->acdirmin*HZ;
	server->acdirmax = data->acdirmax*HZ;
	strcpy(server->hostname, data->hostname);
	sb->u.nfs_sb.s_root = data->root;
	unlock_super(sb);
	if (!(sb->s_mounted = nfs_fhget(sb, &data->root, NULL))) {
		sb->s_dev = 0;
		printk("nfs_read_super: get root inode failed\n");
		return NULL;
	}
	return sb;
}

void nfs_statfs(struct super_block *sb, struct statfs *buf)
{
	int error;
	struct nfs_fsinfo res;

	put_fs_long(NFS_SUPER_MAGIC, &buf->f_type);
	error = nfs_proc_statfs(&sb->u.nfs_sb.s_server, &sb->u.nfs_sb.s_root,
		&res);
	if (error) {
		printk("nfs_statfs: statfs error = %d\n", -error);
		res.bsize = res.blocks = res.bfree = res.bavail = 0;
	}
	put_fs_long(res.bsize, &buf->f_bsize);
	put_fs_long(res.blocks, &buf->f_blocks);
	put_fs_long(res.bfree, &buf->f_bfree);
	put_fs_long(res.bavail, &buf->f_bavail);
	put_fs_long(0, &buf->f_files);
	put_fs_long(0, &buf->f_ffree);
	/* We should really try to interrogate the remote server to find
	   it's maximum name length here */
	put_fs_long(NAME_MAX, &buf->f_namelen);
}

/*
 * This is our own version of iget that looks up inodes by file handle
 * instead of inode number.  We use this technique instead of using
 * the vfs read_inode function because there is no way to pass the
 * file handle or current attributes into the read_inode function.
 * We just have to be careful not to subvert iget's special handling
 * of mount points.
 */

struct inode *nfs_fhget(struct super_block *sb, struct nfs_fh *fhandle,
			struct nfs_fattr *fattr)
{
	struct nfs_fattr newfattr;
	int error;
	struct inode *inode;

	if (!sb) {
		printk("nfs_fhget: super block is NULL\n");
		return NULL;
	}
	if (!fattr) {
		error = nfs_proc_getattr(&sb->u.nfs_sb.s_server, fhandle,
			&newfattr);
		if (error) {
			printk("nfs_fhget: getattr error = %d\n", -error);
			return NULL;
		}
		fattr = &newfattr;
	}
	if (!(inode = iget(sb, fattr->fileid))) {
		printk("nfs_fhget: iget failed\n");
		return NULL;
	}
	if (inode->i_dev == sb->s_dev) {
		if (inode->i_ino != fattr->fileid) {
			printk("nfs_fhget: unexpected inode from iget\n");
			return inode;
		}
		*NFS_FH(inode) = *fhandle;
		nfs_refresh_inode(inode, fattr);
	}
	return inode;
}

int nfs_notify_change(int flags, struct inode *inode)
{
	struct nfs_sattr sattr;
	struct nfs_fattr fattr;
	int error;

	if (flags & NOTIFY_MODE)
		sattr.mode = inode->i_mode;
	else
		sattr.mode = (unsigned) -1;
	if (flags & NOTIFY_UIDGID) {
		sattr.uid = inode->i_uid;
		sattr.gid = inode->i_gid;
	}
	else
		sattr.uid = sattr.gid = (unsigned) -1;
	if (flags & NOTIFY_SIZE)
		sattr.size = S_ISREG(inode->i_mode) ? inode->i_size : -1;
	else
		sattr.size = (unsigned) -1;
	if (flags & NOTIFY_TIME) {
		sattr.mtime.seconds = inode->i_mtime;
		sattr.mtime.useconds = 0;
		sattr.atime.seconds = inode->i_atime;
		sattr.atime.useconds = 0;
	}
	else {
		sattr.mtime.seconds = sattr.mtime.useconds = (unsigned) -1;
		sattr.atime.seconds = sattr.atime.useconds = (unsigned) -1;
	}
	error = nfs_proc_setattr(NFS_SERVER(inode), NFS_FH(inode),
		&sattr, &fattr);
	if (!error)
		nfs_refresh_inode(inode, &fattr);
	inode->i_dirt = 0;
	return error;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
夫妻av一区二区| 一本到不卡免费一区二区| 日韩理论片在线| 91精品国产综合久久久蜜臀粉嫩 | 精品亚洲免费视频| 国产精品电影一区二区三区| 欧美丰满一区二区免费视频| 91最新地址在线播放| 久久不见久久见中文字幕免费| 亚洲精选在线视频| 久久先锋影音av鲁色资源网| 欧美日韩一区在线观看| caoporm超碰国产精品| 久久精品99国产精品| 亚洲一区二区在线免费观看视频| 国产欧美一区在线| 精品国产乱码久久久久久图片| 欧美色图免费看| 91蝌蚪国产九色| 成人精品国产免费网站| 狠狠色狠狠色综合| 蜜桃视频在线一区| 香蕉影视欧美成人| 亚洲香肠在线观看| 亚洲欧美一区二区三区极速播放 | 久久久久久久久久看片| 欧美剧情电影在线观看完整版免费励志电影 | 99久久久精品| 国产成人精品一区二| 极品少妇xxxx精品少妇| 日韩高清电影一区| 亚洲成av人片在www色猫咪| 一区二区三区国产| 亚洲最色的网站| 亚洲人成人一区二区在线观看| 欧美国产激情二区三区| 国产欧美一区二区在线| 国产欧美中文在线| 欧美国产综合色视频| 国产亚洲精品免费| 欧美国产日韩精品免费观看| 国产亚洲欧美色| 国产片一区二区| 国产精品人成在线观看免费 | 丝袜美腿亚洲色图| 99riav一区二区三区| 成人在线视频一区二区| 成人午夜电影小说| 成av人片一区二区| 91美女在线观看| 欧美吞精做爰啪啪高潮| 欧美高清性hdvideosex| 欧美一级电影网站| 26uuu精品一区二区在线观看| 精品国产麻豆免费人成网站| 久久精品在线观看| 国产精品色哟哟网站| 一区二区三区四区视频精品免费| 亚洲激情av在线| 天天爽夜夜爽夜夜爽精品视频 | 成人免费视频一区| 99国产精品久| 9191精品国产综合久久久久久| 日韩一区二区三区视频| 久久久久久**毛片大全| 中文在线一区二区| 夜夜精品视频一区二区| 日韩高清欧美激情| 国产99久久久国产精品潘金| 99国产精品久久久久久久久久| 欧美三级午夜理伦三级中视频| 日韩欧美国产综合一区 | 日韩不卡免费视频| 国产在线视视频有精品| 91香蕉视频在线| 欧美精品xxxxbbbb| 久久久久久久国产精品影院| 《视频一区视频二区| 爽爽淫人综合网网站| 高清不卡一区二区| 欧美三级日韩在线| 久久精品欧美一区二区三区不卡| 亚洲欧美一区二区久久| 美女久久久精品| caoporen国产精品视频| 欧美一区二区三区在| 国产精品国产三级国产aⅴ原创| 亚洲成人你懂的| 国产成人欧美日韩在线电影| 色偷偷一区二区三区| 欧美变态tickle挠乳网站| 亚洲色图在线播放| 蜜桃精品视频在线| 在线看不卡av| 国产日韩一级二级三级| 亚洲444eee在线观看| 懂色av一区二区在线播放| 在线播放91灌醉迷j高跟美女 | 视频一区视频二区中文字幕| 床上的激情91.| 在线综合+亚洲+欧美中文字幕| 国产精品拍天天在线| 美女一区二区三区| 欧美优质美女网站| 中文字幕欧美激情一区| 奇米影视在线99精品| 欧美专区亚洲专区| 日本一区二区三区高清不卡 | 日韩欧美亚洲国产另类| 亚洲欧美激情小说另类| 国产一区二区三区美女| 91麻豆精品91久久久久同性| 日韩美女视频一区| 国产成人av福利| 日韩限制级电影在线观看| 亚洲精品成人悠悠色影视| 国产福利一区在线| 欧美刺激脚交jootjob| 亚洲图片欧美色图| 91麻豆免费观看| 国产精品美女久久福利网站| 狠狠久久亚洲欧美| 欧美电视剧免费观看| 日本不卡高清视频| 在线不卡一区二区| 亚洲aaa精品| 欧美少妇xxx| 亚洲一区二区三区视频在线| 91丝袜呻吟高潮美腿白嫩在线观看| 欧美国产综合一区二区| 国产精品系列在线观看| 欧美精品一区二区在线观看| 免费在线欧美视频| 91精品国产91综合久久蜜臀| 亚洲午夜久久久久久久久电影网| 色婷婷亚洲精品| 一区二区三区在线免费| 91黄视频在线| 亚洲一区二区四区蜜桃| 欧美日韩成人在线一区| 亚洲高清中文字幕| 欧美日本精品一区二区三区| 午夜影视日本亚洲欧洲精品| 欧美日韩三级一区二区| 亚洲va韩国va欧美va精品| 欧美精品xxxxbbbb| 毛片av一区二区| 欧美精品一区二区久久婷婷| 韩日欧美一区二区三区| 久久亚洲综合色一区二区三区 | 欧美性猛交xxxxxxxx| 亚洲成在人线免费| 欧美老女人第四色| 韩国理伦片一区二区三区在线播放| 欧美大黄免费观看| 国产精品69毛片高清亚洲| 国产精品久久久久久久久免费樱桃| 成人午夜看片网址| 亚洲人成小说网站色在线 | av亚洲精华国产精华精华| 亚洲日本一区二区| 精品视频一区二区三区免费| 蜜臀国产一区二区三区在线播放 | 亚洲图片欧美视频| 日韩一区二区三区电影| 国产精品77777| 一区二区三区产品免费精品久久75| 欧美日韩1区2区| 国产一区二区久久| 尤物av一区二区| 日韩欧美国产wwwww| 国产成人免费在线观看不卡| 亚洲免费电影在线| 欧美一级高清片在线观看| 国产69精品久久久久毛片| 亚洲一区二区三区四区不卡| 亚洲精品一区二区三区精华液| 波多野结衣91| 日韩va欧美va亚洲va久久| 国产欧美精品一区二区三区四区 | 免费成人在线播放| 国产精品情趣视频| 337p亚洲精品色噜噜噜| 成人午夜视频在线| 免费观看在线色综合| 综合久久久久久久| 精品裸体舞一区二区三区| 色呦呦国产精品| 国产福利一区在线| 天堂在线一区二区| 亚洲欧洲一区二区在线播放| 欧美一级欧美三级在线观看| av一区二区三区四区| 久久精品国产第一区二区三区| 亚洲美女在线国产| 久久精品欧美日韩| 欧美一区二区黄| 欧美综合在线视频| 成人在线视频一区二区| 欧美aⅴ一区二区三区视频|