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

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

?? nandflash.c

?? 啟動代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
  Nand_SysInfo.Nand_LogPerPhy = chipInfo.phy_page_size/NFC_LOG_PAGE_SIZE;
  Nand_SysInfo.log_spare_size = NFC_LOG_SPARE_SIZE;
  Nand_SysInfo.Fs_Info_size = NFC_FS_INFO_SIZE;
  Nand_SysInfo.log_page_size = NFC_LOG_PAGE_SIZE;
 
  Nand_SysInfo.log_page_per_blk = Nand_SysInfo.Nand_LogPerPhy * chipInfo.phy_page_per_blk;
  Nand_SysInfo.log_page_per_blk_shift = getShiftNum(Nand_SysInfo.log_page_per_blk);
  Nand_SysInfo.phypage_per_chip = chipInfo.phy_page_per_blk * chipInfo.chip_blk_num;
  Nand_SysInfo.phypage_shift_num = getShiftNum(Nand_SysInfo.phypage_per_chip);
  Nand_SysInfo.chip_logpage_num = chipInfo.chip_blk_num*Nand_SysInfo.log_page_per_blk;
  Nand_SysInfo.total_blk_num = chipInfo.chip_blk_num * chipInfo.count;
  Nand_SysInfo.total_group_num = Nand_SysInfo.total_blk_num / chipInfo.group_blk_num;
  Nand_SysInfo.total_phypage_num = Nand_SysInfo.total_blk_num * chipInfo.phy_page_per_blk;
  Nand_SysInfo.total_logpage_num = Nand_SysInfo.log_page_per_blk * Nand_SysInfo.total_blk_num;

//  bNandInit = AK_TRUE;
  return NF_SUCCESS;
}



