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

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

?? balloc.c

?? 內核是系統的心臟
?? C
字號:
/*
 *  linux/fs/sysv/balloc.c
 *
 *  minix/bitmap.c
 *  Copyright (C) 1991, 1992  Linus Torvalds
 *
 *  ext/freelists.c
 *  Copyright (C) 1992  Remy Card (card@masi.ibp.fr)
 *
 *  xenix/alloc.c
 *  Copyright (C) 1992  Doug Evans
 *
 *  coh/alloc.c
 *  Copyright (C) 1993  Pascal Haible, Bruno Haible
 *
 *  sysv/balloc.c
 *  Copyright (C) 1993  Bruno Haible
 *
 *  This file contains code for allocating/freeing blocks.
 */

#include <linux/kernel.h>
#include <linux/fs.h>
#include <linux/sysv_fs.h>
#include <linux/string.h>
#include <linux/locks.h>

/* We don't trust the value of
   sb->sv_sbd->s_tfree = *sb->sv_sb_total_free_blocks
   but we nevertheless keep it up to date. */

extern inline void memzero (void * s, size_t count)
{
__asm__("cld\n\t"
	"rep\n\t"
	"stosl"
	:
	:"a" (0),"D" (s),"c" (count/4)
	:"cx","di","memory");
}

void sysv_free_block(struct super_block * sb, unsigned int block)
{
	struct buffer_head * bh;
	char * bh_data;

	if (!sb) {
		printk("sysv_free_block: trying to free block on nonexistent device\n");
		return;
	}
	if (block < sb->sv_firstdatazone || block >= sb->sv_nzones) {
		printk("sysv_free_block: trying to free block not in datazone\n");
		return;
	}
	lock_super(sb);
	if (*sb->sv_sb_flc_count > sb->sv_flc_size) {
		printk("sysv_free_block: flc_count > flc_size\n");
		unlock_super(sb);
		return;
	}
	/* If the free list head in super-block is full, it is copied
	 * into this block being freed:
	 */
	if (*sb->sv_sb_flc_count == sb->sv_flc_size) {
		unsigned short * flc_count;
		unsigned long * flc_blocks;

		if (sb->sv_block_size_ratio_bits > 0) /* block_size < BLOCK_SIZE ? */
			bh = bread(sb->s_dev, (block >> sb->sv_block_size_ratio_bits) + sb->sv_block_base, BLOCK_SIZE);
		else
			bh = getblk(sb->s_dev, (block >> sb->sv_block_size_ratio_bits) + sb->sv_block_base, BLOCK_SIZE);
		if (!bh) {
			printk("sysv_free_block: getblk() or bread() failed\n");
			unlock_super(sb);
			return;
		}
		bh_data = bh->b_data + ((block & sb->sv_block_size_ratio_1) << sb->sv_block_size_bits);
		switch (sb->sv_type) {
			case FSTYPE_XENIX:
				flc_count = &((struct xenix_freelist_chunk *) bh_data)->fl_nfree;
				flc_blocks = &((struct xenix_freelist_chunk *) bh_data)->fl_free[0];
				break;
			case FSTYPE_SYSV4:
				flc_count = &((struct sysv4_freelist_chunk *) bh_data)->fl_nfree;
				flc_blocks = &((struct sysv4_freelist_chunk *) bh_data)->fl_free[0];
				break;
			case FSTYPE_SYSV2:
				flc_count = &((struct sysv2_freelist_chunk *) bh_data)->fl_nfree;
				flc_blocks = &((struct sysv2_freelist_chunk *) bh_data)->fl_free[0];
				break;
			case FSTYPE_COH:
				flc_count = &((struct coh_freelist_chunk *) bh_data)->fl_nfree;
				flc_blocks = &((struct coh_freelist_chunk *) bh_data)->fl_free[0];
				break;
			default: panic("sysv_free_block: invalid fs type\n");
		}
		*flc_count = *sb->sv_sb_flc_count; /* = sb->sv_flc_size */
		memcpy(flc_blocks, sb->sv_sb_flc_blocks, *flc_count * sizeof(sysv_zone_t));
		bh->b_dirt = 1;
		bh->b_uptodate = 1;
		brelse(bh);
		*sb->sv_sb_flc_count = 0;
	} else
	/* If the free list head in super-block is empty, create a new head
	 * in this block being freed:
	 */
	if (*sb->sv_sb_flc_count == 0) { /* Applies only to Coherent FS */
		if (sb->sv_block_size_ratio_bits > 0) /* block_size < BLOCK_SIZE ? */
			bh = bread(sb->s_dev, (block >> sb->sv_block_size_ratio_bits) + sb->sv_block_base, BLOCK_SIZE);
		else
			bh = getblk(sb->s_dev, (block >> sb->sv_block_size_ratio_bits) + sb->sv_block_base, BLOCK_SIZE);
		if (!bh) {
			printk("sysv_free_block: getblk() or bread() failed\n");
			unlock_super(sb);
			return;
		}
		bh_data = bh->b_data + ((block & sb->sv_block_size_ratio_1) << sb->sv_block_size_bits);
		memzero(bh_data, sb->sv_block_size);
		/* this implies ((struct ..._freelist_chunk *) bh_data)->flc_count = 0; */
		bh->b_dirt = 1;
		bh->b_uptodate = 1;
		brelse(bh);
		/* still *sb->sv_sb_flc_count = 0 */
	} else {
		if (sb->sv_block_size_ratio_bits == 0) { /* block_size == BLOCK_SIZE ? */
			/* Throw away block's contents */
			bh = get_hash_table(sb->s_dev, (block >> sb->sv_block_size_ratio_bits) + sb->sv_block_base, BLOCK_SIZE);
			if (bh)
				bh->b_dirt = 0;
			brelse(bh);
		}
	}
	if (sb->sv_convert)
		block = to_coh_ulong(block);
	sb->sv_sb_flc_blocks[(*sb->sv_sb_flc_count)++] = block;
	if (sb->sv_convert)
		*sb->sv_sb_total_free_blocks =
		  to_coh_ulong(from_coh_ulong(*sb->sv_sb_total_free_blocks) + 1);
	else
		*sb->sv_sb_total_free_blocks = *sb->sv_sb_total_free_blocks + 1;
	sb->sv_bh->b_dirt = 1; /* super-block has been modified */
	sb->s_dirt = 1; /* and needs time stamp */
	unlock_super(sb);
}

