xref: /aosp_15_r20/system/chre/util/nanoapp/debug.cc (revision 84e339476a462649f82315436d70fd732297a399)
1*84e33947SAndroid Build Coastguard Worker /*
2*84e33947SAndroid Build Coastguard Worker  * Copyright (C) 2017 The Android Open Source Project
3*84e33947SAndroid Build Coastguard Worker  *
4*84e33947SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*84e33947SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*84e33947SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*84e33947SAndroid Build Coastguard Worker  *
8*84e33947SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*84e33947SAndroid Build Coastguard Worker  *
10*84e33947SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*84e33947SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*84e33947SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*84e33947SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*84e33947SAndroid Build Coastguard Worker  * limitations under the License.
15*84e33947SAndroid Build Coastguard Worker  */
16*84e33947SAndroid Build Coastguard Worker 
17*84e33947SAndroid Build Coastguard Worker #include "chre/util/nanoapp/debug.h"
18*84e33947SAndroid Build Coastguard Worker 
19*84e33947SAndroid Build Coastguard Worker #include <cctype>
20*84e33947SAndroid Build Coastguard Worker #include <cstdio>
21*84e33947SAndroid Build Coastguard Worker 
22*84e33947SAndroid Build Coastguard Worker #ifdef CHRE_NANOAPP_INTERNAL
23*84e33947SAndroid Build Coastguard Worker #include "chre/platform/log.h"
24*84e33947SAndroid Build Coastguard Worker #else
25*84e33947SAndroid Build Coastguard Worker #define LOG_TAG "[DEBUG]"
26*84e33947SAndroid Build Coastguard Worker #include "chre/util/nanoapp/log.h"
27*84e33947SAndroid Build Coastguard Worker #endif
28*84e33947SAndroid Build Coastguard Worker 
29*84e33947SAndroid Build Coastguard Worker namespace chre {
30*84e33947SAndroid Build Coastguard Worker 
logBuffer(const uint8_t * buffer,size_t bufferSize)31*84e33947SAndroid Build Coastguard Worker void logBuffer(const uint8_t *buffer, size_t bufferSize) {
32*84e33947SAndroid Build Coastguard Worker   char line[32];
33*84e33947SAndroid Build Coastguard Worker   char lineChars[32];
34*84e33947SAndroid Build Coastguard Worker   size_t offset = 0;
35*84e33947SAndroid Build Coastguard Worker   size_t offsetChars = 0;
36*84e33947SAndroid Build Coastguard Worker 
37*84e33947SAndroid Build Coastguard Worker   if (bufferSize > 128) {
38*84e33947SAndroid Build Coastguard Worker     LOGD("Dumping first 128 bytes of buffer @ %p, size %zu", buffer,
39*84e33947SAndroid Build Coastguard Worker          bufferSize);
40*84e33947SAndroid Build Coastguard Worker     bufferSize = 128;
41*84e33947SAndroid Build Coastguard Worker   } else {
42*84e33947SAndroid Build Coastguard Worker     LOGD("Dumping buffer @ %p, size %zu", buffer, bufferSize);
43*84e33947SAndroid Build Coastguard Worker   }
44*84e33947SAndroid Build Coastguard Worker 
45*84e33947SAndroid Build Coastguard Worker   for (size_t i = 1; i <= bufferSize; i++) {
46*84e33947SAndroid Build Coastguard Worker     // This ignores potential errors returned by snprintf. This is a relatively
47*84e33947SAndroid Build Coastguard Worker     // simple case and the deliberate decision to ignore them has been made.
48*84e33947SAndroid Build Coastguard Worker     offset += static_cast<size_t>(
49*84e33947SAndroid Build Coastguard Worker         snprintf(&line[offset], sizeof(line) - offset, "%02x ", buffer[i - 1]));
50*84e33947SAndroid Build Coastguard Worker     offsetChars += static_cast<size_t>(
51*84e33947SAndroid Build Coastguard Worker         snprintf(&lineChars[offsetChars], sizeof(lineChars) - offsetChars, "%c",
52*84e33947SAndroid Build Coastguard Worker                  (isprint(buffer[i - 1])) ? buffer[i - 1] : '.'));
53*84e33947SAndroid Build Coastguard Worker     if ((i % 8) == 0) {
54*84e33947SAndroid Build Coastguard Worker       LOGD("  %s\t%s", line, lineChars);
55*84e33947SAndroid Build Coastguard Worker       offset = 0;
56*84e33947SAndroid Build Coastguard Worker       offsetChars = 0;
57*84e33947SAndroid Build Coastguard Worker     } else if ((i % 4) == 0) {
58*84e33947SAndroid Build Coastguard Worker       offset += static_cast<size_t>(
59*84e33947SAndroid Build Coastguard Worker           snprintf(&line[offset], sizeof(line) - offset, " "));
60*84e33947SAndroid Build Coastguard Worker     }
61*84e33947SAndroid Build Coastguard Worker   }
62*84e33947SAndroid Build Coastguard Worker 
63*84e33947SAndroid Build Coastguard Worker   if (offset > 0) {
64*84e33947SAndroid Build Coastguard Worker     char tabs[8];
65*84e33947SAndroid Build Coastguard Worker     char *pos = tabs;
66*84e33947SAndroid Build Coastguard Worker     while (offset < 28) {
67*84e33947SAndroid Build Coastguard Worker       *pos++ = '\t';
68*84e33947SAndroid Build Coastguard Worker       offset += 8;
69*84e33947SAndroid Build Coastguard Worker     }
70*84e33947SAndroid Build Coastguard Worker     *pos = '\0';
71*84e33947SAndroid Build Coastguard Worker     LOGD("  %s%s%s", line, tabs, lineChars);
72*84e33947SAndroid Build Coastguard Worker   }
73*84e33947SAndroid Build Coastguard Worker }
74*84e33947SAndroid Build Coastguard Worker 
75*84e33947SAndroid Build Coastguard Worker }  // namespace chre
76