WinUsb_ReadPipe和WinUsb_WritePipe函数功能理解

在向管道写数据和读数据时我们经常会用到WinUsb_ReadPipe和WinUsb_WritePipe。

现在我对这两个函数还是不太理解,所以打算自己看英文文档说明,在此记录下。

WinUsb_ReadPipe(这个函数一般处理的是IN包后,USB从机向主机发送过来的数据)

BOOL __stdcall WinUsb_ReadPipe(
  _In_       WINUSB_INTERFACE_HANDLE InterfaceHandle,
  _In_       UCHAR PipeID,
  _Out_      PUCHAR Buffer,
  _In_       ULONG BufferLength,
  _Out_opt_  PULONG LengthTransferred,
  _In_opt_   LPOVERLAPPED Overlapped
);

功能:从指定的管道读数据

第一个参数: InterfaceHandle: 和那个端点的那个管道联接。

第二个参数:PipeID,就是管道的地址,第7位表示端点数据方向:0表示OUT(主-从),1表示IN(从-主)。

第三个参数:Buffer,接收读取的数据的缓冲区。

第四个参数:BufferLength,读取数据的最大个数,这个值必须小于或等于Buffer缓冲区中的字节个数。

第五个参数:LengthTransferred ,一个无符号长整型指针,接收实际复制到Buffer缓冲区中的个数。

第六个参数:Overlapped,一般定为一个空指针,NULL。

返回值:操作成功返回TRUE,失败返回FALSE。(GetLastError获取错误返回值


如果设备返回数据(我理解是INpacket)大于最大的传输长度,WinUSB将分离这个数据成一较小段的,并且连续提交。如果这个传输数据的长度不是最大传输长度的整数倍,WINUSB就会把他增加到最大传输个数的倍数。

USB包的大小不考虑传输请求,如果设备响应了一个对现在的缓冲区来说较大的包,并且读请求符合管道上指针的类型,如果管道指针允许部分读取(ALLOW_PARTIAL_READS,),WINUSB将把剩下的数据放在下次传输的开头,


如果第六个参数为非空,第五个参数设置的值是无意义的。


如果PIPE为空,WinUsb_ReadPipe我们函数不返回直到PIPE中有数据,如果出现错误状况或者超时,函数就返回FALSE,GetLastError获取错误返回值).



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值