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

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

?? swecc.c

?? s3c6410的jtag程序sjf6410_1.0
?? C
字號(hào):
/*****************************************************************************/
/*                                                                           */
/* 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);
}


?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品在线观看网站| 国产精品免费久久| 国产成人精品一区二| 亚洲综合av网| 欧美国产精品v| 欧美电影免费观看高清完整版| 成人av第一页| 激情深爱一区二区| 性久久久久久久| 亚洲色欲色欲www| 久久久久久久久久久99999| 欧美视频中文一区二区三区在线观看| 狠狠色丁香久久婷婷综合丁香| 亚洲一区免费观看| 国产精品私人影院| 久久久精品蜜桃| 在线播放91灌醉迷j高跟美女| 99久久久国产精品| 国产成人亚洲综合a∨婷婷 | 欧美日韩一区二区三区在线看| 国产夫妻精品视频| 久久国产人妖系列| 日韩国产精品大片| 亚洲国产成人av网| 一区二区三区国产精华| 亚洲欧洲三级电影| 国产女主播视频一区二区| 精品欧美乱码久久久久久1区2区| 欧美色男人天堂| 在线精品观看国产| 日本高清成人免费播放| 91丨porny丨国产入口| 成人av综合一区| 成人免费视频视频在线观看免费| 国产一区二区日韩精品| 国产一区激情在线| 7777精品伊人久久久大香线蕉完整版 | 久久亚洲综合av| 欧美成人一区二区| 欧美mv日韩mv国产网站app| 日韩视频在线永久播放| 91精品国产综合久久久久久漫画 | 有坂深雪av一区二区精品| 中文字幕制服丝袜成人av| 国产精品丝袜一区| 中文字幕永久在线不卡| 亚洲乱码中文字幕| 亚洲一级片在线观看| 午夜av电影一区| 日本中文字幕一区二区有限公司| 人人狠狠综合久久亚洲| 麻豆国产91在线播放| 久久黄色级2电影| 国产精品原创巨作av| 国产91丝袜在线观看| 成人av电影在线网| 欧洲精品一区二区三区在线观看| 欧美日韩国产高清一区| 91 com成人网| 精品91自产拍在线观看一区| 久久久噜噜噜久久人人看 | 26uuu精品一区二区三区四区在线| 精品国产青草久久久久福利| 国产女人水真多18毛片18精品视频| 国产精品丝袜91| 成人激情动漫在线观看| 91美女片黄在线观看| 欧美久久久久久久久久| 26uuu亚洲综合色| 国产精品久久久久桃色tv| 一片黄亚洲嫩模| 蜜桃av噜噜一区| 高清国产午夜精品久久久久久| 色综合一个色综合亚洲| 欧美日本一区二区在线观看| 26uuu另类欧美| 亚洲最大成人综合| 男人的天堂久久精品| 成人午夜电影小说| 精品视频全国免费看| 26uuu成人网一区二区三区| 日韩美女精品在线| 日本不卡高清视频| 成av人片一区二区| 欧美视频在线不卡| 久久久久久一二三区| 亚洲综合男人的天堂| 国产一区亚洲一区| 在线观看免费视频综合| 精品久久五月天| 一区二区三区高清| 激情都市一区二区| 91福利国产成人精品照片| 久久综合色一综合色88| 亚洲一区二区高清| 成人精品高清在线| 欧美日韩国产成人在线91| 国产精品毛片无遮挡高清| 日韩高清中文字幕一区| 91色婷婷久久久久合中文| av电影在线不卡| 国产激情视频一区二区在线观看 | 久久精品视频在线看| 亚洲一二三区在线观看| 国产99精品国产| 欧美变态tickling挠脚心| 亚洲综合一区在线| 国产精品123| 日韩欧美久久久| 亚洲va欧美va人人爽午夜| 国产成人免费xxxxxxxx| 91精品国产丝袜白色高跟鞋| 亚洲三级在线免费| 国产 日韩 欧美大片| 日韩女优视频免费观看| 午夜在线电影亚洲一区| 日本乱人伦一区| 中文字幕一区视频| 国产老女人精品毛片久久| 日韩一级片网址| 午夜久久久影院| 在线免费观看成人短视频| 亚洲国产精品激情在线观看| 国产一区二区三区最好精华液 | 亚洲视频电影在线| 国产激情精品久久久第一区二区 | caoporn国产一区二区| 久久精品欧美日韩精品| 激情综合五月天| 日韩欧美亚洲另类制服综合在线| 亚洲国产精品一区二区久久恐怖片 | 国产欧美日本一区二区三区| 国产在线播放一区三区四| 日韩午夜精品视频| 蜜桃av一区二区| 精品国产一区二区精华| 奇米影视7777精品一区二区| 制服丝袜成人动漫| 奇米影视在线99精品| 日韩一区二区不卡| 狠狠色2019综合网| 久久久九九九九| 成人精品一区二区三区中文字幕| 国产午夜精品一区二区三区嫩草 | 精品国产一区二区国模嫣然| 久久99精品国产91久久来源| 精品国产髙清在线看国产毛片| 欧美aaa在线| 久久成人羞羞网站| 日韩亚洲电影在线| 韩国v欧美v日本v亚洲v| www一区二区| 成人aa视频在线观看| 亚洲少妇最新在线视频| 欧美性猛交xxxxxxxx| 奇米色一区二区三区四区| 欧美videos中文字幕| 国产白丝网站精品污在线入口| 中文字幕av一区二区三区免费看| 91影视在线播放| 亚洲成av人片在线观看| 欧美成va人片在线观看| 粉嫩一区二区三区在线看| 亚洲色图色小说| 欧美疯狂性受xxxxx喷水图片| 久久99久久久欧美国产| 欧美高清在线一区二区| 日本久久电影网| 免费久久精品视频| 国产精品视频免费| 欧美日韩亚洲国产综合| 精品一二线国产| 亚洲欧美国产毛片在线| 欧美一区二区三区色| 成人中文字幕电影| 日韩黄色小视频| 亚洲国产精品成人综合| 欧美日韩美女一区二区| 国产成人综合视频| 无码av免费一区二区三区试看| 久久久五月婷婷| 欧美日韩1区2区| 岛国精品在线观看| 亚洲va国产va欧美va观看| 久久午夜国产精品| 欧美日韩一区视频| 风流少妇一区二区| 日韩高清在线不卡| 亚洲色欲色欲www| 精品成人一区二区三区| 色婷婷综合久久久| 国产一区二区三区在线观看免费视频| 亚洲蜜臀av乱码久久精品蜜桃| 日韩欧美精品在线视频| 91久久免费观看| 成人午夜视频网站| 美女网站色91| 一区二区三区av电影| 欧美经典一区二区三区| 日韩一卡二卡三卡四卡|