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

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

?? balloc.c

?? linux 下的文件管理的程序
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*
 *  linux/fs/ext2/balloc.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)
 *
 *  Enhanced block allocation by Stephen Tweedie (sct@dcs.ed.ac.uk), 1993
 *  Big-endian to little-endian byte-swapping/bitmaps by
 *        David S. Miller (davem@caip.rutgers.edu), 1995
 */

#include <linux/config.h>
#include <linux/fs.h>
#include <linux/ext2_fs.h>
#include <linux/locks.h>
#include <linux/quotaops.h>

/*
 * balloc.c contains the blocks allocation and deallocation routines
 */

/*
 * The free blocks are managed by bitmaps.  A file system contains several
 * blocks groups.  Each group contains 1 bitmap block for blocks, 1 bitmap
 * block for inodes, N blocks for the inode table and data blocks.
 *
 * The file system contains group descriptors which are located after the
 * super block.  Each descriptor contains the number of the bitmap block and
 * the free blocks count in the block.  The descriptors are loaded in memory
 * when a file system is mounted (see ext2_read_super).
 */


#define in_range(b, first, len)		((b) >= (first) && (b) <= (first) + (len) - 1)

struct ext2_group_desc * ext2_get_group_desc(struct super_block * sb,
					     unsigned int block_group,
					     struct buffer_head ** bh)
{
	unsigned long group_desc;
	unsigned long desc;
	struct ext2_group_desc * gdp;

	if (block_group >= sb->u.ext2_sb.s_groups_count) {
		ext2_error (sb, "ext2_get_group_desc",
			    "block_group >= groups_count - "
			    "block_group = %d, groups_count = %lu",
			    block_group, sb->u.ext2_sb.s_groups_count);

		return NULL;
	}
	
	group_desc = block_group / EXT2_DESC_PER_BLOCK(sb);
	desc = block_group % EXT2_DESC_PER_BLOCK(sb);
	if (!sb->u.ext2_sb.s_group_desc[group_desc]) {
		ext2_error (sb, "ext2_get_group_desc",
			    "Group descriptor not loaded - "
			    "block_group = %d, group_desc = %lu, desc = %lu",
			     block_group, group_desc, desc);
		return NULL;
	}
	
	gdp = (struct ext2_group_desc *) 
	      sb->u.ext2_sb.s_group_desc[group_desc]->b_data;
	if (bh)
		*bh = sb->u.ext2_sb.s_group_desc[group_desc];
	return gdp + desc;
}

/*
 * Read the bitmap for a given block_group, reading into the specified 
 * slot in the superblock's bitmap cache.
 *
 * Return >=0 on success or a -ve error code.
 */

static int read_block_bitmap (struct super_block * sb,
			       unsigned int block_group,
			       unsigned long bitmap_nr)
{
	struct ext2_group_desc * gdp;
	struct buffer_head * bh = NULL;
	int retval = -EIO;
	
	gdp = ext2_get_group_desc (sb, block_group, NULL);
	if (!gdp)
		goto error_out;
	retval = 0;
	bh = bread (sb->s_dev, le32_to_cpu(gdp->bg_block_bitmap), sb->s_blocksize);
	if (!bh) {
		ext2_error (sb, "read_block_bitmap",
			    "Cannot read block bitmap - "
			    "block_group = %d, block_bitmap = %lu",
			    block_group, (unsigned long) gdp->bg_block_bitmap);
		retval = -EIO;
	}
	/*
	 * On IO error, just leave a zero in the superblock's block pointer for
	 * this group.  The IO will be retried next time.
	 */
error_out:
	sb->u.ext2_sb.s_block_bitmap_number[bitmap_nr] = block_group;
	sb->u.ext2_sb.s_block_bitmap[bitmap_nr] = bh;
	return retval;
}

/*
 * load_block_bitmap loads the block bitmap for a blocks group
 *
 * It maintains a cache for the last bitmaps loaded.  This cache is managed
 * with a LRU algorithm.
 *
 * Notes:
 * 1/ There is one cache per mounted file system.
 * 2/ If the file system contains less than EXT2_MAX_GROUP_LOADED groups,
 *    this function reads the bitmap without maintaining a LRU cache.
 * 
 * Return the slot used to store the bitmap, or a -ve error code.
 */
