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

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

?? rw.c

?? ReactOS是一些高手根據(jù)Windows XP的內(nèi)核編寫出的類XP。內(nèi)核實(shí)現(xiàn)機(jī)理和API函數(shù)調(diào)用幾乎相同。甚至可以兼容XP的程序。喜歡研究系統(tǒng)內(nèi)核的人可以看一看。
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
/*
 * COPYRIGHT:        See COPYING in the top level directory
 * PROJECT:          ReactOS kernel
 * FILE:             drivers/fs/vfat/rw.c
 * PURPOSE:          VFAT Filesystem
 * PROGRAMMER:       Jason Filby (jasonfilby@yahoo.com)
 *
 */

/* INCLUDES *****************************************************************/

#define NDEBUG
#include "vfat.h"

/*
 * Uncomment to enable strict verification of cluster/offset pair
 * caching. If this option is enabled you lose all the benefits of
 * the caching and the read/write operations will actually be
 * slower. It's meant only for debugging!!!
 * - Filip Navara, 26/07/2004
 */
/* #define DEBUG_VERIFY_OFFSET_CACHING */

/* FUNCTIONS *****************************************************************/

NTSTATUS
NextCluster(PDEVICE_EXTENSION DeviceExt,
	    ULONG FirstCluster,
	    PULONG CurrentCluster,
	    BOOLEAN Extend)
     /*
      * Return the next cluster in a FAT chain, possibly extending the chain if
      * necessary
      */
{
 if (FirstCluster == 1)
    {
      (*CurrentCluster) += DeviceExt->FatInfo.SectorsPerCluster;
      return(STATUS_SUCCESS);
    }
  else
    {
      if (Extend)
        return GetNextClusterExtend(DeviceExt, (*CurrentCluster), CurrentCluster);
      else
        return GetNextCluster(DeviceExt, (*CurrentCluster), CurrentCluster);
    }
}

NTSTATUS
OffsetToCluster(PDEVICE_EXTENSION DeviceExt,
		ULONG FirstCluster,
		ULONG FileOffset,
		PULONG Cluster,
		BOOLEAN Extend)
     /*
      * Return the cluster corresponding to an offset within a file,
      * possibly extending the file if necessary
      */
{
  ULONG CurrentCluster;
  ULONG i;
  NTSTATUS Status;
/*
  DPRINT("OffsetToCluster(DeviceExt %x, Fcb %x, FirstCluster %x,"
         " FileOffset %x, Cluster %x, Extend %d)\n", DeviceExt,
         Fcb, FirstCluster, FileOffset, Cluster, Extend);
*/
  if (FirstCluster == 0)
  {
    DbgPrint("OffsetToCluster is called with FirstCluster = 0!\n");
    KEBUGCHECK(0);
  }

  if (FirstCluster == 1)
    {
      /* root of FAT16 or FAT12 */
      *Cluster = DeviceExt->FatInfo.rootStart + FileOffset
	/ (DeviceExt->FatInfo.BytesPerCluster) * DeviceExt->FatInfo.SectorsPerCluster;
      return(STATUS_SUCCESS);
    }
  else
    {
      CurrentCluster = FirstCluster;
      if (Extend)
        {
          for (i = 0; i < FileOffset / DeviceExt->FatInfo.BytesPerCluster; i++)
            {
              Status = GetNextClusterExtend (DeviceExt, CurrentCluster, &CurrentCluster);
              if (!NT_SUCCESS(Status))
                return(Status);
    	    }
          *Cluster = CurrentCluster;
       }
     else
        {
          for (i = 0; i < FileOffset / DeviceExt->FatInfo.BytesPerCluster; i++)
            {
              Status = GetNextCluster (DeviceExt, CurrentCluster, &CurrentCluster);
              if (!NT_SUCCESS(Status))
                return(Status);
    	    }
          *Cluster = CurrentCluster;
       }
     return(STATUS_SUCCESS);
   }
}

static NTSTATUS
VfatReadFileData (PVFAT_IRP_CONTEXT IrpContext,
                  ULONG Length,
		  LARGE_INTEGER ReadOffset,
		  PULONG LengthRead)
