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

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

?? translatednandflash.c

?? at91sam9263操作NAND FLASH代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
    if ((block == translated->currentLogicalBlock)
        && (translated->previousPhysicalBlock != -1)
        && (PageIsClean(translated, page))) {

        trace_LOG(DEBUG, "Reading page from current block\n\r");
        return ManagedNandFlash_ReadPage(MANAGED(translated),
                                         translated->previousPhysicalBlock,
                                         page,
                                         data,
                                         spare);
    }
    else {

        // Try to read the page from the logical block
        error = MappedNandFlash_ReadPage(MAPPED(translated), block, page, data, spare);
    
        // Block was not mapped
        if (error == NandCommon_ERROR_BLOCKNOTMAPPED) {
    
            ASSERT(!spare, "Cannot read the spare information of an unmapped block\n\r");
    
            // Check if a block can be allocated
            if (BlockCanBeAllocated(translated)) {
    
                // Return 0xFF in buffers with no error
                trace_LOG(DEBUG,
                          "Block #%d is not mapped but can be allocated, filling buffer with 0xFF\n\r",
                          block);
                if (data) {
    
                    memset(data, 0xFF, NandFlashModel_GetPageDataSize(MODEL(translated)));
                }
                if (spare) {
    
                    memset(spare, 0xFF, NandFlashModel_GetPageSpareSize(MODEL(translated)));
                }
            }
            else {

                trace_LOG(trace_ERROR, "Block #%d is not mapped and there are no more blocks available\n\r", block);
                return NandCommon_ERROR_NOMOREBLOCKS;
            }
        }
        // Error
        else if (error) {
    
            return error;
        }
    }

    return 0;
}

//------------------------------------------------------------------------------
/// Writes the data and/or spare area of a page on a translated nandflash.
/// Allocates block has needed to keep the wear even between all blocks.
/// \param translated  Pointer to a TranslatedNandFlash instance.
/// \param block  Logical block number.
/// \param page  Number of page to write inside logical block.
/// \param data  Data area buffer, can be 0.
/// \param spare  Spare area buffer, can be 0.
//------------------------------------------------------------------------------
unsigned char TranslatedNandFlash_WritePage(
    struct TranslatedNandFlash *translated,
    unsigned short block,
    unsigned short page,
    void *data,
    void *spare)
{
    unsigned char allocate = 1;
    unsigned char error;

    trace_LOG(INFO, "TranslatedNandFlash_WritePage(B#%d:P#%d)\n\r", block, page);

    // A new block must be allocated unless:
    // 1. the block is not mapped and there are no more blocks to allocate
    if (MappedNandFlash_LogicalToPhysical(MAPPED(translated), block) == -1) {

        // Block is not mapped, check if it can be
        if (!BlockCanBeAllocated(translated)) {

            trace_LOG(trace_ERROR, "TranslatedNandFlash_WritePage: Not enough free blocks\n\r");
            return NandCommon_ERROR_NOMOREBLOCKS;
        }
        trace_LOG(DEBUG, "Allocate because block not mapped\n\r");
    }
    // or 2. the block to write is the current one and the page to write is
    // clean
    else if (translated->currentLogicalBlock == block) {

        if (PageIsClean(translated, page)) {

            trace_LOG(DEBUG, "NO allocate because write in current block\n\r");
            allocate = 0;
        }
        else {

            trace_LOG(DEBUG, "Allocate because page DIRTY in current block\n\r");
        }
    }
    else {

        trace_LOG(DEBUG, "Allocate because block is mapped and different from current block\n\r");
    }

    // Allocate block if needed
    if (allocate) {

        // Flush current block write (if any) and then allocate block
        error = TranslatedNandFlash_Flush(translated);
        if (error) {

            return error;
        }
        translated->previousPhysicalBlock = MappedNandFlash_LogicalToPhysical(
                                                MAPPED(translated),
                                                block);
        trace_LOG(DEBUG, "Previous physical block is now #%d\n\r",
                  translated->previousPhysicalBlock);
        error = AllocateBlock(translated, block);
        if (error) {

            return error;
        }

        // Block becomes the current block with all pages clean
        translated->currentLogicalBlock = block;
        MarkAllPagesClean(translated);
    }

    // Start writing page
    error = MappedNandFlash_WritePage(MAPPED(translated),
                                      block,
                                      page,
                                      data,
                                      spare);
    if (error) {

        return error;
    }

    // If write went through, mark page as written
    MarkPageDirty(translated, page);
    return 0;
}

