[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

WO2016080422A1 - 通信制御装置及び通信システム - Google Patents

通信制御装置及び通信システム Download PDF

Info

Publication number
WO2016080422A1
WO2016080422A1 PCT/JP2015/082349 JP2015082349W WO2016080422A1 WO 2016080422 A1 WO2016080422 A1 WO 2016080422A1 JP 2015082349 W JP2015082349 W JP 2015082349W WO 2016080422 A1 WO2016080422 A1 WO 2016080422A1
Authority
WO
WIPO (PCT)
Prior art keywords
message
transmission
hash value
unit
communication
Prior art date
Application number
PCT/JP2015/082349
Other languages
English (en)
French (fr)
Inventor
高田 広章
亮 倉地
直樹 足立
Original Assignee
国立大学法人名古屋大学
株式会社オートネットワーク技術研究所
住友電装株式会社
住友電気工業株式会社
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 国立大学法人名古屋大学, 株式会社オートネットワーク技術研究所, 住友電装株式会社, 住友電気工業株式会社 filed Critical 国立大学法人名古屋大学
Priority to DE112015005252.6T priority Critical patent/DE112015005252T5/de
Priority to CN201580061067.9A priority patent/CN107005447B/zh
Priority to JP2016560252A priority patent/JP6306206B2/ja
Priority to US15/527,826 priority patent/US10432421B2/en
Publication of WO2016080422A1 publication Critical patent/WO2016080422A1/ja

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/40Bus networks
    • H04L12/40143Bus networks involving priority mechanisms
    • H04L12/40163Bus networks involving priority mechanisms by assigning priority to messages according to a message field
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/40Bus networks
    • H04L12/40052High-speed IEEE 1394 serial bus
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/40Bus networks
    • H04L12/40143Bus networks involving priority mechanisms
    • H04L12/40156Bus networks involving priority mechanisms by using dedicated slots associated with a priority level
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/40Bus networks
    • H04L2012/40208Bus networks characterized by the use of a particular bus standard
    • H04L2012/40215Controller Area Network CAN

Definitions

  • the present invention relates to a communication system in which a plurality of communication devices transmit and receive messages, such as CAN (Controller Area Network), and a communication control apparatus that detects intrusion of unauthorized messages to the system.
  • a communication system in which a plurality of communication devices transmit and receive messages, such as CAN (Controller Area Network), and a communication control apparatus that detects intrusion of unauthorized messages to the system.
  • CAN Controller Area Network
  • a CAN communication protocol has been widely used for communication between a plurality of ECUs (Electronic Control Units) mounted on a vehicle.
  • a communication system that employs a CAN communication protocol has a configuration in which a plurality of ECUs are connected to a common CAN bus, and transmission and reception of messages are performed when the receiving ECU acquires a signal output from the transmitting ECU to the CAN bus. Is done.
  • a technique for detecting or preventing unauthorized message intrusion on a common communication line has been studied.
  • Patent Document 1 proposes a communication management device for a vehicle network that restricts input of external data.
  • This communication management device monitors data on the CAN bus and monitors data input from the outside. When the usage rate of the CAN bus exceeds the load reference value, and when the external data is transferred, the CAN bus When it is predicted that the usage rate will exceed the load reference value, external data transmission restriction is executed.
  • a malicious device may be connected to the CAN bus.
  • Such a device may cause a malfunction of a legitimate ECU or the like connected to the CAN bus by, for example, sending an illegal message to the CAN bus.
  • the communication management device described in Patent Document 1 is configured to determine whether or not the CAN bus usage rate exceeds the load reference value, transmission restrictions are imposed when the amount of message transmission by a malicious device is small. There is a problem that can not be done.
  • the present invention has been made in view of such circumstances, and an object of the present invention is to detect such message transmission when an unauthorized device transmits a message to a common communication line. It is an object of the present invention to provide a communication control apparatus and a communication system that can perform the above-described operation.
  • a communication control apparatus is a communication control apparatus that controls communication by a communication apparatus having a message transmission unit that periodically transmits a message, and a reference for determining a reference time point related to message transmission by the message transmission unit A predetermined time period including the scheduled transmission time with respect to a scheduled transmission time obtained by adding a period that is an integral multiple of a message transmission cycle by the message transmission unit to the reference time determined by the reference time determination unit.
  • a permission period determination unit as a permission period, a message detection unit for detecting a message transmitted by the communication device, and a message detected by the message detection unit are transmitted within the permission period determined by the permission period determination unit
  • a transmission permission / non-permission determining unit that determines whether the message can be transmitted according to whether the message is a message. .
  • the reference time point determination unit and the permission period determination unit determine the reference time point and the permission period for each of the plurality of communication devices. It is made to do so.
  • the message transmitted by the communication apparatus includes information indicating the priority of the message, and the permission period determination unit determines the permission period for each message priority. It is made to do so.
  • the communication control apparatus further includes arbitration means for arbitrating a transmission order according to a priority determined for a message when message transmissions of a plurality of the communication apparatuses collide, and determining whether or not transmission is possible.
  • the section examines the priority of other messages that have completed transmission from the scheduled transmission time of the determination target message to the completion of the transmission of the determination target message, and has a lower priority than the determination target message. When other messages exist, it is determined that transmission of the determination target message is not permitted.
  • the transmission permission / inhibition determining unit may determine that the message non-transmission period exceeds a predetermined length between the scheduled transmission time of the determination target message and the completion of transmission of the determination target message. When the message exists, it is determined that transmission of the determination target message is not permitted.
  • the communication control device includes a hash value request unit that gives a hash value calculation request to the communication device, and a hash value reception unit that receives a hash value transmitted by the communication device as a response to the calculation request And a hash value determination unit that determines whether the hash value received by the hash value reception unit is correct, the reference time point determination unit is based on the time point when the reception of the correct hash value from the communication device is completed, A reference time point is determined.
  • the communication control device includes a discard processing unit that performs processing for causing the communication device that receives the message to discard the message that the transmission permission determination unit determines not to permit transmission. .
  • the communication system is a communication system including a plurality of communication devices that transmit and receive messages to each other and a communication control device that controls communication by the communication devices.
  • the communication device periodically transmits messages.
  • the communication control device includes a reference time determination unit that determines a reference time point related to message transmission by the message transmission unit, and a reference time point determined by the reference time determination unit by the message transmission unit.
  • a message for detecting a message transmitted by the communication apparatus, and a permission period determination unit that sets a predetermined period including the scheduled transmission time as a permission period for message transmission with respect to a scheduled transmission time including a period that is an integral multiple of the message transmission cycle.
  • the detection unit and the message detected by the message detection unit are within the permission period determined by the permission period determination unit. Depending on whether or not sent, and having a determining transmission availability determination unit whether transmission of said message.
  • the communication system is characterized in that the reference time point determination unit and the permission period determination unit determine the reference time point and the permission period for each of the plurality of communication devices.
  • the message transmitted by the communication device includes information indicating the priority of the message, and the permission period determination unit determines the permission period for each message priority. It is made to do so.
  • the communication system further includes arbitration means for arbitrating a transmission order in accordance with a priority determined for a message when message transmissions of a plurality of the communication apparatuses collide, and determining whether or not transmission is possible.
  • the section examines the priority of other messages that have completed transmission from the scheduled transmission time of the determination target message to the completion of the transmission of the determination target message, and has a lower priority than the determination target message. When other messages exist, it is determined that transmission of the determination target message is not permitted.
  • a message non-transmission period that exceeds a predetermined length between the scheduled transmission time of the determination target message and completion of transmission of the determination target message in the communication system according to the present invention.
  • the communication control device includes a hash value request unit that gives a hash value calculation request to the communication device, and a hash value that the communication device transmits as a response to the calculation request.
  • a hash value receiving unit that receives the hash value, and a hash value determination unit that determines whether the hash value received by the hash value receiving unit is correct.
  • a hash value transmission unit that transmits the hash value calculated by the hash value calculation unit to the communication control device, and the reference time point determination unit receives a correct hash value from the communication device. The reference time point is determined on the basis of the time point when the reception is completed.
  • the message transmission unit determines a reference time point based on a time point when the hash value transmission unit completes transmission of a correct hash value, and periodically transmits a message based on the determined time point. It is characterized by carrying out.
  • the communication system includes a discard processing unit that performs processing for causing the communication device that receives the message to discard the message that the communication control device determines that the transmission permission determination unit does not permit transmission. It is characterized by having.
  • a communication control device that detects unauthorized message transmission is provided for a communication system in which a plurality of communication devices are connected to a common communication line and each communication device periodically transmits messages.
  • a predetermined period (t1 ⁇ A to t1 + B, t2 ⁇ A to t2 + B, t3 ⁇ A to t3 + B,..., tn ⁇ A to tn + B) including this time point is determined as a message transmission permission period.
  • the communication control device detects a message transmitted by the communication device by monitoring a common communication line.
  • the communication control device can determine whether or not this message is illegal by determining whether or not the detected message is transmitted within the above-described permission period. It is possible to determine whether or not to permit message transmission.
  • the communication control apparatus of the present invention is configured to determine the permission period for subsequent message transmission based on the reference time determined in the first stage, that is, to determine the permission period on an absolute basis.
  • the communication control apparatus of the present invention determines the permission period for subsequent message transmission based on the reference time determined in the first stage, that is, to determine the permission period on an absolute basis.
  • a predetermined period including a time point when a period T is added to the reception time of this message is used as a permission period, that is, a configuration in which a permission period is determined based on a relative standard Conceivable.
  • a permission period is determined based on a relative standard Conceivable.
  • the CAN communication protocol when a message transmission collision occurs, an arbitration process is performed, and a delay occurs in the transmission of a low-priority message.
  • the permission period for determination when a delay occurs in message transmission, the permission period for determination varies. Therefore, it is necessary to set the permission period wide to some extent, and it is not easy to narrow the permission period. The wider the permission period, the higher the possibility that a fraudulent message will be misjudged as valid. Further, in the configuration in which relative determination is performed, there is a possibility that the permission period of the next message is determined based on reception of an illegal message. When such a situation occurs, there is a possibility that an incorrect message is erroneously determined to be a valid message continuously.
  • the communication control apparatus of the present invention can avoid the occurrence of these problems by determining the permission period on an absolute basis.
  • the communication control device individually determines the reference time for each communication device included in the communication system. In addition, the communication control device determines a permission period for each communication device with respect to each determined reference time point. Note that the message transmission cycle of each communication device may be different. Thereby, even if it is a case where the communication apparatus in which the transmission cycle of a message, a transmission timing, etc. differ in a communication system, a communication control apparatus can determine the propriety of message transmission for every communication apparatus.
  • the communication device can transmit a plurality of types of messages having different transmission cycles, and the communication control device determines the permission period for each message type.
  • the communication control apparatus may determine the reference time point for each message type. Thus, even when one communication device transmits messages having different transmission cycles, the communication control device can determine whether or not transmission is possible for each message type.
  • the communication control apparatus checks whether another message has been transmitted between the scheduled transmission time and the completion of the transmission of the message to be determined. If another message has been transmitted, the communication control device compares the priority of the determination target message with the priority of the other message. When the priority of the other message is higher than the priority of the message to be determined, the communication control device transmits the message to be determined because the message to be determined is considered to have been delayed in transmission due to proper arbitration processing. Allow. On the other hand, if the priority of other messages is lower than the priority of the message to be determined, the delay of the message to be determined is not due to a valid arbitration process. Is not allowed to send messages. Thereby, even in a communication system in which a delay occurs in message transmission due to arbitration processing, the communication control device can determine whether or not message transmission is possible.
  • the communication control device determines whether or not there is a message non-transmission period exceeding a predetermined length between the scheduled transmission time of the message to be determined and the completion of transmission of this message.
  • a message non-transmission period it is considered that the delay of the determination target message is not caused by a valid arbitration process, and therefore the communication control device does not permit transmission of the determination target message.
  • a predetermined procedure is performed between the communication control device and the communication device in order to determine the reference time point.
  • the communication control device transmits a hash value calculation request to the communication device.
  • the communication control apparatus may give information necessary for hash value calculation to the communication apparatus together with the calculation request.
  • the communication device that has received the calculation request from the communication control device calculates a hash value using a predetermined hash function based on, for example, information stored in its own memory, and transmits the calculated hash value to the communication control device. To do.
  • the communication control device that has received the hash value from the communication device determines whether or not this hash value is correct.
  • the communication control apparatus determines a reference time point based on the time point when reception of the hash value is completed. Note that the communication device may use the time when reception of the correct hash value is completed as the reference time, or may use the time when the predetermined time is increased or decreased as the reference time. Similarly, the communication apparatus determines a reference time point based on the time when transmission of the correct hash value is completed, and performs periodic message transmission based on the determined time point. Since the reference time point can be determined based on a highly reliable communication result based on the hash value, the communication control device can perform highly reliable fraud message detection.
  • the communication control device performs a process of causing the communication device that receives this message to discard the message for the message that the communication control device determines is not permitted to be transmitted because it is an illegal message. As a result, it is possible to prevent the communication device from receiving an unauthorized message and performing processing corresponding to this message in the communication device.
  • the communication control device determines a permission period including a time point that is an integral multiple of the message transmission period with respect to the reference time point, and whether or not the message transmitted by the communication device is within the permission period.
  • FIG. 1 is a schematic diagram showing a configuration of a communication system according to the present embodiment.
  • the communication system according to the present embodiment includes a plurality of ECUs 3 mounted on the vehicle 1 and a single monitoring device 5.
  • the ECU 3 and the monitoring device 5 are connected via a common communication line laid on the vehicle 1 and can send and receive messages to and from each other.
  • this communication line is a CAN bus, and the ECU 3 and the monitoring device 5 perform communication according to the CAN protocol.
  • the ECU 3 controls, for example, an engine ECU that controls the engine of the vehicle 1, a body ECU that controls electrical components of the vehicle body, an ABS-ECU that performs control related to ABS (Antilock Brake System), or an airbag of the vehicle 1.
  • ABS Antilock Brake System
  • the monitoring device 5 is a device that monitors unauthorized message transmission to the in-vehicle network.
  • the monitoring device 5 may be provided as a device dedicated to monitoring.
  • the monitoring device 5 may have a configuration in which a monitoring function is added to a device such as a gateway. It may be.
  • FIG. 2 is a block diagram showing the configuration of the ECU 3.
  • blocks relating to communication, fraud detection, and the like are extracted from the plurality of ECUs 3 provided in the vehicle 1. These blocks are common to each ECU 3.
  • the ECU 3 includes a processing unit 31, a ROM (Read Only Memory) 32, a RAM (Random Access Memory) 33, a CAN communication unit 34, and the like.
  • the processing unit 31 is configured using an arithmetic processing device such as a CPU (Central Processing Unit) or an MPU (Micro-Processing Unit).
  • the processing unit 31 reads out and executes the program 32 a stored in the ROM 32 to perform various information processing or control processing related to the vehicle 1.
  • the ROM 32 is configured by using a non-volatile memory element such as a flash memory or an EEPROM (Electrically Erasable Programmable ROM).
  • the ROM 32 stores a program 32a executed by the processing unit 31 and various data 32b necessary for processing performed thereby.
  • the program 32a and data 32b stored in the ROM 32 are different for each ECU 3.
  • the RAM 33 is configured by using a data rewritable memory element such as SRAM (Static Random Access Memory) or DRAM (Dynamic Random Access Memory).
  • the RAM 33 stores various data generated by the processing of the processing unit 31.
  • the CAN communication unit 34 communicates with another ECU 3 or the monitoring device 5 via the CAN bus according to the CAN communication protocol.
  • the CAN communication unit 34 converts the information for transmission given from the processing unit 31 into a signal according to the CAN communication protocol, and outputs the converted signal to the CAN bus to another ECU 3 or the monitoring device 5.
  • Send information The CAN communication unit 34 obtains a signal output by another ECU 3 or the monitoring device 5 by sampling the potential of the CAN bus, and converts this signal into binary information according to the CAN communication protocol. Reception is performed and the received information is given to the processing unit 31.
  • the CAN communication unit 34 performs a process of arbitrating which message is transmitted first when a collision occurs between its own message transmission and message transmission by another ECU 3 or the monitoring device 5, so-called arbitration process.
  • the message transmitted by each ECU 3 has an ID determined in advance according to the type of message. This ID is information handled as a numerical value, and the smaller the value, the higher the priority of message transmission. For this reason, in the communication system, when a plurality of message transmissions collide with each other on the CAN bus, the message transmission with the highest priority is performed, and another message is transmitted after the transmission of this message is completed.
  • the arbitration process performed by the CAN communication unit 34 is an existing technique, and thus a detailed description of the processing procedure is omitted.
  • the message processing unit 41, the hash value calculation unit 42, and the like are realized as software functional blocks by executing the program 32a.
  • part or all of the message processing unit 41 and the hash value calculation unit 42 may be realized as functional blocks by hardware.
  • the message processing unit 41 acquires information such as information detected by a sensor or feedback information from a control target device, creates a CAN protocol message including the acquired information, and sends the created message to the CAN bus. The transmission process is performed periodically. Note that the message transmission cycle is determined for each message type (ie, ID), and the message processing unit 41 can perform transmission with a different cycle for each message type.
  • the hash value calculation unit 42 performs a process of calculating a hash value in response to a calculation request from the monitoring device 5.
  • the hash value calculation unit 42 is based on a part or all of the data stored in the ROM 32 (which may include both the program 32a and the data 32b) and the random seed attached to the calculation request from the monitoring device 5. Then, a hash value is calculated by using a predetermined hash function. A detailed procedure for calculating the hash value by the hash value calculation unit 42 will be described later.
  • the hash value calculation unit 42 transmits the calculated hash value to the monitoring device 5 as a response to the calculation request.
  • FIG. 3 is a block diagram showing the configuration of the monitoring device 5.
  • the monitoring device 5 includes a processing unit 51, a storage unit 52, a CAN communication unit 53, and the like.
  • the processing unit 51 is configured by using an arithmetic processing device such as a CPU or MPU, and performs processing for monitoring the behavior and communication of the ECU 3 of the vehicle 1 by reading and executing a program stored in the storage unit 52.
  • the storage unit 52 is configured using a non-volatile memory element that can rewrite data, such as a flash memory or an EEPROM.
  • the storage unit 52 stores copy data 52 a obtained by copying the stored contents of the ROM 32 of the ECU 3 mounted on the vehicle 1, and cycle information 52 b regarding the transmission cycle of messages transmitted by each ECU 3.
  • the CAN communication unit 53 performs communication with the ECU 3 via the CAN bus according to the CAN communication protocol.
  • the CAN communication unit 53 converts the information for transmission given from the processing unit 51 into a signal according to the CAN communication protocol, and outputs the converted signal to the CAN bus to transmit information to the ECU 3.
  • the CAN communication unit 53 obtains a signal output from the ECU 3 by sampling the potential of the CAN bus, converts the signal into binary information according to the CAN communication protocol, and receives the information. Information is given to the processing unit 51.
  • the processing unit 51 of the monitoring device 5 is provided with a reference time point determination unit 61, a permission period determination unit 62, a transmission availability determination unit 63, a discard processing unit 64, and the like.
  • the reference time determination unit 61 to the discard processing unit 64 may be configured as hardware functional blocks or may be configured as software functional blocks.
  • the reference time point determination unit 61 and the permission period determination unit 62 perform processing for determining conditions for the monitoring device 5 to detect unauthorized message transmission.
  • the transmission permission / inhibition determination unit 63 performs processing for determining whether or not the message output on the CAN bus can be transmitted based on the conditions determined by the reference time determination unit 61 and the permission period determination unit 62.
  • the discard processing unit 64 performs a process for causing the ECU 3 to discard the message that is not permitted to be transmitted by the transmission permission / inhibition determining unit 63 so as to prevent the ECU 3 from receiving the message.
  • FIG. 4 is a schematic diagram illustrating the configuration of the copy data 52a stored in the storage unit 52 of the monitoring device 5.
  • the monitoring device 5 stores the same data stored in the ROM 32 as copy data 52a for all the monitored ECUs 3 mounted on the vehicle 1.
  • identification information uniquely assigned to each ECU 3 (ECUa, ECUb... In FIG. 4) and the stored contents of the ROM 32 of each ECU3 are stored in association with each other.
  • FIG. 5 is a schematic diagram illustrating the configuration of the period information 52b stored in the storage unit 52 of the monitoring device 5.
  • the monitoring device 5 associates identification information (CAN-ID) attached to a message transmitted / received on the network in the vehicle 1 with a cycle in which a message having this CAN-ID is transmitted as cycle information 52b. I remember it.
  • CAN-ID 1 has a transmission cycle of 10 ms
  • a message with CAN-ID 2 has a transmission cycle of 50 ms
  • a message with CAN-ID 3 has a transmission cycle of 32 ms.
  • these numerical values are examples.
  • the monitoring device 5 performs processing for detecting that an unauthorized message is transmitted on the CAN bus through which the plurality of ECUs 3 transmit and receive messages.
  • an unauthorized communication device may be illegally connected to the CAN bus, and this communication device may transmit an unauthorized message on the CAN bus.
  • any ECU 3 mounted on the vehicle 1 is illegally modified or altered and the ECU 3 transmits an illegal message.
  • the unauthorized messages detected by the monitoring device 5 may be due to other factors.
  • An unauthorized communication device can transmit an unauthorized message with a specific CAN-ID according to the CAN protocol.
  • CAN-ID attached to such a fraudulent message, a legitimate one used in the communication system of the vehicle 1 is used, but other data included in the fraudulent message is illegal data.
  • the ECU 3 receives an unauthorized message based on the CAN-ID, the ECU 3 performs processing based on unauthorized data.
  • an unauthorized message with a regular CAN-ID that is, a so-called spoof message is detected.
  • the monitoring device 5 detects an invalid message by determining whether or not this message is transmitted at a correct cycle with respect to a message to be transmitted periodically.
  • FIG. 6 is a schematic diagram for explaining illegal message detection processing by the monitoring device 5. For each CAN-ID attached to a message transmitted and received in the communication system, the monitoring device 5 determines a permission period during which transmission of a message having this CAN-ID is permitted. FIG. 6 illustrates a permission period determined by the monitoring device 5 for a message to which a certain CAN-ID is attached. In the present embodiment, it is assumed that a plurality of ECUs 3 use one CAN-ID, that is, a plurality of ECUs 3 do not transmit a message with the same CAN-ID.
  • the transmission cycle of the message to be monitored by the monitoring device 5 is T.
  • the reference time determination unit 61 of the monitoring device 5 determines a reference time t0 for message transmission by performing a predetermined procedure with the ECU 3 that transmits this message (the details of the reference time determination process will be described later). ).
  • the permission period determination unit 62 of the monitoring device 5 refers to the cycle information 52b stored in the storage unit 52 to obtain the transmission cycle T of the message to be monitored.
  • the permission period determination unit 62 sets a time point t1 obtained by adding the transmission period T to the reference time point t0 as a scheduled message transmission time point t1.
  • the permission period determination unit 62 sets a time point t2 obtained by adding twice the transmission period T to the reference time point t0 as a scheduled transmission time point t2, and a time point when adding three times the transmission period T to the reference time point t0.
  • t3 can be a scheduled transmission time t3
  • the permission period determination unit 62 of the monitoring device 5 determines a period in which a predetermined period A and a period B are provided for the scheduled transmission time t1 as the permission period.
  • the permission period determining unit 62 determines the period of t1 ⁇ A ⁇ t ⁇ t1 + B as the permission period.
  • the same applies to the scheduled transmission times t2, t3,. That is, the permission period determining unit 62 determines t0 + nT ⁇ A ⁇ t ⁇ t0 + nT + B (n 1, 2, 3,...) As the permission period.
  • the period A and the period B for determining the permission period are determined in advance based on, for example, a simulation of a communication system or a measurement result in an actual machine.
  • the same value may be used for all messages.
  • a different value may be used for each CAN-ID.
  • the period A and the period B can be stored in the period information 52b in association with the CAN-ID.
  • the period A can be determined based on a clock error between the monitoring device 5 and the ECU 3 that transmits this message.
  • the period B is determined in consideration of the time that this message is delayed by the arbitration process.
  • the CAN communication unit 53 of the monitoring device 5 monitors the transmission of a message to the CAN bus, and notifies the processing unit 51 when a message transmission is detected. Based on the notification from the CAN communication unit 53, the transmission permission / inhibition determination unit 63 of the processing unit 51 acquires the CAN-ID of the transmitted message and information regarding the start time or end time of message transmission. Further, the transmission permission / inhibition determination unit 63 acquires the permission period determined by the permission period determination unit 62 for the acquired CAN-ID. The transmission permission / inhibition determination unit 63 determines whether or not the message for which transmission has been detected is transmitted within the permission period.
  • the condition for judging whether or not the message has been transmitted within the permission period is that the message transmission has started within the permission period, or that the message transmission has been completed within the permission period. There are two possible conditions. Any of the conditions can be adopted, and the value of the period B may be appropriately set according to which condition is adopted. In the present embodiment, on the condition that the message transmission is completed within the permission period, the transmission permission / inhibition determination unit 63 determines whether the message has been transmitted within the permission period.
  • the transmission permission / inhibition determination unit 63 determines that the message is an unauthorized message and determines that transmission of the message is not permitted.
  • the discard processing unit 64 of the monitoring device 5 performs processing for causing the ECU 3 connected to the CAN bus to discard this message. Details of the message discarding process will be described later.
  • the transmission permission / inhibition determination unit 63 performs another condition determination when the message is transmitted within the permission period.
  • the transmission permission / inhibition determination unit 63 performs condition determination regarding arbitration processing and condition determination regarding a message non-transmission period.
  • FIG. 7 to 9 are schematic diagrams for explaining the condition determination regarding the arbitration process by the transmission permission / inhibition determination unit 63.
  • FIG. 7 As described above, in a CAN communication system, arbitration processing is performed when a plurality of message transmissions collide, and there is a possibility that a delay occurs in the transmission of a low priority message.
  • the CAN-ID of the message to be determined is 7, and three messages with higher priority than this message (messages with CAN-IDs 3, 5, and 2 respectively) were transmitted earlier by the arbitration process. The state is illustrated.
  • the transmission permission / inhibition determination unit 63 determines whether another message transmission is performed before the transmission of the determination target message in the permission period of the determination target message. When other message transmission is performed, the transmission permission / inhibition determination unit 63 checks the CAN-ID of one or more other transmitted messages and compares it with the CAN-ID of the determination target message. The CAN-ID attached to the message in the CAN protocol indicates the priority. The smaller the value, the higher the priority. The transmission permission / inhibition determination unit 63 determines that the determination target message is genuine only when either of the following conditions 1 or 2 is satisfied for all other previously transmitted messages. Condition 1: When the CAN-ID of another message is smaller than the CAN-ID of the message to be determined, that is, when all the previous messages have high priority. Condition 2: The other message is lower than the message to be determined. If it is a priority but a low-priority message has been sent because transmission started before the permitted period of the message to be judged
  • the transmission permission determination unit 63 determines that the determination target message is an unauthorized message.
  • the CAN-ID of the message to be determined is 7, and the state in which the messages with CAN-IDs 3, 5, and 9 are transmitted before this message is transmitted is shown.
  • a message with a CAN-ID of 9 has a lower priority than a determination target message with a CAN-ID of 7.
  • the transmission target determination unit 63 determines that the determination target message is an invalid message and transmission is not permitted, a message discarding process by the discarding processing unit 64 is performed.
  • Condition 2 is an exception to condition 1. That is, according to the condition 1, it is necessary that other messages before the determination target message have higher priority than the determination target message. However, among the one or more other messages sent within the permission period of the message, the first sent message is the message that has already been sent at the start of the permission period. The condition 2 is that the message may have a lower priority than the above message.
  • FIG. 9 shows a state in which a message with CAN-ID 10 is transmitted before the start of the permission period in addition to the message shown in FIG. A message with a CAN-ID of 10 has a lower priority than a determination target message with a CAN-ID of 7. However, since the low priority message is a message that has started transmission before the start of the permission period of the determination target message, the transmission permission / inhibition determination unit 63 permits transmission of the determination target message.
  • FIG. 10 is a schematic diagram for explaining the condition determination regarding the message non-transmission period by the transmission permission / inhibition determination unit 63.
  • the transmission permission / inhibition determination unit 63 determines whether there is a message non-transmission period in which no message is transmitted on the CAN bus between the scheduled transmission time t1 and the transmission of the determination target message in the determination target message permission period. Find out.
  • the transmission permission / inhibition determination unit 63 determines whether or not the message non-transmission period exceeds a predetermined length.
  • the transmission permission / inhibition determination unit 63 individually compares each message non-transmission period with a predetermined length.
  • the predetermined length for example, a period required to transmit about 3 to 10 bits of a message can be set. This is based on a period of 3 bits of IFS (Inter Frame Space) in message transmission of the CAN protocol, or 10 bits obtained by adding 7 bits of EOF (End Of Frame) to IFS.
  • IFS Inter Frame Space
  • EOF End Of Frame
  • the transmission permission / inhibition determination unit 63 determines that the determination target message is an invalid message and transmission is not permitted. If the transmission target determination unit 63 determines that the determination target message is an invalid message and transmission is not permitted, a message discarding process by the discarding processing unit 64 is performed.
  • the transmission propriety determination unit 63 determines that the determination target message is valid It is determined that the message is correct, and transmission is permitted.
  • the transmission permission / inhibition determination unit 63 detects the transmission of the message having the CAN-ID to be determined within the permission period, whether or not a delay other than the delay due to the valid arbitration processing has occurred in the transmission of this message. Determine whether. That is, the transmission permission / inhibition determination unit 63 indicates that the priority of messages transmitted prior to the determination target message within the permission period is high (except for messages that have been transmitted before the permission period), and the scheduled transmission time
  • the condition for permitting the transmission of the message to be determined is that no message non-transmission period exceeding a predetermined length exists between the transmission of the message to be determined and the determination target message.
  • the transmission permission / inhibition determination unit 63 permits transmission of a determination target message when both conditions are satisfied, and does not permit determination target message transmission when at least one of the conditions is not satisfied.
  • the monitoring device 5 stores the history of messages transmitted on the CAN bus in the storage unit 52 in order to perform the condition determination by the transmission permission determination unit 63.
  • the history to be stored includes the CAN-ID of the transmitted message, information on the transmission start time or the transmission end time, and the like.
  • the monitoring of message transmission by the monitoring device 5 is performed for each CAN-ID. That is, the monitoring device 5 determines a permission period for each CAN-ID, and determines whether or not a message can be transmitted for each CAN-ID. For example, in FIG. 7, an example in which the monitoring device 5 performs the determination for a message with a CAN-ID of 7 has been described. At this time, the monitoring device 5 also performs a message with a CAN-ID of 3, 5, and 2, respectively. Individual transmission permission / inhibition is determined.
  • FIG. 11 and FIG. 12 are flowcharts showing a procedure of message transmission permission / inhibition determination processing performed by the monitoring device 5.
  • the variable n used in this flowchart can be realized by using a storage area such as a register or a memory included in the processing unit 51 of the monitoring device 5, for example.
  • the processing unit 51 of the monitoring device 5 performs a process of determining the reference time t0 by the reference time determination unit 61 (step S1).
  • the processing unit 51 reads the cycle information 52b stored in the storage unit 52 (Step S2), and acquires the transmission cycle T of the determination target message.
  • the processing unit 51 initializes the value of the variable n to 1 (step S3).
  • the permission period determination unit 62 of the processing unit 51 determines the permission period based on the reference time t0 determined in step S1, the cycle T acquired in step S2, predetermined constants A and B, and the variable n. Determine (step S4).
  • the permission period can be determined as a period from (t0 + nT ⁇ A) to (t0 + nT + B).
  • the transmission permission determination unit 63 of the processing unit 51 determines whether or not the permission period determined in step S4 has ended (step S5). When the permission period has not expired (S5: NO), the transmission permission / inhibition determination unit 63 checks whether or not the CAN communication unit 53 has detected message reception on the CAN bus (step S7). When the message reception is not detected (S7: NO), the transmission permission / inhibition determination unit 63 returns the process to step S5. When message reception is detected (S7: YES), the transmission permission / inhibition determination unit 63 determines whether or not this message is a determination target message by examining the CAN-ID of the detected message (step S8). ).
  • the transmission permission / inhibition determination unit 63 When the message is not a determination target message (S8: NO), the transmission permission / inhibition determination unit 63 records information (CAN-ID, transmission start time, end time, etc.) related to the message as a history (step S9), and step S5. Return processing to. When it is a message to be determined (S8: YES), the transmission permission / inhibition determination unit 63 determines whether or not this message has been transmitted within the permission period (step S10). If not transmitted within the permission period (S10: NO), the processing unit 10 performs a message discarding process by the discarding processing unit 64 (step S11), and returns the process to step S5.
  • the transmission permission / inhibition determination unit 63 determines whether or not this message has been transmitted within the permission period (step S10). If not transmitted within the permission period (S10: NO), the processing unit 10 performs a message discarding process by the discarding processing unit 64 (step S11), and returns the process to step S5.
  • the transmission availability determination unit 63 determines whether or not there is a delay of this message with respect to the scheduled transmission time tn (step S12). If there is no delay (S12: NO), the transmission permission / inhibition determination unit 63 determines that transmission is permitted because the message is valid, and returns the process to step S5 without performing the message discarding process. When there is a message delay with respect to the scheduled transmission time tn (S12: YES), the transmission permission / inhibition determining unit 63 acquires the history regarding the message transmission recorded in step S9 (step 13).
  • the transmission availability determination unit 63 determines whether a message having a lower priority than the determination target message has been transmitted between the scheduled transmission time tn and the determination target message transmission (Ste S14).
  • the transmission permission determination unit 63 determines whether or not the low-priority message has been transmitted before the determination target message permission period. Is further determined (step S15).
  • the transmission permission / inhibition determining unit 63 When the low-priority message is not transmitted (S14: NO), or when the low-priority message is started before the permission period (S15: YES), the transmission permission / inhibition determining unit 63 Then, it is determined whether there is a non-transmission period of a message exceeding a predetermined length between the scheduled transmission time tn and the determination target message transmission (step S16). If there is no message non-transmission period (S16: NO), the transmission permission determination unit 63 determines that transmission is permitted because the message is valid, and returns the process to step S5 without performing the message discarding process.
  • the transmission availability determination unit 63 Since the message is not valid, it is determined that transmission is not permitted, the message discard process is performed by the discard processing unit 64 (step S17), and the process returns to step S5.
  • step S5 When it determines with the permission period having been complete
  • a message transmitted / received in the communication system according to the present embodiment conforms to the CAN protocol, and includes a CAN header, a data field, a CRC (Cyclic Redundancy Check) field, an ACK field, an EOF (End Of Frame), and the like. It is configured to include.
  • the CAN header includes an SOF (Start Of Frame), an arbitration field, a control field, and the like in the conventional CAN protocol, and the above-mentioned CAN-ID is set in the arbitration field.
  • the data field stores a main body of information to be exchanged between the ECUs 3 such as a control instruction to the ECU 3 or a sensor detection result. Since the CRC field, ACK field, and EOF are the same as those used in the conventional CAN protocol, detailed description thereof is omitted.
  • the CRC field stores information for error detection.
  • the ACK field is a field for a reception response by the ECU 3 that receives this frame.
  • the EOF is a specific bit string indicating the end of the field.
  • the discard processing unit 64 of the monitoring device 5 transmits an error frame to the CAN bus during the EOF output period of this message for the message that the transmission permission determination unit 63 determines not to permit transmission. With this error frame, all ECUs 3 connected to the CAN bus can discard the illegal message being received.
  • the transmission permission / inhibition determination unit 63 of the monitoring device 5 needs to finish the determination before the EOF of the message is output to the CAN bus.
  • the transmission permission / inhibition determination unit 63 starts the above-described determination processing when the CAN header output of the message on the CAN bus is completed, for example, and ends the determination before outputting the EOF. Since the message length of the CAN protocol message is specified, the transmission permission / inhibition determination unit 63 can calculate the transmission end time even before the message transmission ends.
  • the monitoring device 5 stores the CAN-ID determined by the transmission permission / inhibition determination unit 63 as an invalid message, and when a message with the same CAN-ID is output to the CAN bus thereafter.
  • the discard processing unit 64 may discard the message without performing the determination by the transmission permission / inhibition determining unit 63.
  • the message discarding process by the monitoring device 5 is not limited to the above-described method, and may be performed by various other methods.
  • the monitoring device 5 also transmits a warning message to the ECU 3, a notification to the user of the vehicle 1, information transmission to an external server device, or a communication system or It may be configured to perform processing other than discarding such as shutdown of the corresponding communication network.
  • FIG. 13 is a schematic diagram for explaining a reference time point determination process performed between the ECU 3 and the monitoring device 5.
  • the monitoring device 5 of the communication system according to the present embodiment starts the reference time determination process by the reference time determination unit 61 of the processing unit 51 after being activated by turning on the power.
  • the reference time determination unit 61 of the monitoring device 5 first generates information used for hash value calculation.
  • the reference time point determination unit 61 generates a random seed and region designation information.
  • the reference time point determination unit 61 uses, as a random seed, data having a predetermined bit length obtained by generating a random number using a predetermined algorithm.
  • the area designation information is information that designates an area of the ROM 32 that is a target of hash value calculation, and is information such as a start address and an end address, or a start address and a data size.
  • the reference time point determination unit 61 can determine a start address based on, for example, a random number, and add a predetermined number to the start address as an end address.
  • the reference time point determination unit 61 of the monitoring device 5 transmits the generated random seed and region designation information to the ECU 3 together with a hash value calculation request. Further, the reference time point determination unit 61 reads the storage content of the ECU 3 to be processed from the copy data 52a of the storage unit 52, and calculates a hash value using the read storage content and the generated random seed and region designation information. . The reference time point determination unit 61 extracts the location specified by the area specification information from the copied storage content, and inputs the extracted storage content and random seed to a predetermined hash function, thereby obtaining the hash value. calculate. In the present embodiment, it is assumed that the reference time point determination unit 61 calculates a 160-bit hash value using the SHA-1 hash function.
  • the ECU 3 that has received the random seed and region designation information from the monitoring device 5 uses the stored contents of its own ROM 32 and the received random seed and region designation information to perform a hash in the hash value calculation unit 42 of the processing unit 31. Calculate the value.
  • the hash value calculation unit 42 calculates a hash value by extracting a part specified by the area specifying information from the ROM 32 and inputting the extracted storage content and a random seed to a predetermined hash function. Note that the hash function used by the monitoring device 5 and the hash function used by the ECU 3 are the same, and the content stored in the copy data 52a by the monitoring device 5 and the content stored in the ROM 32 by the ECU 3 are the same. Therefore, the monitoring device 5 and the ECU 3 should calculate the same hash value. If the two hash values are different from each other, there is a possibility that the stored content of the ROM 32 of the ECU 3 has been falsified.
  • the monitoring device 5 and the ECU 3 use an existing hash function such as MD (MessageMDDigest) 4, MD5, SHA-1, SHA-256, SHA-384, SHA-512, EIPEMD-160, or SHA-3. It can be configured to calculate a hash value. These are so-called one-way hash functions, and are functions that output one hash value for input information. Information input to the hash function is a part or all of the program 32a or data 32b stored in the ROM 32 of the ECU 3 in the present embodiment.
  • the hash function simply treats the input as binary information, A hash value can be calculated.
  • the monitoring device 5 and the ECU 3 store a predetermined hash function, and calculate a hash value using this hash function.
  • the calculation method in the case where the monitoring device 5 and the ECU 3 calculate the hash value using the hash function of SHA-1 will be described. Note that the detailed processing of the hash function of SHA-1 and the case where the monitoring device 5 and the ECU 3 use other hash functions are omitted because they are existing techniques.
  • the monitoring device 5 and the ECU 3 first perform a padding process.
  • the padding process the monitoring device 5 and the ECU 3 adjust the size of information to be processed to be an integral multiple of a predetermined value (512 bits) by adding extra data after the input information.
  • the monitoring device 5 and the ECU 3 divide the padded information into 512-bit blocks, and perform a first process of calculating 80 values for each block.
  • the monitoring device 5 and the ECU 3 perform an operation using the value calculated in the first process with respect to the initial value of the predetermined size (160 bits), and use the 160-bit value after the operation as the hash value.
  • the monitoring device 5 and the ECU 3 perform an 80-step operation on the initial value of 160 bits using 80 values calculated for one block.
  • block information can be mixed with the 160-bit initial value, and a 160-bit value is obtained as an output.
  • the monitoring device 5 and the ECU 3 use the obtained 160-bit value as an initial value, and similarly perform 80-step calculations using the 80 values calculated for the next block.
  • the monitoring device 5 and the ECU 3 perform the same 80-step process for all the blocks, and use the finally obtained 160-bit value as the hash value.
  • the monitoring device 5 and the ECU 3 need to calculate a hash value using a random seed generated by the monitoring device 5.
  • the monitoring device 5 and the ECU 3 can use a random seed for the data added to the input information in the padding process.
  • the monitoring device 5 and the ECU 3 can use a random seed for the initial value of 160 bits in the second process.
  • a random seed is used as the initial value of the second process.
  • the method of using random seeds by the monitoring device 5 and the ECU 3 is not limited to the above.
  • the monitoring device 5 and the ECU 3 can use, as input information to the hash function, a logical operation value (exclusive OR or the like) between the storage content of the ROM 32 that is the target of hash value calculation and the random seed.
  • the monitoring device 5 and the ECU 3 can use, as input information to the hash function, a random seed added to a predetermined position such as a head portion or a tail portion of the stored contents of the ROM 32 that is a target of hash value calculation.
  • the reference time point determination unit 61 of the monitoring device 5 performs a process of extracting a part of the calculated hash value after the transmission of the random seed and the region designation information to the ECU 3 and the calculation of the hash value.
  • the reference time point determination unit 61 extracts a 64-bit value from the calculated 160-bit hash value and uses it as confirmation information.
  • the reference time point determination unit 61 transmits a hash confirmation request including the extracted confirmation information to the ECU 3 to be processed.
  • the processing unit 31 of the ECU 3 compares the confirmation information acquired from the monitoring device 5 with the hash value calculated by the hash value calculation unit 42 itself. The processing unit 31 determines whether the hash value calculated by the hash value calculation unit 42 includes a part of the hash value acquired as confirmation information from the monitoring device 5. When it is determined that the hash value of the confirmation information is not included in its own hash value, the hash value calculated by the ECU 3 and the hash value calculated by the monitoring device 5 are not considered to match, so the processing unit 31 interrupts the process. Then, an error notification or the like is given to the monitoring device 5.
  • the processing unit 31 Processing for transmitting a response (hash confirmation response) to the hash confirmation request to 5 is performed.
  • the processing unit 31 extracts 64-bit information following the confirmation information from the monitoring device 5 as response information in the 160-bit hash value calculated by the hash value calculation unit 42.
  • the processing unit 31 includes the extracted 64-bit response information in the hash confirmation response and transmits it to the monitoring device 5.
  • the method for extracting the confirmation information and the response information from the hash value is not limited to this. For example, part of the confirmation information and the response information may overlap.
  • the reference time point determination unit 61 of the monitoring device 5 that has received the hash confirmation response from the ECU 3 acquires response information included in the received hash confirmation response.
  • the reference time point determination unit 61 compares the response information acquired from the ECU 3 with the hash value calculated by itself.
  • the reference time point determination unit 61 determines whether or not a part of the hash value acquired as the response information from the ECU 3 is included in the part obtained by removing the confirmation information from the hash value calculated by itself. When it is determined that the hash value of the response information is not included in its own hash value, it is considered that the hash value calculated by the monitoring device 5 and the hash value calculated by the ECU 3 do not match. Is interrupted, and an error notification or the like is made to the ECU 3.
  • the reference time point determination unit 61 regards the hash value calculated by the monitoring device 5 and the hash value calculated by the ECU 3 as the same value. At this time, the reference time point determination unit 61 may notify the ECU 3 that the hash value has been successfully determined. The reference time point determination unit 61 determines the time point when the reception of the valid hash confirmation response from the ECU 3 is completed as the reference time point t0. After determining the reference time t0, the monitoring device 5 determines the scheduled transmission time and the permission period as described above and starts monitoring message transmission.
  • the processing unit 31 of the ECU 3 sets the time point when the transmission of the hash confirmation response to the monitoring device 5 is completed as the reference time point t0.
  • the message processing unit 41 of the ECU 3 transmits a message at a cycle T with respect to the reference time t0.
  • FIG. 14 is a schematic diagram for explaining reference time point determination processing with the plurality of ECUs 3 by the monitoring device 5.
  • the monitoring device 5 performs reference time determination processing with three ECUs 3, but the monitoring device 5 performs reference time determination processing with two or less ECUs 3 or four or more ECUs 3. Is the same.
  • the monitoring device 5 sequentially transmits a hash value calculation request including a random seed and region designation information to each ECU 3. At this time, a common value may be used for the random seed and region designation information included in each hash value calculation request, or a different value may be set for each ECU 3.
  • Each ECU 3 that has received a hash value calculation request from the monitoring device 5 calculates a hash value based on the stored contents of its own ROM 32. Further, the monitoring device 5 reads the stored contents of each ECU 3 from the copy data 52 a of the storage unit 52 and calculates a hash value for each ECU 3.
  • the monitoring device 5 that has finished calculating the hash value of each ECU 3 transmits a hash value confirmation request to any one of the ECUs 3 and receives a hash value confirmation response from the ECU 3.
  • the monitoring device 5 determines whether or not the hash value included in the received hash value confirmation response is correct. If the hash value is correct, the monitoring device 5 determines that the reception of the hash value confirmation response is completed with this ECU 3.
  • the reference time t0 is determined.
  • the monitoring device 5 transmits a hash value confirmation request, receives a hash value confirmation response, and determines a reference time for another ECU 3. In this way, the monitoring device 5 sequentially repeats transmission of the hash value confirmation request, reception of the hash value confirmation response, and determination of the reference time point for each ECU 3 included in the communication system. After the reference time points are determined for all the ECUs 3, the monitoring device 5 starts monitoring message transmission, and each ECU 3 starts message transmission / reception. Note that the monitoring by the monitoring device 5 and the message transmission by the ECU 3 may be started sequentially from the reference time determined.
  • FIG. 15 is a flowchart showing a procedure of reference time determination processing by the monitoring device 5.
  • the reference time point determination unit 61 of the monitoring device 5 generates a random seed used for hash value calculation and area designation information that designates a storage area of the ROM 32 of the ECU 3 as a hash value calculation target (step S21).
  • the reference time point determination unit 61 transmits a hash value calculation request including the generated random seed and region designation information to the ECU 3 to be processed by the CAN communication unit 53 (step S22).
  • the reference time point determination unit 61 acquires the copy data 52a stored in the ECU 3 to be processed from the storage unit 52, and determines the predetermined time based on the acquired copy data 52a and the random seed and region designation information generated in step S21. A hash value is calculated using the hash function (step S23). The reference time point determination unit 61 extracts a part of the hash value calculated in step S23 as confirmation information (step S24). The reference time point determination unit 61 transmits a hash value confirmation request including the extracted confirmation information to the ECU 3 to be processed by the CAN communication unit 53 (step S25).
  • the reference time determination unit 61 determines whether or not the CAN communication unit 53 has received a hash value confirmation response transmitted by the ECU 3 in response to the hash value confirmation request (step S26). When the hash value confirmation response has not been received (S26: NO), the reference time point determination unit 61 determines whether an error notification has been received from the ECU 3 to be processed (step S27). When the error notification is not received (S27: NO), the reference time point determination unit 61 returns the process to step S26 and waits until a hash value confirmation response or an error notification is received from the ECU 3.
  • the reference time point determination unit 61 When the hash value confirmation response is received from the ECU 3 to be processed (S26: YES), the reference time point determination unit 61 includes the response information included in the received hash value confirmation response in the hash value calculated in step S23. Whether or not the response information is successful is determined according to whether or not (step S28). When the error notification is received from the ECU 3 (S27: YES), or when the response information received from the ECU 3 is not correct (S28: NO), the reference time point determination unit 61 modifies the stored contents of the ROM 32 of the target ECU 3. For example, an appropriate error process such as stopping the operation of the ECU 3 is performed (step S29), and the process is terminated.
  • the reference time point determination unit 61 determines the time point when the reception of the hash value confirmation response from the ECU 3 is completed as the reference time point (step S30), and ends the process.
  • FIG. 16 is a flowchart showing a procedure of processing performed by the ECU 3 in response to a hash value calculation request from the monitoring device 5.
  • the processing unit 31 of the ECU 3 determines whether or not the hash value calculation request has been received from the monitoring device 5 by the CAN communication unit 34 (step S31). When the hash value calculation request is not received (S31: NO), the processing unit 31 waits until the hash value calculation request is received. When the hash value calculation request is received (S31: YES), the processing unit 31 acquires the random seed and area designation information included in the received hash value calculation request (step S32).
  • the hash value calculation unit 42 of the processing unit 31 calculates a hash value using a predetermined hash function based on the storage content of the ROM 32 and the random seed and area designation information acquired in step S32 (step S33). .
  • the processing unit 31 stores the calculated hash value in the storage unit 33 (step S34) and ends the process.
  • FIG. 17 is a flowchart showing a procedure of processing performed by the ECU 3 in response to a hash value confirmation request from the monitoring device 5.
  • the processing unit 31 of the ECU 3 determines whether or not the hash value confirmation request has been received from the monitoring device 5 by the CAN communication unit 34 (step S41). When the hash value confirmation request has not been received (S41: NO), the processing unit 31 waits until the hash value confirmation request is received. When the hash value confirmation request is received (S41: YES), the processing unit 31 reads the hash value stored in the storage unit 33 (step S42).
  • the processing unit 31 determines the success or failure of the confirmation information according to whether or not the confirmation information included in the hash value confirmation request received in step S41 is included in the hash value read in step S42 ( Step S43). If the confirmation information is not correct (S43: NO), the processing unit 31 transmits an error notification to the monitoring device 5 (step S44) and ends the process.
  • the processing unit 31 extracts, as response information, a predetermined length portion following the confirmation information from the hash value read in step S42 (step S45). .
  • the processing unit 31 transmits a hash value confirmation response including the extracted response information to the monitoring device 5 through the CAN communication unit 34 (step S46).
  • the processing unit 31 determines the time point when the transmission of the hash value confirmation response is completed as the reference time point (step S47), and ends the process.
  • the reference time determination process is performed when the monitoring device 5 and the ECU 3 are activated.
  • the timing of the process is not limited thereto. Further, when there is a deviation in the timing at which the ECU 3 transmits a message for some reason or when the message transmission cycle is changed, a process for re-determining the reference time point between the monitoring device 5 and the ECU 3 may be performed. .
  • the same process as the first reference time point determination process as described above may be performed. That is, the monitoring device 5 may send a hash value calculation request and a hash value confirmation request, and the ECU 3 may send a hash value confirmation response and redetermine the reference time point accordingly.
  • the ECU 3 may be configured to transmit a request for performing a process for re-determining the reference time point to the monitoring device 5, and the monitoring device 5 may start the reference time point determination process accordingly.
  • the hash value at the time of performing the reference time determination process may be stored, and the ECU 3 may transmit a reference time redetermination request including the hash value to the monitoring device 5.
  • the monitoring device 5 that has received this redetermination request sets the time when the reception of the redetermination request is completed as a new reference time when the hash value included in the redetermination request is correct.
  • the ECU 3 may set the time point when the transmission of the redetermination request is completed as a new reference time point.
  • the communication system is a monitoring system that detects unauthorized message transmission with respect to a communication system in which a plurality of ECUs 3 are connected to a CAN bus and each ECU 3 periodically transmits messages.
  • the apparatus 5 is provided.
  • the monitoring device 5 detects the message transmitted by the ECU 3 by monitoring the CAN bus.
  • the monitoring device 5 can determine whether or not this message is invalid by determining whether or not the detected message is transmitted within the permission period. It can be determined whether or not transmission is permitted.
  • Such a monitoring apparatus 5 is configured to determine a permission period for subsequent message transmission based on the reference time t0 determined in the first stage, that is, to determine the permission period on an absolute basis. It is a configuration. On the other hand, for example, each time a message is received, a configuration is adopted in which the permission period is determined with the time when the period T is added to the reception time of the message as the scheduled transmission time, that is, the permission period is determined on a relative basis. Can be considered. However, in the CAN communication protocol, when a message transmission collision occurs, arbitration processing is performed, and transmission of a low-priority message is delayed. In the configuration in which relative determination is performed, when a delay occurs in message transmission, the permission period for determination varies.
  • the monitoring device 5 can avoid the occurrence of these problems by determining the permission period on an absolute basis.
  • the monitoring device 5 individually determines the reference time point t0 for each ECU 3 included in the communication system.
  • the monitoring device 5 determines the scheduled transmission time tn and the permission period for each ECU 3 with respect to each determined reference time t0. Thereby, even if ECU3 from which the transmission cycle T of a message, transmission timing, etc. are contained in the communication system is contained, the monitoring apparatus 5 can determine the propriety of message transmission for every ECU3.
  • the ECU 3 can transmit a plurality of types of messages having different transmission cycles, and the monitoring device 5 determines a permission period for each CAN-ID of the message. Thereby, even if it is a case where one ECU3 transmits the message from which a transmission period differs, the monitoring apparatus 5 can determine the propriety of transmission for every kind of message.
  • the reference time point t0 is determined for each ECU 3.
  • the present invention is not limited to this, and the reference time point t0 may be determined for each CAN-ID.
  • the monitoring device 5 may perform reference time determination processing a plurality of times (that is, the number of CAN-IDs assigned to the ECU 3) for one ECU 3.
  • the monitoring device 5 checks whether another message has been transmitted between the scheduled transmission time tn and the completion of the transmission of the message to be determined. If another message has been transmitted, the monitoring device 5 compares the priority of the determination target message with the priority of the other message. If the priority of the other message is higher than the priority of the determination target message, it is considered that the determination target message has been delayed in transmission due to the arbitration process, and thus the monitoring device 5 permits transmission of the determination target message. To do.
  • the monitoring device 5 does not permit transmission of the determination target message because it is considered that the message is not a thing. Thereby, even in a communication system in which a delay occurs in message transmission due to arbitration processing, the monitoring device 5 can determine whether message transmission is possible.
  • the monitoring device 5 determines whether or not there is a message non-transmission period exceeding a predetermined length between the scheduled transmission time tn of the determination target message and the completion of transmission of this message. When there is a message non-transmission period, it is considered that the delay of the determination target message is not caused by a valid arbitration process, and therefore the monitoring device 5 does not permit transmission of the determination target message.
  • a predetermined procedure is performed between the monitoring device 5 and the ECU 3 in order to determine the reference time point t0.
  • the monitoring device 5 transmits a hash value calculation request to the ECU 3.
  • the monitoring device 5 gives the ECU 3 a random seed and region designation information necessary for hash value calculation.
  • the ECU 3 that has received the hash value calculation request from the monitoring device 5 determines the hash value using a predetermined hash function based on the random seed and area designation information included in the hash value calculation request and the data stored in the ROM 32. Perform the calculation.
  • the ECU 3 transmits a hash value confirmation response including the calculated hash value to the monitoring device 5.
  • the monitoring device 5 that has received the hash value confirmation response from the ECU 3 determines whether or not the hash value included in the hash value confirmation response is correct.
  • the monitoring device 5 determines the reference time t0 based on the time when reception of the hash value confirmation response is completed. For example, the monitoring device 5 sets the reception completion time such as the hash value confirmation as the reference time t0.
  • the reference time point t0 is not limited to this.
  • the transmission start time point of the hash value confirmation response may be set as the reference time point t0. It is good also as time t0.
  • the ECU 3 determines the reference time t0 based on the transmission completion time of the hash confirmation response including the correct hash value, and performs message transmission in the cycle T based on the determined time. Since the reference time point t0 can be determined based on highly reliable information transmission / reception based on the hash value, the monitoring device 5 can perform highly reliable unauthorized message detection processing.
  • the monitoring device 5 determines that transmission of an unauthorized message is not permitted, the monitoring device 5 performs processing for causing the ECU 3 that receives this message to discard the message. For example, the monitoring device 5 can cause the ECU 3 to discard this message by transmitting an error frame to the CAN bus during the EOF output period of an illegal message. As a result, it is possible to prevent the ECU 3 from receiving an unauthorized message and performing processing corresponding to this message in the ECU 3.
  • the processing unit 51 (so-called CPU or the like) of the monitoring device 5 performs a reference time determination process, a permission period determination process, a transmission permission determination process, an unauthorized message discard process, and the like.
  • the present invention is not limited to this, and the CAN communication unit 53 (a so-called CAN controller or the like) may perform these processes.
  • the reference point determination process such as the hash value calculation process of the ECU 3 may be performed not by the processing unit 31 but by the CAN communication unit 34.
  • the reference time t0 is determined by exchanging information using the hash value between the monitoring device 5 and the ECU 3, the determination of the reference time t0 may be performed by a method that does not use the hash value. For example, information encrypted using a public key or a secret key may be transmitted / received between the monitoring device 5 and the ECU 3, and the reference time t0 may be determined based on the transmission / reception result.
  • the monitoring device 5 and the ECU 3 perform highly reliable communication, and the reference time t0 may be determined based on the communication result.
  • the monitoring device 5 is configured to store the copy data 52a obtained by copying the storage contents of the ROM 32 of the ECU 3 in the storage unit 52
  • the present invention is not limited to this.
  • the copy data 52a may be stored in another server device or the like, and the monitoring device 5 may acquire the copy data 52a from the server device as necessary.
  • the server device may be provided with a hash value calculation function. It is good also as a structure which acquires a required hash value from a server apparatus.
  • the communication system mounted on the vehicle 1 has been described as an example.
  • the communication system is not limited to the one mounted on the vehicle 1, and is mounted on a moving body such as an airplane or a ship. For example, it may be installed in a factory, office, school or the like instead of a mobile object.
  • the monitoring device 5 in the above-described embodiment determines whether the message non-transmission period does not exist between the scheduled transmission time and the message transmission or when the message non-transmission period exists but is shorter than the predetermined length.
  • the transmission permission / rejection determination unit 63 determines that the message is a legitimate message and permits transmission.
  • the monitoring device 5 according to the modification has a configuration in which the determination condition of the transmission permission / inhibition determination unit 63 is added to the configuration of the monitoring device 5 described above.
  • the transmission permission / inhibition determination unit 63 of the monitoring device 5 according to the modification determines that two or more target messages have arrived within the transmission permission period, the subsequent message transmission is not permitted for all of the plurality of messages. .
  • the monitoring device 5 according to the modified example can prohibit transmission of a message that may be illegal.
  • the monitoring device 5 may be configured to count the number of times two or more target messages have arrived within the transmission permission period, for example, and prohibit message transmission when the number exceeds a predetermined number. .

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Small-Scale Networks (AREA)

