WdfDmaTransactionSetMaximumLength 함수(wdfdmatransaction.h)

[KMDF에만 적용]

WdfDmaTransactionSetMaximumLength 메서드는 지정된 DMA 트랜잭션과 연결된 DMA 전송의 최대 길이를 설정합니다.

구문

void WdfDmaTransactionSetMaximumLength(
  [in] WDFDMATRANSACTION DmaTransaction,
  [in] size_t            MaximumLength
);

매개 변수

[in] DmaTransaction

드라이버가 WdfDmaTransactionCreate에 대한 이전 호출에서 가져온 DMA 트랜잭션 개체에 대한 핸들입니다.

[in] MaximumLength

디바이스가 단일 DMA 전송 작업에서 처리할 수 있는 최대 크기(바이트)입니다. 최대 16개의 맵 레지스터를 지원하는 Microsoft Windows 운영 체제 버전에서 드라이버를 실행해야 하는 경우 MaximumLength 는 65536 미만이어야 합니다.

MaximumLength 값은 다음과 같이 지정된 DMA 트랜잭션에만 적용됩니다.

  • 지정된 값이 드라이버가 WDF_DMA_ENABLER_CONFIG 구조에 지정한 기본값보다 작으면 지정된 값이 기본값을 재정의합니다.
  • 지정된 값이 기본값보다 크면 지정된 값이 무시됩니다.

반환 값

없음

설명

드라이버가 잘못된 개체 핸들을 제공하는 경우 버그 검사 발생합니다.

드라이버는 WdfDmaTransactionSetMaximumLength를 호출하기 전에 DMA 트랜잭션을 초기화해야 합니다.

DMA 트랜잭션 초기화에 대한 자세한 내용은 DMA 트랜잭션 만들기 및 초기화를 참조하세요.

예제

다음 코드 예제에서는 지정된 DMA 트랜잭션의 최대 전송 길이를 드라이버 정의 값으로 설정합니다.

WdfDmaTransactionSetMaximumLength(
                                 dmaTransaction,
                                 MAX_TRANSFER_LENGTH/2,
                                 );

요구 사항

요구 사항
대상 플랫폼 유니버설
최소 KMDF 버전 1.0
머리글 wdfdmatransaction.h(Wdf.h 포함)
라이브러리 Wdf01000.sys(프레임워크 라이브러리 버전 관리 참조)
IRQL <=DISPATCH_LEVEL
DDI 규정 준수 규칙 DriverCreate(kmdf)

추가 정보

WDF_DMA_ENABLER_CONFIG

WdfDmaTransaction만들기