//------------------------------------------------------------------------------
/// Terminates the current write operation by copying all the missing pages from
/// the previous physical block.
/// \param translated  Pointer to a TranslatedNandFlash instance.
//------------------------------------------------------------------------------
unsigned char TranslatedNandFlash_Flush(struct TranslatedNandFlash *translated)
{
    unsigned int i;
    unsigned char error;
    unsigned int currentPhysicalBlock;

    // Check if there is a current block and a previous block
    if ((translated->currentLogicalBlock == -1)
        || (translated->previousPhysicalBlock == -1)) {

        return 0;
    }

    trace_LOG(INFO, "TranslatedNandFlash_Flush(PB#%d -> LB#%d)\n\r",
              translated->previousPhysicalBlock, translated->currentLogicalBlock);

    // Copy missing pages in the current block
    currentPhysicalBlock = MappedNandFlash_LogicalToPhysical(
                                MAPPED(translated),
                                translated->currentLogicalBlock);

    for (i=0; i < NandFlashModel_GetBlockSizeInPages(MODEL(translated)); i++) {

        if (PageIsClean(translated, i)) {

            trace_LOG(DEBUG, "Copying back page #%d of block #%d\n\r", i,
                      translated->previousPhysicalBlock);

            // Copy page
            error = ManagedNandFlash_CopyPage(MANAGED(translated),
                                              translated->previousPhysicalBlock,
                                              i,
                                              currentPhysicalBlock,
                                              i);
            if (error) {

                trace_LOG(trace_ERROR, "FinishCurrentWrite: Failed to copy page #%d\n\r", i);
                return error;
            }
        }
    }

    translated->currentLogicalBlock = -1;
    translated->previousPhysicalBlock = -1;
    return 0;
}

//------------------------------------------------------------------------------
/// Allocates a free block to save the current logical mapping on it.
/// Returns 0 if successful; otherwise returns a NandCommon_ERROR code.
/// \param translated  Pointer to a TranslatedNandFlash instance.
//------------------------------------------------------------------------------
unsigned char TranslatedNandFlash_SaveLogicalMapping(
    struct TranslatedNandFlash *translated)
{
    unsigned char error;
    unsigned short freeBlock;

    trace_LOG(INFO, "TranslatedNandFlash_SaveLogicalMapping()\n\r");

    // Save logical mapping in the youngest free block
    // Find the youngest block
    error = ManagedNandFlash_FindYoungestBlock(MANAGED(translated),
                                               NandBlockStatus_FREE,
                                               &freeBlock);
    if (error) {

        trace_LOG(trace_FATAL, "TranslatedNandFlash_SaveLogicalMapping: Could not find a free block\n\r");
        return error;
    }

    // Check if this is the last free block, in which case dirty blocks are wiped
    // prior to saving the mapping
    if (ManagedNandFlash_CountBlocks(MANAGED(translated),
                                     NandBlockStatus_FREE) == 1) {

        TranslatedNandFlash_Flush(translated);
        error = ManagedNandFlash_EraseDirtyBlocks(MANAGED(translated));
        if (error) {
        
            trace_LOG(trace_FATAL, "TranslatedNandFlash_Flush: Could not erase dirty blocks\n\r");
            return error;
        }
    }

    // Save the mapping
    error = MappedNandFlash_SaveLogicalMapping(MAPPED(translated), freeBlock);
    if (error) {

        trace_LOG(trace_FATAL,
                  "TranslatedNandFlash_Flush: Failed to save mapping in block #%d\n\r",
                  freeBlock);
        return error;
    }

    return 0;
}

