1 /**************************************************************************
5 Copyright (c) 2013 Samsung Electronics Co., Ltd All Rights Reserved
7 Contact: Boram Park <boram1288.park@samsung.com>
8 Sangjin LEE <lsj119@samsung.com>
10 Permission is hereby granted, free of charge, to any person obtaining a
11 copy of this software and associated documentation files (the
12 "Software"), to deal in the Software without restriction, including
13 without limitation the rights to use, copy, modify, merge, publish,
14 distribute, sub license, and/or sell copies of the Software, and to
15 permit persons to whom the Software is furnished to do so, subject to
16 the following conditions:
18 The above copyright notice and this permission notice (including the
19 next paragraph) shall be included in all copies or substantial portions
22 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
23 OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
24 MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
25 IN NO EVENT SHALL PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR
26 ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
27 TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
28 SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
30 **************************************************************************/
38 #include "xdbg_module.h"
39 #include "xdbg_module_command.h"
40 #include "xdbg_module_evlog.h"
42 /* Supported options */
49 OPTION_EVLOG_RULE_PATH,
50 OPTION_XERROR_LOG_PATH,
54 static const OptionInfoRec module_options[] =
56 { OPTION_DLOG, "dlog", OPTV_BOOLEAN, {0}, FALSE },
57 { OPTION_LOG_PATH, "log_path", OPTV_STRING, {0}, FALSE },
58 { OPTION_LOG_LEVEL, "log_level", OPTV_INTEGER, {0}, FALSE },
59 { OPTION_EVLOG_PATH, "evlog_path", OPTV_STRING, {0}, FALSE },
60 { OPTION_EVLOG_RULE_PATH, "evlog_rule_path", OPTV_STRING, {0}, FALSE },
61 { OPTION_XERROR_LOG_PATH, "xerror_log_path", OPTV_STRING, {0}, FALSE },
62 { OPTION_TRACE_CNT, "trace_cnt", OPTV_INTEGER, {0}, FALSE },
63 { -1, NULL, OPTV_NONE, {0}, FALSE }
67 xDbgModuleInitTraceClientOptions (XDbgModule *pMod, XF86OptionPtr pOpt)
73 pMod->trace_options = (ModuleTraceClientOption*) calloc (pMod->trace_cnt, sizeof(ModuleTraceClientOption));
75 for (i = 0 ; i < pMod->trace_cnt ; i++)
77 snprintf (name, sizeof(name), "trace_client%d", i+1);
79 option = xf86SetStrOption (pOpt, name, NULL);
80 XDBG_INFO (MXDBG, "trace_client%d : %s\n", i+1, option);
86 token = strtok_r (option, ":", &tokp);
88 strncpy (pMod->trace_options[i].name, token, strlen(token)+1);
90 XDBG_WARNING (MXDBG, "fail to parse trace client name:%s\n", option);
92 token = strtok_r (NULL, ":", &tokp);
94 strncpy (pMod->trace_options[i].action, token, strlen(token)+1);
96 XDBG_WARNING (MXDBG, "fail to parse trace client action:%s\n", option);
98 token = strtok_r (NULL, ":", &tokp);
100 strncpy (pMod->trace_options[i].cmd, token, strlen(token)+1);
102 XDBG_WARNING (MXDBG, "fail to parse trace client log or cmd:%s\n", option);
110 xDbgModuleParseOptions (XDbgModule *pMod, XF86OptionPtr pOpt)
112 OptionInfoPtr options = xnfalloc (sizeof (module_options));
115 int log_level = XLOG_LEVEL_DEFAULT;
117 memcpy (options, module_options, sizeof(module_options));
119 xf86ProcessOptions (-1, pOpt, options);
122 xf86GetOptValBool (options, OPTION_DLOG, &pMod->dlog);
123 XDBG_INFO (MXDBG, "dlog: \"%s\"\n", (pMod->dlog)?"on":"off");
124 xDbgLogEnableDlog (pMod->dlog);
127 path = xf86GetOptValString (options, OPTION_LOG_PATH);
128 XDBG_INFO (MXDBG, "log path: \"%s\"\n", (path)?path:"none");
131 snprintf (temp, sizeof(temp), "%s", path);
132 xDbgModuleCommandInitLogPath (pMod, temp);
136 xf86GetOptValInteger (options, OPTION_LOG_LEVEL, &log_level);
137 XDBG_INFO (MXDBG, "log default level: %d\n", log_level);
138 xDbgLogSetLevel (XDBG_ALL_MODULE, log_level);
141 path = xf86GetOptValString (options, OPTION_EVLOG_PATH);
142 XDBG_INFO (MXDBG, "evlog path: \"%s\"\n", (path)?path:"none");
145 snprintf (temp, sizeof(temp), "%s", path);
146 xDbgModuleEvlogSetEvlogPath (pMod, -1, temp, NULL, NULL);
149 /* evlog_rule_path */
150 path = xf86GetOptValString (options, OPTION_EVLOG_RULE_PATH);
151 XDBG_INFO (MXDBG, "evlog rule path: \"%s\"\n", (path)?path:"none");
154 snprintf (temp, sizeof(temp), "%s", path);
155 xDbgModuleCommandInitEvlogRulePath (pMod, temp);
158 /* xerror_log_path */
159 path = xf86GetOptValString (options, OPTION_XERROR_LOG_PATH);
162 pMod->xerror_log_path = strdup (path);
163 xDbgModuleEvlogXErrorSetPath (pMod->xerror_log_path);
164 XDBG_INFO (MXDBG, "evlog log path: \"%s\"\n", path);
167 pMod->xerror_log_path = NULL;
169 xf86GetOptValInteger (options, OPTION_TRACE_CNT, &pMod->trace_cnt);
170 XDBG_INFO (MXDBG, "trace_cnt: %d\n", pMod->trace_cnt);
172 xDbgModuleInitTraceClientOptions (pMod, pOpt);