blob: ea3090dc7b955f5d3615f259996a91f25c107aef [file] [log] [blame]
/*
* \file cmd_defenv_without.c
* \brief use this cmd but not 'env default',
* to reserve some envs after defaulting envs
*
* \version 1.0.0
* \date 15/09/29
* \author Sam.Wu <yihui.wu@amlgic.com>
*
* Copyright (c) 2015 Amlogic. All Rights Reserved.
*
*/
#include <config.h>
#include <common.h>
#include <command.h>
#include <environment.h>
#include <cli.h>
#include <errno.h>
#include <malloc.h>
#include <linux/stddef.h>
#include <asm/byteorder.h>
static const char* const temp_for_compile[] = {"__test1","__test2","__test3",NULL};
extern const char * const _env_args_reserve_[0] __attribute__((weak, alias("temp_for_compile")));
#define ModPrefix(pre) printf(pre"[def_wi]")
#define debugP(fmt...) //ModPrefix("Dbg"),printf("L%d:", __LINE__),printf(fmt)
#define errorP(fmt...) ModPrefix("Err"), printf("L%d:", __LINE__),printf(fmt)
#define wrnP(fmt...) ModPrefix("Err"), printf(fmt)
#define MsgP(fmt...) ModPrefix("Err"), printf(fmt)
static int _reserve_env_list_after_defenv(const int reservNum, const char* const reservNameList[])
{
int ret = 0;
int index = 0;
unsigned sumOfEnvVal = 0;//sum of strlen(getenv(env_i))
const int MaxReservNum = CONFIG_SYS_MAXARGS - 1;
const char* valListBuf[MaxReservNum];//store at most 64 envs
char* tmpEnvBuf = NULL;
if (reservNum > MaxReservNum) {
errorP("max reserved env list num %d < wanted %d\n", MaxReservNum, reservNum);
return __LINE__;
}
//1, cal the total buf size needed to save the envs
for (index = 0; index < reservNum; ++index)
{
const char* cfgEnvKey = reservNameList[index];
const char* cfgEnvVal = env_get(cfgEnvKey);
if (cfgEnvVal) {
sumOfEnvVal += strlen(cfgEnvVal) + 1;
}
valListBuf[index] = cfgEnvVal;
}
//2, transfer the env values to buffer
if (sumOfEnvVal)
{
tmpEnvBuf = (char*)malloc(sumOfEnvVal);
if (!tmpEnvBuf) {
errorP("Fail in malloc(%d)\n", sumOfEnvVal);
return __LINE__;
}
memset(tmpEnvBuf, 0, sumOfEnvVal);
char* tmpbuf = tmpEnvBuf;
for (index = 0; index < reservNum; ++index )
{
const char* valBeforeDef = valListBuf[index];
if (!valBeforeDef) continue;
const unsigned thisValLen = strlen(valBeforeDef) + 1;
memcpy(tmpbuf, valBeforeDef, thisValLen);
valListBuf[index] = tmpbuf;
tmpbuf += thisValLen ;
debugP("tmpEnvBuf=%p, tmpbuf=%p, thisValLen=%d\n", tmpEnvBuf, tmpbuf, thisValLen);
debugP("cp:k[%s]%s-->%s\n", reservNameList[index], valBeforeDef, tmpEnvBuf);
}
}
set_default_env("## defenv_reserve\n");
if (sumOfEnvVal)
{
for (index = 0; index < reservNum; ++index)
{
const char* cfgEnvKey = reservNameList[index];
const char* valAftDef = valListBuf[index];
if (valAftDef)
{
env_set(cfgEnvKey, valAftDef);
debugP("set[%s=%s]\n", cfgEnvKey, valAftDef);
}
}
}
if (tmpEnvBuf) free(tmpEnvBuf) ;
return ret;
}
static int do_defenv_reserv(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
int envListNum = argc - 1;
const char** envListArr = (const char**)(argv + 1);
if (!envListNum)
{
envListArr = (const char**)_env_args_reserve_;
const char** pArr = (const char**)envListArr;
while (*pArr++) ++envListNum;
}
int ret = _reserve_env_list_after_defenv(envListNum, envListArr);
return ret ? CMD_RET_FAILURE : CMD_RET_SUCCESS;
}
U_BOOT_CMD_COMPLETE(
defenv_reserv, //command name
CONFIG_SYS_MAXARGS, //maxargs
0, //repeatable
do_defenv_reserv, //command function
"reserve some specified envs after defaulting env", //description
" argv: defenv_reserve <reserv_en0 reserv_env1 ...> \n" //usage
" - e.g. \n"
" defenv_reserve :\n" //usage
" NOT env list , reserv cfg array '_env_args_reserve_' in gxbb_p200.c\n"
" defenv_reserve reserv_en0, reserv_env1, ...\n" //usage
" reserve specified envs after defaulting env\n", //usage
var_complete
);