nand flash oob64 算法实例代码

这篇具有很好参考价值的文章主要介绍了nand flash oob64 算法实例代码。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

// SPDX-License-Identifier: GPL-2.0+
/*
 * Copyright 2000-2009
 * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
 */

#include <common.h>
#include <command.h>
#include <version.h>
#include <linux/compiler.h>
#ifdef CONFIG_SYS_COREBOOT
#include <asm/arch/sysinfo.h>
#endif

const char __weak version_string[] = U_BOOT_VERSION_STRING;


#define BCH6_PAGE_SIZE     512
#define BCH6_OOB_SIZE      6
#define BCH6_ECC_SIZE      10
#define BCH6_UNIT_SIZE     (BCH6_PAGE_SIZE+BCH6_OOB_SIZE+BCH6_ECC_SIZE)

#define TenBit_Mask 0x3ff

static const unsigned char gen_poly_6b[79]  = {1,0,1,1,1,1,1,0,1,0,0,0,1,1,0,1,1,0,0,1,1,1,0,1,0,0,1,1,1,0,1,1,0,0,0,0,1,1,1,1,0,0,1,0,0,1,1,1,0,0,0,0,1,1,0,0,1,0,0,1,0,0,1,1,0,0,1,1,1,1,0,0,1,1,1,1,1,1,1};
static unsigned char R_6b[78]  = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};


static inline unsigned char ToBit(unsigned short value, int bth)
{
    value = (value >> bth) & 0x1;
    return (unsigned char)value;
}


static void bch6_encode_ecc_byte(unsigned char input)
{
    unsigned char R7_6b[78], R6_6b[78], R5_6b[78], R4_6b[78], R3_6b[78], R2_6b[78], R1_6b[78], R0_6b[78];
    int i,j;

    for (i=0;i<78;i++)
    {
        if (i == 0)
            R7_6b[0] = 0x0 ^ (gen_poly_6b[0] & (ToBit(input, 7) ^ R_6b[77]));
        else
            R7_6b[i] = R_6b[i-1] ^ (gen_poly_6b[i] & (ToBit(input, 7) ^ R_6b[77]));
    }

    for (i=0;i<78;i++)
    {
        if (i == 0)
            R6_6b[0] = 0x0 ^ (gen_poly_6b[0] & (ToBit(input, 6) ^ R7_6b[77]));
        else
            R6_6b[i] = R7_6b[i-1] ^ (gen_poly_6b[i] & (ToBit(input, 6) ^ R7_6b[77]));
    }

    for (i=0;i<78;i++)
    {
        if (i == 0)
            R5_6b[0] = 0x0 ^ (gen_poly_6b[0] & (ToBit(input, 5) ^ R6_6b[77]));
        else
            R5_6b[i] = R6_6b[i-1] ^ (gen_poly_6b[i] & (ToBit(input, 5) ^ R6_6b[77]));
    }

    for (i=0;i<78;i++)
    {
        if (i == 0)
            R4_6b[0] = 0x0 ^ (gen_poly_6b[0] & (ToBit(input, 4) ^ R5_6b[77]));
        else
            R4_6b[i] = R5_6b[i-1] ^ (gen_poly_6b[i] & (ToBit(input, 4) ^ R5_6b[77]));
    }

    for (i=0;i<78;i++)
    {
        if (i == 0)
            R3_6b[0] = 0x0 ^ (gen_poly_6b[0] & (ToBit(input, 3) ^ R4_6b[77]));
        else
            R3_6b[i] = R4_6b[i-1] ^ (gen_poly_6b[i] & (ToBit(input, 3) ^ R4_6b[77]));
    }

    for (i=0;i<78;i++)
    {
        if (i == 0)
            R2_6b[0] = 0x0 ^ (gen_poly_6b[0] & (ToBit(input, 2) ^ R3_6b[77]));
        else
            R2_6b[i] = R3_6b[i-1] ^ (gen_poly_6b[i] & (ToBit(input, 2) ^ R3_6b[77]));
    }

    for (i=0;i<78;i++)
    {
        if (i == 0)
            R1_6b[0] = 0x0 ^ (gen_poly_6b[0] & (ToBit(input, 1) ^ R2_6b[77]));
        else
            R1_6b[i] = R2_6b[i-1] ^ (gen_poly_6b[i] & (ToBit(input, 1) ^ R2_6b[77]));
    }

    for (i=0;i<78;i++)
    {
        if (i == 0)
            R0_6b[0] = 0x0 ^ (gen_poly_6b[0] & (ToBit(input, 0) ^ R1_6b[77]));
        else
            R0_6b[i] = R1_6b[i-1] ^ (gen_poly_6b[i] & (ToBit(input, 0) ^ R1_6b[77]));
    }

    //dumpR();
    unsigned short synd[6] = {0x0, 0x0, 0x0, 0x0, 0x0, 0x0}; //memset(synd, 0, sizeof(synd));

    for (i=0;i<6;i++)
        for (j=12;j>=0;j--)
            synd[i] |= (R0_6b[j+(i*13)] << j);

    for (i=0;i<6;i++)
        for (j=0;j<13;j++)
            R_6b[(i*13+j)] = ToBit(synd[i], j);

    //dumpSynd();
}

