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

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

?? rawnandflash.c

?? at91sam9263操作NAND FLASH代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* ----------------------------------------------------------------------------
 *         ATMEL Microcontroller Software Support 
 * ----------------------------------------------------------------------------
 * Copyright (c) 2008, Atmel Corporation
 *
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * - Redistributions of source code must retain the above copyright notice,
 * this list of conditions and the disclaimer below.
 *
 * Atmel's name may not be used to endorse or promote products derived from
 * this software without specific prior written permission.
 *
 * DISCLAIMER: THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE
 * DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
 * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
 * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 * ----------------------------------------------------------------------------
 */

//------------------------------------------------------------------------------
//         Headers
//------------------------------------------------------------------------------

#include "RawNandFlash.h"
#include "NandCommon.h"
#include "NandFlashModelList.h"
#include <utility/trace.h>
#include <utility/assert.h>

#include <string.h>

//------------------------------------------------------------------------------
//         Internal definitions
//------------------------------------------------------------------------------

/// Custom trace levels for the current file.
#define DEBUG                           trace_DEBUG
#define INFO                            trace_INFO
#define IMPORTANT                       trace_FATAL

/// Nand flash chip status codes
#define STATUS_READY                    (1 << 6)
#define STATUS_ERROR                    (1 << 0)

/// Nand flash commands
#define COMMAND_READ_1                  0x00
#define COMMAND_READ_2                  0x30
#define COMMAND_COPYBACK_READ_1         0x00
#define COMMAND_COPYBACK_READ_2         0x35
#define COMMAND_COPYBACK_PROGRAM_1      0x85
#define COMMAND_COPYBACK_PROGRAM_2      0x10
#define COMMAND_RANDOM_OUT              0x05
#define COMMAND_RANDOM_OUT_2            0xE0
#define COMMAND_RANDOM_IN               0x85
#define COMMAND_READID                  0x90
#define COMMAND_WRITE_1                 0x80
#define COMMAND_WRITE_2                 0x10
#define COMMAND_ERASE_1                 0x60
#define COMMAND_ERASE_2                 0xD0
#define COMMAND_STATUS                  0x70
#define COMMAND_RESET                   0xFF


/// Nand flash commands (small blocks)
#define COMMAND_READ_A                  0x00
#define COMMAND_READ_C                  0x50

//------------------------------------------------------------------------------
//         Internal macros
//------------------------------------------------------------------------------
#define ENABLE_CE(raw)        PIO_Clear(&(raw->pinChipEnable))
#define DISABLE_CE(raw)       PIO_Set(&(raw->pinChipEnable))

#define WRITE_COMMAND(raw, command) \
    {*((volatile unsigned char *) raw->commandAddress) = (unsigned char) command;}
#define WRITE_ADDRESS(raw, address) \
    {*((volatile unsigned char *) raw->addressAddress) = (unsigned char) address;}
#define WRITE_DATA8(raw, data) \
    {*((volatile unsigned char *) raw->dataAddress) = (unsigned char) data;}
#define READ_DATA8(raw) \
    (*((volatile unsigned char *) raw->dataAddress))
#define WRITE_DATA16(raw, data) \
    {*((volatile unsigned short *) raw->dataAddress) = (unsigned short) data;}
#define READ_DATA16(raw) \
    (*((volatile unsigned short *) raw->dataAddress))

/// Internal cast macros
#define MODEL(raw)  ((struct NandFlashModel *) raw)

/// Number of tries for erasing a block
#define NUMERASETRIES           2
/// Number of tries for writing a block
#define NUMWRITETRIES           2
/// Number of tries for copying a block
#define NUMCOPYTRIES            2

//------------------------------------------------------------------------------
//         Internal functions
//------------------------------------------------------------------------------

