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

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

?? rw.c

?? ReactOS是一些高手根據(jù)Windows XP的內(nèi)核編寫(xiě)出的類(lè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);

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品福利在线一区二区三区| 美女视频黄免费的久久 | 色婷婷av久久久久久久| 91精品啪在线观看国产60岁| 99精品视频一区二区三区| 欧美精品 国产精品| 亚洲色图制服诱惑| 久久se精品一区二区| 欧美三级蜜桃2在线观看| 99国产精品久久久久久久久久| 精品捆绑美女sm三区| 国产性做久久久久久| 亚洲福利一二三区| 成人av在线资源网站| 91色乱码一区二区三区| 日韩欧美在线观看一区二区三区| 亚洲欧美一区二区三区极速播放| 国产精品综合在线视频| 欧美一级二级三级乱码| 五月综合激情网| 欧美亚洲国产一卡| 日韩伦理免费电影| 99久久精品国产导航| 欧美激情一区二区三区不卡| 黄色资源网久久资源365| 91精品国产福利在线观看| 欧美三级韩国三级日本一级| 欧美日韩1区2区| 亚洲国产精品视频| 欧美在线高清视频| 亚洲成人黄色小说| 精品视频在线免费看| 亚洲国产欧美日韩另类综合 | 日本道色综合久久| 国产精品国产馆在线真实露脸| 国产美女精品在线| 国产日产欧产精品推荐色| 国产美女精品一区二区三区| 色先锋资源久久综合| 精品久久久久99| 久久久不卡网国产精品二区| 激情文学综合丁香| 国产在线播精品第三| 久久色在线观看| 国产精品资源站在线| 94-欧美-setu| 一区二区三区成人在线视频| 欧美亚一区二区| 水蜜桃久久夜色精品一区的特点 | 国产精品一区二区久久不卡 | 一区二区三区在线观看视频 | 91免费精品国自产拍在线不卡| 亚洲欧洲精品一区二区精品久久久| 99精品国产99久久久久久白柏| 综合中文字幕亚洲| 欧美日韩久久久| 久久国产精品一区二区| 国产女同性恋一区二区| av男人天堂一区| 天堂va蜜桃一区二区三区| 精品国产乱码久久久久久老虎| 成人自拍视频在线| 亚洲一区免费观看| 337p日本欧洲亚洲大胆色噜噜| 亚洲欧美日韩久久| 欧美一区二区三区系列电影| 国产精品影视在线| 亚洲一级二级在线| 国产精品国产a| 日本女人一区二区三区| 国产欧美一区二区三区鸳鸯浴 | 国产精品一区二区你懂的| 亚洲免费在线播放| 精品91自产拍在线观看一区| 一区二区在线免费观看| 日韩天堂在线观看| 色噜噜狠狠成人网p站| 狠狠色丁香久久婷婷综合丁香| 国产精品国产三级国产三级人妇| 欧美精选在线播放| 不卡一区二区三区四区| 热久久国产精品| 亚洲男帅同性gay1069| 精品处破学生在线二十三| 欧洲色大大久久| 久久久久久久久一| 欧美精选午夜久久久乱码6080| jizzjizzjizz欧美| 精品无码三级在线观看视频 | 中文字幕一区二区三中文字幕| 制服丝袜一区二区三区| 欧美精品一区二区久久婷婷| 久久精品免费观看| 天天影视涩香欲综合网 | 亚洲国产精品欧美一二99| 国产欧美一区二区精品性色| 日韩欧美一区在线观看| 91麻豆精品91久久久久同性| 亚洲免费观看视频| 国产精品久久久久婷婷二区次| 欧美成人精精品一区二区频| 欧美精品v日韩精品v韩国精品v| 91美女在线视频| av高清久久久| 91女人视频在线观看| 波多野结衣中文字幕一区二区三区 | 精品毛片乱码1区2区3区 | 91理论电影在线观看| 国产精品系列在线观看| 国产原创一区二区| 韩国视频一区二区| 韩国一区二区在线观看| 国产一区二区不卡在线| 91福利国产精品| 国产资源在线一区| 国产麻豆9l精品三级站| 狠狠色丁香久久婷婷综合丁香| 久久av中文字幕片| 国产真实乱偷精品视频免| 国产中文字幕精品| 国产白丝精品91爽爽久久| 高清视频一区二区| av在线播放不卡| 色婷婷av一区二区三区大白胸| 色综合久久99| 欧美日韩国产首页| 日韩欧美国产wwwww| 精品日韩一区二区三区免费视频| 精品少妇一区二区三区在线播放| 久久久久成人黄色影片| 中文字幕制服丝袜一区二区三区| 一区二区中文字幕在线| 亚洲高清三级视频| 3751色影院一区二区三区| 欧美白人最猛性xxxxx69交| 久久新电视剧免费观看| 国产精品乱人伦| 亚洲成人激情自拍| 国内精品久久久久影院色| 成人午夜av电影| 日韩美女精品在线| 91精品国产综合久久久蜜臀图片| 欧美一区二区福利在线| 久久久一区二区| 亚洲视频在线一区观看| 五月婷婷综合网| 国产成人精品亚洲777人妖 | 欧美mv和日韩mv的网站| 亚洲国产高清不卡| 亚洲国产一区二区视频| 免费看日韩a级影片| 成人午夜大片免费观看| 欧美日韩成人高清| 国产偷国产偷精品高清尤物| 亚洲人成网站影音先锋播放| 日韩国产在线观看| 成人黄色免费短视频| 毛片一区二区三区| 成人97人人超碰人人99| 欧美视频一区二区三区四区| 精品不卡在线视频| 亚洲免费视频中文字幕| 国产麻豆一精品一av一免费 | 久久久精品免费观看| 青青草国产精品97视觉盛宴| 国产精品第13页| 麻豆专区一区二区三区四区五区| 成人97人人超碰人人99| 欧美成人aa大片| 一区二区三区四区视频精品免费| 久久精品噜噜噜成人88aⅴ| 色综合中文综合网| 偷拍自拍另类欧美| 91丨porny丨首页| 亚洲精品在线免费播放| 天天综合网 天天综合色| 色婷婷综合中文久久一本| 日韩久久久久久| 精品视频色一区| 亚洲欧美日本韩国| 国产精品 欧美精品| 欧美v日韩v国产v| 午夜精品免费在线| 欧美在线色视频| 亚洲丝袜制服诱惑| 成人动漫精品一区二区| 精品国产乱子伦一区| 91亚洲永久精品| 欧美一区二区三区播放老司机| 亚洲精品亚洲人成人网 | 欧美午夜视频网站| 亚洲少妇30p| 91在线一区二区三区| 国产欧美日韩另类一区| 国产一级精品在线| 久久久777精品电影网影网 | 久久综合综合久久综合| 欧美成人官网二区| 久久91精品久久久久久秒播| 日韩亚洲欧美在线|