mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
474 lines
9.0 KiB
474 lines
9.0 KiB
#include "precomp.h"
|
|
|
|
|
|
#define ZONE_AP 1
|
|
|
|
|
|
|
|
#define _GetPlatform() (m_dwState & DP_MASK_PLATFORM)
|
|
#define _SetPlatform(s) (m_dwState = (m_dwState & ~DP_MASK_PLATFORM) | (s & DP_MASK_PLATFORM))
|
|
|
|
///////////////////////////////////////////////////////
|
|
//
|
|
// Public methods
|
|
//
|
|
|
|
|
|
MediaPacket::MediaPacket ( void )
|
|
{
|
|
_Construct ();
|
|
}
|
|
|
|
|
|
MediaPacket::~MediaPacket ( void )
|
|
{
|
|
_Destruct ();
|
|
}
|
|
|
|
|
|
HRESULT MediaPacket::Initialize ( MEDIAPACKETINIT * p )
|
|
{
|
|
HRESULT hr = DPR_SUCCESS;
|
|
|
|
FX_ENTRY ("AdPckt::Init")
|
|
|
|
if (p == NULL)
|
|
{
|
|
DEBUGMSG (ZONE_AP, ("%s: invalid parameter (null ptr)\r\n", _fx_));
|
|
return DPR_INVALID_PARAMETER;
|
|
}
|
|
|
|
_Construct ();
|
|
|
|
// we need to analyze flags to
|
|
// warn conflicting or insufficient flags
|
|
m_dwState |= p->dwFlags;
|
|
|
|
// get handle of stream conversion
|
|
m_hStrmConv = p->hStrmConv;
|
|
|
|
// get handle of wave device
|
|
// m_hDev = p->hDevAudio;
|
|
m_hDev = NULL;
|
|
|
|
// flags about prepared
|
|
m_fDevPrepared = FALSE;
|
|
m_fStrmPrepared = FALSE;
|
|
|
|
// set up wave formats
|
|
m_pStrmConvSrcFmt = p->pStrmConvSrcFmt;
|
|
m_pStrmConvDstFmt = p->pStrmConvDstFmt;
|
|
m_pDevFmt = p->pDevFmt;
|
|
m_payload = p->payload;
|
|
|
|
// net buffer
|
|
if (p->cbSizeNetData)
|
|
{ // send or recv
|
|
m_pNetData = (NETBUF *) LocalAlloc (LMEM_FIXED, p->cbSizeNetData + p->cbOffsetNetData + p->cbPayloadHeaderSize + sizeof (NETBUF));
|
|
if (m_pNetData == NULL)
|
|
{
|
|
DEBUGMSG (ZONE_AP, ("%s: MemAlloc1 (%ld) failed\r\n",
|
|
_fx_, (ULONG) (p->cbSizeNetData + p->cbOffsetNetData)));
|
|
hr = DPR_OUT_OF_MEMORY;
|
|
goto MyExit;
|
|
}
|
|
m_pNetData->data = (PBYTE) m_pNetData + p->cbOffsetNetData + p->cbPayloadHeaderSize + sizeof (NETBUF);
|
|
m_pNetData->length = p->cbSizeNetData;
|
|
m_cbMaxNetData = p->cbSizeNetData;
|
|
m_pNetData->pool = NULL;
|
|
}
|
|
else
|
|
{
|
|
#ifdef PREP_HDR_PER_CONV
|
|
// recv
|
|
m_pNetData = NULL;
|
|
#else
|
|
hr = DPR_INVALID_PARAMETER;
|
|
goto MyExit;
|
|
#endif
|
|
}
|
|
|
|
m_index = p->index;
|
|
|
|
// if m_pStrmConvDstFmt == m_pStrmConvSrcFmt,
|
|
// then m_pRawData <-- m_pNetData
|
|
// else allocate it
|
|
if (IsSameMediaFormat (m_pStrmConvSrcFmt, m_pStrmConvDstFmt))
|
|
{
|
|
m_pRawData = m_pNetData;
|
|
}
|
|
else if (p->fDontAllocRawBufs)
|
|
{
|
|
m_pRawData = NULL;
|
|
}
|
|
else
|
|
{
|
|
m_pRawData = (NETBUF *) LocalAlloc (LMEM_FIXED, p->cbSizeRawData + p->cbOffsetRawData + sizeof(NETBUF));
|
|
if (m_pRawData == NULL)
|
|
{
|
|
DEBUGMSG (ZONE_AP, ("%s: MemAlloc2 (%ld) failed\r\n",
|
|
_fx_, (ULONG) (p->cbSizeRawData + p->cbOffsetRawData)));
|
|
hr = DPR_OUT_OF_MEMORY;
|
|
goto MyExit;
|
|
}
|
|
m_pRawData->data = (PBYTE) m_pRawData + sizeof(NETBUF) + p->cbOffsetRawData;
|
|
m_pRawData->length = p->cbSizeRawData;
|
|
m_pRawData->pool = NULL;
|
|
}
|
|
|
|
// if m_pDevFmt == m_pStrmConvSrcFmt (when SEND)
|
|
// then m_pDevData <-- m_pRawData
|
|
// else allocate it
|
|
if (((m_dwState & DP_FLAG_SEND) &&
|
|
IsSameMediaFormat (m_pStrmConvSrcFmt, m_pDevFmt)) ||
|
|
((m_dwState & DP_FLAG_RECV) &&
|
|
IsSameMediaFormat (m_pStrmConvDstFmt, m_pDevFmt)))
|
|
{
|
|
// typical case - codec raw format matches that of i/o device
|
|
m_pDevData = m_pRawData;
|
|
}
|
|
else
|
|
{
|
|
// codec raw format doesnt match that of device
|
|
// BUGBUG: we dont really handle this case yet
|
|
m_pDevData = (NETBUF *) LocalAlloc (LMEM_FIXED, p->cbSizeDevData + p->cbOffsetDevData + sizeof(NETBUF));
|
|
if (m_pDevData == NULL)
|
|
{
|
|
DEBUGMSG (ZONE_AP, ("%s: MemAlloc3 (%ld) failed\r\n",
|
|
_fx_, (ULONG) (p->cbSizeDevData + p->cbOffsetDevData)));
|
|
hr = DPR_OUT_OF_MEMORY;
|
|
goto MyExit;
|
|
}
|
|
m_pDevData->data = (PBYTE) m_pDevData + sizeof(NETBUF) + p->cbOffsetDevData;
|
|
m_pDevData->length = p->cbSizeDevData;
|
|
m_pDevData->pool = NULL;
|
|
}
|
|
|
|
MakeSilence ();
|
|
|
|
MyExit:
|
|
|
|
if (hr == DPR_SUCCESS)
|
|
{
|
|
m_fInitialized = TRUE;
|
|
SetState (MP_STATE_RESET);
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
|
|
HRESULT MediaPacket::Receive ( NETBUF *pNetBuf, DWORD timestamp, UINT seq, UINT fMark )
|
|
{
|
|
m_seq = seq;
|
|
m_timestamp = timestamp;
|
|
m_fMark = fMark;
|
|
|
|
#ifdef PREP_HDR_PER_CONV
|
|
m_pNetData = pNetBuf;
|
|
#else
|
|
if (pNetBuf) // pNetBuf may be NULL for video
|
|
{
|
|
if (pNetBuf->length > m_cbMaxNetData)
|
|
return DPR_INVALID_PARAMETER;
|
|
if (m_pNetData && pNetBuf)
|
|
{
|
|
CopyMemory (m_pNetData->data, pNetBuf->data,
|
|
(m_pNetData->length = pNetBuf->length));
|
|
|
|
}
|
|
}
|
|
#endif
|
|
|
|
LOG(((m_dwState & DP_FLAG_VIDEO)? LOGMSG_VID_RECV: LOGMSG_AUD_RECV,m_index,seq,m_pNetData->length));
|
|
SetState (MP_STATE_NET_IN_STREAM);
|
|
return DPR_SUCCESS;
|
|
}
|
|
|
|
|
|
HRESULT MediaPacket::Recycle ( void )
|
|
{
|
|
HRESULT hr = DPR_SUCCESS;
|
|
|
|
FX_ENTRY ("MdPckt::Recycle")
|
|
|
|
LOG(((m_dwState & DP_FLAG_VIDEO)? LOGMSG_VID_RECYCLE: LOGMSG_AUD_RECYCLE, m_index));
|
|
if (m_dwState & DP_FLAG_RECV)
|
|
{
|
|
if (m_pRawData && m_pRawData->pool) {
|
|
m_pRawData->pool->ReturnBuffer((PVOID) m_pRawData);
|
|
if (m_pDevData == m_pRawData)
|
|
m_pDevData = NULL;
|
|
m_pRawData = NULL;
|
|
}
|
|
#ifdef PREP_HDR_PER_CONV
|
|
// free net data buffer
|
|
if (m_pNetData && m_pNetData->pool) m_pNetData->pool->ReturnBuffer ((PVOID) m_pNetData);
|
|
if (m_pNetData == m_pRawData) m_pRawData = NULL;
|
|
m_pNetData = NULL;
|
|
#endif
|
|
}
|
|
|
|
SetState (MP_STATE_RESET);
|
|
|
|
return hr;
|
|
}
|
|
|
|
|
|
HRESULT MediaPacket::GetProp ( DWORD dwPropId, PDWORD_PTR pdwPropVal )
|
|
{
|
|
HRESULT hr = DPR_SUCCESS;
|
|
|
|
FX_ENTRY ("AdPckt::GetProp")
|
|
|
|
if (pdwPropVal)
|
|
{
|
|
switch (dwPropId)
|
|
{
|
|
case MP_PROP_STATE:
|
|
*pdwPropVal = GetState ();
|
|
break;
|
|
|
|
case MP_PROP_PLATFORM:
|
|
*pdwPropVal = _GetPlatform ();
|
|
break;
|
|
|
|
case MP_PROP_DEV_MEDIA_FORMAT:
|
|
*pdwPropVal = (DWORD_PTR) m_pDevFmt;
|
|
break;
|
|
|
|
case MP_PROP_DEV_DATA:
|
|
*pdwPropVal = (DWORD_PTR) m_pDevData;
|
|
break;
|
|
|
|
case MP_PROP_DEV_HANDLE:
|
|
*pdwPropVal = (DWORD_PTR) m_hDev;
|
|
break;
|
|
|
|
case MP_PROP_DEV_MEDIA_HDR:
|
|
*pdwPropVal = (DWORD_PTR) m_pDevHdr;
|
|
break;
|
|
|
|
case MP_PROP_IN_STREAM_FORMAT:
|
|
*pdwPropVal = (DWORD_PTR) m_pStrmConvSrcFmt;
|
|
break;
|
|
|
|
case MP_PROP_OUT_STREAM_FORMAT:
|
|
*pdwPropVal = (DWORD_PTR) m_pStrmConvDstFmt;
|
|
break;
|
|
|
|
case MP_PROP_TIMESTAMP:
|
|
*pdwPropVal = (DWORD) m_timestamp;
|
|
break;
|
|
|
|
case MP_PROP_INDEX:
|
|
*pdwPropVal = (DWORD) m_index;
|
|
break;
|
|
|
|
case MP_PROP_PREAMBLE:
|
|
*pdwPropVal = (DWORD) m_fMark;
|
|
break;
|
|
|
|
case MP_PROP_FILTER_HEADER:
|
|
*pdwPropVal = (DWORD_PTR) m_pStrmConvHdr;
|
|
break;
|
|
|
|
case MP_PROP_MAX_NET_LENGTH:
|
|
*pdwPropVal = m_cbMaxNetData;
|
|
break;
|
|
|
|
|
|
default:
|
|
hr = DPR_INVALID_PROP_ID;
|
|
break;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
hr = DPR_INVALID_PARAMETER;
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
|
|
HRESULT MediaPacket::SetProp ( DWORD dwPropId, DWORD_PTR dwPropVal )
|
|
{
|
|
HRESULT hr = DPR_SUCCESS;
|
|
|
|
FX_ENTRY ("AdPckt::SetProp")
|
|
|
|
switch (dwPropId)
|
|
{
|
|
case MP_PROP_STATE:
|
|
SetState ((DWORD)dwPropVal);
|
|
break;
|
|
|
|
case MP_PROP_PLATFORM:
|
|
_SetPlatform ((DWORD)dwPropVal);
|
|
break;
|
|
|
|
case MP_PROP_DEV_MEDIA_FORMAT:
|
|
case MP_PROP_IN_STREAM_FORMAT:
|
|
case MP_PROP_OUT_STREAM_FORMAT:
|
|
hr = DPR_IMPOSSIBLE_SET_PROP;
|
|
break;
|
|
|
|
case MP_PROP_TIMESTAMP:
|
|
m_timestamp = (DWORD)dwPropVal;
|
|
break;
|
|
|
|
case MP_PROP_PREAMBLE:
|
|
m_fMark = dwPropVal ? 1 : 0;
|
|
break;
|
|
|
|
default:
|
|
hr = DPR_INVALID_PROP_ID;
|
|
break;
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
|
|
HRESULT MediaPacket::Release ( void )
|
|
{
|
|
_Destruct ();
|
|
return DPR_SUCCESS;
|
|
}
|
|
|
|
BOOL MediaPacket::SetDecodeBuffer(NETBUF *pBuf)
|
|
{
|
|
ASSERT(!m_pRawData);
|
|
m_pRawData = pBuf;
|
|
if (!m_pDevData) m_pDevData = pBuf;
|
|
return TRUE;
|
|
}
|
|
|
|
///////////////////////////////////////////////////////
|
|
//
|
|
// Private methods
|
|
//
|
|
|
|
|
|
void MediaPacket::_Construct ( void )
|
|
{
|
|
m_hStrmConv = NULL;
|
|
m_pStrmConvHdr = NULL;
|
|
m_pStrmConvSrcFmt = NULL;
|
|
m_pStrmConvDstFmt = NULL;
|
|
|
|
m_hDev = NULL;
|
|
m_pDevHdr = NULL;
|
|
m_pDevFmt = NULL;
|
|
|
|
m_pDevData = NULL;
|
|
m_pRawData = NULL;
|
|
m_pNetData = NULL;
|
|
|
|
m_dwState = 0;
|
|
m_fBusy = FALSE;
|
|
m_timestamp = 0;
|
|
m_seq = 0;
|
|
m_index = 0;
|
|
m_fMark = 0;
|
|
|
|
m_cbValidRawData = 0;
|
|
|
|
m_fRendering = FALSE;
|
|
|
|
m_fInitialized = FALSE;
|
|
|
|
}
|
|
|
|
|
|
void MediaPacket::_Destruct ( void )
|
|
{
|
|
if (m_fInitialized)
|
|
{
|
|
if (m_pDevHdr) MemFree (m_pDevHdr);
|
|
m_pDevHdr = NULL;
|
|
|
|
if (m_pStrmConvHdr) MemFree (m_pStrmConvHdr);
|
|
m_pStrmConvHdr = NULL;
|
|
|
|
if (m_pDevData == m_pRawData) m_pDevData = NULL;
|
|
if (m_pRawData == m_pNetData) m_pRawData = NULL;
|
|
|
|
if (m_pDevData) {
|
|
if (m_pDevData->pool)
|
|
m_pDevData->pool->ReturnBuffer((PVOID) m_pDevData);
|
|
else
|
|
LocalFree (m_pDevData);
|
|
m_pDevData = NULL;
|
|
}
|
|
|
|
if (m_pRawData) {
|
|
if (m_pRawData->pool)
|
|
m_pRawData->pool->ReturnBuffer((PVOID) m_pRawData);
|
|
else
|
|
LocalFree (m_pRawData);
|
|
m_pRawData = NULL;
|
|
}
|
|
|
|
if (m_pNetData && m_pNetData->pool)
|
|
m_pNetData->pool->ReturnBuffer ((PVOID) m_pNetData);
|
|
else if (m_pNetData)
|
|
LocalFree (m_pNetData);
|
|
m_pNetData = NULL;
|
|
|
|
SetState (MP_STATE_RESET);
|
|
|
|
m_fInitialized = FALSE;
|
|
}
|
|
}
|
|
|
|
HRESULT MediaPacket::GetDevData(PVOID *ppData, PUINT pcbData)
|
|
{
|
|
if (!ppData || !pcbData)
|
|
return DPR_INVALID_PARAMETER;
|
|
|
|
if (m_pDevData) {
|
|
*ppData = m_pDevData->data;
|
|
*pcbData = m_pDevData->length;
|
|
} else {
|
|
*ppData = NULL;
|
|
*pcbData = 0;
|
|
}
|
|
|
|
return DPR_SUCCESS;
|
|
}
|
|
|
|
HRESULT MediaPacket::GetNetData(PVOID *ppData, PUINT pcbData)
|
|
{
|
|
|
|
if (!ppData || !pcbData)
|
|
return DPR_INVALID_PARAMETER;
|
|
|
|
if (m_pNetData) {
|
|
*ppData = m_pNetData->data;
|
|
*pcbData = m_pNetData->length;
|
|
} else {
|
|
*ppData = NULL;
|
|
*pcbData = 0;
|
|
}
|
|
|
|
return DPR_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
HRESULT MediaPacket::SetNetLength(UINT uLength)
|
|
{
|
|
if ((m_pNetData) && (m_pNetData->data))
|
|
{
|
|
m_pNetData->length = uLength;
|
|
}
|
|
else
|
|
{
|
|
return E_FAIL;
|
|
}
|
|
return S_OK;
|
|
}
|
|
|
|
|