Line data Source code
1 : /**
2 : * Copyright (C) 2013 - 2018 Advanced Driver Information Technology.
3 : * This code is developed by Advanced Driver Information Technology.
4 : * Copyright of Advanced Driver Information Technology, Bosch and DENSO.
5 : *
6 : * DLT offline log storage functionality source file.
7 : *
8 : * \copyright
9 : * This Source Code Form is subject to the terms of the
10 : * Mozilla Public License, v. 2.0. If a copy of the MPL was not distributed with
11 : * this file, You can obtain one at http://mozilla.org/MPL/2.0/.
12 : *
13 : *
14 : * \author Syed Hameed <shameed@jp.adit-jv.com> ADIT 2013 - 2015
15 : * \author Christoph Lipka <clipka@jp.adit-jv.com> ADIT 2015
16 : *
17 : * \file: dlt_daemon_offline_logstorage.c
18 : * For further information see http://www.covesa.org/.
19 : */
20 :
21 : #include <stdio.h>
22 : #include <stdlib.h>
23 : #include <string.h>
24 : #include <syslog.h>
25 :
26 : #include "dlt_daemon_offline_logstorage.h"
27 : #include "dlt_daemon_offline_logstorage_internal.h"
28 : #include "dlt_gateway_types.h"
29 : #include "dlt_gateway.h"
30 :
31 : /**
32 : * dlt_logstorage_split_ecuid
33 : *
34 : * Split keys with ECU ID alone
35 : *
36 : * @param key Key
37 : * @param len Key length
38 : * @param ecuid ECU ID from key stored here
39 : * @param apid Application ID as .* stored here
40 : * @param ctid Context id as .* stored here
41 : * @return 0 on success -1 on error
42 : */
43 0 : DLT_STATIC DltReturnValue dlt_logstorage_split_ecuid(char *key,
44 : int len,
45 : char *ecuid,
46 : char *apid,
47 : char *ctid)
48 : {
49 0 : if ((len > (DLT_ID_SIZE + 2)) || (len < 2))
50 : return DLT_RETURN_ERROR;
51 :
52 0 : memcpy(ecuid, key, (len - 2));
53 : memcpy(apid, ".*", 2);
54 : memcpy(ctid, ".*", 2);
55 :
56 0 : return DLT_RETURN_OK;
57 : }
58 :
59 : unsigned int g_logstorage_cache_max;
60 : /**
61 : * dlt_logstorage_split_ctid
62 : *
63 : * Split keys with Context ID alone
64 : *
65 : * @param key Key
66 : * @param len Key length
67 : * @param apid Application ID as .* stored here
68 : * @param ctid Context id from key stored here
69 : * @return 0 on success -1 on error
70 : */
71 0 : DLT_STATIC DltReturnValue dlt_logstorage_split_ctid(char *key,
72 : int len,
73 : char *apid,
74 : char *ctid)
75 : {
76 0 : if ((len > (DLT_ID_SIZE + 2)) || (len < 1))
77 : return DLT_RETURN_ERROR;
78 :
79 0 : strncpy(ctid, (key + 2), (len - 1));
80 : memcpy(apid, ".*", 2);
81 :
82 0 : return DLT_RETURN_OK;
83 : }
84 :
85 : /**
86 : * dlt_logstorage_split_apid
87 : *
88 : * Split keys with Application ID alone
89 : *
90 : * @param key Key
91 : * @param len Key length
92 : * @param apid Application ID from key is stored here
93 : * @param ctid Context id as .* stored here
94 : * @return 0 on success -1 on error
95 : */
96 1 : DLT_STATIC DltReturnValue dlt_logstorage_split_apid(char *key,
97 : int len,
98 : char *apid,
99 : char *ctid)
100 : {
101 1 : if ((len > (DLT_ID_SIZE + 2)) || (len < 2))
102 : return DLT_RETURN_ERROR;
103 :
104 1 : strncpy(apid, key + 1, (len - 2));
105 : memcpy(ctid, ".*", 2);
106 :
107 1 : return DLT_RETURN_OK;
108 : }
109 :
110 : /**
111 : * dlt_logstorage_split_apid_ctid
112 : *
113 : * Split keys with Application ID and Context ID
114 : *
115 : * @param key Key
116 : * @param len Key length
117 : * @param apid Application ID from key is stored here
118 : * @param ctid CContext id from key is stored here
119 : * @return 0 on success -1 on error
120 : */
121 1 : DLT_STATIC DltReturnValue dlt_logstorage_split_apid_ctid(char *key,
122 : int len,
123 : char *apid,
124 : char *ctid)
125 : {
126 : char *tok = NULL;
127 :
128 1 : if (len > DLT_OFFLINE_LOGSTORAGE_MAX_KEY_LEN)
129 : return DLT_RETURN_ERROR;
130 :
131 : /* copy apid and ctid */
132 1 : tok = strtok(key, ":");
133 :
134 1 : if (tok != NULL)
135 : strncpy(apid, tok, DLT_ID_SIZE);
136 : else
137 : return DLT_RETURN_ERROR;
138 :
139 1 : tok = strtok(NULL, ":");
140 :
141 1 : if (tok != NULL)
142 : strncpy(ctid, tok, DLT_ID_SIZE);
143 : else
144 : return DLT_RETURN_ERROR;
145 :
146 1 : return DLT_RETURN_OK;
147 : }
148 :
149 : /**
150 : * dlt_logstorage_split_ecuid_apid
151 : *
152 : * Split keys with ECU ID and Application ID
153 : *
154 : * @param key Key
155 : * @param len Key length
156 : * @param ecuid ECU ID from key stored here
157 : * @param apid Application ID from key is stored here
158 : * @param ctid Context id as .* stored here
159 : * @return 0 on success -1 on error
160 : */
161 1 : DLT_STATIC DltReturnValue dlt_logstorage_split_ecuid_apid(char *key,
162 : int len,
163 : char *ecuid,
164 : char *apid,
165 : char *ctid)
166 : {
167 : char *tok = NULL;
168 :
169 1 : if (len > DLT_OFFLINE_LOGSTORAGE_MAX_KEY_LEN)
170 : return DLT_RETURN_ERROR;
171 :
172 : /* copy apid and ctid */
173 1 : tok = strtok(key, ":");
174 :
175 1 : if (tok != NULL)
176 : strncpy(ecuid, tok, DLT_ID_SIZE);
177 : else
178 : return DLT_RETURN_ERROR;
179 :
180 1 : tok = strtok(NULL, ":");
181 :
182 1 : if (tok != NULL)
183 : strncpy(apid, tok, DLT_ID_SIZE);
184 : else
185 : return DLT_RETURN_ERROR;
186 :
187 : memcpy(ctid, ".*", 2);
188 :
189 1 : return DLT_RETURN_OK;
190 : }
191 :
192 : /**
193 : * dlt_logstorage_split_multi
194 : *
195 : * Prepares keys with application ID alone, will use ecuid if provided
196 : * (ecuid\:apid\:\:) or (\:apid\:\:)
197 : *
198 : * @param key Prepared key stored here
199 : * @param len Key length
200 : * @param ecuid ECU ID
201 : * @param apid Application ID
202 : * @param ctid Context ID
203 : * @return None
204 : */
205 34 : DLT_STATIC DltReturnValue dlt_logstorage_split_multi(char *key,
206 : int len,
207 : char *ecuid,
208 : char *apid,
209 : char *ctid)
210 : {
211 : char *tok = NULL;
212 :
213 34 : if (len > DLT_OFFLINE_LOGSTORAGE_MAX_KEY_LEN)
214 : return DLT_RETURN_ERROR;
215 :
216 34 : tok = strtok(key, ":");
217 :
218 34 : if (tok == NULL)
219 : return DLT_RETURN_ERROR;
220 :
221 34 : len = strlen(tok);
222 :
223 34 : if (key[len + 1] == ':') {
224 : strncpy(ecuid, tok, DLT_ID_SIZE);
225 :
226 0 : tok = strtok(NULL, ":");
227 :
228 0 : if (tok != NULL)
229 : strncpy(ctid, tok, DLT_ID_SIZE);
230 :
231 : memcpy(apid, ".*", 2);
232 : }
233 : else {
234 : strncpy(ecuid, tok, DLT_ID_SIZE);
235 34 : tok = strtok(NULL, ":");
236 :
237 34 : if (tok != NULL)
238 : strncpy(apid, tok, DLT_ID_SIZE);
239 :
240 34 : tok = strtok(NULL, ":");
241 :
242 34 : if (tok != NULL)
243 : strncpy(ctid, tok, DLT_ID_SIZE);
244 : }
245 :
246 : return DLT_RETURN_OK;
247 : }
248 :
249 : /**
250 : * dlt_logstorage_split_key
251 : *
252 : * Split a given key into apid and ctid.
253 : * If APID\: - apid = APID and ctid = .*
254 : * If \:CTID - ctid = CTID and apid = .*
255 : * Else apid = APID and ctid = CTID
256 : *
257 : * @param key Given key of filter hash map
258 : * @param apid Application id
259 : * @param ctid Context id
260 : * @param ecuid ECU id
261 : * @return 0 on success, -1 on error
262 : */
263 42 : DLT_STATIC DltReturnValue dlt_logstorage_split_key(char *key, char *apid,
264 : char *ctid, char *ecuid)
265 : {
266 : int len = 0;
267 : char *sep = NULL;
268 :
269 42 : if ((key == NULL) || (apid == NULL) || (ctid == NULL) || (ecuid == NULL))
270 : return DLT_RETURN_WRONG_PARAMETER;
271 :
272 37 : len = strlen(key);
273 :
274 37 : sep = strchr (key, ':');
275 :
276 37 : if (sep == NULL)
277 : return DLT_RETURN_WRONG_PARAMETER;
278 :
279 : /* key is ecuid only ecuid::*/
280 37 : if ((key[len - 1] == ':') && (key[len - 2] == ':'))
281 0 : return dlt_logstorage_split_ecuid(key, len, ecuid, apid, ctid);
282 : /* key is context id only ::apid*/
283 37 : else if ((key[0] == ':') && (key[1] == ':'))
284 0 : return dlt_logstorage_split_ctid(key, len, apid, ctid);
285 : /* key is application id only :apid: */
286 37 : else if ((key[0] == ':') && (key[len - 1] == ':'))
287 1 : return dlt_logstorage_split_apid(key, len, apid, ctid);
288 : /* key is :apid:ctid */
289 36 : else if ((key[0] == ':') && (key[len - 1] != ':'))
290 1 : return dlt_logstorage_split_apid_ctid(key, len, apid, ctid);
291 : /* key is ecuid:apid: */
292 35 : else if ((key[0] != ':') && (key[len - 1] == ':'))
293 1 : return dlt_logstorage_split_ecuid_apid(key, len, ecuid, apid, ctid);
294 : /* key is either ecuid::ctid or ecuid:apid:ctid */
295 : else
296 34 : return dlt_logstorage_split_multi(key, len, ecuid, apid, ctid);
297 : }
298 :
299 : /**
300 : * Forward SET_LOG_LEVEL request to passive node
301 : *
302 : * @param daemon_local pointer to DltDaemonLocal structure
303 : * @param apid Application ID
304 : * @param ctid Context ID
305 : * @param ecuid ECU ID
306 : * @param loglevel requested log level
307 : * @param verbose verbosity flag
308 : */
309 0 : DLT_STATIC DltReturnValue dlt_daemon_logstorage_update_passive_node_context(
310 : DltDaemonLocal *daemon_local,
311 : char *apid,
312 : char *ctid,
313 : char *ecuid,
314 : int loglevel,
315 : int verbose)
316 : {
317 0 : DltServiceSetLogLevel req = { 0 };
318 0 : DltPassiveControlMessage ctrl = { 0 };
319 : DltGatewayConnection *con = NULL;
320 :
321 0 : PRINT_FUNCTION_VERBOSE(verbose);
322 :
323 0 : if ((daemon_local == NULL) || (apid == NULL) || (ctid == NULL) || (ecuid == NULL) ||
324 0 : (loglevel > DLT_LOG_VERBOSE) || (loglevel < DLT_LOG_DEFAULT)) {
325 0 : dlt_vlog(LOG_ERR, "%s: Wrong parameter\n", __func__);
326 0 : return DLT_RETURN_WRONG_PARAMETER;
327 : }
328 :
329 0 : con = dlt_gateway_get_connection(&daemon_local->pGateway, ecuid, verbose);
330 :
331 0 : if (con == NULL) {
332 0 : dlt_vlog(LOG_ERR,
333 : "Failed to fond connection to passive node %s\n",
334 : ecuid);
335 0 : return DLT_RETURN_ERROR;
336 : }
337 :
338 0 : ctrl.id = DLT_SERVICE_ID_SET_LOG_LEVEL;
339 0 : ctrl.type = CONTROL_MESSAGE_ON_DEMAND;
340 :
341 0 : dlt_set_id(req.apid, apid);
342 0 : dlt_set_id(req.ctid, ctid);
343 :
344 0 : req.log_level = loglevel;
345 :
346 0 : if (dlt_gateway_send_control_message(con, &ctrl, (void *)&req, verbose) != 0) {
347 0 : dlt_vlog(LOG_ERR,
348 : "Failed to forward SET_LOG_LEVEL message to passive node %s\n",
349 : ecuid);
350 :
351 0 : return DLT_RETURN_ERROR;
352 : }
353 :
354 : return DLT_RETURN_OK;
355 : }
356 :
357 : /**
358 : * dlt_daemon_logstorage_send_log_level
359 : *
360 : * Send new log level for the provided context, if ecuid is not daemon ecuid
361 : * update log level of passive node
362 : *
363 : * @param daemon DltDaemon structure
364 : * @param daemon_local DltDaemonLocal structure
365 : * @param context DltDaemonContext structure
366 : * @param ecuid ECU id
367 : * @param loglevel log level to be set to context
368 : * @param verbose If set to true verbose information is printed out
369 : * @return 0 on success, -1 on error
370 : */
371 2 : DLT_STATIC DltReturnValue dlt_daemon_logstorage_send_log_level(DltDaemon *daemon,
372 : DltDaemonLocal *daemon_local,
373 : DltDaemonContext *context,
374 : char *ecuid,
375 : int loglevel,
376 : int verbose)
377 : {
378 : int old_log_level = -1;
379 : int ll = DLT_LOG_DEFAULT;
380 :
381 2 : if ((daemon == NULL) || (daemon_local == NULL) || (ecuid == NULL) ||
382 2 : (context == NULL) || (loglevel > DLT_LOG_VERBOSE) || (loglevel < DLT_LOG_DEFAULT)) {
383 0 : dlt_vlog(LOG_ERR, "%s: Wrong parameter\n", __func__);
384 0 : return DLT_RETURN_WRONG_PARAMETER;
385 : }
386 :
387 2 : if (strncmp(ecuid, daemon->ecuid, DLT_ID_SIZE) == 0) {
388 2 : old_log_level = context->storage_log_level;
389 :
390 2 : context->storage_log_level = DLT_OFFLINE_LOGSTORAGE_MAX(loglevel,
391 : context->storage_log_level);
392 :
393 2 : if (context->storage_log_level > old_log_level) {
394 2 : if (dlt_daemon_user_send_log_level(daemon, context, verbose) == -1) {
395 0 : dlt_log(LOG_ERR, "Unable to update log level\n");
396 0 : return DLT_RETURN_ERROR;
397 : }
398 : }
399 : }
400 : else {
401 :
402 0 : old_log_level = context->log_level;
403 :
404 0 : ll = DLT_OFFLINE_LOGSTORAGE_MAX(loglevel, context->log_level);
405 :
406 0 : if (ll > old_log_level)
407 0 : return dlt_daemon_logstorage_update_passive_node_context(daemon_local,
408 0 : context->apid,
409 0 : context->ctid,
410 : ecuid,
411 : ll,
412 : verbose);
413 : }
414 :
415 : return DLT_RETURN_OK;
416 : }
417 :
418 : /**
419 : * dlt_daemon_logstorage_reset_log_level
420 : *
421 : * The log levels are reset if log level provided is -1 (not sent to
422 : * application in this case). Reset and sent to application if current log level
423 : * provided is 0.
424 : *
425 : * @param daemon DltDaemon structure
426 : * @param daemon_local DltDaemonLocal structure
427 : * @param context DltDaemonContext structure
428 : * @param ecuid ECU ID
429 : * @param loglevel log level to be set to context
430 : * @param verbose If set to true verbose information is printed out
431 : * @return 0 on success, -1 on error
432 : */
433 1 : DLT_STATIC DltReturnValue dlt_daemon_logstorage_reset_log_level(DltDaemon *daemon,
434 : DltDaemonLocal *daemon_local,
435 : DltDaemonContext *context,
436 : char *ecuid,
437 : int loglevel,
438 : int verbose)
439 : {
440 1 : if ((daemon == NULL) || (daemon_local == NULL) || (ecuid == NULL) ||
441 1 : (context == NULL) || (loglevel > DLT_LOG_VERBOSE) || (loglevel < DLT_LOG_DEFAULT)) {
442 0 : dlt_vlog(LOG_ERR, "%s: Wrong parameter\n", __func__);
443 0 : return DLT_RETURN_WRONG_PARAMETER;
444 : }
445 :
446 : /* Set storage level to -1, to clear log levels */
447 1 : context->storage_log_level = DLT_LOG_DEFAULT;
448 :
449 1 : if (loglevel == DLT_DAEMON_LOGSTORAGE_RESET_SEND_LOGLEVEL) {
450 1 : if (strncmp(ecuid, daemon->ecuid, DLT_ID_SIZE) == 0) {
451 1 : if (dlt_daemon_user_send_log_level(daemon,
452 : context,
453 : verbose) == DLT_RETURN_ERROR) {
454 0 : dlt_log(LOG_ERR, "Unable to update log level\n");
455 0 : return DLT_RETURN_ERROR;
456 : }
457 : }
458 : else { /* forward set log level to passive node */
459 0 : return dlt_daemon_logstorage_update_passive_node_context(daemon_local,
460 0 : context->apid,
461 0 : context->ctid,
462 : ecuid,
463 : DLT_LOG_DEFAULT,
464 : verbose);
465 : }
466 : }
467 :
468 : return DLT_RETURN_OK;
469 : }
470 :
471 : /**
472 : * dlt_daemon_logstorage_force_reset_level
473 : *
474 : * Force resetting of log level since have no data provided by passive node.
475 : *
476 : * @param daemon DltDaemon structure
477 : * @param daemon_local DltDaemonLocal structure
478 : * @param apid Application ID
479 : * @param ctid Context ID
480 : * @param ecuid ECU ID
481 : * @param loglevel log level to be set to context
482 : * @param verbose If set to true verbose information is printed out
483 : * @return 0 on success, -1 on error
484 : */
485 0 : DLT_STATIC DltReturnValue dlt_daemon_logstorage_force_reset_level(DltDaemon *daemon,
486 : DltDaemonLocal *daemon_local,
487 : char *apid,
488 : char *ctid,
489 : char *ecuid,
490 : int loglevel,
491 : int verbose)
492 : {
493 : int ll = DLT_LOG_DEFAULT;
494 : int num = 0;
495 : int i = 0;
496 0 : DltLogStorageFilterConfig *config[DLT_CONFIG_FILE_SECTIONS_MAX] = { 0 };
497 :
498 0 : if ((daemon == NULL) || (daemon_local == NULL) || (ecuid == NULL) ||
499 0 : (apid == NULL) || (ctid == NULL) || (loglevel > DLT_LOG_VERBOSE) || (loglevel < DLT_LOG_DEFAULT)) {
500 0 : dlt_vlog(LOG_ERR, "%s: Wrong parameter\n", __func__);
501 0 : return DLT_RETURN_WRONG_PARAMETER;
502 : }
503 :
504 0 : for (i = 0; i < daemon_local->flags.offlineLogstorageMaxDevices; i++) {
505 0 : num = dlt_logstorage_get_config(&(daemon->storage_handle[i]), config, apid, ctid, ecuid);
506 :
507 0 : if (num > 0)
508 : break; /* found config */
509 : }
510 :
511 0 : if ((num == 0) || (config[0] == NULL)) {
512 0 : dlt_vlog(LOG_ERR,
513 : "%s: No information about APID: %s, CTID: %s, ECU: %s in Logstorage configuration\n",
514 : __func__, apid, ctid, ecuid);
515 0 : return DLT_RETURN_ERROR;
516 : }
517 :
518 0 : if (loglevel == DLT_DAEMON_LOGSTORAGE_RESET_SEND_LOGLEVEL)
519 0 : ll = config[0]->reset_log_level;
520 : else
521 0 : ll = config[0]->log_level;
522 :
523 0 : return dlt_daemon_logstorage_update_passive_node_context(daemon_local, apid,
524 : ctid, ecuid, ll, verbose);
525 :
526 : }
527 :
528 : /**
529 : * dlt_logstorage_update_all_contexts
530 : *
531 : * Update log level of all contexts of the application by updating the daemon
532 : * internal table. The compare flags (cmp_flag) indicates if Id has to be
533 : * compared with application id or Context id of the daemon internal table.
534 : * The log levels are reset if current log level provided is -1 (not sent to
535 : * application in this case). Reset and sent to application if current log level
536 : * provided is 0.
537 : *
538 : * @param daemon DltDaemon structure
539 : * @param daemon_local DltDaemonLocal structure
540 : * @param id application id or context id
541 : * @param curr_log_level log level to be set to context
542 : * @param cmp_flag compare flag
543 : * @param ecuid ecu id where application runs
544 : * @param verbose If set to true verbose information is printed out
545 : * @return 0 on success, -1 on error
546 : */
547 4 : DltReturnValue dlt_logstorage_update_all_contexts(DltDaemon *daemon,
548 : DltDaemonLocal *daemon_local,
549 : char *id,
550 : int curr_log_level,
551 : int cmp_flag,
552 : char *ecuid,
553 : int verbose)
554 : {
555 : DltDaemonRegisteredUsers *user_list = NULL;
556 : int i = 0;
557 4 : char tmp_id[DLT_ID_SIZE + 1] = { '\0' };
558 :
559 4 : if ((daemon == NULL) || (daemon_local == NULL) || (id == NULL) ||
560 3 : (ecuid == NULL) || (cmp_flag <= DLT_DAEMON_LOGSTORAGE_CMP_MIN) ||
561 : (cmp_flag >= DLT_DAEMON_LOGSTORAGE_CMP_MAX)) {
562 1 : dlt_vlog(LOG_ERR, "Wrong parameter in function %s\n", __func__);
563 1 : return DLT_RETURN_WRONG_PARAMETER;
564 : }
565 :
566 3 : user_list = dlt_daemon_find_users_list(daemon, ecuid, verbose);
567 :
568 3 : if (user_list == NULL)
569 : return DLT_RETURN_ERROR;
570 :
571 3 : for (i = 0; i < user_list->num_contexts; i++) {
572 0 : if (cmp_flag == DLT_DAEMON_LOGSTORAGE_CMP_APID)
573 0 : dlt_set_id(tmp_id, user_list->contexts[i].apid);
574 0 : else if (cmp_flag == DLT_DAEMON_LOGSTORAGE_CMP_CTID)
575 0 : dlt_set_id(tmp_id, user_list->contexts[i].ctid);
576 : else
577 : /* this is for the case when both apid and ctid are wildcard */
578 0 : dlt_set_id(tmp_id, ".*");
579 :
580 0 : if (strncmp(id, tmp_id, DLT_ID_SIZE) == 0) {
581 0 : if (curr_log_level > 0)
582 0 : dlt_daemon_logstorage_send_log_level(daemon,
583 : daemon_local,
584 0 : &user_list->contexts[i],
585 : ecuid,
586 : curr_log_level,
587 : verbose);
588 : else /* The request is to reset log levels */
589 0 : dlt_daemon_logstorage_reset_log_level(daemon,
590 : daemon_local,
591 0 : &user_list->contexts[i],
592 : ecuid,
593 : curr_log_level,
594 : verbose);
595 : }
596 : }
597 :
598 : return DLT_RETURN_OK;
599 : }
600 :
601 : /**
602 : * dlt_logstorage_update_context
603 : *
604 : * Update log level of a context by updating the daemon internal table
605 : * The log levels are reset if current log level provided is -1 (not sent to
606 : * application in this case)
607 : * Reset and sent to application if current log level provided is 0
608 : *
609 : * @param daemon DltDaemon structure
610 : * @param daemon_local DltDaemonLocal structure
611 : * @param apid application id
612 : * @param ctid context id
613 : * @param ecuid ecu id
614 : * @param curr_log_level log level to be set to context
615 : * @param verbose If set to true verbose information is printed out
616 : * @return 0 on success, -1 on error
617 : */
618 38 : DltReturnValue dlt_logstorage_update_context(DltDaemon *daemon,
619 : DltDaemonLocal *daemon_local,
620 : char *apid,
621 : char *ctid,
622 : char *ecuid,
623 : int curr_log_level,
624 : int verbose)
625 : {
626 : DltDaemonContext *context = NULL;
627 :
628 38 : if ((daemon == NULL) || (daemon_local == NULL) || (apid == NULL)
629 37 : || (ctid == NULL) || (ecuid == NULL)) {
630 1 : dlt_vlog(LOG_ERR, "Wrong parameter in function %s\n", __func__);
631 1 : return DLT_RETURN_WRONG_PARAMETER;
632 : }
633 :
634 37 : context = dlt_daemon_context_find(daemon, apid, ctid, ecuid, verbose);
635 :
636 37 : if (context != NULL) {
637 3 : if (curr_log_level > 0)
638 2 : return dlt_daemon_logstorage_send_log_level(daemon,
639 : daemon_local,
640 : context,
641 : ecuid,
642 : curr_log_level,
643 : verbose);
644 : else /* The request is to reset log levels */
645 1 : return dlt_daemon_logstorage_reset_log_level(daemon,
646 : daemon_local,
647 : context,
648 : ecuid,
649 : curr_log_level,
650 : verbose);
651 : }
652 : else {
653 34 : if (strncmp(ecuid, daemon->ecuid, DLT_ID_SIZE) != 0) {
654 : /* we intentionally have no data provided by passive node. */
655 : /* We blindly send the log level or reset log level */
656 0 : return dlt_daemon_logstorage_force_reset_level(daemon,
657 : daemon_local,
658 : apid,
659 : ctid,
660 : ecuid,
661 : curr_log_level,
662 : verbose);
663 : }
664 : else {
665 34 : dlt_vlog(LOG_WARNING,
666 : "%s: No information about APID: %s, CTID: %s, ECU: %s\n",
667 : __func__,
668 : apid,
669 : ctid,
670 : ecuid);
671 34 : return DLT_RETURN_ERROR;
672 :
673 : }
674 : }
675 :
676 : return DLT_RETURN_OK;
677 : }
678 :
679 : /**
680 : * dlt_logstorage_update_context_loglevel
681 : *
682 : * Update all contexts or particular context depending provided key
683 : *
684 : * @param daemon Pointer to DLT Daemon structure
685 : * @param daemon_local Pointer to DLT Daemon Local structure
686 : * @param key Filter key stored in Hash Map
687 : * @param curr_log_level log level to be set to context
688 : * @param verbose If set to true verbose information is printed out
689 : * @return 0 on success, -1 on error
690 : */
691 37 : DltReturnValue dlt_logstorage_update_context_loglevel(DltDaemon *daemon,
692 : DltDaemonLocal *daemon_local,
693 : char *key,
694 : int curr_log_level,
695 : int verbose)
696 : {
697 : int cmp_flag = 0;
698 37 : char apid[DLT_ID_SIZE + 1] = { '\0' };
699 37 : char ctid[DLT_ID_SIZE + 1] = { '\0' };
700 37 : char ecuid[DLT_ID_SIZE + 1] = { '\0' };
701 :
702 37 : PRINT_FUNCTION_VERBOSE(verbose);
703 :
704 37 : if ((daemon == NULL) || (daemon_local == NULL) || (key == NULL))
705 : return DLT_RETURN_WRONG_PARAMETER;
706 :
707 36 : if (dlt_logstorage_split_key(key, apid, ctid, ecuid) != 0) {
708 0 : dlt_log(LOG_ERR,
709 : "Error while updating application log levels (split key)\n");
710 0 : return DLT_RETURN_ERROR;
711 : }
712 :
713 36 : if (ecuid[0] == '\0') /* ECU id was not specified in filter configuration */
714 2 : dlt_set_id(ecuid, daemon->ecuid);
715 :
716 : /* check wildcard for both apid and ctid first of all */
717 36 : if (strcmp(ctid, ".*") == 0 && strcmp(apid, ".*") == 0) {
718 : cmp_flag = DLT_DAEMON_LOGSTORAGE_CMP_ECID;
719 :
720 0 : if (dlt_logstorage_update_all_contexts(daemon,
721 : daemon_local,
722 : apid,
723 : curr_log_level,
724 : cmp_flag,
725 : ecuid,
726 : verbose) != 0)
727 0 : return DLT_RETURN_ERROR;
728 : }
729 36 : else if (strcmp(ctid, ".*") == 0) {
730 : cmp_flag = DLT_DAEMON_LOGSTORAGE_CMP_APID;
731 :
732 1 : if (dlt_logstorage_update_all_contexts(daemon,
733 : daemon_local,
734 : apid,
735 : curr_log_level,
736 : cmp_flag,
737 : ecuid,
738 : verbose) != 0)
739 0 : return DLT_RETURN_ERROR;
740 : }
741 : /* wildcard for application id, find all contexts with context id */
742 35 : else if (strcmp(apid, ".*") == 0)
743 : {
744 : cmp_flag = DLT_DAEMON_LOGSTORAGE_CMP_CTID;
745 :
746 0 : if (dlt_logstorage_update_all_contexts(daemon,
747 : daemon_local,
748 : ctid,
749 : curr_log_level,
750 : cmp_flag,
751 : ecuid,
752 : verbose) != 0)
753 0 : return DLT_RETURN_ERROR;
754 : }
755 : /* In case of given application id, context id pair, call available context
756 : * find function */
757 35 : else if (dlt_logstorage_update_context(daemon,
758 : daemon_local,
759 : apid,
760 : ctid,
761 : ecuid,
762 : curr_log_level,
763 : verbose) != 0)
764 : {
765 34 : return DLT_RETURN_ERROR;
766 : }
767 :
768 : return DLT_RETURN_OK;
769 : }
770 :
771 : /**
772 : * dlt_daemon_logstorage_reset_application_loglevel
773 : *
774 : * Reset storage log level of all running applications
775 : * 2 steps for resetting
776 : * 1. Setup storage_loglevel of all contexts configured for the requested device
777 : * to -1
778 : * 2. Re-run update log level for all other configured devices
779 : *
780 : * @param daemon Pointer to DLT Daemon structure
781 : * @param daemon_local Pointer to DLT Daemon local structure
782 : * @param dev_num Number of attached DLT Logstorage device
783 : * @param max_device Maximum storage devices setup by the daemon
784 : * @param verbose If set to true verbose information is printed out
785 : */
786 2 : void dlt_daemon_logstorage_reset_application_loglevel(DltDaemon *daemon,
787 : DltDaemonLocal *daemon_local,
788 : int dev_num,
789 : int max_device,
790 : int verbose)
791 : {
792 : DltLogStorage *handle = NULL;
793 : DltLogStorageFilterList **tmp = NULL;
794 : int i = 0;
795 2 : char key[DLT_OFFLINE_LOGSTORAGE_MAX_KEY_LEN + 1] = { '\0' };
796 : unsigned int status;
797 : int log_level = 0;
798 :
799 2 : PRINT_FUNCTION_VERBOSE(verbose);
800 :
801 2 : if ((daemon == NULL) || (daemon_local == NULL) ||
802 1 : (daemon->storage_handle == NULL) || (dev_num < 0)) {
803 2 : dlt_vlog(LOG_ERR,
804 : "Invalid function parameters used for %s\n",
805 : __func__);
806 2 : return;
807 : }
808 :
809 0 : handle = &(daemon->storage_handle[dev_num]);
810 :
811 0 : if ((handle->connection_type != DLT_OFFLINE_LOGSTORAGE_DEVICE_CONNECTED) ||
812 0 : (handle->config_status != DLT_OFFLINE_LOGSTORAGE_CONFIG_DONE))
813 : return;
814 :
815 : /* for all filters (keys) check if application context are already running
816 : * and log level need to be reset*/
817 0 : tmp = &(handle->config_list);
818 0 : while (*(tmp) != NULL)
819 : {
820 0 : for (i = 0; i < (*tmp)->num_keys; i++)
821 : {
822 : memset(key, 0, sizeof(key));
823 :
824 0 : strncpy(key, ((*tmp)->key_list
825 0 : + (i * DLT_OFFLINE_LOGSTORAGE_MAX_KEY_LEN)),
826 : DLT_OFFLINE_LOGSTORAGE_MAX_KEY_LEN);
827 :
828 : /* dlt-daemon wants to reset loglevel if
829 : * a logstorage device is disconnected.
830 : */
831 : log_level = DLT_DAEMON_LOGSTORAGE_RESET_LOGLEVEL;
832 :
833 0 : dlt_logstorage_update_context_loglevel(
834 : daemon,
835 : daemon_local,
836 : key,
837 : log_level,
838 : verbose);
839 : }
840 0 : tmp = &(*tmp)->next;
841 : }
842 :
843 : /* Re-run update log level for all other configured devices */
844 0 : for (i = 0; i < max_device; i++) {
845 0 : status = daemon->storage_handle[i].config_status;
846 :
847 0 : if (i == dev_num)
848 0 : continue;
849 :
850 0 : if (status == DLT_OFFLINE_LOGSTORAGE_CONFIG_DONE)
851 0 : dlt_daemon_logstorage_update_application_loglevel(daemon,
852 : daemon_local,
853 : i,
854 : verbose);
855 : }
856 :
857 : return;
858 : }
859 :
860 : /**
861 : * dlt_daemon_logstorage_update_application_loglevel
862 : *
863 : * Update log level of all running applications with new filter configuration
864 : * available due to newly attached DltLogstorage device. The log level is only
865 : * updated when the current application log level is less than the log level
866 : * obtained from the storage configuration file
867 : *
868 : * @param daemon Pointer to DLT Daemon structure
869 : * @param daemon_local Pointer to DLT Daemon local structure
870 : * @param dev_num Number of attached DLT Logstorage device
871 : * @param verbose If set to true verbose information is printed out
872 : */
873 10 : void dlt_daemon_logstorage_update_application_loglevel(DltDaemon *daemon,
874 : DltDaemonLocal *daemon_local,
875 : int dev_num,
876 : int verbose)
877 : {
878 : DltLogStorage *handle = NULL;
879 : DltLogStorageFilterList **tmp = NULL;
880 10 : char key[DLT_OFFLINE_LOGSTORAGE_MAX_KEY_LEN + 1] = { '\0' };
881 : int i = 0;
882 : int log_level = 0;
883 :
884 10 : PRINT_FUNCTION_VERBOSE(verbose);
885 :
886 10 : if ((daemon == NULL) || (daemon_local == NULL) || (dev_num < 0))
887 : {
888 1 : dlt_vlog(LOG_ERR,
889 : "Invalid function parameters used for %s\n",
890 : __func__);
891 1 : return;
892 : }
893 :
894 9 : handle = &(daemon->storage_handle[dev_num]);
895 :
896 9 : if ((handle->connection_type != DLT_OFFLINE_LOGSTORAGE_DEVICE_CONNECTED) ||
897 9 : (handle->config_status != DLT_OFFLINE_LOGSTORAGE_CONFIG_DONE))
898 : return;
899 :
900 : /* for all filters (keys) check if application or context already running
901 : * and log level need to be updated*/
902 9 : tmp = &(handle->config_list);
903 44 : while (*(tmp) != NULL)
904 : {
905 70 : for (i = 0; i < (*tmp)->num_keys; i++)
906 : {
907 : memset(key, 0, sizeof(key));
908 :
909 35 : strncpy(key, ((*tmp)->key_list
910 35 : + (i * DLT_OFFLINE_LOGSTORAGE_MAX_KEY_LEN)),
911 : DLT_OFFLINE_LOGSTORAGE_MAX_KEY_LEN);
912 :
913 : /* Obtain storage configuration data */
914 35 : log_level = dlt_logstorage_get_loglevel_by_key(handle, key);
915 35 : if (log_level < 0)
916 : {
917 0 : dlt_log(LOG_ERR, "Failed to get log level by key \n");
918 0 : return;
919 : }
920 :
921 : /* Update context log level with storage configuration log level */
922 35 : dlt_logstorage_update_context_loglevel(daemon,
923 : daemon_local,
924 : key,
925 : log_level,
926 : verbose);
927 : }
928 35 : tmp = &(*tmp)->next;
929 : }
930 :
931 : return;
932 : }
933 :
934 : /**
935 : * dlt_daemon_logstorage_get_loglevel
936 : *
937 : * Obtain log level as a union of all configured storage devices and filters for
938 : * the provided application id and context id
939 : *
940 : * @param daemon Pointer to DLT Daemon structure
941 : * @param max_device Maximum storage devices setup by the daemon
942 : * @param apid Application ID
943 : * @param ctid Context ID
944 : * @return Log level on success, -1 on error
945 : */
946 35 : int dlt_daemon_logstorage_get_loglevel(DltDaemon *daemon,
947 : int max_device,
948 : char *apid,
949 : char *ctid)
950 : {
951 35 : DltLogStorageFilterConfig *config[DLT_CONFIG_FILE_SECTIONS_MAX] = { 0 };
952 : int i = 0;
953 : int j = 0;
954 : int8_t storage_loglevel = -1;
955 : int8_t configured_loglevel = -1;
956 : int num_config = 0;
957 :
958 35 : if ((daemon == NULL) || (max_device == 0) || (apid == NULL) || (ctid == NULL))
959 : return DLT_RETURN_WRONG_PARAMETER;
960 :
961 68 : for (i = 0; i < max_device; i++)
962 34 : if (daemon->storage_handle[i].config_status ==
963 : DLT_OFFLINE_LOGSTORAGE_CONFIG_DONE) {
964 34 : num_config = dlt_logstorage_get_config(&(daemon->storage_handle[i]),
965 : config,
966 : apid,
967 : ctid,
968 34 : daemon->ecuid);
969 :
970 34 : if (num_config == 0) {
971 1 : dlt_log(LOG_DEBUG, "No valid filter configuration found\n");
972 1 : continue;
973 : }
974 :
975 66 : for (j = 0; j < num_config; j++)
976 : {
977 33 : if (config[j] == NULL)
978 0 : continue;
979 :
980 : /* If logstorage configuration do not contain file name,
981 : * then it is non verbose control filter, so return level as in this filter */
982 33 : if (config[j]->file_name == NULL) {
983 0 : storage_loglevel = config[j]->log_level;
984 0 : break;
985 : }
986 :
987 33 : configured_loglevel = config[j]->log_level;
988 33 : storage_loglevel = DLT_OFFLINE_LOGSTORAGE_MAX(
989 : configured_loglevel,
990 : storage_loglevel);
991 : }
992 : }
993 :
994 34 : return storage_loglevel;
995 : }
996 :
997 : /**
998 : * dlt_daemon_logstorage_write
999 : *
1000 : * Write log message to all attached storage device. If the called
1001 : * dlt_logstorage_write function is not able to write to the device, DltDaemon
1002 : * will disconnect this device.
1003 : *
1004 : * @param daemon Pointer to Dlt Daemon structure
1005 : * @param user_config DltDaemon configuration
1006 : * @param data1 message header buffer
1007 : * @param size1 message header buffer size
1008 : * @param data2 message extended header buffer
1009 : * @param size2 message extended header size
1010 : * @param data3 message data buffer
1011 : * @param size3 message data size
1012 : * @return 0 on success, -1 on error, 1 on disable network routing
1013 : */
1014 5842 : int dlt_daemon_logstorage_write(DltDaemon *daemon,
1015 : DltDaemonFlags *user_config,
1016 : unsigned char *data1,
1017 : int size1,
1018 : unsigned char *data2,
1019 : int size2,
1020 : unsigned char *data3,
1021 : int size3)
1022 : {
1023 : int i = 0;
1024 : int ret = 0;
1025 : DltLogStorageUserConfig file_config;
1026 :
1027 5842 : if ((daemon == NULL) || (user_config == NULL) ||
1028 5841 : (user_config->offlineLogstorageMaxDevices <= 0) || (data1 == NULL) ||
1029 5841 : (data2 == NULL) || (data3 == NULL)) {
1030 1 : dlt_vlog(LOG_DEBUG,
1031 : "%s: message type is not LOG. Skip storing.\n",
1032 : __func__);
1033 1 : return -1;
1034 : /* Log Level changed callback */
1035 : }
1036 :
1037 : /* Copy user configuration */
1038 5841 : file_config.logfile_timestamp = user_config->offlineLogstorageTimestamp;
1039 5841 : file_config.logfile_delimiter = user_config->offlineLogstorageDelimiter;
1040 5841 : file_config.logfile_maxcounter = user_config->offlineLogstorageMaxCounter;
1041 5841 : file_config.logfile_optional_counter = user_config->offlineLogstorageOptionalCounter;
1042 5841 : file_config.logfile_counteridxlen =
1043 5841 : user_config->offlineLogstorageMaxCounterIdx;
1044 :
1045 11682 : for (i = 0; i < user_config->offlineLogstorageMaxDevices; i++) {
1046 5841 : if (daemon->storage_handle[i].config_status ==
1047 : DLT_OFFLINE_LOGSTORAGE_CONFIG_DONE) {
1048 5841 : int disable_nw = 0;
1049 5841 : if ((ret = dlt_logstorage_write(&(daemon->storage_handle[i]),
1050 : &file_config,
1051 : data1,
1052 : size1,
1053 : data2,
1054 : size2,
1055 : data3,
1056 : size3,
1057 : &disable_nw)) < 0) {
1058 0 : dlt_log(LOG_ERR,
1059 : "dlt_daemon_logstorage_write: failed. "
1060 : "Disable storage device\n");
1061 : /* DLT_OFFLINE_LOGSTORAGE_MAX_ERRORS happened,
1062 : * therefore remove logstorage device */
1063 0 : dlt_logstorage_device_disconnected(
1064 0 : &(daemon->storage_handle[i]),
1065 : DLT_LOGSTORAGE_SYNC_ON_DEVICE_DISCONNECT);
1066 : }
1067 5841 : if (i == 0) {
1068 5841 : if (disable_nw == 1) {
1069 : ret = 1;
1070 : }
1071 : } else {
1072 0 : dlt_vlog(LOG_WARNING,
1073 : "%s: DisableNetwork is not supported for more than one device yet\n",
1074 : __func__);
1075 : }
1076 : }
1077 : }
1078 :
1079 : return ret;
1080 : }
1081 :
1082 : /**
1083 : * dlt_daemon_logstorage_setup_internal_storage
1084 : *
1085 : * Setup user defined path as offline log storage device
1086 : *
1087 : * @param daemon Pointer to Dlt Daemon structure
1088 : * @param daemon_local Pointer to Dlt Daemon local structure
1089 : * @param path User configured internal storage path
1090 : * @param verbose If set to true verbose information is printed out
1091 : * @return 0 on sucess, -1 otherwise
1092 : */
1093 8 : int dlt_daemon_logstorage_setup_internal_storage(DltDaemon *daemon,
1094 : DltDaemonLocal *daemon_local,
1095 : char *path,
1096 : int verbose)
1097 : {
1098 : int ret = 0;
1099 :
1100 8 : PRINT_FUNCTION_VERBOSE(verbose);
1101 :
1102 8 : if ((path == NULL) || (daemon == NULL))
1103 : return DLT_RETURN_WRONG_PARAMETER;
1104 :
1105 : /* connect internal storage device */
1106 : /* Device index always used as 0 as it is setup on DLT daemon startup */
1107 7 : ret = dlt_logstorage_device_connected(&(daemon->storage_handle[0]), path);
1108 :
1109 7 : if (ret != 0) {
1110 0 : dlt_vlog(LOG_ERR, "%s: Device connect failed\n", __func__);
1111 0 : return DLT_RETURN_ERROR;
1112 : }
1113 :
1114 : /* check if log level of running application need an update */
1115 7 : dlt_daemon_logstorage_update_application_loglevel(daemon,
1116 : daemon_local,
1117 : 0,
1118 : verbose);
1119 :
1120 7 : if (daemon->storage_handle[0].maintain_logstorage_loglevel !=
1121 : DLT_MAINTAIN_LOGSTORAGE_LOGLEVEL_UNDEF) {
1122 0 : daemon->maintain_logstorage_loglevel =
1123 : daemon->storage_handle[0].maintain_logstorage_loglevel;
1124 :
1125 0 : dlt_vlog(LOG_DEBUG, "[%s] Startup with maintain loglevel: [%d]\n",
1126 : __func__,
1127 : daemon->storage_handle[0].maintain_logstorage_loglevel);
1128 : }
1129 :
1130 : return ret;
1131 : }
1132 :
1133 10 : void dlt_daemon_logstorage_set_logstorage_cache_size(unsigned int size)
1134 : {
1135 : /* store given [KB] size in [Bytes] */
1136 10 : g_logstorage_cache_max = size * 1024;
1137 10 : }
1138 :
1139 8 : int dlt_daemon_logstorage_cleanup(DltDaemon *daemon,
1140 : DltDaemonLocal *daemon_local,
1141 : int verbose)
1142 : {
1143 : int i = 0;
1144 :
1145 8 : PRINT_FUNCTION_VERBOSE(verbose);
1146 :
1147 8 : if ((daemon == NULL) || (daemon_local == NULL) || (daemon->storage_handle == NULL))
1148 : return DLT_RETURN_WRONG_PARAMETER;
1149 :
1150 14 : for (i = 0; i < daemon_local->flags.offlineLogstorageMaxDevices; i++)
1151 : /* call disconnect on all currently connected devices */
1152 7 : if (daemon->storage_handle[i].connection_type ==
1153 : DLT_OFFLINE_LOGSTORAGE_DEVICE_CONNECTED)
1154 : {
1155 6 : (&daemon->storage_handle[i])->uconfig.logfile_counteridxlen =
1156 6 : daemon_local->flags.offlineLogstorageMaxCounterIdx;
1157 6 : (&daemon->storage_handle[i])->uconfig.logfile_delimiter =
1158 6 : daemon_local->flags.offlineLogstorageDelimiter;
1159 6 : (&daemon->storage_handle[i])->uconfig.logfile_maxcounter =
1160 6 : daemon_local->flags.offlineLogstorageMaxCounter;
1161 6 : (&daemon->storage_handle[i])->uconfig.logfile_timestamp =
1162 6 : daemon_local->flags.offlineLogstorageTimestamp;
1163 6 : (&daemon->storage_handle[i])->uconfig.logfile_optional_counter =
1164 6 : daemon_local->flags.offlineLogstorageOptionalCounter;
1165 :
1166 6 : dlt_logstorage_device_disconnected(
1167 : &daemon->storage_handle[i],
1168 : DLT_LOGSTORAGE_SYNC_ON_DAEMON_EXIT);
1169 : }
1170 :
1171 : return 0;
1172 : }
1173 :
1174 4 : int dlt_daemon_logstorage_sync_cache(DltDaemon *daemon,
1175 : DltDaemonLocal *daemon_local,
1176 : char *mnt_point,
1177 : int verbose)
1178 : {
1179 : int i = 0;
1180 : DltLogStorage *handle = NULL;
1181 :
1182 4 : PRINT_FUNCTION_VERBOSE(verbose);
1183 :
1184 4 : if ((daemon == NULL) || (daemon_local == NULL) || (mnt_point == NULL))
1185 : return DLT_RETURN_WRONG_PARAMETER;
1186 :
1187 3 : if (strlen(mnt_point) > 0) { /* mount point is given */
1188 3 : handle = dlt_daemon_logstorage_get_device(daemon,
1189 : daemon_local,
1190 : mnt_point,
1191 : verbose);
1192 :
1193 3 : if (handle == NULL) {
1194 : return DLT_RETURN_ERROR;
1195 : }
1196 : else {
1197 3 : handle->uconfig.logfile_counteridxlen =
1198 3 : daemon_local->flags.offlineLogstorageMaxCounterIdx;
1199 3 : handle->uconfig.logfile_delimiter =
1200 3 : daemon_local->flags.offlineLogstorageDelimiter;
1201 3 : handle->uconfig.logfile_maxcounter =
1202 3 : daemon_local->flags.offlineLogstorageMaxCounter;
1203 3 : handle->uconfig.logfile_timestamp =
1204 3 : daemon_local->flags.offlineLogstorageTimestamp;
1205 3 : handle->uconfig.logfile_optional_counter =
1206 3 : daemon_local->flags.offlineLogstorageOptionalCounter;
1207 :
1208 3 : if (dlt_logstorage_sync_caches(handle) != 0)
1209 0 : return DLT_RETURN_ERROR;
1210 : }
1211 : }
1212 : else { /* sync caches for all connected logstorage devices */
1213 :
1214 0 : for (i = 0; i < daemon_local->flags.offlineLogstorageMaxDevices; i++)
1215 0 : if (daemon->storage_handle[i].connection_type ==
1216 : DLT_OFFLINE_LOGSTORAGE_DEVICE_CONNECTED) {
1217 0 : daemon->storage_handle[i].uconfig.logfile_counteridxlen =
1218 0 : daemon_local->flags.offlineLogstorageMaxCounterIdx;
1219 0 : daemon->storage_handle[i].uconfig.logfile_delimiter =
1220 0 : daemon_local->flags.offlineLogstorageDelimiter;
1221 0 : daemon->storage_handle[i].uconfig.logfile_maxcounter =
1222 0 : daemon_local->flags.offlineLogstorageMaxCounter;
1223 0 : daemon->storage_handle[i].uconfig.logfile_timestamp =
1224 0 : daemon_local->flags.offlineLogstorageTimestamp;
1225 0 : daemon->storage_handle[i].uconfig.logfile_optional_counter =
1226 0 : daemon_local->flags.offlineLogstorageOptionalCounter;
1227 :
1228 0 : if (dlt_logstorage_sync_caches(&daemon->storage_handle[i]) != 0)
1229 : return DLT_RETURN_ERROR;
1230 : }
1231 : }
1232 :
1233 : return 0;
1234 : }
1235 :
1236 5 : DltLogStorage *dlt_daemon_logstorage_get_device(DltDaemon *daemon,
1237 : DltDaemonLocal *daemon_local,
1238 : char *mnt_point,
1239 : int verbose)
1240 : {
1241 : int i = 0;
1242 : int len = 0;
1243 : int len1 = 0;
1244 : int len2 = 0;
1245 :
1246 5 : PRINT_FUNCTION_VERBOSE(verbose);
1247 :
1248 5 : if ((daemon == NULL) || (daemon_local == NULL) || (mnt_point == NULL))
1249 : return NULL;
1250 :
1251 4 : len1 = strlen(mnt_point);
1252 :
1253 4 : for (i = 0; i < daemon_local->flags.offlineLogstorageMaxDevices; i++) {
1254 4 : len2 = strlen(daemon->storage_handle[i].device_mount_point);
1255 :
1256 : /* Check if the requested device path is already used as log storage
1257 : * device. Check for strlen first, to avoid comparison errors when
1258 : * final '/' is given or not */
1259 4 : len = len1 > len2 ? len2 : len1;
1260 :
1261 4 : if (strncmp(daemon->storage_handle[i].device_mount_point, mnt_point, len) == 0)
1262 4 : return &daemon->storage_handle[i];
1263 : }
1264 :
1265 : return NULL;
1266 : }
|