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) |