Advertisers, tool suppliers, search engines, etc. are willing to compensate users for viewing ads or using tool bars or menu bars. Verification of actual use or display of the underwritten content can be difficult and fraud prone. Simply sending data to an electronic device does not guarantee consumption. Some techniques require sending data back to a server to verify consumption of the underwritten content. This can be difficult in developing areas where network access may be limited and frustrating to users who want an immediate and measurable result from viewing or using underwritten content.
A security module in an electronic device may use direct access to display memory to verify that underwritten content is being displayed. To accomplish this, an ad server or intermediate processing point may select all or a portion of displayable data and take a first measurement of the displayable data. In one embodiment, the measurement may be a hash of the ad or portion. The ad and the measurement, including metadata about the measurement process, may be downloaded to an electronic device, such as a pay-per-use computer. When the ad data is reported to be displayed, the security module may read the display memory and copy the ad or portion to the security module where the original measurement may be repeated. If the first and second measurements match, a value packet representing the value associated with display of the displayable data may be immediately added to a local value account.
Although the following text sets forth a detailed description of numerous different embodiments, it should be understood that the legal scope of the description is defined by the words of the claims set forth at the end of this disclosure. The detailed description is to be construed as exemplary only and does not describe every possible embodiment since describing every possible embodiment would be impractical, if not impossible. Numerous alternative embodiments could be implemented, using either current technology or technology developed after the filing date of this patent, which would still fall within the scope of the claims.
It should also be understood that, unless a term is expressly defined in this patent using the sentence “As used herein, the term ‘——————’ is hereby defined to mean . . . ” or a similar sentence, there is no intent to limit the meaning of that term, either expressly or by implication, beyond its plain or ordinary meaning, and such term should not be interpreted to be limited in scope based on any statement made in any section of this patent (other than the language of the claims). To the extent that any term recited in the claims at the end of this patent is referred to in this patent in a manner consistent with a single meaning, that is done for sake of clarity only so as to not confuse the reader, and it is not intended that such claim term by limited, by implication or otherwise, to that single meaning. Finally, unless a claim element is defined by reciting the word “means” and a function without the recital of any structure, it is not intended that the scope of any claim element be interpreted based on the application of 35 U.S.C. §112, sixth paragraph.
Much of the inventive functionality and many of the inventive principles are best implemented with or in software programs or instructions and integrated circuits (ICs) such as application specific ICs. It is expected that one of ordinary skill, notwithstanding possibly significant effort and many design choices motivated by, for example, available time, current technology, and economic considerations, when guided by the concepts and principles disclosed herein will be readily capable of generating such software instructions and programs and ICs with minimal experimentation. Therefore, in the interest of brevity and minimization of any risk of obscuring the principles and concepts in accordance to the present invention, further discussion of such software and ICs, if any, will be limited to the essentials with respect to the principles and concepts of the preferred embodiments.
An advertising server 12 may serve an advertisement 20 to an intermediate service 14 using a communication interface inherent to the advertising server 12. Alternatively, the advertising service 12 and the intermediate service 14 may be the same entity and may even be hosted on the same physical device, such as a server. When separate, the advertising server 12 may include a routing function that directs the advertisement 20 to the intermediary service 14 even though the ultimate target is an electronic device 18. The intermediate service 14 may extract and process data from the ad 20 and forward the ad 20 through a network 16 to the electronic device 18. The electronic device 18 may display a graphical component of the ad 20 on a display 19. Any number of display types may be supported. For example, if the electronic device 18 is a computer, graphical output may be to a CRT or LCD monitor. When the electronic device 18 is a cellular telephone, personal organizer, etc. graphical output may be to a display integral with the electronic device 18.
Looking at the major components in more detail, the intermediate server 14 may include an advertisement processor 24 that takes the advertisement 20 and identifies a measured portion 22 that may be all or a portion of the advertisement 20. The measured portion 22 may be processed into a result, such as a hash, or may be kept in tact. In some cases, the measured portion 22 may be a particular feature, such as a digital watermark or steganographic information. When the ad 20 is served real time, such as during a browsing session, destination information (not depicted) may be included in the advertisement 20 or a data packet (not depicted) containing the advertisement 20. The measured portion 22, raw or processed, may be sent to a packet generator 26 for incorporation into a packet for distribution to the electronic device 18. If less than the whole advertisement is measured, metadata may be created that indicates what portion of the advertisement 20 was measured. If a credit is to be applied at the electronic device 18 when the advertisement 20 is displayed, the packet generator may further incorporate information that can be used by the electronic device 18 to update a local value account, for example, a packet used for provisioning.
The packet, when finally constructed, may include a.) the results of the measurement, b.) metadata pointing to the portion of the advertisement 20 measured, and c.) provisioning information related to credits to be added to a local value account upon verification of the display of the ad 20. A cryptographic function 30 may operate on the generated packet to encrypt, sign, or both. A packet service 28 may forward the packet to the electronic device 18 and may be responsible for assuring once and only once delivery of the packet.
The ad 20 may be sent via data path 32, while the packet may be sent over the same connection 32 or a different connection 34, or even in the same transmission. The two are shown separate to indicate that they may be logically separated, with the ad 20 addressed to a browser process on the electronic device 18, while the packet may be addressed to a security module 48 in the electronic device 18.
Within the electronic device 18, a system memory 36 may incorporate memory allocated as display memory 38. This may be the case if a unified memory architecture (UMA) is used. Other architectures may have physically separate memories for the display memory 38, such as, in a video card.
When the ad 20 is being displayed, its binary image 40 and any measured portion 42 will be present in the display memory 38. A security module 48 may incorporate a bus master function 50, capable of accessing and controlling the system bus 46. Using metadata incorporated in the packet, the security module 48 may take control of the system bus 46 for a timed interval to directly read the contents of the display memory 38, or at least the measured portion 42. In one embodiment, the system bus is a peripheral component interconnect (PCI) bus.
The security module 48 may also include a stored value function 52. The stored value function 52 may store value used to pay for usage of the computer, pay for application usage, network connection time, etc. In some embodiments, the stored value may be used similar to currency or points for purchase of goods or services.
The cryptographic function 54 may be used to decrypt, authenticate a signature, or both. For example, when a packet related to an advertisement 20 is received, it may be signed or encrypted, to ensure authenticity and integrity since a fraudulent packet could lead to giving improper credit when an advertisement is displayed. The security module is discussed in more detail below with respect to
A side effect of the verification process used to convert the display of sponsored content on the electronic device 18 into local value is that the electronic device 18 becomes bound to the intermediary service 14. That is, only intermediary services, such as service 14, for which the security module 48 has keys will be able to decode and use value packets associated with viewing of the content. Because the keys may be tied to an underwriter, this assures the underwriter that ad-based revenue will flow through an authorized channel and not via a rogue channel.
With reference to
A series of system busses may couple various system components including a high speed system bus 123 between the processor 120, the memory/graphics interface 121 and the I/O interface 122, a front-side bus 124 between the memory/graphics interface 121 and the system memory 130, and an advanced graphics processing (AGP) bus 125 between the memory/graphics interface 121 and the graphics processor 190. The system bus 123 may be any of several types of bus structures including, by way of example, and not limitation, such architectures include Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus and Enhanced ISA (EISA) bus. As system architectures evolve, other bus architectures and chip sets may be used but often generally follow this pattern. For example, companies such as Intel and AMD support the Intel Hub Architecture (IHA) and the Hypertransport architecture, respectively.
The computer 110 typically includes a variety of computer readable media. Computer readable media can be any available media that can be accessed by computer 110 and includes both volatile and nonvolatile media, removable and non-removable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes both volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology. CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can accessed by computer 110. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of the any of the above should also be included within the scope of computer readable media.
The system memory 130 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 131 and random access memory (RAM) 132. The system ROM 131 may contain permanent system data 143, such as identifying and manufacturing information. In some embodiments, a basic input/output system (BIOS) may also be stored in system ROM 131. RAM 132 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processor 120. By way of example, and not limitation,
The I/O interface 122 may couple the system bus 123 with a number of other busses 126, 127 and 128 that couple a variety of internal and external devices to the computer 110. A serial peripheral interface (SPI) bus 126 may connect to a basic input/output system (BIOS) memory 133 containing the basic routines that help to transfer information between elements within computer 110, such as during start-up. In some embodiments, a security module 129 may reside on the SPI bus 126. The security module 129 may manage pay-per-use operation, provide secure storage, or control the boot process by managing if the BIOS 133 is used to boot the computer 110, or an alternate boot memory stored in the security module 129. The security module may also have a PCI bus connection 123 that allows the security module 129 to participate on, or in some cases control, the PCI bus 123. The security module 129 is discussed in more detail below with respect to
A super input/output chip 160 may be used to connect to a number of ‘legacy’ peripherals, such as floppy disk 152, keyboard/mouse 162, and printer 196, as examples. The super I/O chip 160 may be connected to the I/O interface 122 with a low pin count (LPC) bus, in some embodiments. The super I/O chip 160 is widely available in the commercial marketplace.
In one embodiment, bus 128 may be a Peripheral Component Interconnect (PCI) bus, or a variation thereof, may be used to connect higher speed peripherals to the I/O interface 122. A PCI bus may also be known as a Mezzanine bus. Variations of the PCI bus include the Peripheral Component Interconnect-Express (PCI-E) and the Peripheral Component Interconnect-Extended (PCI-X) busses, the former having a serial interface and the latter being a backward compatible parallel interface. In other embodiments, bus 128 may be an advanced technology attachment (ATA) bus, in the form of a serial ATA bus (SATA) or parallel ATA (PATA).
The computer 110 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only,
The drives and their associated computer storage media discussed above and illustrated in
The computer 110 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 180 via a network interface controller (NIC) 170. The remote computer 180 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 110. The NIC 170 may serve as a port for sending and receiving data with host computers, such as an advertising service 12 of
In some embodiments, the network interface may use a modem (not depicted) when a broadband connection is not available or is not used. It will be appreciated that the network connection shown is exemplary and other means of establishing a communication link between the computers may be used.
The security module 300 may also include an internal bus 312 coupled to a cryptographic function 314 and a secure memory 320. The crypto function 314 may also include a random number generator and can provide cryptographic capabilities for use in encryption, decryption, and signature processing. The cryptographic function 314 may support public key infrastructure processing, symmetric key processing, or both. In other embodiments, a hardware cryptographic function 314 may be replaced or supplemented by cryptographic algorithms 324 implementing software cryptographic functions.
The secure memory 320, in addition to cryptographic algorithms 324, may store cryptographic keys 322, program code 326, advertising data 328, and stored value 330. The program code 326 may include both executable instructions for the processor 302 and code, such as an alternate BIOS, for use by the main system processor, such as processor 120 of
The advertising data 328 may be measurement and metadata related to a currently displayed advertisement, such as ad 40 of
The stored value 330 may be currency, minutes, or a subscription expiration date. In any case, the stored value 330 has value to a user/owner of the electronic device 18 in the form of future use of the electronic device 18 or for purchase of goods or services.
At block 406, the ad 20 may be sent to the electronic device 18 and stored in normal program memory, such as in system memory 36. At block 508, in no particular order with execution of block 506, a packet 400 may be prepared including the measurement data 404 corresponding to the ad 20, metadata 406, if needed, a digital signature 408, and a value packet 410 representing value associated with the ad 20. The value packet 410 may be the same as or similar to value packets sent when additional usage time, etc. is purchased for consumption by the electronic device 18. At block 510, the packet 400 may be sent to the electronic device 18. In some embodiments, a series of packets may be sent to the electronic device 18 in anticipation of sending multiple ads or streaming data to the electronic device 18. At block 512, the packet may be received at the electronic device 18 and the measurement data and metadata prepared for processing. Processing may include decrypting and verification of the signature using keys stored in the security module 48. The value packet may be stored for processing following verification of the display of the ad 20.
At block 514, the electronic device 18 may load the ad, shown as ad 40 in
At block 518, after the data is loaded into the security module 48, the measurement taken at block 504 may be repeated, using the metadata to identify the portion 42, if the whole of the ad 40 is loaded and is not required for the measurement. If keys are used to encrypt the ad 40 or portion 42, the key or keys 322 may be loaded from the secure memory 320 of the security module 300. After the second measurement data is generated, at block 520, the second measurement may be compared to the first measurement downloaded in the packet. In other embodiments, another criteria may be used, such as matching a given watermark or steganographic information. When the measurements match at block 520, the ‘yes’ branch may be followed to block 524 where the value packet may be processed and the value added to a locally maintained value account 330.
If, at block 520, the two measurements do not match, the ‘no’ branch may be followed to block 522. At block 522, the value packet will not be processed. Rather, data corresponding to the measurement may be logged to allow analysis for determination of a root cause for the failure.
The use of display data verification, be it streaming media, static advertisements, tool bars, menu bars, etc. allows users and underwriters alike to benefit from verified consumption of sponsored content. The security module allows local verification and immediate, viewable, credit applied to a local value account. High speed access to display memory by the security module limits exposure to fraud while allowing even streaming media to be verified. The technique is applicable with some variation to many different types and architectures of display memory, while complicating attempts to fraud the system because when data is in the display memory, the data is necessarily being displayed.
Although the forgoing text sets forth a detailed description of numerous different embodiments of the invention, it should be understood that the scope of the invention is defined by the words of the claims set forth at the end of this patent. The detailed description is to be construed as exemplary only and does not describe every possibly embodiment of the invention because describing every possible embodiment would be impractical, if not impossible. Numerous alternative embodiments could be implemented, using either current technology or technology developed after the filing date of this patent, which would still fall within the scope of the claims defining the invention.
Thus, many modifications and variations may be made in the techniques and structures described and illustrated herein without departing from the spirit and scope of the present invention. Accordingly, it should be understood that the methods and apparatus described herein are illustrative only and are not limiting upon the scope of the invention.
This application is a continuation-in-part of U.S. patent application Ser. No. 11/092,041, publication number 20060227364, filed Mar. 29, 2005 now U.S. Pat. No. 7,669,056, which is incorporated by reference for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
5023907 | Johnson et al. | Jun 1991 | A |
5150420 | Haraguchi | Sep 1992 | A |
5689565 | Spies et al. | Nov 1997 | A |
5778395 | Whiting et al. | Jul 1998 | A |
5881144 | Havens | Mar 1999 | A |
6269456 | Hodges et al. | Jul 2001 | B1 |
6450407 | Freeman et al. | Sep 2002 | B1 |
6505773 | Palmer et al. | Jan 2003 | B1 |
6510513 | Danieli | Jan 2003 | B1 |
6698020 | Zigmond et al. | Feb 2004 | B1 |
6820063 | England et al. | Nov 2004 | B1 |
6837427 | Overhultz et al. | Jan 2005 | B2 |
6856800 | Henry et al. | Feb 2005 | B1 |
6959384 | Serret-Avila | Oct 2005 | B1 |
6974076 | Siegel | Dec 2005 | B1 |
7013286 | Aggarwal et al. | Mar 2006 | B1 |
7055031 | Platt | May 2006 | B2 |
7124115 | Herzberg et al. | Oct 2006 | B1 |
7174457 | England et al. | Feb 2007 | B1 |
7194092 | England et al. | Mar 2007 | B1 |
7219071 | Gallagher | May 2007 | B2 |
7234638 | Lee et al. | Jun 2007 | B2 |
7269846 | Chennakeshu et al. | Sep 2007 | B2 |
7284124 | Ginsberg | Oct 2007 | B1 |
7302709 | England et al. | Nov 2007 | B2 |
7306143 | Bonneau et al. | Dec 2007 | B2 |
7353267 | Cunningham et al. | Apr 2008 | B1 |
7356682 | Lampson et al. | Apr 2008 | B2 |
7376834 | Edwards et al. | May 2008 | B2 |
7444509 | Nadalin et al. | Oct 2008 | B2 |
7447303 | Moneymaker | Nov 2008 | B1 |
7506053 | Qin | Mar 2009 | B1 |
7568211 | Mai et al. | Jul 2009 | B2 |
7571488 | Oho et al. | Aug 2009 | B2 |
7584149 | Bishop et al. | Sep 2009 | B1 |
7610486 | Herrmann et al. | Oct 2009 | B2 |
7613599 | Bade et al. | Nov 2009 | B2 |
7634661 | England et al. | Dec 2009 | B2 |
20020007314 | Maruyama | Jan 2002 | A1 |
20020046098 | Maggio | Apr 2002 | A1 |
20020107809 | Biddle et al. | Aug 2002 | A1 |
20030014673 | Baum et al. | Jan 2003 | A1 |
20030018969 | Humpleman et al. | Jan 2003 | A1 |
20030033543 | Hubbard et al. | Feb 2003 | A1 |
20030050831 | Klayh | Mar 2003 | A1 |
20030236756 | Humpleman et al. | Dec 2003 | A1 |
20050080801 | Kothandaraman et al. | Apr 2005 | A1 |
20050144073 | Morrisroe et al. | Jun 2005 | A1 |
20050149723 | Watkins et al. | Jul 2005 | A1 |
20050216346 | Kusumoto et al. | Sep 2005 | A1 |
20060026569 | Oerting et al. | Feb 2006 | A1 |
20060041754 | Hind et al. | Feb 2006 | A1 |
20060101155 | Damour et al. | May 2006 | A1 |
20060212350 | Ellis et al. | Sep 2006 | A1 |
20060227364 | Frank et al. | Oct 2006 | A1 |
20060265493 | Brindley et al. | Nov 2006 | A1 |
20060265508 | Angel et al. | Nov 2006 | A1 |
20070106521 | Ho et al. | May 2007 | A1 |
20070214043 | Yasuda | Sep 2007 | A1 |
20080021909 | Black et al. | Jan 2008 | A1 |
20080254883 | Patel et al. | Oct 2008 | A1 |
20080307495 | Holtzman et al. | Dec 2008 | A1 |
Number | Date | Country |
---|---|---|
20060028463 | Mar 2006 | KR |
20060103035 | Sep 2006 | KR |
Number | Date | Country | |
---|---|---|---|
20070244820 A1 | Oct 2007 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11092041 | Mar 2005 | US |
Child | 11765571 | US |