/**
* @BRIEF read one logic page to nandflash with ECC.
*   total 518B valide data: incude 512Byte data and 6Byte file system information.
*   hardware check ECC code.
* @AUTHOR dengjian
* @DATE 2006-1-4
* @PARAM LogPage:logic page number.
*  *data:pointer of data buffer
   *FS_info:pointer of fs information
* @RETURN
* @RETVAL
*/
//***********************************************************************************
//tip:chip select by mtd manager, this driver just read current chip page data
//***********************************************************************************
T_S16 nf_read_frame(T_U32 frame,T_U8 *data,T_U8 *fs_info)
{
  T_U8 chip;
  T_U32 status;
  T_U16 j;
  T_U32 columnAddr, rowAddr;

  if( (data == AK_NULL) && (fs_info == AK_NULL))
  {
    printf("\r\nnand dirver read:all of fs_info and data is AK_NULL\r\n");
    return NF_SUCCESS;//because mtd would handle error block,just alert,only write faile return falsereturn AK_FALSE;
    }

  if( frame >= Nand_SysInfo.total_logpage_num )
  {
    printf("\r\n nand read addr error, frame(%d)/total(%d)\r\n",frame,Nand_SysInfo.total_logpage_num);
    //memset(data, 0xFF, Nand_frameSize);
    return NF_SUCCESS;//because mtd would handle error block,just alert,only write faile return false
    }

  //calculate column address and row address
  chip = (T_U8)(frame/Nand_SysInfo.chip_logpage_num);
  rowAddr = (frame%Nand_SysInfo.chip_logpage_num) / Nand_SysInfo.Nand_LogPerPhy;
  columnAddr = ( frame % Nand_SysInfo.Nand_LogPerPhy ) *  (Nand_SysInfo.log_page_size + Nand_SysInfo.log_spare_size) ;

  //read data and do ecc check
  if( data != AK_NULL )
  {
    T_S16 ret;
    
    ret = nf_read_page(chip,rowAddr,columnAddr,data,Nand_SysInfo.log_page_size + Nand_SysInfo.log_spare_size,AK_TRUE);

    if(ret==NF_SUCCESS && fs_info != AK_NULL)
    {
      // 讀出文件系統信息

      HAL_READ_UINT32(FLASH_DMA_REG2, status);  // low 4Byte
      memcpy(fs_info,&status,4);
      //HAL_READ_UINT16(FLASH_DMA_REG3, status);  // high 2Byte
      HAL_READ_UINT32(FLASH_DMA_REG3, status);  // high 2Byte
      memcpy(fs_info+4,&status,2);
      return ECC_Check(data,(T_U8 *)fs_info,(T_U16)(status & 0xFFFF));
    }
        return ret;
  }

  //*****************************ONLY READ FS INFORMATION
  else//only read fs information
  {
    #ifdef STORE_ALL_INT
    store_all_int();//need or not?
    #endif

    //***************************push nandflash command,if need,make next code be a function*************************//
    {
      // execute FIFO to FLASH read sequence(because data is sequence, can only use NFLASH_READ1(0x00) command)
      T_U32 *reg_addr = (T_U32 *) FLASH_CTRL_REG0;

      // sta_clr = 0,
      HAL_WRITE_UINT32(FLASH_CTRL_REG22, 0x00);

      //nandflash read1 command
      HAL_WRITE_UINT32(reg_addr++, (NFLASH_READ1 << 11) | COMMAND_CYCLES_CONF);

      //nandflash byte offset in physic page
      HAL_WRITE_UINT32(reg_addr++, (((columnAddr + NFC_FS_INFO_OFFSET) & 0xff) << 11) | ADDRESS_CYCLES_CONF);
      HAL_WRITE_UINT32(reg_addr++, ((((columnAddr+ NFC_FS_INFO_OFFSET) & 0xff00)>>8) << 11) | ADDRESS_CYCLES_CONF);

      //nandflash physic page address
      HAL_WRITE_UINT32(reg_addr++, ((rowAddr & 0xff) << 11) | ADDRESS_CYCLES_CONF);
      HAL_WRITE_UINT32(reg_addr++, (((rowAddr & 0xff00)>>8) << 11) | ADDRESS_CYCLES_CONF);

      //*******if nand flash >= 256M, this address seek would send******//
      if(3==chipInfo.row_cycle)
      {
        HAL_WRITE_UINT32(reg_addr++, (((rowAddr & 0xff0000)>>16) << 11) | ADDRESS_CYCLES_CONF);
      }


      //nandflash read2 command,this is a wait command
      HAL_WRITE_UINT32(reg_addr++, (NFLASH_READ2 << 11) | COMMAND_CYCLES_CONF|(1 << 10));


      HAL_WRITE_UINT32(reg_addr++, WAIT_JUMP_CONF);// wait R/B rising edge
      //HAL_WRITE_UINT32(reg_addr++, (BASIC_DLYCNT << 11) | DELAY_CNT_CONF);

      //******************read data to status register ***********//
      HAL_WRITE_UINT32(reg_addr, ((NFC_FS_INFO_SIZE-1) << 11) | READ_INFO_CONF | LAST_CMD_FLAG);
      //HAL_WRITE_UINT32(reg_addr,  (7<<11) | READ_INFO_CONF | LAST_CMD_FLAG);

    }

    // excute operation, CE1, enable power saving, CE# keep LOW wait R/B
    //HAL_WRITE_UINT32(FLASH_CTRL_REG22, NCHIP_SELECT(rowAddr%NFLASH_PAGE_SIZE)|DEFAULT_GO|SAVE_MODE_FLAG);
    //HAL_WRITE_UINT32(FLASH_CTRL_REG22, NCHIP_SELECT(0)|DEFAULT_GO|SAVE_MODE_FLAG);
    HAL_WRITE_UINT32(FLASH_CTRL_REG22, NCHIP_SELECT(chip)|DEFAULT_GO);

    // wait reg22 fifo command send done
    while(!check_cmd_done());

    //從reg20中讀出fs信息
    HAL_READ_UINT32(FLASH_CTRL_REG20, status);  // low 4Byte
    memcpy(fs_info,&status,4);
    HAL_READ_UINT32(FLASH_CTRL_REG21, status);  // high 2Byte
    memcpy(fs_info+4,&status,2);

    #ifdef STORE_ALL_INT
    restore_all_int(); //need or not??
    #endif//need or not??
    return NF_SUCCESS;
  }

}

