2015-08-28 15:02:59 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2012-2015 The Android Open Source Project
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2020-05-01 23:45:25 +00:00
|
|
|
#pragma once
|
2015-08-28 15:02:59 +00:00
|
|
|
|
2016-02-08 18:28:12 +00:00
|
|
|
#include <sys/cdefs.h>
|
2015-08-28 15:02:59 +00:00
|
|
|
#include <sys/types.h>
|
|
|
|
|
2016-09-30 20:30:33 +00:00
|
|
|
#include <private/android_logger.h>
|
2015-12-04 18:59:45 +00:00
|
|
|
#include <sysutils/SocketClient.h>
|
2017-03-10 22:31:54 +00:00
|
|
|
#include <utils/FastStrcmp.h>
|
2015-08-28 15:02:59 +00:00
|
|
|
|
|
|
|
// Hijack this header as a common include file used by most all sources
|
|
|
|
// to report some utilities defined here and there.
|
|
|
|
|
|
|
|
namespace android {
|
|
|
|
|
|
|
|
// Furnished in main.cpp. Caller must own and free returned value
|
2017-03-10 22:31:54 +00:00
|
|
|
char* uidToName(uid_t uid);
|
2015-08-28 15:02:59 +00:00
|
|
|
|
2016-09-12 17:29:17 +00:00
|
|
|
// Caller must own and free returned value
|
2017-03-10 22:31:54 +00:00
|
|
|
char* pidToName(pid_t pid);
|
|
|
|
char* tidToName(pid_t tid);
|
2015-08-28 15:02:59 +00:00
|
|
|
|
2016-09-12 21:51:54 +00:00
|
|
|
// Furnished in LogTags.cpp. Thread safe.
|
2017-03-10 22:31:54 +00:00
|
|
|
const char* tagToName(uint32_t tag);
|
2015-08-28 15:02:59 +00:00
|
|
|
|
2016-08-11 15:02:06 +00:00
|
|
|
// Furnished by LogKlog.cpp
|
|
|
|
char* log_strntok_r(char* s, ssize_t& len, char*& saveptr, ssize_t& sublen);
|
|
|
|
|
|
|
|
// needle should reference a string longer than 1 character
|
|
|
|
static inline const char* strnstr(const char* s, ssize_t len,
|
|
|
|
const char* needle) {
|
|
|
|
if (len <= 0) return nullptr;
|
|
|
|
|
|
|
|
const char c = *needle++;
|
|
|
|
const size_t needleLen = strlen(needle);
|
|
|
|
do {
|
|
|
|
do {
|
|
|
|
if (len <= (ssize_t)needleLen) return nullptr;
|
|
|
|
--len;
|
|
|
|
} while (*s++ != c);
|
|
|
|
} while (fastcmp<memcmp>(s, needle, needleLen));
|
|
|
|
s--;
|
|
|
|
return s;
|
|
|
|
}
|
2015-08-28 15:02:59 +00:00
|
|
|
}
|
|
|
|
|
2020-06-02 22:39:21 +00:00
|
|
|
// Returns true if the log buffer is meant for binary logs.
|
|
|
|
static inline bool IsBinary(log_id_t log_id) {
|
|
|
|
return log_id == LOG_ID_EVENTS || log_id == LOG_ID_STATS || log_id == LOG_ID_SECURITY;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Returns the numeric log tag for binary log messages.
|
|
|
|
static inline uint32_t MsgToTag(const char* msg, uint16_t msg_len) {
|
|
|
|
if (msg_len < sizeof(android_event_header_t)) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
return reinterpret_cast<const android_event_header_t*>(msg)->tag;
|
|
|
|
}
|
|
|
|
|
2015-08-28 15:02:59 +00:00
|
|
|
static inline bool worstUidEnabledForLogid(log_id_t id) {
|
2016-07-14 22:34:30 +00:00
|
|
|
return (id == LOG_ID_MAIN) || (id == LOG_ID_SYSTEM) ||
|
2017-03-10 22:31:54 +00:00
|
|
|
(id == LOG_ID_RADIO) || (id == LOG_ID_EVENTS);
|
2015-08-28 15:02:59 +00:00
|
|
|
}
|