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

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

?? group.c

?? Sanos Operating System Kernel ----------------------------- Sanos is an OS kernel for use in PC base
?? C
字號:
//
// group.c
//
// Disk filesystem group routines
//
// Copyright (C) 2002 Michael Ringgaard. All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions
// are met:
// 
// 1. Redistributions of source code must retain the above copyright 
//    notice, this list of conditions and the following disclaimer.  
// 2. Redistributions in binary form must reproduce the above copyright
//    notice, this list of conditions and the following disclaimer in the
//    documentation and/or other materials provided with the distribution.  
// 3. Neither the name of the project nor the names of its contributors
//    may be used to endorse or promote products derived from this software
//    without specific prior written permission. 
// 
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
// FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
// DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
// OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
// HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
// LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
// OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 
// SUCH DAMAGE.
// 

#include <os/krnl.h>

static void mark_group_desc_dirty(struct filsys *fs, int group)
{
  mark_buffer_updated(fs->cache, fs->groupdesc_buffers[group / fs->groupdescs_per_block]);
}

blkno_t new_block(struct filsys *fs, blkno_t goal)
{
  unsigned int group;
  unsigned int i;
  struct buf *buf;
  blkno_t block;

  if (goal < fs->super->block_count)
  {
    // Check the goal
    group = goal / fs->super->blocks_per_group;
    block = goal % fs->super->blocks_per_group;
    buf = get_buffer(fs->cache, fs->groups[group].desc->block_bitmap_block);
    if (!buf) return NOBLOCK;
    if (!test_bit(buf->data, block)) goto block_found;

    // Try to find first free block in group after goal
    block = find_next_zero_bit(buf->data, fs->groups[group].desc->block_count, block + 1);
    if (block != fs->groups[group].desc->block_count) goto block_found;

    release_buffer(fs->cache, buf);
  }
  else
    group = 0;

  // Try to locate a free block by going through all groups cyclicly
  for (i = 0; i < fs->super->group_count; i++)
  {
    if (fs->groups[group].desc->free_block_count > 0)
    {
      // Get block bitmap
      buf = get_buffer(fs->cache, fs->groups[group].desc->block_bitmap_block);
      if (!buf) return NOBLOCK;

      // Try to find first free block
      if (fs->groups[group].first_free_block != -1)
        block = find_next_zero_bit(buf->data, fs->groups[group].desc->block_count, fs->groups[group].first_free_block);
      else
      {
        block = find_first_zero_bit(buf->data, fs->groups[group].desc->block_count);
	fs->groups[group].first_free_block = block;
      }

      if (block != fs->groups[group].desc->block_count) goto block_found;
    
      release_buffer(fs->cache, buf);
    }

    // Try next group
    group++;
    if (group >= fs->super->group_count) group = 0;
  }

  //panic("disk full");
  return NOBLOCK;

block_found:
  set_bit(buf->data, block);
  mark_buffer_updated(fs->cache, buf);

  fs->super->free_block_count--;
  fs->super_dirty = 1;

  if (fs->groups[group].first_free_block == block) fs->groups[group].first_free_block = block + 1;
  fs->groups[group].desc->free_block_count--;
  mark_group_desc_dirty(fs, group);

  release_buffer(fs->cache, buf);
  block += group * fs->super->blocks_per_group;
  return block;
}

void free_blocks(struct filsys *fs, blkno_t *blocks, int count)
{
  unsigned int group;
  unsigned int prev_group;
  struct buf *buf;
  blkno_t block;
  int i;

  prev_group = -1;
  buf = NULL;

  for (i = 0; i < count; i++)
  {
    group = blocks[i] / fs->super->blocks_per_group;
    block = blocks[i] % fs->super->blocks_per_group;

    if (group != prev_group)
    {
      if (buf) release_buffer(fs->cache, buf);
      buf = get_buffer(fs->cache, fs->groups[group].desc->block_bitmap_block);
      if (!buf) return;
      prev_group = group;
    }

    clear_bit(buf->data, block);
    mark_buffer_updated(fs->cache, buf);

    fs->super->free_block_count++;
    fs->super_dirty = 1;

    if (fs->groups[group].first_free_block > block) fs->groups[group].first_free_block = block;
    fs->groups[group].desc->free_block_count++;
    mark_group_desc_dirty(fs, group);
  }

  if (buf) release_buffer(fs->cache, buf);
}

