Leaked source code of windows server 2003
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.

488 lines
16 KiB

  1. ;////////////////////////////////////////////////////////////////////////////
  2. ;//
  3. ;// INTEL CORPORATION PROPRIETARY INFORMATION
  4. ;//
  5. ;// This software is supplied under the terms of a license
  6. ;// agreement or nondisclosure agreement with Intel Corporation
  7. ;// and may not be copied or disclosed except in accordance
  8. ;// with the terms of that agreement.
  9. ;//
  10. ;// Copyright (c) 1995-1996 Intel Corporation.
  11. ;// All Rights Reserved.
  12. ;//
  13. ;////////////////////////////////////////////////////////////////////////////
  14. ;//
  15. ;// $Author: RHAZRA $
  16. ;// $Date: 21 Oct 1996 10:46:40 $
  17. ;// $Archive: S:\h26x\src\enc\e1enc.h_v $
  18. ;// $Header: S:\h26x\src\enc\e1enc.h_v 1.35 21 Oct 1996 10:46:40 RHAZRA $
  19. ;//
  20. ;////////////////////////////////////////////////////////////////////////////
  21. #ifndef __E1ENC_H__
  22. #define __E1ENC_H__
  23. /* This file declares structs which catalog the locations of various
  24. * tables, structures, and arrays needed by the H261 encoder.
  25. */
  26. enum SourceFormat {SF_QCIF=0, SF_CIF=1};
  27. /* If the size of T_H261FrameHeaderStruct is changed, then
  28. * that change must be updated in T_H261EncoderCatalog below
  29. */
  30. typedef struct {
  31. // fields in the header
  32. EnumOnOff Split; // split screen indicator
  33. EnumOnOff DocCamera; // document camera indicator
  34. EnumOnOff PicFreeze; // freeze picture release
  35. EnumOnOff StillImage; // still image mode
  36. EnumPicCodType PicCodType; // picture code type
  37. U8 TR; // temporal reference
  38. U8 SourceFormat; // source format
  39. U8 Spare; // spare bit
  40. U8 PEI; // pei indicator
  41. // Not in the header but needed by the algorithm
  42. U8 PQUANT; // picture level quantization
  43. U8 Pad[3]; // Pad to a mulitple of 4
  44. } T_H261FrameHeaderStruct;
  45. const int sizeof_T_H261FrameHeaderStruct = 28;
  46. /*
  47. This file declares structs which catalog the locations of various
  48. tables, structures, and arrays needed by the H263 encoder.
  49. */
  50. /*
  51. * Block description structure. Must be 16-byte aligned.
  52. */
  53. typedef struct {
  54. U32 BlkOffset; // [0-3] Offset to 8*8 target block from start of Y plane.
  55. union {
  56. U8 *PastRef; // [4-7] Address of 8*8 reference block.
  57. struct {
  58. U8 HMVf;
  59. U8 VMVf;
  60. U8 HMVb;
  61. U8 VMVb;
  62. } BestMV;
  63. } B4_7;
  64. struct {
  65. U8 HMVf;
  66. U8 VMVf;
  67. U8 HMVb;
  68. U8 VMVb;
  69. } CandidateMV;
  70. char PHMV; // [12] Horizontal motion vector for P block..
  71. char PVMV; // [13] Vertical motion vector for P block..
  72. char BHMV; // [14] Horizontal motion vector for B block..
  73. char BVMV; // [15] Vertical motion vector for B block..
  74. } T_Blk;
  75. const int sizeof_T_Blk = 16;
  76. /*
  77. * T_MBlockActionStream - Structure to keep side information for a MB
  78. * used by encoder. This structure must be 16-byte aligned when allocated.
  79. * CodedBlocks must be DWORD aligned.
  80. * The entire structure must be a multiple of 16 bytes, and must
  81. * match the size of the structure in e3mbad.inc.
  82. *
  83. */
  84. typedef struct {
  85. U8 BlockType; // 0 -- See block types below.
  86. U8 MBEdgeType; // 1 -- 1 off if left edge| 2 right| 4 top | 8 bottom.
  87. U8 Unassigned1; // 2 --
  88. U8 FirstMEState; // 3 -- First State Num for Motion Estimation engine.
  89. U8 CodedBlocks; // 4 -- [6] End-of-Stream indicator
  90. // [0] indicates Y1 non-empty
  91. // [1...5] indicates Y2, Y3, Y4, U, V nonempty.
  92. // Other bits zero.
  93. U8 CodedBlocksB; // 5 -- [0...5] like CodedBlocks, but for B frame.
  94. // Set to 0 for non bi-di prediction.
  95. U8 Unassigned2[2]; // 6...7
  96. U32 SWD; // 8...11 Sum of weighted diffs, from motion estimation.
  97. U32 SWDB; // 12...15 Sum of weighted diffs, from B frame motion estimation.
  98. T_Blk BlkY1; // 16...31
  99. T_Blk BlkY2; // 32...47
  100. T_Blk BlkY3; // 48...63
  101. T_Blk BlkY4; // 64...79
  102. T_Blk BlkU; // 80...95
  103. T_Blk BlkV; // 96...111
  104. U8 COD; // 112 -- Coded macroblock indication. When set to "0"
  105. // indicates that macroblock is coded. If set to
  106. // "1", it indicates that the macroblock is not coded
  107. // and the rest of the macroblock layer is empty.
  108. U8 MBType; // 113 -- Macro block type, {INTER, INTER+Q, INTER4V, INTRA, INTRA+Q}
  109. U8 CBPC; // 114 -- Coded block pattern for chrominance.
  110. U8 MODB; // 115 -- Macroblock mode for B-blocks.
  111. U8 CBPB; // 116 -- Coded block pattern for B blocks.
  112. U8 CBPY; // 117 -- Coded block pattern for luminance.
  113. U8 DQUANT; // 118 -- Quantizer information. A two bit pattern to define
  114. // change in QUANT.
  115. U8 InterCodeCnt; // 119 -- Count number of times current MB has been intercoded.
  116. U8 Unassigned4[8]; // 120...127 -- Pad out to a power of two.
  117. } T_MBlockActionStream;
  118. const int sizeof_T_MBlockActionStream = 128;
  119. /*
  120. * Block Types
  121. */
  122. const U8 INTERBLOCK = 0;
  123. const U8 INTRABLOCK = 1;
  124. const U8 INTERSLF = 2;
  125. #define IsInterBlock(t) (t != INTRABLOCK)
  126. #define IsIntraBlock(t) (t == INTRABLOCK)
  127. #define IsSLFBlock(t) (t == INTERSLF)
  128. /* MB Types
  129. */
  130. const U8 INTER = 0;
  131. const U8 INTERQ = 1;
  132. const U8 INTER4V= 2;
  133. const U8 INTRA = 3;
  134. const U8 INTRAQ = 4;
  135. /* First ME state for ME engine
  136. */
  137. const U8 ForceIntra = 0;
  138. const U8 UpperLeft = 1;
  139. const U8 UpperEdge = 2;
  140. const U8 UpperRight = 3;
  141. const U8 LeftEdge = 4;
  142. const U8 CentralBlock = 5;
  143. const U8 RightEdge = 6;
  144. const U8 LowerLeft = 7;
  145. const U8 LowerEdge = 8;
  146. const U8 LowerRight = 9;
  147. const U8 NoVertLeftEdge = 10;
  148. const U8 NoVertCentralBlock = 11;
  149. const U8 NoVertRightEdge = 12;
  150. /* Coded block bit masks.
  151. */
  152. const U8 Y1BLOCK = 0x01;
  153. const U8 Y2BLOCK = 0x02;
  154. const U8 Y3BLOCK = 0x04;
  155. const U8 Y4BLOCK = 0x08;
  156. const U8 UBLOCK = 0x10;
  157. const U8 VBLOCK = 0x20;
  158. /* Bit Rate Control Type
  159. */
  160. const U8 BRC_Undefined = 0;
  161. const U8 BRC_ForcedQuant = 1;
  162. const U8 BRC_ForcedDataRate = 2;
  163. const U8 BRC_Normal = 3;
  164. typedef struct {
  165. U8 StateNumInc_SelectCentralPt;
  166. U8 MVIncIdx_SelectCentralPt;
  167. U8 StateNumInc_SelectRef1;
  168. U8 MVIncIdx_SelectRef1;
  169. U8 StateNumInc_SelectRef2;
  170. U8 MVIncIdx_SelectRef2;
  171. U16 pad;
  172. } T_SADState;
  173. /* For optimal performance, the parameters to be used when invoking motion
  174. estimation should depend on our runtime state. Here we define a struct
  175. to hold motion estimation parameters. A particular instance of this
  176. struct is selected at runtime.
  177. See the motion estimation routines for a description of each parameter.
  178. */
  179. typedef struct {
  180. I32 zero_vector_threshold;
  181. I32 nonzero_MV_differential;
  182. I32 empty_threshold;
  183. I32 intercoding_threshold;
  184. I32 intercoding_differential;
  185. I32 slf_threshold;
  186. I32 slf_differential;
  187. } T_MotionEstimationControls;
  188. /* T_H263EncoderCatalog - Catalog of information needed for an instance.
  189. * This structure must be multiple of 16.
  190. */
  191. typedef struct {
  192. U8 *pU8_CurrFrm; // 0 Pointers to current frame buffers
  193. U8 *pU8_CurrFrm_YPlane; // 4
  194. U8 *pU8_CurrFrm_VPlane; // 8
  195. U8 *pU8_CurrFrm_UPlane; // 12
  196. U8 *pU8_PrevFrm; // 16 Pointers to previous frame buffers
  197. U8 *pU8_PrevFrm_YPlane; // 20
  198. U8 *pU8_PrevFrm_VPlane; // 24
  199. U8 *pU8_PrevFrm_UPlane; // 28
  200. U8 *pU8_SLFFrm; // 32 Pointers to spatial loop filter frame
  201. U8 *pU8_SLFFrm_YPlane; // 36
  202. U8 *pU8_SLFFrm_UPlane; // 40
  203. U8 *pU8_SLFFrm_VPlane; // 44
  204. T_MBlockActionStream *pU8_MBlockActionStream; // 48 Pointer to macro block action stream.
  205. I32 *pU8_DCTCoefBuf; // 52 Pointer to GOB DCT coefficient buffer.
  206. U8 *pU8_BitStream; // 56 Pointer to bitstream buffer.
  207. U32 uBase; // 60 RTP: takes place of Unassigned0[1]
  208. T_H261FrameHeaderStruct PictureHeader; // 64..91 (28 bytes) Picture layer header structure.
  209. UN FrameHeight; // 92
  210. UN FrameWidth; // 96
  211. FrameSize FrameSz; // 100 Define frame size: SQCIF, QCIF, CIF
  212. UN NumMBRows; // 104 Number of rows of MB's
  213. UN NumMBPerRow; // 108 Number of MB's in a row.
  214. UN NumMBs; // 112 Total number of MBs.
  215. LPDECINST pDecInstanceInfo; // 116 Private decoder instance info.
  216. /* Temporal Reference
  217. */
  218. float fTR_Error; // 120
  219. U8 u8LastTR; // 124
  220. U8 u8Pad0[3]; // 125
  221. /* Bit Rate Controller
  222. */
  223. BRCStateStruct BRCState; // 128...159 (32 bytes) Bit Rate Controller state
  224. U32 uQP_cumulative; // 160 Cumulative QP value
  225. U32 uQP_count; // 164 Number of accumulated QP values
  226. U8 u8DefINTRA_QP; // 168 Default Intra QP value
  227. U8 u8DefINTER_QP; // 169 Default Inter QP value
  228. /* Flags
  229. */
  230. U8 bMakeNextFrameKey; // 170
  231. U8 bBitRateControl; // 171
  232. /* Options
  233. */
  234. U8 bUseMotionEstimation; // 172 either 1 or 0 - if 0 ME will not be called
  235. U8 bUseSpatialLoopFilter;// 173 either 1 or 0 - if 0 Spatial Loop Filter will not be used
  236. U8 u8BRCType; // 174 Bit Rate Controller Type
  237. U8 u8Pad1[1]; // 175 align to four bytes
  238. U32 uForcedQuant; // 176 if u8BRCType == BRC_ForcedQuant
  239. U32 uForcedDataRate; // 180 if u8BRCType == BRC_ForcedDataRate
  240. float fForcedFrameRate; // 184 if u8BRCType == BRC_ForcedDataRate
  241. /* Statistics */
  242. ENC_BITSTREAM_INFO BSInfo; // 188..539 (352 bytes)
  243. ENC_TIMING_INFO *pEncTimingInfo; // 540
  244. U32 uStatFrameCount; // 544
  245. /* The following are needed in lower level routines */
  246. int bTimingThisFrame; // 548
  247. U32 uStartLow; // 552
  248. U32 uStartHigh; // 556
  249. U32 uBitUsageProfile[397]; // 560..2147 Table for storing bit usage profile
  250. // 397 is large enough for FCIF+1 worth of MacroBlocks
  251. // element 0...NumMBs-1 stores cumulative bit usage
  252. // element NumMBs stores the final frame size
  253. // Note: NumMBs is 0...395
  254. HANDLE hBsInfoStream; // 2148
  255. void *pBsInfoStream; // 2152
  256. U32 uPacketSizeThreshold; // 2156
  257. void *pBaseBsInfoStream; // 2160
  258. U32 uNumOfPackets; // 2164
  259. U32 uNextIntraMB; // 2168
  260. U32 uNumberForcedIntraMBs; // 2172
  261. U8 *pU8_Signature; // 2176
  262. U8 *pU8_Signature_YPlane; // 2180
  263. I8 *pI8_MBRVS_Luma; // 2184
  264. I8 *pI8_MBRVS_Chroma; // 2188
  265. /* bUseCustomMotionEstimation is used for tuning motion estimation
  266. parameters. It is enabled via the h261 "ini" file, and causes
  267. custom values to be used when invoking motion estimation. See the
  268. GetEncoderOptions routine for a description of the custom values.
  269. */
  270. U8 bUseCustomMotionEstimation;
  271. U8 U8pad[15];
  272. } T_H263EncoderCatalog;
  273. /*
  274. * T_H263EncoderInstanceMemory
  275. * Memory layout for encoder instance. The memory is allocated
  276. * dynamically and the beginning of this structure is aligned to a
  277. * 32 byte boundary.
  278. * All arrays should be start on a DWORD boundary.
  279. * MBActionStream should start on a 16 byte boundary.
  280. */
  281. // Define bit stream buffer size.
  282. const unsigned int sizeof_bitstreambuf = 352*288*3/4;
  283. // This structure is allocated on a 32 byte boundary.
  284. typedef struct {
  285. T_H263EncoderCatalog EC;
  286. U8 UnAssigned0[2304 - sizeof(T_H263EncoderCatalog)]; // Align to 32 byte boundary (2176+32).
  287. T_MBlockActionStream MBActionStream[33*12];
  288. // 57,536 / 32 = 1798 chunks of 32 bytes
  289. U8 UnAssigned1[16]; // Align to 16 and not 32
  290. U8 u8CurrentPlane [ (288+16+8+144)*384 + 8 ];
  291. U8 u8Pad1[ 80 - 8 ]; // (Prev - Current) % 128 == 80
  292. U8 u8PreviousPlane[ (16+288+16+8+144+8)*384 + 64]; // Reconstructed past
  293. /* The difference between the SLF and Previous pointers MOD 4096 should equal 944
  294. * Since the previous memory contains 16 buffered lines with a 16 byte offset
  295. * while the SLF memory only has the 16-byte offset we ignore the 16*PITCH in
  296. * calculating the difference.
  297. * ((288+16+8+144+8)*384 + 64) % 4096 = 2112
  298. * Since 2112 is > 944 we need to pad almost 4096 bytes.
  299. */
  300. U8 u8Pad2[ 4096 - (2112 - 944) ]; // (SLF - Prev) % 4096 == 944
  301. U8 u8SLFPlane[ (288+16+8+144)*384 + 8]; // Spatial Loop Filter working area
  302. U8 u8Pad3[ 8 ];
  303. U8 u8BitStream [ sizeof_bitstreambuf ];
  304. /*
  305. * Allocate space for DCT coefficients for an entire GOB.
  306. * Each block of coefficients is stored in 32 DWORDS (2 coefs/DWORD)
  307. * and there are 6 blocks in a macroblock, and 33 MBs in a GOB.
  308. */
  309. I32 piGOB_DCTCoefs[32*6*33]; // Align to 32 byte boundary
  310. U8 u8Signature[(16+288+16)*384 + 24]; // Should be placed correctly for optimal
  311. U8 u8Pad4[ 8 ]; // Align to 32 byte boundary
  312. I8 i8MBRVS_Luma[65 * 3 * 33 * 4];
  313. I8 i8MBRVS_Chroma[65 * 3 * 33 * 2];
  314. DECINSTINFO DecInstanceInfo; // Private decoder instance.
  315. #ifndef RING0
  316. ENC_TIMING_INFO EncTimingInfo[ENC_TIMING_INFO_FRAME_COUNT];
  317. #endif
  318. } T_H263EncoderInstanceMemory;
  319. // Define offsets from Y to U planes, and U to V planes.
  320. const int YU_OFFSET = (288+16+8)*384;
  321. const int UV_OFFSET = 192;
  322. const int CurPrev_OFFSET = 181328; // Offset from current to previous frame buffer.
  323. /****************************************************************
  324. * Function prototypes
  325. ****************************************************************/
  326. void colorCnvtFrame(
  327. T_H263EncoderCatalog * EC,
  328. LPCODINST lpCompInst,
  329. ICCOMPRESS * lpicComp,
  330. U8 * YPlane,
  331. U8 * UPlane,
  332. U8 * VPlane
  333. );
  334. void PutBits(
  335. unsigned int fieldval, // Value of field to write to stream.
  336. unsigned int fieldlen, // Length of field to be written
  337. unsigned char **pbs, // Pointer to current byte in bitstream
  338. unsigned char *bitoffset // bit offset in current byte of bitstream.
  339. );
  340. extern "C" void FORWARDDCT (T_MBlockActionStream * MBlockActionStream,
  341. U8 * TargetFrameBaseAddr,
  342. U8 * PreviousFrameBaseAddr,
  343. U8 * FutureFrameBaseAddr,
  344. I32 * CoeffStream,
  345. int IsBFrame,
  346. int IsAdvancedPrediction,
  347. int ISPofPBPair,
  348. U8 * ScratchBlocks,
  349. int NumberofMBlksInGOB
  350. );
  351. extern "C" void MOTIONESTIMATION (
  352. T_MBlockActionStream * MBlockActionStream,
  353. U8 * TargetFrameBaseAddr,
  354. U8 * PreviousFrameBaseAddr,
  355. U8 * FilteredFrameBaseAddr,
  356. int DoRadius15Search,
  357. int DoHalfPelEstimation,
  358. int DoBlockLevelVectors,
  359. int DoSpatialFiltering,
  360. int ZeroVectorThreshold,
  361. int NonZeroMVDifferential,
  362. int BlockMVDifferential,
  363. int EmptyThreshold,
  364. int InterCodingThreshold,
  365. int IntraCodingDifferential,
  366. int SLFThreshold,
  367. int SLFDifferential,
  368. U32 * IntraSWDTotal,
  369. U32 * IntraSWDBlocks,
  370. U32 * InterSWDTotal,
  371. U32 * InterSWDBlocks
  372. );
  373. extern "C" I8 * QUANTRLE(
  374. I32 *CoeffStr,
  375. I8 *CodeStr,
  376. I32 QP,
  377. I32 BlockType
  378. );
  379. extern "C" void MBEncodeVLC(
  380. I8 **,
  381. I8 **,
  382. U32 ,
  383. U8 **,
  384. U8 *,
  385. I32,
  386. I32
  387. );
  388. #ifdef SLF_WORK_AROUND
  389. extern "C" {
  390. void FAR EncUVLoopFilter (
  391. U8 * uRefBlock,
  392. U8 * uDstBlock,
  393. I32 uDstPitch);
  394. };
  395. #endif
  396. /*
  397. * Routine to quantize, rle, vlc and write to bitstream
  398. * for an entire GOB.
  399. */
  400. void GOB_Q_RLE_VLC_WriteBS(
  401. T_H263EncoderCatalog * EC,
  402. I32 *DCTCoefs,
  403. U8 **pBitStream,
  404. U8 *pBitOffset,
  405. UN unStartingMB,
  406. UN gquant,
  407. BOOL bOverFlowWarningFlag,
  408. BOOL bRTPHeader, // RTP: definition
  409. U32 uGOBNUmber, // RTP: definition
  410. U8 u8QPMin
  411. );
  412. void GOB_VLC_WriteBS(
  413. T_H263EncoderCatalog * EC,
  414. I8 *pMBRVS_Luma,
  415. I8 *pMBRVS_Chroma,
  416. U8 **pBitStream,
  417. U8 *pBitOffset,
  418. UN unGQuant,
  419. UN unStartingMB,
  420. BOOL bRTPHeader, // RTP: definition
  421. U32 uGOBNUmber // RTP: definition
  422. );
  423. void InitVLC(void);
  424. struct T_MAXLEVEL_PTABLE {
  425. int maxlevel;
  426. int * ptable;
  427. };
  428. //extern "C" { UN FAR ASM_CALLTYPE H263EOffset_DecoderInstInfo(); }
  429. #endif // #ifndef _E1ENC_H_