mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-27 14:43:21 -05:00
[pipe] Fix exit problem due to misuse of COMMAND_PENDING
This commit is contained in:
parent
d8255e1d08
commit
f0c9843194
@ -84,6 +84,12 @@ struct pipe
|
|||||||
struct pipe *next;
|
struct pipe *next;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
union pipe_arg
|
||||||
|
{
|
||||||
|
uint32_t id;
|
||||||
|
struct pipe *pipelist;
|
||||||
|
};
|
||||||
|
|
||||||
// The usual thread stuff
|
// The usual thread stuff
|
||||||
static pthread_t tid_pipe;
|
static pthread_t tid_pipe;
|
||||||
static struct event_base *evbase_pipe;
|
static struct event_base *evbase_pipe;
|
||||||
@ -472,12 +478,12 @@ pipe_read_cb(evutil_socket_t fd, short event, void *arg)
|
|||||||
static enum command_state
|
static enum command_state
|
||||||
pipe_watch_reset(void *arg, int *retval)
|
pipe_watch_reset(void *arg, int *retval)
|
||||||
{
|
{
|
||||||
int *id = arg;
|
union pipe_arg *cmdarg = arg;
|
||||||
struct pipe *pipe;
|
struct pipe *pipe;
|
||||||
|
|
||||||
pipe_autostart_id = 0;
|
pipe_autostart_id = 0;
|
||||||
|
|
||||||
pipe = pipelist_find(pipe_watch_list, *id);
|
pipe = pipelist_find(pipe_watch_list, cmdarg->id);
|
||||||
|
|
||||||
*retval = watch_reset(pipe);
|
*retval = watch_reset(pipe);
|
||||||
|
|
||||||
@ -487,11 +493,15 @@ pipe_watch_reset(void *arg, int *retval)
|
|||||||
static enum command_state
|
static enum command_state
|
||||||
pipe_watch_update(void *arg, int *retval)
|
pipe_watch_update(void *arg, int *retval)
|
||||||
{
|
{
|
||||||
struct pipe *pipelist = arg;
|
union pipe_arg *cmdarg = arg;
|
||||||
|
struct pipe *pipelist = NULL;
|
||||||
struct pipe *pipe;
|
struct pipe *pipe;
|
||||||
struct pipe *next;
|
struct pipe *next;
|
||||||
int count;
|
int count;
|
||||||
|
|
||||||
|
if (cmdarg)
|
||||||
|
pipelist = cmdarg->pipelist;
|
||||||
|
|
||||||
count = 0;
|
count = 0;
|
||||||
for (pipe = pipe_watch_list; pipe; pipe = next)
|
for (pipe = pipe_watch_list; pipe; pipe = next)
|
||||||
{
|
{
|
||||||
@ -499,7 +509,7 @@ pipe_watch_update(void *arg, int *retval)
|
|||||||
|
|
||||||
if (!pipelist_find(pipelist, pipe->id))
|
if (!pipelist_find(pipelist, pipe->id))
|
||||||
{
|
{
|
||||||
DPRINTF(E_DBG, L_PLAYER, "Pipe deleted: '%s'\n", pipe->path);
|
DPRINTF(E_DBG, L_PLAYER, "Pipe watch deleted: '%s'\n", pipe->path);
|
||||||
watch_del(pipe);
|
watch_del(pipe);
|
||||||
pipelist_remove(&pipe_watch_list, pipe); // Will free pipe
|
pipelist_remove(&pipe_watch_list, pipe); // Will free pipe
|
||||||
continue;
|
continue;
|
||||||
@ -518,13 +528,13 @@ pipe_watch_update(void *arg, int *retval)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
DPRINTF(E_DBG, L_PLAYER, "Pipe added: '%s'\n", pipe->path);
|
DPRINTF(E_DBG, L_PLAYER, "Pipe watch added: '%s'\n", pipe->path);
|
||||||
watch_add(pipe);
|
watch_add(pipe);
|
||||||
pipelist_add(&pipe_watch_list, pipe);
|
pipelist_add(&pipe_watch_list, pipe);
|
||||||
}
|
}
|
||||||
|
|
||||||
*retval = 0;
|
*retval = 0;
|
||||||
return COMMAND_PENDING; // Stops commands.c from freeing any of the pipes
|
return COMMAND_END;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void *
|
static void *
|
||||||
@ -700,6 +710,7 @@ pipelist_create(void)
|
|||||||
static void
|
static void
|
||||||
pipe_listener_cb(enum listener_event_type type)
|
pipe_listener_cb(enum listener_event_type type)
|
||||||
{
|
{
|
||||||
|
union pipe_arg *cmdarg;
|
||||||
struct pipe *pipelist;
|
struct pipe *pipelist;
|
||||||
|
|
||||||
pipelist = pipelist_create();
|
pipelist = pipelist_create();
|
||||||
@ -712,7 +723,10 @@ pipe_listener_cb(enum listener_event_type type)
|
|||||||
if (!tid_pipe)
|
if (!tid_pipe)
|
||||||
pipe_thread_start();
|
pipe_thread_start();
|
||||||
|
|
||||||
commands_exec_async(cmdbase, pipe_watch_update, pipelist);
|
CHECK_NULL(L_PLAYER, cmdarg = malloc(sizeof(union pipe_arg)));
|
||||||
|
|
||||||
|
cmdarg->pipelist = pipelist;
|
||||||
|
commands_exec_async(cmdbase, pipe_watch_update, cmdarg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -793,7 +807,7 @@ static int
|
|||||||
stop(struct player_source *ps)
|
stop(struct player_source *ps)
|
||||||
{
|
{
|
||||||
struct pipe *pipe = ps->input_ctx;
|
struct pipe *pipe = ps->input_ctx;
|
||||||
int *id;
|
union pipe_arg *cmdarg;
|
||||||
|
|
||||||
DPRINTF(E_DBG, L_PLAYER, "Stopping pipe\n");
|
DPRINTF(E_DBG, L_PLAYER, "Stopping pipe\n");
|
||||||
|
|
||||||
@ -803,9 +817,9 @@ stop(struct player_source *ps)
|
|||||||
// we will deadlock from the stop in pipe_read_cb().
|
// we will deadlock from the stop in pipe_read_cb().
|
||||||
if (pipe_autostart)
|
if (pipe_autostart)
|
||||||
{
|
{
|
||||||
id = malloc(sizeof(int));
|
CHECK_NULL(L_PLAYER, cmdarg = malloc(sizeof(union pipe_arg)));
|
||||||
*id = pipe->id;
|
cmdarg->id = pipe->id;
|
||||||
commands_exec_async(cmdbase, pipe_watch_reset, id);
|
commands_exec_async(cmdbase, pipe_watch_reset, cmdarg);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pipe_metadata)
|
if (pipe_metadata)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user