usbredir-0.7内容详解(一)-程序员宅基地

技术标签: usbredir  github  c  代码  spice  

      在spice源码中难免会遇到usb重定向的问题,现在最新的usb重定向的版本是:usb重定向协议0.7版本(USB redirection protocol version 0.7),可以点击:usbredir-0.7.tar.bz2, 或者网站http://www.spice-space.org/page/UsbRedir下载就可以了。

 下完解压后里面有个协议说明文档usb-redirection-protocol.txt,主要介绍了版本信息和协议方面的东西,看懂了这个整个协议就差不多了。其他版本的极少就不看了,直接00.7版本了:

版本0.7                 2014.5.19发行

-usb_redir_ep_info_header扩展了max_streams字段,如果两边都有usb_redir_cap_bulk_streams,它将只会被发送/接收。

-改变了了bulk_stream 包的定义,允许在一对多点上分配/释放流,理论上讲是协议上的变化,但是目前未知还没哪一个去使用它,这一点可以安全的使用。


USB 重定向协议  版本0.7

-----------------------------------------------------------

在本文档中这个协议是为一个单独的usb设备建立usb传输隧道(通道),注意:不是整个hub,而是单个的usb设备。

最有意义的应用是将一个client / viewer  "a"上所连接的usb设备,连接到寄宿在主机"b"上的虚拟机 "v"内,并且可以在这个虚拟机 "v" 上显示,就像直接在虚拟机上链接的一样。

这个协议是一个可靠的双向传输协议,例如tcp 套接字socket,在协议中所有的整型都会通过这个管道的有序字节被发送,所有的结构体都被被打包发送(no padding)。

定义:

usb-device:usb-device的usb传输将会建立隧道。

usb-guest:连接usb-device和使用,就像直接连接和使用它一样,例如一个虚拟机运行的是guset os 通过网络连接了一个usb-device,就像usb-device是这个虚拟机的一部分。

usb-host:使一个usb-device可以被usb-guest使用。例如通过网络连接到一个机器上的usb光驱,在另一台上的虚拟设备上呈现。

基本包结构/通信

------------------------------------------------------------

在usb-guest和usb-host之间所交换的每一个包都开始于一个连表头usb_redir_header,后面识根据特定的可选类型的可选数据。

                   
//下面是<span style="font-family: Arial, Helvetica, sans-serif;">usb_redir_header,每个都如下所示 </span>
struct usb_redir_header {
     uint32_t type; 
     uint32_t length;
     uint32_t id;   
 }                  
//或者两边(<span style="font-size:18px;">usb-guest和</span><span style="font-size:18px;">usb-host</span>)都含有<span style="font-family: Arial, Helvetica, sans-serif;">usb_redir_cap_64bits_ids 则如下所示</span>          
struct usb_redir_header {
     uint32_t type;                                 
     uint32_t length;
     uint64_t id;   
 }      

/******************************************************

type:包的类型来,自与枚举
<pre name="code" class="cpp">length:可选类型的header + 可选类型的data,可以为0
id:当usb-guest发送包时就会产生一个唯一的id,usb-host将会使用同样的id来回应这个包,允许usb-guest根据初始的re     quest来匹配回应

************************************************************/

有两个类型的包:

1) control packets       //控制包                                                                                          
2) data packets           //数据包

control packets在usb-host,同时被操作,并且发送request到 host os后,就会“等待”回应,usb-host将会停止进程知道等到回应的包。然而对于数据包data packets,usb-host通过提交包含请求的data packetshost os,让usb-host知道有一个来自usb-device的回应。

注意:control packets 应当仅仅发送到usb-host上,当没有数据包在设备/接口/终点影响的控制包的等待时,所有挂起的数据包将会被丢弃。

包的类型列表        
----------------           
                           
