mm_resource_manager_res_h res, void *user_data);
static void __mmradio_msg_thread(mm_radio_t *radio);
static void __mmradio_msg_push(mm_radio_t *radio, MMRadioMsgTypes msg_type, int msg_data);
-
+static void __mmradio_close_radio_device(mm_radio_t *radio);
typedef void (*thread_function)(mm_radio_t *);
thread_function __mmradio_thread_function[] = {
&__mmradio_msg_thread,
if (ret != MM_RESOURCE_MANAGER_ERROR_NONE)
MMRADIO_LOG_ERROR("resource manager commit fail");
}
-
radio->is_ready = false;
}
{
int ret = MM_ERROR_NONE;
int prev_freq = 0;
-
MMRadioThread_t *p_thread = NULL;
MMRADIO_LOG_FENTER();
MMRADIO_SET_STATE(radio, MM_RADIO_STATE_PLAYING);
} else {
/* close radio device here !!!! */
- if (radio->is_ready) {
- ret = radio_hal_close(radio->hal_inf);
- if (ret)
- __convert_error_code(ret, (char *)__FUNCTION__);
-
- ret = radio_hal_unprepare(radio->hal_inf);
- if (ret)
- __convert_error_code(ret, (char *)__FUNCTION__);
-
- if (!radio->interrupted_by_resource_conflict && /* is being released */
- radio->radio_resource != NULL) {
- ret = mm_resource_manager_mark_for_release(radio->resource_manager,
- radio->radio_resource);
- radio->radio_resource = NULL;
- if (ret != MM_RESOURCE_MANAGER_ERROR_NONE)
- MMRADIO_LOG_ERROR("failed to mark resource for release, ret(0x%x)", ret);
- }
-
- ret = mm_resource_manager_commit(radio->resource_manager);
- if (ret != MM_RESOURCE_MANAGER_ERROR_NONE)
- MMRADIO_LOG_ERROR("resource manager commit fail");
- radio->is_ready = false;
- }
+ __mmradio_close_radio_device(radio);
MMRADIO_SET_STATE(radio, MM_RADIO_STATE_READY);
}
}
EXIT:
+ /* close radio device here !!!! */
+ __mmradio_close_radio_device(radio);
+
p_thread->is_running = false;
MMRADIO_THREAD_UNLOCK(p_thread);
{
mm_radio_msg_t *msg = NULL;
+ mm_radio_msg_t *msg_pop = NULL;
MMRadioThread_t *p_thread = NULL;
MMRADIO_LOG_FENTER();
switch (msg->msg_type) {
case MM_RADIO_MSG_DESTROY:
MMRADIO_LOG_INFO("get destroy msg. pop all event to finish this thread");
- mm_radio_msg_t *msg_pop = NULL;
while ((msg_pop = (mm_radio_msg_t *)g_async_queue_try_pop(radio->msg_queue))) {
if (msg_pop != NULL) {
MMRADIO_LOG_DEBUG("drop this msg type: %d", msg_pop->msg_type);
MMRADIO_LOG_FLEAVE();
pthread_exit(NULL);
}
+
+static void __mmradio_close_radio_device(mm_radio_t *radio)
+{
+ int ret = MM_ERROR_NONE;
+
+ MMRADIO_LOG_FENTER();
+ MMRADIO_CHECK_INSTANCE_RETURN_VOID(radio);
+
+ if (!radio->is_ready) {
+ MMRADIO_LOG_DEBUG("radio device is already closed");
+ return;
+ }
+
+ ret = radio_hal_close(radio->hal_inf);
+ if (ret)
+ __convert_error_code(ret, (char *)__FUNCTION__);
+
+ ret = radio_hal_unprepare(radio->hal_inf);
+ if (ret)
+ __convert_error_code(ret, (char *)__FUNCTION__);
+
+ if (!radio->interrupted_by_resource_conflict && /* is being released */
+ radio->radio_resource != NULL) {
+ ret = mm_resource_manager_mark_for_release(radio->resource_manager,
+ radio->radio_resource);
+ radio->radio_resource = NULL;
+ if (ret != MM_RESOURCE_MANAGER_ERROR_NONE)
+ MMRADIO_LOG_ERROR("failed to mark resource for release, ret(0x%x)", ret);
+ }
+
+ ret = mm_resource_manager_commit(radio->resource_manager);
+ if (ret != MM_RESOURCE_MANAGER_ERROR_NONE)
+ MMRADIO_LOG_ERROR("resource manager commit fail");
+
+ radio->is_ready = false;
+
+}
\ No newline at end of file