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

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

?? volume.c

?? 從大量的wince源代碼中剝離出的fat文件系統(tǒng)源代碼.移植性非常高. 里面帶有source i.rar
?? C
?? 第 1 頁 / 共 5 頁
字號:

    if (!(pvol->v_pdsk->d_diActive.di_flags & DISK_INFO_FLAG_CHS_UNCERTAIN) &&
         (pvol->v_pdsk->d_diActive.di_heads != pbpb->oldBPB.BPB_Heads ||
          pvol->v_pdsk->d_diActive.di_sectors != pbpb->oldBPB.BPB_SectorsPerTrack)) {

        DEBUGMSG(ZONE_INIT || ZONE_ERRORS,
                 (DBGTEXT("FATFS!InitVolume: driver disagrees with BPB (BPB CHS=%d:%d:%d)\n"),
                  (pvol->v_csecTotal + pvol->v_secBlkBias) / (pbpb->oldBPB.BPB_Heads * pbpb->oldBPB.BPB_SectorsPerTrack),
                  pbpb->oldBPB.BPB_Heads,
                  pbpb->oldBPB.BPB_SectorsPerTrack));
    }
#endif

    // We've seen cases where the driver thinks there are fewer sectors on
    // the disk than the BPB does, which means that any I/O near the end of
    // the volume will probably fail.  So for now, we'll try to catch these
    // cases, report them, and then adjust our values to agree with the driver.

    if (pvol->v_pdsk->d_diActive.di_total_sectors < pvol->v_csecTotal + pvol->v_secBlkBias) {

        DEBUGMSG(ZONE_INIT || ZONE_ERRORS,
                 (DBGTEXT("FATFS!InitVolume: driver reports fewer sectors than BPB! (%d vs. %d)\n"),
                  pvol->v_pdsk->d_diActive.di_total_sectors, pvol->v_csecTotal + pvol->v_secBlkBias));

        pvol->v_csecTotal = pvol->v_pdsk->d_diActive.di_total_sectors - pvol->v_secBlkBias;
    }

    pvol->v_log2csecClus = Log2(pbpb->oldBPB.BPB_SectorsPerCluster);
    pvol->v_log2cbSec = Log2(pbpb->oldBPB.BPB_BytesPerSector);
    pvol->v_log2cblkSec = pvol->v_log2cbSec - BLOCK_LOG2;
    pvol->v_log2cblkClus = pvol->v_log2cblkSec + pvol->v_log2csecClus;
    pvol->v_cbClus = 1 << (pvol->v_log2cbSec   + pvol->v_log2csecClus);

    
#ifdef FAT32
    if (pbpb->oldBPB.BPB_SectorsPerFAT == 0) {

        pvol->v_serialID = pbgbs->bgbsVolumeID;
        memcpy(pvol->v_label, pbgbs->bgbsVolumeLabel, sizeof(pbgbs->bgbsVolumeLabel));

        pvol->v_csecFAT = pbpb->BGBPB_BigSectorsPerFAT;

        // Set up the FAT DSTREAM structure

        pvol->v_secEndFAT = pbpb->BGBPB_BigSectorsPerFAT * (pbpb->BGBPB_ExtFlags & BGBPB_F_ActiveFATMsk);
        pvol->v_secEndAllFATs = pbpb->BGBPB_BigSectorsPerFAT * pbpb->oldBPB.BPB_NumberOfFATs;

        pstmFAT->s_size = pbpb->BGBPB_BigSectorsPerFAT << pvol->v_log2cbSec;
        ASSERT(pstmFAT->s_run.r_start == 0);
        pstmFAT->s_run.r_end = pstmFAT->s_size;
        pstmFAT->s_run.r_blk = pvol->v_secEndFAT << pvol->v_log2cblkSec;

        pvol->v_secEndFAT += pbpb->BGBPB_BigSectorsPerFAT;

        // Set up the root directory DSTREAM structure

        pstmRoot->s_size = MAX_DIRSIZE;
        pstmRoot->s_clusFirst = pbpb->BGBPB_RootDirStrtClus;
        RewindStream(pstmRoot, INVALID_POS);

        pvol->v_csecUsed = pvol->v_secEndAllFATs;

        // Compute block bias for cluster 0.  The first data cluster is 2.

        pvol->v_blkClusBias = (pvol->v_csecUsed << pvol->v_log2cblkSec) -
                                  (DATA_CLUSTER << pvol->v_log2cblkClus);

        // Set the maximum cluster # supported for this volume;  it is the
        // smaller of 1) total clusters on the media and 2) total cluster entries
        // the FAT can contain.

        cmaxClus = pstmFAT->s_size/sizeof(DWORD) - DATA_CLUSTER;
        pvol->v_clusMax = ((pvol->v_csecTotal - pvol->v_csecUsed) >> pvol->v_log2csecClus);
        if (pvol->v_clusMax > cmaxClus) {
            DEBUGMSGBREAK(ZONE_INIT || ZONE_ERRORS,
                (DBGTEXT("FATFS!InitVolume: total clusters (%d) exceeds FAT32 size (%d), reducing...\n"), pvol->v_clusMax, cmaxClus));
            pvol->v_clusMax = cmaxClus;
        }
        pvol->v_clusMax++;      // now convert total clusters to max cluster #

        pvol->v_unpack = Unpack32;
        pvol->v_pack = Pack32;
        pvol->v_clusEOF = FAT32_EOF_MIN;

    } else