control packets://控制包           
 usb_redir_hello            
 usb_redir_device_connect   
 usb_redir_device_disconnect
 usb_redir_reset            
 usb_redir_interface_info   
 usb_redir_ep_info          
 usb_redir_set_configuration
 usb_redir_get_configuration
 usb_redir_configuration_status
 usb_redir_set_alt_setting  
 usb_redir_get_alt_setting  
 usb_redir_alt_setting_status
 usb_redir_start_iso_stream 
 usb_redir_stop_iso_stream  
 usb_redir_iso_stream_status                                                                                                        
 usb_redir_start_interrupt_receiving
 usb_redir_stop_interrupt_receiving
 usb_redir_interrupt_receiving_status
 usb_redir_alloc_bulk_streams 
 usb_redir_free_bulk_streams
 usb_redir_bulk_streams_status
 usb_redir_cancel_data_packet 
 usb_redir_filter_reject    
 usb_redir_filter_filter    
 usb_redir_device_disconnect_ack   
 usb_redir_start_bulk_receiving    
 usb_redir_stop_bulk_receiving
 usb_redir_bulk_receiving_status   
data packets://数据包              
 usb_redir_control_packet   
 usb_redir_bulk_packet      
 usb_redir_iso_packet       
 usb_redir_interrupt_packet 
 usb_redir_buffered_bulk_packet                           

每一个usb-host都包含一个状态字段,如下所示

enum {        
    usb_redir_success, 
    usb_redir_cancelled,    /* 传输被取消 */
    usb_redir_inval,        /* Invalid packet type / length / ep, etc. */
    usb_redir_ioerror,      /* IO error 输入输出错误 */
    usb_redir_stall,        /* Stalled 停滞 */
    usb_redir_timeout,      /* Request timed out 请求超时*/
    usb_redir_babble,       /* The device has "babbled" 设备泄露 */
};<span style="font-size: 18px; font-family: Arial, Helvetica, sans-serif;">/*注意在未来的版本有可能会添加状态码到新的 error 情况下,因此位置的状态值将会为译为一个错误*/</span>


usb_redir_hello
----------------------------------

//usb_redir_header.type:    usb_redir_hello
//usb_redir_header.length:  <see description>
//usb_redir_header.id:      0 (always as this is an unsolicited packet)
                           
struct usb_redir_hello_header {
    char     version[64];  
    uint32_t capabilities[0];
}
<span style="font-size: 18.1818180084229px;">/*一旦连接建立的时候这个类型的包将会被两边发送,它是强制被发送的第一个包,他包含</span> :
<pre name="code" class="cpp" style="font-size: 18.1818180084229px;">version:从0开始的开源版本字符串,用作log,不被解析
capabilities:用于发布的可变长度数组,会在下面的枚举定义

*/    
enum {                 
    /* Supports USB 3 bulk streams 支持usb 3 块流*/
    usb_redir_cap_bulk_streams, 
    /* The device_connect packet has the device_version_bcd field设备链接的bcd字段 */
    usb_redir_cap_connect_device_version,
    /* Supports usb_redir_filter_reject and usb_redir_filter_filter pkts */
    usb_redir_cap_filter, 
    /* Supports the usb_redir_device_disconnect_ack packet */
    usb_redir_cap_device_disconnect_ack,
    /* The ep_info packet has the max_packet_size field */
    usb_redir_cap_ep_info_max_packet_size,
    /* Supports 64 bits ids in usb_redir_header */
    usb_redir_cap_64bits_ids,
    /* Supports 32 bits length in usb_redir_bulk_packet_header */
    usb_redir_cap_32bits_bulk_length,
    /* Supports bulk receiving / buffered bulk input */
    usb_redir_cap_bulk_receiving,
};    


usb_redir_device_connect

------------------------

//usb_redir_header.type:    usb_redir_device_connect
//usb_redir_header.length:  sizeof(usb_redir_device_connect_header)
//usb_redir_header.id:      0 (always as this is an unsolicited packet)
                           
enum {//usb重定向的速度:低速,全速,高速,超速                     
    usb_redir_speed_low,   
    usb_redir_speed_full,  
    usb_redir_speed_high,  
    usb_redir_speed_super, 
    usb_redir_speed_unknown = 255
}                          
                           
