US20140020103A1 - System and Method of Opportunistically Protecting a Computer from Malware - Google Patents
System and Method of Opportunistically Protecting a Computer from Malware Download PDFInfo
- Publication number
- US20140020103A1 US20140020103A1 US14/025,799 US201314025799A US2014020103A1 US 20140020103 A1 US20140020103 A1 US 20140020103A1 US 201314025799 A US201314025799 A US 201314025799A US 2014020103 A1 US2014020103 A1 US 2014020103A1
- Authority
- US
- United States
- Prior art keywords
- computer
- malware
- vulnerability
- software
- patch
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/50—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
- G06F21/55—Detecting local intrusion or implementing counter-measures
- G06F21/56—Computer malware detection or handling, e.g. anti-virus arrangements
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/50—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
- G06F21/55—Detecting local intrusion or implementing counter-measures
- G06F21/56—Computer malware detection or handling, e.g. anti-virus arrangements
- G06F21/568—Computer malware detection or handling, e.g. anti-virus arrangements eliminating virus, restoring damaged files
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/50—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
- G06F21/57—Certifying or maintaining trusted computer platforms, e.g. secure boots or power-downs, version controls, system software checks, secure updates or assessing vulnerabilities
- G06F21/577—Assessing vulnerabilities and evaluating computer system security
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/14—Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic
- H04L63/1408—Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic by monitoring network traffic
- H04L63/1416—Event detection, e.g. attack signature detection
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2221/00—Indexing scheme relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F2221/21—Indexing scheme relating to G06F21/00 and subgroups addressing additional information or applications relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F2221/2115—Third party
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/14—Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic
- H04L63/1433—Vulnerability analysis
Definitions
- the present invention relates to computers and, more particularly, to opportunistically protecting a computer from malware.
- FIG. 1 is a pictorial diagram illustrating an exemplary networking environment 100 over which a computer malware is commonly distributed.
- the typical exemplary networking environment 100 includes a plurality of computers 102 - 108 all inter-connected via a communication network 110 such as an intranet or via a larger communication network including the global TCP/IP network commonly referred to as the Internet.
- a malicious party on a computer connected to the network 110 such as computer 102 , develops a computer malware 112 and releases it on the network.
- the released computer malware 112 is received by and infects one or more computers, such as computer 104 , as indicated by arrow 114 .
- malware 112 may be directed to any one of the computers 104 - 108 as a result of a request initiated by the computer 102 .
- a computer malware 112 can “grow” at an exponential rate and quickly disrupt communications between organizations and people.
- a new malware When a new malware is identified as spreading on a communication network such as the Internet, different software providers initiate a process for handling the malware. More specifically, typically at least two software providers create software updates when new malware is identified.
- One software provider is an antivirus software provider that creates a software update designed to identify the new malware and remove the malware from a computer.
- antivirus software a traditional defense against computer malware, and particularly computer viruses and worms, is antivirus software which typically scans data that is transmitted to a computer, searching for identifiable patterns, referred to as signatures, which are associated with known malware. If a malware signature is identified, the antivirus software takes appropriate action, such as deleting the malware/infected file or removing the malware from an infected file.
- Another software provider that typically creates software updates when a new malware is identified is an operating system provider. While most malware released today are based on known vulnerabilities, occasionally a computer malware is released that takes advantage of a previously unknown vulnerability. In this instance, the operating system provider creates a software update, commonly known as a “patch,” that is designed to close the vulnerability exploited by the new malware. By installing a patch designed to close the vulnerability, the computer is protected against being infected with the malware.
- Providing adequate protection against malware includes installing updates to antivirus software and operating system patches designed to prevent the malware from infecting a computer.
- users often leave computers exposed to malware even in instances when software updates would protect the computers.
- some users mistakenly believe that antivirus software will protect a computer from being infected with malware in all instances.
- frequently computers with “up-to-date” antivirus software are infected with malware if a patch designed to close the vulnerability exploited by the malware is not installed.
- a method when antivirus software on a computer identifies malware, a method causes a software update that closes the vulnerability exploited by the malware to be installed on the computer. More specifically, the method comprises: identifying the vulnerability exploited by the malware; using a software update system to obtain a software update that is designed to close the vulnerability; and causing the software update to be installed on the computer.
- a method of identifying a vulnerability exploited by a malware is provided.
- the vulnerability exploited by the malware is identified entirely on a computer associated with a user.
- a lookup of a database that maps a vulnerability to one or more malware is performed in order to identify the vulnerability.
- a remote computer associated with a trusted entity is used to identify the vulnerability. For example, in one embodiment, when a malware is identified the vulnerability is identified by generating a crash dump that contains the current memory contents of the computer; transmitting the crash dump to a remote computer associated with a trusted entity; and causing the remote computer to match the memory contents of the computer with a malware and associated vulnerability.
- a trusted entity provides a Web service that is available to a local computer associated with a user.
- the method for identifying the vulnerability includes causing the local computer associated with the user to issue a call to the Web service and causing the remote computer to match data provided in the call to a vulnerability using a data store that maps a vulnerability to one or more malware.
- a computer-readable medium is provided with contents, i.e., a program that causes a computer to operate in accordance with the methods described herein.
- FIG. 1 is a pictorial diagram illustrating a conventional networking environment over which malware is commonly distributed
- FIG. 2 is a pictorial diagram illustrating a conventional networking environment with computers that are capable of implementing aspects of the present invention
- FIG. 3 is a block diagram that illustrates software components that are capable of closing a vulnerability on the client computer illustrated in FIG. 2 , in accordance with the present invention
- FIG. 4 is a block diagram that illustrates software components that are capable of closing a vulnerability on the client computer illustrated in FIG. 2 , in accordance with present invention
- FIG. 5 is a pictorial depiction of a networking environment that includes the vulnerability computer and client computer illustrated in FIG. 2 that are capable of performing functions implemented by the present invention.
- FIG. 6 is a flow diagram illustrating one embodiment of a method that causes a software update to be installed on a computer when a malware is identified, in accordance with the present invention.
- the present invention provides a system, method, and computer-readable medium that opportunistically installs a software update configured to close a known vulnerability that exists on a computer.
- the first defensive mechanism is “up-to-date” antivirus software that is designed to identify and remove malware from a computer.
- the second defensive mechanism involves regularly installing software updates or “patches” that dose vulnerabilities on the computer.
- antivirus software is used to determine when a computer is vulnerable to malware. For example, when a malware infection is identified, the present invention matches the malware identified to the vulnerability exploited by the malware.
- a software update system is used to obtain the software update that is configured to close the vulnerability exploited by the malware. Finally, the software update is installed on the computer where the malware infection was identified, thereby protecting the computer from malware that exploits this vulnerability.
- the networking environment 200 comprises a plurality of computers—namely, the vulnerability computer 202 , the client computer 204 , the server computer 206 , and the Personal Digital Assistant (“PDA”) 208 .
- the vulnerability computer 202 is shown associated with a trusted entity 210 .
- the vulnerability computer 202 is configured to communicate with the client computer 204 , server computer 206 , and the PDA 208 , via the network 212 , which may be implemented as a local area network (“LAN”), wide area network (“WAN”), or the global network commonly known as the Internet.
- the computers 202 , 204 , 206 , and 208 illustrated in FIG. 2 may be configured to exchange files, commands, and other types of data.
- FIG. 2 illustrates personal computers and a Personal Digital Assistant usable in the networking environment 200 in which complementary tasks may be performed by remote computers linked together through a communication network 212 .
- the invention may be practiced with many other computer system configurations.
- the invention may be practiced with a personal computer operating in a stand-alone environment or with multiprocessor systems, minicomputers, mainframe computers, and the like.
- the functions performed by the computers, described herein may be implemented by a plurality of computers.
- the invention may be practiced on other kinds of computers, including laptop computers, tablet computers, or any device upon which computer software or other digital content may be installed.
- any of the computers 204 , 206 , and 208 that are communicatively connected to the network 212 may obtain a software update that was created by the trusted entity 210 and made available from the vulnerability computer 202 .
- the software update is obtained when antivirus software on the computers 204 , 206 , and 208 identifies malware infection. Then software formed in accordance with the present invention identifies the vulnerability exploited by the malware.
- the present invention takes advantage of the fact that when malware is identified on a computer, the identification means that the computer was not updated with a “patch” designed to close the vulnerability exploited by the malware. As a result, the present invention automatically and conveniently protects the computer where the malware was identified from future infections without requiring significant effort on the part of the user.
- the client computer 204 may be any one of a variety of devices including, but not limited to, personal computing devices, server-based computing devices, and the like.
- FIG. 3 does not show the typical components of many computers, such as a CPU, keyboard, mouse, printer, or other I/O devices, display, etc.
- FIG. 3 does not show the typical components of many computers, such as a CPU, keyboard, mouse, printer, or other I/O devices, display, etc.
- FIG. 3 does not show the typical components of many computers, such as a CPU, keyboard, mouse, printer, or other I/O devices, display, etc.
- the client computer 204 contains antivirus software 300 , a malware database 302 , a software update client 304 , and a coordination module 306 which collectively provide a way to opportunistically close a vulnerability on the client computer 204 , thereby protecting the computer 204 from malware.
- the client computer 204 includes an antivirus software 300 designed to identify data characteristic of malware
- Many different software vendors provide antivirus software to identify and remove malware from a computer.
- One known technique employed by some existing antivirus software that is used to identify data characteristic of malware includes obtaining a copy of the malware “in the wild.”
- the program code that implements the malware is processed with a hash function that converts the program code or a characteristic subset of the program code into a signature that uniquely identifies the malware.
- the antivirus software 300 illustrated in FIG. 3 may employ this known technique of scanning data for a malware signature.
- heuristic techniques employed for identifying malware may be used by the antivirus software 300 .
- the examples described herein should be construed as exemplary and not limiting, as the antivirus software 300 may employ any of a number of malware detection techniques.
- the client computer 204 includes a coordination module 306 and a malware database 302 . Since functions and different embodiments of the coordination module 306 are described below with reference to FIG. 6 , a detailed description of the module 306 will not be provided here. However, generally described, the coordination module 306 receives notice from the antivirus software 300 when malware is identified on a computer 204 . Then, in one embodiment of the present invention, the coordination module 306 performs a lookup in the malware database 302 . As described in further detail below, the malware database 302 maps a vulnerability to one or more malware that exploit the vulnerability to gain access to the computer 204 .
- the coordination module 306 By performing a lookup in the malware database 302 , the coordination module 306 is able to identify the vulnerability exploited by the malware. Then, in accordance with one embodiment of the present invention, the coordination module 306 uses the software update client 304 to install a software update on the computer 204 that is configured to close the identified vulnerability.
- the client computer 204 illustrated in FIG. 3 includes a software update client 304 that is configured to obtain and install a software update on the computer 204 .
- the software update client 304 identifies the software state of the computer 204 by performing an analysis of configuration databases stored on the computer 204 .
- configuration databases stored on the computer 204 .
- modern computers maintain databases from which configuration information may be obtained.
- the system registry is a database used to store settings, options, and preferences regarding the operation of a computer, including settings for all the hardware, software, and user preferences.
- the system registry also stores references to libraries, such as dynamically linked libraries, which identify the code segments and data used by application programs installed on the client computer 204 .
- the software update client 304 analyzes the system registry and other configuration databases to identify the operating system, application programs, and software updates installed on the client computer 204 . Then the software update client 304 queries a data store for information about available software updates and rules that govern when a particular software update should be installed. As a result, the software update client 304 produces data that identifies any software updates that need to be installed on the client computer 204 , given the configuration of the computer 204 and malware that was identified by the antivirus software 300 . Also, the software update client 304 communicates with server-based software on the vulnerability computer 202 in order to obtain any necessary software updates.
- FIG. 3 is a simplified example of one client computer 204 that is capable of performing the functions implemented by the present invention. Actual embodiments of the client computer 204 will have additional components not illustrated in FIG. 3 or described in the accompanying text. Also, FIG. 3 shows an exemplary component architecture for opportunistically “patching” a computer—but other component architectures are possible.
- FIG. 4 an alternative embodiment of the present invention in which the vulnerability computer 202 maintains logic for identifying the software update that will be installed on the client computer 204 is described.
- the client computer 204 contains many of the same software components that were described above with reference to FIG. 3 .
- a dump file 400 is generated and transmitted to the vulnerability computer 202 .
- existing systems are able to generate “dump files” (sometimes referred to as memory dumps or core dumps) when a malware is identified on a computer.
- a dump file is a record of the memory state of a computer that provides developers with access to data and other information that captures the state of different system components.
- a detailed description of one system suitable to obtain a dump file from a computer may be found in commonly assigned U.S. Pat. No. 6,629,267, titled METHOD AND SYSTEM FOR REPORTING A PROGRAM FAILURE, issued Sep. 30, 2003, the content of which is expressly incorporated herein by reference.
- the software update client 304 causes the dump file 400 to be transmitted to the vulnerability computer 202 .
- the vulnerability computer 202 maintains identification logic 402 that takes the dump file 400 as input.
- the identification logic 402 performs an analysis, using techniques generally known in the art, to identify the identified malware from data in the dump file 400 .
- the identification logic 402 performs a lookup of the malware database 302 in order to identify the vulnerability exploited by the malware.
- the vulnerability computer 202 transmits a software update 404 to the client computer 204 that is designed to close the exploited vulnerability.
- the software update client 304 causes the software update 404 to be installed, thereby protecting the computer from malware that exploits this vulnerability.
- FIG. 5 another alternative embodiment of the present invention in which the vulnerability computer 202 is used to distribute a software update to the client computer 204 will be described.
- a Web service refers to a software system with a network accessible interface that performs actions on behalf of other software systems.
- a Web service is typically accessed using standard protocols such as the Simple Object Access Protocol (“SOAP”).
- SOAP Simple Object Access Protocol
- a software system located on a remote computer may interact with a Web service in a manner prescribed by definitions that are provided in a service description.
- XML Extensible Markup Language
- HTTP HyperText Transfer Protocol
- a Web service may expose processes to remote software systems for accessing data or executing operations on a computer or a cluster of computers that provides the Web service.
- a Web service supports interactions with other software systems at a specified location on a network that may be identified using a Uniform Resource Indicator (“URI”).
- URI Uniform Resource Indicator
- FIG. 5 and the following discussion is intended to provide a general description of a Web service that distributes software updates to vulnerable computers in accordance with one embodiment of the present invention.
- the client computer 204 and the vulnerability computer 202 are communicatively connected via the network 212 .
- the client computer 204 maintains an exemplary flow 500 of program execution.
- programs Prior to the infrastructure of modern networks, programs were executed entirely on a single computer.
- a Web service provides “black-box functionality” that allows program execution to be distributed over a plurality of computers.
- an application executing on one computer may invoke a function on a computer that provides the Web service at event 502 , by issuing a request.
- the flow 500 of program execution is transferred from the client computer 204 to the vulnerability computer 202 .
- invoking the function will typically cause program code to be executed on the vulnerability computer 202 .
- the Web service will cause data in the form of a response to be transmitted to the client computer 204 using standard network protocols.
- a Web service is a type of virtual application that uses the network 212 to link software components.
- the client computer 204 when malware is identified, the client computer 204 makes a request to a Web service that is maintained by the vulnerability computer 202 .
- the request is designed to provide sufficient information so that the Web service may identify a software update that is configured to close the vulnerability exploited by the malware.
- the identity of the malware and/or configuration data that describes the software state of the client computer 204 may be transmitted to the Web service.
- the vulnerability computer 202 may provide a Web page from which the necessary software update can be obtained.
- FIG. 6 an exemplary embodiment of the coordination module 306 , illustrated in FIGS. 3 and 4 , that opportunistically protects a computer from malware will be described.
- the coordination module 306 begins at block 600 where the module 306 remains idle until antivirus software identifies malware on a computer that implements the present invention.
- many different software vendors provide antivirus software that identifies a malware infection.
- currently available antivirus software may use a variety of malware detection techniques, alone or in combination, to protect a computer from malware.
- the coordination module 306 may be used in conjunction with any currently existing or yet to be developed antivirus software.
- the antivirus software used by the present invention may employ any one of a number of malware detection techniques.
- the coordination module 306 is notified of the malware, using techniques for communicating between software modules that are generally known in the art.
- coordination module 306 may begin functioning in other contexts without departing from the scope of the present invention.
- the present invention may be integrated with other types of anti-malware products such as firewalls, anti-spyware software, and the like.
- the malware infection identified at block 600 is handled by the antivirus software.
- the infection may be handled in one of many different ways.
- the infected computer is capable of being “cleaned” so that the malware is no longer resident on the computer.
- the malware may be configured to employ self-preservation techniques to resist being cleaned. As a result, removing the malware from the computer may not be feasible in all instances. As a result, the malware may be “quarantined,” so that data associated with the malware is incapable of being executed on the computer.
- the coordination module 306 determines whether the vulnerability exploited by the malware will be identified by a local computer where the malware was identified (e.g., the client computer 204 ) or a remote computer associated with a trusted entity (e.g., the vulnerability computer 202 ). As described previously with reference to FIGS. 3-5 , aspects of the present invention may be implemented either on a computer associated with a user or a remote computer associated with a trusted entity. For example, aspects of the present invention may be implemented as a Web service that identifies vulnerabilities on behalf of other computers. In any event, if the vulnerability exploited by the malware will be identified by a local computer associated with a user, the coordination module 306 proceeds to block 605 described below. Conversely, if the vulnerability exploited by the malware will be identified by a remote computer associated with a trusted entity, the coordination module 306 proceeds to block 604 .
- data is transmitted from a local computer associated with the user to a remote computer associated with a trusted entity.
- a trusted entity provides a Web service that performs functions on behalf of a local computer.
- a Web service request is generated at block 604 and transmitted from a local computer to a computer associated with a trusted entity.
- the request is designed to provide the Web service with sufficient information so that the Web service may identify a software update that is configured to close the vulnerability that exists on the requesting computer.
- the identity of the malware and/or configuration data that describes the software state of the requesting computer may be transmitted to the Web service in the request.
- a computer associated with a trusted entity may identify a vulnerability on behalf of a local computer in other contexts than a Web service. For example, at block 604 a dump file may be transmitted to a computer associated with the trusted entity using existing software systems. In this embodiment, a request to a Web service is not generated. Instead, at block 604 , a dump file that contains the contents of computer memory is generated and transmitted to a computer associated with the trusted entity. As mentioned previously, logic on a computer associated with the trusted entity performs an analysis of the dump file to identify the malware that is infecting the local computer.
- the coordination module 306 identifies the vulnerability exploited by the malware that is infecting the local computer associated with a user.
- software providers continuously monitor communication networks for new computer malware.
- the developers analyze code that implements the malware to detect vulnerabilities exploited by the malware.
- a software update or “patch” is created to close the exploited vulnerability.
- software updates are distributed through a Web site or an automatic software update system.
- users may not obtain software updates that are needed to close vulnerabilities on their computers. For example, a user may not obtain the software updates from a Web site or “opt-in” to an automatic update system designed to distribute the software updates.
- developers also maintain a data store (e.g., the malware database 302 ) that maps a vulnerability to one or more malware that exploits the vulnerability.
- the malware database records a vulnerability “TYPE 1 BUFFER OVERFLOW”) and identifies one or more malware (e.g., “SASSER”) that are known to exploit this vulnerability.
- the vulnerability exploited by the malware is identified, at block 605 , by performing a lookup in a data store that is maintained on a local computer associated with a user (e.g., the client computer 204 ).
- the vulnerability is identified by generating a query to the data store using techniques that are generally known in the art.
- the vulnerability exploited by the malware is identified at block 605 by a computer associated with a trusted entity.
- a computer associated with a trusted entity For example, as described previously, aspects of the present invention may be provided as a Web service.
- the local computer associated with the user e.g., the client computer 204
- the vulnerability computer 202 the vulnerability computer 202
- a database lookup is performed, that extracts information in a data store.
- a data store that maps a vulnerability to one or more malware may be maintained on the computer associated with a trusted entity.
- data such as a Web service request on a dump file is received from the local computer, the data is analyzed and used to identify the vulnerabilities exploited from a data store.
- the coordination module 306 determines whether a software update exists that is configured to close the vulnerability identified at block 605 . Those skilled in the art and others will recognize that creating a software update that closes a vulnerability may take a significant amount of time. As a result, the necessary software update may not be available in all instances. If a software update that is designed to close the vulnerability is available, the coordination module 306 proceeds to block 610 described below. Conversely, if a software update that is designed to close the vulnerability is not available, the coordination module 306 proceeds to block 608 .
- the coordination module 306 reports the non-availability of a software update to the trusted entity. By reporting the non-availability of the necessary software update, the coordination module 306 provides data to developers that may be used to identify critical software updates that need to be distributed to users in order to counter a new malware threat. Then the coordination module proceeds to block 614 where it terminates.
- the necessary software update or “patch” is transmitted from a computer associated with the trusted entity (e.g., vulnerability computer 202 ) to a local computer where the malware was discovered (e.g., the client computer 204 ).
- a computer associated with the trusted entity e.g., vulnerability computer 202
- a local computer where the malware was discovered e.g., the client computer 204
- aspects of the present invention may use an existing software update client 304 to communicate with a computer associated with the trusted entity and obtain one or more software updates.
- the software update client 304 maintains an application programming interface (“API”) that is called by the coordination module 306 .
- API application programming interface
- the software update client 304 satisfies the API call by communicating with the computer associated with the trusted entity using standard network protocols.
- the software update is installed on the local computer at block 612 , using a system and method that are generally known in the art.
- the coordination module 306 proceeds to block 614 where it terminates.
- other systems may be used to obtain and install the software update without departing from the scope of the present invention.
- the necessary software update may be obtained manually from a Web page or other distribution mechanism without departing from the scope of the present invention.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Hardware Design (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Health & Medical Sciences (AREA)
- Virology (AREA)
- General Health & Medical Sciences (AREA)
- Computing Systems (AREA)
- Signal Processing (AREA)
- Computer Networks & Wireless Communication (AREA)
- Information Transfer Between Computers (AREA)
Abstract
The present invention provides a system, method, and computer-readable medium that opportunistically install a software update on a computer that closes a vulnerability that existed on the computer. In accordance with one aspect of the present invention, when antivirus software on a computer identifies malware, a method causes a software update that closes the vulnerability exploited by the malware to be installed on the computer. The method includes identifying the vulnerability exploited by the malware, using a software update system to obtain a software update that is configured to close the vulnerability; and causing the software update to be installed on the computer where the vulnerability exists.
Description
- This Application is a Continuation of and claims benefit from U.S. patent application Ser. No. 11/130,570 that was filed on May 16, 2005, and that is incorporated herein by reference in its entirety.
- The present invention relates to computers and, more particularly, to opportunistically protecting a computer from malware.
- As more and more computers and other computing devices are interconnected through various networks such as the Internet, computer security has become increasingly more important, particularly from invasions or attacks delivered over a network or over an information stream. As those skilled in the art will recognize, these attacks come in many different forms, including, but certainly not limited to, computer viruses, computer worms, system component replacements, denial of service attacks, even misuse/abuse of legitimate computer system features—all of which exploit one or more computer system vulnerabilities for illegitimate purposes. While those skilled in the art will realize that the various computer attacks are technically distinct from one another, for purposes of the present invention and for simplicity in description, all malicious computer programs will be generally referred to hereinafter as computer malware or, more simply, malware.
- When a computer is attacked or “infected” by computer malware, the adverse results are varied, including disabling system devices; erasing or corrupting firmware, applications, or data files; transmitting potentially sensitive data to another location on the network; shutting down the computer; or causing the computer to crash. Yet another pernicious aspect of many, though not all, computer malware is that an infected computer is used to infect other systems.
-
FIG. 1 is a pictorial diagram illustrating anexemplary networking environment 100 over which a computer malware is commonly distributed. As shown inFIG. 1 , the typicalexemplary networking environment 100 includes a plurality of computers 102-108 all inter-connected via acommunication network 110 such as an intranet or via a larger communication network including the global TCP/IP network commonly referred to as the Internet. For whatever reason, a malicious party on a computer connected to thenetwork 110, such ascomputer 102, develops acomputer malware 112 and releases it on the network. The releasedcomputer malware 112 is received by and infects one or more computers, such ascomputer 104, as indicated byarrow 114. As is typical with many computer malware, once infected,computer 104 is used to infect other computers, such ascomputer 106 as indicated byarrow 116 that, in turn, infects yet other computers, such ascomputer 108 as indicated byarrow 118. It should be appreciated that themalware 112 may be directed to any one of the computers 104-108 as a result of a request initiated by thecomputer 102. Clearly, due to the speed and reach of the modern computer networks, acomputer malware 112 can “grow” at an exponential rate and quickly disrupt communications between organizations and people. - When a new malware is identified as spreading on a communication network such as the Internet, different software providers initiate a process for handling the malware. More specifically, typically at least two software providers create software updates when new malware is identified. One software provider is an antivirus software provider that creates a software update designed to identify the new malware and remove the malware from a computer. Those skilled in the art and others will recognize that a traditional defense against computer malware, and particularly computer viruses and worms, is antivirus software which typically scans data that is transmitted to a computer, searching for identifiable patterns, referred to as signatures, which are associated with known malware. If a malware signature is identified, the antivirus software takes appropriate action, such as deleting the malware/infected file or removing the malware from an infected file. However, existing antivirus software does not provide software updates that are designed to close the vulnerability exploited by the malware to infect one or more computers. As a result, a computer may become reinfected with the malware, in some instances, even though antivirus software on a computer is “up-to-date” with the most recent software updates.
- Another software provider that typically creates software updates when a new malware is identified is an operating system provider. While most malware released today are based on known vulnerabilities, occasionally a computer malware is released that takes advantage of a previously unknown vulnerability. In this instance, the operating system provider creates a software update, commonly known as a “patch,” that is designed to close the vulnerability exploited by the new malware. By installing a patch designed to close the vulnerability, the computer is protected against being infected with the malware.
- Providing adequate protection against malware includes installing updates to antivirus software and operating system patches designed to prevent the malware from infecting a computer. However, users often leave computers exposed to malware even in instances when software updates would protect the computers. For example, some users mistakenly believe that antivirus software will protect a computer from being infected with malware in all instances. However, frequently computers with “up-to-date” antivirus software are infected with malware if a patch designed to close the vulnerability exploited by the malware is not installed.
- The foregoing problems with the state of the prior art are overcome by the principles of the present invention, which are directed toward a system, method, and computer-readable medium for opportunistically installing a software update on a computer that closes a vulnerability that exists on the computer.
- In accordance with one aspect of the present invention, when antivirus software on a computer identifies malware, a method causes a software update that closes the vulnerability exploited by the malware to be installed on the computer. More specifically, the method comprises: identifying the vulnerability exploited by the malware; using a software update system to obtain a software update that is designed to close the vulnerability; and causing the software update to be installed on the computer.
- In accordance with another aspect of the present invention, a method of identifying a vulnerability exploited by a malware is provided. In one embodiment, the vulnerability exploited by the malware is identified entirely on a computer associated with a user. In this instance, a lookup of a database that maps a vulnerability to one or more malware is performed in order to identify the vulnerability. In other embodiments, a remote computer associated with a trusted entity is used to identify the vulnerability. For example, in one embodiment, when a malware is identified the vulnerability is identified by generating a crash dump that contains the current memory contents of the computer; transmitting the crash dump to a remote computer associated with a trusted entity; and causing the remote computer to match the memory contents of the computer with a malware and associated vulnerability. In yet another embodiment that uses a remote computer to identify the vulnerability exploited by the malware, a trusted entity provides a Web service that is available to a local computer associated with a user. In this instance, the method for identifying the vulnerability includes causing the local computer associated with the user to issue a call to the Web service and causing the remote computer to match data provided in the call to a vulnerability using a data store that maps a vulnerability to one or more malware.
- In still another aspect of the present invention, a computer-readable medium is provided with contents, i.e., a program that causes a computer to operate in accordance with the methods described herein.
- The foregoing aspects and many of the attendant advantages of this invention will become in more readily appreciated as the same become better understood by reference to the following detailed description, when taken in conjunction with the accompanying drawings, wherein:
-
FIG. 1 is a pictorial diagram illustrating a conventional networking environment over which malware is commonly distributed; -
FIG. 2 is a pictorial diagram illustrating a conventional networking environment with computers that are capable of implementing aspects of the present invention; -
FIG. 3 is a block diagram that illustrates software components that are capable of closing a vulnerability on the client computer illustrated inFIG. 2 , in accordance with the present invention; -
FIG. 4 is a block diagram that illustrates software components that are capable of closing a vulnerability on the client computer illustrated inFIG. 2 , in accordance with present invention; -
FIG. 5 is a pictorial depiction of a networking environment that includes the vulnerability computer and client computer illustrated inFIG. 2 that are capable of performing functions implemented by the present invention; and -
FIG. 6 is a flow diagram illustrating one embodiment of a method that causes a software update to be installed on a computer when a malware is identified, in accordance with the present invention. - The present invention provides a system, method, and computer-readable medium that opportunistically installs a software update configured to close a known vulnerability that exists on a computer. Those skilled in the art and others will recognize that, to protect a computer from malware, at least two defensive mechanisms are necessary. The first defensive mechanism is “up-to-date” antivirus software that is designed to identify and remove malware from a computer. The second defensive mechanism involves regularly installing software updates or “patches” that dose vulnerabilities on the computer. In general terms describing one aspect of the present invention, antivirus software is used to determine when a computer is vulnerable to malware. For example, when a malware infection is identified, the present invention matches the malware identified to the vulnerability exploited by the malware. Once the vulnerability exploited by the malware is known, a software update system is used to obtain the software update that is configured to close the vulnerability exploited by the malware. Finally, the software update is installed on the computer where the malware infection was identified, thereby protecting the computer from malware that exploits this vulnerability.
- The following description first provides an overview of aspects of the present invention. Then a method for implementing the present invention is described. The illustrative examples provided herein are not intended to be exhaustive or to limit the invention to the precise forms disclosed. Similarly, any steps described herein may be interchangeable with other steps or combinations of steps in order to achieve the same result.
- The following discussion is intended to provide a brief, general description of a
networking environment 200 suitable to implement aspects of the present invention. As illustrated inFIG. 2 , thenetworking environment 200 comprises a plurality of computers—namely, thevulnerability computer 202, theclient computer 204, theserver computer 206, and the Personal Digital Assistant (“PDA”) 208. Thevulnerability computer 202 is shown associated with a trustedentity 210. Also, thevulnerability computer 202 is configured to communicate with theclient computer 204,server computer 206, and thePDA 208, via thenetwork 212, which may be implemented as a local area network (“LAN”), wide area network (“WAN”), or the global network commonly known as the Internet. As known to those skilled in the art and others, thecomputers FIG. 2 may be configured to exchange files, commands, and other types of data. - For the sake of convenience,
FIG. 2 illustrates personal computers and a Personal Digital Assistant usable in thenetworking environment 200 in which complementary tasks may be performed by remote computers linked together through acommunication network 212. However, those skilled in the art will appreciate that the invention may be practiced with many other computer system configurations. For example, the invention may be practiced with a personal computer operating in a stand-alone environment or with multiprocessor systems, minicomputers, mainframe computers, and the like. In this regard, the functions performed by the computers, described herein, may be implemented by a plurality of computers. In addition to the conventional computer systems illustrated inFIG. 1 , those skilled in the art will also recognize that the invention may be practiced on other kinds of computers, including laptop computers, tablet computers, or any device upon which computer software or other digital content may be installed. - When software formed in accordance with the present invention is implemented in one or more computers, the software provides a way to opportunistically close a vulnerability on a computer. More specifically, in one embodiment of the present invention, any of the
computers network 212 may obtain a software update that was created by the trustedentity 210 and made available from thevulnerability computer 202. Typically, the software update is obtained when antivirus software on thecomputers vulnerability computer 202 and installed on the computer where the malware was identified. The present invention takes advantage of the fact that when malware is identified on a computer, the identification means that the computer was not updated with a “patch” designed to close the vulnerability exploited by the malware. As a result, the present invention automatically and conveniently protects the computer where the malware was identified from future infections without requiring significant effort on the part of the user. - Referring now to
FIG. 3 , the following is intended to provide an exemplary overview of the components that implement aspects of the present invention. As mentioned previously, theclient computer 204 may be any one of a variety of devices including, but not limited to, personal computing devices, server-based computing devices, and the like. For ease of illustration and because they are not important for an understanding of the present invention,FIG. 3 does not show the typical components of many computers, such as a CPU, keyboard, mouse, printer, or other I/O devices, display, etc. However, as illustrated inFIG. 3 , theclient computer 204 containsantivirus software 300, amalware database 302, asoftware update client 304, and acoordination module 306 which collectively provide a way to opportunistically close a vulnerability on theclient computer 204, thereby protecting thecomputer 204 from malware. - As illustrated in
FIG. 3 , theclient computer 204 includes anantivirus software 300 designed to identify data characteristic of malware, Many different software vendors provide antivirus software to identify and remove malware from a computer. One known technique employed by some existing antivirus software that is used to identify data characteristic of malware includes obtaining a copy of the malware “in the wild.” The program code that implements the malware is processed with a hash function that converts the program code or a characteristic subset of the program code into a signature that uniquely identifies the malware. Theantivirus software 300 illustrated inFIG. 3 may employ this known technique of scanning data for a malware signature. Also, increasingly, heuristic techniques employed for identifying malware may be used by theantivirus software 300. However, it should be well understood that the examples described herein should be construed as exemplary and not limiting, as theantivirus software 300 may employ any of a number of malware detection techniques. - As further illustrated in
FIG. 3 , theclient computer 204 includes acoordination module 306 and amalware database 302. Since functions and different embodiments of thecoordination module 306 are described below with reference toFIG. 6 , a detailed description of themodule 306 will not be provided here. However, generally described, thecoordination module 306 receives notice from theantivirus software 300 when malware is identified on acomputer 204. Then, in one embodiment of the present invention, thecoordination module 306 performs a lookup in themalware database 302. As described in further detail below, themalware database 302 maps a vulnerability to one or more malware that exploit the vulnerability to gain access to thecomputer 204. By performing a lookup in themalware database 302, thecoordination module 306 is able to identify the vulnerability exploited by the malware. Then, in accordance with one embodiment of the present invention, thecoordination module 306 uses thesoftware update client 304 to install a software update on thecomputer 204 that is configured to close the identified vulnerability. - The
client computer 204 illustrated inFIG. 3 includes asoftware update client 304 that is configured to obtain and install a software update on thecomputer 204. In this regard, thesoftware update client 304 identifies the software state of thecomputer 204 by performing an analysis of configuration databases stored on thecomputer 204. As known to those skilled in the art and others, modern computers maintain databases from which configuration information may be obtained. For example, the system registry is a database used to store settings, options, and preferences regarding the operation of a computer, including settings for all the hardware, software, and user preferences. The system registry also stores references to libraries, such as dynamically linked libraries, which identify the code segments and data used by application programs installed on theclient computer 204. Thesoftware update client 304 analyzes the system registry and other configuration databases to identify the operating system, application programs, and software updates installed on theclient computer 204. Then thesoftware update client 304 queries a data store for information about available software updates and rules that govern when a particular software update should be installed. As a result, thesoftware update client 304 produces data that identifies any software updates that need to be installed on theclient computer 204, given the configuration of thecomputer 204 and malware that was identified by theantivirus software 300. Also, thesoftware update client 304 communicates with server-based software on thevulnerability computer 202 in order to obtain any necessary software updates. - Those skilled in the art and others will recognize that
FIG. 3 is a simplified example of oneclient computer 204 that is capable of performing the functions implemented by the present invention. Actual embodiments of theclient computer 204 will have additional components not illustrated inFIG. 3 or described in the accompanying text. Also,FIG. 3 shows an exemplary component architecture for opportunistically “patching” a computer—but other component architectures are possible. - Now with reference to
FIG. 4 , an alternative embodiment of the present invention in which thevulnerability computer 202 maintains logic for identifying the software update that will be installed on theclient computer 204 is described. As illustrated inFIG. 4 , in this embodiment, theclient computer 204 contains many of the same software components that were described above with reference toFIG. 3 . However, when theantivirus software 300 identifies malware on thecomputer 204, adump file 400 is generated and transmitted to thevulnerability computer 202. As known to those skilled in the art and others, existing systems are able to generate “dump files” (sometimes referred to as memory dumps or core dumps) when a malware is identified on a computer. Generally described, a dump file is a record of the memory state of a computer that provides developers with access to data and other information that captures the state of different system components. A detailed description of one system suitable to obtain a dump file from a computer may be found in commonly assigned U.S. Pat. No. 6,629,267, titled METHOD AND SYSTEM FOR REPORTING A PROGRAM FAILURE, issued Sep. 30, 2003, the content of which is expressly incorporated herein by reference. - As illustrated in
FIG. 4 , when theantivirus software 300 identifies a malware infection on thecomputer 204, thesoftware update client 304 causes thedump file 400 to be transmitted to thevulnerability computer 202. In this embodiment, thevulnerability computer 202 maintainsidentification logic 402 that takes thedump file 400 as input. In response to receiving thedump file 400, theidentification logic 402 performs an analysis, using techniques generally known in the art, to identify the identified malware from data in thedump file 400. Once the malware is identified, theidentification logic 402 performs a lookup of themalware database 302 in order to identify the vulnerability exploited by the malware. When the vulnerability is known, thevulnerability computer 202 transmits asoftware update 404 to theclient computer 204 that is designed to close the exploited vulnerability. When thesoftware update 404 is received, thesoftware update client 304 causes thesoftware update 404 to be installed, thereby protecting the computer from malware that exploits this vulnerability. - Now with reference to
FIG. 5 , another alternative embodiment of the present invention in which thevulnerability computer 202 is used to distribute a software update to theclient computer 204 will be described. One system that facilitates the communication of data between computers, using protocols developed for the Internet, is a Web service. Those skilled in the art and others will recognize that a Web service refers to a software system with a network accessible interface that performs actions on behalf of other software systems. A Web service is typically accessed using standard protocols such as the Simple Object Access Protocol (“SOAP”). A software system located on a remote computer may interact with a Web service in a manner prescribed by definitions that are provided in a service description. Also, interactions between software systems typically occur using Extensible Markup Language (“XML”)-based messages exchanged via Internet-based protocols, such as the HyperText Transfer Protocol (“HTTP”). In this way, a Web service may expose processes to remote software systems for accessing data or executing operations on a computer or a cluster of computers that provides the Web service. Typically, a Web service supports interactions with other software systems at a specified location on a network that may be identified using a Uniform Resource Indicator (“URI”). -
FIG. 5 and the following discussion is intended to provide a general description of a Web service that distributes software updates to vulnerable computers in accordance with one embodiment of the present invention. As illustrated inFIG. 5 , theclient computer 204 and thevulnerability computer 202 are communicatively connected via thenetwork 212. As further illustrated inFIG. 5 , theclient computer 204 maintains anexemplary flow 500 of program execution. Prior to the infrastructure of modern networks, programs were executed entirely on a single computer. However, those skilled in the art and others will recognize that a Web service provides “black-box functionality” that allows program execution to be distributed over a plurality of computers. For example, an application executing on one computer, such as theclient computer 204, may invoke a function on a computer that provides the Web service atevent 502, by issuing a request. As a result, theflow 500 of program execution is transferred from theclient computer 204 to thevulnerability computer 202. In this instance, invoking the function will typically cause program code to be executed on thevulnerability computer 202. When the function invoked on the Web service completes, atevent 504, theflow 500 of program execution is transferred back to theclient computer 204. Typically, the Web service will cause data in the form of a response to be transmitted to theclient computer 204 using standard network protocols. As illustrated inFIG. 5 , a Web service is a type of virtual application that uses thenetwork 212 to link software components. - In one embodiment of the present invention, when malware is identified, the
client computer 204 makes a request to a Web service that is maintained by thevulnerability computer 202. The request is designed to provide sufficient information so that the Web service may identify a software update that is configured to close the vulnerability exploited by the malware. For example, the identity of the malware and/or configuration data that describes the software state of theclient computer 204 may be transmitted to the Web service. In response to the request, thevulnerability computer 202 may provide a Web page from which the necessary software update can be obtained. - Now with reference to
FIG. 6 , an exemplary embodiment of thecoordination module 306, illustrated inFIGS. 3 and 4 , that opportunistically protects a computer from malware will be described. - As illustrated in
FIG. 6 , thecoordination module 306 begins atblock 600 where themodule 306 remains idle until antivirus software identifies malware on a computer that implements the present invention. As described previously, many different software vendors provide antivirus software that identifies a malware infection. Moreover, currently available antivirus software may use a variety of malware detection techniques, alone or in combination, to protect a computer from malware. Thecoordination module 306 may be used in conjunction with any currently existing or yet to be developed antivirus software. Moreover, the antivirus software used by the present invention may employ any one of a number of malware detection techniques. When malware is identified atblock 600, thecoordination module 306 is notified of the malware, using techniques for communicating between software modules that are generally known in the art. However, those skilled in the art and others will recognize that thecoordination module 306 may begin functioning in other contexts without departing from the scope of the present invention. For example, the present invention may be integrated with other types of anti-malware products such as firewalls, anti-spyware software, and the like. - At
block 602, the malware infection identified atblock 600 is handled by the antivirus software. Those skilled in the art and others will recognize that when a malware infection is detected, the infection may be handled in one of many different ways. Preferably, the infected computer is capable of being “cleaned” so that the malware is no longer resident on the computer. However, in some instances, the malware may be configured to employ self-preservation techniques to resist being cleaned. As a result, removing the malware from the computer may not be feasible in all instances. As a result, the malware may be “quarantined,” so that data associated with the malware is incapable of being executed on the computer. - At
block 603, thecoordination module 306 determines whether the vulnerability exploited by the malware will be identified by a local computer where the malware was identified (e.g., the client computer 204) or a remote computer associated with a trusted entity (e.g., the vulnerability computer 202). As described previously with reference toFIGS. 3-5 , aspects of the present invention may be implemented either on a computer associated with a user or a remote computer associated with a trusted entity. For example, aspects of the present invention may be implemented as a Web service that identifies vulnerabilities on behalf of other computers. In any event, if the vulnerability exploited by the malware will be identified by a local computer associated with a user, thecoordination module 306 proceeds to block 605 described below. Conversely, if the vulnerability exploited by the malware will be identified by a remote computer associated with a trusted entity, thecoordination module 306 proceeds to block 604. - At
block 604, data. is transmitted from a local computer associated with the user to a remote computer associated with a trusted entity. As mentioned above, in one embodiment of the present invention, a trusted entity provides a Web service that performs functions on behalf of a local computer. In this instance, a Web service request is generated atblock 604 and transmitted from a local computer to a computer associated with a trusted entity. The request is designed to provide the Web service with sufficient information so that the Web service may identify a software update that is configured to close the vulnerability that exists on the requesting computer. Thus, the identity of the malware and/or configuration data that describes the software state of the requesting computer may be transmitted to the Web service in the request. - A computer associated with a trusted entity may identify a vulnerability on behalf of a local computer in other contexts than a Web service. For example, at block 604 a dump file may be transmitted to a computer associated with the trusted entity using existing software systems. In this embodiment, a request to a Web service is not generated. Instead, at
block 604, a dump file that contains the contents of computer memory is generated and transmitted to a computer associated with the trusted entity. As mentioned previously, logic on a computer associated with the trusted entity performs an analysis of the dump file to identify the malware that is infecting the local computer. - As illustrated in
FIG. 6 , atblock 605, thecoordination module 306 identifies the vulnerability exploited by the malware that is infecting the local computer associated with a user. Those skilled in the art and others will recognize that software providers continuously monitor communication networks for new computer malware. When a new computer malware is identified, the developers analyze code that implements the malware to detect vulnerabilities exploited by the malware. Then, a software update or “patch” is created to close the exploited vulnerability, Typically, software updates are distributed through a Web site or an automatic software update system. However, with these distribution mechanisms, users may not obtain software updates that are needed to close vulnerabilities on their computers. For example, a user may not obtain the software updates from a Web site or “opt-in” to an automatic update system designed to distribute the software updates. - As part of the process of creating software “patches,” developers also maintain a data store (e.g., the malware database 302) that maps a vulnerability to one or more malware that exploits the vulnerability. For example, the malware database records a vulnerability “TYPE 1 BUFFER OVERFLOW”) and identifies one or more malware (e.g., “SASSER”) that are known to exploit this vulnerability. In one embodiment of the present invention, the vulnerability exploited by the malware is identified, at
block 605, by performing a lookup in a data store that is maintained on a local computer associated with a user (e.g., the client computer 204). In this instance, the vulnerability is identified by generating a query to the data store using techniques that are generally known in the art. - In alternative embodiments of the present invention, the vulnerability exploited by the malware is identified at
block 605 by a computer associated with a trusted entity. For example, as described previously, aspects of the present invention may be provided as a Web service. In this instance, the local computer associated with the user (e.g., the client computer 204) generates a Web service request that is handled by a computer associated with the trusted entity the vulnerability computer 202). in response, a database lookup is performed, that extracts information in a data store. For example, a data store that maps a vulnerability to one or more malware may be maintained on the computer associated with a trusted entity. When data such as a Web service request on a dump file is received from the local computer, the data is analyzed and used to identify the vulnerabilities exploited from a data store. - As illustrated in
FIG. 6 atblock 606, thecoordination module 306 determines whether a software update exists that is configured to close the vulnerability identified atblock 605. Those skilled in the art and others will recognize that creating a software update that closes a vulnerability may take a significant amount of time. As a result, the necessary software update may not be available in all instances. If a software update that is designed to close the vulnerability is available, thecoordination module 306 proceeds to block 610 described below. Conversely, if a software update that is designed to close the vulnerability is not available, thecoordination module 306 proceeds to block 608. - At
block 608, thecoordination module 306 reports the non-availability of a software update to the trusted entity. By reporting the non-availability of the necessary software update, thecoordination module 306 provides data to developers that may be used to identify critical software updates that need to be distributed to users in order to counter a new malware threat. Then the coordination module proceeds to block 614 where it terminates. - As illustrated in
FIG. 6 , atblock 610, the necessary software update or “patch” is transmitted from a computer associated with the trusted entity (e.g., vulnerability computer 202) to a local computer where the malware was discovered (e.g., the client computer 204). As mentioned previously with reference toFIG. 3 , aspects of the present invention may use an existingsoftware update client 304 to communicate with a computer associated with the trusted entity and obtain one or more software updates. In accordance with one embodiment of the present invention, thesoftware update client 304 maintains an application programming interface (“API”) that is called by thecoordination module 306. In response, thesoftware update client 304 satisfies the API call by communicating with the computer associated with the trusted entity using standard network protocols. Then the software update is installed on the local computer atblock 612, using a system and method that are generally known in the art. Finally, thecoordination module 306 proceeds to block 614 where it terminates. However, those skilled in the art will recognize that other systems may be used to obtain and install the software update without departing from the scope of the present invention. For example, as mentioned previously, the necessary software update may be obtained manually from a Web page or other distribution mechanism without departing from the scope of the present invention. - While the preferred embodiment of the invention has been illustrated and described, it will be appreciated that various changes can be made therein without departing from the spirit and scope of the invention.
Claims (20)
1. A method performed on a first computing device, the method comprising:
receiving data comprising an identification of detected malware infecting a second computing device;
obtaining, in response to the receiving, a patch that corresponds to the detected malware and to a vulnerability exploited to infect the second computing device with the detected malware; and
sending the obtained patch to the second computing device.
2. The method of claim 1 where the received at a further comprises an identification of the vulnerability.
3. The method of claim 1 further comprising identifying, based on the received data, the vulnerability.
4. The method of claim 3 where the identifying comprises mapping the vulnerability to the detected malware.
5. The method of claim 1 where the patch is configured for closing the identified vulnerability on the second computing device.
6. The method of claim 1 where the obtaining the patch is from a service that is a trusted entity.
7. The method of claim 1 further comprising reporting, in response to the obtaining failing, a non-availability of the patch to a trusted entity.
8. At least one computer-readable storage device storing computer-executable instructions that, when executed by a first computing device, cause the first computing device to perform actions comprising:
receiving data comprising an identification of detected malware infecting a second computing device;
obtaining, in response to the receiving, a patch that corresponds to the detected malware and to a vulnerability exploited to infect the second computing device with the detected malware; and
sending the obtained patch to the second computing device.
9. The at least one computer-readable storage device of claim 8 where the received data further comprises an identification of the vulnerability.
10. The at least one computer-readable storage device of claim 8 , the actions further comprising identifying, based on the received data, the vulnerability.
11. The at least one computer-readable storage device of claim 10 where the identifying comprises mapping the vulnerability to the detected malware.
12. The at least one computer-readable storage device of claim 8 where the patch is configured for closing the identified vulnerability on the second computing device.
13. The at least one computer-readable storage device of claim 8 where the obtaining the patch is from a service that is a trusted entity.
14. The at least one computer-readable storage device of claim 8 , the actions further comprising reporting, in response to the obtaining failing, a non-availability of the patch to a trusted entity.
15. A system comprising a first computing device and at least one program module together configured for performing actions comprising:
receiving data comprising an identification of detected malware infecting a second computing device;
obtaining, in response to the receiving, a patch that corresponds to the detected malware and to a vulnerability exploited to infect the second computing device with the detected malware; and
sending the obtained patch to the second computing device.
16. The method of claim 15 where the received data further comprises an identification of the vulnerability.
17. The method of claim 15 , the actions further comprising identifying, based on the received data, the vulnerability.
18. The method of claim 17 where the identify comprises mapping the vulnerability to the detected malware.
19. The method of claim 15 where the obtaining the patch is from a service that is a trusted entity, or where the patch is configured for closing the identified vulnerability on the second computing device.
20. The method of claim 15 , the actions further comprising reporting, in response to the obtaining failing, a non-availability of the patch to a trusted entity.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/025,799 US20140020103A1 (en) | 2005-05-16 | 2013-09-12 | System and Method of Opportunistically Protecting a Computer from Malware |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/130,570 US8561190B2 (en) | 2005-05-16 | 2005-05-16 | System and method of opportunistically protecting a computer from malware |
US14/025,799 US20140020103A1 (en) | 2005-05-16 | 2013-09-12 | System and Method of Opportunistically Protecting a Computer from Malware |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/130,570 Continuation US8561190B2 (en) | 2005-05-16 | 2005-05-16 | System and method of opportunistically protecting a computer from malware |
Publications (1)
Publication Number | Publication Date |
---|---|
US20140020103A1 true US20140020103A1 (en) | 2014-01-16 |
Family
ID=37420712
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/130,570 Active 2029-09-21 US8561190B2 (en) | 2005-05-16 | 2005-05-16 | System and method of opportunistically protecting a computer from malware |
US14/025,799 Abandoned US20140020103A1 (en) | 2005-05-16 | 2013-09-12 | System and Method of Opportunistically Protecting a Computer from Malware |
US14/026,226 Abandoned US20140020104A1 (en) | 2005-05-16 | 2013-09-13 | System and Method of Opportunistically Protecting a Computer from Malware |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/130,570 Active 2029-09-21 US8561190B2 (en) | 2005-05-16 | 2005-05-16 | System and method of opportunistically protecting a computer from malware |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/026,226 Abandoned US20140020104A1 (en) | 2005-05-16 | 2013-09-13 | System and Method of Opportunistically Protecting a Computer from Malware |
Country Status (1)
Country | Link |
---|---|
US (3) | US8561190B2 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108900323A (en) * | 2018-06-11 | 2018-11-27 | 广州视源电子科技股份有限公司 | Communication method, device, equipment and medium |
Families Citing this family (36)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8561190B2 (en) * | 2005-05-16 | 2013-10-15 | Microsoft Corporation | System and method of opportunistically protecting a computer from malware |
US7739740B1 (en) * | 2005-09-22 | 2010-06-15 | Symantec Corporation | Detecting polymorphic threats |
US20070094496A1 (en) * | 2005-10-25 | 2007-04-26 | Michael Burtscher | System and method for kernel-level pestware management |
US7844829B2 (en) * | 2006-01-18 | 2010-11-30 | Sybase, Inc. | Secured database system with built-in antivirus protection |
JP4722730B2 (en) * | 2006-03-10 | 2011-07-13 | 富士通株式会社 | Security management program, security management device, and security management method |
US8190868B2 (en) | 2006-08-07 | 2012-05-29 | Webroot Inc. | Malware management through kernel detection |
US9147271B2 (en) | 2006-09-08 | 2015-09-29 | Microsoft Technology Licensing, Llc | Graphical representation of aggregated data |
US8234706B2 (en) * | 2006-09-08 | 2012-07-31 | Microsoft Corporation | Enabling access to aggregated software security information |
US20080208957A1 (en) * | 2007-02-28 | 2008-08-28 | Microsoft Corporation | Quarantine Over Remote Desktop Protocol |
US7831051B2 (en) * | 2007-03-13 | 2010-11-09 | Aladdin Europe Gmbh | Secure communication between a hardware device and a computer |
US8302197B2 (en) * | 2007-06-28 | 2012-10-30 | Microsoft Corporation | Identifying data associated with security issue attributes |
US8250651B2 (en) * | 2007-06-28 | 2012-08-21 | Microsoft Corporation | Identifying attributes of aggregated data |
US8271642B1 (en) | 2007-08-29 | 2012-09-18 | Mcafee, Inc. | System, method, and computer program product for isolating a device associated with at least potential data leakage activity, based on user input |
US8019700B2 (en) * | 2007-10-05 | 2011-09-13 | Google Inc. | Detecting an intrusive landing page |
US8037529B1 (en) * | 2008-03-19 | 2011-10-11 | Symantec Corporation | Buffer overflow vulnerability detection and patch generation system and method |
US8745703B2 (en) * | 2008-06-24 | 2014-06-03 | Microsoft Corporation | Identifying exploitation of vulnerabilities using error report |
US8095987B2 (en) * | 2008-09-04 | 2012-01-10 | Microsoft Corporation | Software anti-piracy protection |
US11489857B2 (en) | 2009-04-21 | 2022-11-01 | Webroot Inc. | System and method for developing a risk profile for an internet resource |
US20110202995A1 (en) * | 2010-02-16 | 2011-08-18 | Honeywell International Inc. | Single hardware platform multiple software redundancy |
US8925091B2 (en) * | 2011-09-01 | 2014-12-30 | Dell Products, Lp | System and method for evaluation in a collaborative security assurance system |
US9003532B2 (en) * | 2011-09-15 | 2015-04-07 | Raytheon Company | Providing a network-accessible malware analysis |
US9141805B2 (en) * | 2011-09-16 | 2015-09-22 | Rapid7 LLC | Methods and systems for improved risk scoring of vulnerabilities |
RU2487405C1 (en) * | 2011-11-24 | 2013-07-10 | Закрытое акционерное общество "Лаборатория Касперского" | System and method for correcting antivirus records |
US9715325B1 (en) | 2012-06-21 | 2017-07-25 | Open Text Corporation | Activity stream based interaction |
US9392003B2 (en) | 2012-08-23 | 2016-07-12 | Raytheon Foreground Security, Inc. | Internet security cyber threat reporting system and method |
US9256746B2 (en) * | 2012-12-14 | 2016-02-09 | Vmware, Inc. | Device and method for remediating vulnerabilities |
US20140359077A1 (en) * | 2013-05-30 | 2014-12-04 | Qualcomm Incorporated | Method and apparatus for transmitting symbol files |
RU2571721C2 (en) * | 2014-03-20 | 2015-12-20 | Закрытое акционерное общество "Лаборатория Касперского" | System and method of detecting fraudulent online transactions |
US10284593B1 (en) * | 2015-01-15 | 2019-05-07 | EMC IP Holding Company LLC | Protecting newly restored clients from computer viruses |
JP6284039B2 (en) * | 2015-06-03 | 2018-02-28 | パナソニックIpマネジメント株式会社 | Stockout management device and stockout management method |
WO2017137804A1 (en) * | 2016-02-11 | 2017-08-17 | Morphisec Information Security Ltd. | Automated classification of exploits based on runtime environmental features |
US9973522B2 (en) | 2016-07-08 | 2018-05-15 | Accenture Global Solutions Limited | Identifying network security risks |
US10268825B2 (en) * | 2016-12-01 | 2019-04-23 | International Business Machines Corporation | Amalgamating code vulnerabilities across projects |
US10409582B1 (en) * | 2017-07-21 | 2019-09-10 | Jpmorgan Chase Bank, N.A. | Method and system for implementing a retail event management tool |
JP2019192956A (en) * | 2018-04-18 | 2019-10-31 | コニカミノルタ株式会社 | Information processing device, image formation device, image formation system, and virus check method |
US11570199B2 (en) | 2020-12-23 | 2023-01-31 | Intel Corporation | Threat prevention by selective feature deprivation |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5960170A (en) * | 1997-03-18 | 1999-09-28 | Trend Micro, Inc. | Event triggered iterative virus detection |
US20040088581A1 (en) * | 2002-11-04 | 2004-05-06 | Brawn John Melvin | Signal level propagation mechanism for distribution of a payload to vulnerable systems |
US20040127195A1 (en) * | 2002-12-28 | 2004-07-01 | Ki Chul An | Mobile communication system and mobile terminal having function of inactivating mobile communication viruses, and method thereof |
US20040153644A1 (en) * | 2003-02-05 | 2004-08-05 | Mccorkendale Bruce | Preventing execution of potentially malicious software |
US20050198527A1 (en) * | 2004-03-08 | 2005-09-08 | International Business Machiness Corporation | Method, system, and computer program product for computer system vulnerability analysis and fortification |
US20070256132A2 (en) * | 2003-07-01 | 2007-11-01 | Securityprofiling, Inc. | Vulnerability and remediation database |
US8561190B2 (en) * | 2005-05-16 | 2013-10-15 | Microsoft Corporation | System and method of opportunistically protecting a computer from malware |
Family Cites Families (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6374287B1 (en) * | 1996-01-24 | 2002-04-16 | Sun Microsystems, Inc. | Method and system for allowing client processes to run on distributed window server extensions |
US7133897B1 (en) * | 1999-11-18 | 2006-11-07 | International Business Machines Corporation | Method to import/export or detach/attach a file to/from a remote mail server |
US20050131811A1 (en) * | 2000-02-10 | 2005-06-16 | Ranzini Stephen L. | System and method for message handling |
JP2005532606A (en) * | 2001-12-31 | 2005-10-27 | シタデル セキュリティ ソフトウェア インコーポレイテッド | An automated system that resolves computer vulnerabilities |
US7359962B2 (en) * | 2002-04-30 | 2008-04-15 | 3Com Corporation | Network security system integration |
CN1705938A (en) * | 2002-10-22 | 2005-12-07 | 崔云虎 | Integrated emergency response system in information infrastructure and operating method therefor |
US7761917B1 (en) * | 2002-11-21 | 2010-07-20 | Vmware, Inc. | Method and apparatus for the detection and prevention of intrusions, computer worms, and denial of service attacks |
US7296293B2 (en) * | 2002-12-31 | 2007-11-13 | Symantec Corporation | Using a benevolent worm to assess and correct computer security vulnerabilities |
US7523501B2 (en) * | 2003-07-21 | 2009-04-21 | Trend Micro, Inc. | Adaptive computer worm filter and methods of use thereof |
US7260844B1 (en) * | 2003-09-03 | 2007-08-21 | Arcsight, Inc. | Threat detection in a network security system |
US7437764B1 (en) * | 2003-11-14 | 2008-10-14 | Symantec Corporation | Vulnerability assessment of disk images |
US7475427B2 (en) * | 2003-12-12 | 2009-01-06 | International Business Machines Corporation | Apparatus, methods and computer programs for identifying or managing vulnerabilities within a data processing network |
US20050172280A1 (en) * | 2004-01-29 | 2005-08-04 | Ziegler Jeremy R. | System and method for preintegration of updates to an operating system |
US7568230B2 (en) * | 2004-06-09 | 2009-07-28 | Lieberman Software Corporation | System for selective disablement and locking out of computer system objects |
US7694150B1 (en) * | 2004-06-22 | 2010-04-06 | Cisco Technology, Inc | System and methods for integration of behavioral and signature based security |
US7434261B2 (en) * | 2004-09-27 | 2008-10-07 | Microsoft Corporation | System and method of identifying the source of an attack on a computer network |
US7568233B1 (en) * | 2005-04-01 | 2009-07-28 | Symantec Corporation | Detecting malicious software through process dump scanning |
-
2005
- 2005-05-16 US US11/130,570 patent/US8561190B2/en active Active
-
2013
- 2013-09-12 US US14/025,799 patent/US20140020103A1/en not_active Abandoned
- 2013-09-13 US US14/026,226 patent/US20140020104A1/en not_active Abandoned
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5960170A (en) * | 1997-03-18 | 1999-09-28 | Trend Micro, Inc. | Event triggered iterative virus detection |
US20040088581A1 (en) * | 2002-11-04 | 2004-05-06 | Brawn John Melvin | Signal level propagation mechanism for distribution of a payload to vulnerable systems |
US20040127195A1 (en) * | 2002-12-28 | 2004-07-01 | Ki Chul An | Mobile communication system and mobile terminal having function of inactivating mobile communication viruses, and method thereof |
US20040153644A1 (en) * | 2003-02-05 | 2004-08-05 | Mccorkendale Bruce | Preventing execution of potentially malicious software |
US20070256132A2 (en) * | 2003-07-01 | 2007-11-01 | Securityprofiling, Inc. | Vulnerability and remediation database |
US20050198527A1 (en) * | 2004-03-08 | 2005-09-08 | International Business Machiness Corporation | Method, system, and computer program product for computer system vulnerability analysis and fortification |
US8561190B2 (en) * | 2005-05-16 | 2013-10-15 | Microsoft Corporation | System and method of opportunistically protecting a computer from malware |
Non-Patent Citations (1)
Title |
---|
Curtsinger et al., âZozzle: Fast and Precise In-Browser JavaScript Malware Detectionâ, 2011, 16 pages * |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108900323A (en) * | 2018-06-11 | 2018-11-27 | 广州视源电子科技股份有限公司 | Communication method, device, equipment and medium |
Also Published As
Publication number | Publication date |
---|---|
US8561190B2 (en) | 2013-10-15 |
US20060259974A1 (en) | 2006-11-16 |
US20140020104A1 (en) | 2014-01-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8561190B2 (en) | System and method of opportunistically protecting a computer from malware | |
JP7460696B2 (en) | Real-time detection and protection from malware and steganography in kernel mode | |
US8239944B1 (en) | Reducing malware signature set size through server-side processing | |
US10599841B2 (en) | System and method for reverse command shell detection | |
US9542556B2 (en) | Malware family identification using profile signatures | |
EP2754081B1 (en) | Dynamic cleaning for malware using cloud technology | |
US8381298B2 (en) | Malware detention for suspected malware | |
US7650639B2 (en) | System and method for protecting a limited resource computer from malware | |
US10726125B2 (en) | Malware detection using clustering with malware source information | |
US7571482B2 (en) | Automated rootkit detector | |
US8819835B2 (en) | Silent-mode signature testing in anti-malware processing | |
US8127358B1 (en) | Thin client for computer security applications | |
US8719924B1 (en) | Method and apparatus for detecting harmful software | |
US9015829B2 (en) | Preventing and responding to disabling of malware protection software | |
US20070162975A1 (en) | Efficient collection of data | |
US20120102568A1 (en) | System and method for malware alerting based on analysis of historical network and process activity | |
EP2417552B1 (en) | Malware determination | |
Sheikh | Trojans, Backdoors, Viruses, and Worms | |
RU2673407C1 (en) | System and method for identifying malicious files | |
CN117278288A (en) | Network attack protection method and device, electronic equipment and storage medium |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC, WASHINGTON Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICROSOFT CORPORATION;REEL/FRAME:034544/0541 Effective date: 20141014 |
|
AS | Assignment |
Owner name: MICROSOFT CORPORATION, WASHINGTON Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:MARINESCU, ADRIAN M.;SEINFELD, MARC E.;BRAVERMAN, MATTHEW I.;SIGNING DATES FROM 20050510 TO 20050516;REEL/FRAME:037455/0688 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO PAY ISSUE FEE |