#endif  // FAT32
    {
        // 16-bit or 12-bit FAT volume

        PBOOTSEC pbs = (PBOOTSEC)pbgbs;

        pvol->v_serialID = pbs->bsVolumeID;
        memcpy(pvol->v_label, pbs->bsVolumeLabel, sizeof(pbs->bsVolumeLabel));

        pvol->v_csecFAT = pbpb->oldBPB.BPB_SectorsPerFAT;

        // Set up the FAT DSTREAM structure;  always assume that the first FAT
        // is the active one

        pvol->v_secEndFAT = pbpb->oldBPB.BPB_SectorsPerFAT;
        pvol->v_secEndAllFATs = pbpb->oldBPB.BPB_SectorsPerFAT * pbpb->oldBPB.BPB_NumberOfFATs;

        pstmFAT->s_size = pbpb->oldBPB.BPB_SectorsPerFAT << pvol->v_log2cbSec;
        ASSERT(pstmFAT->s_run.r_start == 0);
        pstmFAT->s_run.r_end = pstmFAT->s_size;
        pstmFAT->s_run.r_blk = 0;

        // Set up the root directory DSTREAM structure

        pstmRoot->s_size = pbpb->oldBPB.BPB_RootEntries * sizeof(DIRENTRY);
        pstmRoot->s_clusFirst = ROOT_PSEUDO_CLUSTER;
        pstmRoot->s_run.r_start = 0;
        pstmRoot->s_run.r_end = pstmRoot->s_size;
        pstmRoot->s_run.r_blk = pvol->v_secEndAllFATs << pvol->v_log2cblkSec;

        pvol->v_csecUsed = pvol->v_secEndAllFATs + ((pstmRoot->s_size + pbpb->oldBPB.BPB_BytesPerSector-1) >> pvol->v_log2cbSec);

        // Compute block bias for cluster 0.  The first data cluster is 2.

        pvol->v_blkClusBias = (pvol->v_csecUsed << pvol->v_log2cblkSec) -
                                  (DATA_CLUSTER << pvol->v_log2cblkClus);

        // clusMax is temporarily the total # of clusters, and cmaxClus is
        // temporarily the total number of BITS contained in the FAT (we'll divide
        // that by 12 or 16 as appropriate, and then use it to make sure clusMax is valid).

        pvol->v_clusMax = (pvol->v_csecTotal - pvol->v_csecUsed) >> pvol->v_log2csecClus;
        cmaxClus = pvol->v_csecFAT << (pvol->v_log2cbSec+3);    // add 3 to get # bits instead of # bytes

        if (pvol->v_clusMax >= FAT1216_THRESHOLD) {
            cmaxClus /= 16;
            pvol->v_flags |= VOLF_16BIT_FAT;
            pvol->v_unpack = Unpack16;
            pvol->v_pack = Pack16;
            pvol->v_clusEOF = FAT16_EOF_MIN;
        } else {
            cmaxClus /= 12;
            pvol->v_flags |= VOLF_12BIT_FAT;
            pvol->v_unpack = Unpack12;
            pvol->v_pack = Pack12;
            pvol->v_clusEOF = (pvol->v_clusMax < FAT12_EOF_SPECIAL-1)? FAT12_EOF_SPECIAL : FAT12_EOF_MIN;
        }

        // Set the maximum cluster # supported for this volume;  it is the
        // smaller of 1) total clusters on the media and 2) total cluster entries
        // the FAT can contain.

        cmaxClus -= DATA_CLUSTER;
        if (pvol->v_clusMax > cmaxClus) {
            DEBUGMSGBREAK(ZONE_INIT || ZONE_ERRORS,
                (DBGTEXT("FATFS!InitVolume: total clusters (%d) exceeds FAT size (%d), reducing...\n"), pvol->v_clusMax, cmaxClus));
            pvol->v_clusMax = cmaxClus;
        }
        pvol->v_clusMax++;      // now convert total clusters to max cluster #
    }

  exit:
    pvol->v_clusAlloc = pvol->v_cclusFree = UNKNOWN_CLUSTER;

    // If the FORMATTING bit is set and the volume is valid, then we assume that the volume
    // has just been reformatted, and therefore that the number of free clusters is the same
    // as total clusters.

    if ((pvol->v_flags & (VOLF_INVALID|VOLF_FORMATTING)) == VOLF_FORMATTING)
        pvol->v_cclusFree = pvol->v_clusMax-1;

    CloseStream(pstmRoot);
    CloseStream(pstmFAT);