Abstract

 共通の通信線に対して不正な装置がメッセージ送信を行った場合に、このようなメッセージ送信を検出することができる通信制御装置及び通信システムを提供する。 監視装置は、ECUによる周期的なメッセージ送信の基準時点t0を決定し、基準時点t0に対してメッセージの送信周期Tの整数倍の期間を加えた複数の送信予定時点t1,t2…を決定し、各送信予定時点に対してこの時点を含む所定期間をメッセージ送信の許可期間と決定する。監視装置は、CANバス上に検出されたメッセージが許可期間内に送信されたものであるか否かを判定する。監視装置は、不正なメッセージに対して送信を許可しないと判定した場合、このメッセージを受信するECUに対してメッセージを破棄させるための処理を行う。

Description

通信制御装置及び通信システム
 本発明は、例えばCAN(Controller Area Network)などのように、複数の通信装置がメッセージの送受信を行う通信システム、及び、このシステムに対する不正なメッセージの侵入を検出する通信制御装置に関する。
 従来、車両に搭載された複数のECU(Electronic Control Unit)間の通信には、CANの通信プロトコルが広く採用されている。CANの通信プロトコルを採用した通信システムは、複数のECUが共通のCANバスに接続された構成となり、送信側のECUがCANバスへ出力した信号を受信側のECUが取得することによってメッセージの送受信が行われる。このような通信システムにおいて、共通の通信線上への不正なメッセージ侵入を検出又は防止するための技術が研究されている。
 特許文献1においては、外部データの入力規制を行う車両ネットワークの通信管理装置が提案されている。この通信管理装置は、CANバス上のデータの監視及び外部から入力されるデータの監視を行い、CANバスの使用率が負荷基準値を超えているとき、及び、外部データの転送に伴いCANバスの使用率が負荷基準値を超えることが予測されるときに、外部データの送信規制を実行する。
