다음을 통해 공유


DXVA_MBctrl_P_HostResidDiff_1 구조체(dxva.h)

DXVA_MBctrl_P_HostResidDiff_1 구조체는 호스트 디코더에 의해 macroblock당 한 번 가속기로 전송되어 호스트 기반 IDCT를 사용할 때 대부분의 비인트라 그림 사례에 대해 macroblock 컨트롤 명령을 지정합니다.

구문

typedef struct _DXVA_MBctrl_P_HostResidDiff_1 {
  WORD         wMBaddress;
  WORD         wMBtype;
  DWORD        dwMB_SNL;
  WORD         wPatternCode;
  WORD         wPC_Overflow;
  DWORD        dwReservedBits2;
  DXVA_MVvalue MVector[DXVA_NumMV_OBMC_off_BinPBwith4MV_off];
} DXVA_MBctrl_P_HostResidDiff_1;

멤버

wMBaddress

현재 macroblock의 macroblock 주소를 래스터 스캔 순서로 지정합니다. 매크로 블록 주소의 예는 macroblock 주소를 참조하세요.

wMBtype

처리 중인 macroblock의 형식을 지정합니다. 다음 비트는 wMBtype의 내용을 정의합니다.

Bits 설명
15-12 MvertFieldSel_3(비트 15, 가장 중요한 비트)에서 MvertFieldSel_0(비트 12)
나중에 macroblock 컨트롤 명령에서 보낸 해당 동작 벡터에 대한 세로 필드 선택을 지정합니다. 프레임 그림 구조가 있는 프레임 기반 동작(예: H.261 및 H.263)의 경우 이러한 비트는 모두 0이어야 합니다. 이러한 비트의 사용은 MPEG-2 섹션 6.3.17.2의 해당 비트에 대해 지정된 것과 동일합니다.
11 예약 비트입니다. 0이어야 합니다.
10 HostResidDiff
공간 도메인 잔차 디코딩 블록이 전송되는지 또는 현재 매크로 블록에 대해 오프 호스트 IDCT에 대해 변환 계수를 보낼지 여부를 지정합니다.
HostResidDif 플래그는 이 구조체에서 항상 1과 같습니다. bConfigResidDiffHost가 0인 경우 이 플래그는 0이어야 합니다. bConfigResidDiffAccelerator가 0인 경우 이 플래그는 1이어야 합니다.
9 및 8 MotionType
그림의 동작 유형을 지정합니다. 예를 들어 프레임 그림 구조가 있는 프레임 기반 동작의 경우(H.261에서와 같이) 비트 9는 1이어야 하고 비트 8은 0이어야 합니다.
이러한 비트의 사용은 MPEG-2에 있는 MPEG-2 비디오의 섹션 6.3.17.1 및 테이블 6-17 및 6-18에서 frame_motion_type 또는 field_motion_type 비트를 사용하는 것과 직접 일치합니다. 이러한 비트의 사용은 다음 설명 섹션에서 자세히 설명합니다.
7 및 6 MBscanMethod
이 변수는 의미가 없으며 이러한 비트는 이 구조체에서 0으로 설정해야 합니다.
5 FieldResidual
잔차 블록이 MPEG-2에 지정된 필드 IDCT 구조를 사용하는지 여부를 나타냅니다.
DXVA_PictureParameters bPicStructure 멤버가 1 또는 2이면 1이어야 합니다. MPEG-2에 사용되는 경우 MPEG-2 구문의 frame_pred_frame_DCT 변수가 1이면 FieldResidual이 0이어야 하며 매크로 블록에 dct_type 있는 경우 MPEG-2 구문의 dct_type 변수와 같아야 합니다.
4 H261LoopFilter
H.261 루프 필터(H.261의 섹션 3.2.3)가 현재 매크로 블록 예측에 활성 상태인지 여부를 지정합니다. H.261 루프 필터는 탭 중 하나가 블록 밖으로 떨어지는 블록 가장자리를 제외하고 H.261 매크로 블록의 6개 블록 모두에 가로 및 세로로 적용된 분리 가능한 1/4, 1/2, 1/4 필터입니다. 이러한 경우 필터는 계수 0, 1, 0으로 변경됩니다. 전체 산술 정밀도는 2차원 필터 프로세스의 출력에서 8비트 정수로 반올림하여 유지됩니다(반올림되는 반정수 이상 값).
3 Motion4MV
H.263 부속서 F 및 J. Motion4MV에 사용된 것처럼 앞으로 이동이 매크로 블록의 4개 광도 블록 각각에 대해 고유한 동작 벡터를 사용함을 나타내는 변수입니다. MotionForward가 0이거나 DXVA_PictureParameters bPic4MVallowed 멤버가 0인 경우 0이어야 합니다.
2 MotionBackward
MPEG-2의 해당 macroblock_motion_backward 변수에 대해 지정된 방식으로 사용됩니다. DXVA_PictureParameters bPicBackwardPrediction 멤버가 0이면 MotionBackward는 0이어야 합니다. 이 비트의 사용은 다음 설명 섹션에서 자세히 설명합니다.
1 MotionForward
MPEG-2의 해당 macroblock_motion_forward 변수에 사용됩니다. 이 비트의 사용은 다음 설명 섹션에서 자세히 설명합니다.
0 IntraMacroblock
macroblock이 인트라로 코딩되고 현재 매크로 블록에 사용되는 동작 벡터가 없음을 나타냅니다. macroblock_intrain MPEG-2에 해당합니다. 이 비트의 사용은 다음 설명 섹션에서 자세히 설명합니다.

