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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? super.c

?? linux和2410結(jié)合開(kāi)發(fā) 用他可以生成2410所需的zImage文件
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/* *  linux/fs/ext2/super.c * * Copyright (C) 1992, 1993, 1994, 1995 * Remy Card (card@masi.ibp.fr) * Laboratoire MASI - Institut Blaise Pascal * Universite Pierre et Marie Curie (Paris VI) * *  from * *  linux/fs/minix/inode.c * *  Copyright (C) 1991, 1992  Linus Torvalds * *  Big-endian to little-endian byte-swapping/bitmaps by *        David S. Miller (davem@caip.rutgers.edu), 1995 */#include <linux/config.h>#include <linux/module.h>#include <linux/string.h>#include <linux/fs.h>#include <linux/ext2_fs.h>#include <linux/slab.h>#include <linux/init.h>#include <linux/locks.h>#include <linux/blkdev.h>#include <asm/uaccess.h>static void ext2_sync_super(struct super_block *sb,			    struct ext2_super_block *es);static char error_buf[1024];void ext2_error (struct super_block * sb, const char * function,		 const char * fmt, ...){	va_list args;	struct ext2_super_block *es = EXT2_SB(sb)->s_es;	if (!(sb->s_flags & MS_RDONLY)) {		sb->u.ext2_sb.s_mount_state |= EXT2_ERROR_FS;		es->s_state =			cpu_to_le16(le16_to_cpu(es->s_state) | EXT2_ERROR_FS);		ext2_sync_super(sb, es);	}	va_start (args, fmt);	vsprintf (error_buf, fmt, args);	va_end (args);	if (test_opt (sb, ERRORS_PANIC) ||	    (le16_to_cpu(sb->u.ext2_sb.s_es->s_errors) == EXT2_ERRORS_PANIC &&	     !test_opt (sb, ERRORS_CONT) && !test_opt (sb, ERRORS_RO)))		panic ("EXT2-fs panic (device %s): %s: %s\n",		       bdevname(sb->s_dev), function, error_buf);	printk (KERN_CRIT "EXT2-fs error (device %s): %s: %s\n",		bdevname(sb->s_dev), function, error_buf);	if (test_opt (sb, ERRORS_RO) ||	    (le16_to_cpu(sb->u.ext2_sb.s_es->s_errors) == EXT2_ERRORS_RO &&	     !test_opt (sb, ERRORS_CONT) && !test_opt (sb, ERRORS_PANIC))) {		printk ("Remounting filesystem read-only\n");		sb->s_flags |= MS_RDONLY;	}}NORET_TYPE void ext2_panic (struct super_block * sb, const char * function,			    const char * fmt, ...){	va_list args;	if (!(sb->s_flags & MS_RDONLY)) {		sb->u.ext2_sb.s_mount_state |= EXT2_ERROR_FS;		sb->u.ext2_sb.s_es->s_state =			cpu_to_le16(le16_to_cpu(sb->u.ext2_sb.s_es->s_state) | EXT2_ERROR_FS);		mark_buffer_dirty(sb->u.ext2_sb.s_sbh);		sb->s_dirt = 1;	}	va_start (args, fmt);	vsprintf (error_buf, fmt, args);	va_end (args);	sb->s_flags |= MS_RDONLY;	panic ("EXT2-fs panic (device %s): %s: %s\n",	       bdevname(sb->s_dev), function, error_buf);}void ext2_warning (struct super_block * sb, const char * function,		   const char * fmt, ...){	va_list args;	va_start (args, fmt);	vsprintf (error_buf, fmt, args);	va_end (args);	printk (KERN_WARNING "EXT2-fs warning (device %s): %s: %s\n",		bdevname(sb->s_dev), function, error_buf);}void ext2_update_dynamic_rev(struct super_block *sb){	struct ext2_super_block *es = EXT2_SB(sb)->s_es;	if (le32_to_cpu(es->s_rev_level) > EXT2_GOOD_OLD_REV)		return;	ext2_warning(sb, __FUNCTION__,		     "updating to rev %d because of new feature flag, "		     "running e2fsck is recommended",		     EXT2_DYNAMIC_REV);	es->s_first_ino = cpu_to_le32(EXT2_GOOD_OLD_FIRST_INO);	es->s_inode_size = cpu_to_le16(EXT2_GOOD_OLD_INODE_SIZE);	es->s_rev_level = cpu_to_le32(EXT2_DYNAMIC_REV);	/* leave es->s_feature_*compat flags alone */	/* es->s_uuid will be set by e2fsck if empty */	/*	 * The rest of the superblock fields should be zero, and if not it	 * means they are likely already in use, so leave them alone.  We	 * can leave it up to e2fsck to clean up any inconsistencies there.	 */}void ext2_put_super (struct super_block * sb){	int db_count;	int i;	if (!(sb->s_flags & MS_RDONLY)) {		struct ext2_super_block *es = EXT2_SB(sb)->s_es;		es->s_state = le16_to_cpu(EXT2_SB(sb)->s_mount_state);		ext2_sync_super(sb, es);	}	db_count = EXT2_SB(sb)->s_gdb_count;	for (i = 0; i < db_count; i++)		if (sb->u.ext2_sb.s_group_desc[i])			brelse (sb->u.ext2_sb.s_group_desc[i]);	kfree(sb->u.ext2_sb.s_group_desc);	for (i = 0; i < EXT2_MAX_GROUP_LOADED; i++)		if (sb->u.ext2_sb.s_inode_bitmap[i])			brelse (sb->u.ext2_sb.s_inode_bitmap[i]);	for (i = 0; i < EXT2_MAX_GROUP_LOADED; i++)		if (sb->u.ext2_sb.s_block_bitmap[i])			brelse (sb->u.ext2_sb.s_block_bitmap[i]);	brelse (sb->u.ext2_sb.s_sbh);	return;}static struct super_operations ext2_sops = {	read_inode:	ext2_read_inode,	write_inode:	ext2_write_inode,	put_inode:	ext2_put_inode,	delete_inode:	ext2_delete_inode,	put_super:	ext2_put_super,	write_super:	ext2_write_super,	statfs:		ext2_statfs,	remount_fs:	ext2_remount,};/* * This function has been shamelessly adapted from the msdos fs */static int parse_options (char * options, unsigned long * sb_block,			  unsigned short *resuid, unsigned short * resgid,			  unsigned long * mount_options){	char * this_char;	char * value;	if (!options)		return 1;	for (this_char = strtok (options, ",");	     this_char != NULL;	     this_char = strtok (NULL, ",")) {		if ((value = strchr (this_char, '=')) != NULL)			*value++ = 0;		if (!strcmp (this_char, "bsddf"))			clear_opt (*mount_options, MINIX_DF);		else if (!strcmp (this_char, "nouid32")) {			set_opt (*mount_options, NO_UID32);		}		else if (!strcmp (this_char, "check")) {			if (!value || !*value || !strcmp (value, "none"))				clear_opt (*mount_options, CHECK);			else#ifdef CONFIG_EXT2_CHECK				set_opt (*mount_options, CHECK);#else				printk("EXT2 Check option not supported\n");#endif		}		else if (!strcmp (this_char, "debug"))			set_opt (*mount_options, DEBUG);		else if (!strcmp (this_char, "errors")) {			if (!value || !*value) {				printk ("EXT2-fs: the errors option requires "					"an argument\n");				return 0;			}			if (!strcmp (value, "continue")) {				clear_opt (*mount_options, ERRORS_RO);				clear_opt (*mount_options, ERRORS_PANIC);				set_opt (*mount_options, ERRORS_CONT);			}			else if (!strcmp (value, "remount-ro")) {				clear_opt (*mount_options, ERRORS_CONT);				clear_opt (*mount_options, ERRORS_PANIC);				set_opt (*mount_options, ERRORS_RO);			}			else if (!strcmp (value, "panic")) {				clear_opt (*mount_options, ERRORS_CONT);				clear_opt (*mount_options, ERRORS_RO);				set_opt (*mount_options, ERRORS_PANIC);			}			else {				printk ("EXT2-fs: Invalid errors option: %s\n",					value);				return 0;			}		}		else if (!strcmp (this_char, "grpid") ||			 !strcmp (this_char, "bsdgroups"))			set_opt (*mount_options, GRPID);		else if (!strcmp (this_char, "minixdf"))			set_opt (*mount_options, MINIX_DF);		else if (!strcmp (this_char, "nocheck"))			clear_opt (*mount_options, CHECK);		else if (!strcmp (this_char, "nogrpid") ||			 !strcmp (this_char, "sysvgroups"))			clear_opt (*mount_options, GRPID);		else if (!strcmp (this_char, "resgid")) {			if (!value || !*value) {				printk ("EXT2-fs: the resgid option requires "					"an argument\n");				return 0;			}			*resgid = simple_strtoul (value, &value, 0);			if (*value) {				printk ("EXT2-fs: Invalid resgid option: %s\n",					value);				return 0;			}		}		else if (!strcmp (this_char, "resuid")) {			if (!value || !*value) {				printk ("EXT2-fs: the resuid option requires "					"an argument");				return 0;			}			*resuid = simple_strtoul (value, &value, 0);			if (*value) {				printk ("EXT2-fs: Invalid resuid option: %s\n",					value);				return 0;			}		}		else if (!strcmp (this_char, "sb")) {			if (!value || !*value) {				printk ("EXT2-fs: the sb option requires "					"an argument");				return 0;			}			*sb_block = simple_strtoul (value, &value, 0);			if (*value) {				printk ("EXT2-fs: Invalid sb option: %s\n",					value);				return 0;			}		}		/* Silently ignore the quota options */		else if (!strcmp (this_char, "grpquota")		         || !strcmp (this_char, "noquota")		         || !strcmp (this_char, "quota")		         || !strcmp (this_char, "usrquota"))			/* Don't do anything ;-) */ ;		else {			printk ("EXT2-fs: Unrecognized mount option %s\n", this_char);			return 0;		}	}	return 1;}static int ext2_setup_super (struct super_block * sb,			      struct ext2_super_block * es,			      int read_only){	int res = 0;	if (le32_to_cpu(es->s_rev_level) > EXT2_MAX_SUPP_REV) {		printk ("EXT2-fs warning: revision level too high, "			"forcing read-only mode\n");		res = MS_RDONLY;	}	if (read_only)		return res;	if (!(sb->u.ext2_sb.s_mount_state & EXT2_VALID_FS))		printk ("EXT2-fs warning: mounting unchecked fs, "			"running e2fsck is recommended\n");	else if ((sb->u.ext2_sb.s_mount_state & EXT2_ERROR_FS))		printk ("EXT2-fs warning: mounting fs with errors, "			"running e2fsck is recommended\n");	else if ((__s16) le16_to_cpu(es->s_max_mnt_count) >= 0 &&		 le16_to_cpu(es->s_mnt_count) >=		 (unsigned short) (__s16) le16_to_cpu(es->s_max_mnt_count))		printk ("EXT2-fs warning: maximal mount count reached, "			"running e2fsck is recommended\n");	else if (le32_to_cpu(es->s_checkinterval) &&		(le32_to_cpu(es->s_lastcheck) + le32_to_cpu(es->s_checkinterval) <= CURRENT_TIME))		printk ("EXT2-fs warning: checktime reached, "			"running e2fsck is recommended\n");	if (!(__s16) le16_to_cpu(es->s_max_mnt_count))		es->s_max_mnt_count = (__s16) cpu_to_le16(EXT2_DFL_MAX_MNT_COUNT);	es->s_mnt_count=cpu_to_le16(le16_to_cpu(es->s_mnt_count) + 1);	ext2_write_super(sb);	if (test_opt (sb, DEBUG))		printk ("[EXT II FS %s, %s, bs=%lu, fs=%lu, gc=%lu, "			"bpg=%lu, ipg=%lu, mo=%04lx]\n",			EXT2FS_VERSION, EXT2FS_DATE, sb->s_blocksize,			sb->u.ext2_sb.s_frag_size,			sb->u.ext2_sb.s_groups_count,			EXT2_BLOCKS_PER_GROUP(sb),			EXT2_INODES_PER_GROUP(sb),			sb->u.ext2_sb.s_mount_opt);#ifdef CONFIG_EXT2_CHECK	if (test_opt (sb, CHECK)) {		ext2_check_blocks_bitmap (sb);		ext2_check_inodes_bitmap (sb);	}#endif	return res;}static int ext2_check_descriptors (struct super_block * sb){	int i;	int desc_block = 0;	unsigned long block = le32_to_cpu(sb->u.ext2_sb.s_es->s_first_data_block);	struct ext2_group_desc * gdp = NULL;	ext2_debug ("Checking group descriptors");	for (i = 0; i < sb->u.ext2_sb.s_groups_count; i++)	{		if ((i % EXT2_DESC_PER_BLOCK(sb)) == 0)			gdp = (struct ext2_group_desc *) sb->u.ext2_sb.s_group_desc[desc_block++]->b_data;		if (le32_to_cpu(gdp->bg_block_bitmap) < block ||		    le32_to_cpu(gdp->bg_block_bitmap) >= block + EXT2_BLOCKS_PER_GROUP(sb))		{			ext2_error (sb, "ext2_check_descriptors",				    "Block bitmap for group %d"				    " not in group (block %lu)!",				    i, (unsigned long) le32_to_cpu(gdp->bg_block_bitmap));			return 0;		}		if (le32_to_cpu(gdp->bg_inode_bitmap) < block ||		    le32_to_cpu(gdp->bg_inode_bitmap) >= block + EXT2_BLOCKS_PER_GROUP(sb))		{			ext2_error (sb, "ext2_check_descriptors",				    "Inode bitmap for group %d"				    " not in group (block %lu)!",				    i, (unsigned long) le32_to_cpu(gdp->bg_inode_bitmap));			return 0;		}		if (le32_to_cpu(gdp->bg_inode_table) < block ||		    le32_to_cpu(gdp->bg_inode_table) + sb->u.ext2_sb.s_itb_per_group >=		    block + EXT2_BLOCKS_PER_GROUP(sb))		{			ext2_error (sb, "ext2_check_descriptors",				    "Inode table for group %d"				    " not in group (block %lu)!",				    i, (unsigned long) le32_to_cpu(gdp->bg_inode_table));			return 0;		}		block += EXT2_BLOCKS_PER_GROUP(sb);		gdp++;	}	return 1;}#define log2(n) ffz(~(n)) /* * Maximal file size.  There is a direct, and {,double-,triple-}indirect * block limit, and also a limit of (2^32 - 1) 512-byte sectors in i_blocks. * We need to be 1 filesystem block less than the 2^32 sector limit. */static loff_t ext2_max_size(int bits){	loff_t res = EXT2_NDIR_BLOCKS;	res += 1LL << (bits-2);	res += 1LL << (2*(bits-2));	res += 1LL << (3*(bits-2));	res <<= bits;	if (res > (512LL << 32) - (1 << bits))		res = (512LL << 32) - (1 << bits);	return res;}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 short resuid = EXT2_DEF_RESUID;	unsigned short resgid = EXT2_DEF_RESGID;	unsigned long logic_sb_block = 1;	unsigned long offset = 0;	kdev_t dev = sb->s_dev;	int blocksize = BLOCK_SIZE;	int db_count;	int i, j;

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91麻豆精品久久久久蜜臀 | 中文字幕在线不卡一区二区三区| 日韩中文字幕区一区有砖一区| 欧美午夜免费电影| 亚洲成人免费影院| 日韩欧美高清在线| 国产成人精品免费看| 亚洲欧洲日产国码二区| 色先锋资源久久综合| 亚洲成人福利片| 日韩欧美第一区| 国产福利精品导航| 亚洲黄网站在线观看| 91麻豆精品国产自产在线观看一区| 秋霞电影一区二区| 国产精品久久午夜夜伦鲁鲁| 色婷婷狠狠综合| 另类小说图片综合网| 日本一区二区三区在线观看| 欧美日韩一区中文字幕| 狠狠色狠狠色综合| 自拍偷拍国产精品| 91精品国产高清一区二区三区蜜臀| 精品一区二区免费视频| 亚洲精品日韩综合观看成人91| 91精品国产91综合久久蜜臀| 国产成人免费视| 日韩成人一级大片| 国产精品理伦片| 日韩欧美国产高清| 色综合婷婷久久| 精品在线免费观看| 一区二区三区在线免费观看| 久久精品在线观看| 7878成人国产在线观看| 成人av综合在线| 毛片一区二区三区| 亚洲欧美另类在线| 久久人人爽爽爽人久久久| 91精彩视频在线观看| 国产一区二区三区高清播放| 亚洲成av人片www| 亚洲色图19p| 欧美韩国日本综合| 欧美精品 日韩| 一本一本大道香蕉久在线精品| 国产一区免费电影| 日本女人一区二区三区| 一区二区三区在线免费| 国产午夜精品福利| 日韩精品中午字幕| 欧美三区在线视频| 99久久精品免费看| 国产成人免费高清| 日韩国产欧美在线播放| 亚洲九九爱视频| 国产精品二区一区二区aⅴ污介绍| 日韩写真欧美这视频| 欧美视频一区二区三区四区| 一本一道久久a久久精品| 成人高清免费在线播放| 国产一区二区在线看| 青娱乐精品在线视频| 天天射综合影视| 亚洲国产aⅴ成人精品无吗| 亚洲欧美日韩成人高清在线一区| 国产精品不卡在线| 国产亚洲精品资源在线26u| 日韩一级黄色大片| 欧美肥大bbwbbw高潮| 在线观看免费亚洲| 91福利社在线观看| 色国产精品一区在线观看| 91在线观看美女| 成人精品免费网站| 99久久久免费精品国产一区二区| 成人午夜视频免费看| 成人午夜看片网址| 成人黄色一级视频| 成人黄色一级视频| 91一区二区三区在线播放| 91视频免费看| 欧美丝袜自拍制服另类| 在线观看三级视频欧美| 欧美美女网站色| 精品福利一区二区三区免费视频| 欧美大度的电影原声| 久久精品视频免费| 国产精品美女久久久久av爽李琼| 亚洲四区在线观看| 夜夜嗨av一区二区三区中文字幕| 亚洲制服丝袜av| 日韩专区欧美专区| 国产麻豆欧美日韩一区| av一二三不卡影片| 日本道色综合久久| 日韩三级中文字幕| 欧美精品一区二区三区一线天视频| 久久婷婷色综合| 国产精品人人做人人爽人人添| 亚洲精品国产视频| 麻豆精品在线视频| 粉嫩aⅴ一区二区三区四区| 在线观看免费亚洲| 欧美成人精精品一区二区频| 中文久久乱码一区二区| 亚洲一区av在线| 国内不卡的二区三区中文字幕 | 成人app网站| 欧美日韩高清影院| 久久精品视频免费观看| 一区二区三区色| 韩国v欧美v日本v亚洲v| 91福利在线看| 精品国产伦一区二区三区观看方式| 国产精品污污网站在线观看| 亚洲高清不卡在线| 国产一区二区免费看| 91国产丝袜在线播放| 欧美成人一级视频| 亚洲乱码中文字幕综合| 精品无人区卡一卡二卡三乱码免费卡 | 日韩美女在线视频| 亚洲三级理论片| 国产美女久久久久| 欧美精品乱码久久久久久按摩| 国产精品久久三区| 精品一区精品二区高清| 欧美主播一区二区三区美女| 久久亚洲精品小早川怜子| 亚洲一区二区三区爽爽爽爽爽| 国产在线播精品第三| 欧美美女视频在线观看| 日韩毛片一二三区| 韩国毛片一区二区三区| 欧美三级资源在线| 成人欧美一区二区三区视频网页| 九九国产精品视频| 欧美片在线播放| 亚洲精品大片www| 成人激情免费视频| 久久久不卡影院| 久久99精品久久久| 欧美日韩免费电影| 亚洲美女屁股眼交| 春色校园综合激情亚洲| 久久精品视频在线看| 久久精品国内一区二区三区| 欧美日韩在线观看一区二区 | 在线观看亚洲专区| 自拍偷拍亚洲激情| av一区二区久久| 国产精品国产精品国产专区不片| 国产福利一区二区三区视频在线| 日韩精品在线一区二区| 免费在线视频一区| 6080日韩午夜伦伦午夜伦| 亚洲高清免费观看 | 国产精品国产自产拍高清av | 日本欧美一区二区| 欧美一区二区视频免费观看| 日韩中文字幕1| 欧美精品成人一区二区三区四区| 亚洲成av人影院| 欧美精品丝袜中出| 日日摸夜夜添夜夜添国产精品| 欧美四级电影网| 午夜精品爽啪视频| 欧美一区二区视频在线观看2020| 青青草国产成人99久久| 日韩精品一区二区三区四区| 美女看a上一区| 精品国产一区二区三区久久影院| 天天射综合影视| 日韩精品中文字幕一区二区三区 | 偷窥少妇高潮呻吟av久久免费| 欧美私人免费视频| 日韩国产欧美三级| 精品久久久久香蕉网| 国产剧情一区二区| 国产精品久久毛片| 日本韩国欧美三级| 亚洲国产欧美一区二区三区丁香婷| 欧美怡红院视频| 日韩电影在线免费观看| 精品国产3级a| 99久久精品情趣| 午夜影院在线观看欧美| 日韩免费高清视频| 不卡免费追剧大全电视剧网站| 亚洲日本青草视频在线怡红院| 91福利社在线观看| 久久国产婷婷国产香蕉| 日本一区二区三区久久久久久久久不| av中文字幕亚洲| 图片区小说区区亚洲影院| 久久久久久久久岛国免费| a4yy欧美一区二区三区| 水野朝阳av一区二区三区| 久久久久久9999|