特開2013-38711号公報
 車載の通信システムにおいて、例えばCANバスに悪意のある装置が接続される可能性がある。このような装置は、例えばCANバスに対して不正なメッセージ送信を行うことによって、CANバスに接続された正規のECUなどを誤動作させる虞がある。特許文献1に記載の通信管理装置は、CANバスの使用率が負荷基準値を超えているか否かを判定する構成であるため、悪意のある装置によるメッセージ送信量が少ない場合には送信規制を行うことができないという問題がある。
 本発明は、斯かる事情に鑑みてなされたものであって、その目的とするところは、共通の通信線に対して不正な装置がメッセージ送信を行った場合に、このようなメッセージ送信を検出することができる通信制御装置及び通信システムを提供することにある。
 本発明に係る通信制御装置は、周期的にメッセージ送信を行うメッセージ送信部を有する通信装置による通信を制御する通信制御装置であって、前記メッセージ送信部によるメッセージ送信に係る基準時点を決定する基準時点決定部と、該基準時点決定部が決定した基準時点に前記メッセージ送信部によるメッセージ送信周期の整数倍の期間を加えた送信予定時点に対し、該送信予定時点を含む所定期間をメッセージ送信の許可期間とする許可期間決定部と、前記通信装置が送信したメッセージを検出するメッセージ検出部と、該メッセージ検出部が検出したメッセージが、前記許可期間決定部が決定した許可期間内に送信されたものであるか否かに応じて、前記メッセージの送信可否を判定する送信可否判定部とを備えることを特徴とする。
 また本発明に係る通信制御装置は、制御対象の通信装置が複数存在する場合に、前記基準時点決定部及び前記許可期間決定部は、複数の通信装置それぞれについて前記基準時点及び前記許可期間を決定するようにしてあることを特徴とする。
 また本発明に係る通信制御装置は、前記通信装置が送信する前記メッセージには、該メッセージの優先度を示す情報を含み、前記許可期間決定部は、メッセージの優先度毎に前記許可期間を決定するようにしてあることを特徴とする。
 また本発明に係る通信制御装置は、複数の前記通信装置のメッセージ送信が衝突した場合に、メッセージに対して定められた優先度に応じて送信順序を調停する調停手段を備え、前記送信可否判定部は、判定対象のメッセージに関する前記送信予定時点から前記判定対象のメッセージの送信が完了するまでの間に送信を完了した他のメッセージの優先度を調べ、前記判定対象のメッセージより優先度が低い他のメッセージが存在する場合に、前記判定対象のメッセージの送信を許可しないと判定するようにしてあることを特徴とする。
 また本発明に係る通信制御装置は、前記送信可否判定部は、判定対象のメッセージに関する前記送信予定時点から前記判定対象のメッセージの送信が完了するまでの間に、所定長を超えるメッセージ無送信期間が存在する場合に、前記判定対象のメッセージの送信を許可しないと判定するようにしてあることを特徴とする。
 また本発明に係る通信制御装置は、前記通信装置に対してハッシュ値の算出要求を与えるハッシュ値要求部と、前記算出要求に対する応答として前記通信装置が送信するハッシュ値を受信するハッシュ値受信部と、該ハッシュ値受信部が受信したハッシュ値の正誤を判定するハッシュ値判定部とを備え、前記基準時点決定部は、前記通信装置から正しいハッシュ値の受信を完了した時点に基づいて、前記基準時点を決定するようにしてあることを特徴とする。
 また本発明に係る通信制御装置は、前記送信可否判定部が送信を許可しないと判定したメッセージを、該メッセージを受信する前記通信装置に破棄させる処理を行う破棄処理部を備えることを特徴とする。
 また本発明に係る通信システムは、互いにメッセージの送受信を行う複数の通信装置及び該通信装置による通信を制御する通信制御装置を備える通信システムであって、前記通信装置は、周期的にメッセージ送信を行うメッセージ送信部を有し、前記通信制御装置は、前記メッセージ送信部によるメッセージ送信に係る基準時点を決定する基準時点決定部と、該基準時点決定部が決定した基準時点に前記メッセージ送信部によるメッセージ送信周期の整数倍の期間を加えた送信予定時点に対し、該送信予定時点を含む所定期間をメッセージ送信の許可期間とする許可期間決定部と、前記通信装置が送信したメッセージを検出するメッセージ検出部と、該メッセージ検出部が検出したメッセージが、前記許可期間決定部が決定した許可期間内に送信されたものであるか否かに応じて、前記メッセージの送信可否を判定する送信可否判定部とを有することを特徴とする。
 また、本発明に係る通信システムは、前記基準時点決定部及び前記許可期間決定部が、前記複数の通信装置それぞれについて前記基準時点及び前記許可期間を決定するようにしてあることを特徴とする。
 また、本発明に係る通信システムは、前記通信装置が送信する前記メッセージには、該メッセージの優先度を示す情報を含み、前記許可期間決定部は、メッセージの優先度毎に前記許可期間を決定するようにしてあることを特徴とする。
 また、本発明に係る通信システムは、複数の前記通信装置のメッセージ送信が衝突した場合に、メッセージに対して定められた優先度に応じて送信順序を調停する調停手段を備え、前記送信可否判定部は、判定対象のメッセージに関する前記送信予定時点から前記判定対象のメッセージの送信が完了するまでの間に送信を完了した他のメッセージの優先度を調べ、前記判定対象のメッセージより優先度が低い他のメッセージが存在する場合に、前記判定対象のメッセージの送信を許可しないと判定するようにしてあることを特徴とする。
 また、本発明に係る通信システムは、前記送信可否判定部が、判定対象のメッセージに関する前記送信予定時点から前記判定対象のメッセージの送信が完了するまでの間に、所定長を超えるメッセージ無送信期間が存在する場合に、前記判定対象のメッセージの送信を許可しないと判定するようにしてあることを特徴とする。
 また、本発明に係る通信システムは、前記通信制御装置が、前記通信装置に対してハッシュ値の算出要求を与えるハッシュ値要求部と、前記算出要求に対する応答として前記通信装置が送信するハッシュ値を受信するハッシュ値受信部と、該ハッシュ値受信部が受信したハッシュ値の正誤を判定するハッシュ値判定部とを有し、前記通信装置は、前記通信制御装置からの算出要求に応じてハッシュ値を算出するハッシュ値算出部と、該ハッシュ値算出部が算出したハッシュ値を前記通信制御装置へ送信するハッシュ値送信部とを有し、前記基準時点決定部は、前記通信装置から正しいハッシュ値の受信を完了した時点に基づいて、前記基準時点を決定するようにしてあることを特徴とする。
 また、本発明に係る通信システムは、前記メッセージ送信部が、前記ハッシュ値送信部が正しいハッシュ値の送信を完了した時点に基づく基準時点を決定し、決定した時点を基準として周期的にメッセージ送信を行うようにしてあることを特徴とする。
 また、本発明に係る通信システムは、前記通信制御装置が、前記送信可否判定部が送信を許可しないと判定したメッセージを、該メッセージを受信する前記通信装置に破棄させる処理を行う破棄処理部を有することを特徴とする。
 本発明においては、共通の通信線に複数の通信装置が接続され、各通信装置が周期的にメッセージ送信を行う構成の通信システムに対して、不正なメッセージ送信を検出する通信制御装置を設ける。通信制御装置は、通信装置による周期的なメッセージ送信の基準時点(t0)を決定し、基準時点(t0)に対してメッセージの送信周期(T)の整数(n=1,2,3,…)倍の期間を加えた複数の時点(t1=t0+T,t2=t0+2T,t3=t0+3T,…,tn=t0+nT)を送信予定時点と決定し、各送信予定時点(t1,t2,t3,…,tn)に対してこの時点を含む所定期間(t1-A~t1+B,t2-A~t2+B,t3-A~t3+B,…,tn-A~tn+B)をメッセージ送信の許可期間と決定する。
 また通信制御装置は、共通の通信線を監視することによって、通信装置が送信したメッセージを検出する。通信制御装置は、検出されたメッセージが上記の許可期間内に送信されたものであるか否かを判定することにより、このメッセージが不正なものであるか否かを判定することができ、このメッセージの送信を許可するか否かを判定することができる。
 上記のように本発明の通信制御装置は、最初の段階で決定した基準時点に基づいて、以降のメッセージ送信の許可期間を決定する構成、即ち絶対的な基準で許可期間を決定する構成である。これに対して例えばメッセージ受信毎に、このメッセージの受信時点に周期Tを加えた時点を含む所定期間を許可期間とする構成、即ち相対的な基準で許可期間を決定する構成を採用することが考えられる。しかし、CANの通信プロトコルではメッセージ送信の衝突が発生した場合には調停処理が行われ、優先度の低いメッセージの送信に遅延が発生する。相対的な決定を行う構成では、メッセージ送信に遅延が発生した場合に、判定のための許可期間が変動するため、許可期間をある程度広く設定する必要があり、許可期間を狭めることが容易でない。許可期間が広いほど不正なメッセージを正当であると誤判定する可能性が高まる。また相対的な決定を行う構成では、不正なメッセージの受信を基準として次のメッセージの許可期間が決定される虞がある。このような事態が発生した場合、不正なメッセージが連続的に正当なメッセージであると誤判定される可能性がある。本発明の通信制御装置は、絶対的な基準で許可期間を決定することによって、これらの問題が発生することを回避することが可能である。
 また本発明においては、通信システムに含まれる各通信装置について、通信制御装置は基準時点をそれぞれ個別に決定する。また通信制御装置は、決定したそれぞれの基準時点に対して許可期間を通信装置毎に決定する。なお各通信装置のメッセージ送信周期はそれぞれ異なっていてよい。これにより、通信システムにメッセージの送信周期及び送信タイミング等が異なる通信装置が含まれる場合であっても、通信制御装置が通信装置毎にメッセージ送信の可否を判定することができる。
 また本発明においては、送信周期が異なる複数種別のメッセージを通信装置が送信可能とし、通信制御装置はメッセージ種別毎に許可期間を決定する。なお通信制御装置は、基準時点についてもメッセージの種別毎に決定してもよい。これにより送信周期が異なるメッセージを1つの通信装置が送信する場合であっても、通信制御装置は、メッセージの種別毎に送信の可否を判定することができる。
 また本発明においては、共通の通信線に対して複数の通信装置が接続される構成であるため、複数の通信装置が同時的にメッセージ送信を行った場合に、通信線上で複数のメッセージが衝突する可能性がある。このような場合には通信装置間で調停処理を行い、メッセージの優先度に応じた順序で送信がなされる。即ち、衝突した複数のメッセージについて、まず優先度が高いメッセージの送信が行われた後、優先度が低いメッセージの送信が行われる。
 このような調停処理が行われる通信システムでは、通信装置が周期的に送信しようとしたメッセージが他のメッセージと衝突して遅延する可能性がある。そこで通信制御装置は、判定対象のメッセージについて送信予定時点からこのメッセージの送信完了までの間に、他のメッセージが送信されたか否かを調べる。他のメッセージが送信されていた場合、通信制御装置は、判定対象のメッセージの優先度と他のメッセージの優先度とを比較する。
 他のメッセージの優先度が判定対象のメッセージの優先度より高い場合、判定対象のメッセージは正当な調停処理によって送信に遅延が発生したと考えられるため、通信制御装置は、判定対象のメッセージの送信を許可する。これに対して、他のメッセージの優先度が判定対象のメッセージの優先度より低い場合、判定対象のメッセージの遅れは正当な調停処理によるものではないと考えられるため、通信制御装置は、判定対象のメッセージの送信を許可しない。これにより、調停処理によってメッセージ送信に遅延が発生する通信システムであっても、通信制御装置は、メッセージ送信の可否を判定することができる。
 また本発明においては、判定対象のメッセージの送信予定時点からこのメッセージの送信が完了するまでの間に、所定長を超えるメッセージ無送信期間が存在するか否かを通信制御装置が判定する。メッセージ無送信期間が存在する場合、判定対象のメッセージの遅延は正当な調停処理によって発生したものではないと考えられるため、通信制御装置は、判定対象のメッセージの送信を許可しない。
 また本発明においては、基準時点を決定するために、通信制御装置と通信装置との間で所定の手続を行う。通信制御装置は、通信装置に対してハッシュ値の算出要求を送信する。このときに通信制御装置は、ハッシュ値算出に必要な情報を算出要求と共に通信装置へ与えてもよい。通信制御装置から算出要求を受信した通信装置は、例えば自身のメモリに記憶された情報などに基づいて所定のハッシュ関数を用いたハッシュ値の算出を行い、算出したハッシュ値を通信制御装置へ送信する。通信装置からハッシュ値を受信した通信制御装置は、このハッシュ値が正しいものであるか否かを判定する。受信したハッシュ値が正しいものである場合、通信制御装置は、このハッシュ値の受信を完了した時点に基づいて基準時点を決定する。なお通信装置は、正しいハッシュ値の受信完了時点を基準時点としてもよく、受信完了時点に所定の時間を増減した時点を基準時点としてもよい。
 同様に通信装置は、正しいハッシュ値の送信を完了した時点に基づいて基準時点を決定し、決定した時点を基準として周期的なメッセージ送信を行う。
 ハッシュ値に基づく信頼性の高い通信結果に基づいて基準時点を決定することができるため、通信制御装置は、信頼性の高い不正メッセージ検出を行うことができる。
 また本発明においては、通信制御装置が不正なメッセージであるとして送信を許可しないと判定したメッセージについて、このメッセージを受信する通信装置に対してメッセージを破棄させる処理を通信制御装置が行う。これにより不正なメッセージを通信装置が受信し、このメッセージに応じた処理が通信装置にて行われることを防止できる。
 本発明による場合は、通信制御装置が基準時点に対してメッセージ送信期間の整数倍の期間を加えた時点を含む許可期間を決定し、通信装置が送信したメッセージが許可期間内であるか否かを判定する構成とすることにより、不正な装置が共通の通信線に対して送信したメッセージを精度よく検出することができる。
