1*4882a593Smuzhiyun /* 2*4882a593Smuzhiyun * Copyright (C) 2022 Rockchip Electronics Co., Ltd. 3*4882a593Smuzhiyun * Authors: 4*4882a593Smuzhiyun * Cerf Yu <cerf.yu@rock-chips.com> 5*4882a593Smuzhiyun * 6*4882a593Smuzhiyun * Licensed under the Apache License, Version 2.0 (the "License"); 7*4882a593Smuzhiyun * you may not use this file except in compliance with the License. 8*4882a593Smuzhiyun * You may obtain a copy of the License at 9*4882a593Smuzhiyun * 10*4882a593Smuzhiyun * http://www.apache.org/licenses/LICENSE-2.0 11*4882a593Smuzhiyun * 12*4882a593Smuzhiyun * Unless required by applicable law or agreed to in writing, software 13*4882a593Smuzhiyun * distributed under the License is distributed on an "AS IS" BASIS, 14*4882a593Smuzhiyun * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 15*4882a593Smuzhiyun * See the License for the specific language governing permissions and 16*4882a593Smuzhiyun * limitations under the License. 17*4882a593Smuzhiyun */ 18*4882a593Smuzhiyun #ifndef _im2d_log_hpp_ 19*4882a593Smuzhiyun #define _im2d_log_hpp_ 20*4882a593Smuzhiyun 21*4882a593Smuzhiyun #define IM_ERR_MSG_LEN 512 22*4882a593Smuzhiyun 23*4882a593Smuzhiyun typedef enum { 24*4882a593Smuzhiyun IM_LOG_UNKNOWN = 0x0, 25*4882a593Smuzhiyun IM_LOG_DEFAULT = 0x1, 26*4882a593Smuzhiyun IM_LOG_DEBUG = 0x3, 27*4882a593Smuzhiyun IM_LOG_INFO = 0x4, 28*4882a593Smuzhiyun IM_LOG_WARN = 0x5, 29*4882a593Smuzhiyun IM_LOG_ERROR = 0x6, 30*4882a593Smuzhiyun IM_LOG_LEVEL_MASK = 0xff, 31*4882a593Smuzhiyun 32*4882a593Smuzhiyun IM_LOG_FORCE = 0x1 << 8, /* This will force output to stdout, not to internal error messages. */ 33*4882a593Smuzhiyun } IM_LOG_LEVEL; 34*4882a593Smuzhiyun 35*4882a593Smuzhiyun #define GET_LOG_LEVEL(level) ((level) & IM_LOG_LEVEL_MASK) 36*4882a593Smuzhiyun #define LOG_LEVEL_CHECK(level) ((level) >= rga_log_level_get()) 37*4882a593Smuzhiyun 38*4882a593Smuzhiyun int rga_error_msg_set(const char* format, ...); 39*4882a593Smuzhiyun int rga_log_level_init(void); 40*4882a593Smuzhiyun void rga_log_level_update(void); 41*4882a593Smuzhiyun int rga_log_level_get(void); 42*4882a593Smuzhiyun int rga_log_enable_get(void); 43*4882a593Smuzhiyun 44*4882a593Smuzhiyun size_t rga_get_current_time_ms(void); 45*4882a593Smuzhiyun size_t rga_get_start_time_ms(void); 46*4882a593Smuzhiyun 47*4882a593Smuzhiyun #ifdef ANDROID 48*4882a593Smuzhiyun #define IM_LOG(level, ...) \ 49*4882a593Smuzhiyun do { \ 50*4882a593Smuzhiyun if (!((level) & IM_LOG_FORCE)) \ 51*4882a593Smuzhiyun rga_error_msg_set(__VA_ARGS__); \ 52*4882a593Smuzhiyun if ((rga_log_enable_get() > 0 && LOG_LEVEL_CHECK(level)) || \ 53*4882a593Smuzhiyun GET_LOG_LEVEL(level) == ANDROID_LOG_ERROR || \ 54*4882a593Smuzhiyun (level) & IM_LOG_FORCE) \ 55*4882a593Smuzhiyun ((void)__android_log_print(GET_LOG_LEVEL(level), LOG_TAG, __VA_ARGS__)); \ 56*4882a593Smuzhiyun } while(0) 57*4882a593Smuzhiyun #define IM_LOGD(_str, ...) IM_LOG(ANDROID_LOG_DEBUG, _str , ## __VA_ARGS__) 58*4882a593Smuzhiyun #define IM_LOGI(_str, ...) IM_LOG(ANDROID_LOG_INFO, _str , ## __VA_ARGS__) 59*4882a593Smuzhiyun #define IM_LOGW(_str, ...) IM_LOG(ANDROID_LOG_WARN, _str , ## __VA_ARGS__) 60*4882a593Smuzhiyun #define IM_LOGE(_str, ...) IM_LOG(ANDROID_LOG_ERROR, _str , ## __VA_ARGS__) 61*4882a593Smuzhiyun #define IM_LOGFD(_str, ...) IM_LOG(ANDROID_LOG_DEBUG | IM_LOG_FORCE, _str , ## __VA_ARGS__) 62*4882a593Smuzhiyun #define IM_LOGFI(_str, ...) IM_LOG(ANDROID_LOG_INFO | IM_LOG_FORCE, _str , ## __VA_ARGS__) 63*4882a593Smuzhiyun #define IM_LOGFW(_str, ...) IM_LOG(ANDROID_LOG_WARN | IM_LOG_FORCE, _str , ## __VA_ARGS__) 64*4882a593Smuzhiyun #define IM_LOGFE(_str, ...) IM_LOG(ANDROID_LOG_ERROR | IM_LOG_FORCE, _str , ## __VA_ARGS__) 65*4882a593Smuzhiyun 66*4882a593Smuzhiyun #else 67*4882a593Smuzhiyun #define IM_LOG(level, _str, ...) \ 68*4882a593Smuzhiyun do { \ 69*4882a593Smuzhiyun if (!((level) & IM_LOG_FORCE)) \ 70*4882a593Smuzhiyun rga_error_msg_set(_str, ## __VA_ARGS__); \ 71*4882a593Smuzhiyun if ((rga_log_enable_get() > 0 && LOG_LEVEL_CHECK(level)) || \ 72*4882a593Smuzhiyun GET_LOG_LEVEL(level) == IM_LOG_ERROR || \ 73*4882a593Smuzhiyun (level) & IM_LOG_FORCE) \ 74*4882a593Smuzhiyun fprintf(stdout, "%lu " LOG_TAG " %s(%d): " _str "\n", \ 75*4882a593Smuzhiyun (unsigned long)(rga_get_current_time_ms()-rga_get_start_time_ms()), \ 76*4882a593Smuzhiyun __FUNCTION__, __LINE__, ## __VA_ARGS__); \ 77*4882a593Smuzhiyun } while(0) 78*4882a593Smuzhiyun #define IM_LOGD(_str, ...) IM_LOG(IM_LOG_DEBUG, _str , ## __VA_ARGS__) 79*4882a593Smuzhiyun #define IM_LOGI(_str, ...) IM_LOG(IM_LOG_INFO, _str , ## __VA_ARGS__) 80*4882a593Smuzhiyun #define IM_LOGW(_str, ...) IM_LOG(IM_LOG_WARN, _str , ## __VA_ARGS__) 81*4882a593Smuzhiyun #define IM_LOGE(_str, ...) IM_LOG(IM_LOG_ERROR, _str , ## __VA_ARGS__) 82*4882a593Smuzhiyun #define IM_LOGFD(_str, ...) IM_LOG(IM_LOG_DEBUG | IM_LOG_FORCE, _str , ## __VA_ARGS__) 83*4882a593Smuzhiyun #define IM_LOGFI(_str, ...) IM_LOG(IM_LOG_INFO | IM_LOG_FORCE, _str , ## __VA_ARGS__) 84*4882a593Smuzhiyun #define IM_LOGFW(_str, ...) IM_LOG(IM_LOG_WARN | IM_LOG_FORCE, _str , ## __VA_ARGS__) 85*4882a593Smuzhiyun #define IM_LOGFE(_str, ...) IM_LOG(IM_LOG_ERROR | IM_LOG_FORCE, _str , ## __VA_ARGS__) 86*4882a593Smuzhiyun #endif 87*4882a593Smuzhiyun 88*4882a593Smuzhiyun #endif /* #define _im2d_log_hpp_ */ 89