void bch6_ecc_512B_encode(unsigned char *ecc,  // ecc: output 10 bytes of ECC code
    const unsigned char *input_buf,     // input_buf: the 512 bytes input data (BCH6_PAGE_SIZE bytes)
    const unsigned char *oob){          // oob: 6 bytes out-of-band for input (BCH6_OOB_SIZE bytes)

    // no need to init: synd, R7_6b[78], R6_6b[78], R5_6b[78], R4_6b[78], R3_6b[78], R2_6b[78], R1_6b[78], R0_6b[78];
    // should be init here: R_6b, ecc[10]
    //unsigned char ecc[10] = {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,};
    
    //bzero(R_6b, sizeof(R_6b));
    //bzero(ecc, BCH6_ECC_SIZE);

    memset( R_6b, 0x00, sizeof(R_6b) );
    memset( ecc,  0x00, BCH6_ECC_SIZE );

    
    int i,j;
    for ( i=0; i< BCH6_PAGE_SIZE; i++)
        bch6_encode_ecc_byte(input_buf[i]);
        
    for ( i=0; i< BCH6_OOB_SIZE; i++)
        bch6_encode_ecc_byte(oob[i]);

    for (i=0;i<9;i++)
        for (j=7;j>=0;j--)
            ecc[i] |= (R_6b[j+((8-i)*8+6)] << j);

    for (j=5;j>=0;j--)
        ecc[9] |= (R_6b[j] << (j+2));
    
    #if 1
    printf("ecc0=%x, ecc1=%x, ecc2=%x, ecc3=%x, ecc4=%x, ecc5=%x, ecc6=%x, ecc7=%x, ecc8=%x, ecc9=%x\n",
        ecc[0], ecc[1], ecc[2], ecc[3], ecc[4], ecc[5], ecc[6], ecc[7], ecc[8], ecc[9]);
    #endif
}


#define BCH_SECTS_PER_2K_PAGE (4)
#define BCH_SECTS_PER_4K_PAGE (8)
#define BCH_TAG_SIZE          (6)


/* 未命名9 (2023/7/25 16:36:48)
   起始位置(h): 00000000, 结束位置(h): 000007FF, 长度(h): 00000800 */

