Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(277)

Unified Diff: webrtc/base/messagequeue.cc

Issue 2019423006: Adding more detail to MessageQueue::Dispatch logging. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: webrtc/base/messagequeue.cc
diff --git a/webrtc/base/messagequeue.cc b/webrtc/base/messagequeue.cc
index e8b5bf5bc1f4836b91c1fddef30aad2fa071d6f1..7b8244612afd9ad66ce8bd6c3b16dd9167b8f7b9 100644
--- a/webrtc/base/messagequeue.cc
+++ b/webrtc/base/messagequeue.cc
@@ -13,11 +13,13 @@
#include "webrtc/base/common.h"
#include "webrtc/base/logging.h"
#include "webrtc/base/messagequeue.h"
+#include "webrtc/base/stringencode.h"
#include "webrtc/base/trace_event.h"
namespace rtc {
const int kMaxMsgLatency = 150; // 150 ms
+const int kSlowDispatchLoggingThreshold = 50; // 50 ms
//------------------------------------------------------------------
// MessageQueueManager
@@ -308,7 +310,8 @@ bool MessageQueue::Get(Message *pmsg, int cmsWait, bool process_io) {
void MessageQueue::ReceiveSends() {
}
-void MessageQueue::Post(MessageHandler* phandler,
+void MessageQueue::Post(const Location& posted_from,
+ MessageHandler* phandler,
uint32_t id,
MessageData* pdata,
bool time_sensitive) {
@@ -322,6 +325,7 @@ void MessageQueue::Post(MessageHandler* phandler,
{
CritScope cs(&crit_);
Message msg;
+ msg.posted_from = posted_from;
msg.phandler = phandler;
msg.message_id = id;
msg.pdata = pdata;
@@ -333,30 +337,36 @@ void MessageQueue::Post(MessageHandler* phandler,
WakeUpSocketServer();
}
-void MessageQueue::PostDelayed(int cmsDelay,
+void MessageQueue::PostDelayed(const Location& posted_from,
+ int cmsDelay,
MessageHandler* phandler,
uint32_t id,
MessageData* pdata) {
- return DoDelayPost(cmsDelay, TimeAfter(cmsDelay), phandler, id, pdata);
+ return DoDelayPost(posted_from, cmsDelay, TimeAfter(cmsDelay), phandler, id,
+ pdata);
}
-void MessageQueue::PostAt(uint32_t tstamp,
+void MessageQueue::PostAt(const Location& posted_from,
+ uint32_t tstamp,
MessageHandler* phandler,
uint32_t id,
MessageData* pdata) {
// This should work even if it is used (unexpectedly).
int delay = static_cast<uint32_t>(TimeMillis()) - tstamp;
- return DoDelayPost(delay, tstamp, phandler, id, pdata);
+ return DoDelayPost(posted_from, delay, tstamp, phandler, id, pdata);
}
-void MessageQueue::PostAt(int64_t tstamp,
+void MessageQueue::PostAt(const Location& posted_from,
+ int64_t tstamp,
MessageHandler* phandler,
uint32_t id,
MessageData* pdata) {
- return DoDelayPost(TimeUntil(tstamp), tstamp, phandler, id, pdata);
+ return DoDelayPost(posted_from, TimeUntil(tstamp), tstamp, phandler, id,
+ pdata);
}
-void MessageQueue::DoDelayPost(int cmsDelay,
+void MessageQueue::DoDelayPost(const Location& posted_from,
+ int cmsDelay,
int64_t tstamp,
MessageHandler* phandler,
uint32_t id,
@@ -371,6 +381,7 @@ void MessageQueue::DoDelayPost(int cmsDelay,
{
CritScope cs(&crit_);
Message msg;
+ msg.posted_from = posted_from;
msg.phandler = phandler;
msg.message_id = id;
msg.pdata = pdata;
@@ -451,8 +462,18 @@ void MessageQueue::Clear(MessageHandler* phandler,
}
void MessageQueue::Dispatch(Message *pmsg) {
- TRACE_EVENT0("webrtc", "MessageQueue::Dispatch");
+ TRACE_EVENT3("webrtc", "MessageQueue::Dispatch", "src_file",
+ pmsg->posted_from.file_name(), "src_func",
+ pmsg->posted_from.function_name(), "src_line",
+ pmsg->posted_from.line_number());
+ int64_t start_time = TimeMillis();
pmsg->phandler->OnMessage(pmsg);
+ int64_t end_time = TimeMillis();
+ int64_t diff = TimeDiff(end_time, start_time);
+ if (diff >= kSlowDispatchLoggingThreshold) {
+ LOG(LS_INFO) << "Message took " << diff << "ms to dispatch. Posted from: "
tommi 2016/05/31 19:56:27 LS_WARNING?
Taylor Brandstetter 2016/06/02 22:38:41 I'd prefer INFO since this is more for performance
pthatcher1 2016/06/03 00:09:30 INFO is fine.
+ << pmsg->posted_from.ToString();
+ }
}
} // namespace rtc

Powered by Google App Engine
This is Rietveld 408576698