//------------------------------------------------------------------------------
/// Sends the column address to the NandFlash chip.
/// \param raw  Pointer to a RawNandFlash instance.
/// \param columnAddress  Column address to send.
//------------------------------------------------------------------------------
static void WriteColumnAddress(
    const struct RawNandFlash *raw,
    unsigned short columnAddress)
{
    unsigned short pageDataSize = NandFlashModel_GetPageDataSize(MODEL(raw));

    /* Check the data bus width of the NandFlash */
    if (NandFlashModel_GetDataBusWidth(MODEL(raw)) == 16) {
        /* Div 2 is because we address in word and not in byte */
        columnAddress >>= 1;
    }
    
    while (pageDataSize > 0) {
    
        WRITE_ADDRESS(raw, columnAddress & 0xFF);
        pageDataSize >>= 8;
        columnAddress >>= 8;
    }
}

//------------------------------------------------------------------------------
/// Sends the row address to the NandFlash chip.
/// \param raw  Pointer to a RawNandFlash instance.
/// \param rowAddress  Row address to send.
//------------------------------------------------------------------------------
static void WriteRowAddress(
    const struct RawNandFlash *raw,
    unsigned int rowAddress)
{
    unsigned int numPages = NandFlashModel_GetDeviceSizeInPages(MODEL(raw));

    while (numPages > 0) {
    
        WRITE_ADDRESS(raw, rowAddress & 0xFF);
        numPages >>= 8;
        rowAddress >>= 8;
    }
}

//------------------------------------------------------------------------------
/// Waiting for the completion of a page program, erase and random read completion.
/// \param raw  Pointer to a RawNandFlash instance.
//------------------------------------------------------------------------------
static void WaitReady(const struct RawNandFlash *raw)
{
    if (raw->pinReadyBusy.mask) {
        while (!PIO_Get(&(raw->pinReadyBusy)));
    }
    else {
        WRITE_COMMAND(raw, COMMAND_STATUS);
        while ((READ_DATA8(raw) & STATUS_READY) != STATUS_READY);
    }
}

//------------------------------------------------------------------------------
/// Return 1 if program or erase operation is completed.
/// and the program or erase operation is completed successfully, otherwise return 0.
/// \param raw  Pointer to a RawNandFlash instance.
//------------------------------------------------------------------------------
static unsigned char IsOperationComplete(const struct RawNandFlash *raw)
{
    unsigned char status;

    WRITE_COMMAND(raw, COMMAND_STATUS);

    status = READ_DATA8(raw);

    if (((status & STATUS_READY) != STATUS_READY) || ((status & STATUS_ERROR) != 0)) {
        return 0;
    }
    return 1;
}

//------------------------------------------------------------------------------
/// Sends data to the NandFlash chip from the provided buffer.
/// \param raw  Pointer to a RawNandFlash instance.
/// \param buffer  Buffer where the data is stored.
/// \param size  Number of bytes that will be written
//------------------------------------------------------------------------------
static void WriteData(
    const struct RawNandFlash *raw,
    unsigned char *buffer,
    unsigned int size)
{
    unsigned int i;

    // Check the data bus width of the NandFlash
    if (NandFlashModel_GetDataBusWidth(MODEL(raw)) == 16) {

        unsigned short *buffer16 = (unsigned short *) buffer;
        size >>= 1;

        for(i=0; i < size; i++) {

            WRITE_DATA16(raw, buffer16[i]);
        }
    }
    else {

        for(i=0; i < size; i++) {

            WRITE_DATA8(raw, buffer[i]);
        }
    }
}

//------------------------------------------------------------------------------
/// Reads data from the NandFlash chip into the provided buffer.
/// \param nand  Pointer to a RawNandFlash instance.
/// \param buffer  Buffer where the data will be stored.
/// \param size  Number of bytes that will be read
//------------------------------------------------------------------------------
static void ReadData(
    const struct RawNandFlash *raw,
    unsigned char *buffer,
    unsigned int size)
{
    unsigned int i;

    // Check the chip data bus width
    if (NandFlashModel_GetDataBusWidth(MODEL(raw)) == 16) {

        unsigned short *buffer16 = (unsigned short *) buffer;
        size >>= 1;

        for (i=0; i < size; i++) {

            buffer16[i] = READ_DATA16(raw);
        }
    }
    else {
    
        for (i=0; i < size; i++) {
    
            buffer[i] = READ_DATA8(raw);
        }
    }
}

