CN102135900B - 信息处理装置和信息处理方法 - Google Patents
信息处理装置和信息处理方法 Download PDFInfo
- Publication number
- CN102135900B CN102135900B CN2011100288918A CN201110028891A CN102135900B CN 102135900 B CN102135900 B CN 102135900B CN 2011100288918 A CN2011100288918 A CN 2011100288918A CN 201110028891 A CN201110028891 A CN 201110028891A CN 102135900 B CN102135900 B CN 102135900B
- Authority
- CN
- China
- Prior art keywords
- state
- status information
- runtime environment
- information
- environment
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/451—Execution arrangements for user interfaces
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Human Computer Interaction (AREA)
- Debugging And Monitoring (AREA)
- Stored Programmes (AREA)
Abstract
本发明涉及信息处理装置和信息处理方法。该信息处理装置包括:环境存储单元,该环境存储单元存储指令集,所述指令集用于实现包括第一运行时环境和第二运行时环境的多个运行时环境;执行装置,该执行装置执行存储在所述环境存储装置中的所述指令集;状态保持装置,该状态保持装置存储要从所述第一运行时环境发送到所述第二运行时环境的一条或多条状态信息;定时存储装置,该定时存储装置存储与所述第一运行时环境和所述第二运行时环境中的一个的执行状态相关的条件;以及发送装置,该发送装置在存储在所述定时存储装置中的所述条件得到满足的情况下,向所述第二运行时环境发送存储在所述状态保持装置中的所述一条或多条状态信息。
Description
本申请基于并根据35U.S.C.119要求2010年1月26日提交的日本专利申请No.2010-013999的优先权。
技术领域
本发明涉及两个运行时(runtime)环境之间的通信。
背景技术
已知一种用于在单个信息处理装置上虚拟化的两个运行时环境之间传递数据的技术。例如,JP2009-116561A公开了在具有多核CPU或多个处理器的信息处理装置中的虚拟机之间发送/接收数据。JP2002-351854A公开了经由主机系统和子系统(虚拟机)之间的DPRAM发送/接收数据。JP3-65734A公开了在两个虚拟机之间发送/接收消息。JP2008-299791A公开了在虚拟机(VM)之间执行诸如复制数据的处理。
发明内容
当在运行时环境之间传送表示电子邮件到达的状态、表示设置信息处理装置的状态(例如,静默模式)等时,如果频繁地进行传送,则造成处理负荷增加,并且这可能导致响应的劣化和/或功耗的增加。另一方面,如果仅在切换运行时环境时才执行传送,则造成在切换时执行的处理的量增加,这可能导致切换速度劣化。
为解决这种问题,本发明提供了一种用于在运行时环境之间有效地传送状态信息的技术。
在本发明的一个方面,提供了一种信息处理装置,该信息处理装置包括:环境存储装置,该环境存储装置存储指令集,所述指令集用于实现包括第一运行时环境和第二运行时环境的多个运行时环境;执行装置,该执行装置在所述多个运行时环境中的一个运行时环境的执行状态是前台状态,而各个其它运行时环境的执行状态是后台状态的情况下,执行存储在所述环境存储装置中的所述指令集;状态保持装置,该状态保持装置存储要从所述第一运行时环境发送到所述第二运行时环境的一条(或多条)状态信息;定时存储装置,该定时存储装置存储与目标运行时环境的执行状态相关的条件,该目标运行时环境是所述第一运行时环境和所述第二运行时环境中的一个运行时环境;以及发送装置,该发送装置在存储在所述定时存储装置中的所述条件得到满足的情况下,向所述第二运行时环境发送存储在所述状态保持装置中的所述一条(或多条)状态信息。
在这种信息处理装置中,可以比其中发送状态信息的配置更有效地传送状态信息,而与和目标运行时环境的执行状态相关的条件无关。
在一优选实施方式中,所述目标运行时环境可以是所述第一运行时环境,并且所述条件可以包括以下的条件:所述目标运行时环境的执行状态是后台状态或已经从所述前台状态切换至所述后台状态。
在这种信息处理装置中,与其中发送状态信息的配置相比,可以减小传送状态信息的频度,而与和目标运行时环境的执行状态相关的条件无关。
在另一优选实施方式中,所述信息处理装置还可以包括:接收装置,该接收装置接收来自所述第一运行时环境的所述一条(或多条)状态信息;和输出装置,该输出装置输出所述接收装置接收到的所述一条(或多条)状态信息。
在又一优选实施方式中,所述信息处理装置还可以包括状态信息使用装置,该状态信息使用装置使用从所述输出装置输出的所述一条(或多条)状态信息。
在又一优选实施方式中,可以将所述一条(或多条)状态信息中的每一条状态信息分类为多种类型中的一种类型,所述目标运行时环境是所述第一运行时环境,所述定时存储装置存储表示针对所述多种类型中的每一种类型的优先级程度的信息,并且所述条件包括如下条件:对于优先级程度高的类型,与所述目标运行时环境的执行状态无关地发送所述一条(或多条)状态信息,而对于优先级程度低的类型,在所述目标运行时环境的执行状态是所述后台状态或已经从所述前台状态切换至所述后台状态时发送所述一条(或多条)状态信息。
在又一优选实施方式中,所述状态保持装置可以存储多个数据集,所述多个数据集中的每一个数据集都包括状态信息和与该状态信息相对应的标志,在输入新状态信息时,所述状态保持装置将该新状态信息写入所述数据集,在将该新状态信息写入至所述数据集之后,所述状态保持装置重写与所写入的状态信息相对应的标志,以表示该状态信息尚未被发送,当执行所述发送时,所述发送装置从存储在所述状态保持装置中的所述一条(或多条)状态信息当中提取对应标志表示状态信息尚未被发送的一条(或多条)状态信息,并发送所提取的所述一条(或多条)状态信息,并且所述状态保持装置重写由所述发送装置发送的所述一条(或多条)状态信息中的每一条状态信息对应的标志,以使该标志表示对应的状态信息已经被发送。
在又一优选实施方式中,可以将所述一条(或多条)状态信息中的每一条状态信息分类为包括与信息呈现相关的信息呈现状态的多种状态中的一种状态,所述目标运行时环境是所述第一运行时环境,并且所述条件包括以下的条件:在所述一条(或多条)状态信息中的任一条状态信息与所述信息呈现状态相关的情况下,当所述目标运行时环境的执行状态是所述前台状态时不执行该条状态信息的发送,而当所述目标运行时环境的执行状态是所述后台状态或者已经从所述前台状态切换至所述后台状态时执行该条状态信息的发送。
在又一优选实施方式中,所述多种状态可以包括与所述信息处理装置的设置相关的设置状态,并且所述条件包括以下的条件:在所述一条(或多条)状态信息中的任一条状态信息与所述设置状态相关的情况下,与所述目标运行时环境的执行状态无关地发送该条状态信息。
在又一优选实施方式中,所述多个数据集中的每一个数据集还可以包括表示各条状态信息的类型的状态类型,并且当输入一条新状态信息时,所述状态保持装置将该条新状态信息与包括在所述多个数据集中的所述一条(或多条)状态信息中的、与和该条新状态信息的状态类型相同的状态类型相对应的一条状态信息,并且当所比较的状态信息不同时,利用该条新状态信息重写包括在所述数据集中的该条状态信息,并且重写与所重写的该条状态信息相对应的标志,以表示对应的该条状态信息尚未被发送。
在这种信息处理装置中,与不在新状态信息与已存储的状态信息之间执行比较的配置相比,可以减小通信的频度。
在又一优选实施方式中,所述目标运行时环境可以是所述第一运行时环境,并且所述条件可以包括以下的条件:在所述目标运行时环境的执行状态已经从所述前台状态切换至所述后台状态之后,执行所述一条(或多条)状态信息的发送。
在这种信息处理装置中,与在完成切换至后台状态之前执行一条(或多条)状态信息的发送的配置相比,可以减少使运行时环境处于前台状态下所需的时段。
在又一优选实施方式中,所述条件可以包括如下条件:当存储在所述状态保持装置中的所述一条(或多条)状态信息的量超出阈值时,执行所述一条(或多条)状态信息的发送。
在又一优选实施方式中,所述条件可以包括如下条件:当发送一条状态信息时,发送另一条状态信息。
在又一优选实施方式中,所述发送装置可以响应于来自所述第二运行时环境或其它装置的请求而发送所述一条(或多条)状态信息。
在又一优选实施方式中,所述状态保持装置可以存储多个数据集,所述多个数据集中的每一个数据集都包括状态信息和表示该状态信息的类型的状态类型,所述信息处理装置包括访问限制管理装置,该访问限制管理装置存储策略,所述策略针对各个所述状态类型表示是否准许接收对应的状态信息,并且所述接收装置根据存储在所述访问限制管理装置中的所述策略来处理所述一条(或多条)状态信息。
在这种信息处理装置中,与不使用访问限制管理装置的情况相比,可以提高安全性。
在又一优选实施方式中,所述状态保持装置可以存储多个数据集,所述多个数据集中的每一个数据集都包括状态信息和表示该状态信息的类型的状态类型,所述信息处理装置包括访问限制管理装置,该访问限制管理装置存储策略,所述策略针对各个所述状态类型表示是否准许使用对应的状态信息,并且所述状态信息使用装置根据存储在所述访问限制管理装置中的所述策略来处理所述一条(或多条)状态信息。
在又一优选实施方式中,所述状态保持装置可以存储多个数据集,所述多个数据集中的每一个数据集都包括状态信息和表示该状态信息的类型的状态类型,所述信息处理装置包括访问限制管理装置,该访问限制管理装置存储策略,所述策略针对各个所述状态类型表示是否准许发送对应的状态信息,并且所述发送装置根据存储在所述访问限制管理装置中的所述策略来处理所述一条(或多条)状态信息。
在又一优选实施方式中,所述信息处理装置还可以包括访问限制管理装置,该访问限制管理装置存储策略,所述策略针对所述多个运行时环境中的除了所述第一运行时环境以外的各个运行时环境,包括:表示该运行时环境与所述第一运行时环境相比安全还是非安全的第一信息,和表示禁止从所述第一运行时环境向由所述第一信息表示为非安全的运行时环境发送状态信息的第二信息,其中所述发送装置根据存储在所述访问限制管理装置中的所述策略来处理所述一条(或多条)状态信息。
在又一优选实施方式中,所述访问限制管理装置可以响应于来自所述第一运行时环境以外的运行时环境或其它装置的请求而重写所述策略。
在又一优选实施方式中,所述策略针对所述多个运行时环境中的所述第一运行时环境以外的各个运行时环境,可以包括:表示该运行时环境与所述第一运行时环境相比安全还是非安全的信息,并且所述访问限制管理装置仅在所述请求的发送源是安全的运行时环境时才重写所述策略。
在又一优选实施方式中,所述第一运行时环境可以没有所述第二运行时环境安全,第一状态通信装置在所述第一运行时环境下进行操作,该第一状态通信装置包括所述状态保持装置、所述定时存储装置以及所述发送装置,通过所述发送装置发送的所述一条(或多条)状态信息与所述信息处理装置的设置相关,第二状态通信装置在所述第二运行时环境下进行操作,并且所述第二状态通信装置包括第二接收装置和第二输出装置,所述第二接收装置接收从所述第一运行时环境发送的所述一条(或多条)状态信息,所述第二输出装置向在所述第二运行时环境中进行所述设置的程序输出由所述第二接收装置接收到的所述一条(或多条)状态信息。
在又一优选实施方式中,所述第二状态通信装置可以包括检查装置,该检查装置检查所述第二接收装置接收到的所述一条(或多条)状态信息,并且所述第二输出装置输出已经通过由所述检查装置执行的所述检查的一条(或多条)状态信息。
此外,根据本发明的另一方面,提供了一种在信息处理装置中执行的信息处理方法,所述信息处理装置包括:存储装置,该存储装置存储指令集和条件,所述指令集用于实现包括第一运行时环境和第二运行时环境的多个运行时环境,所述条件与目标运行时环境的执行状态相关,所述目标运行时环境是所述第一运行时环境和所述第二运行时环境中的一个运行时环境;和执行装置,该执行装置在所述多个运行时环境中的一个运行时环境的执行状态是前台状态,而各个其它运行时环境的执行状态是后台状态的情况下,执行存储在所述存储装置中的所述指令集,所述方法包括以下步骤:通过所述执行装置使所述存储装置存储要从第一运行时环境发送到第二运行时环境的状态信息;和在存储在所述存储装置中的所述条件得到满足的情况下,通过所述执行装置向所述第二运行时环境发送存储在所述存储装置中的状态信息。
在一优选实施方式中,所述第一运行时环境可以没有所述第二运行时环境安全,使所述存储装置存储状态信息的步骤和发送所述状态信息的所述步骤在所述第一运行时环境中执行,并且要发送的所述状态信息与所述信息处理装置的设置相关,所述方法还包括以下步骤:执行所述第二运行时环境的所述执行装置接收从所述第一运行时环境发送的所述状态信息;执行所述第二运行时环境的所述执行装置向在所述第二运行时环境中进行所述设置的程序输出接收到的所述状态信息。
附图说明
现将参照下列附图,对本发明的示例性实施方式进行详细描述,其中:
图1是示出根据一个实施方式的信息处理装置1的功能构造的图;
图2是示出存储在状态保持单元121中的信息的示例的图;
图3是示出存储在定时存储单元122中的信息的示例的图;
图4是示出存储在状态输出单元125中的信息的示例的图;
图5是示出与访问限制相关的策略的示例的图;
图6是示出信息处理装置1的硬件构造的图;
图7是示出在输入新状态信息时所执行的处理的流程图;
图8是示出在切换执行状态时所执行的处理的流程图;
图9是示出在请求状态信息时所执行的处理的流程图;
图10是示出访问限制的处理的流程图;
图11是示出状态信息的使用限制的处理的流程图;
图12是示出在安全运行时环境中执行的改变设置的处理的流程图;
图13A和13B是示出操作例2中的画面转换的图;
图14是示出根据修改例1的信息处理装置1的功能构造的图;以及
图15是示出根据修改例2的信息处理装置1的功能构造的图。
具体实施方式
1、构造
图1是示出根据本发明一个实施方式的信息处理装置1的功能构造的图。在该示例中,信息处理装置1是所谓的智能手机。信息处理装置1包括:运行时环境10(第一运行时环境的示例)、运行时环境20(第二运行时环境的示例)、VM(虚拟机)至VM通信功能30,以及VMM(虚拟机监视器)40。运行时环境10和运行时环境20都在虚拟机上实现。运行时环境10和运行时环境20分别运行OS(操作系统)11和OS 21。这里应注意到,“运行时环境”是一程序(基于该程序来执行特定种类的程序),或者是指通过这种程序实现的功能。
VMM 40是操作多个运行时环境的功能(或用于实现这种功能的程序)。在VMM40的控制下,运行时环境10和运行时环境20包括相互独立的OS和驱动程序(driver)。VM至VM通信功能30是用于运行时环境之间的通信的功能(或用于实现这种功能的程序)。
在这个示例中,执行运行时环境10和运行时环境20,以使它们中的一个具有前台状态,而另一个具有后台状态。“前台状态”是其中接受用户所输入的信息的状态,而“后台状态”是与前台状态不同的状态,即,其中不接受用户所输入的信息的状态。响应于多个特定事件中的一个来切换运行时环境的执行状态(即,前台状态或后台状态)。例如,该事件是用户所执行的按钮操作,或者诸如消息到达等的系统事件。
运行时环境10包括状态通信装置12。状态通信装置12用于在运行时环境10与运行时环境20之间传送与状态相关的信息(下面,称为“状态信息”)。后面将对状态信息所表示的“状态”进行描述。状态通信装置12的功能通过运行在OS 11下的程序来实现。状态通信装置12包括:状态保持单元121、定时存储单元122、状态发送单元123、状态接收单元124、状态输出单元125、状态信息使用单元126,以及访问限制管理单元127。
状态保持单元121(状态保持装置的示例)存储状态信息。在这个示例中,状态信息包括有关与向用户呈现信息相关的状态的信息(下面,称为“信息呈现状态”)和有关与信息处理装置1的设置相关的状态的信息(下面,称为“设置状态”)。信息呈现状态例如是其中已经接收到电子邮件、SMS、电话呼叫等(消息到达)的状态、其中已经接收到由推送型信息发布服务所提供的新信息的状态、或者其中已经完成诸如下载文件的处理的状态。设置状态例如是其中信息处理装置1处于静默模式的状态、信息处理装置1的操作被锁定(本地锁定、远程锁定等)的状态、或者与网络服务(话音邮件服务、呼叫等待服务等)的设置相关的状态。
图2是示出存储在状态保持单元121中的信息的示例的图。状态保持单元121存储了多个数据集。每一个数据集都包括状态类型、状态信息,以及标志。状态类型是表示状态的类型的信息。在这个示例中,将“电子邮件到达”、“电话呼叫到达”、“最近接收到的信息”、“处理完成”、“静默模式”,以及“锁定状态”存储为状态类型。该标志表示是否已经发送了状态信息。在图2所示的示例中,对于状态类型“电子邮件到达”,其表示该状态信息表示“两个电子邮件未读”并且表示该状态信息“已经发送”。
再次参照图1,定时存储单元122(定时存储装置的示例)存储表示以下条件的信息,该条件指定要发送状态信息的定时。例如,针对状态信息的每一个分类来设置该条件。
图3是示出存储在定时存储单元122中的信息的示例。定时存储单元122存储多个数据集,每一个数据集都包括状态类型和分类。在图3所示的示例中,指示了状态类型“电子邮件到达”、“电话呼叫到达”、“最近接收到的信息”以及“处理完成”属于分类“信息呈现状态”,而状态类型“方式模式”和“锁定状态”属于分类“设置状态”。与发送源的运行时环境(在这种情况下为运行时环境10)的执行状态无关地发送与设置状态相关的状态信息。即,在发送源的运行时环境处于前台状态的情况和发送源的运行时环境处于后台状态的情况中的每一种情况下立即发送与设置状态相关的状态信息。在发送源的运行时环境的执行状态处于后台状态时或者在进行从前台状态向后台状态的切换时发送与信息呈现状态相关的状态信息。因而,当发送源的运行时环境处于前台状态时,不发送与信息呈现状态相关的状态信息。
再次参照图1,状态发送单元123(发送装置的示例)根据运行时环境10和运行时环境20中的至少一个的执行状态并且利用存储在定时存储单元122中的条件来向运行时环境20发送状态信息。在运行时环境10与运行时环境20之间传送信息时,使用VM至VM通信功能30。此外,状态发送单元123获取运行时环境10和运行时环境20中的至少一个的执行状态。在这个示例中,状态发送单元123从VMM 40获取运行时环境10的执行状态。VMM 40管理运行时环境10和运行时环境20中的每一个的执行状态,并且具有指定前台状态下的运行时环境和后台状态下的运行时环境的信息。此外,状态发送单元123在定时存储单元122中陈述的条件得到满足时向发送目的地的运行时环境发送状态信息和状态类型。
状态接收单元124(接收装置的示例)经由VM至VM通信功能30从诸如运行时环境20的另一运行时环境接收状态信息。此外,状态接收单元124验证所接收的状态信息是否可信。该验证例如通过使用CRC(循环冗余校验)、MAC(消息认证码)或电子签名来执行。此外,状态接收单元124参照访问限制管理单元127(后面描述的)所拥有的策略,并且基于该策略限制状态信息的接收。
状态输出单元125(输出装置的示例)向使用状态信息的功能部件输出所接收的状态信息。“使用状态信息的功能部件”例如是在运行时环境10中运行的程序,例如应用程序、中间件(middleware)、OS、设备驱动程序等。在这个示例中,状态输出单元125存储指定每一条状态信息与该信息所输出到的功能部件之间的对应关系的信息。
图4是示出存储在状态输出单元125中的信息的示例的图。状态输出单元125存储多个数据集。每一个数据集都包括状态类型和该信息所输出到的功能。在这个示例中,状态类型“电子邮件到达”例如与“状态栏”相关联。因而,当所接收的状态信息的状态类型是“电子邮件到达”时,状态输出单元125向程序“状态栏”输出所接收的信息。
再次参照图1继续进行说明。状态信息使用单元126(使用装置的示例)使用状态信息。状态信息使用单元126显示与信息呈现状态相关的状态信息,或根据与设置状态相关的状态信息来设置信息处理装置1。状态信息使用单元126可以是状态输出单元125所陈述的状态信息的输出目的地。
访问限制管理单元127(访问限制管理装置)存储与状态信息的访问限制相关的策略。
图5是示出与访问限制相关的策略的示例的图。该策略包括多个数据集。每一个数据集都包括状态类型和访问限制的内容。在图5所示的示例中,该访问限制包括接收时的访问限制和发送时的访问限制。访问限制的内容包括:“接收”、“不接收”、“发送”、“不发送”、以及“询问用户”。例如,对于状态类型“最近接收到的信息”,将“不接收”设置为接收时的访问限制,并将“发送”设置为发送时的访问限制。对于状态类型“锁定状态”,将“询问用户”设置为接收时的访问限制,并将“发送”设置为发送时的访问限制。应注意到,“询问用户”意指向用户发出有关是否准许接收/发送的询问。
访问限制的策略响应于另一程序或装置的请求而变化。例如,从在运行时环境10中运行的应用程序或中间件、诸如运行时环境20的另一运行时环境、管理该系统的模块(如VMM 40)、或信息处理装置1以外的装置(如连接至移动通信网络或因特网的服务器)发送改变策略的请求。访问限制管理单元127响应于来自这些程序和装置的请求而改变策略。
再次参照图1继续进行说明。运行时环境20包括状态通信装置22。状态通信装置22用于在运行时环境10与运行时环境20之间传送状态信息。状态通信装置22的功能通过在OS 21中运行的程序来实现。状态通信装置22包括:状态保持单元221、定时存储单元222、状态发送单元223、状态接收单元224、状态输出单元225、状态信息使用单元226,以及访问限制管理单元227。这些单元的功能与状态通信装置12中的那些单元的功能相同。
图6是示出信息处理装置1的硬件构造的图。信息处理装置1包括:控制单元110、存储单元120、输入单元130、显示单元140,以及通信单元150。控制单元110控制信息处理装置1的构造部件。控制单元110包括:CPU(中央处理单元)111、RAM(随机存取存储器)112,以及ROM(只读存储器)113。CPU 111是执行各种操作的单元。RAM 112是在CPU 111执行程序时用作工作区的存储装置。ROM 113是存储程序和数据的存储装置。存储单元120包括诸如内置闪存的非易失性存储装置、HDD(硬盘驱动器)、可分离存储卡等。存储单元120存储包括诸如OS 11、OS21等的基本程序、在这些操作系统上运行的应用程序、用于实现VM至VM通信功能30和VMM 40的程序等的各种程序以及各种数据。图1所示的功能通过控制单元110执行存储在存储单元120中的程序来实现。存储信息的功能(例如由状态保持单元121、定时存储单元122、状态输出单元125、访问限制单元127等执行的存储信息的功能)确保RAM 111或存储单元120中的存储区,并在该存储区中存储信息。
输入单元130向控制单元110输入信息。输入单元130包括诸如十键键区、键区、按钮、触摸板、触摸面板等的输入装置。显示单元140显示信息,并且包括诸如LCD(液晶显示器)、EL显示器等的显示器。通信单元150经由移动通信网络进行通信。通信单元150包括天线和诸如放大器的发送/接收装置等。
在这个示例中,RAM 112、ROM 113或存储单元120是存储装置或其中存储用于实现多个运行时环境的指令集的环境存储装置的示例。CPU 111是执行该指令集的执行装置的示例。
2、操作
2-1、发送状态信息
接下来,对状态通信装置12的操作进行说明。这里,将运行时环境10是发送源的运行时环境而运行时环境20是发送目的地的运行时环境的情况作为示例来进行说明。响应于特定事件,状态通信装置12向运行时环境20发送存储在状态保持单元121中的状态信息。触发该发送的事件包括:(1)输入新状态信息;(2)运行时环境10的执行状态从前台状态切换至后台状态;以及(3)对于状态信息的请求。在下面的描述中,对由这些事件(1)-(3)中的每一个事件所触发的发送处理进行说明。
2-1-1、在输入新状态信息时的处理
图7是示出在输入新状态信息时所执行的处理的流程图。在下面的描述中,状态通信装置的构造部件被描述为用于执行该处理,并且这意味通过CPU 111执行用于实现这些构造部件的指令集(程序模块)以控制其它硬件部件来执行该处理。
首先,在作为发送源的运行时环境的运行时环境10中,将一条状态信息输入到状态保持单元121(步骤S101)。从在运行时环境10中运行的应用程序、中间件、OS、设备驱动程序等输入该条状态信息。在步骤S102中,状态保持单元121确定所输入的该条状态信息是否与所存储的多条状态信息中的任一条状态信息不同。如果确定所输入的该条状态信息与所存储的多条状态信息中的任一条状态信息不同(S102:是),则状态保持单元121使该处理进行至步骤S103。如果确定所输入的该条状态信息与所存储的多条状态信息中的一条状态信息相同(S102:否),则状态保持单元121使该处理进行至步骤S105。
在步骤S103中,状态保持单元121更新所存储的状态信息。即,状态保持单元121利用所输入的状态信息重写(overwrite)所存储的状态信息。在更新状态信息之后,状态保持单元121重写与所更新的状态信息相对应的标志,以表示“尚未发送”。
在步骤S104中,状态发送单元123获取发送源的运行时环境(在这个示例中为运行时环境10)的执行状态。
在步骤S105和S106中,状态发送单元123确定是否立即发送所输入的该条状态信息。在这个示例中,状态发送单元123在该条状态信息不属于信息呈现状态的情况下或者在发送源的运行时环境不处于前台状态的情况下发送该条状态信息,后面将进行具体描述。状态发送单元123针对在步骤S101中输入的该条状态信息来确定是否满足存储在定时存储单元122中的条件。具体来说,在步骤S105中,状态发送单元123确定所输入的该条状态信息是否属于信息呈现状态。如果确定所输入的该条状态信息属于信息呈现状态(S105:是),则状态发送单元123使该处理进行至步骤S106。如果确定所输入的该条状态信息不属于信息呈现状态,即,所输入的该条状态信息属于设置状态(S105:否),则状态发送单元123使该处理进行至步骤S107。而且,在步骤S106中,状态发送单元123确定发送源的运行时环境的执行状态是否为前台状态。如果确定发送源的运行时环境的执行状态为前台状态(S106:是),则状态发送单元123终止图7所示的处理。如果确定发送源的运行时环境的执行状态不是前台状态,即,发送源的运行时环境的执行状态是后台状态(S106:否),则状态发送单元123使该处理进行至步骤S107。
在步骤S107中,状态发送单元123提取标志表示“尚未发送”的一条(或多条)状态信息。在步骤S108中,状态发送单元123向发送目的地的运行时环境(在这个示例中为运行时环境20)发送所提取的一条(或多条状态信息。在步骤S109中,状态发送单元123访问状态保持单元121,并且重写与所发送的各条状态信息相对应的标志,使得该标志表示“已发送”。在这种情况下,当状态通信装置12接收到表示发送错误的回复时,状态发送单元123访问状态保持单元121并且重写与出现了错误的状态信息相对应的标志,使得该标志表示“尚未发送”。在完成标志的重写之后,状态通信装置12终止图7所示的处理。
在作为发送目的地的运行时环境的运行时环境20中,状态接收单元224接收来自运行时环境10的一条(或多条)状态信息(步骤S110)。在步骤S111中,状态输出单元225向使用所接收的一条(或多条)状态信息的(多个)功能输出该一条(或多条)状态信息。在这个示例中,将所述一条(或多条)状态信息输出至状态信息使用单元226。在步骤S112中,状态信息使用单元226使用所接收的一条(或多条)状态信息。在使用该一条(或多条)状态信息之后,状态通信装置22终止图7所示的处理。
2-1-2、在切换执行状态时
图8是示出在切换执行状态时所执行的处理的流程图。在这个示例中,假定在开始图8所示的流程之前,运行时环境10处于前台状态,而运行时环境20处于后台状态。响应于生成用于切换执行状态的触发(如用户操作按钮,或系统事件)而执行图8所示的处理。
在步骤S201中,状态发送单元123检测到完成了将发送源的运行时环境的执行状态从前台状态至后台状态的切换。在这个示例中,VMM 40管理运行时环境10和运行时环境20中的每一个的执行状态。VMM 40将运行时环境10的执行状态从前台状态切换至后台状态。当完成了该切换时,VMM 40向在VMM 40控制下的运行时环境(运行时环境10和运行时环境20)通知完成了该切换。状态发送单元123基于来自VMM 40的通知检测到已经将运行时环境10的执行状态从前台状态切换至后台状态。
在步骤S202中,状态发送单元123从存储在状态保持单元121中的多条状态信息当中提取标志表示“尚未发送”的一条(或多条)状态信息。在步骤S203中,状态发送单元123发送所提取的一条(或多条)状态信息。在步骤S204中,状态发送单元123访问状态保持单元121,并且重写与所发送的各条状态信息相对应的标志,使得该标志表示“已发送”。在重写标志之后,状态通信装置12终止图8所示的处理。
2-1-3、在请求状态信息时
图9是示出在请求状态信息时所执行处理的流程图。在步骤S301中,状态发送单元123接收对状态信息的请求。该请求是针对发送该状态信息的请求,并且包括标识该状态信息的标识符(例如,状态类型)。
在步骤S302中,状态发送单元123从存储在状态保持单元121中的多条状态信息当中提取与和该请求中所包括的状态类型相同的状态类型相对应的状态信息。在步骤S303中,状态发送单元123向该请求的发送源的运行时环境发送所提取的状态信息。在步骤S304中,状态发送单元123访问状态保持单元121,并且重写与所发送的状态信息相对应的标志,使得该标志表示“已发送”。在重写标志之后,状态通信装置12终止图9所示的处理。
2-2、访问限制
在前述2-1-1到2-1-3的描述中,省略了对状态信息的访问限制的说明。因而,这里,将对访问限制进行说明。将在如在2-1-2中所述的切换执行状态时所执行的处理作为示例来进行说明。然而,对于在2-1-1和2-1-3中所述的处理类似地执行访问限制。
图10是示出访问限制的处理的流程图。在图10中,将相同标号用于指示和图8相同的部分。在完成步骤S202中的处理之后,状态发送单元123从所提取的一条(或多条)状态信息中排除发送被限制的一条(或多条)状态信息(步骤S401)。下面,进行详细描述。状态发送单元123向访问限制管理单元127发送有关是否准许发送所提取的一条(或多条)状态信息的询问。该询问包括一个(或多个)状态类型。当接收到该询问时,访问限制管理单元127提取该询问中所包括的一个(或多个)状态类型。访问限制管理单元127参照所存储的策略,以提取与和所提取的一个(或多个)状态类型相对应的一条(或多条)状态信息中的每一条状态信息相关的访问限制的内容。访问限制管理单元127向状态发送单元123发送所提取的访问限制的一条(或多条)内容(在图5所示的示例中为“发送”、“不发送”以及“询问用户”中的一种),作为对该询问的响应。状态发送单元123从要发送的一条(或多条)状态信息中排除所接收的响应中所包括的访问限制的内容为“不发送”的一条(或多条)状态信息。
在步骤S402中,状态发送单元123确定是否需要向用户发出询问,即,是否存在访问信息的内容为“询问用户”的信息。如果确定需要向用户发出询问(S402:是),则状态发送单元123使该处理进行至步骤S403。如果确定不必向用户发出询问(S402:否),则状态发送单元123使该处理进行至步骤S203。
在步骤S403中,状态发送单元123向用户发出有关是否准许发送的询问。具体来说,状态发送单元123针对访问限制的内容为“询问用户”的每一条状态信息,显示用于允许用户输入准许/禁止发送的画面。观看该画面的用户操作输入单元130以输入准许/禁止发送。在步骤S404中,状态发送单元123从要发送的一条(或多条)状态信息中排除用户输入了“不发送”的一条(或多条)状态信息。
除了没有发送从在步骤S401-S404中要发送的一条(或多条)状态信息中排除的一条(或多条)状态信息以外,步骤S203和此后的处理与前面描述的相同。
接下来,对状态通信装置22所执行的处理进行说明,该状态通信装置22在发送目的地的运行时环境上操作。在步骤S410中,状态接收单元224接收来自状态通信装置12(运行时环境10)的一条(或多条)状态信息。
在步骤S411中,状态接收单元224从所接收的一条(或多条)状态信息中排除接收被限制的一条(或多条)状态信息。下面进行详细说明。状态接收单元224向访问限制管理单元227发送有关是否准许接收所接收的一条(或多条)状态信息的询问。该询问包括一个(或多个)状态类型。当接收到该询问时,访问限制管理单元227提取该询问中所包括的一个(或多个)状态类型。访问限制管理单元227参照所存储的策略,以提取与和所提取的一个(或多个)状态类型相对应的一条(或多条)状态信息中的各条状态信息相关的访问限制的内容。访问限制管理单元227向状态接收单元224发送所提取的访问限制的内容(在图5所示的示例中为“接收”、“不接收”以及“询问用户”中的一种),作为对该询问的响应。状态接收单元224从所接收的一条(或多条)状态信息中排除或删除所接收的响应中所包括的访问限制的内容为“不接收”的一条(或多条)状态信息。对于从所接收的一条(或多条)状态信息中排除的一条(或多条)状态信息,状态接收单元224将错误消息返回至发送源。另选的是,状态接收单元224不必向发送源返回错误消息。
在步骤S412中,状态接收单元224确定是否需要向用户发出询问,即,是否存在访问信息的内容为“询问用户”的信息。如果确定需要向用户发出询问(S422:是),则状态接收单元224使该处理进行至步骤S413。如果确定不必向用户发出询问(S412:否),则状态接收单元224使该处理进行至步骤S415。
在步骤S413中,状态接收单元224向用户发出有关是否准许接收的询问。具体来说,状态接收单元224针对访问限制的内容为“询问用户”的每一条状态信息,显示用于允许用户输入准许/禁止接收的画面。观看该画面的用户操作输入单元130以输入准许/禁止接收。在步骤S414中,状态接收单元224从所接收的一条(或多条)状态信息中排除或删除用户输入了“不接收”的一条(或多条)状态信息。
在步骤S415中,状态输出单元225向使用所接收的一条(或多条)状态信息的一个(或多个)功能部件输出该一条(或多条)状态信息。被输入了该一条(或多条)状态信息的一个(或多个)功能部件使用该一条(或多条)状态信息。在使用该一条(或多条)状态信息之后,状态通信装置22终止图10所示的处理。对于从状态输出单元225接收和输出的一条(或多条)状态信息,状态接收单元224向发送源的运行时环境发送确认(ACK)。
2-3、使用限制
图11是示出在发送目的地(在这个示例中为运行时环境20)中的状态信息的使用限制的流程图。在步骤S501中,状态接收单元224接收来自运行时环境10的一条(或多条)状态信息。在步骤S502中,状态输出单元225向状态信息使用单元226输出所接收的一条(或多条)状态信息。
在步骤S503中,从所输入的多条状态信息中,排除使用被限制的一条(或多条)状态信息。具体来说,状态信息使用单元226向访问限制管理单元227发送有关是否准许使用所输入的一条(或多条)状态信息的询问。该询问包括一个(或多个)状态类型。当接收到该询问时,访问限制管理单元227提取该询问中所包括的一个(或多个)状态类型。访问限制管理单元227参照所存储的策略,以提取与和所提取的一条(或多条)状态类型相对应的一条(或多条)状态信息中的每一条状态信息相关的访问限制的内容。访问限制管理单元227向状态信息使用单元226发送所提取的访问限制的内容(在图7所示的示例中为“使用”、“不使用”以及“询问用户”中的一种),作为对该询问的响应。状态信息使用单元226从要使用的一条(或多条)状态信息中排除或删除所接收的响应中所包括的访问限制的内容为“不使用”的一条(或多条)状态信息。
在步骤S504中,状态信息使用单元226确定是否需要向用户发出询问,即,是否存在访问限制的内容为“询问用户”的信息。如果确定需要向用户发出询问(S504:是),则状态信息使用单元226使该处理进行至步骤S505。如果确定不必向用户发出询问(S504:否),则状态信息使用单元226使该处理进行至步骤S507。
在步骤S505中,状态信息使用单元226向用户发出有关是否准许使用的询问。具体来说,状态信息使用单元226针对访问限制的内容为“询问用户”的每一条状态信息,显示允许用户输入准许/禁止使用的画面。观看该画面的用户操作输入单元130以输入准许/禁止使用。在步骤S506中,状态信息使用单元226从要使用的一条(或多条)状态信息中排除或删除用户输入了“不使用”的一条(或多条)状态信息。
在步骤S507中,状态信息使用单元226使用该一条(或多条)状态信息。在使用该一条(或多条)状态信息之后,状态通信装置22终止图11所示的处理。
2-4、操作的具体示例
下面,对操作的具体示例进行说明。这里,对两个具体示例进行说明,即,(1)在安全运行时环境中改变信息处理装置1的设置,和(2)在后台状态下的运行时环境中显示电子邮件接收。
2-4-1、操作示例1:在安全运行时环境中改变设置
在这个示例中,运行时环境10和运行时环境20的安全等级不同。运行时环境10是非安全运行时环境,而运行时环境20是安全运行时环境。这里应注意到,“安全运行时环境”是仅允许受信任的程序运行的封闭式运行时环境。“非安全运行时环境”是允许执行或安装可能不受信任的第三方程序的开放式运行时环境。这里,对从非安全运行时环境向安全运行时环境发送与设置相关的状态信息并且在安全运行时环境中执行改变信息处理装置1的设置的示例进行说明。术语“安全”和“非安全”在此意指,彼此相对地,这两个运行时环境中的一个更安全,而另一个较不安全。
在这个示例中,所关注的状态类型是“锁定状态”。信息处理装置1被设计为使得出于安全理由,不能在运行时环境10中直接改变与信息处理装置1的锁定状态相关的设置。即,对于在运行时环境10中运行的程序要设置锁定状态,需要向运行时环境20进行请求。这里假定运行时环境10是前台状态,而运行时环境20是后台状态。而且,假定锁定状态为“关闭”,即,进行设置,以使得可以接收来自输入单元130的输入。在运行时环境10中,运行用于改变锁定状态的设置的应用程序(下面,称为“锁定状态改变应用”)。
图12是示出安全运行时环境中所执行的改变设置的处理的流程图。在这个流程图中,为简单起见,省略了针对访问限制等的处理。在步骤S601中,锁定状态改变应用调用状态通信装置12,并且输入状态信息以使锁定状态打开。应注意到,因为不能在运行时环境10中执行改变信息处理装置1的设置,所以将锁定状态改变应用设置成调用状态通信装置12,并且输入状态信息以使锁定状态打开,而不是执行改变设置。
在步骤S602中,状态保持单元121存储由锁定状态改变应用所输入的状态信息。在步骤S603中,状态发送单元123向运行时环境20发送所输入的状态信息。在发送该状态信息之后,状态通信装置12终止图12所示的处理。在这个处理期间,运行时环境10保持在前台状态下。
在运行时环境20中,状态通信装置22的状态接收单元224接收来自运行时环境10的状态信息(步骤S604)。在步骤S605中,状态输出单元225向状态信息使用单元226输出所接收的状态信息。在步骤S606中,状态信息使用单元226使用从状态输出单元225输出的状态信息。下面,对具体操作进行说明。该状态信息用于使信息处理装置1的锁定状态打开。在运行时环境20中,可以运行用于改变信息处理装置1的锁定状态的程序。状态输出单元225调用这个程序以使锁定状态打开。在这个处理期间,运行时环境20保持在后台状态下。在使用该状态信息之后,状态通信装置22终止图12所示的处理。
2-4-2、操作示例2:在后台状态下的运行时环境中显示电子邮件接收
在这个示例中,假定运行时环境10处于后台状态而运行时环境20处于前台状态。所关注的状态类型为“电子邮件到达”。在运行时环境10中,运行用于接收电子邮件的应用程序(下面,称为“邮件程序(mailer)”)。
当接收到新电子邮件时,邮件程序调用状态通信装置12,并且输入表示新电子邮件到达的状态信息(例如,“三个电子邮件未读”)。状态保持单元121存储由邮件程序所输入的状态信息。状态发送单元123向运行时环境20发送所输入的状态信息。在这个处理期间,运行时环境10保持在后台状态下。
在运行时环境20中,状态通信装置22的状态接收单元224接收来自运行时环境10的状态信息。状态输出单元225向程序“状态栏”输出所接收的状态信息。该状态栏是用于在画面上显示电子邮件到达的程序。
图13A和13B是示出操作示例2中的画面转换的图。图13A示出了在发送状态信息之前的状态,而图13B示出了在发送状态信息之后的状态。该画面被划分成状态栏SB和自由区FA。自由区FA是可以被任何应用程序自由使用的显示区。状态栏SB是显示与诸如剩余电池电量、电磁波强度、当前时间等的预定参数相关的信息的显示区。在这个示例中,在自由区FA中仅显示了与前台状态下的运行时环境相关的画面。因为运行时环境20在这个示例中处于前台状态,所以在自由区FA中显示了与在运行时环境20中运行的应用程序有关的画面。然而,在状态栏SB中,显示了与后台状态下的运行时环境相关的状态(在这个示例中为未读电子邮件的数量)。图标I1是表示存在两个未读电子邮件的图像。图标I2是表示存在三个未读电子邮件的图像。状态栏SB中的图片响应于运行时环境10中的变化而更新,同时在自由区FA中显示与运行时环境20相关的画面。
3、其它实施方式
本发明不限于上述实施方式,而是可以具有多种修改实施方式。在下面的描述中,对一些这种修改例进行说明。应注意到,可以组合使用下列修改例中的两个或更多个。
3-1、修改例1
状态通信装置与运行时环境之间的关系不限于示例性实施方式中所述的关系。状态通信装置12的部分或全部功能可以在发送源的运行时环境(运行时环境10)和发送目的地的运行时环境(运行时环境20)以外的其它运行时环境中进行操作。
图14是示出根据修改例1的信息处理装置1的功能构造的图(未示出状态通信装置22的细节)。在这个示例中,信息处理装置1除了运行时环境10和运行时环境20以外还包括运行时环境50。运行时环境10和运行时环境20进行操作,以使它们中的一个处于前台状态而另一个处于后台状态,而运行时环境50始终处于后台状态。在这个示例中,OS 51在运行时环境50中进行操作,而状态通信装置52在OS 51下进行操作。状态通信装置52包括状态保持单元121。运行时环境10上的状态通信装置12不包括状态保持单元121。当希望状态通信装置12的功能部件访问状态保持单元121时,其利用VM至VM通信功能30来访问运行时环境50。应注意到,对运行时环境10和运行时环境50的功能分配不限于图14中所示例性示出的功能分配。状态通信装置12的功能可以按任何方式分配给运行时环境10和运行时环境50。而且,运行时环境50可以是状态可以切换至前台状态的运行时环境。
3-2、修改例2
运行时环境10和运行时环境20之间的关系不限于示例性实施方式所述的关系。运行时环境20可以在运行时环境10中进行操作。
图15是示出根据修改例2的信息处理装置1的功能构造的图。在这个示例中,运行时环境10和运行时环境20具有以下的关系:OS 11是主机OS,而OS 21是客户机(guest)OS。通过用于生成虚拟机的应用程序使OS 21在OS 11下进行操作。该应用程序还允许运行时环境10与运行时环境20之间的通信。状态信息的传送方式与示例性实施方式中所述的方式相同。应注意到,主机OS与客户机OS之间的关系不限于图15中示例性示出的关系。该关系可以是以下的关系:OS 21为主机OS,而OS 11为客户机OS。
3-3、修改例3
用于发送状态信息的条件不限于示例性实施方式中所述的条件。可以使用任何条件,只要其包括与目标运行时环境的执行状态相关的条件即可,该目标运行时环境是运行时环境10和运行时环境20中的、在定义该条件时所关注的一个运行时环境。除了已经在示例性实施方式中描述的条件以外,例如可以使用下列条件中的任一个作为与目标运行时环境的执行状态相关的条件。这些条件中的每一个都可以独立地使用,或者可以与这些条件中的另一条件组合使用。在下列示例中,目标运行时环境是发送源的运行时环境。
(1)在发送源的运行时环境处于后台状态时发送状态信息。
(2)在发送源的运行时环境已经从前台状态切换至后台状态时发送状态信息。
(3)对于优先级程度高的状态类型,与发送源的运行时环境的执行状态无关地发送状态信息。
(4)对于优先级程度低的状态类型,在发送源的运行时环境处于后台状态时发送状态信息。
(5)对于优先级程度低的状态类型,在发送源的运行时环境已经从前台状态切换至后台状态时执行发送。在情况(3)-(5)中,存储在定时存储单元122中的每一个数据集都包括相应状态类型的优先级程度。
(6)对于与信息呈现状态相关的状态信息,在发送源的运行时环境处于前台状态时不执行发送。
(7)对于与信息呈现状态相关的状态信息,在发送源的运行时环境处于后台状态时执行发送。
(8)对于与信息呈现状态有关的状态信息,在发送源的运行时环境已经从前台状态切换至后台状态时执行发送。
(9)在发送源的运行时环境已经从前台状态切换至后台状态之后发送状态信息。
上述条件(1)-(9)是在目标运行时环境为发送源的运行时环境的情况下的示例。然而,目标运行时环境可以是发送目的地的运行时环境。在这种情况下,例如,条件(1)应当读作“在发送目的地的运行时环境处于前台状态时发送状态信息”。这同样应用于条件(2)-(9)。
除了与目标运行时环境的执行状态相关的条件以外,还可以使用与执行状态不相关的其它条件。下面是这种条件的示例。
(10)对于与设置状态相关的状态信息,在输入该信息时立即执行发送,而与目标运行时环境的执行状态无关。对于与信息呈现状态相关的状态信息,根据目标运行时环境的执行状态来执行发送。即,基于状态信息的分类或类型,在根据目标运行时环境的执行状态所执行的发送与和目标运行时环境的执行状态无关地执行的发送之间进行切换。
(11)在存储在状态保持单元121中的状态信息的量(数据集的数量或数据大小)超出阈值时发送状态信息。在这种情况下,状态保持单元121存储与状态信息的量相关的阈值(例如,数据集的数量的上限=3,数据大小的上限=1kB)。
(12)在发送一个数据集中所包括的状态信息时,同时发送另一数据集中所包括的状态信息。
(13)在从另一程序或另一装置接收到请求时,响应于该请求发送状态信息。
(14)当在先前发送的状态信息之后经过了预定时段时发送状态信息。在这种情况下,状态保持单元121存储执行先前发送状态信息的时间和用于发送状态信息的时间间隔。
(15)在发送目的地的运行时环境中出现问题时或者在初始化发送目的地的运行时环境时执行发送。在这种情况下,状态保持单元121获取表示在发送目的地的运行时环境中出现了问题或者已经初始化发送目的地的运行时环境的信息。
(16)在用作主运行时环境的运行时环境启动时执行发送。例如,在安全运行时环境20是主运行时环境的情况下,在运行时环境20启动时向运行时环境10发送指定的状态信息。在这种情况下,定时存储单元122存储用于确定用作主运行时环境的运行时环境的信息和要发送的状态信息,并且基于存储在定时存储单元122中的信息,状态发送单元123确定用作主运行时环境的运行时环境和要发送的状态信息。另选的是,状态发送单元123可以获取用于确定用作主运行时环境的运行时环境的信息和要从运行时环境10外部(如从VMM 40)发送的状态信息。
(17)当在发送目的地的运行时环境中重置设置信息等时执行发送。例如,当将设置信息重置为运行时环境20中的初始值时,状态发送单元223向运行时环境10发送指定的状态信息。
此外,用于确定在输入了新状态信息时是否立即发送状态信息的条件(如参照图7中的步骤S105和S106所述的)不限于示例性实施方式中所述的条件。该条件可以是与状态信息的分类或类型相关的条件。例如,该条件可以陈述:如果状态类型是“电子邮件到达”则立即执行状态信息的发送,而如果状态类型是“电子邮件到达”以外的类型则不立即执行状态信息的发送。
3-4、修改例4
向状态通信装置12的功能部件的功能分配不限于示例性实施方式中所述的功能分配。例如,在示例性实施方式中,对状态发送单元123具有获取发送源的运行时环境的执行状态以及确定是否满足存储在定时存储单元122中的条件的功能的示例进行说明。然而,另一功能部件可以具有这些功能的一部分。实质上,向功能部件的功能分配可以是任意的,只要状态通信装置12整体上具有示例性实施方式中所述的功能即可。
而且,可以省略状态通信装置12的一部分功能。例如,状态通信装置12不必包括与访问限制相关的功能或使用状态信息的功能。这同样应用于状态通信装置22。
在这方面,可以省略图7-12中所示的流程的一部分的处理。
3-5、修改例5
在前台状态和后台状态中使用画面的方式不限于图13A和13B中示例性地示出的方式。在多窗口系统中,可以在最前部显示用于前台状态下的运行时环境的窗口,而不是使用整个画面来显示与前台状态下的运行时环境相关的画面。
3-6、修改例6
检测执行状态的切换(步骤S201)的处理不限于示例性实施方式中所述的处理。状态发送单元123可以从具有与运行时环境10的执行状态相关的信息的功能(程序或装置)获取运行时环境10的执行状态。在这种情况下,状态发送单元123存储对于执行状态要参照的功能的标识符(程序名称、IP地址等)。状态发送单元123向所存储的参照(reference)发出与运行时环境10的执行状态相关的询问。当接收到该询问时,该程序或装置向状态发送单元123返回包括运行时环境的执行状态的回复。状态发送单元123从该回复获取执行状态。例如,在信息处理装置1具有控制在运行时环境之间切换显示单元(显示器)140的功能并且该控制功能存储了前台状态下的运行时环境的标识符的情况下,状态发送单元123可以从该切换控制功能获取执行状态。
3-7、修改例7
与访问限制相关的策略不限于示例性实施方式中所述的策略。在图5所示的示例中,该策略陈述了在接收时、在发送时以及在使用时的限制。然而,它们的一部分可以从该策略省略。例如,该策略可以仅包括发送时的限制。
3-8、修改例8
状态信息不限于示例性实施方式中所述的状态信息。例如,状态信息可以包括当切换前台状态下的运行时环境时表示是否响应于用户操作或响应于系统事件来执行切换的信息。状态信息可以包括指示用户已经执行了特定操作的信息、选择了菜单中的特定项目的信息、已经进行;了传送的信息,显示特定信息的信息等。这些状态信息例如可以通过这些处理的挂钩(hooking)执行来获取。
3-9、修改例9
状态通信装置12和状态通信装置22都可以具有用于检查所接收的状态信息的检查装置。这里进行检查以例如发现状态信息的值是否在正常范围内、状态信息是否为正确格式、以及状态信息是否包括非法字符串。在这种情况下,状态输出单元125和状态输出单元225输出已经通过检查的状态信息。
3-10、修改例10
用于实现图1所示功能的硬件构造不限于参照图6说明的硬件构造。例如,可以使用适于执行特定处理的处理器来代替通用CPU。
在上述实施方式中,CPU 111所执行的程序可以存储在计算机可读存储介质中,例如磁存储介质(磁带、磁盘(HDD、FD(软盘))等)、光存储介质(光盘(CD(只读光盘)、DVD(数字多功能盘))等)、磁光存储介质、半导体存储器(闪存ROM等)等。还可以经由诸如因特网的网络下载该程序。
3-11、修改例11
在与示例性实施方式相关的2-2中描述的访问限制可以包括基于运行时环境的安全等级的限制。例如,访问限制管理单元127可以陈述如下的策略:如果与运行时环境10相比,运行时环境20不安全,则禁止从运行时环境10向运行时环境20发送状态信息。在除了运行时环境20以外还存在一个或更多个附加运行时环境的情况下,访问限制管理单元127可以陈述以下的策略:禁止从运行时环境10向与运行时环境10相比不安全的任何运行时环境发送状态信息。
3-12、修改例12
在示例性实施方式中,响应于另一程序或装置的请求,通过在运行时环境10下进行操作的状态通信装置12的访问限制管理单元127来改变访问限制的策略。然而,仅当通过与运行时环境10相比安全的运行时环境进行请求时才可以允许改变访问限制的策略。
Claims (23)
1.一种信息处理装置,该信息处理装置包括:
环境存储装置,该环境存储装置存储指令集,该指令集用于实现包括第一运行时环境和第二运行时环境的多个运行时环境;
执行装置,该执行装置在所述多个运行时环境中的一个运行时环境的执行状态是前台状态,而各个其它运行时环境的执行状态是后台状态的情况下,执行存储在所述环境存储装置中的所述指令集;
状态保持装置,该状态保持装置存储要从所述第一运行时环境发送到所述第二运行时环境的一条或多条状态信息;
定时存储装置,该定时存储装置存储与目标运行时环境的执行状态相关的条件,该目标运行时环境是所述第一运行时环境和所述第二运行时环境中的一个运行时环境;以及
发送装置,该发送装置在存储在所述定时存储装置中的所述条件得到满足的情况下,向所述第二运行时环境发送存储在所述状态保持装置中的所述一条或多条状态信息。
2.根据权利要求1所述的信息处理装置,其中,
所述目标运行时环境是所述第一运行时环境;并且
所述条件包括以下的条件:所述目标运行时环境的执行状态是后台状态或已经从所述前台状态切换至所述后台状态。
3.根据权利要求1或2所述的信息处理装置,所述信息处理装置还包括:
接收装置,该接收装置接收来自所述第一运行时环境的所述一条或多条状态信息;和
输出装置,该输出装置输出由所述接收装置接收到的所述一条或多条状态信息。
4.根据权利要求3所述的信息处理装置,所述信息处理装置还包括:状态信息使用装置,该状态信息使用装置使用从所述输出装置输出的所述一条或多条状态信息。
5.根据权利要求1所述的信息处理装置,其中,
所述一条或多条状态信息中的每一条状态信息都被分类为多种类型中的一种类型;
所述目标运行时环境是所述第一运行时环境;
所述定时存储装置存储表示针对所述多种类型中的每一种类型的优先级程度的信息;并且
所述条件包括以下的条件:对于优先级程度高的类型,与所述目标运行时环境的执行状态无关地发送所述一条或多条状态信息,而对于优先级程度低的类型,在所述目标运行时环境的执行状态是所述后台状态或已经从所述前台状态切换至所述后台状态时发送所述一条或多条状态信息。
6.根据权利要求1所述的信息处理装置,其中,
所述状态保持装置存储多个数据集;
所述多个数据集中的每一个数据集都包括状态信息和与该状态信息相对应的标志;
在输入新状态信息时,所述状态保持装置将该新状态信息写入至所述数据集;
在将所述新状态信息写入至所述数据集之后,所述状态保持装置重写与所写入的状态信息相对应的标志,以表示该状态信息尚未被发送;
当执行所述发送时,所述发送装置从存储在所述状态保持装置中的所述一条或多条状态信息当中提取对应标志表示状态信息尚未被发送的一条或多条状态信息,并发送所提取的一条或多条状态信息;并且
所述状态保持装置重写由所述发送装置发送的一条或多条状态信息中的每一条状态信息对应的标志,以使该标志表示对应的状态信息已经被发送。
7.根据权利要求1所述的信息处理装置,其中,
所述一条或多条状态信息中的每一条状态信息都被分类为包括与信息呈现相关的信息呈现状态的多种状态中的一种状态;
所述目标运行时环境是所述第一运行时环境;并且
所述条件包括以下的条件:在所述一条或多条状态信息中的任一条状态信息与所述信息呈现状态相关的情况下,当所述目标运行时环境的执行状态是所述前台状态时不执行该条状态信息的发送,而当所述目标运行时环境的执行状态是所述后台状态或者已经从所述前台状态切换至所述后台状态时执行该条状态信息的发送。
8.根据权利要求7所述的信息处理装置,其中,
所述多种状态包括与所述信息处理装置的设置相关的设置状态;并且
所述条件包括以下的条件:在所述一条或多条状态信息中的任一条状态信息与所述设置状态相关的情况下,与所述目标运行时环境的执行状态无关地发送该条状态信息。
9.根据权利要求6所述的信息处理装置,其中,
所述多个数据集中的每一个数据集还包括表示各条状态信息的类型的状态类型;并且
当输入一条新状态信息时,所述状态保持装置将该条新状态信息与所述多个数据集中包括的一条或多条状态信息中的、与和该条新状态信息的状态类型相同的状态类型相对应的一条状态信息进行比较,并且当所比较的状态信息不同时,利用该条新状态信息重写所述数据集中包括的该条状态信息,并且重写与所重写的该条状态信息相对应的标志,以表示对应的该条状态信息尚未被发送。
10.根据权利要求1所述的信息处理装置,其中,
所述目标运行时环境是所述第一运行时环境,并且
所述条件包括以下的条件:在所述目标运行时环境的执行状态已经从所述前台状态切换至所述后台状态之后,执行所述一条或多条状态信息的发送。
11.根据权利要求1所述的信息处理装置,其中,
所述条件包括以下的条件:当存储在所述状态保持装置中的所述一条或多条状态信息的量超出阈值时,执行所述一条或多条状态信息的发送。
12.根据权利要求1所述的信息处理装置,其中,
所述条件包括以下的条件:当发送一条状态信息时,发送另一条状态信息。
13.根据权利要求1所述的信息处理装置,其中,
所述发送装置响应于来自所述第二运行时环境或其它装置的请求而发送所述一条或多条状态信息。
14.根据权利要求3所述的信息处理装置,其中,
所述状态保持装置存储多个数据集;
所述多个数据集中的每一个数据集都包括状态信息和表示该状态信息的类型的状态类型;
所述信息处理装置包括访问限制管理装置,该访问限制管理装置存储策略,所述策略针对各个所述状态类型表示是否准许接收对应的状态信息;并且
所述接收装置根据存储在所述访问限制管理装置中的所述策略来处理所述一条或多条状态信息。
15.根据权利要求4所述的信息处理装置,其中,
所述状态保持装置存储多个数据集;
所述多个数据集中的每一个数据集都包括状态信息和表示该状态信息的类型的状态类型;
所述信息处理装置包括访问限制管理装置,该访问限制管理装置存储策略,所述策略针对各个所述状态类型表示是否准许使用对应的状态信息;并且
所述状态信息使用装置根据存储在所述访问限制管理装置中的所述策略来处理所述一条或多条状态信息。
16.根据权利要求1所述的信息处理装置,其中,
所述状态保持装置存储多个数据集;
所述多个数据集中的每一个数据集都包括状态信息和表示该状态信息的类型的状态类型;
所述信息处理装置包括访问限制管理装置,该访问限制管理装置存储策略,所述策略针对各个所述状态类型表示是否准许发送对应的状态信息;并且
所述发送装置根据存储在所述访问限制管理装置中的所述策略来处理所述一条或多条状态信息。
17.根据权利要求1所述的信息处理装置,所述信息处理装置还包括访问限制管理装置,该访问限制管理装置存储策略,对于所述多个运行时环境中的除了所述第一运行时环境以外的各个运行时环境,所述策略包括:表示该运行时环境与所述第一运行时环境相比安全还是非安全的第一信息,和表示禁止从所述第一运行时环境向由所述第一信息表示为非安全的运行时环境发送状态信息的第二信息;
其中,所述发送装置根据存储在所述访问限制管理装置中的所述策略来处理所述一条或多条状态信息。
18.根据权利要求14所述的信息处理装置,其中,
所述访问限制管理装置响应于来自所述第一运行时环境以外的运行时环境或来自其它装置的请求而重写所述策略。
19.根据权利要求18所述的信息处理装置,其中,
所述策略针对所述多个运行时环境中的除了所述第一运行时环境以外的各个运行时环境,包括:表示该运行时环境与所述第一运行时环境相比安全还是非安全的信息;并且
所述访问限制管理装置仅在所述请求的发送源是安全的运行时环境时才重写所述策略。
20.根据权利要求1所述的信息处理装置,其中,
所述第一运行时环境没有所述第二运行时环境安全;
第一状态通信装置在所述第一运行时环境下进行操作,该第一状态通信装置包括所述状态保持装置、所述定时存储装置以及所述发送装置;
通过所述发送装置发送的所述一条或多条状态信息与所述信息处理装置的设置相关;
第二状态通信装置在所述第二运行时环境下进行操作;并且
所述第二状态通信装置包括第二接收装置和第二输出装置,所述第二接收装置接收从所述第一运行时环境发送的所述一条或多条状态信息,所述第二输出装置向在所述第二运行时环境中进行所述设置的程序输出所述第二接收装置接收到的所述一条或多条状态信息。
21.根据权利要求20所述的信息处理装置,其中,
所述第二状态通信装置包括检查装置,该检查装置检查所述第二接收装置接收到的所述一条或多条状态信息;并且
所述第二输出装置输出已经通过由所述检查装置执行的所述检查的一条或多条状态信息。
22.一种在信息处理装置中执行的信息处理方法,所述信息处理装置包括:存储装置,该存储装置存储指令集和条件,所述指令集用于实现包括第一运行时环境和第二运行时环境的多个运行时环境,所述条件与目标运行时环境的执行状态相关,所述目标运行时环境为所述第一运行时环境和所述第二运行时环境中的一个运行时环境;和执行装置,该执行装置在所述多个运行时环境中的一个运行时环境的执行状态是前台状态,而各个其它运行时环境的执行状态是后台状态的情况下,执行存储在所述存储装置中的所述指令集,
所述方法包括以下步骤:
所述执行装置使所述存储装置存储要从所述第一运行时环境发送到所述第二运行时环境的状态信息;和
在存储在所述存储装置中的所述条件得到满足的情况下,所述执行装置向所述第二运行时环境发送存储在所述存储装置中的所述状态信息。
23.根据权利要求22所述的信息处理方法,其中,
所述第一运行时环境没有所述第二运行时环境安全;
使所述存储装置存储状态信息的步骤和发送所述状态信息的步骤在所述第一运行时环境中执行;并且
要发送的所述状态信息与所述信息处理装置的设置相关;
所述方法还包括以下步骤:
执行所述第二运行时环境的所述执行装置接收从所述第一运行时环境发送的所述状态信息;
执行所述第二运行时环境的所述执行装置向在所述第二运行时环境中进行所述设置的程序输出接收到的所述状态信息。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2010-013999 | 2010-01-26 | ||
JP2010013999 | 2010-01-26 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN102135900A CN102135900A (zh) | 2011-07-27 |
CN102135900B true CN102135900B (zh) | 2013-05-08 |
Family
ID=43972195
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN2011100288918A Expired - Fee Related CN102135900B (zh) | 2010-01-26 | 2011-01-26 | 信息处理装置和信息处理方法 |
Country Status (4)
Country | Link |
---|---|
US (1) | US20110185396A1 (zh) |
EP (1) | EP2348411A3 (zh) |
JP (1) | JP5566309B2 (zh) |
CN (1) | CN102135900B (zh) |
Families Citing this family (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP5729146B2 (ja) * | 2011-06-03 | 2015-06-03 | 富士通株式会社 | 情報端末装置、情報端末装置の制御方法およびプログラム |
US9063775B2 (en) | 2011-09-01 | 2015-06-23 | Microsoft Technology Licensing, Llc | Event aggregation for background work execution |
US9032413B2 (en) * | 2011-09-01 | 2015-05-12 | Microsoft Technology Licensing, Llc | Decoupling background work and foreground work |
KR102006470B1 (ko) | 2011-12-28 | 2019-08-02 | 삼성전자 주식회사 | 사용자 디바이스에서 멀티태스킹 운용 방법 및 장치 |
US9164803B2 (en) | 2012-01-20 | 2015-10-20 | Microsoft Technology Licensing, Llc | Background task resource control |
US9609108B2 (en) | 2012-09-26 | 2017-03-28 | Kyocera Corporation | Electronic device, control method, and control program |
US9846598B2 (en) * | 2013-04-03 | 2017-12-19 | Hewlett Packard Enterprise Development Lp | Modifying a flow of operations to be executed in a plurality of execution environments |
CN106027309B (zh) * | 2016-06-14 | 2019-05-07 | 青岛海信传媒网络技术有限公司 | 设备状态信息的获取方法和装置 |
KR101989249B1 (ko) * | 2017-12-14 | 2019-06-13 | 연세대학교 산학협력단 | 이동 단말기의 오프로딩 방법 및 그 이동 단말기 |
CN110294372B (zh) * | 2018-03-23 | 2023-02-28 | 奥的斯电梯公司 | 一种无线信号装置、电梯服务请求系统和方法 |
Family Cites Families (26)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH0365734A (ja) | 1989-08-04 | 1991-03-20 | Fujitsu Ltd | 仮想計算機システムにおけるvm間通信方式 |
US8127121B2 (en) * | 1999-01-28 | 2012-02-28 | Ati Technologies Ulc | Apparatus for executing programs for a first computer architechture on a computer of a second architechture |
US6518983B1 (en) * | 1999-07-21 | 2003-02-11 | International Business Machines Corporation | Display of messages from a plurality of processes running in parallel |
US6871214B2 (en) * | 2000-10-30 | 2005-03-22 | Nortel Networks Limited | Generating and providing alert messages in a communications network |
JP2002351854A (ja) | 2001-05-30 | 2002-12-06 | Omron Corp | プログラム実行装置および携帯型情報処理装置 |
JP3746224B2 (ja) * | 2001-11-06 | 2006-02-15 | 株式会社東芝 | 情報処理装置及び再生処理制御方法 |
US6957363B2 (en) * | 2002-03-27 | 2005-10-18 | International Business Machines Corporation | Method and apparatus for controlling the termination of processes in response to a shutdown command |
JP4091792B2 (ja) * | 2002-05-17 | 2008-05-28 | 株式会社エヌ・ティ・ティ・ドコモ | 電子機器、イベント提供方法、プログラム、及び記録媒体 |
US7380218B2 (en) * | 2003-03-27 | 2008-05-27 | International Business Machines Corporation | Method and apparatus for managing windows |
US7644376B2 (en) * | 2003-10-23 | 2010-01-05 | Microsoft Corporation | Flexible architecture for notifying applications of state changes |
JP2006135634A (ja) * | 2004-11-05 | 2006-05-25 | Nec Corp | 携帯型移動通信端末装置およびマナーモード設定方法 |
JP4438013B2 (ja) * | 2005-02-17 | 2010-03-24 | パイオニア株式会社 | 通信装置および通信方法 |
US8082292B2 (en) * | 2005-04-18 | 2011-12-20 | Research In Motion Limited | Method and system for centralized user notification and application execution control |
US7698706B2 (en) * | 2005-05-20 | 2010-04-13 | International Business Machines Corporation | Methods and apparatus for implementing an integrated user interface for managing multiple virtual machines operative in a computing system |
JP4233585B2 (ja) * | 2006-07-25 | 2009-03-04 | 株式会社エヌ・ティ・ティ・ドコモ | ペリフェラル切替装置及びペリフェラル切替制御装置 |
US9176765B2 (en) * | 2006-09-25 | 2015-11-03 | Lenovo (Beijing) Limited | Virtual machine system and a method for sharing a graphics card amongst virtual machines |
US8219650B2 (en) * | 2006-12-28 | 2012-07-10 | Sap Ag | Communicating with a status management component in a computer system |
JP2008301077A (ja) * | 2007-05-30 | 2008-12-11 | Toshiba Corp | ネットワークコントローラ、情報処理装置およびウェイクアップ制御方法 |
JP2008299791A (ja) | 2007-06-04 | 2008-12-11 | Hitachi Ltd | 仮想計算機システム |
WO2009031573A1 (ja) * | 2007-09-07 | 2009-03-12 | Nec Corporation | 情報処理装置、プロセッサの状態遷移方法、プロセッサの状態遷移の制御装置、プロセッサ |
JP2009116561A (ja) | 2007-11-06 | 2009-05-28 | Mitsubishi Electric Corp | データ転送システム |
US8521966B2 (en) * | 2007-11-16 | 2013-08-27 | Vmware, Inc. | VM inter-process communications |
US8677174B2 (en) * | 2007-12-28 | 2014-03-18 | International Business Machines Corporation | Management of runtime events in a computer environment using a containment region |
JP2010013999A (ja) | 2008-07-02 | 2010-01-21 | Nissan Motor Co Ltd | 車両の制御装置 |
US20140075567A1 (en) * | 2009-01-28 | 2014-03-13 | Headwater Partners I Llc | Service Processor Configurations for Enhancing or Augmenting System Software of a Mobile Communications Device |
US8321558B1 (en) * | 2009-03-31 | 2012-11-27 | Amazon Technologies, Inc. | Dynamically monitoring and modifying distributed execution of programs |
-
2011
- 2011-01-24 US US13/012,229 patent/US20110185396A1/en not_active Abandoned
- 2011-01-25 EP EP11151986.4A patent/EP2348411A3/en not_active Withdrawn
- 2011-01-25 JP JP2011012984A patent/JP5566309B2/ja not_active Expired - Fee Related
- 2011-01-26 CN CN2011100288918A patent/CN102135900B/zh not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
CN102135900A (zh) | 2011-07-27 |
JP5566309B2 (ja) | 2014-08-06 |
US20110185396A1 (en) | 2011-07-28 |
EP2348411A2 (en) | 2011-07-27 |
JP2011175633A (ja) | 2011-09-08 |
EP2348411A3 (en) | 2013-07-10 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN102135900B (zh) | 信息处理装置和信息处理方法 | |
CN101809536B (zh) | 便于经由移动设备的多操作系统引导的系统和方法 | |
CN104102882B (zh) | 一种应用程序隐私数据的保护方法及装置 | |
CN103339607A (zh) | 利用单个手势输入来锁定和解锁多个操作系统环境的方法和设备 | |
US9280365B2 (en) | Systems and methods for managing configuration data at disconnected remote devices | |
US9760413B2 (en) | Power efficient brokered communication supporting notification blocking | |
KR101907486B1 (ko) | 보안성이 우수한 실행환경을 제공하는 이동 컴퓨팅 시스템 | |
CN108351772A (zh) | 跨应用实例的标识符 | |
US9667703B1 (en) | System, method and computer program product for generating remote views in a virtual mobile device platform | |
US20160306988A1 (en) | Providing secure access to data in mobile devices | |
US20210279095A1 (en) | Interrupt Management for a Hypervisor | |
TW202002595A (zh) | 基於tee和ree的分離式切換方法及其系統 | |
US20140156952A1 (en) | Information processing apparatus, information processing method, and computer readable medium | |
CN113467656B (zh) | 一种屏幕触摸事件的通知方法和车机 | |
JP2008217698A (ja) | 携帯端末 | |
CN110188532B (zh) | 一种密码保护方法及装置 | |
WO2019139297A1 (ko) | 기기의 어플리케이션에 선택적으로 네트워크 기능을 제공하는 기술 및 방법 | |
US20240015156A1 (en) | Electronic device for controlling access to device resource and operation method thereof | |
WO2023172317A1 (en) | Preventing illicit data transfer and storage | |
CN116089930A (zh) | 应用管控方法、装置及存储介质 | |
CN113806718A (zh) | 访问权限的管理方法及终端设备 | |
CN115525382A (zh) | 一种远程协助方法、装置及终端设备 | |
JP2018195104A (ja) | 駅務システム | |
CN108804125A (zh) | 应用管理方法、装置及终端设备 | |
KR20130081093A (ko) | 영상 표시 장치에서 잠금 기능을 제어하기 위한 장치 및 방법 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
C14 | Grant of patent or utility model | ||
GR01 | Patent grant | ||
CF01 | Termination of patent right due to non-payment of annual fee | ||
CF01 | Termination of patent right due to non-payment of annual fee |
Granted publication date: 20130508 Termination date: 20170126 |