Demo: Rio: a system solution for sharing I/O between mobile systems

A. A. Sani, Kevin Boos, Minhong Yun, Lin Zhong
{"title":"Demo: Rio: a system solution for sharing I/O between mobile systems","authors":"A. A. Sani, Kevin Boos, Minhong Yun, Lin Zhong","doi":"10.1145/2594368.2601471","DOIUrl":null,"url":null,"abstract":"A user nowadays owns a variety of mobile systems, including smartphones, tablets, smart glasses, and smart watches, each equipped with a plethora of I/O devices, such as cameras, speakers, microphones, sensors, and cellular modems. There are many interesting use cases in which an application running on one mobile system accesses I/O on another system, for three fundamental reasons. (i) Mobile systems can be in different physical locations or orientations. For example, one can control a smartphone's high-resolution camera from a tablet camera application to more easily capture a self-portrait. (ii) Mobile systems can serve different users. For example, one can a play music for another user if one's smartphone can access the other device's speaker. (iii) Certain mobile systems have unique I/O devices due to their distinct form factor and targeted use cases. For example, a user can make a phone call from her tablet using the modem and SIM card in her smartphone. Solutions exist for sharing I/O devices, e.g., for camera [1], speaker [2], and modem (for messaging) [3]. However, these solutions have three limitations. (i) They do not support unmodified applications. (ii) They do not expose all the functionality of an I/O device for sharing. (iii) They are I/O class-specific, requiring significant engineering effort to support new I/O devices. We demonstrate Rio (Remote I/O), an I/O sharing solution for mobile systems that overcomes all three aforementioned limitations. Rio adopts a split-stack I/O sharing model, in which the I/O stack is split between the two mobile systems at a certain boundary. All communications that cross this boundary are intercepted on the mobile system hosting the application and forwarded to the mobile system with the I/O device, where they are served by the rest of the I/O stack. Rio uses device files as its boundary of choice. Device files are used in Unix-like OSes, such as Android and iOS, to abstract many classes of I/O devices, providing an I/O class-agnostic boundary. The device file boundary supports I/O sharing for unmodified applications, as it is transparent to the application layer. It also exposes the full functionality of each I/O device to other mobile systems by allowing processes in one system to directly communicate with the device drivers in another. Rio is not the first system to exploit the device file boundary; our previous work, Paradice [5], uses device files as the boundary for I/O virtualization inside a single system. However, Rio faces a different set of challenges regarding how to properly exploit this boundary, as explained in the full paper [6]. In this demo, we use a prototype implementation of Rio for Android systems. Our implementation supports four important I/O classes: camera, audio devices such as speaker and microphone, sensors such as accelerometer, and cellular modem (for phone calls and SMS). It consists of about 7100 lines of code, of which less than 500 are specific to I/O classes. Rio also supports I/O sharing between heterogeneous mobile systems, including tablets and smartphones. See [4] for a video of the demo.","PeriodicalId":131209,"journal":{"name":"Proceedings of the 12th annual international conference on Mobile systems, applications, and services","volume":"1 1","pages":"0"},"PeriodicalIF":0.0000,"publicationDate":"2014-06-02","publicationTypes":"Journal Article","fieldsOfStudy":null,"isOpenAccess":false,"openAccessPdf":"","citationCount":"0","resultStr":null,"platform":"Semanticscholar","paperid":null,"PeriodicalName":"Proceedings of the 12th annual international conference on Mobile systems, applications, and services","FirstCategoryId":"1085","ListUrlMain":"https://doi.org/10.1145/2594368.2601471","RegionNum":0,"RegionCategory":null,"ArticlePicture":[],"TitleCN":null,"AbstractTextCN":null,"PMCID":null,"EPubDate":"","PubModel":"","JCR":"","JCRName":"","Score":null,"Total":0}
引用次数: 0

Abstract