#ifdef DISK_CACHING
    pvol->v_CacheSize = 0;
    pvol->v_pFATCacheBuffer = NULL;
    pvol->v_pFATCacheLookup = NULL;
    SetupDiskCache(pvol);
#endif
    
    
    return pstmFAT && pstmRoot;
}


/*  ValidateFATSector - Verify FAT sector has valid media ID
 *
 *  ENTRY
 *      pvol - pointer to VOLUME
 *      pvSector - pointer to memory containing FAT sector
 *
 *  EXIT
 *      TRUE if given FAT sector appears to be valid, FALSE if not
 */

BOOL ValidateFATSector(PVOLUME pvol, PVOID pvSector)
{
    DWORD dwMask;

    dwMask = 0xff0;
    if (pvol->v_bMediaDesc == MEDIA_HD)
        dwMask = 0xff8;

    if (pvol->v_flags & VOLF_16BIT_FAT)
        dwMask |= 0xfff0;
#ifdef FAT32
    else if (pvol->v_flags & VOLF_32BIT_FAT)
        dwMask |= 0x0ffffff0;
#endif
    else
        ASSERT(pvol->v_flags & VOLF_12BIT_FAT);

    if ((*(PDWORD)pvSector & dwMask) < dwMask)
        return FALSE;

    
    return TRUE;
}




PVOLUME FindVolume(PDSK pdsk, PBIGFATBOOTSEC pbgbs)
{
    PBIGFATBPB pbpb = &pbgbs->bgbsBPB;
    PVOLUME pvol = pdsk->pVol;

    ASSERT(OWNCRITICALSECTION(&csFATFS));

    if (!pvol) {
        pvol = (PVOLUME)LocalAlloc(LPTR, sizeof(VOLUME));
    } else {
        pvol->v_flags |= VOLF_REMOUNTED;
        return pvol;
    }    
    if (!pvol)
        DEBUGMSG(ZONE_INIT || ZONE_ERRORS,(DBGTEXT("FATFS!FindVolume: out of memory!\n")));
    else {
        DEBUGALLOC(sizeof(VOLUME));

        InitializeCriticalSection(&pvol->v_cs);
        DEBUGALLOC(DEBUGALLOC_CS);
        InitializeCriticalSection(&pvol->v_csStms);
        DEBUGALLOC(DEBUGALLOC_CS);

#ifdef PATH_CACHING
        InitList((PDLINK)&pvol->v_dlCaches);
        InitializeCriticalSection(&pvol->v_csCaches);
        DEBUGALLOC(DEBUGALLOC_CS);
#endif
        InitList((PDLINK)&pvol->v_dlOpenStreams);
        pvol->v_pdsk = pdsk;
        pvol->v_volID = INVALID_AFS;
    }
    return pvol;
}




/*  ProbeVolume - Test for the (continued) existence of a VOLUME
 *
 *  ENTRY
 *      pvol - pointer to VOLUME
 *
 *  EXIT
 *      Sets the volume's VOLF_RETAIN flag as appropriate.  When set,
 *      the RETAIN flag causes the PC Card volume to persist across a
 *      power on/off sequence;  otherwise, if the user was browsing the
 *      PC Card folder, the shell could close the browser window unexpectedly.
 */

