mirror of
https://github.com/Fishwaldo/u-boot.git
synced 2025-03-21 14:41:31 +00:00
common: env_nand: use get_nand_dev_by_index()
As part of preparation for nand DM conversion the new API has been introduced to remove direct access to nand_info array. So, use it here instead of accessing to nand_info array directly. Signed-off-by: Grygorii Strashko <grygorii.strashko@ti.com>
This commit is contained in:
parent
ad92dff28c
commit
a94a261939
1 changed files with 21 additions and 12 deletions
|
@ -130,17 +130,22 @@ static int writeenv(size_t offset, u_char *buf)
|
||||||
size_t end = offset + CONFIG_ENV_RANGE;
|
size_t end = offset + CONFIG_ENV_RANGE;
|
||||||
size_t amount_saved = 0;
|
size_t amount_saved = 0;
|
||||||
size_t blocksize, len;
|
size_t blocksize, len;
|
||||||
|
struct mtd_info *mtd;
|
||||||
u_char *char_ptr;
|
u_char *char_ptr;
|
||||||
|
|
||||||
blocksize = nand_info[0]->erasesize;
|
mtd = get_nand_dev_by_index(0);
|
||||||
|
if (!mtd)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
blocksize = mtd->erasesize;
|
||||||
len = min(blocksize, (size_t)CONFIG_ENV_SIZE);
|
len = min(blocksize, (size_t)CONFIG_ENV_SIZE);
|
||||||
|
|
||||||
while (amount_saved < CONFIG_ENV_SIZE && offset < end) {
|
while (amount_saved < CONFIG_ENV_SIZE && offset < end) {
|
||||||
if (nand_block_isbad(nand_info[0], offset)) {
|
if (nand_block_isbad(mtd, offset)) {
|
||||||
offset += blocksize;
|
offset += blocksize;
|
||||||
} else {
|
} else {
|
||||||
char_ptr = &buf[amount_saved];
|
char_ptr = &buf[amount_saved];
|
||||||
if (nand_write(nand_info[0], offset, &len, char_ptr))
|
if (nand_write(mtd, offset, &len, char_ptr))
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
offset += blocksize;
|
offset += blocksize;
|
||||||
|
@ -161,13 +166,15 @@ struct env_location {
|
||||||
static int erase_and_write_env(const struct env_location *location,
|
static int erase_and_write_env(const struct env_location *location,
|
||||||
u_char *env_new)
|
u_char *env_new)
|
||||||
{
|
{
|
||||||
|
struct mtd_info *mtd;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
if (!nand_info[0])
|
mtd = get_nand_dev_by_index(0);
|
||||||
|
if (!mtd)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
printf("Erasing %s...\n", location->name);
|
printf("Erasing %s...\n", location->name);
|
||||||
if (nand_erase_opts(nand_info[0], &location->erase_opts))
|
if (nand_erase_opts(mtd, &location->erase_opts))
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
printf("Writing to %s... ", location->name);
|
printf("Writing to %s... ", location->name);
|
||||||
|
@ -248,22 +255,24 @@ static int readenv(size_t offset, u_char *buf)
|
||||||
size_t end = offset + CONFIG_ENV_RANGE;
|
size_t end = offset + CONFIG_ENV_RANGE;
|
||||||
size_t amount_loaded = 0;
|
size_t amount_loaded = 0;
|
||||||
size_t blocksize, len;
|
size_t blocksize, len;
|
||||||
|
struct mtd_info *mtd;
|
||||||
u_char *char_ptr;
|
u_char *char_ptr;
|
||||||
|
|
||||||
if (!nand_info[0])
|
mtd = get_nand_dev_by_index(0);
|
||||||
|
if (!mtd)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
blocksize = nand_info[0]->erasesize;
|
blocksize = mtd->erasesize;
|
||||||
len = min(blocksize, (size_t)CONFIG_ENV_SIZE);
|
len = min(blocksize, (size_t)CONFIG_ENV_SIZE);
|
||||||
|
|
||||||
while (amount_loaded < CONFIG_ENV_SIZE && offset < end) {
|
while (amount_loaded < CONFIG_ENV_SIZE && offset < end) {
|
||||||
if (nand_block_isbad(nand_info[0], offset)) {
|
if (nand_block_isbad(mtd, offset)) {
|
||||||
offset += blocksize;
|
offset += blocksize;
|
||||||
} else {
|
} else {
|
||||||
char_ptr = &buf[amount_loaded];
|
char_ptr = &buf[amount_loaded];
|
||||||
if (nand_read_skip_bad(nand_info[0], offset,
|
if (nand_read_skip_bad(mtd, offset,
|
||||||
&len, NULL,
|
&len, NULL,
|
||||||
nand_info[0]->size, char_ptr))
|
mtd->size, char_ptr))
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
offset += blocksize;
|
offset += blocksize;
|
||||||
|
@ -390,12 +399,12 @@ void env_relocate_spec(void)
|
||||||
ALLOC_CACHE_ALIGN_BUFFER(char, buf, CONFIG_ENV_SIZE);
|
ALLOC_CACHE_ALIGN_BUFFER(char, buf, CONFIG_ENV_SIZE);
|
||||||
|
|
||||||
#if defined(CONFIG_ENV_OFFSET_OOB)
|
#if defined(CONFIG_ENV_OFFSET_OOB)
|
||||||
|
struct mtd_info *mtd = get_nand_dev_by_index(0);
|
||||||
/*
|
/*
|
||||||
* If unable to read environment offset from NAND OOB then fall through
|
* If unable to read environment offset from NAND OOB then fall through
|
||||||
* to the normal environment reading code below
|
* to the normal environment reading code below
|
||||||
*/
|
*/
|
||||||
if (nand_info[0] && !get_nand_env_oob(nand_info[0],
|
if (mtd && !get_nand_env_oob(mtd, &nand_env_oob_offset)) {
|
||||||
&nand_env_oob_offset)) {
|
|
||||||
printf("Found Environment offset in OOB..\n");
|
printf("Found Environment offset in OOB..\n");
|
||||||
} else {
|
} else {
|
||||||
set_default_env("!no env offset in OOB");
|
set_default_env("!no env offset in OOB");
|
||||||
|
|
Loading…
Add table
Reference in a new issue