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

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

?? swecc.c

?? s3c6400(ARM11)的JTAG燒寫軟件
?? C
字號:
/*****************************************************************************/
/*                                                                           */
/* PROJECT : AnyStore II                                                     */
/* MODULE  : XSR BML                                                         */
/* NAME    : SW Error Correction Code (Hamming Algorithm)                    */
/* FILE    : SWEcc.cpp                                                       */
/* PURPOSE : Implementation of FIL                                           */
/*           Guarantee Data Intigrity                                        */
/*                                                                           */
/*---------------------------------------------------------------------------*/
/*                                                                           */
/*        COPYRIGHT 2003-2006, SAMSUNG ELECTRONICS CO., LTD.                 */
/*                      ALL RIGHTS RESERVED                                  */
/*                                                                           */
/*   Permission is hereby granted to licenses of Samsung Electronics         */
/*   Co., Ltd. products to use or abstract this computer program only in     */
/*   accordance with the terms of the NAND FLASH MEMORY SOFTWARE LICENSE     */
/*   AGREEMENT for the sole purpose of implementing a product based on       */
/*   Samsung Electronics Co., Ltd. products. No other rights to reproduce,   */
/*   use, or disseminate this computer program, whether in part or in whole, */
/*   are granted.                                                            */
/*                                                                           */
/*   Samsung Electronics Co., Ltd. makes no representation or warranties     */
/*   with respect to the performance of this computer program, and           */
/*   specifically disclaims any responsibility for any damages,              */
/*   special or consequential, connected with the use of this program.       */
/*                                                                           */
/*---------------------------------------------------------------------------*/
/*                                                                           */
/* REVISION HISTORY                                                          */
/*                                                                           */
/* - 27/DEC/2002 [Kwangyoon Lee] : first writing                             */
/* - 15/JUL/2003 [SeWook Na] : code modification                             */
/* - 10/AUG/2003 [Janghwan Kim] : add codes                                  */
/* - 11/AUG/2003 [Janghwan Kim] : code optimization                          */
/* - 15/AUG/2003 [Janghwan Kim] : bug fix                                    */
/* - 02/OCT/2003 [Janghwan Kim] : reorganization                             */
/* - 13/NOV/2003 [Chang JongBaek] : Rewriting with new algorithm             */
/* - 26/NOV/2003 [JangHwan Kim] : Reoranization                              */
/* - 27/NOV/2003 [JangHwan Kim] : Add Gen, Comp function for Spare Array     */
/*                                                                           */
/*---------------------------------------------------------------------------*/
/*                                                                           */
/* - Make ECC parity code of 512bytes and 3 bytes are represented            */
/*   And ECC compare & Correction code is also represented                   */
/*                                                                           */
/*****************************************************************************/

#include "..\include\Def.h"
#include "..\include\swecc.h"

/*****************************************************************************/
/* Debug Configuration                                                       */
/*****************************************************************************/
/*
#undef  ECC_DEBUG
#undef  ECC_ERR_TRACE

#define ECC_RTL_PRINT(x)        XSR_RTL_PRINT(x)

#if defined(ECC_DEBUG)
    #define ECC_ERR_PRINT(x)        XSR_RTL_PRINT(x)
    #define ECC_DBG_PRINT(x)        XSR_DBG_PRINT(x)
#else
    #if defined(ECC_ERR_TRACE)
    #define ECC_DBG_PRINT(x)
    #define ECC_ERR_PRINT(x)        XSR_RTL_PRINT(x)
    #else
    #define ECC_DBG_PRINT(x)
    #define ECC_ERR_PRINT(x)
    #endif  
*/
/* #if defined(ECC_ERR_TRACE) */

//#endif  /* #if defined(ECC_DEBUG) */



