C#USB设备枚举Kernel32的PInvoke
- using System;
- using System.Runtime.InteropServices;
- using System.Security;
- namespace Splash
- {
- #region Kernel32
- [SuppressUnmanagedCodeSecurity]
- internal static class Kernel32
- {
- /// <summary>
- /// 无效的文件句柄
- /// </summary>
- public static readonly IntPtr INVALID_HANDLE_VALUE = new IntPtr(-1);
- #region CreateFile
- [DllImport("kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
- public static extern IntPtr CreateFile(
- String fileName,
- [MarshalAs(UnmanagedType.U4)] NativeFileAccess fileAccess,
- [MarshalAs(UnmanagedType.U4)] NativeFileShare fileShare,
- IntPtr securityAttributes,
- [MarshalAs(UnmanagedType.U4)] NativeFileMode creationDisposition,
- NativeFileFlag flags,
- IntPtr template
- );
- [DllImport("kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
- public static extern IntPtr CreateFile(
- String fileName,
- [MarshalAs(UnmanagedType.U4)] NativeFileAccess fileAccess,
- [MarshalAs(UnmanagedType.U4)] NativeFileShare fileShare,
- IntPtr securityAttributes,
- [MarshalAs(UnmanagedType.U4)] NativeFileMode creationDisposition,
- IntPtr flags,
- IntPtr template
- );
- #endregion
- [DllImport("kernel32.dll", SetLastError = true)]
- [return: MarshalAs(UnmanagedType.Bool)]
- public static extern Boolean CloseHandle(IntPtr hFile);
- #region ReadFile
- [DllImport("kernel32.dll", SetLastError = true)]
- public static extern Boolean ReadFile(
- IntPtr hFile,
- [Out] Byte[] lpBuffer,
- Int32 nNumberOfBytesToRead,
- out Int32 lpNumberOfBytesRead,
- [In] ref System.Threading.NativeOverlapped lpOverlapped
- );
- [DllImport("kernel32.dll", SetLastError = true)]
- public static extern Boolean ReadFile(
- IntPtr hFile,
- [Out] Byte[] lpBuffer,
- Int32 nNumberOfBytesToRead,
- IntPtr lpNumberOfBytesRead,
- [In] ref System.Threading.NativeOverlapped lpOverlapped
- );
- [DllImport("kernel32.dll", SetLastError = true)]
- public static extern Boolean ReadFile(
- IntPtr hFile,
- [Out] Byte[] lpBuffer,
- Int32 nNumberOfBytesToRead,
- out Int32 lpNumberOfBytesRead,
- IntPtr lpOverlapped
- );
- #endregion
- #region WriteFile
- [DllImport("kernel32.dll")]
- public static extern Boolean WriteFile(
- IntPtr hFile,
- Byte[] lpBuffer,
- Int32 nNumberOfBytesToWrite,
- out Int32 lpNumberOfBytesWritten,
- [In] ref System.Threading.NativeOverlapped lpOverlapped
- );
- [DllImport("kernel32.dll")]
- public static extern Boolean WriteFile(
- IntPtr hFile,
- Byte[] lpBuffer,
- Int32 nNumberOfBytesToWrite,
- IntPtr lpNumberOfBytesWritten,
- [In] ref System.Threading.NativeOverlapped lpOverlapped
- );
- [DllImport("kernel32.dll")]
- public static extern Boolean WriteFile(
- IntPtr hFile,
- Byte[] lpBuffer,
- Int32 nNumberOfBytesToWrite,
- IntPtr lpNumberOfBytesWritten,
- IntPtr lpOverlapped
- );
- #endregion
- [DllImport("kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
- public static extern Boolean GetOverlappedResult(
- IntPtr hFile,
- [In] ref System.Threading.NativeOverlapped lpOverlapped,
- out Int32 lpNumberOfBytesTransferred,
- Boolean bWait
- );
- }
- #endregion
- #region ENUM
- [Flags]
- internal enum NativeFileAccess : uint
- {
- GENERIC_READ = (0x80000000),
- GENERIC_WRITE = (0x40000000),
- GENERIC_EXECUTE = (0x20000000),
- GENERIC_ALL = (0x10000000),
- FILE_SPECIAL = 0,
- FILE_APPEND_DATA = (0x0004), // 文件
- FILE_READ_DATA = (0x0001), // 文件和管道
- FILE_WRITE_DATA = (0x0002), // 文件和管道
- FILE_READ_EA = (0x0008), // 文件和目录
- FILE_WRITE_EA = (0x0010), // 文件和目录
- FILE_READ_ATTRIBUTES = (0x0080), // 所有
- FILE_WRITE_ATTRIBUTES = (0x0100), // 所有
- DELETE = 0x00010000,
- READ_CONTROL = (0x00020000),
- WRITE_DAC = (0x00040000),
- WRITE_OWNER = (0x00080000),
- SYNCHRONIZE = (0x00100000),
- STANDARD_RIGHTS_REQUIRED = (0x000F0000),
- STANDARD_RIGHTS_READ = (READ_CONTROL),
- STANDARD_RIGHTS_WRITE = (READ_CONTROL),
- STANDARD_RIGHTS_EXECUTE = (READ_CONTROL),
- STANDARD_RIGHTS_ALL = (0x001F0000),
- SPECIFIC_RIGHTS_ALL = (0x0000FFFF),
- FILE_GENERIC_READ = (STANDARD_RIGHTS_READ | FILE_READ_DATA | FILE_READ_ATTRIBUTES | FILE_READ_EA | SYNCHRONIZE),
- FILE_GENERIC_WRITE = (STANDARD_RIGHTS_WRITE | FILE_WRITE_DATA | FILE_WRITE_ATTRIBUTES | FILE_WRITE_EA | FILE_APPEND_DATA | SYNCHRONIZE),
- SPECIAL = 0
- }
- internal enum NativeFileMode : uint
- {
- CREATE_NEW = 1,
- CREATE_ALWAYS = 2,
- OPEN_EXISTING = 3,
- OPEN_ALWAYS = 4,
- TRUNCATE_EXISTING = 5,
- }
- [Flags]
- internal enum NativeFileShare : uint
- {
- NONE = 0,
- FILE_SHARE_READ = 0x00000001,
- FILE_SHARE_WRITE = 0x00000002,
- FILE_SHARE_DEELETE = 0x00000004,
- }
- [Flags]
- internal enum NativeFileFlag : uint
- {
- FILE_ATTRIBUTE_READONLY = 0x00000001,
- FILE_ATTRIBUTE_HIDDEN = 0x00000002,
- FILE_ATTRIBUTE_SYSTEM = 0x00000004,
- FILE_ATTRIBUTE_DIRECTORY = 0x00000010,
- FILE_ATTRIBUTE_ARCHIVE = 0x00000020,
- FILE_ATTRIBUTE_DEVICE = 0x00000040,
- FILE_ATTRIBUTE_NORMAL = 0x00000080,
- FILE_ATTRIBUTE_TEMPORARY = 0x00000100,
- FILE_ATTRIBUTE_SPARSE_FILE = 0x00000200,
- FILE_ATTRIBUTE_REPARSE_POINT = 0x00000400,
- FILE_ATTRIBUTE_COMPRESSED = 0x00000800,
- FILE_ATTRIBUTE_OFFLINE = 0x00001000,
- FILE_ATTRIBUTE_NOT_CONTENT_INDEXED = 0x00002000,
- FILE_ATTRIBUTE_ENCRYPTED = 0x00004000,
- FILE_FLAG_WRITE_THROUGH = 0x80000000,
- FILE_FLAG_OVERLAPPED = 0x40000000,
- FILE_FLAG_NO_BUFFERING = 0x20000000,
- FILE_FLAG_RANDOM_ACCESS = 0x10000000,
- FILE_FLAG_SEQUENTIAL_SCAN = 0x08000000,
- FILE_FLAG_DELETE_ON_CLOSE = 0x04000000,
- FILE_FLAG_BACKUP_SEMANTICS = 0x02000000,
- FILE_FLAG_POSIX_SEMANTICS = 0x01000000,
- FILE_FLAG_OPEN_REPARSE_POINT = 0x00200000,
- FILE_FLAG_OPEN_NO_RECALL = 0x00100000,
- FILE_FLAG_FIRST_PIPE_INSTANCE = 0x00080000,
- }
- #endregion
- }
C#USB设备枚举Kernel32的PInvoke的更多相关文章
- C#:USB设备枚举 --转自CSDN作者:Splash
(一)DeviceIoControl的PInvoke /* ---------------------------------------------------------- 文件名称:Device ...
- usb设备枚举过程
USB主机在检测到USB设备插入后,就要对设备进行枚举了.为什么要枚举呢?枚举就是从设备读取一些信息,知道设备是什么样的设备,如何进行通信,这样主机就可以根据这些信息来加载合适的驱动程序.调试USB设 ...
- USB设备驱动之设备初始化(设备枚举)
USB设备从接入HUB到正常工作之前.都属于设备枚举阶段.所谓设备枚举.就是让host控制器认识USB设备,并为其准备资源.建立好主机与设备间的数据传递机制. 该阶段的工作,是USB通信协议规定的,所 ...
- Linux下usb设备驱动详解
USB驱动分为两块,一块是USB的bus驱动,这个东西,Linux内核已经做好了,我们可以不管,我们只需要了解它的功能.形象的说,USB的bus驱动相当于铺出一条路来,让所有的信息都可以通过这条USB ...
- USB 设备驱动(写给自己看的)
集线器与控制器(USB地址7bit) 设备,配置,端点,接口 USB1.0(低速1.2),1.1(全速450m),2.0(高速,电流传输)区别 引脚4根(V,D-,D+,gnd),miniUSB增加 ...
- Windows下USB磁盘开发系列二:枚举系统中所有USB设备
上篇 <Windows下USB磁盘开发系列一:枚举系统中U盘的盘符>介绍了很简单的获取系统U盘盘符的办法,现在介绍下如何枚举系统中所有USB设备(不光是U盘). 主要调用的API如下: 1 ...
- USB协议-USB设备的枚举过程
USB主机在检测到USB设备插入后,就要对设备进行枚举了.为什么要枚举?枚举就是从设备读取各种描述符信息,这样主机就可以根据这些信息来加载合适的驱动程序,从而知道设备是什么样的设备,如何进行通信等. ...
- MFC枚举USB设备碰到的一个疑难,还没解决
代码如下: 打开USB Hub设备之后,返回句柄hHubDevice,然后使用EnumerateHubPorts来枚举Hub的端 口.疑问在代码的中文注释中. bool CUsbEnumHub::En ...
- 浅析USB之设备枚举
当一个USB设备插入主机后,会有以下活动: 配上状态图
随机推荐
- C/C++基础----拷贝控制
拷贝控制操作,有5个特殊成员函数copy ctor,copy =opt,move ctor,move =opt,dtor 有哪些地方会用到 拷贝初始化 除了=定义变量时 参数传递和函数返回时 花括号列 ...
- mysql备份学习笔记及xtrabackup安装
(参考书籍:<深入浅出MySQL>) 一.备份恢复策略 a) 确定要备份的表的存储引擎是事务型还是非事务型 b) 确定使用全备份还是增量备份 c) 定期做备份 ...
- 在Linux里安装Samba(文件共享)方便在Windows下面操作
第一步:安装包 在CentOS是 yum install samba 在Ubuntu是 apt install samba 第二步:添加用户 adduser 用户名 smbpasswd -a 用户名 ...
- Notepad++ 列操作
在网上找到一篇关于socket编程的文章,想把其中的代码直接拷贝下来运行测试,但是人家网站做的不够人性化,每行的开头都有行号,直接拷贝就要一行行的删除,甚是麻烦,想到linux下的vi编辑器可以完成列 ...
- MySQL学习----explain查看一条sql 的性能
在开发的过程中,对于我们写的sql语句,我们有时候会考虑sql语句的性能,那么explain就是首选.Explain命令在解决数据库性能上是第一推荐使用命令,大部分的性能问题可以通过此命令来简单的解决 ...
- go语言学习--map中键值得删除
测试 map1 中是否存在 key1: 在例子 8.1 中,我们已经见过可以使用 val1 = map1[key1] 的方法获取 key1 对应的值 val1.如果 map 中不存在 key1,val ...
- Shell案例:图案打印
打印三角形图案 #!/bin/bash echo "Stars" ; i<=; i++ )) do ; j<=i; j++ )) do echo -n " * ...
- 函数的进阶(动态参数,命名空间和作用域,函数的嵌套,gloabal和nonlocal关键字)
1. 函数参数--动态传参 昨天已经解过了传参, 如果需要给一个函数传参,而参数又是不确定的. 或者我们给一个函数传很多参数, 我的形参就要写很多, 写起来就很麻烦, 这时我们可以考虑使用动态参数.形 ...
- [UE4]制作按钮小技巧
Normal和Pressed一样的图片和大小,Hovered也是一样的图片但是大小比Normal稍微大一点,这样点击按钮的时候就会产生按钮被按下去的感觉.
- [UE4]HorizontalBox,整体向右对齐