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

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

?? super.c

?? 《嵌入式系統(tǒng)設(shè)計(jì)與實(shí)例開(kāi)發(fā)實(shí)驗(yàn)教材二源碼》Linux內(nèi)核移植與編譯實(shí)驗(yàn)
?? C
字號(hào):
/* * linux/fs/hfs/super.c * * Copyright (C) 1995-1997  Paul H. Hargrove * This file may be distributed under the terms of the GNU General Public License. * * This file contains hfs_read_super(), some of the super_ops and * init_module() and cleanup_module().	The remaining super_ops are in * inode.c since they deal with inodes. * * Based on the minix file system code, (C) 1991, 1992 by Linus Torvalds * * "XXX" in a comment is a note to myself to consider changing something. * * In function preconditions the term "valid" applied to a pointer to * a structure means that the pointer is non-NULL and the structure it * points to has all fields initialized to consistent values. * * The code in this file initializes some structures which contain * pointers by calling memset(&foo, 0, sizeof(foo)). * This produces the desired behavior only due to the non-ANSI * assumption that the machine representation of NULL is all zeros. */#include "hfs.h"#include <linux/hfs_fs_sb.h>#include <linux/hfs_fs_i.h>#include <linux/hfs_fs.h>#include <linux/config.h> /* for CONFIG_MAC_PARTITION */#include <linux/blkdev.h>#include <linux/module.h>#include <linux/init.h>/*================ Forward declarations ================*/static void hfs_read_inode(struct inode *);static void hfs_put_super(struct super_block *);static int hfs_statfs(struct super_block *, struct statfs *);static void hfs_write_super(struct super_block *);/*================ Global variables ================*/static struct super_operations hfs_super_operations = { 	read_inode:	hfs_read_inode,	put_inode:	hfs_put_inode,	put_super:	hfs_put_super,	write_super:	hfs_write_super,	statfs:		hfs_statfs,};/*================ File-local variables ================*/static DECLARE_FSTYPE_DEV(hfs_fs, "hfs", hfs_read_super);/*================ File-local functions ================*//*  * hfs_read_inode() * * this doesn't actually do much. hfs_iget actually fills in the  * necessary inode information. */static void hfs_read_inode(struct inode *inode){  inode->i_mode = 0;}/* * hfs_write_super() * * Description: *   This function is called by the VFS only. When the filesystem *   is mounted r/w it updates the MDB on disk. * Input Variable(s): *   struct super_block *sb: Pointer to the hfs superblock * Output Variable(s): *   NONE * Returns: *   void * Preconditions: *   'sb' points to a "valid" (struct super_block). * Postconditions: *   The MDB is marked 'unsuccessfully unmounted' by clearing bit 8 of drAtrb *   (hfs_put_super() must set this flag!). Some MDB fields are updated *   and the MDB buffer is written to disk by calling hfs_mdb_commit(). */static void hfs_write_super(struct super_block *sb){	struct hfs_mdb *mdb = HFS_SB(sb)->s_mdb;	/* is this a valid hfs superblock? */	if (!sb || sb->s_magic != HFS_SUPER_MAGIC) {		return;	}	if (!(sb->s_flags & MS_RDONLY)) {		/* sync everything to the buffers */		hfs_mdb_commit(mdb, 0);	}	sb->s_dirt = 0;}/* * hfs_put_super() * * This is the put_super() entry in the super_operations structure for * HFS filesystems.  The purpose is to release the resources * associated with the superblock sb. */static void hfs_put_super(struct super_block *sb){	struct hfs_mdb *mdb = HFS_SB(sb)->s_mdb; 	if (!(sb->s_flags & MS_RDONLY)) {		hfs_mdb_commit(mdb, 0);		sb->s_dirt = 0;	}	/* release the MDB's resources */	hfs_mdb_put(mdb, sb->s_flags & MS_RDONLY);	/* restore default blocksize for the device */	set_blocksize(sb->s_dev, BLOCK_SIZE);}/* * hfs_statfs() * * This is the statfs() entry in the super_operations structure for * HFS filesystems.  The purpose is to return various data about the * filesystem. * * changed f_files/f_ffree to reflect the fs_ablock/free_ablocks. */static int hfs_statfs(struct super_block *sb, struct statfs *buf){	struct hfs_mdb *mdb = HFS_SB(sb)->s_mdb;	buf->f_type = HFS_SUPER_MAGIC;	buf->f_bsize = HFS_SECTOR_SIZE;	buf->f_blocks = mdb->alloc_blksz * mdb->fs_ablocks;	buf->f_bfree = mdb->alloc_blksz * mdb->free_ablocks;	buf->f_bavail = buf->f_bfree;	buf->f_files = mdb->fs_ablocks;  	buf->f_ffree = mdb->free_ablocks;	buf->f_namelen = HFS_NAMELEN;	return 0;}/* * parse_options() *  * adapted from linux/fs/msdos/inode.c written 1992,93 by Werner Almesberger * This function is called by hfs_read_super() to parse the mount options. */static int parse_options(char *options, struct hfs_sb_info *hsb, int *part){	char *this_char, *value;	char names, fork;	/* initialize the sb with defaults */	memset(hsb, 0, sizeof(*hsb));	hsb->magic = HFS_SB_MAGIC;	hsb->s_uid   = current->uid;	hsb->s_gid   = current->gid;	hsb->s_umask = current->fs->umask;	hsb->s_type    = 0x3f3f3f3f;	/* == '????' */	hsb->s_creator = 0x3f3f3f3f;	/* == '????' */	hsb->s_lowercase = 0;	hsb->s_quiet     = 0;	hsb->s_afpd      = 0;        /* default version. 0 just selects the defaults */	hsb->s_version   = 0; 	hsb->s_conv = 'b';	names = '?';	fork = '?';	*part = 0;	if (!options) {		goto done;	}	for (this_char = strtok(options,","); this_char;	     this_char = strtok(NULL,",")) {		if ((value = strchr(this_char,'=')) != NULL) {			*value++ = 0;		}	/* Numeric-valued options */		if (!strcmp(this_char, "version")) {			if (!value || !*value) {				return 0;			}			hsb->s_version = simple_strtoul(value,&value,0);			if (*value) {				return 0;			}		} else if (!strcmp(this_char,"uid")) {			if (!value || !*value) {				return 0;			}			hsb->s_uid = simple_strtoul(value,&value,0);			if (*value) {				return 0;			}		} else if (!strcmp(this_char,"gid")) {			if (!value || !*value) {				return 0;			}			hsb->s_gid = simple_strtoul(value,&value,0);			if (*value) {				return 0;			}		} else if (!strcmp(this_char,"umask")) {			if (!value || !*value) {				return 0;			}			hsb->s_umask = simple_strtoul(value,&value,8);			if (*value) {				return 0;			}		} else if (!strcmp(this_char,"part")) {			if (!value || !*value) {				return 0;			}			*part = simple_strtoul(value,&value,0);			if (*value) {				return 0;			}	/* String-valued options */		} else if (!strcmp(this_char,"type") && value) {			if (strlen(value) != 4) {				return 0;			}			hsb->s_type = hfs_get_nl(value);		} else if (!strcmp(this_char,"creator") && value) {			if (strlen(value) != 4) {				return 0;			}			hsb->s_creator = hfs_get_nl(value);	/* Boolean-valued options */		} else if (!strcmp(this_char,"quiet")) {			if (value) {				return 0;			}			hsb->s_quiet = 1;		} else if (!strcmp(this_char,"afpd")) {			if (value) {				return 0;			}			hsb->s_afpd = 1;	/* Multiple choice options */		} else if (!strcmp(this_char,"names") && value) {			if ((*value && !value[1] && strchr("ntal78c",*value)) ||			    !strcmp(value,"netatalk") ||			    !strcmp(value,"trivial") ||			    !strcmp(value,"alpha") ||			    !strcmp(value,"latin") ||			    !strcmp(value,"7bit") ||			    !strcmp(value,"8bit") ||			    !strcmp(value,"cap")) {				names = *value;			} else {				return 0;			}		} else if (!strcmp(this_char,"fork") && value) {			if ((*value && !value[1] && strchr("nsdc",*value)) ||			    !strcmp(value,"netatalk") ||			    !strcmp(value,"single") ||			    !strcmp(value,"double") ||			    !strcmp(value,"cap")) {				fork = *value;			} else {				return 0;			}		} else if (!strcmp(this_char,"case") && value) {			if ((*value && !value[1] && strchr("la",*value)) ||			    !strcmp(value,"lower") ||			    !strcmp(value,"asis")) {				hsb->s_lowercase = (*value == 'l');			} else {				return 0;			}		} else if (!strcmp(this_char,"conv") && value) {			if ((*value && !value[1] && strchr("bta",*value)) ||			    !strcmp(value,"binary") ||			    !strcmp(value,"text") ||			    !strcmp(value,"auto")) {				hsb->s_conv = *value;			} else {				return 0;			}		} else {			return 0;		}	}done:	/* Parse the "fork" and "names" options */	if (fork == '?') {		fork = hsb->s_afpd ? 'n' : 'c';	}	switch (fork) {	default:	case 'c':		hsb->s_ifill = hfs_cap_ifill;		hsb->s_reserved1 = hfs_cap_reserved1;		hsb->s_reserved2 = hfs_cap_reserved2;		break;	case 's':		hfs_warn("hfs_fs: AppleSingle not yet implemented.\n");		return 0;		/* break; */		case 'd':		hsb->s_ifill = hfs_dbl_ifill;		hsb->s_reserved1 = hfs_dbl_reserved1;		hsb->s_reserved2 = hfs_dbl_reserved2;		break;	case 'n':		hsb->s_ifill = hfs_nat_ifill;		hsb->s_reserved1 = hfs_nat_reserved1;		hsb->s_reserved2 = hfs_nat_reserved2;		break;	}	if (names == '?') {		names = fork;	}	switch (names) {	default:	case 'n':		hsb->s_nameout = hfs_colon2mac;		hsb->s_namein = hfs_mac2nat;		break;	case 'c':		hsb->s_nameout = hfs_colon2mac;		hsb->s_namein = hfs_mac2cap;		break;	case 't':		hsb->s_nameout = hfs_triv2mac;		hsb->s_namein = hfs_mac2triv;		break;	case '7':		hsb->s_nameout = hfs_prcnt2mac;		hsb->s_namein = hfs_mac2seven;		break;	case '8':		hsb->s_nameout = hfs_prcnt2mac;		hsb->s_namein = hfs_mac2eight;		break;	case 'l':		hsb->s_nameout = hfs_latin2mac;		hsb->s_namein = hfs_mac2latin;		break; 	case 'a':	/* 's' and 'd' are unadvertised aliases for 'alpha', */ 	case 's':	/* since 'alpha' is the default if fork=s or fork=d. */ 	case 'd':	/* (It is also helpful for poor typists!)           */		hsb->s_nameout = hfs_prcnt2mac;		hsb->s_namein = hfs_mac2alpha;		break;	}	return 1;}/*================ Global functions ================*//* * hfs_read_super() * * This is the function that is responsible for mounting an HFS * filesystem.	It performs all the tasks necessary to get enough data * from the disk to read the root inode.  This includes parsing the * mount options, dealing with Macintosh partitions, reading the * superblock and the allocation bitmap blocks, calling * hfs_btree_init() to get the necessary data about the extents and * catalog B-trees and, finally, reading the root inode into memory. */struct super_block *hfs_read_super(struct super_block *s, void *data,				   int silent){	struct hfs_mdb *mdb;	struct hfs_cat_key key;	kdev_t dev = s->s_dev;	hfs_s32 part_size, part_start;	struct inode *root_inode;	int part;	if (!parse_options((char *)data, HFS_SB(s), &part)) {		hfs_warn("hfs_fs: unable to parse mount options.\n");		goto bail3;	}	/* set the device driver to 512-byte blocks */	set_blocksize(dev, HFS_SECTOR_SIZE);	s->s_blocksize_bits = HFS_SECTOR_SIZE_BITS;	s->s_blocksize = HFS_SECTOR_SIZE;#ifdef CONFIG_MAC_PARTITION	/* check to see if we're in a partition */	mdb = hfs_mdb_get(s, s->s_flags & MS_RDONLY, 0);	/* erk. try parsing the partition table ourselves */	if (!mdb) {		if (hfs_part_find(s, part, silent, &part_size, &part_start)) {	    		goto bail2;	  	}	  	mdb = hfs_mdb_get(s, s->s_flags & MS_RDONLY, part_start);	}#else	if (hfs_part_find(s, part, silent, &part_size, &part_start)) {		goto bail2;	}	mdb = hfs_mdb_get(s, s->s_flags & MS_RDONLY, part_start);#endif	if (!mdb) {		if (!silent) {			hfs_warn("VFS: Can't find a HFS filesystem on dev %s.\n",			       kdevname(dev));		}		goto bail2;	}	HFS_SB(s)->s_mdb = mdb;	if (HFS_ITYPE(mdb->next_id) != 0) {		hfs_warn("hfs_fs: too many files.\n");		goto bail1;	}	s->s_magic = HFS_SUPER_MAGIC;	s->s_op = &hfs_super_operations;	/* try to get the root inode */	hfs_cat_build_key(htonl(HFS_POR_CNID),			  (struct hfs_name *)(mdb->vname), &key);	root_inode = hfs_iget(hfs_cat_get(mdb, &key), HFS_ITYPE_NORM, NULL);	if (!root_inode) 		goto bail_no_root;	  	s->s_root = d_alloc_root(root_inode);	if (!s->s_root) 		goto bail_no_root;	/* fix up pointers. */	HFS_I(root_inode)->entry->sys_entry[HFS_ITYPE_TO_INT(HFS_ITYPE_NORM)] =	  s->s_root;	s->s_root->d_op = &hfs_dentry_operations;	/* everything's okay */	return s;bail_no_root: 	hfs_warn("hfs_fs: get root inode failed.\n");	iput(root_inode);bail1:	hfs_mdb_put(mdb, s->s_flags & MS_RDONLY);bail2:	set_blocksize(dev, BLOCK_SIZE);bail3:	return NULL;	}static int __init init_hfs_fs(void){        hfs_cat_init();	return register_filesystem(&hfs_fs);}static void __exit exit_hfs_fs(void) {	hfs_cat_free();	unregister_filesystem(&hfs_fs);}module_init(init_hfs_fs)module_exit(exit_hfs_fs)#if defined(DEBUG_ALL) || defined(DEBUG_MEM)long int hfs_alloc = 0;#endif

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产午夜精品久久久久久久| 中文字幕av不卡| 成人免费va视频| 日韩国产精品久久久| 国产精品久久久久久一区二区三区 | 91蜜桃免费观看视频| 免费成人av在线| 亚洲精品日韩一| 久久精品男人的天堂| 欧美一区二区久久| 欧美日韩一区三区四区| 成人av网站在线| 国产一区二区导航在线播放| 亚洲福利视频一区二区| 亚洲欧美日韩人成在线播放| 久久久综合精品| 日韩欧美国产一区二区在线播放 | 精品少妇一区二区三区免费观看| 国产视频一区二区三区在线观看| 欧美日韩的一区二区| 99国产精品久久| 成人免费视频网站在线观看| 精品无人区卡一卡二卡三乱码免费卡| 亚洲国产精品自拍| 亚洲午夜免费福利视频| 亚洲乱码国产乱码精品精的特点| 一区视频在线播放| 国产精品视频线看| 国产精品另类一区| 欧美国产乱子伦| 中文字幕精品一区二区三区精品 | 亚洲日本在线视频观看| 国产精品无圣光一区二区| 亚洲精品在线免费播放| 精品久久久久久久久久久久久久久久久 | 色综合色综合色综合色综合色综合| 国产九九视频一区二区三区| 久久99精品国产麻豆婷婷| 麻豆中文一区二区| 美女视频一区在线观看| 久久精品久久久精品美女| 蜜臀av一区二区| 蜜桃av一区二区| 看电影不卡的网站| 国产乱对白刺激视频不卡| 国产精品一区不卡| 99久久免费精品高清特色大片| 99国内精品久久| 在线亚洲一区二区| 欧美日韩国产综合一区二区三区 | 欧美一级在线观看| 欧美精品一区二区三区蜜桃| 久久久99精品久久| 国产精品久久久久国产精品日日| 国产精品家庭影院| 亚洲尤物视频在线| 日本sm残虐另类| 国产寡妇亲子伦一区二区| 成人午夜电影久久影院| 色老汉一区二区三区| 制服丝袜在线91| 久久久美女毛片| 综合色天天鬼久久鬼色| 色悠悠久久综合| 欧美一区二区在线不卡| 久久精品视频一区二区三区| 国产精品第五页| 婷婷综合另类小说色区| 韩国欧美一区二区| 99精品视频中文字幕| 欧美性猛交xxxx黑人交| 欧美大胆人体bbbb| 综合久久一区二区三区| 日韩精品91亚洲二区在线观看 | 国产美女精品人人做人人爽| 成人sese在线| 欧美一三区三区四区免费在线看| 国产三级欧美三级| 亚洲影视在线播放| 国内精品伊人久久久久av影院| 成人av在线资源| 欧美一级在线观看| 1024成人网色www| 久久国产精品露脸对白| av午夜精品一区二区三区| 欧美日韩国产高清一区二区| 国产三级精品三级| 婷婷六月综合网| a亚洲天堂av| 91精品一区二区三区在线观看| 久久免费偷拍视频| 午夜精品福利在线| 波多野结衣在线一区| 717成人午夜免费福利电影| 欧美国产成人精品| 蜜臀va亚洲va欧美va天堂| 在线一区二区三区四区五区 | 香蕉成人伊视频在线观看| 国产伦精品一区二区三区在线观看 | 久久夜色精品一区| 日韩av电影免费观看高清完整版在线观看| 成人丝袜18视频在线观看| 日韩一级片在线播放| 亚洲欧美日韩国产综合在线| 国产一区二区主播在线| 欧美日韩久久一区二区| 亚洲欧美电影院| 成人一道本在线| 久久综合九色综合欧美亚洲| 丝袜美腿一区二区三区| 欧美在线一二三四区| 中文字幕亚洲一区二区va在线| 精品一区二区三区免费| 欧美一区二区三区日韩视频| 亚洲一二三四区| 97超碰欧美中文字幕| 久久蜜臀精品av| 狠狠v欧美v日韩v亚洲ⅴ| 日韩视频免费观看高清完整版在线观看 | 91视频.com| 亚洲三级久久久| youjizz国产精品| 久久久91精品国产一区二区三区| 久久99国产精品麻豆| 欧美tk丨vk视频| 免费xxxx性欧美18vr| 欧美一二三四在线| 日日夜夜一区二区| 91精品欧美福利在线观看| 午夜av区久久| 欧美年轻男男videosbes| 亚洲一区二区3| 7799精品视频| 蜜桃久久精品一区二区| 日韩欧美黄色影院| 狠狠色狠狠色综合| 久久久久久9999| 高清视频一区二区| 中文幕一区二区三区久久蜜桃| 国产精品88av| 国产精品成人免费精品自在线观看| av网站一区二区三区| 亚洲精品国产无天堂网2021| 日本高清不卡在线观看| 亚洲电影在线播放| 日韩视频免费观看高清在线视频| 麻豆国产精品视频| 国产日韩欧美不卡在线| 91在线免费播放| 亚洲国产精品精华液网站| 制服丝袜亚洲播放| 美腿丝袜一区二区三区| 久久综合色婷婷| 成人精品高清在线| 亚洲精品日韩一| 欧美一区二区免费视频| 国产一区日韩二区欧美三区| 国产精品传媒入口麻豆| 色综合色综合色综合色综合色综合 | 樱花影视一区二区| 56国语精品自产拍在线观看| 琪琪一区二区三区| 亚洲国产成人一区二区三区| 99久久婷婷国产精品综合| 亚洲gay无套男同| 久久综合狠狠综合久久综合88| 丰满少妇久久久久久久| 亚洲在线中文字幕| 日韩精品一区二区三区swag| 成人午夜在线视频| 亚洲国产精品一区二区久久| 久久亚洲精华国产精华液| 91丝袜呻吟高潮美腿白嫩在线观看| 香蕉成人伊视频在线观看| 国产三级精品三级在线专区| 欧美亚洲国产一区二区三区| 国产综合成人久久大片91| 亚洲码国产岛国毛片在线| 日韩欧美在线不卡| 91在线一区二区| 国内精品自线一区二区三区视频| 亚洲黄色尤物视频| 久久精品男人天堂av| 欧美日韩和欧美的一区二区| 国产不卡视频一区二区三区| 午夜视频一区二区| 国产精品中文欧美| 亚洲国产精品一区二区久久恐怖片| 久久精品在这里| 91 com成人网| 色呦呦网站一区| 懂色av一区二区三区免费观看 | 日本亚洲三级在线| 亚洲欧美中日韩| 欧美精品一区二区三区很污很色的 | 精品少妇一区二区三区免费观看| 在线区一区二视频| 成人18视频在线播放| 精品一二三四区| 日韩经典中文字幕一区|