202 lines
5.8 KiB
C++
202 lines
5.8 KiB
C++
/* *************************************************************************
|
|
** INTEL Corporation Proprietary Information
|
|
**
|
|
** This listing is supplied under the terms of a license
|
|
** agreement with INTEL Corporation and may not be copied
|
|
** nor disclosed except in accordance with the terms of
|
|
** that agreement.
|
|
**
|
|
** Copyright (c) 1995 Intel Corporation.
|
|
** Copyright (c) 1996 Intel Corporation.
|
|
** All Rights Reserved.
|
|
**
|
|
** *************************************************************************
|
|
// $Header: S:\h26x\src\common\c3rtp.cpv 1.8 03 Dec 1996 13:16:16 CZHU $
|
|
// $Log: S:\h26x\src\common\c3rtp.cpv $
|
|
//
|
|
// Rev 1.8 03 Dec 1996 13:16:16 CZHU
|
|
// adjust format of debug message.
|
|
//
|
|
// Rev 1.7 26 Nov 1996 16:00:26 GMLIM
|
|
// Increase size returned by getrtpBsInfoSize() for larger PB bs info buffer.
|
|
//
|
|
// Rev 1.6 06 Nov 1996 15:11:42 CZHU
|
|
// Added minor change for debug output
|
|
//
|
|
// Rev 1.5 31 Oct 1996 10:12:36 KLILLEVO
|
|
// changed from DBOUT to DBgLog
|
|
//
|
|
// Rev 1.4 17 Sep 1996 09:22:58 CZHU
|
|
// minor cleaning
|
|
//
|
|
// Rev 1.3 16 Sep 1996 16:38:44 CZHU
|
|
// Extended the minimum packet size to 128 bytes. Fixed buffer overflow bug
|
|
//
|
|
// Rev 1.2 02 May 1996 13:27:04 CZHU
|
|
// Adjust for merging with main database in the decoder
|
|
//
|
|
// Rev 1.1 28 Apr 1996 20:34:50 BECHOLS
|
|
//
|
|
// Removed IFDEF -- RTP_HEADER.
|
|
//
|
|
// Rev 1.0 22 Apr 1996 17:47:54 BECHOLS
|
|
// Initial revision.
|
|
//
|
|
// Rev 1.3 10 Apr 1996 13:32:08 CZHU
|
|
//
|
|
// Moved testing packet loss into this module for common use by encoder or dec
|
|
//
|
|
// Rev 1.2 29 Mar 1996 14:45:06 CZHU
|
|
//
|
|
// Rev 1.1 29 Mar 1996 14:39:34 CZHU
|
|
// Some cleaning
|
|
//
|
|
// Rev 1.0 29 Mar 1996 13:32:42 CZHU
|
|
// Initial revision.
|
|
//
|
|
*/
|
|
#include "precomp.h"
|
|
|
|
const int MAX_RATE = 2*1024*1024 ;//set this limit for now
|
|
|
|
I32 H263RTP_VerifyBsInfoStream(
|
|
T_H263DecoderCatalog *DC,
|
|
U8 *pu8Src,
|
|
U32 uSize
|
|
)
|
|
{
|
|
T_H263_RTP_BSINFO_TRAILER *pBsTrailer;
|
|
T_RTP_H263_BSINFO *pBsInfo;
|
|
int i;
|
|
int iRet = FALSE;
|
|
|
|
FX_ENTRY("H263RTP_VerifyBsInfoStream")
|
|
|
|
ASSERT(!DC->iVerifiedBsExt);
|
|
|
|
DC->iVerifiedBsExt=TRUE;
|
|
pBsTrailer =(T_H263_RTP_BSINFO_TRAILER *)(pu8Src + uSize);
|
|
pBsTrailer--;
|
|
|
|
DEBUGMSG (ZONE_DECODE_RTP, ("%s: StartCode = %8ld, CompSize=%8ld, No.Pack=%4ld, SRC=%4d, TR=%4d, TRB=%4d, DBQ=%2d\r\n", _fx_, pBsTrailer->uUniqueCode, pBsTrailer->uCompressedSize, pBsTrailer->uNumOfPackets, pBsTrailer->u8Src, pBsTrailer->u8TR,pBsTrailer->u8TRB,pBsTrailer->u8DBQ));
|
|
|
|
if (pBsTrailer->uUniqueCode != H263_RTP_BS_START_CODE)
|
|
{
|
|
//#ifdef LOSS_RECOVERY
|
|
DEBUGMSG (ZONE_DECODE_RTP, ("%s: No RTP BS Extension found\r\n", _fx_));
|
|
DC->iValidBsExt = FALSE;
|
|
DC->uNumOfPackets = 0;
|
|
DC->pBsInfo = NULL;
|
|
DC->pBsTrailer = NULL;
|
|
|
|
//#endif
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
//bitstream is valid, so...
|
|
pBsInfo = (T_RTP_H263_BSINFO *)pBsTrailer;
|
|
pBsInfo -= pBsTrailer->uNumOfPackets;
|
|
|
|
//#ifdef LOSS_RECOVERY
|
|
DC->pBsTrailer = (void *)pBsTrailer;
|
|
DC->uNumOfPackets = pBsTrailer->uNumOfPackets;
|
|
DC->iValidBsExt =TRUE;
|
|
DC->pBsInfo = (void *)pBsInfo;
|
|
//#endif
|
|
|
|
for (i=0; i< (int)pBsTrailer->uNumOfPackets; i++)
|
|
{
|
|
DEBUGMSG (ZONE_DECODE_RTP, ("%s: uFlag =%2d,BitOffset=%8d, Mode=%2d, MBA=%4d, uQuant=%2d,GOBN=%2d\r\n", _fx_, pBsInfo->uFlags, pBsInfo->uBitOffset, pBsInfo->u8Mode, pBsInfo->u8MBA, pBsInfo->u8Quant, pBsInfo->u8GOBN));
|
|
pBsInfo++;
|
|
}
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
//#ifdef LOSS_RECOVERY
|
|
void RtpForcePacketLoss(
|
|
U8 * pDst,
|
|
U32 uExtSize,
|
|
U32 uLossNum)
|
|
{
|
|
T_H263_RTP_BSINFO_TRAILER *pTrailer;
|
|
T_RTP_H263_BSINFO *pBsInfo, *pBsInfoNext;
|
|
U32 uNum;
|
|
// U32 uDelta,u, U32 uToCopy;
|
|
U8 * ptr;
|
|
U8 mask[]={0, 0x80, 0xc0, 0xe0, 0xf0,0xf8,0xfc,0xfe};
|
|
|
|
//throw away packet number uPNum packet
|
|
pTrailer =(T_H263_RTP_BSINFO_TRAILER *)(pDst+uExtSize);
|
|
pTrailer--;
|
|
|
|
if (pTrailer->uUniqueCode != H263_RTP_BS_START_CODE)
|
|
{
|
|
goto ret;
|
|
}
|
|
|
|
pBsInfo = (T_RTP_H263_BSINFO *)pTrailer;
|
|
pBsInfo -= pTrailer->uNumOfPackets; //point at the beginning of the BS_INFO
|
|
|
|
for (uNum =0; uNum < pTrailer->uNumOfPackets-1; uNum++)
|
|
{ pBsInfoNext = pBsInfo+1; //exclude the last packet
|
|
// if (pBsInfoNext->u8Mode == RTP_H263_MODE_B)
|
|
if (uNum == uLossNum)
|
|
{
|
|
pBsInfo->uFlags |= RTP_H26X_PACKET_LOST;
|
|
ptr = (U8 *)(pDst + (pBsInfo->uBitOffset)/8);
|
|
*ptr = *ptr & mask[pBsInfo->uBitOffset % 8];
|
|
if ( pBsInfo->uBitOffset % 8) ptr++;
|
|
|
|
*ptr++ = 0; //add dword of 0
|
|
*ptr++ = 0;
|
|
if (uNum)
|
|
{
|
|
*ptr++ = 0;
|
|
*ptr++ = 0;
|
|
}
|
|
else
|
|
{//first packet with PSC
|
|
*ptr++ = 128;
|
|
*ptr++ =3;
|
|
}
|
|
break;
|
|
}
|
|
pBsInfo++;
|
|
}
|
|
ret:
|
|
return;
|
|
}
|
|
|
|
/////////////////////////////////////////////////////////
|
|
// return the size of memory used for bitstream extension
|
|
// rate up limit set to 1MB for now.
|
|
// Chad, 9/13/96
|
|
/////////////////////////////////////////////////////////
|
|
|
|
DWORD getRTPBsInfoSize(LPCODINST lpInst)
|
|
{
|
|
FX_ENTRY("getRTPBsInfoSize");
|
|
|
|
DWORD dwExtSize = 1024UL;
|
|
DWORD dwNumGOBs;
|
|
DWORD dwNumPacketsPerGOB;
|
|
|
|
// Get the max number of GOBs
|
|
dwNumGOBs = (lpInst->FrameSz == SQCIF) ? 6 : (lpInst->FrameSz == QCIF) ? 9 : (lpInst->FrameSz == QCIF) ? 18 : 0;
|
|
|
|
// Assume there will be at least one header per GOB - worse case
|
|
// Double estimated size to be safe
|
|
if ((lpInst->FrameRate != 0.0f) && dwNumGOBs && lpInst->Configuration.unPacketSize)
|
|
{
|
|
dwNumPacketsPerGOB = (DWORD)(lpInst->DataRate / lpInst->FrameRate) / dwNumGOBs / lpInst->Configuration.unPacketSize + 1;
|
|
dwExtSize = (DWORD)(dwNumPacketsPerGOB * dwNumGOBs * sizeof(T_RTP_H263_BSINFO) + sizeof(T_H263_RTP_BSINFO_TRAILER)) << 1;
|
|
}
|
|
|
|
return (dwExtSize);
|
|
}
|
|
|
|
//#endif
|
|
|