/**
* @BRIEF read a block data
* @AUTHOR qxj
* @DATE 2006-7-17
* @PARAM 
  BlockNO: block number
  pData:   point to buffer to store data, 
           the buffer size is Nand_SysInfo.log_page_size * Nand_SysInfo.log_page_per_blk
* @RETURN
* @RETVAL
  return next valid block number, if return 0 indicate read this block fail
*/
static T_U16 nf_read_block(T_U32 BlockNO, T_U8 *pData)
{
    
    T_U32 i = 0, j = 0;
    T_U32 StartLogPageNO = 0;
    T_U8 spare[NFC_FS_INFO_SIZE];
  
  
    if(BlockNO >= Nand_SysInfo.total_blk_num || pData == AK_NULL)
        return 0;
  
    StartLogPageNO = BlockNO * Nand_SysInfo.log_page_per_blk;
    
  
    //printf("StartLogPageNO %d\n", StartLogPageNO);
    #ifdef BAD_BLOCK_TEST
    if(if_write_read_bad_block(BlockNO))
        return 0;
    #endif
    
    if( !nf_read_frame(StartLogPageNO , AK_NULL, spare) )
    {
        printf("read this block the first logpage 0x%x fail\n", StartLogPageNO);
        return 0;
    }
    
    if(spare[AVAILABLE_FLAG_OFFSET] != AVAILABLE_FLAG)
    {
        printf("this block the first page 0x%x, error available flag 0x%x\n", StartLogPageNO, spare[AVAILABLE_FLAG_OFFSET]);
        return 0;
    }
    
    if( (spare[BLOCK_INDEX_OFFSET] == 0xff)
	     &&(spare[BLOCK_INDEX_OFFSET + 1] == 0xff)
	     &&(spare[AVAILABLE_FLAG_OFFSET] == 0xff))//this block is a empty blk
    {
        printf("this is a empty block 0x%x, 0x%x 0x%x 0x%x\n", 
            StartLogPageNO + (i * Nand_SysInfo.Nand_LogPerPhy) + j, spare[BLOCK_INDEX_OFFSET],
            spare[BLOCK_INDEX_OFFSET + 1], spare[AVAILABLE_FLAG_OFFSET]);
        return 0;
    }
    
    
    for(i = 0; i < chipInfo.phy_page_per_blk; i++)
    {
        for(j = 0; j < Nand_SysInfo.Nand_LogPerPhy; j++)
        {
            //printf("read page %d\n", StartLogPageNO + (i * NFLASH_LOG_PER_PHY) + j);
      
            if( nf_read_frame(StartLogPageNO + (i * Nand_SysInfo.Nand_LogPerPhy) + j,
                              (T_U8 *)(pData + ((i * Nand_SysInfo.Nand_LogPerPhy) + j) * Nand_SysInfo.log_page_size),
                              spare) != AK_TRUE)
            {
                printf("read logpage %x fail\n", StartLogPageNO + (i * Nand_SysInfo.Nand_LogPerPhy) + j);
                return 0;
            }
        }
    }
    //printf("read block success\n");
  
    return *(T_S16 *)(spare + BLOCK_INDEX_OFFSET);
}