//------------------------------------------------------------------------------
/// Returns the number of available blocks in a translated nandflash.
/// \param translated  Pointer to a TranslatedNandFlash instance.
//------------------------------------------------------------------------------
unsigned short TranslatedNandFlash_GetDeviceSizeInBlocks(
   const struct TranslatedNandFlash *translated)
{
    return NandFlashModel_GetDeviceSizeInBlocks(MODEL(translated))
           - MINNUMUNALLOCATEDBLOCKS
           - ManagedNandFlash_CountBlocks(MANAGED(translated), NandBlockStatus_BAD)
           - 1; // Logical mapping block
}

//------------------------------------------------------------------------------
/// Returns the number of available pages in a translated nandflash.
/// \param translated  Pointer to a TranslatedNandFlash instance.
//------------------------------------------------------------------------------
unsigned int TranslatedNandFlash_GetDeviceSizeInPages(
   const struct TranslatedNandFlash *translated)
{
    return TranslatedNandFlash_GetDeviceSizeInBlocks(translated)
           * NandFlashModel_GetBlockSizeInPages(MODEL(translated));
}

//------------------------------------------------------------------------------
/// Returns the number of available data bytes in a translated nandflash.
/// \param translated  Pointer to a TranslatedNandFlash instance.
//------------------------------------------------------------------------------
unsigned long long TranslatedNandFlash_GetDeviceSizeInBytes(
   const struct TranslatedNandFlash *translated)
{
    return TranslatedNandFlash_GetDeviceSizeInPages(translated)
           * NandFlashModel_GetPageDataSize(MODEL(translated));
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜臀av一区二区在线免费观看 | 久久久久青草大香线综合精品| 成人白浆超碰人人人人| 久久精品国产99久久6| 日韩高清一区在线| 日韩av中文在线观看| 丝袜诱惑制服诱惑色一区在线观看| 亚洲欧美日韩在线| 一区二区三区在线播放| 一级中文字幕一区二区| 一区二区欧美视频| 午夜欧美在线一二页| 天天av天天翘天天综合网色鬼国产| 亚洲成人黄色小说| 国产综合久久久久久久久久久久| 天天免费综合色| 青青青爽久久午夜综合久久午夜| 久久国产三级精品| 韩国三级在线一区| 成人午夜免费av| 在线视频国内自拍亚洲视频| 欧美中文字幕久久| 91精品欧美综合在线观看最新| 日韩一区二区三区观看| 精品av久久707| 亚洲欧洲日本在线| 亚洲v日本v欧美v久久精品| 日本91福利区| 懂色av一区二区在线播放| 色婷婷久久一区二区三区麻豆| 欧美日韩一区二区三区四区五区| 日韩欧美一级二级| 中文字幕视频一区二区三区久| 一区二区三区日韩精品| 麻豆成人免费电影| caoporm超碰国产精品| 欧美日韩在线观看一区二区| 精品福利av导航| 亚洲女人****多毛耸耸8| 免费高清在线一区| 91免费国产在线| 26uuu精品一区二区| 亚洲欧美一区二区久久| 精品影视av免费| 色欧美日韩亚洲| 久久精品一二三| 亚洲va国产天堂va久久en| 国产黄色成人av| 欧美日韩精品免费| 中文字幕av一区二区三区高 | 午夜久久久影院| 国产91精品久久久久久久网曝门| 欧美日本不卡视频| 国产精品蜜臀在线观看| 久久99精品一区二区三区三区| 91视频国产资源| 久久精品在线观看| 美女精品一区二区| 精品视频1区2区3区| 中文字幕一区二区三区不卡在线| 美国精品在线观看| 欧美日韩综合一区| 亚洲精选免费视频| 成人av电影在线播放| xnxx国产精品| 成人永久免费视频| 久久在线观看免费| 免费看日韩a级影片| 欧美男同性恋视频网站| 亚洲精品久久嫩草网站秘色| 粉嫩高潮美女一区二区三区 | 久久精品国产一区二区三| 欧美色老头old∨ideo| 国产精品久久久久久久久快鸭| 国产在线国偷精品免费看| 欧美一区2区视频在线观看| 亚洲观看高清完整版在线观看 | 夜夜精品浪潮av一区二区三区| 国产成人免费av在线| 久久亚洲二区三区| 国产又黄又大久久| 国产欧美日韩亚州综合| 国产成人午夜电影网| 国产精品素人一区二区| 成人在线视频首页| 中文字幕一区二区三区精华液| 99精品视频一区二区| 亚洲精品国久久99热| 欧美在线观看18| 日韩精品一级中文字幕精品视频免费观看 | 欧美日韩一区高清| 日精品一区二区三区| 欧美日本一区二区三区| 日韩高清一区在线| 精品久久久久久无| 91丝袜美女网| 亚洲欧美偷拍三级| 欧美日韩一二三区| 美女高潮久久久| 国产亚洲人成网站| 色综合av在线| 偷拍与自拍一区| 精品日产卡一卡二卡麻豆| 国产一区二区成人久久免费影院| 国产欧美精品一区aⅴ影院 | 亚洲视频在线观看一区| 欧美性受xxxx黑人xyx性爽| 天天操天天干天天综合网| 2021国产精品久久精品| 99免费精品视频| 首页综合国产亚洲丝袜| 精品国产精品网麻豆系列| 成人美女视频在线观看18| 亚洲中国最大av网站| 日韩欧美一级二级| 91免费视频网| 蜜桃视频一区二区三区| 综合在线观看色| 日韩三级电影网址| 色综合久久88色综合天天6| 日产国产高清一区二区三区| 亚洲国产成人一区二区三区| 在线观看91视频| 国产馆精品极品| 日韩中文字幕麻豆| 国产精品欧美精品| 日韩精品一区二| 色综合视频在线观看| 久久精品国产亚洲a| 亚洲精品成人精品456| 国产欧美日韩精品一区| 欧美一区二区人人喊爽| 色乱码一区二区三区88| 国产乱人伦偷精品视频免下载| 麻豆91在线观看| 亚洲综合图片区| 国产精品久久久久久户外露出| 88在线观看91蜜桃国自产| 91老师国产黑色丝袜在线| 国产成人99久久亚洲综合精品| 视频一区二区三区入口| 亚洲最大成人网4388xx| 国产精品久久久久久久久久久免费看| 日韩你懂的电影在线观看| 欧美久久一二三四区| 91黄视频在线观看| 99re热这里只有精品视频| 韩国欧美国产1区| 免费成人av在线| 免费成人深夜小野草| 日韩中文字幕麻豆| 日韩黄色在线观看| 亚洲gay无套男同| 亚洲成av人在线观看| 一区二区三区欧美久久| 亚洲视频在线一区观看| 亚洲欧美国产77777| 亚洲黄色片在线观看| 亚洲激情网站免费观看| 亚洲少妇最新在线视频| 一区二区中文视频| 亚洲视频中文字幕| 一区二区三区欧美久久| 亚洲一区av在线| 亚洲图片欧美综合| 性感美女极品91精品| 日韩成人dvd| 久久99最新地址| 国产剧情av麻豆香蕉精品| 韩国精品在线观看| 国产成人自拍网| av影院午夜一区| 日本乱码高清不卡字幕| 欧美伦理电影网| 日韩精品一区二区三区视频播放| 精品伦理精品一区| 欧美韩国日本综合| 亚洲乱码国产乱码精品精小说| 亚洲一区在线观看免费观看电影高清| 亚洲一二三级电影| 久久99在线观看| www.av精品| 欧美日韩精品免费| 精品毛片乱码1区2区3区| 国产精品电影一区二区三区| 亚洲综合视频在线观看| 另类综合日韩欧美亚洲| 国产河南妇女毛片精品久久久| 一本大道久久a久久综合婷婷| 欧美精品xxxxbbbb| 日本一区二区三区视频视频| 亚洲精品高清在线| 久久精品av麻豆的观看方式| 成人av资源网站| 在线综合+亚洲+欧美中文字幕| 久久亚洲一级片| 亚洲国产sm捆绑调教视频| 国产麻豆视频一区二区| 欧美性三三影院| 国产免费久久精品|