3 * modules/parser/msg_parser.c
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
19 * Copyright (C) Samsung Electronics, 2013
21 * 2013 Vyacheslav Cherkashin, Vitaliy Cherepanov: SWAP Parser implement
26 #include <linux/slab.h>
27 #include "msg_parser.h"
29 #include "parser_defs.h"
32 static int str_to_u32(const char* str, u32 *val)
38 for (result = 0 ; *str; ++str) {
39 if (*str < '0' || *str> '9')
42 result = result * 10 + (*str - '0');
54 /* ============================================================================
56 * ============================================================================
58 struct app_info_data *create_app_info(struct msg_buf *mb)
61 struct app_info_data *ai;
63 char *ta_id, *exec_path;
65 print_parse_debug("app_info:\n");
67 print_parse_debug("type:");
68 ret = get_u32(mb, &app_type);
70 print_err("failed to read target application type\n");
74 print_parse_debug("id:");
75 ret = get_string(mb, &ta_id);
77 print_err("failed to read target application ID\n");
81 print_parse_debug("exec path:");
82 ret = get_string(mb, &exec_path);
84 print_err("failed to read executable path\n");
88 ai = kmalloc(sizeof(*ai), GFP_KERNEL);
90 print_err("out of memory\n");
95 case AT_TIZEN_NATIVE_APP:
101 ret = str_to_u32(ta_id, &tgid);
103 print_err("converting string to PID, str='%s'\n", ta_id);
111 print_err("wrong application type(%u)\n", app_type);
116 ai->app_type = (enum APP_TYPE)app_type;
117 ai->exec_path = exec_path;
127 put_string(exec_path);
135 void destroy_app_info(struct app_info_data *ai)
137 put_string(ai->exec_path);
145 /* ============================================================================
147 * ============================================================================
149 struct conf_data *create_conf_data(struct msg_buf *mb)
151 struct conf_data *conf;
152 u64 use_features0, use_features1;
155 print_parse_debug("conf_data:\n");
157 print_parse_debug("features:");
158 if (get_u64(mb, &use_features0)) {
159 print_err("failed to read use_features\n");
163 if (get_u64(mb, &use_features1)) {
164 print_err("failed to read use_features\n");
168 print_parse_debug("sys trace period:");
169 if (get_u32(mb, &stp)) {
170 print_err("failed to read sys trace period\n");
174 print_parse_debug("data msg period:");
175 if (get_u32(mb, &dmp)) {
176 print_err("failed to read data message period\n");
180 conf = kmalloc(sizeof(*conf), GFP_KERNEL);
182 print_err("out of memory\n");
186 conf->use_features0 = use_features0;
187 conf->use_features1 = use_features1;
188 conf->sys_trace_period = stp;
189 conf->data_msg_period = dmp;
194 void destroy_conf_data(struct conf_data *conf)
199 static struct conf_data config;
200 void save_config(const struct conf_data *conf)
202 memcpy(&config, conf, sizeof(config));
205 void restore_config(struct conf_data *conf)
207 memcpy(conf, &config, sizeof(*conf));
212 /* ============================================================================
214 * ============================================================================
216 struct func_inst_data *create_func_inst_data(struct msg_buf *mb)
218 struct func_inst_data *fi;
223 print_parse_debug("func addr:");
224 if (get_u64(mb, &addr)) {
225 print_err("failed to read data function address\n");
229 print_parse_debug("funct args:");
230 if (get_string(mb, &args)) {
231 print_err("failed to read data function arguments\n");
235 print_parse_debug("funct ret type:");
236 if (get_u8(mb, (u8 *)&ret_type)) {
237 print_err("failed to read data function arguments\n");
241 fi = kmalloc(sizeof(*fi), GFP_KERNEL);
243 print_err("out of memory\n");
249 fi->ret_type = ret_type;
258 void destroy_func_inst_data(struct func_inst_data *fi)
260 put_string(fi->args);
268 /* ============================================================================
270 * ============================================================================
272 struct lib_inst_data *create_lib_inst_data(struct msg_buf *mb)
274 struct lib_inst_data *li;
275 struct func_inst_data *fi;
279 print_parse_debug("bin path:");
280 if (get_string(mb, &path)) {
281 print_err("failed to read path of binary\n");
285 print_parse_debug("func count:");
286 if (get_u32(mb, &cnt)) {
287 print_err("failed to read count of functions\n");
291 if (remained_mb(mb) / MIN_SIZE_FUNC_INST < cnt) {
292 print_err("to match count of functions(%u)\n", cnt);
296 li = kmalloc(sizeof(*li), GFP_KERNEL);
299 print_err("out of memory\n");
303 li->func = kmalloc(sizeof(struct func_inst_data *) * cnt, GFP_KERNEL);
304 if (li->func == NULL)
305 if (li->func == NULL) {
306 print_err("out of memory\n");
310 for (i = 0; i < cnt; ++i) {
311 print_parse_debug("func #%d:\n", i + 1);
312 fi = create_func_inst_data(mb);
325 for (j = 0; j < i; ++j)
326 destroy_func_inst_data(li->func[j]);
338 void destroy_lib_inst_data(struct lib_inst_data *li)
342 put_string(li->path);
344 for (i = 0; i < li->cnt_func; ++i)
345 destroy_func_inst_data(li->func[i]);
355 /* ============================================================================
357 * ============================================================================
359 struct app_inst_data *create_app_inst_data(struct msg_buf *mb)
361 struct app_inst_data *app_inst;
362 struct app_info_data *app_info;
363 struct func_inst_data *func;
364 struct lib_inst_data *lib;
365 u32 cnt_func, i_func = 0, cnt_lib, i_lib = 0, i;
367 app_info = create_app_info(mb);
368 if (app_info == NULL)
371 print_parse_debug("func count:");
372 if (get_u32(mb, &cnt_func)) {
373 print_err("failed to read count of functions\n");
377 if (remained_mb(mb) / MIN_SIZE_FUNC_INST < cnt_func) {
378 print_err("to match count of functions(%u)\n", cnt_func);
382 app_inst = kmalloc(sizeof(*app_inst), GFP_KERNEL);
383 if (app_inst == NULL) {
384 print_err("out of memory\n");
388 app_inst->func = kmalloc(sizeof(struct func_inst_data *) * cnt_func,
390 if (app_inst->func == NULL) {
391 print_err("out of memory\n");
395 for (i_func = 0; i_func < cnt_func; ++i_func) {
396 print_parse_debug("func #%d:\n", i_func + 1);
397 func = create_func_inst_data(mb);
401 app_inst->func[i_func] = func;
404 print_parse_debug("lib count:");
405 if (get_u32(mb, &cnt_lib)) {
406 print_err("failed to read count of libraries\n");
410 if (remained_mb(mb) / MIN_SIZE_LIB_INST < cnt_lib) {
411 print_err("to match count of libraries(%u)\n", cnt_lib);
415 app_inst->lib = kmalloc(sizeof(struct lib_inst_data *) * cnt_lib,
417 if (app_inst->lib == NULL) {
418 print_err("out of memory\n");
422 for (i_lib = 0; i_lib < cnt_lib; ++i_lib) {
423 print_parse_debug("lib #%d:\n", i_lib + 1);
424 lib = create_lib_inst_data(mb);
428 app_inst->lib[i_lib] = lib;
431 app_inst->app_info = app_info;
432 app_inst->cnt_func = cnt_func;
433 app_inst->cnt_lib = cnt_lib;
438 for (i = 0; i < i_lib; ++i)
439 destroy_lib_inst_data(app_inst->lib[i]);
440 kfree(app_inst->lib);
443 for (i = 0; i < i_func; ++i)
444 destroy_func_inst_data(app_inst->func[i]);
445 kfree(app_inst->func);
451 destroy_app_info(app_info);
456 void destroy_app_inst_data(struct app_inst_data *ai)
460 for (i = 0; i < ai->cnt_lib; ++i)
461 destroy_lib_inst_data(ai->lib[i]);
464 for (i = 0; i < ai->cnt_func; ++i)
465 destroy_func_inst_data(ai->func[i]);
468 destroy_app_info(ai->app_info);
476 /* ============================================================================
478 * ============================================================================
480 struct us_inst_data *create_us_inst_data(struct msg_buf *mb)
482 struct us_inst_data *ui;
483 struct app_inst_data *ai;
486 print_parse_debug("us_inst_data:\n");
488 print_parse_debug("app count:");
489 if (get_u32(mb, &cnt)) {
490 print_err("failed to read count of applications\n");
494 if (remained_mb(mb) / MIN_SIZE_APP_INST < cnt) {
495 print_err("to match count of applications(%u)\n", cnt);
499 ui = kmalloc(sizeof(struct us_inst_data), GFP_KERNEL);
501 print_err("out of memory\n");
505 ui->app_inst = kmalloc(sizeof(struct app_inst_data *) * cnt,
507 if (ui->app_inst == NULL) {
508 print_err("out of memory\n");
512 for (i = 0; i < cnt; ++i) {
513 print_parse_debug("app #%d:\n",i+1);
514 ai = create_app_inst_data(mb);
518 ui->app_inst[i] = ai;
526 for (j = 0; j < i; ++j)
527 destroy_app_inst_data(ui->app_inst[j]);
536 void destroy_us_inst_data(struct us_inst_data *ui)
540 for (i = 0; i < ui->cnt; ++i)
541 destroy_app_inst_data(ui->app_inst[i]);