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设备插入主机后,会有以下活动: 配上状态图
随机推荐
- boost::asio::io_context类
//有个疑惑: 向io_context对象中提交的任务只能被顺序化的执行. //下面这个构造函数表明可以运行多线程啊..... /** * Construct with a hint about th ...
- Centos7.2/7.3集群安装Kubernetes 1.8.4 + Dashboard(转)
原文https://www.cnblogs.com/burningTheStar/p/7865998.html 1.环境配置 结点数量:3 结点系统:CentOS 7.2 / 7.3 2.效果展示 3 ...
- java多线程——监视锁(monitor)(转)
https://blog.csdn.net/hqq2023623/article/details/51000153 java中每个对象都有唯一的一个monitor,想拥有一个对象的monitor的话有 ...
- int, bool, string的操作
基本数据类型 1.int型 可以求整数的二进制长度.输入一个数字a,"a.bit_length()"语法求a的二进制长度. a = 3 #二进制为11 print(a.bit_le ...
- [UE4]运行时脱离视角,进入自由视角
按 Shift + F1让鼠标脱离游戏窗口,然后点击右上角的按钮,然后鼠标在游戏窗口点击一下,就只有自由漫游了. 还可以点击选中Word Outliner窗口的物体.
- svn 的add 和 commit
add 功能:向文件拷贝所在的文件夹中添加新的文件,并作出标识,是新添加的,下一步提交时将一并提交到Subversion版本库中去.简单的说就是将一新文件加入svn,你添加再提交后该文件就进入subv ...
- AI的胜利,人类的荣耀
在围棋界,AI战胜人类,这不是人类的耻辱,是人类的荣耀. 看到柯洁悲伤哭泣的画面,曾经放出豪言的大男孩,低下了骄傲的头.我相信经过这样一次挑战,对他的成长有好处,无论是人生,还是棋艺. 在围棋领域,人 ...
- 点不到的NO
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> ...
- es6基础(3)-正则扩展
//正则扩展 { let regex=new RegExp('xyz','i'); let regex2=new RegExp(/xyz/i); console.log(regex.test('xyz ...
- mac“打不开身份不明的开发者”
在mac安装软件发现这样的提示 解决方法: 打开系统偏好设置-->安全与隐私-->通用-->选择任何来源 不能选择的话点击按钮锁即可编辑 没有“任何来源”选项(比如我的mac) 打开 ...