unsigned char rawData[2124] = {
    0x27, 0x05, 0x19, 0x56, 0x92, 0x03, 0x34, 0x84, 0x64, 0xBE, 0x4B, 0x71,
    0x00, 0x03, 0x16, 0x43, 0x83, 0xC0, 0x00, 0x00, 0x83, 0xC0, 0x00, 0x00,
    0xA1, 0xCA, 0x24, 0x46, 0x11, 0x05, 0x05, 0x03, 0x00, 0x00, 0x00, 0x00,
    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
    0x00, 0x00, 0x00, 0x00, 0x5D, 0x00, 0x00, 0x80, 0x00, 0x79, 0xA9, 0x08,
    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, 0x2F, 0x00, 0xEC, 0xD1,
    0x71, 0x3C, 0x7A, 0xB6, 0x63, 0x39, 0xB6, 0x01, 0x16, 0x1B, 0xC4, 0xA8,
    0x5E, 0x29, 0xAB, 0xD2, 0xD1, 0x46, 0x10, 0x28, 0x7D, 0x02, 0xA9, 0x17,
    0x3B, 0x84, 0xD5, 0x23, 0x59, 0x8A, 0xB4, 0x68, 0xAE, 0x3B, 0x84, 0x84,
    0x3E, 0x8E, 0x16, 0x02, 0x63, 0x2B, 0x90, 0x10, 0x11, 0x3C, 0x94, 0x9A,
    0x19, 0x10, 0x96, 0x09, 0x2B, 0x1C, 0x23, 0xBB, 0x5C, 0x07, 0x1B, 0x84,
    0xED, 0x0F, 0x0F, 0x88, 0x6B, 0xA8, 0x82, 0x10, 0x59, 0x38, 0x2A, 0xA2,
    0xA7, 0x49, 0x5E, 0xB4, 0x2A, 0x19, 0xD9, 0x5E, 0x58, 0x7D, 0x2B, 0x67,
    0x1C, 0x67, 0xC6, 0x6D, 0x8E, 0x87, 0xB2, 0x9E, 0x27, 0x2D, 0x27, 0x68,
    0x09, 0x2C, 0x4F, 0xA1, 0x9A, 0x23, 0x21, 0x34, 0x23, 0x72, 0xAF, 0x46,
    0x15, 0xB3, 0x2C, 0xD9, 0x76, 0x2A, 0x39, 0x8F, 0xE6, 0x95, 0xBF, 0xEF,
    0xC2, 0xDA, 0x26, 0x88, 0xB1, 0x3B, 0x0D, 0xD5, 0x23, 0x6E, 0xD0, 0xD7,
    0x59, 0x3F, 0xDD, 0x4B, 0x20, 0x2E, 0x8E, 0x9C, 0x8B, 0x72, 0x47, 0x1B,
    0xF1, 0x72, 0x86, 0x9A, 0xC4, 0x29, 0x78, 0xF3, 0xAD, 0x78, 0xFA, 0x53,
    0x14, 0xE4, 0xA6, 0xA1, 0xC1, 0x91, 0x17, 0x09, 0x09, 0x0A, 0x88, 0x63,
    0x8B, 0x3A, 0x2B, 0x3F, 0x34, 0x5E, 0x4D, 0x36, 0x23, 0x8D, 0xCB, 0x3C,
    0x51, 0xC8, 0xD5, 0x5B, 0x4C, 0x37, 0x71, 0x49, 0xAC, 0xBD, 0xAC, 0xE9,
    0x48, 0xB1, 0xED, 0x81, 0xBF, 0x9A, 0xA5, 0x02, 0xA0, 0xCF, 0xEE, 0x5B,
    0x69, 0x07, 0x7B, 0xF5, 0x2F, 0x53, 0xCB, 0x6E, 0xDC, 0xA4, 0x70, 0x44,
    0xB5, 0x51, 0x55, 0x90, 0x44, 0xFF, 0xFC, 0x33, 0xCB, 0x46, 0xF4, 0x1A,
    0x32, 0xEF, 0xE8, 0x8F, 0xEA, 0x6F, 0x4F, 0xC2, 0xF3, 0xF0, 0x7B, 0x02,
    0xC0, 0x64, 0x7E, 0x4D, 0xF5, 0xAD, 0xF1, 0xC1, 0xCF, 0x24, 0xBA, 0xE2,
    0xE1, 0x0B, 0xBA, 0xD0, 0x5B, 0xBD, 0x62, 0x04, 0xD6, 0xE0, 0x8D, 0x64,
    0x84, 0x0F, 0x8F, 0xF2, 0x33, 0x6D, 0x72, 0x6E, 0x17, 0xEE, 0x9D, 0x92,
    0x72, 0xF3, 0x35, 0x54, 0xDF, 0xC8, 0x3D, 0x1C, 0x8D, 0xDB, 0x84, 0x21,
    0xF9, 0x7B, 0x62, 0xED, 0x7D, 0x84, 0xE8, 0xAB, 0x91, 0xBC, 0x3D, 0xC9,
    0xF1, 0x6F, 0x9A, 0x01, 0x17, 0xB9, 0x97, 0x95, 0x24, 0x9E, 0x18, 0x49,
    0x15, 0x6D, 0x9C, 0x30, 0xF8, 0x04, 0xFC, 0x3B, 0xA1, 0xB0, 0x57, 0xF4,
    0xD8, 0xDD, 0x4E, 0x11, 0x6F, 0x5C, 0x98, 0x57, 0xE0, 0x5F, 0x86, 0x5D,
    0xD0, 0x91, 0x97, 0xDB, 0xCF, 0x4B, 0xF6, 0xED, 0xE8, 0x92, 0xF5, 0xB5,
    0x8E, 0x4E, 0x5E, 0x54, 0x3F, 0xD3, 0x3C, 0xBA, 0xBB, 0xBC, 0x55, 0x35,
    0xD6, 0x99, 0xA5, 0x6A, 0x81, 0xCA, 0x2D, 0x48, 0xE9, 0x95, 0x95, 0x53,
    0xAB, 0x1F, 0xE9, 0x6B, 0xAE, 0x73, 0xF1, 0xC8, 0x2D, 0x2E, 0x1D, 0x92,
    0x36, 0xB4, 0x8A, 0xB5, 0x14, 0x92, 0x8D, 0xFC, 0x20, 0xF0, 0x56, 0x7D,
    0x85, 0x55, 0xE3, 0x5C, 0x8D, 0xAA, 0x16, 0x1D, 0x5A, 0xAA, 0xB7, 0x0B,
    0x6A, 0x34, 0x29, 0x39, 0x37, 0x48, 0x3B, 0xFA, 0x75, 0x8B, 0x3C, 0xDE,
    0x07, 0x9B, 0xA6, 0xC3, 0xEE, 0xD6, 0xA1, 0xEF, 0x9B, 0x27, 0x5E, 0xAD,
    0x3F, 0xB2, 0xD5, 0x3F, 0x0C, 0x93, 0x65, 0x07, 0x6D, 0xFA, 0xD0, 0x2F,
    0x84, 0xF3, 0xBA, 0x66, 0x2A, 0xF2, 0x66, 0x22, 0x4B, 0x98, 0x63, 0x37,
    0x15, 0x64, 0xCD, 0x96, 0x72, 0xA1, 0x9E, 0xDF, 0x9A, 0xF8, 0x6F, 0x11,
    0x39, 0x87, 0x87, 0x75, 0x3D, 0xA4, 0x84, 0xFD, 0x53, 0x8C, 0x2E, 0x28,
    0xF2, 0xFE, 0xFC, 0x12, 0x7D, 0x9C, 0x71, 0x5F, 0x09, 0x74, 0xBC, 0x6B,
    0x7A, 0x01, 0xFB, 0xB3, 0x0B, 0x78, 0x35, 0x92, 0x3D, 0x3B, 0x39, 0xA3,
    0x10, 0x45, 0x6B, 0xB2, 0x2B, 0xE7, 0x4B, 0xE5, 0x5E, 0x47, 0x90, 0x94,
    0xE6, 0x53, 0x53, 0xE1, 0xEA, 0xA8, 0x16, 0x36, 0x4C, 0xE2, 0xE3, 0xB9,
    0xD1, 0x5C, 0x40, 0xFF, 0x18, 0x8B, 0x6D, 0x3D, 0xFA, 0x40, 0xA6, 0x83,
    0xB8, 0x26, 0x59, 0x0F, 0x27, 0xDB, 0x2A, 0x36, 0x9C, 0xB1, 0xCB, 0xC1,
    0x21, 0x40, 0x48, 0x4A, 0x1E, 0x26, 0xF1, 0x69, 0x2B, 0xFE, 0x0C, 0x93,
    0x8B, 0x81, 0x91, 0xAA, 0x13, 0x19, 0x91, 0x59, 0x9C, 0xD6, 0x3E, 0x71,
    0xDC, 0x2F, 0x24, 0xCC, 0xCC, 0x3D, 0x4F, 0x98, 0xFD, 0xBD, 0xC7, 0x26,
    0xFA, 0xC6, 0xBA, 0x9E, 0x9A, 0x02, 0xDC, 0xFD, 0xAB, 0xB4, 0xA1, 0xCE,
    0x88, 0x11, 0x6C, 0xB3, 0x05, 0x02, 0xB3, 0x37, 0xF8, 0x65, 0x80, 0x50,
    0x17, 0xED, 0xBB, 0x7A, 0xBA, 0x55, 0x2F, 0xA6, 0xE2, 0xBF, 0x86, 0xB0,
    0xB0, 0xDE, 0x5B, 0xBE, 0x33, 0x2A, 0x21, 0x62, 0x24, 0xD3, 0xE9, 0x2D,
    0xAE, 0x75, 0xF8, 0x9B, 0x12, 0xE4, 0x0D, 0x12, 0x21, 0x1F, 0xA6, 0xED,
    0x83, 0x4A, 0x31, 0xAB, 0x69, 0x83, 0x64, 0x0A, 0x25, 0xE0, 0x36, 0x91,
    0xCA, 0xEE, 0xF1, 0xAE, 0x2E, 0x84, 0x09, 0x66, 0xF6, 0xC0, 0x89, 0x38,
    0xF9, 0x0B, 0x9A, 0x4A, 0xA5, 0xA9, 0x88, 0x2B, 0x2E, 0x7F, 0xE9, 0x4D,
    0xDB, 0x46, 0x81, 0xFA, 0x73, 0x3E, 0x57, 0xDD, 0xA2, 0x5B, 0x4F, 0x5D,
    0xA6, 0x88, 0x4F, 0x94, 0x9D, 0x64, 0xD9, 0x8C, 0xC7, 0x60, 0x11, 0xBF,
    0xCF, 0x35, 0xC1, 0x93, 0xEA, 0x65, 0x6C, 0x2A, 0x7E, 0x97, 0x08, 0xC8,
    0xCD, 0xD6, 0x19, 0xE5, 0xA5, 0x7A, 0x99, 0xB2, 0x95, 0xB6, 0x15, 0x99,
    0x4A, 0xED, 0xF7, 0x16, 0xD8, 0x5B, 0x4E, 0x6A, 0x54, 0x38, 0x0F, 0xAE,
    0x73, 0x41, 0x33, 0x84, 0x3C, 0xFC, 0xDB, 0xAA, 0x95, 0xDD, 0x64, 0x89,
    0x50, 0xE7, 0x15, 0x1D, 0x40, 0x60, 0xD5, 0x87, 0xBA, 0x12, 0x3B, 0x46,
    0x26, 0x20, 0x02, 0x0D, 0xE1, 0x58, 0x2A, 0xD5, 0xAA, 0x9D, 0xDC, 0xB1,
    0x8F, 0x8B, 0x6C, 0xF0, 0x0E, 0x9E, 0x14, 0xA4, 0xAB, 0xF1, 0xF8, 0xDE,
    0xA0, 0x3C, 0xE6, 0x6D, 0x39, 0x38, 0x71, 0x6C, 0x5F, 0xA4, 0xB4, 0x92,
    0x96, 0xBA, 0xD1, 0x7B, 0x80, 0x21, 0x4C, 0x06, 0x92, 0xA3, 0x29, 0x25,
    0x51, 0xAA, 0xD4, 0x36, 0xF1, 0xE9, 0x5B, 0x75, 0x5E, 0xE8, 0x03, 0x2E,
    0xA6, 0xEC, 0x30, 0x41, 0xF6, 0x2A, 0xB0, 0xE6, 0x60, 0x64, 0x05, 0x06,
    0xF0, 0xAB, 0x9F, 0xCD, 0x61, 0xEB, 0x1D, 0x80, 0xD9, 0x4C, 0xAA, 0x44,
    0x47, 0x8D, 0xA4, 0x5A, 0x3D, 0xCE, 0x91, 0x04, 0xAB, 0xED, 0x8B, 0xD0,
    0x8B, 0xEF, 0x81, 0x13, 0x78, 0xE2, 0x0D, 0x55, 0xB1, 0xCE, 0xFD, 0xBB,
    0xA7, 0xDD, 0x56, 0x1D, 0x58, 0x04, 0xE1, 0x97, 0x20, 0x6B, 0xD3, 0x0C,
    0xDC, 0xAC, 0xB9, 0x52, 0xC4, 0x2C, 0x2A, 0x73, 0x45, 0x9D, 0xD3, 0xAC,
    0x3B, 0xE3, 0x51, 0xC4, 0x4C, 0x6B, 0x34, 0xB6, 0xA0, 0x21, 0x47, 0xC2,
    0xC4, 0x39, 0x17, 0x9E, 0xE9, 0xB7, 0x14, 0x50, 0xDF, 0x69, 0xF3, 0x48,
    0xF4, 0x56, 0x14, 0xFA, 0x62, 0x44, 0x13, 0x3A, 0x44, 0x0D, 0xBF, 0x04,
    0xAA, 0x86, 0x17, 0xBF, 0xFC, 0xC7, 0x60, 0x05, 0xD6, 0x90, 0x0B, 0xC3,
    0x20, 0xEF, 0xD1, 0xCE, 0x70, 0x64, 0x3E, 0xA5, 0x8B, 0x23, 0x06, 0xCB,
    0x68, 0x37, 0xCC, 0xA1, 0x91, 0x41, 0x7D, 0x69, 0x6E, 0xF9, 0xF2, 0xE2,
    0x4A, 0x96, 0xB9, 0xB9, 0x2E, 0x1F, 0xCD, 0xD7, 0x1C, 0xF8, 0x67, 0x65,
    0xF4, 0x56, 0xD2, 0x67, 0x06, 0xA7, 0x66, 0xB0, 0x62, 0xFF, 0xE4, 0xDD,
    0xDA, 0x74, 0xCF, 0xF2, 0xBE, 0xF0, 0x3C, 0xCF, 0x13, 0x0C, 0x5E, 0x52,
    0x30, 0x6B, 0xB8, 0x39, 0xB4, 0xCD, 0xFC, 0x8A, 0xE4, 0x65, 0x81, 0x3D,
    0xBB, 0x96, 0x5A, 0x0C, 0xAD, 0x53, 0x08, 0xD3, 0xEE, 0xF9, 0xDA, 0xE4,
    0x74, 0xEC, 0xFB, 0x81, 0xAF, 0x3F, 0xC0, 0xD2, 0xB2, 0x98, 0xD7, 0x45,
    0x9B, 0x08, 0x8F, 0xC4, 0xB9, 0x80, 0xE2, 0x55, 0x0A, 0xA2, 0xE5, 0xA1,
    0xD6, 0x07, 0xEA, 0xE9, 0xB6, 0xFD, 0xC2, 0x8C, 0x1A, 0x25, 0xB5, 0x21,
    0x89, 0xF9, 0x52, 0xC0, 0x9F, 0x83, 0xCE, 0x1C, 0x05, 0xA6, 0x03, 0xF2,
    0xA4, 0xAC, 0xB5, 0x2C, 0xDE, 0x2C, 0x9C, 0x61, 0xBF, 0xC0, 0xFB, 0xC6,
    0x51, 0x6C, 0x30, 0x71, 0xD7, 0x32, 0x86, 0xA4, 0x29, 0xA6, 0xE1, 0x54,
    0x45, 0xB8, 0xAC, 0xAF, 0xA4, 0x75, 0x9D, 0x80, 0x2E, 0x45, 0xD5, 0xDA,
    0x5C, 0xCF, 0xFC, 0x17, 0x08, 0x33, 0xA5, 0x2D, 0x4D, 0xF1, 0x20, 0x45,
    0x82, 0x78, 0x41, 0xD4, 0xFE, 0xAE, 0x94, 0x00, 0x32, 0x57, 0x2A, 0xBE,
    0x30, 0x50, 0x84, 0x09, 0x3C, 0x7D, 0xB9, 0xC7, 0x48, 0x20, 0xB7, 0x6B,
    0xCD, 0x17, 0xA2, 0x70, 0x3B, 0xE2, 0xCD, 0x8E, 0x81, 0x9C, 0x12, 0x4D,
    0xD6, 0x01, 0x7D, 0x58, 0xA2, 0x0E, 0x5C, 0xF8, 0x88, 0x28, 0xD3, 0xC0,
    0xEB, 0x5F, 0xBF, 0x89, 0x47, 0x24, 0x8E, 0xF3, 0xC1, 0x97, 0x56, 0x82,
    0xC1, 0x3E, 0xC8, 0x8A, 0x67, 0x4C, 0x5C, 0x6C, 0xA7, 0x2C, 0x7D, 0x95,
    0xE1, 0x45, 0x67, 0xFC, 0x04, 0x6C, 0xA1, 0xA0, 0x88, 0x8A, 0xA7, 0x9E,
    0x2E, 0x4B, 0x6F, 0x67, 0x5E, 0x46, 0xE6, 0xE7, 0x36, 0x63, 0x74, 0x07,
    0x10, 0xD2, 0xE3, 0x26, 0x13, 0x66, 0xD3, 0x91, 0xDA, 0x47, 0xD8, 0xF6,
    0xCD, 0x73, 0x21, 0x22, 0x05, 0xEF, 0x65, 0x59, 0x6B, 0x28, 0x2D, 0xD4,
    0x40, 0xE1, 0x6C, 0x17, 0x61, 0x97, 0x62, 0x11, 0x0F, 0x65, 0x40, 0x19,
    0x86, 0x39, 0xCE, 0x02, 0x77, 0x74, 0xA9, 0x9B, 0x6D, 0xE8, 0x05, 0x4E,
    0x83, 0xFE, 0x2D, 0xDB, 0xE5, 0xE0, 0xFB, 0xBD, 0x31, 0x1A, 0x78, 0xD1,
    0x8E, 0xBE, 0x33, 0x72, 0xA8, 0x1C, 0x6F, 0x03, 0x61, 0x3F, 0xB2, 0xC1,
    0x6A, 0x12, 0xF1, 0xBE, 0x75, 0x08, 0x1A, 0xC2, 0xDF, 0xE2, 0xC0, 0x37,
    0xAF, 0x71, 0xB4, 0x6C, 0x1D, 0x2F, 0xA2, 0x9C, 0xDB, 0x6F, 0x0A, 0x51,
    0xF1, 0xFB, 0x0E, 0xDD, 0x45, 0xB9, 0xC1, 0x67, 0x18, 0x13, 0x46, 0xC2,
    0x79, 0x1C, 0xFD, 0xD1, 0xE0, 0xA5, 0xA7, 0x66, 0xBB, 0x3E, 0xED, 0x7E,
    0x5E, 0x1D, 0x0D, 0x44, 0xC2, 0xBC, 0xBD, 0xC0, 0x9A, 0x03, 0x1C, 0xC7,
    0x78, 0x98, 0x68, 0xF1, 0x19, 0x8D, 0x88, 0xCA, 0x0C, 0x92, 0x59, 0x35,
    0xF5, 0xAA, 0x31, 0x9D, 0x20, 0x5E, 0xAB, 0x76, 0x32, 0x3F, 0x66, 0xF7,
    0xCA, 0x4E, 0x7C, 0x54, 0xDD, 0x4E, 0xEB, 0x97, 0xAC, 0x3B, 0x10, 0xD1,
    0x6D, 0x35, 0x28, 0x33, 0xA3, 0xBF, 0x6E, 0x67, 0x29, 0x66, 0xA0, 0x17,
    0x69, 0xE7, 0x5B, 0x84, 0x3A, 0xC7, 0x8C, 0x9F, 0xDC, 0x6B, 0x98, 0xD2,
    0x00, 0x82, 0xF2, 0xB9, 0xAD, 0xD5, 0x2D, 0xE4, 0xB7, 0x31, 0xAF, 0x14,
    0x31, 0x33, 0x96, 0x03, 0x2B, 0x00, 0xA2, 0x84, 0xD2, 0x62, 0xA8, 0xC9,
    0xA2, 0x31, 0xDE, 0x9D, 0x16, 0xCB, 0xE0, 0x79, 0xBC, 0x7B, 0x8E, 0x77,
    0xDE, 0xF8, 0x08, 0xD6, 0x1B, 0x0B, 0xC5, 0xFA, 0x87, 0xE5, 0xFE, 0x8C,
    0x2D, 0x22, 0x29, 0xFC, 0xFC, 0xDA, 0x2D, 0x5D, 0x11, 0xA9, 0xDD, 0xE1,
    0xD4, 0x11, 0x7D, 0xDA, 0xAA, 0xBB, 0x58, 0x81, 0xBD, 0x71, 0x0A, 0x31,
    0x39, 0xD2, 0x79, 0x41, 0x98, 0x27, 0x4D, 0xAC, 0xA5, 0x05, 0xF1, 0xA7,
    0x77, 0xCB, 0x14, 0x1B, 0x68, 0x04, 0x19, 0x69, 0xAC, 0x4A, 0x3F, 0x4F,
    0x03, 0x48, 0x99, 0xD4, 0x97, 0xE1, 0x3B, 0xB4, 0xFE, 0xA9, 0xF9, 0xC4,
    0x2A, 0x8F, 0x21, 0xEB, 0x10, 0x96, 0xBB, 0x55, 0x9F, 0xA9, 0x60, 0x2D,
    0xF2, 0xE7, 0x56, 0x87, 0x9B, 0xB2, 0x77, 0xDB, 0x53, 0x8E, 0x9F, 0xD7,
    0xF1, 0x6F, 0xAC, 0x15, 0x9B, 0xB0, 0x09, 0xB1, 0x91, 0x78, 0x1A, 0x00,
    0x87, 0x6A, 0x09, 0xED, 0x8A, 0xD2, 0xFF, 0x19, 0x5E, 0xF5, 0xB0, 0x3D,
    0x60, 0x7E, 0xFB, 0xEF, 0xEB, 0x24, 0x17, 0x73, 0x02, 0xF3, 0x3F, 0x27,
    0xED, 0x33, 0x94, 0x83, 0x81, 0xAE, 0x1A, 0x1A, 0xCE, 0x3C, 0xCD, 0xC7,
    0x02, 0x66, 0xF5, 0xA7, 0x76, 0xFB, 0xAC, 0x95, 0x1C, 0xE9, 0xA0, 0xE8,
    0x25, 0x22, 0x6E, 0x66, 0x1F, 0x24, 0xEA, 0x7B, 0x2D, 0x47, 0x76, 0x46,
    0x2D, 0x62, 0xEF, 0x59, 0x8E, 0x23, 0xC1, 0x46, 0xAB, 0xAE, 0x3A, 0x0D,
    0x81, 0x47, 0x00, 0xED, 0xFA, 0x9B, 0x03, 0xBF, 0x53, 0x48, 0xE0, 0x8E,
    0xF8, 0xB0, 0xD5, 0x93, 0x59, 0xE1, 0xAD, 0xBC, 0xDD, 0x5B, 0x23, 0x9F,
    0x83, 0x19, 0x01, 0xCB, 0x06, 0x72, 0xDD, 0xEA, 0x5D, 0xAE, 0x7A, 0x0E,
    0xDA, 0x1D, 0xC7, 0x88, 0x06, 0x75, 0x84, 0xC3, 0x17, 0x54, 0x8C, 0x7D,
    0x74, 0x74, 0x8F, 0xE8, 0x06, 0x2E, 0x07, 0x49, 0xAE, 0xFB, 0x02, 0x6E,
    0x0D, 0xD0, 0xA1, 0xFC, 0xAA, 0x62, 0xA4, 0xCE, 0x2C, 0xCC, 0x25, 0x4A,
    0x9C, 0x63, 0x98, 0xAC, 0xD8, 0xDF, 0x8B, 0x21, 0x23, 0xB3, 0xC0, 0xC2,
    0xC7, 0x92, 0x78, 0x1C, 0x81, 0x35, 0x61, 0xA5, 0xD8, 0x15, 0xD0, 0x7C,
    0x8F, 0x31, 0x7E, 0x3B, 0x16, 0x18, 0x43, 0x24, 0xAC, 0xF0, 0x45, 0x02,
    0xB5, 0x97, 0x7B, 0x1C, 0x74, 0xF6, 0xCD, 0xAF, 0xBF, 0xD2, 0x2C, 0x69,
    0xCD, 0xB6, 0x40, 0x84, 0x37, 0x80, 0xC7, 0xAD, 0x39, 0xCC, 0x66, 0xC8,
    0x70, 0x93, 0xB3, 0xCC, 0x51, 0x3C, 0xE5, 0x20, 0xD7, 0x47, 0xF5, 0x2D,
    0xB4, 0xB9, 0x23, 0x2D, 0x09, 0xFE, 0x4E, 0x08, 0x60, 0x15, 0xF6, 0xDB,
    0xE4, 0x63, 0x45, 0x19, 0x1F, 0xE7, 0x07, 0x9F, 0x49, 0x1E, 0xE8, 0xAC,
    0x4D, 0x53, 0xCD, 0xDC, 0xC7, 0xEA, 0x2B, 0x94, 0x6F, 0x7F, 0x13, 0x76,
    0x9F, 0x96, 0xDB, 0xD0, 0x23, 0x80, 0x1F, 0x32, 0x7F, 0xEF, 0x8B, 0xD5,
    0x7E, 0x68, 0x1C, 0xDF, 0x43, 0xA4, 0x85, 0x2A, 0xFF, 0x78, 0xAF, 0x93,
    0x76, 0x17, 0x35, 0xF1, 0x54, 0x81, 0x40, 0xEC, 0x8A, 0xCC, 0x6F, 0x0F,
    0x9F, 0x61, 0xE7, 0x66, 0xE3, 0x4A, 0xBD, 0xB0, 0xEF, 0x8E, 0x4A, 0x08,
    0x27, 0x54, 0xE6, 0x7A, 0x2C, 0x2D, 0xCA, 0x82, 0xAD, 0x36, 0x96, 0x21,
    0x5D, 0x93, 0x0C, 0xA4, 0x2E, 0xB6, 0x62, 0x25, 0xF3, 0x7E, 0xEE, 0x71,
    0xB4, 0x86, 0xF1, 0xB6, 0x7B, 0xDD, 0xAD, 0x55, 0x55, 0xA7, 0xB1, 0x6D,
    0xE9, 0xA6, 0xAB, 0xA7, 0x2D, 0x70, 0x0D, 0xFD, 0x38, 0x97, 0x1F, 0x6D,
    0x18, 0xB4, 0x3B, 0x2F, 0xB1, 0x2D, 0x5B, 0xC0, 0x8E, 0x5D, 0xB5, 0x82,
    0x67, 0x03, 0xAA, 0x8E, 0x19, 0x0A, 0x8D, 0x58, 0x8C, 0x16, 0xA9, 0xD8,
    0x14, 0xFF, 0xD8, 0x27, 0x70, 0x01, 0x4B, 0x10, 0x29, 0x19, 0x68, 0xE9,
    0x64, 0x5E, 0xA9, 0x42, 0xBD, 0x5A, 0xCB, 0x9B, 0xBC, 0x52, 0x3B, 0x93,
    0x01, 0x48, 0x19, 0x30, 0xFC, 0x29, 0x0A, 0x35
};

