mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-14 16:25:03 -05:00
[player] Purge laudio from player.c
This commit is contained in:
parent
36755031cb
commit
617303d545
423
src/player.c
423
src/player.c
@ -54,7 +54,6 @@
|
|||||||
|
|
||||||
/* Audio outputs */
|
/* Audio outputs */
|
||||||
#include "outputs.h"
|
#include "outputs.h"
|
||||||
#include "laudio.h"
|
|
||||||
|
|
||||||
/* Audio inputs */
|
/* Audio inputs */
|
||||||
#include "transcode.h"
|
#include "transcode.h"
|
||||||
@ -286,10 +285,6 @@ static int dev_autoselect; //TODO [player] Is this still necessary?
|
|||||||
static struct output_device *dev_list;
|
static struct output_device *dev_list;
|
||||||
|
|
||||||
/* Output status */
|
/* Output status */
|
||||||
static enum laudio_state laudio_status;
|
|
||||||
static int laudio_selected;
|
|
||||||
static int laudio_volume;
|
|
||||||
static int laudio_relvol;
|
|
||||||
static int output_sessions;
|
static int output_sessions;
|
||||||
|
|
||||||
/* Commands */
|
/* Commands */
|
||||||
@ -388,9 +383,6 @@ volume_master_update(int newvol)
|
|||||||
|
|
||||||
master_volume = newvol;
|
master_volume = newvol;
|
||||||
|
|
||||||
if (laudio_selected)
|
|
||||||
laudio_relvol = vol_to_rel(laudio_volume);
|
|
||||||
|
|
||||||
for (device = dev_list; device; device = device->next)
|
for (device = dev_list; device; device = device->next)
|
||||||
{
|
{
|
||||||
if (device->selected)
|
if (device->selected)
|
||||||
@ -406,9 +398,6 @@ volume_master_find(void)
|
|||||||
|
|
||||||
newmaster = -1;
|
newmaster = -1;
|
||||||
|
|
||||||
if (laudio_selected)
|
|
||||||
newmaster = laudio_volume;
|
|
||||||
|
|
||||||
for (device = dev_list; device; device = device->next)
|
for (device = dev_list; device; device = device->next)
|
||||||
{
|
{
|
||||||
if (device->selected && (device->volume > newmaster))
|
if (device->selected && (device->volume > newmaster))
|
||||||
@ -420,22 +409,6 @@ volume_master_find(void)
|
|||||||
|
|
||||||
|
|
||||||
/* Device select/deselect hooks */
|
/* Device select/deselect hooks */
|
||||||
static void
|
|
||||||
speaker_select_laudio(void)
|
|
||||||
{
|
|
||||||
laudio_selected = 1;
|
|
||||||
|
|
||||||
if (laudio_volume > master_volume)
|
|
||||||
{
|
|
||||||
if (player_state == PLAY_STOPPED || master_volume == -1)
|
|
||||||
volume_master_update(laudio_volume);
|
|
||||||
else
|
|
||||||
laudio_volume = master_volume;
|
|
||||||
}
|
|
||||||
|
|
||||||
laudio_relvol = vol_to_rel(laudio_volume);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
speaker_select_output(struct output_device *device)
|
speaker_select_output(struct output_device *device)
|
||||||
{
|
{
|
||||||
@ -452,15 +425,6 @@ speaker_select_output(struct output_device *device)
|
|||||||
device->relvol = vol_to_rel(device->volume);
|
device->relvol = vol_to_rel(device->volume);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
speaker_deselect_laudio(void)
|
|
||||||
{
|
|
||||||
laudio_selected = 0;
|
|
||||||
|
|
||||||
if (laudio_volume == master_volume)
|
|
||||||
volume_master_find();
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
speaker_deselect_output(struct output_device *device)
|
speaker_deselect_output(struct output_device *device)
|
||||||
{
|
{
|
||||||
@ -514,36 +478,6 @@ player_get_current_pos_clock(uint64_t *pos, struct timespec *ts, int commit)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
|
||||||
player_get_current_pos_laudio(uint64_t *pos, struct timespec *ts, int commit)
|
|
||||||
{
|
|
||||||
int ret;
|
|
||||||
|
|
||||||
*pos = laudio_get_pos();
|
|
||||||
|
|
||||||
ret = clock_gettime_with_res(CLOCK_MONOTONIC, ts, &timer_res);
|
|
||||||
if (ret < 0)
|
|
||||||
{
|
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Couldn't get clock: %s\n", strerror(errno));
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (commit)
|
|
||||||
{
|
|
||||||
pb_pos = *pos;
|
|
||||||
|
|
||||||
pb_pos_stamp.tv_sec = ts->tv_sec;
|
|
||||||
pb_pos_stamp.tv_nsec = ts->tv_nsec;
|
|
||||||
|
|
||||||
#ifdef DEBUG_SYNC
|
|
||||||
DPRINTF(E_DBG, L_PLAYER, "Pos: %" PRIu64 " (laudio)\n", *pos);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
int
|
||||||
player_get_current_pos(uint64_t *pos, struct timespec *ts, int commit)
|
player_get_current_pos(uint64_t *pos, struct timespec *ts, int commit)
|
||||||
{
|
{
|
||||||
@ -552,8 +486,8 @@ player_get_current_pos(uint64_t *pos, struct timespec *ts, int commit)
|
|||||||
case PLAYER_SYNC_CLOCK:
|
case PLAYER_SYNC_CLOCK:
|
||||||
return player_get_current_pos_clock(pos, ts, commit);
|
return player_get_current_pos_clock(pos, ts, commit);
|
||||||
|
|
||||||
case PLAYER_SYNC_LAUDIO:
|
default:
|
||||||
return player_get_current_pos_laudio(pos, ts, commit);
|
DPRINTF(E_LOG, L_PLAYER, "Bug! player_get_current_pos called with unknown source\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
@ -616,54 +550,6 @@ playerqueue_clear(struct player_command *cmd);
|
|||||||
static void
|
static void
|
||||||
player_metadata_send(struct player_metadata *pmd);
|
player_metadata_send(struct player_metadata *pmd);
|
||||||
|
|
||||||
static void
|
|
||||||
player_laudio_status_cb(enum laudio_state status)
|
|
||||||
{
|
|
||||||
struct timespec ts;
|
|
||||||
uint64_t pos;
|
|
||||||
|
|
||||||
switch (status)
|
|
||||||
{
|
|
||||||
/* Switch sync to clock sync */
|
|
||||||
case LAUDIO_STOPPING:
|
|
||||||
DPRINTF(E_DBG, L_PLAYER, "Local audio stopping\n");
|
|
||||||
|
|
||||||
laudio_status = status;
|
|
||||||
|
|
||||||
/* Synchronize pb_pos and pb_pos_stamp before laudio stops entirely */
|
|
||||||
player_get_current_pos_laudio(&pos, &ts, 1);
|
|
||||||
|
|
||||||
pb_sync_source = PLAYER_SYNC_CLOCK;
|
|
||||||
break;
|
|
||||||
|
|
||||||
/* Switch sync to laudio sync */
|
|
||||||
case LAUDIO_RUNNING:
|
|
||||||
DPRINTF(E_DBG, L_PLAYER, "Local audio running\n");
|
|
||||||
|
|
||||||
laudio_status = status;
|
|
||||||
|
|
||||||
pb_sync_source = PLAYER_SYNC_LAUDIO;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case LAUDIO_FAILED:
|
|
||||||
DPRINTF(E_DBG, L_PLAYER, "Local audio failed\n");
|
|
||||||
|
|
||||||
pb_sync_source = PLAYER_SYNC_CLOCK;
|
|
||||||
|
|
||||||
laudio_close();
|
|
||||||
|
|
||||||
if (output_sessions == 0)
|
|
||||||
playback_abort();
|
|
||||||
|
|
||||||
speaker_deselect_laudio();
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
laudio_status = status;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Callback from the worker thread (async operation as it may block) */
|
/* Callback from the worker thread (async operation as it may block) */
|
||||||
static void
|
static void
|
||||||
playcount_inc_cb(void *arg)
|
playcount_inc_cb(void *arg)
|
||||||
@ -1603,9 +1489,6 @@ playback_write(void)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (laudio_status & LAUDIO_F_STARTED)
|
|
||||||
laudio_write(rawbuf, last_rtptime);
|
|
||||||
|
|
||||||
outputs_write(rawbuf, last_rtptime);
|
outputs_write(rawbuf, last_rtptime);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2160,9 +2043,6 @@ device_restart_cb(struct output_device *device, struct output_session *session,
|
|||||||
static void
|
static void
|
||||||
playback_abort(void)
|
playback_abort(void)
|
||||||
{
|
{
|
||||||
if (laudio_status != LAUDIO_CLOSED)
|
|
||||||
laudio_close();
|
|
||||||
|
|
||||||
outputs_playback_stop();
|
outputs_playback_stop();
|
||||||
|
|
||||||
pb_timer_stop();
|
pb_timer_stop();
|
||||||
@ -2331,9 +2211,6 @@ playback_stop(struct player_command *cmd)
|
|||||||
{
|
{
|
||||||
struct player_source *ps_playing;
|
struct player_source *ps_playing;
|
||||||
|
|
||||||
if (laudio_status != LAUDIO_CLOSED)
|
|
||||||
laudio_close();
|
|
||||||
|
|
||||||
/* We may be restarting very soon, so we don't bring the devices to a
|
/* We may be restarting very soon, so we don't bring the devices to a
|
||||||
* full stop just yet; this saves time when restarting, which is nicer
|
* full stop just yet; this saves time when restarting, which is nicer
|
||||||
* for the user.
|
* for the user.
|
||||||
@ -2369,27 +2246,13 @@ playback_start_bh(struct player_command *cmd)
|
|||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if ((laudio_status == LAUDIO_CLOSED) && (output_sessions == 0))
|
if (output_sessions == 0)
|
||||||
{
|
{
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Cannot start playback: no output started\n");
|
DPRINTF(E_LOG, L_PLAYER, "Cannot start playback: no output started\n");
|
||||||
|
|
||||||
goto out_fail;
|
goto out_fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Start laudio first as it can fail, but can be stopped easily if needed */
|
|
||||||
if (laudio_status == LAUDIO_OPEN)
|
|
||||||
{
|
|
||||||
laudio_set_volume(laudio_volume);
|
|
||||||
|
|
||||||
ret = laudio_start(pb_pos, last_rtptime + AIRTUNES_V2_PACKET_SAMPLES);
|
|
||||||
if (ret < 0)
|
|
||||||
{
|
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Local audio failed to start\n");
|
|
||||||
|
|
||||||
goto out_fail;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = clock_gettime_with_res(CLOCK_MONOTONIC, &pb_pos_stamp, &timer_res);
|
ret = clock_gettime_with_res(CLOCK_MONOTONIC, &pb_pos_stamp, &timer_res);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
@ -2496,16 +2359,7 @@ playback_start_item(struct player_command *cmd, struct queue_item *qii)
|
|||||||
|
|
||||||
metadata_trigger(1);
|
metadata_trigger(1);
|
||||||
|
|
||||||
|
/* Start sessions on selected devices */
|
||||||
/* Start local audio if needed */
|
|
||||||
if (laudio_selected && (laudio_status == LAUDIO_CLOSED))
|
|
||||||
{
|
|
||||||
ret = laudio_open();
|
|
||||||
if (ret < 0)
|
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Could not open local audio, will try AirPlay\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Start RAOP sessions on selected devices if needed */
|
|
||||||
cmd->output_requests_pending = 0;
|
cmd->output_requests_pending = 0;
|
||||||
|
|
||||||
for (device = dev_list; device; device = device->next)
|
for (device = dev_list; device; device = device->next)
|
||||||
@ -2524,8 +2378,8 @@ playback_start_item(struct player_command *cmd, struct queue_item *qii)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Try to autoselect a non-selected RAOP device if the above failed */
|
/* Try to autoselect a non-selected device if the above failed */
|
||||||
if ((laudio_status == LAUDIO_CLOSED) && (cmd->output_requests_pending == 0) && (output_sessions == 0))
|
if ((cmd->output_requests_pending == 0) && (output_sessions == 0))
|
||||||
for (device = dev_list; device; device = device->next)
|
for (device = dev_list; device; device = device->next)
|
||||||
{
|
{
|
||||||
if (!device->session)
|
if (!device->session)
|
||||||
@ -2546,7 +2400,7 @@ playback_start_item(struct player_command *cmd, struct queue_item *qii)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* No luck finding valid output */
|
/* No luck finding valid output */
|
||||||
if ((laudio_status == LAUDIO_CLOSED) && (cmd->output_requests_pending == 0) && (output_sessions == 0))
|
if ((cmd->output_requests_pending == 0) && (output_sessions == 0))
|
||||||
{
|
{
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Could not start playback: no output selected or couldn't start any output\n");
|
DPRINTF(E_LOG, L_PLAYER, "Could not start playback: no output selected or couldn't start any output\n");
|
||||||
|
|
||||||
@ -2801,9 +2655,6 @@ playback_pause(struct player_command *cmd)
|
|||||||
|
|
||||||
cmd->output_requests_pending = outputs_flush(device_command_cb, last_rtptime + AIRTUNES_V2_PACKET_SAMPLES);
|
cmd->output_requests_pending = outputs_flush(device_command_cb, last_rtptime + AIRTUNES_V2_PACKET_SAMPLES);
|
||||||
|
|
||||||
if (laudio_status != LAUDIO_CLOSED)
|
|
||||||
laudio_stop();
|
|
||||||
|
|
||||||
pb_timer_stop();
|
pb_timer_stop();
|
||||||
|
|
||||||
source_pause(pos);
|
source_pause(pos);
|
||||||
@ -2826,25 +2677,11 @@ speaker_enumerate(struct player_command *cmd)
|
|||||||
struct output_device *device;
|
struct output_device *device;
|
||||||
struct spk_enum *spk_enum;
|
struct spk_enum *spk_enum;
|
||||||
struct spk_flags flags;
|
struct spk_flags flags;
|
||||||
char *laudio_name;
|
|
||||||
|
|
||||||
spk_enum = cmd->arg.spk_enum;
|
spk_enum = cmd->arg.spk_enum;
|
||||||
|
|
||||||
laudio_name = cfg_getstr(cfg_getsec(cfg, "audio"), "nickname");
|
|
||||||
|
|
||||||
/* Auto-select local audio if there are no other output devices */
|
|
||||||
if (!dev_list && !laudio_selected)
|
|
||||||
speaker_select_laudio();
|
|
||||||
|
|
||||||
flags.selected = laudio_selected;
|
|
||||||
flags.has_password = 0;
|
|
||||||
flags.has_video = 0;
|
|
||||||
|
|
||||||
spk_enum->cb(0, laudio_name, laudio_relvol, flags, spk_enum->arg);
|
|
||||||
|
|
||||||
#ifdef DEBUG_RELVOL
|
#ifdef DEBUG_RELVOL
|
||||||
DPRINTF(E_DBG, L_PLAYER, "*** master: %d\n", master_volume);
|
DPRINTF(E_DBG, L_PLAYER, "*** master: %d\n", master_volume);
|
||||||
DPRINTF(E_DBG, L_PLAYER, "*** laudio: abs %d rel %d\n", laudio_volume, laudio_relvol);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
for (device = dev_list; device; device = device->next)
|
for (device = dev_list; device; device = device->next)
|
||||||
@ -2869,113 +2706,49 @@ speaker_enumerate(struct player_command *cmd)
|
|||||||
static int
|
static int
|
||||||
speaker_activate(struct output_device *device)
|
speaker_activate(struct output_device *device)
|
||||||
{
|
{
|
||||||
struct timespec ts;
|
|
||||||
uint64_t pos;
|
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (!device)
|
if (!device)
|
||||||
{
|
{
|
||||||
/* Local */
|
DPRINTF(E_LOG, L_PLAYER, "Bug! speaker_activate called with device\n");
|
||||||
DPRINTF(E_DBG, L_PLAYER, "Activating local audio\n");
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
if (laudio_status == LAUDIO_CLOSED)
|
if (player_state == PLAY_PLAYING)
|
||||||
|
{
|
||||||
|
DPRINTF(E_DBG, L_PLAYER, "Activating %s device '%s'\n", device->type_name, device->name);
|
||||||
|
|
||||||
|
ret = outputs_device_start(device, device_activate_cb, last_rtptime + AIRTUNES_V2_PACKET_SAMPLES);
|
||||||
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
ret = laudio_open();
|
DPRINTF(E_LOG, L_PLAYER, "Could not start %s device '%s'\n", device->type_name, device->name);
|
||||||
if (ret < 0)
|
return -1;
|
||||||
{
|
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Could not open local audio\n");
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (player_state == PLAY_PLAYING)
|
|
||||||
{
|
|
||||||
laudio_set_volume(laudio_volume);
|
|
||||||
|
|
||||||
ret = player_get_current_pos(&pos, &ts, 0);
|
|
||||||
if (ret < 0)
|
|
||||||
{
|
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Could not get current stream position for local audio start\n");
|
|
||||||
|
|
||||||
laudio_close();
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = laudio_start(pos, last_rtptime + AIRTUNES_V2_PACKET_SAMPLES);
|
|
||||||
if (ret < 0)
|
|
||||||
{
|
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Local playback failed to start\n");
|
|
||||||
|
|
||||||
laudio_close();
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (player_state == PLAY_PLAYING)
|
DPRINTF(E_DBG, L_PLAYER, "Probing %s device '%s'\n", device->type_name, device->name);
|
||||||
|
|
||||||
|
ret = outputs_device_probe(device, device_probe_cb);
|
||||||
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
DPRINTF(E_DBG, L_PLAYER, "Activating %s device '%s'\n", device->type_name, device->name);
|
DPRINTF(E_LOG, L_PLAYER, "Could not probe %s device '%s'\n", device->type_name, device->name);
|
||||||
|
return -1;
|
||||||
ret = outputs_device_start(device, device_activate_cb, last_rtptime + AIRTUNES_V2_PACKET_SAMPLES);
|
|
||||||
if (ret < 0)
|
|
||||||
{
|
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Could not start %s device '%s'\n", device->type_name, device->name);
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
DPRINTF(E_DBG, L_PLAYER, "Probing %s device '%s'\n", device->type_name, device->name);
|
|
||||||
|
|
||||||
ret = outputs_device_probe(device, device_probe_cb);
|
|
||||||
if (ret < 0)
|
|
||||||
{
|
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Could not probe %s device '%s'\n", device->type_name, device->name);
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return -1;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
speaker_deactivate(struct output_device *device)
|
speaker_deactivate(struct output_device *device)
|
||||||
{
|
{
|
||||||
if (!device)
|
DPRINTF(E_DBG, L_PLAYER, "Deactivating %s device '%s'\n", device->type_name, device->name);
|
||||||
{
|
|
||||||
/* Local */
|
|
||||||
DPRINTF(E_DBG, L_PLAYER, "Deactivating local audio\n");
|
|
||||||
|
|
||||||
if (laudio_status == LAUDIO_CLOSED)
|
outputs_status_cb(device->session, device_shutdown_cb);
|
||||||
return 0;
|
outputs_device_stop(device->session);
|
||||||
|
|
||||||
if (laudio_status & LAUDIO_F_STARTED)
|
return 0;
|
||||||
laudio_stop();
|
|
||||||
|
|
||||||
laudio_close();
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
DPRINTF(E_DBG, L_PLAYER, "Deactivating %s device '%s'\n", device->type_name, device->name);
|
|
||||||
|
|
||||||
outputs_status_cb(device->session, device_shutdown_cb);
|
|
||||||
outputs_device_stop(device->session);
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
@ -3037,8 +2810,7 @@ speaker_set(struct player_command *cmd)
|
|||||||
cmd->ret = -1;
|
cmd->ret = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ret = 1 if RAOP needs to take action */
|
cmd->output_requests_pending += 1;
|
||||||
cmd->output_requests_pending += ret;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -3059,56 +2831,7 @@ speaker_set(struct player_command *cmd)
|
|||||||
cmd->ret = -1;
|
cmd->ret = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ret = 1 if RAOP needs to take action */
|
cmd->output_requests_pending += 1;
|
||||||
cmd->output_requests_pending += ret;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Local audio */
|
|
||||||
for (i = 1; i <= nspk; i++)
|
|
||||||
{
|
|
||||||
if (ids[i] == 0)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (i <= nspk)
|
|
||||||
{
|
|
||||||
DPRINTF(E_DBG, L_PLAYER, "Local audio selected\n");
|
|
||||||
|
|
||||||
if (!laudio_selected)
|
|
||||||
speaker_select_laudio();
|
|
||||||
|
|
||||||
if (!(laudio_status & LAUDIO_F_STARTED))
|
|
||||||
{
|
|
||||||
ret = speaker_activate(NULL);
|
|
||||||
if (ret < 0)
|
|
||||||
{
|
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Could not activate local audio output\n");
|
|
||||||
|
|
||||||
speaker_deselect_laudio();
|
|
||||||
|
|
||||||
if (cmd->ret != -2)
|
|
||||||
cmd->ret = -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
DPRINTF(E_DBG, L_PLAYER, "Local audio NOT selected\n");
|
|
||||||
|
|
||||||
if (laudio_selected)
|
|
||||||
speaker_deselect_laudio();
|
|
||||||
|
|
||||||
if (laudio_status != LAUDIO_CLOSED)
|
|
||||||
{
|
|
||||||
ret = speaker_deactivate(NULL);
|
|
||||||
if (ret < 0)
|
|
||||||
{
|
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Could not deactivate local audio output\n");
|
|
||||||
|
|
||||||
if (cmd->ret != -2)
|
|
||||||
cmd->ret = -1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3134,16 +2857,6 @@ volume_set(struct player_command *cmd)
|
|||||||
|
|
||||||
master_volume = volume;
|
master_volume = volume;
|
||||||
|
|
||||||
if (laudio_selected)
|
|
||||||
{
|
|
||||||
laudio_volume = rel_to_vol(laudio_relvol);
|
|
||||||
laudio_set_volume(laudio_volume);
|
|
||||||
|
|
||||||
#ifdef DEBUG_RELVOL
|
|
||||||
DPRINTF(E_DBG, L_PLAYER, "*** laudio: abs %d rel %d\n", laudio_volume, laudio_relvol);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
cmd->output_requests_pending = 0;
|
cmd->output_requests_pending = 0;
|
||||||
|
|
||||||
for (device = dev_list; device; device = device->next)
|
for (device = dev_list; device; device = device->next)
|
||||||
@ -3179,38 +2892,25 @@ volume_setrel_speaker(struct player_command *cmd)
|
|||||||
id = cmd->arg.vol_param.spk_id;
|
id = cmd->arg.vol_param.spk_id;
|
||||||
relvol = cmd->arg.vol_param.volume;
|
relvol = cmd->arg.vol_param.volume;
|
||||||
|
|
||||||
if (id == 0)
|
for (device = dev_list; device; device = device->next)
|
||||||
{
|
{
|
||||||
laudio_relvol = relvol;
|
if (device->id != id)
|
||||||
laudio_volume = rel_to_vol(relvol);
|
continue;
|
||||||
laudio_set_volume(laudio_volume);
|
|
||||||
|
if (!device->selected)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
device->relvol = relvol;
|
||||||
|
device->volume = rel_to_vol(relvol);
|
||||||
|
|
||||||
#ifdef DEBUG_RELVOL
|
#ifdef DEBUG_RELVOL
|
||||||
DPRINTF(E_DBG, L_PLAYER, "*** laudio: abs %d rel %d\n", laudio_volume, laudio_relvol);
|
DPRINTF(E_DBG, L_PLAYER, "*** %s: abs %d rel %d\n", device->name, device->volume, device->relvol);
|
||||||
#endif
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
for (device = dev_list; device; device = device->next)
|
|
||||||
{
|
|
||||||
if (device->id != id)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (!device->selected)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
device->relvol = relvol;
|
|
||||||
device->volume = rel_to_vol(relvol);
|
|
||||||
|
|
||||||
#ifdef DEBUG_RELVOL
|
|
||||||
DPRINTF(E_DBG, L_PLAYER, "*** %s: abs %d rel %d\n", device->name, device->volume, device->relvol);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (device->session)
|
if (device->session)
|
||||||
cmd->output_requests_pending = outputs_device_volume_set(device, device_command_cb);
|
cmd->output_requests_pending = outputs_device_volume_set(device, device_command_cb);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
listener_notify(LISTENER_VOLUME);
|
listener_notify(LISTENER_VOLUME);
|
||||||
@ -3233,19 +2933,6 @@ volume_setabs_speaker(struct player_command *cmd)
|
|||||||
|
|
||||||
master_volume = volume;
|
master_volume = volume;
|
||||||
|
|
||||||
if (id == 0)
|
|
||||||
{
|
|
||||||
laudio_relvol = 100;
|
|
||||||
laudio_volume = volume;
|
|
||||||
laudio_set_volume(laudio_volume);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
laudio_relvol = vol_to_rel(laudio_volume);
|
|
||||||
|
|
||||||
#ifdef DEBUG_RELVOL
|
|
||||||
DPRINTF(E_DBG, L_PLAYER, "*** laudio: abs %d rel %d\n", laudio_volume, laudio_relvol);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
for (device = dev_list; device; device = device->next)
|
for (device = dev_list; device; device = device->next)
|
||||||
{
|
{
|
||||||
if (!device->selected)
|
if (!device->selected)
|
||||||
@ -4544,10 +4231,6 @@ player(void *arg)
|
|||||||
/* Save selected devices */
|
/* Save selected devices */
|
||||||
db_speaker_clear_all();
|
db_speaker_clear_all();
|
||||||
|
|
||||||
ret = db_speaker_save(0, laudio_selected, laudio_volume, "Local audio");
|
|
||||||
if (ret < 0)
|
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Could not save state for local audio\n");
|
|
||||||
|
|
||||||
for (device = dev_list; device; device = device->next)
|
for (device = dev_list; device; device = device->next)
|
||||||
{
|
{
|
||||||
ret = db_speaker_save(device->id, device->selected, device->volume, device->name);
|
ret = db_speaker_save(device->id, device->selected, device->volume, device->name);
|
||||||
@ -4586,8 +4269,6 @@ player_init(void)
|
|||||||
|
|
||||||
master_volume = -1;
|
master_volume = -1;
|
||||||
|
|
||||||
laudio_selected = 0;
|
|
||||||
laudio_status = LAUDIO_CLOSED;
|
|
||||||
output_sessions = 0;
|
output_sessions = 0;
|
||||||
|
|
||||||
cur_cmd = NULL;
|
cur_cmd = NULL;
|
||||||
@ -4646,12 +4327,6 @@ player_init(void)
|
|||||||
gcry_randomize(&rnd, sizeof(rnd), GCRY_STRONG_RANDOM);
|
gcry_randomize(&rnd, sizeof(rnd), GCRY_STRONG_RANDOM);
|
||||||
last_rtptime = ((uint64_t)1 << 32) | rnd;
|
last_rtptime = ((uint64_t)1 << 32) | rnd;
|
||||||
|
|
||||||
ret = db_speaker_get(0, &laudio_selected, &laudio_volume);
|
|
||||||
if (ret < 0)
|
|
||||||
laudio_volume = PLAYER_DEFAULT_VOLUME;
|
|
||||||
else if (laudio_selected)
|
|
||||||
speaker_select_laudio(); // Run the select helper
|
|
||||||
|
|
||||||
audio_buf = evbuffer_new();
|
audio_buf = evbuffer_new();
|
||||||
if (!audio_buf)
|
if (!audio_buf)
|
||||||
{
|
{
|
||||||
@ -4721,13 +4396,6 @@ player_init(void)
|
|||||||
event_add(cmdev, NULL);
|
event_add(cmdev, NULL);
|
||||||
event_add(pb_timer_ev, NULL);
|
event_add(pb_timer_ev, NULL);
|
||||||
|
|
||||||
ret = laudio_init(player_laudio_status_cb);
|
|
||||||
if (ret < 0)
|
|
||||||
{
|
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Local audio init failed\n");
|
|
||||||
goto laudio_fail;
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = outputs_init();
|
ret = outputs_init();
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
@ -4753,8 +4421,6 @@ player_init(void)
|
|||||||
thread_fail:
|
thread_fail:
|
||||||
outputs_deinit();
|
outputs_deinit();
|
||||||
outputs_fail:
|
outputs_fail:
|
||||||
laudio_deinit();
|
|
||||||
laudio_fail:
|
|
||||||
evnew_fail:
|
evnew_fail:
|
||||||
event_base_free(evbase_player);
|
event_base_free(evbase_player);
|
||||||
evbase_fail:
|
evbase_fail:
|
||||||
@ -4810,7 +4476,6 @@ player_deinit(void)
|
|||||||
|
|
||||||
evbuffer_free(audio_buf);
|
evbuffer_free(audio_buf);
|
||||||
|
|
||||||
laudio_deinit();
|
|
||||||
outputs_deinit();
|
outputs_deinit();
|
||||||
|
|
||||||
close(exit_pipe[0]);
|
close(exit_pipe[0]);
|
||||||
|
Loading…
Reference in New Issue
Block a user