本実施の形態に係る通信システムの構成を示す模式図である。 ECUの構成を示すブロック図である。 監視装置の構成を示すブロック図である。 監視装置の記憶部に記憶される複写データの構成を説明する模式図である。 監視装置の記憶部に記憶される周期情報の構成を説明する模式図である。 監視装置による不正メッセージ検出処理を説明するための模式図である。 送信可否判定部によるアービトレーション処理に関する条件判定を説明するための模式図である。 送信可否判定部によるアービトレーション処理に関する条件判定を説明するための模式図である。 送信可否判定部によるアービトレーション処理に関する条件判定を説明するための模式図である。 送信可否判定部によるメッセージ無送信期間に関する条件判定を説明するための模式図である。 監視装置が行うメッセージ送信の可否判定処理の手順を示すフローチャートである。 監視装置が行うメッセージ送信の可否判定処理の手順を示すフローチャートである。 ECU及び監視装置の間で行われる基準時点決定処理を説明するための模式図である。 監視装置による複数のECUとの基準時点決定処理を説明するための模式図である。 監視装置による基準時点決定処理の手順を示すフローチャートである。 監視装置からのハッシュ値算出要求に応じてECUが行う処理の手順を示すフローチャートである。 監視装置からのハッシュ値確認要求に応じてECUが行う処理の手順を示すフローチャートである。
<システム構成>
 図1は、本実施の形態に係る通信システムの構成を示す模式図である。本実施の形態に係る通信システムは、車両1に搭載された複数のECU3と、1つの監視装置5とを備えて構成されている。ECU3及び監視装置5は、車両1に敷設された共通の通信線を介して接続され、相互にメッセージを送受信することができる。本実施の形態においては、この通信線をCANバスとし、ECU3及び監視装置5は、CANプロトコルに従った通信を行う。ECU3は、例えば車両1のエンジンの制御を行うエンジンECU、車体の電装品の制御を行うボディECU、ABS(Antilock Brake System)に関する制御を行うABS-ECU、又は、車両1のエアバッグの制御を行うエアバッグECU等のように、種々の電子制御装置であってよい。監視装置5は、車内ネットワークに対する不正なメッセージ送信を監視する装置である。監視装置5は、監視専用の装置として設けられてもよく、例えばゲートウェイなどの装置に監視の機能を付加した構成であってもよく、また例えばいずれか1つのECU3に監視の機能を付加した構成であってもよい。
 図2は、ECU3の構成を示すブロック図である。なお図2においては、車両1に設けられた複数のECU3について、通信及び不正検知等に関するブロックを抜き出して図示してある。これらのブロックは各ECU3に共通である。本実施の形態に係るECU3は、処理部31、ROM(Read Only Memory)32、RAM(Random Access Memory)33及びCAN通信部34等を備えて構成されている。処理部31は、CPU(Central Processing Unit)又はMPU(Micro-Processing Unit)等の演算処理装置を用いて構成されている。処理部31は、ROM32に記憶されたプログラム32aを読み出して実行することにより、車両1に係る種々の情報処理又は制御処理等を行う。
 ROM32は、フラッシュメモリ又はEEPROM(Electrically Erasable Programmable ROM)等の不揮発性のメモリ素子を用いて構成されている。ROM32は、処理部31が実行するプログラム32aと、これにより行われる処理に必要な種々のデータ32bとが記憶されている。なおROM32に記憶されるプログラム32a及びデータ32bは、ECU3毎に異なる。RAM33は、SRAM(Static Random Access Memory)又はDRAM(Dynamic Random Access Memory)等のデータ書き換え可能なメモリ素子を用いて構成されている。RAM33は、処理部31の処理により生成された種々のデータを記憶する。
 CAN通信部34は、CANの通信プロトコルに従って、CANバスを介した他のECU3又は監視装置5との通信を行う。CAN通信部34は、処理部31から与えられた送信用の情報を、CANの通信プロトコルに従った信号に変換し、変換した信号をCANバスへ出力することで他のECU3又は監視装置5への情報送信を行う。CAN通信部34は、CANバスの電位をサンプリングすることによって、他のECU3又は監視装置5が出力した信号を取得し、この信号をCANの通信プロトコルに従って2値の情報に変換することで情報の受信を行い、受信した情報を処理部31へ与える。
 またCAN通信部34は、自らのメッセージ送信と、他のECU3又は監視装置5によるメッセージ送信とに衝突が発生した場合に、いずれのメッセージを先に送信するかを調停する処理、いわゆるアービトレーション処理を行う。各ECU3が送信するメッセージには、メッセージの種別に応じて予めIDが定められている。このIDは、数値として扱われる情報であり、その値が小さいほどメッセージ送信の優先度が高い。このため通信システムにおいては、CANバス上で複数のメッセージ送信が衝突した場合、最も優先度が高いメッセージ送信が行われ、このメッセージの送信完了後に他のメッセージの送信が行われる。なおCAN通信部34が行うアービトレーション処理は、既存の技術であるため、詳細な処理手順の説明は省略する。
 本実施の形態においてECU3の処理部31には、プログラム32aの実行により、メッセージ処理部41及びハッシュ値算出部42等がソフトウェア的な機能ブロックとして実現される。なおメッセージ処理部41及びハッシュ値算出部42等は、その一部又は全部がハードウェアによる機能ブロックとして実現されてもよい。メッセージ処理部41は、センサなどが検知した情報又は制御対象の機器からのフィードバック情報等の情報を取得し、取得した情報を含むCANプロトコルのメッセージを作成し、作成したメッセージをCANバスに対して送信する処理を周期的に行う。なおメッセージの送信周期は、メッセージの種別(即ちID)毎に定められており、メッセージ処理部41は、メッセージの種別毎に異なる周期で送信を行うことができる。
 ハッシュ値算出部42は、監視装置5からの算出要求に応じて、ハッシュ値を算出する処理を行う。ハッシュ値算出部42は、ROM32に記憶されているデータ(プログラム32a及びデータ32bの両方を含んでよい)の一部又は全部と、監視装置5からの算出要求に付されたランダムシードとに基づいて、予め定められたハッシュ関数を用いることによりハッシュ値を算出する。ハッシュ値算出部42によりハッシュ値算出の詳細手順は後述する。ハッシュ値算出部42は、算出したハッシュ値を、算出要求に対する応答として、監視装置5へ送信する。
 図3は、監視装置5の構成を示すブロック図である。監視装置5は、処理部51、記憶部52及びCAN通信部53等を備えて構成されている。処理部51は、CPU又はMPU等の演算処理装置を用いて構成され、記憶部52に記憶されたプログラムを読み出して実行することにより、車両1のECU3の挙動及び通信等を監視する処理を行う。記憶部52は、フラッシュメモリ又はEEPROM等のデータ書き換え可能な不揮発性のメモリ素子を用いて構成されている。本実施の形態において記憶部52は、車両1に搭載されたECU3のROM32の記憶内容を複写した複写データ52aと、各ECU3が送信するメッセージの送信周期に関する周期情報52bとを記憶している。
 CAN通信部53は、CANの通信プロトコルに従って、CANバスを介したECU3との通信を行う。CAN通信部53は、処理部51から与えられた送信用の情報を、CANの通信プロトコルに従った信号に変換し、変換した信号をCANバスへ出力することでECU3への情報送信を行う。CAN通信部53は、CANバスの電位をサンプリングすることによって、ECU3が出力した信号を取得し、この信号をCANの通信プロトコルに従って2値の情報に変換することで情報の受信を行い、受信した情報を処理部51へ与える。
 本実施の形態において監視装置5の処理部51には、基準時点決定部61、許可期間決定部62、送信可否判定部63及び破棄処理部64等が設けられている。基準時点決定部61~破棄処理部64は、ハードウェアの機能ブロックとして構成されるものであってもよく、ソフトウェアの機能ブロックとして構成されるものであってもよい。基準時点決定部61及び許可期間決定部62は、監視装置5が不正なメッセージ送信を検出するための条件などを決定する処理を行う。送信可否判定部63は、基準時点決定部61及び許可期間決定部62が決定した条件に基づいて、CANバス上に出力されたメッセージの送信可否を判定する処理を行う。破棄処理部64は、送信可否判定部63により送信を許可されなかったメッセージについて、このメッセージがECU3にて受信されることを阻止すべく、ECU3にメッセージを破棄させるための処理を行う。
 図4は、監視装置5の記憶部52に記憶される複写データ52aの構成を説明する模式図である。監視装置5は、車両1に搭載された監視対象の全てのECU3について、ROM32の記憶内容と同じものを複写データ52aとして記憶している。複写データ52aは、各ECU3に対して一意に付された識別情報(図4においてECUa、ECUb…)と、各ECU3のROM32の記憶内容とが対応付けて記憶されている。
 図5は、監視装置5の記憶部52に記憶される周期情報52bの構成を説明する模式図である。監視装置5は、車両1内のネットワーク上で送受信されるメッセージに付される識別情報(CAN-ID)と、このCAN-IDを有するメッセージが送信される周期とを対応付けて周期情報52bとして記憶している。図示の例では、CAN-IDが1のメッセージは送信周期が10msであり、CAN-IDが2のメッセージは送信周期が50msであり、CAN-IDが3のメッセージは送信周期が32msであることが周期情報52bに記憶されている。なお、これらの数値は一例である。