struct usb_redir_device_connect_header {
    uint8_t speed;//由上面的枚举获得         
    uint8_t device_class;  //设备类
    uint8_t device_subclass;//子类
    uint8_t device_protocol; //协议
    uint16_t vendor_id;    //供应商id
    uint16_t product_id;   //产品id
    uint16_t device_version_bcd;//版本bcd
}  //这个包只被usb-host发送,当设备可用的时候。注意:usb-host可能会重新利用存在连接对于一个新的/新挂载的设备上,这种情况下会在一个usb_redir_device_disconnect消息被发送通知usb-guest一个新的可用设备后重新被发送。注意:在发送usb_redir_device_connect_info 之前首先通过usb_redir_interface_info发送usb_redir_ep_info.    
usb_redir_device_disconnect

-------------------------------------------

//usb_redir_header.type:    usb_redir_device_disconnect
//usb_redir_header.length:  0
//usb_redir_header.id:      0 (always as this is an unsolicited packet)
//这个包被usb-host发送来告知设备已经断开(卸载),注意:在一些平台上usb-host也许不会自动发现断开直到usb包被发送到设备。
 
usb_redir_reset

-----------------------------------

//usb_redir_header.type:    usb_redir_reset
//usb_redir_header.length:  0
//这个包会被usb-guest发送来触发一个usb设备的重置。注意:在reset之后当有东西出错时usb-host可能无法重连,如果发生这样的情况usb_redir_device_disconnect将会呗usb-host发送












版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/hubbybob1/article/details/48651695

智能推荐

Kyligence 发布数据和分析领域垂直大模型司南(Compass)_司南模型怎么测试-程序员宅基地

文章浏览阅读140次。12 月 19 日,跬智信息(Kyligence)正式发布数据和分析领域垂直大模型司南(Compass)(以下简称“司南大模型”)。基于多年数据和分析领域的实践积累和全行业指标洞察的海量语料,Kyligence司南大模型已具备自然语言对话分析、指标搜索与推荐、自动化数据洞察、KPI 评估、智能决策建议等核心能力。_司南模型怎么测试

MySQL数据库Insert语句慢SQL处理-程序员宅基地

文章浏览阅读3.8k次。#问题描述insert into …普通的插入语句,经常出现耗时2s以上#数据状态1.表数据量大,每天产生200万条数据2.高并发插入#问题解决1.由于表中数据量庞大,建议数据归档处理,冷热处理2.表中有过多索引,当数据insert时,索引会重排产生太多的io操作。导致缓慢,有必然要的只保留主键。3.表的数据库引擎,默认InnerDB,若数据不重要,可以使用MyISAM......

EasyDarwin开源流媒体云平台之EasyRMS录播服务器功能设计_开源录播系统-程序员宅基地

文章浏览阅读3.6k次。需求背景EasyDarwin开发团队维护EasyDarwin开源流媒体服务器也已经很多年了,之前也陆陆续续尝试过很多种服务端录像的方案,有:在EasyDarwin中直接解析收到的RTP包,重新组包录像;也有:在EasyDarwin中新增一个RecordModule,再以RTSPClient的方式请求127.0.0.1自己的直播流录像,但这些始终都没有成气候;我们的想法是能够让整套EasyDarwin_开源录播系统

oracle Plsql 执行update或者delete时卡死问题解决办法_oracle delete update 锁表问题-程序员宅基地

文章浏览阅读1.1w次。今天碰到一个执行语句等了半天没有执行:delete table XXX where ......,但是在select 的时候没问题。后来发现是在执行select * from XXX for update 的时候没有commit,oracle将该记录锁住了。可以通过以下办法解决: 先查询锁定记录 Sql代码 SELECT s.sid, s.seri_oracle delete update 锁表问题

Xcode Undefined symbols 错误_xcode undefined symbols:-程序员宅基地

文章浏览阅读3.4k次。报错信息error:Undefined symbol: typeinfo for sdk::IConfigUndefined symbol: vtable for sdk::IConfig具体信息:Undefined symbols for architecture x86_64: "typeinfo for sdk::IConfig", referenced from: typeinfo for sdk::ConfigImpl in sdk.a(config_impl.o) _xcode undefined symbols:

项目05(Mysql升级07Mysql5.7.32升级到Mysql8.0.22)_mysql8.0.26 升级32-程序员宅基地