/**
* @BRIEF read data from flash in chain
in this chain,each item is a block.each block's the last spare area store a index which indicate
next valid block.
    CAUTION: must read all chain, because static value BlockIndex
* @AUTHOR qxj
* @DATE 2006-7-17
* @PARAM
  StartAddress : start address,this value will be change to next read block address
  EndAddress   : the chain last block address
  pData        : read data
  ReadLength   : read data length
  BackupMapAddress: backup chain store address

* @RETURN
* @RETVAL
  return AK_TRUE : success AK_FAIL: unsucess
*/
T_BOOL nf_force_read(T_U32 *StartAddress, T_U32 EndAddress, 
                     T_U8 *pData, T_U32 ReadLength, 
                     T_U32 BackupMapAddress)
{
    
    T_S32 readlen = (T_S32)ReadLength;
    T_U32 Offset = 0;
    T_U16 BackupBlockMap[NFC_LOG_PAGE_SIZE / 2];
    T_U32 MapBlockPage = 0, preMapBlockPage = 0;
    
    T_U32 StartBlockNumber;
    T_U32 EndBlockNumber;
    T_U32 CurrentBlockNumber;
    
    
    T_U32 StartLogicPageNumber = 0;
    T_U32 EndLogicPageNumber = 0;
    T_U8 chip;
    
    static T_U16 BlockIndex = 0;
    
    if(StartAddress == AK_NULL || pData == AK_NULL)
        return AK_FALSE;

    if(*StartAddress < (Nand_SysInfo.log_page_size * Nand_SysInfo.log_page_per_blk))//the first block
    {
        StartLogicPageNumber = *StartAddress / Nand_SysInfo.log_page_size;
        EndLogicPageNumber = EndAddress / Nand_SysInfo.log_page_size;
        
        printf("read from 0 block\n");
        printf("Start logic page 0x%x End logic page 0x%x data length 0x%x\n", 
                StartLogicPageNumber, EndLogicPageNumber, readlen);
        
        while((StartLogicPageNumber < EndLogicPageNumber) && readlen > 0)
    	{
    	    chip = (T_U8)(StartLogicPageNumber / Nand_SysInfo.chip_logpage_num);
            
            if(nf_read_page(chip, StartLogicPageNumber / Nand_SysInfo.Nand_LogPerPhy,
            (StartLogicPageNumber % Nand_SysInfo.Nand_LogPerPhy) * Nand_SysInfo.log_page_size,\
                pData,Nand_SysInfo.log_page_size, AK_FALSE) == AK_FALSE)
            {
                printf("read failed!\n");
                break;
            }
            //printf("successful!\n");
            pData += Nand_SysInfo.log_page_size;
            readlen -= Nand_SysInfo.log_page_size;
            StartLogicPageNumber++;
            *StartAddress += Nand_SysInfo.log_page_size;
    	}
    	
    	if(readlen <= 0)
            return AK_TRUE;
        else
        {
            printf("not all data read\n");
            return AK_FALSE;
        }
    }
    
    StartBlockNumber = (*StartAddress) / 
                       (Nand_SysInfo.log_page_size * Nand_SysInfo.log_page_per_blk);
                       
    EndBlockNumber = EndAddress / 
                     (Nand_SysInfo.log_page_size * Nand_SysInfo.log_page_per_blk);
    
    printf("StartBlockNumber 0x%x EndBlockNumber 0x%x readlen 0x%x\n", 
            StartBlockNumber, EndBlockNumber, readlen);
    
    for(CurrentBlockNumber = StartBlockNumber;
        CurrentBlockNumber <= EndBlockNumber && readlen > 0;)
    {
        //read ECC ok
        printf("read block 0x%x\n", CurrentBlockNumber);
        
        T_U32 tmp_block;
        if((tmp_block = nf_read_block(CurrentBlockNumber, pData)) == 0)
        {
            printf("read block fail\n");
            
            if(BackupMapAddress == 0)
            {
                printf("no backup data\n");
                //return AK_FALSE;
                CurrentBlockNumber++;
                continue;
            }
      
            //read the backup page
            MapBlockPage = BackupMapAddress / Nand_SysInfo.log_page_size;
            MapBlockPage += (BlockIndex / (Nand_SysInfo.log_page_size / 2));
            Offset = BlockIndex % (Nand_SysInfo.log_page_size / 2);
            
            printf("backup map page 0x%x offset 0x%x\n", MapBlockPage, Offset);

            if(MapBlockPage != preMapBlockPage)
            {
                preMapBlockPage = MapBlockPage;
        
                chip = (T_U8)(MapBlockPage / Nand_SysInfo.chip_logpage_num);
        
                if(nf_read_page(chip, MapBlockPage / Nand_SysInfo.Nand_LogPerPhy, 
                    (MapBlockPage % Nand_SysInfo.Nand_LogPerPhy) * Nand_SysInfo.log_page_size,
                    (T_U8 *)BackupBlockMap, Nand_SysInfo.log_page_size, AK_FALSE) == AK_FALSE)
                {
                    printf("read backup map false\n");
                    return AK_FALSE;
                }
                /*
                T_U32 i;
    
                for(i = 0; i < 512 / 2; i++)
                {
                  if(i != 0 && i % 8 == 0)
                    printf("\n");
                  
                  printf(" 0x%x ", BackupBlockMap[i]);
                }
                */
            }
      
            printf("read backup block 0x%x\n", BackupBlockMap[Offset]);
      
            if((tmp_block = nf_read_block((T_U32)(BackupBlockMap[Offset]),pData)) == 0)
            {
                printf("read backup data false\n");
                return AK_FALSE;
            }
        }
        CurrentBlockNumber = tmp_block;
        
        printf("success, next block 0x%x\n", CurrentBlockNumber);

        //Block is OK
  
        //printf("BlockNO %d\n", BlockNO);
  
        //to read the specified next Block        
        pData += (Nand_SysInfo.log_page_size * Nand_SysInfo.log_page_per_blk);
        readlen -= (Nand_SysInfo.log_page_size * Nand_SysInfo.log_page_per_blk);

        //the last block, all data be readed
        if(CurrentBlockNumber == LAST_BLOCK_FLAG)
        {
            printf("last block flag\n");
            readlen = 0;
            BlockIndex = 0;
            break;
        }
        
        printf("readlen 0x%x\n", readlen);
        BlockIndex++;
    }
  
    *StartAddress = CurrentBlockNumber * (Nand_SysInfo.log_page_size * Nand_SysInfo.log_page_per_blk);

    //force read ok
    if (readlen <= 0)
        return AK_TRUE;
    else 
        return AK_FALSE;
}