ino_t new_inode(struct filsys *fs, ino_t parent, int flags)
{
  unsigned int group;
  unsigned int i;
  unsigned int avefreei;
  struct buf *buf;
  ino_t ino;

  if (flags & DFS_INODE_FLAG_DIRECTORY)
  {
    // Find group with above average free inodes with most free blocks
    avefreei = fs->super->free_inode_count / fs->super->group_count;

    group = -1;
    for (i = 0; i < fs->super->group_count; i++)
    {
      if (fs->groups[i].desc->free_inode_count && fs->groups[i].desc->free_inode_count >= avefreei)
      {
	if (group == -1 || fs->groups[i].desc->free_block_count > fs->groups[group].desc->free_block_count)
	{
	  group = i;
	}
      }
    }
    if (group == -1) group = 0;
  }
  else
  {
    // Try to locate a free inode by going through all groups cyclicly starting with parents group
    group = parent / fs->super->inodes_per_group;
    for (i = 0; i < fs->super->group_count; i++)
    {
      if (fs->groups[group].desc->free_inode_count) break;
      group++;
      if (group >= fs->super->group_count) group = 0;
    }
  }

  // Get inode bitmap
  buf = get_buffer(fs->cache, fs->groups[group].desc->inode_bitmap_block);
  if (!buf) return NOINODE;

  // Find first free inode in block
  if (fs->groups[group].first_free_inode != -1)
    ino = find_next_zero_bit(buf->data, fs->super->inodes_per_group, fs->groups[group].first_free_inode);
  else
  {
    ino = find_first_zero_bit(buf->data, fs->super->inodes_per_group);
    fs->groups[group].first_free_inode = ino;
  }

  if (ino == fs->super->inodes_per_group)
  {
    release_buffer(fs->cache, buf);
    panic("inode table full");
    return NOINODE;
  }

  // Mark inode as used
  set_bit(buf->data, ino);
  mark_buffer_updated(fs->cache, buf);

  fs->super->free_inode_count--;
  fs->super_dirty = 1;

  if (fs->groups[group].first_free_inode == ino) fs->groups[group].first_free_inode = ino + 1;
  fs->groups[group].desc->free_inode_count--;
  mark_group_desc_dirty(fs, group);

  release_buffer(fs->cache, buf);
  ino += group * fs->super->inodes_per_group;

  return ino;
}

