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

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

?? super.c

?? 內核是系統的心臟
?? C
?? 第 1 頁 / 共 2 頁
字號:
		    gdp->bg_inode_table + sb->u.ext2_sb.s_itb_per_group >=
		    block + EXT2_BLOCKS_PER_GROUP(sb))
		{
			ext2_error (sb, "ext2_check_desciptors",
				    "Inode table for group %d"
				    " not in group (block %lu)!",
				    i, gdp->bg_inode_table);
			return 0;
		}
		block += EXT2_BLOCKS_PER_GROUP(sb);
		gdp++;
	}
	return 1;
}

struct super_block * ext2_read_super (struct super_block * sb, void * data,
				      int silent)
{
	struct buffer_head * bh;
	struct ext2_super_block * es;
	unsigned long sb_block = 1;
	unsigned long logic_sb_block = 1;
	int dev = sb->s_dev;
	int bh_count;
	int i, j;
#ifdef EXT2FS_PRE_02B_COMPAT
	int fs_converted = 0;
#endif

	set_opt (sb->u.ext2_sb.s_mount_opt, CHECK_NORMAL);
	if (!parse_options ((char *) data, &sb_block,
	    &sb->u.ext2_sb.s_mount_opt)) {
		sb->s_dev = 0;
		return NULL;
	}

	lock_super (sb);
	set_blocksize (dev, BLOCK_SIZE);
	if (!(bh = bread (dev, sb_block, BLOCK_SIZE))) {
		sb->s_dev = 0;
		unlock_super (sb);
		printk ("EXT2-fs: unable to read superblock\n");
		return NULL;
	}
	/*
	 * Note: s_es must be initialized s_es as soon as possible because
	 * some ext2 macro-instructions depend on its value
	 */
	es = (struct ext2_super_block *) bh->b_data;
	sb->u.ext2_sb.s_es = es;
	sb->s_magic = es->s_magic;
	if (sb->s_magic != EXT2_SUPER_MAGIC
#ifdef EXT2FS_PRE_02B_COMPAT
	   && sb->s_magic != EXT2_PRE_02B_MAGIC
#endif
	   ) {
		sb->s_dev = 0;
		unlock_super (sb);
		brelse (bh);
		if (!silent)
			printk ("VFS: Can't find an ext2 filesystem on dev %d/%d.\n",
				MAJOR(dev), MINOR(dev));
		return NULL;
	}
	sb->s_blocksize = EXT2_MIN_BLOCK_SIZE << es->s_log_block_size;
	sb->s_blocksize_bits = EXT2_BLOCK_SIZE_BITS(sb);
	if (sb->s_blocksize != BLOCK_SIZE && 
	    (sb->s_blocksize == 1024 || sb->s_blocksize == 2048 ||  
	     sb->s_blocksize == 4096)) {
		unsigned long offset;

		brelse (bh);
		set_blocksize (dev, sb->s_blocksize);
		logic_sb_block = sb_block / sb->s_blocksize;
		offset = sb_block % sb->s_blocksize;
		bh = bread (dev, logic_sb_block, sb->s_blocksize);
		if(!bh)
			return NULL;
		es = (struct ext2_super_block *) (((char *)bh->b_data) + offset);
		sb->u.ext2_sb.s_es = es;
		if (es->s_magic != EXT2_SUPER_MAGIC) {
			sb->s_dev = 0;
			unlock_super (sb);
			brelse (bh);
			printk ("EXT2-fs: Magic mismatch, very weird !\n");
			return NULL;
		}
	}
	sb->u.ext2_sb.s_frag_size = EXT2_MIN_FRAG_SIZE <<
				   es->s_log_frag_size;
	if (sb->u.ext2_sb.s_frag_size)
		sb->u.ext2_sb.s_frags_per_block = sb->s_blocksize /
						  sb->u.ext2_sb.s_frag_size;
	else
		sb->s_magic = 0;
	sb->u.ext2_sb.s_blocks_per_group = es->s_blocks_per_group;
	sb->u.ext2_sb.s_frags_per_group = es->s_frags_per_group;
	sb->u.ext2_sb.s_inodes_per_group = es->s_inodes_per_group;
	sb->u.ext2_sb.s_inodes_per_block = sb->s_blocksize /
					   sizeof (struct ext2_inode);
	sb->u.ext2_sb.s_itb_per_group = sb->u.ext2_sb.s_inodes_per_group /
				        sb->u.ext2_sb.s_inodes_per_block;
	sb->u.ext2_sb.s_desc_per_block = sb->s_blocksize /
					 sizeof (struct ext2_group_desc);
	sb->u.ext2_sb.s_sbh = bh;
	sb->u.ext2_sb.s_es = es;
	sb->u.ext2_sb.s_mount_state = es->s_state;
	sb->u.ext2_sb.s_rename_lock = 0;
	sb->u.ext2_sb.s_rename_wait = NULL;
#ifdef EXT2FS_PRE_02B_COMPAT
	if (sb->s_magic == EXT2_PRE_02B_MAGIC) {
		if (es->s_blocks_count > 262144) {
			/*
			 * fs > 256 MB can't be converted
			 */ 
			sb->s_dev = 0;
			unlock_super (sb);
			brelse (bh);
			printk ("EXT2-fs: trying to mount a pre-0.2b file"
				"system which cannot be converted\n");
			return NULL;
		}
		printk ("EXT2-fs: mounting a pre 0.2b file system, "
			"will try to convert the structure\n");
		if (!(sb->s_flags & MS_RDONLY)) {
			sb->s_dev = 0;
			unlock_super (sb);
			brelse (bh);
			printk ("EXT2-fs: cannot convert a read-only fs\n");
			return NULL;
		}
		if (!convert_pre_02b_fs (sb, bh)) {
			sb->s_dev = 0;
			unlock_super (sb);
			brelse (bh);
			printk ("EXT2-fs: conversion failed !!!\n");
			return NULL;
		}
		printk ("EXT2-fs: conversion succeeded !!!\n");
		fs_converted = 1;
	}
#endif
	if (sb->s_magic != EXT2_SUPER_MAGIC) {
		sb->s_dev = 0;
		unlock_super (sb);
		brelse (bh);
		if (!silent)
			printk ("VFS: Can't find an ext2 filesystem on dev %d/%d.\n",
				MAJOR(dev), MINOR(dev));
		return NULL;
	}
	if (sb->s_blocksize != bh->b_size) {
		sb->s_dev = 0;
		unlock_super (sb);
		brelse (bh);
		if (!silent)
			printk ("VFS: Unsupported blocksize on dev 0x%04x.\n",
				dev);
		return NULL;
	}

	if (sb->s_blocksize != sb->u.ext2_sb.s_frag_size) {
		sb->s_dev = 0;
		unlock_super (sb);
		brelse (bh);
		printk ("EXT2-fs: fragsize %lu != blocksize %lu (not supported yet)\n",
			sb->u.ext2_sb.s_frag_size, sb->s_blocksize);
		return NULL;
	}

	sb->u.ext2_sb.s_groups_count = (es->s_blocks_count -
				        es->s_first_data_block +
				       EXT2_BLOCKS_PER_GROUP(sb) - 1) /
				       EXT2_BLOCKS_PER_GROUP(sb);
	for (i = 0; i < EXT2_MAX_GROUP_DESC; i++)
		sb->u.ext2_sb.s_group_desc[i] = NULL;
	bh_count = (sb->u.ext2_sb.s_groups_count + EXT2_DESC_PER_BLOCK(sb) - 1) /
		   EXT2_DESC_PER_BLOCK(sb);
	if (bh_count > EXT2_MAX_GROUP_DESC) {
		sb->s_dev = 0;
		unlock_super (sb);
		brelse (bh);
		printk ("EXT2-fs: file system is too big\n");
		return NULL;
	}
	for (i = 0; i < bh_count; i++) {
		sb->u.ext2_sb.s_group_desc[i] = bread (dev, logic_sb_block + i + 1,
						       sb->s_blocksize);
		if (!sb->u.ext2_sb.s_group_desc[i]) {
			sb->s_dev = 0;
			unlock_super (sb);
			for (j = 0; j < i; j++)
				brelse (sb->u.ext2_sb.s_group_desc[j]);
			brelse (bh);
			printk ("EXT2-fs: unable to read group descriptors\n");
			return NULL;
		}
	}
	if (!ext2_check_descriptors (sb)) {
		sb->s_dev = 0;
		unlock_super (sb);
		for (j = 0; j < i; j++)
			brelse (sb->u.ext2_sb.s_group_desc[j]);
		brelse (bh);
		printk ("EXT2-fs: group descriptors corrupted !\n");
		return NULL;
	}
	for (i = 0; i < EXT2_MAX_GROUP_LOADED; i++) {
		sb->u.ext2_sb.s_inode_bitmap_number[i] = 0;
		sb->u.ext2_sb.s_inode_bitmap[i] = NULL;
		sb->u.ext2_sb.s_block_bitmap_number[i] = 0;
		sb->u.ext2_sb.s_block_bitmap[i] = NULL;
	}
	sb->u.ext2_sb.s_loaded_inode_bitmaps = 0;
	sb->u.ext2_sb.s_loaded_block_bitmaps = 0;
	unlock_super (sb);
	/*
	 * set up enough so that it can read an inode
	 */
	sb->s_dev = dev;
	sb->s_op = &ext2_sops;
	if (!(sb->s_mounted = iget (sb, EXT2_ROOT_INO))) {
		sb->s_dev = 0;
		for (i = 0; i < EXT2_MAX_GROUP_DESC; i++)
			if (sb->u.ext2_sb.s_group_desc[i])
				brelse (sb->u.ext2_sb.s_group_desc[i]);
		brelse (bh);
		printk ("EXT2-fs: get root inode failed\n");
		return NULL;
	}
#ifdef EXT2FS_PRE_02B_COMPAT
	if (fs_converted) {
		for (i = 0; i < bh_count; i++)
			sb->u.ext2_sb.s_group_desc[i]->b_dirt = 1;
		sb->s_dirt = 1;
	}
#endif
	ext2_setup_super (sb, es);
	return sb;
}