//------------------------------------------------------------------------------
/// Erases the specified block of the device. Returns 0 if the operation was
/// successful; otherwise returns an error code.
/// \param raw  Pointer to a RawNandFlash instance.
/// \param block  Number of the physical block to erase.
//------------------------------------------------------------------------------
static unsigned char EraseBlock(
    const struct RawNandFlash *raw,
    unsigned short block)
{
    unsigned char error = 0;
    unsigned int rowAddress;

    trace_LOG(DEBUG, "EraseBlock(%d)\r\n", block);

    // Calculate address used for erase
    rowAddress = block * NandFlashModel_GetBlockSizeInPages(MODEL(raw));

    // Start erase
    ENABLE_CE(raw);
    WRITE_COMMAND(raw, COMMAND_ERASE_1);
    WriteRowAddress(raw, rowAddress);
    WRITE_COMMAND(raw, COMMAND_ERASE_2);

    WaitReady(raw);
    if (!IsOperationComplete(raw)) {
        trace_LOG(trace_ERROR,
                 "EraseBlock: Could not erase block.\n\r");
        error = NandCommon_ERROR_CANNOTERASE;
    }

    DISABLE_CE(raw);

    return error;
}

//------------------------------------------------------------------------------
/// Writes the data and/or the spare area of a page on a NandFlash chip. If one
/// of the buffer pointer is 0, the corresponding area is not written.
/// Returns 0 if the write operation is successful; otherwise returns 1.
/// \param raw  Pointer to a RawNandFlash instance.
/// \param block  Number of the block where the page to write resides.
/// \param page  Number of the page to write inside the given block.
/// \param data  Buffer containing the data area.
/// \param spare  Buffer containing the spare area.
//------------------------------------------------------------------------------
static unsigned char WritePage(
    const struct RawNandFlash *raw,
    unsigned short block,
    unsigned short page,
    void *data,
    void *spare)
{
    unsigned char error = 0;
    unsigned int pageDataSize = NandFlashModel_GetPageDataSize(MODEL(raw));
    unsigned int spareDataSize = NandFlashModel_GetPageSpareSize(MODEL(raw));
    unsigned int rowAddress;

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

    // Calculate physical address of the page
    rowAddress = block * NandFlashModel_GetBlockSizeInPages(MODEL(raw)) + page;

    // Start write operation
    ENABLE_CE(raw);

    // Write data area if needed
    if (data) {

        WRITE_COMMAND(raw, COMMAND_WRITE_1);
        WriteColumnAddress(raw, 0);
        WriteRowAddress(raw, rowAddress);
        WriteData(raw, (unsigned char *) data, pageDataSize);

        // Spare is written here as well since it is more efficient
        if (spare) {

            WriteData(raw, (unsigned char *) spare, spareDataSize);
        }

        WRITE_COMMAND(raw, COMMAND_WRITE_2);

        WaitReady(raw);
        if (!IsOperationComplete(raw)) {
            trace_LOG(trace_ERROR, "WritePage: Failed writing data area.\n\r");
            error = NandCommon_ERROR_CANNOTWRITE;
        }
    }

    // Write spare area alone if needed
    if (spare && !data) {

        WRITE_COMMAND(raw, COMMAND_WRITE_1);
        WriteColumnAddress(raw, pageDataSize);
        WriteRowAddress(raw, rowAddress);
        WriteData(raw, (unsigned char *) spare, spareDataSize);
        WRITE_COMMAND(raw, COMMAND_WRITE_2);

        WaitReady(raw);
        if (!IsOperationComplete(raw)) {
            trace_LOG(trace_ERROR, "WritePage: Failed writing data area.\n\r");
            error = NandCommon_ERROR_CANNOTWRITE;
        }
    }

    // Disable chip
    DISABLE_CE(raw);

    return error;
}


