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

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

?? inode.c

?? 內核是系統的心臟
?? 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一区二区三区免费野_久草精品视频
国产白丝精品91爽爽久久| 亚洲理论在线观看| 久久国产精品露脸对白| 欧亚一区二区三区| 亚洲欧洲成人自拍| 国产91精品精华液一区二区三区 | 91蜜桃传媒精品久久久一区二区| 国产亚洲欧美在线| 国产在线播放一区二区三区| 久久影视一区二区| www.欧美亚洲| 欧美国产精品久久| 成a人片国产精品| 综合激情成人伊人| 91伊人久久大香线蕉| 亚洲综合一区二区三区| 在线电影一区二区三区| 免费不卡在线视频| 国产色一区二区| 99久久精品情趣| 亚洲国产一区视频| 91精品国产综合久久久久久久久久 | 日韩电影一二三区| 日韩精品一区二区三区老鸭窝| 美国欧美日韩国产在线播放| xfplay精品久久| 不卡视频在线看| 午夜欧美2019年伦理| 精品国产91乱码一区二区三区 | 欧美精品一二三区| 久久精品国产99久久6| 国产人伦精品一区二区| 色欧美片视频在线观看| 看电视剧不卡顿的网站| 亚洲国产精品99久久久久久久久 | 日韩美女在线视频| 久久99热国产| 伊人婷婷欧美激情| 久久综合久久鬼色中文字| 99国产精品国产精品毛片| 天堂资源在线中文精品| 国产日韩成人精品| 欧美私人免费视频| 成人av中文字幕| 美女视频一区二区| 夜夜亚洲天天久久| 国产女人aaa级久久久级| 日韩一区二区电影在线| 91福利社在线观看| 波多野结衣中文字幕一区二区三区| 亚洲福利国产精品| 国产精品久久久久一区| www激情久久| 91精品国产91久久久久久最新毛片 | 中文字幕免费在线观看视频一区| 欧美一区二区久久| 欧美性受xxxx| 91成人国产精品| 99麻豆久久久国产精品免费| 精品中文字幕一区二区| 日韩电影免费在线观看网站| 一区二区三区高清不卡| 亚洲精品久久7777| 亚洲一本大道在线| 日韩高清欧美激情| 久久99精品一区二区三区三区| 精品在线一区二区| 国产精品66部| 日本高清成人免费播放| 欧美精品一二三| 精品福利在线导航| 中文字幕永久在线不卡| 一区二区三区在线看| 午夜欧美2019年伦理| 国产一区二区在线免费观看| 成人午夜在线视频| 欧美日韩大陆一区二区| 26uuu国产日韩综合| 亚洲精品免费看| 日韩电影免费在线看| 99精品在线免费| 欧美中文字幕不卡| 欧美日韩国产高清一区二区三区| 欧美精品tushy高清| 欧美大片日本大片免费观看| 欧美激情资源网| 一区二区三区在线影院| 日韩黄色小视频| 国产成人精品三级| 91麻豆精品国产91久久久久| 777亚洲妇女| 国产精品伦理在线| 五月激情丁香一区二区三区| 韩国成人精品a∨在线观看| proumb性欧美在线观看| 欧美一区二视频| 亚洲日本韩国一区| 久久精品99久久久| 日本高清视频一区二区| 久久久久久一二三区| 亚洲国产精品久久不卡毛片| 国内国产精品久久| 欧美在线一区二区| 中文字幕乱码日本亚洲一区二区| 亚洲国产欧美在线人成| 成人一区二区三区中文字幕| 欧美久久久久久蜜桃| 亚洲天天做日日做天天谢日日欢| 精品一区二区三区免费观看| 欧美日韩免费观看一区二区三区| 国产女人aaa级久久久级| 久久av中文字幕片| 欧美久久久久久久久久| 亚洲日本va在线观看| 粉嫩av一区二区三区在线播放 | 日本不卡1234视频| 欧美美女一区二区三区| 亚洲免费高清视频在线| 成人午夜看片网址| 中文一区二区完整视频在线观看| 久久www免费人成看片高清| 日韩欧美激情在线| 久草在线在线精品观看| 欧美不卡一区二区| 久久成人av少妇免费| 日韩一区二区三区视频在线观看 | 97精品视频在线观看自产线路二| 日本一二三四高清不卡| 成人av影视在线观看| 国产精品私人影院| 日本高清免费不卡视频| 亚洲成a人片在线观看中文| 91精品欧美久久久久久动漫| 在线观看一区日韩| 日日骚欧美日韩| 精品成人一区二区三区| 成人性视频网站| 亚洲啪啪综合av一区二区三区| 96av麻豆蜜桃一区二区| 午夜久久电影网| 日韩欧美国产三级电影视频| 国产一区二区三区最好精华液| 国产精品素人视频| 日本韩国视频一区二区| 蜜臀av一区二区在线免费观看| 精品99999| 欧美一区二区日韩一区二区| 久久精品国产精品青草| 国产精品成人免费在线| 欧美精品精品一区| 成人av影院在线| 日本aⅴ免费视频一区二区三区| 久久久不卡网国产精品一区| 色狠狠av一区二区三区| 麻豆国产精品官网| 亚洲男人的天堂一区二区 | 色婷婷综合激情| 激情欧美一区二区三区在线观看| 成人免费在线观看入口| 99久久久精品| 日韩不卡一区二区三区| 亚洲在线免费播放| 国产精品毛片久久久久久| 欧美精品乱码久久久久久| 成人av网在线| 狠狠色狠狠色综合系列| 午夜精品久久久久久久久久| 最近日韩中文字幕| 久久视频一区二区| 欧美亚一区二区| 99久久精品国产毛片| 国产成+人+日韩+欧美+亚洲| 免费三级欧美电影| 午夜精品一区二区三区电影天堂| 中文字幕av一区二区三区高 | 蜜臀av性久久久久蜜臀aⅴ| 亚洲高清免费视频| 一区2区3区在线看| 一区二区三区在线播| 国产精品理伦片| 亚洲色图制服丝袜| 综合久久国产九一剧情麻豆| 国产精品高潮呻吟| 亚洲精品国产无套在线观 | 99精品偷自拍| 一本大道久久精品懂色aⅴ| 91在线观看免费视频| 一本到一区二区三区| 欧美日韩不卡一区二区| 日韩欧美在线综合网| 2021久久国产精品不只是精品| 精品国产电影一区二区| 国产亚洲制服色| 亚洲视频免费在线| 亚洲成av人片在线观看| 久久国产精品区| 成人性生交大片免费看中文网站| 91亚洲午夜精品久久久久久| 在线亚洲一区二区| 欧美电影免费观看完整版|