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

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

?? rw.c

?? 一個類似windows
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*
 * 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
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲男同性视频| 丁香激情综合国产| 91超碰这里只有精品国产| 一区二区三区四区中文字幕| 色先锋资源久久综合| 日韩毛片在线免费观看| 91美女在线视频| 香蕉久久一区二区不卡无毒影院| 欧美性videosxxxxx| 欧美a一区二区| 欧美精品一区二区在线观看| 国产成人av电影在线| 亚洲男女一区二区三区| 欧美伦理影视网| 国产一区二区伦理片| 中文字幕一区二区不卡| 欧美日韩和欧美的一区二区| 日韩av二区在线播放| 久久精品一区二区三区不卡| 91免费在线视频观看| 视频一区中文字幕| 国产日韩欧美精品在线| 欧美午夜片在线观看| 久久99久国产精品黄毛片色诱| 中文字幕不卡一区| 欧美日韩精品一区二区三区| 国产一区二区三区四区五区美女| 国产精品美女久久久久久2018| 欧美午夜精品电影| 国产一区二区女| 亚洲bt欧美bt精品777| 久久免费精品国产久精品久久久久| 99免费精品在线| 麻豆精品在线播放| 亚洲日本乱码在线观看| 精品国产伦一区二区三区免费 | 成人免费观看av| 午夜久久福利影院| 国产精品免费视频观看| 欧美一区二区在线免费观看| 99精品黄色片免费大全| 久草在线在线精品观看| 亚洲女厕所小便bbb| 国产色综合久久| 欧美一区二区三区婷婷月色| 99综合影院在线| 国产做a爰片久久毛片| 亚洲午夜在线视频| 中文字幕一区日韩精品欧美| 精品久久久久久久久久久院品网 | 午夜影院久久久| 国产精品久久久久久一区二区三区 | 日本精品裸体写真集在线观看 | 91麻豆自制传媒国产之光| 极品美女销魂一区二区三区 | 26uuu久久综合| 欧美日韩午夜在线视频| 91麻豆国产精品久久| 国产精品羞羞答答xxdd| 男女男精品视频网| 亚洲成人手机在线| 亚洲精品中文在线观看| 亚洲国产精品激情在线观看| 2024国产精品| 精品国产免费人成在线观看| 欧美一区二区三区四区五区| 在线不卡中文字幕播放| 欧美日本一道本在线视频| 欧美综合亚洲图片综合区| 不卡欧美aaaaa| 成人免费av在线| 岛国av在线一区| 成人av在线网站| 成人精品高清在线| 岛国精品在线观看| 91网站视频在线观看| av激情亚洲男人天堂| av亚洲精华国产精华| 99久久精品情趣| 成人h动漫精品一区二| 成人免费毛片aaaaa**| 成人黄色在线看| 97久久精品人人做人人爽50路| www.欧美色图| 91视频观看免费| 一本大道综合伊人精品热热| 日本伦理一区二区| 欧美日韩成人综合在线一区二区| 欧美日韩午夜在线| 日韩免费成人网| 国产偷国产偷亚洲高清人白洁 | 亚洲一区二区三区国产| 亚洲一区在线视频观看| 午夜精品成人在线视频| 蜜臀av性久久久久蜜臀aⅴ| 国内精品不卡在线| 成人h版在线观看| 色综合久久88色综合天天| 欧美日韩一区二区三区在线| 欧美一区在线视频| 国产精品天干天干在线综合| 亚洲免费资源在线播放| 午夜欧美一区二区三区在线播放| 蜜臀av一区二区| 国产成都精品91一区二区三| 欧美亚洲禁片免费| 精品久久久久久亚洲综合网| 中国av一区二区三区| 亚洲二区视频在线| 国产在线不卡一区| 91免费国产在线| 日韩三级视频在线观看| 中文字幕久久午夜不卡| 亚洲成人手机在线| 国产美女久久久久| 在线观看91视频| 精品国产a毛片| 一区二区三区成人在线视频| 卡一卡二国产精品| 色婷婷一区二区三区四区| 日韩精品一区二区三区在线播放| 国产精品国产三级国产普通话99 | 自拍偷拍亚洲激情| 久久精品999| 色悠悠久久综合| 日韩欧美高清dvd碟片| 亚洲区小说区图片区qvod| 久久激情五月婷婷| 精品视频1区2区| 国产精品色在线| 毛片av一区二区| 91久久精品网| 国产欧美日韩在线| 美女免费视频一区二区| 在线国产亚洲欧美| 国产精品久久久99| 国产麻豆精品一区二区| 7777精品伊人久久久大香线蕉经典版下载 | 在线观看日产精品| 国产丝袜在线精品| 欧美96一区二区免费视频| 91久久精品一区二区三区| 欧美国产欧美综合| 精品一二三四在线| 日韩视频一区二区三区| 亚洲成人自拍偷拍| 色综合久久精品| 国产精品毛片久久久久久久| 九九九精品视频| 日韩无一区二区| 日韩va亚洲va欧美va久久| 91成人免费网站| 伊人色综合久久天天人手人婷| zzijzzij亚洲日本少妇熟睡| 国产无一区二区| 国产成人在线视频播放| 欧美精品一区二区三区蜜臀 | 国产精品色眯眯| 国产乱人伦偷精品视频不卡| 欧美电影免费观看高清完整版在线观看| 一二三区精品视频| 在线免费不卡电影| 亚洲综合色噜噜狠狠| 91福利在线观看| 亚洲午夜久久久久久久久久久 | 波多野结衣在线一区| 久久嫩草精品久久久精品| 激情深爱一区二区| 久久久国际精品| 国产成人精品午夜视频免费| 国产香蕉久久精品综合网| 国产精品一区一区三区| 欧美国产视频在线| 99re成人在线| 一区二区三区不卡视频| 欧美日韩在线播| 蜜臀av亚洲一区中文字幕| 精品久久久久久久久久久久久久久久久 | 欧美日韩精品一区视频| 热久久国产精品| 91在线观看地址| 国产成人午夜片在线观看高清观看| 亚洲一区二区三区精品在线| 青青草伊人久久| 国产日产亚洲精品系列| 91国产精品成人| 99国产精品99久久久久久| 免费人成网站在线观看欧美高清| 美洲天堂一区二卡三卡四卡视频| 国产精品麻豆视频| 亚洲精品欧美在线| 青青草国产精品97视觉盛宴 | 日韩在线卡一卡二| 色成人在线视频| 欧美一三区三区四区免费在线看 | 亚洲综合区在线| 国产欧美一区二区精品久导航| 337p亚洲精品色噜噜噜| 色偷偷久久人人79超碰人人澡| 日本aⅴ精品一区二区三区 |