A user nowadays owns a variety of mobile systems, including smartphones, tablets, smart glasses, and smart watches, each equipped with a plethora of I/O devices, such as cameras, speakers, microphones, sensors, and cellular modems. There are many interesting use cases in which an application running on one mobile system accesses I/O on another system, for three fundamental reasons. (i) Mobile systems can be in different physical locations or orientations. For example, one can control a smartphone's high-resolution camera from a tablet camera application to more easily capture a self-portrait. (ii) Mobile systems can serve different users. For example, one can a play music for another user if one's smartphone can access the other device's speaker. (iii) Certain mobile systems have unique I/O devices due to their distinct form factor and targeted use cases. For example, a user can make a phone call from her tablet using the modem and SIM card in her smartphone. Solutions exist for sharing I/O devices, e.g., for camera [1], speaker [2], and modem (for messaging) [3]. However, these solutions have three limitations. (i) They do not support unmodified applications. (ii) They do not expose all the functionality of an I/O device for sharing. (iii) They are I/O class-specific, requiring significant engineering effort to support new I/O devices. We demonstrate Rio (Remote I/O), an I/O sharing solution for mobile systems that overcomes all three aforementioned limitations. Rio adopts a split-stack I/O sharing model, in which the I/O stack is split between the two mobile systems at a certain boundary. All communications that cross this boundary are intercepted on the mobile system hosting the application and forwarded to the mobile system with the I/O device, where they are served by the rest of the I/O stack. Rio uses device files as its boundary of choice. Device files are used in Unix-like OSes, such as Android and iOS, to abstract many classes of I/O devices, providing an I/O class-agnostic boundary. The device file boundary supports I/O sharing for unmodified applications, as it is transparent to the application layer. It also exposes the full functionality of each I/O device to other mobile systems by allowing processes in one system to directly communicate with the device drivers in another. Rio is not the first system to exploit the device file boundary; our previous work, Paradice [5], uses device files as the boundary for I/O virtualization inside a single system. However, Rio faces a different set of challenges regarding how to properly exploit this boundary, as explained in the full paper [6]. In this demo, we use a prototype implementation of Rio for Android systems. Our implementation supports four important I/O classes: camera, audio devices such as speaker and microphone, sensors such as accelerometer, and cellular modem (for phone calls and SMS). It consists of about 7100 lines of code, of which less than 500 are specific to I/O classes. Rio also supports I/O sharing between heterogeneous mobile systems, including tablets and smartphones. See [4] for a video of the demo.
演示:Rio:用于在移动系统之间共享I/O的系统解决方案
现在,用户拥有各种各样的移动系统,包括智能手机、平板电脑、智能眼镜和智能手表,每个系统都配备了大量的I/O设备,如摄像头、扬声器、麦克风、传感器和蜂窝调制解调器。有许多有趣的用例,其中运行在一个移动系统上的应用程序访问另一个系统上的I/O,原因有三个。(i)移动系统可以在不同的物理位置或方向。例如,人们可以通过平板电脑相机应用程序控制智能手机的高分辨率相机,更轻松地拍摄自画像。移动系统可以为不同的用户服务。例如,如果一个人的智能手机可以访问另一个设备的扬声器,他就可以为另一个用户播放音乐。(iii)某些移动系统由于其独特的外形因素和目标用例而具有独特的I/O设备。例如,用户可以使用智能手机中的调制解调器和SIM卡在平板电脑上打电话。存在用于共享I/O设备的解决方案,例如用于相机[1]、扬声器[2]和调制解调器(用于消息传递)[3]。然而,这些解决方案有三个限制。它们不支持未经修改的应用程序。(ii)它们不公开I/O设备的所有功能以供共享。(iii)它们是特定于I/O类别的,需要大量的工程工作来支持新的I/O设备。我们将演示Rio(远程I/O),这是一种用于移动系统的I/O共享解决方案,它克服了上述所有三个限制。Rio采用split-stack I/O共享模型,将I/O堆栈在两个移动系统之间按一定边界进行分割。所有跨越这个边界的通信都在承载应用程序的移动系统上被拦截,并通过I/O设备转发到移动系统,在那里它们由I/O堆栈的其余部分提供服务。Rio使用设备文件作为其选择的边界。设备文件用于类unix操作系统,如Android和iOS,用于抽象I/O设备的许多类,提供与I/O类无关的边界。设备文件边界支持未修改应用程序的I/O共享,因为它对应用层是透明的。它还允许一个系统中的进程与另一个系统中的设备驱动程序直接通信,从而向其他移动系统公开每个I/O设备的全部功能。Rio并不是第一个利用设备文件边界的系统;我们之前的工作Paradice[5]使用设备文件作为单个系统内I/O虚拟化的边界。然而,正如全文所述[6],里约在如何正确利用这一边界方面面临着一系列不同的挑战。在这个演示中,我们使用了Rio在Android系统上的原型实现。我们的实现支持四种重要的I/O类:相机、音频设备(如扬声器和麦克风)、传感器(如加速度计)和蜂窝调制解调器(用于电话和短信)。它由大约7100行代码组成,其中不到500行是特定于I/O类的。Rio还支持异构移动系统(包括平板电脑和智能手机)之间的I/O共享。参见[4]的演示视频。
本文章由计算机程序翻译,如有差异,请以英文原文为准。
求助全文
约1分钟内获得全文 求助全文
来源期刊
自引率
0.00%
发文量
0
×
引用
GB/T 7714-2015
复制
MLA
复制
APA
复制
导出至
BibTeX EndNote RefMan NoteFirst NoteExpress
×
提示
您的信息不完整,为了账户安全,请先补充。
现在去补充
×
提示
您因"违规操作"
具体请查看互助需知
我知道了
×
提示
确定
请完成安全验证×
copy
已复制链接
快去分享给好友吧!
我知道了
右上角分享
点击右上角分享
0
联系我们:info@booksci.cn Book学术提供免费学术资源搜索服务,方便国内外学者检索中英文文献。致力于提供最便捷和优质的服务体验。 Copyright © 2023 布克学术 All rights reserved.
京ICP备2023020795号-1
ghs 京公网安备 11010802042870号
Book学术文献互助
Book学术文献互助群
群 号:481959085
Book学术官方微信