A system, a method, and computer-readable media are provided for altering behavior of software based on detection of an internet connection. The system, method, and media detect when a computer has connected to the internet or is capable of connecting to the internet. This detection may include analyzing a connection history of the computer to the internet, reporting in real-time when the computer establishes a connection to the internet, or attempting to actively establish a connection with an internet resource using the computer. A first set of software functionality may be disabled when a previously established connection with the internet is identified, a real-time report of a connection with the internet is generated, or a connection with the internet resource is established. In addition, a second set of software functionality may be enabled when the first set of software functionality is disabled.
|
1. computer-readable storage media storing computer-executable instructions that, when executed, perform a method of altering a behavior of software based on detection of an internet connection, the method comprising:
detecting when a first computer has connected to an internet or is capable of connecting to the internet, wherein said detecting includes attempting to actively establish a connection with an internet resource using said first computer; and
disabling a first set of software functionality for a second computer in communication with said first computer when said connection with an internet resource using said first computer is established.
14. A computer-implemented method for altering behavior of software based on detection of a connection to an internet, said method comprising:
detecting software operating in a network environment that is connected to the internet by identifying at least one computer in said network environment that has connected to the internet or is capable of connecting to the internet;
in response to said detection, instructing said software to operate in accordance with an altered functionality mode on at least one other computer, wherein one or more functions of said software are disabled in said altered functionality mode; and
re-enabling said one or more functions of said software incident to detecting compliance with a set of rules associated with said software.
10. A system for altering software behavior based on detection of an internet connection, said system comprising:
a detection component configured to determine if a first computer has connected to an internet or is capable of connecting to the internet, wherein said detection component includes an active-testing component configured to attempt to establish a connection with an internet resource using said first computer;
a disabling component configured to disable a first set of software functionality in a second computer when said detection component detects said first computer has connected to the internet or is capable of connecting to the internet; and
a licensing component configured to re-enable said first set of software functionality in said second computer when licensing data is obtained for said second computer.
2. The media of
3. The media of
4. The media of
5. The media of
6. The media of
7. The media of
8. The media of
9. The media of
11. The system of
12. The system of
13. The system of
15. The method of
|
Not applicable.
Not applicable.
Software piracy creates significant losses for software publishers worldwide. Preventing software piracy is even more complicated when the software is designed for high-security environments (e.g., a government agency or an R&D facility). The complication exists because the software must still function without enabling some traditional license enforcement features. With these license enforcement features disabled, the software becomes a prime target for commercialized piracy where it may be duplicated and sold without the knowledge or consent of the publisher.
Embodiments of the invention are defined by the claims below, not this summary. A high-level overview of various aspects of the invention are provided here for that reason, to provide an overview of the disclosure, and to introduce a selection of concepts that are further described in the detailed-description section below. This summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in isolation to determine the scope of the claimed subject matter.
A software solution is provided that alters the licensed behavior of software based on detection of an Internet connection. This may be implemented by detecting when a computer has connected to the Internet or is capable of connecting to the Internet. This detection may include analyzing a connection history of the computer to the Internet, detecting in real-time when the computer establishes a connection to the Internet, or attempting to actively establish a connection with an Internet resource using the computer. A first set of software functionality may be disabled when a previously established connection with the Internet is identified, a real-time report of a connection with the Internet is generated, or a connection with an Internet resource is established. In addition, a second set of software functionality may be enabled when the first set of software functionality is disabled. The second set of software functionality may reduce, increase, or enhance the functionality of the software. Finally, disabling the first set of software functionality and enabling the second set of functionality may be performed without user intervention.
Illustrative embodiments of the present invention are described in detail below with reference to the attached drawing figures, and wherein:
The subject matter of embodiments of the present invention is described with specificity herein to meet statutory requirements. But the description itself is not intended to necessarily limit the scope of claims. Rather, the claimed subject matter might be embodied in other ways to include different steps or combinations of steps similar to the ones described in this document, in conjunction with other present or future technologies. Terms should not be interpreted as implying any particular order among or between various steps herein disclosed unless and except when the order of individual steps is explicitly described.
Embodiments of the present invention may be embodied as, among other things: a method, system, or set of instructions embodied on one or more computer-readable media. Computer-readable media include both volatile and nonvolatile media, removable and nonremovable media, and contemplate media readable by a database, a switch, and various other network devices. By way of example, and not limitation, computer-readable media comprise media implemented in any method or technology for storing information. Examples of stored information include computer-useable instructions, data structures, program modules, and other data representations. Media examples include, but are not limited to information-delivery media, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile discs (DVD), holographic media or other optical disc storage, magnetic cassettes, magnetic tape, magnetic disk storage, and other magnetic storage devices. These technologies can store data momentarily, temporarily, or permanently.
Turning now to
The invention may be described in the general context of computer code or machine-useable instructions, including computer-executable instructions such as program modules, being executed by a computer or other machine, such as a personal data assistant or other handheld device. Generally, program modules including routines, programs, objects, components, data structures, etc., refer to code that perform particular tasks or implement particular abstract data types. The invention may be practiced in a variety of system configurations, including handheld devices, consumer electronics, general-purpose computers, specialty computing devices (e.g., cameras and printers), etc. The invention may also be practiced in distributed computing environments where tasks are performed by remote-processing devices that are linked through a communications network, such as network 112 or Internet 114.
With reference to
Computing device 110, network 112, and Internet 114 typically include a variety of computer-readable media or make use of devices that include computer-readable media. By way of example, and not limitation, computer-readable media may comprise Random Access Memory (RAM); Read Only Memory (ROM); Electronically Erasable Programmable Read Only Memory (EEPROM); flash memory or other memory technologies; CD-ROM, digital versatile disks (DVD) or other optical or holographic media; magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to encode desired information and be accessed by computing device 110, network 112, and/or Internet 114.
Memory 116 includes computer-storage media in the form of volatile and/or nonvolatile memory. The memory may be removable, nonremovable, or a combination thereof. Exemplary hardware devices include solid-state memory, hard drives, optical-disc drives, etc. Computing device 110 includes one or more processors 118 that read data from various entities such as memory 116 or I/O components 124. As discussed in more detail below, memory 116 may store software that is executed by processor 118. The software may include a number of components that are stored in memory 116 and executed by processor 118. In the alternative, these components may be stored remotely and executed locally by accessing processor 118 and memory 116.
Presentation component(s) 120 present data indications to a user or other device. Exemplary presentation components include a display device, speaker, printing component, vibrating component, etc. I/O ports 122 allow computing device 110 to be logically coupled to other devices including I/O components 124, some of which may be built in. Illustrative components include a microphone, joystick, game pad, satellite dish, scanner, printer, wireless device, etc. In addition, I/O ports 122 may include network ports 126 that allow computing devices 110 to communication with one another via network 112 and/or Internet 114.
Turning now to
Computing device 110 includes software 220 that may be stored in memory 116 and executed by processor 118. Software 220 may include multiple feature sets and/or policies. For instance, software 220 may include a first feature set 224 and a second feature set 226. First feature set 224 may enable software 220 to operate with full functionality, where second feature set 226 may reduce the functionality of software 220. For example, software 220 may include a word processing or spreadsheet application. In this scenario, first feature set 224 might provide full functionality to a user. That is, the user could create new files, edit existing files, save files, etc. Likewise, second feature set 226 could reduce the functionality of software 220. For instance, second feature set 226 may only allow the user to view a file and not save any changes made to the file. Alternatively, second feature set 226 may enhance the functionality of software 220 by providing additional functionality not enabled by first feature set 224. In other words, embodiments of the present invention provide for an altered functionality mode which is not limited to reducing the functionality of software 220, and may actually provide additional functionality. In addition, second feature set 226 may be enabled for a “trial period” to encourage the user to obtain a license to gain access to this feature set. Finally, although two feature sets or policies are illustrated in
In addition to software 220, computing device 110 may include a connection history application or applications 228 that provide a history of past Internet connections or network connections. Such application may include a web browser 230, system cache 232, and event log 234. Web browser 230 may include a data store 236 that tracks and records history of websites visited by computing device 110. For example, Internet Explorer® and Firefox® include a browser history that provides a log of websites visited by a user of computing device 110. In sum, connection history application 228 may include any application containing a data store, folder, directory, or repository that provides a history or log of past Internet connectivity, and is not limited to the applications illustrated.
Besides web browsers, computing device 110 may include other network-enabled applications that directly or indirectly record connection history. For example, computing device 110 may also include a cache 232 that may be used for detecting evidence of Internet connectivity. Specifically, cache 232 may include an error cache that is only emptied when software 220 connects to the software publisher. For example, an application debugger may include information that provides evidence of Internet connectivity for a given application. It should be noted that even though cache 232 is illustrated within computing device 110, it is not so limited and may also be external to computing system 110. In addition, connection history applications 228 may include an event log 234 that may also be stored in memory 116 of computing device 110. Event log 234 may include any other sources of information stored by computing device 110 that record connection history.
As will be discussed in more detail below, the information collected from connection history applications provides one possible source for detecting an Internet connection. However, it may be desirable to evaluate or authenticate the trustworthiness of this data because often these data sources can be easily modified. For instance, it is not uncommon for a user to delete the browser history in a web browser. Thus, embodiments of the present invention may include both a forensic data component 244 that authenticates the data and/or an authentication component 214 that may not only authenticate the data obtained from application 228, but may also authenticate data obtained from other components and/or sources. One skilled in the art would appreciate that data stored on a computer may be a potential target for a malicious attack and may need to be verified or authenticated before being utilized. One way around this problem is to store this data in a secure data store, as will be discussed in more detail below. Ultimately, however, it is up to the publisher to decide what provides a reasonable level of protection for the given software.
As illustrated in
Computing device 110 may also include a secure data store 240 which may provide authenticated and encrypted data. For example, Secure Sockets Layer (SSL) is a Web protocol for establishing authenticated and encrypted sessions between a server and a client. Thus, an SSL connection is a trustworthy source of evidence of a possible Internet connection, with the caveat that the record of the SSL connection is stored securely. In other words, if an SSL log is not protected, then it can be easily deleted or modified. It must ne noted that SSL protocol is only one example of authentication-capable protocol and other protocols may be implemented (e.g., Transport Layer Security (TLS)). Thus, secure data store 240 provides an application a location for securely storing data from various sources and protocols that may be used to detect an Internet connection.
Finally, computing device 110 may include other components that may be implemented by embodiments of the present invention to detect Internet connectivity. These other components are illustrated by numeral 242. Again,
To detect an Internet connection, embodiments of the present invention may include detection component 212. Detection component 212 may be included in computing device 110 or may be external to computing device 110. In general, detection component 212 may include three main components. These components include forensic data component 244, active testing component 246, and real-time component 248. Each of these components focuses on different aspects or mechanisms for detecting an Internet connection. Forensic data component 244 focuses on data indicating a prior connection to the Internet. Active testing component 246 focuses on attempting to actively establish a connection with an Internet resource to indicate a capability of connecting to the Internet. Real-time component 248 focuses on reporting in real-time when an Internet connection is established.
As illustrated, each of these components may access or interact with computing device 110 and/or elements of computing device 110. Indeed, these components may be included as part of software 220 and stored in memory 116 of computing device 110. Further, each of these components may access and leverage the data stored on computing device 110 to determine if the device has connected to the Internet or is capable of connecting to the Internet. Each of these components will be discussed in more detail below. It should be noted, however, that embodiments of the present invention may include each component individually, employ a combination of different components, or employ all of the components as a collective set. Furthermore, other components 242 may be implemented with the ones disclosed to aid in the detection of an Internet connection. Finally, each of the components described or contemplated may be run in the background and performed without user intervention.
Forensic data component 244 is the first illustrated component that may be included as part of detection component 212. As discussed, forensic data component 244 focuses on analyzing the connection history of computing device 110 to the Internet to detect a previously established connection with the Internet. Specifically, forensic data component 244 may search or query connection history applications 228 for data indicating a prior connection. For example, forensic data component 244 may access data store 236 of web browser 230 and analyze the browser history stored by the application. Likewise, forensic data component 244 may search or query cache 232 of computing device 110 for traces of Internet connectivity. Similarly, forensic data component 244 may review event log 234 to determine if computing device 110 has connected to the Internet. Generally speaking, forensic data component is looking backwards in time and attempting to locate data indicating a previous connection to the Internet.
Active testing component 246 is the second illustrated component that may be included in detection component 212. As discussed, active testing component 246 focuses on attempting to actively establish a connection with an Internet resource. Active testing component 246 may attempt to establish this connection in a number of different ways. For example, active testing component 246 may send a DNS query 250 to resolve known Internet facing hosts stored on network 238 or computing device 110. One of ordinary skill in the art would appreciate that host names may be stored in a name server associated with network 238 or DNS resolver of computing device 110. If there is a record for an internet-facing host it may indicate a connection to the Internet. This is especially helpful if a DNS record is returned for a site that a user would not normally visit. For example, some DNS records may not be commonly accessed, but instead are published or related to a specific software application and accessed in the background. In other words, an application on computing device 110 may access a domain for updates or to obtain licensing data. This previous access may be evidenced by DNS query 250 even though the computing device is not currently connected to the Internet.
Active testing component 246 may also attempt to contact the publisher server 252 via network port 126 and network 238. This may be similar to a “call home” function used to prevent piracy in other software applications. It should be noted, however, that one difference is that the “call home” is not a prerequisite for enabling software 220. Instead it is used as one way of detecting an Internet connection. Indeed, an advantage of embodiments of the present invention is that they enable software to operate in an “air gap” or 100% disconnected environments which traditionally was not possible without disabling piracy protection features. That is, embodiments of the present invention provide piracy protection without limiting the operating environment. Moreover, the call home functionality of other software stored on computing device 110 and network 238 may be used to determine a previous Internet connection without requiring a call home functionality in software 220. Finally, active testing component 246 may attempt to connect to a URL 254 or ping a known IP address located external to network 238. A return of data or an establishment of a connection may indicate that computing device 110 is capable of connecting to the Internet.
Real-time component 248 is the third illustrated component that may be included in detection component 212. As discussed, real-time component 248 focuses on reporting in real-time when computing device 110 establishes a connection to the Internet. One way that real-time component 248 may report an Internet connection is via licensing component 218 that may contact a licensing server 219 via network 238. Another way real-time component 248 may report Internet connectivity is by monitoring one or more applications for Internet connectivity and storing a record of an Internet connection in a secure data store 240. For example, real-time component 248 may store a secure record of an SSL connection in secure data store 240. Again, secure data store 240 provides an extra level of security for the data utilized by detection component 212, but it is not an absolute requirement for embodiments of the present invention.
The data obtained by detection component 212 may be authenticated or verified via authentication component 214. As discussed, this may be important because the detection data may not be securely stored by applications running on computing device 110 and may be a prime target for a malicious attack. For example, data stored in secured data store 240 would generally be more trustworthy than data stored in data store 236 of web browser 230. However, that is not to imply that this is always the case or that embodiments of the present invention are limited to this hierarchy of trustworthiness. Moreover, data obtained by one component of detection component 212 may be more trustworthy than data obtained by another component in one computing environment, yet the opposite may be true in another computing environment. Thus, authentication component 214 provides a way to verify or authenticate the data for different environments and different components. For instance, any application, utility, service, or data source that is external to software 220 may be monitored for a historical or real-time Internet connection. Thus, authentication component 214 may be used to authenticate data obtained from a plurality of sources. In addition, data obtained by detection component 212 may be independently authenticated and bypass authentication component 214.
If an Internet connection is detected by detection component 212, then disabling component 216 may be engaged to alter functionality of software 220. For instance, disabling component 216 may be used to disable a first set of policies or feature sets 224. In addition, disabling component 216 may be used to enable a second set of policies or feature sets 226 when first feature set 224 is disabled. As discussed above, the second set of software functionality 226 may include a reduced set of software functionality or an increased set of software functionality. Again, disabling component 216 is illustrated as separate from computing device 110 and software 220, but this is for illustration purposes only. Indeed, disabling components may be included within computing device 110 as a component or module of software 220. Likewise, each component may be stored remotely from computing device 110, or some of the components may be stored locally on computing device 110, while others may be stored remotely from computing device 110.
Once software 220 is operating with an altered functionality (e.g., reduced, increased, or enhanced functionality) a user may be required to obtain licensing data to re-enable the first set of software functionality. This licensing data may be obtained via licensing component 218 that may be either stored locally or remotely from computing device 110. Alternatively, licensing data may be obtained through another source (e.g., via telephone) and installed on computing device 110 via licensing component 218 and/or disabling component 216. In addition, software 220 may operate with a reduced functionality for a limited period of time before it is completely disabled. In other words, once an Internet connection is detected, the user may be given a grace period before the first set of software functionality is altered or changed. Moreover, embodiments of the present invention are not limited only to licensing data and may require the user to comply with a set of rules before re-enabling the first set of software functionality. For example, the software publisher may require a hardware key, a new piece of hardware, a reboot, etc., to re-enable the first set of software functionality. Thus, receiving licensing data may be just one facet of complying with a set of rules established by a software publisher before re-enabling the first set of software functionality.
Turning now to
In addition, network 312 may include a management or administration system 320 to manage the network. Computing devices 318 may be in communication with a management system 320 via network 312. In addition, computing device 322 may be able to connect to Internet 314 without accessing network 312 (e.g., satellite network). This exposes another path for attacks that may occur if computing device 322 is connected to network 312. Thus, one aspect of management system 320 is to monitor against malicious attacks from sources outside of network 312.
In contrast, disconnected network 316 limits connections to computing devices 326 and not to any external computing devices. For example, computing devices 326 would not be able to communicate with computing device 328 because computing device 328 is not connected to network 316. Likewise, computing devices 326 would not be able to communicate with computing devices 318 or computing devices 324 located on Internet 314 because these devices are not connected to network 316. There may be a number of reasons or scenarios a publisher would like to provide software to these disconnected networks 316. For example, it may be desirable to offer full software functionality at a discounted rate in countries where Internet connectivity may not yet be available. The concern being that someone might decide to pirate the software and distribute in other locations around the world (i.e., copying and distributing it over the Internet). As discussed, one way to avoid this in the past was to require the software to “call home” as soon as it was installed. The problem with this approach is that it is not possible to call home in a disconnected environment. Thus, embodiments of the present invention maximize potential operating environments while still protecting against piracy. This is because the software functionality may be fully enabled in environments that do not have Internet connectivity but disabled in environments that do have Internet connectivity. Again, detection of an Internet connection and disablement of software functionality may be provided without any user intervention.
Another example of where air gap networks might be desirable is where computing devices 326 include highly confidential information, such as for a government agency or R&D facility. In these facilities, disconnected network 316 provides an extra level of protection from a malicious attack. However, similar to the disconnected environment discussed above, traditional “call home” anti-piracy measures prevented the software from operating in these disconnected environments. As before, software publishers incurred great risk if they disabled their piracy prevention features. For example, computing device 326 could be moved from disconnected network 316 to network 312 creating a risk that the software may be freely distributed to other devices on network 312. Thus, embodiments of the present invention not only detect when the computing device is connected to the Internet but may also monitor when the device is operating in a network environment that is connected to the Internet. For example, embodiments of the present invention may identify at least one other computer in the network environment that is connected to the Internet and enable a different set of features accordingly. In this scenario, any device that is connected to network 312 may be required to obtain licensing data in order to re-enable software functionality.
Embodiments of the present invention also offer an additional advantage of providing an alert when a disconnected network has been breached. For instance, management system 320 may be alerted when the software operating on computing device 326 is disabled due to the detection of an Internet connection. This would indicate that at some point one of the devices 326 located on disconnected network 316 connected to the Internet. For instance, if a user of a computing device 326 is connecting the device to the Internet to download or upload data, then embodiments of the present invention might detect this connection. This example also illustrates a scenario where authentication component 214 may be important. Specifically, if a user is able to give the appearance that device 326 has connected to the Internet then they could potentially disable software located on device 326 even though the device has never actually connected to the Internet. It is in these situations, that authentication component 214 may be of particular importance.
Turning now to
At a step 420, the data obtained during the detection step may be authenticated. One way this may be implemented is via authentication component 214. Again authentication may be more important for some environments than it is for others. Thus, embodiments of the present invention contemplate different levels of authentication, and some contemplate no authentication at all. At a step 422, the data is processed and it is determined if the computing device and/or network is connected to the Internet or is capable of connecting to the Internet. If Internet connectivity was not detected, then the method returns to step 410 and repeats the detection process.
At a step 426, a first set of software functionality is disabled when an Internet connection is detected. As discussed, one way this may be implemented is via disabling component 216. At a step 428, a second set of software functionality may be enabled when the first set of functionality is disabled. The second set of software functionality may require production activation, and the related license constraints may be completely independent from the first set. As discussed, one way this may be implemented is via disabling component 216. At a step 430, a user is required to obtain licensing data to re-enable the first feature set. This may be implemented by either disabling component 216 or licensing component 218. Once the licensing data is obtained the first set of software functionality may be re-enabled at a step 432.
Many different arrangements of the various components depicted, as well as components not shown, are possible without departing from the scope of the claims below. Embodiments of our technology have been described with the intent to be illustrative rather than restrictive. Alternative embodiments will become apparent to readers of this disclosure after and because of reading it. Alternative means of implementing the aforementioned can be completed without departing from the scope of the claims below. Certain features and subcombinations are of utility and may be employed without reference to other features and subcombinations and are contemplated within the scope of the claims.
Patel, Kalpesh, Smith, Aaron J., Soulami, Tarik, Cheng, Paul, Sliouniaev, Valentin, Kao, Chih-Pin Benjamin, Eizenhoefer, Richard S.
Patent | Priority | Assignee | Title |
9900229, | Jan 29 2016 | Microsoft Technology Licensing, LLC | Network-connectivity detection |
Patent | Priority | Assignee | Title |
4685055, | Jul 01 1985 | CORBAN INTERNATIONAL, LTD A CORP OF ANGUILLA | Method and system for controlling use of protected software |
5883955, | Jun 07 1995 | DIGITAL RIVER, INC | On-line try before you buy software distribution system |
5903647, | Jun 07 1995 | DIGITAL RIVER, INC | Self-launching encrypted digital information distribution system |
5907617, | Jun 07 1995 | Digital River, Inc. | Try before you buy software distribution and marketing system |
5940504, | Jul 01 1991 | INFOLOGIC SOFTWARE, INC ; Intertrust Technologies Corporation | Licensing management system and method in which datagrams including an address of a licensee and indicative of use of a licensed product are sent from the licensee's site |
6243468, | Apr 29 1998 | Microsoft Corporation | Software anti-piracy system that adapts to hardware upgrades |
6606657, | Jun 22 1999 | Mavenir LTD | System and method for processing and presenting internet usage information |
6720983, | Jan 05 2000 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Digital feedback display panel for communicating computer status information |
7089425, | Mar 18 2003 | CI4 Technologies, Inc.; CI 4 TECHNOLOGIES INC | Remote access authorization of local content |
7353205, | Dec 15 1992 | SL Patent Holdings LLC | Method for causing a digital product to revert to a demo mode |
7353207, | Dec 15 1992 | SL Patent Holdings LLC | Method of altering a software product in response to predetermined events |
7363318, | Jul 21 2000 | Wind River Systems, Inc.; WIND RIVER SYSTEMS, INC | Method and apparatus for management of an automated license installation |
7472286, | Aug 29 2003 | Microsoft Technology Licensing, LLC | Selectively authorizing software functionality after installation of the software |
7716476, | Aug 29 2003 | Microsoft Technology Licensing, LLC | Selectively authorizing software functionality after installation of the software |
7849511, | Feb 16 2007 | Microsoft Technology Licensing, LLC | Determining authorized use of a software application |
7861306, | Jun 27 2000 | Microsoft Technology Licensing, LLC | Method and system for limiting the use of user-specific software features |
20010044782, | |||
20020120726, | |||
20040143746, | |||
20040215969, | |||
20060059100, | |||
20070143222, | |||
20070150294, | |||
20070157195, | |||
20070177499, | |||
20090049442, | |||
20090083710, | |||
20090253414, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Jun 12 2009 | SMITH, AARON J | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 022833 | /0053 | |
Jun 12 2009 | PATEL, KALPESH | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 022833 | /0053 | |
Jun 12 2009 | SOULAMI, TARIK | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 022833 | /0053 | |
Jun 12 2009 | SLIOUNIAEV, VALENTIN | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 022833 | /0053 | |
Jun 12 2009 | CHENG, PAUL | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 022833 | /0053 | |
Jun 12 2009 | EIZENHOEFER, RICHARD S | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 022833 | /0053 | |
Jun 15 2009 | KAO, CHIH-PIN BENJAMIN | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 022833 | /0053 | |
Jun 16 2009 | Microsoft Corporation | (assignment on the face of the patent) | / | |||
Oct 14 2014 | Microsoft Corporation | Microsoft Technology Licensing, LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 034564 | /0001 |
Date | Maintenance Fee Events |
May 31 2013 | ASPN: Payor Number Assigned. |
Oct 13 2016 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Sep 30 2020 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Dec 16 2024 | REM: Maintenance Fee Reminder Mailed. |
Date | Maintenance Schedule |
Apr 30 2016 | 4 years fee payment window open |
Oct 30 2016 | 6 months grace period start (w surcharge) |
Apr 30 2017 | patent expiry (for year 4) |
Apr 30 2019 | 2 years to revive unintentionally abandoned end. (for year 4) |
Apr 30 2020 | 8 years fee payment window open |
Oct 30 2020 | 6 months grace period start (w surcharge) |
Apr 30 2021 | patent expiry (for year 8) |
Apr 30 2023 | 2 years to revive unintentionally abandoned end. (for year 8) |
Apr 30 2024 | 12 years fee payment window open |
Oct 30 2024 | 6 months grace period start (w surcharge) |
Apr 30 2025 | patent expiry (for year 12) |
Apr 30 2027 | 2 years to revive unintentionally abandoned end. (for year 12) |