Merge "hal: Resolves rewound and restart issue during SSR/PDR."

This commit is contained in:
Linux Build Service Account 2019-03-04 01:16:58 -08:00 committed by Gerrit - the friendly Code Review server
commit dd4dfb6d04
2 changed files with 15 additions and 1 deletions

View File

@ -3848,6 +3848,12 @@ static int out_on_error(struct audio_stream *stream)
if (out->flags & AUDIO_OUTPUT_FLAG_COMPRESS_OFFLOAD) {
send_offload_cmd_l(out, OFFLOAD_CMD_ERROR);
}
if (is_offload_usecase(out->usecase) && out->card_status == CARD_STATUS_OFFLINE) {
ALOGD("Setting previous card status if offline");
out->prev_card_status_offline = true;
}
pthread_mutex_unlock(&out->lock);
return status;
@ -5143,6 +5149,9 @@ static int out_get_render_position(const struct audio_stream_out *stream,
*/
ALOGE(" ERROR: sound card not active, return error");
ret = -EINVAL;
} else if (out->prev_card_status_offline) {
ALOGE("ERROR: previously sound card was offline,return error");
ret = -EINVAL;
} else {
ret = 0;
adjust_frames_for_device_delay(out, dsp_frames);
@ -5245,7 +5254,10 @@ static int out_get_presentation_position(const struct audio_stream_out *stream,
} else if (out->card_status == CARD_STATUS_OFFLINE) {
*frames = out->written;
clock_gettime(CLOCK_MONOTONIC, timestamp);
ret = 0;
if (is_offload_usecase(out->usecase))
ret = -EINVAL;
else
ret = 0;
}
}
pthread_mutex_unlock(&out->lock);
@ -6380,6 +6392,7 @@ int adev_open_output_stream(struct audio_hw_device *dev,
out->hal_output_suspend_supported = 0;
out->dynamic_pm_qos_config_supported = 0;
out->set_dual_mono = false;
out->prev_card_status_offline = false;
if ((flags & AUDIO_OUTPUT_FLAG_BD) &&
(property_get_bool("vendor.audio.matrix.limiter.enable", false)))

View File

@ -371,6 +371,7 @@ struct stream_out {
mix_matrix_params_t pan_scale_params;
mix_matrix_params_t downmix_params;
bool set_dual_mono;
bool prev_card_status_offline;
error_log_t *error_log;
};