#endif//OS_ANYKA

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩国产在线观看| 国产不卡视频在线播放| 777a∨成人精品桃花网| 视频一区中文字幕国产| 日韩美一区二区三区| 精品午夜久久福利影院| 久久精品一区二区三区不卡| 成人高清av在线| 亚洲一二三四久久| 日韩一区二区三区在线观看 | 91九色02白丝porn| 午夜影院在线观看欧美| 日韩欧美123| av动漫一区二区| 性做久久久久久久免费看| 日韩欧美一级在线播放| 国产 日韩 欧美大片| 亚洲精品菠萝久久久久久久| 欧美一区二区视频网站| 国产一区二区福利| 一区二区三区高清在线| 日韩欧美一级二级| 99re6这里只有精品视频在线观看| 一区二区三区在线观看视频| 精品美女在线观看| 91网上在线视频| 蜜臂av日日欢夜夜爽一区| 国产农村妇女毛片精品久久麻豆| 在线观看精品一区| 国产毛片精品一区| 一区二区在线观看av| 精品国偷自产国产一区| 99久久免费视频.com| 裸体健美xxxx欧美裸体表演| 中文字幕日韩一区二区| 日韩欧美成人激情| 91黄色免费网站| 国产成人亚洲综合a∨猫咪| 亚洲综合小说图片| 国产精品免费久久久久| 日韩免费性生活视频播放| 一本一道久久a久久精品 | 精品成人免费观看| 91美女在线视频| 国产一区二区三区香蕉| 亚洲不卡一区二区三区| 中文字幕一区二区视频| 日韩免费高清av| 欧美日精品一区视频| 国产成人aaaa| 久热成人在线视频| 亚洲第一电影网| 亚洲色图制服丝袜| 国产欧美一区二区三区在线看蜜臀 | 色婷婷综合久久| 国产凹凸在线观看一区二区| 亚洲精品成人精品456| 欧美高清性hdvideosex| 97se亚洲国产综合自在线观| 国产真实乱对白精彩久久| 视频一区免费在线观看| 亚洲一区二区三区四区在线观看 | 一级女性全黄久久生活片免费| 久久久久久黄色| 亚洲精品在线观看视频| 91精品国产综合久久香蕉的特点| 色av一区二区| 91麻豆国产在线观看| 成人高清视频免费观看| 成人午夜视频网站| 成人一级视频在线观看| 国产精品中文字幕欧美| 国产精品一区久久久久| 亚洲精品国产a久久久久久 | 成人h精品动漫一区二区三区| 国产主播一区二区| 国产精品综合av一区二区国产馆| 国内久久婷婷综合| 韩国女主播一区| 国产精品亚洲人在线观看| 国产成人在线视频网站| 成人免费视频一区| 97久久精品人人澡人人爽| 91在线观看地址| 色爱区综合激月婷婷| 欧美性大战久久久久久久| 欧美日韩国产高清一区二区| 制服.丝袜.亚洲.另类.中文| 欧美一区二区三区四区在线观看| 日韩一卡二卡三卡| 久久精品人人做| 亚洲婷婷综合久久一本伊一区| 中文字幕一区二区三| 亚洲精品久久7777| 日韩精品电影在线| 国产综合久久久久久鬼色| 成人av免费在线| 91黄色在线观看| 日韩欧美在线网站| 国产女人18毛片水真多成人如厕 | 亚洲午夜羞羞片| 日本中文一区二区三区| 韩国av一区二区三区四区 | 国产ts人妖一区二区| 成人18视频日本| 欧美三级日韩三级国产三级| 日韩欧美国产麻豆| 国产精品久久久久久久久免费相片 | 亚洲免费在线视频| 水野朝阳av一区二区三区| 经典三级视频一区| av成人老司机| 欧美第一区第二区| 亚洲视频一区二区在线观看| 日韩精品一卡二卡三卡四卡无卡| 国产精品自拍网站| 欧美日韩在线免费视频| 精品久久久久久无| 一区二区三区精品在线| 久久99精品一区二区三区| 成人少妇影院yyyy| 9191精品国产综合久久久久久| 国产亚洲va综合人人澡精品| 一区二区三区四区亚洲| 国产剧情一区二区| 欧美电影一区二区三区| 国产精品美女久久久久久久| 婷婷夜色潮精品综合在线| 国产夫妻精品视频| 91精品免费在线观看| 亚洲欧美日本在线| 国产精品影视在线观看| 欧美日韩免费观看一区三区| 中文字幕不卡在线观看| 另类综合日韩欧美亚洲| 欧美日韩三级视频| 综合自拍亚洲综合图不卡区| 国内精品免费**视频| 欧美日韩亚洲丝袜制服| 亚洲视频在线一区观看| 国产成人免费视频一区| 日韩欧美国产一区二区三区| 亚洲一二三四久久| 色综合天天综合给合国产| 国产午夜精品一区二区三区视频 | 国产又黄又大久久| 7777精品久久久大香线蕉| 一区二区三区中文字幕| 成人av电影在线播放| 久久久久久99久久久精品网站| 日本成人在线不卡视频| 欧美性猛交xxxxxxxx| 一区二区三区毛片| 91麻豆国产在线观看| 亚洲欧洲国产日本综合| 国产成人精品亚洲午夜麻豆| 精品国产一区a| 麻豆精品一区二区综合av| 欧美片网站yy| 亚洲va韩国va欧美va| 欧洲av一区二区嗯嗯嗯啊| 亚洲欧美电影一区二区| 白白色 亚洲乱淫| 国产精品不卡视频| 成人久久18免费网站麻豆| 国产精品色眯眯| jiyouzz国产精品久久| 中文字幕+乱码+中文字幕一区| 国产精品12区| 国产精品美女视频| av网站一区二区三区| 综合色天天鬼久久鬼色| 91色.com| 亚洲福利视频三区| 欧美日韩免费在线视频| 日本亚洲一区二区| 日韩一区二区电影| 国产精品77777| 国产精品视频免费看| 91美女片黄在线观看91美女| 亚洲一区二区三区激情| 欧美剧在线免费观看网站| 蜜桃久久久久久| 国产亚洲综合在线| 91美女蜜桃在线| 视频一区二区三区中文字幕| 日韩精品一区二区三区老鸭窝| 国产乱子轮精品视频| 中文字幕一区日韩精品欧美| 欧洲色大大久久| 男女男精品视频网| 2014亚洲片线观看视频免费| 成人av网站大全| 亚洲国产视频网站| 久久久蜜臀国产一区二区| 99精品视频免费在线观看| 亚洲成a人v欧美综合天堂下载 | 久久综合给合久久狠狠狠97色69| 国产成人免费视频网站 | 欧美视频一区二区三区|