void plr_ecc_encode_bch(u32_t ecc_ability, void *dma_addr, void *p_eccbuf)
{
    u32_t encode_addr = (u32_t)dma_addr;
    u32_t page_size = BCH_SECTOR_SIZE*BCH_SECTS_PER_2K_PAGE;
    u8_t *tag_addr = (u8_t *)(encode_addr + page_size);
    u8_t *syn_addr = (u8_t *)(tag_addr + BCH_TAG_SIZE*BCH_SECTS_PER_2K_PAGE);

    u32_t syn_size;
    if(12 == ecc_ability) syn_size = BCH12_SYNDROME_SIZE;
    else syn_size = BCH6_SYNDROME_SIZE;

   // dcache_wr_inv((u32_t)dma_addr, (u32_t)(dma_addr+page_size));
  
    u32_t j;
    for(j=0 ; j<BCH_SECTS_PER_2K_PAGE ; j++, encode_addr+=BCH_SECTOR_SIZE, tag_addr+=BCH_TAG_SIZE, syn_addr+=syn_size){
        bch6_ecc_512B_encode((unsigned char *)(syn_addr), (unsigned char *)encode_addr, (unsigned char *)tag_addr);
        //dcache_wr_inv((u32_t)tag_addr, (u32_t)(tag_addr+BCH_TAG_SIZE));
        //dcache_wr_inv((u32_t)syn_addr, (u32_t)(syn_addr+syn_size));
    }
}


