pmconfig: update pmconfig dump
Signed-off-by: ligd <liguiding1@xiaomi.com>
This commit is contained in:
parent
a109a6e58b
commit
75155532b6
@ -71,6 +71,10 @@
|
|||||||
UNAME_MACHINE | UNAME_PLATFORM)
|
UNAME_MACHINE | UNAME_PLATFORM)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef CONFIG_NSH_PROC_MOUNTPOINT
|
||||||
|
# define CONFIG_NSH_PROC_MOUNTPOINT "/proc"
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Private Data
|
* Private Data
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -172,6 +176,30 @@ int cmd_shutdown(FAR struct nsh_vtbl_s *vtbl, int argc, char **argv)
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#if defined(CONFIG_PM) && !defined(CONFIG_NSH_DISABLE_PMCONFIG)
|
#if defined(CONFIG_PM) && !defined(CONFIG_NSH_DISABLE_PMCONFIG)
|
||||||
|
static int cmd_pmconfig_recursive(FAR struct nsh_vtbl_s *vtbl,
|
||||||
|
FAR const char *dirpath,
|
||||||
|
FAR struct dirent *entryp,
|
||||||
|
FAR void *pvarg)
|
||||||
|
{
|
||||||
|
char *path;
|
||||||
|
int ret = ERROR;
|
||||||
|
|
||||||
|
if (DIRENT_ISDIRECTORY(entryp->d_type))
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
path = nsh_getdirpath(vtbl, dirpath, entryp->d_name);
|
||||||
|
if (path)
|
||||||
|
{
|
||||||
|
nsh_output(vtbl, "\n%s:\n", path);
|
||||||
|
ret = nsh_catfile(vtbl, pvarg, path);
|
||||||
|
free(path);
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
int cmd_pmconfig(FAR struct nsh_vtbl_s *vtbl, int argc, char **argv)
|
int cmd_pmconfig(FAR struct nsh_vtbl_s *vtbl, int argc, char **argv)
|
||||||
{
|
{
|
||||||
struct boardioc_pm_ctrl_s ctrl =
|
struct boardioc_pm_ctrl_s ctrl =
|
||||||
@ -182,10 +210,6 @@ int cmd_pmconfig(FAR struct nsh_vtbl_s *vtbl, int argc, char **argv)
|
|||||||
{
|
{
|
||||||
int next_state;
|
int next_state;
|
||||||
int last_state;
|
int last_state;
|
||||||
int normal_count;
|
|
||||||
int idle_count;
|
|
||||||
int standby_count;
|
|
||||||
int sleep_count;
|
|
||||||
|
|
||||||
if (argc == 2)
|
if (argc == 2)
|
||||||
{
|
{
|
||||||
@ -200,27 +224,12 @@ int cmd_pmconfig(FAR struct nsh_vtbl_s *vtbl, int argc, char **argv)
|
|||||||
boardctl(BOARDIOC_PM_CONTROL, (uintptr_t)&ctrl);
|
boardctl(BOARDIOC_PM_CONTROL, (uintptr_t)&ctrl);
|
||||||
next_state = ctrl.state;
|
next_state = ctrl.state;
|
||||||
|
|
||||||
ctrl.action = BOARDIOC_PM_STAYCOUNT;
|
nsh_output(vtbl, "Last state %d, Next state %d\n",
|
||||||
ctrl.state = PM_NORMAL;
|
last_state, next_state);
|
||||||
boardctl(BOARDIOC_PM_CONTROL, (uintptr_t)&ctrl);
|
|
||||||
normal_count = ctrl.count;
|
|
||||||
|
|
||||||
ctrl.state = PM_IDLE;
|
return nsh_foreach_direntry(vtbl, argv[0],
|
||||||
boardctl(BOARDIOC_PM_CONTROL, (uintptr_t)&ctrl);
|
CONFIG_NSH_PROC_MOUNTPOINT "/pm",
|
||||||
idle_count = ctrl.count;
|
cmd_pmconfig_recursive, argv[0]);
|
||||||
|
|
||||||
ctrl.state = PM_STANDBY;
|
|
||||||
boardctl(BOARDIOC_PM_CONTROL, (uintptr_t)&ctrl);
|
|
||||||
standby_count = ctrl.count;
|
|
||||||
|
|
||||||
ctrl.state = PM_SLEEP;
|
|
||||||
boardctl(BOARDIOC_PM_CONTROL, (uintptr_t)&ctrl);
|
|
||||||
sleep_count = ctrl.count;
|
|
||||||
|
|
||||||
nsh_output(vtbl, "Last state %d, Next state %d"
|
|
||||||
"PM stay [%d, %d, %d, %d]\n",
|
|
||||||
last_state, next_state, normal_count, idle_count,
|
|
||||||
standby_count, sleep_count);
|
|
||||||
}
|
}
|
||||||
else if (argc <= 4)
|
else if (argc <= 4)
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user