Files
mpp/osal/linux/os_log.cpp
Fenrir Lin 04a6811127 [osal]: syslog remove LOG_PERROR
Signed-off-by: Fenrir Lin <fenrir.lin@rock-chips.com>
Change-Id: I592b76a1d5f6fb0bbd8b36d2d5857ac29d16dc4d
2022-03-17 18:15:21 +08:00

64 lines
1.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(__gnu_linux__)
#include <stdio.h>
#include <stdarg.h>
#include <syslog.h>
#include "os_log.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()
{
openlog("mpp", LOG_PID | LOG_CONS, LOG_USER);
}
SyslogWrapper::~SyslogWrapper()
{
closelog();
}
void os_log(const char* tag, const char* msg, va_list list)
{
char line[LINE_SZ] = {0};
snprintf(line, sizeof(line), "%s: %s", tag, msg);
vsyslog(LOG_INFO, line, list);
}
void os_err(const char* tag, const char* msg, va_list list)
{
char line[LINE_SZ] = {0};
snprintf(line, sizeof(line), "%s: %s", tag, msg);
vsyslog(LOG_ERR, line, list);
}
#endif