openpilot is an open source driver assistance system. openpilot performs the functions of Automated Lane Centering and Adaptive Cruise Control for over 200 supported car makes and models.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

124 lines
2.9 KiB

#ifndef _GNU_SOURCE
5 years ago
#define _GNU_SOURCE
#endif
5 years ago
#include "selfdrive/common/swaglog.h"
5 years ago
#include <cassert>
#include <cstring>
#include <mutex>
#include <string>
#include <zmq.h>
#include "json11.hpp"
5 years ago
#include "selfdrive/common/util.h"
#include "selfdrive/common/version.h"
#include "selfdrive/hardware/hw.h"
5 years ago
class LogState {
public:
LogState() = default;
~LogState();
std::mutex lock;
5 years ago
bool inited;
json11::Json::object ctx_j;
5 years ago
void *zctx;
void *sock;
int print_level;
};
LogState::~LogState() {
zmq_close(sock);
zmq_ctx_destroy(zctx);
}
5 years ago
static LogState s = {};
5 years ago
static void cloudlog_bind_locked(const char* k, const char* v) {
s.ctx_j[k] = v;
5 years ago
}
static void cloudlog_init() {
if (s.inited) return;
s.ctx_j = json11::Json::object {};
5 years ago
s.zctx = zmq_ctx_new();
s.sock = zmq_socket(s.zctx, ZMQ_PUSH);
int timeout = 100; // 100 ms timeout on shutdown for messages to be received by logmessaged
zmq_setsockopt(s.sock, ZMQ_LINGER, &timeout, sizeof(timeout));
5 years ago
zmq_connect(s.sock, "ipc:///tmp/logmessage");
s.print_level = CLOUDLOG_WARNING;
const char* print_level = getenv("LOGPRINT");
if (print_level) {
if (strcmp(print_level, "debug") == 0) {
s.print_level = CLOUDLOG_DEBUG;
} else if (strcmp(print_level, "info") == 0) {
s.print_level = CLOUDLOG_INFO;
} else if (strcmp(print_level, "warning") == 0) {
s.print_level = CLOUDLOG_WARNING;
}
}
// openpilot bindings
char* dongle_id = getenv("DONGLE_ID");
if (dongle_id) {
cloudlog_bind_locked("dongle_id", dongle_id);
}
cloudlog_bind_locked("version", COMMA_VERSION);
s.ctx_j["dirty"] = !getenv("CLEAN");
5 years ago
// device type
if (Hardware::EON()) {
cloudlog_bind_locked("device", "eon");
} else if (Hardware::TICI()) {
cloudlog_bind_locked("device", "tici");
} else {
cloudlog_bind_locked("device", "pc");
}
5 years ago
s.inited = true;
}
void log(int levelnum, const char* filename, int lineno, const char* func, const char* msg, const std::string& log_s) {
std::lock_guard lk(s.lock);
5 years ago
cloudlog_init();
if (levelnum >= s.print_level) {
printf("%s: %s\n", filename, msg);
}
char levelnum_c = levelnum;
zmq_send(s.sock, (levelnum_c + log_s).c_str(), log_s.length() + 1, ZMQ_NOBLOCK);
}
5 years ago
void cloudlog_e(int levelnum, const char* filename, int lineno, const char* func,
const char* fmt, ...) {
char* msg_buf = nullptr;
5 years ago
va_list args;
va_start(args, fmt);
vasprintf(&msg_buf, fmt, args);
va_end(args);
if (!msg_buf) return;
5 years ago
json11::Json log_j = json11::Json::object {
{"msg", msg_buf},
{"ctx", s.ctx_j},
{"levelnum", levelnum},
{"filename", filename},
{"lineno", lineno},
{"funcname", func},
{"created", seconds_since_epoch()}
};
std::string log_s = log_j.dump();
log(levelnum, filename, lineno, func, msg_buf, log_s);
5 years ago
free(msg_buf);
}
void cloudlog_bind(const char* k, const char* v) {
std::lock_guard lk(s.lock);
5 years ago
cloudlog_init();
cloudlog_bind_locked(k, v);
}