BR102019000921A2 - Sistema para habilitar uma experiência de desktop completa com base em um dispositivo móvel - Google Patents
Sistema para habilitar uma experiência de desktop completa com base em um dispositivo móvel Download PDFInfo
- Publication number
- BR102019000921A2 BR102019000921A2 BR102019000921-7A BR102019000921A BR102019000921A2 BR 102019000921 A2 BR102019000921 A2 BR 102019000921A2 BR 102019000921 A BR102019000921 A BR 102019000921A BR 102019000921 A2 BR102019000921 A2 BR 102019000921A2
- Authority
- BR
- Brazil
- Prior art keywords
- linux
- mobile device
- operating system
- desktop
- fact
- Prior art date
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/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
-
- 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
- G06F9/452—Remote windowing, e.g. X-Window System, desktop virtualisation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/14—Handling requests for interconnection or transfer
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/40—Bus structure
- G06F13/4063—Device-to-bus coupling
- G06F13/4068—Electrical coupling
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/62—Protecting access to data via a platform, e.g. using keys or access control rules
- G06F21/6218—Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database
- G06F21/6236—Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database between heterogeneous systems
-
- 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/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45504—Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
- G06F9/45529—Embedded in an application, e.g. JavaScript in a Web browser
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04B—TRANSMISSION
- H04B1/00—Details of transmission systems, not covered by a single one of groups H04B3/00 - H04B13/00; Details of transmission systems not characterised by the medium used for transmission
- H04B1/38—Transceivers, i.e. devices in which transmitter and receiver form a structural unit and in which at least one part is used for functions of transmitting and receiving
- H04B1/3827—Portable transceivers
- H04B1/3833—Hand-held transceivers
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/42—Bus transfer protocol, e.g. handshake; Synchronisation
- G06F13/4282—Bus transfer protocol, e.g. handshake; Synchronisation on a serial bus, e.g. I2C bus, SPI bus
Abstract
a presente invenção refere-se a um sistema para habilitar uma experiência de desktop completa com base em um dispositivo móvel compreendendo um núcleo linux e uma distribuição linux em que um sistema operacional móvel, empacotado em um container virtual, é executado no topo de uma distribuição linux padrão; ou em que o desktop e o sistema operacional móvel são executados em seus próprios containers virtuais isolados um do outro.
Description
[0001] A presente invenção refere-se a um sistema para habilitar uma experiência completa de desktop executando uma distribuição de sistema operacional Linux regular com todas as suas funcionalidades juntamente com um sistema operacional móvel.
[0002] O sistema da presente invenção permite que o usuário carregue virtualmente com ele e utilize o seu ambiente de desktop em qualquer lugar, propondo um método para habilitar uma experiência de desktop com base em um dispositivo smartphone, quando conectado a um visor (por exemplo, monitor ou TV). Além disso, o presente sistema supera as limitações de recursos do estado da técnica (por exemplo, Samsung Dex): falta de controles avançados de hardware, permissões restritas de usuário do sistema e restrições de gerenciamento de recursos.
[0003] A presente invenção é de particular interesse para empresas de dispositivos móveis, convergindo, para um único dispositivo de bolso, as funções do telefone móvel e do desktop/laptop.
[0004] A Samsung® também está desenvolvendo uma solução chamada Linux on Galaxy que executará uma distribuição Linux dentro da interface Dex. O problema da solução Linux on Galaxy consiste no fato de que o cliente é impactado por limitações do Android, tais como controle de permissões, grupo/usuário único por aplicativo, limitações do núcleo, etc. A presente invenção propõe a arquitetura inversa, uma vez que o Núcleo Linux é mais permissivo e fornece ao usuário mais controle sobre o sistema. A ideia é executar o sistema operacional Linux no topo do Núcleo Linux, dessa forma, não limitando a experiência de desktop do usuário.
[0005] A presente invenção também pode ser usada para adicionar a experiência de desktop completa a diferentes classes de dispositivos (smartphones, tablets, phablets, etc.). O visor conectado pode ser um monitor/TV em uma base de encaixe (dock station) ou algum dispositivo de transmissão remota, tal como Amazon Fire ou Chrome Cast.
[0006] Os seguintes documentos de patente e soluções já disponíveis no mercado que se aproximam da presente invenção são listados abaixo.
[0007] O Samsung Dex é um dispositivo que estende a funcionalidade para permitir funcionalidade semelhante a desktop pela conexão de um teclado, mouse e monitor. (https://en.wikipedia.org/wiki/Samsung_DeX).
[0008] O Docker provê a capacidade de empacotar e executar um aplicativo em um ambiente parcialmente isolado chamado de container. O isolamento e a segurança permitem que o usuário execute muitos containers simultaneamente em um determinado host. Os containers são leves porque não precisam do carregamento extra de um hipervisor, mas são executados diretamente no núcleo da máquina host. Isso significa que o usuário pode executar mais containers em uma determinada combinação de hardware do que se estivesse usando máquinas virtuais. O usuário pode até mesmo executar containers Docker em máquinas host que são, na verdade, máquinas virtuais (disponível no site https://docs.docker.com/engine/docker-overview/).
[0009] Os Namespaces são um recurso do núcleo Linux que particionam os recursos do núcleo de tal forma que um conjunto de processos visualiza um conjunto de recursos, enquanto outro conjunto de processos visualiza um conjunto de recursos diferente. A característica funciona tendo o mesmo espaço de nomes para esses recursos nos vários conjuntos de processos, mas esses nomes se referindo a recursos distintos. Exemplos de nomes de recursos que podem existir em múltiplos espaços, de modo que os recursos nomeados sejam particionados, são IDs de processo, nomes de host, IDs de usuário, nomes de arquivos e alguns nomes associados ao acesso de rede e comunicação entre processos (disponível no site https://en.wikipedia.org/wiki/Linux_namespaces).
[0010] Union Files Systems: Union é um serviço de sistema de arquivos para Linux, FreeBSD e NetBSD que implementa uma montagem de união para outros sistemas de arquivos. Ele permite que arquivos e diretórios de sistemas de arquivos separados, conhecidos como ramificações, sejam transparentemente sobrepostos, formando um único sistema de arquivos coerente. Os conteúdos dos diretórios que possuem o mesmo caminho dentro das ramificações mescladas serão vistos juntos em um único diretório mesclado, dentro do novo sistema de arquivos virtual. (disponível no site https://en.wikipedia.org/wiki/UnionFS).
[0011] O documento de patente US 9,152,582 B2 intitulado "AUTO-CONFIGURATION OF A DOCKED SYSTEM IN A MULTI-OS ENVIRONMENT", por Z124, concedido em 06 de outubro de 2015, propõe um método para autoconfigurar vários sistemas operacionais (no topo de um Kernel Android modificado) em um dispositivo móvel, a fim de fornecer uma experiência de desktop completa ao usuário, quando estiver acoplado a um ambiente de terminal secundário. A presente invenção difere do documento US 9,152,582 B2 ao propor o uso de tecnologias existentes em vez de modificar o Kernel Android. Também melhora a segurança ao executar dois containers, porque isola os recursos (processos, arquivos, usuários, memória etc.) em cada container.
[0012] A solução chamada Linux on Galaxy, da Samsung, habilita uma experiência de desktop em que o sistema nativo baseado em Android contém dentro dele uma distribuição Linux, em que as funcionalidades de Linux têm limitações de recursos: falta de controles avançados de hardware, permissões restritas a usuário do sistema e restrições de gerenciamento de recursos. A presente invenção difere da solução Linux on Galaxy apresentando, ao contrário, um sistema operacional Linux completo contendo funcionalidades Android em um container, superando as limitações citadas e fornecendo uma experiência de desktop Linux completa ao usuário, simultaneamente com as funcionalidades normais do smartphone.
[0013] A solução chamada Android in a Box, da Anbox, executa aplicativos Android em janelas Linux fazendo parecer que o sistema operacional Android está sendo executado dentro do Linux. A presente invenção difere desta solução, uma vez que traz uma experiência Android para o ambiente Linux, e não o contrário, como proposto pela solução chamada Android in Box. Além disso, a solução Android in Box não fornece isolamento entre os dois ambientes de sistema operacional.
[0014] O documento de patente CN 106095530, intitulado "MULTI-ANDROID-SYSTEM CONTAINER AUTOMATIC CREATING AND STARTING MIETHOD", da Universidade de Ciência e Tecnologia Eletrônica da China, depositado em 08 de junho de 2016, propõe a criação de várias instâncias de Android em containers separados em execução em um núcleo Linux, da mesma forma, mas com um propósito diferente do proposto pela presente invenção, ou seja, habilitando uma experiência de desktop completa, executando em containers virtuais no topo de um núcleo Linux, com base em aparelho móvel físico.
[0015] O sistema da presente invenção habilita uma experiência de desktop completa a partir de um dispositivo móvel (tal como smartphones e tablets), enquanto este permanece totalmente funcional. Isso permite que o usuário use simultaneamente um desktop e um telefone celular a partir do mesmo dispositivo, sem precisar carregar um laptop ou usar um desktop, apenas conectando o dispositivo a um visor (por exemplo, monitor, TV, projetor etc.).
[0016] Além disso, a presente invenção habilita uma experiência de desktop completa executando uma distribuição de sistema operacional Linux regular com todas as suas funcionalidades juntamente com um sistema operacional móvel. Quando o dispositivo está conectado a uma tela maior por qualquer meio (por exemplo, dock station, saída HDMI, transmissão de tela através da rede, compartilhamento de tela, VNC, etc.), o sistema operacional Linux é acessível ao usuário e sistema operacional móvel é mantido em execução na tela do dispositivo móvel normalmente com todas as suas funcionalidades. O acesso dos sistemas operacionais aos arquivos e processos um do outro pode ser restrito por razões de segurança. Se necessário, é possível compartilhar as pastas comuns entre os sistemas operacionais para trocar informações. Não há necessidade de modificar o código original do Núcleo Linux para implementar a invenção.
[0017] Os objetivos e vantagens da presente invenção se tornarão mais claros através da descrição detalhada a seguir do exemplo e desenhos não limitativos apresentados no final deste documento:
[0018] A Figura 1 divulga um exemplo de uma arquitetura padrão de sistema operacional de dispositivo móvel que permite que um dispositivo móvel se comporte como uma estação de trabalho de Desktop.
[0019] A Figura 2 apresenta um diagrama em que o sistema operacional móvel é empacotado em um container virtual que é executado no topo de uma distribuição Linux padrão.
[0020] A Figura 3 descreve uma abordagem alternativa pelo empacotamento da distribuição Linux padrão em um container virtual junto com o sistema operacional móvel.
[0021] A Figura 4 apresenta uma experiência móvel atual em comparação com a nova experiência com Desktop: exemplo das funções disponíveis atualmente no dispositivo móvel no lado esquerdo e a experiência de desktop completa no lado direito.
[0022] A Figura 1 apresenta o diagrama de Pilha de Tecnologia regular de um sistema operacional de dispositivo móvel do estado da técnica, que inclui um núcleo Linux enxuto que suporta um tempo de execução de sistema operacional móvel (por exemplo, Android). A fim de trazer a experiência de uma estação de trabalho de Desktop, ele altera algumas camadas daquela pilha em particular. Ele mantém as camadas do sistema operacional móvel existente como na arquitetura original. Além disso, de acordo com a Figura 1, a referência (010) representa uma das mudanças na camada de tempo de execução do sistema operacional móvel que identifica um dispositivo móvel conectado a uma dock station permitindo a emulação de um ambiente virtual de desktop pelo framework de aplicativo (Application Framework). Uma vez que uma conexão de encaixe ocorre ou um fluxo de transmissão de vídeo é detectado, o aplicativo de destino (011) assume o controle para emular um ambiente semelhante ao desktop para que o usuário tenha uma experiência de estação de trabalho. Apesar disso, essa abordagem apresenta algumas limitações: falta de controles avançados de hardware, permissões restritas a usuários do sistema e restrições de gerenciamento de recursos.
[0023] Na Figura 2, é divulgado o sistema da presente invenção para realizar uma experiência de desktop completa e não limitada, capaz de realizar qualquer tarefa ou atividade normal do desktop. O novo sistema compreende uma pilha de tecnologia modificada para habilitar um dispositivo móvel para se comportar como um computador de estação de trabalho. Abaixo, são descritos os principais componentes do sistema:
[0024] As duas primeiras camadas representam um núcleo Linux padrão (020) e distribuição Linux (021), tais como as distribuídas em laptops/computadores comuns. No Núcleo Linux (020), alterações adicionais são recebidas para suportar o hardware do dispositivo móvel. Além disso, a distribuição Linux (021) é a mesma distribuição Linux que alimenta computadores e laptops em todo o mundo. O container de sistema operacional móvel (022) é uma representação da Figura 1, em que o sistema operacional móvel será executado em um container Virtual no topo de uma distribuição Linux regular. Assim, a camada em (021) fornece uma experiência de desktop completa no topo de um dispositivo móvel; e a camada em (022) fornece uma experiência móvel regular como qualquer outro smartphone ou tablet.
[0025] Alternativamente, a Figura 3 descreve como o sistema pode ser projetado para executar as duas experiências, Desktop e Móvel, em seu próprio container virtual isolado um do outro para impedir que o container de desktop (030) tenha autoridade/controle sobre o container móvel. A figura 3 descreve a execução simultânea de vários containers no topo de uma Distribuição Linux minimalista, atendendo a diferentes propósitos no mesmo dispositivo móvel físico: atuar como dispositivos Desktop e Móvel simultaneamente.
[0026] A Figura 4 apresenta a mesma abordagem de conteinerização da Figura 3, porém com mais de um container de Desktop. Ela permite que múltiplos usuários trabalhem virtualmente ao mesmo tempo em Desktops separados com base no mesmo dispositivo móvel físico.
[0027] Embora a presente invenção tenha sido descrita em conexão com determinadas modalidades preferidas, deve ser entendido que não se pretende limitar a invenção a tais modalidades particulares. Pelo contrário, pretende-se abranger todas as alternativas, modificações e equivalentes possíveis dentro do espírito e escopo da invenção como definida pelas reivindicações anexas.
Claims (8)
- Sistema para habilitar uma Experiência de Desktop completa com base em um dispositivo móvel compreendendo um núcleo Linux e uma distribuição Linux em tal dispositivo móvel, caracterizado pelo fato de que um sistema operacional do dispositivo móvel é empacotado em um container virtual, enquanto o container é executado rodando dentro da distribuição Linux e o núcleo Linux gerencia ambos a distribuição Linux e o sistema operacional do dispositivo móvel.
- Sistema, de acordo com a reivindicação 1, caracterizado pelo fato de que o sistema operacional Linux é acessível ao usuário e o sistema operacional móvel é também mantido em execução na tela do dispositivo móvel normalmente com todas as suas funcionalidades.
- Sistema, de acordo com a reivindicação 1, caracterizado pelo fato de que habilita múltiplas instâncias de desktop, em que múltiplas instâncias de distribuições de sistema operacional Linux são empacotadas em seus respectivos containers virtuais.
- Sistema, de acordo com a reivindicação 1, caracterizado pelo fato de que o acesso dos sistemas operacionais aos arquivos e processos um do outro é restrito por razões de segurança.
- Sistema para habilitar uma Experiência de Desktop completa com base em um dispositivo móvel compreendendo um núcleo Linux e uma distribuição Linux em tal dispositivo móvel, caracterizado pelo fato de que um sistema operacional de desktop e um sistema operacional de dispositivo móvel executam em seus respectivos containers virtuais de forma independente um do outro e o núcleo Linux gerencia ambos a distribuição Linux e o sistema operacional móvel.
- Sistema, de acordo com a reivindicação 5, caracterizado pelo fato de que o sistema operacional Linuzx é acessível ao usuário e o sistema operacional móvel é mantido em execução na tela do dispositivo móvel com todas as suas funcionalidades.
- Sistema, de acordo com a reivindicação 5, caracterizado pelo fato de habilitar múltiplas instâncias de desktop em que múltiplas instâncias de distribuições de sistema operacional Linux são empacotadas em seus respectivos containers virtuais.
- Sistema, de acordo com a reivindicação 5, caracterizado pelo fato de que o acesso dos sistemas operacionais a cada arquivo e processo um do outro é restrito por segurança.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
BR102019000921-7A BR102019000921A2 (pt) | 2019-01-16 | 2019-01-16 | Sistema para habilitar uma experiência de desktop completa com base em um dispositivo móvel |
US16/380,382 US11385912B2 (en) | 2019-01-16 | 2019-04-10 | System to enable a full desktop experience based on a mobile device |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
BR102019000921-7A BR102019000921A2 (pt) | 2019-01-16 | 2019-01-16 | Sistema para habilitar uma experiência de desktop completa com base em um dispositivo móvel |
Publications (1)
Publication Number | Publication Date |
---|---|
BR102019000921A2 true BR102019000921A2 (pt) | 2020-08-04 |
Family
ID=71516654
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
BR102019000921-7A BR102019000921A2 (pt) | 2019-01-16 | 2019-01-16 | Sistema para habilitar uma experiência de desktop completa com base em um dispositivo móvel |
Country Status (2)
Country | Link |
---|---|
US (1) | US11385912B2 (pt) |
BR (1) | BR102019000921A2 (pt) |
Family Cites Families (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9152582B2 (en) * | 2010-10-01 | 2015-10-06 | Z124 | Auto-configuration of a docked system in a multi-OS environment |
US8726294B2 (en) * | 2010-10-01 | 2014-05-13 | Z124 | Cross-environment communication using application space API |
WO2012044557A2 (en) * | 2010-10-01 | 2012-04-05 | Imerj, Llc | Auto-configuration of a docked system in a multi-os environment |
US8856805B2 (en) * | 2011-12-29 | 2014-10-07 | Oracle International Corporation | Virtual channel for embedded process communication |
US9451043B2 (en) * | 2013-09-13 | 2016-09-20 | Evie Labs, Inc. | Remote virtualization of mobile apps |
US9674336B2 (en) * | 2013-10-20 | 2017-06-06 | Karim Jean Yaghmour | Portable processing unit add on for mobile devices |
CN106663018B (zh) * | 2014-09-24 | 2020-09-15 | 甲骨文国际公司 | 修改移动设备应用生命周期的系统、方法、介质和设备 |
US10002113B2 (en) * | 2014-12-30 | 2018-06-19 | Samsung Electronics Co., Ltd. | Accessing related application states from a current application state |
US10296323B2 (en) * | 2016-02-02 | 2019-05-21 | ZeroTurnaround AS | System and method for fast initial and incremental deployment of apps |
-
2019
- 2019-01-16 BR BR102019000921-7A patent/BR102019000921A2/pt unknown
- 2019-04-10 US US16/380,382 patent/US11385912B2/en active Active
Also Published As
Publication number | Publication date |
---|---|
US20200225965A1 (en) | 2020-07-16 |
US11385912B2 (en) | 2022-07-12 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10050850B2 (en) | Rack awareness data storage in a cluster of host computing devices | |
EP2622490B1 (en) | Cross-environment communication framework | |
US8726294B2 (en) | Cross-environment communication using application space API | |
US9098437B2 (en) | Cross-environment communication framework | |
US20180276229A1 (en) | Trusted File Indirection | |
US8726337B1 (en) | Computing with presentation layer for multiple virtual machines | |
US10255088B2 (en) | Modification of write-protected memory using code patching | |
US20210224100A1 (en) | Virtual machine migration using multiple, synchronized streams of state data | |
US9836357B1 (en) | Systems and methods for backing up heterogeneous virtual environments | |
US20070143315A1 (en) | Inter-partition communication in a virtualization environment | |
Kibe et al. | The evaluations of desktop as a service in an educational cloud | |
US11392395B2 (en) | Generating and presenting contextual user interfaces on devices with foldable displays | |
US9678984B2 (en) | File access for applications deployed in a cloud environment | |
US11165888B1 (en) | Image acquisition device virtualization for remote computing | |
WO2015088374A1 (en) | Systems and methods for cross-architecture container virtualization | |
CN107704618B (zh) | 一种基于aufs文件系统的热迁徙方法和系统 | |
BR102019000921A2 (pt) | Sistema para habilitar uma experiência de desktop completa com base em um dispositivo móvel | |
US10261921B2 (en) | Universal secure platform virtualization system and method thereof | |
US11513825B2 (en) | System and method for implementing trusted execution environment on PCI device | |
Gerofi et al. | Toward full specialization of the HPC software stack: reconciling application containers and lightweight multi-kernels | |
Pickartz et al. | A locality-aware communication layer for virtualized clusters | |
US9912787B2 (en) | Zero-copy multiplexing using copy-on-write | |
Afoulki et al. | MAC protection of the OpenNebula Cloud environment | |
Zhang et al. | Lightweight Container-based User Environment | |
US20240126580A1 (en) | Transparently providing virtualization features to unenlightened guest operating systems |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
B03A | Publication of a patent application or of a certificate of addition of invention [chapter 3.1 patent gazette] | ||
B15K | Others concerning applications: alteration of classification |
Free format text: AS CLASSIFICACOES ANTERIORES ERAM: G06F 13/14 , G06F 13/40 , G06F 13/42 Ipc: G06F 13/40 (2006.01), G06F 13/42 (2006.01) |