dwMB_SNL

현재 매크로 블록 다음에 생성할 건너뛴 매크로 블록 수를 지정하고 현재 매크로 블록 블록에 대한 잔차 데이터의 위치를 나타냅니다. 이 멤버에는 가장 중요한 8 비트에서 MBskipsFollowing , 가장 중요한 24비트 에서 MBdataLocation 이라는 두 개의 변수가 포함되어 있습니다. MBskipsFollowing 은 현재 매크로 블록 다음에 생성될 건너뛴 매크로 블록 수를 나타냅니다. MBdataLocation 은 잔차 블록 데이터 버퍼에 대한 인덱스입니다. 이 인덱스는 32비트 배수로 표현된 현재 macroblock 블록의 잔차 데이터 위치를 나타냅니다.

wPatternCode

현재 매크로 블록의 각 블록에 대해 잔차 데이터가 전송되는지 여부를 나타냅니다.

wPatternCode의 비트(11-i)(비트 0이 가장 중요한 비트인 경우)는 잔차 차이 데이터가 블록 i에 대해 전송되는지 여부를 나타냅니다. 여기서 은 MPEG-2 그림 6-10, 6-11 및 6-12(Y에 대한 래스터 스캔 순서, 래스터 스캔 순서로 Cb의 4:2:0 블록 뒤에 4:2:0 블록)에 지정된 대로 macroblock 내 블록의 인덱스입니다. 그 다음으로 Cr 4:2:0 블록, Cb의 4:2:2 블록, 4:2:2 블록, Cb 4:4:4 블록, Cr 4:4:4 블록이 뒤따릅니다. 코딩된 블록의 데이터(비트(11-i)가 1과 같은 블록)은 동일한 인덱싱 순서(i 증가)의 잔차 코딩 버퍼에서 찾을 수 있습니다. 4:2:0 MPEG-2 데이터의 경우 wPatternCode 값은 CBP의 디코딩된 값(코딩된 블록 패턴)을 6비트 위치(4:2:2 및 4:4:4 크로마 형식에 사용되는 하위 비트 위치)로 왼쪽으로 이동하는 데 해당합니다.

