Merge "Decrease size of LogBufferElements to 32 bytes." am: 44ad937411 am: e23b30a6da

am: 90c25cbdd3

Change-Id: Iaadb84c017b37edfaf54505c9aa845f1d9e4e67b
This commit is contained in:
Christopher Ferris 2017-08-15 17:09:59 +00:00 committed by android-build-merger
commit 784d6626fb
2 changed files with 47 additions and 31 deletions

View file

@ -41,22 +41,20 @@ LogBufferElement::LogBufferElement(log_id_t log_id, log_time realtime,
mTid(tid), mTid(tid),
mRealTime(realtime), mRealTime(realtime),
mMsgLen(len), mMsgLen(len),
mLogId(log_id) { mLogId(log_id),
mDropped(false) {
mMsg = new char[len]; mMsg = new char[len];
memcpy(mMsg, msg, len); memcpy(mMsg, msg, len);
mTag = (isBinary() && (mMsgLen >= sizeof(uint32_t)))
? le32toh(reinterpret_cast<android_event_header_t*>(mMsg)->tag)
: 0;
} }
LogBufferElement::LogBufferElement(const LogBufferElement& elem) LogBufferElement::LogBufferElement(const LogBufferElement& elem)
: mTag(elem.mTag), : mUid(elem.mUid),
mUid(elem.mUid),
mPid(elem.mPid), mPid(elem.mPid),
mTid(elem.mTid), mTid(elem.mTid),
mRealTime(elem.mRealTime), mRealTime(elem.mRealTime),
mMsgLen(elem.mMsgLen), mMsgLen(elem.mMsgLen),
mLogId(elem.mLogId) { mLogId(elem.mLogId),
mDropped(elem.mDropped) {
mMsg = new char[mMsgLen]; mMsg = new char[mMsgLen];
memcpy(mMsg, elem.mMsg, mMsgLen); memcpy(mMsg, elem.mMsg, mMsgLen);
} }
@ -65,6 +63,32 @@ LogBufferElement::~LogBufferElement() {
delete[] mMsg; delete[] mMsg;
} }
uint32_t LogBufferElement::getTag() const {
return (isBinary() &&
((mDropped && mMsg != nullptr) ||
(!mDropped && mMsgLen >= sizeof(android_event_header_t))))
? reinterpret_cast<const android_event_header_t*>(mMsg)->tag
: 0;
}
unsigned short LogBufferElement::setDropped(unsigned short value) {
// The tag information is saved in mMsg data, if the tag is non-zero
// save only the information needed to get the tag.
if (getTag() != 0) {
if (mMsgLen > sizeof(android_event_header_t)) {
char* truncated_msg = new char[sizeof(android_event_header_t)];
memcpy(truncated_msg, mMsg, sizeof(android_event_header_t));
delete[] mMsg;
mMsg = truncated_msg;
} // mMsgLen == sizeof(android_event_header_t), already at minimum.
} else {
delete[] mMsg;
mMsg = nullptr;
}
mDropped = true;
return mDroppedCount = value;
}
// caller must own and free character string // caller must own and free character string
char* android::tidToName(pid_t tid) { char* android::tidToName(pid_t tid) {
char* retval = NULL; char* retval = NULL;
@ -164,8 +188,8 @@ size_t LogBufferElement::populateDroppedMessage(char*& buffer, LogBuffer* parent
// identical to below to calculate the buffer size required // identical to below to calculate the buffer size required
const char* type = lastSame ? "identical" : "expire"; const char* type = lastSame ? "identical" : "expire";
size_t len = snprintf(NULL, 0, format_uid, mUid, name ? name : "", size_t len = snprintf(NULL, 0, format_uid, mUid, name ? name : "",
commName ? commName : "", type, mDropped, commName ? commName : "", type, getDropped(),
(mDropped > 1) ? "s" : ""); (getDropped() > 1) ? "s" : "");
size_t hdrLen; size_t hdrLen;
if (isBinary()) { if (isBinary()) {
@ -196,8 +220,8 @@ size_t LogBufferElement::populateDroppedMessage(char*& buffer, LogBuffer* parent
} }
snprintf(buffer + hdrLen, len + 1, format_uid, mUid, name ? name : "", snprintf(buffer + hdrLen, len + 1, format_uid, mUid, name ? name : "",
commName ? commName : "", type, mDropped, commName ? commName : "", type, getDropped(),
(mDropped > 1) ? "s" : ""); (getDropped() > 1) ? "s" : "");
free(const_cast<char*>(name)); free(const_cast<char*>(name));
free(const_cast<char*>(commName)); free(const_cast<char*>(commName));
@ -225,7 +249,7 @@ log_time LogBufferElement::flushTo(SocketClient* reader, LogBuffer* parent,
char* buffer = NULL; char* buffer = NULL;
if (!mMsg) { if (mDropped) {
entry.len = populateDroppedMessage(buffer, parent, lastSame); entry.len = populateDroppedMessage(buffer, parent, lastSame);
if (!entry.len) return mRealTime; if (!entry.len) return mRealTime;
iovec[1].iov_base = buffer; iovec[1].iov_base = buffer;

View file

@ -32,25 +32,25 @@ class LogBuffer;
// chatty for the temporal expire messages // chatty for the temporal expire messages
#define EXPIRE_RATELIMIT 10 // maximum rate in seconds to report expiration #define EXPIRE_RATELIMIT 10 // maximum rate in seconds to report expiration
class LogBufferElement { class __attribute__((packed)) LogBufferElement {
friend LogBuffer; friend LogBuffer;
// sized to match reality of incoming log packets // sized to match reality of incoming log packets
uint32_t mTag; // only valid for isBinary()
const uint32_t mUid; const uint32_t mUid;
const uint32_t mPid; const uint32_t mPid;
const uint32_t mTid; const uint32_t mTid;
log_time mRealTime; log_time mRealTime;
char* mMsg; char* mMsg;
union { union {
const uint16_t mMsgLen; // mMSg != NULL const uint16_t mMsgLen; // mDropped == false
uint16_t mDropped; // mMsg == NULL uint16_t mDroppedCount; // mDropped == true
}; };
const uint8_t mLogId; const uint8_t mLogId;
bool mDropped;
static atomic_int_fast64_t sequence; static atomic_int_fast64_t sequence;
// assumption: mMsg == NULL // assumption: mDropped == true
size_t populateDroppedMessage(char*& buffer, LogBuffer* parent, size_t populateDroppedMessage(char*& buffer, LogBuffer* parent,
bool lastSame); bool lastSame);
@ -58,7 +58,7 @@ class LogBufferElement {
LogBufferElement(log_id_t log_id, log_time realtime, uid_t uid, pid_t pid, LogBufferElement(log_id_t log_id, log_time realtime, uid_t uid, pid_t pid,
pid_t tid, const char* msg, unsigned short len); pid_t tid, const char* msg, unsigned short len);
LogBufferElement(const LogBufferElement& elem); LogBufferElement(const LogBufferElement& elem);
virtual ~LogBufferElement(); ~LogBufferElement();
bool isBinary(void) const { bool isBinary(void) const {
return (mLogId == LOG_ID_EVENTS) || (mLogId == LOG_ID_SECURITY); return (mLogId == LOG_ID_EVENTS) || (mLogId == LOG_ID_SECURITY);
@ -76,24 +76,16 @@ class LogBufferElement {
pid_t getTid(void) const { pid_t getTid(void) const {
return mTid; return mTid;
} }
uint32_t getTag() const { uint32_t getTag() const;
return mTag;
}
unsigned short getDropped(void) const { unsigned short getDropped(void) const {
return mMsg ? 0 : mDropped; return mDropped ? mDroppedCount : 0;
}
unsigned short setDropped(unsigned short value) {
if (mMsg) {
delete[] mMsg;
mMsg = NULL;
}
return mDropped = value;
} }
unsigned short setDropped(unsigned short value);
unsigned short getMsgLen() const { unsigned short getMsgLen() const {
return mMsg ? mMsgLen : 0; return mDropped ? 0 : mMsgLen;
} }
const char* getMsg() const { const char* getMsg() const {
return mMsg; return mDropped ? nullptr : mMsg;
} }
log_time getRealTime(void) const { log_time getRealTime(void) const {
return mRealTime; return mRealTime;