|
@@ -60,11 +60,14 @@ uchar env_get_char_spec(int index)
|
|
void env_relocate_spec(void)
|
|
void env_relocate_spec(void)
|
|
{
|
|
{
|
|
struct mtd_info *mtd = &onenand_mtd;
|
|
struct mtd_info *mtd = &onenand_mtd;
|
|
|
|
+ struct onenand_chip *this = &onenand_chip;
|
|
loff_t env_addr;
|
|
loff_t env_addr;
|
|
int use_default = 0;
|
|
int use_default = 0;
|
|
size_t retlen;
|
|
size_t retlen;
|
|
|
|
|
|
env_addr = CONFIG_ENV_ADDR;
|
|
env_addr = CONFIG_ENV_ADDR;
|
|
|
|
+ if (FLEXONENAND(this))
|
|
|
|
+ env_addr = CONFIG_ENV_ADDR_FLEX;
|
|
|
|
|
|
/* Check OneNAND exist */
|
|
/* Check OneNAND exist */
|
|
if (mtd->writesize)
|
|
if (mtd->writesize)
|
|
@@ -91,6 +94,7 @@ void env_relocate_spec(void)
|
|
int saveenv(void)
|
|
int saveenv(void)
|
|
{
|
|
{
|
|
struct mtd_info *mtd = &onenand_mtd;
|
|
struct mtd_info *mtd = &onenand_mtd;
|
|
|
|
+ struct onenand_chip *this = &onenand_chip;
|
|
loff_t env_addr = CONFIG_ENV_ADDR;
|
|
loff_t env_addr = CONFIG_ENV_ADDR;
|
|
struct erase_info instr = {
|
|
struct erase_info instr = {
|
|
.callback = NULL,
|
|
.callback = NULL,
|
|
@@ -98,6 +102,12 @@ int saveenv(void)
|
|
size_t retlen;
|
|
size_t retlen;
|
|
|
|
|
|
instr.len = CONFIG_ENV_SIZE;
|
|
instr.len = CONFIG_ENV_SIZE;
|
|
|
|
+ if (FLEXONENAND(this)) {
|
|
|
|
+ env_addr = CONFIG_ENV_ADDR_FLEX;
|
|
|
|
+ instr.len = CONFIG_ENV_SIZE_FLEX;
|
|
|
|
+ instr.len <<= onenand_mtd.eraseregions[0].numblocks == 1 ?
|
|
|
|
+ 1 : 0;
|
|
|
|
+ }
|
|
instr.addr = env_addr;
|
|
instr.addr = env_addr;
|
|
instr.mtd = mtd;
|
|
instr.mtd = mtd;
|
|
if (mtd->erase(mtd, &instr)) {
|
|
if (mtd->erase(mtd, &instr)) {
|