/*****************************************************************************/
/*                                                                           */
/* NAME                                                                      */
/*      GenEccM                                                              */
/* DESCRIPTION                                                               */
/*      This function generates 3 byte ECC for 512 byte data.                */
/*      (Software ECC)                                                       */
/* PARAMETERS                                                                */
/*      pEcc                                                                 */
/*          The memory location for given ECC val                            */
/*      pBuf                                                                 */
/*          The memory location for given data                               */
/*      nBW                                                                  */
/*          Data Band Width of the device                                    */
/* RETURN VALUES                                                             */
/*      none                                                                 */
/*                                                                           */
/*****************************************************************************/
void ECC_GenM(U8 *pEcc, U32 *pBuf, U8 nBW)// nBW = 0(8bit), nBW = 1(16bit)
{
    U32  nCnt, nTmp;
    U32  nEcc = 0;
    U32  nCol, nRow = 0;
    U32  nCol4 = 0, nCol2 = 0, nCol1 = 0, nColT = 0;
    U32  nXorT = 0;
    U32 *pDat32 = pBuf;  

    for(nCnt = 0; nCnt < 16; nCnt++)
    {
        nCol = *pDat32++; 
        nTmp = *pDat32++; nCol ^= nTmp; nCol1 ^= nTmp;
        nTmp = *pDat32++; nCol ^= nTmp;                nCol2 ^= nTmp;
        nTmp = *pDat32++; nCol ^= nTmp; nCol1 ^= nTmp; nCol2 ^= nTmp;
        nTmp = *pDat32++; nCol ^= nTmp;                               nCol4 ^= nTmp;
        nTmp = *pDat32++; nCol ^= nTmp; nCol1 ^= nTmp;                nCol4 ^= nTmp;
        nTmp = *pDat32++; nCol ^= nTmp;                nCol2 ^= nTmp; nCol4 ^= nTmp;
        nTmp = *pDat32++; nCol ^= nTmp; nCol1 ^= nTmp; nCol2 ^= nTmp; nCol4 ^= nTmp;

        nColT ^= nCol;

        nTmp = (nCol  >> 16) ^ nCol;
        nTmp = (nTmp  >>  8) ^ nTmp;
        nTmp = (nTmp  >>  4) ^ nTmp;
        nTmp = ((nTmp >>  2) ^ nTmp) & 0x03;

        if ((nTmp == 0x01) || (nTmp == 0x02))
        {
            nRow  ^= nCnt;
            nXorT ^= 0x01;
        }
    }

    if (nBW == BW_X08)
    {
        nTmp  = (nCol4 >> 16) ^ nCol4;              /********/
        nTmp  = (nTmp  <<  8) ^ nTmp;               /*      */
        nTmp  = (nTmp  >>  4) ^ nTmp;               /* p128 */
        nTmp  = (nTmp  >>  2) ^ nTmp;               /*      */
        nEcc |= ((nTmp <<  1) ^ nTmp) & 0x200;      /********/
    
        nTmp  = (nCol2 >> 16) ^ nCol2;              /********/
        nTmp  = (nTmp  >>  8) ^ nTmp;               /*      */
        nTmp  = (nTmp  <<  4) ^ nTmp;               /* p64  */
        nTmp  = (nTmp  <<  2) ^ nTmp;               /*      */
        nEcc |= ((nTmp <<  1) ^ nTmp) & 0x80;       /********/
    
        nTmp  = (nCol1 >> 16) ^ nCol1;              /********/
        nTmp  = (nTmp  >>  8) ^ nTmp;               /*      */
        nTmp  = (nTmp  <<  4) ^ nTmp;               /* p32  */
        nTmp  = (nTmp  >>  2) ^ nTmp;               /*      */
        nEcc |= ((nTmp <<  1) ^ nTmp) & 0x20;       /********/
    
        nTmp  = (nColT & 0xFFFF0000);               /********/
        nTmp  = (nTmp  >> 16);                      /*      */
        nTmp  = (nTmp  >>  8) ^ nTmp;               /* p16  */
        nTmp  = (nTmp  >>  4) ^ nTmp;               /*      */
        nTmp  = (nTmp  <<  2) ^ nTmp;               /*      */
        nEcc |= ((nTmp <<  1) ^ nTmp) & 0x08;       /********/
    
        nTmp  = (nColT & 0xFF00FF00);               /********/
        nTmp  = (nTmp  >> 16) ^ nTmp;               /*      */
        nTmp  = (nTmp  >>  8);                      /*  p8  */
        nTmp  = (nTmp  >>  4) ^ nTmp;               /*      */
        nTmp  = (nTmp  >>  2) ^ nTmp;               /*      */
        nEcc |= ((nTmp <<  1) ^ nTmp) & 0x02;       /********/
    
        nTmp  = (nColT & 0xF0F0F0F0);               /********/
        nTmp  = (nTmp  << 16) ^ nTmp;               /*      */
        nTmp  = (nTmp  >>  8) ^ nTmp;               /*  p4  */
        nTmp  = (nTmp  <<  2) ^ nTmp;               /*      */
        nEcc |= ((nTmp <<  1) ^ nTmp) & 0x800000;   /********/
                                                    
        nTmp  = (nColT & 0xCCCCCCCC);               /********/
        nTmp  = (nTmp  << 16) ^ nTmp;               /*      */
        nTmp  = (nTmp  >>  8) ^ nTmp;               /*  p2  */
        nTmp  = (nTmp  <<  4) ^ nTmp;               /*      */
        nTmp  = (nTmp  >>  2);                      /*      */
        nEcc |= ((nTmp <<  1) ^ nTmp) & 0x200000;   /********/
    
        nTmp  = (nColT & 0xAAAAAAAA);               /********/
        nTmp  = (nTmp  << 16) ^ nTmp;               /*      */
        nTmp  = (nTmp  >>  8) ^ nTmp;               /*  p1  */
        nTmp  = (nTmp  >>  4) ^ nTmp;               /*      */
        nTmp  = (nTmp  <<  2) ^ nTmp;               /*      */
        nEcc |= (nTmp  & 0x80000);                  /********/
    
        nEcc |= (nRow  & 0x01) << 11;               /* p256 */
        nEcc |= (nRow  & 0x02) << 12;               /* p512 */
        nEcc |= (nRow  & 0x04) << 13;               /* p1024*/
        nEcc |= (nRow  & 0x08) << 14;               /* p2048*/
    }
    else    /* BW_X16 */
    {
        nTmp  = (nCol4 >> 16) ^ nCol4;              /********/
        nTmp  = (nTmp  >>  8) ^ nTmp;               /*      */
        nTmp  = (nTmp  <<  4) ^ nTmp;               /* p128 */
        nTmp  = (nTmp  <<  2) ^ nTmp;               /*      */
        nEcc |= ((nTmp <<  1) ^ nTmp) & 0x80;       /********/
                                                              
        nTmp  = (nCol2 >> 16) ^ nCol2;              /********/
        nTmp  = (nTmp  >>  8) ^ nTmp;               /*      */
        nTmp  = (nTmp  <<  4) ^ nTmp;               /* p64  */
        nTmp  = (nTmp  >>  2) ^ nTmp;               /*      */
        nEcc |= ((nTmp <<  1) ^ nTmp) & 0x20;       /********/
                                                              
        nTmp  = (nCol1 >> 16) ^ nCol1;              /********/
        nTmp  = (nTmp  >>  8) ^ nTmp;               /*      */
        nTmp  = (nTmp  >>  4) ^ nTmp;               /* p32  */
        nTmp  = (nTmp  <<  2) ^ nTmp;               /*      */
        nEcc |= ((nTmp <<  1) ^ nTmp) & 0x08;       /********/
                                                              
        nTmp  = (nColT & 0xFFFF0000);               /********/
        nTmp  = (nTmp  >> 16);                      /*      */
        nTmp  = (nTmp  >>  8) ^ nTmp;               /* p16  */
        nTmp  = (nTmp  >>  4) ^ nTmp;               /*      */
        nTmp  = (nTmp  >>  2) ^ nTmp;               /*      */
        nEcc |= ((nTmp <<  1) ^ nTmp) & 0x02;       /********/
                                                              
        nTmp  = (nColT & 0xFF00FF00);               /********/
        nTmp  = (nTmp  << 16) ^ nTmp;               /*      */
        nTmp  = (nTmp  >>  8);                      /*  p8  */
        nTmp  = (nTmp  <<  4) ^ nTmp;               /*      */
        nTmp  = (nTmp  <<  2) ^ nTmp;               /*      */
        nEcc |= ((nTmp <<  1) ^ nTmp) & 0x800000;   /********/
                                                              
        nTmp  = (nColT & 0xF0F0F0F0);               /********/
        nTmp  = (nTmp  << 16) ^ nTmp;               /*      */
        nTmp  = (nTmp  >>  8) ^ nTmp;               /*  p4  */
        nTmp  = (nTmp  >>  2) ^ nTmp;               /*      */
        nEcc |= ((nTmp <<  1) ^ nTmp) & 0x200000;   /********/
                                                              
        nTmp  = (nColT & 0xCCCCCCCC);               /********/
        nTmp  = (nTmp  << 16) ^ nTmp;               /*      */
        nTmp  = (nTmp  >>  8) ^ nTmp;               /*  p2  */
        nTmp  = (nTmp  >>  4) ^ nTmp;               /*      */
        nEcc |= ((nTmp <<  1) ^ nTmp) & 0x80000;    /********/
                                                              
        nTmp  = (nColT & 0xAAAAAAAA);               /********/
        nTmp  = (nTmp  << 16) ^ nTmp;               /*      */
        nTmp  = (nTmp  >>  8) ^ nTmp;               /*  p1  */
        nTmp  = (nTmp  >>  4) ^ nTmp;               /*      */
        nTmp  = (nTmp  >>  2) ^ nTmp;               /*      */
        nEcc |= (nTmp  & 0x20000);                  /********/
                                                              
        nEcc |= (nRow  & 0x01) <<  9;               /* p256 */
        nEcc |= (nRow  & 0x02) << 10;               /* p512 */
        nEcc |= (nRow  & 0x04) << 11;               /* p1024*/
        nEcc |= (nRow  & 0x08) << 12;               /* p2048*/
    }

    if (nXorT)
    {
        nEcc |= (nEcc ^ 0x00AAAAAA) >> 1;
    }
    else
    {
        nEcc |= (nEcc >> 1);
    }

    nEcc = ~nEcc;

    *(pEcc + 2) = (U8)(nEcc >> 16);
    *(pEcc + 1) = (U8)(nEcc >> 8);
    *(pEcc + 0) = (U8)(nEcc);
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩免费电影网站| 青青草97国产精品免费观看| 美女被吸乳得到大胸91| 99久久精品99国产精品| 日韩无一区二区| 一区二区三区四区精品在线视频 | 91精品国产综合久久香蕉麻豆| 2017欧美狠狠色| 亚洲成人精品影院| 本田岬高潮一区二区三区| 欧美岛国在线观看| 天堂蜜桃一区二区三区| 一本久久a久久免费精品不卡| 国产亚洲成aⅴ人片在线观看 | 1000精品久久久久久久久| 乱中年女人伦av一区二区| 在线观看欧美日本| 一区二区中文视频| 粉嫩av一区二区三区粉嫩| 欧美mv和日韩mv的网站| 蜜桃久久久久久久| 日韩一区二区三区高清免费看看| 亚洲欧美成aⅴ人在线观看| 国产成人精品三级麻豆| wwwwxxxxx欧美| 精品一二三四在线| 精品三级在线看| 九色porny丨国产精品| 欧美一三区三区四区免费在线看 | 美女视频网站久久| 91福利社在线观看| 亚洲一区免费观看| 欧美三级电影网站| 亚洲大片一区二区三区| 欧美色综合久久| 午夜精品久久久久久久99水蜜桃| 欧美日韩中文另类| 天天色天天操综合| 91精品国产色综合久久ai换脸 | 成人精品电影在线观看| 国产精品传媒在线| 99久久夜色精品国产网站| 亚洲天堂2014| 欧美日韩久久久久久| 五月婷婷欧美视频| 精品少妇一区二区三区日产乱码 | 激情国产一区二区| 国产午夜亚洲精品不卡 | 老司机精品视频线观看86| 精品少妇一区二区三区日产乱码 | 亚洲曰韩产成在线| 91精品国产一区二区三区蜜臀| 久久99精品久久久久久国产越南| 国产日韩欧美一区二区三区乱码 | 不卡电影一区二区三区| 一区二区成人在线| 91精选在线观看| 国产综合久久久久影院| 国产精品久久精品日日| 欧美日韩一区在线| 蜜桃av一区二区在线观看| 国产日产欧美一区| 欧美视频中文一区二区三区在线观看| 奇米四色…亚洲| 国产精品美女久久久久久久久| 欧美午夜精品久久久久久孕妇| 看片的网站亚洲| 亚洲欧美偷拍另类a∨色屁股| 91麻豆精品国产91久久久更新时间| 久久99久久99小草精品免视看| 中文字幕中文在线不卡住| 精品1区2区3区| 大陆成人av片| 日本美女一区二区三区视频| 中文字幕国产一区| 欧美一区二区三区视频免费 | 国产伦精品一区二区三区免费 | 看电影不卡的网站| 亚洲一区二区美女| 久久久国产午夜精品| 欧美性生活一区| 波多野结衣亚洲一区| 奇米一区二区三区| 亚洲制服丝袜av| 国产精品网曝门| 欧美成人免费网站| 国产精品美日韩| 国产精品日产欧美久久久久| 成人app软件下载大全免费| 亚洲一区在线视频| 亚洲欧洲精品一区二区三区不卡| 日韩一级大片在线观看| 欧美中文字幕一区二区三区| 国产成人综合自拍| 蜜桃视频免费观看一区| 久久综合国产精品| 欧美一级免费观看| 国产日韩欧美不卡在线| 18欧美亚洲精品| 亚洲成人免费视| 国产一区二区三区日韩| 成人自拍视频在线观看| 色婷婷精品久久二区二区蜜臀av | 成人免费看视频| 欧美亚洲精品一区| 欧美xxxx老人做受| 欧美韩日一区二区三区四区| 一区二区三区美女| 精品无码三级在线观看视频| 成人午夜私人影院| 欧美人与禽zozo性伦| 日韩色视频在线观看| 国产精品三级av| 日韩中文字幕区一区有砖一区| 精品综合久久久久久8888| 99国产精品视频免费观看| 欧美一级国产精品| 国产精品久久久久久久久果冻传媒| 亚洲va韩国va欧美va| 福利91精品一区二区三区| 色婷婷久久久久swag精品| 精品国产髙清在线看国产毛片| 国产精品久久久久影院| 日本91福利区| 色94色欧美sute亚洲线路一ni| 精品av久久707| 亚洲图片自拍偷拍| 粉嫩av一区二区三区在线播放 | 欧美日韩精品欧美日韩精品| 国产亚洲婷婷免费| 丝袜a∨在线一区二区三区不卡| 成人午夜精品在线| 5858s免费视频成人| 亚洲色图色小说| 国产精品一区二区91| 欧美放荡的少妇| 自拍偷拍欧美激情| 国产精品小仙女| 欧美tickling网站挠脚心| 亚州成人在线电影| 99国产精品99久久久久久| 久久欧美一区二区| 日本美女一区二区| 精品视频在线免费观看| 亚洲免费av观看| av中文一区二区三区| 国产亚洲一区二区三区| 蜜臀av性久久久久蜜臀av麻豆| 欧美色视频在线| 夜夜精品视频一区二区| 99国产精品久久久久久久久久 | 奇米色一区二区| 欧美久久久久免费| 亚洲一区日韩精品中文字幕| 91在线观看视频| 亚洲三级在线播放| av高清不卡在线| 精品在线播放午夜| 在线不卡的av| 亚洲不卡一区二区三区| 欧美日韩一区三区| 日韩中文字幕1| 欧美精品亚洲一区二区在线播放| 亚洲午夜一区二区| 欧美日韩在线直播| 视频一区在线播放| 这里只有精品电影| 蜜臀av一级做a爰片久久| 日韩一区二区影院| 免费成人你懂的| 日韩你懂的在线观看| 国产一区二区免费看| 国产午夜精品一区二区三区视频| 丁香一区二区三区| 亚洲欧美怡红院| 91久久线看在观草草青青| 亚洲综合自拍偷拍| 欧美一区三区二区| 精品在线你懂的| 亚洲国产精品二十页| 91丨porny丨户外露出| 亚洲精品免费在线播放| 欧美日韩一区二区三区在线看| 亚洲成人综合网站| 欧美变态凌虐bdsm| 国产ts人妖一区二区| 亚洲美女免费在线| 欧美精品日韩一本| 国产高清精品在线| 中文字幕在线观看一区二区| 色狠狠色狠狠综合| 日本欧美一区二区三区乱码| 精品电影一区二区| 成人av网站免费观看| 亚洲电影视频在线| 欧美成人精品1314www| av成人免费在线观看| 亚洲一二三区在线观看| 日韩一级免费观看| 成人黄色小视频|