static int __load_block_bitmap (struct super_block * sb,
			        unsigned int block_group)
{
	int i, j, retval = 0;
	unsigned long block_bitmap_number;
	struct buffer_head * block_bitmap;

	if (block_group >= sb->u.ext2_sb.s_groups_count)
		ext2_panic (sb, "load_block_bitmap",
			    "block_group >= groups_count - "
			    "block_group = %d, groups_count = %lu",
			    block_group, sb->u.ext2_sb.s_groups_count);

	if (sb->u.ext2_sb.s_groups_count <= EXT2_MAX_GROUP_LOADED) {
		if (sb->u.ext2_sb.s_block_bitmap[block_group]) {
			if (sb->u.ext2_sb.s_block_bitmap_number[block_group] ==
			    block_group)
				return block_group;
			ext2_error (sb, "__load_block_bitmap",
				    "block_group != block_bitmap_number");
		}
		retval = read_block_bitmap (sb, block_group, block_group);
		if (retval < 0)
			return retval;
		return block_group;
	}

	for (i = 0; i < sb->u.ext2_sb.s_loaded_block_bitmaps &&
		    sb->u.ext2_sb.s_block_bitmap_number[i] != block_group; i++)
		;
	if (i < sb->u.ext2_sb.s_loaded_block_bitmaps &&
  	    sb->u.ext2_sb.s_block_bitmap_number[i] == block_group) {
		block_bitmap_number = sb->u.ext2_sb.s_block_bitmap_number[i];
		block_bitmap = sb->u.ext2_sb.s_block_bitmap[i];
		for (j = i; j > 0; j--) {
			sb->u.ext2_sb.s_block_bitmap_number[j] =
				sb->u.ext2_sb.s_block_bitmap_number[j - 1];
			sb->u.ext2_sb.s_block_bitmap[j] =
				sb->u.ext2_sb.s_block_bitmap[j - 1];
		}
		sb->u.ext2_sb.s_block_bitmap_number[0] = block_bitmap_number;
		sb->u.ext2_sb.s_block_bitmap[0] = block_bitmap;

		/*
		 * There's still one special case here --- if block_bitmap == 0
		 * then our last attempt to read the bitmap failed and we have
		 * just ended up caching that failure.  Try again to read it.
		 */
		if (!block_bitmap)
			retval = read_block_bitmap (sb, block_group, 0);
	} else {
		if (sb->u.ext2_sb.s_loaded_block_bitmaps < EXT2_MAX_GROUP_LOADED)
			sb->u.ext2_sb.s_loaded_block_bitmaps++;
		else
			brelse (sb->u.ext2_sb.s_block_bitmap[EXT2_MAX_GROUP_LOADED - 1]);
		for (j = sb->u.ext2_sb.s_loaded_block_bitmaps - 1; j > 0;  j--) {
			sb->u.ext2_sb.s_block_bitmap_number[j] =
				sb->u.ext2_sb.s_block_bitmap_number[j - 1];
			sb->u.ext2_sb.s_block_bitmap[j] =
				sb->u.ext2_sb.s_block_bitmap[j - 1];
		}
		retval = read_block_bitmap (sb, block_group, 0);
	}
	return retval;
}

/*
 * Load the block bitmap for a given block group.  First of all do a couple
 * of fast lookups for common cases and then pass the request onto the guts
 * of the bitmap loader.
 *
 * Return the slot number of the group in the superblock bitmap cache's on
 * success, or a -ve error code.
 *
 * There is still one inconsistency here --- if the number of groups in this
 * filesystems is <= EXT2_MAX_GROUP_LOADED, then we have no way of 
 * differentiating between a group for which we have never performed a bitmap
 * IO request, and a group for which the last bitmap read request failed.
 */
static inline int load_block_bitmap (struct super_block * sb,
				     unsigned int block_group)
{
	int slot;
	
	/*
	 * Do the lookup for the slot.  First of all, check if we're asking
	 * for the same slot as last time, and did we succeed that last time?
	 */
	if (sb->u.ext2_sb.s_loaded_block_bitmaps > 0 &&
	    sb->u.ext2_sb.s_block_bitmap_number[0] == block_group &&
	    sb->u.ext2_sb.s_block_bitmap[0]) {
		return 0;
	}
	/*
	 * Or can we do a fast lookup based on a loaded group on a filesystem
	 * small enough to be mapped directly into the superblock?
	 */
	else if (sb->u.ext2_sb.s_groups_count <= EXT2_MAX_GROUP_LOADED && 
		 sb->u.ext2_sb.s_block_bitmap_number[block_group] == block_group &&
		 sb->u.ext2_sb.s_block_bitmap[block_group]) {
		slot = block_group;
	}
	/*
	 * If not, then do a full lookup for this block group.
	 */
	else {
		slot = __load_block_bitmap (sb, block_group);
	}

	/*
	 * <0 means we just got an error
	 */
	if (slot < 0)
		return slot;
	
	/*
	 * If it's a valid slot, we may still have cached a previous IO error,
	 * in which case the bh in the superblock cache will be zero.
	 */
	if (!sb->u.ext2_sb.s_block_bitmap[slot])
		return -EIO;
	
	/*
	 * Must have been read in OK to get this far.
	 */
	return slot;
}