文章浏览阅读249次。背景《承接上文,项目05(Mysql升级06Mysql5.6.51升级到Mysql5.7.32)》,写在前面需要(考虑)检查和测试的层面很多,不限于以下内容。参考文档https://dev.mysql.com/doc/refman/8.0/en/upgrade-prerequisites.htmllink推荐阅读以上链接,因为对应以下问题,有详细的建议。官方文档:不得存在以下问题:0.不得有使用过时数据类型或功能的表。不支持就地升级到MySQL 8.0,如果表包含在预5.6.4格_mysql8.0.26 升级32

随便推点

使用flex-wrap实现弹性盒自动换行-程序员宅基地

文章浏览阅读2w次,点赞6次,收藏10次。布局的时候,我们常常会需要一行排列3/4/5/6个盒子,必要时自动换行,这时可以借助CSS3中的flex-wrap属性。flex-wrap: nowrap|wrap|wrap-reverse|initial|inherit;nowrap为默认值,wrap必要时实现自动换行,reverse必要时换行并反向排列关键是在父元素中设置flex-wrap值为wrap, 然后是设置子元素的wi...

改变Android Studio的背景background_as怎么设置背景-程序员宅基地

文章浏览阅读2.7k次,点赞2次,收藏5次。改变Android Studio的背景background我们先点File然后再点Settings里的Appearance,点击Theme换成Darcula 把白色换成黑色,这样的好处是换成background是图片比较清晰。此处正式开始AS换背景这里我们颜色从白色换成了黑色,先点File里Settings的Appearance然后点background image把你喜欢的图片放进去(图片放在D盘自己新建的文件)..._as怎么设置背景

桩筏有限元中的弹性板计算_专栏 l 增材制造点阵结构在压力容器优化设计中的应用...-程序员宅基地

文章浏览阅读179次。“增材制造是未来制造业的发展趋势,其优势显而易见,它可以实现传统加工工艺难以制造的设计,比如复杂薄壁结构、点阵结构、一体化结构等。其中,点阵结构作为一种新型的轻量化结构,具有良好的比刚度、比强度等力学性能。传统加工工艺很难制造点阵结构,3D打印技术的快速发展使得点阵结构的制造更加具有可行性。”本期谷.专栏列举了面向增材制造的点阵加筋一体化压力容器的设计与分析案例,仿真技术作为正向设计体系..._点阵结构的等效属性计算

Firefox安装广告屏蔽插件(uBlock Origin)_ublock origin插件-程序员宅基地

文章浏览阅读5.9k次,点赞2次,收藏2次。由于国内用户IP被屏蔽的原因,安装广告屏蔽插件(uBlock Origin、AdGuard、AdBlocker、AdBlock For Firefox、AdBlock)访问受限,官方原因为“由于法律原因不可用(HTTP 451 Unavailable For Legal Reasons)”,需要另辟蹊径安装,以下是安装uBlock Origin的方法介绍。然后,在Firefox的扩展管理页面,打开【从文件安装附加组件】选项。选择刚才下载的.xpi文件,就可以成功安装了。_ublock origin插件

k8s挂载目录_kubernetes(k8s)的pod使用统一的配置文件configmap挂载-程序员宅基地

文章浏览阅读1.2k次。在容器化应用中,每个环境都要独立的打一个镜像再给镜像一个特有的tag,这很麻烦,这就要用到k8s原生的配置中心configMap就是用解决这个问题的。使用configMap部署应用。这里使用nginx来做示例,简单粗暴。直接用vim常见nginx的配置文件,用命令导入进去kubectl create cm nginx.conf --from-file=/home/nginx.conf然后查看kub..._pod mount目录会自动创建吗

java计算机毕业设计springcloud+vue基于微服务的分布式新生报到系统_关于spring cloud的参考文献有啥-程序员宅基地

文章浏览阅读169次。随着互联网技术的发发展,计算机技术广泛应用在人们的生活中,逐渐成为日常工作、生活不可或缺的工具,高校各种管理系统层出不穷。高校作为学习知识和技术的高等学府,信息技术更加的成熟,为新生报到管理开发必要的系统,能够有效的提升管理效率。一直以来,新生报到一直没有进行系统化的管理,学生无法准确查询学院信息,高校也无法记录新生报名情况,由此提出开发基于微服务的分布式新生报到系统,管理报名信息,学生可以在线查询报名状态,节省时间,提高效率。_关于spring cloud的参考文献有啥