DXVA_ConfigPictureDecode bConfigSpatialResidInterleaved 멤버가 1이면 호스트 기반 잔차가 사용 중인 YUV 픽셀 형식과 일치하는 chroma 인터리브 형식으로 전송됩니다. 이 경우 각 Cb 및 공간적으로 해당하는 Cr 블록 쌍은 단일 잔차 구조체 단위로 처리됩니다. 이는 wPatternCode의 값이나 의미를 변경하지는 않지만 이러한 데이터 블록 중 하나에 wPatternCode에 해당 비트 집합이 있을 때마다 각 Cb 및 Cr 데이터 블록 쌍의 멤버가 모두 전송됨을 의미합니다. 특정 데이터 블록에 대한 wPatternCode 의 비트가 0이면 이 페어링에서 wPatternCode 비트가 0인 블록에 대해 잔차 데이터 블록을 보내야 할 때마다 해당 잔차 데이터 값을 0으로 보내야 합니다.

wPC_Overflow

오버플로 잔차 데이터를 사용하는 macroblock의 블록을 지정합니다.

DXVA_PictureParameters 1과 같고 IntraMacroblock이 0(8-8 오버플로 메서드)인 bPicOverflowBlocks 멤버와 함께 호스트 기반 잔차 디코딩을 사용하는 경우 wPC_Overflow 오버플로 블록의 패턴 코드를 포함합니다. 패턴 코드는 wPatternCode와 동일한 방식으로 지정됩니다. 코딩된 오버플로 블록(비트(11-i)이 1과 같은 블록)에 대한 데이터는 동일한 인덱싱 순서(i 증가)의 잔차 코딩 버퍼에 있습니다.

dwReservedBits2

압축 및 맞춤에 사용되는 예약된 비트입니다. 0이어야 합니다.

MVector[DXVA_NumMV_OBMC_off_BinPBwith4MV_off]

매크로 블록의 동작 벡터 값을 포함하는 배열로, 각 동작 벡터는 DXVA_MVvalue 구조체로 표시됩니다.

설명

MBskipsFollowing에서 지정한 건너뛴 각 macroblock은 wMBaddress 값을 증분한 다음 동일한 macroblock 컨트롤 명령을 반복하는 것과 수학적으로 동일한 방식으로 생성되어야 합니다.

MBskipsFollowing에 대해 0이 아닌 값을 가진 macroblock 컨트롤 명령의 콘텐츠는 건너뛴 매크로 블록 계열의 첫 번째 콘텐츠와 동일합니다(MBskipsFollowing 값 제외). 따라서 MBskipsFollowing이 0이 아닐 때마다 구조체 멤버와 변수는 모두 0과 같아야 합니다. Motion4MV, IntraMacroblock, wPatternCodewPC_Overflow. 그런 다음 건너뛴 각 macroblock은 wMBaddress 값을 증가시키는 것을 제외하고 첫 번째 매크로 블록과 동일한 방식으로 생성됩니다.

mBdataLocation 은 macroblock 컨트롤 명령 버퍼의 첫 번째 macroblock에 대해 0이어야 합니다. macroblock 컨트롤 명령 버퍼의 첫 번째 macroblock 이외의 매크로 블록의 경우 wPatternCode가 0인 경우 MBdataLocation에 값이 포함될 수 있습니다. wPatternCode가 0이면 디코더가 권장되지만 이 값을 0으로 설정하거나 다음 macroblock 컨트롤 명령과 동일한 값으로 설정할 필요는 없습니다.

건너뛴 매크로 블록이 생성되는 방법에 대한 자세한 내용은 건너뛴 매크로 블록 생성을 참조하세요.

IntraMacroblock, MotionForward, MotionBackward, MotionType, MvertFieldSelMVector의 유효한 조합은 Macroblock 컨트롤 명령 구조의 첫 번째 부분에 있는 테이블에 표시됩니다.

요구 사항

요구 사항
헤더 dxva.h(Dxva.h 포함)

추가 정보

DXVA_ConfigPictureDecode

DXVA_MBctrl_P_OffHostIDCT_1

DXVA_MVvalue

DXVA_PictureParameters