PM update; NSH extension to catch return values
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@4987 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
1f5e173a70
commit
cea531d7dc
@ -259,3 +259,5 @@
|
|||||||
* apps/modbus: Add CONFIG_MB_TERMIOS. If the driver doesn't support
|
* apps/modbus: Add CONFIG_MB_TERMIOS. If the driver doesn't support
|
||||||
termios ioctls, then don't bother trying to configure the baud, parity
|
termios ioctls, then don't bother trying to configure the baud, parity
|
||||||
etc.
|
etc.
|
||||||
|
* apps/nslib: If waitpid() is supported, then NSH not catches the
|
||||||
|
return value from spawned applications.
|
||||||
|
@ -84,7 +84,22 @@
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: nsh_execute
|
* Name: nsh_execapp
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Attempt to execute the application task whose name is 'cmd'
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* -1 (ERRROR) if the application task corresponding to 'cmd' could not
|
||||||
|
* be started (possibly because it doesn not exist).
|
||||||
|
* 0 (OK) if the application task corresponding to 'cmd' was
|
||||||
|
* and successfully started. If CONFIG_SCHED_WAITPID is
|
||||||
|
* defined, this return value also indicates that the
|
||||||
|
* application returned successful status (EXIT_SUCCESS)
|
||||||
|
* 1 If CONFIG_SCHED_WAITPID is defined, then this return value
|
||||||
|
* indicates that the application task was spawned successfully
|
||||||
|
* but returned failure exit status.
|
||||||
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
int nsh_execapp(FAR struct nsh_vtbl_s *vtbl, FAR const char *cmd,
|
int nsh_execapp(FAR struct nsh_vtbl_s *vtbl, FAR const char *cmd,
|
||||||
@ -103,7 +118,21 @@ int nsh_execapp(FAR struct nsh_vtbl_s *vtbl, FAR const char *cmd,
|
|||||||
#ifdef CONFIG_SCHED_WAITPID
|
#ifdef CONFIG_SCHED_WAITPID
|
||||||
if (vtbl->np.np_bg == false)
|
if (vtbl->np.np_bg == false)
|
||||||
{
|
{
|
||||||
waitpid(ret, NULL, 0);
|
int rc = 0;
|
||||||
|
|
||||||
|
waitpid(ret, &rc, 0);
|
||||||
|
|
||||||
|
/* We can't return the exact status (nsh has nowhere to put it)
|
||||||
|
* so just pass back zero/nonzero in a fashion that doesn't look
|
||||||
|
* like an error.
|
||||||
|
*/
|
||||||
|
|
||||||
|
ret = (rc == 0) ? OK : 1;
|
||||||
|
|
||||||
|
/* TODO: Set the environment variable '?' to a string corresponding
|
||||||
|
* to WEXITSTATUS(rc) so that $? will expand to the exit status of
|
||||||
|
* the most recently executed task.
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
@ -111,11 +140,15 @@ int nsh_execapp(FAR struct nsh_vtbl_s *vtbl, FAR const char *cmd,
|
|||||||
struct sched_param param;
|
struct sched_param param;
|
||||||
sched_getparam(0, ¶m);
|
sched_getparam(0, ¶m);
|
||||||
nsh_output(vtbl, "%s [%d:%d]\n", cmd, ret, param.sched_priority);
|
nsh_output(vtbl, "%s [%d:%d]\n", cmd, ret, param.sched_priority);
|
||||||
|
|
||||||
|
/* Backgrounded commands always 'succeed' as long as we can start
|
||||||
|
* them.
|
||||||
|
*/
|
||||||
|
|
||||||
|
ret = OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
return OK;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* CONFIG_NSH_BUILTIN_APPS */
|
#endif /* CONFIG_NSH_BUILTIN_APPS */
|
||||||
|
|
||||||
|
|
||||||
|
@ -67,7 +67,7 @@
|
|||||||
#include "nsh_console.h"
|
#include "nsh_console.h"
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Definitions
|
* Pre-processor Definitions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/* Argument list size
|
/* Argument list size
|
||||||
@ -487,6 +487,16 @@ static int cmd_exit(FAR struct nsh_vtbl_s *vtbl, int argc, char **argv)
|
|||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: nsh_execute
|
* Name: nsh_execute
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Exectue the command in argv[0]
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* -1 (ERRROR) if the command was unsuccessful
|
||||||
|
* 0 (OK) if the command was successful
|
||||||
|
* 1 if an application task was spawned successfully, but
|
||||||
|
* returned failure exit status.
|
||||||
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
static int nsh_execute(FAR struct nsh_vtbl_s *vtbl, int argc, char *argv[])
|
static int nsh_execute(FAR struct nsh_vtbl_s *vtbl, int argc, char *argv[])
|
||||||
@ -506,19 +516,21 @@ static int nsh_execute(FAR struct nsh_vtbl_s *vtbl, int argc, char *argv[])
|
|||||||
|
|
||||||
cmd = argv[0];
|
cmd = argv[0];
|
||||||
|
|
||||||
/* Try to find a command in the application library.
|
/* Try to find a command in the application library. */
|
||||||
*/
|
|
||||||
|
|
||||||
#ifdef CONFIG_NSH_BUILTIN_APPS
|
#ifdef CONFIG_NSH_BUILTIN_APPS
|
||||||
if (nsh_execapp(vtbl, cmd, argv) == OK)
|
ret = nsh_execapp(vtbl, cmd, argv);
|
||||||
{
|
|
||||||
/* The pre-built application was successfully started -- return OK. */
|
|
||||||
|
|
||||||
return OK;
|
/* The pre-built application was successfully started -- return OK
|
||||||
}
|
* or 1 if it returned a non-zero exit status.
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (ret >= 0)
|
||||||
|
{
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* See if the command is one that we understand */
|
/* See if the command is one that we understand */
|
||||||
|
|
||||||
for (cmdmap = g_cmdmap; cmdmap->cmd; cmdmap++)
|
for (cmdmap = g_cmdmap; cmdmap->cmd; cmdmap++)
|
||||||
@ -1123,6 +1135,7 @@ int nsh_parse(FAR struct nsh_vtbl_s *vtbl, char *cmdline)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
argv[argc] = NULL;
|
argv[argc] = NULL;
|
||||||
|
|
||||||
/* Check if the command should run in background */
|
/* Check if the command should run in background */
|
||||||
@ -1136,7 +1149,6 @@ int nsh_parse(FAR struct nsh_vtbl_s *vtbl, char *cmdline)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* Check if the output was re-directed using > or >> */
|
/* Check if the output was re-directed using > or >> */
|
||||||
|
|
||||||
if (argc > 2)
|
if (argc > 2)
|
||||||
@ -1285,6 +1297,7 @@ int nsh_parse(FAR struct nsh_vtbl_s *vtbl, char *cmdline)
|
|||||||
nsh_release(bkgvtbl);
|
nsh_release(bkgvtbl);
|
||||||
goto errout;
|
goto errout;
|
||||||
}
|
}
|
||||||
|
|
||||||
nsh_output(vtbl, "%s [%d:%d]\n", cmd, thread, param.sched_priority);
|
nsh_output(vtbl, "%s [%d:%d]\n", cmd, thread, param.sched_priority);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -1300,7 +1313,12 @@ int nsh_parse(FAR struct nsh_vtbl_s *vtbl, char *cmdline)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Then execute the command in "foreground" -- i.e., while the user waits
|
/* Then execute the command in "foreground" -- i.e., while the user waits
|
||||||
* for the next prompt.
|
* for the next prompt. nsh_execute will return:
|
||||||
|
*
|
||||||
|
* -1 (ERRROR) if the command was unsuccessful
|
||||||
|
* 0 (OK) if the command was successful
|
||||||
|
* 1 if an application task was spawned successfully, but
|
||||||
|
* returned failure exit status.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
ret = nsh_execute(vtbl, argc, argv);
|
ret = nsh_execute(vtbl, argc, argv);
|
||||||
@ -1314,7 +1332,11 @@ int nsh_parse(FAR struct nsh_vtbl_s *vtbl, char *cmdline)
|
|||||||
nsh_undirect(vtbl, save);
|
nsh_undirect(vtbl, save);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ret < 0)
|
/* Treat both errors and non-zero return codes as "errors" so that
|
||||||
|
* it is possible to test for non-zero returns in nsh scripts.
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (ret != OK)
|
||||||
{
|
{
|
||||||
goto errout;
|
goto errout;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user