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设备插入主机后,会有以下活动: 配上状态图
随机推荐
- java取余%练习
package ltb6w1; import java.io.*; public class TestMod { String st; int c; InputStreamReader is=new ...
- Centos 安装Sublime text 3
1.下载sublime3 http://www.sublimetext.com/3 2.解压缩,即为安装. # cd /opt # tar xjf /home/alex/Downloads/subli ...
- pytest.9.使用fixture参数化接口入参
From: http://www.testclass.net/pytest/test_api_using_params/ 背景 接上一节v2ex网站的查看论坛节点信息的api.具体如下: 节点信息 获 ...
- Redis持久化实践及灾难恢复模拟 [转]
参考资料:Redis Persistence http://redis.io/topics/persistenceGoogle Groups https://groups.google.com/for ...
- vue之v-model
上一篇文章总结了v-bind的用法,我们发现v-bind实现了数据的单向绑定,将vue实例中的数据同元素属性值进行绑定,今天我们将总结vue中的数据双向绑定v-model. v-model实现双向绑定 ...
- 学习笔记之GitHub
GitHub https://github.com/ GitHub - Wikipedia https://en.wikipedia.org/wiki/GitHub GitHub (originall ...
- Scrapy学习篇(四)之数据存储
上一篇中,我们简单的实现了toscrapy网页信息的爬取,并存储到mongo,本篇文章信息看看数据的存储.这一篇主要是实现信息的存储,我们以将信息保存到文件和mongo数据库为例,学习数据的存储,依然 ...
- centos7安装zabbix4.2
附zabbixdocker镜像地址 https://hub.docker.com/u/zabbix/ zabbix官方文档 https://www.zabbix.com/cn/download 1.关 ...
- Dom操作的常用案例实现
本文介绍几个Dom操作的几个常用的案例.虽然现在各种web框架层出不穷,也很方便.但是了解最基本的实现方法对我们开发还是有很大的帮助的: 1.图片滚动案例 1.1 效果如下: 1.2 代码如下: ...
- [UE4]在AI Character中要获得AI的controller,需要使用Get AIController