This document relates to vehicle monitoring and control.
Autonomous vehicle navigation is a technology for sensing the position and movement of a vehicle and, based on the sensing, autonomously control the vehicle to navigate towards a destination. Autonomous vehicle navigation can have important applications in transportation of people, goods and services.
Disclosed are devices, systems and methods for securing wireless communications between a remote monitor center and a vehicle. This may be achieved by using redundancy measures to increase the robustness of the system. For example, embodiments of the disclosed technology may use redundant communication channels, deploy redundant hardware and software stacks to enable switching to a backup in an emergency situation, and employ hypervisors at both the remote monitor center and the vehicle to monitor hardware and software resources and perform integrity checks.
In one aspect, the disclosed technology can be used to implement a method for providing security for a vehicular monitoring system. This method includes generating a first message digest that is an output of a cryptographic hash function with an input that is a plurality of predetermined commands sent to the vehicle, receiving, from the vehicle, a second message digest that is an output of the cryptographic hash function with an input that is a plurality of predetermined commands received by the vehicle, comparing the first message digest and the second message digest to determine whether the first message digest is identical to the second message digest, and generating an indicator for a security breach at least when the first message digest is different from the second message digest.
In another aspect, the disclosed technology can be used to implement a method for providing security for a vehicular monitoring system. This method includes periodically performing an integrity check on a software stack associated with control or operation of a vehicle, and replacing the software stack with a new version of the software stack from a backup software system at least when a failure of the integrity check is determined.
The above and other aspects and features of the disclosed technology are described in greater detail in the drawings, the description and the claims.
A communication link between a vehicle and remote monitor center, if unprotected, is vulnerable to cyber-attacks. The damage caused by a successful attack on a vehicular monitoring system may range from mild to disastrous—to the extent of serious casualties and property losses. Current approaches fall short in two aspects; a lack of high availability guarantee, and the inability to defend against physical attacks and/or threats. To enforce the security objectives for deployed and developing vehicular monitoring systems, embodiments of the disclosed technology include a stack of security mechanisms, which can protect the information and resources of remote monitoring and control systems.
Embodiments of the disclosed technology, as described in this document and in the context of the Figures and Claims, may provide one or more of the following advantages.
(1) Authenticity of the communication parties;
(2) Authenticity, integrity and secrecy of remote monitoring and control messages;
(3) Integrity of the system components;
(4) High availability of a communication link; and
(5) Safe handling in failure or emergency situations.
Embodiments of the disclosed technology include various components that enable providing security to a real-time remote vehicular monitoring system. These components include one or more of (1) secure communication between the vehicle and the remote monitor center that are essential for secure transmission of control commands, (2) platform integrity checks at both the vehicle and the remote monitor center to ensure continuously safe operation, (3) redundant wireless communication links that provide high availability, (4) emergency handling services that protect against adverse circumstances, and (5) command feedback validation to ensure authenticity of the commands. Various aspects, features and implementations of these components are described in this document.
Secure Communication: In some embodiments, the operational link may be secured using an Internet layer cryptographic protocol, which enforces authenticity, integrity and secrecy. In an example, the operational link may use the Internet Protocol security (IPsec) protocol. The emergency channel may be secured using a low-latency Application layer cryptographic protocol, due to the imperative nature of emergency communications. In an example, the Secure Sockets Layer (SSL) protocol or the Transport Layer Security (TLS) protocol may be used for the emergency channel, which does not require explicit client authentication after an initial authentication process.
Platform Integrity Checks: In some embodiments, periodic integrity checks may be used for safe operation assurances. For example, continuous success of integrity checks for the vehicle, the in-vehicle systems and the remote monitor center indicate that the systems are operating in a safe state. On the other hand, if any of the integrity checks fail, the system may invoke emergency handling routines.
In some embodiments, the state of the vehicle may be defined using one or more of the following aspects: position, velocity, acceleration, availability of human operator, traffic conditions, and the driving environment. In other embodiments, the state of the in-vehicle system may be defined by the operational condition of the in-vehicle sensors, the hardware systems and the software systems. In yet other embodiments, the state of the remote monitor center may be defined by the operational condition of the hardware and software systems.
As shown in
During normal operation, the truck hypervisor continuously verifies the integrity of truck system (one or more of the SW/HW stack, the SW/HW stand-by and the sensors), and the monitor center hypervisor verifies the integrity and liveness of monitor servers. In an example, the truck and remote monitor server hypervisors communicate over the operational link that is secured using the IPsec protocol.
Depending on the type of failure detected by the hypervisors, the different actions that may be undertaken are enumerated in Table 1.
Redundancy: Embodiments of the disclosed technology implement redundancy in many aspects to ensure the robust performance of the real-time remote vehicular monitoring system. As described in this document, redundant communication links are deployed in the form of the operational channel and the emergency channel. In another aspect, the operational channel may use a variety of different protocols.
In addition to communication redundancy, embodiments of the disclosed technology include hardware and software redundancies as discussed in this document. In an example, one or more of the sensors, the battery, the electronic control units (ECUs) and the monitor servers may be replicated to provide robustness against faults.
In some embodiments, two copies of at least one control command are received using two different wireless communication protocols, and are compared. The at least one control command is executed when the two copies are in agreement, but is rejected when the two copies differ. In other embodiments, additional wireless communication protocols may exist to provide a redundant mode of communication when one of the two different wireless communication protocols are unavailable. In yet other embodiments, redundant GPS units may be used to determine availability of any of the communication protocols, and relevant control commands may be downloaded in advance to circumvent the lack of coverage.
Emergency Handling System (EHS): In some embodiments, the EHS can include an emergency communication link (ECL) and an emergency handling routine (EHR).
As shown in
In an example, and when a failure is detected, the vehicle may initialize an emergency communication with the remote monitor center to report its geolocation. In some embodiments, the geolocation may include geographic coordinates (e.g. longitude and latitude). In other embodiments, the geolocation may further include street addresses, landmarks or mile markers. In yet other embodiments, the geolocation may include an approximate location derived using base stations and/or Wi-Fi hotspots (instead of a more precise location derived using GPS).
In some embodiments, and based on the geolocation information, the remote monitor server selects a nearest service station or exit (if the vehicle is on a highway), and navigates the vehicle to safely exit its current environment. In other embodiments, operation personnel are also informed of the EHRs being currently undertaken.
In some embodiments, a vehicle may perform self-tests, generate a report based on the results, and transmit it to a remote monitor center over one or both of a high-speed channel for regular data transfers or a reliable channel for emergency situations. In other embodiments, the remote monitor center may determine that immediate intervention is required, and may transmit a control command with high priority, which when received by the vehicle, is implemented and overrides any local commands being processed. In yet other embodiments, the control command with high priority is selected from a small group of predetermined control commands the remote monitor center may issue.
In some embodiments, the real-time remote vehicular monitoring system may be configured to account for various operational factors and conditions. In an exemplary case, many normal environmental factors can cause signal loss for a non-negligible period of time, e.g. a vehicle entering a tunnel may lose wireless connectivity for a prolonged period of time, but this situation should not be deemed an emergency.
In order to distinguish between these two scenarios, a signal loss time threshold may be established. In some embodiments, the threshold may be predetermined based on the longest tunnel known to exist on the route the vehicle is scheduled to travel on. Thus, signal faults within that threshold of time are reported to the remote monitor center, but do not trigger the EHS.
Command Feedback Validation: Embodiments of the disclosed technology may include the remote monitor center issuing several types of control commands to the vehicle, and in this case, ensuring the integrity of the commands is critical. In some scenarios, an attacker may inject commands from covers channels (not protected channels, e.g. 4G-LTE), and ensuring the authenticity of commands sent from the remote monitor center and received at the vehicle will protect against just such an attack.
As control commands are sent and received, they are consecutively placed in the monitor server command buffer and vehicle command buffer, respectively. When the buffers are full, a cryptographic hash of the buffer is computed to generate a message digest. The message digest from the vehicle is received, and then compared to the message digest generated at the monitor server. If the hashes of the two message digests are not equal, an indicator of a security breach is generated and the EHS is triggered.
In some embodiments, any one-way function may be used to implement command feedback validation. A one-way function is a function that is easy to on every input, but is hard to invert given the image of a random input (where “easy” and “hard” are understood in the sense of computational complexity theory).
In various embodiments, the cryptographic hash function may be computed on different types of inputs. For example, the input may be a fixed number control commands. In another example, the input may be the control commands in a sliding time-window. In yet another example, the input may be control commands that have been flagged with a specific tag by the remote monitor server (or the vehicle itself). In yet another example, the input may be control commands that are directed to a specific subsystem or subcomponent of the vehicle. In yet another example, a combination of the different methods described may be employed.
The security architecture disclosed in this document is resilient to various types of attack scenarios based on the amalgamation of the described components.
Eavesdropping, tampering: The use of the IPsec protocol on the operational channel and SSL/TLS on the emergency channel precludes an attacker learning any knowledge from an eavesdropped packet due to the inherent security advantages of these protocols. The command feedback validation process, for example, will be able to detect any attempt at tampering.
Command injection: In an example and in order to inject a malicious command, an attacker must either impersonate the server or replay command messages. The impersonation of the monitor server is defended by IPsec authentication, and the replaying of commands is countered by the IPsec anti-replay protocol. With regard to command injection from unexpected channels, the command feedback validation process protects against this scenario.
Jamming: Jamming attacks may compromise the availability of the communication channels and/or GPS signals. Upon detecting a jamming attack, the EHS is triggered.
Cryptographic attacks: The use of current IPsec and SSL/TLS protocol implementations (that typically use 256-bit or higher strength keys, etc.) preclude the success of a cryptographic attack on the real-time remote vehicular monitoring system.
In some embodiments, the plurality of predetermined commands may include only those commands that have a certain priority, or flagged by the remote monitor center, or more generally, be of a specific type. In other embodiments, the predetermined commands may be the most recent set of control commands transmitted by the remote monitor center. In yet other embodiments, the predetermined commands may include commands destined for a specific subcomponent or subsystem in the vehicle.
The method 500 includes, at step 504, receiving, from the vehicle, a second message digest that is an output of the cryptographic hash function with an input that is a plurality of predetermined commands received by the vehicle. In some embodiments, the message digest from the vehicle may be received over the emergency channel, which may be a satellite link. In other embodiments, the satellite link is secured using a low-latency cryptographic protocol, e.g. SSL/TLS. In other embodiments, the plurality of predetermined commands received by the vehicle are stored in a remote command buffer in the vehicle.
The method 500 includes, at step 506, comparing the first message digest and the second message digest to determine whether the first message digest is identical to the second message digest.
The method 500 includes, at step 508, generating an indicator for a security breach at least when the first message digest is different from the second message digest. In some embodiments, the EHS system is triggered when the security breach indicator is generated. In other embodiments, the EHS system may include an EHR that includes requesting, and subsequently receiving, geolocation information from the vehicle, and then, transmitting one or more control commands to navigate the vehicle to a safe location. In an example, the geolocation information and the control commands may be transmitted on the emergency channel. In another example, the geolocation information may be sent from the vehicle over the operational channel, and the control commands sent from the remote monitor center over the emergency channel.
In some embodiments, an indicator for a security breach is generated when the generated and received message digests are different. In other embodiments, the indicator may be generated based on other factors, including detection of malicious control commands being received, the detection of jamming signals, etc.
In some embodiments, the integrity check may include determining whether a position, velocity or acceleration of a vehicle is within a pre-determined acceptable operating range. In an example, the pre-determined acceptable operating range may be based on a location of the vehicle, e.g. a speed limit is used to determine the operating range for the velocity.
In other embodiments, the integrity check may include determining whether data from one or more vehicular sensors are within a pre-determined acceptable operating range. In an example, a LIDAR (Light Detection And Ranging) sensor may indicate that the vehicle is too close to the vehicle in front of it, and a deceleration procedure may be invoked. In another example, a temperature sensor may provide a reading of greater than 300° F., in which case the hypervisor will recognize that the temperature sensor may be faulty (based on independent location data, for example), and the temperature sensor data will be discarded and that sensor will not be used until it can be serviced or replaced.
The method 600 includes, at step 604, replacing the software stack with a new version of the software stack from a backup software system at least when a failure of the integrity check is determined. In some embodiments, the replication strategy described in this document enables both the vehicle and the remote monitor center to replace a software and/or hardware system that has failed an integrity check. In other embodiments, the software stack may be replaced with a new version if an updated version or other software updates have been made available.
Implementations of the subject matter and the functional operations described in this patent document can be implemented in various systems, digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this specification and their structural equivalents, or in combinations of one or more of them. Implementations of the subject matter described in this specification can be implemented as one or more computer program products, e.g., one or more modules of computer program instructions encoded on a tangible and non-transitory computer readable medium for execution by, or to control the operation of, data processing apparatus. The computer readable medium can be a machine-readable storage device, a machine-readable storage substrate, a memory device, a composition of matter effecting a machine-readable propagated signal, or a combination of one or more of them. The term “data processing unit” or “data processing apparatus” encompasses all apparatus, devices, and machines for processing data, including by way of example a programmable processor, a computer, or multiple processors or computers. The apparatus can include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, or a combination of one or more of them.
A computer program (also known as a program, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program does not necessarily correspond to a file in a file system. A program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub programs, or portions of code). A computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.
The processes and logic flows described in this specification can be performed by one or more programmable processors executing one or more computer programs to perform functions by operating on input data and generating output. The processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit).
Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read only memory or a random access memory or both. The essential elements of a computer are a processor for performing instructions and one or more memory devices for storing instructions and data. Generally, a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto optical disks, or optical disks. However, a computer need not have such devices. Computer readable media suitable for storing computer program instructions and data include all forms of nonvolatile memory, media and memory devices, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices. The processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
It is intended that the specification, together with the drawings, be considered exemplary only, where exemplary means an example. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. Additionally, the use of “or” is intended to include “and/or”, unless the context clearly indicates otherwise.
While this patent document contains many specifics, these should not be construed as limitations on the scope of any invention or of what may be claimed, but rather as descriptions of features that may be specific to particular embodiments of particular inventions. Certain features that are described in this patent document in the context of separate embodiments can also be implemented in combination in a single embodiment. Conversely, various features that are described in the context of a single embodiment can also be implemented in multiple embodiments separately or in any suitable subcombination. Moreover, although features may be described above as acting in certain combinations and even initially claimed as such, one or more features from a claimed combination can in some cases be excised from the combination, and the claimed combination may be directed to a subcombination or variation of a subcombination.
Similarly, while operations are depicted in the drawings in a particular order, this should not be understood as requiring that such operations be performed in the particular order shown or in sequential order, or that all illustrated operations be performed, to achieve desirable results. Moreover, the separation of various system components in the embodiments described in this patent document should not be understood as requiring such separation in all embodiments.
Only a few implementations and examples are described and other implementations, enhancements and variations can be made based on what is described and illustrated in this patent document.
This patent document claims priority to and benefits of U.S. Provisional patent Application No. 62/689,720 entitled “SECURITY ARCHITECTURE FOR A REAL-TIME REMOTE VEHICLE MONITORING SYSTEM” filed on Jun. 25, 2018. The entire contents of the aforementioned patent application are incorporated by reference as part of the disclosure of this patent document.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US19/38332 | 6/20/2019 | WO | 00 |
Number | Date | Country | |
---|---|---|---|
62689720 | Jun 2018 | US |