<不正メッセージ検出処理>
 本実施の形態に係る通信システムでは、複数のECU3がメッセージの送受信を行うCANバス上に不正なメッセージが送信されたことを検出する処理を監視装置5が行う。例えばCANバスに対して不正な通信装置が不正に接続され、この通信装置が不正なメッセージをCANバス上に送信することが考えられる。また例えば、車両1に搭載されたいずれかのECU3に不正な改造又は改変等がなされ、このECU3が不正なメッセージを送信することが考えられる。これらは不正なメッセージの一例であり、監視装置5が検出する不正なメッセージはこれら以外の要因によるものであってよい。
 不正な通信装置は、CANプロトコルに従い、特定のCAN-IDを付した不正メッセージを送信することができる。このような不正メッセージに付されるCAN-IDは、車両1の通信システムにおいて利用される正当なものが用いられるが、不正メッセージに含まれる他のデータは不正なデータとなる。CAN-IDに基づいてECU3が不正メッセージを受信した場合、ECU3は不正なデータに基づく処理を行うこととなる。本実施の形態に係る通信システムでは、正規のCAN-IDが付された不正メッセージ、いわゆるなりすましメッセージの検出を行うものである。
 本実施の形態に係る監視装置5は、周期的に送信されるべきメッセージについて、このメッセージが正しい周期で送信されているか否かを判断することにより、不正なメッセージの検出を行う。図6は、監視装置5による不正メッセージ検出処理を説明するための模式図である。監視装置5は、通信システム内で送受信されるメッセージに付されるCAN-ID毎に、このCAN-IDを有するメッセージの送信を許可する許可期間を決定する。図6には、ある1つのCAN-IDが付されるメッセージについて、監視装置5が決定した許可期間などを図示してある。なお本実施の形態においては、1つのCAN-IDを複数のECU3が利用する、即ち同一のCAN-IDが付されたメッセージを複数のECU3が送信することはないものとしている。
 本例において、監視装置5が監視対象とするメッセージの送信周期はTである。監視装置5の基準時点決定部61は、このメッセージを送信するECU3との間で所定の手続を行うことによって、メッセージ送信の基準時点t0を決定する(なお基準時点の決定処理の詳細は後述する)。監視装置5の許可期間決定部62は、記憶部52に記憶した周期情報52bを参照することによって、監視対象のメッセージの送信周期Tを取得する。許可期間決定部62は、基準時点t0に対して送信周期Tを加えた時点t1をメッセージの送信予定時点t1とする。同様に、許可期間決定部62は、基準時点t0に対して送信周期Tの2倍を加えた時点t2を送信予定時点t2とし、基準時点t0に対して送信周期Tの3倍を加えた時点t3を送信予定時点t3とし、…、基準時点t0に対して送信周期Tのn倍を加えた時点tnを送信予定時点tnとすることができる(n=1,2,3…)。
 監視装置5の許可期間決定部62は、送信予定時点t1に対して所定の期間A及び期間Bの猶予を設けた期間を許可期間と決定する。許可期間決定部62は、t1-A≦t≦t1+Bの期間を許可期間と決定する。送信予定時点t2、t3…についても同様である。即ち許可期間決定部62は、t0+nT-A≦t≦t0+nT+B(n=1,2,3…)を許可期間と決定する。
 なお許可期間を決定するための期間A及び期間Bは、例えば通信システムのシミュレーション又は実機での測定結果等に基づいて、予め決定される。期間A及び期間Bは、全てのメッセージについて同じ値を用いてもよく、例えばCAN-ID毎に異なる値を用いてもよい。CAN-ID毎に異なる値を用いる場合、周期情報52bにCAN-IDと対応付けて期間A及び期間Bを記憶しておくことができる。期間Aは、監視装置5とこのメッセージを送信するECU3とのクロック誤差などに基づいて決定することができる。期間Bは、このメッセージがアービトレーション処理によって遅延する時間を考慮して決定される。
 監視装置5のCAN通信部53は、CANバスに対するメッセージの送信を監視しており、メッセージ送信を検出した場合に処理部51へ通知する。処理部51の送信可否判定部63は、CAN通信部53からの通知に基づいて、送信されたメッセージのCAN-ID、及び、メッセージ送信の開始時点又は終了時点に関する情報を取得する。また送信可否判定部63は、取得したCAN-IDに対して許可期間決定部62が決定した許可期間を取得する。送信可否判定部63は、送信が検出されたメッセージが、許可期間内に送信されたものであるか否かを判定する。
 なおメッセージが許可期間内に送信されたか否かを判断する条件には、メッセージの送信が許可期間内に開始されることを条件とするか、又は、メッセージの送信が許可期間内に完了したことを条件とするかの2通りが考えられる。いずれの条件を採用しても可能であり、いずれの条件を採用するかに応じて期間Bの値を適宜に設定すればよい。なお本実施の形態においては、許可期間内にメッセージ送信が完了することを条件として、送信可否判定部63はメッセージが許可期間内に送信されたか否かを判定するものとする。
 送信可否判定部63は、メッセージが許可期間内に送信されたものではない場合、このメッセージが不正メッセージであると判断し、このメッセージの送信を許可しないと判定する。メッセージ送信を許可しないと送信可否判定部63が判定した場合、監視装置5の破棄処理部64は、CANバスに接続されたECU3に対して、このメッセージを破棄させる処理を行う。なお、メッセージ破棄処理の詳細は後述する。
 送信可否判定部63は、メッセージが許可期間内に送信されたものである場合、更に別の条件判定を行う。送信可否判定部63は、アービトレーション処理に関する条件判定と、メッセージ無送信期間に関する条件判定とを行う。
 図7乃至図9は、送信可否判定部63によるアービトレーション処理に関する条件判定を説明するための模式図である。上述のようにCANの通信システムにおいては、複数のメッセージ送信が衝突した場合にアービトレーション処理が行われ、優先度の低いメッセージの送信に遅延が発生する可能性がある。図7では、判定対象のメッセージのCAN-IDが7であり、このメッセージより優先度の高い3つのメッセージ(CAN-IDがそれぞれ3,5,2のメッセージ)がアービトレーション処理によって先に送信された状態を図示してある。
 送信可否判定部63は、判定対象のメッセージの許可期間において、判定対象のメッセージの送信以前に、他のメッセージ送信が行われているか否かを判定する。他のメッセージ送信が行われている場合、送信可否判定部63は、送信された一又は複数の他のメッセージのCAN-IDを調べ、判定対象のメッセージのCAN-IDと比較する。CANプロトコルにおいてメッセージに付されるCAN-IDは優先度を示しており、その数値が小さいほど優先度が高い。送信可否判定部63は、以前に送信された他のメッセージの全てについて、以下の条件1又は条件2のいずれかが成立する場合に限り、判定対象のメッセージを正規のものであると判断する。
 条件1:他のメッセージのCAN-IDが判定対象のメッセージのCAN-IDより小さい場合、即ち以前のメッセージが全て優先度の高いものである場合
 条件2:他のメッセージが判定対象のメッセージより低優先度であるが、判定対象メッセージの許可期間の開始以前に送信開始されて低優先度のメッセージが送信されていた場合
 条件1に関して、送信許可後に連続して送信されるメッセージのうち、以前に送信されたメッセージの少なくとも1つのCAN-IDが判定対象のメッセージのCAN-IDより大きい場合、即ち以前に優先度の低いメッセージが送信されている場合に、送信可否判定部63は、判定対象のメッセージを不正なメッセージであると判断する。図8では、判定対象のメッセージのCAN-IDが7であり、このメッセージの送信以前に、CAN-IDが3,5,9のメッセージが送信された状態を図示してある。CAN-IDが9のメッセージは、CAN-IDが7である判定対象のメッセージより優先度が低い。このため判定対象のメッセージは、アービトレーション処理によって図示のタイミングに遅延したのではなく、不正な通信装置によって図示のタイミングで送信された可能性がある。判定対象のメッセージが不正なメッセージであり送信を許可しないと送信可否判定部63が判定した場合、破棄処理部64によるメッセージ破棄処理が行われる。
 条件2は、条件1の例外を規定したものである。即ち条件1によれば、判定対象のメッセージ以前の他のメッセージは、判定対象のメッセージより優先度が高いものであることが必要である。しかし、メッセージの許可期間内に送信された一又は複数の他のメッセージのうち、最初に送信されたメッセージについては、許可期間の開始時点で既に送信されているメッセージである場合には、判定対象のメッセージより低優先度であってもよいとしたものが条件2である。図9では、図7に示したメッセージに加えて、許可期間の開始以前にCAN-IDが10のメッセージが送信された状態を図示してある。CAN-IDが10のメッセージは、CAN-IDが7である判定対象のメッセージより優先度が低い。しかしこの低優先度のメッセージは、判定対象のメッセージの許可期間の開始以前に送信開始されたメッセージであるため、送信可否判定部63は、判定対象のメッセージの送信を許可する。
 図10は、送信可否判定部63によるメッセージ無送信期間に関する条件判定を説明するための模式図である。送信可否判定部63は、判定対象のメッセージの許可期間において、送信予定時点t1から判定対象メッセージの送信までの間に、CANバス上にメッセージが送信されていないメッセージ無送信期間が存在するか否かを調べる。メッセージ無送信期間が存在する場合、送信可否判定部63は、このメッセージ無送信期間が所定長を超えるか否かを判定する。なお、メッセージ無送信期間が複数存在する場合、送信可否判定部63は、各メッセージ無送信期間と所定長との比較を個別に行う。
 所定長としては、例えばメッセージの3ビット~10ビット程度を送信するために必要な期間を設定することができる。これはCANプロトコルのメッセージ送信におけるIFS(Inter Frame Space)の3ビット、又は、IFSにEOF(End Of Frame)の7ビットを加えた10ビット等の期間に基づくものである。ただしこれらの数値は一例であって、所定長はこれら以外の期間であってよい。
 送信予定時点からメッセージ送信までの間に存在するメッセージ無送信期間が所定長を超える場合、判定対象のメッセージの遅れは正当な遅れではないと判断できる。よってこのような場合、送信可否判定部63は、判定対象のメッセージが不正なメッセージであり、送信を許可しないと判定する。判定対象のメッセージが不正なメッセージであり送信を許可しないと送信可否判定部63が判定した場合、破棄処理部64によるメッセージ破棄処理が行われる。
 また送信予定時点からメッセージ送信までの間にメッセージ無送信期間が存在しない場合、又は、メッセージ無送信期間が存在しても所定長より短い場合、送信可否判定部63は、判定対象のメッセージが正当なメッセージであると判定し、送信を許可する。
 このように送信可否判定部63は、許可期間内に判定対象のCAN-IDを有するメッセージの送信を検出した場合、このメッセージの送信に正当なアービトレーション処理による遅延以外の遅れが発生しているか否かを判定する。即ち送信可否判定部63は、許可期間内にて判定対象のメッセージより先に送信されたメッセージの優先度が高いこと(ただし許可期間以前に送信開始されたメッセージを除く)、及び、送信予定時点から判定対象のメッセージ送信までに所定長を超えるメッセージ無送信期間が存在しないことを、判定対象のメッセージの送信を許可する条件とする。送信可否判定部63は、両条件が満たされる場合に判定対象のメッセージ送信を許可し、少なくとも一方の条件が満たされない場合には判定対象のメッセージ送信を許可しない。
 なお監視装置5は、送信可否判定部63によるこれらの条件判定を行うために、CANバス上に送信されたメッセージの履歴を記憶部52に記憶している。記憶する履歴には、送信されたメッセージのCAN-ID、及び、送信開始時点又は送信終了時点に関する情報等が含まれる。また監視装置5によるメッセージ送信の監視は、CAN-ID毎に行われる。即ち監視装置5は、CAN-ID毎に許可期間を決定し、CAN-ID毎にメッセージ送信の可否を判定する。例えば図7においては、CAN-IDが7のメッセージを対象として監視装置5が判定を行う例を説明したが、このときに監視装置5はCAN-IDが3,5,2のメッセージについてもそれぞれ個別に送信可否の判定を行っている。
 図11及び図12は、監視装置5が行うメッセージ送信の可否判定処理の手順を示すフローチャートである。なお本フローチャートにて用いる変数nは、例えば監視装置5の処理部51が有するレジスタ又はメモリ等の記憶領域を利用して実現され得る。まず、監視装置5の処理部51は、基準時点決定部61にて基準時点t0を決定する処理を行う(ステップS1)。処理部51は、記憶部52に記憶された周期情報52bを読み出して(ステップS2)、判定対象のメッセージの送信周期Tを取得する。次いで処理部51は、変数nの値を1に初期化する(ステップS3)。処理部51の許可期間決定部62は、ステップS1にて決定した基準時点t0、ステップS2にて取得した周期T、予め定められた定数A及びB、並びに、変数nに基づいて、許可期間を決定する(ステップS4)。なお許可期間は、(t0+nT-A)から(t0+nT+B)までの期間と決定することができる。
 処理部51の送信可否判定部63は、ステップS4にて決定した許可期間が終了したか否かを判定する(ステップS5)。許可期間が終了していない場合(S5:NO)、送信可否判定部63は、CAN通信部53にてCANバス上でのメッセージ受信を検出したか否かを調べる(ステップS7)。メッセージ受信を検出していない場合(S7:NO)、送信可否判定部63は、ステップS5へ処理を戻す。メッセージ受信を検出した場合(S7:YES)、送信可否判定部63は、検出されたメッセージのCAN-IDを調べることにより、このメッセージが判定対象のメッセージであるか否かを判定する(ステップS8)。判定対象のメッセージでない場合(S8:NO)、送信可否判定部63は、このメッセージに関する情報(CAN-ID、送信開始時点及び終了時点等の情報)を履歴として記録し(ステップS9)、ステップS5へ処理を戻す。判定対象のメッセージである場合(S8:YES)、送信可否判定部63は、このメッセージが許可期間内に送信されたものであるか否かを判定する(ステップS10)。許可期間内に送信されたものでない場合(S10:NO)、処理部10は、破棄処理部64によるメッセージ破棄処理を行って(ステップS11)、ステップS5へ処理を戻す。
 判定対象のメッセージが許可期間内に送信されたものである場合(S10:YES)、送信可否判定部63は、送信予定時点tnに対するこのメッセージの遅延の有無を判定する(ステップS12)。遅延がない場合(S12:NO)、送信可否判定部63は、このメッセージが正当なものであるため送信を許可すると判定し、メッセージ破棄処理を行うことなくステップS5へ処理を戻す。送信予定時点tnに対するメッセージの遅延がある場合(S12:YES)、送信可否判定部63は、ステップS9にて記録していたメッセージ送信に関する履歴を取得する(ステップ13)。
 送信可否判定部63は、取得した履歴に基づいて、送信予定時点tnから判定対象のメッセージ送信までの間に、判定対象のメッセージより低優先度のメッセージの送信がなされたか否かを判定する(ステップS14)。低優先度のメッセージ送信がなされている場合(S14:YES)、送信可否判定部63は、この低優先度のメッセージが、判定対象のメッセージの許可期間以前に送信開始されたものであるか否かを更に判定する(ステップS15)。
 低優先度のメッセージの送信がなされていない場合(S14:NO)、又は、低優先度のメッセージが許可期間以前に送信開始されたものである場合(S15:YES)、送信可否判定部63は、送信予定時点tnから判定対象のメッセージ送信までの間に、所定長を超えるメッセージの無送信期間があるか否かを判定する(ステップS16)。メッセージ無送信期間がない場合(S16:NO)、送信可否判定部63は、このメッセージが正当なものであるため送信を許可すると判定し、メッセージ破棄処理を行うことなくステップS5へ処理を戻す。
 低優先度のメッセージが許可期間以前に送信開始されたものでない場合(S15:NO)、又は、所定長を超えるメッセージ無送信期間がある場合(S16:YES)、送信可否判定部63は、このメッセージが正当なものではないため送信を許可しないと判定し、破棄処理部64によるメッセージ破棄処理を行って(ステップS17)、ステップS5へ処理を戻す。
 ステップS5において許可期間が終了したと判定した場合(S5:YES)、処理部51は、変数nに1を加算し(ステップS6)、ステップS4へ処理を戻し、次の許可期間に関する監視を行う。
