提交 e8190760 编写于 作者: G goprife@gmail.com

fix bugs in bsp/simulator/nanddrv_file.c; support NFTL and uffs!; format coding style with astyle

git-svn-id: https://rt-thread.googlecode.com/svn/trunk@2573 bbd45198-f89e-11dd-88c7-29a3b14d5316
上级 6e6d5c5b
...@@ -6,6 +6,7 @@ ...@@ -6,6 +6,7 @@
#define NAND_SIM "nand.bin" #define NAND_SIM "nand.bin"
#if 1 #if 1
#define OOB_SIZE 64 #define OOB_SIZE 64
#define PAGE_DATA_SIZE 2048
#define PAGE_SIZE (2048 + 64) #define PAGE_SIZE (2048 + 64)
#define PAGE_PER_BLOCK 64 #define PAGE_PER_BLOCK 64
#define BLOCK_SIZE (PAGE_SIZE * PAGE_PER_BLOCK) #define BLOCK_SIZE (PAGE_SIZE * PAGE_PER_BLOCK)
...@@ -19,6 +20,8 @@ ...@@ -19,6 +20,8 @@
#define BLOCK_NUM 512 #define BLOCK_NUM 512
#endif #endif
#define ECC_SIZE ((PAGE_DATA_SIZE) * 3 / 256)
static unsigned char block_data[BLOCK_SIZE]; static unsigned char block_data[BLOCK_SIZE];
static struct rt_mtd_nand_device _nanddrv_file_device; static struct rt_mtd_nand_device _nanddrv_file_device;
static FILE *file = NULL; static FILE *file = NULL;
...@@ -189,8 +192,8 @@ static rt_err_t nanddrv_file_read_page(struct rt_mtd_nand_device *device, ...@@ -189,8 +192,8 @@ static rt_err_t nanddrv_file_read_page(struct rt_mtd_nand_device *device,
rt_uint8_t *spare, rt_uint32_t spare_len) rt_uint8_t *spare, rt_uint32_t spare_len)
{ {
rt_uint32_t offset; rt_uint32_t offset;
rt_uint8_t oob_buffer[OOB_SIZE]; rt_uint8_t oob_ecc [ECC_SIZE];
rt_uint8_t oob_ecc [OOB_SIZE]; rt_uint8_t ecc [ECC_SIZE];
page = page + device->block_start * device->pages_per_block; page = page + device->block_start * device->pages_per_block;
...@@ -201,25 +204,27 @@ static rt_err_t nanddrv_file_read_page(struct rt_mtd_nand_device *device, ...@@ -201,25 +204,27 @@ static rt_err_t nanddrv_file_read_page(struct rt_mtd_nand_device *device,
/* write page */ /* write page */
offset = page * PAGE_SIZE; offset = page * PAGE_SIZE;
if (data != NULL) if (data != NULL && data_len != 0)
{ {
fseek(file, offset, SEEK_SET); fseek(file, offset, SEEK_SET);
fread(data, data_len, 1, file); fread(data, data_len, 1, file);
} if (data_len == PAGE_DATA_SIZE)
{
/* read ecc size */
fread(oob_ecc, ECC_SIZE, 1, file);
offset = page * PAGE_SIZE + (PAGE_SIZE - OOB_SIZE); /* verify ECC */
fseek(file, offset, SEEK_SET); ecc_hamming_compute256x(data, PAGE_DATA_SIZE, &ecc[0]);
fread(oob_buffer, OOB_SIZE, 1, file); if (memcmp(&oob_ecc[0], &ecc[0], ECC_SIZE) != 0)
if (spare != NULL) return -RT_MTD_EECC;
{ }
memcpy(spare, oob_buffer, spare_len);
} }
/* verify ECC */ if (spare != NULL && spare_len)
if (data != RT_NULL)
{ {
ecc_hamming_compute256x(data, PAGE_SIZE - OOB_SIZE, &oob_ecc[0]); offset = page * PAGE_SIZE + PAGE_DATA_SIZE;
if (memcmp(&oob_ecc[0], &oob_buffer[0], OOB_SIZE - device->oob_free) != 0) return -RT_MTD_EECC; fseek(file, offset, SEEK_SET);
fread(spare, spare_len, 1, file);
} }
return RT_EOK; return RT_EOK;
...@@ -231,7 +236,7 @@ static rt_err_t nanddrv_file_write_page(struct rt_mtd_nand_device *device, ...@@ -231,7 +236,7 @@ static rt_err_t nanddrv_file_write_page(struct rt_mtd_nand_device *device,
const rt_uint8_t *oob, rt_uint32_t spare_len) const rt_uint8_t *oob, rt_uint32_t spare_len)
{ {
rt_uint32_t offset; rt_uint32_t offset;
rt_uint8_t oob_buffer[OOB_SIZE]; rt_uint8_t ecc[ECC_SIZE];
page = page + device->block_start * device->pages_per_block; page = page + device->block_start * device->pages_per_block;
if (page / device->pages_per_block > device->block_end) if (page / device->pages_per_block > device->block_end)
...@@ -241,24 +246,26 @@ static rt_err_t nanddrv_file_write_page(struct rt_mtd_nand_device *device, ...@@ -241,24 +246,26 @@ static rt_err_t nanddrv_file_write_page(struct rt_mtd_nand_device *device,
/* write page */ /* write page */
offset = page * PAGE_SIZE; offset = page * PAGE_SIZE;
if (data != NULL) if (data != RT_NULL && data_len != 0)
{ {
fseek(file, offset, SEEK_SET); fseek(file, offset, SEEK_SET);
fwrite(data, PAGE_SIZE - OOB_SIZE, 1, file); fwrite(data, data_len, 1, file);
}
offset = page * PAGE_SIZE + (PAGE_SIZE - OOB_SIZE); if (data_len == PAGE_DATA_SIZE)
fseek(file, offset, SEEK_SET); {
/*write the ecc information */
ecc_hamming_compute256x(data, PAGE_DATA_SIZE, ecc);
fwrite(ecc, ECC_SIZE, 1, file);
}
}
memset(oob_buffer, 0xff, sizeof(oob_buffer)); if (oob != RT_NULL && spare_len != 0)
ecc_hamming_compute256x(data, PAGE_SIZE - OOB_SIZE, &oob_buffer[0]);
if (oob != RT_NULL)
{ {
memcpy(&oob_buffer[OOB_SIZE - device->oob_free], offset = page * PAGE_SIZE + PAGE_DATA_SIZE + ECC_SIZE;
&oob[OOB_SIZE - device->oob_free], fseek(file, offset, SEEK_SET);
device->oob_free); fwrite(&oob[ECC_SIZE], spare_len-ECC_SIZE, 1, file);
} }
fwrite(oob_buffer, OOB_SIZE, 1, file);
return RT_EOK; return RT_EOK;
} }
...@@ -266,7 +273,7 @@ static rt_err_t nanddrv_file_write_page(struct rt_mtd_nand_device *device, ...@@ -266,7 +273,7 @@ static rt_err_t nanddrv_file_write_page(struct rt_mtd_nand_device *device,
static rt_err_t nanddrv_file_move_page(struct rt_mtd_nand_device *device, rt_off_t from, rt_off_t to) static rt_err_t nanddrv_file_move_page(struct rt_mtd_nand_device *device, rt_off_t from, rt_off_t to)
{ {
rt_uint32_t offset; rt_uint32_t offset;
rt_uint8_t page_buffer[PAGE_SIZE - OOB_SIZE]; rt_uint8_t page_buffer[PAGE_DATA_SIZE];
rt_uint8_t oob_buffer[OOB_SIZE]; rt_uint8_t oob_buffer[OOB_SIZE];
from = from + device->block_start * device->pages_per_block; from = from + device->block_start * device->pages_per_block;
...@@ -315,7 +322,7 @@ static rt_err_t nanddrv_file_erase_block(struct rt_mtd_nand_device *device, rt_u ...@@ -315,7 +322,7 @@ static rt_err_t nanddrv_file_erase_block(struct rt_mtd_nand_device *device, rt_u
if (block > BLOCK_NUM) return -RT_EIO; if (block > BLOCK_NUM) return -RT_EIO;
/* add the start blocks */ /* add the start blocks */
block = block + device->block_start * device->pages_per_block; block = block + device->block_start;
fseek(file, block * BLOCK_SIZE, SEEK_SET); fseek(file, block * BLOCK_SIZE, SEEK_SET);
fwrite(block_data, sizeof(block_data), 1, file); fwrite(block_data, sizeof(block_data), 1, file);
...@@ -323,11 +330,6 @@ static rt_err_t nanddrv_file_erase_block(struct rt_mtd_nand_device *device, rt_u ...@@ -323,11 +330,6 @@ static rt_err_t nanddrv_file_erase_block(struct rt_mtd_nand_device *device, rt_u
return RT_EOK; return RT_EOK;
} }
static rt_err_t nanddrv_file_no_op(struct rt_mtd_nand_device *device, rt_uint32_t block)
{
return RT_EOK;
}
const static struct rt_mtd_nand_driver_ops _ops = const static struct rt_mtd_nand_driver_ops _ops =
{ {
nanddrv_file_read_id, nanddrv_file_read_id,
...@@ -335,8 +337,8 @@ const static struct rt_mtd_nand_driver_ops _ops = ...@@ -335,8 +337,8 @@ const static struct rt_mtd_nand_driver_ops _ops =
nanddrv_file_write_page, nanddrv_file_write_page,
nanddrv_file_move_page, nanddrv_file_move_page,
nanddrv_file_erase_block, nanddrv_file_erase_block,
nanddrv_file_no_op, /* check block */ RT_NULL,
nanddrv_file_no_op /* mark bad block */ RT_NULL,
}; };
void nand_eraseall(void); void nand_eraseall(void);
...@@ -368,11 +370,11 @@ void rt_hw_mtd_nand_init(void) ...@@ -368,11 +370,11 @@ void rt_hw_mtd_nand_init(void)
} }
fseek(file, 0, SEEK_SET); fseek(file, 0, SEEK_SET);
ecc_size = (PAGE_SIZE - OOB_SIZE) * 3 / 256; ecc_size = (PAGE_DATA_SIZE) * 3 / 256;
_nanddrv_file_device.plane_num = 2; _nanddrv_file_device.plane_num = 2;
_nanddrv_file_device.oob_size = OOB_SIZE; _nanddrv_file_device.oob_size = OOB_SIZE;
_nanddrv_file_device.oob_free = OOB_SIZE - ecc_size; _nanddrv_file_device.oob_free = OOB_SIZE - ecc_size;
_nanddrv_file_device.page_size = PAGE_SIZE - OOB_SIZE; _nanddrv_file_device.page_size = PAGE_DATA_SIZE;
_nanddrv_file_device.pages_per_block = PAGE_PER_BLOCK; _nanddrv_file_device.pages_per_block = PAGE_PER_BLOCK;
_nanddrv_file_device.block_start = 0; _nanddrv_file_device.block_start = 0;
_nanddrv_file_device.block_end = BLOCK_NUM / 2; _nanddrv_file_device.block_end = BLOCK_NUM / 2;
...@@ -394,12 +396,4 @@ void nand_eraseall() ...@@ -394,12 +396,4 @@ void nand_eraseall()
} }
FINSH_FUNCTION_EXPORT(nand_eraseall, erase all of block in the nand flash); FINSH_FUNCTION_EXPORT(nand_eraseall, erase all of block in the nand flash);
#if 0
void nand_log(int level)
{
nftl_set_trace_level(level);
}
FINSH_FUNCTION_EXPORT(nand_log, set NFTL trace level);
#endif
#endif //RT_USING_FINSH #endif //RT_USING_FINSH
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册