//------------------------------------------------------------------------------
/// Copies the data in a page of the NandFlash device to an other page on that
/// same chip. Both pages must have be even or odd; it is not possible to copy
/// and even page to an odd page and vice-versa.
/// Returns 0 if the operation is successful; otherwise returns a 
/// NandCommon_ERROR code.
/// \param raw  Pointer to a RawNandFlash instance.
/// \param sourceBlock  Source block number.
/// \param sourcePage  Source page number inside the source block.
/// \param destBlock  Destination block number.
/// \param destPage  Destination page number inside the destination block.
//------------------------------------------------------------------------------
static unsigned char CopyPage(
    const struct RawNandFlash *raw,
    unsigned short sourceBlock,
    unsigned short sourcePage,
    unsigned short destBlock,

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲综合成人在线视频| 喷水一区二区三区| 91精品国产手机| 91在线观看污| 精品一区二区三区在线观看| 一区二区三区欧美在线观看| 久久夜色精品国产噜噜av| 欧洲亚洲精品在线| 不卡的电影网站| 国内精品久久久久影院一蜜桃| ...av二区三区久久精品| 欧美一级一区二区| 在线看国产日韩| 99久久精品免费看国产免费软件| 久久疯狂做爰流白浆xx| 亚州成人在线电影| 亚洲男人都懂的| 国产无遮挡一区二区三区毛片日本| 7777精品伊人久久久大香线蕉 | 日韩成人精品在线观看| ...xxx性欧美| 欧美国产激情一区二区三区蜜月| 91麻豆精品国产91久久久使用方法| 91麻豆精品在线观看| 成人午夜激情在线| 国产高清不卡一区二区| 国产麻豆视频一区二区| 理论电影国产精品| 免费美女久久99| 毛片av中文字幕一区二区| 亚洲电影一区二区| 亚洲在线视频网站| 亚洲午夜在线观看视频在线| 亚洲精品乱码久久久久久久久| 亚洲视频狠狠干| 亚洲女同女同女同女同女同69| 国产精品午夜春色av| 中文字幕免费一区| 中文字幕在线不卡一区| 一区二区中文字幕在线| 综合久久国产九一剧情麻豆| 国产精品美女视频| 中文字幕亚洲成人| 亚洲人精品午夜| 一区二区三区不卡视频| 亚洲va欧美va人人爽| 婷婷成人综合网| 久久国产精品一区二区| 精品一区免费av| 国产91丝袜在线播放0| 北条麻妃国产九九精品视频| bt7086福利一区国产| 色综合天天天天做夜夜夜夜做| 91在线视频18| 在线观看国产一区二区| 欧美精品vⅰdeose4hd| 日韩欧美你懂的| 2020日本不卡一区二区视频| 国产三级欧美三级| 亚洲天堂久久久久久久| 亚洲自拍偷拍麻豆| 久久精品免费看| 国产99久久久国产精品免费看| 99精品视频在线播放观看| 日本福利一区二区| 欧美一级欧美三级| 久久久精品黄色| 一区二区三区资源| 日本大胆欧美人术艺术动态| 国产美女在线精品| 色激情天天射综合网| 91精品国产一区二区三区蜜臀| 久久伊人中文字幕| 亚洲伊人伊色伊影伊综合网| 另类小说一区二区三区| 97久久精品人人澡人人爽| 欧美精品精品一区| 国产精品你懂的在线| 一区二区三区欧美在线观看| 久久国产精品99久久久久久老狼 | 成人a免费在线看| 欧美性欧美巨大黑白大战| 亚洲精品在线免费观看视频| 中文字幕日韩av资源站| 蜜臀av一区二区三区| 9人人澡人人爽人人精品| 91精品国产色综合久久不卡电影| 国产人妖乱国产精品人妖| 亚洲一卡二卡三卡四卡五卡| 国产剧情一区在线| 6080午夜不卡| 亚洲人成网站在线| 国精品**一区二区三区在线蜜桃| 91麻豆自制传媒国产之光| 精品久久久久香蕉网| 亚洲第一福利视频在线| 成人性生交大片免费看视频在线 | 中文字幕制服丝袜成人av| 免费一级片91| 91成人在线免费观看| 欧美激情综合五月色丁香| 日本中文字幕一区二区有限公司| 91热门视频在线观看| 久久久久久久国产精品影院| 午夜精品一区二区三区三上悠亚| 粗大黑人巨茎大战欧美成人| 日韩女同互慰一区二区| 夜夜精品视频一区二区| 国产v日产∨综合v精品视频| 日韩无一区二区| 性做久久久久久久久| 91高清视频在线| 亚洲欧美怡红院| 国产91丝袜在线播放九色| 欧美xxxxxxxx| 男女激情视频一区| 欧美片网站yy| 亚洲在线观看免费| 91色porny在线视频| 国产精品网友自拍| 国产成人精品网址| 久久精品水蜜桃av综合天堂| 久久精品av麻豆的观看方式| 91精品久久久久久久久99蜜臂| 亚洲免费观看视频| 91啪亚洲精品| 亚洲欧美激情一区二区| 99久久精品国产毛片| 国产精品久久三| 不卡的看片网站| 中文字幕中文在线不卡住| 国产成a人亚洲精| 欧美国产精品一区二区三区| 国产高清精品久久久久| 精品成人一区二区三区| 麻豆国产一区二区| 欧美精品一区二区精品网| 国产主播一区二区三区| 久久影视一区二区| 国产成人精品免费视频网站| 国产亚洲精品aa| av成人免费在线| 亚洲男人的天堂一区二区| 色屁屁一区二区| 亚欧色一区w666天堂| 欧美一级免费观看| 国产一区二区毛片| 中文字幕av一区二区三区| 成人av网址在线观看| 亚洲欧洲综合另类| 欧美日韩一区二区不卡| 日本亚洲天堂网| 久久综合九色综合97婷婷女人| 国产精品一区一区| 自拍偷拍国产精品| 欧美日韩高清在线| 国产呦萝稀缺另类资源| 欧美国产日韩在线观看| 色综合天天综合网天天狠天天 | 一区二区在线观看不卡| 欧美色视频在线观看| 美女视频黄免费的久久| 久久久久成人黄色影片| 91麻豆免费看| 免费成人在线观看| 国产亚洲欧美日韩在线一区| av亚洲精华国产精华精华| 一区二区三区精品视频在线| 欧美群妇大交群中文字幕| 久久av中文字幕片| 亚洲欧美中日韩| 在线综合+亚洲+欧美中文字幕| 国产精品99精品久久免费| 亚洲美女免费在线| 欧美成人精品福利| av一区二区三区黑人| 亚洲伊人伊色伊影伊综合网| 精品国产成人系列| 91精彩视频在线| 精品午夜久久福利影院| 亚洲免费大片在线观看| 精品日韩99亚洲| 一本久久a久久免费精品不卡| 成人午夜免费电影| 性做久久久久久免费观看| 国产情人综合久久777777| 欧美高清一级片在线| 国产精品一区不卡| 日韩电影免费一区| 亚洲日本va午夜在线电影| 亚洲精品一区二区三区香蕉 | 成人黄色大片在线观看| 奇米综合一区二区三区精品视频| 亚洲国产精品av| 日韩欧美黄色影院| 欧美伊人久久大香线蕉综合69| 国内成人精品2018免费看| 午夜精品久久久久久久久久久| 国产精品视频第一区| 日韩一区二区三区电影|