void ext2_free_blocks (const struct inode * inode, unsigned long block,
		       unsigned long count)
{
	struct buffer_head * bh;
	struct buffer_head * bh2;
	unsigned long block_group;
	unsigned long bit;
	unsigned long i;
	int bitmap_nr;
	unsigned long overflow;
	struct super_block * sb;
	struct ext2_group_desc * gdp;
	struct ext2_super_block * es;

	sb = inode->i_sb;
	if (!sb) {
		printk ("ext2_free_blocks: nonexistent device");
		return;
	}
	lock_super (sb);
	es = sb->u.ext2_sb.s_es;
	if (block < le32_to_cpu(es->s_first_data_block) || 
	    (block + count) > le32_to_cpu(es->s_blocks_count)) {
		ext2_error (sb, "ext2_free_blocks",
			    "Freeing blocks not in datazone - "
			    "block = %lu, count = %lu", block, count);
		goto error_return;
	}

	ext2_debug ("freeing block %lu\n", block);

do_more:
	overflow = 0;
	block_group = (block - le32_to_cpu(es->s_first_data_block)) /
		      EXT2_BLOCKS_PER_GROUP(sb);
	bit = (block - le32_to_cpu(es->s_first_data_block)) %
		      EXT2_BLOCKS_PER_GROUP(sb);
	/*
	 * Check to see if we are freeing blocks across a group
	 * boundary.
	 */
	if (bit + count > EXT2_BLOCKS_PER_GROUP(sb)) {
		overflow = bit + count - EXT2_BLOCKS_PER_GROUP(sb);
		count -= overflow;
	}
	bitmap_nr = load_block_bitmap (sb, block_group);
	if (bitmap_nr < 0)
		goto error_return;
	
	bh = sb->u.ext2_sb.s_block_bitmap[bitmap_nr];
	gdp = ext2_get_group_desc (sb, block_group, &bh2);
	if (!gdp)
		goto error_return;

	if (in_range (le32_to_cpu(gdp->bg_block_bitmap), block, count) ||
	    in_range (le32_to_cpu(gdp->bg_inode_bitmap), block, count) ||
	    in_range (block, le32_to_cpu(gdp->bg_inode_table),
		      sb->u.ext2_sb.s_itb_per_group) ||
	    in_range (block + count - 1, le32_to_cpu(gdp->bg_inode_table),
		      sb->u.ext2_sb.s_itb_per_group))
		ext2_error (sb, "ext2_free_blocks",
			    "Freeing blocks in system zones - "
			    "Block = %lu, count = %lu",
			    block, count);

	for (i = 0; i < count; i++) {
		if (!ext2_clear_bit (bit + i, bh->b_data))
			ext2_error (sb, "ext2_free_blocks",
				      "bit already cleared for block %lu", 
				      block);
		else {
			DQUOT_FREE_BLOCK(sb, inode, 1);
			gdp->bg_free_blocks_count =
				cpu_to_le16(le16_to_cpu(gdp->bg_free_blocks_count)+1);
			es->s_free_blocks_count =
				cpu_to_le32(le32_to_cpu(es->s_free_blocks_count)+1);
		}
	}
	
	mark_buffer_dirty(bh2);
	mark_buffer_dirty(sb->u.ext2_sb.s_sbh);

	mark_buffer_dirty(bh);
	if (sb->s_flags & MS_SYNCHRONOUS) {
		ll_rw_block (WRITE, 1, &bh);
		wait_on_buffer (bh);
	}
	if (overflow) {
		block += count;
		count = overflow;
		goto do_more;
	}
	sb->s_dirt = 1;
error_return:
	unlock_super (sb);
	return;
}

