IOCTL_SFFDISK_DEVICE_COMMAND IOCTL (sffdisk.h)

用户模式应用程序使用此 IOCTL 将安全数字 (SD) 卡 命令发送到 SD 卡。 有关这些命令的说明,请参阅 SD 内存卡第 1 部分物理层规范SD 内存卡第 3 部分安全 规范。

调用方必须填写 SFFDISK_DEVICE_COMMAND_DATA 结构,并将其作为参数传递给调用。

若要执行此操作,请使用以下参数 (Microsoft Windows SDK文档) 中所述调用 DeviceIoControl 函数。

bRet = DeviceIoControl (
    (HANDLE)  hDevice, 
    (DWORD)  dwIoControlCode, 
    (PUCHAR)  lpInBuffer,
    (DWORD)  nInBufferSize, 
    (PUCHAR)  lpOutBuffer,
    (DWORD)  nOutBufferSize, 
    (LPDWORD)  lpBytesReturned,
    (LPOVERLAPPED)  lpOverlapped 
  );

参数

hDevice
SD 堆栈中卷的句柄。
dwIoControlCode
操作的控制代码。 此值标识要执行的特定操作以及要执行该操作的设备类型。 对此操作使用 IOCTL_SFFDISK_DEVICE_COMMAND。
lpInBuffer
指向输入缓冲区的指针。 调用方必须初始化 SFFDISK_DEVICE_COMMAND_DATA 结构并将其存储在缓冲区的开头。 调用方应将与命令关联的参数存储在紧跟SFFDISK_DEVICE_COMMAND_DATA结构之后的位置。
nInBufferSize
指示 lpInBuffer 参数指向的输入缓冲区的大小(以字节为单位)。 输入缓冲区的大小应是 (SFFDISK_DEVICE_COMMAND_DATA) 大小 的总和,以及其后跟的命令参数的大小。
lpOutBuffer
指向包含操作结果的输出缓冲区的指针。 如果操作失败且 GetLastError 返回错误代码ERROR_INSUFFICIENT_BUFFER,则输出缓冲区不够大,无法保存结果数据。
nOutBufferSize
lpOutBuffer 参数指向的输出缓冲区的大小(以字节为单位)。
lpBytesReturned
指向变量的指针,该变量接收 lpOutBuffer 指向的缓冲区中存储的结果数据的大小(以字节为单位)。

如果输出缓冲区太小而无法保存返回数据,则输出时将包含值零,调用将失败, GetLastError 将ERROR_INSUFFICIENT_BUFFER返回错误代码。 万一。

如果 lpOverlapped (非重叠 I/O) 为 NULL,则调用方无法在输入时为 lpBytesReturned 参数分配 NULL。 如果 lpOverlapped 不是 NULL (重叠的 I/O) ,则调用方可以为 lpBytesReturned 参数分配 NULL

如果这是一个重叠的操作,可以通过调用 GetOverlappedResult 函数来检索返回的字节数。 如果 hDevice 与 I/O 完成端口相关联,可以通过调用 GetQueuedCompletionStatus 函数来获取返回的字节数。 有关 GetOverlappedResultGetQueuedCompletionStatus 函数的说明,请参阅 Windows SDK 文档。

lpOverlapped
指向 OVERLAPPED 结构的指针,如 Windows SDK 文档中所述。

如果调用方使用 FILE_FLAG_OVERLAPPED 标志打开设备, 则 lpOverlapped 必须指向有效的 OVERLAPPED 结构。 在这种情况下,系统会将 DeviceIoControl 作为重叠的异步操作执行。 如果调用方使用 FILE_FLAG_OVERLAPPED 标志打开设备,并且 lpOverlappedNULL,则函数以不可预知的方式失败。

如果调用方在未指定FILE_FLAG_OVERLAPPED标志的情况下打开设备,则系统会忽略 lpOverlapped 中的值,并且 DeviceIoControl 函数在操作完成或发生错误之前不会返回。

主要代码

IRP_MJ_DEVICE_CONTROL

状态块

如果操作成功, DeviceIoControl 将返回非零值。

如果操作失败, DeviceIoControl 将返回零。 要获得更多的错误信息,请调用 GetLastError。

要求

要求
Header sffdisk.h (包括 Sffdisk.h)