Windows2003-3790/enduser/netmeeting/av/codecs/intel/h263/c3rtp.cpp
2020-09-30 16:53:55 +02:00

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