• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2019, The Linux Foundation. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are
6  * met:
7  *    * Redistributions of source code must retain the above copyright
8  *      notice, this list of conditions and the following disclaimer.
9  *    * Redistributions in binary form must reproduce the above
10  *      copyright notice, this list of conditions and the following
11  *      disclaimer in the documentation and/or other materials provided
12  *      with the distribution.
13  *    * Neither the name of The Linux Foundation nor the names of its
14  *      contributors may be used to endorse or promote products derived
15  *      from this software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
18  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
19  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
20  * ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
21  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
24  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
25  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
26  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
27  * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28  */
29 
30 #include "adspmsgd_apps.h"
31 #include "remote.h"
32 
33 #include <stdio.h>
34 
35 #define LOG_NODE_SIZE           256
36 #define LOG_FILENAME_SIZE       30
37 #define LOG_MSG_SIZE            LOG_NODE_SIZE - LOG_FILENAME_SIZE - \
38     sizeof(enum adspmsgd_apps_Level) - (2*sizeof(unsigned short))
39 
40 typedef struct __attribute__((packed))
41 {
42     enum adspmsgd_apps_Level level;
43     unsigned short line;
44     unsigned short thread_id;
45     char str[LOG_MSG_SIZE];
46     char file [LOG_FILENAME_SIZE];
47 } LogNode;
48 
49 #if 0
50 static inline android_LogPriority convert_level_to_android_priority(
51     enum adspmsgd_apps_Level level)
52 {
53     switch (level) {
54         case LOW:
55             return LOW;
56         case MEDIUM:
57             return MEDIUM;
58         case HIGH:
59             return HIGH;
60         case ERROR:
61             return ERROR;
62         case FATAL:
63             return FATAL;
64         default:
65             return 0;
66         }
67 }
68 #endif
69 
adspmsgd_apps_log(const unsigned char * log_message_buffer,int log_message_bufferLen)70 int adspmsgd_apps_log(const unsigned char *log_message_buffer,
71                       int log_message_bufferLen)
72 {
73     LogNode *logMessage = (LogNode *)log_message_buffer;
74     while (  (log_message_bufferLen  > 0) && (logMessage != NULL)) {
75         printf("adsprpc: %s:%d:0x%x:%s", logMessage->file, logMessage->line,
76             logMessage->thread_id, logMessage->str);
77         logMessage++;
78         log_message_bufferLen -= sizeof(LogNode);
79     };
80 
81     return 0;
82 }
83