int sysv_new_block(struct super_block * sb)
{
	unsigned int block;
	struct buffer_head * bh;
	char * bh_data;

	if (!sb) {
		printk("sysv_new_block: trying to get new block from nonexistent device\n");
		return 0;
	}
	lock_super(sb);
	if (*sb->sv_sb_flc_count == 0) { /* Applies only to Coherent FS */
		unlock_super(sb);
		return 0;		/* no blocks available */
	}
	block = sb->sv_sb_flc_blocks[(*sb->sv_sb_flc_count)-1];
	if (sb->sv_convert)
		block = from_coh_ulong(block);
	if (block == 0) { /* Applies only to Xenix FS, SystemV FS */
		unlock_super(sb);
		return 0;		/* no blocks available */
	}
	(*sb->sv_sb_flc_count)--;
	if (block < sb->sv_firstdatazone || block >= sb->sv_nzones) {
		printk("sysv_new_block: new block %d is not in data zone\n",block);
		unlock_super(sb);
		return 0;
	}
	if (*sb->sv_sb_flc_count == 0) { /* the last block continues the free list */
		unsigned short * flc_count;
		unsigned long * flc_blocks;

		if (!(bh = sysv_bread(sb, sb->s_dev, block, &bh_data))) {
			printk("sysv_new_block: cannot read free-list block\n");
			/* retry this same block next time */
			(*sb->sv_sb_flc_count)++;
			unlock_super(sb);
			return 0;
		}
		switch (sb->sv_type) {
			case FSTYPE_XENIX:
				flc_count = &((struct xenix_freelist_chunk *) bh_data)->fl_nfree;
				flc_blocks = &((struct xenix_freelist_chunk *) bh_data)->fl_free[0];
				break;
			case FSTYPE_SYSV4:
				flc_count = &((struct sysv4_freelist_chunk *) bh_data)->fl_nfree;
				flc_blocks = &((struct sysv4_freelist_chunk *) bh_data)->fl_free[0];
				break;
			case FSTYPE_SYSV2:
				flc_count = &((struct sysv2_freelist_chunk *) bh_data)->fl_nfree;
				flc_blocks = &((struct sysv2_freelist_chunk *) bh_data)->fl_free[0];
				break;
			case FSTYPE_COH:
				flc_count = &((struct coh_freelist_chunk *) bh_data)->fl_nfree;
				flc_blocks = &((struct coh_freelist_chunk *) bh_data)->fl_free[0];
				break;
			default: panic("sysv_new_block: invalid fs type\n");
		}
		if (*flc_count > sb->sv_flc_size) {
			printk("sysv_new_block: free-list block with >flc_size entries\n");
			brelse(bh);
			unlock_super(sb);
			return 0;
		}
		*sb->sv_sb_flc_count = *flc_count;
		memcpy(sb->sv_sb_flc_blocks, flc_blocks, *flc_count * sizeof(sysv_zone_t));
		brelse(bh);
	}
	/* Now the free list head in the superblock is valid again. */
	if (sb->sv_block_size_ratio_bits > 0) /* block_size < BLOCK_SIZE ? */
		bh = bread(sb->s_dev, (block >> sb->sv_block_size_ratio_bits) + sb->sv_block_base, BLOCK_SIZE);
	else
		bh = getblk(sb->s_dev, (block >> sb->sv_block_size_ratio_bits) + sb->sv_block_base, BLOCK_SIZE);
	if (!bh) {
		printk("sysv_new_block: getblk() or bread() failed\n");
		unlock_super(sb);
		return 0;
	}
	bh_data = bh->b_data + ((block & sb->sv_block_size_ratio_1) << sb->sv_block_size_bits);
	if (sb->sv_block_size_ratio_bits == 0) /* block_size == BLOCK_SIZE ? */
		if (bh->b_count != 1) {
			printk("sysv_new_block: block already in use\n");
			unlock_super(sb);
			return 0;
		}
	memzero(bh_data,sb->sv_block_size);
	bh->b_dirt = 1;
	bh->b_uptodate = 1;
	brelse(bh);
	if (sb->sv_convert)
		*sb->sv_sb_total_free_blocks =
		  to_coh_ulong(from_coh_ulong(*sb->sv_sb_total_free_blocks) - 1);
	else
		*sb->sv_sb_total_free_blocks = *sb->sv_sb_total_free_blocks - 1;
	sb->sv_bh->b_dirt = 1; /* super-block has been modified */
	sb->s_dirt = 1; /* and needs time stamp */
	unlock_super(sb);
	return block;
}