#if !defined(__LUNA_KERNEL__)
void init_ecc_sw_patch(void)
{
   // plr_spi_nand_flash_info._ecc_encode = &plr_ecc_encode_bch;
}
//REG_INIT_FUNC(init_ecc_sw_patch, 5);
#endif

unsigned char p_eccbuf[64] = {0xff};

    
    

/* 未命名11 (2023/7/25 17:30:44)
   起始位置(h): 00000000, 结束位置(h): 0000003F, 长度(h): 00000040 */

unsigned char rawData_oob[64] = {
    0xFF, 0xFF, 0xFF, 0xFF, 0x35, 0x32, 0x31, 0x30, 0x00, 0x01, 0x00, 0x00,
    0xFF, 0xFF, 0xFF, 0xFF, 0x00, 0x00, 0x00, 0x63, 0x00, 0x00, 0x00, 0x02,
    0xD0, 0xA2, 0x92, 0xD8, 0x80, 0xFE, 0x30, 0xB5, 0x8C, 0x64, 0xE5, 0x47,
    0x50, 0xFB, 0x30, 0x19, 0x86, 0x8B, 0x28, 0x4C, 0xEC, 0x82, 0x30, 0x8A,
    0x25, 0x23, 0x2A, 0xD2, 0xF0, 0xFC, 0x06, 0x13, 0x32, 0xD4, 0x61, 0x30,
    0x27, 0x69, 0x01, 0x40
};