<メッセージ破棄処理>
 本実施の形態に係る通信システムでは、CANバス上に出力されたメッセージが正当なものではなく、送信を許可しないと判定した場合に、監視装置5は、CANバスに接続されたECU3にこのメッセージを破棄させるための処理を行う。本実施の形態に係る通信システムにて送受信されるメッセージは、CANプロトコルに従ったものであり、CANヘッダ、データフィールド、CRC(Cyclic Redundancy Check)フィールド、ACKフィールド及びEOF(End Of Frame)等を含んで構成されている。CANヘッダは、従来のCANプロトコルにおけるSOF(Start Of Frame)、アービトレーションフィールド及びコントロールフィールド等を含むものであり、アービトレーションフィールドに上述のCAN-IDが設定される。データフィールドは、例えばECU3に対する制御指示又はセンサ検知結果等のように、ECU3間で授受すべき情報の本体が格納される。CRCフィールド、ACKフィールド及びEOFは、従来のCANプロトコルにて用いられるものと同じであるため詳細な説明は省略する。CRCフィールドは、誤り検出を行うための情報を格納する。ACKフィールドは、このフレームを受信するECU3による受信応答のためのフィールドである。EOFは、フィールドの終了を示す特定のビット列である。
 監視装置5の破棄処理部64は、送信可否判定部63が送信を許可しないと判定したメッセージについて、このメッセージのEOFの出力期間中に、CANバスに対してエラーフレームを送信する。このエラーフレームにより、CANバスに接続された全てのECU3は、受信中の不正なメッセージを破棄することができる。
 この方法でメッセージの破棄を行うために、監視装置5の送信可否判定部63はメッセージのEOFがCANバスに出力される前に判定を終える必要がある。送信可否判定部63は、例えばCANバス上へのメッセージのCANヘッダ出力が終了した時点で上述の判定処理を開始し、EOFの出力前に判定を終える。なおCANプロトコルのメッセージは、そのメッセージ長が規定されているため、送信可否判定部63は、メッセージの送信終了前であっても送信終了時点を算出することが可能である。
 なお監視装置5は、送信可否判定部63が不正なメッセージであると判定したCAN-IDを記憶しておき、これ以後にCANバスに対して同じCAN-IDのメッセージが出力された場合には、送信可否判定部63による判定を行うことなく、破棄処理部64によってこのメッセージを破棄させる構成としてもよい。また監視装置5によるメッセージ破棄の処理は上述の方法によるものに限らず、その他の種々の方法で行ってよい。また監視装置5は、送信可否判定部63が不正なメッセージであると判定した場合に、ECU3に対する警告メッセージの送信、車両1のユーザに対する報知、外部のサーバ装置に対する情報送信、又は、通信システム若しくは該当する通信ネットワークのシャットダウン等の破棄以外の処理を行う構成としてもよい。
<基準時点決定処理>
 本実施の形態に係る通信システムでは、ECU3によるメッセージ送信及び監視装置5によるメッセージ送信の監視を開始する前に、基準時点t0を決定する処理を行う必要がある。図13は、ECU3及び監視装置5の間で行われる基準時点決定処理を説明するための模式図である。本実施の形態に係る通信システムの監視装置5は、電源投入などにより起動した後、処理部51の基準時点決定部61による基準時点決定処理を開始する。
 基準時点決定処理において監視装置5の基準時点決定部61は、まずハッシュ値算出に用いられる情報の生成を行う。本実施の形態において基準時点決定部61は、ランダムシード及び領域指定情報を生成する。基準時点決定部61は、所定のアルゴリズムにより乱数を発生させて得られた所定ビット長のデータをランダムシードとする。領域指定情報は、ハッシュ値算出の対象とするROM32の領域を指定する情報であり、例えば開始アドレス及び終了アドレス、又は、開始アドレス及びデータサイズ等の情報である。基準時点決定部61は、例えば乱数に基づいて開始アドレスを決定し、この開始アドレスに所定数を加算したものを終了アドレスとすることができる。
 監視装置5の基準時点決定部61は、生成したランダムシード及び領域指定情報を、ハッシュ値の算出要求と共に、ECU3へ送信する。また基準時点決定部61は、記憶部52の複写データ52aから処理対象のECU3の記憶内容を読み出し、読み出した記憶内容と、生成したランダムシード及び領域指定情報とを用いて、ハッシュ値を算出する。基準時点決定部61は、複写された記憶内容から領域指定情報にて指定された箇所を抽出し、抽出した記憶内容とランダムシードとを予め定められたハッシュ関数へ入力することにより、ハッシュ値を算出する。本実施の形態において基準時点決定部61は、SHA-1のハッシュ関数を用いて160ビットのハッシュ値を算出するものとする。
 監視装置5からのランダムシード及び領域指定情報を受信したECU3は、自らのROM32の記憶内容と、受信したランダムシード及び領域指定情報とを用いて、処理部31のハッシュ値算出部42にてハッシュ値を算出する。ハッシュ値算出部42は、ROM32から領域指定情報にて指定された箇所を抽出し、抽出した記憶内容とランダムシードとを予め定められたハッシュ関数へ入力することにより、ハッシュ値を算出する。なお、監視装置5が用いるハッシュ関数とECU3が用いるハッシュ関数とは同じものであり、監視装置5が複写データ52aに記憶している内容とECU3がROM32に記憶している内容とは同じであるため、監視装置5及びECU3は同じハッシュ値を算出するはずである。なお両ハッシュ値が異なる値となった場合、ECU3のROM32の記憶内容が改ざんされている可能性がある。
 ここで、監視装置5及びECU3によるハッシュ値算出の方法を簡単に説明する。監視装置5及びECU3は、例えばMD(Message Digest)4、MD5、SHA-1、SHA-256、SHA-384、SHA-512、EIPEMD-160又はSHA-3等の既存のハッシュ関数を利用してハッシュ値の算出を行う構成とすることができる。これらはいわゆる一方向のハッシュ関数であり、入力された情報に対して一つのハッシュ値を出力する関数である。ハッシュ関数に入力される情報は、本実施の形態においてECU3のROM32に記憶されたプログラム32a又はデータ32bの一部又は全部である。ハッシュ関数に入力されるものがプログラム32a若しくはデータ32bのいずれであっても、又は、プログラム32a及びデータ32bの両方であっても、ハッシュ関数は入力されたものを単に2値の情報として扱い、ハッシュ値を算出することができる。監視装置5及びECU3は、予め定められたハッシュ関数を記憶しており、このハッシュ関数を用いてハッシュ値の算出を行う。
 以下、監視装置5及びECU3がSHA-1のハッシュ関数を用いてハッシュ値を算出する場合について、算出方法を説明する。なおSHA-1のハッシュ関数の詳細な処理、並びに、監視装置5及びECU3が他のハッシュ関数を用いる場合については、これらのハッシュ関数は既存の技術であるため、説明を省略する。
 SHA-1のハッシュ関数を利用する場合、監視装置5及びECU3は、まずパディング処理を行う。パディング処理において監視装置5及びECU3は、入力情報の後に余分なデータを付け加えることによって、処理対象の情報のサイズを所定値(512ビット)の整数倍となるように調整する。次いで監視装置5及びECU3は、パディング処理された情報を512ビット毎のブロックに分割し、各ブロックについて80個の値を算出する第1処理を行う。
 次いで監視装置5及びECU3は、所定サイズ(160ビット)の初期値に対して、第1処理にて算出した値を用いた演算を行い、演算後の160ビットの値をハッシュ値とする第2処理を行う。第2処理において、まず監視装置5及びECU3は、160ビットの初期値に対して、1つのブロックについて算出した80個の値を用いて80ステップの演算を行う。この80ステップの演算により、160ビットの初期値に対して、ブロックの情報を混ぜ込むことができ、出力として160ビットの値が得られる。監視装置5及びECU3は、得られた160ビットの値を初期値として、次のブロックについて算出した80個の値を用いて同様に80ステップの演算を行う。監視装置5及びECU3は、全ブロックについて同様の80ステップの処理を行い、最終的に得られた160ビットの値をハッシュ値とする。
 また本実施の形態において監視装置5及びECU3は、監視装置5が生成したランダムシードを利用してハッシュ値の算出を行う必要がある。例えば監視装置5及びECU3は、上記のパディング処理において、入力情報に付加するデータにランダムシードを用いることができる。また例えば監視装置5及びECU3は、上記の第2処理において、160ビットの初期値にランダムシードを用いることができる。本実施の形態においては、第2処理の初期値にランダムシードを用いるものとする。
 なお監視装置5及びECU3によるランダムシードの利用方法は上記のものに限らない。例えば監視装置5及びECU3は、ハッシュ値算出の対象とするROM32の記憶内容とランダムシードとの論理演算値(排他的論理和など)をハッシュ関数への入力情報とすることができる。また例えば監視装置5及びECU3は、ハッシュ値算出の対象とするROM32の記憶内容の先頭部分又は末尾部分等の所定位置にランダムシードを付加したものをハッシュ関数への入力情報とすることができる。
 監視装置5の基準時点決定部61は、ランダムシード及び領域指定情報のECU3への送信並びにハッシュ値の算出を終えた後、算出したハッシュ値の一部分を抽出する処理を行う。本実施の形態において基準時点決定部61は、算出した160ビットのハッシュ値から、64ビットの値を抽出して確認用情報とする。基準時点決定部61は、抽出した確認用情報を含むハッシュ確認要求を、処理対象のECU3へ送信する。
 監視装置5からハッシュ確認要求を受信したECU3は、受信したハッシュ確認要求に含まれる確認用情報を取得する。ECU3の処理部31は、監視装置5から取得した確認用情報と、自らがハッシュ値算出部42にて算出したハッシュ値とを比較する。処理部31は、ハッシュ値算出部42が算出したハッシュ値に、監視装置5から確認用情報として取得したハッシュ値の一部が含まれるか否かを判定する。自らのハッシュ値に確認用情報のハッシュ値が含まれないと判定した場合、ECU3が算出したハッシュ値と監視装置5が算出したハッシュ値が一致しないと考えられるため、処理部31は処理を中断し、監視装置5へエラー通知などを行う。
 自らのハッシュ値に確認用情報のハッシュ値が含まれると判定した場合、ECU3が算出したハッシュ値と監視装置5が算出したハッシュ値とが同じ値であるとみなし、処理部31は、監視装置5へハッシュ確認要求に対する応答(ハッシュ確認応答)を送信する処理を行う。このときに処理部31は、ハッシュ値算出部42が算出した160ビットのハッシュ値において監視装置5からの確認用情報に続く64ビットの情報を、応答情報として抽出する。処理部31は、抽出した64ビットの応答情報をハッシュ確認応答に含めて監視装置5へ送信する。なおハッシュ値から確認用情報及び応答情報を抽出する方法は、これに限らない。例えば確認用情報及び応答情報の一部が重複していてもよい。
 ECU3からハッシュ確認応答を受信した監視装置5の基準時点決定部61は、受信したハッシュ確認応答に含まれる応答情報を取得する。基準時点決定部61は、ECU3から取得した応答情報と、自らが算出したハッシュ値とを比較する。基準時点決定部61は、自らが算出したハッシュ値から確認用情報を除いた部分に、ECU3からの応答情報として取得したハッシュ値の一部が含まれるか否かを判定する。自らのハッシュ値に応答情報のハッシュ値が含まれないと判定した場合、監視装置5が算出したハッシュ値とECU3が算出したハッシュ値とが一致しないと考えられるため、基準時点決定部61は処理を中断し、ECU3へエラー通知などを行う。
 自らのハッシュ値に応答情報のハッシュ値が含まれると判定した場合、基準時点決定部61は、監視装置5が算出したハッシュ値とECU3が算出したハッシュ値とが同じ値であるとみなす。このときに基準時点決定部61は、ECU3へハッシュ値の判定に成功した旨を通知してもよい。基準時点決定部61は、ECU3から正当なハッシュ確認応答の受信を完了した時点を、基準時点t0と決定する。基準時点t0を決定した後、監視装置5は、上述のように送信予定時点及び許可期間を決定してメッセージ送信の監視を開始する。
 同様に、ECU3の処理部31は、監視装置5に対するハッシュ確認応答の送信を完了した時点を、基準時点t0とする。ECU3のメッセージ処理部41は、この基準時点t0に対して周期Tでメッセージの送信を行う。
 なお本実施の形態に係る通信システムにおいてはCANバスに複数のECU3が接続されており、監視装置5は複数のECU3との間で基準時点決定処理をそれぞれ行う必要がある。図14は、監視装置5による複数のECU3との基準時点決定処理を説明するための模式図である。本例においては、監視装置5が3つのECU3との間で基準時点決定処理を行うものとするが、監視装置5が2つ以下のECU3又は4つ以上のECU3と基準時点決定処理を行う場合も同様である。
 監視装置5は、ランダムシード及び領域指定情報を含むハッシュ値算出要求を各ECU3へ順次送信する。このときに各ハッシュ値算出要求に含めるランダムシード及び領域指定情報は、共通の値を用いてもよく、ECU3毎に異なる値を設定してもよい。監視装置5からハッシュ値算出要求を受信した各ECU3は、自らのROM32の記憶内容に基づいてそれぞれハッシュ値の算出を行う。また監視装置5は、記憶部52の複写データ52aから各ECU3の記憶内容を読み出し、各ECU3についてハッシュ値の算出を行う。
 各ECU3のハッシュ値の算出を終えた監視装置5は、いずれか1つのECU3に対してハッシュ値確認要求を送信し、このECU3からハッシュ値確認応答を受信する。監視装置5は、受信したハッシュ値確認応答に含まれるハッシュ値が正しいものであるか否かを判定し、ハッシュ値が正しいものであればハッシュ値確認応答の受信を完了した時点をこのECU3との基準時点t0と決定する。
 次いで監視装置5は、別の1つのECU3についてハッシュ値確認要求の送信、ハッシュ値確認応答の受信及び基準時点の決定を行う。このように監視装置5は、ハッシュ値確認要求の送信、ハッシュ値確認応答の受信及び基準時点の決定を、通信システムに含まれる各ECU3に対して順次的に繰り返し行う。全てのECU3について基準時点が決定した後、監視装置5はメッセージ送信の監視を開始し、各ECU3はメッセージの送受信を開始する。なお監視装置5による監視及びECU3によるメッセージ送信は、基準時点が決定したものから順次的に開始してもよい。
 図15は、監視装置5による基準時点決定処理の手順を示すフローチャートである。監視装置5の基準時点決定部61は、ハッシュ値算出に用いられるランダムシードと、ハッシュ値算出の対象とするECU3のROM32の記憶領域を指定する領域指定情報とを生成する(ステップS21)。基準時点決定部61は、生成したランダムシード及び領域指定情報を含むハッシュ値算出要求を、CAN通信部53にて処理対象のECU3へ送信する(ステップS22)。
 基準時点決定部61は、記憶部52から処理対象のECU3の記憶内容の複写データ52aを取得し、取得した複写データ52aとステップS21にて生成したランダムシード及び領域指定情報とを基に、所定のハッシュ関数を用いてハッシュ値を算出する(ステップS23)。基準時点決定部61は、ステップS23にて算出したハッシュ値から一部分を確認用情報として抽出する(ステップS24)。基準時点決定部61は、抽出した確認用情報を含むハッシュ値確認要求を、CAN通信部53にて処理対象のECU3へ送信する(ステップS25)。
 次いで基準時点決定部61は、ハッシュ値確認要求に対してECU3が送信するハッシュ値確認応答をCAN通信部53にて受信したか否かを判定する(ステップS26)。ハッシュ値確認応答を受信していない場合(S26:NO)、基準時点決定部61は、処理対象のECU3からエラー通知を受信したか否かを判定する(ステップS27)。エラー通知を受信していない場合(S27:NO)、基準時点決定部61はステップS26へ処理を戻し、ハッシュ値確認応答又はエラー通知をECU3から受信するまで待機する。
 処理対象のECU3からハッシュ値確認応答を受信した場合(S26:YES)、基準時点決定部61は、受信したハッシュ値確認応答に含まれる応答情報が、ステップS23にて算出したハッシュ値に含まれるか否かに応じて、応答情報の成否を判定する(ステップS28)。ECU3からエラー通知を受信した場合(S27:YES)、又は、ECU3から受信した応答情報が正しいものでない場合(S28:NO)、基準時点決定部61は、対象のECU3のROM32の記憶内容が改変された可能性があると判断し、例えばこのECU3の動作を停止させるなどの適宜のエラー処理を行って(ステップS29)、処理を終了する。
 ECU3から受信した応答情報が正しい場合(S28:YES)、基準時点決定部61は、ECU3からハッシュ値確認応答の受信を完了した時点を基準時点と決定し(ステップS30)、処理を終了する。
 図16は、監視装置5からのハッシュ値算出要求に応じてECU3が行う処理の手順を示すフローチャートである。ECU3の処理部31は、CAN通信部34にて監視装置5からハッシュ値算出要求を受信したか否かを判定する(ステップS31)。ハッシュ値算出要求を受信していない場合(S31:NO)、処理部31は、ハッシュ値算出要求を受信するまで待機する。ハッシュ値算出要求を受信した場合(S31:YES)、処理部31は、受信したハッシュ値算出要求に含まれるランダムシード及び領域指定情報を取得する(ステップS32)。処理部31のハッシュ値算出部42は、ROM32の記憶内容と、ステップS32にて取得したランダムシード及び領域指定情報とに基づいて、所定のハッシュ関数を用いてハッシュ値を算出する(ステップS33)。処理部31は、算出したハッシュ値を記憶部33に記憶し(ステップS34)、処理を終了する。
 図17は、監視装置5からのハッシュ値確認要求に応じてECU3が行う処理の手順を示すフローチャートである。ECU3の処理部31は、CAN通信部34にて監視装置5からハッシュ値確認要求を受信したか否かを判定する(ステップS41)。ハッシュ値確認要求を受信していない場合(S41:NO)、処理部31は、ハッシュ値確認要求を受信するまで待機する。ハッシュ値確認要求を受信した場合(S41:YES)、処理部31は、記憶部33に記憶したハッシュ値を読み出す(ステップS42)。処理部31は、ステップS41にて受信したハッシュ値確認要求に含まれる確認用情報が、ステップS42にて読み出したハッシュ値に含まれるか否かに応じて、確認用情報の成否を判定する(ステップS43)。確認用情報が正しいものでない場合(S43:NO)、処理部31は、エラー通知を監視装置5へ送信し(ステップS44)、処理を終了する。
 監視装置5からの確認用情報が正しい場合(S43:YES)、処理部31は、ステップS42にて読み出したハッシュ値から確認用情報に続く所定長の部分を応答情報として抽出する(ステップS45)。処理部31は、抽出した応答情報を含むハッシュ値確認応答をCAN通信部34にて監視装置5へ送信する(ステップS46)。処理部31は、ハッシュ値確認応答の送信を完了した時点を基準時点と決定し(ステップS47)、処理を終了する。
 なお本実施の形態に係る通信システムにおいては、監視装置5及びECU3の起動時に基準時点の決定処理を行う構成としたが、処理を行うタイミングはこれに限らない。また何らかの要因によりECU3がメッセージを送信するタイミングにズレなどが生じた場合又はメッセージ送信の周期を変更した場合等に、監視装置5及びECU3の間で基準時点を再決定する処理を行ってもよい。
 基準時点を再決定する場合、上述のような最初の基準時点決定処理と同様の処理を行ってもよい。即ち監視装置5がハッシュ値算出要求及びハッシュ値確認要求を送信し、これに応じてECU3がハッシュ値確認応答を送信して基準時点を再決定してもよい。なお場合には、ECU3から監視装置5に対して基準時点を再決定する処理を行う要求を送信し、これに応じて監視装置5が基準時点決定処理を開始する構成としてよい。
 又は、基準時点決定処理を行った際のハッシュ値を記憶しておき、ECU3がこのハッシュ値を含む基準時点の再決定要求を監視装置5へ送信してもよい。この再決定要求を受信した監視装置5は、再決定要求に含まれるハッシュ値が正しいものである場合に、再決定要求の受信を完了した時点を新たな基準時点とする。ECU3は、再決定要求の送信を完了した時点を新たな基準時点とすればよい。
