mirror of
				https://github.com/nyanmisaka/mpp.git
				synced 2025-10-31 04:26:39 +08:00 
			
		
		
		
	 0f0d28c2ec
			
		
	
	0f0d28c2ec
	
	
	
		
			
			Tested on RK3588 EVB with musl-1.2.2 and gcc-10.2. Change-Id: I10574446f46964bad5e67ab45c76060a193b8335 Signed-off-by: Jeffy Chen <jeffy.chen@rock-chips.com>
		
			
				
	
	
		
			100 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright 2015 Rockchip Electronics Co. LTD
 | |
|  *
 | |
|  * Licensed under the Apache License, Version 2.0 (the "License");
 | |
|  * you may not use this file except in compliance with the License.
 | |
|  * You may obtain a copy of the License at
 | |
|  *
 | |
|  *      http://www.apache.org/licenses/LICENSE-2.0
 | |
|  *
 | |
|  * Unless required by applicable law or agreed to in writing, software
 | |
|  * distributed under the License is distributed on an "AS IS" BASIS,
 | |
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
|  * See the License for the specific language governing permissions and
 | |
|  * limitations under the License.
 | |
|  */
 | |
| 
 | |
| #if defined(linux) && !defined(__ANDROID__)
 | |
| #include <stdio.h>
 | |
| #include <stdarg.h>
 | |
| #include <syslog.h>
 | |
| 
 | |
| #include "os_log.h"
 | |
| #include "os_env.h"
 | |
| 
 | |
| #define LINE_SZ 1024
 | |
| 
 | |
| class SyslogWrapper
 | |
| {
 | |
| private:
 | |
|     // avoid any unwanted function
 | |
|     SyslogWrapper(const SyslogWrapper &);
 | |
|     SyslogWrapper &operator=(const SyslogWrapper &);
 | |
| public:
 | |
|     SyslogWrapper();
 | |
|     ~SyslogWrapper();
 | |
| };
 | |
| 
 | |
| static SyslogWrapper syslog_wrapper;
 | |
| 
 | |
| SyslogWrapper::SyslogWrapper()
 | |
| {
 | |
|     int option = LOG_PID | LOG_CONS;
 | |
|     RK_U32 syslog_perror = 0;
 | |
| 
 | |
|     os_get_env_u32("mpp_syslog_perror", &syslog_perror, 0);
 | |
|     if (syslog_perror)
 | |
|         option |= LOG_PERROR;
 | |
| 
 | |
|     openlog("mpp", option, LOG_USER);
 | |
| }
 | |
| 
 | |
| SyslogWrapper::~SyslogWrapper()
 | |
| {
 | |
|     closelog();
 | |
| }
 | |
| 
 | |
| void os_log_trace(const char* tag, const char* msg, va_list list)
 | |
| {
 | |
|     char line[LINE_SZ] = {0};
 | |
|     snprintf(line, sizeof(line) - 1, "%s: %s", tag, msg);
 | |
|     vsyslog(LOG_NOTICE, line, list);
 | |
| }
 | |
| 
 | |
| void os_log_debug(const char* tag, const char* msg, va_list list)
 | |
| {
 | |
|     char line[LINE_SZ] = {0};
 | |
|     snprintf(line, sizeof(line) - 1, "%s: %s", tag, msg);
 | |
|     vsyslog(LOG_DEBUG, line, list);
 | |
| }
 | |
| 
 | |
| void os_log_info(const char* tag, const char* msg, va_list list)
 | |
| {
 | |
|     char line[LINE_SZ] = {0};
 | |
|     snprintf(line, sizeof(line) - 1, "%s: %s", tag, msg);
 | |
|     vsyslog(LOG_INFO, line, list);
 | |
| }
 | |
| 
 | |
| void os_log_warn(const char* tag, const char* msg, va_list list)
 | |
| {
 | |
|     char line[LINE_SZ] = {0};
 | |
|     snprintf(line, sizeof(line) - 1, "%s: %s", tag, msg);
 | |
|     vsyslog(LOG_WARNING, line, list);
 | |
| }
 | |
| 
 | |
| void os_log_error(const char* tag, const char* msg, va_list list)
 | |
| {
 | |
|     char line[LINE_SZ] = {0};
 | |
|     snprintf(line, sizeof(line) - 1, "%s: %s", tag, msg);
 | |
|     vsyslog(LOG_ERR, line, list);
 | |
| }
 | |
| 
 | |
| void os_log_fatal(const char* tag, const char* msg, va_list list)
 | |
| {
 | |
|     char line[LINE_SZ] = {0};
 | |
|     snprintf(line, sizeof(line) - 1, "%s: %s", tag, msg);
 | |
|     vsyslog(LOG_CRIT, line, list);
 | |
| }
 | |
| 
 | |
| #endif
 |