unsigned long sysv_count_free_blocks(struct super_block * sb)
{
#if 1 /* test */
	int count, old_count;
	unsigned int block;
	struct buffer_head * bh;
	char * bh_data;
	int i;

	/* this causes a lot of disk traffic ... */
	count = 0;
	lock_super(sb);
	if (*sb->sv_sb_flc_count > 0) {
		for (i = *sb->sv_sb_flc_count ; /* i > 0 */ ; ) {
			block = sb->sv_sb_flc_blocks[--i];
			if (sb->sv_convert)
				block = from_coh_ulong(block);
			if (block == 0) /* block 0 terminates list */
				goto done;
			count++;
			if (i == 0)
				break;
		}
		/* block = sb->sv_sb_flc_blocks[0], the last block continues the free list */
		while (1) {
			unsigned short * flc_count;
			unsigned long * flc_blocks;

			if (block < sb->sv_firstdatazone || block >= sb->sv_nzones) {
				printk("sysv_count_free_blocks: new block %d is not in data zone\n",block);
				break;
			}
			if (!(bh = sysv_bread(sb, sb->s_dev, block, &bh_data))) {
				printk("sysv_count_free_blocks: cannot read free-list block\n");
				break;
			}
			switch (sb->sv_type) {
				case FSTYPE_XENIX:
					flc_count = &((struct xenix_freelist_chunk *) bh_data)->fl_nfree;
					flc_blocks = &((struct xenix_freelist_chunk *) bh_data)->fl_free[0];
					break;
				case FSTYPE_SYSV4:
					flc_count = &((struct sysv4_freelist_chunk *) bh_data)->fl_nfree;
					flc_blocks = &((struct sysv4_freelist_chunk *) bh_data)->fl_free[0];
					break;
				case FSTYPE_SYSV2:
					flc_count = &((struct sysv2_freelist_chunk *) bh_data)->fl_nfree;
					flc_blocks = &((struct sysv2_freelist_chunk *) bh_data)->fl_free[0];
					break;
				case FSTYPE_COH:
					flc_count = &((struct coh_freelist_chunk *) bh_data)->fl_nfree;
					flc_blocks = &((struct coh_freelist_chunk *) bh_data)->fl_free[0];
					break;
				default: panic("sysv_count_free_blocks: invalid fs type\n");
			}
			if (*flc_count > sb->sv_flc_size) {
				printk("sysv_count_free_blocks: free-list block with >flc_size entries\n");
				brelse(bh);
				break;
			}
			if (*flc_count == 0) { /* Applies only to Coherent FS */
				brelse(bh);
				break;
			}
			for (i = *flc_count ; /* i > 0 */ ; ) {
				block = flc_blocks[--i];
				if (sb->sv_convert)
					block = from_coh_ulong(block);
				if (block == 0) /* block 0 terminates list */
					break;
				count++;
				if (i == 0)
					break;
			}
			/* block = flc_blocks[0], the last block continues the free list */
			brelse(bh);
			if (block == 0) /* Applies only to Xenix FS and SystemV FS */
				break;
		}
		done: ;
	}
	old_count = *sb->sv_sb_total_free_blocks;
	if (sb->sv_convert)
		old_count = from_coh_ulong(old_count);
	if (count != old_count) {
		printk("sysv_count_free_blocks: free block count was %d, correcting to %d\n",old_count,count);
		if (!(sb->s_flags & MS_RDONLY)) {
			*sb->sv_sb_total_free_blocks = (sb->sv_convert ? to_coh_ulong(count) : count);
			sb->sv_bh->b_dirt = 1; /* super-block has been modified */
			sb->s_dirt = 1; /* and needs time stamp */
		}
	}
	unlock_super(sb);
	return count;
#else
	int count;

	count = *sb->sv_sb_total_free_blocks;
	if (sb->sv_convert)
		count = from_coh_ulong(count);
	return count;
#endif
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
不卡欧美aaaaa| 天天色图综合网| 亚洲在线视频网站| 国产毛片精品国产一区二区三区| 成人午夜电影网站| 日韩视频免费观看高清在线视频| 91黄色在线观看| 久久久精品国产免费观看同学| 亚洲精选免费视频| 丁香婷婷综合网| 日韩久久久精品| 日韩电影免费在线观看网站| 91丨porny丨国产| 国产亚洲欧美一级| 国产一区二区三区精品视频| 一区二区在线电影| 成人激情校园春色| 国产日韩欧美高清在线| 免费在线成人网| 欧美日本韩国一区| 亚洲永久免费av| 91精品国产乱| 亚洲精品一线二线三线| 日韩精品免费专区| 欧美日韩国产a| 亚洲午夜在线电影| 欧美色欧美亚洲另类二区| 91亚洲精品一区二区乱码| 亚洲综合无码一区二区| 国产精品99久久久久久久vr| 91精品国产麻豆| 日本 国产 欧美色综合| 欧美男男青年gay1069videost | 美国毛片一区二区| 五月综合激情婷婷六月色窝| 91国偷自产一区二区三区成为亚洲经典| 国产情人综合久久777777| 精品影视av免费| 久久婷婷色综合| 国产精品乡下勾搭老头1| 国产三级欧美三级| 色综合天天性综合| 在线观看国产日韩| 亚洲国产精品麻豆| 欧美高清www午色夜在线视频| 亚洲成在人线在线播放| 国产成都精品91一区二区三| 91啦中文在线观看| 亚洲狼人国产精品| 欧美日韩国产小视频| 日韩黄色免费电影| 久久夜色精品国产欧美乱极品| 国产一区中文字幕| 中文字幕亚洲成人| 欧美色偷偷大香| 日韩欧美国产成人一区二区| 日韩欧美美女一区二区三区| 国产一区视频在线看| 国产精品美女www爽爽爽| 在线亚洲一区二区| 麻豆一区二区三区| 国产精品白丝在线| 欧美日韩国产首页在线观看| 韩国女主播一区| 国产精品久久久久影视| 欧美日韩一二区| 欧美激情一区二区三区全黄| 91香蕉视频在线| 奇米精品一区二区三区四区| 国产日韩欧美激情| 国产亚洲欧美中文| 国产乱码精品1区2区3区| 亚洲男人的天堂av| 欧美成人精品福利| 一区二区三区久久| 欧美大片在线观看一区二区| 99久久99精品久久久久久| 日韩av高清在线观看| 国产精品久久久久久久久免费丝袜 | 欧美精品日韩精品| 成人妖精视频yjsp地址| 日韩中文字幕一区二区三区| 国产精品美女一区二区三区| 免费在线观看视频一区| 亚洲日本成人在线观看| 精品对白一区国产伦| 在线观看一区二区视频| 国产精品一二三区在线| 日韩二区三区四区| 亚洲一区影音先锋| 国产精品久久久久aaaa樱花 | 久久综合色综合88| 在线免费不卡视频| 成年人国产精品| 国内偷窥港台综合视频在线播放| 亚洲一区av在线| 亚洲欧美日韩人成在线播放| 国产调教视频一区| 精品99999| 日韩欧美一区二区在线视频| 欧美三级韩国三级日本一级| 99精品在线免费| 不卡的电视剧免费网站有什么| 国产精品亚洲一区二区三区妖精| 91精品久久久久久久91蜜桃| 91精彩视频在线观看| 99久久伊人精品| 成人性视频网站| 欧美韩国日本不卡| 国产偷国产偷亚洲高清人白洁 | 国产欧美视频在线观看| 欧美一级淫片007| 56国语精品自产拍在线观看| 日本电影欧美片| www.亚洲精品| www.亚洲国产| 99精品视频一区| 在线影院国内精品| 欧美精品日日鲁夜夜添| 欧美电影在线免费观看| 欧美一级免费大片| 欧美成人三级电影在线| 日韩欧美国产电影| 国产性天天综合网| 中文无字幕一区二区三区| 中文字幕二三区不卡| 日韩一区在线播放| 欧美激情一区二区三区| 日韩美女精品在线| 亚洲午夜精品17c| 日日摸夜夜添夜夜添精品视频 | 国产婷婷色一区二区三区在线| 国产亚洲欧洲一区高清在线观看| 中文在线一区二区| 亚洲精品伦理在线| 精品一区二区三区在线播放视频| 国产精品人妖ts系列视频| 亚洲日本丝袜连裤袜办公室| 亚洲国产精品久久人人爱蜜臀| 五月婷婷综合激情| 精品亚洲欧美一区| 成人av电影观看| 欧美日韩五月天| 久久精品视频在线免费观看| 亚洲天堂精品在线观看| 婷婷久久综合九色综合绿巨人| 极品少妇xxxx精品少妇| 97国产精品videossex| 欧美乱妇15p| 中日韩av电影| 无吗不卡中文字幕| 国产成人av资源| 91久久精品国产91性色tv| 亚洲精品一区二区三区精华液| 综合色天天鬼久久鬼色| 免费成人在线观看视频| www.久久久久久久久| 欧美一区二区三区在线观看视频| 欧美国产日韩亚洲一区| 丝袜美腿亚洲一区| 国产一区二区在线视频| 国产一区二区电影| 97aⅴ精品视频一二三区| 欧美夫妻性生活| 国产精品久久久一区麻豆最新章节| 五月天中文字幕一区二区| 国产麻豆一精品一av一免费 | 91性感美女视频| 日韩你懂的在线观看| 亚洲视频一区二区在线| 精品一区二区久久| 欧美三级韩国三级日本三斤| 久久久777精品电影网影网| 午夜激情一区二区| 色婷婷av一区二区三区大白胸| 久久综合久久综合九色| 爽好久久久欧美精品| 久久国内精品视频| 国产美女精品人人做人人爽| 91精品国产综合久久久蜜臀图片| 亚洲日本成人在线观看| 丁香婷婷深情五月亚洲| 欧美不卡一区二区三区| 日本一区中文字幕| 欧美无砖砖区免费| 亚洲激情图片一区| 91美女视频网站| 国产精品久久久久9999吃药| 国产精品一二三四| 久久婷婷国产综合精品青草| 男女视频一区二区| 7777女厕盗摄久久久| 亚欧色一区w666天堂| 欧美中文字幕亚洲一区二区va在线| 国产精品久久久久久久久免费相片 | 成人免费一区二区三区在线观看 | 青青国产91久久久久久| 欧美日韩在线三区| 五月天一区二区三区| 在线播放视频一区|