1*38e8c45fSAndroid Build Coastguard Worker /* 2*38e8c45fSAndroid Build Coastguard Worker * Copyright 2022 The Android Open Source Project 3*38e8c45fSAndroid Build Coastguard Worker * 4*38e8c45fSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*38e8c45fSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*38e8c45fSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*38e8c45fSAndroid Build Coastguard Worker * 8*38e8c45fSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*38e8c45fSAndroid Build Coastguard Worker * 10*38e8c45fSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*38e8c45fSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*38e8c45fSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*38e8c45fSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*38e8c45fSAndroid Build Coastguard Worker * limitations under the License. 15*38e8c45fSAndroid Build Coastguard Worker */ 16*38e8c45fSAndroid Build Coastguard Worker 17*38e8c45fSAndroid Build Coastguard Worker #pragma once 18*38e8c45fSAndroid Build Coastguard Worker 19*38e8c45fSAndroid Build Coastguard Worker #include "Tracing/TransactionTracing.h" 20*38e8c45fSAndroid Build Coastguard Worker 21*38e8c45fSAndroid Build Coastguard Worker // Uncomment to trace layer updates for a single layer 22*38e8c45fSAndroid Build Coastguard Worker // #define LOG_LAYER 1 23*38e8c45fSAndroid Build Coastguard Worker 24*38e8c45fSAndroid Build Coastguard Worker #ifdef LOG_LAYER 25*38e8c45fSAndroid Build Coastguard Worker #define LLOGV(LAYER_ID, x, ...) \ 26*38e8c45fSAndroid Build Coastguard Worker ALOGV_IF(((LAYER_ID) == LOG_LAYER), "[%d] %s " x, LOG_LAYER, __func__, ##__VA_ARGS__); 27*38e8c45fSAndroid Build Coastguard Worker #else 28*38e8c45fSAndroid Build Coastguard Worker #define LLOGV(LAYER_ID, x, ...) ALOGV("[%d] %s " x, (LAYER_ID), __func__, ##__VA_ARGS__); 29*38e8c45fSAndroid Build Coastguard Worker #endif 30*38e8c45fSAndroid Build Coastguard Worker 31*38e8c45fSAndroid Build Coastguard Worker #define LLOGD(LAYER_ID, x, ...) ALOGD("[%d] %s " x, (LAYER_ID), __func__, ##__VA_ARGS__); 32*38e8c45fSAndroid Build Coastguard Worker 33*38e8c45fSAndroid Build Coastguard Worker #define LLOG_ALWAYS_FATAL_WITH_TRACE(...) \ 34*38e8c45fSAndroid Build Coastguard Worker do { \ 35*38e8c45fSAndroid Build Coastguard Worker TransactionTraceWriter::getInstance().invoke(__func__, /* overwrite= */ false); \ 36*38e8c45fSAndroid Build Coastguard Worker LOG_ALWAYS_FATAL(##__VA_ARGS__); \ 37*38e8c45fSAndroid Build Coastguard Worker } while (false) 38*38e8c45fSAndroid Build Coastguard Worker 39*38e8c45fSAndroid Build Coastguard Worker #define LLOG_ALWAYS_FATAL_WITH_TRACE_IF(cond, ...) \ 40*38e8c45fSAndroid Build Coastguard Worker do { \ 41*38e8c45fSAndroid Build Coastguard Worker if (__predict_false(cond)) { \ 42*38e8c45fSAndroid Build Coastguard Worker TransactionTraceWriter::getInstance().invoke(__func__, /* overwrite= */ false); \ 43*38e8c45fSAndroid Build Coastguard Worker } \ 44*38e8c45fSAndroid Build Coastguard Worker LOG_ALWAYS_FATAL_IF(cond, ##__VA_ARGS__); \ 45*38e8c45fSAndroid Build Coastguard Worker } while (false)