static void ext2_commit_super (struct super_block * sb,
			       struct ext2_super_block * es)
{
	es->s_wtime = CURRENT_TIME;
	sb->u.ext2_sb.s_sbh->b_dirt = 1;
	sb->s_dirt = 0;
}

/*
 * In the second extended file system, it is not necessary to
 * write the super block since we use a mapping of the
 * disk super block in a buffer.
 *
 * However, this function is still used to set the fs valid
 * flags to 0.  We need to set this flag to 0 since the fs
 * may have been checked while mounted and e2fsck may have
 * set s_state to EXT2_VALID_FS after some corrections.
 */

void ext2_write_super (struct super_block * sb)
{
	struct ext2_super_block * es;

	if (!(sb->s_flags & MS_RDONLY)) {
		es = sb->u.ext2_sb.s_es;

		ext2_debug ("setting valid to 0\n");

		if (es->s_state & EXT2_VALID_FS) {
			es->s_state &= ~EXT2_VALID_FS;
			es->s_mtime = CURRENT_TIME;
		}
		ext2_commit_super (sb, es);
	}
	sb->s_dirt = 0;
}

int ext2_remount (struct super_block * sb, int * flags, char * data)
{
	struct ext2_super_block * es;
	unsigned long tmp;

	/*
	 * Allow the "check" option to be passed as a remount option.
	 */
	set_opt (sb->u.ext2_sb.s_mount_opt, CHECK_NORMAL);
	parse_options (data, &tmp, &sb->u.ext2_sb.s_mount_opt);

	es = sb->u.ext2_sb.s_es;
	if ((*flags & MS_RDONLY) == (sb->s_flags & MS_RDONLY))
		return 0;
	if (*flags & MS_RDONLY) {
		if (es->s_state & EXT2_VALID_FS ||
		    !(sb->u.ext2_sb.s_mount_state & EXT2_VALID_FS))
			return 0;
		/*
		 * OK, we are remounting a valid rw partition rdonly, so set
		 * the rdonly flag and then mark the partition as valid again.
		 */
		es->s_state = sb->u.ext2_sb.s_mount_state;
		es->s_mtime = CURRENT_TIME;
		sb->u.ext2_sb.s_sbh->b_dirt = 1;
		sb->s_dirt = 1;
		ext2_commit_super (sb, es);
	}
	else {
		/*
		 * Mounting a RDONLY partition read-write, so reread and
		 * store the current valid flag.  (It may have been changed 
		 * by e2fsck since we originally mounted the partition.)
		 */
		sb->u.ext2_sb.s_mount_state = es->s_state;
		sb->s_flags &= ~MS_RDONLY;
		ext2_setup_super (sb, es);
	}
	return 0;
}