void ProbeVolume(PVOLUME pvol)
{
    
    pvol->v_flags |= VOLF_RETAIN;

#ifdef LATER
    PBYTE pbSector;

    __try {

        pbSector = _alloca(pvol->v_pdsk->d_diActive.di_bytes_per_sect);

        
        // Perform a trial read of the first sector (sector 0) now.

        if (pbSector) {
            if (ReadWriteDisk(pvol,
                              pvol->v_pdsk->d_hdsk,
                              DISK_IOCTL_READ,
                              &pvol->v_pdsk->d_diActive,
                              pvol->v_secVolBias + 0,
                              1,
                              pbSector) == ERROR_SUCCESS) {
                pvol->v_flags |= VOLF_RETAIN;
            }
        }
    } __except (EXCEPTION_EXECUTE_HANDLER) {
        ;
    }

    DEBUGMSGW(ZONE_INIT,(DBGTEXTW("FATFS!ProbeVolume: %sretaining volume 0x%08x\n"), pvol->v_flags & VOLF_RETAIN? TEXTW("") : TEXTW("NOT "), pvol));
#endif
}


/*  TestVolume - Test a VOLUME's validity
 *
 *  ENTRY
 *      pvol - pointer to VOLUME
 *      ppbgbs - pointer to address of PBR (partition boot record) for volume
 *
 *  EXIT
 *      ERROR_SUCCESS, else VOLUME's INVALID bit set if any errors encountered
 */