/*
 * ext2_new_block uses a goal block to assist allocation.  If the goal is
 * free, or there is a free block within 32 blocks of the goal, that block
 * is allocated.  Otherwise a forward search is made for a free block; within 
 * each block group the search first looks for an entire free byte in the block
 * bitmap, and then for any free bit if that fails.
 */
int ext2_new_block (const struct inode * inode, unsigned long goal,
    u32 * prealloc_count, u32 * prealloc_block, int * err)
{
	struct buffer_head * bh;
	struct buffer_head * bh2;
	char * p, * r;
	int i, j, k, tmp;
	int bitmap_nr;
	struct super_block * sb;
	struct ext2_group_desc * gdp;
	struct ext2_super_block * es;
#ifdef EXT2FS_DEBUG
	static int goal_hits = 0, goal_attempts = 0;
#endif
	*err = -ENOSPC;
	sb = inode->i_sb;
	if (!sb) {
		printk ("ext2_new_block: nonexistent device");
		return 0;
	}

	lock_super (sb);
	es = sb->u.ext2_sb.s_es;
	if (le32_to_cpu(es->s_free_blocks_count) <= le32_to_cpu(es->s_r_blocks_count) &&
	    ((sb->u.ext2_sb.s_resuid != current->fsuid) &&
	     (sb->u.ext2_sb.s_resgid == 0 ||
	      !in_group_p (sb->u.ext2_sb.s_resgid)) && 
	     !capable(CAP_SYS_RESOURCE)))
		goto out;

	ext2_debug ("goal=%lu.\n", goal);

repeat:
	/*
	 * First, test whether the goal block is free.
	 */
	if (goal < le32_to_cpu(es->s_first_data_block) ||
	    goal >= le32_to_cpu(es->s_blocks_count))
		goal = le32_to_cpu(es->s_first_data_block);
	i = (goal - le32_to_cpu(es->s_first_data_block)) / EXT2_BLOCKS_PER_GROUP(sb);

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久亚洲精品一区二区三区| 在线不卡一区二区| 石原莉奈一区二区三区在线观看| 久久亚洲一区二区三区明星换脸| 91蝌蚪国产九色| 麻豆高清免费国产一区| 国产一区二区三区不卡在线观看 | 亚洲一区二区中文在线| 亚洲精品在线三区| 欧美色爱综合网| 成人av电影免费在线播放| 日韩成人一区二区| 亚洲精品日韩综合观看成人91| 日韩你懂的电影在线观看| 一本大道av伊人久久综合| 国产一区二区主播在线| 偷拍日韩校园综合在线| 中文字幕一区二区三| 精品粉嫩超白一线天av| 欧美日韩在线电影| youjizz久久| 国产精品综合在线视频| 五月婷婷久久丁香| 亚洲一区二区欧美日韩 | 久久精品一区二区三区av| 欧美日韩国产免费一区二区| 91浏览器在线视频| 99精品国产91久久久久久| 国产精品综合网| 久久成人免费网站| 蜜臀a∨国产成人精品| 午夜精品久久久久久久久久| 亚洲精品老司机| 亚洲天天做日日做天天谢日日欢| 国产欧美一区二区精品性| 久久久久国产精品麻豆| 日韩精品一区二区三区在线| 3d成人动漫网站| 欧美精品免费视频| 欧美久久一区二区| 欧美日韩日本视频| 欧美伦理视频网站| 欧美高清你懂得| 欧美精品一区二区不卡| 欧美日韩电影在线| 91福利视频久久久久| 91无套直看片红桃| 色综合久久中文字幕综合网 | 成人激情免费视频| 成人免费高清视频在线观看| 国产suv精品一区二区三区| 国产超碰在线一区| 成人天堂资源www在线| av在线不卡电影| 91视频在线观看| 在线观看日韩毛片| 在线播放中文字幕一区| 欧美精品色综合| 欧美va亚洲va香蕉在线| 久久蜜臀中文字幕| 国产精品久久久久久久久动漫 | 欧美大片国产精品| 久久久精品日韩欧美| 国产亚洲欧美日韩俺去了| 国产精品毛片大码女人| 亚洲男人电影天堂| 天堂一区二区在线| 久久99精品久久久久久国产越南| 精品一区二区三区免费播放| 国产成人av一区二区三区在线 | 在线一区二区视频| 欧美精品 国产精品| 精品国产乱码久久久久久久久 | 日韩美女啊v在线免费观看| 亚洲欧美激情在线| 视频在线观看91| 国产精品一区二区在线观看网站| 成人精品免费视频| 欧美日韩中文国产| 欧美电影免费观看高清完整版在线观看| 26uuu精品一区二区在线观看| 国产视频一区不卡| 亚洲精品成人精品456| 美女在线一区二区| av中文字幕一区| 4438x亚洲最大成人网| 日本一区二区久久| 天天色综合成人网| 丁香六月综合激情| 7777精品伊人久久久大香线蕉超级流畅 | 午夜在线成人av| 国产一区久久久| 在线观看av一区二区| 欧美精品一区二区三区蜜桃| 亚洲三级电影全部在线观看高清| 日韩中文字幕亚洲一区二区va在线| 韩国精品主播一区二区在线观看| 色一情一伦一子一伦一区| 日韩欧美国产成人一区二区| 亚洲蜜臀av乱码久久精品蜜桃| 麻豆国产精品官网| 欧美性淫爽ww久久久久无| 久久久久久久久蜜桃| 亚洲国产aⅴ成人精品无吗| 成人性色生活片| 欧美一区二区三区啪啪| 亚洲美腿欧美偷拍| 国产成人av网站| 日韩一区二区三区在线观看| |精品福利一区二区三区| 激情成人综合网| 制服.丝袜.亚洲.另类.中文| 亚洲精选一二三| 懂色av一区二区夜夜嗨| 日韩欧美一区二区三区在线| 一区二区三区鲁丝不卡| 成人av午夜电影| 久久久久青草大香线综合精品| 亚洲一区二区三区四区五区黄| 波多野洁衣一区| 国产日产亚洲精品系列| 久久精品国产99久久6| 欧美日韩国产综合视频在线观看 | 懂色av中文字幕一区二区三区| 精品少妇一区二区三区免费观看| 亚洲国产日产av| 色吊一区二区三区 | 免费观看91视频大全| 欧美国产激情一区二区三区蜜月| 日本va欧美va瓶| 欧美日韩电影一区| 亚洲国产精品欧美一二99| 91丨九色丨尤物| 一区二区中文视频| 成人的网站免费观看| 日本一区二区三区国色天香| 国内精品写真在线观看| 日韩欧美国产不卡| 另类小说欧美激情| 日韩欧美一区在线观看| 日韩和欧美一区二区| 欧美精品在欧美一区二区少妇| 亚洲成人资源在线| 在线不卡一区二区| 麻豆国产精品视频| 欧美精品一区男女天堂| 久久电影网站中文字幕| 久久这里只有精品首页| 国产在线日韩欧美| 国产日韩精品一区| av亚洲精华国产精华| 亚洲卡通欧美制服中文| 欧美日韩国产一级二级| 全部av―极品视觉盛宴亚洲| 日韩视频免费观看高清完整版在线观看| 日本视频免费一区| 精品国产成人在线影院 | 蜜桃久久av一区| 久久伊99综合婷婷久久伊| 国产91精品一区二区麻豆网站| 日本一区二区电影| 在线观看一区二区视频| 亚洲第一福利视频在线| 日韩精品一区二区三区中文精品| 国产精品自拍在线| 亚洲视频在线观看三级| 91国偷自产一区二区三区成为亚洲经典 | 日本一区二区久久| 日本伦理一区二区| 奇米四色…亚洲| 国产亚洲女人久久久久毛片| 99久久99久久精品国产片果冻| 一区二区三区四区高清精品免费观看 | 666欧美在线视频| 九九热在线视频观看这里只有精品| 国产欧美日韩精品一区| 一本色道久久综合狠狠躁的推荐 | 最新国产成人在线观看| 欧美日本一区二区| 国产一区二区三区不卡在线观看| 亚洲区小说区图片区qvod| 欧美日韩高清不卡| 国产99久久精品| 亚洲高清中文字幕| 国产婷婷一区二区| 欧美午夜精品一区二区蜜桃 | 国内精品第一页| 亚洲日本欧美天堂| 日韩天堂在线观看| 99久久免费视频.com| 免费美女久久99| 亚洲免费观看在线视频| 精品国精品国产尤物美女| 91色九色蝌蚪| 国产又黄又大久久| 亚洲国产精品一区二区久久| 久久久www成人免费无遮挡大片| 在线一区二区三区四区五区| 国产资源精品在线观看| 亚洲一区二区3|