4 * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
6 * Contact: JongHyuk Choi <jhchoi.choi@samsung.com>, YeJin Cho <cho.yejin@samsung.com>,
7 * Seungbae Shin <seungbae.shin@samsung.com>, YoungHwan An <younghwan_.an@samsung.com>
9 * Licensed under the Apache License, Version 2.0 (the "License");
10 * you may not use this file except in compliance with the License.
11 * You may obtain a copy of the License at
13 * http://www.apache.org/licenses/LICENSE-2.0
15 * Unless required by applicable law or agreed to in writing, software
16 * distributed under the License is distributed on an "AS IS" BASIS,
17 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18 * See the License for the specific language governing permissions and
19 * limitations under the License.
23 #ifndef __MM_PLAYER_INI_C__
24 #define __MM_PLAYER_INI_C__
30 #include "iniparser.h"
31 #include <mm_player_ini.h>
33 #include <mm_player_utils.h>
34 #include <glib/gstdio.h>
36 /* internal functions, macros here */
37 #ifdef MM_PLAYER_DEFAULT_INI
38 static gboolean __generate_default_ini(void);
40 static void __get_element_list(mmplayer_ini_t *ini, gchar *str, int keyword_type);
42 static void __mm_player_ini_check_ini_status(void);
45 #define MMPLAYER_INI_GET_STRING(x_dict, x_item, x_ini, x_default) \
47 gchar *str = iniparser_getstring(x_dict, x_ini, x_default); \
49 (strlen(str) > 0) && \
50 (strlen(str) < PLAYER_INI_MAX_STRLEN)) \
51 strncpy(x_item, str, PLAYER_INI_MAX_STRLEN-1); \
53 strncpy(x_item, x_default, PLAYER_INI_MAX_STRLEN-1); \
56 #define MMPLAYER_INI_GET_COLOR(x_dict, x_item, x_ini, x_default) \
58 gchar *str = iniparser_getstring(x_dict, x_ini, x_default); \
60 (strlen(str) > 0) && \
61 (strlen(str) < PLAYER_INI_MAX_STRLEN)) \
62 x_item = (guint) strtoul(str, NULL, 16); \
64 x_item = (guint) strtoul(x_default, NULL, 16); \
67 /* x_ini is the list of index to set TRUE at x_list[index] */
68 #define MMPLAYER_INI_GET_BOOLEAN_FROM_LIST(x_dict, x_list, x_list_max, x_ini, x_default) \
71 const char *delimiters = " ,"; \
72 char *usr_ptr = NULL; \
74 gchar temp_arr[PLAYER_INI_MAX_STRLEN] = {0}; \
75 MMPLAYER_INI_GET_STRING(x_dict, temp_arr, x_ini, x_default); \
76 token = strtok_r(temp_arr, delimiters, &usr_ptr); \
78 index = atoi(token); \
79 if (index < 0 || index > x_list_max -1) \
80 LOGW("%d is not valid index", index); \
82 x_list[index] = TRUE; \
83 token = strtok_r(NULL, delimiters, &usr_ptr); \
87 /* x_ini is the list of value to be set at x_list[index] */
88 #define MMPLAYER_INI_GET_INT_FROM_LIST(x_dict, x_list, x_list_max, x_ini, x_default) \
92 const char *delimiters = " ,"; \
93 char *usr_ptr = NULL; \
95 gchar temp_arr[PLAYER_INI_MAX_STRLEN] = {0, }; \
96 MMPLAYER_INI_GET_STRING(x_dict, temp_arr, x_ini, x_default); \
97 token = strtok_r(temp_arr, delimiters, &usr_ptr); \
99 if (index > x_list_max -1) { \
100 LOGE("%d is not valid index", index); \
103 value = atoi(token); \
104 x_list[index] = value; \
107 token = strtok_r(NULL, delimiters, &usr_ptr); \
112 mm_player_ini_load(mmplayer_ini_t *ini)
114 dictionary *dict = NULL;
117 __mm_player_ini_check_ini_status();
119 /* first, try to load existing ini file */
120 dict = iniparser_load(MM_PLAYER_INI_DEFAULT_PATH);
122 /* if no file exists. create one with set of default values */
124 #ifdef MM_PLAYER_DEFAULT_INI
125 LOGD("No inifile found. player will create default inifile.");
126 if (__generate_default_ini() == FALSE)
127 LOGW("Creating default inifile failed. Player will use default values.");
129 dict = iniparser_load(MM_PLAYER_INI_DEFAULT_PATH); /* load default ini */
131 LOGD("No ini file found. ");
132 return MM_ERROR_FILE_NOT_FOUND;
137 memset(ini, 0, sizeof(mmplayer_ini_t));
140 /* if dict is available */
142 ini->disable_segtrap = iniparser_getboolean(dict, "general:disable segtrap", DEFAULT_DISABLE_SEGTRAP);
143 ini->skip_rescan = iniparser_getboolean(dict, "general:skip rescan", DEFAULT_SKIP_RESCAN);
144 ini->generate_dot = iniparser_getboolean(dict, "general:generate dot", DEFAULT_GENERATE_DOT);
145 ini->use_system_clock = iniparser_getboolean(dict, "general:use system clock", DEFAULT_USE_SYSTEM_CLOCK);
146 ini->live_state_change_timeout = iniparser_getint(dict, "general:live state change timeout", DEFAULT_LIVE_STATE_CHANGE_TIMEOUT);
147 ini->localplayback_state_change_timeout = iniparser_getint(dict, "general:localplayback state change timeout", DEFAULT_LOCALPLAYBACK_STATE_CHANGE_TIMEOUT);
148 ini->eos_delay = iniparser_getint(dict, "general:eos delay", DEFAULT_EOS_DELAY);
149 ini->async_start = iniparser_getboolean(dict, "general:async start", DEFAULT_ASYNC_START);
150 ini->video_playback_supported = iniparser_getboolean(dict, "general:video playback supported", DEFAULT_VIDEO_PLAYBACK_SUPPORTED);
151 ini->delay_before_repeat = iniparser_getint(dict, "general:delay before repeat", DEFAULT_DELAY_BEFORE_REPEAT);
152 ini->pcm_buffer_size = iniparser_getint(dict, "general:pcm buffer size", DEFAULT_PCM_BUFFER_SIZE);
153 ini->num_of_video_bo = iniparser_getint(dict, "general:video bo max", DEFAULT_NUM_OF_VIDEO_BO);
154 ini->video_bo_timeout = iniparser_getint(dict, "general:video bo timeout", DEFAULT_TIMEOUT_OF_VIDEO_BO);
156 MMPLAYER_INI_GET_STRING(dict, ini->audioresampler_element, "general:audio resampler element", DEFAULT_AUDIORESAMPLER);
157 MMPLAYER_INI_GET_STRING(dict, ini->audiocodec_element_hw, "general:audio codec element hw", DEFAULT_CODEC_HW);
158 MMPLAYER_INI_GET_STRING(dict, ini->audiosink_element, "general:audiosink element", DEFAULT_AUDIOSINK);
159 MMPLAYER_INI_GET_STRING(dict, ini->audio_offload_sink_element, "general:audio offload sink element", DEFAULT_AUDIO_OFFLOAD_SINK);
161 MMPLAYER_INI_GET_STRING(dict, ini->videosink_element_overlay, "general:videosink element overlay", DEFAULT_VIDEOSINK_OVERLAY);
162 MMPLAYER_INI_GET_STRING(dict, ini->videosink_element_fake, "general:videosink element fake", DEFAULT_VIDEOSINK_FAKE);
163 MMPLAYER_INI_GET_STRING(dict, ini->videocodec_element_hw, "general:video codec element hw", DEFAULT_CODEC_HW);
164 MMPLAYER_INI_GET_STRING(dict, ini->videoconverter_element, "general:video converter element", DEFAULT_VIDEO_CONVERTER);
166 __get_element_list(ini,
167 iniparser_getstring(dict, "general:audio codec element sw", DEFAULT_CODEC_SW), KEYWORD_A_SW_CODEC);
169 __get_element_list(ini,
170 iniparser_getstring(dict, "general:video codec element sw", DEFAULT_CODEC_SW), KEYWORD_V_SW_CODEC);
172 __get_element_list(ini,
173 iniparser_getstring(dict, "general:element exclude keyword", DEFAULT_EXCLUDE_KEYWORD), KEYWORD_EXCLUDE);
175 __get_element_list(ini,
176 iniparser_getstring(dict, "general:audio offload device type", DEFAULT_A_OFFLOAD_DEVICE_TYPE), KEYWORD_A_OFFLOAD_DEVICE_TYPE);
178 __get_element_list(ini,
179 iniparser_getstring(dict, "general:audio offload media format", DEFAULT_EMPTY_VALUE), KEYWORD_A_OFFLOAD_MEDIA_FORMAT);
181 __get_element_list(ini,
182 iniparser_getstring(dict, "general:media stream input format", DEFAULT_EMPTY_VALUE), KEYWORD_MEDIA_STREAM_IN_FORMAT);
184 __get_element_list(ini,
185 iniparser_getstring(dict, "general:unsupported codec keyword", DEFAULT_UNSUPPORTED_CODEC_KEYWORD), KEYWORD_UNSUPPORTED_CODEC);
187 MMPLAYER_INI_GET_STRING(dict, ini->gst_param[0], "general:gstparam1", DEFAULT_GST_PARAM);
188 MMPLAYER_INI_GET_STRING(dict, ini->gst_param[1], "general:gstparam2", DEFAULT_GST_PARAM);
189 MMPLAYER_INI_GET_STRING(dict, ini->gst_param[2], "general:gstparam3", DEFAULT_GST_PARAM);
190 MMPLAYER_INI_GET_STRING(dict, ini->gst_param[3], "general:gstparam4", DEFAULT_GST_PARAM);
191 MMPLAYER_INI_GET_STRING(dict, ini->gst_param[4], "general:gstparam5", DEFAULT_GST_PARAM);
194 MMPLAYER_INI_GET_STRING(dict, ini->httpsrc_element, "http streaming:httpsrc element", DEFAULT_HTTPSRC);
195 ini->http_ring_buffer_size = iniparser_getint(dict, "http streaming:http ring buffer size", DEFAULT_HTTP_RING_BUFFER_SIZE);
196 ini->http_timeout = iniparser_getint(dict, "http streaming:http timeout", DEFAULT_HTTP_TIMEOUT);
198 /* dump buffer for debug */
199 __get_element_list(ini,
200 iniparser_getstring(dict, "general:dump element keyword", DEFAULT_EXCLUDE_KEYWORD), KEYWORD_DUMP);
202 MMPLAYER_INI_GET_STRING(dict, ini->dump_element_path, "general:dump element path", DEFAULT_DUMP_ELEMENT_PATH);
204 /* if dict is not available just fill the structure with default value */
205 LOGW("failed to load ini. using hardcoded default");
208 ini->disable_segtrap = DEFAULT_DISABLE_SEGTRAP;
209 ini->skip_rescan = DEFAULT_SKIP_RESCAN;
210 strncpy(ini->videosink_element_overlay, DEFAULT_VIDEOSINK_OVERLAY, PLAYER_INI_MAX_STRLEN - 1);
211 strncpy(ini->videosink_element_fake, DEFAULT_VIDEOSINK_FAKE, PLAYER_INI_MAX_STRLEN - 1);
212 ini->generate_dot = DEFAULT_GENERATE_DOT;
213 ini->use_system_clock = DEFAULT_USE_SYSTEM_CLOCK;
214 ini->live_state_change_timeout = DEFAULT_LIVE_STATE_CHANGE_TIMEOUT;
215 ini->localplayback_state_change_timeout = DEFAULT_LOCALPLAYBACK_STATE_CHANGE_TIMEOUT;
216 ini->eos_delay = DEFAULT_EOS_DELAY;
217 ini->async_start = DEFAULT_ASYNC_START;
218 ini->delay_before_repeat = DEFAULT_DELAY_BEFORE_REPEAT;
219 ini->video_playback_supported = DEFAULT_VIDEO_PLAYBACK_SUPPORTED;
220 ini->pcm_buffer_size = DEFAULT_PCM_BUFFER_SIZE;
221 ini->num_of_video_bo = DEFAULT_NUM_OF_VIDEO_BO;
222 ini->video_bo_timeout = DEFAULT_TIMEOUT_OF_VIDEO_BO;
224 strncpy(ini->audioresampler_element, DEFAULT_AUDIORESAMPLER, PLAYER_INI_MAX_STRLEN - 1);
225 strncpy(ini->audiosink_element, DEFAULT_AUDIOSINK, PLAYER_INI_MAX_STRLEN - 1);
226 strncpy(ini->audio_offload_sink_element, DEFAULT_AUDIO_OFFLOAD_SINK, PLAYER_INI_MAX_STRLEN - 1);
227 strncpy(ini->audiocodec_element_hw, DEFAULT_CODEC_HW, PLAYER_INI_MAX_STRLEN - 1);
228 strncpy(ini->videocodec_element_hw, DEFAULT_CODEC_HW, PLAYER_INI_MAX_STRLEN - 1);
229 strncpy(ini->videoconverter_element, DEFAULT_VIDEO_CONVERTER, PLAYER_INI_MAX_STRLEN - 1);
231 __get_element_list(ini, DEFAULT_CODEC_SW, KEYWORD_A_SW_CODEC);
232 __get_element_list(ini, DEFAULT_CODEC_SW, KEYWORD_V_SW_CODEC);
233 __get_element_list(ini, DEFAULT_A_OFFLOAD_DEVICE_TYPE, KEYWORD_A_OFFLOAD_DEVICE_TYPE);
234 __get_element_list(ini, DEFAULT_EMPTY_VALUE, KEYWORD_A_OFFLOAD_MEDIA_FORMAT);
235 __get_element_list(ini, DEFAULT_EMPTY_VALUE, KEYWORD_MEDIA_STREAM_IN_FORMAT);
236 __get_element_list(ini, DEFAULT_EXCLUDE_KEYWORD, KEYWORD_EXCLUDE);
237 __get_element_list(ini, DEFAULT_UNSUPPORTED_CODEC_KEYWORD, KEYWORD_UNSUPPORTED_CODEC);
239 strncpy(ini->gst_param[0], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1);
240 strncpy(ini->gst_param[1], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1);
241 strncpy(ini->gst_param[2], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1);
242 strncpy(ini->gst_param[3], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1);
243 strncpy(ini->gst_param[4], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1);
246 strncpy(ini->httpsrc_element, DEFAULT_HTTPSRC, PLAYER_INI_MAX_STRLEN - 1);
247 ini->http_ring_buffer_size = DEFAULT_HTTP_RING_BUFFER_SIZE;
248 ini->http_timeout = DEFAULT_HTTP_TIMEOUT;
250 /* dump buffer for debug */
251 __get_element_list(ini, DEFAULT_DUMP_ELEMENT_KEYWORD, KEYWORD_DUMP);
252 strncpy(ini->dump_element_path, DEFAULT_DUMP_ELEMENT_PATH, PLAYER_INI_MAX_STRLEN - 1);
255 /* free dict as we got our own structure */
256 iniparser_freedict(dict);
259 LOGD("player settings -----------------------------------");
262 LOGD("disable segtrap : %d", ini->disable_segtrap);
263 LOGD("skip rescan : %d", ini->skip_rescan);
264 LOGD("videosink element overlay: %s", ini->videosink_element_overlay);
265 LOGD("videosink element fake: %s", ini->videosink_element_fake);
266 LOGD("video converter element : %s", ini->videoconverter_element);
267 LOGD("video codec element(hw) : %s", ini->videocodec_element_hw);
268 for (idx = 0; ini->videocodec_element_sw[idx][0] != '\0'; idx++)
269 LOGD("video codec element(sw%d) %s", idx, ini->videocodec_element_sw[idx]);
270 LOGD("audio codec element(hw) : %s", ini->audiocodec_element_hw);
271 for (idx = 0; ini->audiocodec_element_sw[idx][0] != '\0'; idx++)
272 LOGD("audio codec element(sw%d) %s", idx, ini->audiocodec_element_sw[idx]);
273 LOGD("audio resampler element : %s", ini->audioresampler_element);
274 LOGD("audiosink element : %s", ini->audiosink_element);
275 LOGD("audio offload sink element : %s", ini->audio_offload_sink_element);
276 for (idx = 0; ini->audio_offload_device_type[idx][0] != '\0'; idx++)
277 LOGD("audio_offload_device_type [%d] : %s", idx, ini->audio_offload_device_type[idx]);
278 for (idx = 0; ini->audio_offload_media_format[idx][0] != '\0'; idx++)
279 LOGD("audio_offload_media_format [%d] : %s", idx, ini->audio_offload_media_format[idx]);
280 for (idx = 0; ini->media_stream_input_format[idx][0] != '\0'; idx++)
281 LOGD("media_stream_input_format [%d] : %s", idx, ini->media_stream_input_format[idx]);
282 LOGD("generate dot : %d", ini->generate_dot);
283 LOGD("use system clock(video only) : %d", ini->use_system_clock);
284 LOGD("live state change timeout(sec) : %d", ini->live_state_change_timeout);
285 LOGD("localplayback state change timeout(sec) : %d", ini->localplayback_state_change_timeout);
286 LOGD("eos_delay(msec) : %d", ini->eos_delay);
287 LOGD("delay before repeat(msec) : %d", ini->delay_before_repeat);
288 LOGD("async_start : %d", ini->async_start);
289 LOGD("video_playback_supported : %d", ini->video_playback_supported);
290 LOGD("pcm buffer size(bytes) : %d", ini->pcm_buffer_size);
291 LOGD("num of video bo : %d", ini->num_of_video_bo);
292 LOGD("video bo timeout : %d", ini->video_bo_timeout);
293 LOGD("gst param1 : %s", ini->gst_param[0]);
294 LOGD("gst param2 : %s", ini->gst_param[1]);
295 LOGD("gst param3 : %s", ini->gst_param[2]);
296 LOGD("gst param4 : %s", ini->gst_param[3]);
297 LOGD("gst param5 : %s", ini->gst_param[4]);
299 for (idx = 0; ini->exclude_element_keyword[idx][0] != '\0'; idx++)
300 LOGD("exclude_element_keyword [%d] : %s", idx, ini->exclude_element_keyword[idx]);
302 for (idx = 0; ini->dump_element_keyword[idx][0] != '\0'; idx++)
303 LOGD("dump_element_keyword [%d] : %s", idx, ini->dump_element_keyword[idx]);
305 for (idx = 0; ini->unsupported_codec_keyword[idx][0] != '\0'; idx++)
306 LOGD("unsupported_codec_keyword [%d] : %s", idx, ini->unsupported_codec_keyword[idx]);
309 LOGD("httpsrc element : %s", ini->httpsrc_element);
310 LOGD("http ring buffer size : %d", ini->http_ring_buffer_size);
311 LOGD("http timeout : %d", ini->http_timeout);
313 return MM_ERROR_NONE;
317 mm_player_audio_effect_ini_load(mmplayer_ini_t *ini)
319 dictionary *dict_audioeffect = NULL;
321 dict_audioeffect = iniparser_load(MM_PLAYER_INI_DEFAULT_AUDIOEFFECT_PATH);
322 if (!dict_audioeffect) {
323 LOGE("No audio effect ini file found.");
324 return MM_ERROR_FILE_NOT_FOUND;
327 /* audio effect element name */
328 MMPLAYER_INI_GET_STRING(dict_audioeffect, ini->audioeffect_element, "audio effect:audio effect element", DEFAULT_AUDIO_EFFECT_ELEMENT);
329 if (!ini->audioeffect_element[0]) {
330 LOGW("could not parse name of audio effect.");
331 iniparser_freedict(dict_audioeffect);
332 /* NOTE : in this case, we are not going to create audio filter element */
333 return MM_ERROR_NONE;
336 /* audio effect (Preset)*/
337 ini->use_audio_effect_preset = iniparser_getboolean(dict_audioeffect, "audio effect:audio effect preset", DEFAULT_USE_AUDIO_EFFECT_PRESET);
338 if (ini->use_audio_effect_preset) {
339 MMPLAYER_INI_GET_BOOLEAN_FROM_LIST(dict_audioeffect, ini->audio_effect_preset_list, MM_AUDIO_EFFECT_PRESET_NUM,
340 "audio effect:audio effect preset list", DEFAULT_AUDIO_EFFECT_PRESET_LIST);
341 MMPLAYER_INI_GET_BOOLEAN_FROM_LIST(dict_audioeffect, ini->audio_effect_preset_earphone_only_list, MM_AUDIO_EFFECT_PRESET_NUM,
342 "audio effect:audio effect preset earphone only", DEFAULT_AUDIO_EFFECT_PRESET_LIST_EARPHONE_ONLY);
345 /* audio effect user (EQ / Extension effects) */
346 ini->use_audio_effect_custom = iniparser_getboolean(dict_audioeffect, "audio effect:audio effect custom", DEFAULT_USE_AUDIO_EFFECT_CUSTOM);
347 if (ini->use_audio_effect_custom) {
348 MMPLAYER_INI_GET_BOOLEAN_FROM_LIST(dict_audioeffect, ini->audio_effect_custom_list, MM_AUDIO_EFFECT_CUSTOM_NUM,
349 "audio effect:audio effect custom list", DEFAULT_AUDIO_EFFECT_CUSTOM_LIST);
350 MMPLAYER_INI_GET_BOOLEAN_FROM_LIST(dict_audioeffect, ini->audio_effect_custom_earphone_only_list, MM_AUDIO_EFFECT_CUSTOM_NUM,
351 "audio effect:audio effect custom earphone only", DEFAULT_AUDIO_EFFECT_CUSTOM_LIST_EARPHONE_ONLY);
353 /* audio effect custom : EQ */
354 if (ini->audio_effect_custom_list[MM_AUDIO_EFFECT_CUSTOM_EQ]) {
355 ini->audio_effect_custom_eq_band_num = iniparser_getint(dict_audioeffect, "audio effect:audio effect custom eq band num",
356 DEFAULT_AUDIO_EFFECT_CUSTOM_EQ_BAND_NUM);
357 if (ini->audio_effect_custom_eq_band_num < DEFAULT_AUDIO_EFFECT_CUSTOM_EQ_BAND_NUM ||
358 ini->audio_effect_custom_eq_band_num > MM_AUDIO_EFFECT_EQ_BAND_NUM_MAX) {
359 LOGE("audio_effect_custom_eq_band_num(%d) is not valid range(%d - %d), set the value %d",
360 ini->audio_effect_custom_eq_band_num, DEFAULT_AUDIO_EFFECT_CUSTOM_EQ_BAND_NUM, MM_AUDIO_EFFECT_EQ_BAND_NUM_MAX, DEFAULT_AUDIO_EFFECT_CUSTOM_EQ_BAND_NUM);
361 ini->audio_effect_custom_eq_band_num = DEFAULT_AUDIO_EFFECT_CUSTOM_EQ_BAND_NUM;
363 iniparser_freedict(dict_audioeffect);
364 return MM_ERROR_PLAYER_INTERNAL;
366 if (ini->audio_effect_custom_eq_band_num) {
367 MMPLAYER_INI_GET_INT_FROM_LIST(dict_audioeffect, ini->audio_effect_custom_eq_band_width, MM_AUDIO_EFFECT_EQ_BAND_NUM_MAX,
368 "audio effect:audio effect custom eq band width", DEFAULT_AUDIO_EFFECT_CUSTOM_EQ_BAND_WIDTH);
369 MMPLAYER_INI_GET_INT_FROM_LIST(dict_audioeffect, ini->audio_effect_custom_eq_band_freq, MM_AUDIO_EFFECT_EQ_BAND_NUM_MAX,
370 "audio effect:audio effect custom eq band freq", DEFAULT_AUDIO_EFFECT_CUSTOM_EQ_BAND_FREQ);
375 /* audio effect custom : Extension effects */
376 ini->audio_effect_custom_ext_num = iniparser_getint(dict_audioeffect, "audio effect:audio effect custom ext num",
377 DEFAULT_AUDIO_EFFECT_CUSTOM_EXT_NUM);
379 /* Min/Max value list of EQ / Extension effects */
380 if (ini->audio_effect_custom_eq_band_num || ini->audio_effect_custom_ext_num) {
381 MMPLAYER_INI_GET_INT_FROM_LIST(dict_audioeffect, ini->audio_effect_custom_min_level_list, MM_AUDIO_EFFECT_CUSTOM_NUM,
382 "audio effect:audio effect custom min list", DEFAULT_AUDIO_EFFECT_CUSTOM_LIST);
383 MMPLAYER_INI_GET_INT_FROM_LIST(dict_audioeffect, ini->audio_effect_custom_max_level_list, MM_AUDIO_EFFECT_CUSTOM_NUM,
384 "audio effect:audio effect custom max list", DEFAULT_AUDIO_EFFECT_CUSTOM_LIST);
388 /* audio effect element name */
389 MMPLAYER_INI_GET_STRING(dict_audioeffect, ini->audioeffect_element_custom, "audio effect:audio effect element custom", DEFAULT_AUDIO_EFFECT_ELEMENT);
390 if (!ini->audioeffect_element_custom[0])
391 LOGW("no secondary audio effect");
393 LOGD("audioeffect element custom : %s", ini->audioeffect_element_custom);
396 LOGD("audioeffect element : %s", ini->audioeffect_element);
397 LOGD("audio effect preset mode : %d", ini->use_audio_effect_preset);
398 LOGD("audio effect custom mode : %d", ini->use_audio_effect_custom);
401 for (i = 0; i < MM_AUDIO_EFFECT_PRESET_NUM; i++)
402 LOGD("audio_effect_preset_list: %d (is it for earphone only?(%d))", ini->audio_effect_preset_list[i], ini->audio_effect_preset_earphone_only_list[i]);
404 for (i = 0; i < MM_AUDIO_EFFECT_CUSTOM_NUM; i++)
405 LOGD("audio_effect_custom_list : %d (is it for earphone only?(%d))", ini->audio_effect_custom_list[i], ini->audio_effect_custom_earphone_only_list[i]);
406 LOGD("audio_effect_custom : eq_band_num(%d), ext_num(%d)", ini->audio_effect_custom_eq_band_num, ini->audio_effect_custom_ext_num);
407 LOGD("audio_effect_custom_EQ : width(Hz) / central frequency(Hz)");
408 for (i = 0; i < ini->audio_effect_custom_eq_band_num; i++)
409 LOGD(" EQ band index(%d) : %8d / %8d", i, ini->audio_effect_custom_eq_band_width[i], ini->audio_effect_custom_eq_band_freq[i]);
410 for (i = 0; i < MM_AUDIO_EFFECT_CUSTOM_NUM; i++)
411 LOGD("audio_effect_custom_level_min_max(idx:%d) : Min(%d), Max(%d)", i, ini->audio_effect_custom_min_level_list[i], ini->audio_effect_custom_max_level_list[i]);
413 iniparser_freedict(dict_audioeffect);
415 return MM_ERROR_NONE;
420 __mm_player_ini_check_ini_status(void)
422 struct stat ini_buff;
424 if (g_stat(MM_PLAYER_INI_DEFAULT_PATH, &ini_buff) < 0) {
425 LOGW("failed to get player ini status");
427 if (ini_buff.st_size < 5) {
428 LOGW("player.ini file size=%d, Corrupted!So, Removed", (int)ini_buff.st_size);
430 if (g_remove(MM_PLAYER_INI_DEFAULT_PATH) == -1)
431 LOGE("failed to delete corrupted ini");
436 #ifdef MM_PLAYER_DEFAULT_INI
438 __generate_default_ini(void)
441 gchar *default_ini = MM_PLAYER_DEFAULT_INI;
444 /* create new file */
445 fp = fopen(MM_PLAYER_INI_DEFAULT_PATH, "wt");
449 /* writing default ini file */
450 if (strlen(default_ini) != fwrite(default_ini, 1, strlen(default_ini), fp)) {
461 __get_element_list(mmplayer_ini_t *ini, gchar *str, int keyword_type)
466 gchar *strtmp = NULL;
467 gchar (*ini_keyword)[PLAYER_INI_MAX_STRLEN] = {NULL, };
475 strtmp = g_strdup(str);
477 /* trimming. it works inplace */
481 list = g_strsplit(strtmp, ",", 10);
484 MMPLAYER_FREEIF(strtmp);
489 switch (keyword_type) {
490 case KEYWORD_EXCLUDE:
491 ini_keyword = ini->exclude_element_keyword;
494 ini_keyword = ini->dump_element_keyword;
496 case KEYWORD_UNSUPPORTED_CODEC:
497 ini_keyword = ini->unsupported_codec_keyword;
499 case KEYWORD_V_SW_CODEC:
500 ini_keyword = ini->videocodec_element_sw;
502 case KEYWORD_A_SW_CODEC:
503 ini_keyword = ini->audiocodec_element_sw;
505 case KEYWORD_A_OFFLOAD_DEVICE_TYPE:
506 ini_keyword = ini->audio_offload_device_type;
508 case KEYWORD_A_OFFLOAD_MEDIA_FORMAT:
509 ini_keyword = ini->audio_offload_media_format;
511 case KEYWORD_MEDIA_STREAM_IN_FORMAT:
512 ini_keyword = ini->media_stream_input_format;
519 for (walk = list; *walk && ini_keyword[i]; walk++) {
520 strncpy(ini_keyword[i], *walk, (PLAYER_INI_MAX_STRLEN - 1));
521 g_strstrip(ini_keyword[i]);
522 ini_keyword[i][PLAYER_INI_MAX_STRLEN -1] = '\0';
526 /* mark last item to NULL */
527 if (ini_keyword[i]) {
528 ini_keyword[i][0] = '\0';
530 LOGE("too many keyword exist in list (%d)", i);
532 ini_keyword[i-1][0] = '\0';
537 MMPLAYER_FREEIF(strtmp);