|Publication number||US7373656 B2|
|Application number||US 09/853,827|
|Publication date||May 13, 2008|
|Filing date||May 11, 2001|
|Priority date||Oct 27, 2000|
|Also published as||US20020078367, WO2002093468A1|
|Publication number||09853827, 853827, US 7373656 B2, US 7373656B2, US-B2-7373656, US7373656 B2, US7373656B2|
|Inventors||Alex Lang, Shimon S. Shmueli, David W. Sharp, Brian J. Adkins|
|Original Assignee||Sandisk Il Ltd.|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (47), Non-Patent Citations (3), Referenced by (27), Classifications (30), Legal Events (4)|
|External Links: USPTO, USPTO Assignment, Espacenet|
Applications related to the present invention include provisional application Ser. No. 60/243,816, filed Oct. 27, 2000, entitled PORTABLE PRIVACY AND CONFIGURATION FOR COMPUTER AND WEB BASED APPLICATIONS; and utility application Ser. No. 09/802,691, entitled PREFERENCE PORTABILITY FOR COMPUTING, Ser. No. 09/802,634, entitled ACCOUNT PORTABILITY FOR COMPUTING, Ser. No. 09/803,601, entitled SHOPPING CART PORTABILITY FOR COMPUTING, Ser. No. 09/803,291, entitled PORTABLE INTERFACE FOR COMPUTING, and Ser. No. 09/803,290, entitled PRIVACY ASSURANCE FOR PORTABLE COMPUTING, all filed Mar. 9, 2001, the disclosures of which are incorporated herein by reference in their entirety.
The present invention relates to portable devices to facilitate computing, and in particular, relates to a portable device capable of interacting with a computing device to facilitate portability of cryptography services.
Using multiple computers and multiple computing devices is becoming commonplace. The need or desire for people to use more than one computer in addition to mobile computing devices, such as personal digital assistants (PDAs) and mobile telephones accessing the Internet, is increasing for private and business use. These users frequently use applications to access the Internet and send email, and require cryptography in association with these applications to authenticate, secure, or otherwise protect transmitted and transactional information. Many operating systems, such as Microsoft® Windows®, use specialized services such as a cryptographic service provider (CSP) to implement desired cryptographic standards and algorithms. Typically, a CSP consists of a dynamic-link library (DLL) that implements defined functions in a system program interface, such as Microsoft® Crypto SPI. CSPs typically cooperate with a cryptography application program interface (API) to serve cryptography functions required by applications. CSPs may be any combination of software and hardware, and may implement their functionality in association with a computer device's operating system and processor, or separately in an associated device having its own processing capability.
In a Windows environment, the cryptographic device, such as a CSP, must be installed and registered with the host. This typically involves copying software to the host and modifying configuration data so that the operating system, and particularly the necessary API is aware of the presence of the CSP or the device providing the services of the CSP. Thus, for a user to access and implement cryptographic services on multiple devices, the necessary software or hardware must be installed on each host prior to being able to use the services, if these services are not already installed on the desired host.
Given the ever-increasing need for security and cryptography services, users need to take additional precautions to protect encryption keys and related cryptography functions when using multiple devices. As such, there is a need to provide a secure and efficient way to transport cryptography services from one device to another, while eliminating the need to separately install and register cryptography services and devices on each host.
The present invention relates to a portable device configured to interact with any number of host computing devices. The portable device primarily includes memory associated with an interface to facilitate interaction with the host computing devices. The portable device may include control circuitry to assist in interactions with the host computing devices, as well as to execute software and organize data stored thereon.
In operation, the portable device will initially appear to a host computing device as a known device type. The host computing device will be configured to interact with the portable device as the known device type. Upon such interaction, the host computing device will access indicia sufficient to identify the portable device as a second device type and instruct the host computing device to configure itself to interact with the portable device as the second device type. The indicia may be provided in hardware, firmware, software, data, or any combination thereof. The second device type is preferably configured to provide a service for applications running on the host computing device.
In a preferred embodiment, the second device type is a cryptographic service provider (CSP) capable of providing cryptography services for applications running on the host computing device. The known device type will preferably emulate a mass storage device readily accessible and addressable by the host computing device upon recognition. Software or data provided in the memory of the device is preferably accessible and executable by the host computing device. The data may include keys for encryption/decryption, cryptography algorithms, and the like. Notably, portable devices equipped with processing capabilities may operate to provide processing for the services provided by the second device type on the portable device.
Those skilled in the art will appreciate the scope of the present invention and realize additional aspects thereof after reading the following detailed description of the preferred embodiments in association with the accompanying drawing figures.
The accompanying drawing figures incorporated in and forming a part of the specification illustrate several aspects of the invention, and together with the description serve to explain the principles of the invention.
The present invention provides a portable device capable of interfacing with a number of host computing devices. The portable device is preferably configured to automatically interact with a host to install and register cryptography services provided by software or hardware on the portable device for use by applications capable of running on the host. The applications may be pre-installed on the host, or may be provided on the portable device itself and executed on the host as desired.
The portable device is preferably configured to appear as a memory device, including the necessary software and data to facilitate cryptographic services. The software and data may be accessed and used by the host operating system to facilitate cryptographic services. Alternatively, the portable device may include processing capability sufficient to provide a portion of or all of the necessary cryptography functions required by applications running on the host. Preferably, the portable device will store cryptography keys, such as private and perhaps public keys used for encryption and decryption. The portable device may also include any other type of authentication or verification indicia necessary for operation. Although this specification focuses on the use of a cryptographic service provider (CSP), those skilled in the art will recognize alternative service providers and functions falling within the concepts of the described invention.
The embodiments set forth below represent the necessary information to enable those skilled in the art to practice the invention and illustrate the best mode of practicing the invention. Upon reading the following description in light of the accompanying drawing figures, those skilled in the art will understand the concepts of the invention and will recognize applications of these concepts not particularly addressed herein. It should be understood that these applications and concepts fall within the scope of this disclosure and the accompanying claims. Prior to delving into the detailed operation of the present invention, the basic environment and configuration of the portable device is described. Details of the specific operation and functionality of the invention follow.
With reference to
The portable device 10 may include a central processing unit (CPU) 17 having memory 18 associated with software 20 capable of running on one of the hosts 12, and data 22. The memory 18 will be associated with a portable device interface 24 to facilitate an interface with one or more of the hosts 12. Preferably, once an interaction between the portable device 10 and a host 12 is established, the memory 18 will emulate a file system on a memory device, such as a hard disk drive, accessible by the host 12 wherein at least certain aspects of the software 20 are capable of running or executing on the host 12. Further detail is provided below.
In the preferred embodiment, the portable device 10 will include four or more megabytes of flash memory and a built-in USB sleeve interface. When the portable device 10 is plugged into a USB port of a host 12, the portable device 10 may emulate a file system on a solid state mass storage device, and via plug-and-play functionality, rely on device drivers that are typically associated with the host's operating system. The portable device 10 is preferably configured for auto run capability, which is described in detail below. This configuration will allow a start-up application stored on the portable device 10 to start executing when the portable device 10 is plugged in to the USB port of the host 12.
Those skilled in the art will recognize a variety of configurations for the portable device 10 wherein when the portable device 10 is placed into or associated with the host 12, one or more keylets or other applications, functions, or the like are automatically executed by the host 12. The organization of the memory 18 will preferably resemble a file structure addressable by the host 12. Preferably, the software 20 will include Java applets, Active-X components, or the like capable of automatically running on the host 12 upon engaging the portable device 10 with the host 12, or otherwise establishing an interaction between the two devices. Additional detail is provided below.
The host 12 may take many forms, including a personal computer (PC), workstation, personal digital assistant (PDA), notebook computer, web-enabled mobile telephone, or the like. The host 12, regardless of form, will typically include a CPU 26 associated with memory 28 having the requisite software 30 and data 32 for operation. Typically, a user interface 34 is provided to facilitate interaction with the host's user, which is preferably the owner of the portable device 10, who is interacting with the host 12. The CPU 26 is preferably associated with a host interface 36 to facilitate interaction with the portable device 10, and a network interface 38 to facilitate interaction with any number of devices associated with network 16, such as the servers 14.
Importantly, certain software 20 on the portable device 10 is configured to readily execute on the host 12 upon interface. For example, the portable device 10 may be compatible with Windows plug-and-play or autorun capability, and the portable device interface 24 may be USB compatible, wherein when the portable device 10 is plugged into the host interface 36 of the host 12, the host 12 will recognize the portable device 10 and execute select applications or functions provided by the software 20 of the portable device 10.
The host 12 is preferably configured to access various servers 14 over the network 16 upon executing applications or functions of the portable device 10. These servers 14 may be configured in any number of ways. The servers 14 may be traditional application servers facilitating the function of the host 12, or may be web servers capable of downloading markup language content upon request from a browser running on the host 12.
The server 14 will typically include a CPU 40 having memory 42 with the requisite software 44 and data 46 to facilitate operation. The server 14 will typically include a user interface 48 and a network interface 50 cooperating with the CPU 40. The user interface 48 allows a direct interface with the server 14, wherein the network interface 50 facilitates interaction with any number of network devices, including other servers 14 and hosts 12.
Turning now to
The applications or functions stored on the portable device 10 and capable of executing on the host 12 are referred to in general as keylets. Keylets may also reside on a host system itself, depending on the security level associated with that host 12. Typically, keylets are assigned a class indicating the basic functionality of the keylet, and preferably a security level corresponding to the functionality of the keylet. The keylets are preferably Java applets, but may incorporate any software technology facilitating ready execution on a host 12. The keylets may provide any number of functions.
In the preferred embodiment, the portable device 10 acts as a storage device as well as a cryptographic device. The portable device 10 takes advantage of the mass storage persona in order to allow the device to bring along its own cryptographic services, preferably a CSP, to any host 12 that it is plugged into or with which it is associated. As a result of this capability, there is no need for separate installation of the CSP, but rather a keylet present in the portable device 10 runs on the host 12 to access the CSP on the portable device 10 and redirect the host operating system to use the services of the CSP on the portable device 10. Preferably, the cryptography API layer of the operating system is reconfigured to access the CSP on the portable device 10 in lieu of the CSPs residing on the host 12, as necessary. CSPs are well known in the art, and those skilled in the art are directed to the various resources available describing and defining the construction and use of CSPs, particularly those used in a Microsoft operating environment.
In general, the functionality of cryptographic services contained in a CSP depend on the type of task the CSP is requested to perform. As an example, the CSP may be used to provide digital signatures, authenticate the user for physical or electronic access, or encrypt and decrypt transferred media. Typically, CSPs perform one or more of the following functions and services:
CSPs typically provide secure storage for private keys. Various applications may query the services of the CSP through a cryptography API, among other logical layers, to access private keys kept within the CSP. The CSP will control access to private keys and require applications to be authorized to use such private keys. Applications requiring the services of CSPs may interact with one or more CSPs. A CSP may be implemented in software executed by the host, or facilitated in a separate hardware device.
In the present invention, the CSP may be implemented using software 20 stored on the portable device 10 wherein the software 20 is ultimately run by the host processor, or alternatively, the portable device 10 may include processing capabilities capable of performing services, such as cryptography functions by executing software 20 stored on the portable device 10 by the CPU 17 on the portable device 10. Thus, CSPs can be instantiated in hardware, firmware, software, or a combination thereof. Functionally, the distinction should be transparent to the applications requiring the services of the CSP. Typically, applications incorporating a more hardware-intensive embodiment, such as those incorporating the CPU 17 in the portable device 10, are more tamper-resistant than those implemented solely in software, wherein the CSP is actually facilitated using host processing.
As noted, the CSP functions to implement cryptographic standards and algorithms. The CSP consists of a dynamic-link library (DLL) implementing the cryptographic standards and algorithms via a system program interface, such as crypto SPI.
Turning now to
Applications typically use handles to refer to data objects within a respective CSP 58. Example data objects that are often referenced by their handles include public and private key pairs, session keys, hashing information, and key containers. The operating system 52 will access these various objects using the handles and facilitate coordination between the applications 50 and the CSP 58.
For the present invention, the portable device 10 will include the necessary software to interact with the host 12 when the portable device 10 is plugged into the host 12 or otherwise associated with the host 12, to effectively register and install a CSP 58 provided by the portable device 10 with the host 12. Once installed, the CSP 58X of the portable device 10 appears as any other CSP 58 registered with the operating system 52. Preferably, the portable device 10 will appear to the operating system 52 as a memory device with the necessary software and data to facilitate the CSP 58X, or as a separate device functioning to implement the services of the CSP 58X.
As such, the portable device 10 may appear to the host system as one or more devices, as illustrated in
Turning now to the flow chart of
Preferably, the automatic initialization uses Microsoft's autorun feature, wherein the portable device 10 will include an executable autorun.inf file in a memory portion accessible and expected by the host 12. The autorun.inf file will include instructions for the operating system to configure the host 12 to recognize the portable device 10 as a CSP 58 or provide instructions to execute a file on the portable device 10 that will configure the host 12 to recognize the device as a CSP 58. Either of these actions will effectively register the CSP 58X provided by or contained on the portable device 10 with the host 12 (block 110). The registration of the CSP 58X will include providing the necessary device drivers or modifying any registries in the operating system or associated APIs to direct calls from the application to the CSP 58X on the portable device 10 as desired.
Although operating systems will vary from device to device, the present invention essentially registers the CSP 58X on the host 12 with the host operating system 52 via a crypto API 54 or like software layer. The result is that applications can access the CSP 58X through the pertinent API 54 to use the services provided by the CSP 58X on the portable device 10. Again, the CSP 58X may be implemented by running software 20 provided by the portable device 10, on the host CPU 26, or having the portable device 10 do the processing and simply returning results in response to calls from applications to the operating system 52 or API 54 (block 112). Notably, the keylets initially provided on and by the portable device 10 are capable of running on the host 12 and may use the CSP 58X, which was automatically installed on the host 12 when the portable device 10 was plugged into or otherwise associated with the host 12.
Given the mobility provided by the present invention, additional keylets or like software may be provided by the portable device 10 to effectively de-register CSPs 58X previously automatically installed in association with using the portable device 10 (block 114). In essence, the keylet will operate to reconfigure the host 12 to its original configuration prior to installing the CSP 58X. De-registering such CSPs 58X will prevent the host 12 from trying to access certain functions, services, or drivers after the portable device 10 has been removed. To provide additional security, the same or additional keylets may operate to remove all or select information from the host 12 indicative of the user's interaction (block 116).
Depending on the keylet being executed, the user may indicate a desire to end the session, wherein the keylets or data involved in the interaction may be updated as necessary. Throughout this process, one or more of the keylets may monitor for the insertion or loss of presence of the portable device 10. If the portable device 10 is not removed, the process will repeat. If the portable device 10 has been removed, one or more of the keylets will preferably continue to run on the host to clean any residue left from the user interaction. Cleansing the residue from the host 12 will preferably include removing any cookies, histories, information in cache, or other memory indicative of the user's interaction. Such a cleansing is also preferable upon a scheduled termination of the session, wherein the cleansing will occur upon the user signaling for an end of the interaction. The automatic cleansing upon removal of the portable device 10 is a safeguard for those forgetting to properly end the session and simply removing the portable device 10 without providing the host 12 forewarning.
The portable devices 10 may have various combinations of memory and interface types. The memory types may include: flash memory with hard disk drive emulation; SRAM-based, typically with hard disk drive emulation and a battery backup; internally mapped device memory; or memory, such as that used in a smart card, which does not require or use hard disk drive emulation. The interfaces may include those standard for personal computers, such as the universal serial bus (USB), IEEE 1392, etc., or wireless interfaces, such as that provided by Bluetooth, IEEE 802.11, and the like.
Regardless of the type of memory and interface, the portable devices 10 will be able to interface to the host 12. In addition to computers, personal digital assistants (PDAs), and mobile telephones, hosts 12 may also include various types of kiosks, such as automated teller machines (ATMs) and the like. Portable devices 10 may emulate various types of Windows- and UNIX-based systems and the like.
Those skilled in the art will recognize certain variations and modifications to the concepts described herein. These variations and modifications are considered within the scope of the disclosure and the claims that follow.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US5404485||Mar 8, 1993||Apr 4, 1995||M-Systems Flash Disk Pioneers Ltd.||Flash file system|
|US5497455||Jun 25, 1993||Mar 5, 1996||Kabushiki Kaisha Toshiba||Portable computer which has a task selection menu allowing easy selection and execution of arbitrary application software without entering a command|
|US5519843||Mar 15, 1993||May 21, 1996||M-Systems||Flash memory system providing both BIOS and user storage capability|
|US5535357||Jun 5, 1995||Jul 9, 1996||M-Systems Flash Disk Pioneers Ltd.||Flash memory system providing both BIOS and user storage capability|
|US5777903||Jan 22, 1996||Jul 7, 1998||Motorola, Inc.||Solar cell powered smart card with integrated display and interface keypad|
|US5778071 *||Aug 12, 1996||Jul 7, 1998||Information Resource Engineering, Inc.||Pocket encrypting and authenticating communications device|
|US5781723||Jun 3, 1996||Jul 14, 1998||Microsoft Corporation||System and method for self-identifying a portable information device to a computing unit|
|US5799168||Jan 5, 1996||Aug 25, 1998||M-Systems Flash Disk Pioneers Ltd.||Standardized flash controller|
|US5815577 *||Mar 24, 1997||Sep 29, 1998||Innovonics, Inc.||Methods and apparatus for securely encrypting data in conjunction with a personal computer|
|US5907620 *||Aug 23, 1996||May 25, 1999||Cheyenne Property Trust||Method and apparatus for enforcing the use of cryptography in an international cryptography framework|
|US5937425||Oct 16, 1997||Aug 10, 1999||M-Systems Flash Disk Pioneers Ltd.||Flash file system optimized for page-mode flash technologies|
|US5954808||Sep 17, 1997||Sep 21, 1999||Micron Electronics, Inc.||Method for configuring a computer-based system with a configuration card|
|US5960085||Apr 14, 1997||Sep 28, 1999||De La Huerga; Carlos||Security badge for automated access control and secure data gathering|
|US5987612||Dec 2, 1997||Nov 16, 1999||Nippon Telegraph And Telephone Corporation||Internet accessing system using card readers and dual cards with information pertaining to log on|
|US6003135 *||Jun 4, 1997||Dec 14, 1999||Spyrus, Inc.||Modular security device|
|US6040851 *||Jan 20, 1998||Mar 21, 2000||Conexant Systems, Inc.||Small-format subsystem for broadband communication services|
|US6055314 *||Mar 22, 1996||Apr 25, 2000||Microsoft Corporation||System and method for secure purchase and delivery of video content programs|
|US6084968 *||Oct 29, 1997||Jul 4, 2000||Motorola, Inc.||Security token and method for wireless applications|
|US6088802||Jun 4, 1997||Jul 11, 2000||Spyrus, Inc.||Peripheral device with integrated security functionality|
|US6095412||Oct 24, 1997||Aug 1, 2000||Intellect Australia Pty Ltd.||Host and user transaction system|
|US6101482||Sep 15, 1997||Aug 8, 2000||International Business Machines Corporation||Universal web shopping cart and method of on-line transaction processing|
|US6101483||May 29, 1998||Aug 8, 2000||Symbol Technologies, Inc.||Personal shopping system portable terminal|
|US6148354||Apr 5, 1999||Nov 14, 2000||M-Systems Flash Disk Pioneers Ltd.||Architecture for a universal serial bus-based PC flash disk|
|US6182217 *||Sep 3, 1999||Jan 30, 2001||Siemens Aktiengesellschaft||Electronic data-processing device and system|
|US6199114||Nov 9, 1999||Mar 6, 2001||Webtv Networks, Inc.||Initiating a user session at an internet terminal using a smart card|
|US6282522||Oct 16, 1997||Aug 28, 2001||Visa International Service Association||Internet payment system using smart card|
|US6334216||Dec 2, 1998||Dec 25, 2001||Alcatel||Access control facility for a service-on-demand system|
|US6351813 *||Aug 7, 1998||Feb 26, 2002||Digital Privacy, Inc.||Access control/crypto system|
|US6385729||May 26, 1998||May 7, 2002||Sun Microsystems, Inc.||Secure token device access to services provided by an internet service provider (ISP)|
|US6397224||Dec 10, 1999||May 28, 2002||Gordon W. Romney||Anonymously linking a plurality of data records|
|US6425084 *||Oct 10, 2000||Jul 23, 2002||Durango Corporation||Notebook security system using infrared key|
|US6434530||Jan 20, 1999||Aug 13, 2002||Retail Multimedia Corporation||Interactive shopping system with mobile apparatus|
|US6453342||Dec 3, 1998||Sep 17, 2002||International Business Machines Corporation||Method and apparatus for selective caching and cleaning of history pages for web browsers|
|US6460076||Dec 21, 1998||Oct 1, 2002||Qwest Communications International, Inc.||Pay per record system and method|
|US6481621||Nov 19, 1999||Nov 19, 2002||International Business Machines Corporation||System method and article of manufacture for accessing and processing smart card information|
|US6529992 *||Jul 26, 1999||Mar 4, 2003||Iomega Corporation||Self-contained application disk for automatically launching application software or starting devices and peripherals|
|US6550672||Nov 4, 1999||Apr 22, 2003||Symbol Technologies, Inc.||Method and system for presenting item information using a portable data terminal|
|US6567915||Oct 23, 1998||May 20, 2003||Microsoft Corporation||Integrated circuit card with identity authentication table and authorization tables defining access rights based on Boolean expressions of authenticated identities|
|US6581072||May 17, 2001||Jun 17, 2003||Rakesh Mathur||Techniques for identifying and accessing information of interest to a user in a network environment without compromising the user's privacy|
|US6609113||Feb 3, 2000||Aug 19, 2003||The Chase Manhattan Bank||Method and system for processing internet payments using the electronic funds transfer network|
|US6708272 *||May 20, 1999||Mar 16, 2004||Storage Technology Corporation||Information encryption system and method|
|US6738901||Dec 15, 1999||May 18, 2004||3M Innovative Properties Company||Smart card controlled internet access|
|US6775770 *||Dec 30, 1999||Aug 10, 2004||Intel Corporation||Platform and method for securing data provided through a user input device|
|US6792464||Feb 15, 2001||Sep 14, 2004||Colin Hendrick||System for automatic connection to a network|
|US7117369 *||May 3, 1999||Oct 3, 2006||Microsoft Corporation||Portable smart card secured memory system for porting user profiles and documents|
|US20020034301 *||Aug 14, 2001||Mar 21, 2002||Stefan Andersson||Network authentication|
|US20020052806||Jun 1, 2001||May 2, 2002||David Hodson||Integrated electronic shopping cart system and method|
|1||"Portable Internet Settings", IBM Technical Disclosure Bulletin, vol. 40, Issue No. 12, pp. 183-184, Dec. 1997.|
|2||Anonymous, "Wireless Local Area Network Cuts Costs, Setup Time", Modern Materials Handling, Jun. 1997, Scan Tech News, p. S-24.|
|3||Ecommerce-guide.com, "BuyWiz Unveils Universal Shopping Cart", www.ecommerce.internet.com/news/insights/trends, Aug. 29, 1999.|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US7917949||Dec 21, 2005||Mar 29, 2011||Sandisk Corporation||Voice controlled portable memory storage device|
|US8041863 *||Nov 16, 2006||Oct 18, 2011||International Business Machines Corporation||Automated solution to provide personalized user environment on any public computer using portable storage devices with personalized user settings uploaded to local registry of public computer|
|US8161289||Dec 21, 2005||Apr 17, 2012||SanDisk Technologies, Inc.||Voice controlled portable memory storage device|
|US8284781 *||Sep 25, 2009||Oct 9, 2012||Htc Corporation||Portable electronic device and image data communication method thereof|
|US8406238 *||Apr 3, 2012||Mar 26, 2013||Htc Corporation||Portable electronic device and image data communication method thereof|
|US8473941 *||Jul 8, 2008||Jun 25, 2013||Sandisk Il Ltd.||Dynamic file system restriction for portable storage devices|
|US8527679 *||Jun 16, 2009||Sep 3, 2013||Samsung Electronics Co., Ltd.||Apparatus and method for adaptation of input/output interface in virtualization environment|
|US8966142 *||Jun 19, 2008||Feb 24, 2015||Samsung Electronics Co., Ltd.||Method and apparatus for inputting/outputting virtual operating system from removable storage device on a host using virtualization technique|
|US9046931||Jun 26, 2013||Jun 2, 2015||Samsung Electronics Co., Ltd.||Apparatus and method for adaptation of input/output interface in virtualization environment|
|US9164919||Jan 15, 2015||Oct 20, 2015||Samsung Electronics Co., Ltd.||Method and apparatus for inputting/outputting virtual operating system from removable storage device on a host using virtualization technique|
|US9356913||Jun 30, 2014||May 31, 2016||Microsoft Technology Licensing, Llc||Authorization of joining of transformation chain instances|
|US9396698||Jun 30, 2014||Jul 19, 2016||Microsoft Technology Licensing, Llc||Compound application presentation across multiple devices|
|US9659394||Jun 30, 2014||May 23, 2017||Microsoft Technology Licensing, Llc||Cinematization of output in compound device environment|
|US20050114183 *||Sep 13, 2004||May 26, 2005||Digiovanna Leonard D.||Advertising method and system for health related fields|
|US20050273845 *||Jun 6, 2005||Dec 8, 2005||Akihiro Urano||Information processing device, program therefor, and information processing system wherein information processing devices are connected via a network|
|US20060062387 *||Apr 28, 2005||Mar 23, 2006||Maciej Michalczak||System for controlling conditional access systems and method for controlling conditional access systems|
|US20070143111 *||Dec 21, 2005||Jun 21, 2007||Conley Kevin M||Voice controlled portable memory storage device|
|US20070143117 *||Dec 21, 2005||Jun 21, 2007||Conley Kevin M||Voice controlled portable memory storage device|
|US20070143533 *||Dec 21, 2005||Jun 21, 2007||Conley Kevin M||Voice controlled portable memory storage device|
|US20080071935 *||Oct 31, 2007||Mar 20, 2008||Microsoft Corporation||Self-Installing Computer Peripherals|
|US20080120439 *||Nov 16, 2006||May 22, 2008||International Business Machines Corporation||Automated solution to provide immediate requisite access to data and applications on an attached external device|
|US20090216916 *||Jun 19, 2008||Aug 27, 2009||Samsung Electronics Co., Ltd.||Method and apparatus for inputting/outputting data using virtualization technique|
|US20090313406 *||Jun 16, 2009||Dec 17, 2009||Suh Sang-Bum||Apparatus and method for adaptation of input/output interface in virtualization environment|
|US20100011351 *||Jul 8, 2008||Jan 14, 2010||Sandisk Il Ltd.||Dynamic file system restriction for portable storage devices|
|US20100271543 *||Sep 25, 2009||Oct 28, 2010||Htc Corporation||Portable Electronic Device and Image Data Communication Method Thereof|
|US20120194533 *||Apr 3, 2012||Aug 2, 2012||Htc Corporation||Portable electronic device and image data communication method thereof|
|US20130166456 *||Nov 25, 2010||Jun 27, 2013||Zte Corporation||System and Method for Remote Payment Based on Mobile Terminal|
|U.S. Classification||726/3, 713/159|
|International Classification||G06Q20/00, H04L29/06, H04L9/00, G06F21/00, G06K19/00|
|Cooperative Classification||H04L63/0485, G06Q20/32, G06F21/35, H04L63/0853, G06F21/41, G06F21/78, G06F21/6218, G06F21/602, G06F2221/2119, G06F21/34, G06F21/31, G06Q30/06|
|European Classification||G06Q30/06, G06F21/34, G06F21/35, G06F21/41, G06F21/60A, G06F21/62B, G06F21/31, G06F21/78, H04L63/04B14, G06Q20/32, H04L63/08E|
|Mar 29, 2002||AS||Assignment|
Owner name: M-SYSTEMS FLASH DISK PIONEERS LIMITED, ISRAEL
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:KEYNETICA, INC.;REEL/FRAME:012770/0793
Effective date: 20020315
|Apr 4, 2008||AS||Assignment|
Owner name: MSYSTEMS LTD, ISRAEL
Free format text: CHANGE OF NAME;ASSIGNORS:M-SYSTEMS FLASH DISK PIONEERS LTD.;MSYSTEMS LTD;REEL/FRAME:020760/0675;SIGNING DATES FROM 20060504 TO 20070101
Owner name: SANDISK IL LTD., ISRAEL
Free format text: CHANGE OF NAME;ASSIGNORS:M-SYSTEMS FLASH DISK PIONEERS LTD.;MSYSTEMS LTD;REEL/FRAME:020760/0675;SIGNING DATES FROM 20060504 TO 20070101
|Sep 19, 2011||FPAY||Fee payment|
Year of fee payment: 4
|Oct 28, 2015||FPAY||Fee payment|
Year of fee payment: 8