/*
 * FUNCTION: Reads data from a file
 */
{
  ULONG CurrentCluster;
  ULONG FirstCluster;
  ULONG StartCluster;
  ULONG ClusterCount;
  LARGE_INTEGER StartOffset;
  PDEVICE_EXTENSION DeviceExt;
  BOOLEAN First = TRUE;
  PVFATFCB Fcb;
  PVFATCCB Ccb;
  NTSTATUS Status;
  ULONG BytesDone;
  ULONG BytesPerSector;
  ULONG BytesPerCluster;
  ULONG LastCluster;
  ULONG LastOffset;

  /* PRECONDITION */
  ASSERT(IrpContext);
  DeviceExt = IrpContext->DeviceExt;
  ASSERT(DeviceExt);
  ASSERT(DeviceExt->FatInfo.BytesPerCluster);
  ASSERT(IrpContext->FileObject);
  ASSERT(IrpContext->FileObject->FsContext2 != NULL);

  DPRINT("VfatReadFileData(DeviceExt %x, FileObject %x, "
	 "Length %d, ReadOffset 0x%I64x)\n", DeviceExt,
	 IrpContext->FileObject, Length, ReadOffset.QuadPart);

  *LengthRead = 0;

  Ccb = (PVFATCCB)IrpContext->FileObject->FsContext2;
  Fcb = IrpContext->FileObject->FsContext;
  BytesPerSector = DeviceExt->FatInfo.BytesPerSector;
  BytesPerCluster = DeviceExt->FatInfo.BytesPerCluster;

  ASSERT(ReadOffset.QuadPart + Length <= ROUND_UP(Fcb->RFCB.FileSize.QuadPart, BytesPerSector));
  ASSERT(ReadOffset.u.LowPart % BytesPerSector == 0);
  ASSERT(Length % BytesPerSector == 0);

  /* Is this a read of the FAT? */
  if (Fcb->Flags & FCB_IS_FAT)
  {
    ReadOffset.QuadPart += DeviceExt->FatInfo.FATStart * BytesPerSector;
    Status = VfatReadDiskPartial(IrpContext, &ReadOffset, Length, 0, TRUE);

    if (NT_SUCCESS(Status))
    {
      *LengthRead = Length;
    }
    else
    {
      DPRINT1("FAT reading failed, Status %x\n", Status);
    }
    return Status;
  }
  /* Is this a read of the Volume ? */
  if (Fcb->Flags & FCB_IS_VOLUME)
  {
    Status = VfatReadDiskPartial(IrpContext, &ReadOffset, Length, 0, TRUE);
    if (NT_SUCCESS(Status))
    {
      *LengthRead = Length;
    }
    else
    {
      DPRINT1("Volume reading failed, Status %x\n", Status);
    }
    return Status;
  }

  /*
   * Find the first cluster
   */
  FirstCluster = CurrentCluster =
    vfatDirEntryGetFirstCluster (DeviceExt, &Fcb->entry);

  if (FirstCluster == 1)
  {
    // Directory of FAT12/16 needs a special handling
    CHECKPOINT;
    if (ReadOffset.u.LowPart + Length > DeviceExt->FatInfo.rootDirectorySectors * BytesPerSector)
    {
      Length = DeviceExt->FatInfo.rootDirectorySectors * BytesPerSector - ReadOffset.u.LowPart;
    }
    ReadOffset.u.LowPart += DeviceExt->FatInfo.rootStart * BytesPerSector;

    // Fire up the read command

    Status = VfatReadDiskPartial (IrpContext, &ReadOffset, Length, 0, TRUE);
    if (NT_SUCCESS(Status))
    {
      *LengthRead = Length;
    }
    return Status;
  }

  ExAcquireFastMutex(&Fcb->LastMutex);
  LastCluster = Fcb->LastCluster;
  LastOffset = Fcb->LastOffset;
  ExReleaseFastMutex(&Fcb->LastMutex);

  /*
   * Find the cluster to start the read from
   */
  if (LastCluster > 0 && ReadOffset.u.LowPart >= LastOffset)
  {
    Status = OffsetToCluster(DeviceExt, LastCluster,
                             ROUND_DOWN(ReadOffset.u.LowPart, BytesPerCluster) -
                             LastOffset,
                             &CurrentCluster, FALSE);
#ifdef DEBUG_VERIFY_OFFSET_CACHING
    /* DEBUG VERIFICATION */
    {
      ULONG CorrectCluster;
      OffsetToCluster(DeviceExt, FirstCluster,
                      ROUND_DOWN(ReadOffset.u.LowPart, BytesPerCluster),
                      &CorrectCluster, FALSE);
      if (CorrectCluster != CurrentCluster)
        KEBUGCHECK(FAT_FILE_SYSTEM);
    }
#endif
  }
  else
  {
    Status = OffsetToCluster(DeviceExt, FirstCluster,
                             ROUND_DOWN(ReadOffset.u.LowPart, BytesPerCluster),
                             &CurrentCluster, FALSE);
  }
  if (!NT_SUCCESS(Status))
  {
    return(Status);
  }

  ExAcquireFastMutex(&Fcb->LastMutex);
  Fcb->LastCluster = CurrentCluster;
  Fcb->LastOffset = ROUND_DOWN (ReadOffset.u.LowPart, BytesPerCluster);
  ExReleaseFastMutex(&Fcb->LastMutex);

  KeInitializeEvent(&IrpContext->Event, NotificationEvent, FALSE);
  IrpContext->RefCount = 1;

  while (Length > 0 && CurrentCluster != 0xffffffff)
  {
    StartCluster = CurrentCluster;
    StartOffset.QuadPart = ClusterToSector(DeviceExt, StartCluster) * BytesPerSector;
    BytesDone = 0;
    ClusterCount = 0;

    do
    {
      ClusterCount++;
      if (First)
      {
        BytesDone =  min (Length, BytesPerCluster - (ReadOffset.u.LowPart % BytesPerCluster));
      	StartOffset.QuadPart += ReadOffset.u.LowPart % BytesPerCluster;
      	First = FALSE;
      }
      else
      {
      	if (Length - BytesDone > BytesPerCluster)
      	{
      	  BytesDone += BytesPerCluster;
      	}
      	else
      	{
      	  BytesDone = Length;
      	}
      }
      Status = NextCluster(DeviceExt, FirstCluster, &CurrentCluster, FALSE);
    }
    while (StartCluster + ClusterCount == CurrentCluster && NT_SUCCESS(Status) && Length > BytesDone);
    DPRINT("start %08x, next %08x, count %d\n",
           StartCluster, CurrentCluster, ClusterCount);

    ExAcquireFastMutex(&Fcb->LastMutex);
    Fcb->LastCluster = StartCluster + (ClusterCount - 1);
    Fcb->LastOffset = ROUND_DOWN(ReadOffset.u.LowPart, BytesPerCluster) + (ClusterCount - 1) * BytesPerCluster;
    ExReleaseFastMutex(&Fcb->LastMutex);

    // Fire up the read command
    Status = VfatReadDiskPartial (IrpContext, &StartOffset, BytesDone, *LengthRead, FALSE);
    if (!NT_SUCCESS(Status) && Status != STATUS_PENDING)
      {
        break;
      }
    *LengthRead += BytesDone;
    Length -= BytesDone;
    ReadOffset.u.LowPart += BytesDone;
  }
  if (0 != InterlockedDecrement((PLONG)&IrpContext->RefCount))
    {
      KeWaitForSingleObject(&IrpContext->Event, Executive, KernelMode, FALSE, NULL);
    }
  if (NT_SUCCESS(Status) || Status == STATUS_PENDING)
    {
      if (Length > 0)
        {
	  Status = STATUS_UNSUCCESSFUL;
	}
      else
        {
          Status = IrpContext->Irp->IoStatus.Status;
	}
    }
  return Status;
}