void ext2_statfs (struct super_block * sb, struct statfs * buf)
{
	long tmp;

	put_fs_long (EXT2_SUPER_MAGIC, &buf->f_type);
	put_fs_long (sb->s_blocksize, &buf->f_bsize);
	put_fs_long (sb->u.ext2_sb.s_es->s_blocks_count, &buf->f_blocks);
	tmp = ext2_count_free_blocks (sb);
	put_fs_long (tmp, &buf->f_bfree);
	if (tmp >= sb->u.ext2_sb.s_es->s_r_blocks_count)
		put_fs_long (tmp - sb->u.ext2_sb.s_es->s_r_blocks_count,
			     &buf->f_bavail);
	else
		put_fs_long (0, &buf->f_bavail);
	put_fs_long (sb->u.ext2_sb.s_es->s_inodes_count, &buf->f_files);
	put_fs_long (ext2_count_free_inodes (sb), &buf->f_ffree);
	put_fs_long (EXT2_NAME_LEN, &buf->f_namelen);
	/* Don't know what value to put in buf->f_fsid */
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜欧美2019年伦理| 成人免费黄色大片| 成人av电影在线| 欧亚洲嫩模精品一区三区| 久久久九九九九| 亚洲va欧美va国产va天堂影院| 国产一区免费电影| 色999日韩国产欧美一区二区| 精品欧美一区二区三区精品久久| 一区二区理论电影在线观看| 国产风韵犹存在线视精品| 欧美日韩国产不卡| 国产精品久久免费看| 久热成人在线视频| 欧美一区二区三区男人的天堂| ...xxx性欧美| 国产精品91xxx| 精品久久久久一区二区国产| 午夜国产精品影院在线观看| 在线观看av一区二区| 亚洲日本在线a| 成人午夜视频福利| 国产欧美精品在线观看| 裸体健美xxxx欧美裸体表演| 欧美日韩一级视频| 亚洲成人久久影院| 欧美性受xxxx| 最新欧美精品一区二区三区| 国产精品久久午夜夜伦鲁鲁| 91一区二区三区在线播放| 日韩欧美资源站| 一级特黄大欧美久久久| 无码av免费一区二区三区试看| 精品综合免费视频观看| 国产精品久久久久久久久晋中 | 丁香另类激情小说| 久久先锋影音av鲁色资源网| 老色鬼精品视频在线观看播放| 91精品视频网| 日本aⅴ免费视频一区二区三区| 欧美日韩二区三区| 狠狠色2019综合网| 91麻豆免费看片| 亚洲高清不卡在线观看| 免费精品视频在线| 在线播放国产精品二区一二区四区| 亚洲高清三级视频| 欧美一区二区三区免费视频| 麻豆精品国产传媒mv男同| 久久综合网色—综合色88| 国产精品一二三| 亚洲你懂的在线视频| 欧美日韩中字一区| 免费人成黄页网站在线一区二区| 日韩精品一区二区在线观看| 黄色精品一二区| 国产精品欧美一区喷水| 日本高清不卡视频| 亚洲乱码国产乱码精品精可以看| 欧美另类一区二区三区| 久久超碰97人人做人人爱| 中文字幕不卡在线| 91麻豆精品一区二区三区| 在线亚洲高清视频| 欧美日韩中字一区| 色综合久久中文综合久久牛| 亚洲v中文字幕| 久久综合色8888| 91国偷自产一区二区使用方法| 一区二区三区四区国产精品| 宅男噜噜噜66一区二区66| 国产ts人妖一区二区| 亚洲小少妇裸体bbw| 欧美va亚洲va| 91麻豆免费观看| 国产一区二区三区精品视频| 一级女性全黄久久生活片免费| 欧美精品一区二区精品网| 91视频免费看| 蜜臀av一区二区三区| 亚洲人成在线观看一区二区| 欧美一区二区三区婷婷月色| 成人免费精品视频| 精品一区二区三区在线视频| 亚洲精品国产精华液| 精品黑人一区二区三区久久| 在线免费观看不卡av| 国产成人午夜高潮毛片| 亚洲bdsm女犯bdsm网站| 亚洲欧美中日韩| 欧美mv日韩mv国产网站| 国产精品久久久久aaaa| 欧美三区在线观看| 中文字幕一区二区三中文字幕| 92精品国产成人观看免费| 久久99国产精品免费网站| 亚洲中国最大av网站| 国产精品午夜久久| 久久在线免费观看| 91精品蜜臀在线一区尤物| 成年人网站91| 国产不卡一区视频| 国产在线播放一区二区三区| 琪琪久久久久日韩精品| 亚洲成人1区2区| 亚洲人成网站影音先锋播放| 久久久久国产精品免费免费搜索| 日韩欧美在线综合网| 91精品国产综合久久久久久漫画| 在线一区二区三区四区| 99久久精品免费看国产免费软件| 国产 欧美在线| 国产酒店精品激情| 国产裸体歌舞团一区二区| 久久福利资源站| 麻豆成人久久精品二区三区小说| 久久精品国产999大香线蕉| 久久久精品免费观看| 色悠悠亚洲一区二区| 97久久超碰精品国产| 97久久久精品综合88久久| 99久久精品免费看国产免费软件| 成人av在线影院| 一本色道a无线码一区v| 色综合久久六月婷婷中文字幕| 91蜜桃视频在线| 在线观看日韩高清av| 欧美日韩一级视频| 欧美一级夜夜爽| 精品精品国产高清一毛片一天堂| 精品久久久久久久久久久院品网| 欧美成人aa大片| 久久亚洲精华国产精华液 | 激情六月婷婷久久| 国产在线日韩欧美| 成人毛片老司机大片| 一本久道久久综合中文字幕| 在线看一区二区| 欧美成人精品福利| 国产三级一区二区| 亚洲v中文字幕| 蜜桃视频一区二区| 久久久久国色av免费看影院| 欧美日韩电影一区| 欧美一区二区三区精品| 久久久精品免费观看| 日韩美女精品在线| 日本视频免费一区| 国产在线精品一区二区三区不卡| 成人美女在线观看| 欧美性感一区二区三区| 日韩精品中文字幕在线一区| 国产精品少妇自拍| 婷婷夜色潮精品综合在线| 国产永久精品大片wwwapp| 日本高清成人免费播放| 欧美成人国产一区二区| 亚洲男女毛片无遮挡| 另类成人小视频在线| 99精品一区二区| 精品久久久久久无| 自拍偷自拍亚洲精品播放| 日韩国产一区二| 成人在线视频首页| 日韩一二三四区| 一区二区三区日韩精品视频| 激情都市一区二区| 蜜桃av一区二区在线观看| 在线观看日韩一区| 亚洲猫色日本管| 欧美私模裸体表演在线观看| 一区二区三区在线看| 日韩欧美国产系列| 色一区在线观看| 琪琪久久久久日韩精品| 国产视频视频一区| 欧美日韩国产精品成人| 国产黄色成人av| 日本伊人午夜精品| 亚洲美女视频在线| 不卡大黄网站免费看| 蜜臀va亚洲va欧美va天堂| 成人av免费在线播放| 在线成人高清不卡| 国产目拍亚洲精品99久久精品| 国产欧美精品国产国产专区| 青娱乐精品视频| 99久久99久久久精品齐齐| 欧美性生活一区| 成人免费视频免费观看| 成人白浆超碰人人人人| 91色婷婷久久久久合中文| 欧美在线视频不卡| 国产精品你懂的在线欣赏| 三级欧美韩日大片在线看| 国产一区二区三区国产| 欧美片网站yy| 夜夜嗨av一区二区三区中文字幕| 国产高清精品网站| 久久精品亚洲一区二区三区浴池|