<まとめ>
 以上の構成の本実施の形態に係る通信システムは、CANバスに複数のECU3が接続され、各ECU3が周期的にメッセージ送信を行う構成の通信システムに対して、不正なメッセージ送信を検出する監視装置5を設けた構成である。監視装置5は、ECU3による周期的なメッセージ送信の基準時点t0を決定し、基準時点t0に対してメッセージの送信周期Tの整数倍の期間を加えた複数の送信予定時点t1=t0+T,t2=t0+2T,…を決定し、各送信予定時点に対してこの時点を含む所定期間t1-A~t1+B,t2-A~t2+B,…をメッセージ送信の許可期間と決定する。
 また監視装置5は、CANバスを監視することによって、ECU3が送信したメッセージを検出する。監視装置5は、検出されたメッセージが許可期間内に送信されたものであるか否かを判定することによって、このメッセージが不正なものであるか否かを判定することができ、このメッセージの送信を許可するか否かを判定することができる。
 このようの本実施の形態に係る監視装置5は、最初の段階で決定した基準時点t0に基づいて、以降のメッセージ送信の許可期間を決定する構成、即ち絶対的な基準で許可期間を決定する構成である。これに対して例えばメッセージ受信毎に、このメッセージの受信時点に周期Tを加えた時点を送信予定時点として許可期間を決定する構成、即ち相対的な基準で許可期間を決定する構成を採用することが考えられる。しかし、CANの通信プロトコルではメッセージ送信の衝突が発生した場合にはアービトレーション処理が行われ、優先度の低いメッセージの送信に遅延が発生する。相対的な決定を行う構成では、メッセージ送信に遅延が発生した場合に、判定のための許可期間が変動するため、許可期間をある程度広く設定する必要があり、許可期間を狭めることが容易でない。許可期間が広いほど不正なメッセージを正当であると誤判定する可能性が高まる。また相対的な決定を行う構成では、不正なメッセージの受信を基準として次のメッセージの許可期間が決定される虞がある。このような事態が発生した場合、不正なメッセージが連続的に正当なメッセージであると誤判定される可能性がある。本実施の形態に係る監視装置5は、絶対的な基準で許可期間を決定することによって、これらの問題が発生することを回避できる。
 また監視装置5は、通信システムに含まれる各ECU3について、基準時点t0をそれぞれ個別に決定する。監視装置5は、決定したそれぞれの基準時点t0に対して送信予定時点tn及び許可期間をECU3毎に決定する。これにより、通信システムにメッセージの送信周期T及び送信タイミング等が異なるECU3が含まれていても、監視装置5はECU3毎にメッセージ送信の可否を判定することができる。
 またECU3は送信周期が異なる複数種別のメッセージ送信を行うことが可能であり、監視装置5はメッセージのCAN-ID毎に許可期間を決定する。これにより送信周期が異なるメッセージを1つのECU3が送信する場合であっても、監視装置5は、メッセージの種別毎に送信の可否を判定することができる。なお本実施の形態においては基準時点t0をECU3毎に決定したが、これに限るものではなく、基準時点t0をCAN-ID毎に決定してもよい。この場合、監視装置5は、1つのECU3に対して複数回(即ち、このECU3に割り当てられたCAN-IDの数)の基準時点決定処理を行えばよい。
 またCANの通信プロトコルにおいてはメッセージの送信が衝突した場合に、アービトレーション処理によってメッセージ送信が遅延する可能性がある。そこで監視装置5は、判定対象のメッセージについて送信予定時点tnからこのメッセージの送信完了までの間に、他のメッセージが送信されたか否かを調べる。他のメッセージが送信されていた場合、監視装置5は、判定対象のメッセージの優先度と他のメッセージの優先度とを比較する。他のメッセージの優先度が判定対象のメッセージの優先度より高い場合、判定対象のメッセージはアービトレーション処理によって送信に遅延が発生したと考えられるため、監視装置5は、判定対象のメッセージの送信を許可する。これに対して、他のメッセージの優先度が判定対象のメッセージの優先度より低い場合(ただし、許可期間開始以前に送信されたメッセージを除く)、判定対象のメッセージの遅れが正当なアービトレーション処理によるものではないと考えられるため、監視装置5は、判定対象のメッセージの送信を許可しない。これにより、アービトレーション処理によってメッセージ送信に遅延が発生する通信システムであっても、監視装置5は、メッセージ送信の可否を判定することができる。
 また監視装置5は、判定対象のメッセージの送信予定時点tnからこのメッセージの送信が完了するまでの間に、所定長を超えるメッセージ無送信期間が存在するか否かを判定する。メッセージ無送信期間が存在する場合、判定対象のメッセージの遅延は正当なアービトレーション処理によって発生したものではないと考えられるため、監視装置5は、判定対象のメッセージの送信を許可しない。
 また本実施の形態に係る通信システムにおいては、基準時点t0を決定するために、監視装置5とECU3との間で所定の手続を行う。監視装置5は、ECU3に対してハッシュ値算出要求を送信する。このときに監視装置5は、ハッシュ値算出に必要なランダムシード及び領域指定情報をECU3へ与える。監視装置5からハッシュ値算出要求を受信したECU3は、ハッシュ値算出要求に含まれるランダムシード及び領域指定情報と、ROM32に記憶されたデータとに基づいて、所定のハッシュ関数を用いたハッシュ値の算出を行う。ECU3は、監視装置5からのハッシュ値確認要求に応じて、算出したハッシュ値を含むハッシュ値確認応答を監視装置5へ送信する。ECU3からハッシュ値確認応答を受信した監視装置5は、ハッシュ値確認応答に含まれるハッシュ値が正しいものであるか否かを判定する。ハッシュ値が正しいものである場合、監視装置5は、ハッシュ値確認応答の受信を完了した時点に基づいて基準時点t0を決定する。例えば監視装置5は、ハッシュ値確認等々の受信完了時点を基準時点t0とする。ただし基準時点t0はこれに限るものではなく、例えばハッシュ値確認応答の送信開始時点を基準時点t0としてもよく、また例えばハッシュ値確認応答の受信完了時点に対して所定期間を増減した時点を基準時点t0としてもよい。この場合にECU3は、正しいハッシュ値を含むハッシュ確認応答の送信完了時点に基づいて基準時点t0を決定し、決定した時点を基準に周期Tでのメッセージ送信を行う。ハッシュ値に基づく信頼性の高い情報送受信に基づいて基準時点t0を決定することができるため、監視装置5は、信頼性の高い不正メッセージ検出処理を行うことができる。
 また監視装置5は、不正なメッセージに対して送信を許可しないと判定した場合、このメッセージを受信するECU3に対してメッセージを破棄させるための処理を行う。例えば監視装置5は、不正なメッセージのEOFの出力期間中に、CANバスに対してエラーフレームを送信することによって、ECU3にこのメッセージを破棄させることができる。これにより、不正なメッセージをECU3が受信し、このメッセージに応じた処理がECU3にて行われることを防止できる。
 なお本実施の形態においては、基準時点の決定処理、許可期間の決定処理、送信可否の判定処理及び不正メッセージの破棄処理等を監視装置5の処理部51(いわゆるCPUなど)が行う構成としたが、これに限るものではなく、これらの処理をCAN通信部53(いわゆるCANコントローラなど)が行う構成としてもよい。同様に、ECU3のハッシュ値算出処理など基準時点の決定処理は、処理部31が行うのではなく、CAN通信部34が行う構成としてもよい。
 また、監視装置5及びECU3の間でハッシュ値を利用した情報交換を行って基準時点t0を決定する構成としたが、基準時点t0の決定はハッシュ値を利用しない方法で行ってもよい。例えば公開鍵又は秘密鍵等を利用して暗号化された情報を監視装置5及びECU3の間で送受信し、この送受信結果に基づいて基準時点t0を決定してもよい。監視装置5及びECU3が信頼性の高い通信を行い、この通信結果に基づいて基準時点t0を決定すればよい。また、監視装置5及びECU3が時刻同期機能を有する場合には、この機能により同期された時刻を用いて基準時点t0を決定してもよい。
 また監視装置5は、ECU3のROM32の記憶内容を複写した複写データ52aを記憶部52に記憶する構成としたが、これに限るものではない。例えば複写データ52aは別のサーバ装置などが記憶し、監視装置5が必要に応じてサーバ装置から複写データ52aを取得してもよく、更にはサーバ装置にハッシュ値算出機能を設けて監視装置5がサーバ装置から必要なハッシュ値を取得する構成としてもよい。また本実施の形態においては、車両1に搭載された通信システムを例に説明を行ったが、通信システムは車両1に搭載されるものに限らず、例えば飛行機又は船舶等の移動体に搭載されるものであってよく、また例えば移動体ではなく工場、オフィス又は学校等に設置されるものであってもよい。
 (変形例)
 上述の実施の形態における監視装置5は、送信予定時点からメッセージ送信までの間にメッセージ無送信期間が存在しない場合、又は、メッセージ無送信期間が存在しても所定長より短い場合に、判定対象のメッセージが正当なメッセージであると送信可否判定部63が判定し、送信を許可する構成であった。変形例に係る監視装置5は、上述の監視装置5の構成に、送信可否判定部63の判定条件を追加した構成である。
 例えば、対象となる2つ以上のメッセージが送信許可期間内に到着する場合、いずれのメッセージが正当なメッセージであるかをこの時点で判定することはできない。しかしながら、このような状況が頻繁に発生する場合には、いずれかのメッセージが不正なものである可能性がある。
 そこで変形例に係る監視装置5の送信可否判定部63は、送信許可期間内に2つ以上の対象メッセージが到着したと判定した場合、これら複数のメッセージの全てについて、以降のメッセージ送信を許可しない。これにより変形例に係る監視装置5は、不正である可能性のあるメッセージの送信を禁止することができる。
 なお変形例に係る監視装置5は、例えば送信許可期間内に2つ以上の対象メッセージが到着した回数をカウントし、この回数が所定回数を超えた場合にメッセージの送信を禁止する構成としてもよい。
 1 車両
 3 ECU(通信装置)
 5 監視装置(通信制御装置)
 31 処理部(ハッシュ値送信部)
 32 ROM
 32a プログラム
 32b データ
 33 RAM
 34 CAN通信部(調停手段)
 41 メッセージ処理部(メッセージ送信部)
 42 ハッシュ値算出部
 51 処理部
 52 記憶部
 52a 複写データ
 52b 周期情報
 53 CAN通信部(メッセージ検出部)
 61 基準時点決定部(ハッシュ値要求部、ハッシュ値受信部、ハッシュ値判定部)
 62 許可期間決定部
 63 送信可否判定部
 64 破棄処理部
 