static NTSTATUS
VfatWriteFileData(PVFAT_IRP_CONTEXT IrpContext,
		  ULONG Length,
		  LARGE_INTEGER WriteOffset)
{
   PDEVICE_EXTENSION DeviceExt;
   PVFATFCB Fcb;
   PVFATCCB Ccb;
   ULONG Count;
   ULONG FirstCluster;
   ULONG CurrentCluster;
   ULONG BytesDone;
   ULONG StartCluster;
   ULONG ClusterCount;
   NTSTATUS Status = STATUS_SUCCESS;
   BOOLEAN First = TRUE;
   ULONG BytesPerSector;
   ULONG BytesPerCluster;
   LARGE_INTEGER StartOffset;
   ULONG BufferOffset;
   ULONG LastCluster;
   ULONG LastOffset;

   /* PRECONDITION */
   ASSERT(IrpContext);
   DeviceExt = IrpContext->DeviceExt;
   ASSERT(DeviceExt);
   ASSERT(DeviceExt->FatInfo.BytesPerCluster);
   ASSERT(IrpContext->FileObject);
   ASSERT(IrpContext->FileObject->FsContext2 != NULL);

   Ccb = (PVFATCCB)IrpContext->FileObject->FsContext2;
   Fcb = IrpContext->FileObject->FsContext;
   BytesPerCluster = DeviceExt->FatInfo.BytesPerCluster;
   BytesPerSector = DeviceExt->FatInfo.BytesPerSector;

   DPRINT("VfatWriteFileData(DeviceExt %x, FileObject %x, "
	  "Length %d, WriteOffset 0x%I64x), '%wZ'\n", DeviceExt,
	  IrpContext->FileObject, Length, WriteOffset,
	  &Fcb->PathNameU);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲电影在线免费观看| 欧美一区二区三区思思人| 欧美性生活大片视频| 日韩一区二区三区高清免费看看 | 日韩在线a电影| 精品在线亚洲视频| 99re免费视频精品全部| 91精品欧美久久久久久动漫| 国产欧美日韩亚州综合| 亚洲一区成人在线| 国产黄色成人av| 91精品91久久久中77777| 精品久久人人做人人爽| 亚洲美女视频在线| 久久国产精品99精品国产| 94-欧美-setu| 久久一二三国产| 亚洲一区二区精品视频| 国产成人免费视频网站 | 蜜臀a∨国产成人精品| 99在线热播精品免费| 欧美一区二区黄色| 玉足女爽爽91| 国产激情视频一区二区在线观看 | 亚洲电影一区二区三区| 国产精品77777| 欧美久久久久久蜜桃| 中文字幕一区免费在线观看| 日本va欧美va精品| 色悠悠亚洲一区二区| 久久精品一区八戒影视| 日本vs亚洲vs韩国一区三区| 色视频一区二区| 国产女同互慰高潮91漫画| 蜜臀av性久久久久蜜臀aⅴ流畅 | 亚洲成人av在线电影| 成人小视频免费在线观看| 日韩精品中午字幕| 亚洲图片欧美色图| 色婷婷国产精品| 国产精品高潮呻吟| 国产精品99久久久久久久vr| 日韩亚洲欧美中文三级| 性欧美大战久久久久久久久| av在线一区二区| 国产午夜亚洲精品午夜鲁丝片 | 久久中文字幕电影| 日韩黄色一级片| 欧美日韩亚洲高清一区二区| 亚洲日本在线a| 972aa.com艺术欧美| 日本一二三四高清不卡| 国产麻豆视频精品| 欧美tickle裸体挠脚心vk| 青青草国产精品亚洲专区无| 欧美日韩视频在线第一区| 亚洲精品日日夜夜| 91在线视频观看| 欧美高清在线精品一区| 国产成人午夜片在线观看高清观看| 日韩欧美国产一区在线观看| 日韩国产欧美在线视频| 欧美日韩国产高清一区| 亚洲成人综合网站| 欧美日韩久久久| 午夜欧美在线一二页| 欧美日韩一区二区在线观看视频| 亚洲男帅同性gay1069| 色综合夜色一区| 一区二区三区产品免费精品久久75 | 欧美日本国产一区| 午夜伊人狠狠久久| 欧美精品第一页| 日韩不卡一区二区三区| 91精品国产麻豆国产自产在线 | 欧美大肚乱孕交hd孕妇| 麻豆高清免费国产一区| 精品88久久久久88久久久| 国产一区二区三区久久久| 国产日韩欧美一区二区三区综合| 国产白丝精品91爽爽久久| 国产精品二三区| 色狠狠色狠狠综合| 午夜欧美在线一二页| 日韩三级在线观看| 国内精品国产成人| 日本一区二区视频在线| 99re热视频精品| 亚洲国产wwwccc36天堂| 91精品欧美一区二区三区综合在| 日本不卡不码高清免费观看 | 成人免费精品视频| 亚洲美女视频在线| 4438x亚洲最大成人网| 久久99精品久久久久久动态图| 久久精品无码一区二区三区| 99久久精品国产精品久久| 亚洲小说春色综合另类电影| 欧美一级专区免费大片| 国产不卡一区视频| 一区二区三区免费在线观看| 91精品在线麻豆| 国产精品一二三四| 亚洲自拍都市欧美小说| 日韩一本二本av| a美女胸又www黄视频久久| 污片在线观看一区二区| 欧美精品一区二区三区一线天视频| 高清视频一区二区| 亚洲妇熟xx妇色黄| 久久久www成人免费毛片麻豆| 91在线视频官网| 蜜臀av性久久久久av蜜臀妖精| 国产精品素人视频| 欧美日韩国产首页| 高清av一区二区| 午夜一区二区三区视频| 国产欧美日韩综合精品一区二区| 91成人看片片| 国产成人三级在线观看| 亚洲成人第一页| 国产精品亲子乱子伦xxxx裸| 欧美日韩成人高清| 成人免费视频网站在线观看| 五月天视频一区| 欧美国产精品中文字幕| 91精品婷婷国产综合久久竹菊| www.亚洲国产| 麻豆国产欧美日韩综合精品二区| 亚洲同性gay激情无套| 日韩午夜激情视频| 色哟哟一区二区在线观看| 国内精品视频一区二区三区八戒| 亚洲精品免费播放| 国产婷婷精品av在线| 欧美一区二区三区思思人| 色综合婷婷久久| 大陆成人av片| 美女久久久精品| 亚洲午夜成aⅴ人片| 国产精品麻豆视频| 欧美成人一区二区三区片免费| 色综合一个色综合亚洲| 国产成人精品三级麻豆| 日本成人在线网站| 亚洲一区精品在线| 亚洲欧美综合网| 久久久91精品国产一区二区精品| 91.成人天堂一区| 在线中文字幕一区| 99久久久久久| 国产69精品久久777的优势| 久久国产精品区| 免费欧美在线视频| 天堂成人国产精品一区| 亚洲激情在线激情| 国产精品免费人成网站| 国产欧美一区在线| 国产午夜精品久久| 久久日韩精品一区二区五区| 日韩你懂的在线播放| 欧美一区二区福利在线| 欧美日韩在线播放一区| 欧美在线制服丝袜| 在线观看av一区二区| 99国产欧美另类久久久精品| 成人美女在线观看| 国产不卡视频在线观看| av一区二区三区黑人| 激情六月婷婷久久| 奇米一区二区三区av| 人人爽香蕉精品| 奇米777欧美一区二区| 五月天激情综合| 日本成人在线一区| 另类欧美日韩国产在线| 免费亚洲电影在线| 免费在线观看一区| 久久精品国产一区二区| 久草热8精品视频在线观看| 另类专区欧美蜜桃臀第一页| 免费观看日韩电影| 精品亚洲成av人在线观看| 国产精品一区二区视频| 国产不卡视频一区| 北岛玲一区二区三区四区| 91浏览器在线视频| 91黄色激情网站| 欧美日高清视频| 91精品国产免费久久综合| 欧美成人video| 国产区在线观看成人精品| 国产精品美女久久久久久久网站| √…a在线天堂一区| 亚洲综合一区二区精品导航| 午夜精品福利在线| 极品少妇一区二区| 成人精品免费看| 97久久精品人人澡人人爽| 在线观看一区二区精品视频|