logcatd_android.cc: fix repeating the same messages (#23713)
* fix repeating the same message * cleanup * use blocking mode * check duplicate msg in testpull/23315/head^2
parent
12f74ade98
commit
ee85e7026a
2 changed files with 47 additions and 78 deletions
@ -1,72 +1,51 @@ |
|||||||
#include <sys/time.h> |
|
||||||
#include <sys/resource.h> |
|
||||||
|
|
||||||
#include <android/log.h> |
#include <android/log.h> |
||||||
#include <log/logger.h> |
#include <log/logger.h> |
||||||
#include <log/logprint.h> |
#include <log/logprint.h> |
||||||
|
#include <sys/resource.h> |
||||||
|
|
||||||
|
#include <csignal> |
||||||
|
|
||||||
#include "cereal/messaging/messaging.h" |
#include "cereal/messaging/messaging.h" |
||||||
#include "selfdrive/common/util.h" |
|
||||||
|
#undef LOG_ID_KERNEL |
||||||
|
#define LOG_ID_KERNEL 5 |
||||||
|
|
||||||
int main() { |
int main() { |
||||||
|
std::signal(SIGINT, exit); |
||||||
|
std::signal(SIGTERM, exit); |
||||||
setpriority(PRIO_PROCESS, 0, -15); |
setpriority(PRIO_PROCESS, 0, -15); |
||||||
|
|
||||||
ExitHandler do_exit; |
// setup android logging
|
||||||
PubMaster pm({"androidLog"}); |
logger_list *logger_list = android_logger_list_alloc(ANDROID_LOG_RDONLY, 0, 0); |
||||||
|
assert(logger_list); |
||||||
log_time last_log_time = {}; |
for (auto log_id : {LOG_ID_MAIN, LOG_ID_RADIO, LOG_ID_SYSTEM, LOG_ID_CRASH, (log_id_t)LOG_ID_KERNEL}) { |
||||||
logger_list *logger_list = android_logger_list_alloc(ANDROID_LOG_RDONLY | ANDROID_LOG_NONBLOCK, 0, 0); |
logger *logger = android_logger_open(logger_list, log_id); |
||||||
|
assert(logger); |
||||||
while (!do_exit) { |
|
||||||
// setup android logging
|
|
||||||
if (!logger_list) { |
|
||||||
logger_list = android_logger_list_alloc_time(ANDROID_LOG_RDONLY | ANDROID_LOG_NONBLOCK, last_log_time, 0); |
|
||||||
} |
|
||||||
assert(logger_list); |
|
||||||
|
|
||||||
struct logger *main_logger = android_logger_open(logger_list, LOG_ID_MAIN); |
|
||||||
assert(main_logger); |
|
||||||
struct logger *radio_logger = android_logger_open(logger_list, LOG_ID_RADIO); |
|
||||||
assert(radio_logger); |
|
||||||
struct logger *system_logger = android_logger_open(logger_list, LOG_ID_SYSTEM); |
|
||||||
assert(system_logger); |
|
||||||
struct logger *crash_logger = android_logger_open(logger_list, LOG_ID_CRASH); |
|
||||||
assert(crash_logger); |
|
||||||
struct logger *kernel_logger = android_logger_open(logger_list, (log_id_t)5); // LOG_ID_KERNEL
|
|
||||||
assert(kernel_logger); |
|
||||||
|
|
||||||
while (!do_exit) { |
|
||||||
log_msg log_msg; |
|
||||||
int err = android_logger_list_read(logger_list, &log_msg); |
|
||||||
if (err <= 0) break; |
|
||||||
|
|
||||||
AndroidLogEntry entry; |
|
||||||
err = android_log_processLogBuffer(&log_msg.entry_v1, &entry); |
|
||||||
if (err < 0) continue; |
|
||||||
last_log_time.tv_sec = entry.tv_sec; |
|
||||||
last_log_time.tv_nsec = entry.tv_nsec; |
|
||||||
|
|
||||||
MessageBuilder msg; |
|
||||||
auto androidEntry = msg.initEvent().initAndroidLog(); |
|
||||||
androidEntry.setId(log_msg.id()); |
|
||||||
androidEntry.setTs(entry.tv_sec * 1000000000ULL + entry.tv_nsec); |
|
||||||
androidEntry.setPriority(entry.priority); |
|
||||||
androidEntry.setPid(entry.pid); |
|
||||||
androidEntry.setTid(entry.tid); |
|
||||||
androidEntry.setTag(entry.tag); |
|
||||||
androidEntry.setMessage(entry.message); |
|
||||||
|
|
||||||
pm.send("androidLog", msg); |
|
||||||
} |
|
||||||
|
|
||||||
android_logger_list_free(logger_list); |
|
||||||
logger_list = NULL; |
|
||||||
util::sleep_for(500); |
|
||||||
} |
} |
||||||
|
|
||||||
if (logger_list) { |
PubMaster pm({"androidLog"}); |
||||||
android_logger_list_free(logger_list); |
|
||||||
|
while (true) { |
||||||
|
log_msg log_msg; |
||||||
|
int err = android_logger_list_read(logger_list, &log_msg); |
||||||
|
if (err <= 0) break; |
||||||
|
|
||||||
|
AndroidLogEntry entry; |
||||||
|
err = android_log_processLogBuffer(&log_msg.entry_v1, &entry); |
||||||
|
if (err < 0) continue; |
||||||
|
|
||||||
|
MessageBuilder msg; |
||||||
|
auto androidEntry = msg.initEvent().initAndroidLog(); |
||||||
|
androidEntry.setId(log_msg.id()); |
||||||
|
androidEntry.setTs(entry.tv_sec * NS_PER_SEC + entry.tv_nsec); |
||||||
|
androidEntry.setPriority(entry.priority); |
||||||
|
androidEntry.setPid(entry.pid); |
||||||
|
androidEntry.setTid(entry.tid); |
||||||
|
androidEntry.setTag(entry.tag); |
||||||
|
androidEntry.setMessage(entry.message); |
||||||
|
pm.send("androidLog", msg); |
||||||
} |
} |
||||||
|
|
||||||
|
android_logger_list_free(logger_list); |
||||||
return 0; |
return 0; |
||||||
} |
} |
||||||
|
Loading…
Reference in new issue