This invention relates generally to proprietary components and more particularly to facilitating control over the use of a proprietary component in an open-platform device.
Various open-platform devices are known in the art. Such devices typically operate using an operating system (such as a Windows family operating system) that will, in turn, permit compatible support of a variety of proprietary components (wherein the proprietary components can be hardware-based, software-based (including but not limited to software components in the form of a dynamic link library, a static library, or an executable application, to name a few), or a combination thereof). As used herein, “proprietary” will be understood to refer to some degree of legal and/or technical control wherein at least some aspect of the corresponding component (such as the location, point of installation, manner of use, quantity of use, or the like) is subject to such control.
To illustrate, a given cellular telephone may comprise a microprocessor that operates a given operating system which accepts and supports the operation of proprietary components such as proprietary third party media engines (or even engagement with a supplemental microprocessor). So configured, such a media engine can be installed in (or engaged with) the microprocessor and the cellular telephone will thereafter have access to the use of that media engine during its operations.
Unless some practical degree of control can be established with respect to the installation and/or use of that media engine component, however, the proprietary nature of that component may be effectively lost. For example, the intent of the third party who invests the resources to develop, market, and support that media engine component may be effectively foiled if that one copy can be installed on a succession of open-platform devices beyond an initial expected and authorized installation.
The above needs are at least partially met through provision of the proprietary component for use in an open-platform device and corresponding method described in the following detailed description, particularly when studied in conjunction with the drawings, wherein:
Skilled artisans will appreciate that elements in the figures are illustrated for simplicity and clarity and have not necessarily been drawn to scale. For example, the dimensions and/or relative positioning of some of the elements in the figures may be exaggerated relative to other elements to help to improve understanding of various embodiments of the present invention. Also, common but well-understood elements that are useful or necessary in a commercially feasible embodiment are often not depicted in order to facilitate a less obstructed view of these various embodiments of the present invention. It will also be understood that the terms and expressions used herein have the ordinary meaning as is accorded to such terms and expressions with respect to their corresponding respective areas of inquiry and study except where specific meanings have otherwise been set forth herein.
Generally speaking, pursuant to these various embodiments, a proprietary component as is installed in an open-platform device will receive from that open-platform device at least one item of information that is substantially unique to that open-platform device and will store that information. Upon then detecting requested usage of the proprietary component, the proprietary component obtains verification information (typically from the open-platform device itself) and compares that verification information against the previously stored information. When a match occurs, the proprietary component can facilitate the requested use. When the comparison fails to correspond to an expected result, however, at least some usage (and possibly all usage) of the proprietary component can be prohibited.
Depending upon the embodiment, the verification information can be automatically provided by the open-platform device or can be provided in response to a specific inquiry from the proprietary component. Depending upon the needs of a given setting, the above-described prohibition can be temporary or can be essentially permanent.
Pursuant to one approach, the proprietary component can also receive (and/or exchange) similar kinds of verification information with other proprietary components as may also have been installed in the open-platform device. In such a case, requested usage of the proprietary component can be further conditioned upon similarly verifying the presence of such additional proprietary components through comparison of later-received verification information with previously stored identifying information.
So configured, the proprietary component, once installed, will prohibit at least some degree of operability should it be removed and reinstalled on another open-platform device. These teachings are useful with software-only components but are particularly useful when deployed in conjunction with components that are at least partially hardware-based (such as architectures that make use of two or more processors, where one processor is an open-platform device and at least one of the additional processors comprises a proprietary component that interacts with the open-platform processor). This, in turn, permits the provider of the proprietary component to retain at least some degree of control with respect to the applied usage of a given proprietary component. Those skilled in the art will appreciate that such teachings can be effected in a relatively transparent manner and with little or no interaction required on the part of an end-user.
These and other benefits may become clearer upon making a thorough review and study of the following detailed description. Referring now to the drawings, and in particular to
This unique information can assume any of a wide variety of forms, including but not limited to a unique (or substantially unique) hardware identifier as may correspond in some predetermined way to the open-platform device. Such a hardware identifier might comprise, for example, a platform serial number as was assigned during manufacture of the device, or another unique identifier as may have been assigned by the manufacturer, a third party (such as a distributor or system operator), a standards body, a law enforcement agency, or the like.
As another example, the unique identifier can comprise, for example, a random sequence number as may have been developed, obtained, or otherwise provided to the open-platform device. Such a random sequence number can be developed in any of a wide variety of known ways. Furthermore, such a random sequence number could be uniquely generated for each proprietary component that a given open-platform device might encounter on an as-needed basis such that each such proprietary component would be provided with a different unique identifier by the open-platform device. In the alternative, if desired, a single random sequence number could be generated by the open-platform device (or otherwise provided thereto) and used with all proprietary components as might become associated with the open-platform device.
Such examples are to be understood as being illustrative of a unique identifier and are not to be taken as an exhaustive listing. Instead, it will be well appreciated that these teachings are compatible for use with any of a wide variety of presently known (as well, in all probability, with various hereafter-developed) unique identifiers as may be available and/or preferred in a given application setting.
This receipt 101 of unique information can be the result of any of a variety of instigating conditions. For example, such information may be automatically initially provided upon first installing the proprietary component. As another example, such information may be provided by the open-platform device only in response to a specific request tendered by the proprietary component for such information. Other possibilities also no doubt exist and it will be understood that these teachings are not limited in this regard.
When the proprietary component then subsequently detects 13 requested usage of the proprietary component (by, for example, the open-platform device itself and/or another proprietary component), the proprietary component can then optionally request 104 verification information and then, regardless, receive 105 verification information (in this case, preferably from the open-platform device that seeks to make use of the proprietary component). In a case where the proprietary component does not itself request such verification information, it may be desirable to have the open-platform device (or a suitable proxy) automatically provide such information concurrent with or at least in association with the taking of an action that will likely be interpreted by the proprietary component as a request for usage of the proprietary component.
Upon receiving such verification information, the proprietary component can then compare 106 that verification information with respect to the stored information referred to earlier. The proprietary component can then determine 107 whether that comparison corresponds to an expected result (for example, whether the verification information matches previously supplied identification information for the open-platform device). When true, this process 100 can then effect facilitation 108 of the requested use of the proprietary component. When false, however, this process 100 can prohibit 109 at least some usage of the proprietary component.
This prohibition of usage can be partial or complete. When partial, the prohibition can be with respect to certain features or capabilities of the proprietary component and/or with respect to a permitted duration of usage. This prohibition can also be either temporary or permanent. When temporary, and depending upon the needs of a given setting, the prohibition may persist for only some predetermined period of time or may require intervention on the part of an authorized person (for example, an authorized technician who can effectively cause the proprietary component to reset itself and/or to other permit present usage via entry of an appropriate authorization code or the like).
So configured, those skilled in the art will recognize that such a proprietary component will likely not operate to full capacity when removed from a first installed setting and then re-installed in a new and different setting, as the verification information provided by the second open-platform device will not likely match the unique identifying information provided by the initial open-platform device. This, in turn, can greatly support controlling the subsequent distribution and use of the proprietary component itself.
In the embodiment described above, the proprietary component interacts with the open-platform device itself to establish its proper operating environment and to thereafter determine, at least from time to time, whether the proprietary component continues to remain within an authorized operational setting. As mentioned earlier, however, a given open-platform device, by its very nature, may also couple, now or in the future, to other proprietary components. These teachings are employable to further leverage such circumstances.
In particular, and referring now to
So configured, and referring again to
So configured, the operational security offered a given proprietary component is further enhanced. In particular, the greater the number of additional proprietary components as may be operably engaged with a given open-platform device, effectively the greater the protection offered by these teachings. In particular, when each such proprietary component interacts with every other proprietary component in this manner, removal of any of the proprietary components will not only render the removed proprietary component operationally limited but will also render the remaining proprietary components similarly limited as well.
To more fully participate in such a distributed fashion, and referring again to
These teachings can be enabled in various ways. Pursuant to a not-untypical approach, and referring now to
The latter responds to the comparison output of the comparator 303 to effect the above-described teachings. In particular, this controller 304 serves to render the proprietary component 300 at least partially inoperable when the proprietary component is used with an open-platform device other than a particular open-platform device.
As described above, it is also possible to so condition the operability of the proprietary component 300 based upon the presence of other proprietary components. To support such an approach, the proprietary component 300 can also optionally comprise a memory 305 that serves to store identifying information as corresponds to such other proprietary component ( or components), a buffer 306 to store verification information as corresponds to such other proprietary component(s), and a comparator 307 that operably couples to such memory 305 and buffer 306 in order to compare their respective contents and provide a comparison result to a trigger input of the denial-of-operability controller 304. So configured, the proprietary component 300 can be rendered at least partially inoperable when used in conjunction with an open-platform device that presently lacks one or more other proprietary components that this proprietary component otherwise expects to be present.
Those skilled in the art will recognize that the described embodiment can be configured and realized in various ways. For example, a single memory platform can serve as the various memories and buffers depicted in
So configured, it will be appreciated that these teachings yield a proprietary component having an ability to store both information that tends to uniquely correspond to a particular open-platform device and other information that tends to uniquely correspond to at least one other proprietary component as also interacts with that particular open-platform device. Such a proprietary component then has the ability to condition its own subsequent operability upon receipt of subsequent information from both the particular open-platform device and the at least one other proprietary component, which subsequent information corresponds (or not) in an expected way with the stored information. This can include, as desired, the ability to request, on a repeated basis, such subsequent information and to compare, on a repeated basis, this subsequent information against the stored information.
These teachings are deployable in various settings. As noted above, for example, these approaches will work well in a dual-processor environment. These teachings can also be used, however, as between a proprietary component and a remotely located server and/or application to achieve the same benefits.
Those skilled in the art will recognize that a wide variety of modifications, alterations, and combinations can be made with respect to the above described embodiments without departing from the spirit and scope of the invention, and that such modifications, alterations, and combinations are to be viewed as being within the ambit of the inventive concept. For example, upon determining that later supplied verification information from an open-platform device does not yield the expected match, the proprietary component, prior to effecting its own disablement, can first take steps to partially or fully disable other proprietary components as may also be operably engaged with the present open-platform device. This approach would aid in providing protection for proprietary components that otherwise lack a native ability to implement these teachings or that are not presently being otherwise tasked by the open-platform device. As another example, such a proprietary component could also be provided with an ability to provide an alert via an available communication bearer to a predetermined server regarding invocation of operability prohibitions as per these teachings. Such an alert could be coupled with such other useful information as may be available to the proprietary component, including but not limited to geographic location information, current identifying and/or addressing information for the open-platform device, and so forth.