Claims (15)

  1.  周期的にメッセージ送信を行うメッセージ送信部を有する通信装置による通信を制御する通信制御装置であって、
     前記メッセージ送信部によるメッセージ送信に係る基準時点を決定する基準時点決定部と、
     該基準時点決定部が決定した基準時点に前記メッセージ送信部によるメッセージ送信周期の整数倍の期間を加えた送信予定時点に対し、該送信予定時点を含む所定期間をメッセージ送信の許可期間とする許可期間決定部と、
     前記通信装置が送信したメッセージを検出するメッセージ検出部と、
     該メッセージ検出部が検出したメッセージが、前記許可期間決定部が決定した許可期間内に送信されたものであるか否かに応じて、前記メッセージの送信可否を判定する送信可否判定部と
     を備えることを特徴とする通信制御装置。
  2.  制御対象の通信装置が複数存在する場合に、
     前記基準時点決定部及び前記許可期間決定部は、複数の通信装置それぞれについて前記基準時点及び前記許可期間を決定するようにしてあること
     を特徴とする請求項1に記載の通信制御装置。
  3.  前記通信装置が送信する前記メッセージには、該メッセージの優先度を示す情報を含み、
     前記許可期間決定部は、メッセージの優先度毎に前記許可期間を決定するようにしてあること
     を特徴とする請求項1又は請求項2に記載の通信制御装置。
  4.  複数の前記通信装置のメッセージ送信が衝突した場合に、メッセージに対して定められた優先度に応じて送信順序を調停する調停手段を備え、
     前記送信可否判定部は、判定対象のメッセージに関する前記送信予定時点から前記判定対象のメッセージの送信が完了するまでの間に送信を完了した他のメッセージの優先度を調べ、前記判定対象のメッセージより優先度が低い他のメッセージが存在する場合に、前記判定対象のメッセージの送信を許可しないと判定するようにしてあること
     を特徴とする請求項3に記載の通信制御装置。
  5.  前記送信可否判定部は、判定対象のメッセージに関する前記送信予定時点から前記判定対象のメッセージの送信が完了するまでの間に、所定長を超えるメッセージ無送信期間が存在する場合に、前記判定対象のメッセージの送信を許可しないと判定するようにしてあること
     を特徴とする請求項1乃至請求項4のいずれか1つに記載の通信制御装置。
  6.  前記通信装置に対してハッシュ値の算出要求を与えるハッシュ値要求部と、
     前記算出要求に対する応答として前記通信装置が送信するハッシュ値を受信するハッシュ値受信部と、
     該ハッシュ値受信部が受信したハッシュ値の正誤を判定するハッシュ値判定部と
     を備え、
     前記基準時点決定部は、前記通信装置から正しいハッシュ値の受信を完了した時点に基づいて、前記基準時点を決定するようにしてあること
     を特徴とする請求項1乃至請求項5のいずれか1つに記載の通信制御装置。
  7.  前記送信可否判定部が送信を許可しないと判定したメッセージを、該メッセージを受信する前記通信装置に破棄させる処理を行う破棄処理部を備えること
     を特徴とする請求項1乃至請求項6のいずれか1つに記載の通信制御装置。
  8.  互いにメッセージの送受信を行う複数の通信装置及び該通信装置による通信を制御する通信制御装置を備える通信システムであって、
     前記通信装置は、周期的にメッセージ送信を行うメッセージ送信部を有し、
     前記通信制御装置は、
     前記メッセージ送信部によるメッセージ送信に係る基準時点を決定する基準時点決定部と、
     該基準時点決定部が決定した基準時点に前記メッセージ送信部によるメッセージ送信周期の整数倍の期間を加えた送信予定時点に対し、該送信予定時点を含む所定期間をメッセージ送信の許可期間とする許可期間決定部と、
     前記通信装置が送信したメッセージを検出するメッセージ検出部と、
     該メッセージ検出部が検出したメッセージが、前記許可期間決定部が決定した許可期間内に送信されたものであるか否かに応じて、前記メッセージの送信可否を判定する送信可否判定部と
     を有すること
     を特徴とする通信システム。
  9.  前記基準時点決定部及び前記許可期間決定部は、前記複数の通信装置それぞれについて前記基準時点及び前記許可期間を決定するようにしてあること
     を特徴とする請求項8に記載の通信システム。
  10.  前記通信装置が送信する前記メッセージには、該メッセージの優先度を示す情報を含み、
     前記許可期間決定部は、メッセージの優先度毎に前記許可期間を決定するようにしてあること
     を特徴とする請求項8又は請求項9に記載の通信システム。
  11.  複数の前記通信装置のメッセージ送信が衝突した場合に、メッセージに対して定められた優先度に応じて送信順序を調停する調停手段を備え、
     前記送信可否判定部は、判定対象のメッセージに関する前記送信予定時点から前記判定対象のメッセージの送信が完了するまでの間に送信を完了した他のメッセージの優先度を調べ、前記判定対象のメッセージより優先度が低い他のメッセージが存在する場合に、前記判定対象のメッセージの送信を許可しないと判定するようにしてあること
     を特徴とする請求項10に記載の通信システム。
  12.  前記送信可否判定部は、判定対象のメッセージに関する前記送信予定時点から前記判定対象のメッセージの送信が完了するまでの間に、所定長を超えるメッセージ無送信期間が存在する場合に、前記判定対象のメッセージの送信を許可しないと判定するようにしてあること
     を特徴とする請求項8乃至請求項11のいずれか1つに記載の通信システム。
  13.  前記通信制御装置は、
     前記通信装置に対してハッシュ値の算出要求を与えるハッシュ値要求部と、
     前記算出要求に対する応答として前記通信装置が送信するハッシュ値を受信するハッシュ値受信部と、
     該ハッシュ値受信部が受信したハッシュ値の正誤を判定するハッシュ値判定部と
     を有し、
     前記通信装置は、
     前記通信制御装置からの算出要求に応じてハッシュ値を算出するハッシュ値算出部と、
     該ハッシュ値算出部が算出したハッシュ値を前記通信制御装置へ送信するハッシュ値送信部と
     を有し、
     前記基準時点決定部は、前記通信装置から正しいハッシュ値の受信を完了した時点に基づいて、前記基準時点を決定するようにしてあること
     を特徴とする請求項8乃至請求項12のいずれか1つに記載の通信システム。
  14.  前記メッセージ送信部は、前記ハッシュ値送信部が正しいハッシュ値の送信を完了した時点に基づく基準時点を決定し、決定した時点を基準として周期的にメッセージ送信を行うようにしてあること
     を特徴とする請求項13に記載の通信システム。
  15.  前記通信制御装置は、前記送信可否判定部が送信を許可しないと判定したメッセージを、該メッセージを受信する前記通信装置に破棄させる処理を行う破棄処理部を有すること
     を特徴とする請求項8乃至請求項14のいずれか1つに記載の通信システム。
     
PCT/JP2015/082349 2014-11-20 2015-11-18 通信制御装置及び通信システム WO2016080422A1 (ja)

Priority Applications (4)

Application Number Priority Date Filing Date Title
DE112015005252.6T DE112015005252T5 (de) 2014-11-20 2015-11-18 Kommunikationssteuereinrichtung und Kommunikationssystem
CN201580061067.9A CN107005447B (zh) 2014-11-20 2015-11-18 通信控制装置及通信系统
JP2016560252A JP6306206B2 (ja) 2014-11-20 2015-11-18 通信制御装置及び通信システム
US15/527,826 US10432421B2 (en) 2014-11-20 2015-11-18 Communication control device and communication system

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP2014-235782 2014-11-20
JP2014235782 2014-11-20

Publications (1)

Publication Number Publication Date
WO2016080422A1 true WO2016080422A1 (ja) 2016-05-26

Family

ID=56013957

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/JP2015/082349 WO2016080422A1 (ja) 2014-11-20 2015-11-18 通信制御装置及び通信システム

Country Status (5)

Country Link
US (1) US10432421B2 (ja)
JP (1) JP6306206B2 (ja)
CN (1) CN107005447B (ja)
DE (1) DE112015005252T5 (ja)
WO (1) WO2016080422A1 (ja)

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2018051607A1 (ja) * 2016-09-15 2018-03-22 住友電気工業株式会社 検知装置、ゲートウェイ装置、検知方法および検知プログラム
JP2018056980A (ja) * 2016-09-27 2018-04-05 富士通株式会社 攻撃検知装置、攻撃検知方法、および、攻撃検知プログラム
JP2018088616A (ja) * 2016-11-29 2018-06-07 富士通株式会社 攻撃検知装置、攻撃検知方法、および、攻撃検知プログラム
JP2019068253A (ja) * 2017-09-29 2019-04-25 株式会社デンソー 異常検知装置、異常検知方法、プログラム及び通信システム
JP2019176473A (ja) * 2018-03-29 2019-10-10 パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカPanasonic Intellectual Property Corporation of America 不正検知方法、不正検知装置及びプログラム
JP2020530967A (ja) * 2017-08-14 2020-10-29 アーガス サイバー セキュリティ リミテッド 自動車用サイバーセキュリティ
JPWO2021065069A1 (ja) * 2019-09-30 2021-04-08
US11849324B2 (en) 2019-09-30 2023-12-19 Autonetworks Technologies, Ltd. Detection device, vehicle, detection method, and detection program
WO2024195467A1 (ja) * 2023-03-20 2024-09-26 株式会社オートネットワーク技術研究所 車載装置、プログラム及び情報処理方法

Families Citing this family (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109644153B (zh) * 2016-04-12 2020-10-13 伽德诺克斯信息技术有限公司 具有被配置为实现安全锁定的相关设备的特别编程的计算系统及其使用方法
JP7094670B2 (ja) * 2017-07-03 2022-07-04 矢崎総業株式会社 設定装置及びコンピュータ
US10387139B2 (en) 2017-07-25 2019-08-20 Aurora Labs Ltd. Opportunistic software updates during select operational modes
CN109696900A (zh) * 2017-10-23 2019-04-30 北京长城华冠汽车科技股份有限公司 一种测试汽车控制器局域网络报文发送周期的系统和方法
US10009325B1 (en) * 2017-12-07 2018-06-26 Karamba Security End-to-end communication security
CN108833018B (zh) * 2018-04-09 2021-01-22 桂林电子科技大学 一种组网通信系统及方法
US11711384B2 (en) * 2018-08-27 2023-07-25 Lear Corporation Method and system for detecting message injection anomalies
KR20200056192A (ko) * 2018-11-14 2020-05-22 현대자동차주식회사 데이터 통신 시스템과 데이터 통신 방법, 서버, 차량
JP7175858B2 (ja) * 2019-08-07 2022-11-21 株式会社日立製作所 情報処理装置および正規通信判定方法
CN112738151B (zh) * 2019-09-17 2024-05-31 三菱重工业株式会社 传送装置
JP7347141B2 (ja) * 2019-11-13 2023-09-20 株式会社オートネットワーク技術研究所 車載通信装置及び情報置換方法
CN113271612B (zh) * 2020-02-17 2024-04-09 华为技术有限公司 一种随流信息遥测iFIT检测信息的上报方法及装置
US20210312729A1 (en) * 2020-04-01 2021-10-07 Gm Cruise Holdings Llc Distributed autonomous vehicle data logger
US20230072454A1 (en) * 2021-08-24 2023-03-09 Robert Bosch Gmbh System and method for generating random numbers within a vehicle controller
CN113923139B (zh) * 2021-12-15 2022-03-01 北京城市轨道交通咨询有限公司 一种评估列控数据通信系统可靠性的方法及装置

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2013094072A1 (ja) * 2011-12-22 2013-06-27 トヨタ自動車 株式会社 通信システム及び通信方法
JP2014146868A (ja) * 2013-01-28 2014-08-14 Hitachi Automotive Systems Ltd ネットワーク装置およびデータ送受信システム

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
RU2355130C2 (ru) * 2003-03-11 2009-05-10 Конинклейке Филипс Электроникс Н.В. Способ планирования периодов обслуживания в беспроводной локальной сети (wlan)
CN100563162C (zh) * 2003-09-02 2009-11-25 华为技术有限公司 一种实现网络访问控制的方法
US7788713B2 (en) * 2004-06-23 2010-08-31 Intel Corporation Method, apparatus and system for virtualized peer-to-peer proxy services
NZ552760A (en) * 2004-07-06 2008-09-26 Ntt Docomo Inc Message transmission system and message transmission method
US7609625B2 (en) * 2005-07-06 2009-10-27 Fortinet, Inc. Systems and methods for detecting and preventing flooding attacks in a network environment
US7949317B2 (en) * 2008-02-13 2011-05-24 Apple Inc. Momentary burst protocol for wireless communication
JP5594255B2 (ja) 2011-08-10 2014-09-24 トヨタ自動車株式会社 車両ネットワークの通信管理装置
WO2015106333A1 (en) * 2014-01-16 2015-07-23 Perry + Currier Inc. Device, system and method of mobile identity verification
US9220013B2 (en) * 2014-02-06 2015-12-22 Verizon Patent And Licensing Inc. Tune control for shared access system

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2013094072A1 (ja) * 2011-12-22 2013-06-27 トヨタ自動車 株式会社 通信システム及び通信方法
JP2014146868A (ja) * 2013-01-28 2014-08-14 Hitachi Automotive Systems Ltd ネットワーク装置およびデータ送受信システム

Cited By (20)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109691029B (zh) * 2016-09-15 2021-10-22 住友电气工业株式会社 检测装置、网关装置和检测方法
JP2018046432A (ja) * 2016-09-15 2018-03-22 住友電気工業株式会社 検知装置、ゲートウェイ装置、検知方法および検知プログラム
CN109691029A (zh) * 2016-09-15 2019-04-26 住友电气工业株式会社 检测装置、网关装置、检测方法、以及检测程序
US10880415B2 (en) 2016-09-15 2020-12-29 Sumitomo Electric Industries, Ltd. Detecting device, gateway device, and detecting method
WO2018051607A1 (ja) * 2016-09-15 2018-03-22 住友電気工業株式会社 検知装置、ゲートウェイ装置、検知方法および検知プログラム
JP2018056980A (ja) * 2016-09-27 2018-04-05 富士通株式会社 攻撃検知装置、攻撃検知方法、および、攻撃検知プログラム
JP2018088616A (ja) * 2016-11-29 2018-06-07 富士通株式会社 攻撃検知装置、攻撃検知方法、および、攻撃検知プログラム
JP7030957B2 (ja) 2017-08-14 2022-03-07 アーガス サイバー セキュリティ リミテッド 自動車用サイバーセキュリティ
JP2020530967A (ja) * 2017-08-14 2020-10-29 アーガス サイバー セキュリティ リミテッド 自動車用サイバーセキュリティ
JP2019068253A (ja) * 2017-09-29 2019-04-25 株式会社デンソー 異常検知装置、異常検知方法、プログラム及び通信システム
JP7003544B2 (ja) 2017-09-29 2022-01-20 株式会社デンソー 異常検知装置、異常検知方法、プログラム及び通信システム
JP2019176473A (ja) * 2018-03-29 2019-10-10 パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカPanasonic Intellectual Property Corporation of America 不正検知方法、不正検知装置及びプログラム
JP7512473B2 (ja) 2018-03-29 2024-07-08 パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカ 不正検知方法、不正検知装置及びプログラム
JP7280082B2 (ja) 2018-03-29 2023-05-23 パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカ 不正検知方法、不正検知装置及びプログラム
WO2021065069A1 (ja) * 2019-09-30 2021-04-08 株式会社オートネットワーク技術研究所 検知装置、車両、検知方法および検知プログラム
JP7396363B2 (ja) 2019-09-30 2023-12-12 株式会社オートネットワーク技術研究所 検知装置、車両、検知方法および検知プログラム
US11849324B2 (en) 2019-09-30 2023-12-19 Autonetworks Technologies, Ltd. Detection device, vehicle, detection method, and detection program
US11870789B2 (en) 2019-09-30 2024-01-09 Autonetworks Technologies, Ltd. Detection device, vehicle, detection method, and detection program
JPWO2021065069A1 (ja) * 2019-09-30 2021-04-08
WO2024195467A1 (ja) * 2023-03-20 2024-09-26 株式会社オートネットワーク技術研究所 車載装置、プログラム及び情報処理方法

Also Published As

Publication number Publication date
US20170324579A1 (en) 2017-11-09
DE112015005252T5 (de) 2017-08-10
CN107005447B (zh) 2020-09-08
CN107005447A (zh) 2017-08-01
JPWO2016080422A1 (ja) 2017-08-17
JP6306206B2 (ja) 2018-04-04
US10432421B2 (en) 2019-10-01

Similar Documents

Publication Publication Date Title
JP6306206B2 (ja) 通信制御装置及び通信システム
JP6477281B2 (ja) 車載中継装置、車載通信システム及び中継プログラム
CN108353015B (zh) 中继装置
EP3151462B1 (en) Transmission device, reception device, transmission method, and reception method
CN106471767B (zh) 通信系统及密钥信息共享方法
JP5880898B2 (ja) 送信装置
JP6282216B2 (ja) 通信システム及び通信装置
US10050983B2 (en) Communication system, receiving apparatus, receiving method, and computer program product
US11647045B2 (en) Monitoring a network connection for eavesdropping
WO2017057165A1 (ja) 車載通信システム
CN113169979B (zh) 用于检测对网络的分布式现场总线的入侵的方法及其系统
JP6404848B2 (ja) 監視装置、及び、通信システム
CN108632242B (zh) 通信装置及接收装置
CN113273144B (zh) 车载通信系统、车载通信控制装置、车载通信装置、通信控制方法及通信方法
JP7110950B2 (ja) ネットワークシステム
KR20190097216A (ko) 센서의 측정값들에 서명하기 위한 방법, 장치 및 명령어들을 포함하는 컴퓨터 판독 가능 저장 매체
JP2023519910A (ja) 特に自動車におけるデータの異常を処理するための方法
JP6108251B2 (ja) 受信装置、及び受信方法
JP6447974B2 (ja) 送信方法
JP7328419B2 (ja) 車載通信システム、車載通信装置、コンピュータプログラム及び通信方法
JP6676065B2 (ja) 接続された装置による認証連鎖
JP6822090B2 (ja) 通信システム
JP2018011155A (ja) Can通信システム
JP6149716B2 (ja) 車載ネットワークシステム
JP2022086429A (ja) 通信装置、通信装置が行なう通信異常判定方法、および通信装置を制御するためのプログラム

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 15861317

Country of ref document: EP

Kind code of ref document: A1

ENP Entry into the national phase

Ref document number: 2016560252

Country of ref document: JP

Kind code of ref document: A

WWE Wipo information: entry into national phase

Ref document number: 15527826

Country of ref document: US

WWE Wipo information: entry into national phase

Ref document number: 112015005252

Country of ref document: DE

122 Ep: pct application non-entry in european phase

Ref document number: 15861317

Country of ref document: EP

Kind code of ref document: A1