extern int macdbg_dmphex(const char* buff, int len);


unsigned char ecc_out[64];


void test_fuck( void )     
{
    macdbg_dmphex( (const char *)ecc_out, sizeof(ecc_out) ); 
    bch6_ecc_512B_encode(ecc_out, rawData, rawData_oob  );
    macdbg_dmphex( (const char *)ecc_out, sizeof(ecc_out) ); 
}


static int do_version(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
    char buf[DISPLAY_OPTIONS_BANNER_LENGTH];

    printf(display_options_get_banner(false, buf, sizeof(buf)));


    printf("do_version = %p\n", do_version);

    macdbg_dmphex( (const char *)rawData, sizeof(rawData) ); 

    memcpy( &rawData[2048], rawData_oob, 24);
    plr_ecc_encode_bch(6, rawData, NULL);

    macdbg_dmphex( (const char *)rawData, sizeof(rawData) ); 
    
    //test_fuck();

    
#ifdef CC_VERSION_STRING
    puts(CC_VERSION_STRING "\n");
#endif
#ifdef LD_VERSION_STRING
    puts(LD_VERSION_STRING "\n");
#endif
#ifdef CONFIG_SYS_COREBOOT
    printf("coreboot-%s (%s)\n", lib_sysinfo.version, lib_sysinfo.build);
#endif
    return 0;
}

