xref: /aosp_15_r20/system/chre/platform/shared/tokenized_log.cc (revision 84e339476a462649f82315436d70fd732297a399)
1*84e33947SAndroid Build Coastguard Worker /*
2*84e33947SAndroid Build Coastguard Worker  * Copyright (C) 2024 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/platform/shared/nanoapp/tokenized_log.h"
18*84e33947SAndroid Build Coastguard Worker #include "chre/core/event_loop_manager.h"
19*84e33947SAndroid Build Coastguard Worker #include "chre/platform/log.h"
20*84e33947SAndroid Build Coastguard Worker #include "chre/platform/shared/log_buffer_manager.h"
21*84e33947SAndroid Build Coastguard Worker #include "chre_api/chre/re.h"
22*84e33947SAndroid Build Coastguard Worker 
23*84e33947SAndroid Build Coastguard Worker #include "pw_log_tokenized/config.h"
24*84e33947SAndroid Build Coastguard Worker #include "pw_tokenizer/encode_args.h"
25*84e33947SAndroid Build Coastguard Worker #include "pw_tokenizer/tokenize.h"
26*84e33947SAndroid Build Coastguard Worker 
platform_chrePwTokenizedLog(enum chreLogLevel level,uint32_t token,uint64_t types,...)27*84e33947SAndroid Build Coastguard Worker void platform_chrePwTokenizedLog(enum chreLogLevel level, uint32_t token,
28*84e33947SAndroid Build Coastguard Worker                                  uint64_t types, ...) {
29*84e33947SAndroid Build Coastguard Worker   va_list args;
30*84e33947SAndroid Build Coastguard Worker   va_start(args, types);
31*84e33947SAndroid Build Coastguard Worker   pw::tokenizer::EncodedMessage<pw::log_tokenized::kEncodingBufferSizeBytes>
32*84e33947SAndroid Build Coastguard Worker       encodedMessage(token, types, args);
33*84e33947SAndroid Build Coastguard Worker   va_end(args);
34*84e33947SAndroid Build Coastguard Worker 
35*84e33947SAndroid Build Coastguard Worker   chre::LogBufferManagerSingleton::get()->logNanoappTokenized(
36*84e33947SAndroid Build Coastguard Worker       level,
37*84e33947SAndroid Build Coastguard Worker       chre::EventLoopManagerSingleton::get()
38*84e33947SAndroid Build Coastguard Worker           ->getEventLoop()
39*84e33947SAndroid Build Coastguard Worker           .getCurrentNanoapp()
40*84e33947SAndroid Build Coastguard Worker           ->getInstanceId(),
41*84e33947SAndroid Build Coastguard Worker       encodedMessage.data_as_uint8(), encodedMessage.size());
42*84e33947SAndroid Build Coastguard Worker }
43