(转)DeviceIOControl详解[通俗易懂]

(转)DeviceIOControl详解[通俗易懂]http://blog.csdn.net/gis_wudi/article/details/6639739DeviceIoControl这个api我们用的不多,但是很重要,有时会帮助我们实现一些特别

大家好,又见面了,我是你们的朋友全栈君。

http://blog.csdn.net/gis_wudi/article/details/6639739

  DeviceIoControl这个api我们用的不多,但是很重要,有时会帮助我们实现一些特别的需求, 如获取硬件设备信息、与硬件设备通信(读写数据)等,对照msdn,下面我们详细解释一下这个api的用法(有什么错误再所难免,各位不吝指教啊)。
  DeviceIoControl是用来控制我们指定设备的输入输出操作,使设备按照我们发的指令去工作。

  DeviceIoControl是kernel32中的函数,需要包含的头文件是winbase.h,先看函数原型

BOOL DeviceIoControl(
    HANDLE hDevice, 
    DWORD dwIoControlCode, 
    LPVOID lpInBuffer, 
    DWORD nInBufferSize, 
    LPVOID lpOutBuffer, 
    DWORD nOutBufferSize, 
    LPDWORD lpBytesReturned, 
    LPOVERLAPPED lpOverlapped
);

  哈哈,参数不少,而且还都很抽象,没关系,我们一个一个击破它

  来到第一个参数,hDevice,当然是要操作的设备的句柄了,这个句柄需要通过CreateFile的返回值中获取,对于createfile这里只做一个粗略的解释:

HANDLE CreateFile(
    LPCTSTR lpFileName, 
    DWORD dwDesiredAccess, 
    DWORD dwShareMode, 
    LPSECURITY_ATTRIBUTES lpSecurityAttributes, 
    DWORD dwCreationDisposition, 
    DWORD dwFlagsAndAttributes, 
    HANDLE hTemplateFile
); 

  参数:要打开的文件名,访问权限,共享模式,安全属性,文件存在与不存在时的文件创建模式,文件属性设定(隐藏、只读、压缩、指定为系统文件等),文件副本句柄。要说明的是第一个参数lpFileName,是设备的名称或者是和设备关连的驱动的名称,一般用\\.\DeviceName的形式,比如要打开逻辑驱动盘A就用\\.\a,也可以用\\.\PhysicalDevice0,\\.\PhsycalDebive1来指定物理驱动器,\\.\PhysicalDevice0表示本机的物理驱动器0(一般是主硬盘),从而来获取硬盘的序列号、模块名、扇区数、磁头数等相关信息

  搞定hDevice!

  dwIoControlCode: 当然就是控制设备的指令了,指令怎么来是个问题,微软已经定义好了很多种操作,在winioctl.h文件中,但最终都是通过CTL_CODE宏来实现的,其实这就是一种通信协议。CTL_CODE的具体用法在最后来介绍。

  lpInBuffer: 设备操控请求数据的缓冲区基址,如果dwIoControlCode 指定了一个操作,该操作不需要输入数据,那么这个参数设为NULL

  nInBufferSize:lplnBuffer的size

  lpOutBuffer:存放输出数据的buffer,同样,如果dwIoControlCode 指定了一个操作,该操作不需要处理输出数据,那么这个参数设为NULL

  nOutBufferSize:haha,别说你不知道什么什么意思,pass

  lpBytesReturned:实际输出数据的bytes

  lpOverlapped:Ignored; set to NULL.(Are you understand?)

 

下面来到第二个参数的详解,CTL_CODE的定义与应用:

  CTL_CODE原型:

  #define CTL_CODE(DeviceType, Function, Method, Access) (
  ((DeviceType) << 16) | ((Access) << 14) | ((Function) << 2) | (Method)
  )

  
  可以看到,这个宏四个参数,自然是一个32位分成了4部分,高16位存储设备类型( 这里不列举了,看msdn哦),14~15位访问权限,2~13位操作功能,最后一个就是确定缓冲区(别忘记上面DeviceIOControl中缓冲区的定义哦)是如何与I/O和文件系统数据缓冲区进行数据传递的方式(具体取值查看msdn)我们最常用的就是METHOD_BUFFERED

  Function codes 0-2047 are reserved for Microsoft; codes 2048-4095 are reserved for OEMs and IHVs. (我们能用的是2048~4095)

