xref: /OK3568_Linux_fs/external/linux-rga/im2d_api/src/im2d_log.cpp (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Copyright (C) 2021 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 
19*4882a593Smuzhiyun #include <stdio.h>
20*4882a593Smuzhiyun #include <stdlib.h>
21*4882a593Smuzhiyun #include <stdarg.h>
22*4882a593Smuzhiyun #include <sys/time.h>
23*4882a593Smuzhiyun 
24*4882a593Smuzhiyun #ifndef __cplusplus
25*4882a593Smuzhiyun # include <stdatomic.h>
26*4882a593Smuzhiyun #else
27*4882a593Smuzhiyun # include <atomic>
28*4882a593Smuzhiyun # define _Atomic(X) std::atomic< X >
29*4882a593Smuzhiyun using namespace std;
30*4882a593Smuzhiyun #endif
31*4882a593Smuzhiyun 
32*4882a593Smuzhiyun #ifdef ANDROID
33*4882a593Smuzhiyun #include <android/log.h>
34*4882a593Smuzhiyun #include <sys/system_properties.h>
35*4882a593Smuzhiyun #endif
36*4882a593Smuzhiyun 
37*4882a593Smuzhiyun #include "im2d_log.h"
38*4882a593Smuzhiyun 
39*4882a593Smuzhiyun static int rga_log_property_get(void);
40*4882a593Smuzhiyun static int rga_log_level_property_get(void);
41*4882a593Smuzhiyun 
42*4882a593Smuzhiyun __thread char g_rga_err_str[IM_ERR_MSG_LEN] = "The current error message is empty!";
43*4882a593Smuzhiyun static atomic_int g_log_en = ATOMIC_VAR_INIT(rga_log_property_get());
44*4882a593Smuzhiyun static atomic_int g_log_level = ATOMIC_VAR_INIT(rga_log_level_property_get());
45*4882a593Smuzhiyun static size_t g_start_time = rga_get_current_time_ms();
46*4882a593Smuzhiyun 
rga_error_msg_set(const char * format,...)47*4882a593Smuzhiyun int rga_error_msg_set(const char* format, ...) {
48*4882a593Smuzhiyun     int ret = 0;
49*4882a593Smuzhiyun     va_list ap;
50*4882a593Smuzhiyun 
51*4882a593Smuzhiyun     va_start(ap, format);
52*4882a593Smuzhiyun     ret = vsnprintf(g_rga_err_str, IM_ERR_MSG_LEN, format, ap);
53*4882a593Smuzhiyun     va_end(ap);
54*4882a593Smuzhiyun 
55*4882a593Smuzhiyun     return ret;
56*4882a593Smuzhiyun }
57*4882a593Smuzhiyun 
rga_log_property_get(void)58*4882a593Smuzhiyun static int inline rga_log_property_get(void) {
59*4882a593Smuzhiyun #ifdef ANDROID
60*4882a593Smuzhiyun     char level[PROP_VALUE_MAX];
61*4882a593Smuzhiyun     __system_property_get("vendor.rga.log" ,level);
62*4882a593Smuzhiyun #else
63*4882a593Smuzhiyun     char *level = getenv("ROCKCHIP_RGA_LOG");
64*4882a593Smuzhiyun     if (level == nullptr)
65*4882a593Smuzhiyun         level = (char *)"0";
66*4882a593Smuzhiyun #endif
67*4882a593Smuzhiyun 
68*4882a593Smuzhiyun     return atoi(level);
69*4882a593Smuzhiyun }
70*4882a593Smuzhiyun 
rga_log_level_property_get(void)71*4882a593Smuzhiyun static int inline rga_log_level_property_get(void) {
72*4882a593Smuzhiyun #ifdef ANDROID
73*4882a593Smuzhiyun     char level[PROP_VALUE_MAX];
74*4882a593Smuzhiyun     __system_property_get("vendor.rga.log_level" ,level);
75*4882a593Smuzhiyun #else
76*4882a593Smuzhiyun     char *level = getenv("ROCKCHIP_RGA_LOG_LEVEL");
77*4882a593Smuzhiyun     if (level == nullptr)
78*4882a593Smuzhiyun         level = (char *)"0";
79*4882a593Smuzhiyun #endif
80*4882a593Smuzhiyun 
81*4882a593Smuzhiyun     return atoi(level);
82*4882a593Smuzhiyun }
83*4882a593Smuzhiyun 
rga_log_level_init(void)84*4882a593Smuzhiyun int rga_log_level_init(void) {
85*4882a593Smuzhiyun     return rga_log_level_get();
86*4882a593Smuzhiyun }
87*4882a593Smuzhiyun 
rga_log_level_update(void)88*4882a593Smuzhiyun void rga_log_level_update(void) {
89*4882a593Smuzhiyun     g_log_level = rga_log_level_get();
90*4882a593Smuzhiyun }
91*4882a593Smuzhiyun 
rga_log_level_get(void)92*4882a593Smuzhiyun int rga_log_level_get(void) {
93*4882a593Smuzhiyun     return g_log_level;
94*4882a593Smuzhiyun }
95*4882a593Smuzhiyun 
rga_log_enable_get(void)96*4882a593Smuzhiyun int rga_log_enable_get(void) {
97*4882a593Smuzhiyun     return g_log_en;
98*4882a593Smuzhiyun }
99*4882a593Smuzhiyun 
rga_get_current_time_ms(void)100*4882a593Smuzhiyun size_t rga_get_current_time_ms(void) {
101*4882a593Smuzhiyun     struct timeval tv;
102*4882a593Smuzhiyun     gettimeofday(&tv,NULL);
103*4882a593Smuzhiyun     return tv.tv_sec * 1000 + tv.tv_usec / 1000;
104*4882a593Smuzhiyun }
105*4882a593Smuzhiyun 
rga_get_start_time_ms(void)106*4882a593Smuzhiyun size_t rga_get_start_time_ms(void) {
107*4882a593Smuzhiyun     return g_start_time;
108*4882a593Smuzhiyun }
109