This invention relates generally to network security, and more particularly provides a system and method for implementing content and network security inside a chip.
The internet is an interconnection of millions of individual computer networks owned by governments, universities, nonprofit groups, companies and individuals. While the internet is a great source of valuable information and entertainment, the internet has also become a major source of system damaging and system fatal application code, such as “viruses,” “spyware,” “adware,” “worms,” “Trojan horses,” and other malicious code.
To protect users, programmers design computer and computer-network security systems for blocking malicious code from attacking both individual and network computers. On the most part, network security systems have been relatively successful. A computer that connects to the internet from within an enterprise's network typically has two lines of defense. The first line of defense includes a network security system, which may be part of the network gateway, that includes firewalls, anti-virus, anti-spyware and content filtering. The second line of defense includes individual security software on individual machines, which is not typically as secure as the network security system and is thus more vulnerable to attacks. In combination, the first and second lines of defense together provide pretty good security protection. However, when a device connects to the internet without the intervening network security system, the device loses its first line of defense. Thus, mobile devices (e.g., laptops, desktops, PDAs such as RIM's Blackberry, cell phones, any wireless device that connects to the internet, etc.) when traveling outside the enterprise network are more vulnerable to attacks.
As the number of mobile devices and the number of attacks grow, mobile security is becoming increasingly important. The problem was emphasized in the recent Info-Security Conference in New York on Dec. 7-8, 2005. However, no complete solutions were presented.
There is a need for personal security appliances capable of providing levels of network security as provided by enterprise network security systems.
An embodiment of the present invention uses a small piece of hardware that connects to a mobile device and filters out attacks and malicious code. The piece of hardware may be referred to as a “mobile security system” or “personal security appliance.” Using the mobile security system, a mobile device can be protected by greater security and possibly by the same level of security offered by its associated corporation/enterprise.
In an embodiment, a mobile security system includes a connection mechanism for connecting to a data port of a mobile device and for communicating with the mobile device; a network connection module for acting as a gateway to a network; a security policy for determining whether to forward content intended for the mobile device to the mobile device; and a security engine for executing the security policy.
The connection mechanism may include at least one of a USB connector, a PCMCIA connector, an Ethernet connector, an internal computer bus, a computer local bus, memory bus, network bus, hard disks bus, serial bus, parallel bus and/or a BlueTooth communication module. The network connection module may include a network interface card that implements WiFi, WiMAX, GPRS, GSM, UMTS, CDMA, Generation 3, other cell phone internet connection protocols, etc. The security engine may include at least one of an antivirus engine, an antispyware engine, a firewall engine, an IPS/IDS engine, a content filtering engine, a multilayered security monitor, a bytecode monitor, and a URL monitor. The security policy may performs weighted risk analysis based on content type, content source, content category, or historical actions of the user. The remote management module may be capable of receiving security policy updates, security engine updates, and security data updates (including malicious content signatures). The mobile security system may include a distribution module capable of forwarding updates to other mobile security systems, and/or a backup module capable of storing at least a portion of the boot sector of the mobile device should the boot sector of the mobile device become compromised. The mobile security system may include a remote configuration module capable of communicating with a wizard, the wizard being in communication with an enterprise network security system, the wizard capable of substantially automatic generation of policies and data based on the policies and data on the enterprise network security system, the remote configuration module capable of installing the policies and data generated by the wizard. The mobile security system may include a preboot memory that is not accessible during runtime, the preboot memory storing a copy of at least a portion of the operating system of the mobile security system, the mobile security system being configured to load the operating system portion every time the mobile security system is rebooted.
In another embodiment, a method comprises receiving a network connection request from a mobile device outside of a trusted network; acting as a gateway to a network on behalf of the mobile device; receiving information intended for the mobile device from the network; and determining whether to forward the information to the mobile device in accordance with a security policy.
In another embodiment, a mobile security system comprises means for acting as a gateway to a network on behalf of a mobile device outside of a trusted network; receiving information intended for the mobile device from the network; and determining whether to forward the information to the mobile device in accordance with a security policy.
In yet another embodiment, a method comprises receiving internet traffic on a mobile device via a wireless connection; redirecting the internet traffic at the kernel level to a mobile security system; scanning the internet traffic for violations of a security policy; cleaning the internet traffic of any violations of the security policy to generate cleaned internet traffic; and sending the cleaned internet traffic to the mobile device for execution.
In still another embodiment, a system comprises a wireless network interface card on a mobile device for receiving internet traffic; a kernel-level redirector on the mobile device for redirecting the internet traffic at the kernel level to a mobile security system; a security engine for scanning the internet traffic for violations of a security policy and for cleaning the internet traffic of any violations of the security policy to generate cleaned internet traffic; and a connection mechanism for receiving the redirected internet traffic from the kernel-level redirector and for sending the cleaned internet traffic to the mobile device for execution.
Systems and methods for implementing content and network security inside a chip are disclosed. In exemplary embodiments, a system comprises a communication chip and a second processor. The communication chip comprises a router and security instructions. The router is configured to intercept untrusted data between a network and a first router. The second processor is configured to receive the untrusted data from the router, process the untrusted data with the security instructions to produce trusted data, and provide the trusted data to the router.
The security instructions may comprise an operating system. The security instructions may also be stored in a protected memory. The security instructions may be loaded into RAM of a digital device.
The communication chip may be within a network interface card. The second processor may be within the communication chip. The first processor may comprise the second processor
In other embodiments, the system comprises a flash memory device and a second processor. The flash memory device may comprise flash memory media, a router, and security instructions. The router may be configured to intercept untrusted data between a first processor and the flash memory media. The second processor may be configured to receive the untrusted data from the router, to process the untrusted data with the security instructions to produce trusted data, and to provide the trusted data to the router.
In some embodiments, a method comprises storing security instructions, loading the security instructions into a memory, executing the security instructions with a second processor, intercepting untrusted data between a network and a first processor with a router in a communication chip, routing the untrusted data from the router to the second processor, processing the untrusted data with the second processor executing the security instructions to produce trusted data, and providing the trusted data from the second processor to the router.
Alternatively, a method may comprise, in some embodiments, storing security instructions, loading the security instructions into a memory, executing the security instructions with a second processor, intercepting untrusted data between a first processor and flash memory media, routing the untrusted data from the router to the second processor, processing the untrusted data with the second processor executing the security instructions to produce trusted data, and providing the trusted data from the second processor to the router.
An exemplary computer readable medium is configured to store instructions in a communication chip, the instructions executable by a processor to perform a method. The method comprises, before reaching a destination, intercepting untrusted data between a network and a first processor within in a communication chip, routing the untrusted data to the second processor, processing the untrusted data with the second processor executing the security instructions to produce trusted data, and providing the trusted data from the second processor to the data's destination.
An exemplary computer readable medium is configured to store instructions in a flash memory device, the instructions executable by a processor to perform a method. The method comprises, before reaching a destination, intercepting untrusted data between a first processor and flash memory media within the flash memory device, routing the untrusted data to the second processor, processing the untrusted data with the second processor executing the security instructions to produce trusted data, and providing the trusted data from the second processor to the data's destination.
The following description is provided to enable any person skilled in the art to make and use the invention, and is provided in the context of a particular application and its requirements. Various modifications to the embodiments may be possible to those skilled in the art, and the generic principles defined herein may be applied to these and other embodiments and applications without departing from the spirit and scope of the invention. Thus, the present invention is not intended to be limited to the embodiments shown, but is to be accorded the widest scope consistent with the principles, features and teachings disclosed herein.
An embodiment of the present invention uses a small piece of hardware that connects to a mobile device and filters out attacks and malicious code. The piece of hardware may be referred to as a “mobile security system” or “personal security appliance.” Using the mobile security system, a mobile device can be protected by greater security and possibly by the same level of security offered by its associated corporation/enterprise.
Demarcation 335 divides the trusted enterprise 340 and the untrusted publicly accessible internet 330. Each of mobile device 310a, 310b and 310c may be referred to generically as mobile device 310, although they need not be identical. Each mobile security system 345a and 345b may be referred to generically as mobile security system 345, although they need not be identical.
As shown, although the mobile device 310c has traveled outside the trusted enterprise 340, the mobile device 310c connects to the untrusted internet 330 via the mobile security system 345b and thus retains two lines of defense (namely, the mobile security system 345b and the security software resident on the device itself). In this embodiment, the mobile security system 345 effectively acts as a mobile internet gateway on behalf of the mobile device 310c. In an embodiment, the mobile security system 345 may be a device dedicated to network security. In an embodiment, each mobile security system 345 may support multiple mobile devices 310, and possibly only registered mobile devices 310, e.g., those belonging to enterprise 340.
Each mobile security system 345 (e.g., 345a, 345b) may be a miniature server, based on commercial hardware (with Intel's Xscale or any other CPU as the core), Linux OS and network services, and open-source firewall, IDS/IPS and antivirus protection. The mobile security system 345 may be based on a hardened embedded Linux 2.6.
In this embodiment, because the security administrator 325 is capable of remotely communicating with the mobile security system 345b, IT can monitor and/or update the security policies/data/engines implemented on the mobile security system 345b. The security administrator 325 can centrally manage all enterprise devices, remotely or directly. Further, the security administrator 325 and mobile security systems 345 can interact to automatically translate enterprise security policies into mobile security policies and configure mobile security systems 345 accordingly. Because the mobile security system 345 may be generated from the relevant security policies of the enterprise 340, the mobile device 310c currently traveling may have the same level of protection as the devices 305/310 within the trusted enterprise 340.
The mobile security system 345 may be designed as an add-on to existing software security or to replace all security hardware and software on a traveling mobile device. These security applications will preferably operate on different OSI layers to provide maximum security and malicious code detection, as shown in the example system illustrated in
The data storage device 430 and/or memory 435 may store an operating system 440 such as the Microsoft Windows XP, the IBM OS/2 operating system, the MAC OS, UNIX OS, LINUX OS and/or other programs 445. It will be appreciated that a preferred embodiment may also be implemented on platforms and operating systems other than those mentioned. An embodiment may be written using JAVA, C, and/or C++ language, or other programming languages, possibly using object oriented programming methodology.
One skilled in the art will recognize that the computer system 400 may also include additional information, such as network connections, additional memory, additional processors, LANs, input/output lines for transferring information across a hardware channel, the internet or an intranet, etc. One skilled in the art will also recognize that the programs and data may be received by and stored in the system in alternative ways. For example, a computer-readable storage medium (CRSM) reader 450 such as a magnetic disk drive, hard disk drive, magneto-optical reader, CPU, etc. may be coupled to the communications bus 410 for reading a computer-readable storage medium (CRSM) 455 such as a magnetic disk, a hard disk, a magneto-optical disk, RAM, etc. Accordingly, the computer system 400 may receive programs and/or data via the CRSM reader 450. Further, it will be appreciated that the term “memory” herein is intended to cover all data storage media whether permanent or temporary.
The adapters/ports/drivers 505 include connection mechanisms (including software, e.g., drivers) for USB, Ethernet, WiFi, WiMAX, GSM, CDMA, BlueTooth, PCMCIA, an Internal computer bus, a computer local bus, memory bus, network bus, hard disks bus, serial or parallel bus, and/or other connection data ports on the mobile security system 345. In one embodiment, the adapters/ports/drivers 505 may be capable of connection to multiple devices 310 to provide network security to the multiple devices 310.
Memory 510 and processor 515 execute the operating system and applications on the mobile security system 345. In this example, the preboot flash 520 stores the operating system and applications. At boot time, the operating system and applications are loaded from the preboot flash 520 into memory 510 for execution. Since the operating system and applications are stored in the preboot flash 520, which cannot be accessed during runtime by the user, the operating system and applications in the preboot flash 520 are not corruptible. Should the copy of the operating system and applications in memory 510 be corrupted, e.g., by malicious code, the operating system and applications may be reloaded into the memory 510 from the preboot flash 520, e.g., upon restart. Although described as stored within the preboot flash 520, the OS and applications can be securely stored within other read-only memory devices, such as ROM, PROM, EEPROM, etc.
As shown in
Upon each “hard” restart, the boot loader (resident at area 1 in read only memory 570) of the mobile security system 345 copies the kernel and security applications (a fresh unchanged copy) from read only memory 570 to random access memory 575. This causes a clean version of the OS and applications to be loaded into random access memory 575 each time. That way, if a special attack on mobile security system 345 is developed, the attack will be unable to infect the system, since the OS and applications are precluded from accessing read only memory 570 during runtime. Further, any attack that does reach memory 510 will be able to run only once and will disappear upon a hard restart. A triggering mechanism may be available to restart the mobile security system 345 automatically upon infection detection.
The network connection module 525 enables network connection, e.g., to the internet 330 or the intranet 315 via network communication hardware/software including WiFi, WiMAX, CDMA, GSM, GPRS, Ethernet, modem, etc. For example, if the mobile device 310 wishes to connect to the internet 330 via a WiFi connection, the adapters/ports/drivers 505 may be connected to the PCI port, USB port or PCMCIA port of the mobile device 310, and the network connection module 525 of the mobile security system 345 may include a WiFi network interface card for connecting to wireless access points. Using the network connection module 425, the mobile security system 345 may communicate with the network as a secure gateway for the mobile device 310. Other connection architectures are described in
The security engines 530 execute security programs based on the security policies 535 and on security data 540, both of which may be developed by IT managers. Security engines 530 may include firewalls, VPN, IPS/IDS, anti-virus, anti-spyware, malicious content filtering, multilayered security monitors, Java and bytecode monitors, etc. Each security engine 530 may have dedicated security policies 535 and security data 540 to indicate which procedures, content, URLs, system calls, etc. the engines 530 may or may not allow. The security engines 530, security policies 535 and security data 540 may be the same as, a subset of, and/or developed from the engines, policies and data on the network security system 320.
To provide a higher security level provided by antivirus and antispyware software, the security engines 530 on each mobile security system 345 may implement content analysis and risk assessment algorithms. Operating for example at OSI Layer 7 and above (mobile code encapsulated within Layer 7), these algorithms may be executed by dedicated High Risk Content Filtering (HRCF) that can be controlled by a rules engine and rule updates. The HRCF will be based on a powerful detection library that can perform deep content analysis to verify real content types. This is because many attacks are hidden within wrong mime types and/or may use sophisticated tricks to present a text file type to a dangerous active script or ActiveX content type. The HRCF may integrate with a URL categorization security engine 530 for automatic rule adjustment based on the URL category. In one embodiment, when the risk level increases (using the described mechanism) the mobile security system 345 may automatically adjust and increase filtering to remove more active content from the traffic. For example, if greater risk is determined, every piece of mobile code, e.g., Java script, VB script, etc. may be stripped out.
Three aspects for integration with corporate policy server legacy systems include rules, LDAP and active directory, and logging and reporting as discussed below. In one embodiment, a policy import agent running on the security administrator 325 will access the rule base of Checkpoint Firewall-1 and Cisco PIX Firewalls and import them into a local copy. A rule analysis module will process the important rules and will offer out-of-the-box rules and policies for mobile security systems 345. This proposed policy will offer all mobile security systems 345 a best fit of rules that conform the firewall policy of the enterprise 340. The agent will run periodically to reflect any changes and generate updates for mobile security system 345 policies 535. The LDAP and Active Directory may be integrated with the directory service to maintain mobile security system 345 security policies 535 that respond to the enterprise's directory definitions. For example, a corporate policy for LDAP user Group “G” may automatically propagate to all mobile security systems 345 in “G” group. Mobile security system 345 local logs and audit trails may be sent in accordance to a logging and reporting policy to a central log stored at the security administrator 325. Using a web interface, IT may be able to generate reports and audit views related to all mobile device 310 users, their internet experiences, and attempts to bring infected devices back to the enterprise 340. IT will be able to forward events and log records into legacy management systems via SYSLOG and SNMP Traps.
The security engines 530 may perform weighted risk analysis. For example, the security engine 530 may analyze content transferred via protocols such as HTTP, FTP, SMTP, POP3, IM, P2P, network layer 1 to layer 6 (based on OSI model), SCSI, iSCSI, IDE, ATA, SATA and other hard disk protocols, etc. including any traffic arriving from the internet 330. The security engine 530 may assign a weight and rank for every object based on its type, complexity, richness in abilities, source of the object, etc. The security engine 530 may assign weight based on the source using a list of known dangerous or known safe sources. The security engine 530 may assign weight to objects based on the category of the source, e.g., a gambling source, an adult content source, a news source, a reputable company source, a banking source, etc. The security engine 530 may calculate the weight, and based on the result determine whether to allow or disallow access to the content, the script to run, the system modification to occur, etc. The security engine 530 may “learn” user content (by analyzing for a predetermined period of time the general content that the user accesses) and accordingly may create personal content profiles. The personal content profile may be used to calibrate the weight assigned to content during runtime analysis to improve accuracy and tailor weighted risk analysis for specific user characteristics.
In some embodiments, the security engines 530, security policies 535 and security data 540 may enable bypassing the mobile security system 345. The security policy 535, set by the security administrator 325, may include a special attribute to force network connection through the mobile security system 325 when outside the trusted enterprise 340. Thus, if this attribute is set “on,” when a mobile device 310 attempts to connect to the internet 330 without the mobile security system 345 and not from within the trusted enterprise 340, all data transfer connections including LAN connection, USB-net, modem, Bluetooth, WiFi, etc. may be closed. The mobile device 310 may be totally isolated and unable to connect to any network, including the internet 330.
In one embodiment, to enable this, when first connecting the mobile security system 345 to the mobile device 310 using for example the USB cable (for both power and USB connection creation), the USB plug & play device driver will be sent into the mobile device 310. The installed driver may be “Linux.inf” which allows a USB-net connection for the mobile security system 345. This connection allows the mobile security system 345 to access the internet 330 via the USB port and using the mobile device 310 network connection plus additional code (“the connection client”). In a Windows example, the connection client may be installed at the NDIS level of the mobile device 310 above all the network interface cards of every network connection as shown in
It will be appreciated that NDIS is one possible implementation of intercepting traffic at the kernel level. For example, in another embodiment, the system may hook Winsock or apply other ways that may be in future Windows versions.
In an embodiment where the mobile security system 345 supports multiple mobile devices 310, the security engines 530, security policies 535 and security data 540 may be different for each mobile device 310 (e.g., based on for example user preferences or IT decision). Alternatively, it can apply the same engines 530, policies 535 and data 540 for all connected devices 310.
The remote management module 550 enables communication with security administrator 325 (and/or other security administrators), and enables local updating of security engines 530, security policies 535, security data 540 including signatures and other applications. In one embodiment, modification to the security policies 535 and data 540 can be done by the security administrator 325 only. The remote management module 550 of the mobile security system 345 may receive updates from an update authorities device (UAD), e.g., on the security administrator 325 via a secured connection. A UAD may operate on an update server at a customer IT center located on the internet 330 to forward updates to mobile security systems 345 that possibly do not belong to an enterprise 540 in charge of managing updates. A UAD may operate on a mobile security system 345. Security engine 530 updates may modify the antivirus engine DLL, etc. OS and security application updates may be implemented only from within the enterprise 540 while connecting to the security administrator 325 and via an encrypted and authenticated connection.
The security administrator 325 can modify URL black and white lists for remote support to traveling users. In case of false positives, the security administrator 325 may allow access to certain URLs, by bypassing the proactive heuristics security but still monitoring by firewall, antivirus, IPS/IDS, etc. Additional remote device-management features may enable the security administrator 325 to perform remote diagnostics, access local logs, change configuration parameters, etc. on the mobile security system 345. The security administrator 325 may delegate tasks to a helpdesk for support.
The remote management module 550 may communicate with a wizard (e.g., wizard 745), which may be on the security administrator 325, as illustrated in
The distribution module 555 enables distribution of updates, e.g., security policy 535 updates including rule updates, security data 540 updates including signature updates, security engine 530 updates, application/OS updates, etc. by the mobile security system 345 to N other mobile security systems 345. A routing table identifying the N other mobile security systems 345 to whom to forward the updates may be provided to the distribution module 555 to enable system 345 to system 345 communication. Updates may be implemented according to policies set by the security administrator 325. When forwarding updates, the distribution module 555 acts as a UAD.
Each mobile security system 345 may obtain its routing table with security information updates, periodically, at predetermined times, upon login, etc. The routing tables may be maintained on a server, e.g., the security administrator 325 or another mobile security system 345. In one embodiment, the mobile security systems 345 may contact the server to retrieve the routing tables. Alternatively, the server may push the routing tables to the mobile security systems 345.
The distribution module 555 may enable rapid updates as shown in
The backup module 560 may constantly backup image and changes of the boot sector and system files of the mobile device 310 into the flash memory 520 or into another persistent memory device. That way, in case of major failure, including a loss of the system or boot sector of the mobile device 310, the mobile security system 345 may be identified as a CD-ROM during reboot and may launch the backup module (or separate program) to restore the boot sector and system files on the mobile device 310, thereby recovering the mobile device 310 without the need for IT support. In an embodiment where the network security system 345 supports multiple mobile devices 310, the backup module 560 may contain separate boot sector and system files for each of the mobile devices 310, if different.
The security administrator 325 includes a wizard 745 for enabling substantially automatic initial and possibly dynamic setup of the security engines 530, security policies 535 and security data 540 on the mobile security system 345. In one embodiment, the wizard 745 may automatically load all security engines 705 and policies and data 710 of the network security system 320 as the security engines 530 and policies and data 535/540 on the mobile security system 345. In another embodiment, the wizard 745 may include all security engines 705 and policies and data 710 except those known to be irrelevant, e.g., those related to billing software used by accounting, those relating to web software running only on the web servers, etc. In another embodiment, the engines 530 would need to be loaded by an IT manager, and would not be loaded automatically by the wizard 745.
In one embodiment, the wizard 745 may determine whether the mobile security system 345 requires a particular security engine 530, e.g., an antivirus engine 755, IPS/IDS engine 760, firewall engine 765, etc. If so determined, then the wizard 745 would load the engine 530 onto the mobile security system 345. The wizard 745 would then determine which policies and data sets, e.g., some for antivirus engine 755, some for the IPS/IDS engine 760, some for the firewall engine 765, etc. are important to the mobile security system 345. The wizard 745 will then determine which of the antivirus policies and data 730 on the network security system 320 are relevant to the antivirus policies and data 770 on the mobile security system 345, which of the IPS/IDS policies and data 735 on the network security system 320 are relevant to the IPS/IDS policies and data 775 on the mobile security system 345, which of the firewall policies and data 740 on the network security system 320 are relevant to the firewall policies and data 780 on the mobile security system 345, and which of the other policies and data on the network security system 320 are relevant to the policies and data on the mobile security system 345. As stated above, the wizard 745 may determine that all security engines 705 or just a subset are needed on the mobile security system 345. The wizard 745 may determine that all policies and data 710 for a given engine type or just a subset should be forwarded. The wizard 745 may determine which relevant policies and data 710 should be forwarded to the mobile security system 345 based on rules developed by an IT manager, based on item-by-item selection during the setup procedure, etc. Alternative to the wizard 745, an IT manager can setup the engines 530 and policies and data 535/540 on the mobile security system 345 without the wizard 745.
The security administrator 325 may also include an update authorities device 750. The update authorities device 750 may obtain security system updates (e.g., signature updates) and may send the updates to the network security system 320 and to the mobile security system 345. One skilled in the art will recognize that the updates to the network security system 320 and the updates to the mobile security system 345 need not be the same. Further, the update authorities device 750 may obtain the updates from security managers, security engine developers, antivirus specialists, etc. The update authorities device 750 may forward the updates to all network security systems 320 and all mobile security systems 345, or may forward routing tables to all mobile security systems 345 and the updates only to an initial set of mobile security systems 345. The initial set of mobile security systems 345 may forward the updates to the mobile security systems 345 identified in the routing tables in a P2P manner, similar to the process illustrated in
Other applications may be included on the mobile security system 345. For example, add-on applications for recurring revenue from existing customers may include general email, anti-spam, direct and secured email delivery, information vaults, safe skype and other instant messaging services, etc.
Although not shown, a small battery may be included with the mobile security system 345. This battery may be charged by the USB connection during runtime or using the power adapter at any time. The battery may guarantee proper shutdown, e.g., when user disconnects the USB cable from the mobile security system 345. It will be signaled by the system which will launch applications and system shutdown. This will ensure a proper state of the file system and flashing open files buffers.
A multi-layered defense and detection abilities is required. This may be done by a special code that is constantly monitoring the scanning result by different systems (antivirus, IDS/IPS, firewall, antispyware, URL category, etc.) and at different levels to build a puzzle and identify an attack even if its not recognized by each of the individual subsystems. By doing this, the mobile security system 345 will maintain and in some cases even improve the security level provided within the enterprise 540.
One available benefit of the mobile security system 345 is its ability to enforce the policy of the enterprise 540 on the end user while they are traveling or working from home. Since the mobile security system 345 uses similar security engines and policy as when connected from within the enterprise 540 and since the end user cannot access the internet 330 without it (except via VPN connection into the enterprise 540), IT may be capable of enforcing its security policy beyond the boundaries of the enterprise 540. The OS may be under the entire supervision of IT, while the mobile security system 345 OS acts as an end user OS under his control. This resolves the problems of who controls what and how security and productivity face minimal compromise.
A standalone version of the mobile security system 345 may offer the same functionality, and may provide a local management interface via web browser. Attractive to home users and small offices that lack an IT department, the mobile security system 345 enables the end user to launch a browser, connect to the mobile security system 345, set the different policies (update policy, security rules, etc.) including modifying the white and black URL lists, etc. There is also an opportunity to provide end users with a service of remote management of the mobile security systems 345 by subscription.
The security block 1102 may reside in a digital device (e.g., any device with memory and a processor). In various embodiments, the security block 1102 may reside in flash memory devices, communication chips, or processors (e.g., network processors, general purpose processors, communication processors, or DSPs). The security block 1102 may comprise instructions 1116 (e.g., security instructions such as for security applications) associated with a variety of programs (e.g., applications) including a firewall, network address translator (NAT), VPN client, intrusion detection and prevention system, HTTP proxy, FTP proxy, POP3 proxy, SMTP proxy, anti-virus program, anti-spyware program, anti-phishing program, anti-spam program, URL CAT, L-8 security engine, MLA security agent, DRM application, anti-leakage program, malicious content filter, multilayered security monitor, Java monitor, bytecode monitor and/or data access client.
In various embodiments, the processor 1104 is configured by the instructions 1116 to analyze data for the presence of malicious code (e.g., malware). The processor 1104 may comprise circuitry capable of processing the instructions 1116. In some embodiments, the processor 1104 is virtualized. In other embodiments, the processor 1104 comprises a CPU, DSP, FPGA, or any processing unit.
The memory module 1106 includes memory (e.g., RAM, ROM, preboot flash 520, or a ram cache). The instructions 1116 may be loaded into the memory module 1106.
The storage module 1108 is any storage configured to retrieve and store data. Some examples of the storage module 1108 are flash media, hard drives, optical drives, and/or magnetic tape. In some embodiments, the security block 1102 includes a memory module 1106 in the form of RAM and a storage module 1108 in the form of flash memory. Both the memory module 1106 and the storage module 1108 comprise computer readable media which may store instructions or programs that are executable by a computer processor including the processor 1104.
The security router 1110 is any device that receives data over link 1114. In some embodiments, the security router 1110 is coupled to a network (e.g., internet 130) via the link 1114. Further, the security router 1110 may also support wired and/or wireless communication (e.g., 802.11 a/b/g/n, WiMax).
The security block 1102 as well as one or more of the components of the security block 1102 (e.g., processor 1104, the memory module 1106, the storage module 1108, and the security router 1110) may be virtualized. Further, those skilled in the art will appreciate that the security block 1102 may be a part of a larger digital device. In one example, the processor 1104 used by the security block 1102 may be the same processor used by the digital device.
Further, the memory module 1106 may comprise all or a portion of RAM memory within a digital device with one or more other components. In one example, a digital device may comprise 2 gigabytes of RAM memory. Some or all of that memory may be shared by the CPU of the digital device and the memory module 1106. In one example, the CPU scans data, cleans data, analyzes data, or otherwise protects the digital device from malware.
Similarly, the storage module 1108 may comprise all or a portion of the storage of the digital device. In one example, the digital device may comprise a one terabyte hard drive. Some or all of the one terabyte hard drive may be shared with the storage module 1108. In one example, the storage of the digital device stores instructions 1116.
Those skilled in the art will appreciate that the security block 1102 may comprise more processors, modules, security routers, and/or other components than those depicted in
In various embodiments, a digital device comprises a processor such as a CPU. The processor 1104 may comprise all or a portion of the processor of the digital device. In one example, the communication chip 1202 may be in communication with the processor within the digital device. The processor 1104 within the security block 1102 may comprise all or a portion of the processor within a digital device (e.g., the digital device and the security block 1102 share the same processor).
In various embodiments, the communication chip 1202 receives data to be distributed over one or more communication channels (e.g., comm. channel 1206a-1206c). Data may also be received from the communication channels to be provided over link 1114 (e.g., to a network in communication with the communication chip 1202).
In various embodiments, untrusted data is received by the communication chip 1202 from a network (not depicted) over the link 1114. The security router 1110 of the security block 1102 may receive the data from the link 1114. The processor 1104 may process the untrusted data using instructions associated with one or more security programs. The instructions may be loaded in the memory module 1106. In one example, the instructions comprise an antivirus program that instructs the processor 1104 to scan the untrusted data for malware. In some embodiments, once the process by the processor 1104 is completed, the security router 1110 will provide the trusted data (i.e., data that has been processed by the processor 1104 using instructions associated with the one or more security programs) to the communication controller 1204. The communication controller 1204 may provide the trusted data to one or more communication channels (e.g., communication channels 1206a-1206c). In one example, the communication controller 1204 functions as a standard communication controller on a standard communication chip when data is received.
In various embodiments, the processor 1104 executes one or more various security programs while processing the untrusted data. These one or more security programs include, for example, a firewall, network address translator (NAT), VPN client, intrusion detection and prevention system, HTTP proxy, FTP proxy, POP3 proxy, SMTP proxy, anti-virus program, anti-spyware program, anti-phishing program, anti-spam program, URL CAT, L-8 security engine, MLA security agent, DRM application, anti-leakage program, malicious content filter, multilayered security monitor, Java monitor, bytecode monitor and/or data access client.
In one example, the processor 1104 executes a firewall that prevents the security router 1110 from routing data to the communication controller 1204. In another example, the processor 1104 executes an antivirus program that scans and removes viruses from untrusted data. The cleaned data (i.e., trusted data) may be provided by the security router 1110 to the communication controller 1204.
Further, in some embodiments, untrusted data may be received by the communication chip 1202 over one or more of the communication channels 1206a-1206c. The untrusted data may then be received by the communication controller 1204 and provided to the security router 1110. The processor 1104 then processes the untrusted data with instructions associated with one or more security programs to produce trusted data. The security router 1110 may then transmit the trusted data over the link 1114.
Those skilled in the art will appreciate that the communication chip 1202 may comprise any number of components beyond those displayed in
In various embodiments, the computing device 1302 is modified to route data and content between the security block 1102 and the communication module 1306, the processor 1308, the memory module 1310, and the storage module 1312. In one example, the computing device 1302 performs security checks and performs malicious content removal on the fly. In various embodiments, the computing device 1302 comprises a PC, desktop PC, Mobile Phone, Server, network processor, communication controller, NAS processor, router processor, wireless communication processor, or digital device etc.
In various embodiments, the communication module 1306 is any interface configured to communicate data between the computing device 1302 and a digital device. The processor 1308 may be similar to the processor 1104. In one example, the processor 1308 is virtualized. In other examples, the processor 1306 comprises a CPU, DSP, FPGA, or any processing unit. In some embodiments, the processor 1306 and the processor 1104 may be the same processor.
The memory module 1310 may be similar to the memory module 1106. In one example, the memory module 1310 includes memory (e.g., RAM, ROM, preboot flash 520, or a ram cache). In some embodiments, the memory module 1310 and the memory module 1106 may be the same memory.
The storage module 1312 may be similar to the storage module 1108. In one example, the storage module 1312 may be any storage configured to retrieve and store data. Some examples of the storage module 1312 are flash media, hard drives, optical drives, and/or magnetic tape. In some embodiments, the storage module 1312 and the storage module 1108 may be the same storage.
Those skilled in the art will appreciate that the computing device 1302 may comprise more or less blocks, processors, and modules, than depicted in
In various embodiments, the flash memory device 1402 receives data to be stored in the memory banks 1406a-1406c. The memory banks 1406a-1406c may comprise any kind of flash memory, including, but not limited to, NAND or NOR flash. Further, the memory banks 1406a-1406c may comprise different kinds of flash memory (e.g., bank 1406A may comprise NAND flash memory and bank 1408B may comprise NOR flash memory).
In various embodiments, untrusted data is received by the flash memory device 1402 from a network or digital device (not depicted) over a memory data bus operatively coupled to the link 1114. In one example, the security router 1114 intercepts untrusted data associated with a write command. The security router 1110 of the security block 1102 may receive the data from the link 1114. The processor 1104 may process the untrusted data using instructions associated with one or more security programs. In some embodiments, once the process by the processor 1104 is completed, the security router 1110 will provide the trusted data to the memory controller 1404. The memory controller 1404 may then function as a standard memory controller and provide the trusted data to one or more memory banks (e.g., memory banks 1406a-1406c).
Further, in some embodiments such as when a read command is executed to read data from the memory bank(s), untrusted data may be received by the memory controller 1404 from the media banks 1406a-1406c and provided to the security router 1110. The processor 1104 then processes the untrusted data with instructions associated with one or more security programs to produce trusted data. The security router 1110 may then transmit the trusted data over the link 1114.
Those skilled in the art will appreciate that the flash memory device 1402 may comprise any number of components beyond those displayed in
Although
In some embodiments, the one or more of the memory banks 1406a-1406c are shared by the memory module 1106 and/or the storage module 1106. In one example, a portion of the memory bank 1406a may be protected (e.g., a portion of memory in the memory bank 1406a is read-only). The protected portion of memory within memory bank 1406a may function as the memory module 1106 and/or the storage module 1108 (e.g., a place in memory in which instructions associated with one or more security programs are stored and/or loaded).
Those skilled in the art will appreciate that device disclosed in
Although
In some embodiments, once the data is trusted (e.g., processed using the security programs prior to storage), the trusted data is retrieved by the digital device 1502 and further processing is not performed. In one example, the security router 1110 is configured to make the determination whether received data is trusted or untrusted prior to processing.
In step 1506, the security router 1110 receives untrusted data from the digital device 1502. In one example, data to be stored in the flash memory media 1504 is intercepted by the security router 1110. The security router 1110 may then identify the data as untrusted. In one example, the security router 1110 is configured to determine the source of the data and whether the data has been previously processed with one or more security programs. In step 1508, the security router 1110 provides the data to the processor 1104. In one example, the security router 1110 provides only untrusted data for processing by the processor 1104.
In step 1510, the processor 1104 secures the data by processing the untrusted data using instructions associated with one or more security programs. In some embodiments, the untrusted data may be quarantined or blocked from being stored in the flash memory media 1504. In one example, malware, such as a virus, is found in the untrusted data. Information regarding the infection may be logged and an alarm provided to the user of the digital device. The untrusted data may then be stored (for further analysis, for example) or deleted.
Assuming that some or all of the untrusted data is not adversely affected by malware, the processor 1104 sends the portion of unaffected data (i.e., trusted data) to the security router 1110 in step 1512. The security router 1110 may determine that the recently received data is trusted (e.g., by virtue of receiving the data from the processor 1104 of the security block 1102), and then route the trusted data to the flash memory media 1504 in step 1514. The flash memory media 1504 may then store the trusted data.
In some embodiments, the digital device 1502 retrieves data from the flash memory media 1504. The retrieved data may comprise all, some, or none of the data that was previously stored in the flash memory media 1504 in steps 1506-1514.
In step 1516, the security router receives the data (e.g., via the memory controller 1404) from the flash memory media 1504. In some embodiments, the security router 1110 determines if the data has been previously processed with instructions associated with the one or more security programs prior to storage. If the data had been previously processed with the instructions, then the security router 1110 may provide the data to the digital device 1502 without further processing. However, if the data had not been previously processed or the data was previously processed by instructions associated with out-of-date security programs (e.g., the virus definitions of an anti-virus program are not current), then the security router 1110 may provide the data to the processor 1104 for processing in step 1518.
In step 1520, the processor 1104 secures the retrieved data. In one example, the processor 1104 processes the retrieved data with instructions (i.e., associated with the security programs) loaded into the memory module 1106, the processor 1104 may send data that is not affected by malware or a hacker (e.g., trusted data) to the security router 1110 in step 1522. The security router 1110 may then route the trusted data to the digital device 1502 in step 1524.
In step 1606, the security router 1110 routes the intercepted untrusted data to the processor 1104. In some embodiments, the security router 1110 may scan data received by the security router 1110 to determine if the data has already been processed by the processor 1104. If the data has already been processed by the processor 1104, then the security router 1110 may provide the data to the second digital device 1602 without passing the data to the processor 1104.
In step 1608, the processor 1104 processes the untrusted data from the security router 1110 with instructions related to one or more security programs. If the untrusted data does not contain malware or the untrusted data is not associated with malware, a hacker, or an unauthorized user, the processor 1104 may send the trusted data back to the security router 1110 in step 1610. In one example, a malware bot resident on the first digital device 1502 may send out packets of data to probe open ports on the second digital device 1602. The security router 1110 may intercept the probe packets and provide the packets to the processor 1104 which determines that the data is either associated with a bot or related to forbidden activity (i.e., probing open ports). The processor 1104 may, for example, instruct the security router 1110 to log the event, quarantine the probe packets, and/or delete the probe packets.
In various embodiments, the processor 1104 may scan the untrusted data to determine if the intended recipient of the data is authorized to receive the data. In one example, the processor 1104 may check if the untrusted data is confidential and that the intended receiver is authorized to receive the data in order to prevent the leakage of confidential information. If the receiver is not authorized to receive the data, the data may be barred from being sent (e.g., data transmission is denied or stopped).
In some embodiments, the processor 1104 may return trusted data to the security router 1110 with an indicator, such as a flag, to indicate to the security router 1110 that the data from the processor 1104 is trusted and/or has been processed. The security router 1110 may route the trusted data to the second digital device 1602 in step 1612.
As discussed herein, in various embodiments, the same security router 1110 may intercept data sent from the first digital device 1502 to the second digital device 1602 as well as intercept data sent from the second digital device 1602 to the first digital device 1502. In step 1614, the security router 1110 intercepts untrusted data sent by the second digital device 1602 to the first digital device 1502. The security router 1110 may then route the untrusted data to the processor 1104 in step 1616.
In step 1618, the processor 1104 processes the untrusted data with the instructions associated with one or more security programs. Trusted data (e.g., data that is not affected by malware or is otherwise unrelated to malware) is sent to the security router 1110 in step 1620. The security router 1110 may then route the trusted data to the first digital device 1502 in step 1622.
In step 1704, the security instructions are loaded from the storage into memory. In some embodiments, the security instructions are loaded from the storage module 1108 to the memory module 1106. For example, the storage module 1108 may comprise ROM and the memory module 1106 may comprise RAM.
In some embodiments, the security instructions are loaded from the protected storage module 1108 to the memory module 1106 upon startup, bootup, or reboot of the security block 1102. The security instructions may include instructions for executing one or more security programs as well as an operating system and/or any data necessary to execute the security programs. In some embodiments, all data necessary to execute the one or more security programs are loaded from protected storage to RAM so that the security instructions used to process untrusted data are not corrupted or adversely affected by malware, system error, and/or users.
In step 1706, the processor 1104 executes the security instructions. In one example, the processor 1104 boots an operating system and executes the security programs from the protected storage to prepare to receive untrusted data from the security router 1110.
In step 1708, the security router 1110 receives untrusted data. In various embodiments, the security router 1110 intercepts untrusted data between the untrusted data's source and the untrusted data's destination. The security router 1110 may receive and/or intercept data, in some examples, between two digital devices, between a processor such as a CPU and storage, or between a processor and memory. In step 1710, the security router 1110 routes the untrusted data to the processor 1104.
In step 1712, the processor 1104 processes the untrusted data to produce trusted data. In various examples, the processor 1104 executes the security instructions loaded from storage to the memory to process the untrusted data. In one example, the processor 1104 scans the untrusted data for a virus. If the untrusted data comprises a virus, the processor 1104 may, based on the security instructions for an anti-virus program, remove the virus from the untrusted data, quarantine the untrusted data, delete the untrusted data, and/or log information regarding the virus. The processor 1104 may provide the unaffected remaining data (i.e., the trusted data), if any data exists after processing, back to the security router 1110 in step 1714.
In step 1716, the security router 1110 may then route the trusted data to the data's original destination. In some embodiments, the processor 1104 may instruct the security router 1110 to take one or more actions including, but not limited to, quarantining the original untrusted data, logging information about the original untrusted data, and/or barring data received from the source of the original untrusted data.
The foregoing description of the preferred embodiments of the present invention is by way of example only, and other variations and modifications of the above-described embodiments and methods are possible in light of the foregoing teaching. Although the network sites are being described as separate and distinct sites, one skilled in the art will recognize that these sites may be a part of an integral site, may each include portions of multiple sites, or may include combinations of single and multiple sites. The various embodiments set forth herein may be implemented utilizing hardware, software, or any desired combination thereof. For that matter, any type of logic may be utilized which is capable of implementing the various functionality set forth herein. Components may be implemented using a programmed general purpose digital computer, using application specific integrated circuits, or using a network of interconnected conventional components and circuits. Connections may be wired, wireless, modem, etc. The embodiments described herein are not intended to be exhaustive or limiting. The present invention is limited only by the following claims.
Further, the each term “comprising,” “including,” “having,” “with,” and “containing” is inclusive or open-ended and does not exclude additional, unrecited elements or method steps.
This application is a continuation of U.S. patent application Ser. No. 17/362,412, filed Jun. 29, 2021 and entitled “System and Method for Implementing Content and Network Security Inside a Chip,” now U.S. Pat. No. 11,757,835, which is a continuation of U.S. patent application Ser. No. 16/389,886, filed Apr. 19, 2019 and entitled “System and Method for Implementing Content and Network Security Inside a Chip,” now U.S. Pat. No. 11,050,712, which is a continuation of U.S. patent application Ser. No. 14/520,314, filed Oct. 21, 2014 and entitled “System and Method for Implementing Content and Network Security Inside a Chip,” now U.S. Pat. No. 10,541,969, which is a continuation of U.S. patent application Ser. No. 12/402,443, filed Mar. 11, 2009 and entitled “System and Method for Implementing Content and Network Security Inside a Chip,” now U.S. Pat. No. 8,869,270, which claims priority to U.S. Provisional Patent Application Ser. No. 61/039,729, filed Mar. 26, 2008 and entitled “Methods for Implementing Content and Network security Inside Communication and Memory Chips,” which are incorporated by reference herein. This application also incorporates by reference U.S. patent application Ser. No. 11/376,919, filed Mar. 15, 2006 and entitled “System and Method for Providing Network Security to Mobile Devices,” now U.S. Pat. No. 8,381,297, which claims priority to U.S. Provisional Patent Application Ser. No. 60/750,326, filed Dec. 13, 2005 and entitled “Personal Security Appliance,” which is also incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
H1944 | Cheswick | Feb 2001 | H |
6286087 | Ito | Sep 2001 | B1 |
6466779 | Moles | Oct 2002 | B1 |
6725294 | Moore et al. | Apr 2004 | B1 |
6772345 | Shetty | Aug 2004 | B1 |
6813682 | Bress | Nov 2004 | B2 |
7036143 | Leung | Apr 2006 | B1 |
7065644 | Daniell | Jun 2006 | B2 |
7069330 | McArdle | Jun 2006 | B1 |
7076690 | Todd | Jul 2006 | B1 |
7086089 | Hrastar | Aug 2006 | B2 |
7131141 | Blewett | Oct 2006 | B1 |
7168089 | Nguyen | Jan 2007 | B2 |
D537036 | Chen | Feb 2007 | S |
7184554 | Freese | Feb 2007 | B2 |
7197638 | Grawrock | Mar 2007 | B1 |
7283542 | Mitchell | Oct 2007 | B2 |
7353533 | Wright | Apr 2008 | B2 |
7359983 | Maufer | Apr 2008 | B1 |
7360242 | Syvanne | Apr 2008 | B2 |
7418253 | Kavanagh | Aug 2008 | B2 |
7529932 | Haustein | May 2009 | B1 |
7539828 | Lomnes | May 2009 | B2 |
7657941 | Zaitsev | Feb 2010 | B1 |
7665137 | Barton | Feb 2010 | B1 |
7818803 | Gordon | Oct 2010 | B2 |
7894480 | Wang et al. | Feb 2011 | B1 |
7908476 | Kandasamy | Mar 2011 | B2 |
7971258 | Liao et al. | Jun 2011 | B1 |
7984479 | Brabson | Jul 2011 | B2 |
7992199 | Winick | Aug 2011 | B1 |
8145733 | Cheng et al. | Mar 2012 | B1 |
8180654 | Berkman | May 2012 | B2 |
8218449 | Taylor | Jul 2012 | B2 |
8218558 | Tan | Jul 2012 | B2 |
8234261 | Monahan | Jul 2012 | B2 |
8239531 | Bellovin | Aug 2012 | B1 |
8266670 | Merkow | Sep 2012 | B1 |
8321934 | Cooley | Nov 2012 | B1 |
8365272 | Touboul | Jan 2013 | B2 |
8402528 | McCorkendale | Mar 2013 | B1 |
8495290 | Sugar et al. | Jul 2013 | B2 |
8495700 | Shahbazi | Jul 2013 | B2 |
8631488 | Oz | Jan 2014 | B2 |
RE45009 | Vange et al. | Jul 2014 | E |
8789202 | Touboul et al. | Jul 2014 | B2 |
8904523 | Gordon | Dec 2014 | B2 |
8978132 | Henry | Mar 2015 | B2 |
9202070 | Rajakarunanayake et al. | Dec 2015 | B2 |
9332028 | Xaypanya | May 2016 | B2 |
9438631 | Bettini | Sep 2016 | B2 |
9565202 | Kindlund | Feb 2017 | B1 |
9747444 | Touboul | Aug 2017 | B1 |
9762614 | Ely | Sep 2017 | B2 |
9832603 | Schlaupitz | Nov 2017 | B2 |
9847020 | Davis | Dec 2017 | B2 |
9910979 | Ben-Haim | Mar 2018 | B2 |
9916439 | Jakubowski et al. | Mar 2018 | B2 |
10162975 | Ely | Dec 2018 | B2 |
10291656 | Ely | May 2019 | B2 |
10417421 | Touboul | Sep 2019 | B2 |
10496834 | Ely | Dec 2019 | B2 |
10666688 | Ely | May 2020 | B2 |
11316905 | Ely | Apr 2022 | B2 |
11743297 | Ely | Aug 2023 | B2 |
11979370 | McDonald | May 2024 | B2 |
12026261 | Wyatt | Jul 2024 | B2 |
20010014102 | Mattingly | Aug 2001 | A1 |
20020095540 | Zolnowsky | Jul 2002 | A1 |
20020111824 | Grainger | Aug 2002 | A1 |
20020193015 | Milan | Dec 2002 | A1 |
20030046397 | Trace | Mar 2003 | A1 |
20030055994 | Herrmann | Mar 2003 | A1 |
20030070084 | Satomaa | Apr 2003 | A1 |
20030084319 | Tarquini et al. | May 2003 | A1 |
20030097431 | Dill | May 2003 | A1 |
20030097589 | Syvanne | May 2003 | A1 |
20030110391 | Wolff | Jun 2003 | A1 |
20030126468 | Markham | Jul 2003 | A1 |
20030131245 | Linderman | Jul 2003 | A1 |
20030142683 | Lam | Jul 2003 | A1 |
20030148656 | Huang | Aug 2003 | A1 |
20030182415 | Vicard | Sep 2003 | A1 |
20030224758 | O'Neill | Dec 2003 | A1 |
20030229808 | Heintz et al. | Dec 2003 | A1 |
20040003262 | England | Jan 2004 | A1 |
20040019656 | Smith | Jan 2004 | A1 |
20040064575 | Rasheed | Apr 2004 | A1 |
20040078568 | Pham et al. | Apr 2004 | A1 |
20040085944 | Boehm | May 2004 | A1 |
20040093520 | Lee | May 2004 | A1 |
20040123153 | Wright | Jun 2004 | A1 |
20040148450 | Chen et al. | Jul 2004 | A1 |
20040177274 | Aroya | Sep 2004 | A1 |
20040199763 | Freund | Oct 2004 | A1 |
20040203296 | Moreton | Oct 2004 | A1 |
20040210775 | Gbadegesin | Oct 2004 | A1 |
20040237079 | Cox | Nov 2004 | A1 |
20050055578 | Wright | Mar 2005 | A1 |
20050091522 | Hearn | Apr 2005 | A1 |
20050109841 | Ryan | May 2005 | A1 |
20050114711 | Hesselink | May 2005 | A1 |
20050114870 | Song | May 2005 | A1 |
20050149757 | Corbett | Jul 2005 | A1 |
20050182883 | Overtoom | Aug 2005 | A1 |
20050208967 | Buniatyan | Sep 2005 | A1 |
20050254455 | Plehn | Nov 2005 | A1 |
20050260996 | Groenendaal | Nov 2005 | A1 |
20050265385 | Cromer | Dec 2005 | A1 |
20050278544 | Baxter | Dec 2005 | A1 |
20060020723 | Chia-Chun | Jan 2006 | A1 |
20060022802 | Bridgelall | Feb 2006 | A1 |
20060031940 | Rozman | Feb 2006 | A1 |
20060037071 | Rao | Feb 2006 | A1 |
20060056317 | Manning | Mar 2006 | A1 |
20060059092 | Burshan | Mar 2006 | A1 |
20060064391 | Petrov | Mar 2006 | A1 |
20060070129 | Sobel et al. | Mar 2006 | A1 |
20060074896 | Thomas | Apr 2006 | A1 |
20060075494 | Bertman | Apr 2006 | A1 |
20060075501 | Thomas | Apr 2006 | A1 |
20060085528 | Thomas | Apr 2006 | A1 |
20060095595 | Dalton et al. | May 2006 | A1 |
20060101277 | Meenan et al. | May 2006 | A1 |
20060161985 | Zhao | Jul 2006 | A1 |
20060174342 | Zaheer | Aug 2006 | A1 |
20060206300 | Garg et al. | Sep 2006 | A1 |
20060224794 | Stevens | Oct 2006 | A1 |
20060229741 | Achanta | Oct 2006 | A1 |
20060230199 | Yu | Oct 2006 | A1 |
20060242686 | Toda | Oct 2006 | A1 |
20060272020 | Gardner | Nov 2006 | A1 |
20060277405 | Bowler | Dec 2006 | A1 |
20070005987 | Durham | Jan 2007 | A1 |
20070022474 | Rowett | Jan 2007 | A1 |
20070050426 | Dubal et al. | Mar 2007 | A1 |
20070058642 | Eisink | Mar 2007 | A1 |
20070061887 | Hoover | Mar 2007 | A1 |
20070083939 | Fruhauf | Apr 2007 | A1 |
20070097976 | Wood | May 2007 | A1 |
20070104197 | King | May 2007 | A1 |
20070110053 | Soni et al. | May 2007 | A1 |
20070118874 | Adams | May 2007 | A1 |
20070118893 | Crawford | May 2007 | A1 |
20070123214 | Mock | May 2007 | A1 |
20070124536 | Carper | May 2007 | A1 |
20070130433 | Safa | Jun 2007 | A1 |
20070130457 | Kamat | Jun 2007 | A1 |
20070143827 | Nicodemus | Jun 2007 | A1 |
20070143851 | Nicodemus | Jun 2007 | A1 |
20070162582 | Belali et al. | Jul 2007 | A1 |
20070192500 | Lum | Aug 2007 | A1 |
20070192854 | Kelley | Aug 2007 | A1 |
20070199060 | Touboul | Aug 2007 | A1 |
20070199061 | Byres | Aug 2007 | A1 |
20070209067 | Fogel | Sep 2007 | A1 |
20070214369 | Roberts | Sep 2007 | A1 |
20070220187 | Kates | Sep 2007 | A1 |
20070233842 | Roberts | Oct 2007 | A1 |
20070240217 | Tuvell | Oct 2007 | A1 |
20070261112 | Todd | Nov 2007 | A1 |
20070266265 | Zmudzinski | Nov 2007 | A1 |
20070281664 | Kaneko | Dec 2007 | A1 |
20070294744 | Alessio | Dec 2007 | A1 |
20080016339 | Shukla | Jan 2008 | A1 |
20080034419 | Mullick | Feb 2008 | A1 |
20080066148 | Lim | Mar 2008 | A1 |
20080083030 | Durham et al. | Apr 2008 | A1 |
20080083037 | Kruse | Apr 2008 | A1 |
20080084799 | Repasi | Apr 2008 | A1 |
20080098478 | Vaidya | Apr 2008 | A1 |
20080109871 | Jacobs | May 2008 | A1 |
20080114990 | Hilbert | May 2008 | A1 |
20080120423 | Hall et al. | May 2008 | A1 |
20080134163 | Golde | Jun 2008 | A1 |
20080141349 | Lyle | Jun 2008 | A1 |
20080165957 | Kandasamy et al. | Jul 2008 | A1 |
20080201264 | Brown | Aug 2008 | A1 |
20080235755 | Blaisdell | Sep 2008 | A1 |
20080282337 | Crawford | Nov 2008 | A1 |
20080307240 | Dahan et al. | Dec 2008 | A1 |
20090019223 | Lection | Jan 2009 | A1 |
20090054075 | Boejer | Feb 2009 | A1 |
20090106556 | Hamid | Apr 2009 | A1 |
20090135751 | Hodges et al. | May 2009 | A1 |
20090143057 | Arun et al. | Jun 2009 | A1 |
20090165132 | Jain | Jun 2009 | A1 |
20090249465 | Touboul | Oct 2009 | A1 |
20090253454 | Sampson | Oct 2009 | A1 |
20090254993 | Leone | Oct 2009 | A1 |
20100064341 | Aldera | Mar 2010 | A1 |
20100186093 | Aussel | Jul 2010 | A1 |
20100195833 | Priestley | Aug 2010 | A1 |
20100218012 | Joseph et al. | Aug 2010 | A1 |
20100225493 | Zishaan | Sep 2010 | A1 |
20100242109 | Lee | Sep 2010 | A1 |
20100251369 | Grant | Sep 2010 | A1 |
20100269172 | Xie | Oct 2010 | A1 |
20100333088 | Rogel | Dec 2010 | A1 |
20110023118 | Wright | Jan 2011 | A1 |
20110154443 | Thakur | Jun 2011 | A1 |
20110154477 | Parla | Jun 2011 | A1 |
20110182180 | Riddle | Jul 2011 | A1 |
20110264931 | Chang et al. | Oct 2011 | A1 |
20110268106 | Dalton, Jr. | Nov 2011 | A1 |
20110269397 | Bella | Nov 2011 | A1 |
20110296397 | Vidal et al. | Dec 2011 | A1 |
20120005756 | Hoefelmeyer | Jan 2012 | A1 |
20120030750 | Bhargava et al. | Feb 2012 | A1 |
20120042391 | Risan | Feb 2012 | A1 |
20120054744 | Singh | Mar 2012 | A1 |
20120084831 | Hu | Apr 2012 | A1 |
20120110320 | Kumar | May 2012 | A1 |
20120110331 | Falk | May 2012 | A1 |
20120149350 | Fan | Jun 2012 | A1 |
20120173609 | Kulaga | Jul 2012 | A1 |
20120185846 | Recio | Jul 2012 | A1 |
20120216273 | Rolette | Aug 2012 | A1 |
20120233695 | Mahaffey | Sep 2012 | A1 |
20120239739 | Manglik | Sep 2012 | A1 |
20120240183 | Sinha | Sep 2012 | A1 |
20120240236 | Wyatt | Sep 2012 | A1 |
20120278543 | Yu et al. | Nov 2012 | A1 |
20120303971 | Palka | Nov 2012 | A1 |
20120324504 | Archer et al. | Dec 2012 | A1 |
20130031601 | Bott | Jan 2013 | A1 |
20130064373 | Hagbard | Mar 2013 | A1 |
20130074144 | Narayanaswamy | Mar 2013 | A1 |
20130091534 | Gilde | Apr 2013 | A1 |
20130097659 | Das | Apr 2013 | A1 |
20130097660 | Das | Apr 2013 | A1 |
20130254829 | Jakubowski | Sep 2013 | A1 |
20140032314 | Gieseke | Jan 2014 | A1 |
20140058679 | Varoglu | Feb 2014 | A1 |
20140317679 | Wade | Oct 2014 | A1 |
20160105847 | Smith | Apr 2016 | A1 |
20160234204 | Rishi | Aug 2016 | A1 |
20170039367 | Ionescu | Feb 2017 | A1 |
20170103647 | Davis | Apr 2017 | A1 |
20190238538 | Shaw et al. | Aug 2019 | A1 |
20190268302 | McDonald | Aug 2019 | A1 |
20200285752 | Wyatt et al. | Sep 2020 | A1 |
20230076156 | Abotabl et al. | Mar 2023 | A1 |
Number | Date | Country |
---|---|---|
2000078008 | Dec 2000 | WO |
2004030308 | Apr 2004 | WO |
2006069041 | Jun 2006 | WO |
2007110094 | Oct 2007 | WO |
2008154726 | Dec 2008 | WO |
2009004452 | Jan 2009 | WO |
2010004296 | Jan 2010 | WO |
2013016663 | Jan 2013 | WO |
Entry |
---|
Breeden II, John et al., “A Hardware Firewall You Take With You,” Government Computer News, located at http:/gcn.com/Articles/2005/06/01/A-hardware-firewall-you-take-with-you.aspx?p=1, Jun. 1, 2005. |
Claessens, Joris et al., “(How) Can Mobile Agents Do Secure Electronic Transactions on Mobile Hosts? A Survey of the Security Issues and the Current Solutions,” ACM Transactions on Internet Technology, vol. 3, No. 1, pp. 28-48, Feb. 2003. |
CyberGuard Corporation, “Model 1: Wireless Mobile Security Appliance,” located at http://support2.cyberguard.com/products/oem/model1.htm, 2005. |
Dong et al., “An Opportunistic Scheduler to Balance Performance Measures and Energy Consumption in Wireless Networks: Design and Implementation,” Proceedings of the First International Conference on Wireless Internet (WICON'05) (Year: 2005), Conference Paper, Publisher: IEEE, 8 pages. |
Entry, Inc., “CyberGuard Develops a Custom Mobile Security Appliance,” SecurityProNews, located at http://www.securitypronews.com/news/securitynews/spn-45-20041007CyberGuardDevelo . . . , Oct. 7, 2004. |
Fielding, R. et al., “Hypertext Transfer Protocol—HTTP/1.1,” I.E.T.F. Network Working Group, RFC 2616, Jun. 1999. |
Hall, Marty, “Core Web Programming: Chapter 16—The Hypertext Transfer Protocol,” Prentice Hall PTR, ISBN 0-13-625666-X, pp. 867-911, Dec. 1997. |
Hall, Marty, “More Servlets and JavaServer Pages Chapter 2—A Fast Introduction to Basic Servlet Programming,” Prentice Hall PTR, ISBN 0-13-067614-4, pp. 34-118, Dec. 1997. |
“Helping Users Deal with Digital Threats: The Online User Supervision Architecture”, Living with Insecurity, IEEE Security & Privacy, IEEE Computer and Reliability Societies, downloaded from <URL: https://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=5959149>, Nov./Dec. 2011 (Year: 2011), pp. 29-35. |
Henmi, Anne et al., “Firewall Policies and VPN Configurations,” Syngress Publishing, Inc., ISBN 1-59749-088-1, pp. 99-133, 291-313, Dec. 2006. |
Jakobsson, Markus, “Invasive Browser Sniffing and Countermeasures,” Proceedings of the 15th International Conference on World Wide Web, pp. 523-532, May 23, 2006. |
Kent, S. et al., “Security Architecture for the Internet Protocol,” I.E.T.F. Network Working Group, RFC 4301, pp. 10-11, Dec. 2005. |
Lee, Henry C.J. et al., “Port Hopping for Resilient Networks,” IEEE 60th Vehicular Technology Conference (VTC2004), Sep. 26, 2004. |
Liang et al., “Passive Wake-up Scheme for Wireless Sensor Networks”, Second International Conference on Innovative Computing, Information and Control, 2007, 4 pages. |
Lim et al., “Adaptice power controllable retrodirective array system for wireless sensor server applications”, IEEE Transactions on Microwave Theory and Techniques, vol. 53, No. 12, Dec. 2005, pp. 3735-3743. |
“Method and System to Provide Automatic Parental Control in Television Broadcasting Environment”, downloaded through IP.com, IP.com No. IPCOM000221537D, Sep. 7, 2012 (Year: 2012), 3 pages. |
O'Brien, Kevin J., “Microsoft Hit by Antitrust Complaint for Browser,” The International Herald Tribune, Dec. 14, 2007. |
PMC-Sierra, Inc., “MSP8120 Multi-Service Security Processor,” Product Brief, 2007. |
Prevelakis, Vassilis et al., “Drop-In Security for Distributed and Portable Computing Elements,” Internet Research: Electronic Networking, Applications and Policy, vol. 13, No. 2, pp. 107-115, located at http://www.cs.columbia.edu/˜angelos/Papers/InternetResearch-Final.pdf, 2003. |
Russo, Alejandro, et al., “Securing Interaction Between Threads and the Scheduler,” Proceedings of the 19th IEEE Computer Security Foundations Workshop ( CSFW'06), (Year: 2006), Conference Paper, Publisher: IEEE, 13 pages. |
Sen, Subhabrata et al., “Accurate, Scalable In-Network, Identification of P2P Traffic Using Application Signatures,” Proceedings of the 13th International Conference on World Wide Web, pp. 512-521, May 17, 2004. |
Shreeve, Jimmy Lee, “Hasta la Vista, Microsoft!; It's Faster than Windows, It Fights Viruses—and It's Free,” Independent Extra, Aug. 29, 2007. |
Shuler, Rus, “How Does the Internet Work,” white paper, 2002 [retrieved online at https://web.stanford.edu/class/msande91si/www-spr04/readings/week1/InternetWhitepaper.htm on Dec. 11, 2018]. |
Srisuresh, P. et al., “IP Network Address Translator (NAT) Terminology and Considerations,” I.E.T.F. Network Working Group, RFC 2663, Aug. 1999. |
Srisuresh, P. et al., “Traditional IP Network Address Translator (Traditional NAT),” I.E.T.F. Network Working Group, RFC 3022, Jan. 2001. |
WatchGuard Technologies, Inc., “Mobile User VPN and PPTP,” Internet Security Handbook, copyright 1998-2001, pp. 1-2, located at http://www.watchguard.com/help/lss/41 /handbook/vpn3.htm, believe published Jun. 5, 2003. |
World Wide Web Consortium (W3C), “HTTP Request Fields,” May 3, 1994 [retrieved online at https://web.archive.org/web/20060110150527/http://www.w3.org:80/Protocols/HTTP/HTRQ_Headers.html on Jan. 24, 2019]. |
ZyXEL Communications Corp., “ZyXEL Releases Worlds First Palm-Sized Portable Personal Firewall for Ultimate Security: ZyWALL P1 Pushes Network Security to the End-Point PC's with Minimum Administration Effort,” ZyXEL News, located at http://global.zyxel.com/news/press.php?indexflag=20050310013432, Mar. 8, 2005. |
European Patent Application No. 06821641.5, Examination Report dated Dec. 16, 2016. |
European Patent Application No. 06821641.5, Search Report dated May 17, 2011. |
European Patent Application No. 08847968.8, Search Report dated Oct. 25, 2011. |
European Patent Application No. 13845746.0, Search Report dated Jun. 7, 2016. |
International Application No. PCT/IL2006/001428, International Search Report and Written Opinion dated Jul. 15, 2008. |
International Application No. PCT/IL2008/000740, International Search Report and Written Opinion dated Nov. 5, 2008. |
International Application No. PCT/US2008/055942, International Search Report and Written Opinion dated Apr. 6, 2009. |
International Application No. PCT/US2009/065204, International Search Report and Written Opinion dated Jan. 13, 2010. |
International Application No. PCT/US2013/064161, International Search Report and Written Opinion dated Apr. 18, 2014. |
International Application No. PCT/US2014/045826, International Search Report and Written Opinion dated Oct. 30, 2014. |
International Application No. PCT/US2015/015970, International Search Report and Written Opinion dated May 28, 2015. |
Decision—Institution of Inter Partes Review of U.S. Pat. No. 9,781,164 entered Jun. 25, 2019, 28 pages. |
Decision—Institution of Inter Partes Review of U.S. Pat. No. 8,631,488 entered Aug. 28, 2019, 39 pages. |
Decision—Institution of Inter Partes Review of U.S. Pat. No. 9,106,683 entered Aug. 28, 2019, 39 pages. |
Decision—Institution of Inter Partes Review of U.S. Pat. No. 9,843,595 entered Aug. 28, 2019, 33 pages. |
Decision—Institution of Inter Partes Review of U.S. Pat. No. 8,365,272 entered Jul. 26, 2019, 27 pages. |
Decision—Institution of Inter Partes Review of U.S. Pat. No. 9,756,079 entered Jul. 26, 2019, 32 pages. |
Decision—Institution of Inter Partes Review of U.S. Pat. No. 8,789,202 entered Sep. 18, 2019, 33 pages. |
Trend Micro Inc. v. CUPP Computing AS, IPR2019-00765, U.S. Pat. No. 9,843,595, Judgment Final Written Decision Determining All Challenged Claims Unpatentable entered Aug. 25, 2020, 47 pages. |
Trend Micro Inc. v. CUPP Computing AS, IPR2019-00803, U.S. Pat. No. 8,789,202, Judgment Final Written Decision Determining No Challenged Claims Unpatentable entered Sep. 15, 2020, 30 pages. |
CUPP Cybersecurity, LLC and CUPP Computing AS v. Trend Micro, Inc., Trend Micro America, Inc., and Trend Micro Incorporated, Case No. 3:20-cv-03206-K, Complaint for Patent Infringement, filed Oct. 20, 2020, 99 pages. |
CUPP Cybersecurity, LLC and CUPP Computing AS v. Trend Micro, Inc., Trend Micro America, Inc., and Trend Micro Incorporated, Case No. 20-cv-03206-M, First Amended Complaint for Patent Infringement, filed Apr. 23, 2021, 140 pages. |
Decision Granting Institution of Inter Partes Review of U.S. Pat. No. 10,621,344 entered Oct. 25, 2021, 38 pages. |
Decision Granting Institution of Inter Partes Review of U.S. Pat. No. 10,951,632 entered Jan. 19, 2022, IPR2021-01236, 46 pages. |
Decision Granting Institution of Inter Partes Review of U.S. Pat. No. 10,951,632 entered Jan. 19, 2022, IPR2021-01237, 25 pages. |
Trend Micro Inc. v. CUPP Computing AS, IPR2021-00813, U.S. Pat. No. 10,621,344, Judgment Final Written Decision Determining All Challenged Claims Unpatentable entered Oct. 14, 2022, 41 pages. |
Trend Micro Inc. v. CUPP Computing AS, IPR2021-01236, U.S. Pat. No. 10,951,632, Judgment Final Written Decision Determining All Challenged Claims Unpatentable entered Jan. 17, 2023, 49 pages. |
Trend Micro Inc. v. CUPP Computing AS, IPR2021-01237, U.S. Pat. No. 10,951,632, Judgment Final Written Decision Determining All Challenged Claims Unpatentable entered Jan. 17, 2023, 30 pages. |
Inter Partes Review Certificate, U.S. Pat. No. 9,781,164 K1, issued May 12, 2023, 2 pages. |
Inter Partes Review Certificate, U.S. Pat. No. 8,631,488 K1, issued Jun. 21, 2023, 2 pages. |
Inter Partes Review Certificate, U.S. Pat. No. 9,106,683 K1, issued Jun. 21, 2023, 2 pages. |
Inter Partes Review Certificate, U.S. Pat. No. 9,843,595 K1, issued Jun. 21, 2023, 2 pages. |
Inter Partes Review Certificate, U.S. Pat. No. 8,365,272 K1, issued Jul. 5, 2023, 2 pages. |
Inter Partes Review Certificate, U.S. Pat. No. 9,756,079 K1, issued Jul. 7, 2023, 2 pages. |
Number | Date | Country | |
---|---|---|---|
20240106797 A1 | Mar 2024 | US |
Number | Date | Country | |
---|---|---|---|
61039729 | Mar 2008 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17362412 | Jun 2021 | US |
Child | 18242795 | US | |
Parent | 16389886 | Apr 2019 | US |
Child | 17362412 | US | |
Parent | 14520314 | Oct 2014 | US |
Child | 16389886 | US | |
Parent | 12402443 | Mar 2009 | US |
Child | 14520314 | US |