ref: 0ff1eb482f7bf0e1acaa2f913f4f5345ef95974c
parent: ec99819ce83a29982cb73c9d434155ee8e8ed2f9
parent: 3e57fdc448656d6e7906cdc0fb069e7e71d6d64c
author: sijchen <sijchen@cisco.com>
date: Thu Dec 11 12:01:38 EST 2014
Merge pull request #1612 from huili2/log_add_this_codec add this log for codec
--- a/codec/common/inc/utils.h
+++ b/codec/common/inc/utils.h
@@ -54,6 +54,7 @@
typedef struct TagLogContext {
PWelsLogCallbackFunc pfLog;
void* pLogCtx;
+ void* pCodecInstance;
} SLogContext;
--- a/codec/common/inc/welsCodecTrace.h
+++ b/codec/common/inc/welsCodecTrace.h
@@ -44,6 +44,7 @@
welsCodecTrace();
~welsCodecTrace();
+ void SetCodecInstance (void* pCodecInstance);
void SetTraceLevel (const int32_t kiLevel);
void SetTraceCallback (WelsTraceCallback func);
void SetTraceCallbackContext (void* pCtx);
--- a/codec/common/src/utils.cpp
+++ b/codec/common/src/utils.cpp
@@ -53,19 +53,19 @@
char pTraceTag[MAX_LOG_SIZE];
switch (iLevel) {
case WELS_LOG_ERROR:
- WelsSnprintf (pTraceTag, MAX_LOG_SIZE, "[OpenH264] Error:");
+ WelsSnprintf (pTraceTag, MAX_LOG_SIZE, "[OpenH264] this = 0x%p, Error:", logCtx->pCodecInstance);
break;
case WELS_LOG_WARNING:
- WelsSnprintf (pTraceTag, MAX_LOG_SIZE, "[OpenH264] Warning:");
+ WelsSnprintf (pTraceTag, MAX_LOG_SIZE, "[OpenH264] this = 0x%p, Warning:", logCtx->pCodecInstance);
break;
case WELS_LOG_INFO:
- WelsSnprintf (pTraceTag, MAX_LOG_SIZE, "[OpenH264] Info:");
+ WelsSnprintf (pTraceTag, MAX_LOG_SIZE, "[OpenH264] this = 0x%p, Info:", logCtx->pCodecInstance);
break;
case WELS_LOG_DEBUG:
- WelsSnprintf (pTraceTag, MAX_LOG_SIZE, "[OpenH264] Debug:");
+ WelsSnprintf (pTraceTag, MAX_LOG_SIZE, "[OpenH264] this = 0x%p, Debug:", logCtx->pCodecInstance);
break;
default:
- WelsSnprintf (pTraceTag, MAX_LOG_SIZE, "[OpenH264] Detail:");
+ WelsSnprintf (pTraceTag, MAX_LOG_SIZE, "[OpenH264] this = 0x%p, Detail:", logCtx->pCodecInstance);
break;
}
WelsStrcat (pTraceTag, MAX_LOG_SIZE, kpFmt);
--- a/codec/common/src/welsCodecTrace.cpp
+++ b/codec/common/src/welsCodecTrace.cpp
@@ -83,6 +83,10 @@
}
}
+void welsCodecTrace::SetCodecInstance (void* pCodecInstance) {
+ m_sLogCtx.pCodecInstance = pCodecInstance;
+}
+
void welsCodecTrace::SetTraceLevel (const int32_t iLevel) {
if (iLevel >= 0)
m_iTraceLevel = iLevel;
--- a/codec/decoder/plus/src/welsDecoderExt.cpp
+++ b/codec/decoder/plus/src/welsDecoderExt.cpp
@@ -104,6 +104,7 @@
m_pWelsTrace = new welsCodecTrace();
if (m_pWelsTrace != NULL) {
+ m_pWelsTrace->SetCodecInstance (this);
m_pWelsTrace->SetTraceLevel (WELS_LOG_ERROR);
WelsLog (&m_pWelsTrace->m_sLogCtx, WELS_LOG_INFO, "CWelsDecoder::CWelsDecoder() entry");
--- a/codec/encoder/plus/src/welsEncoderExt.cpp
+++ b/codec/encoder/plus/src/welsEncoderExt.cpp
@@ -166,6 +166,7 @@
if (m_pWelsTrace == NULL) {
return;
}
+ m_pWelsTrace->SetCodecInstance (this);
}
/* Interfaces override from ISVCEncoder */