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

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

?? super.c

?? 嵌入式系統(tǒng)設(shè)計與實例開發(fā)源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* *  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;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区不卡在线| 日韩专区中文字幕一区二区| 97se狠狠狠综合亚洲狠狠| 亚洲视频你懂的| 91精品国产手机| 韩国v欧美v日本v亚洲v| 久久综合色综合88| fc2成人免费人成在线观看播放 | 欧美一区二区在线免费观看| 亚洲成人av在线电影| 91精品国产高清一区二区三区蜜臀| 国产美女精品一区二区三区| 亚洲日本在线看| 欧美一区二区成人| 不卡电影一区二区三区| 午夜精品久久久久久久久久久 | 国产一区二区三区免费在线观看| 久久精品一区蜜桃臀影院| 91亚洲永久精品| 看电视剧不卡顿的网站| 国产精品免费观看视频| 欧美精品在线一区二区| 国内久久精品视频| 一区二区三区精密机械公司| 久久精品视频在线免费观看 | 99re在线视频这里只有精品| 美女视频黄频大全不卡视频在线播放| 亚洲色图视频网| 国产欧美一区二区三区鸳鸯浴 | 9191成人精品久久| 成人妖精视频yjsp地址| 久久精品免费观看| 亚洲一区二区免费视频| 国产精品毛片久久久久久久| 国产肉丝袜一区二区| 日韩写真欧美这视频| 日韩亚洲欧美高清| 欧美精选一区二区| 成人av资源站| 99精品久久只有精品| 国产精品亚洲人在线观看| 精品一区二区在线视频| 婷婷久久综合九色国产成人 | 秋霞电影网一区二区| 一区二区三区蜜桃网| 一片黄亚洲嫩模| 亚洲欧美另类小说视频| 国产欧美日韩视频一区二区| 久久久久久久久久久黄色| 精品免费一区二区三区| 日韩视频免费观看高清在线视频| 欧美精品久久99| 欧美一区二区免费观在线| 欧美精品一二三四| 色综合色综合色综合| 欧美日韩一二区| 欧美三级电影在线观看| 欧美一区二区久久| 91 com成人网| 337p粉嫩大胆色噜噜噜噜亚洲| 欧美一区二区三区思思人| 欧美疯狂做受xxxx富婆| 精品理论电影在线| 日韩欧美黄色影院| 精品久久久久久久久久久久久久久 | 黑人巨大精品欧美一区| 免费成人性网站| 日本不卡123| 久久国产精品第一页| 国产大陆亚洲精品国产| 高清不卡一二三区| 日本高清免费不卡视频| 色乱码一区二区三区88| 69久久夜色精品国产69蝌蚪网| 欧美视频一区在线| 欧美日韩黄色影视| 欧美一二三区在线观看| www国产精品av| 亚洲欧美日韩在线播放| 亚洲成人一二三| 一个色妞综合视频在线观看| 精品一区二区三区免费视频| 国产成人免费在线观看不卡| 欧美优质美女网站| 欧美在线啊v一区| 久久久久亚洲蜜桃| 国产精品伦一区| 国产一区91精品张津瑜| 97久久久精品综合88久久| 欧美专区日韩专区| 久久综合av免费| 1024成人网色www| 日韩二区三区在线观看| 国产精品一线二线三线| 色欧美乱欧美15图片| 日韩精品在线网站| 国产欧美一区二区三区网站 | 色综合久久久久久久久| 欧美大胆人体bbbb| 国产欧美日韩三区| 日本午夜精品一区二区三区电影| 国产一区二区三区不卡在线观看| 欧美日韩精品二区第二页| 久久综合国产精品| 中文字幕av不卡| 美女视频黄免费的久久 | 日本不卡在线视频| 成人aa视频在线观看| 91精品国模一区二区三区| 亚洲人一二三区| 日本不卡一二三区黄网| 91成人免费在线视频| 久久亚洲综合色一区二区三区| 精品国产乱码久久久久久免费| 亚洲一区二区精品久久av| 国产电影一区在线| 日韩女优视频免费观看| 亚洲黄色免费电影| 成人精品高清在线| 日韩欧美一级二级三级久久久| 亚洲一区二区三区四区的| 国产成人免费av在线| 欧美日韩在线免费视频| 一区二区三区资源| 国产成人精品亚洲日本在线桃色| 欧美刺激午夜性久久久久久久| 亚洲中国最大av网站| 97久久久精品综合88久久| 久久久亚洲综合| 免费一级片91| 欧美精品丝袜中出| 国产精品久久看| 成人精品一区二区三区四区| 久久免费电影网| 国产一区二区三区精品视频| 亚洲欧美日本韩国| 成人丝袜高跟foot| 26uuu国产日韩综合| 久久99久久99| 欧美日韩另类国产亚洲欧美一级| 伊人色综合久久天天| 成人a免费在线看| 久久久久久久久久美女| 国产91综合一区在线观看| 日韩网站在线看片你懂的| 美日韩一级片在线观看| 56国语精品自产拍在线观看| 蜜桃av噜噜一区| 欧美一区二区黄| 久久精工是国产品牌吗| 欧美一区二区三区小说| 亚洲大片一区二区三区| 欧美影视一区在线| 亚洲精品免费在线观看| 日本道免费精品一区二区三区| 亚洲欧洲成人精品av97| 91精品办公室少妇高潮对白| 亚洲欧美国产高清| 日本韩国一区二区三区| 亚洲自拍欧美精品| 7777精品伊人久久久大香线蕉的 | 成人免费在线观看入口| 色综合久久久久| 亚洲自拍偷拍av| 欧美二区三区的天堂| 一区二区三区四区视频精品免费| 丰满岳乱妇一区二区三区| 亚洲欧洲成人av每日更新| 91视频免费看| 午夜精品久久久久| 欧美日韩国产精品自在自线| 国模一区二区三区白浆| 国产日本欧美一区二区| 色偷偷88欧美精品久久久| 一区二区三区日韩精品视频| 欧美一区二区视频在线观看2022| 韩国女主播一区| 日韩欧美国产电影| 成人黄色777网| 亚洲黄色小说网站| 精品少妇一区二区三区在线视频| 国产麻豆91精品| 亚洲国产日韩精品| 日韩欧美国产综合在线一区二区三区| 国产精品一区二区久久不卡| 亚洲天堂中文字幕| 91精品国产欧美一区二区成人| 激情五月婷婷综合| 亚洲四区在线观看| 91精品国产乱| 成人教育av在线| 丝袜美腿亚洲色图| 中文字幕成人av| 欧美日韩另类一区| 肉肉av福利一精品导航| 国产精品福利一区二区三区| 欧美视频第二页| 波多野结衣的一区二区三区| 亚洲v精品v日韩v欧美v专区| 最新日韩av在线|