From 4f3674f5f22d41dd58a6ea51d3a5fed89ef1990b Mon Sep 17 00:00:00 2001 From: Giovanni Di Sirio Date: Fri, 19 Feb 2016 16:32:09 +0000 Subject: git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@8912 35acf78f-673a-0410-8e92-d51de3d6d3f4 --- os/various/shell.c | 45 ++++++++------------------------------------- os/various/shell.h | 6 +----- 2 files changed, 9 insertions(+), 42 deletions(-) (limited to 'os/various') diff --git a/os/various/shell.c b/os/various/shell.c index 0de6f449a..a60f9b479 100644 --- a/os/various/shell.c +++ b/os/various/shell.c @@ -133,7 +133,7 @@ static bool cmdexec(const ShellCommand *scp, BaseSequentialStream *chp, * * @param[in] p pointer to a @p BaseSequentialStream object */ -static THD_FUNCTION(shell_thread, p) { +THD_FUNCTION(shellThread, p) { int n; BaseSequentialStream *chp = ((ShellConfig *)p)->sc_channel; const ShellCommand *scp = ((ShellConfig *)p)->sc_commands; @@ -217,44 +217,15 @@ void shellExit(msg_t msg) { chThdExitS(msg); } -/** - * @brief Spawns a new shell. - * @pre @p CH_CFG_USE_HEAP and @p CH_CFG_USE_DYNAMIC must be enabled. - * - * @param[in] scp pointer to a @p ShellConfig object - * @param[in] size size of the shell working area to be allocated - * @param[in] prio priority level for the new shell - * @return A pointer to the shell thread. - * @retval NULL thread creation failed because memory allocation. - * - * @api - */ -#if CH_CFG_USE_HEAP && CH_CFG_USE_DYNAMIC -thread_t *shellCreate(const ShellConfig *scp, size_t size, tprio_t prio) { - - return chThdCreateFromHeap(NULL, size, prio, shell_thread, (void *)scp); -} -#endif - -/** - * @brief Create statically allocated shell thread. - * - * @param[in] scp pointer to a @p ShellConfig object - * @param[in] wsp pointer to a working area dedicated to the shell thread stack - * @param[in] size size of the shell working area - * @param[in] prio priority level for the new shell - * @return A pointer to the shell thread. - * - * @api - */ -thread_t *shellCreateStatic(const ShellConfig *scp, void *wsp, - size_t size, tprio_t prio) { - - return chThdCreateStatic(wsp, size, prio, shell_thread, (void *)scp); -} - /** * @brief Reads a whole line from the input channel. + * @note Input chars are echoed on the same stream object with the + * following exceptions: + * - DEL and BS are echoed as BS-SPACE-BS. + * - CR is echoed as CR-LF. + * - 0x4 is echoed as "^D". + * - Other values below 0x20 are not echoed. + * . * * @param[in] chp pointer to a @p BaseSequentialStream object * @param[in] line pointer to the line buffer diff --git a/os/various/shell.h b/os/various/shell.h index 29d20db5e..9ee73d4dc 100644 --- a/os/various/shell.h +++ b/os/various/shell.h @@ -70,12 +70,8 @@ extern event_source_t shell_terminated; extern "C" { #endif void shellInit(void); + THD_FUNCTION(shellThread, p); void shellExit(msg_t msg); -#if CH_CFG_USE_HEAP && CH_CFG_USE_DYNAMIC - thread_t *shellCreate(const ShellConfig *scp, size_t size, tprio_t prio); -#endif - thread_t *shellCreateStatic(const ShellConfig *scp, void *wsp, - size_t size, tprio_t prio); bool shellGetLine(BaseSequentialStream *chp, char *line, unsigned size); #ifdef __cplusplus } -- cgit v1.2.3