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

153 lines
4.0 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.
** All Rights Reserved.
**
** *************************************************************************
*/
/*****************************************************************************
* exbitsio.cpp
*
* Description:
* Routines to write fields to a bit stream buffer.
*
* Routines: Prototypes in:
* BSWriteField e3enc.h
*/
//
// $Author: RMCKENZX $
// $Date: 27 Dec 1995 15:32:50 $
// $Archive: S:\h26x\src\enc\exbitsio.cpv $
// $Header: S:\h26x\src\enc\exbitsio.cpv 1.5 27 Dec 1995 15:32:50 RMCKENZX $
// $Log: S:\h26x\src\enc\exbitsio.cpv $
//
// Rev 1.5 27 Dec 1995 15:32:50 RMCKENZX
// Added copyright notice
//
// Rev 1.4 09 Nov 1995 14:11:22 AGUPTA2
// PB-frame+performance+structure enhancements.
//
// Rev 1.3 11 Sep 1995 11:14:06 DBRUCKS
// add h261 ifdef
//
// Rev 1.2 25 Aug 1995 11:54:06 TRGARDOS
//
// Debugged PutBits routine.
//
// Rev 1.1 14 Aug 1995 11:35:18 TRGARDOS
// y
// Finished writing picture frame header
//
// Rev 1.0 11 Aug 1995 17:28:34 TRGARDOS
// Initial revision.
;////////////////////////////////////////////////////////////////////////////
#include "precomp.h"
/*************************************************************************
* BSWriteField
*
* Write a field value of a specified size of bits into the
* bitstream at the specified byte and bit offset.
*
* It is assumed that the field value is right justified
* in the parameter fieldval, and field len never exceeds
* 25.
*
* Returns void
*/
void PutBits(
unsigned int fieldval,
unsigned int fieldlen,
unsigned char **pbs,
unsigned char *bitoffset
)
{
unsigned int wordval;
// Shift field left so that the field starts at
// the current bit offset in the dword.
fieldval <<= (32 - fieldlen) - *bitoffset;
// Read in next dword starting at current byte position.
wordval = (**pbs << 24) + (*(*pbs+1) << 16) + (*(*pbs+2) << 8) + *(*pbs+3);
// Bitwise or the two dwords.
wordval |= fieldval;
// Write word back into memory, big-endian.
*(*pbs+3) = wordval & 0xff;
wordval >>= 8;
*(*pbs+2) = wordval & 0xff;
wordval >>= 8;
*(*pbs+1) = wordval & 0xff;
wordval >>= 8;
**pbs = wordval & 0xff;
// update byte and bit counters.
*pbs += (*bitoffset + fieldlen) >> 3;
*bitoffset = (*bitoffset + fieldlen) % 8;
} // end of BSWriteField function.
/*************************************************************
* CopyBits
*
************************************************************/
void CopyBits(
U8 **pDestBS,
U8 *pDestBSOffset,
const U8 *pSrcBS,
const U32 uSrcBitOffset,
const U32 uBits
)
{
U32 bitstocopy, bitsinbyte;
const U8 *sptr;
if (uBits == 0) goto done;
bitstocopy = uBits;
sptr = pSrcBS + (uSrcBitOffset >> 3);
bitsinbyte = 8 - (uSrcBitOffset & 0x7);
if (bitsinbyte <= bitstocopy)
{
PutBits((*sptr) & ((1 << bitsinbyte) - 1),
bitsinbyte, pDestBS, pDestBSOffset);
bitstocopy -= bitsinbyte;
sptr++;
}
else
{
PutBits( (*sptr >> (8 - (uSrcBitOffset & 0x7) - bitstocopy))
& ((1 << bitstocopy) - 1),
bitstocopy, pDestBS, pDestBSOffset);
goto done;
}
while (bitstocopy >= 8)
{
PutBits(*sptr, 8, pDestBS, pDestBSOffset);
bitstocopy -= 8;
sptr++;
}
if (bitstocopy > 0)
{
PutBits((*sptr)>>(8-bitstocopy), bitstocopy, pDestBS, pDestBSOffset);
}
done:
return;
} // CopyBits function