U_BOOT_CMD(
    version,    1,        1,    do_version,
    "print monitor, compiler and linker version",
    ""
);
 文章来源地址https://www.toymoban.com/news/detail-603929.html

到了这里,关于nand flash oob64 算法实例代码的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • [NAND Flash 6.3] NAND FLASH基本编程(写)操作及原理_NAND FLASH Program Operation 源码实现

    依公知及经验整理,原创保护,禁止转载。 专栏 《深入理解NAND Flash》 返回总目录 全文 3244 字 ​ 前言 使用的 NAND FLASH 的硬件原理图,面对这些引脚,很难明白他们是什么含义,下面先来个热身: 问1. 原理图上 NAND FLASH 只有数据线,怎么传输地址? 答1. 在 DATA0~DATA7 上既传

    2024年01月19日
    浏览(33)
  • [NAND Flash 3.2] 3D NAND 工艺与发展前沿

    依公知及经验整理,原创保护,禁止转载。 专栏 《深入理解NAND Flash》 全文 6200 字,​ 2023.12.12 更新 3D NAND, 也叫做 Sumsung V-NAND, 是一种高密度闪存。 以前,把NAND闪存颗粒,直接平铺在SSD固态硬盘电路板上,叫2D技术。后来,厂家为节约成本,节省空间,像建高楼一样,一层

    2024年02月04日
    浏览(33)
  • Nor Flash和Nand Flash的区别——笔记

    NorFlash: 串行存储器、读取速度比较快(比NandFlash快),适合用于存储程序代码和执行代码,但NorFlash写入速度比较慢、容量比较小。 数据线和地址线是分开的。 NandFlash: 并行存储器、写入速度比较快(比NorFlash快)、容量比较大,适合用于存储大量数据。但NandFlash读取速度

    2024年02月08日
    浏览(31)
  • [NAND Flash 6.6] NAND FLASH Multi Plane Program(写)操作_multi plane 为何能提高闪存速度

    依公知及经验整理,原创保护,禁止转载。 专栏 《深入理解NAND Flash》 返回总目录 Multi Plane 简介 Multi Plane Program 时序图 Multi Plane 提速机理 Multi Plane Program 状态检查 前言 上一篇我们介绍了 NAND FLASH 基本编程(写)操作及原理_ NAND FLASH Program Operation 源码实现。这只是一次对单

    2024年02月01日
    浏览(45)
  • stm32读写nand flash

    目前我在使用stm32f407ZGT6来读写三星的nand flash【K9F1G08U0E】。 板子我是在这里买的 【STM32F407ZGT6最小系统板/核心板/转接板/开发板/加128M FLASH】 他上面可以选装一个K9F1G08U0E。 针对这个nand flash,可以选择采用stm32的FSMC来进行读写。 stm32的程序我是stm32cubeide来编写的,感觉挺方便

    2024年02月11日
    浏览(39)
  • [深入理解NAND Flash (失效篇) ] NAND VT Distribution 和失效模式

    传送门    总目录 主页 : 元存储的博客_CSDN博客 本文依据公开知识及个人经验整理而成,如有错误请留言。 文章为个人辛苦整理,付费内容,禁止私自转载。 全文 2800 字, 内容摘要: 1 从NMOS Vt到FGNMOS Vt 2 Vt Distribution 3 Vt Distribution 恶化之源     3.1 P/E cycle increase     3.2

    2024年02月14日
    浏览(39)
  • [深入理解NAND Flash (指令篇) ] NAND FLASH Multi Plane Program(写)操作_multi plane 为何能提高闪存速度

    传送门    总目录 主页 : 元存储的博客_CSDN博客 依公开知识及经验整理,如有误请留言。 个人辛苦整理,付费内容,禁止转载。 内容摘要 前言 Multi Plane 简介 Multi Plane Program 时序图 Multi Plane 提速机理 Multi Plane Program 状态检查 前言 上一篇我们介绍了 [深入理解SSD系列 闪存实

    2024年02月13日
    浏览(41)
  • [深入理解NAND Flash (架构篇) ] 3D(三维)NAND图文详解_2D NAND 和 3D NAND 横向对比_VNAND 技术详解

      传送门   总目录  所在专栏   《深入理解SSD》 个人辛苦整理,付费内容,禁止转载。 内容摘要 前言 2.1.4.1. 何为 3D NAND? 2.1.4.2. 3D NAND 技术 2.1.4.

    2024年02月14日
    浏览(37)
  • RT thread 之 Nand flash 读写过程分析

    NAND Flash 是一种常见的闪存存储器类型,广泛应用于各种电子设备中,如手机、平板电脑、嵌入式系统等。它是一种非易失性存储器,可以持久地保存数据即使在断电情况下。 NAND Flash 与传统的 NOR Flash 相比具有较高的存储密度和较低的成本,但其随机访问速度较慢。它使用了

    2024年02月15日
    浏览(32)
  • 【FLASH存储器系列四】NAND和NOR两种Flash的本质区别是什么?

    👉个人主页: highman110 👉作者简介:一名硬件工程师,持续学习,不断记录,保持思考,输出干货内容 目录 1 Nand 和Nor的区别 2 从存储原理上分析这些区别的原因         1、为什么nor flash的读取速度比nand flash要稍快?         2、为什么nand flash的容量比nor flash更大?

    2024年02月20日
    浏览(43)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包