Cybersecurity may involve the authentication of a computing device, preventing access of a computing device by an unauthorized party, and further, to prevent two computing devices from communicating with each other unless authorized to do so. Such cybersecurity measures may be employed in an aircraft to prevent unauthorized access to avionics control systems. Aircrafts may also employ physical security measures, such as barriers to prevent access to secure avionics systems. Such avionics systems may control the functions and features available on an aircraft. In the event features and functions of the aircraft are added or removed, recertification of the aircraft may be required to verify compliance of the aircraft's physical and cybersecurity against security requirements.
In one example aspect, a computer-implemented method includes: receiving, by an authentication device, from a client device and via a network device, a plurality of passcode packets as part of a request to be authenticated by the authentication device; recording, by the authentication device, a sequence of port identifiers corresponding to respective ports of the network device via which the plurality of passcode packets are received; and authenticating, by the authentication device, the client device based on the sequence of port identifiers.
In another example aspect, a computer program product includes a computer readable storage medium having program instructions embodied therewith. The program instructions are executable by a computing device to cause the computing device to perform operations including: receiving, from a client device and via a network device, a plurality of passcode packets as part of a request to be authenticated by the authentication device; recording a sequence of respective transmission delay durations between the transmission of the plurality of the passcode packets; and authenticating the client device based on the sequence of transmission delay durations.
In another example aspect, a system includes a processor, a computer readable memory, a non-transitory computer readable storage medium associated with a computing device, and program instructions executable by the computing device to cause the computing device to perform operations comprising: receiving, from a client device and via a network device, a plurality of passcode packets as part of a request to be authenticated by the authentication device; recording a sequence of respective transmission delay durations between the transmission of the plurality of the passcode packets; recording a sequence of port identifiers corresponding to respective ports of the network device via which the plurality of passcode packets are received; and authenticating the client device based on the sequence of transmission delay durations and the sequence of port identifiers.
Certain embodiments of the disclosure will hereafter be described with reference to the accompanying drawings, wherein like reference numerals denote like elements. It should be understood, however, that the accompanying drawings illustrate only the various implementations described herein and are not meant to limit the scope of various technologies described herein. The drawings show and describe various embodiments of the current disclosure.
Cybersecurity may involve authenticating a computing device, preventing access of a computing device by an unauthorized party, and further, to prevent two computing devices from communicating with each other unless authorized to do so. As one illustrative example, such cybersecurity measures may be employed in an aircraft to prevent unauthorized access to avionics control systems. However, avionics control systems may still be exposed to insider threats, and/or other types of techniques whereby an unauthorized party may gain access to the avionics control system, or other type of system. Further, to modify a feature or function available for use on the aircraft, a lengthy, time consuming, and possibly bureaucratic recertification process may be required. Accordingly, aspects of the present disclosure may include a system and/or method to improve authentication of a client device, thereby improving the secure access of a host device by a client device based on verifying a dynamic “port punching” sequence. As described herein, dynamic port punching may include receiving and verifying “passcode packets” from the client device via a network device through a series of ports. The sequence of the ports from which these packets are received may be recorded, as well as the time delay between the receipt of the packets. Further, signatures and payload values within the packet may be verified to match expected signatures and payload known only to authorized parties. If the sequence, time delay, signatures, and/or payload match preconfigured values, a client device may be authenticated and a secure session may be established between the client device and the host device. From this secure session, the client device may securely communicate with the host device for any variety of purposes.
As one illustrative example, aspects of the present disclosure may authenticate a client device and secure the access by a client device to an avionics control system in in order to enable or disable features and functions on an aircraft remotely. Such features may include those that have been pre-certified previously (e.g., without requiring additional recertification). That is, aspects of the present disclosure may be used to securely enable or disable aircraft features remotely in connection with a service level agreement (SLA). Additionally, or alternatively, aspects of the present disclosure may be used to securely enable or disable aircraft features as part of incident response. Example features may include features relating to weather forecasting along flight routes, automated flight service features, en-route automation features, flight management/planning features, user evaluation features, wind shear detection features, etc. As another illustrative example, aspects of the present disclosure may secure the access of an avionics control system to obtain records, or data from a flight log, or other system.
The techniques described herein are not so limited to being used in in avionics systems. Rather, the techniques described herein may be used to authorize the communications between two devices in any environment for any variety applications or systems. For example, aspects of the present disclosure may be used to establish secure communications between a client device and a host device that hosts banking applications, financial applications, enterprise data, sensor data, etc.
Embodiments of the disclosure may include a system, a method, and/or a computer program product at any possible technical detail level of integration. The computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present disclosure.
The network 110 may include network nodes and one or more wired and/or wireless networks. For example, the network 110 may include a cellular network (e.g., a second generation (1G) network, a third generation (3G) network, a fourth generation (4G) network, a fifth generation (1G) network, a long-term evolution (LTE) network, a global system for mobile (GSM) network, a code division multiple access (CDMA) network, an evolution-data optimized (EVDO) network, or the like), a public land mobile network (PLMN), and/or another network. Additionally, or alternatively, the network 110 may include a local area network (LAN), a wide area network (WAN), a metropolitan network (MAN), the Public Switched Telephone Network (PSTN), an ad hoc network, a managed Internet Protocol (IP) network, a virtual private network (VPN), an intranet, the Internet, a fiber optic-based network, and/or a combination of these or other types of networks. In embodiments, the network 110 may include copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers.
The client device 120 may include a computing device capable of communicating via a network, such as the network 110. In example embodiments, the client device 120 corresponds to a mobile communication device (e.g., a smart phone or a personal digital assistant (PDA)), a portable computer device (e.g., a laptop or a tablet computer), a desktop computer, a server computer, and/or another type of computing device. In some embodiments, the client device 120 may request access to a host device (e.g., the authentication device 140) via the network device 130. For example, the client device 120 may request the authentication device 140 to update a feature implemented and/or hosted by the feature management device 150. As described in greater detail herein, the authentication device 140 may authorize the request based on verifying a dynamic port punch sequence.
The network device 130 may include one or more network communication devices, such as switches, hubs, routers, modems, access points, or the like. In some embodiments, the network device 130 may incorporate any number of physical or virtual ports via which data may be received and transmitted. In the context of one or more embodiments described herein, the network device 130 may receive passcode packets from the client device 120 via specific ports, and provide the passcode packets to the authentication device 140.
The authentication device 140 may include one or more computing devices that receives passcode packets from the client device 120 as part of a request to be authenticated (e.g., to communicate and/or establish a secure session between the client device 120 and the authentication device 140). In some embodiments, the authentication device 140 may verify the passcode packets or dynamic port punching (e.g., the sequence of the ports via which the packets are received, the duration delay between the transmission of the packets, the signature of the packet, and/or the payload of the packets). Based on verifying the passcode packets as described herein, the authentication device 140 may authenticate the client device 120 and/or establish a secure session with the client device 120 for secure communications. That is, the authentication device 140 may also function as a host device in a client/host relationship with the client device 120. In the example of
The feature management device 150 may include one or more computing devices that's hosts or implements an application, or feature in an external system. As one example, the feature management device 150 may be part of an avionics controls system that hosts one or more applications, functions, and/or features of an aircraft. In some embodiments, the feature management device 150 may update (e.g., enable or disable) the features based on receiving an instruction from the authentication device 140.
The quantity of devices and/or networks in the environment 100 is not limited to what is shown in
As further shown in
The authentication device 140 may receive these passcode packets, and verify the passcode packets. More specifically, the authentication device 140 may verify the port punch sequence (e.g., the sequence of ports via which the passcode packets are transmitted), the transmission delays, the signature values within each passcode, the payload values within each passcode packet, and/or any other information that indicates that the client device 120 is authorized to communicate with the authentication device 140. Based on verifying the passcode packets, the authentication device 140 may establish a secure session with the client device 120. In the example of
In some embodiments, the authentication information (e.g., the port punch sequence, transmission delays, signature values, payload values, etc.) may be preconfigured and stored by the authentication device 140. As described herein, any variety of secure information dissemination techniques may be used to provide and/or disseminate authorized devices, such as the client device 120, with the authentication information related to the port punch sequence, transmission delays, signature values, payload values, etc. For example, the authentication information may be stored in a secure location, encrypted, etc. Additionally, or alternatively, both the client device 120 and the authentication device 140 may use a common time-based algorithm to determine the port punch sequence and/or transmission delays. Additionally, or alternatively, any other techniques and measures may be taken to securely safeguard the authentication information for distribution only to authorized devices and parties. As such, the host device (e.g., the authentication device 140) may authenticate a client device (e.g., the client device 120) based on verifying the port punch sequence, transmission delays, signature values, payload values, and/or any other data. The use of such multiple different parameters provides additional layers of security for accessing a host device.
As shown in
Process 200 also may include authenticating passcode packet signature and/or payload values (block 210). For example, the authentication device 140 may authenticate passcode packet signature and/or payload values by comparing the signature and/or payload values within the passcode packet with values that are considered to be authenticated. In some embodiments, the passcode packet may include a private key and the authentication device 140 may apply a public decryption key to decrypt the signature and/or payload values.
Process 200 further may include determining whether the signature and/or payload values are authenticated (block 215). For example, the authentication device 140 may determine whether the signature and/or payload values are authenticated as described in block 210. Unauthenticated signature and/or payload values may indicate that an authorized party may be attempting to access the authentication device 140. Thus, if signature and/or payload values are not authenticated (block 215—NO), process 200 may end, without access being granted to the client device 120.
If, on the other hand, the signature and/or payload values are authenticated (block 215—YES), process 200 also may include recording the port from which the passcode packet is received (block 220). For example, the authentication device 140 may record an identifier of the port from which the passcode packet is received (e.g., the port of network device 130 via which the passcode packet is received, as may be found in a session request log, or the like).
Process 200 further may include recording the transmission delay duration from the receipt of a preceding passcode packet (block 225). For example, the authentication device 140 may record the transmission delay duration from the receipt of a preceding passcode packet. In some embodiments, the authentication device 140 may determine the delay duration based on a session log that identifies a time when each passcode packet is received. Process 200 may then return to block 205 in which blocks 205-225 are repeated for each passcode packet received from the client device 120. If the passcode packet is the first received passcode packet, block 225 may be omitted. In this way, the authentication device 140 may authenticate each packet against its signature and/or payload values to verify that each packet is received from an authorized client device 120. Further, each port from which the packets are received may be recorded as part of a port punch sequence. Additionally, the transmission delay between the transmission of each packet may be recorded. As described in greater detail herein, the recorded port and transmission delay sequences may be used to authenticate the client device 120.
Process 200 also may include receiving a command packet (block 230). For example, the authentication device 140 may receive a command packet from the client device 120 (e.g., after all passcode packets have been received). In some embodiments, the command packet may include a command instruction or request for the authentication device 140. As one illustrative example, the command packet may include an instruction or request for the authentication device 140 to enable or disable one or more features, applications, or functions, hosted by the feature management device 150, available for use on an aircraft. In some embodiments, the command packet may further include a signature and/or payload values to authenticate the client device 120.
Referring to
Process 200 also may include determining whether the signature and/or payload is authenticated (block 240). For example, the authentication device 140 may verify whether the signature and/or payload values from the command packet are authenticated (e.g., by comparing the signature and/or payload values within the command packet with values that are considered to be authenticated). If the signature and/or payload values are not authenticated (block 240—NO), process 200 may end, thereby preventing unauthorized commands from being executed.
If, on the other hand, the signature and/or payload values from the command packet are authenticated (block 240—YES), process 200 further may include recording the port from which the command packet is received (block 245). For example, the authentication device 140 may record an identifier of the port from which the command packet is received (e.g., the port of network device 130 via which the command packet is received, as may be found in a session request log, or the like).
Process 200 also may include recording the delay duration between the receipt of the preceding passcode packet and the command packet (block 250). For example, the authentication device 140 may record the delay duration between the receipt of the preceding passcode packet and the command packet (e.g., based on a session log that identifies times in which the preceding passcode packet and the command packet are received).
Process 200 further may include verifying a port punch and delay duration sequences (block 255). For example, the authentication device 140 may verify a port punch and delay duration sequences based on the recorded ports from which the passcode and command packets are received (e.g., from blocks 220 and 250). Further, the authentication device 140 may verify the delay duration sequence between the received passcode and command packets (e.g., recorded at blocks 225 and 255). In some embodiments, the authentication device 140 may verify the port punch and delay duration sequences against preconfigured and/or stored port punch and delay duration sequences known only to authorized devices. As such, the port punch and delay duration sequences may be verified when the passcode and/or command packets are received by an authorized client device 120 that has knowledge of the correct port punch and/or delay duration sequence.
If, for example, the port punch and delay duration sequences are not verified (block 260—NO), process 200 may end, thereby preventing a command from an unauthorized client device 120 to be executed, or prevent the client device 120 and the authentication device 140 from further communicating. If, on the other hand, the port punch and delay duration sequences are verified (block 260—YES), process 200 may include authenticating the client device (block 265). For example, the authentication device 140 may authenticate the client device 120 by establishing a secure session with the client device 120, storing information indicating that the client device is authenticated, etc.
Process 200 may further include executing instructions from the command packet (block 270). For example, the authentication device 140 may execute the instructions included in the command packet. As one illustrative example, the authentication device 140 may execute the instructions to enable or disable one or more features, applications, or functions, hosted by the feature management device 150, available for use on an aircraft. As another illustrative example, the authentication device 140 may execute the instructions to provide the client device 120 with activity logs, sensor logs, etc.
In some embodiments, one or more process blocks of 200 may be modified, rearranged, or omitted. For example, blocks 230-250 may be omitted and block 270 may be modified in which a secure communications session is established between the client device 120 and the authentication device 140 based on verifying the port punch sequence and delay duration sequence of the passcode packets (e.g., without a command packet). In an alternative embodiment, the authentication device 140 may authenticate a client device 120 based only either on the port punch sequence or the delay duration sequence. Once a secure session is established, the client device 120 and authentication device 140 may communicate with each other for any variety of purposes, such as to exchange data (e.g., from sensor logs, activity logs, etc.), send/receive commands, perform API calls, process data for an application, or the like. That is to say, the authentication of the client device 120 may permit the client device 120 to perform any of the aforementioned tasks. Additionally, or alternatively, the authentication device 140 may provide an indication to an external system that the client device 120 is authenticated to allow communication between the client device 120 and the external system, or to allow the external system to execute a process involving the client device 120. In other words, process 200 may be used, in a broad sense, to authenticate the client device 120 for a variety of purposes in which the authentication is based on the port punch sequence and/or the delay duration sequence which is known to authorized client devices 120. As an additional layer of security, the signatures and/or payload values within the received packets may be verified against the values known to authorized client devices 120.
As shown in
Bus 505 may include a path that permits communication among the components of device 500. Processor 510 may include a processor, a microprocessor, an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), or another type of processor that interprets and executes instructions. Main memory 515 may include a random access memory (RAM) or another type of dynamic storage device that stores information or instructions for execution by processor 510. ROM 520 may include a ROM device or another type of static storage device that stores static information or instructions for use by processor 510. Storage device 525 may include a magnetic storage medium, such as a hard disk drive, or a removable memory, such as a flash memory.
Input device 530 may include a component that permits an operator to input information to device 500, such as a control button, a keyboard, a keypad, or another type of input device. Output device 535 may include a component that outputs information to the operator, such as a light emitting diode (LED), a display, or another type of output device. Communication interface 540 may include any transceiver-like component that enables device 500 to communicate with other devices or networks. In some implementations, communication interface 540 may include a wireless interface, a wired interface, or a combination of a wireless interface and a wired interface. In embodiments, communication interface 540 may receiver computer readable program instructions from a network and may forward the computer readable program instructions for storage in a computer readable storage medium (e.g., storage device 525).
Device 500 may perform certain operations, as described in detail below. Device 500 may perform these operations in response to processor 510 executing software instructions contained in a computer-readable medium, such as main memory 515. A computer-readable medium may be defined as a non-transitory memory device and is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire. A memory device may include memory space within a single physical storage device or memory space spread across multiple physical storage devices.
The software instructions may be read into main memory 515 from another computer-readable medium, such as storage device 525, or from another device via communication interface 540. The software instructions contained in main memory 515 may direct processor 510 to perform processes that will be described in greater detail herein. Alternatively, hardwired circuitry may be used in place of or in combination with software instructions to implement processes described herein. Thus, implementations described herein are not limited to any specific combination of hardware circuitry and software.
In some implementations, device 500 may include additional components, fewer components, different components, or differently arranged components than are shown in
Aspects of the present disclosure are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the disclosure. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer readable program instructions.
These computer readable program instructions may be provided to a processor of a general-purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods, and computer program products according to various embodiments of the present disclosure. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s). In some alternative implementations, the functions noted in the blocks may occur out of the order noted in the Figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts or carry out combinations of special purpose hardware and computer instructions.
Embodiments of the disclosure may include a system, a method, and/or a computer program product at any possible technical detail level of integration. The computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out or execute aspects and/or processes of the present disclosure.
In embodiments, the computer readable program instructions may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, configuration data for integrated circuitry, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++, or the like, and procedural programming languages, such as the “C” programming language or similar programming languages. The computer readable program instructions may execute entirely on a user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server.
In some embodiments, electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present disclosure.
The computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
In embodiments, a service provider could offer to perform the processes described herein. In this case, the service provider can create, maintain, deploy, support, etc., the computer infrastructure that performs the process steps of the disclosure for one or more customers. These customers may be, for example, any business that uses technology. In return, the service provider can receive payment from the customer(s) under a subscription and/or fee agreement and/or the service provider can receive payment from the sale of advertising content to one or more third parties.
The foregoing description provides illustration and description, but is not intended to be exhaustive or to limit the possible implementations to the precise form disclosed. Modifications and variations are possible in light of the above disclosure or may be acquired from practice of the implementations.
It will be apparent that different examples of the description provided above may be implemented in many different forms of software, firmware, and hardware in the implementations illustrated in the figures. The actual software code or specialized control hardware used to implement these examples is not limiting of the implementations. Thus, the operation and behavior of these examples were described without reference to the specific software code—it being understood that software and control hardware can be designed to implement these examples based on the description herein.
Even though particular combinations of features are recited in the claims and/or disclosed in the specification, these combinations are not intended to limit the disclosure of the possible implementations. In fact, many of these features may be combined in ways not specifically recited in the claims and/or disclosed in the specification. Although each dependent claim listed below may directly depend on only one other claim, the disclosure of the possible implementations includes each dependent claim in combination with every other claim in the claim set.
While the present disclosure has been disclosed with respect to a limited number of embodiments, those skilled in the art, having the benefit of this disclosure, will appreciate numerous modifications and variations there from. It is intended that the appended claims cover such modifications and variations as fall within the true spirit and scope of the disclosure.
No element, act, or instruction used in the present application should be construed as critical or essential unless explicitly described as such. Also, as used herein, the article “a” is intended to include one or more items and may be used interchangeably with “one or more.” Where only one item is intended, the term “one” or similar language is used. Further, the phrase “based on” is intended to mean “based, at least in part, on” unless explicitly stated otherwise.
Number | Name | Date | Kind |
---|---|---|---|
6246684 | Chapman | Jun 2001 | B1 |
6360271 | Schuster | Mar 2002 | B1 |
6385451 | Kalliokulju | May 2002 | B1 |
6512761 | Schuster | Jan 2003 | B1 |
6539026 | Waclawsky | Mar 2003 | B1 |
6717917 | Weissberger | Apr 2004 | B1 |
6725390 | Liu | Apr 2004 | B1 |
6862298 | Smith | Mar 2005 | B1 |
7197556 | Short | Mar 2007 | B1 |
7254616 | Ennis | Aug 2007 | B1 |
7257469 | Pemble | Aug 2007 | B1 |
7346005 | Dowdal | Mar 2008 | B1 |
7516255 | Hobbs | Apr 2009 | B1 |
7823194 | Shay | Oct 2010 | B2 |
8149863 | Sahotra | Apr 2012 | B1 |
8670466 | Sathe | Mar 2014 | B1 |
8706865 | L'Heureux | Apr 2014 | B1 |
8934492 | King | Jan 2015 | B1 |
10142214 | Kim | Nov 2018 | B2 |
10523685 | Kostka | Dec 2019 | B1 |
10698030 | Parodi | Jun 2020 | B1 |
10735339 | Matthews | Aug 2020 | B1 |
10979390 | Hiramoto | Apr 2021 | B2 |
11075847 | Kwan | Jul 2021 | B1 |
20020147820 | Yokote | Oct 2002 | A1 |
20030056097 | Araki | Mar 2003 | A1 |
20030065799 | Kitamura | Apr 2003 | A1 |
20030101273 | Hensbergen | May 2003 | A1 |
20030161276 | Lundberg | Aug 2003 | A1 |
20040125787 | May | Jul 2004 | A1 |
20050058090 | Chang | Mar 2005 | A1 |
20050094637 | Umesawa | May 2005 | A1 |
20050138352 | Gauvreau | Jun 2005 | A1 |
20050219084 | Dietrich | Oct 2005 | A1 |
20060041742 | Oba | Feb 2006 | A1 |
20060178150 | Kim | Aug 2006 | A1 |
20060227811 | Hussain | Oct 2006 | A1 |
20060259583 | Matsuura | Nov 2006 | A1 |
20070018708 | Yoo | Jan 2007 | A1 |
20070019552 | Senarath | Jan 2007 | A1 |
20070038855 | Brown | Feb 2007 | A1 |
20070110087 | Abel | May 2007 | A1 |
20070115821 | Sim | May 2007 | A1 |
20070142005 | Sundstrom | Jun 2007 | A1 |
20070189486 | Ise | Aug 2007 | A1 |
20070195819 | Chen | Aug 2007 | A1 |
20070208836 | Madnani | Sep 2007 | A1 |
20070242702 | Shim | Oct 2007 | A1 |
20080010565 | Jeng | Jan 2008 | A1 |
20080028210 | Asano | Jan 2008 | A1 |
20080112440 | Bedekar | May 2008 | A1 |
20080137542 | Chiu | Jun 2008 | A1 |
20080225746 | Bedrosian | Sep 2008 | A1 |
20080225747 | Bedrosian | Sep 2008 | A1 |
20080279189 | Smith | Nov 2008 | A1 |
20080320582 | Chen | Dec 2008 | A1 |
20090116426 | Ho | May 2009 | A1 |
20090161744 | Smith | Jun 2009 | A1 |
20090190482 | Blair | Jul 2009 | A1 |
20090259445 | Bedrosian | Oct 2009 | A1 |
20090259712 | Sugawara | Oct 2009 | A1 |
20090323687 | Nishimura | Dec 2009 | A1 |
20100058148 | Lu | Mar 2010 | A1 |
20100085886 | Okada | Apr 2010 | A1 |
20100103946 | Nomura | Apr 2010 | A1 |
20100110892 | Lai | May 2010 | A1 |
20100124178 | Baccelli | May 2010 | A1 |
20100172453 | Cankaya | Jul 2010 | A1 |
20100260204 | Pepper | Oct 2010 | A1 |
20110037904 | Yokokawa | Feb 2011 | A1 |
20110110375 | Boucadair | May 2011 | A1 |
20110164625 | Fourcand | Jul 2011 | A1 |
20110211593 | Pepper | Sep 2011 | A1 |
20110238817 | Okita | Sep 2011 | A1 |
20110294539 | Shin | Dec 2011 | A1 |
20110314269 | Stavrou | Dec 2011 | A1 |
20120039194 | Kure | Feb 2012 | A1 |
20120063339 | Song | Mar 2012 | A1 |
20120216192 | Tsai | Aug 2012 | A1 |
20120233461 | Takahashi | Sep 2012 | A1 |
20120269093 | Grammel | Oct 2012 | A1 |
20130080817 | Mihelic | Mar 2013 | A1 |
20130114448 | Koo | May 2013 | A1 |
20130198546 | Fujisawa | Aug 2013 | A1 |
20130315241 | Kamat | Nov 2013 | A1 |
20130329585 | Okada | Dec 2013 | A1 |
20130343747 | Sarwar | Dec 2013 | A1 |
20140036695 | Ziegler | Feb 2014 | A1 |
20140050002 | Sun | Feb 2014 | A1 |
20140153572 | Hampel | Jun 2014 | A1 |
20140160952 | Astigarraga | Jun 2014 | A1 |
20140181893 | Von Bokern | Jun 2014 | A1 |
20140215642 | Huxham | Jul 2014 | A1 |
20140269372 | Roy | Sep 2014 | A1 |
20150023189 | Okada | Jan 2015 | A1 |
20150085877 | Kono | Mar 2015 | A1 |
20150124611 | Attar | May 2015 | A1 |
20150131450 | Weill | May 2015 | A1 |
20150236957 | Albanese | Aug 2015 | A1 |
20150244634 | Azogui | Aug 2015 | A1 |
20160065655 | Bentley | Mar 2016 | A1 |
20160112336 | Hong | Apr 2016 | A1 |
20160315841 | Kang | Oct 2016 | A1 |
20160315860 | Nichols | Oct 2016 | A1 |
20170048076 | Li | Feb 2017 | A1 |
20170171226 | Watkins | Jun 2017 | A1 |
20170230310 | Takeuchi | Aug 2017 | A1 |
20170295099 | Murphy | Oct 2017 | A1 |
20180115478 | Kim | Apr 2018 | A1 |
20180145781 | Chaloupka | May 2018 | A1 |
20180176144 | Luo | Jun 2018 | A1 |
20180198616 | Feather | Jul 2018 | A1 |
20180288129 | Joshi | Oct 2018 | A1 |
20180309689 | Nainar | Oct 2018 | A1 |
20180337945 | Takabe | Nov 2018 | A1 |
20190107415 | Fumey | Apr 2019 | A1 |
20190109822 | Clark | Apr 2019 | A1 |
20190110196 | Simileysky | Apr 2019 | A1 |
20190363990 | Lorenz | Nov 2019 | A1 |
20190372403 | Park | Dec 2019 | A1 |
20190373041 | Lee | Dec 2019 | A1 |
20200007548 | Sanghavi | Jan 2020 | A1 |
20200021558 | Xu | Jan 2020 | A1 |
20200052979 | Clemm | Feb 2020 | A1 |
20200068446 | Nimbavikar | Feb 2020 | A1 |
20200077440 | Lee | Mar 2020 | A1 |
20200106710 | Ryoo | Apr 2020 | A1 |
20200127808 | Takahashi | Apr 2020 | A1 |
20200220812 | Butcher | Jul 2020 | A1 |
20200228496 | Mori | Jul 2020 | A1 |
20200228515 | Hassan | Jul 2020 | A1 |
20200322245 | Ansah | Oct 2020 | A1 |
20200322378 | Yang | Oct 2020 | A1 |
20200374955 | Dudda | Nov 2020 | A1 |
20200389436 | Go | Dec 2020 | A1 |
20210058369 | Hillis | Feb 2021 | A1 |
20210075797 | Gan | Mar 2021 | A1 |
20210194876 | Kasahara | Jun 2021 | A1 |
20210203412 | Whitefield | Jul 2021 | A1 |
20220255840 | Mori | Aug 2022 | A1 |
Number | Date | Country |
---|---|---|
3796579 | Mar 2021 | EP |
Number | Date | Country | |
---|---|---|---|
20210226936 A1 | Jul 2021 | US |