DWORD TestVolume(PVOLUME pvol, PBIGFATBOOTSEC *ppbgbs)
{
    DWORD cbSecOrig;
    DWORD dwError = ERROR_SUCCESS;
    PDSK pdsk = pvol->v_pdsk;
    PBIGFATBOOTSEC pbgbs = *ppbgbs;


    if (pvol->v_flags & VOLF_INVALID)
        return dwError;

    // Make sure other key BPB values are in sync with the driver (ie, sector
    // size), assuming driver info was provided.

    cbSecOrig = pdsk->d_diActive.di_bytes_per_sect;

    if (cbSecOrig != pbgbs->bgbsBPB.oldBPB.BPB_BytesPerSector) {

        DEBUGMSG(ZONE_INIT || ZONE_ERRORS,
                        (DBGTEXT("FATFS!TestVolume: forcing driver sector size (%d) to match BPB (%d)\n"),
                         cbSecOrig, pbgbs->bgbsBPB.oldBPB.BPB_BytesPerSector));

        pdsk->d_diActive.di_bytes_per_sect = pbgbs->bgbsBPB.oldBPB.BPB_BytesPerSector;

        if (SetDiskInfo(pdsk->d_hdsk, &pdsk->d_diActive) == ERROR_SUCCESS) {

            pvol->v_flags |= VOLF_MODDISKINFO;

            
            if (pdsk->d_diActive.di_bytes_per_sect > cbSecOrig) {

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美精品一区二区色综合| 国模娜娜一区二区三区| 经典三级视频一区| 欧美男人的天堂一二区| 国产精品久久久久天堂| 国产精品一区二区在线观看不卡 | 久久久久99精品国产片| 亚洲韩国精品一区| 欧美日本免费一区二区三区| 亚洲精品中文在线影院| 97se亚洲国产综合在线| 亚洲欧美经典视频| 91精品国产一区二区三区香蕉 | 欧美国产精品一区二区| 天堂精品中文字幕在线| aa级大片欧美| 99re热视频精品| 国产精品国模大尺度视频| 国产成人高清在线| 日韩电影在线免费看| 亚洲18女电影在线观看| 国产乱人伦偷精品视频不卡| 国产精品香蕉一区二区三区| 日韩在线一区二区| 亚洲综合激情另类小说区| 17c精品麻豆一区二区免费| 2欧美一区二区三区在线观看视频| 欧美三级中文字| 欧洲精品视频在线观看| 99久久伊人精品| 99热精品一区二区| 国产98色在线|日韩| 黑人精品欧美一区二区蜜桃| 男男成人高潮片免费网站| 亚洲超丰满肉感bbw| 亚洲国产日韩综合久久精品| 亚洲久本草在线中文字幕| 中文在线免费一区三区高中清不卡 | 国产亲近乱来精品视频| 亚洲精品在线一区二区| 精品日本一线二线三线不卡 | 国产精品区一区二区三| 国产日韩欧美一区二区三区综合| 精品国偷自产国产一区| 欧美第一区第二区| 亚洲精品在线观看视频| 久久久久久亚洲综合| 久久久久久99久久久精品网站| 精品盗摄一区二区三区| 国产亚洲成aⅴ人片在线观看| 日韩精品一区二区三区老鸭窝 | 欧美精品电影在线播放| 欧美一区在线视频| 欧美电影免费观看完整版| 日韩视频一区二区| 久久久精品欧美丰满| 久久精品一区二区三区不卡牛牛| 国产日韩亚洲欧美综合| 中文字幕一区二区三中文字幕| 亚洲视频精选在线| 亚洲成人av一区二区三区| 日韩av电影免费观看高清完整版在线观看 | 亚洲精品在线免费播放| 国产人伦精品一区二区| 亚洲男人的天堂av| 午夜国产不卡在线观看视频| 日韩**一区毛片| 国产成人aaa| 91蜜桃在线免费视频| 在线不卡中文字幕| 久久久噜噜噜久噜久久综合| 国产精品久久久久久久久晋中| 亚洲男人天堂一区| 美女视频一区在线观看| 精品99久久久久久| 最新欧美精品一区二区三区| 亚洲最色的网站| 精品伊人久久久久7777人| 成人免费视频播放| 欧美女孩性生活视频| 久久精品在这里| 亚洲综合偷拍欧美一区色| 久久9热精品视频| 99精品视频在线免费观看| 欧美精品黑人性xxxx| 中文字幕国产精品一区二区| 亚洲国产精品一区二区www在线| 久久99精品久久久久久久久久久久| 高清beeg欧美| 91精品国产欧美日韩| 欧美韩日一区二区三区| 日韩影院精彩在线| 99热在这里有精品免费| 日韩免费视频一区二区| 亚洲欧美区自拍先锋| 激情成人综合网| 欧美色网一区二区| 国产精品国模大尺度视频| 免费成人在线网站| 91久久精品一区二区三| 国产亚洲欧美激情| 日韩av成人高清| 色综合久久久久综合99| 久久日一线二线三线suv| 亚洲午夜一区二区三区| 成人av在线一区二区三区| 日韩一级片网址| 亚洲另类在线制服丝袜| 国产成人午夜视频| 精品日韩欧美在线| 三级在线观看一区二区| 99精品一区二区三区| 国产亚洲一本大道中文在线| 欧美a一区二区| 欧美日韩国产另类一区| 成人动漫中文字幕| 精品va天堂亚洲国产| 日韩av电影免费观看高清完整版在线观看| 91网址在线看| 国产精品女人毛片| 国产精品一二一区| 精品久久国产字幕高潮| 亚洲成人动漫在线观看| 91久久久免费一区二区| 亚洲欧美日韩一区二区三区在线观看| 国产乱理伦片在线观看夜一区| 欧美一区二区精品在线| 午夜精品久久久久影视| 欧美吻胸吃奶大尺度电影 | 亚洲乱码日产精品bd| 成人一级片网址| 国产无人区一区二区三区| 久久精品99国产精品| 日韩欧美一级在线播放| 日本三级亚洲精品| 91精品国产麻豆国产自产在线| 亚洲chinese男男1069| 91福利社在线观看| 亚洲一二三四区| 欧美日韩在线播放一区| 亚洲午夜精品网| 欧美日韩国产高清一区| 日本在线不卡视频| 日韩三级av在线播放| 蜜臀va亚洲va欧美va天堂 | 久久久国际精品| 亚洲国产精品一区二区www| 日韩无一区二区| 91国产丝袜在线播放| 国内欧美视频一区二区| 亚洲精品国产a| 一级中文字幕一区二区| 久久蜜桃一区二区| 中文字幕不卡在线播放| 51精品久久久久久久蜜臀| 国产成人亚洲综合a∨婷婷| 天堂成人国产精品一区| 一区二区成人在线| 国产精品大尺度| 国产午夜久久久久| 欧美精三区欧美精三区| 一本久道久久综合中文字幕| 国产大片一区二区| 精品一区二区三区在线观看国产 | 精品一区二区三区日韩| 亚洲欧洲日本在线| 最新久久zyz资源站| 国产亚洲精品aa午夜观看| 爽好久久久欧美精品| 欧美日韩一区国产| 国产精品传媒视频| 久久av老司机精品网站导航| 国产女同互慰高潮91漫画| 色老汉av一区二区三区| 奇米影视一区二区三区| 欧美韩国日本一区| 欧美日韩国产免费| 欧美一级片免费看| 成人黄色小视频在线观看| 亚洲午夜在线观看视频在线| 欧美成人在线直播| 99国产精品久久| 蜜臀91精品一区二区三区| 国产精品欧美久久久久无广告| 欧美日韩一卡二卡| 国产v日产∨综合v精品视频| 亚洲综合免费观看高清在线观看| 精品久久久网站| 欧美综合在线视频| 国产精品系列在线观看| 午夜伦欧美伦电影理论片| 久久蜜桃av一区二区天堂| 在线观看日韩精品| 国产精品99久久不卡二区| 午夜久久久影院| 中文字幕一区三区| 久久久国产精华| 欧美一区二区视频在线观看| 91麻豆精品在线观看| 国产伦理精品不卡|