sched/spawn: Launch nxposix_spawn_proxy through nxthread_create
to ensure the caller environment variable always get copied Signed-off-by: Xiang Xiao <xiaoxiang@xiaomi.com>
This commit is contained in:
parent
aed85964ff
commit
9ccddde6a9
@ -297,6 +297,10 @@ extern volatile spinlock_t g_cpu_tasklistlock;
|
|||||||
* Public Function Prototypes
|
* Public Function Prototypes
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
|
int nxthread_create(FAR const char *name, uint8_t ttype, int priority,
|
||||||
|
FAR void *stack_ptr, int stack_size, main_t entry,
|
||||||
|
FAR char * const argv[], FAR char * const envp[]);
|
||||||
|
|
||||||
/* Task list manipulation functions */
|
/* Task list manipulation functions */
|
||||||
|
|
||||||
bool nxsched_add_readytorun(FAR struct tcb_s *rtrtcb);
|
bool nxsched_add_readytorun(FAR struct tcb_s *rtrtcb);
|
||||||
|
@ -39,7 +39,7 @@
|
|||||||
#include "task/task.h"
|
#include "task/task.h"
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Private Functions
|
* Public Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@ -70,7 +70,7 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
static int nxthread_create(FAR const char *name, uint8_t ttype, int priority,
|
int nxthread_create(FAR const char *name, uint8_t ttype, int priority,
|
||||||
FAR void *stack_ptr, int stack_size, main_t entry,
|
FAR void *stack_ptr, int stack_size, main_t entry,
|
||||||
FAR char * const argv[], FAR char * const envp[])
|
FAR char * const argv[], FAR char * const envp[])
|
||||||
{
|
{
|
||||||
@ -112,10 +112,6 @@ static int nxthread_create(FAR const char *name, uint8_t ttype, int priority,
|
|||||||
return (int)pid;
|
return (int)pid;
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Public Functions
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: nxtask_create
|
* Name: nxtask_create
|
||||||
*
|
*
|
||||||
|
@ -388,10 +388,10 @@ int posix_spawn(FAR pid_t *pid, FAR const char *path,
|
|||||||
* task.
|
* task.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
proxy = kthread_create("nxposix_spawn_proxy", param.sched_priority,
|
proxy = nxthread_create("nxposix_spawn_proxy", TCB_FLAG_TTYPE_KERNEL,
|
||||||
|
param.sched_priority, NULL,
|
||||||
CONFIG_POSIX_SPAWN_PROXY_STACKSIZE,
|
CONFIG_POSIX_SPAWN_PROXY_STACKSIZE,
|
||||||
(main_t)nxposix_spawn_proxy,
|
nxposix_spawn_proxy, NULL, environ);
|
||||||
(FAR char * const *)NULL);
|
|
||||||
if (proxy < 0)
|
if (proxy < 0)
|
||||||
{
|
{
|
||||||
ret = -proxy;
|
ret = -proxy;
|
||||||
|
Loading…
Reference in New Issue
Block a user