看以下一段:

  这个宏经常用来定义IOCTL(I/O控制)和FSCTL(文件系统控制)功能控制代码,所有的IOCTLs必须通过这种方式定义,以确保这些指令能被Microsoft,以及其他的硬件厂商通信接口所识别

  The following illustration shows the format of the resulting IOCTL.

 

  援引微软定义的一个指令:锁卷

  #define FSCTL_LOCK_VOLUME CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 6, METHOD_BUFFERED,   FILE_ANY_ACCESS)

Game over!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/155631.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月3日 下午4:00
下一篇 2022年7月3日 下午4:16


相关推荐

  • 反锐化掩模

    反锐化掩模英文 unsharpmaski 中文 反锐化掩模法 nbsp nbsp nbsp nbsp 将原图像通过反锐化掩模进行模糊预处理 相当于采用低通滤波 后与原图逐点做差值运算 然后乘上一个修正因子再与原图求和 以达到提高图像中高频成分 增强图像轮廓的目的 nbsp nbsp nbsp nbsp nbsp 反锐化掩模技术最早是应用于摄影技术中 以增强图像的边缘和细节 光学上的操作方法是将聚焦的正片和散焦的负片在底片上进行叠加

    2026年3月16日
    2
  • 2022 idea最新激活码【2022免费激活】2022.02.16「建议收藏」

    (2022 idea最新激活码)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.htmlFZP9ED60OK-eyJsaWNlbnNlSW…

    2022年4月1日
    269
  • pytest fixtures_figure可数吗

    pytest fixtures_figure可数吗fixture的优势Pytest的fixture相对于传统的xUnit的setup/teardown函数做了显著的改进:命名方式灵活,不局限于setup和teardown这几个命名conf

    2022年7月28日
    9
  • Python字符串转义符大全

    Python字符串转义符大全0 NUL 空字符 ascii 值 0 1 SOH 标题开始 ascii 值 1 2 STX 正文开始 ascii 值 2 3 ETX 正文结束 ascii 值 3 4 EOT 传输结束 ascii 值 4 5 ENQ 请求 ascii 值 5 6 ACK 收到通知 ascii 值 6 7 BEL 响铃 ascii 值 7 a BEL 响铃 ascii 值 7 b BS 退格 ascii 值 8 t HT 水平制表符 ascii 值 9 n NL 换行键 ascii 值 10 v VT 垂直制表符 ascii 值 11 f FF 换页键 ascii 值 12

    2026年3月17日
    1
  • 免费天气api适合商用吗_4个免费的天气提供商API开发天气应用

    免费天气api适合商用吗_4个免费的天气提供商API开发天气应用免费天气 api 适合商用吗提供天气信息的 Android 应用在 Play 商店中很常见 此外 Weather 应用程序和小部件是下载次数最多的项目之一 当需要开发天气应用程序时 有必要使用天气提供程序作为天气信息的来源 这些天气提供程序公开了一组服务 换句话说 就是一组支持 RestFulWebse 的 API 这些服务大多数都接受 XML 或 JSON 数据 在根据我们的需求选择

    2026年3月26日
    2
  • Tomcat下载——tomcat7、tomcat8、tomcat9官网下载链接

    Tomcat下载——tomcat7、tomcat8、tomcat9官网下载链接1.官网下载链接:https://tomcat.apache.org2.选择Download——>tomcat7/8/9,如下图所示:3.选择32/64位相应下载。4.下载好的zip包进行解压缩即可。…

    2022年5月19日
    49

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号