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

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

?? super.c

?? 《嵌入式系統設計與實例開發實驗教材二源碼》Linux內核移植與編譯實驗
?? C
?? 第 1 頁 / 共 4 頁
字號:
/* * super.c * * PURPOSE *  Super block routines for the OSTA-UDF(tm) filesystem. * * DESCRIPTION *  OSTA-UDF(tm) = Optical Storage Technology Association *  Universal Disk Format. * *  This code is based on version 2.00 of the UDF specification, *  and revision 3 of the ECMA 167 standard [equivalent to ISO 13346]. *    http://www.osta.org/ *    http://www.ecma.ch/ *    http://www.iso.org/ * * CONTACTS *  E-mail regarding any portion of the Linux UDF file system should be *  directed to the development team mailing list (run by majordomo): *	  linux_udf@hpesjro.fc.hp.com * * COPYRIGHT *  This file is distributed under the terms of the GNU General Public *  License (GPL). Copies of the GPL can be obtained from: *    ftp://prep.ai.mit.edu/pub/gnu/GPL *  Each contributing author retains all rights to their own work. * *  (C) 1998 Dave Boynton *  (C) 1998-2000 Ben Fennema *  (C) 2000 Stelias Computing Inc * * HISTORY * *  09/24/98 dgb  changed to allow compiling outside of kernel, and *                added some debugging. *  10/01/98 dgb  updated to allow (some) possibility of compiling w/2.0.34 *  10/16/98      attempting some multi-session support *  10/17/98      added freespace count for "df" *  11/11/98 gr   added novrs option *  11/26/98 dgb  added fileset,anchor mount options *  12/06/98 blf  really hosed things royally. vat/sparing support. sequenced vol descs *                rewrote option handling based on isofs *  12/20/98      find the free space bitmap (if it exists) */#include "udfdecl.h"    #include <linux/config.h>#include <linux/version.h>#include <linux/blkdev.h>#include <linux/slab.h>#include <linux/kernel.h>#include <linux/locks.h>#include <linux/module.h>#include <linux/stat.h>#include <linux/cdrom.h>#include <linux/nls.h>#include <asm/byteorder.h>#include <linux/udf_fs.h>#include "udf_sb.h"#include "udf_i.h"#include <linux/init.h>#include <asm/uaccess.h>#define VDS_POS_PRIMARY_VOL_DESC	0#define VDS_POS_UNALLOC_SPACE_DESC	1#define VDS_POS_LOGICAL_VOL_DESC	2#define VDS_POS_PARTITION_DESC		3#define VDS_POS_IMP_USE_VOL_DESC	4#define VDS_POS_VOL_DESC_PTR		5#define VDS_POS_TERMINATING_DESC	6#define VDS_POS_LENGTH			7static char error_buf[1024];/* These are the "meat" - everything else is stuffing */static struct super_block *udf_read_super(struct super_block *, void *, int);static void udf_put_super(struct super_block *);static void udf_write_super(struct super_block *);static int udf_remount_fs(struct super_block *, int *, char *);static int udf_check_valid(struct super_block *, int, int);static int udf_vrs(struct super_block *sb, int silent);static int udf_load_partition(struct super_block *, lb_addr *);static int udf_load_logicalvol(struct super_block *, struct buffer_head *, lb_addr *);static void udf_load_logicalvolint(struct super_block *, extent_ad);static void udf_find_anchor(struct super_block *);static int udf_find_fileset(struct super_block *, lb_addr *, lb_addr *);static void udf_load_pvoldesc(struct super_block *, struct buffer_head *);static void udf_load_fileset(struct super_block *, struct buffer_head *, lb_addr *);static void udf_load_partdesc(struct super_block *, struct buffer_head *);static void udf_open_lvid(struct super_block *);static void udf_close_lvid(struct super_block *);static unsigned int udf_count_free(struct super_block *);static int udf_statfs(struct super_block *, struct statfs *);/* UDF filesystem type */static DECLARE_FSTYPE_DEV(udf_fstype, "udf", udf_read_super);/* Superblock operations */static struct super_operations udf_sb_ops = {	read_inode:		udf_read_inode,	write_inode:		udf_write_inode,	put_inode:		udf_put_inode,	delete_inode:		udf_delete_inode,	put_super:		udf_put_super,	write_super:		udf_write_super,	statfs:			udf_statfs,	remount_fs:		udf_remount_fs,};struct udf_options{	unsigned char novrs;	unsigned int blocksize;	unsigned int session;	unsigned int lastblock;	unsigned int anchor;	unsigned int volume;	unsigned short partition;	unsigned int fileset;	unsigned int rootdir;	unsigned int flags;	mode_t umask;	gid_t gid;	uid_t uid;	struct nls_table *nls_map;};static int __init init_udf_fs(void){	printk(KERN_NOTICE "udf: registering filesystem\n");	return register_filesystem(&udf_fstype);}static void __exit exit_udf_fs(void){	printk(KERN_NOTICE "udf: unregistering filesystem\n");	unregister_filesystem(&udf_fstype);}EXPORT_NO_SYMBOLS;module_init(init_udf_fs)module_exit(exit_udf_fs)/* * udf_parse_options * * PURPOSE *	Parse mount options. * * DESCRIPTION *	The following mount options are supported: * *	gid=		Set the default group. *	umask=		Set the default umask. *	uid=		Set the default user. *	bs=			Set the block size. *	unhide		Show otherwise hidden files. *	undelete	Show deleted files in lists. *	adinicb		Embed data in the inode (default) *	noadinicb	Don't embed data in the inode *	shortad		Use short ad's *	longad		Use long ad's (default) *	nostrict	Unset strict conformance *	iocharset=	Set the NLS character set * *	The remaining are for debugging and disaster recovery: * *	novrs		Skip volume sequence recognition  * *	The following expect a offset from 0. * *	session=	Set the CDROM session (default= last session) *	anchor=		Override standard anchor location. (default= 256) *	volume=		Override the VolumeDesc location. (unused) *	partition=	Override the PartitionDesc location. (unused) *	lastblock=	Set the last block of the filesystem/ * *	The following expect a offset from the partition root. * *	fileset=	Override the fileset block location. (unused) *	rootdir=	Override the root directory location. (unused) *		WARNING: overriding the rootdir to a non-directory may *		yield highly unpredictable results. * * PRE-CONDITIONS *	options		Pointer to mount options string. *	uopts		Pointer to mount options variable. * * POST-CONDITIONS *	<return>	0	Mount options parsed okay. *	<return>	-1	Error parsing mount options. * * HISTORY *	July 1, 1997 - Andrew E. Mileski *	Written, tested, and released. */static intudf_parse_options(char *options, struct udf_options *uopt){	char *opt, *val;	uopt->novrs = 0;	uopt->blocksize = 2048;	uopt->partition = 0xFFFF;	uopt->session = 0xFFFFFFFF;	uopt->lastblock = 0;	uopt->anchor = 0;	uopt->volume = 0xFFFFFFFF;	uopt->rootdir = 0xFFFFFFFF;	uopt->fileset = 0xFFFFFFFF;	uopt->nls_map = NULL;	if (!options)		return 1;	for (opt = strtok(options, ","); opt; opt = strtok(NULL, ","))	{		/* Make "opt=val" into two strings */		val = strchr(opt, '=');		if (val)			*(val++) = 0;		if (!strcmp(opt, "novrs") && !val)			uopt->novrs = 1;		else if (!strcmp(opt, "bs") && val)			uopt->blocksize = simple_strtoul(val, NULL, 0);		else if (!strcmp(opt, "unhide") && !val)			uopt->flags |= (1 << UDF_FLAG_UNHIDE);		else if (!strcmp(opt, "undelete") && !val)			uopt->flags |= (1 << UDF_FLAG_UNDELETE);		else if (!strcmp(opt, "noadinicb") && !val)			uopt->flags &= ~(1 << UDF_FLAG_USE_AD_IN_ICB);		else if (!strcmp(opt, "adinicb") && !val)			uopt->flags |= (1 << UDF_FLAG_USE_AD_IN_ICB);		else if (!strcmp(opt, "shortad") && !val)			uopt->flags |= (1 << UDF_FLAG_USE_SHORT_AD);		else if (!strcmp(opt, "longad") && !val)			uopt->flags &= ~(1 << UDF_FLAG_USE_SHORT_AD);		else if (!strcmp(opt, "gid") && val)			uopt->gid = simple_strtoul(val, NULL, 0);		else if (!strcmp(opt, "umask") && val)			uopt->umask = simple_strtoul(val, NULL, 0);		else if (!strcmp(opt, "nostrict") && !val)			uopt->flags &= ~(1 << UDF_FLAG_STRICT);		else if (!strcmp(opt, "uid") && val)			uopt->uid = simple_strtoul(val, NULL, 0);		else if (!strcmp(opt, "session") && val)			uopt->session = simple_strtoul(val, NULL, 0);		else if (!strcmp(opt, "lastblock") && val)			uopt->lastblock = simple_strtoul(val, NULL, 0);		else if (!strcmp(opt, "anchor") && val)			uopt->anchor = simple_strtoul(val, NULL, 0);		else if (!strcmp(opt, "volume") && val)			uopt->volume = simple_strtoul(val, NULL, 0);		else if (!strcmp(opt, "partition") && val)			uopt->partition = simple_strtoul(val, NULL, 0);		else if (!strcmp(opt, "fileset") && val)			uopt->fileset = simple_strtoul(val, NULL, 0);		else if (!strcmp(opt, "rootdir") && val)			uopt->rootdir = simple_strtoul(val, NULL, 0);#ifdef CONFIG_NLS		else if (!strcmp(opt, "iocharset") && val)		{			uopt->nls_map = load_nls(val);			uopt->flags |= (1 << UDF_FLAG_NLS_MAP);		}#endif		else if (!strcmp(opt, "utf8") && !val)			uopt->flags |= (1 << UDF_FLAG_UTF8);		else if (val)		{			printk(KERN_ERR "udf: bad mount option \"%s=%s\"\n",				opt, val);			return 0;		}		else		{			printk(KERN_ERR "udf: bad mount option \"%s\"\n",				opt);			return 0;		}	}	return 1;}voidudf_write_super(struct super_block *sb){	if (!(sb->s_flags & MS_RDONLY))		udf_open_lvid(sb);	sb->s_dirt = 0;}static intudf_remount_fs(struct super_block *sb, int *flags, char *options){	struct udf_options uopt;	uopt.flags = UDF_SB(sb)->s_flags ;	uopt.uid   = UDF_SB(sb)->s_uid ;	uopt.gid   = UDF_SB(sb)->s_gid ;	uopt.umask = UDF_SB(sb)->s_umask ;	if ( !udf_parse_options(options, &uopt) )		return -EINVAL;	UDF_SB(sb)->s_flags = uopt.flags;	UDF_SB(sb)->s_uid   = uopt.uid;	UDF_SB(sb)->s_gid   = uopt.gid;	UDF_SB(sb)->s_umask = uopt.umask;#if UDFFS_RW != 1	*flags |= MS_RDONLY;#endif	if ((*flags & MS_RDONLY) == (sb->s_flags & MS_RDONLY))		return 0;	if (*flags & MS_RDONLY)		udf_close_lvid(sb);	else		udf_open_lvid(sb);	return 0;}/* * udf_set_blocksize * * PURPOSE *	Set the block size to be used in all transfers. * * DESCRIPTION *	To allow room for a DMA transfer, it is best to guess big when unsure. *	This routine picks 2048 bytes as the blocksize when guessing. This *	should be adequate until devices with larger block sizes become common. * *	Note that the Linux kernel can currently only deal with blocksizes of *	512, 1024, 2048, 4096, and 8192 bytes. * * PRE-CONDITIONS *	sb			Pointer to _locked_ superblock. * * POST-CONDITIONS *	sb->s_blocksize		Blocksize. *	sb->s_blocksize_bits	log2 of blocksize. *	<return>	0	Blocksize is valid. *	<return>	1	Blocksize is invalid. * * HISTORY *	July 1, 1997 - Andrew E. Mileski *	Written, tested, and released. */static  intudf_set_blocksize(struct super_block *sb, int bsize){	/* Use specified block size if specified */	if (bsize)		sb->s_blocksize = bsize;	if (get_hardsect_size(sb->s_dev) > sb->s_blocksize)		sb->s_blocksize = get_hardsect_size(sb->s_dev); 	/* Block size must be an even multiple of 512 */	switch (sb->s_blocksize)	{		case 512: sb->s_blocksize_bits = 9;	break;		case 1024: sb->s_blocksize_bits = 10; break;		case 2048: sb->s_blocksize_bits = 11; break;		case 4096: sb->s_blocksize_bits = 12; break;		case 8192: sb->s_blocksize_bits = 13; break;		default:		{			udf_debug("Bad block size (%ld)\n", sb->s_blocksize);			printk(KERN_ERR "udf: bad block size (%ld)\n", sb->s_blocksize);			return 0;		}	}	/* Set the block size */	set_blocksize(sb->s_dev, sb->s_blocksize);	return sb->s_blocksize;}static intudf_vrs(struct super_block *sb, int silent){	struct VolStructDesc *vsd = NULL;	int sector = 32768;	int sectorsize;	struct buffer_head *bh = NULL;	int iso9660=0;	int nsr02=0;	int nsr03=0;	/* Block size must be a multiple of 512 */	if (sb->s_blocksize & 511)		return 0;	if (sb->s_blocksize < sizeof(struct VolStructDesc))		sectorsize = sizeof(struct VolStructDesc);	else		sectorsize = sb->s_blocksize;	sector += (UDF_SB_SESSION(sb) << sb->s_blocksize_bits);	udf_debug("Starting at sector %u (%ld byte sectors)\n",		(sector >> sb->s_blocksize_bits), sb->s_blocksize);	/* Process the sequence (if applicable) */	for (;!nsr02 && !nsr03; sector += sectorsize)	{		/* Read a block */		bh = udf_tread(sb, sector >> sb->s_blocksize_bits);		if (!bh)			break;		/* Look for ISO  descriptors */		vsd = (struct VolStructDesc *)(bh->b_data +			(sector & (sb->s_blocksize - 1)));		if (vsd->stdIdent[0] == 0)		{			udf_release_data(bh);			break;		}		else if (!strncmp(vsd->stdIdent, STD_ID_CD001, STD_ID_LEN))		{			iso9660 = sector;			switch (vsd->structType)			{				case 0: 					udf_debug("ISO9660 Boot Record found\n");					break;				case 1: 					udf_debug("ISO9660 Primary Volume Descriptor found\n");					break;				case 2: 					udf_debug("ISO9660 Supplementary Volume Descriptor found\n");					break;				case 3: 					udf_debug("ISO9660 Volume Partition Descriptor found\n");					break;				case 255: 					udf_debug("ISO9660 Volume Descriptor Set Terminator found\n");					break;				default: 					udf_debug("ISO9660 VRS (%u) found\n", vsd->structType);					break;			}		}		else if (!strncmp(vsd->stdIdent, STD_ID_BEA01, STD_ID_LEN))

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91日韩精品一区| 日本午夜精品一区二区三区电影| www国产成人| 欧美大胆一级视频| 精品国产精品网麻豆系列| 日韩一级大片在线观看| 日韩亚洲欧美在线| 欧美精品一区男女天堂| 久久亚洲影视婷婷| 国产精品高清亚洲| 亚洲精品久久久蜜桃| 亚洲午夜激情网页| 麻豆精品一二三| 国产成人av福利| 91在线国内视频| 精品视频1区2区| 日韩你懂的电影在线观看| 久久蜜臀精品av| 国产精品久久久久影院| 亚洲一级电影视频| 久久精品国产成人一区二区三区| 国内精品自线一区二区三区视频| 豆国产96在线|亚洲| 欧美日韩一区视频| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 337p日本欧洲亚洲大胆精品| www国产亚洲精品久久麻豆| 国产精品视频在线看| 亚洲一区二区三区三| 狠狠色狠狠色合久久伊人| 本田岬高潮一区二区三区| 欧洲一区在线电影| 久久综合久久99| 亚洲综合av网| 国产成人丝袜美腿| 欧美精品久久天天躁| 亚洲欧美乱综合| 青青草国产成人av片免费 | 亚洲国产精品高清| 亚洲中国最大av网站| 国产高清不卡一区| 欧美影片第一页| 国产精品国产精品国产专区不片| 日韩 欧美一区二区三区| 99在线精品一区二区三区| 制服.丝袜.亚洲.中文.综合| 国产精品久久久久天堂| 青草av.久久免费一区| 色就色 综合激情| 欧美国产综合色视频| 久久超级碰视频| 欧美日韩国产首页在线观看| 亚洲欧美综合另类在线卡通| 激情六月婷婷综合| 欧美一区二区视频在线观看 | 成人性色生活片| 精品国产露脸精彩对白| 一级日本不卡的影视| 99久久99久久精品国产片果冻| 日韩三级电影网址| 五月婷婷久久综合| 日本福利一区二区| 亚洲三级久久久| 97精品国产97久久久久久久久久久久 | 91久久精品一区二区三区| 国产欧美精品一区二区三区四区| 日本中文一区二区三区| 欧美日本免费一区二区三区| 国产精品热久久久久夜色精品三区| 激情综合色播激情啊| 精品国产91久久久久久久妲己| 天天色图综合网| 91精品综合久久久久久| 视频一区在线播放| 日韩一区二区电影网| 日韩av一二三| 亚洲免费av观看| 色94色欧美sute亚洲线路二| 亚洲三级电影网站| 在线观看视频91| 视频在线在亚洲| 精品久久久久久久久久久久包黑料 | 日韩电影一区二区三区| 91精品国产综合久久福利软件| 日本成人在线电影网| 日韩视频在线一区二区| 国产呦萝稀缺另类资源| 欧美激情一区不卡| 91在线视频18| 日韩成人免费在线| 久久一留热品黄| 91香蕉视频黄| 日韩黄色一级片| 国产午夜精品美女毛片视频| caoporn国产精品| 亚洲国产综合视频在线观看| 欧美日韩国产另类一区| 韩国视频一区二区| 国产精品久久久久久久久动漫| 色综合久久综合网欧美综合网| 亚洲成人av在线电影| 久久一日本道色综合| 在线观看日韩一区| 久久成人羞羞网站| 国产精品久久久久影视| 欧美精三区欧美精三区| 国产黄色精品视频| 亚洲制服丝袜av| 久久你懂得1024| 欧美色电影在线| 国产夫妻精品视频| 亚洲va欧美va人人爽| 久久先锋资源网| 久久久久九九视频| 色美美综合视频| 国产成人8x视频一区二区| 亚洲成av人**亚洲成av**| 久久久久久久久久美女| 在线成人午夜影院| 91蜜桃在线免费视频| 久久99精品国产麻豆婷婷| 亚洲精品中文字幕在线观看| 精品福利在线导航| 欧美色老头old∨ideo| 不卡免费追剧大全电视剧网站| 免费在线观看视频一区| 亚洲麻豆国产自偷在线| 国产日韩三级在线| 日韩一区二区在线播放| 欧美视频一区二区三区四区 | 亚洲在线中文字幕| 中文字幕国产一区二区| 欧美xxxxxxxx| 91精品国产乱| 777xxx欧美| 欧美日韩久久久一区| 一本久久a久久精品亚洲| 成人免费观看视频| 国产99一区视频免费| 国产精品888| 国产美女一区二区| 激情综合色丁香一区二区| 天天做天天摸天天爽国产一区 | 国产欧美精品一区二区色综合| 精品欧美一区二区久久| 亚洲天堂福利av| 国产精品国产三级国产专播品爱网| 久久久久免费观看| 久久久久久亚洲综合| 久久综合成人精品亚洲另类欧美| 欧美xxxx在线观看| 久久久久一区二区三区四区| 精品福利视频一区二区三区| 精品国产乱码久久久久久闺蜜 | 在线播放国产精品二区一二区四区 | 亚洲另类春色校园小说| 亚洲色图一区二区三区| 一区二区三区在线视频播放| 亚洲欧美区自拍先锋| 亚洲国产综合人成综合网站| 五月婷婷久久综合| 毛片av一区二区| 国产综合成人久久大片91| 国产成a人亚洲精品| 99精品欧美一区二区三区综合在线| 91丝袜呻吟高潮美腿白嫩在线观看| 高清不卡一区二区| 91亚洲精品一区二区乱码| 91精品1区2区| 欧美一区二区观看视频| 久久精品一级爱片| 中文字幕亚洲区| 亚洲电影激情视频网站| 麻豆91精品91久久久的内涵| 国产乱人伦偷精品视频不卡| www.99精品| 欧美顶级少妇做爰| 国产亚洲污的网站| 亚洲宅男天堂在线观看无病毒| 首页亚洲欧美制服丝腿| 成人综合婷婷国产精品久久蜜臀| 风间由美一区二区三区在线观看| 色婷婷综合在线| 欧美成人a视频| 亚洲三级电影网站| 轻轻草成人在线| 一级女性全黄久久生活片免费| 日本 国产 欧美色综合| 99综合电影在线视频| 91精品国产综合久久蜜臀| 日韩欧美亚洲国产另类 | 亚洲一区在线视频| 国产精品一区二区在线观看不卡 | 国产精品中文字幕欧美| 92精品国产成人观看免费| 日韩欧美国产综合一区 | 精品美女在线播放| 国产精品久久久久久久久果冻传媒| 亚洲h在线观看| 99re这里只有精品6|