void free_inode(struct filsys *fs, ino_t ino)
{
  unsigned int group;
  struct buf *buf;

  group = ino / fs->super->inodes_per_group;
  ino = ino % fs->super->inodes_per_group;

  buf = get_buffer(fs->cache, fs->groups[group].desc->inode_bitmap_block);
  if (!buf) return;

  clear_bit(buf->data, ino);
  mark_buffer_updated(fs->cache, buf);

  fs->super->free_inode_count++;
  fs->super_dirty = 1;

  if (fs->groups[group].first_free_inode > ino) fs->groups[group].first_free_inode = ino;
  fs->groups[group].desc->free_inode_count++;
  mark_group_desc_dirty(fs, group);

  release_buffer(fs->cache, buf);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美成人r级一区二区三区| 粉嫩av亚洲一区二区图片| www国产成人| 日韩欧美一二三区| 欧美日韩卡一卡二| 在线观看国产日韩| 色综合久久中文综合久久97| av成人动漫在线观看| 99久久99久久精品免费观看| 成人免费毛片高清视频| 成人中文字幕在线| 成人激情小说网站| 91丝袜国产在线播放| 91首页免费视频| 欧美在线高清视频| 欧美日韩精品一区二区在线播放| 91国偷自产一区二区开放时间| 91理论电影在线观看| 欧美午夜精品免费| 欧美日韩国产区一| 欧美一区二区视频在线观看| 6080日韩午夜伦伦午夜伦| 日韩欧美国产系列| 久久久www成人免费毛片麻豆 | 久久99精品国产91久久来源| 日本视频一区二区| 国产69精品久久99不卡| 99视频精品免费视频| 日本大香伊一区二区三区| 欧美三级日韩三级国产三级| 欧美一区二区三区免费观看视频| 精品国产乱码久久久久久1区2区| 欧美激情一区不卡| 亚洲狠狠爱一区二区三区| 精品一区二区三区在线播放| 国产成人精品三级麻豆| 在线观看一区二区精品视频| 国产女同互慰高潮91漫画| 国产精品系列在线| 首页国产丝袜综合| 成人国产精品免费网站| 欧美日韩精品一区二区天天拍小说 | 亚洲gay无套男同| 久久精品国产精品亚洲红杏| 成人精品在线视频观看| 日韩一区二区电影在线| 中文字幕在线观看一区二区| 婷婷六月综合网| 成人激情黄色小说| 欧美日韩久久一区| 国产精品三级电影| 免费成人美女在线观看.| 色综合久久久久网| 久久久www成人免费毛片麻豆| 亚洲一区二区三区精品在线| 国产91综合一区在线观看| 欧美群妇大交群中文字幕| 国产精品三级av在线播放| 久久99精品久久久久婷婷| 欧美视频一区在线| 国产精品成人免费精品自在线观看| 视频精品一区二区| 99re这里只有精品视频首页| 久久久精品影视| 久久99精品久久久久| 欧美日韩不卡一区二区| 亚洲三级电影网站| 国产69精品久久99不卡| 久久久久久久久久久电影| 免费成人美女在线观看| 欧美日韩精品一区二区三区蜜桃 | 成人国产精品免费网站| 日韩西西人体444www| 亚洲成人av一区二区| 欧洲精品一区二区三区在线观看| 欧美国产欧美综合| 国产成人aaa| 欧美国产日韩精品免费观看| 国产精品资源网站| 久久久久国产精品厨房| 美国精品在线观看| 欧美一区日本一区韩国一区| 亚洲成人久久影院| 欧美男女性生活在线直播观看| 亚洲欧美另类小说| 色综合视频一区二区三区高清| 亚洲色图欧美在线| 色丁香久综合在线久综合在线观看| 国产精品第四页| 91视频.com| 亚洲在线免费播放| 欧美日韩激情在线| 奇米精品一区二区三区四区| 日韩一级免费观看| 国产精品影视网| 国产精品视频在线看| 一本色道久久加勒比精品 | 成人激情免费电影网址| 国产精品久久夜| 在线精品观看国产| 男人操女人的视频在线观看欧美| 欧美成人激情免费网| 国产精品一区二区在线观看网站| 中文幕一区二区三区久久蜜桃| 成人手机电影网| 一区二区三区高清不卡| 欧美日韩国产综合一区二区三区| 毛片av一区二区三区| 国产午夜精品久久久久久久| 成人h动漫精品一区二区| 亚洲另类色综合网站| 欧美日产国产精品| 国产电影精品久久禁18| 亚洲情趣在线观看| 精品久久久久久久久久久久包黑料 | 精品国精品国产| 99久久综合狠狠综合久久| 亚洲自拍偷拍图区| 精品电影一区二区| 成人av电影在线| 日韩电影免费在线看| 亚洲国产高清在线观看视频| 在线观看日韩高清av| 韩国精品一区二区| 亚洲愉拍自拍另类高清精品| 久久综合精品国产一区二区三区| 成人午夜激情视频| 日韩高清不卡一区| 综合久久一区二区三区| 日韩精品综合一本久道在线视频| 99国产精品久久久久| 蜜桃91丨九色丨蝌蚪91桃色| 亚洲视频免费看| 久久免费电影网| 欧美日韩一级视频| av亚洲精华国产精华| 另类调教123区 | 一区二区三区 在线观看视频| 欧美精品一区二区三区蜜桃| 欧美日韩国产综合久久| 成人av资源下载| 国产一区二区免费视频| 日韩精品亚洲一区| 一区二区三区自拍| 亚洲欧美色综合| 国产欧美日韩三区| 精品区一区二区| 日韩精品自拍偷拍| 欧美一级高清大全免费观看| 欧美视频一二三区| 日本韩国欧美一区二区三区| 99久久99久久精品国产片果冻 | 欧美精品一区二区久久婷婷| 9191国产精品| 欧美蜜桃一区二区三区| 欧美日韩在线播放一区| 欧美性大战久久| 色婷婷久久99综合精品jk白丝| www.欧美精品一二区| 粉嫩一区二区三区在线看| 国产白丝精品91爽爽久久| 国产精品影视网| 国产精品一区二区视频| 处破女av一区二区| 福利视频网站一区二区三区| 国产精品白丝jk黑袜喷水| 国产精品亚洲视频| 国产成人精品三级| 99久久国产综合色|国产精品| 91丝袜美腿高跟国产极品老师 | 亚洲国产精品激情在线观看| 中文字幕第一区| 亚洲三级电影全部在线观看高清| 亚洲欧洲另类国产综合| 亚洲嫩草精品久久| 天堂在线一区二区| 精品一区二区三区视频在线观看| 久久91精品久久久久久秒播| 国产成人久久精品77777最新版本| 国产成人精品免费| 99在线精品一区二区三区| 色偷偷成人一区二区三区91 | 日本美女一区二区三区| 免费在线观看视频一区| 国产成人av影院| 欧美专区在线观看一区| 日韩一区二区三区在线| 久久精品一区二区三区不卡| 亚洲精品乱码久久久久久久久| 日韩中文字幕一区二区三区| 国产一区二区在线视频| 99精品偷自拍| 欧美电影免费观看高清完整版在线观看| 久久久久久亚洲综合| 一区二区日韩电影| 激情深爱一区二区| 色婷婷亚洲精品| 久久免费视频一区| 性做久久久久久久久| 国产盗摄精品一区二区三区在线|