JP2018026866A - Management system, data providing device, on-vehicle computer, management method, and computer program - Google Patents

Management system, data providing device, on-vehicle computer, management method, and computer program Download PDF

Info

Publication number
JP2018026866A
JP2018026866A JP2017197257A JP2017197257A JP2018026866A JP 2018026866 A JP2018026866 A JP 2018026866A JP 2017197257 A JP2017197257 A JP 2017197257A JP 2017197257 A JP2017197257 A JP 2017197257A JP 2018026866 A JP2018026866 A JP 2018026866A
Authority
JP
Japan
Prior art keywords
key
ecu
data
vehicle
encrypted data
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2017197257A
Other languages
Japanese (ja)
Other versions
JP6454919B2 (en
Inventor
竹森 敬祐
Keisuke Takemori
敬祐 竹森
誠一郎 溝口
Seiichiro Mizoguch
誠一郎 溝口
秀明 川端
Hideaki Kawabata
秀明 川端
歩 窪田
Ayumi Kubota
歩 窪田
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
KDDI Corp
Original Assignee
KDDI Corp
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 KDDI Corp filed Critical KDDI Corp
Priority to JP2017197257A priority Critical patent/JP6454919B2/en
Publication of JP2018026866A publication Critical patent/JP2018026866A/en
Application granted granted Critical
Publication of JP6454919B2 publication Critical patent/JP6454919B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Abstract

PROBLEM TO BE SOLVED: To improve the reliability of an on-vehicle computer such as an ECU mounted on a vehicle such as an automobile.SOLUTION: A server device generates a second key to be stored in an on-vehicle computer, calculates an expectation value of application data to be applied to the on-vehicle computer with the second key, and transmits the application data and expectation value to a vehicle. The on-vehicle computer calculates the measurement value of the application data received from the server device with the second key, verifies the measurement value on the basis of the expectation value received from the server device, and transmits a verification result of the measurement value to the server device. The server device receives the verification result of the measurement value of the application data from the vehicle.SELECTED DRAWING: Figure 14

Description

本発明は、管理システム、データ提供装置、車載コンピュータ、管理方法、及びコンピュータプログラムに関する。   The present invention relates to a management system, a data providing device, an in-vehicle computer, a management method, and a computer program.

従来、自動車は、ECU(Electronic Control Unit:電子制御装置)を有し、ECUによってエンジン制御等の機能を実現する。ECUは、コンピュータの一種であり、コンピュータプログラムによって所望の機能を実現する。複数のECUをCAN(Controller Area Network)に接続して構成される車載制御システムについてのセキュリティ技術が例えば非特許文献1に記載されている。   2. Description of the Related Art Conventionally, an automobile has an ECU (Electronic Control Unit), and functions such as engine control are realized by the ECU. The ECU is a kind of computer and realizes a desired function by a computer program. For example, Non-Patent Document 1 discloses a security technique for an in-vehicle control system configured by connecting a plurality of ECUs to a CAN (Controller Area Network).

竹森敬祐、“セキュアエレメントを基点とした車載制御システムの保護 −要素技術の整理と考察−”、電子情報通信学会、信学技報、vol. 114、no. 508、pp. 73-78、2015年3月Keisuke Takemori, “Protection of in-vehicle control systems based on secure elements: Organizing and considering element technologies”, IEICE, IEICE Technical Report, vol. 114, no. 508, pp. 73-78, 2015 March 日本工業規格、JISD4901、“車両識別番号(VIN)”Japanese Industrial Standard, JIS D4901, “Vehicle Identification Number (VIN)” STMicroelectronics、“AN4240 Application note”、[平成28年6月28日検索]、インターネット<URL:http://www.st.com/web/en/resource/technical/document/application_note/DM00075575.pdf>STMicroelectronics, “AN4240 Application note”, [Search June 28, 2016], Internet <URL: http://www.st.com/web/en/resource/technical/document/application_note/DM00075575.pdf>

自動車の車載制御システムに適用されるECUの信頼性を向上させることが一つの課題であった。   One problem is to improve the reliability of an ECU applied to an in-vehicle control system of an automobile.

本発明は、このような事情を考慮してなされたものであり、自動車等の車両に搭載されるECU等の車載コンピュータの信頼性を向上させることができる管理システム、データ提供装置、車載コンピュータ、管理方法、及びコンピュータプログラムを提供することを課題とする。   The present invention has been made in consideration of such circumstances, and a management system, a data providing apparatus, an in-vehicle computer, It is an object to provide a management method and a computer program.

本発明の一態様は、データ提供装置と、車両に搭載される車載コンピュータとを備え、前記データ提供装置は、前記車両とデータを送受する車両インタフェースと、前記車載コンピュータに格納される第1の鍵及び第2の鍵を生成する鍵生成部と、前記第2の鍵を使用して、前記車載コンピュータに適用される適用データの期待値を計算する期待値計算部と、前記車載コンピュータが予め格納している初期鍵により前記第1の鍵を暗号化して第1の暗号化データを生成し、前記第1の鍵により前記第2の鍵を暗号化して第2の暗号化データを生成し、前記第1の鍵により前記期待値を暗号化して第4の暗号化データを生成する暗号処理部と、を備え、前記適用データ、前記第1の暗号化データ、前記第2の暗号化データ及び前記第4の暗号化データを前記車両インタフェースにより前記車両に送信し、前記適用データの測定値の検証結果を前記車両インタフェースにより前記車両から受信し、前記車載コンピュータは、自車載コンピュータの外部の装置とデータを送受するインタフェース部と、前記インタフェース部により前記データ提供装置から受信した第1の暗号化データを自車載コンピュータが予め格納している初期鍵により復号して第1の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第2の暗号化データを該取得した第1の鍵により復号して第2の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第4の暗号化データを該取得した第1の鍵により復号して期待値を取得する暗号処理部と、前記インタフェース部により前記データ提供装置から受信した適用データの測定値を該取得された第2の鍵を使用して計算し、該取得された期待値に基づいて該測定値を検証する測定部と、を備え、該測定値の検証結果を前記インタフェース部により前記データ提供装置に送信する、管理システムである。   One aspect of the present invention includes a data providing device and an in-vehicle computer mounted on a vehicle, and the data providing device includes a vehicle interface for transmitting and receiving data to and from the vehicle, and a first stored in the in-vehicle computer. A key generation unit that generates a key and a second key, an expected value calculation unit that calculates an expected value of application data to be applied to the in-vehicle computer using the second key, and the in-vehicle computer The first key is encrypted with the stored initial key to generate first encrypted data, and the second key is encrypted with the first key to generate second encrypted data. An encryption processing unit that encrypts the expected value with the first key to generate fourth encrypted data, the application data, the first encrypted data, and the second encrypted data. And the fourth encryption Data is transmitted to the vehicle via the vehicle interface, the verification result of the measurement value of the application data is received from the vehicle via the vehicle interface, and the in-vehicle computer transmits / receives data to / from an external device of the in-vehicle computer. The first encryption data received from the data providing device by the interface unit and the interface unit is decrypted by the initial key stored in advance by the in-vehicle computer, and the first key is obtained by the interface unit. The second encrypted data received from the data providing device is decrypted with the obtained first key to obtain a second key, and the fourth encrypted data received from the data providing device by the interface unit is obtained. An encryption processing unit that obtains an expected value by decrypting with the obtained first key, and an interface unit A measurement unit that calculates a measurement value of the application data received from the data providing device using the acquired second key, and verifies the measurement value based on the acquired expected value; and In the management system, the verification result of the measurement value is transmitted to the data providing apparatus by the interface unit.

本発明の一態様は、車両とデータを送受する車両インタフェースと、前記車両に搭載される車載コンピュータに格納される第1の鍵及び第2の鍵を生成する鍵生成部と、前記第2の鍵を使用して、前記車載コンピュータに適用される適用データの期待値を計算する期待値計算部と、前記車載コンピュータが予め格納している初期鍵により前記第1の鍵を暗号化して第1の暗号化データを生成し、前記第1の鍵により前記第2の鍵を暗号化して第2の暗号化データを生成し、前記第1の鍵により前記期待値を暗号化して第4の暗号化データを生成する暗号処理部と、を備え、前記適用データ、前記第1の暗号化データ、前記第2の暗号化データ及び前記第4の暗号化データを前記車両インタフェースにより前記車両に送信し、前記適用データの測定値の検証結果を前記車両インタフェースにより前記車両から受信する、データ提供装置である。   One aspect of the present invention is a vehicle interface that transmits and receives data to and from a vehicle, a key generation unit that generates a first key and a second key stored in an in-vehicle computer mounted on the vehicle, and the second An expected value calculation unit that calculates an expected value of application data applied to the in-vehicle computer using a key, and the first key is encrypted by an initial key stored in advance in the in-vehicle computer. Encrypted data is generated, the second key is encrypted with the first key to generate second encrypted data, the expected value is encrypted with the first key, and a fourth cipher is generated. An encryption processing unit for generating encrypted data, and transmitting the application data, the first encrypted data, the second encrypted data, and the fourth encrypted data to the vehicle through the vehicle interface. Of the applicable data The verification result of the value received from the vehicle by the vehicle interface, the data providing apparatus.

本発明の一態様は、車両に搭載される車載コンピュータにおいて、自車載コンピュータの外部の装置とデータを送受するインタフェース部と、前記インタフェース部によりデータ提供装置から受信した第1の暗号化データを自車載コンピュータが予め格納している初期鍵により復号して第1の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第2の暗号化データを該取得した第1の鍵により復号して第2の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第4の暗号化データを該取得した第1の鍵により復号して期待値を取得する暗号処理部と、前記インタフェース部により前記データ提供装置から受信した適用データの測定値を該取得された第2の鍵を使用して計算し、該取得された期待値に基づいて該測定値を検証する測定部と、を備え、該測定値の検証結果を前記インタフェース部により前記データ提供装置に送信する、車載コンピュータである。   According to one aspect of the present invention, in an in-vehicle computer mounted on a vehicle, an interface unit that transmits / receives data to / from an external device of the in-vehicle computer, and the first encrypted data received from the data providing device by the interface unit The in-vehicle computer decrypts with the initial key stored in advance to obtain the first key, and the interface unit decrypts the second encrypted data received from the data providing device with the obtained first key. An encryption processing unit for obtaining a second key, decrypting the fourth encrypted data received from the data providing apparatus by the interface unit using the obtained first key, and obtaining an expected value; and the interface The measured value of the applied data received from the data providing device by the unit using the acquired second key, and the acquired period And a measuring unit for verifying the measured value based on the value, and transmits the verification result of the measured value to the data providing device by said interface unit, an in-vehicle computer.

本発明の一態様は、データ提供装置と、車両に搭載される車載コンピュータとを備える管理システムの管理方法であって、前記データ提供装置が、前記車載コンピュータに格納される第1の鍵及び第2の鍵を生成する鍵生成ステップと、前記データ提供装置が、前記第2の鍵を使用して、前記車載コンピュータに適用される適用データの期待値を計算する期待値計算ステップと、前記データ提供装置が、前記車載コンピュータが予め格納している初期鍵により前記第1の鍵を暗号化して第1の暗号化データを生成し、前記第1の鍵により前記第2の鍵を暗号化して第2の暗号化データを生成し、前記第1の鍵により前記期待値を暗号化して第4の暗号化データを生成する暗号処理ステップと、前記データ提供装置が、前記車両とデータを送受する車両インタフェースにより、前記適用データ、前記第1の暗号化データ、前記第2の暗号化データ及び前記第4の暗号化データを前記車両に送信するステップと、前記車載コンピュータが、自車載コンピュータの外部の装置とデータを送受するインタフェース部により前記データ提供装置から受信した第1の暗号化データを自車載コンピュータが予め格納している初期鍵により復号して第1の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第2の暗号化データを該取得した第1の鍵により復号して第2の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第4の暗号化データを該取得した第1の鍵により復号して期待値を取得する暗号処理ステップと、前記車載コンピュータが、前記インタフェース部により前記データ提供装置から受信した適用データの測定値を該取得された第2の鍵を使用して計算し、該取得された期待値に基づいて該測定値を検証する測定ステップと、前記車載コンピュータが、該測定値の検証結果を前記インタフェース部により前記データ提供装置に送信するステップと、前記データ提供装置が、前記適用データの測定値の検証結果を前記車両インタフェースにより前記車両から受信するステップと、を含む管理方法である。   One aspect of the present invention is a management method of a management system including a data providing device and an in-vehicle computer mounted on a vehicle, wherein the data providing device includes a first key and a first key stored in the in-vehicle computer. A key generation step of generating a key of 2, an expected value calculation step in which the data providing device calculates an expected value of application data applied to the in-vehicle computer using the second key, and the data The providing device generates the first encrypted data by encrypting the first key with the initial key stored in advance in the in-vehicle computer, and encrypts the second key with the first key. An encryption processing step of generating second encrypted data, encrypting the expected value with the first key to generate fourth encrypted data, and the data providing device sends and receives data to and from the vehicle. A step of transmitting the application data, the first encrypted data, the second encrypted data, and the fourth encrypted data to the vehicle by a vehicle interface, and the in-vehicle computer comprising: The first encryption data received from the data providing device is decrypted with the initial key stored in advance in the in-vehicle computer by the interface unit that transmits / receives data to / from an external device to obtain the first key, and the interface The second encrypted data received from the data providing device by the unit is decrypted with the obtained first key to obtain a second key, and the fourth encryption received from the data providing device by the interface unit A cryptographic processing step of decrypting the encrypted data with the acquired first key to acquire an expected value; and A measurement step of calculating a measurement value of application data received from the data providing device by the interface unit using the acquired second key, and verifying the measurement value based on the acquired expected value; The in-vehicle computer transmits the measurement result verification result to the data providing device by the interface unit, and the data providing device receives the measurement value verification result of the application data from the vehicle by the vehicle interface. And a step of managing.

本発明の一態様は、車両とデータを送受する車両インタフェースを備えるデータ提供装置のコンピュータに、前記車載コンピュータに格納される第1の鍵及び第2の鍵を生成する鍵生成機能と、前記第2の鍵を使用して、前記車載コンピュータに適用される適用データの期待値を計算する期待値計算機能と、前記車載コンピュータが予め格納している初期鍵により前記第1の鍵を暗号化して第1の暗号化データを生成し、前記第1の鍵により前記第2の鍵を暗号化して第2の暗号化データを生成し、前記第1の鍵により前記期待値を暗号化して第4の暗号化データを生成する暗号処理機能と、前記車両インタフェースにより、前記適用データ、前記第1の暗号化データ、前記第2の暗号化データ及び前記第4の暗号化データを前記車両に送信する送信機能と、前記車両インタフェースにより、前記適用データの測定値の検証結果を前記車両から受信する受信機能と、を実現させるためのコンピュータプログラムである。   According to one aspect of the present invention, in a computer of a data providing apparatus including a vehicle interface for transmitting and receiving data to and from a vehicle, a key generation function for generating a first key and a second key stored in the in-vehicle computer, The first key is encrypted with an expected value calculation function for calculating an expected value of application data applied to the in-vehicle computer using an key 2 and an initial key stored in advance in the in-vehicle computer. Generating first encrypted data, encrypting the second key with the first key to generate second encrypted data, encrypting the expected value with the first key, and The application data, the first encrypted data, the second encrypted data, and the fourth encrypted data are transmitted to the vehicle by the encryption processing function for generating the encrypted data of the vehicle and the vehicle interface. A transmission function that, by the vehicle interface is a computer program for implementing the, a receiving function for receiving a verification result of the measurement value of the applied data from the vehicle.

本発明の一態様は、車両に搭載される車載コンピュータに、自車載コンピュータの外部の装置とデータを送受するインタフェース部によりデータ提供装置から受信した第1の暗号化データを自車載コンピュータが予め格納している初期鍵により復号して第1の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第2の暗号化データを該取得した第1の鍵により復号して第2の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第4の暗号化データを該取得した第1の鍵により復号して期待値を取得する暗号処理機能と、前記インタフェース部により前記データ提供装置から受信した適用データの測定値を該取得された第2の鍵を使用して計算し、該取得された期待値に基づいて該測定値を検証する測定機能と、該測定値の検証結果を前記インタフェース部により前記データ提供装置に送信する送信機能と、を実現させるためのコンピュータプログラムである。   According to one aspect of the present invention, the in-vehicle computer stores in advance the first encrypted data received from the data providing device by the interface unit that transmits / receives data to / from an external device of the in-vehicle computer. The first key is obtained by decrypting with the initial key, and the second encrypted data received from the data providing device by the interface unit is decrypted with the obtained first key. And obtaining the expected value by decrypting the fourth encrypted data received from the data providing device by the interface unit with the obtained first key, and providing the data by the interface unit. Calculate the measured value of the application data received from the device using the acquired second key and verify the measured value based on the acquired expected value A measurement function that is a computer program for realizing a transmitting function of transmitting the data providing device by said interface unit the verification result of the measured value.

本発明によれば、自動車等の車両に搭載されるECU等の車載コンピュータの信頼性を向上させることができるという効果が得られる。   According to the present invention, it is possible to improve the reliability of an in-vehicle computer such as an ECU mounted on a vehicle such as an automobile.

一実施形態に係る管理システム及び自動車1001の構成例を示す図である。1 is a diagram illustrating a configuration example of a management system and an automobile 1001 according to an embodiment. 一実施形態に係る鍵生成装置1300の構成例を示す図である。It is a figure which shows the structural example of the key generation apparatus 1300 which concerns on one Embodiment. 一実施形態に係る第1のECU1010の構成例を示す図である。It is a figure which shows the structural example of 1st ECU1010 which concerns on one Embodiment. 一実施形態に係る第2のECU1020の構成例を示す図である。It is a figure which shows the structural example of 2nd ECU1020 which concerns on one Embodiment. 一実施形態に係る管理方法の例1のシーケンス図である。It is a sequence diagram of Example 1 of the management method according to an embodiment. 一実施形態に係る管理方法の例2のシーケンス図である。It is a sequence diagram of example 2 of the management method concerning one embodiment. 一実施形態に係る管理方法の例3のシーケンス図である。It is a sequence diagram of Example 3 of the management method according to an embodiment. 一実施形態に係る管理方法の例4のシーケンス図である。It is a sequence diagram of Example 4 of the management method according to an embodiment. 一実施形態に係る管理方法の例5のシーケンス図である。It is a sequence diagram of Example 5 of the management method according to an embodiment. 一実施形態に係る管理方法の例6のシーケンス図である。It is a sequence diagram of Example 6 of the management method according to an embodiment. 一実施形態に係る管理システム及び自動車1001の他の構成例を示す図である。It is a figure which shows the management system which concerns on one Embodiment, and the other structural example of the motor vehicle. 一実施形態に係る管理システムの他の構成例を示す図である。It is a figure which shows the other structural example of the management system which concerns on one Embodiment. 一実施形態に係るサーバ装置2000の構成例を示す図である。It is a figure which shows the structural example of the server apparatus 2000 which concerns on one Embodiment. 一実施形態に係るECUコードの提供手順の例を示すシーケンスチャートである。It is a sequence chart which shows the example of the provision procedure of ECU code which concerns on one Embodiment.

以下、図面を参照し、本発明の実施形態について説明する。なお、以下に示す実施形態では、車両として自動車を例に挙げて説明する。   Hereinafter, embodiments of the present invention will be described with reference to the drawings. In the following embodiment, a vehicle will be described as an example of a vehicle.

図1は、本実施形態に係る管理システム及び自動車1001の構成例を示す図である。本実施形態では、車載コンピュータの一例として、自動車1001に搭載されるECU(電子制御装置)を挙げて説明する。   FIG. 1 is a diagram illustrating a configuration example of a management system and an automobile 1001 according to the present embodiment. In the present embodiment, an ECU (electronic control device) mounted on the automobile 1001 will be described as an example of the in-vehicle computer.

図1において、自動車1001は、第1のECU1010と複数の第2のECU1020とを備える。第1のECU1010及び第2のECU1020は、自動車1001に備わる車載コンピュータである。第1のECU1010は、自動車1001に搭載されたECUのうち、ゲートウェイ機能を有するECUである。第2のECU1020は、自動車1001に搭載されたECUのうち、エンジン制御等の機能を有するECUである。第2のECU1020として、例えば、エンジン制御機能を有するECU、ハンドル制御機能を有するECU、ブレーキ制御機能を有するECUなどがある。   In FIG. 1, an automobile 1001 includes a first ECU 1010 and a plurality of second ECUs 1020. The first ECU 1010 and the second ECU 1020 are in-vehicle computers provided in the automobile 1001. First ECU 1010 is an ECU having a gateway function among ECUs mounted on automobile 1001. The second ECU 1020 is an ECU having functions such as engine control among ECUs mounted on the automobile 1001. Examples of the second ECU 1020 include an ECU having an engine control function, an ECU having a handle control function, and an ECU having a brake control function.

第1のECU1010と複数の第2のECU1020は、自動車1001に備わるCAN(Controller Area Network)1030に接続される。CAN1030は通信ネットワークである。CANは車両に搭載される通信ネットワークの一つとして知られている。   The first ECU 1010 and the plurality of second ECUs 1020 are connected to a CAN (Controller Area Network) 1030 provided in the automobile 1001. CAN 1030 is a communication network. CAN is known as one of communication networks mounted on vehicles.

第1のECU1010は、CAN1030を介して、各第2のECU1020との間でデータを交換する。第2のECU1020は、CAN1030を介して、他の第2のECU1020との間でデータを交換する。   First ECU 1010 exchanges data with each second ECU 1020 via CAN 1030. Second ECU 1020 exchanges data with other second ECU 1020 via CAN 1030.

なお、車両に搭載される通信ネットワークとして、CAN以外の通信ネットワークを自動車1001に備え、CAN以外の通信ネットワークを介して、第1のECU1010と第2のECU1020との間のデータの交換、及び、第2のECU1020同士の間のデータの交換が行われてもよい。例えば、LIN(Local Interconnect Network)を自動車1001に備えてもよい。また、CANとLINとを自動車1001に備えてもよい。また、自動車1001において、LINに接続する第2のECU1020を備えてもよい。また、第1のECU1010は、CANとLINとに接続されてもよい。また、第1のECU1010は、CANを介して該CANに接続される第2のECU1020との間でデータを交換し、また、LINを介して該LINに接続される第2のECU1020との間でデータを交換してもよい。また、第2のECU1020同士が、LINを介してデータを交換してもよい。   In addition, as a communication network mounted on the vehicle, a communication network other than CAN is provided in the automobile 1001, and exchange of data between the first ECU 1010 and the second ECU 1020 via the communication network other than CAN, and Data exchange between the second ECUs 1020 may be performed. For example, the automobile 1001 may include a LIN (Local Interconnect Network). In addition, the automobile 1001 may include CAN and LIN. In addition, the automobile 1001 may include a second ECU 1020 connected to the LIN. The first ECU 1010 may be connected to CAN and LIN. Further, the first ECU 1010 exchanges data with the second ECU 1020 connected to the CAN via the CAN, and also exchanges data with the second ECU 1020 connected to the LIN via the LIN. You may exchange data with. Further, the second ECUs 1020 may exchange data via the LIN.

自動車1001は診断ポート1060を備える。診断ポート1060として、例えばOBD(On-board Diagnostics)ポートを使用してもよい。診断ポート1060には、自動車1001の外部の装置を接続可能である。診断ポート1060に接続可能な自動車1001の外部の装置として、例えば、診断端末や図1に示される鍵生成装置1300などがある。診断ポート1060は第1のECU1010に接続される。第1のECU1010と、診断ポート1060に接続された装置、例えば鍵生成装置1300とは、診断ポート1060を介して、データを交換する。   The automobile 1001 includes a diagnostic port 1060. As the diagnostic port 1060, for example, an OBD (On-board Diagnostics) port may be used. A device outside the automobile 1001 can be connected to the diagnostic port 1060. Examples of devices external to the automobile 1001 that can be connected to the diagnostic port 1060 include a diagnostic terminal and a key generation device 1300 shown in FIG. Diagnostic port 1060 is connected to first ECU 1010. The first ECU 1010 and a device connected to the diagnostic port 1060, for example, the key generation device 1300 exchange data via the diagnostic port 1060.

自動車1001はインフォテイメント(Infotainment)機器1040を備える。インフォテイメント機器1040として、例えば、ナビゲーション機能、位置情報サービス機能、音楽や動画などのマルチメディア再生機能、音声通信機能、データ通信機能、インターネット接続機能などを有するものが挙げられる。インフォテイメント機器1040は第1のECU1010に接続される。第1のECU1010は、インフォテイメント機器1040から入力された情報を第2のECU1020へ送信する。   The automobile 1001 includes an infotainment device 1040. Examples of the infotainment device 1040 include a navigation function, a location information service function, a multimedia playback function such as music and video, a voice communication function, a data communication function, and an Internet connection function. The infotainment device 1040 is connected to the first ECU 1010. The first ECU 1010 transmits information input from the infotainment device 1040 to the second ECU 1020.

自動車1001は、TCU(Tele Communication Unit)1050を備える。TCU1050は通信装置である。TCU1050は通信モジュール1051を備える。通信モジュール1051は、無線通信ネットワークを利用して無線通信を行う。通信モジュール1051は、SIM(Subscriber Identity Module)1052を備える。SIM1052は、無線通信ネットワークを利用するための情報が書き込まれたSIMである。通信モジュール1051は、SIM1052を使用することにより該無線通信ネットワークに接続して無線通信を行うことができる。なお、SIM1052として、eSIM(Embedded Subscriber Identity Module)を使用してもよい。   The automobile 1001 includes a TCU (Tele Communication Unit) 1050. The TCU 1050 is a communication device. The TCU 1050 includes a communication module 1051. The communication module 1051 performs wireless communication using a wireless communication network. The communication module 1051 includes a SIM (Subscriber Identity Module) 1052. The SIM 1052 is a SIM in which information for using the wireless communication network is written. The communication module 1051 can use the SIM 1052 to connect to the wireless communication network and perform wireless communication. Note that an eSIM (Embedded Subscriber Identity Module) may be used as the SIM 1052.

TCU1050は第1のECU1010に接続される。第1のECU1010は、TCU1050の通信モジュール1051とデータを交換する。   The TCU 1050 is connected to the first ECU 1010. The first ECU 1010 exchanges data with the communication module 1051 of the TCU 1050.

なお、図1の構成では第1のECU1010とTCU1050を直接接続することにより第1のECU1010と通信モジュール1051の間でデータを交換するが、これに限定されない。例えば、TCU1050をインフォテイメント機器1040に接続し、第1のECU1010が、インフォテイメント機器1040を介して、TCU1050の通信モジュール1051とデータを交換してもよい。又は、TCU1050を診断ポート1060に接続し、第1のECU1010が、診断ポート1060を介して、該診断ポート1060に接続されたTCU1050の通信モジュール1051とデータを交換してもよい。又は、第1のECU1010が、SIM1052を含む通信モジュール1051を備えてもよい。第1のECU1010がSIM1052を含む通信モジュール1051を備える場合には、自動車1001はTCU1050を備えなくてもよい。   In the configuration of FIG. 1, data is exchanged between the first ECU 1010 and the communication module 1051 by directly connecting the first ECU 1010 and the TCU 1050, but the present invention is not limited to this. For example, the TCU 1050 may be connected to the infotainment device 1040, and the first ECU 1010 may exchange data with the communication module 1051 of the TCU 1050 via the infotainment device 1040. Alternatively, the TCU 1050 may be connected to the diagnostic port 1060, and the first ECU 1010 may exchange data with the communication module 1051 of the TCU 1050 connected to the diagnostic port 1060 via the diagnostic port 1060. Alternatively, the first ECU 1010 may include a communication module 1051 including a SIM 1052. When the first ECU 1010 includes the communication module 1051 including the SIM 1052, the automobile 1001 may not include the TCU 1050.

第1のECU1010は、メイン演算器1011とHSM(Hardware Security Module)1012を備える。メイン演算器1011は、第1のECU1010の機能を実現させるためのコンピュータプログラムを実行する。HSM1012は暗号処理機能等を有する。HSM1012は耐タンパー性(Tamper Resistant)を有する。HSM1012はセキュアエレメント(Secure Element:SE)の例である。HSM1012は、鍵等のデータを記憶する記憶部1013を備える。メイン演算器1011はHSM1012を使用する。   The first ECU 1010 includes a main computing unit 1011 and an HSM (Hardware Security Module) 1012. The main arithmetic unit 1011 executes a computer program for realizing the function of the first ECU 1010. The HSM 1012 has a cryptographic processing function and the like. HSM 1012 has tamper resistance. The HSM 1012 is an example of a secure element (Secure Element: SE). The HSM 1012 includes a storage unit 1013 that stores data such as keys. The main arithmetic unit 1011 uses an HSM 1012.

第2のECU1020は、メイン演算器1021とSHE(Secure Hardware Extension)1022を備える。メイン演算器1021は、第2のECU1020の機能を実現させるためのコンピュータプログラムを実行する。SHE1022は暗号処理機能等を有する。SHE1022は耐タンパー性を有する。SHE1022はセキュアエレメントの例である。SHE1022は、鍵等のデータを記憶する記憶部1023を備える。メイン演算器1021はSHE1022を使用する。   The second ECU 1020 includes a main computing unit 1021 and a SHE (Secure Hardware Extension) 1022. The main computing unit 1021 executes a computer program for realizing the function of the second ECU 1020. The SHE 1022 has a cryptographic processing function and the like. SHE1022 has tamper resistance. SHE1022 is an example of a secure element. The SHE 1022 includes a storage unit 1023 that stores data such as keys. The main computing unit 1021 uses SHE1022.

自動車1001に備わる車載コンピュータシステム1002は、第1のECU1010と複数の第2のECU1020とがCAN1030に接続されて構成される。第1のECU1010は、ゲートウェイ機能を有し、車載コンピュータシステム1002の内部と外部の間の通信を監視する。本実施形態において、車載コンピュータシステム1002は、自動車1001の車載制御システムとして機能する。なお、第1のECU1010がゲートウェイ機能を有さないように構成してもよい。   An in-vehicle computer system 1002 provided in the automobile 1001 is configured by connecting a first ECU 1010 and a plurality of second ECUs 1020 to a CAN 1030. The first ECU 1010 has a gateway function and monitors communication between the inside and the outside of the in-vehicle computer system 1002. In the present embodiment, the in-vehicle computer system 1002 functions as an in-vehicle control system for the automobile 1001. The first ECU 1010 may be configured not to have a gateway function.

以下の説明において、第1のECU1010と第2のECU1020とを特に区別しないときは単にECUと称する。   In the following description, when the first ECU 1010 and the second ECU 1020 are not particularly distinguished, they are simply referred to as an ECU.

図2は、鍵生成装置1300の構成例を示す図である。図2において、鍵生成装置1300は、車両インタフェース11と記憶部12と期待値計算部13と検証部14と鍵生成部15と暗号処理部16とを備える。   FIG. 2 is a diagram illustrating a configuration example of the key generation device 1300. In FIG. 2, the key generation device 1300 includes a vehicle interface 11, a storage unit 12, an expected value calculation unit 13, a verification unit 14, a key generation unit 15, and a cryptographic processing unit 16.

車両インタフェース11は、自動車1001とデータを送受するインタフェースである。本実施形態では、車両インタフェース11は、診断ポート1060に接続し、診断ポート1060を介してデータを送受する。なお、車両インタフェース11として、診断ポート1060のインタフェース以外のインタフェースを備えてもよい。例えば、車両インタフェース11として、通信モジュールを備え、自動車1001の通信モジュール1051と無線通信を行ってもよい。また、例えば、車両インタフェース11として、CANインタフェースを備え、自動車1001のCAN1030に接続し、CAN1030を介してデータを送受してもよい。   The vehicle interface 11 is an interface that transmits and receives data to and from the automobile 1001. In the present embodiment, the vehicle interface 11 is connected to the diagnostic port 1060 and transmits / receives data via the diagnostic port 1060. The vehicle interface 11 may include an interface other than the diagnostic port 1060 interface. For example, the vehicle interface 11 may include a communication module and perform wireless communication with the communication module 1051 of the automobile 1001. Further, for example, the vehicle interface 11 may be provided with a CAN interface, connected to the CAN 1030 of the automobile 1001, and data may be transmitted / received via the CAN 1030.

記憶部12は、鍵等のデータを記憶する。期待値計算部13は、ECUが予め格納しているデータの期待値を計算する。ECUが予め格納しているデータとして、例えば、ECUコード(ECU code)が挙げられる。ECUコードは、ECUに適用されるデータの例である。ECUコードは、ECUに予めインストールされる初期プログラム等のコンピュータプログラムであってもよく、又は、ECUに予め設定される初期パラメータ設定値などの設定データであってもよい。   The storage unit 12 stores data such as keys. The expected value calculation unit 13 calculates an expected value of data stored in advance by the ECU. An example of data stored in advance by the ECU is an ECU code. The ECU code is an example of data applied to the ECU. The ECU code may be a computer program such as an initial program installed in advance in the ECU, or may be setting data such as an initial parameter setting value preset in the ECU.

検証部14は、ECUの測定値の検証に係る処理を行う。例えば、検証部14は、期待値計算部13が計算した期待値に基づいて、ECUの測定値を検証する。鍵生成部15は、ECUの鍵を生成する。暗号処理部16は、データの暗号化及び暗号化データの復号を行う。   The verification unit 14 performs processing related to verification of measurement values of the ECU. For example, the verification unit 14 verifies the measurement value of the ECU based on the expected value calculated by the expected value calculation unit 13. The key generation unit 15 generates a key for the ECU. The encryption processing unit 16 encrypts data and decrypts encrypted data.

鍵生成装置1300の機能は、該鍵生成装置1300が備えるCPU(Central Processing Unit:中央演算処理装置)がコンピュータプログラムを実行することにより実現される。なお、鍵生成装置1300として、汎用のコンピュータ装置を使用して構成してもよく、又は、専用のハードウェア装置として構成してもよい。   The function of the key generation device 1300 is realized when a CPU (Central Processing Unit) included in the key generation device 1300 executes a computer program. The key generation device 1300 may be configured using a general-purpose computer device or may be configured as a dedicated hardware device.

図3は、第1のECU1010の構成例を示す図である。図3において、第1のECU1010は、メイン演算器1011とHSM1012とインタフェース部20とを備える。メイン演算器1011は、制御部21と記憶部22とを備える。HSM1012は、記憶部1013と測定値計算部31と暗号処理部32と測定部33と鍵生成部34とを備える。   FIG. 3 is a diagram illustrating a configuration example of the first ECU 1010. In FIG. 3, the first ECU 1010 includes a main computing unit 1011, an HSM 1012, and an interface unit 20. The main computing unit 1011 includes a control unit 21 and a storage unit 22. The HSM 1012 includes a storage unit 1013, a measurement value calculation unit 31, an encryption processing unit 32, a measurement unit 33, and a key generation unit 34.

インタフェース部20は、自第1のECU1010の外部の装置とデータを送受する。インタフェース部20は、CAN1030を介してデータを送受するインタフェースと、インフォテイメント機器1040とデータを送受するインタフェースと、TCU1050とデータを送受するインタフェースと、診断ポート1060を介してデータを送受するインタフェースとを備える。メイン演算器1011は、インタフェース部20を介して、第1のECU1010以外の他の装置とデータの送受を行う。   The interface unit 20 transmits / receives data to / from an external device of the first ECU 1010 itself. The interface unit 20 includes an interface for transmitting / receiving data via the CAN 1030, an interface for transmitting / receiving data to / from the infotainment device 1040, an interface for transmitting / receiving data to / from the TCU 1050, and an interface for transmitting / receiving data via the diagnostic port 1060. Prepare. The main computing unit 1011 transmits / receives data to / from devices other than the first ECU 1010 via the interface unit 20.

制御部21は、第1のECU1010の制御を行う。記憶部22は、データを記憶する。記憶部1013は、鍵等のデータを記憶する。測定値計算部31は、ECUコード等のデータの測定値を計算する。暗号処理部32は、データの暗号化及び暗号化データの復号を行う。測定部33は、ECUコード等のデータの測定値を計算し、該測定値を期待値に基づいて検証する。鍵生成部34は、自動車1001内部で使用される鍵(以下、車内鍵と称する)を生成する。   The control unit 21 controls the first ECU 1010. The storage unit 22 stores data. The storage unit 1013 stores data such as keys. The measurement value calculation unit 31 calculates a measurement value of data such as an ECU code. The encryption processing unit 32 encrypts data and decrypts encrypted data. The measurement unit 33 calculates a measured value of data such as an ECU code and verifies the measured value based on an expected value. The key generation unit 34 generates a key used in the automobile 1001 (hereinafter referred to as an in-vehicle key).

図4は、第2のECU1020の構成例を示す図である。図4において、第2のECU1020は、メイン演算器1021とSHE1022とインタフェース部40とを備える。メイン演算器1021は、制御部41と記憶部42とを備える。SHE1022は、記憶部1023と測定値計算部51と暗号処理部52と測定部53とを備える。   FIG. 4 is a diagram illustrating a configuration example of the second ECU 1020. In FIG. 4, the second ECU 1020 includes a main computing unit 1021, a SHE 1022, and an interface unit 40. The main computing unit 1021 includes a control unit 41 and a storage unit 42. The SHE 1022 includes a storage unit 1023, a measurement value calculation unit 51, an encryption processing unit 52, and a measurement unit 53.

インタフェース部40は、自第2のECU1020の外部の装置とデータを送受する。インタフェース部40は、CAN1030を介してデータを送受するインタフェースを備える。メイン演算器1021は、インタフェース部40を介して、自第2のECU1020以外の他の装置とデータの送受を行う。   The interface unit 40 transmits / receives data to / from a device external to the second ECU 1020 itself. The interface unit 40 includes an interface that transmits and receives data via the CAN 1030. The main computing unit 1021 transmits and receives data to and from devices other than the second ECU 1020 through the interface unit 40.

制御部41は、第2のECU1020の制御を行う。記憶部42は、データを記憶する。記憶部1023は、鍵等のデータを記憶する。測定値計算部51は、ECUコード等のデータの測定値を計算する。暗号処理部52は、データの暗号化及び暗号化データの復号を行う。測定部53は、ECUコード等のデータの測定値を計算し、該測定値を期待値に基づいて検証する。   The control unit 41 controls the second ECU 1020. The storage unit 42 stores data. The storage unit 1023 stores data such as keys. The measurement value calculation unit 51 calculates a measurement value of data such as an ECU code. The encryption processing unit 52 encrypts data and decrypts encrypted data. The measurement unit 53 calculates a measurement value of data such as an ECU code, and verifies the measurement value based on an expected value.

なお、本実施形態では、第1のECU1010にHSMを使用しているが、第1のECU1010においてHSMの代わりにSHEを使用してもよい。なお、SHEについては、例えば非特許文献3に記載されている。   In the present embodiment, the HSM is used for the first ECU 1010. However, the SHE may be used instead of the HSM in the first ECU 1010. In addition, about SHE, it describes in the nonpatent literature 3, for example.

[ECU識別子の構成例]
本実施形態に係るECU識別子の構成例1、構成例1を説明する。ECU識別子は、ECUを識別する情報である。
[Configuration example of ECU identifier]
Configuration example 1 and configuration example 1 of the ECU identifier according to this embodiment will be described. The ECU identifier is information for identifying the ECU.

<ECU識別子の構成例1>
ECU識別子の構成例1では、ECU識別子のビット長を64ビット以内にする。このECU識別子のビットの内訳の例を以下に示す。
・ECUベンダー識別子:16ビット
・ECU機種識別子:16ビット
・シリアル番号:32ビット
<Configuration Example 1 of ECU Identifier>
In the configuration example 1 of the ECU identifier, the bit length of the ECU identifier is set to 64 bits or less. An example of the breakdown of the ECU identifier bits is shown below.
-ECU vendor identifier: 16 bits-ECU model identifier: 16 bits-Serial number: 32 bits

<ECU識別子の構成例2>
ECU識別子の構成例2では、ECU識別子のビット長を128ビット以内にする。このECU識別子のビットの内訳の例1、例2、例3を以下に示す。
(例1)
・車両識別番号(VIN:Vehicle Identification Number):102ビット(17ケタの英数字、1文字は6ビット)
・CAN識別子:11ビット
CAN識別子の11ビットは、CANの標準フォーマットのデータフレーム中の11ビット長のIDフィールドに格納されるCAN識別子である。又は、CAN識別子の11ビットは、CANの拡張フォーマットのデータフレーム中の11ビット長のベースID(Base ID)フィールドに格納されるCAN識別子である。なお、車両識別番号(VIN)については、例えば非特許文献2に記載されている。
<Configuration Example 2 of ECU Identifier>
In the configuration example 2 of the ECU identifier, the bit length of the ECU identifier is set to 128 bits or less. Examples 1, 2, and 3 of the breakdown of the ECU identifier bits are shown below.
(Example 1)
-Vehicle Identification Number (VIN): 102 bits (17 digits of alphanumeric characters, 1 character is 6 bits)
CAN identifier: 11 bits The 11 bits of the CAN identifier is a CAN identifier stored in an ID field having an 11-bit length in a data frame in a CAN standard format. Alternatively, the 11 bits of the CAN identifier is a CAN identifier stored in a base ID field having an 11-bit length in a data frame in the CAN extended format. The vehicle identification number (VIN) is described in Non-Patent Document 2, for example.

(例2)
・車両識別番号(VIN)の製造業者識別コード(WMI:World Manufacturer Identifier)以外の残りの部分:84ビット(14ケタの英数字、1文字6ビット)
・CAN識別子:29ビット
CAN識別子の29ビットは、CANの拡張フォーマットのデータフレーム中の11ビット長のベースIDフィールドに格納されるCAN識別子部分「11ビット」と、18ビット長の拡張ID(Extend ID)フィールドに格納されるCAN識別子部分「18ビット」との合計である。
(Example 2)
-The remaining part of the vehicle identification number (VIN) other than the manufacturer identification code (WMI: World Manufacturer Identifier): 84 bits (14 alphanumeric characters, 6 characters)
CAN identifier: 29 bits The 29 bits of the CAN identifier are a CAN identifier portion “11 bits” stored in a base ID field of 11 bits length in a data frame of the CAN extension format, and an extension ID (Extend of 18 bits length). It is the sum of the CAN identifier part “18 bits” stored in the (ID) field.

(例3)
・SHEの識別子(UID):120ビット
この例3では、ECUに備わるSHEのUIDを当該ECUのECU識別子に使用する。
(Example 3)
-SHE identifier (UID): 120 bits In this example 3, the SHE UID provided in the ECU is used as the ECU identifier of the ECU.

車両識別番号(VIN)、CAN識別子及びSHEのUIDは、例えば自動車1001の製造工場において事前に取得される。   The vehicle identification number (VIN), the CAN identifier, and the SHE UID are acquired in advance, for example, at the manufacturing factory of the automobile 1001.

[管理方法の例]
次に本実施形態に係る管理方法の例を説明する。
[Example of management method]
Next, an example of a management method according to the present embodiment will be described.

<管理方法の例1>
図5は、本実施形態に係る管理方法の例1のシーケンス図である。図5を参照して本実施形態に係る管理方法の例1を説明する。鍵生成装置1300は、例えば、自動車1001の製造工場に設けられている。鍵生成装置1300の車両インタフェース11は、該製造工場で製造中の自動車1001の診断ポート1060に接続される。
<Example 1 of management method>
FIG. 5 is a sequence diagram of Example 1 of the management method according to the present embodiment. An example 1 of the management method according to the present embodiment will be described with reference to FIG. The key generation device 1300 is provided, for example, in a manufacturing factory for the automobile 1001. The vehicle interface 11 of the key generation device 1300 is connected to the diagnostic port 1060 of the automobile 1001 being manufactured at the manufacturing factory.

図5には、説明の便宜上、自動車1001に搭載される第2のECU(n)1020のうち、1個の第2のECU(1)1020のみを示している。但し、nは1からNまでの整数である。Nは、自動車1001に搭載されている第2のECU1020のうち、鍵配信対象の第2のECU1020の個数である。   FIG. 5 shows only one second ECU (1) 1020 out of the second ECU (n) 1020 mounted on the automobile 1001 for convenience of explanation. However, n is an integer from 1 to N. N is the number of second ECUs 1020 targeted for key distribution among the second ECUs 1020 mounted on the automobile 1001.

鍵生成装置1300は、マスタ鍵Master_Secretと、ECUのECUコードと、初期Root鍵Kriとを予め記憶部12に格納している。ECUのECUコードは、ECUの初期ECUコードを含む。   The key generation device 1300 stores a master key Master_Secret, an ECU code of the ECU, and an initial root key Kri in the storage unit 12 in advance. The ECU code of the ECU includes an initial ECU code of the ECU.

第1のECU1010のHSM1012は、初期Root鍵Kri及び初期署名鍵Kbiを予め記憶部1013に格納している。初期Root鍵Kri及び初期署名鍵Kbiは、例えば第1のECU1010の製造時に、HSM1012に書き込まれる。第2のECU1020のSHE1022は、初期Root鍵Kri及び初期署名鍵Kbiを予め記憶部1023に格納している。初期Root鍵Kri及び初期署名鍵Kbiは、例えば第2のECU1020の製造時に、SHE1022に書き込まれる。初期Root鍵Kri及び初期署名鍵Kbiは、新品のECUに格納される鍵である。   The HSM 1012 of the first ECU 1010 stores the initial root key Kri and the initial signature key Kbi in the storage unit 1013 in advance. The initial root key Kri and the initial signature key Kbi are written in the HSM 1012 when the first ECU 1010 is manufactured, for example. The SHE 1022 of the second ECU 1020 stores the initial root key Kri and the initial signature key Kbi in the storage unit 1023 in advance. The initial root key Kri and the initial signature key Kbi are written in the SHE 1022 when the second ECU 1020 is manufactured, for example. The initial root key Kri and the initial signature key Kbi are keys stored in a new ECU.

第1のECU1010のメイン演算器1011は、初期ECUコードEciを予め記憶部22に格納している。初期ECUコードEciは、例えば第1のECU1010の製造時に、メイン演算器1011に書き込まれる。初期ECUコードEciは、新品の第1のECU1010に格納されるECUコードである。第2のECU(n)1020のメイン演算器1021は、初期ECUコードEniを予め記憶部42に格納している。初期ECUコードEniは、例えば第2のECU(n)1020の製造時に、メイン演算器1021に書き込まれる。初期ECUコードEniは、新品の第2のECU(n)1020に格納されるECUコードである。   The main arithmetic unit 1011 of the first ECU 1010 stores the initial ECU code Eci in the storage unit 22 in advance. The initial ECU code Eci is written in the main computing unit 1011 when the first ECU 1010 is manufactured, for example. The initial ECU code Eci is an ECU code stored in the new first ECU 1010. The main arithmetic unit 1021 of the second ECU (n) 1020 stores the initial ECU code Eni in the storage unit 42 in advance. The initial ECU code Eni is written in the main computing unit 1021 when the second ECU (n) 1020 is manufactured, for example. The initial ECU code Eni is an ECU code stored in the new second ECU (n) 1020.

以下、鍵生成装置1300の車両インタフェース11と自動車1001の診断ポート1060とは接続されている。   Hereinafter, the vehicle interface 11 of the key generation device 1300 and the diagnosis port 1060 of the automobile 1001 are connected.

(ステップS1)鍵生成装置1300において、鍵生成部15は、自動車1001に搭載されているECUのRoot鍵と署名鍵とを生成する。本実施形態では、鍵生成部15は、第1のECU1010のRoot鍵Krc及び署名鍵Kbcと、N個の第2のECU(n)1020の各々のRoot鍵Krn及び署名鍵Kbnとを生成する。記憶部12は、第1のECU1010のRoot鍵Krc及び署名鍵Kbcと、N個の第2のECU(n)1020の各々のRoot鍵Krn及び署名鍵Kbnとを格納する。Root鍵Krc及びKrnは、第1の鍵に対応する。署名鍵Kbc及びKbnは、第2の鍵に対応する。 (Step S <b> 1) In the key generation device 1300, the key generation unit 15 generates a root key and a signature key for the ECU mounted on the automobile 1001. In the present embodiment, the key generation unit 15 generates the root key Krc and signature key Kbc of the first ECU 1010, and the root key Krn and signature key Kbn of each of the N second ECUs (n) 1020. . The storage unit 12 stores the root key Krc and signature key Kbc of the first ECU 1010, and the root key Krn and signature key Kbn of each of the N second ECUs (n) 1020. Root keys Krc and Krn correspond to the first key. The signature keys Kbc and Kbn correspond to the second key.

鍵生成部15は、鍵生成装置1300の記憶部12に格納されているマスタ鍵Master_Secretと、第1のECU1010のECU識別子ECU_IDとから第1ダイジェスト値を算出する。第1ダイジェスト値は、第1のECU1010のRoot鍵Krcである。鍵生成部15は、鍵生成装置1300の記憶部12に格納されているマスタ鍵Master_Secretと、第1のECU1010のECU識別子ECU_IDとから第2ダイジェスト値を算出する。第2ダイジェスト値は、第1のECU1010の署名鍵Kbcである。第1ダイジェスト値の算出方法と、第2ダイジェスト値を算出方法とは異なる。よって、第1ダイジェスト値(第1のECU1010のRoot鍵Krc)と第2ダイジェスト値(第1のECU1010の署名鍵Kbc)とは異なる。   The key generation unit 15 calculates a first digest value from the master key Master_Secret stored in the storage unit 12 of the key generation device 1300 and the ECU identifier ECU_ID of the first ECU 1010. The first digest value is the root key Krc of the first ECU 1010. The key generation unit 15 calculates a second digest value from the master key Master_Secret stored in the storage unit 12 of the key generation device 1300 and the ECU identifier ECU_ID of the first ECU 1010. The second digest value is the signature key Kbc of the first ECU 1010. The calculation method of the first digest value is different from the calculation method of the second digest value. Therefore, the first digest value (Root key Krc of the first ECU 1010) is different from the second digest value (signature key Kbc of the first ECU 1010).

鍵生成部15は、鍵生成装置1300の記憶部12に格納されているマスタ鍵Master_Secretと、第2のECU(n)1020のECU識別子ECU_IDとから第1ダイジェスト値を算出する。第1ダイジェスト値は、第2のECU(n)1020のRoot鍵Krnである。鍵生成部15は、鍵生成装置1300の記憶部12に格納されているマスタ鍵Master_Secretと、第2のECU(n)1020のECU識別子ECU_IDとから第2ダイジェスト値を算出する。第2ダイジェスト値は、第2のECU(n)1020の署名鍵Kbnである。第1ダイジェスト値の算出方法と、第2ダイジェスト値の算出方法とは異なる。よって、第1ダイジェスト値(第2のECU(n)1020のRoot鍵Krn)と第2ダイジェスト値(第2のECU(n)1020の署名鍵Kbn)とは異なる。   The key generation unit 15 calculates the first digest value from the master key Master_Secret stored in the storage unit 12 of the key generation device 1300 and the ECU identifier ECU_ID of the second ECU (n) 1020. The first digest value is the root key Krn of the second ECU (n) 1020. The key generation unit 15 calculates a second digest value from the master key Master_Secret stored in the storage unit 12 of the key generation device 1300 and the ECU identifier ECU_ID of the second ECU (n) 1020. The second digest value is the signature key Kbn of the second ECU (n) 1020. The calculation method of the first digest value is different from the calculation method of the second digest value. Therefore, the first digest value (root key Krn of the second ECU (n) 1020) and the second digest value (signature key Kbn of the second ECU (n) 1020) are different.

自動車1001のECUのECU識別子ECU_IDは、上述のECU識別子の構成例のいずれかによって生成される。鍵生成装置1300が自動車1001のECUのECU識別子ECU_IDを生成してもよく、又は、自動車1001のECUのECU識別子ECU_IDが鍵生成装置1300に入力されてもよい。   The ECU identifier ECU_ID of the ECU of the automobile 1001 is generated by any one of the above-described configuration examples of the ECU identifier. The key generation device 1300 may generate the ECU identifier ECU_ID of the ECU of the automobile 1001, or the ECU identifier ECU_ID of the ECU of the automobile 1001 may be input to the key generation device 1300.

ダイジェスト値として、例えば、ハッシュ(hash)関数により算出される値や排他的論理和演算により算出される値などが挙げられる。   Examples of the digest value include a value calculated by a hash function and a value calculated by an exclusive OR operation.

本実施形態に係る鍵(共通鍵)の生成方法の一例を次式に示す。
共通鍵=ダイジェスト(Master_Secret、ECU_ID、Nk)
但し、Nkは変数である。ダイジェスト(Master_Secret、ECU_ID、Nk)は、マスタ鍵Master_SecretとECU識別子ECU_IDと変数Nkとから生成されるダイジェスト値である。例えば、共通鍵は、マスタ鍵Master_SecretとECU識別子ECU_IDと変数Nkとを入力値に使用して算出されるハッシュ関数値である。変数Nkの値が異なれば、ダイジェスト値の算出方法は異なる。変数Nkの値を変えることによって、同じマスタ鍵Master_SecretとECU識別子ECU_IDとから、異なる共通鍵を生成することができる。例えば、Root鍵用の変数Nkの値をNk_1とし、署名鍵用の変数Nkの値をNk_2とする。この場合、同じマスタ鍵Master_SecretとECU識別子ECU_IDとを使用して、
Root鍵=ダイジェスト(Master_Secret、ECU_ID、Nk_1)、
署名鍵=ダイジェスト(Master_Secret、ECU_ID、Nk_2)、
により、Root鍵と署名鍵とを異なる鍵として生成することができる。
An example of a key (common key) generation method according to this embodiment is shown in the following equation.
Common key = digest (Master_Secret, ECU_ID, Nk)
Nk is a variable. The digest (Master_Secret, ECU_ID, Nk) is a digest value generated from the master key Master_Secret, the ECU identifier ECU_ID, and the variable Nk. For example, the common key is a hash function value calculated using a master key Master_Secret, an ECU identifier ECU_ID, and a variable Nk as input values. If the value of the variable Nk is different, the digest value calculation method is different. By changing the value of the variable Nk, different common keys can be generated from the same master key Master_Secret and ECU identifier ECU_ID. For example, the value of the root key variable Nk is Nk_1, and the value of the signature key variable Nk is Nk_2. In this case, using the same master key Master_Secret and ECU identifier ECU_ID,
Root key = Digest (Master_Secret, ECU_ID, Nk_1),
Signature key = Digest (Master_Secret, ECU_ID, Nk_2),
Thus, the Root key and the signature key can be generated as different keys.

本実施形態に係る鍵(共通鍵)の生成方法の他の例として、ECUのRoot鍵をハッシュ関数により算出される値とし、署名鍵を排他的論理和演算により算出される値としてもよい。又は、その逆、つまり、ECUのRoot鍵を排他的論理和演算により算出される値とし、署名鍵をハッシュ関数により算出される値としてもよい。   As another example of the key (common key) generation method according to this embodiment, the root key of the ECU may be a value calculated by a hash function, and the signature key may be a value calculated by an exclusive OR operation. Or, the reverse, that is, the Root key of the ECU may be a value calculated by an exclusive OR operation, and the signature key may be a value calculated by a hash function.

(ステップS2)鍵生成装置1300の暗号処理部16は、初期Root鍵Kriにより第1のECU1010のRoot鍵Krcを暗号化して第1の暗号化データKri(Krc)を生成する。鍵生成装置1300は、車両インタフェース11により、第1の暗号化データKri(Krc)を自動車1001の第1のECU1010に送信する。自動車1001の第1のECU1010は、インタフェース部20により、鍵生成装置1300から診断ポート1060を介して、第1の暗号化データKri(Krc)を受信する。 (Step S2) The encryption processing unit 16 of the key generation device 1300 encrypts the Root key Krc of the first ECU 1010 with the initial Root key Kri to generate the first encrypted data Kri (Krc). The key generation device 1300 transmits the first encrypted data Kri (Krc) to the first ECU 1010 of the automobile 1001 through the vehicle interface 11. The first ECU 1010 of the automobile 1001 receives the first encrypted data Kri (Krc) from the key generation device 1300 via the diagnostic port 1060 by the interface unit 20.

(ステップS3)第1のECU1010の制御部21は、第1の暗号化データKri(Krc)をHSM1012に渡す。HSM1012の暗号処理部32は、記憶部1013に格納している初期Root鍵Kriにより第1の暗号化データKri(Krc)を復号して、Root鍵Krcを取得する。HSM1012は、該取得したRoot鍵Krcを記憶部1013に格納する。HSM1012は、記憶部1013において、該取得したRoot鍵Krcを初期Root鍵Kriに代えて格納してもよい。 (Step S3) The control unit 21 of the first ECU 1010 passes the first encrypted data Kri (Krc) to the HSM 1012. The encryption processing unit 32 of the HSM 1012 decrypts the first encrypted data Kri (Krc) using the initial root key Kri stored in the storage unit 1013, and acquires the root key Krc. The HSM 1012 stores the acquired root key Krc in the storage unit 1013. The HSM 1012 may store the acquired root key Krc in the storage unit 1013 instead of the initial root key Kri.

(ステップS4)鍵生成装置1300の暗号処理部16は、第1のECU1010のRoot鍵Krcにより第1のECU1010の署名鍵Kbcを暗号化して第2の暗号化データKrc(Kbc)を生成する。鍵生成装置1300は、車両インタフェース11により、第2の暗号化データKrc(Kbc)を自動車1001の第1のECU1010に送信する。自動車1001の第1のECU1010は、インタフェース部20により、鍵生成装置1300から診断ポート1060を介して、第2の暗号化データKrc(Kbc)を受信する。 (Step S4) The encryption processing unit 16 of the key generation device 1300 generates the second encrypted data Krc (Kbc) by encrypting the signature key Kbc of the first ECU 1010 with the Root key Krc of the first ECU 1010. The key generation device 1300 transmits the second encrypted data Krc (Kbc) to the first ECU 1010 of the automobile 1001 through the vehicle interface 11. The first ECU 1010 of the automobile 1001 receives the second encrypted data Krc (Kbc) from the key generation device 1300 via the diagnostic port 1060 by the interface unit 20.

(ステップS5)第1のECU1010の制御部21は、第2の暗号化データKrc(Kbc)をHSM1012に渡す。HSM1012の暗号処理部32は、記憶部1013に格納しているRoot鍵Krcにより第2の暗号化データKrc(Kbc)を復号して、署名鍵Kbcを取得する。HSM1012は、該取得した署名鍵Kbcを記憶部1013に格納する。HSM1012は、記憶部1013において、該取得した署名鍵Kbcを初期署名鍵Kbiに代えて格納してもよい。 (Step S5) The control unit 21 of the first ECU 1010 passes the second encrypted data Krc (Kbc) to the HSM 1012. The encryption processing unit 32 of the HSM 1012 acquires the signature key Kbc by decrypting the second encrypted data Krc (Kbc) with the Root key Krc stored in the storage unit 1013. The HSM 1012 stores the acquired signature key Kbc in the storage unit 1013. The HSM 1012 may store the acquired signature key Kbc in the storage unit 1013 instead of the initial signature key Kbi.

(ステップS6)第1のECU1010の制御部21は、記憶部22に格納している初期ECUコードEciをHSM1012に渡して、セキュアブート処理を実行させる。セキュアブート処理において、HSM1012の測定値計算部31は、記憶部1013に格納している署名鍵Kbcにより、初期ECUコードEciの測定値を計算する。本実施形態では、測定値の一例として、CMAC(Cipher-based Message Authentication Code)を使用する。よって、測定値計算部31は、記憶部1013に格納している署名鍵Kbcにより、初期ECUコードEciのCMACを計算する。この計算結果のCMACを測定値Ecn_aと称する。HSM1012は、測定値Ecn_aをセキュアブート処理で使用する期待値に設定する。該期待値「測定値Ecn_a」は記憶部1013に格納される。 (Step S6) The control unit 21 of the first ECU 1010 passes the initial ECU code Eci stored in the storage unit 22 to the HSM 1012 to execute the secure boot process. In the secure boot process, the measurement value calculation unit 31 of the HSM 1012 calculates the measurement value of the initial ECU code Eci using the signature key Kbc stored in the storage unit 1013. In the present embodiment, CMAC (Cipher-based Message Authentication Code) is used as an example of the measurement value. Therefore, the measurement value calculation unit 31 calculates the CMAC of the initial ECU code Eci using the signature key Kbc stored in the storage unit 1013. The CMAC resulting from this calculation is referred to as a measured value Ecn_a. The HSM 1012 sets the measurement value Ecn_a to an expected value used in the secure boot process. The expected value “measured value Ecn_a” is stored in the storage unit 1013.

(ステップS7)第1のECU1010のHSM1012の暗号処理部32は、記憶部1013に格納しているRoot鍵Krcにより測定値Ecn_aを暗号化して第3の暗号化データKrc(Ecn_a)を生成する。HSM1012は、第3の暗号化データKrc(Ecn_a)を制御部21に渡す。制御部21は、インタフェース部20により、第3の暗号化データKrc(Ecn_a)を、診断ポート1060を介して、鍵生成装置1300に送信する。鍵生成装置1300は、車両インタフェース11により、自動車1001の第1のECU1010から診断ポート1060を介して、第3の暗号化データKrc(Ecn_a)を受信する。 (Step S7) The encryption processing unit 32 of the HSM 1012 of the first ECU 1010 encrypts the measurement value Ecn_a with the Root key Krc stored in the storage unit 1013 to generate third encrypted data Krc (Ecn_a). The HSM 1012 passes the third encrypted data Krc (Ecn_a) to the control unit 21. The control unit 21 uses the interface unit 20 to transmit the third encrypted data Krc (Ecn_a) to the key generation device 1300 via the diagnostic port 1060. The key generation device 1300 receives the third encrypted data Krc (Ecn_a) from the first ECU 1010 of the automobile 1001 via the diagnosis port 1060 by the vehicle interface 11.

(ステップS8)鍵生成装置1300の暗号処理部16は、第1のECU1010のRoot鍵Krcにより第3の暗号化データKrc(Ecn_a)を復号して測定値Ecn_aを取得する。期待値計算部13は、第1のECU1010の署名鍵Kbcにより、第1のECU1010の初期ECUコードEciのCMACを計算する。この計算結果のCMACを期待値Ecn_bと称する。
なお、第1のECU1010は、測定値Ecn_aを暗号化しないでそのままのデータで鍵生成装置1300に送信してもよい。
(Step S8) The cryptographic processing unit 16 of the key generation device 1300 decrypts the third encrypted data Krc (Ecn_a) with the Root key Krc of the first ECU 1010 to obtain the measured value Ecn_a. The expected value calculation unit 13 calculates the CMAC of the initial ECU code Eci of the first ECU 1010 using the signature key Kbc of the first ECU 1010. This calculated CMAC is referred to as an expected value Ecn_b.
Note that the first ECU 1010 may transmit the measurement value Ecn_a to the key generation device 1300 as it is without encrypting it.

検証部14は、測定値Ecn_aと期待値Ecn_bとを比較し、両者が一致するか否かを判断する。この判断の結果、両者が一致する場合には測定値Ecn_aの検証が合格である。測定値Ecn_aの検証が合格である場合には、ステップS9に進む。一方、両者が一致しない場合には測定値Ecn_aの検証が不合格である。測定値Ecn_aの検証が不合格である場合には、図5の処理を終了する。また、測定値Ecn_aの検証が不合格である場合には、鍵生成装置1300は所定のエラー処理を実行してもよい。   The verification unit 14 compares the measured value Ecn_a and the expected value Ecn_b, and determines whether or not they match. As a result of the determination, if both coincide, the verification of the measured value Ecn_a is acceptable. If the verification of the measurement value Ecn_a is acceptable, the process proceeds to step S9. On the other hand, when the two do not match, the verification of the measurement value Ecn_a fails. If the verification of the measurement value Ecn_a fails, the process of FIG. If the verification of the measurement value Ecn_a fails, the key generation device 1300 may execute a predetermined error process.

(ステップS9)第1のECU1010のHSM1012の鍵生成部34は、車内鍵Kvを生成する。記憶部1013は、車内鍵Kvを格納する。 (Step S9) The key generation unit 34 of the HSM 1012 of the first ECU 1010 generates the in-vehicle key Kv. The storage unit 1013 stores the in-vehicle key Kv.

(ステップS10)鍵生成装置1300の暗号処理部16は、初期Root鍵Kriにより第2のECU(1)1020のRoot鍵Kr1を暗号化して第1の暗号化データKri(Kr1)を生成する。鍵生成装置1300は、車両インタフェース11により、第1の暗号化データKri(Kr1)を、自動車1001の第1のECU1010経由で第2のECU(1)1020に送信する。自動車1001の第1のECU1010は、インタフェース部20により、鍵生成装置1300から診断ポート1060を介して、第1の暗号化データKri(Kr1)を受信すると、該第1の暗号化データKri(Kr1)を、インタフェース部20により、CAN1030を介して第2のECU(1)1020に転送する。第2のECU(1)1020は、インタフェース部40により、第1のECU1010からCAN1030を介して、第1の暗号化データKri(Kr1)を受信する。 (Step S10) The encryption processing unit 16 of the key generation device 1300 encrypts the root key Kr1 of the second ECU (1) 1020 with the initial root key Kri to generate first encrypted data Kri (Kr1). The key generation device 1300 transmits the first encrypted data Kri (Kr1) by the vehicle interface 11 to the second ECU (1) 1020 via the first ECU 1010 of the automobile 1001. When the first ECU 1010 of the automobile 1001 receives the first encrypted data Kri (Kr1) from the key generation device 1300 via the diagnosis port 1060 by the interface unit 20, the first ECU 1010 receives the first encrypted data Kri (Kr1). ) Is transferred to the second ECU (1) 1020 via the CAN 1030 by the interface unit 20. The second ECU (1) 1020 receives the first encrypted data Kri (Kr1) from the first ECU 1010 via the CAN 1030 by the interface unit 40.

(ステップS11)第2のECU(1)1020の制御部41は、第1の暗号化データKri(Kr1)をSHE1022に渡す。SHE1022の暗号処理部52は、記憶部1023に格納している初期Root鍵Kriにより第1の暗号化データKri(Kr1)を復号して、Root鍵Kr1を取得する。SHE1022は、該取得したRoot鍵Kr1を記憶部1023に格納する。SHE1022は、記憶部1023において、該取得したRoot鍵Kr1を初期Root鍵Kriに代えて格納してもよい。 (Step S11) The control unit 41 of the second ECU (1) 1020 passes the first encrypted data Kri (Kr1) to the SHE1022. The encryption processing unit 52 of the SHE 1022 decrypts the first encrypted data Kri (Kr1) with the initial root key Kri stored in the storage unit 1023, and acquires the root key Kr1. The SHE 1022 stores the acquired root key Kr1 in the storage unit 1023. The SHE 1022 may store the acquired root key Kr1 in the storage unit 1023 in place of the initial root key Kri.

(ステップS12)鍵生成装置1300の暗号処理部16は、第2のECU(1)1020のRoot鍵Kr1により第2のECU(1)1020の署名鍵Kb1を暗号化して第2の暗号化データKr1(Kb1)を生成する。鍵生成装置1300は、車両インタフェース11により、第2の暗号化データKr1(Kb1)を、自動車1001の第1のECU1010経由で第2のECU(1)1020に送信する。自動車1001の第1のECU1010は、インタフェース部20により、鍵生成装置1300から診断ポート1060を介して、第2の暗号化データKr1(Kb1)を受信すると、該第2の暗号化データKr1(Kb1)を、インタフェース部20により、CAN1030を介して第2のECU(1)1020に転送する。第2のECU(1)1020は、インタフェース部40により、第1のECU1010からCAN1030を介して、第2の暗号化データKr1(Kb1)を受信する。 (Step S12) The encryption processing unit 16 of the key generation device 1300 encrypts the signature key Kb1 of the second ECU (1) 1020 with the Root key Kr1 of the second ECU (1) 1020, and the second encrypted data. Kr1 (Kb1) is generated. The key generation device 1300 transmits the second encrypted data Kr1 (Kb1) via the vehicle interface 11 to the second ECU (1) 1020 via the first ECU 1010 of the automobile 1001. When the first ECU 1010 of the automobile 1001 receives the second encrypted data Kr1 (Kb1) from the key generation device 1300 via the diagnostic port 1060 by the interface unit 20, the first ECU 1010 receives the second encrypted data Kr1 (Kb1). ) Is transferred to the second ECU (1) 1020 via the CAN 1030 by the interface unit 20. The second ECU (1) 1020 receives the second encrypted data Kr1 (Kb1) from the first ECU 1010 via the CAN 1030 by the interface unit 40.

(ステップS13)第2のECU(1)1020の制御部41は、第2の暗号化データKr1(Kb1)をSHE1022に渡す。SHE1022の暗号処理部52は、記憶部1023に格納しているRoot鍵Kr1により第2の暗号化データKr1(Kb1)を復号して、署名鍵Kb1を取得する。SHE1022は、該取得した署名鍵Kb1を記憶部1023に格納する。SHE1022は、記憶部1023において、該取得した署名鍵Kb1を初期署名鍵Kbiに代えて格納してもよい。 (Step S13) The control unit 41 of the second ECU (1) 1020 passes the second encrypted data Kr1 (Kb1) to the SHE1022. The encryption processing unit 52 of the SHE 1022 decrypts the second encrypted data Kr1 (Kb1) with the Root key Kr1 stored in the storage unit 1023, and acquires the signature key Kb1. The SHE 1022 stores the acquired signature key Kb1 in the storage unit 1023. The SHE 1022 may store the obtained signature key Kb1 in the storage unit 1023 in place of the initial signature key Kbi.

(ステップS14)第2のECU(1)1020の制御部41は、記憶部42に格納している初期ECUコードE1iをSHE1022に渡して、セキュアブート処理を実行させる。セキュアブート処理において、SHE1022の測定値計算部51は、記憶部1023に格納している署名鍵Kb1により、初期ECUコードE1iの測定値を計算する。本実施形態では、測定値の一例として、CMACを使用する。よって、測定値計算部51は、記憶部1023に格納している署名鍵Kb1により、初期ECUコードE1iのCMACを計算する。この計算結果のCMACを測定値E1n_aと称する。SHE1022は、測定値E1n_aをセキュアブート処理で使用する期待値に設定する。該期待値「測定値E1n_a」は記憶部1023に格納される。 (Step S14) The control unit 41 of the second ECU (1) 1020 passes the initial ECU code E1i stored in the storage unit 42 to the SHE 1022, and executes secure boot processing. In the secure boot process, the measurement value calculation unit 51 of the SHE 1022 calculates the measurement value of the initial ECU code E1i using the signature key Kb1 stored in the storage unit 1023. In this embodiment, CMAC is used as an example of the measurement value. Therefore, the measurement value calculation unit 51 calculates the CMAC of the initial ECU code E1i using the signature key Kb1 stored in the storage unit 1023. The CMAC resulting from this calculation is referred to as a measured value E1n_a. The SHE 1022 sets the measurement value E1n_a to an expected value used in the secure boot process. The expected value “measured value E1n_a” is stored in the storage unit 1023.

(ステップS15)第2のECU(1)1020のSHE1022の暗号処理部52は、記憶部1023に格納しているRoot鍵Kr1により測定値E1n_aを暗号化して第3の暗号化データKr1(E1n_a)を生成する。SHE1022は、第3の暗号化データKr1(E1n_a)を制御部41に渡す。制御部41は、インタフェース部40により、第3の暗号化データKr1(E1n_a)を、CAN1030を介して第1のECU1010経由で鍵生成装置1300に送信する。第1のECU1010は、インタフェース部20により、第2のECU(1)1020からCAN1030を介して、第3の暗号化データKr1(E1n_a)を受信すると、該第3の暗号化データKr1(E1n_a)を、インタフェース部20により、診断ポート1060を介して鍵生成装置1300に転送する。鍵生成装置1300は、車両インタフェース11により、自動車1001の第1のECU1010から診断ポート1060を介して、第3の暗号化データKr1(E1n_a)を受信する。 (Step S15) The encryption processing unit 52 of the SHE 1022 of the second ECU (1) 1020 encrypts the measured value E1n_a with the Root key Kr1 stored in the storage unit 1023, and third encrypted data Kr1 (E1n_a) Is generated. The SHE 1022 passes the third encrypted data Kr1 (E1n_a) to the control unit 41. The control unit 41 uses the interface unit 40 to transmit the third encrypted data Kr1 (E1n_a) to the key generation device 1300 via the CAN 1030 and the first ECU 1010. When the first ECU 1010 receives the third encrypted data Kr1 (E1n_a) from the second ECU (1) 1020 via the CAN 1030, the first ECU 1010 receives the third encrypted data Kr1 (E1n_a). Is transferred to the key generation device 1300 via the diagnostic port 1060 by the interface unit 20. The key generation device 1300 receives the third encrypted data Kr1 (E1n_a) from the first ECU 1010 of the automobile 1001 via the diagnosis port 1060 by the vehicle interface 11.

(ステップS16)鍵生成装置1300の暗号処理部16は、第2のECU(1)1020のRoot鍵Kr1により第3の暗号化データKr1(E1n_a)を復号して測定値E1n_aを取得する。期待値計算部13は、第2のECU(1)1020の署名鍵Kb1により、第2のECU(1)1020の初期ECUコードE1iのCMACを計算する。この計算結果のCMACを期待値E1n_bと称する。
なお、第2のECU(1)1020は、測定値E1n_aを暗号化しないでそのままのデータで鍵生成装置1300に送信してもよい。
(Step S16) The encryption processing unit 16 of the key generation device 1300 decrypts the third encrypted data Kr1 (E1n_a) with the Root key Kr1 of the second ECU (1) 1020 to obtain the measured value E1n_a. The expected value calculation unit 13 calculates the CMAC of the initial ECU code E1i of the second ECU (1) 1020 using the signature key Kb1 of the second ECU (1) 1020. This calculated CMAC is referred to as an expected value E1n_b.
Note that the second ECU (1) 1020 may transmit the measurement value E1n_a to the key generation apparatus 1300 as it is without encrypting the measurement value E1n_a.

検証部14は、測定値E1n_aと期待値E1n_bとを比較し、両者が一致するか否かを判断する。この判断の結果、両者が一致する場合には測定値E1n_aの検証が合格である。測定値E1n_aの検証が合格である場合には、ステップS17に進む。一方、両者が一致しない場合には測定値E1n_aの検証が不合格である。測定値E1n_aの検証が不合格である場合には、第2のECU(1)1020について図5の処理を終了する。よって、測定値E1n_aの検証が不合格である場合には、第2のECU(1)1020についてステップS17は実行されない。また、測定値E1n_aの検証が不合格である場合には、鍵生成装置1300は所定のエラー処理を実行してもよい。   The verification unit 14 compares the measured value E1n_a and the expected value E1n_b, and determines whether or not they match. As a result of this determination, if the two coincide, the measurement value E1n_a has been verified. If the verification of the measurement value E1n_a is acceptable, the process proceeds to step S17. On the other hand, when the two do not match, the verification of the measurement value E1n_a fails. If the verification of the measurement value E1n_a fails, the process of FIG. 5 is terminated for the second ECU (1) 1020. Therefore, when the verification of the measurement value E1n_a fails, step S17 is not executed for the second ECU (1) 1020. If the verification of the measurement value E1n_a fails, the key generation device 1300 may execute a predetermined error process.

(ステップS17)鍵生成装置1300は、車両インタフェース11により、車内鍵送付要求メッセージを自動車1001の第1のECU1010に送信する。この車内鍵送付要求メッセージは、測定値E1n_aの検証が合格した第2のECU(1)1020に車内鍵を送付することを要求するメッセージである。該車内鍵送付要求メッセージは、第2のECU(1)1020のRoot鍵Kr1を含む。該Root鍵Kr1は、第1のECU1010のRoot鍵Krcにより暗号化されて該車内鍵送付要求メッセージに格納されることが好ましい。自動車1001の第1のECU1010は、インタフェース部20により、鍵生成装置1300から診断ポート1060を介して、車内鍵送付要求メッセージを受信する。 (Step S <b> 17) The key generation device 1300 transmits an in-vehicle key transmission request message to the first ECU 1010 of the automobile 1001 through the vehicle interface 11. This in-vehicle key sending request message is a message requesting that the in-vehicle key be sent to the second ECU (1) 1020 that has passed the verification of the measurement value E1n_a. The in-vehicle key transmission request message includes the root key Kr1 of the second ECU (1) 1020. The root key Kr1 is preferably encrypted with the root key Krc of the first ECU 1010 and stored in the in-vehicle key transmission request message. The first ECU 1010 of the automobile 1001 receives an in-vehicle key sending request message from the key generation device 1300 via the diagnostic port 1060 by the interface unit 20.

(ステップS18)第1のECU1010の制御部21は、車内鍵送付要求メッセージに含まれる第2のECU(1)1020のRoot鍵Kr1をHSM1012に渡して、車内鍵Kvの暗号化を実行させる。なお、車内鍵送付要求メッセージに含まれる第2のECU(1)1020のRoot鍵Kr1が暗号化されている場合には、制御部21は、該Root鍵Kr1の暗号化データKrc(Kr1)をHSM1012に渡して、Root鍵Krcにより復号させることにより、第2のECU(1)1020のRoot鍵Kr1を取得する。 (Step S18) The control unit 21 of the first ECU 1010 passes the Root key Kr1 of the second ECU (1) 1020 included in the in-vehicle key transmission request message to the HSM 1012 and causes the in-vehicle key Kv to be encrypted. When the root key Kr1 of the second ECU (1) 1020 included in the in-vehicle key transmission request message is encrypted, the control unit 21 stores the encrypted data Krc (Kr1) of the root key Kr1. It is passed to the HSM 1012, and decrypted with the root key Krc, thereby obtaining the root key Kr1 of the second ECU (1) 1020.

HSM1012の暗号処理部32は、第2のECU(1)1020のRoot鍵Kr1により車内鍵Kvを暗号化して暗号化データKr1(Kv)を生成する。HSM1012は、暗号化データKr1(Kv)を制御部21に渡す。制御部21は、インタフェース部20により、暗号化データKr1(Kv)を、CAN1030を介して第2のECU(1)1020に送信する。第2のECU(1)1020は、インタフェース部40により、第1のECU1010からCAN1030を介して、暗号化データKr1(Kv)を受信する。   The encryption processing unit 32 of the HSM 1012 generates encrypted data Kr1 (Kv) by encrypting the in-vehicle key Kv with the root key Kr1 of the second ECU (1) 1020. The HSM 1012 passes the encrypted data Kr1 (Kv) to the control unit 21. The control unit 21 uses the interface unit 20 to transmit the encrypted data Kr1 (Kv) to the second ECU (1) 1020 via the CAN 1030. The second ECU (1) 1020 receives the encrypted data Kr1 (Kv) from the first ECU 1010 via the CAN 1030 by the interface unit 40.

(ステップS19)第2のECU(1)1020の制御部41は、暗号化データKr1(Kv)をSHE1022に渡す。SHE1022の暗号処理部52は、記憶部1023に格納しているRoot鍵Kr1により暗号化データKr1(Kv)を復号して、車内鍵Kvを取得する。SHE1022は、該取得した車内鍵Kvを記憶部1023に格納する。 (Step S19) The control unit 41 of the second ECU (1) 1020 passes the encrypted data Kr1 (Kv) to the SHE1022. The encryption processing unit 52 of the SHE 1022 decrypts the encrypted data Kr1 (Kv) with the Root key Kr1 stored in the storage unit 1023, and acquires the in-vehicle key Kv. The SHE 1022 stores the acquired in-vehicle key Kv in the storage unit 1023.

上記ステップS10からステップS19までは、自動車1001に搭載されている全ての第2のECU(n)1020に対して同様に実行される。   Steps S10 to S19 are similarly executed for all second ECUs (n) 1020 mounted on the automobile 1001.

上述した管理方法の例1によれば、自動車1001に搭載されているECUが算出したECUコードの測定値を、鍵生成装置1300が期待値に基づいて検証することにより、自動車1001に搭載されているECUの真贋判定を行う。これにより、自動車1001に搭載されているECUの信頼性が向上する効果を奏する。   According to Example 1 of the management method described above, the key generation device 1300 verifies the measured value of the ECU code calculated by the ECU mounted on the automobile 1001 based on the expected value. The authenticity of the ECU is checked. Thereby, there is an effect that the reliability of the ECU mounted on the automobile 1001 is improved.

<管理方法の例2>
管理方法の例2は、上述した管理方法の例1の変形例である。図6は、本実施形態に係る管理方法の例2のシーケンス図である。図6において、図5の各部に対応する部分には同一の符号を付け、その説明を省略する。以下、図6を参照して、上述した管理方法の例1と異なる点を主に説明する。
<Example 2 of management method>
The management method example 2 is a modification of the management method example 1 described above. FIG. 6 is a sequence diagram of the second example of the management method according to the present embodiment. In FIG. 6, parts corresponding to those in FIG. Hereinafter, with reference to FIG. 6, the difference from Example 1 of the management method described above will be mainly described.

鍵生成装置1300の車両インタフェース11と自動車1001の診断ポート1060とは接続されている。ステップS1からステップS8までが実行される。ステップS1からステップS8までは、上述した図5に係る管理方法の例1と同じである。ステップS8において測定値Ecn_aの検証が合格である場合には、ステップS21に進む。一方、ステップS8において測定値Ecn_aの検証が不合格である場合には、図6の処理を終了する。また、測定値Ecn_aの検証が不合格である場合には、鍵生成装置1300は所定のエラー処理を実行してもよい。   The vehicle interface 11 of the key generation device 1300 and the diagnostic port 1060 of the automobile 1001 are connected. Steps S1 to S8 are executed. Steps S1 to S8 are the same as those in the example 1 of the management method according to FIG. 5 described above. If the verification of the measurement value Ecn_a is acceptable in step S8, the process proceeds to step S21. On the other hand, if the verification of the measurement value Ecn_a fails in step S8, the process of FIG. If the verification of the measurement value Ecn_a fails, the key generation device 1300 may execute a predetermined error process.

(ステップS21)鍵生成装置1300の暗号処理部16は、第1のECU1010のRoot鍵Krcにより、N個の第2のECU(n)1020の各々のRoot鍵Krn及び署名鍵Kbnを各々に暗号化する。この暗号化によって、N個の第1の暗号化データKrc(Kr1)、Krc(Kr2)、・・・、Krc(KrN)と、N個の第2の暗号化データKrc(Kb1)、Krc(Kb2)、・・・、Krc(KbN)とが生成される。 (Step S21) The encryption processing unit 16 of the key generation device 1300 encrypts the root key Krn and the signature key Kbn of each of the N second ECUs (n) 1020 with the root key Krc of the first ECU 1010. Turn into. By this encryption, N pieces of first encrypted data Krc (Kr1), Krc (Kr2),..., Krc (KrN) and N pieces of second encrypted data Krc (Kb1), Krc ( Kb2),..., Krc (KbN) are generated.

鍵生成装置1300は、車両インタフェース11により、N個の第1の暗号化データKrc(Kr1)、Krc(Kr2)、・・・、Krc(KrN)と、N個の第2の暗号化データKrc(Kb1)、Krc(Kb2)、・・・、Krc(KbN)とを自動車1001の第1のECU1010に送信する。自動車1001の第1のECU1010は、インタフェース部20により、鍵生成装置1300から診断ポート1060を介して、N個の第1の暗号化データKrc(Kr1)、Krc(Kr2)、・・・、Krc(KrN)と、N個の第2の暗号化データKrc(Kb1)、Krc(Kb2)、・・・、Krc(KbN)とを受信する。   The key generation device 1300 uses the vehicle interface 11 to generate N pieces of first encrypted data Krc (Kr1), Krc (Kr2),..., Krc (KrN) and N pieces of second encrypted data Krc. (Kb1), Krc (Kb2),..., Krc (KbN) are transmitted to the first ECU 1010 of the automobile 1001. The first ECU 1010 of the automobile 1001 uses the interface unit 20 to transmit N pieces of first encrypted data Krc (Kr1), Krc (Kr2),..., Krc from the key generation device 1300 via the diagnostic port 1060. (KrN) and N pieces of second encrypted data Krc (Kb1), Krc (Kb2),..., Krc (KbN) are received.

(ステップS22)第1のECU1010の制御部21は、N個の第1の暗号化データKrc(Kr1)、Krc(Kr2)、・・・、Krc(KrN)と、N個の第2の暗号化データKrc(Kb1)、Krc(Kb2)、・・・、Krc(KbN)とをHSM1012に渡す。HSM1012の暗号処理部32は、記憶部1013に格納しているRoot鍵Krcにより、N個の第1の暗号化データKrc(Kr1)、Krc(Kr2)、・・・、Krc(KrN)と、N個の第2の暗号化データKrc(Kb1)、Krc(Kb2)、・・・、Krc(KbN)とを各々に復号する。この復号によって、N個のRoot鍵Kr1、Kr2、・・・、KrNと、N個の署名鍵Kb1、Kb2、・・・、KbNとが取得される。HSM1012は、該取得したN個のRoot鍵Kr1、Kr2、・・・、KrNと、N個の署名鍵Kb1、Kb2、・・・、KbNとを記憶部1013に格納する。 (Step S22) The control unit 21 of the first ECU 1010 includes N pieces of first encrypted data Krc (Kr1), Krc (Kr2),..., Krc (KrN), and N second ciphers. , Krc (Kb1), Krc (Kb2),..., Krc (KbN) are passed to the HSM 1012. The encryption processing unit 32 of the HSM 1012 uses the Root key Krc stored in the storage unit 1013 to generate N pieces of first encrypted data Krc (Kr1), Krc (Kr2),..., Krc (KrN), N pieces of second encrypted data Krc (Kb1), Krc (Kb2),..., Krc (KbN) are decrypted respectively. By this decryption, N root keys Kr1, Kr2,..., KrN and N signature keys Kb1, Kb2,. The HSM 1012 stores the acquired N root keys Kr1, Kr2,..., KrN and the N signature keys Kb1, Kb2,.

(ステップS23)第1のECU1010のHSM1012の鍵生成部34は、車内鍵Kvを生成する。記憶部1013は、車内鍵Kvを格納する。 (Step S23) The key generation unit 34 of the HSM 1012 of the first ECU 1010 generates an in-vehicle key Kv. The storage unit 1013 stores the in-vehicle key Kv.

(ステップS24)第1のECU1010のHSM1012の暗号処理部32は、初期Root鍵Kriにより第2のECU(1)1020のRoot鍵Kr1を暗号化して第1の暗号化データKri(Kr1)を生成する。HSM1012は、第1の暗号化データKri(Kr1)を制御部21に渡す。制御部21は、インタフェース部20により、第1の暗号化データKri(Kr1)を、CAN1030を介して第2のECU(1)1020に送信する。第2のECU(1)1020は、インタフェース部40により、第1のECU1010からCAN1030を介して、第1の暗号化データKri(Kr1)を受信する。 (Step S24) The encryption processing unit 32 of the HSM 1012 of the first ECU 1010 generates the first encrypted data Kri (Kr1) by encrypting the Root key Kr1 of the second ECU (1) 1020 with the initial Root key Kri. To do. The HSM 1012 passes the first encrypted data Kri (Kr1) to the control unit 21. The control unit 21 transmits the first encrypted data Kri (Kr1) to the second ECU (1) 1020 via the CAN 1030 through the interface unit 20. The second ECU (1) 1020 receives the first encrypted data Kri (Kr1) from the first ECU 1010 via the CAN 1030 by the interface unit 40.

(ステップS25)第2のECU(1)1020の制御部41は、第1の暗号化データKri(Kr1)をSHE1022に渡す。SHE1022の暗号処理部52は、記憶部1023に格納している初期Root鍵Kriにより第1の暗号化データKri(Kr1)を復号して、Root鍵Kr1を取得する。SHE1022は、該取得したRoot鍵Kr1を記憶部1023に格納する。SHE1022は、記憶部1023において、該取得したRoot鍵Kr1を初期Root鍵Kriに代えて格納してもよい。 (Step S25) The control unit 41 of the second ECU (1) 1020 passes the first encrypted data Kri (Kr1) to the SHE1022. The encryption processing unit 52 of the SHE 1022 decrypts the first encrypted data Kri (Kr1) with the initial root key Kri stored in the storage unit 1023, and acquires the root key Kr1. The SHE 1022 stores the acquired root key Kr1 in the storage unit 1023. The SHE 1022 may store the acquired root key Kr1 in the storage unit 1023 in place of the initial root key Kri.

(ステップS26)第1のECU1010のHSM1012の暗号処理部32は、第2のECU(1)1020のRoot鍵Kr1により第2のECU(1)1020の署名鍵Kb1を暗号化して第2の暗号化データKr1(Kb1)を生成する。HSM1012は、第2の暗号化データKr1(Kb1)を制御部21に渡す。制御部21は、インタフェース部20により、第2の暗号化データKr1(Kb1)を、CAN1030を介して第2のECU(1)1020に送信する。第2のECU(1)1020は、インタフェース部40により、第1のECU1010からCAN1030を介して、第2の暗号化データKr1(Kb1)を受信する。 (Step S26) The encryption processing unit 32 of the HSM 1012 of the first ECU 1010 encrypts the signature key Kb1 of the second ECU (1) 1020 with the Root key Kr1 of the second ECU (1) 1020, and the second encryption Generated data Kr1 (Kb1). The HSM 1012 passes the second encrypted data Kr1 (Kb1) to the control unit 21. The control unit 21 causes the interface unit 20 to transmit the second encrypted data Kr1 (Kb1) to the second ECU (1) 1020 via the CAN 1030. The second ECU (1) 1020 receives the second encrypted data Kr1 (Kb1) from the first ECU 1010 via the CAN 1030 by the interface unit 40.

(ステップS27)第2のECU(1)1020の制御部41は、第2の暗号化データKr1(Kb1)をSHE1022に渡す。SHE1022の暗号処理部52は、記憶部1023に格納しているRoot鍵Kr1により第2の暗号化データKr1(Kb1)を復号して、署名鍵Kb1を取得する。SHE1022は、該取得した署名鍵Kb1を記憶部1023に格納する。SHE1022は、記憶部1023において、該取得した署名鍵Kb1を初期署名鍵Kbiに代えて格納してもよい。 (Step S27) The control unit 41 of the second ECU (1) 1020 passes the second encrypted data Kr1 (Kb1) to the SHE1022. The encryption processing unit 52 of the SHE 1022 decrypts the second encrypted data Kr1 (Kb1) with the Root key Kr1 stored in the storage unit 1023, and acquires the signature key Kb1. The SHE 1022 stores the acquired signature key Kb1 in the storage unit 1023. The SHE 1022 may store the obtained signature key Kb1 in the storage unit 1023 in place of the initial signature key Kbi.

次いでステップS14からステップS19までが実行される。ステップS14からステップS19までは、上述した図5に係る管理方法の例1と同じである。   Next, steps S14 to S19 are executed. Steps S14 to S19 are the same as in the management method example 1 according to FIG. 5 described above.

上記ステップS24からステップS27及びステップS14からステップS19までは、自動車1001に搭載されている全ての第2のECU(n)1020に対して同様に実行される。   Steps S24 to S27 and steps S14 to S19 are executed in the same manner for all second ECUs (n) 1020 mounted on the automobile 1001.

なお、上記ステップS22からステップS27までは、自動車1001内に閉じた処理である。このため、ステップS22からステップS27までは、鍵生成装置1300の車両インタフェース11と自動車1001の診断ポート1060とは接続されていなくてもよい。   Steps S22 to S27 are processes closed in the automobile 1001. For this reason, from step S22 to step S27, the vehicle interface 11 of the key generation device 1300 and the diagnostic port 1060 of the automobile 1001 may not be connected.

上述した管理方法の例2によれば、管理方法の例1と同様に、自動車1001に搭載されているECUが算出したECUコードの測定値を、鍵生成装置1300が期待値に基づいて検証することにより、自動車1001に搭載されているECUの真贋判定を行う。これにより、自動車1001に搭載されているECUの信頼性が向上する効果を奏する。   According to the management method example 2 described above, as in the management method example 1, the key generation device 1300 verifies the measured value of the ECU code calculated by the ECU mounted on the automobile 1001 based on the expected value. Thus, the authenticity of the ECU mounted on the automobile 1001 is determined. Thereby, there is an effect that the reliability of the ECU mounted on the automobile 1001 is improved.

また、管理方法の例2によれば、第1のECU1010は、第2のECU(n)1020に、鍵生成装置1300から送信されるN個の第1の暗号化データKrc(Kr1)、Krc(Kr2)、・・・、Krc(KrN)と、N個の第2の暗号化データKrc(Kb1)、Krc(Kb2)、・・・、Krc(KbN)とを中継する機能(ステップS22、S24及びS26に対応する機能)を有する。これにより、鍵生成装置1300と自動車1001とが接続される時間を、管理方法の例1よりも短縮できる。   Further, according to the management method example 2, the first ECU 1010 transmits the N pieces of first encrypted data Krc (Kr1) and Krc transmitted from the key generation device 1300 to the second ECU (n) 1020. (Kr2),..., Krc (KrN) and the N pieces of second encrypted data Krc (Kb1), Krc (Kb2),..., Krc (KbN) (step S22, (Functions corresponding to S24 and S26). Thereby, the time for which the key generation device 1300 and the automobile 1001 are connected can be shortened compared to the management method example 1.

<管理方法の例3>
図7は、本実施形態に係る管理方法の例3のシーケンス図である。図7を参照して本実施形態に係る管理方法の例3を説明する。鍵生成装置1300は、例えば、自動車1001の製造工場に設けられている。鍵生成装置1300の車両インタフェース11は、該製造工場で製造中の自動車1001の診断ポート1060に接続される。
<Example 3 of management method>
FIG. 7 is a sequence diagram of the third example of the management method according to the present embodiment. An example 3 of the management method according to the present embodiment will be described with reference to FIG. The key generation device 1300 is provided, for example, in a manufacturing factory for the automobile 1001. The vehicle interface 11 of the key generation device 1300 is connected to the diagnostic port 1060 of the automobile 1001 being manufactured at the manufacturing factory.

図7には、説明の便宜上、自動車1001に搭載される第2のECU(n)1020のうち、1個の第2のECU(1)1020のみを示している。但し、nは1からNまでの整数である。Nは、自動車1001に搭載されている第2のECU1020のうち、鍵配信対象の第2のECU1020の個数である。   FIG. 7 shows only one second ECU (1) 1020 out of the second ECU (n) 1020 mounted on the automobile 1001 for convenience of explanation. However, n is an integer from 1 to N. N is the number of second ECUs 1020 targeted for key distribution among the second ECUs 1020 mounted on the automobile 1001.

鍵生成装置1300は、図5に係る管理方法の例1と同様に、マスタ鍵Master_Secretと、ECUのECUコードと、初期Root鍵Kriとを予め記憶部12に格納している。ECUのECUコードは、ECUの初期ECUコードを含む。   The key generation device 1300 stores the master key Master_Secret, the ECU's ECU code, and the initial root key Kri in the storage unit 12 in advance as in the management method example 1 shown in FIG. The ECU code of the ECU includes an initial ECU code of the ECU.

第1のECU1010のHSM1012は、図5に係る管理方法の例1と同様に、初期Root鍵Kri及び初期署名鍵Kbiを予め記憶部1013に格納している。第2のECU1020のSHE1022は、図5に係る管理方法の例1と同様に、初期Root鍵Kri及び初期署名鍵Kbiを予め記憶部1023に格納している。   The HSM 1012 of the first ECU 1010 stores the initial root key Kri and the initial signature key Kbi in the storage unit 1013 in advance as in the management method example 1 according to FIG. The SHE 1022 of the second ECU 1020 stores the initial root key Kri and the initial signature key Kbi in the storage unit 1023 in advance as in the management method example 1 shown in FIG.

第1のECU1010のメイン演算器1011は、図5に係る管理方法の例1と同様に、初期ECUコードEciを予め記憶部22に格納している。第2のECU(n)1020のメイン演算器1021は、図5に係る管理方法の例1と同様に、初期ECUコードEniを予め記憶部42に格納している。   The main computing unit 1011 of the first ECU 1010 stores the initial ECU code Eci in the storage unit 22 in advance, as in the management method example 1 according to FIG. The main computing unit 1021 of the second ECU (n) 1020 stores the initial ECU code Eni in the storage unit 42 in advance, as in the management method example 1 according to FIG.

以下、鍵生成装置1300の車両インタフェース11と自動車1001の診断ポート1060とは接続されている。   Hereinafter, the vehicle interface 11 of the key generation device 1300 and the diagnosis port 1060 of the automobile 1001 are connected.

(ステップS31)鍵生成装置1300において、鍵生成部15は、自動車1001に搭載されているECUのRoot鍵と署名鍵とを生成する。本実施形態では、鍵生成部15は、第1のECU1010のRoot鍵Krc及び署名鍵Kbcと、N個の第2のECU(n)1020の各々のRoot鍵Krn及び署名鍵Kbnとを生成する。記憶部12は、第1のECU1010のRoot鍵Krc及び署名鍵Kbcと、N個の第2のECU(n)1020の各々のRoot鍵Krn及び署名鍵Kbnとを格納する。Root鍵Krc及びKrnは、第1の鍵に対応する。署名鍵Kbc及びKbnは、第2の鍵に対応する。Root鍵Krc及びKrn、並びに、署名鍵Kbc及びKbnの生成方法は、図5に係る管理方法の例1のステップS1と同じである。 (Step S31) In the key generation device 1300, the key generation unit 15 generates a root key and a signature key of the ECU mounted on the automobile 1001. In the present embodiment, the key generation unit 15 generates the root key Krc and signature key Kbc of the first ECU 1010, and the root key Krn and signature key Kbn of each of the N second ECUs (n) 1020. . The storage unit 12 stores the root key Krc and signature key Kbc of the first ECU 1010, and the root key Krn and signature key Kbn of each of the N second ECUs (n) 1020. Root keys Krc and Krn correspond to the first key. The signature keys Kbc and Kbn correspond to the second key. The generation method of the root keys Krc and Krn and the signature keys Kbc and Kbn is the same as step S1 of the management method example 1 according to FIG.

期待値計算部13は、第1のECU1010の署名鍵Kbcにより、第1のECU1010の初期ECUコードEci(CGWコード)のCMACを計算する。この計算結果のCMACを期待値Ecnと称する。期待値計算部13は、第2のECU(n)1020の署名鍵Kbnにより、第2のECU(n)1020の初期ECUコードEni(ECUnコード)のCMACを計算する。この計算結果のCMACを期待値Ennと称する。これにより、第1のECU1010の初期ECUコードEci(CGWコード)についての期待値Ecnと、N個の第2のECU(n)1020の初期ECUコードEni(ECUnコード)についての各々の期待値E1n、E2n、・・・、ENnとが、期待値計算部13によって生成された。記憶部12は、第1のECU1010の初期ECUコードEci(CGWコード)についての期待値Ecnと、N個の第2のECU(n)1020の初期ECUコードEni(ECUnコード)についての各々の期待値E1n、E2n、・・・、ENnとを格納する。   The expected value calculation unit 13 calculates the CMAC of the initial ECU code Eci (CGW code) of the first ECU 1010 using the signature key Kbc of the first ECU 1010. The CMAC resulting from this calculation is referred to as an expected value Ecn. The expected value calculation unit 13 calculates the CMAC of the initial ECU code Eni (ECUn code) of the second ECU (n) 1020 using the signature key Kbn of the second ECU (n) 1020. The CMAC resulting from this calculation is referred to as an expected value Enn. Thereby, the expected value Ecn for the initial ECU code Eci (CGW code) of the first ECU 1010 and the expected value E1n for the initial ECU code Eni (ECUn code) of the N second ECU (n) 1020 , E2n,..., ENn are generated by the expected value calculator 13. The storage unit 12 has an expected value Ecn for the initial ECU code Eci (CGW code) of the first ECU 1010 and each expected value for the initial ECU code Eni (ECU code) of the N second ECUs (n) 1020. Stores the values E1n, E2n,..., ENn.

次いでステップS32及びステップS33が実行される。ステップS32は、図5に係る管理方法の例1のステップS2と同じである。ステップS33は、図5に係る管理方法の例1のステップS3と同じである。次いでステップS34が実行される。   Next, step S32 and step S33 are executed. Step S32 is the same as Step S2 of Example 1 of the management method according to FIG. Step S33 is the same as step S3 of the management method example 1 according to FIG. Next, step S34 is executed.

(ステップS34)鍵生成装置1300の暗号処理部16は、第1のECU1010のRoot鍵Krcにより第1のECU1010の署名鍵Kbc及び期待値Ecnを各々に暗号化して、第2の暗号化データKrc(Kbc)及び第4の暗号化データKrc(Ecn)を生成する。鍵生成装置1300は、車両インタフェース11により、第2の暗号化データKrc(Kbc)及び第4の暗号化データKrc(Ecn)を自動車1001の第1のECU1010に送信する。自動車1001の第1のECU1010は、インタフェース部20により、鍵生成装置1300から診断ポート1060を介して、第2の暗号化データKrc(Kbc)及び第4の暗号化データKrc(Ecn)を受信する。 (Step S34) The encryption processing unit 16 of the key generation device 1300 encrypts the signature key Kbc and the expected value Ecn of the first ECU 1010 with the Root key Krc of the first ECU 1010, respectively, and the second encrypted data Krc. (Kbc) and fourth encrypted data Krc (Ecn) are generated. The key generation device 1300 transmits the second encrypted data Krc (Kbc) and the fourth encrypted data Krc (Ecn) to the first ECU 1010 of the automobile 1001 through the vehicle interface 11. The first ECU 1010 of the automobile 1001 receives the second encrypted data Krc (Kbc) and the fourth encrypted data Krc (Ecn) from the key generation device 1300 via the diagnostic port 1060 by the interface unit 20. .

(ステップS35)第1のECU1010の制御部21は、第2の暗号化データKrc(Kbc)及び第4の暗号化データKrc(Ecn)をHSM1012に渡す。HSM1012の暗号処理部32は、記憶部1013に格納しているRoot鍵Krcにより第2の暗号化データKrc(Kbc)及び第4の暗号化データKrc(Ecn)を各々に復号して、署名鍵Kbc及び期待値Ecnを取得する。HSM1012は、該取得した署名鍵Kbcを記憶部1013に格納する。HSM1012は、記憶部1013において、該取得した署名鍵Kbcを初期署名鍵Kbiに代えて格納してもよい。また、HSM1012は、該取得した期待値Ecnをセキュアブート処理で使用する期待値に設定する。 (Step S35) The control unit 21 of the first ECU 1010 passes the second encrypted data Krc (Kbc) and the fourth encrypted data Krc (Ecn) to the HSM 1012. The encryption processing unit 32 of the HSM 1012 decrypts the second encrypted data Krc (Kbc) and the fourth encrypted data Krc (Ecn) with the Root key Krc stored in the storage unit 1013, respectively. Kbc and expected value Ecn are acquired. The HSM 1012 stores the acquired signature key Kbc in the storage unit 1013. The HSM 1012 may store the acquired signature key Kbc in the storage unit 1013 instead of the initial signature key Kbi. Also, the HSM 1012 sets the acquired expected value Ecn to an expected value used in the secure boot process.

(ステップS36)第1のECU1010の制御部21は、記憶部22に格納している初期ECUコードEciをHSM1012に渡して、セキュアブート処理を実行させる。セキュアブート処理において、HSM1012の測定部33は、記憶部1013に格納している署名鍵Kbcにより、初期ECUコードEciの測定値を計算する。本実施形態では、測定値の一例として、CMACを使用する。よって、測定部33は、記憶部1013に格納している署名鍵Kbcにより、初期ECUコードEciのCMACを計算する。この計算結果のCMACを測定値Ecn_xと称する。 (Step S36) The control unit 21 of the first ECU 1010 passes the initial ECU code Eci stored in the storage unit 22 to the HSM 1012 to execute the secure boot process. In the secure boot process, the measurement unit 33 of the HSM 1012 calculates the measurement value of the initial ECU code Eci using the signature key Kbc stored in the storage unit 1013. In this embodiment, CMAC is used as an example of the measurement value. Therefore, the measurement unit 33 calculates the CMAC of the initial ECU code Eci using the signature key Kbc stored in the storage unit 1013. The CMAC resulting from this calculation is referred to as a measured value Ecn_x.

測定部33は、測定値Ecn_xと期待値Ecnとを比較し、両者が一致するか否かを判断する。この判断の結果、両者が一致する場合には測定値Ecn_xの検証が合格である。一方、両者が一致しない場合には測定値Ecn_xの検証が不合格である。HSM1012は、測定値Ecn_xの検証結果「合格又は不合格」を制御部21に渡す。   The measuring unit 33 compares the measured value Ecn_x with the expected value Ecn and determines whether or not they match. As a result of this determination, if both match, the verification of the measured value Ecn_x is acceptable. On the other hand, if the two do not match, the verification of the measurement value Ecn_x fails. The HSM 1012 passes the verification result “pass or fail” of the measurement value Ecn_x to the control unit 21.

(ステップS37)制御部21は、インタフェース部20により、セキュアブート結果として測定値Ecn_xの検証結果「合格又は不合格」を、診断ポート1060を介して、鍵生成装置1300に送信する。鍵生成装置1300は、車両インタフェース11により、自動車1001の第1のECU1010から診断ポート1060を介して、セキュアブート結果「合格又は不合格」を受信する。
なお、第1のECU1010は、セキュアブート結果としての測定値Ecn_xの検証結果「合格又は不合格」をRoot鍵Krcにより暗号化して鍵生成装置1300に送信してもよい。この場合、鍵生成装置1300は、該暗号化されたセキュアブート結果「合格又は不合格」を受信して第1のECU1010のRoot鍵Krcにより復号する。
(Step S <b> 37) The control unit 21 transmits the verification result “pass or fail” of the measurement value Ecn_x as the secure boot result to the key generation device 1300 via the diagnostic port 1060 by the interface unit 20. The key generation device 1300 receives the secure boot result “pass or fail” from the first ECU 1010 of the automobile 1001 via the diagnosis port 1060 by the vehicle interface 11.
Note that the first ECU 1010 may encrypt the verification result “pass or fail” of the measurement value Ecn_x as the secure boot result with the Root key Krc and transmit it to the key generation device 1300. In this case, the key generation device 1300 receives the encrypted secure boot result “pass or fail” and decrypts it with the root key Krc of the first ECU 1010.

鍵生成装置1300が自動車1001の第1のECU1010から受信したセキュアブート結果「合格又は不合格」が「合格」である場合には、ステップS38に進む。一方、該セキュアブート結果「合格又は不合格」が「不合格」である場合には、図7の処理を終了する。また、該セキュアブート結果「合格又は不合格」が「不合格」である場合には、鍵生成装置1300は所定のエラー処理を実行してもよい。   If the secure boot result “pass or fail” received by the key generation device 1300 from the first ECU 1010 of the automobile 1001 is “pass”, the process proceeds to step S38. On the other hand, when the secure boot result “pass or fail” is “fail”, the process of FIG. When the secure boot result “pass or fail” is “fail”, the key generation device 1300 may execute a predetermined error process.

(ステップS38)第1のECU1010のHSM1012の鍵生成部34は、車内鍵Kvを生成する。記憶部1013は、車内鍵Kvを格納する。 (Step S38) The key generation unit 34 of the HSM 1012 of the first ECU 1010 generates the in-vehicle key Kv. The storage unit 1013 stores the in-vehicle key Kv.

次いでステップS39及びステップS40が実行される。ステップS39は、図5に係る管理方法の例1のステップS10と同じである。ステップS40は、図5に係る管理方法の例1のステップS11と同じである。次いでステップS41が実行される。   Next, step S39 and step S40 are executed. Step S39 is the same as Step S10 in Example 1 of the management method according to FIG. Step S40 is the same as step S11 of the management method example 1 according to FIG. Step S41 is then executed.

(ステップS41)鍵生成装置1300の暗号処理部16は、第2のECU(1)1020のRoot鍵Kr1により第2のECU(1)1020の署名鍵Kb1及び期待値E1nを各々に暗号化して、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を生成する。鍵生成装置1300は、車両インタフェース11により、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を、自動車1001の第1のECU1010経由で第2のECU(1)1020に送信する。自動車1001の第1のECU1010は、インタフェース部20により、鍵生成装置1300から診断ポート1060を介して、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を受信すると、該第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を、インタフェース部20により、CAN1030を介して第2のECU(1)1020に転送する。第2のECU(1)1020は、インタフェース部40により、第1のECU1010からCAN1030を介して、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を受信する。 (Step S41) The encryption processing unit 16 of the key generation device 1300 encrypts the signature key Kb1 and the expected value E1n of the second ECU (1) 1020 with the Root key Kr1 of the second ECU (1) 1020, respectively. Second encrypted data Kr1 (Kb1) and fourth encrypted data Kr1 (E1n) are generated. The key generation device 1300 uses the vehicle interface 11 to transmit the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) to the second ECU (1) via the first ECU 1010 of the automobile 1001. To 1020. When the first ECU 1010 of the automobile 1001 receives the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) from the key generation device 1300 via the diagnostic port 1060 by the interface unit 20. The second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) are transferred by the interface unit 20 to the second ECU (1) 1020 via the CAN 1030. The second ECU (1) 1020 receives the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) from the first ECU 1010 via the CAN 1030 by the interface unit 40.

(ステップS42)第2のECU(1)1020の制御部41は、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)をSHE1022に渡す。SHE1022の暗号処理部52は、記憶部1023に格納しているRoot鍵Kr1により第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を各々に復号して、署名鍵Kb1及び期待値E1nを取得する。SHE1022は、該取得した署名鍵Kb1を記憶部1023に格納する。SHE1022は、記憶部1023において、該取得した署名鍵Kb1を初期署名鍵Kbiに代えて格納してもよい。また、SHE1022は、該取得した期待値E1nをセキュアブート処理で使用する期待値に設定する。 (Step S42) The control unit 41 of the second ECU (1) 1020 passes the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) to the SHE1022. The encryption processing unit 52 of the SHE 1022 decrypts the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) with the Root key Kr1 stored in the storage unit 1023, respectively. Kb1 and expected value E1n are acquired. The SHE 1022 stores the acquired signature key Kb1 in the storage unit 1023. The SHE 1022 may store the obtained signature key Kb1 in the storage unit 1023 in place of the initial signature key Kbi. Further, the SHE 1022 sets the acquired expected value E1n to an expected value used in the secure boot process.

(ステップS43)第2のECU(1)1020の制御部41は、記憶部42に格納している初期ECUコードE1iをSHE1022に渡して、セキュアブート処理を実行させる。セキュアブート処理において、SHE1022の測定部53は、記憶部1023に格納している署名鍵Kb1により、初期ECUコードE1iの測定値を計算する。本実施形態では、測定値の一例として、CMACを使用する。よって、測定部53は、記憶部1023に格納している署名鍵Kb1により、初期ECUコードE1iのCMACを計算する。この計算結果のCMACを測定値E1n_xと称する。 (Step S43) The control unit 41 of the second ECU (1) 1020 passes the initial ECU code E1i stored in the storage unit 42 to the SHE 1022, and executes secure boot processing. In the secure boot process, the measurement unit 53 of the SHE 1022 calculates the measurement value of the initial ECU code E1i using the signature key Kb1 stored in the storage unit 1023. In this embodiment, CMAC is used as an example of the measurement value. Therefore, the measurement unit 53 calculates the CMAC of the initial ECU code E1i using the signature key Kb1 stored in the storage unit 1023. The CMAC resulting from this calculation is referred to as a measured value E1n_x.

測定部53は、測定値E1n_xと期待値E1nとを比較し、両者が一致するか否かを判断する。この判断の結果、両者が一致する場合には測定値E1n_xの検証が合格である。一方、両者が一致しない場合には測定値E1n_xの検証が不合格である。SHE1022は、測定値E1n_xの検証結果「合格又は不合格」を制御部41に渡す。   The measuring unit 53 compares the measured value E1n_x with the expected value E1n, and determines whether or not they match. As a result of this determination, if both match, the verification of the measured value E1n_x is acceptable. On the other hand, if the two do not match, the verification of the measured value E1n_x fails. The SHE 1022 passes the verification result “pass or fail” of the measurement value E1n_x to the control unit 41.

(ステップS44)制御部41は、インタフェース部40により、セキュアブート結果として測定値E1n_xの検証結果「合格又は不合格」を、CAN1030を介して第1のECU1010経由で鍵生成装置1300に送信する。第1のECU1010は、インタフェース部20により、第2のECU(1)1020からCAN1030を介して、セキュアブート結果「合格又は不合格」を受信すると、該セキュアブート結果「合格又は不合格」を、インタフェース部20により、診断ポート1060を介して鍵生成装置1300に転送する。鍵生成装置1300は、車両インタフェース11により、自動車1001の第1のECU1010から診断ポート1060を介して、第2のECU(1)1020のセキュアブート結果「合格又は不合格」を受信する。
なお、第2のECU(1)1020は、セキュアブート結果としての測定値E1n_xの検証結果「合格又は不合格」をRoot鍵Kr1により暗号化して鍵生成装置1300に送信してもよい。この場合、鍵生成装置1300は、該暗号化されたセキュアブート結果「合格又は不合格」を受信して第2のECU(1)1020のRoot鍵Kr1により復号する。
(Step S44) The control unit 41 transmits the verification result “pass or fail” of the measurement value E1n_x as the secure boot result to the key generation device 1300 via the first ECU 1010 via the CAN 1030. When the first ECU 1010 receives the secure boot result “pass or fail” from the second ECU (1) 1020 via the CAN 1030, the first ECU 1010 receives the secure boot result “pass or fail”. The data is transferred to the key generation device 1300 via the diagnostic port 1060 by the interface unit 20. The key generation device 1300 receives the secure boot result “pass or fail” of the second ECU (1) 1020 from the first ECU 1010 of the automobile 1001 via the diagnosis port 1060 by the vehicle interface 11.
Note that the second ECU (1) 1020 may encrypt the verification result “pass or fail” of the measurement value E1n_x as the secure boot result with the Root key Kr1 and transmit it to the key generation device 1300. In this case, the key generation device 1300 receives the encrypted secure boot result “pass or fail” and decrypts it with the root key Kr1 of the second ECU (1) 1020.

鍵生成装置1300が自動車1001の第2のECU(1)1020から受信したセキュアブート結果「合格又は不合格」が「合格」である場合には、ステップS45に進む。一方、該セキュアブート結果「合格又は不合格」が不合格である場合には、第2のECU(1)1020について図7の処理を終了する。よって、第2のECU(1)1020からのセキュアブート結果「合格又は不合格」が不合格である場合には、第2のECU(1)1020についてステップS45は実行されない。また、第2のECU(1)1020からのセキュアブート結果「合格又は不合格」が不合格である場合には、鍵生成装置1300は所定のエラー処理を実行してもよい。   If the secure boot result “pass or fail” received by the key generation device 1300 from the second ECU (1) 1020 of the automobile 1001 is “pass”, the process proceeds to step S45. On the other hand, when the secure boot result “pass or fail” is unsuccessful, the process of FIG. 7 is terminated for the second ECU (1) 1020. Therefore, when the secure boot result “pass or fail” from the second ECU (1) 1020 is unsuccessful, step S45 is not executed for the second ECU (1) 1020. When the secure boot result “pass or fail” from the second ECU (1) 1020 is unsuccessful, the key generation device 1300 may execute a predetermined error process.

次いでステップS45からステップS47までが実行される。ステップS45は、図5に係る管理方法の例1のステップS17と同じである。ステップS46は、図5に係る管理方法の例1のステップS18と同じである。ステップS47は、図5に係る管理方法の例1のステップS19と同じである。   Next, steps S45 to S47 are executed. Step S45 is the same as step S17 of the management method example 1 according to FIG. Step S46 is the same as step S18 of the management method example 1 according to FIG. Step S47 is the same as Step S19 in Example 1 of the management method according to FIG.

上記ステップS39からステップS47までは、自動車1001に搭載されている全ての第2のECU(n)1020に対して同様に実行される。   Steps S39 to S47 are executed in the same manner for all second ECUs (n) 1020 mounted on the automobile 1001.

上述した管理方法の例3によれば、自動車1001に搭載されているECUのECUコードの期待値を鍵生成装置1300が生成してECUに供給する。そして、ECUが、自己のECUコードの測定値を、鍵生成装置1300から供給された期待値に基づいて検証し、この検証結果を鍵生成装置1300に通知することにより、自動車1001に搭載されているECUの真贋判定を行う。これにより、自動車1001に搭載されているECUの信頼性が向上する効果を奏する。   According to the third example of the management method described above, the key generation device 1300 generates the expected value of the ECU code of the ECU mounted on the automobile 1001 and supplies it to the ECU. Then, the ECU verifies the measured value of its own ECU code based on the expected value supplied from the key generation device 1300, and notifies the key generation device 1300 of the verification result, so that the ECU 1001 is mounted on the automobile 1001. The authenticity of the ECU is checked. Thereby, there is an effect that the reliability of the ECU mounted on the automobile 1001 is improved.

<管理方法の例4>
管理方法の例4は、上述した管理方法の例3の変形例である。図8は、本実施形態に係る管理方法の例4のシーケンス図である。図8において、図7の各部に対応する部分には同一の符号を付け、その説明を省略する。以下、図8を参照して、上述した管理方法の例3と異なる点を主に説明する。
<Example 4 of management method>
The management method example 4 is a modification of the management method example 3 described above. FIG. 8 is a sequence diagram of Example 4 of the management method according to the present embodiment. In FIG. 8, parts corresponding to those in FIG. 7 are given the same reference numerals, and explanation thereof is omitted. Hereinafter, with reference to FIG. 8, the difference from Example 3 of the management method described above will be mainly described.

鍵生成装置1300の車両インタフェース11と自動車1001の診断ポート1060とは接続されている。ステップS31からステップS38までが実行される。ステップS31からステップS38までは、上述した図7に係る管理方法の例3と同じである。鍵生成装置1300が自動車1001の第1のECU1010から受信したセキュアブート結果「合格又は不合格」が「合格」である場合には、ステップS38に次いでステップS51が実行される。一方、該セキュアブート結果「合格又は不合格」が「不合格」である場合には、図8の処理を終了する。また、該セキュアブート結果「合格又は不合格」が「不合格」である場合には、鍵生成装置1300は所定のエラー処理を実行してもよい。   The vehicle interface 11 of the key generation device 1300 and the diagnostic port 1060 of the automobile 1001 are connected. Steps S31 to S38 are executed. Steps S31 to S38 are the same as those in the third example of the management method according to FIG. 7 described above. When the secure boot result “pass or fail” received by the key generation apparatus 1300 from the first ECU 1010 of the automobile 1001 is “pass”, step S51 is executed after step S38. On the other hand, when the secure boot result “pass or fail” is “fail”, the process of FIG. 8 ends. When the secure boot result “pass or fail” is “fail”, the key generation device 1300 may execute a predetermined error process.

(ステップS51)鍵生成装置1300の暗号処理部16は、第1のECU1010のRoot鍵Krcにより、N個の第2のECU(n)1020の各々のRoot鍵Krn、署名鍵Kbn及び期待値Ennを各々に暗号化する。この暗号化によって、N個の第1の暗号化データKrc(Kr1)、Krc(Kr2)、・・・、Krc(KrN)と、N個の第2の暗号化データKrc(Kb1)、Krc(Kb2)、・・・、Krc(KbN)と、N個の第4の暗号化データKrc(E1n)、Krc(E2n)、・・・、Krc(ENn)が生成される。 (Step S51) The cryptographic processing unit 16 of the key generation device 1300 uses the root key Krc of the first ECU 1010 to start the root key Krn, the signature key Kbn, and the expected value Enn of each of the N second ECUs (n) 1020. Is encrypted in each. By this encryption, N pieces of first encrypted data Krc (Kr1), Krc (Kr2),..., Krc (KrN) and N pieces of second encrypted data Krc (Kb1), Krc ( Kb2),..., Krc (KbN) and N pieces of fourth encrypted data Krc (E1n), Krc (E2n),..., Krc (ENn) are generated.

鍵生成装置1300は、車両インタフェース11により、N個の第1の暗号化データKrc(Kr1)、Krc(Kr2)、・・・、Krc(KrN)と、N個の第2の暗号化データKrc(Kb1)、Krc(Kb2)、・・・、Krc(KbN)と、N個の第4の暗号化データKrc(E1n)、Krc(E2n)、・・・、Krc(ENn)とを自動車1001の第1のECU1010に送信する。自動車1001の第1のECU1010は、インタフェース部20により、鍵生成装置1300から診断ポート1060を介して、N個の第1の暗号化データKrc(Kr1)、Krc(Kr2)、・・・、Krc(KrN)と、N個の第2の暗号化データKrc(Kb1)、Krc(Kb2)、・・・、Krc(KbN)と、N個の第4の暗号化データKrc(E1n)、Krc(E2n)、・・・、Krc(ENn)とを受信する。   The key generation device 1300 uses the vehicle interface 11 to generate N pieces of first encrypted data Krc (Kr1), Krc (Kr2),..., Krc (KrN) and N pieces of second encrypted data Krc. (Kb1), Krc (Kb2),..., Krc (KbN) and N pieces of fourth encrypted data Krc (E1n), Krc (E2n),..., Krc (ENn) To the first ECU 1010. The first ECU 1010 of the automobile 1001 uses the interface unit 20 to transmit N pieces of first encrypted data Krc (Kr1), Krc (Kr2),..., Krc from the key generation device 1300 via the diagnostic port 1060. (KrN), N pieces of second encrypted data Krc (Kb1), Krc (Kb2),..., Krc (KbN), and N pieces of fourth encrypted data Krc (E1n), Krc ( E2n),..., Krc (ENn).

(ステップS52)第1のECU1010の制御部21は、N個の第1の暗号化データKrc(Kr1)、Krc(Kr2)、・・・、Krc(KrN)と、N個の第2の暗号化データKrc(Kb1)、Krc(Kb2)、・・・、Krc(KbN)と、N個の第4の暗号化データKrc(E1n)、Krc(E2n)、・・・、Krc(ENn)とをHSM1012に渡す。HSM1012の暗号処理部32は、記憶部1013に格納しているRoot鍵Krcにより、N個の第1の暗号化データKrc(Kr1)、Krc(Kr2)、・・・、Krc(KrN)と、N個の第2の暗号化データKrc(Kb1)、Krc(Kb2)、・・・、Krc(KbN)と、N個の第4の暗号化データKrc(E1n)、Krc(E2n)、・・・、Krc(ENn)とを各々に復号する。この復号によって、N個のRoot鍵Kr1、Kr2、・・・、KrNと、N個の署名鍵Kb1、Kb2、・・・、KbNと、N個の期待値E1n、E2n、・・・、ENnとが取得される。HSM1012は、該取得したN個のRoot鍵Kr1、Kr2、・・・、KrNと、N個の署名鍵Kb1、Kb2、・・・、KbNと、N個の期待値E1n、E2n、・・・、ENnとを記憶部1013に格納する。 (Step S52) The control unit 21 of the first ECU 1010 includes N pieces of first encrypted data Krc (Kr1), Krc (Kr2),..., Krc (KrN), and N pieces of second encryption data. Data Krc (Kb1), Krc (Kb2),..., Krc (KbN) and N pieces of fourth encrypted data Krc (E1n), Krc (E2n),..., Krc (ENn) To HSM1012. The encryption processing unit 32 of the HSM 1012 uses the Root key Krc stored in the storage unit 1013 to generate N pieces of first encrypted data Krc (Kr1), Krc (Kr2),..., Krc (KrN), N pieces of second encrypted data Krc (Kb1), Krc (Kb2),..., Krc (KbN) and N pieces of fourth encrypted data Krc (E1n), Krc (E2n),. Decrypt Krc (ENn) into each. By this decryption, N root keys Kr1, Kr2,..., KrN, N signature keys Kb1, Kb2,..., KbN and N expected values E1n, E2n,. And are acquired. The HSM 1012 acquires the N root keys Kr1, Kr2,..., KrN, the N signature keys Kb1, Kb2,..., KbN, and the N expected values E1n, E2n,. , ENn are stored in the storage unit 1013.

次いでステップS53及びステップS54が実行される。ステップS53は、図6に係る管理方法の例2のステップS24と同じである。ステップS54は、図6に係る管理方法の例2のステップS25と同じである。次いでステップS55が実行される。   Next, step S53 and step S54 are executed. Step S53 is the same as step S24 of the management method example 2 according to FIG. Step S54 is the same as step S25 of the management method example 2 according to FIG. Next, step S55 is executed.

(ステップS55)第1のECU1010のHSM1012の暗号処理部32は、第2のECU(1)1020のRoot鍵Kr1により第2のECU(1)1020の署名鍵Kb1及び期待値E1nを各々に暗号化して、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を生成する。HSM1012は、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を制御部21に渡す。制御部21は、インタフェース部20により、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を、CAN1030を介して第2のECU(1)1020に送信する。第2のECU(1)1020は、インタフェース部40により、第1のECU1010からCAN1030を介して、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を受信する。 (Step S55) The encryption processing unit 32 of the HSM 1012 of the first ECU 1010 encrypts the signature key Kb1 and the expected value E1n of the second ECU (1) 1020 with the Root key Kr1 of the second ECU (1) 1020, respectively. To generate second encrypted data Kr1 (Kb1) and fourth encrypted data Kr1 (E1n). The HSM 1012 passes the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) to the control unit 21. The control unit 21 uses the interface unit 20 to transmit the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) to the second ECU (1) 1020 via the CAN 1030. The second ECU (1) 1020 receives the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) from the first ECU 1010 via the CAN 1030 by the interface unit 40.

(ステップS56)第2のECU(1)1020の制御部41は、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)をSHE1022に渡す。SHE1022の暗号処理部52は、記憶部1023に格納しているRoot鍵Kr1により第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を各々に復号して、署名鍵Kb1及び期待値E1nを取得する。SHE1022は、該取得した署名鍵Kb1を記憶部1023に格納する。SHE1022は、記憶部1023において、該取得した署名鍵Kb1を初期署名鍵Kbiに代えて格納してもよい。また、SHE1022は、該取得した期待値E1nをセキュアブート処理で使用する期待値に設定する。 (Step S56) The control unit 41 of the second ECU (1) 1020 passes the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) to the SHE1022. The encryption processing unit 52 of the SHE 1022 decrypts the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) with the Root key Kr1 stored in the storage unit 1023, respectively. Kb1 and expected value E1n are acquired. The SHE 1022 stores the acquired signature key Kb1 in the storage unit 1023. The SHE 1022 may store the obtained signature key Kb1 in the storage unit 1023 in place of the initial signature key Kbi. Further, the SHE 1022 sets the acquired expected value E1n to an expected value used in the secure boot process.

次いでステップS57が実行される。ステップS57は、図7に係る管理方法の例3のステップS43と同じである。次いでステップS58が実行される。   Next, step S57 is executed. Step S57 is the same as step S43 of the management method example 3 according to FIG. Step S58 is then executed.

(ステップS58)第2のECU(1)1020の制御部41は、インタフェース部40により、セキュアブート結果として測定値E1n_xの検証結果「合格又は不合格」を、CAN1030を介して第1のECU1010に送信する。第1のECU1010は、インタフェース部20により、第2のECU(1)1020からCAN1030を介して、セキュアブート結果「合格又は不合格」を受信する。 (Step S58) The control unit 41 of the second ECU (1) 1020 sends the verification result “pass or fail” of the measurement value E1n_x as the secure boot result to the first ECU 1010 via the CAN 1030 by the interface unit 40. Send. The first ECU 1010 receives the secure boot result “pass or fail” from the second ECU (1) 1020 via the CAN 1030 via the interface unit 20.

第1のECU1010が第2のECU(1)1020から受信したセキュアブート結果「合格又は不合格」が「合格」である場合には、ステップS59に進む。一方、該セキュアブート結果「合格又は不合格」が不合格である場合には、第2のECU(1)1020について図8の処理を終了する。よって、第2のECU(1)1020からのセキュアブート結果「合格又は不合格」が不合格である場合には、第2のECU(1)1020についてステップS59は実行されない。また、第2のECU(1)1020からのセキュアブート結果「合格又は不合格」が不合格である場合には、第1のECU1010は所定のエラー処理を実行してもよい。   When the secure boot result “pass or fail” received by the first ECU 1010 from the second ECU (1) 1020 is “pass”, the process proceeds to step S59. On the other hand, if the secure boot result “pass or fail” is unsuccessful, the process of FIG. 8 is terminated for the second ECU (1) 1020. Therefore, when the secure boot result “pass or fail” from the second ECU (1) 1020 is unsuccessful, step S59 is not executed for the second ECU (1) 1020. When the secure boot result “pass or fail” from the second ECU (1) 1020 is unsuccessful, the first ECU 1010 may execute a predetermined error process.

(ステップS59)第1のECU1010のHSM1012の暗号処理部32は、第2のECU(1)1020のRoot鍵Kr1により車内鍵Kvを暗号化して暗号化データKr1(Kv)を生成する。HSM1012は、暗号化データKr1(Kv)を制御部21に渡す。制御部21は、インタフェース部20により、暗号化データKr1(Kv)を、CAN1030を介して第2のECU(1)1020に送信する。第2のECU(1)1020は、インタフェース部40により、第1のECU1010からCAN1030を介して、暗号化データKr1(Kv)を受信する。 (Step S59) The encryption processing unit 32 of the HSM 1012 of the first ECU 1010 encrypts the in-vehicle key Kv with the Root key Kr1 of the second ECU (1) 1020 to generate encrypted data Kr1 (Kv). The HSM 1012 passes the encrypted data Kr1 (Kv) to the control unit 21. The control unit 21 uses the interface unit 20 to transmit the encrypted data Kr1 (Kv) to the second ECU (1) 1020 via the CAN 1030. The second ECU (1) 1020 receives the encrypted data Kr1 (Kv) from the first ECU 1010 via the CAN 1030 by the interface unit 40.

(ステップS60)第2のECU(1)1020の制御部41は、暗号化データKr1(Kv)をSHE1022に渡す。SHE1022の暗号処理部52は、記憶部1023に格納しているRoot鍵Kr1により暗号化データKr1(Kv)を復号して、車内鍵Kvを取得する。SHE1022は、該取得した車内鍵Kvを記憶部1023に格納する。 (Step S60) The control unit 41 of the second ECU (1) 1020 passes the encrypted data Kr1 (Kv) to the SHE1022. The encryption processing unit 52 of the SHE 1022 decrypts the encrypted data Kr1 (Kv) with the Root key Kr1 stored in the storage unit 1023, and acquires the in-vehicle key Kv. The SHE 1022 stores the acquired in-vehicle key Kv in the storage unit 1023.

上記ステップS53からステップS60までは、自動車1001に搭載されている全ての第2のECU(n)1020に対して同様に実行される。   Steps S53 to S60 are executed in the same manner for all second ECUs (n) 1020 mounted on the automobile 1001.

なお、上記ステップS53からステップS60までは、自動車1001内に閉じた処理である。このため、ステップS53からステップS60までは、鍵生成装置1300の車両インタフェース11と自動車1001の診断ポート1060とは接続されていなくてもよい。   Steps S53 to S60 are processes closed in the automobile 1001. For this reason, from step S53 to step S60, the vehicle interface 11 of the key generation device 1300 and the diagnostic port 1060 of the automobile 1001 do not have to be connected.

上述した管理方法の例4によれば、管理方法の例3と同様に、自動車1001に搭載されているECUのECUコードの期待値を鍵生成装置1300が生成してECUに供給する。そして、ECUが、自己のECUコードの測定値を、鍵生成装置1300から供給された期待値に基づいて検証する。そして、本管理方法の例4によれば、第1のECU1010による検証結果を鍵生成装置1300に通知することにより、自動車1001に搭載されている第1のECU1010の真贋判定を行う。また、第2のECU(n)1020による検証結果を第1のECU1010に通知することにより、自動車1001に搭載されている第2のECU(n)1020の真贋判定を行う。これにより、自動車1001に搭載されているECUの信頼性が向上する効果を奏する。また、第1のECU1010がN個の第2のECU(n)1020の真贋判定を行うことにより、鍵生成装置1300と自動車1001とが接続される時間を、管理方法の例3よりも短縮できる。   According to the management method example 4 described above, as in the management method example 3, the key generation device 1300 generates the expected value of the ECU code of the ECU mounted on the automobile 1001 and supplies the ECU to the ECU. Then, the ECU verifies the measured value of its own ECU code based on the expected value supplied from the key generation device 1300. Then, according to Example 4 of the present management method, the authentication result of the first ECU 1010 mounted on the automobile 1001 is determined by notifying the key generation device 1300 of the verification result by the first ECU 1010. Further, the verification result of the second ECU (n) 1020 is notified to the first ECU 1010, whereby the authenticity of the second ECU (n) 1020 mounted on the automobile 1001 is determined. Thereby, there is an effect that the reliability of the ECU mounted on the automobile 1001 is improved. Further, when the first ECU 1010 determines the authenticity of the N second ECUs (n) 1020, the time during which the key generation device 1300 and the automobile 1001 are connected can be shortened compared to the management method example 3. .

また、管理方法の例4によれば、第1のECU1010は、第2のECU(n)1020に、鍵生成装置1300から送信されるN個の第1の暗号化データKrc(Kr1)、Krc(Kr2)、・・・、Krc(KrN)と、N個の第2の暗号化データKrc(Kb1)、Krc(Kb2)、・・・、Krc(KbN)と、N個の第4の暗号化データKrc(E1n)、Krc(E2n)、・・・、Krc(ENn)とを中継する機能(ステップS52、S53及びS55に対応する機能)を有する。これにより、鍵生成装置1300と自動車1001とが接続される時間を、管理方法の例3よりも短縮できる。   Also, according to the management method example 4, the first ECU 1010 transmits the N pieces of first encrypted data Krc (Kr1) and Krc transmitted from the key generation device 1300 to the second ECU (n) 1020. , Krc (KrN), N pieces of second encrypted data Krc (Kb1), Krc (Kb2),..., Krc (KbN), and N fourth ciphers .., Krc (ENn) (functions corresponding to steps S52, S53, and S55) are relayed to the data Krc (E1n), Krc (E2n),. Thereby, the time for which the key generation device 1300 and the automobile 1001 are connected can be shortened compared to the third example of the management method.

<管理方法の例5>
図9は、本実施形態に係る管理方法の例5のシーケンス図である。図9を参照して本実施形態に係る管理方法の例5を説明する。鍵生成装置1300は、例えば、自動車1001の製造工場に設けられている。鍵生成装置1300の車両インタフェース11は、該製造工場で製造中の自動車1001の診断ポート1060に接続される。
<Example 5 of management method>
FIG. 9 is a sequence diagram of Example 5 of the management method according to the present embodiment. An example 5 of the management method according to the present embodiment will be described with reference to FIG. The key generation device 1300 is provided, for example, in a manufacturing factory for the automobile 1001. The vehicle interface 11 of the key generation device 1300 is connected to the diagnostic port 1060 of the automobile 1001 being manufactured at the manufacturing factory.

図9には、説明の便宜上、自動車1001に搭載される第2のECU(n)1020のうち、1個の第2のECU(1)1020のみを示している。但し、nは1からNまでの整数である。Nは、自動車1001に搭載されている第2のECU1020のうち、鍵配信対象の第2のECU1020の個数である。   For convenience of explanation, FIG. 9 shows only one second ECU (1) 1020 out of the second ECU (n) 1020 mounted on the automobile 1001. However, n is an integer from 1 to N. N is the number of second ECUs 1020 targeted for key distribution among the second ECUs 1020 mounted on the automobile 1001.

鍵生成装置1300は、図5に係る管理方法の例1と同様に、マスタ鍵Master_Secretと、ECUのECUコードと、初期Root鍵Kriとを予め記憶部12に格納している。ECUのECUコードは、ECUの初期ECUコードを含む。   The key generation device 1300 stores the master key Master_Secret, the ECU's ECU code, and the initial root key Kri in the storage unit 12 in advance as in the management method example 1 shown in FIG. The ECU code of the ECU includes an initial ECU code of the ECU.

第1のECU1010のHSM1012は、図5に係る管理方法の例1と同様に、初期Root鍵Kri及び初期署名鍵Kbiを予め記憶部1013に格納している。本管理方法の例5では、第1のECU1010のHSM1012は、さらに初期暗号鍵Keciを予め記憶部1013に格納している。第2のECU1020のSHE1022は、図5に係る管理方法の例1と同様に、初期Root鍵Kri及び初期署名鍵Kbiを予め記憶部1023に格納している。本管理方法の例5では、第2のECU1020のSHE1022は、さらに初期暗号鍵Keeiを予め記憶部1023に格納している。   The HSM 1012 of the first ECU 1010 stores the initial root key Kri and the initial signature key Kbi in the storage unit 1013 in advance as in the management method example 1 according to FIG. In Example 5 of this management method, the HSM 1012 of the first ECU 1010 further stores an initial encryption key Keci in the storage unit 1013 in advance. The SHE 1022 of the second ECU 1020 stores the initial root key Kri and the initial signature key Kbi in the storage unit 1023 in advance as in the management method example 1 shown in FIG. In Example 5 of this management method, the SHE 1022 of the second ECU 1020 further stores the initial encryption key Keei in the storage unit 1023 in advance.

第1のECU1010のメイン演算器1011は、図5に係る管理方法の例1と同様に、初期ECUコードEciを予め記憶部22に格納している。第2のECU(n)1020のメイン演算器1021は、図5に係る管理方法の例1と同様に、初期ECUコードEniを予め記憶部42に格納している。   The main computing unit 1011 of the first ECU 1010 stores the initial ECU code Eci in the storage unit 22 in advance, as in the management method example 1 according to FIG. The main computing unit 1021 of the second ECU (n) 1020 stores the initial ECU code Eni in the storage unit 42 in advance, as in the management method example 1 according to FIG.

以下、鍵生成装置1300の車両インタフェース11と自動車1001の診断ポート1060とは接続されている。   Hereinafter, the vehicle interface 11 of the key generation device 1300 and the diagnosis port 1060 of the automobile 1001 are connected.

(ステップS71)鍵生成装置1300において、鍵生成部15は、自動車1001に搭載されているECUのRoot鍵と署名鍵とを生成する。本実施形態では、鍵生成部15は、第1のECU1010のRoot鍵Krc及び署名鍵Kbcと、N個の第2のECU(n)1020の各々のRoot鍵Krn及び署名鍵Kbnとを生成する。記憶部12は、第1のECU1010のRoot鍵Krc及び署名鍵Kbcと、N個の第2のECU(n)1020の各々のRoot鍵Krn及び署名鍵Kbnとを格納する。Root鍵Krc及びKrnは、第1の鍵に対応する。署名鍵Kbc及びKbnは、第2の鍵に対応する。Root鍵Krc及びKrn、並びに、署名鍵Kbc及びKbnの生成方法は、図5に係る管理方法の例1のステップS1と同じである。 (Step S <b> 71) In the key generation device 1300, the key generation unit 15 generates a root key and a signature key for the ECU mounted on the automobile 1001. In the present embodiment, the key generation unit 15 generates the root key Krc and signature key Kbc of the first ECU 1010, and the root key Krn and signature key Kbn of each of the N second ECUs (n) 1020. . The storage unit 12 stores the root key Krc and signature key Kbc of the first ECU 1010, and the root key Krn and signature key Kbn of each of the N second ECUs (n) 1020. Root keys Krc and Krn correspond to the first key. The signature keys Kbc and Kbn correspond to the second key. The generation method of the root keys Krc and Krn and the signature keys Kbc and Kbn is the same as step S1 of the management method example 1 according to FIG.

本管理方法の例5では、鍵生成部15は、さらに、自動車1001に搭載されているECUの暗号鍵を生成する。暗号鍵は、Root鍵及び署名鍵とは異なるように生成される。例えば、Root鍵用の変数Nkの値をNk_1とし、署名鍵用の変数Nkの値をNk_2とし、暗号鍵用の変数Nkの値をNk_3とする。鍵生成部15は、マスタ鍵Master_SecretとECUのECU識別子ECU_IDとを使用して、
Root鍵=ダイジェスト(Master_Secret、ECU_ID、Nk_1)、
署名鍵=ダイジェスト(Master_Secret、ECU_ID、Nk_2)、
暗号鍵=ダイジェスト(Master_Secret、ECU_ID、Nk_3)、
により、Root鍵と署名鍵と暗号鍵とを異なる鍵として生成する。鍵生成部15は、上述した第1のECU1010のRoot鍵Krc及び署名鍵KbcとN個の第2のECU(n)1020の各々のRoot鍵Krn及び署名鍵Kbnとに加えて、さらに、第1のECU1010の暗号鍵Kecと、N個の第2のECU(n)1020の各々の暗号鍵Kenとを生成する。記憶部12は、上述した第1のECU1010のRoot鍵Krc及び署名鍵KbcとN個の第2のECU(n)1020の各々のRoot鍵Krn及び署名鍵Kbnとに加えて、さらに、第1のECU1010の暗号鍵Kecと、N個の第2のECU(n)1020の各々の暗号鍵Kenとを格納する。暗号鍵Kec及びKenは、第3の鍵に対応する。
In Example 5 of this management method, the key generation unit 15 further generates an encryption key for the ECU mounted on the automobile 1001. The encryption key is generated differently from the Root key and the signature key. For example, the value of the root key variable Nk is Nk_1, the value of the signature key variable Nk is Nk_2, and the value of the encryption key variable Nk is Nk_3. The key generation unit 15 uses the master key Master_Secret and the ECU identifier ECU_ID of the ECU,
Root key = Digest (Master_Secret, ECU_ID, Nk_1),
Signature key = Digest (Master_Secret, ECU_ID, Nk_2),
Encryption key = digest (Master_Secret, ECU_ID, Nk_3),
Thus, the Root key, the signature key, and the encryption key are generated as different keys. In addition to the above-described root key Krc and signature key Kbc of the first ECU 1010 and the root key Krn and signature key Kbn of each of the N second ECU (n) 1020, the key generation unit 15 further includes the first The encryption key Kec of one ECU 1010 and the encryption keys Ken of each of the N second ECU (n) 1020 are generated. In addition to the above-described root key Krc and signature key Kbc of the first ECU 1010 and the root key Krn and signature key Kbn of each of the N second ECU (n) 1020, the storage unit 12 further includes a first key. The encryption key Kec of the ECU 1010 and the encryption keys Ken of the N second ECU (n) 1020 are stored. The encryption keys Kec and Ken correspond to the third key.

期待値計算部13は、第1のECU1010の署名鍵Kbcにより、第1のECU1010の初期ECUコードEci(CGWコード)のCMACを計算する。この計算結果のCMACを期待値Ecnと称する。期待値計算部13は、第2のECU(n)1020の署名鍵Kbnにより、第2のECU(n)1020の初期ECUコードEni(ECUnコード)のCMACを計算する。この計算結果のCMACを期待値Ennと称する。これにより、第1のECU1010の初期ECUコードEci(CGWコード)についての期待値Ecnと、N個の第2のECU(n)1020の初期ECUコードEni(ECUnコード)についての各々の期待値E1n、E2n、・・・、ENnとが、期待値計算部13によって生成された。記憶部12は、第1のECU1010の初期ECUコードEci(CGWコード)についての期待値Ecnと、N個の第2のECU(n)1020の初期ECUコードEni(ECUnコード)についての各々の期待値E1n、E2n、・・・、ENnとを格納する。   The expected value calculation unit 13 calculates the CMAC of the initial ECU code Eci (CGW code) of the first ECU 1010 using the signature key Kbc of the first ECU 1010. The CMAC resulting from this calculation is referred to as an expected value Ecn. The expected value calculation unit 13 calculates the CMAC of the initial ECU code Eni (ECUn code) of the second ECU (n) 1020 using the signature key Kbn of the second ECU (n) 1020. The CMAC resulting from this calculation is referred to as an expected value Enn. Thereby, the expected value Ecn for the initial ECU code Eci (CGW code) of the first ECU 1010 and the expected value E1n for the initial ECU code Eni (ECUn code) of the N second ECU (n) 1020 , E2n,..., ENn are generated by the expected value calculator 13. The storage unit 12 has an expected value Ecn for the initial ECU code Eci (CGW code) of the first ECU 1010 and each expected value for the initial ECU code Eni (ECU code) of the N second ECUs (n) 1020. Stores the values E1n, E2n,..., ENn.

次いでステップS72及びステップS73が実行される。ステップS72は、図5に係る管理方法の例1のステップS2と同じである。ステップS73は、図5に係る管理方法の例1のステップS3と同じである。次いでステップS74が実行される。   Next, Step S72 and Step S73 are executed. Step S72 is the same as step S2 of the management method example 1 according to FIG. Step S73 is the same as step S3 of the management method example 1 according to FIG. Next, step S74 is executed.

(ステップS74)鍵生成装置1300の暗号処理部16は、第1のECU1010のRoot鍵Krcにより第1のECU1010の暗号鍵Kecを暗号化して、第5の暗号化データKrc(Kec)を生成する。検証部14は、乱数Nonceを発生させる。記憶部12は、該乱数Nonceを格納する。鍵生成装置1300は、車両インタフェース11により、第5の暗号化データKrc(Kec)及び乱数Nonceを自動車1001の第1のECU1010に送信する。自動車1001の第1のECU1010は、インタフェース部20により、鍵生成装置1300から診断ポート1060を介して、第5の暗号化データKrc(Kec)及び乱数Nonceを受信する。 (Step S74) The encryption processing unit 16 of the key generation device 1300 encrypts the encryption key Kec of the first ECU 1010 with the Root key Krc of the first ECU 1010 to generate fifth encrypted data Krc (Kec). . The verification unit 14 generates a random number Nonce. The storage unit 12 stores the random number Nonce. The key generation device 1300 transmits the fifth encrypted data Krc (Kec) and the random number Nonce to the first ECU 1010 of the automobile 1001 through the vehicle interface 11. The first ECU 1010 of the automobile 1001 receives the fifth encrypted data Krc (Kec) and the random number Nonce from the key generation device 1300 via the diagnostic port 1060 by the interface unit 20.

(ステップS75)第1のECU1010の制御部21は、第5の暗号化データKrc(Kec)をHSM1012に渡す。HSM1012の暗号処理部32は、記憶部1013に格納しているRoot鍵Krcにより第5の暗号化データKrc(Kec)を復号して、暗号鍵Kecを取得する。HSM1012は、該取得した暗号鍵Kecを記憶部1013に格納する。HSM1012は、記憶部1013において、該取得した暗号鍵Kecを初期暗号鍵Keciに代えて格納してもよい。本実施形態では、暗号鍵Kecは、HSM1012が実行するセキュアブート処理において測定値の検証が合格した場合に使用することができる暗号鍵として設定される。したがって、暗号鍵Kecは、HSM1012が実行するセキュアブート処理において測定値の検証が不合格になった場合には使用することができない。 (Step S75) The control unit 21 of the first ECU 1010 passes the fifth encrypted data Krc (Kec) to the HSM 1012. The encryption processing unit 32 of the HSM 1012 decrypts the fifth encrypted data Krc (Kec) using the Root key Krc stored in the storage unit 1013, and acquires the encryption key Kec. The HSM 1012 stores the acquired encryption key Kec in the storage unit 1013. The HSM 1012 may store the acquired encryption key Kec in the storage unit 1013 instead of the initial encryption key Keci. In the present embodiment, the encryption key Kec is set as an encryption key that can be used when the verification of the measurement value passes in the secure boot process executed by the HSM 1012. Therefore, the encryption key Kec cannot be used when the measurement value verification fails in the secure boot process executed by the HSM 1012.

記憶部22は、乱数Nonceを格納する。乱数Nonceの格納場所は、記憶部22の記憶領域のうち、セキュアブートの測定対象外の不揮発性記憶領域である。   The storage unit 22 stores a random number Nonce. The storage location of the random number Nonce is a non-volatile storage area outside the measurement target of the secure boot in the storage area of the storage unit 22.

(ステップS76)鍵生成装置1300の暗号処理部16は、第1のECU1010のRoot鍵Krcにより第1のECU1010の署名鍵Kbc及び期待値Ecnを各々に暗号化して、第2の暗号化データKrc(Kbc)及び第4の暗号化データKrc(Ecn)を生成する。鍵生成装置1300は、車両インタフェース11により、第2の暗号化データKrc(Kbc)及び第4の暗号化データKrc(Ecn)を自動車1001の第1のECU1010に送信する。自動車1001の第1のECU1010は、インタフェース部20により、鍵生成装置1300から診断ポート1060を介して、第2の暗号化データKrc(Kbc)及び第4の暗号化データKrc(Ecn)を受信する。 (Step S76) The encryption processing unit 16 of the key generation device 1300 encrypts the signature key Kbc and the expected value Ecn of the first ECU 1010 with the Root key Krc of the first ECU 1010, respectively, and the second encrypted data Krc. (Kbc) and fourth encrypted data Krc (Ecn) are generated. The key generation device 1300 transmits the second encrypted data Krc (Kbc) and the fourth encrypted data Krc (Ecn) to the first ECU 1010 of the automobile 1001 through the vehicle interface 11. The first ECU 1010 of the automobile 1001 receives the second encrypted data Krc (Kbc) and the fourth encrypted data Krc (Ecn) from the key generation device 1300 via the diagnostic port 1060 by the interface unit 20. .

(ステップS77)第1のECU1010の制御部21は、第2の暗号化データKrc(Kbc)及び第4の暗号化データKrc(Ecn)をHSM1012に渡す。HSM1012の暗号処理部32は、記憶部1013に格納しているRoot鍵Krcにより第2の暗号化データKrc(Kbc)及び第4の暗号化データKrc(Ecn)を各々に復号して、署名鍵Kbc及び期待値Ecnを取得する。HSM1012は、該取得した署名鍵Kbcを記憶部1013に格納する。HSM1012は、記憶部1013において、該取得した署名鍵Kbcを初期署名鍵Kbiに代えて格納してもよい。また、HSM1012は、該取得した期待値Ecnをセキュアブート処理で使用する期待値に設定する。 (Step S77) The control unit 21 of the first ECU 1010 passes the second encrypted data Krc (Kbc) and the fourth encrypted data Krc (Ecn) to the HSM 1012. The encryption processing unit 32 of the HSM 1012 decrypts the second encrypted data Krc (Kbc) and the fourth encrypted data Krc (Ecn) with the Root key Krc stored in the storage unit 1013, respectively. Kbc and expected value Ecn are acquired. The HSM 1012 stores the acquired signature key Kbc in the storage unit 1013. The HSM 1012 may store the acquired signature key Kbc in the storage unit 1013 instead of the initial signature key Kbi. Also, the HSM 1012 sets the acquired expected value Ecn to an expected value used in the secure boot process.

(ステップS78)第1のECU1010の制御部21は、記憶部22に格納している初期ECUコードEciをHSM1012に渡して、セキュアブート処理を実行させる。セキュアブート処理において、HSM1012の測定部33は、記憶部1013に格納している署名鍵Kbcにより、初期ECUコードEciの測定値を計算する。本実施形態では、測定値の一例として、CMACを使用する。よって、測定部33は、記憶部1013に格納している署名鍵Kbcにより、初期ECUコードEciのCMACを計算する。この計算結果のCMACを測定値Ecn_xと称する。 (Step S78) The control unit 21 of the first ECU 1010 passes the initial ECU code Eci stored in the storage unit 22 to the HSM 1012 to execute the secure boot process. In the secure boot process, the measurement unit 33 of the HSM 1012 calculates the measurement value of the initial ECU code Eci using the signature key Kbc stored in the storage unit 1013. In this embodiment, CMAC is used as an example of the measurement value. Therefore, the measurement unit 33 calculates the CMAC of the initial ECU code Eci using the signature key Kbc stored in the storage unit 1013. The CMAC resulting from this calculation is referred to as a measured value Ecn_x.

測定部33は、測定値Ecn_xと期待値Ecnとを比較し、両者が一致するか否かを判断する。この判断の結果、両者が一致する場合には測定値Ecn_xの検証が合格である。測定値Ecn_xの検証が合格した場合、暗号鍵Kecが使用可能になる。一方、両者が一致しない場合には測定値Ecn_xの検証が不合格である。測定値Ecn_xの検証が不合格になった場合、暗号鍵Kecは使用することができない。HSM1012は、測定値Ecn_xの検証結果「合格又は不合格」を制御部21に渡す。   The measuring unit 33 compares the measured value Ecn_x with the expected value Ecn and determines whether or not they match. As a result of this determination, if both match, the verification of the measured value Ecn_x is acceptable. If the verification of the measurement value Ecn_x passes, the encryption key Kec can be used. On the other hand, if the two do not match, the verification of the measurement value Ecn_x fails. If the verification of the measurement value Ecn_x fails, the encryption key Kec cannot be used. The HSM 1012 passes the verification result “pass or fail” of the measurement value Ecn_x to the control unit 21.

(ステップS79)制御部21は、HSM1012から受け取った測定値Ecn_xの検証結果が「合格」である場合、記憶部22に格納している乱数NonceをHSM1012に渡して、暗号鍵Kecにより暗号化を実行させる。HSM1012の暗号処理部32は、記憶部1013に格納している暗号鍵Kecにより乱数Nonceを暗号化して、第6の暗号化データKec(Nonce)を生成する。HSM1012は、第6の暗号化データKec(Nonce)を制御部21に渡す。一方、制御部21は、HSM1012から受け取った測定値Ecn_xの検証結果が「不合格」である場合には、乱数Nonceの暗号化を実施しない。 (Step S79) When the verification result of the measurement value Ecn_x received from the HSM 1012 is “pass”, the control unit 21 passes the random number Nonce stored in the storage unit 22 to the HSM 1012 and performs encryption using the encryption key Kec. Let it run. The encryption processing unit 32 of the HSM 1012 encrypts the random number Nonce with the encryption key Kec stored in the storage unit 1013 to generate sixth encrypted data Kec (Nonce). The HSM 1012 passes the sixth encrypted data Kec (Nonce) to the control unit 21. On the other hand, when the verification result of the measurement value Ecn_x received from the HSM 1012 is “fail”, the control unit 21 does not encrypt the random number Nonce.

制御部21は、インタフェース部20により、セキュアブート結果として測定値Ecn_xの検証結果「合格又は不合格」を、診断ポート1060を介して、鍵生成装置1300に送信する。このとき、制御部21は、測定値Ecn_xの検証結果が「合格」である場合には、セキュアブート結果「合格(OK)」に第6の暗号化データKec(Nonce)を含める。鍵生成装置1300は、車両インタフェース11により、自動車1001の第1のECU1010から診断ポート1060を介して、第1のECU1010のセキュアブート結果「合格又は不合格」を受信する。
なお、セキュアブート結果「合格(OK)」に、乱数Nonceを暗号化しないでそのまま含めてもよい。また、セキュアブート結果「合格(OK)」に、乱数Nonceと乱数NonceのCMACとを含めてもよい。乱数NonceのCMACは、暗号鍵Kecにより、計算されてもよい。セキュアブート結果「合格(OK)」に、乱数Nonceと乱数NonceのCMACとを含める場合、乱数Nonce若しくは乱数NonceのCMACのいずれか一方、又は、乱数Nonceと乱数NonceのCMACの両方を暗号化してもよい。
The control unit 21 transmits the verification result “pass or fail” of the measurement value Ecn_x as the secure boot result to the key generation device 1300 via the diagnostic port 1060 by the interface unit 20. At this time, when the verification result of the measurement value Ecn_x is “pass”, the control unit 21 includes the sixth encrypted data Kec (Nonce) in the secure boot result “pass (OK)”. The key generation device 1300 receives the secure boot result “pass or fail” of the first ECU 1010 from the first ECU 1010 of the automobile 1001 via the diagnosis port 1060 by the vehicle interface 11.
Note that the random number Nonce may be included in the secure boot result “pass (OK)” without encryption. Further, the random number Nonce and the CMAC of the random number Nonce may be included in the secure boot result “pass (OK)”. The CMAC of the random number Nonce may be calculated using the encryption key Kec. When the random number Nonce and the CMAC of the random number Nonce are included in the secure boot result “pass (OK)”, either the random number Nonce or the random number Nonce CMAC or both the random number Nonce and the random number Nonce CMAC are encrypted. Also good.

(ステップS80)鍵生成装置1300の暗号処理部16は、第1のECU1010のセキュアブート結果「合格(OK)」に含まれる第6の暗号化データKec(Nonce)を、第1のECU1010の暗号鍵Kecにより復号して復号データNonceを取得する。検証部14は、復号データNonceと記憶部12に格納されている乱数Nonceとを比較し、両者が一致するか否かを判断する。この判断の結果、両者が一致する場合には、第1のECU1010のセキュアブート結果「合格」が正しいと判断する。セキュアブート結果「合格」が正しいと判断された場合にはステップS81に進む。一方、両者が一致しない場合には、第1のECU1010のセキュアブート結果「合格」が正しくないと判断する。セキュアブート結果「合格」が正しくないと判断された場合には、図9の処理を終了する。また、セキュアブート結果「合格」が正しくないと判断された場合には、鍵生成装置1300は所定のエラー処理を実行してもよい。 (Step S80) The encryption processing unit 16 of the key generation device 1300 uses the sixth encrypted data Kec (Nonce) included in the secure boot result “pass (OK)” of the first ECU 1010 as the encryption of the first ECU 1010. Decrypted with the key Kec to obtain decrypted data Nonce. The verification unit 14 compares the decrypted data Nonce with the random number Nonce stored in the storage unit 12 and determines whether or not they match. As a result of this determination, if both match, it is determined that the secure boot result “pass” of the first ECU 1010 is correct. If it is determined that the secure boot result “pass” is correct, the process proceeds to step S81. On the other hand, if the two do not match, it is determined that the secure boot result “pass” of the first ECU 1010 is not correct. If it is determined that the secure boot result “pass” is not correct, the processing in FIG. 9 is terminated. If it is determined that the secure boot result “pass” is not correct, the key generation device 1300 may execute a predetermined error process.

また、鍵生成装置1300が自動車1001の第1のECU1010のセキュアブート結果「不合格」を受信した場合には、図9の処理を終了する。また、セキュアブート結果「不合格」を受信した場合には、鍵生成装置1300は所定のエラー処理を実行してもよい。   Further, when the key generation device 1300 receives the result of “fail” of the secure boot of the first ECU 1010 of the automobile 1001, the processing of FIG. When the secure boot result “fail” is received, the key generation device 1300 may execute a predetermined error process.

(ステップS81)第1のECU1010のHSM1012の鍵生成部34は、車内鍵Kvを生成する。記憶部1013は、車内鍵Kvを格納する。 (Step S81) The key generation unit 34 of the HSM 1012 of the first ECU 1010 generates an in-vehicle key Kv. The storage unit 1013 stores the in-vehicle key Kv.

次いでステップS82及びステップS83が実行される。ステップS82は、図5に係る管理方法の例1のステップS10と同じである。ステップS83は、図5に係る管理方法の例1のステップS11と同じである。次いでステップS84が実行される。   Next, step S82 and step S83 are executed. Step S82 is the same as Step S10 in Example 1 of the management method according to FIG. Step S83 is the same as step S11 of the management method example 1 according to FIG. Next, step S84 is executed.

(ステップS84)鍵生成装置1300の暗号処理部16は、第2のECU(1)1020のRoot鍵Kr1により第2のECU(1)1020の暗号鍵Ke1を暗号化して、第5の暗号化データKr1(Ke1)を生成する。検証部14は、乱数Nonce1を発生させる。記憶部12は、該乱数Nonce1を格納する。鍵生成装置1300は、車両インタフェース11により、第5の暗号化データKr1(Ke1)及び乱数Nonce1を、自動車1001の第1のECU1010経由で第2のECU(1)1020に送信する。自動車1001の第1のECU1010は、インタフェース部20により、鍵生成装置1300から診断ポート1060を介して、第5の暗号化データKr1(Ke1)及び乱数Nonce1を受信すると、該第5の暗号化データKr1(Ke1)及び乱数Nonce1を、インタフェース部20により、CAN1030を介して第2のECU(1)1020に転送する。第2のECU(1)1020は、インタフェース部40により、第1のECU1010からCAN1030を介して、第5の暗号化データKr1(Ke1)及び乱数Nonce1を受信する。 (Step S84) The encryption processing unit 16 of the key generation device 1300 encrypts the encryption key Ke1 of the second ECU (1) 1020 with the Root key Kr1 of the second ECU (1) 1020, and performs the fifth encryption. Data Kr1 (Ke1) is generated. The verification unit 14 generates a random number Nonce1. The storage unit 12 stores the random number Nonce1. The key generation device 1300 transmits the fifth encrypted data Kr1 (Ke1) and the random number Nonce1 to the second ECU (1) 1020 via the first ECU 1010 of the automobile 1001 through the vehicle interface 11. When the first ECU 1010 of the automobile 1001 receives the fifth encrypted data Kr1 (Ke1) and the random number Nonce1 from the key generation device 1300 via the diagnostic port 1060 by the interface unit 20, the fifth encrypted data Kr1 (Ke1) and the random number Nonce1 are transferred to the second ECU (1) 1020 via the CAN 1030 by the interface unit 20. The second ECU (1) 1020 receives the fifth encrypted data Kr1 (Ke1) and the random number Nonce1 from the first ECU 1010 via the CAN 1030 by the interface unit 40.

(ステップS85)第2のECU(1)1020の制御部41は、第5の暗号化データKr1(Ke1)をSHE1022に渡す。SHE1022の暗号処理部52は、記憶部1023に格納しているRoot鍵Kr1により第5の暗号化データKr1(Ke1)を復号して、暗号鍵Ke1を取得する。SHE1022は、該取得した暗号鍵Ke1を記憶部1023に格納する。SHE1022は、記憶部1023において、該取得した暗号鍵Ke1を初期暗号鍵Keeiに代えて格納してもよい。本実施形態では、暗号鍵Ke1は、SHE1022が実行するセキュアブート処理において測定値の検証が合格した場合に使用することができる暗号鍵として設定される。したがって、暗号鍵Ke1は、SHE1022が実行するセキュアブート処理において測定値の検証が不合格になった場合には使用することができない。 (Step S85) The control unit 41 of the second ECU (1) 1020 passes the fifth encrypted data Kr1 (Ke1) to the SHE1022. The encryption processing unit 52 of the SHE 1022 decrypts the fifth encrypted data Kr1 (Ke1) with the Root key Kr1 stored in the storage unit 1023, and acquires the encryption key Ke1. The SHE 1022 stores the acquired encryption key Ke1 in the storage unit 1023. The SHE 1022 may store the acquired encryption key Ke1 in the storage unit 1023 in place of the initial encryption key Keei. In the present embodiment, the encryption key Ke1 is set as an encryption key that can be used when the verification of the measurement value passes in the secure boot process executed by the SHE1022. Therefore, the encryption key Ke1 cannot be used when the measurement value verification fails in the secure boot process executed by the SHE1022.

記憶部42は、乱数Nonce1を格納する。乱数Nonce1の格納場所は、記憶部42の記憶領域のうち、セキュアブートの測定対象外の不揮発性記憶領域である。   The storage unit 42 stores a random number Nonce1. The storage location of the random number Nonce1 is a non-volatile storage area that is not a measurement target of the secure boot in the storage area of the storage unit 42.

(ステップS86)鍵生成装置1300の暗号処理部16は、第2のECU(1)1020のRoot鍵Kr1により第2のECU(1)1020の署名鍵Kb1及び期待値E1nを各々に暗号化して、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を生成する。鍵生成装置1300は、車両インタフェース11により、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を、自動車1001の第1のECU1010経由で第2のECU(1)1020に送信する。自動車1001の第1のECU1010は、インタフェース部20により、鍵生成装置1300から診断ポート1060を介して、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を受信すると、該第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を、インタフェース部20により、CAN1030を介して第2のECU(1)1020に転送する。第2のECU(1)1020は、インタフェース部40により、第1のECU1010からCAN1030を介して、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を受信する。 (Step S86) The encryption processing unit 16 of the key generation device 1300 encrypts the signature key Kb1 and the expected value E1n of the second ECU (1) 1020 with the Root key Kr1 of the second ECU (1) 1020, respectively. Second encrypted data Kr1 (Kb1) and fourth encrypted data Kr1 (E1n) are generated. The key generation device 1300 uses the vehicle interface 11 to transmit the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) to the second ECU (1) via the first ECU 1010 of the automobile 1001. To 1020. When the first ECU 1010 of the automobile 1001 receives the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) from the key generation device 1300 via the diagnostic port 1060 by the interface unit 20. The second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) are transferred by the interface unit 20 to the second ECU (1) 1020 via the CAN 1030. The second ECU (1) 1020 receives the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) from the first ECU 1010 via the CAN 1030 by the interface unit 40.

(ステップS87)第2のECU(1)1020の制御部41は、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)をSHE1022に渡す。SHE1022の暗号処理部52は、記憶部1023に格納しているRoot鍵Kr1により第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を各々に復号して、署名鍵Kb1及び期待値E1nを取得する。SHE1022は、該取得した署名鍵Kb1を記憶部1023に格納する。SHE1022は、記憶部1023において、該取得した署名鍵Kb1を初期署名鍵Kbiに代えて格納してもよい。また、SHE1022は、該取得した期待値E1nをセキュアブート処理で使用する期待値に設定する。 (Step S87) The control unit 41 of the second ECU (1) 1020 passes the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) to the SHE1022. The encryption processing unit 52 of the SHE 1022 decrypts the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) with the Root key Kr1 stored in the storage unit 1023, respectively. Kb1 and expected value E1n are acquired. The SHE 1022 stores the acquired signature key Kb1 in the storage unit 1023. The SHE 1022 may store the obtained signature key Kb1 in the storage unit 1023 in place of the initial signature key Kbi. Further, the SHE 1022 sets the acquired expected value E1n to an expected value used in the secure boot process.

(ステップS88)第2のECU(1)1020の制御部41は、記憶部42に格納している初期ECUコードE1iをSHE1022に渡して、セキュアブート処理を実行させる。セキュアブート処理において、SHE1022の測定部53は、記憶部1023に格納している署名鍵Kb1により、初期ECUコードE1iの測定値を計算する。本実施形態では、測定値の一例として、CMACを使用する。よって、測定部53は、記憶部1023に格納している署名鍵Kb1により、初期ECUコードE1iのCMACを計算する。この計算結果のCMACを測定値E1n_xと称する。 (Step S88) The control unit 41 of the second ECU (1) 1020 passes the initial ECU code E1i stored in the storage unit 42 to the SHE 1022, and executes the secure boot process. In the secure boot process, the measurement unit 53 of the SHE 1022 calculates the measurement value of the initial ECU code E1i using the signature key Kb1 stored in the storage unit 1023. In this embodiment, CMAC is used as an example of the measurement value. Therefore, the measurement unit 53 calculates the CMAC of the initial ECU code E1i using the signature key Kb1 stored in the storage unit 1023. The CMAC resulting from this calculation is referred to as a measured value E1n_x.

測定部53は、測定値E1n_xと期待値E1nとを比較し、両者が一致するか否かを判断する。この判断の結果、両者が一致する場合には測定値E1n_xの検証が合格である。測定値E1n_xの検証が合格した場合、暗号鍵Ke1が使用可能になる。一方、両者が一致しない場合には測定値E1n_xの検証が不合格である。測定値E1n_xの検証が不合格になった場合、暗号鍵Ke1は使用することができない。SHE1022は、測定値E1n_xの検証結果「合格又は不合格」を制御部41に渡す。   The measuring unit 53 compares the measured value E1n_x with the expected value E1n, and determines whether or not they match. As a result of this determination, if both match, the verification of the measured value E1n_x is acceptable. If the verification of the measured value E1n_x passes, the encryption key Ke1 can be used. On the other hand, if the two do not match, the verification of the measured value E1n_x fails. When the verification of the measurement value E1n_x fails, the encryption key Ke1 cannot be used. The SHE 1022 passes the verification result “pass or fail” of the measurement value E1n_x to the control unit 41.

(ステップS89)制御部41は、SHE1022から受け取った測定値E1n_xの検証結果が「合格」である場合、記憶部42に格納している乱数Nonce1をSHE1022に渡して、暗号鍵Ke1により暗号化を実行させる。SHE1022の暗号処理部52は、記憶部1023に格納している暗号鍵Ke1により乱数Nonce1を暗号化して、第6の暗号化データKe1(Nonce1)を生成する。SHE1022は、第6の暗号化データKe1(Nonce1)を制御部41に渡す。一方、制御部41は、SHE1022から受け取った測定値E1n_xの検証結果が「不合格」である場合には、乱数Nonce1の暗号化を実施しない。 (Step S89) When the verification result of the measurement value E1n_x received from the SHE 1022 is “pass”, the control unit 41 passes the random number Nonce1 stored in the storage unit 42 to the SHE 1022 and encrypts it with the encryption key Ke1. Let it run. The encryption processing unit 52 of the SHE 1022 encrypts the random number Nonce1 with the encryption key Ke1 stored in the storage unit 1023 to generate sixth encrypted data Ke1 (Nonce1). The SHE 1022 passes the sixth encrypted data Ke1 (Nonce1) to the control unit 41. On the other hand, when the verification result of the measurement value E1n_x received from the SHE 1022 is “fail”, the control unit 41 does not encrypt the random number Nonce1.

制御部41は、インタフェース部40により、セキュアブート結果として測定値E1n_xの検証結果「合格又は不合格」を、CAN1030を介して第1のECU1010経由で鍵生成装置1300に送信する。このとき、制御部41は、測定値E1n_xの検証結果が「合格」である場合には、セキュアブート結果「合格(OK)」に第6の暗号化データKe1(Nonce1)を含める。第1のECU1010は、インタフェース部20により、第2のECU(1)1020からCAN1030を介して、セキュアブート結果「合格又は不合格」を受信すると、該セキュアブート結果「合格又は不合格」を、インタフェース部20により、診断ポート1060を介して鍵生成装置1300に転送する。鍵生成装置1300は、車両インタフェース11により、自動車1001の第1のECU1010から診断ポート1060を介して、第2のECU(1)1020のセキュアブート結果「合格又は不合格」を受信する。
なお、セキュアブート結果「合格(OK)」に、乱数Nonce1を暗号化しないでそのまま含めてもよい。また、セキュアブート結果「合格(OK)」に、乱数Nonce1と乱数Nonce1のCMACとを含めてもよい。乱数Nonce1のCMACは、暗号鍵Ke1により、計算されてもよい。セキュアブート結果「合格(OK)」に、乱数Nonce1と乱数Nonce1のCMACとを含める場合、乱数Nonce1若しくは乱数Nonce1のCMACのいずれか一方、又は、乱数Nonce1と乱数Nonce1のCMACの両方を暗号化してもよい。
The control unit 41 transmits the verification result “pass or fail” of the measurement value E1n_x as the secure boot result via the CAN 1030 to the key generation device 1300 via the first ECU 1010 via the interface unit 40. At this time, when the verification result of the measurement value E1n_x is “pass”, the control unit 41 includes the sixth encrypted data Ke1 (Nonce1) in the secure boot result “pass (OK)”. When the first ECU 1010 receives the secure boot result “pass or fail” from the second ECU (1) 1020 via the CAN 1030, the first ECU 1010 receives the secure boot result “pass or fail”. The data is transferred to the key generation device 1300 via the diagnostic port 1060 by the interface unit 20. The key generation device 1300 receives the secure boot result “pass or fail” of the second ECU (1) 1020 from the first ECU 1010 of the automobile 1001 via the diagnosis port 1060 by the vehicle interface 11.
Note that the random number Nonce1 may be included in the secure boot result “pass (OK)” without encryption. Further, the random number Nonce1 and the CMAC of the random number Nonce1 may be included in the secure boot result “pass (OK)”. The CMAC of the random number Nonce1 may be calculated using the encryption key Ke1. When the random number Nonce1 and the CMAC of the random number Nonce1 are included in the secure boot result “pass (OK)”, either the random number Nonce1 or the CMAC of the random number Nonce1 or both the random number Nonce1 and the CMAC of the random number Nonce1 are encrypted. Also good.

(ステップS90)鍵生成装置1300の暗号処理部16は、第2のECU(1)1020のセキュアブート結果「合格(OK)」に含まれる第6の暗号化データKe1(Nonce1)を、第2のECU(1)1020の暗号鍵Ke1により復号して復号データNonce1を取得する。検証部14は、復号データNonce1と記憶部12に格納されている乱数Nonce1とを比較し、両者が一致するか否かを判断する。この判断の結果、両者が一致する場合には、第2のECU(1)1020のセキュアブート結果「合格」が正しいと判断する。セキュアブート結果「合格」が正しいと判断された場合にはステップS91に進む。一方、両者が一致しない場合には、第2のECU(1)1020のセキュアブート結果「合格」が正しくないと判断する。第2のECU(1)1020のセキュアブート結果「合格」が正しくないと判断された場合には、第2のECU(1)1020について図9の処理を終了する。よって、第2のECU(1)1020のセキュアブート結果「合格」が正しくないと判断された場合には、第2のECU(1)1020についてステップS91は実行されない。また、セキュアブート結果「合格」が正しくないと判断された場合には、鍵生成装置1300は所定のエラー処理を実行してもよい。 (Step S90) The cryptographic processing unit 16 of the key generation device 1300 uses the sixth encrypted data Ke1 (Nonce1) included in the secure boot result “pass (OK)” of the second ECU (1) 1020 as the second The decrypted data Nonce1 is obtained by decrypting with the encryption key Ke1 of the ECU (1) 1020. The verification unit 14 compares the decrypted data Nonce1 with the random number Nonce1 stored in the storage unit 12 and determines whether or not they match. As a result of the determination, if both match, it is determined that the secure boot result “pass” of the second ECU (1) 1020 is correct. If it is determined that the secure boot result “pass” is correct, the process proceeds to step S91. On the other hand, if they do not match, it is determined that the secure boot result “pass” of the second ECU (1) 1020 is not correct. When it is determined that the secure boot result “pass” of the second ECU (1) 1020 is not correct, the processing of FIG. 9 is terminated for the second ECU (1) 1020. Therefore, when it is determined that the secure boot result “pass” of the second ECU (1) 1020 is not correct, step S91 is not executed for the second ECU (1) 1020. If it is determined that the secure boot result “pass” is not correct, the key generation device 1300 may execute a predetermined error process.

また、鍵生成装置1300が自動車1001の第2のECU(1)1020のセキュアブート結果「不合格」を受信した場合には、第2のECU(1)1020について図9の処理を終了する。よって、第2のECU(1)1020のセキュアブート結果「不合格」を受信した場合には、第2のECU(1)1020についてステップS91は実行されない。また、セキュアブート結果「不合格」を受信した場合には、鍵生成装置1300は所定のエラー処理を実行してもよい。   When the key generation device 1300 receives the secure boot result “fail” of the second ECU (1) 1020 of the automobile 1001, the processing of FIG. 9 is terminated for the second ECU (1) 1020. Therefore, when the secure boot result “fail” of the second ECU (1) 1020 is received, step S91 is not executed for the second ECU (1) 1020. When the secure boot result “fail” is received, the key generation device 1300 may execute a predetermined error process.

次いでステップS91からステップS93までが実行される。ステップS91は、図5に係る管理方法の例1のステップS17と同じである。ステップS92は、図5に係る管理方法の例1のステップS18と同じである。ステップS93は、図5に係る管理方法の例1のステップS19と同じである。   Next, steps S91 to S93 are executed. Step S91 is the same as step S17 of the management method example 1 according to FIG. Step S92 is the same as step S18 of the management method example 1 according to FIG. Step S93 is the same as step S19 of the management method example 1 according to FIG.

上記ステップS82からステップS93までは、自動車1001に搭載されている全ての第2のECU(n)1020に対して同様に実行される。   Steps S82 to S93 are executed in the same manner for all second ECUs (n) 1020 mounted on the automobile 1001.

上述した管理方法の例5によれば、自動車1001に搭載されているECUのECUコードの期待値を鍵生成装置1300が生成してECUに供給する。そして、ECUが、自己のECUコードの測定値を、鍵生成装置1300から供給された期待値に基づいて検証し、この検証結果を鍵生成装置1300に通知することにより、自動車1001に搭載されているECUの真贋判定を行う。これにより、自動車1001に搭載されているECUの信頼性が向上する効果を奏する。   According to the fifth example of the management method described above, the key generation device 1300 generates the expected value of the ECU code of the ECU mounted on the automobile 1001 and supplies it to the ECU. Then, the ECU verifies the measured value of its own ECU code based on the expected value supplied from the key generation device 1300, and notifies the key generation device 1300 of the verification result, so that the ECU 1001 is mounted on the automobile 1001. The authenticity of the ECU is checked. Thereby, there is an effect that the reliability of the ECU mounted on the automobile 1001 is improved.

さらに、上述した管理方法の例5によれば、ECUが自己のECUコードの測定値の検証結果を鍵生成装置1300に通知する際に、鍵生成装置1300から供給された検証値(上述の例では乱数Nonce,Nonce1)を、測定値の検証が合格した場合に使用することができる暗号鍵により暗号化して第6の暗号化データを生成し、該第6の暗号化データを鍵生成装置1300に送信する。該暗号鍵は、鍵生成装置1300と共有されている。鍵生成装置1300は、該第6の暗号化データを復号し、この復号データとECUに供給した元の検証値との一致を判断することにより、ECUのECUコードの測定値の検証結果の正当性を確認することができる。   Furthermore, according to Example 5 of the management method described above, when the ECU notifies the key generation device 1300 of the verification result of the measured value of its own ECU code, the verification value supplied from the key generation device 1300 (the above example) Then, a random number Nonce, Nonce1) is encrypted with an encryption key that can be used when the measurement value verification passes, to generate sixth encrypted data, and the sixth encrypted data is generated as a key generation device 1300. Send to. The encryption key is shared with the key generation apparatus 1300. The key generation device 1300 decrypts the sixth encrypted data and determines whether the decrypted data matches the original verification value supplied to the ECU, thereby verifying the verification result of the measured value of the ECU code of the ECU. Sex can be confirmed.

<管理方法の例6>
管理方法の例6は、上述した管理方法の例5の変形例である。図10は、本実施形態に係る管理方法の例6のシーケンス図である。図10において、図9の各部に対応する部分には同一の符号を付け、その説明を省略する。以下、図10を参照して、上述した管理方法の例5と異なる点を主に説明する。
<Example 6 of management method>
The management method example 6 is a modification of the management method example 5 described above. FIG. 10 is a sequence diagram of Example 6 of the management method according to the present embodiment. 10, parts corresponding to those in FIG. 9 are given the same reference numerals, and descriptions thereof are omitted. Hereinafter, with reference to FIG. 10, differences from the above-described management method example 5 will be mainly described.

鍵生成装置1300の車両インタフェース11と自動車1001の診断ポート1060とは接続されている。ステップS71からステップS81までが実行される。ステップS71からステップS81までは、上述した図9に係る管理方法の例5と同じである。鍵生成装置1300が受信した自動車1001の第1のECU1010のセキュアブート結果「合格」が正しいと判断された場合には、ステップS81に次いでステップS101が実行される。この場合、第1のECU1010のセキュアブート結果は「合格」であるので、第1のECU1010のHSM1012において暗号鍵Kecは使用可能になる。   The vehicle interface 11 of the key generation device 1300 and the diagnostic port 1060 of the automobile 1001 are connected. Steps S71 to S81 are executed. Steps S71 to S81 are the same as those in the fifth example of the management method according to FIG. 9 described above. If it is determined that the secure boot result “pass” of the first ECU 1010 of the automobile 1001 received by the key generation device 1300 is correct, step S101 is executed after step S81. In this case, since the secure boot result of the first ECU 1010 is “pass”, the encryption key Kec can be used in the HSM 1012 of the first ECU 1010.

一方、該セキュアブート結果「合格」が正しくないと判断された場合及び鍵生成装置1300が自動車1001の第1のECU1010のセキュアブート結果「不合格」を受信した場合には、図10の処理を終了する。また、該セキュアブート結果「合格」が正しくないと判断された場合及び鍵生成装置1300が自動車1001の第1のECU1010のセキュアブート結果「不合格」を受信した場合には、鍵生成装置1300は所定のエラー処理を実行してもよい。   On the other hand, when it is determined that the secure boot result “pass” is not correct, and when the key generation device 1300 receives the secure boot result “fail” of the first ECU 1010 of the automobile 1001, the processing of FIG. finish. When it is determined that the secure boot result “pass” is not correct and when the key generation device 1300 receives the secure boot result “fail” of the first ECU 1010 of the automobile 1001, the key generation device 1300 Predetermined error processing may be executed.

(ステップS101)鍵生成装置1300の暗号処理部16は、第1のECU1010の暗号鍵Kecにより、N個の第2のECU(n)1020の各々のRoot鍵Krn、署名鍵Kbn、期待値Enn及び暗号鍵Kenを各々に暗号化する。この暗号化によって、N個の第1の暗号化データKec(Kr1)、Kec(Kr2)、・・・、Kec(KrN)と、N個の第2の暗号化データKec(Kb1)、Kec(Kb2)、・・・、Kec(KbN)と、N個の第4の暗号化データKec(E1n)、Kec(E2n)、・・・、Kec(ENn)と、N個の第7の暗号化データKec(Ke1)、Kec(Ke2)、・・・、Kec(KeN)と、が生成される。 (Step S101) The encryption processing unit 16 of the key generation device 1300 uses the encryption key Kec of the first ECU 1010 to start the root key Krn, the signature key Kbn, and the expected value Enn of each of the N second ECUs (n) 1020. And the encryption key Ken is encrypted respectively. By this encryption, N pieces of first encrypted data Kec (Kr1), Kec (Kr2),..., Kec (KrN) and N pieces of second encrypted data Kec (Kb1), Kec ( Kb2), ..., Kec (KbN), N pieces of fourth encrypted data Kec (E1n), Kec (E2n), ..., Kec (ENn), and N pieces of seventh encryption Data Kec (Ke1), Kec (Ke2), ..., Kec (KeN) are generated.

鍵生成装置1300は、車両インタフェース11により、N個の第1の暗号化データKec(Kr1)、Kec(Kr2)、・・・、Kec(KrN)と、N個の第2の暗号化データKec(Kb1)、Kec(Kb2)、・・・、Kec(KbN)と、N個の第4の暗号化データKec(E1n)、Kec(E2n)、・・・、Kec(ENn)と、N個の第7の暗号化データKec(Ke1)、Kec(Ke2)、・・・、Kec(KeN)と、を自動車1001の第1のECU1010に送信する。自動車1001の第1のECU1010は、インタフェース部20により、鍵生成装置1300から診断ポート1060を介して、N個の第1の暗号化データKec(Kr1)、Kec(Kr2)、・・・、Kec(KrN)と、N個の第2の暗号化データKec(Kb1)、Kec(Kb2)、・・・、Kec(KbN)と、N個の第4の暗号化データKec(E1n)、Kec(E2n)、・・・、Kec(ENn)と、N個の第7の暗号化データKec(Ke1)、Kec(Ke2)、・・・、Kec(KeN)と、を受信する。   The key generation device 1300 uses the vehicle interface 11 to generate N pieces of first encrypted data Kec (Kr1), Kec (Kr2),..., Kec (KrN) and N pieces of second encrypted data Kec. (Kb1), Kec (Kb2), ..., Kec (KbN), N pieces of fourth encrypted data Kec (E1n), Kec (E2n), ..., Kec (ENn), and N pieces The seventh encrypted data Kec (Ke1), Kec (Ke2), ..., Kec (KeN) are transmitted to the first ECU 1010 of the automobile 1001. The first ECU 1010 of the automobile 1001 uses the interface unit 20 to transmit N pieces of first encrypted data Kec (Kr1), Kec (Kr2),..., Kec from the key generation device 1300 via the diagnostic port 1060. (KrN), N pieces of second encrypted data Kec (Kb1), Kec (Kb2),..., Kec (KbN), and N pieces of fourth encrypted data Kec (E1n), Kec ( E2n), ..., Kec (ENn) and N pieces of seventh encrypted data Kec (Ke1), Kec (Ke2), ..., Kec (KeN).

(ステップS102)第1のECU1010の制御部21は、N個の第1の暗号化データKec(Kr1)、Kec(Kr2)、・・・、Kec(KrN)と、N個の第2の暗号化データKec(Kb1)、Kec(Kb2)、・・・、Kec(KbN)と、N個の第4の暗号化データKec(E1n)、Kec(E2n)、・・・、Kec(ENn)と、N個の第7の暗号化データKec(Ke1)、Kec(Ke2)、・・・、Kec(KeN)と、をHSM1012に渡して、暗号鍵Kecにより復号を実行させる。HSM1012は、記憶部1013に格納している暗号鍵Kecにより、N個の第1の暗号化データKec(Kr1)、Kec(Kr2)、・・・、Kec(KrN)と、N個の第2の暗号化データKec(Kb1)、Kec(Kb2)、・・・、Kec(KbN)と、N個の第4の暗号化データKec(E1n)、Kec(E2n)、・・・、Kec(ENn)と、N個の第7の暗号化データKec(Ke1)、Kec(Ke2)、・・・、Kec(KeN)と、を各々に復号する。この復号によって、N個のRoot鍵Kr1、Kr2、・・・、KrNと、N個の署名鍵Kb1、Kb2、・・・、KbNと、N個の期待値E1n、E2n、・・・、ENnと、N個の暗号鍵Ke1、Ke2、・・・、KeNと、が取得される。HSM1012は、該取得したN個のRoot鍵Kr1、Kr2、・・・、KrNと、N個の署名鍵Kb1、Kb2、・・・、KbNと、N個の期待値E1n、E2n、・・・、ENnと、N個の暗号鍵Ke1、Ke2、・・・、KeNと、を記憶部1013に格納する。 (Step S102) The control unit 21 of the first ECU 1010 includes N pieces of first encrypted data Kec (Kr1), Kec (Kr2),..., Kec (KrN), and N pieces of second encryption data. Data Kec (Kb1), Kec (Kb2),..., Kec (KbN) and N pieces of fourth encrypted data Kec (E1n), Kec (E2n),..., Kec (ENn) , N pieces of seventh encrypted data Kec (Ke1), Kec (Ke2),..., Kec (KeN) are passed to the HSM 1012, and are decrypted by the encryption key Kec. The HSM 1012 uses the encryption key Kec stored in the storage unit 1013 to generate N first encrypted data Kec (Kr1), Kec (Kr2),..., Kec (KrN), and N second data Encrypted data Kec (Kb1), Kec (Kb2),..., Kec (KbN) and N pieces of fourth encrypted data Kec (E1n), Kec (E2n),. ) And N pieces of seventh encrypted data Kec (Ke1), Kec (Ke2),..., Kec (KeN). By this decryption, N root keys Kr1, Kr2,..., KrN, N signature keys Kb1, Kb2,..., KbN and N expected values E1n, E2n,. N encryption keys Ke1, Ke2,..., KeN are acquired. The HSM 1012 acquires the N root keys Kr1, Kr2,..., KrN, the N signature keys Kb1, Kb2,..., KbN, and the N expected values E1n, E2n,. , ENn, and N encryption keys Ke1, Ke2,..., KeN are stored in the storage unit 1013.

次いでステップS103及びステップS104が実行される。ステップS103は、図6に係る管理方法の例2のステップS24と同じである。ステップS104は、図6に係る管理方法の例2のステップS25と同じである。次いでステップS105が実行される。   Next, Step S103 and Step S104 are executed. Step S103 is the same as step S24 of the management method example 2 according to FIG. Step S104 is the same as step S25 of the management method example 2 according to FIG. Next, step S105 is executed.

(ステップS105)第1のECU1010のHSM1012の暗号処理部32は、第2のECU(1)1020のRoot鍵Kr1により第2のECU(1)1020の暗号鍵Ke1を暗号化して、第5の暗号化データKr1(Ke1)を生成する。HSM1012は、第5の暗号化データKr1(Ke1)を制御部21に渡す。制御部21は、乱数Nonce1を発生させる。記憶部22は、該乱数Nonce1を格納する。制御部21は、インタフェース部20により、第5の暗号化データKr1(Ke1)及び乱数Nonce1を、CAN1030を介して第2のECU(1)1020に送信する。第2のECU(1)1020は、インタフェース部40により、第1のECU1010からCAN1030を介して、第5の暗号化データKr1(Ke1)及び乱数Nonce1を受信する。 (Step S105) The encryption processing unit 32 of the HSM 1012 of the first ECU 1010 encrypts the encryption key Ke1 of the second ECU (1) 1020 with the Root key Kr1 of the second ECU (1) 1020, and Encrypted data Kr1 (Ke1) is generated. The HSM 1012 passes the fifth encrypted data Kr1 (Ke1) to the control unit 21. The control unit 21 generates a random number Nonce1. The storage unit 22 stores the random number Nonce1. The control unit 21 transmits the fifth encrypted data Kr1 (Ke1) and the random number Nonce1 to the second ECU (1) 1020 via the CAN 1030 through the interface unit 20. The second ECU (1) 1020 receives the fifth encrypted data Kr1 (Ke1) and the random number Nonce1 from the first ECU 1010 via the CAN 1030 by the interface unit 40.

(ステップS106)第2のECU(1)1020の制御部41は、第5の暗号化データKr1(Ke1)をSHE1022に渡す。SHE1022の暗号処理部52は、記憶部1023に格納しているRoot鍵Kr1により第5の暗号化データKr1(Ke1)を復号して、暗号鍵Ke1を取得する。SHE1022は、該取得した暗号鍵Ke1を記憶部1023に格納する。SHE1022は、記憶部1023において、該取得した暗号鍵Ke1を初期暗号鍵Keeiに代えて格納してもよい。本実施形態では、暗号鍵Ke1は、SHE1022が実行するセキュアブート処理において測定値の検証が合格した場合に使用することができる暗号鍵として設定される。したがって、暗号鍵Ke1は、SHE1022が実行するセキュアブート処理において測定値の検証が不合格になった場合には使用することができない。 (Step S106) The control unit 41 of the second ECU (1) 1020 passes the fifth encrypted data Kr1 (Ke1) to the SHE1022. The encryption processing unit 52 of the SHE 1022 decrypts the fifth encrypted data Kr1 (Ke1) with the Root key Kr1 stored in the storage unit 1023, and acquires the encryption key Ke1. The SHE 1022 stores the acquired encryption key Ke1 in the storage unit 1023. The SHE 1022 may store the acquired encryption key Ke1 in the storage unit 1023 in place of the initial encryption key Keei. In the present embodiment, the encryption key Ke1 is set as an encryption key that can be used when the verification of the measurement value passes in the secure boot process executed by the SHE1022. Therefore, the encryption key Ke1 cannot be used when the measurement value verification fails in the secure boot process executed by the SHE1022.

記憶部42は、乱数Nonce1を格納する。乱数Nonce1の格納場所は、記憶部42の記憶領域のうち、セキュアブートの測定対象外の不揮発性記憶領域である。   The storage unit 42 stores a random number Nonce1. The storage location of the random number Nonce1 is a non-volatile storage area that is not a measurement target of the secure boot in the storage area of the storage unit 42.

(ステップS107)第1のECU1010のHSM1012の暗号処理部32は、第2のECU(1)1020のRoot鍵Kr1により第2のECU(1)1020の署名鍵Kb1及び期待値E1nを各々に暗号化して、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を生成する。HSM1012は、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を制御部21に渡す。制御部21は、インタフェース部20により、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を、CAN1030を介して第2のECU(1)1020に送信する。第2のECU(1)1020は、インタフェース部40により、第1のECU1010からCAN1030を介して、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を受信する。 (Step S107) The encryption processing unit 32 of the HSM 1012 of the first ECU 1010 encrypts the signature key Kb1 and the expected value E1n of the second ECU (1) 1020 with the Root key Kr1 of the second ECU (1) 1020, respectively. To generate second encrypted data Kr1 (Kb1) and fourth encrypted data Kr1 (E1n). The HSM 1012 passes the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) to the control unit 21. The control unit 21 uses the interface unit 20 to transmit the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) to the second ECU (1) 1020 via the CAN 1030. The second ECU (1) 1020 receives the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) from the first ECU 1010 via the CAN 1030 by the interface unit 40.

(ステップS108)第2のECU(1)1020の制御部41は、第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)をSHE1022に渡す。SHE1022の暗号処理部52は、記憶部1023に格納しているRoot鍵Kr1により第2の暗号化データKr1(Kb1)及び第4の暗号化データKr1(E1n)を各々に復号して、署名鍵Kb1及び期待値E1nを取得する。SHE1022は、該取得した署名鍵Kb1を記憶部1023に格納する。SHE1022は、記憶部1023において、該取得した署名鍵Kb1を初期署名鍵Kbiに代えて格納してもよい。また、SHE1022は、該取得した期待値E1nをセキュアブート処理で使用する期待値に設定する。 (Step S108) The control unit 41 of the second ECU (1) 1020 passes the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) to the SHE1022. The encryption processing unit 52 of the SHE 1022 decrypts the second encrypted data Kr1 (Kb1) and the fourth encrypted data Kr1 (E1n) with the Root key Kr1 stored in the storage unit 1023, respectively. Kb1 and expected value E1n are acquired. The SHE 1022 stores the acquired signature key Kb1 in the storage unit 1023. The SHE 1022 may store the obtained signature key Kb1 in the storage unit 1023 in place of the initial signature key Kbi. Further, the SHE 1022 sets the acquired expected value E1n to an expected value used in the secure boot process.

次いでステップS109が実行される。ステップS109は、図9に係る管理方法の例5のステップS88と同じである。次いでステップS110が実行される。   Next, step S109 is executed. Step S109 is the same as step S88 in Example 5 of the management method according to FIG. Next, step S110 is executed.

(ステップS110)制御部41は、SHE1022から受け取った測定値E1n_xの検証結果が「合格」である場合、記憶部42に格納している乱数Nonce1をSHE1022に渡して、暗号鍵Ke1により暗号化を実行させる。SHE1022の暗号処理部52は、記憶部1023に格納している暗号鍵Ke1により乱数Nonce1を暗号化して、第6の暗号化データKe1(Nonce1)を生成する。SHE1022は、第6の暗号化データKe1(Nonce1)を制御部41に渡す。一方、制御部41は、SHE1022から受け取った測定値E1n_xの検証結果が「不合格」である場合には、乱数Nonce1の暗号化を実施しない。 (Step S110) When the verification result of the measurement value E1n_x received from the SHE 1022 is “pass”, the control unit 41 passes the random number Nonce1 stored in the storage unit 42 to the SHE 1022 and encrypts it with the encryption key Ke1. Let it run. The encryption processing unit 52 of the SHE 1022 encrypts the random number Nonce1 with the encryption key Ke1 stored in the storage unit 1023 to generate sixth encrypted data Ke1 (Nonce1). The SHE 1022 passes the sixth encrypted data Ke1 (Nonce1) to the control unit 41. On the other hand, when the verification result of the measurement value E1n_x received from the SHE 1022 is “fail”, the control unit 41 does not encrypt the random number Nonce1.

制御部41は、インタフェース部40により、セキュアブート結果として測定値E1n_xの検証結果「合格又は不合格」を、CAN1030を介して第1のECU1010に送信する。このとき、制御部41は、測定値E1n_xの検証結果が「合格」である場合には、セキュアブート結果「合格(OK)」に第6の暗号化データKe1(Nonce1)を含める。第1のECU1010は、インタフェース部20により、第2のECU(1)1020からCAN1030を介して、第2のECU(1)1020のセキュアブート結果「合格又は不合格」を受信する。
なお、セキュアブート結果「合格(OK)」に、乱数Nonce1を暗号化しないでそのまま含めてもよい。また、セキュアブート結果「合格(OK)」に、乱数Nonce1と乱数Nonce1のCMACとを含めてもよい。乱数Nonce1のCMACは、暗号鍵Ke1により、計算されてもよい。セキュアブート結果「合格(OK)」に、乱数Nonce1と乱数Nonce1のCMACとを含める場合、乱数Nonce1若しくは乱数Nonce1のCMACのいずれか一方、又は、乱数Nonce1と乱数Nonce1のCMACの両方を暗号化してもよい。
The control unit 41 transmits the verification result “pass or fail” of the measurement value E1n_x as the secure boot result to the first ECU 1010 via the CAN 1030 by the interface unit 40. At this time, when the verification result of the measurement value E1n_x is “pass”, the control unit 41 includes the sixth encrypted data Ke1 (Nonce1) in the secure boot result “pass (OK)”. The first ECU 1010 receives the secure boot result “pass or fail” of the second ECU (1) 1020 from the second ECU (1) 1020 via the CAN 1030 via the interface unit 20.
Note that the random number Nonce1 may be included in the secure boot result “pass (OK)” without encryption. Further, the random number Nonce1 and the CMAC of the random number Nonce1 may be included in the secure boot result “pass (OK)”. The CMAC of the random number Nonce1 may be calculated using the encryption key Ke1. When the random number Nonce1 and the CMAC of the random number Nonce1 are included in the secure boot result “pass (OK)”, either the random number Nonce1 or the CMAC of the random number Nonce1 or both the random number Nonce1 and the CMAC of the random number Nonce1 are encrypted. Also good.

(ステップS111)第1のECU1010の制御部21は、第2のECU(1)1020のセキュアブート結果「合格(OK)」に含まれる第6の暗号化データKe1(Nonce1)を、HSM1012に渡して、第2のECU(1)1020の暗号鍵Ke1により復号を実行させる。HSM1012の暗号処理部32は、記憶部1013に格納している第2のECU(1)1020の暗号鍵Ke1により第6の暗号化データKe1(Nonce1)を復号して、復号データNonce1を取得する。HSM1012は、復号データNonce1を制御部21に渡す。 (Step S111) The control unit 21 of the first ECU 1010 passes the sixth encrypted data Ke1 (Nonce1) included in the secure boot result “pass (OK)” of the second ECU (1) 1020 to the HSM 1012. Thus, decryption is executed with the encryption key Ke1 of the second ECU (1) 1020. The encryption processing unit 32 of the HSM 1012 decrypts the sixth encrypted data Ke1 (Nonce1) with the encryption key Ke1 of the second ECU (1) 1020 stored in the storage unit 1013 to obtain the decrypted data Nonce1. . The HSM 1012 passes the decoded data Nonce1 to the control unit 21.

制御部21は、復号データNonce1と記憶部22に格納されている乱数Nonce1とを比較し、両者が一致するか否かを判断する。この判断の結果、両者が一致する場合には、第2のECU(1)1020のセキュアブート結果「合格」が正しいと判断する。セキュアブート結果「合格」が正しいと判断された場合にはステップS112に進む。一方、両者が一致しない場合には、第2のECU(1)1020のセキュアブート結果「合格」が正しくないと判断する。第2のECU(1)1020のセキュアブート結果「合格」が正しくないと判断された場合には、第2のECU(1)1020について図10の処理を終了する。よって、第2のECU(1)1020のセキュアブート結果「合格」が正しくないと判断された場合には、第2のECU(1)1020についてステップS112は実行されない。また、セキュアブート結果「合格」が正しくないと判断された場合には、鍵生成装置1300は所定のエラー処理を実行してもよい。   The control unit 21 compares the decrypted data Nonce1 with the random number Nonce1 stored in the storage unit 22, and determines whether or not they match. As a result of the determination, if both match, it is determined that the secure boot result “pass” of the second ECU (1) 1020 is correct. If it is determined that the secure boot result “pass” is correct, the process proceeds to step S112. On the other hand, if they do not match, it is determined that the secure boot result “pass” of the second ECU (1) 1020 is not correct. When it is determined that the secure boot result “pass” of the second ECU (1) 1020 is not correct, the processing of FIG. 10 is terminated for the second ECU (1) 1020. Therefore, when it is determined that the secure boot result “pass” of the second ECU (1) 1020 is not correct, step S112 is not executed for the second ECU (1) 1020. If it is determined that the secure boot result “pass” is not correct, the key generation device 1300 may execute a predetermined error process.

また、第1のECU1010が第2のECU(1)1020のセキュアブート結果「不合格」を受信した場合には、第2のECU(1)1020について図10の処理を終了する。よって、第2のECU(1)1020のセキュアブート結果「不合格」を受信した場合には、第2のECU(1)1020についてステップS112は実行されない。また、セキュアブート結果「不合格」を受信した場合には、第1のECU1010は所定のエラー処理を実行してもよい。   When the first ECU 1010 receives the result of the secure boot of the second ECU (1) 1020 “fail”, the process of FIG. 10 is finished for the second ECU (1) 1020. Thus, when the secure boot result “fail” of the second ECU (1) 1020 is received, step S112 is not executed for the second ECU (1) 1020. When the secure boot result “fail” is received, the first ECU 1010 may execute a predetermined error process.

次いでステップS112及びステップS113が実行される。ステップS112は、図8に係る管理方法の例4のステップS59と同じである。ステップS113は、図8に係る管理方法の例4のステップS60と同じである。   Next, Step S112 and Step S113 are executed. Step S112 is the same as step S59 of the management method example 4 according to FIG. Step S113 is the same as step S60 of the management method example 4 according to FIG.

上記ステップS103からステップS113までは、自動車1001に搭載されている全ての第2のECU(n)1020に対して同様に実行される。   The above steps S103 to S113 are executed in the same manner for all second ECUs (n) 1020 mounted on the automobile 1001.

なお、上記ステップS103からステップS113までは、自動車1001内に閉じた処理である。このため、ステップS103からステップS113までは、鍵生成装置1300の車両インタフェース11と自動車1001の診断ポート1060とは接続されていなくてもよい。   Note that steps S103 to S113 are processes closed in the automobile 1001. For this reason, from step S103 to step S113, the vehicle interface 11 of the key generation device 1300 and the diagnostic port 1060 of the automobile 1001 do not have to be connected.

上述した管理方法の例6によれば、管理方法の例5と同様に、自動車1001に搭載されているECUのECUコードの期待値を鍵生成装置1300が生成してECUに供給する。そして、ECUが、自己のECUコードの測定値を、鍵生成装置1300から供給された期待値に基づいて検証する。そして、本管理方法の例6によれば、第1のECU1010による検証結果を鍵生成装置1300に通知することにより、自動車1001に搭載されている第1のECU1010の真贋判定を行う。また、第2のECU(n)1020による検証結果を第1のECU1010に通知することにより、自動車1001に搭載されている第2のECU(n)1020の真贋判定を行う。これにより、自動車1001に搭載されているECUの信頼性が向上する効果を奏する。また、第1のECU1010がN個の第2のECU(n)1020の真贋判定を行うことにより、鍵生成装置1300と自動車1001とが接続される時間を、管理方法の例5よりも短縮できる。   According to the management method example 6 described above, as with the management method example 5, the key generation device 1300 generates the expected value of the ECU code of the ECU mounted on the automobile 1001 and supplies the ECU to the ECU. Then, the ECU verifies the measured value of its own ECU code based on the expected value supplied from the key generation device 1300. Then, according to Example 6 of the present management method, the authentication result of the first ECU 1010 mounted in the automobile 1001 is determined by notifying the key generation device 1300 of the verification result by the first ECU 1010. Further, the verification result of the second ECU (n) 1020 is notified to the first ECU 1010, whereby the authenticity of the second ECU (n) 1020 mounted on the automobile 1001 is determined. Thereby, there is an effect that the reliability of the ECU mounted on the automobile 1001 is improved. Further, when the first ECU 1010 determines the authenticity of the N second ECUs (n) 1020, the time during which the key generation device 1300 and the automobile 1001 are connected can be shortened compared to the management method example 5. .

さらに、上述した管理方法の例6によれば、管理方法の例5と同様に、第1のECU1010が自己のECUコードの測定値の検証結果を鍵生成装置1300に通知する際に、鍵生成装置1300から供給された検証値(上述の例では乱数Nonce)を、測定値の検証が合格した場合に使用することができる暗号鍵により暗号化して第6の暗号化データを生成し、該第6の暗号化データを鍵生成装置1300に送信する。該暗号鍵は、鍵生成装置1300と共有されている。鍵生成装置1300は、該第6の暗号化データを復号し、この復号データと第1のECU1010に供給した元の検証値との一致を判断することにより、第1のECU1010のECUコードの測定値の検証結果の正当性を確認することができる。   Furthermore, according to the management method example 6 described above, as in the management method example 5, when the first ECU 1010 notifies the key generation device 1300 of the verification result of the measured value of its own ECU code, the key generation is performed. The verification value (random number Nonce in the above example) supplied from the device 1300 is encrypted with an encryption key that can be used when the verification of the measurement value passes, and the sixth encrypted data is generated. 6 encrypted data is transmitted to the key generation apparatus 1300. The encryption key is shared with the key generation apparatus 1300. The key generation device 1300 decrypts the sixth encrypted data, and determines the coincidence between the decrypted data and the original verification value supplied to the first ECU 1010, thereby measuring the ECU code of the first ECU 1010. The validity of the value verification result can be confirmed.

また、上述した管理方法の例6によれば、第2のECU1020が自己のECUコードの測定値の検証結果を第1のECU1010に通知する際に、第1のECU1010から供給された検証値(上述の例では乱数Nonce1)を、測定値の検証が合格した場合に使用することができる暗号鍵により暗号化して第6の暗号化データを生成し、該第6の暗号化データを第1のECU1010に送信する。該暗号鍵は、第1のECU1010と共有されている。第1のECU1010は、該第6の暗号化データを復号し、この復号データと第2のECU1020に供給した元の検証値との一致を判断することにより、第2のECU1020のECUコードの測定値の検証結果の正当性を確認することができる。
なお、検証値(上述の例では乱数Nonceや乱数Nonce1)は、暗号化されずに、鍵生成装置1300や第1のECU1010に送信されてもよい。また、検証値と検証値のCMACとが鍵生成装置1300や第1のECU1010に送信されてもよい。検証値のCMACは、測定値の検証が合格した場合に使用することができる暗号鍵により、計算されてもよい。検証値と検証値のCMACとが鍵生成装置1300や第1のECU1010に送信される場合、検証値若しくは検証値のCMACのいずれか一方、又は、検証値と検証値のCMACの両方を暗号化してもよい。
Further, according to Example 6 of the management method described above, when the second ECU 1020 notifies the first ECU 1010 of the verification result of the measured value of its own ECU code, the verification value (supplied from the first ECU 1010 ( In the above example, the random number Nonce1) is encrypted with an encryption key that can be used when the verification of the measurement value is passed to generate sixth encrypted data, and the sixth encrypted data is stored in the first encrypted data. It transmits to ECU1010. The encryption key is shared with the first ECU 1010. The first ECU 1010 decrypts the sixth encrypted data and determines the coincidence between the decrypted data and the original verification value supplied to the second ECU 1020, thereby measuring the ECU code of the second ECU 1020. The validity of the value verification result can be confirmed.
Note that the verification value (random number Nonce or random number Nonce1 in the above example) may be transmitted to the key generation device 1300 or the first ECU 1010 without being encrypted. Also, the verification value and the CMAC of the verification value may be transmitted to the key generation device 1300 and the first ECU 1010. The verification value CMAC may be calculated from an encryption key that can be used if the measurement value verification passes. When the verification value and the verification value CMAC are transmitted to the key generation device 1300 or the first ECU 1010, either the verification value or the verification value CMAC, or both the verification value and the verification value CMAC are encrypted. May be.

[自動車の他の構成例]
図11は、本実施形態に係る管理システム及び自動車1001の他の構成例を示す図である。図11において、図1の各部に対応する部分には同一の符号を付け、その説明を省略する。以下、図11を参照して、図1に示す自動車1001と異なる点を主に説明する。
[Other vehicle configuration examples]
FIG. 11 is a diagram illustrating another configuration example of the management system and the automobile 1001 according to the present embodiment. In FIG. 11, parts corresponding to those in FIG. 1 are given the same reference numerals, and explanation thereof is omitted. Hereinafter, with reference to FIG. 11, the difference from the automobile 1001 shown in FIG. 1 will be mainly described.

図11において、図1に示す構成と異なる点として、第1のECU1010がゲートウェイ機能を有さない点と、第1のECU1010とは別個の装置としてゲートウェイ1070を設けた点とがある。ゲートウェイ1070はCAN1030に接続される。ゲートウェイ1070は、インフォテイメント機器1040、TCU1050及び診断ポート1060と接続される。図11に示す自動車1001に備わる車載コンピュータシステム1002aは、第1のECU1010と複数の第2のECU1020とがCAN1030に接続されて構成される。第1のECU1010及び第2のECU1020は、ゲートウェイ1070を介して、車載コンピュータシステム1002aの外部の装置と通信を行う。ゲートウェイ1070は、車載コンピュータシステム1002aの内部と外部の間の通信を監視する。本実施形態において、車載コンピュータシステム1002aは、自動車1001の車載制御システムとして機能する。   11 differs from the configuration shown in FIG. 1 in that the first ECU 1010 does not have a gateway function and in that a gateway 1070 is provided as a separate device from the first ECU 1010. The gateway 1070 is connected to the CAN 1030. The gateway 1070 is connected to the infotainment device 1040, the TCU 1050, and the diagnostic port 1060. An in-vehicle computer system 1002a provided in the automobile 1001 shown in FIG. 11 is configured by connecting a first ECU 1010 and a plurality of second ECUs 1020 to a CAN 1030. The first ECU 1010 and the second ECU 1020 communicate with an external device of the in-vehicle computer system 1002a via the gateway 1070. The gateway 1070 monitors communication between the inside and the outside of the in-vehicle computer system 1002a. In the present embodiment, the in-vehicle computer system 1002a functions as an in-vehicle control system of the automobile 1001.

なお、CAN1030の構成として、CAN1030が複数のバス(通信線)を備え、該複数のバスをゲートウェイ1070に接続してもよい。この場合、一つのバスに、一つのECU又は複数のECUが接続される。また、同じバスに第1のECU1010と第2のECU1020とが接続されてもよく、又は、第1のECU1010が接続されるバスと第2のECU1020が接続されるバスとを別個にしてもよい。   As a configuration of the CAN 1030, the CAN 1030 may include a plurality of buses (communication lines), and the plurality of buses may be connected to the gateway 1070. In this case, one ECU or a plurality of ECUs are connected to one bus. Further, the first ECU 1010 and the second ECU 1020 may be connected to the same bus, or the bus to which the first ECU 1010 is connected and the bus to which the second ECU 1020 is connected may be separated. .

[管理方法の他の例]
図12、図13及び図14を参照して管理方法の他の例を説明する。本管理方法の他の例は、ECUコードの管理方法の一例である。図12は、本実施形態に係る管理システムの他の構成例を示す図である。図12において、自動車1001は、図11の構成を適用している。なお、図1に示す自動車1001の構成を適用してもよい。図12に示す管理システムは、サーバ装置2000を備える。
[Other examples of management methods]
Another example of the management method will be described with reference to FIGS. Another example of this management method is an example of an ECU code management method. FIG. 12 is a diagram illustrating another configuration example of the management system according to the present embodiment. In FIG. 12, the configuration of FIG. 11 is applied to an automobile 1001. Note that the configuration of the automobile 1001 illustrated in FIG. 1 may be applied. The management system illustrated in FIG. 12 includes a server device 2000.

サーバ装置2000は、通信回線を介して、自動車1001のTCU1050の通信モジュール1051とデータを送受する。サーバ装置2000は、自動車1001のTCU1050の通信モジュール1051が利用する無線通信ネットワークを介して、該通信モジュール1051とデータを送受する。又は、サーバ装置2000は、インターネット等の通信ネットワークと該無線通信ネットワークとを介して、該通信モジュール1051とデータを送受してもよい。また、例えば、サーバ装置2000と通信モジュール1051との間をVPN(Virtual Private Network)回線等の専用回線で接続し、該専用回線でデータを送受してもよい。例えば、SIM1052に対応する無線通信ネットワークによって、VPN回線等の専用回線が提供されてもよい。   Server device 2000 transmits and receives data to and from communication module 1051 of TCU 1050 of automobile 1001 via a communication line. Server device 2000 transmits and receives data to and from communication module 1051 via a wireless communication network used by communication module 1051 of TCU 1050 of automobile 1001. Alternatively, the server device 2000 may transmit / receive data to / from the communication module 1051 via a communication network such as the Internet and the wireless communication network. Further, for example, the server apparatus 2000 and the communication module 1051 may be connected by a dedicated line such as a VPN (Virtual Private Network) line, and data may be transmitted / received through the dedicated line. For example, a dedicated line such as a VPN line may be provided by a wireless communication network corresponding to the SIM 1052.

サーバ装置2000は、ECUに適用されるECUコードを自動車1001へ提供する。ECUコードは、ECUに適用されるデータの例である。ECUコードは、ECUにインストールされる更新プログラム等のコンピュータプログラムであってもよく、又は、ECUに設定されるパラメータ設定値などの設定データであってもよい。   Server device 2000 provides ECU 1001 with an ECU code applied to the ECU. The ECU code is an example of data applied to the ECU. The ECU code may be a computer program such as an update program installed in the ECU, or may be setting data such as a parameter setting value set in the ECU.

自動車1001の診断ポート1060にはメンテナンスツール(maintenance tool)2100を接続可能である。自動車1001の診断ポート1060に接続されたメンテナンスツール2100は、ゲートウェイ1070を介して、CAN1030に接続されるECUと通信を行うことができる。メンテナンスツール2100は、OBDポートに接続される従来の診断端末の機能を有していてもよい。   A maintenance tool 2100 can be connected to the diagnostic port 1060 of the automobile 1001. The maintenance tool 2100 connected to the diagnostic port 1060 of the automobile 1001 can communicate with the ECU connected to the CAN 1030 via the gateway 1070. The maintenance tool 2100 may have a function of a conventional diagnostic terminal connected to the OBD port.

図13は、サーバ装置2000の構成例を示す図である。図13において、サーバ装置2000は、通信部2011と記憶部2012と期待値計算部2013と検証部2014と鍵生成部2015と暗号処理部2016とを備える。通信部2011は、通信回線を介して、他の装置と通信を行う。記憶部2012は、鍵等のデータを記憶する。期待値計算部2013は、ECUコードについての期待値を計算する。検証部2014は、ECUコードについての検証を行う。鍵生成部2015は、ECUの鍵を生成する。暗号処理部2016は、データの暗号化及び暗号化データの復号を行う。   FIG. 13 is a diagram illustrating a configuration example of the server apparatus 2000. In FIG. 13, the server apparatus 2000 includes a communication unit 2011, a storage unit 2012, an expected value calculation unit 2013, a verification unit 2014, a key generation unit 2015, and an encryption processing unit 2016. The communication unit 2011 communicates with other devices via a communication line. The storage unit 2012 stores data such as keys. The expected value calculation unit 2013 calculates an expected value for the ECU code. The verification unit 2014 verifies the ECU code. The key generation unit 2015 generates a key for the ECU. The encryption processing unit 2016 encrypts data and decrypts encrypted data.

サーバ装置2000の機能は、該サーバ装置2000が備えるCPUがコンピュータプログラムを実行することにより実現される。なお、サーバ装置2000として、汎用のコンピュータ装置を使用して構成してもよく、又は、専用のハードウェア装置として構成してもよい。   The functions of the server device 2000 are realized by the CPU provided in the server device 2000 executing a computer program. Note that the server device 2000 may be configured using a general-purpose computer device, or may be configured as a dedicated hardware device.

次に図14を参照して、管理方法の他の例の手順を説明する。図14は、ECUコードの提供手順の例を示すシーケンスチャートである。なお、図14において、ECUは、自動車1001に搭載されるECUであって、第1のECU1010であってもよく、又は、第2のECU1020であってもよい。   Next, a procedure of another example of the management method will be described with reference to FIG. FIG. 14 is a sequence chart illustrating an example of an ECU code providing procedure. In FIG. 14, the ECU is an ECU mounted on the automobile 1001 and may be the first ECU 1010 or the second ECU 1020.

サーバ装置2000は、マスタ鍵Master_SecretとECUのECUコードとを予め記憶部2012に格納している。ECUのECUコードは、ECUに適用する予定のECUコードを含む。ECUは、Root鍵Kr、署名鍵Kb、暗号鍵Ke及びECUコードEcを予め格納している。第1のECU1010においては、HSM1012の記憶部1013が各鍵を格納し、メイン演算器1011の記憶部22がECUコードを格納する。第2のECU1020においては、SHE1022の記憶部1023が各鍵を格納し、メイン演算器1021の記憶部42がECUコードを格納する。   The server device 2000 stores the master key Master_Secret and the ECU code of the ECU in the storage unit 2012 in advance. The ECU code of the ECU includes an ECU code scheduled to be applied to the ECU. The ECU stores a Root key Kr, a signature key Kb, an encryption key Ke, and an ECU code Ec in advance. In the first ECU 1010, the storage unit 1013 of the HSM 1012 stores each key, and the storage unit 22 of the main computing unit 1011 stores the ECU code. In the second ECU 1020, the storage unit 1023 of the SHE 1022 stores each key, and the storage unit 42 of the main computing unit 1021 stores the ECU code.

以下、サーバ装置2000は、通信部2011により、自動車1001のTCU1050と通信を行い、TCU1050及びゲートウェイ1070を介して、自動車1001のCAN1030に接続される各ECUとの間でデータを送受する。また、以下の説明では、第1のECU1010と第2のECU1020とを特に区別せず、ECUとして説明する。このため、説明の便宜上、セキュアエレメントとは、ECUが第1のECU1010の場合にはHSM1012を指し、ECUが第2のECU1020の場合にはSHE1022を指す。また、セキュアエレメントの記憶部とは、ECUが第1のECU1010の場合にはHSM1012の記憶部1013を指し、ECUが第2のECU1020の場合にはSHE1022の記憶部1023を指す。また、ECUの制御部とは、ECUが第1のECU1010の場合には制御部21を指し、ECUが第2のECU1020の場合には制御部41を指す。   Hereinafter, the server apparatus 2000 communicates with the TCU 1050 of the automobile 1001 through the communication unit 2011, and transmits / receives data to / from each ECU connected to the CAN 1030 of the automobile 1001 via the TCU 1050 and the gateway 1070. In the following description, the first ECU 1010 and the second ECU 1020 are not particularly distinguished from each other, and are described as ECUs. Therefore, for convenience of explanation, the secure element indicates the HSM 1012 when the ECU is the first ECU 1010, and the SHE 1022 when the ECU is the second ECU 1020. The secure element storage unit refers to the storage unit 1013 of the HSM 1012 when the ECU is the first ECU 1010, and the storage unit 1023 of the SHE 1022 when the ECU is the second ECU 1020. The ECU control unit refers to the control unit 21 when the ECU is the first ECU 1010, and refers to the control unit 41 when the ECU is the second ECU 1020.

(ステップS201)サーバ装置2000の鍵生成部2015は、自動車1001に搭載されているECUのRoot鍵Kr、署名鍵Kb及び暗号鍵Keを生成する。これらの鍵の生成方法は、図9に係る管理方法の例5のステップS71に係るRoot鍵、署名鍵及び暗号鍵の生成方法と同様である。例えば、Root鍵用の変数Nkの値をNk_1とし、署名鍵用の変数Nkの値をNk_2とし、暗号鍵用の変数Nkの値をNk_3とする。鍵生成部2015は、マスタ鍵Master_SecretとECUのECU識別子ECU_IDとを使用して、
Root鍵=ダイジェスト(Master_Secret、ECU_ID、Nk_1)、
署名鍵=ダイジェスト(Master_Secret、ECU_ID、Nk_2)、
暗号鍵=ダイジェスト(Master_Secret、ECU_ID、Nk_3)、
により、Root鍵Krと署名鍵Kbと暗号鍵Keを異なる鍵として生成する。記憶部2012は、Root鍵Kr、署名鍵Kb及び暗号鍵Keを格納する。
(Step S201) The key generation unit 2015 of the server device 2000 generates a root key Kr, a signature key Kb, and an encryption key Ke for the ECU mounted on the automobile 1001. The method for generating these keys is the same as the method for generating the Root key, signature key, and encryption key according to step S71 of the fifth management method example shown in FIG. For example, the value of the root key variable Nk is Nk_1, the value of the signature key variable Nk is Nk_2, and the value of the encryption key variable Nk is Nk_3. The key generation unit 2015 uses the master key Master_Secret and the ECU identifier ECU_ID of the ECU,
Root key = Digest (Master_Secret, ECU_ID, Nk_1),
Signature key = Digest (Master_Secret, ECU_ID, Nk_2),
Encryption key = digest (Master_Secret, ECU_ID, Nk_3),
Thus, the Root key Kr, the signature key Kb, and the encryption key Ke are generated as different keys. The storage unit 2012 stores a Root key Kr, a signature key Kb, and an encryption key Ke.

また、サーバ装置2000の期待値計算部2013は、自動車1001に搭載されているECUに適用する予定のECUコード(以下、Ecnewコードと称する)のCMACを、署名鍵Kbにより計算する。この計算結果のCMACを期待値Ecnと称する。記憶部2012は、期待値Ecnを格納する。   In addition, the expected value calculation unit 2013 of the server device 2000 calculates a CMAC of an ECU code (hereinafter referred to as an “Ecnew code”) to be applied to an ECU mounted on the automobile 1001 using the signature key Kb. The CMAC resulting from this calculation is referred to as an expected value Ecn. The storage unit 2012 stores the expected value Ecn.

(ステップS202)サーバ装置2000は、通信部2011により、期待値EcnをECUに送信する。ECUは、サーバ装置2000から送信された期待値Ecnを受信する。 (Step S202) The server apparatus 2000 transmits the expected value Ecn to the ECU through the communication unit 2011. The ECU receives the expected value Ecn transmitted from the server device 2000.

(ステップS203)ECUのセキュアエレメントは、サーバ装置2000から受信した期待値Ecnを、セキュアブート処理で使用する期待値に設定する。 (Step S203) The secure element of the ECU sets the expected value Ecn received from the server device 2000 to the expected value used in the secure boot process.

(ステップS204)サーバ装置2000は、通信部2011により、EcnewコードをECUに送信する。ECUは、サーバ装置2000から送信されたEcnewコードを受信する。 (Step S204) The server apparatus 2000 transmits an Ecnew code to the ECU through the communication unit 2011. The ECU receives the Ecnew code transmitted from the server device 2000.

(ステップS205)ECUの制御部は、サーバ装置2000から受信したEcnewコードを自己に適用する。 (Step S205) The control unit of the ECU applies the Ecnew code received from the server device 2000 to itself.

(ステップS206)ECUの制御部は、Ecnewコードの適用後に、セキュアブートを実行する。このセキュアブートでは、ECUのセキュアエレメントは、セキュアエレメントの記憶部に格納している署名鍵KbによりEcnewコードのCMACを計算し、該計算結果のCMACと期待値Ecnとの比較を行う。この比較の結果、両者が一致する場合にはセキュアブート結果が合格であり、両者が一致しない場合にはセキュアブート結果が不合格である。ECUのセキュアエレメントは、セキュアブート結果をECUの制御部に渡す。ECUの制御部は、セキュアブート結果が合格である場合にEcnewコードの実行を進める。一方、ECUは、セキュアブート結果が不合格である場合にはEcnewコードの実行を停止する。 (Step S206) The control unit of the ECU executes secure boot after the application of the Ecnew code. In this secure boot, the secure element of the ECU calculates the CMAC of the Ecnew code with the signature key Kb stored in the storage unit of the secure element, and compares the calculated CMAC with the expected value Ecn. As a result of this comparison, if both match, the secure boot result is acceptable, and if both do not match, the secure boot result is unacceptable. The secure element of the ECU passes the secure boot result to the control unit of the ECU. The control unit of the ECU advances the execution of the Ecnew code when the secure boot result is acceptable. On the other hand, if the secure boot result is unacceptable, the ECU stops the execution of the Ecnew code.

(ステップS207)ECUは、セキュアブート結果「合格又は不合格」をサーバ装置2000に送信する。サーバ装置2000は、通信部2011により、ECUから送信されたセキュアブート結果「合格又は不合格」を受信する。サーバ装置2000は、ECUから受信したセキュアブート結果「合格又は不合格」に応じて、所定の処理を実行する。例えば、セキュアブート結果が合格である場合には、その旨を記録する。一方、セキュアブート結果が不合格である場合には、例えば、サーバ装置2000が期待値Ecnを再生成し、サーバ装置2000とECUとは上記のステップS202からステップS207までを再実行する。この期待値Ecnの再生成及びステップS202からステップS207までの再実行は、セキュアブート結果が合格になるまで繰り返す、又は、所定回数だけ繰り返す。 (Step S <b> 207) The ECU transmits the secure boot result “pass or fail” to the server device 2000. The server apparatus 2000 receives the secure boot result “pass or fail” transmitted from the ECU by the communication unit 2011. The server device 2000 executes a predetermined process in accordance with the secure boot result “pass or fail” received from the ECU. For example, if the secure boot result is acceptable, the fact is recorded. On the other hand, when the secure boot result is unacceptable, for example, the server apparatus 2000 regenerates the expected value Ecn, and the server apparatus 2000 and the ECU re-execute the above steps S202 to S207. The regeneration of the expected value Ecn and the re-execution from step S202 to step S207 are repeated until the secure boot result is passed or repeated a predetermined number of times.

次に、上述した図14のECUコードの提供手順の変形例を説明する。   Next, a modified example of the ECU code provision procedure of FIG. 14 described above will be described.

<ECUコードの提供手順の変形例1>
ステップS202において、サーバ装置2000は、暗号処理部2016により期待値Ecnを暗号化して、ECUに送信する。この暗号化に用いる鍵は、Root鍵Kr、署名鍵Kb又は暗号鍵Keのいずれであってもよい。ECUのセキュアエレメントは、サーバ装置2000から受信した暗号化データを、自己の暗号処理部により、セキュアエレメントの記憶部に格納されている該当の鍵で復号して、期待値Ecnを取得する。
<Variation 1 of the procedure for providing the ECU code>
In step S202, the server apparatus 2000 encrypts the expected value Ecn by the encryption processing unit 2016 and transmits it to the ECU. The key used for this encryption may be any of the root key Kr, the signature key Kb, and the encryption key Ke. The secure element of the ECU decrypts the encrypted data received from the server device 2000 with its corresponding encryption key stored in the storage unit of the secure element, and acquires the expected value Ecn.

<ECUコードの提供手順の変形例2>
ステップS204において、サーバ装置2000は、暗号処理部2016によりEcnewコードを暗号化して、ECUに送信する。この暗号化に用いる鍵は、Root鍵Kr、署名鍵Kb、又は暗号鍵Keのいずれであってもよい。ECUのセキュアエレメントは、サーバ装置2000から受信した暗号化データを、自己の暗号処理部により、セキュアエレメントの記憶部に格納されている該当の鍵で復号して、Ecnewコードを取得する。
<Variation 2 of ECU Code Providing Procedure>
In step S204, the server apparatus 2000 encrypts the Ecnew code by the encryption processing unit 2016 and transmits it to the ECU. The key used for this encryption may be any of the Root key Kr, the signature key Kb, and the encryption key Ke. The secure element of the ECU acquires the Ecnew code by decrypting the encrypted data received from the server device 2000 with the corresponding key stored in the storage unit of the secure element by its own encryption processing unit.

<ECUコードの提供手順の変形例3>
上記のECUコードの提供手順の変形例1とECUコードの提供手順の変形例2の両方を適用する。つまり、期待値EcnとEcnewコードの両方を暗号化して、サーバ装置2000からECUに送信する。
<Variation 3 of ECU Code Providing Procedure>
Both Modification 1 of the ECU code provision procedure and Modification 2 of the ECU code provision procedure are applied. That is, both the expected value Ecn and the Ecnew code are encrypted and transmitted from the server device 2000 to the ECU.

<ECUコードの提供手順の変形例4>
ステップS207において、ECUからサーバ装置2000に送信するセキュアブート結果「合格又は不合格」は所定値とする。例えば、合格は「1」であり、不合格は「0」である。
<ECUコードの提供手順の変形例5>
ステップS207において、ECUからサーバ装置2000に送信するセキュアブート結果「合格又は不合格」は、ステップS206のセキュアブートで計算された結果のEcnewコードのCMACとする。サーバ装置2000の検証部2014は、ECUから受信したセキュアブート結果のCMACと、ステップS202でECUに送信した期待値Ecnとを比較する。サーバ装置2000の検証部2014は、該比較の結果、両者が一致する場合にはECUのセキュアブート結果が合格であると判断し、両者が一致しない場合にはECUのセキュアブート結果が不合格であると判断する。
<ECUコードの提供手順の変形例6>
サーバ装置2000は、検証値(例えば、乱数Nonce)を予めECUに供給する。ステップS207において、ECUは、セキュアブート結果が合格である場合にはセキュアブート結果「合格」に検証値を含め、一方、セキュアブート結果が不合格である場合にはセキュアブート結果「不合格」に検証値を含めない。サーバ装置2000の検証部2014は、ECUから受信したセキュアブート結果「合格」に含まれる検証値と、予めECUに供給した元の検証値とを比較する。サーバ装置2000の検証部2014は、該比較の結果、両者が一致する場合にはECUのセキュアブート結果が合格であると判断し、両者が一致しない場合にはECUのセキュアブート結果が不合格であると判断する。
<Variation 4 of ECU Code Providing Procedure>
In step S207, the secure boot result “pass or fail” transmitted from the ECU to the server apparatus 2000 is set to a predetermined value. For example, the pass is “1” and the failure is “0”.
<Variation 5 of ECU Code Providing Procedure>
In step S207, the secure boot result “pass or fail” transmitted from the ECU to the server apparatus 2000 is the CMAC of the Ecnew code calculated in the secure boot in step S206. The verification unit 2014 of the server device 2000 compares the CMAC of the secure boot result received from the ECU with the expected value Ecn transmitted to the ECU in step S202. As a result of the comparison, the verification unit 2014 of the server device 2000 determines that the ECU's secure boot result is acceptable, and if they do not match, the ECU's secure boot result is unacceptable. Judge that there is.
<Variation 6 of the procedure for providing the ECU code>
The server device 2000 supplies a verification value (for example, a random number Nonce) to the ECU in advance. In step S207, the ECU includes the verification value in the secure boot result “pass” if the secure boot result is acceptable, while the secure boot result “failed” if the secure boot result is unsuccessful. Do not include verification values. The verification unit 2014 of the server device 2000 compares the verification value included in the secure boot result “pass” received from the ECU with the original verification value supplied in advance to the ECU. As a result of the comparison, the verification unit 2014 of the server device 2000 determines that the ECU's secure boot result is acceptable, and if they do not match, the ECU's secure boot result is unacceptable. Judge that there is.

<ECUコードの提供手順の変形例7>
上記のECUコードの提供手順の変形例4,5,6のいずれか複数を組合せて適用する。
<Modification 7 of ECU Code Providing Procedure>
Any one of the modified examples 4, 5, and 6 of the ECU code provision procedure is applied in combination.

<ECUコードの提供手順の変形例8>
上記のECUコードの提供手順の変形例4,5,6,7において、ECUは、セキュアエレメントの暗号処理部によりセキュアブート結果を暗号化して、サーバ装置2000に送信する。この暗号化に用いる鍵は、Root鍵Kr又は署名鍵Kbのいずれであってもよい。サーバ装置2000は、ECUから受信した暗号化データを、暗号処理部2016により、記憶部2012に格納されている該当の鍵で復号して、セキュアブート結果を取得する。なお、セキュアブート結果が合格である場合には、暗号鍵Keが使用可能になるので、セキュアブート結果「合格」を暗号鍵Keにより暗号化してもよい。
<Variation 8 of ECU Code Providing Procedure>
In the modified examples 4, 5, 6, and 7 of the ECU code provision procedure, the ECU encrypts the secure boot result by the encryption processing unit of the secure element and transmits the result to the server device 2000. The key used for this encryption may be either the root key Kr or the signature key Kb. The server device 2000 uses the encryption processing unit 2016 to decrypt the encrypted data received from the ECU with the corresponding key stored in the storage unit 2012, and obtains a secure boot result. If the secure boot result is acceptable, the encryption key Ke can be used, so the secure boot result “pass” may be encrypted with the encryption key Ke.

上述した管理方法の他の例によれば、サーバ装置2000は、ECUに適用するECUコードの期待値をECUに提供する。ECUは、サーバ装置2000から提供されたECUコードの期待値に基づいて、サーバ装置2000から提供されたECUコードを検証する。ECUは、ECUコードの検証結果をサーバ装置2000に送信する。これにより、ECUに適用されるECUコードの信頼性を向上させることができる。   According to another example of the management method described above, server device 2000 provides the ECU with an expected value of an ECU code applied to the ECU. The ECU verifies the ECU code provided from the server device 2000 based on the expected value of the ECU code provided from the server device 2000. The ECU transmits the verification result of the ECU code to the server device 2000. Thereby, the reliability of the ECU code applied to the ECU can be improved.

上述した管理方法の他の例において、サーバ装置2000はデータ提供装置に対応し、通信部2011は車両インタフェースに対応する。   In another example of the management method described above, the server device 2000 corresponds to a data providing device, and the communication unit 2011 corresponds to a vehicle interface.

なお、メンテナンスツール2100が、サーバ装置2000と同様の機能を備え、サーバ装置2000と同様のECUコードの提供手順により、診断ポート1060を介してECUにECUコードを提供するように構成してもよい。   The maintenance tool 2100 may be configured to have the same function as the server device 2000 and to provide the ECU code to the ECU via the diagnosis port 1060 according to the same ECU code provision procedure as that of the server device 2000. .

また、自動車1001のTCU1050が、サーバ装置2000からECUコードを受信し、受信したECUコードについて期待値を生成し、生成したECUコードの期待値をECUに提供してもよい。例えば、TCU1050の通信モジュール1051のSIM1052が、マスタ鍵Master_Secretを予め格納し、マスタ鍵Master_SecretとECUのECU識別子ECU_IDとを使用してCMACの生成に使用する鍵を生成し、生成した鍵によりECUコードのCMAC(期待値)を計算する。   Alternatively, the TCU 1050 of the automobile 1001 may receive an ECU code from the server device 2000, generate an expected value for the received ECU code, and provide the ECU with the expected value of the generated ECU code. For example, the SIM 1052 of the communication module 1051 of the TCU 1050 stores the master key Master_Secret in advance, generates a key used for generating the CMAC using the master key Master_Secret and the ECU identifier ECU_ID of the ECU, and generates an ECU code using the generated key. CMAC (expected value) is calculated.

また、自動車1001の第1のECU1010が、サーバ装置2000から第2のECU1020のECUコードを受信し、受信した第2のECU1020のECUコードについて期待値を生成し、生成した第2のECU1020のECUコードの期待値を第2のECU1020に提供してもよい。例えば、第1のECU1010のHSM1012が、マスタ鍵Master_Secretを予め格納し、マスタ鍵Master_Secretと第2のECU1020のECU識別子ECU_IDとを使用してCMACの生成に使用する鍵を生成し、生成した鍵により第2のECU1020のECUコードのCMAC(期待値)を計算する。   The first ECU 1010 of the automobile 1001 receives the ECU code of the second ECU 1020 from the server device 2000, generates an expected value for the received ECU code of the second ECU 1020, and generates the generated ECU of the second ECU 1020. The expected value of the code may be provided to the second ECU 1020. For example, the HSM 1012 of the first ECU 1010 stores the master key Master_Secret in advance, generates a key used for generating the CMAC using the master key Master_Secret and the ECU identifier ECU_ID of the second ECU 1020, and uses the generated key. The CMAC (expected value) of the ECU code of the second ECU 1020 is calculated.

以上、本発明の実施形態について図面を参照して詳述してきたが、具体的な構成はこの実施形態に限られるものではなく、本発明の要旨を逸脱しない範囲の設計変更等も含まれる。   As mentioned above, although embodiment of this invention was explained in full detail with reference to drawings, the specific structure is not restricted to this embodiment, The design change etc. of the range which does not deviate from the summary of this invention are included.

上述した実施形態では、ECUにHSM又はSHEを備えたが、HSM及びSHE以外の暗号処理チップを使用してもよい。第1のECU1010に対して、例えば「TPM(Trusted Platform Module)f」と呼ばれる暗号処理チップを使用してもよい。TPMfは耐タンパー性を有する。TPMfはセキュアエレメントの例である。第2のECU1020に対して、例えば「TPMt」と呼ばれる暗号処理チップを使用してもよい。TPMtは耐タンパー性を有する。TPMtはセキュアエレメントの例である。   In the above-described embodiment, the ECU is provided with HSM or SHE, but a cryptographic processing chip other than HSM and SHE may be used. For the first ECU 1010, for example, a cryptographic processing chip called “TPM (Trusted Platform Module) f” may be used. TPMf has tamper resistance. TPMf is an example of a secure element. For the second ECU 1020, for example, a cryptographic processing chip called “TPMt” may be used. TPMt has tamper resistance. TPMt is an example of a secure element.

上述した実施形態は、自動車の製造工場において、自動車の製造工程で自動車に搭載された新品のECUに適用してもよい。また、上述した実施形態は、自動車の整備工場や販売店等において、自動車のECUを新品に交換した際に、自動車に搭載された新品のECUに適用してもよい。   The above-described embodiment may be applied to a new ECU mounted on a car in a car manufacturing process in a car manufacturing factory. In addition, the above-described embodiment may be applied to a new ECU mounted on a car when the car ECU is replaced with a new one at a car maintenance shop or a store.

上述した実施形態では、車両として自動車を例に挙げたが、原動機付自転車や鉄道車両等の自動車以外の他の車両にも適用可能である。   In the above-described embodiment, an automobile is taken as an example of the vehicle, but the present invention can also be applied to vehicles other than automobiles such as a motorbike and a railway vehicle.

また、上述した鍵生成装置又はECUの機能を実現するためのコンピュータプログラムをコンピュータ読み取り可能な記録媒体に記録して、この記録媒体に記録されたプログラムをコンピュータシステムに読み込ませ、実行するようにしてもよい。なお、ここでいう「コンピュータシステム」とは、OSや周辺機器等のハードウェアを含むものであってもよい。
また、「コンピュータ読み取り可能な記録媒体」とは、フレキシブルディスク、光磁気ディスク、ROM、フラッシュメモリ等の書き込み可能な不揮発性メモリ、DVD(Digital Versatile Disc)等の可搬媒体、コンピュータシステムに内蔵されるハードディスク等の記憶装置のことをいう。
Further, a computer program for realizing the functions of the key generation device or ECU described above is recorded on a computer-readable recording medium, and the program recorded on the recording medium is read into a computer system and executed. Also good. Here, the “computer system” may include an OS and hardware such as peripheral devices.
“Computer-readable recording medium” refers to a flexible disk, a magneto-optical disk, a ROM, a writable nonvolatile memory such as a flash memory, a portable medium such as a DVD (Digital Versatile Disc), and a built-in computer system. A storage device such as a hard disk.

さらに「コンピュータ読み取り可能な記録媒体」とは、インターネット等のネットワークや電話回線等の通信回線を介してプログラムが送信された場合のサーバやクライアントとなるコンピュータシステム内部の揮発性メモリ(例えばDRAM(Dynamic Random Access Memory))のように、一定時間プログラムを保持しているものも含むものとする。
また、上記プログラムは、このプログラムを記憶装置等に格納したコンピュータシステムから、伝送媒体を介して、あるいは、伝送媒体中の伝送波により他のコンピュータシステムに伝送されてもよい。ここで、プログラムを伝送する「伝送媒体」は、インターネット等のネットワーク(通信網)や電話回線等の通信回線(通信線)のように情報を伝送する機能を有する媒体のことをいう。
また、上記プログラムは、前述した機能の一部を実現するためのものであっても良い。さらに、前述した機能をコンピュータシステムにすでに記録されているプログラムとの組み合わせで実現できるもの、いわゆる差分ファイル(差分プログラム)であっても良い。
Further, the “computer-readable recording medium” means a volatile memory (for example, DRAM (Dynamic DRAM) in a computer system that becomes a server or a client when a program is transmitted through a network such as the Internet or a communication line such as a telephone line. Random Access Memory)), etc., which hold programs for a certain period of time.
The program may be transmitted from a computer system storing the program in a storage device or the like to another computer system via a transmission medium or by a transmission wave in the transmission medium. Here, the “transmission medium” for transmitting the program refers to a medium having a function of transmitting information, such as a network (communication network) such as the Internet or a communication line (communication line) such as a telephone line.
The program may be for realizing a part of the functions described above. Furthermore, what can implement | achieve the function mentioned above in combination with the program already recorded on the computer system, and what is called a difference file (difference program) may be sufficient.

11…車両インタフェース、12,22,42,2012…記憶部、13,2013…期待値計算部、14,2014…検証部、15,34,2015…鍵生成部、16,32,52,2016…暗号処理部、20,40…インタフェース部、21,41…制御部、31,51…測定値計算部、33,53…測定部、1001…自動車、1002,1002a…車載コンピュータシステム、1010…第1のECU、1011,1021…メイン演算器、1012…HSM、1013,1023…記憶部、1020…第2のECU、1022…SHE、1030…CAN、1040…インフォテイメント機器、1050…TCU、1051…通信モジュール、1052…SIM、1060…診断ポート、1070…ゲートウェイ、1300…鍵生成装置、2000…サーバ装置、2011…通信部、2100…メンテナンスツール DESCRIPTION OF SYMBOLS 11 ... Vehicle interface, 12, 22, 42, 2012 ... Memory | storage part, 13, 2013 ... Expected value calculation part, 14, 2014 ... Verification part, 15, 34, 2015 ... Key generation part, 16, 32, 52, 2016 ... Cryptographic processing unit 20, 40 ... interface unit, 21, 41 ... control unit, 31, 51 ... measurement value calculation unit, 33, 53 ... measurement unit, 1001 ... automobile, 1002, 1002a ... in-vehicle computer system, 1010 ... first ECU, 1011, 1021 ... main arithmetic unit, 1012 ... HSM, 1013, 1023 ... storage unit, 1020 ... second ECU, 1022 ... SHE, 1030 ... CAN, 1040 ... infotainment device, 1050 ... TCU, 1051 ... communication Module, 1052 ... SIM, 1060 ... diagnostic port, 1070 ... gateway, 1300 ... Generating device, 2000 ... server, 2011 ... communication unit, 2100 ... maintenance tool

Claims (6)

データ提供装置と、車両に搭載される車載コンピュータとを備え、
前記データ提供装置は、
前記車両とデータを送受する車両インタフェースと、
前記車載コンピュータに格納される第1の鍵及び第2の鍵を生成する鍵生成部と、
前記第2の鍵を使用して、前記車載コンピュータに適用される適用データの期待値を計算する期待値計算部と、
前記車載コンピュータが予め格納している初期鍵により前記第1の鍵を暗号化して第1の暗号化データを生成し、前記第1の鍵により前記第2の鍵を暗号化して第2の暗号化データを生成し、前記第1の鍵により前記期待値を暗号化して第4の暗号化データを生成する暗号処理部と、を備え、前記適用データ、前記第1の暗号化データ、前記第2の暗号化データ及び前記第4の暗号化データを前記車両インタフェースにより前記車両に送信し、前記適用データの測定値の検証結果を前記車両インタフェースにより前記車両から受信し、
前記車載コンピュータは、
自車載コンピュータの外部の装置とデータを送受するインタフェース部と、
前記インタフェース部により前記データ提供装置から受信した第1の暗号化データを自車載コンピュータが予め格納している初期鍵により復号して第1の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第2の暗号化データを該取得した第1の鍵により復号して第2の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第4の暗号化データを該取得した第1の鍵により復号して期待値を取得する暗号処理部と、
前記インタフェース部により前記データ提供装置から受信した適用データの測定値を該取得された第2の鍵を使用して計算し、該取得された期待値に基づいて該測定値を検証する測定部と、を備え、該測定値の検証結果を前記インタフェース部により前記データ提供装置に送信する、
管理システム。
A data providing device and an in-vehicle computer mounted on the vehicle;
The data providing device includes:
A vehicle interface for transmitting and receiving data to and from the vehicle;
A key generation unit for generating a first key and a second key stored in the in-vehicle computer;
Using the second key, an expected value calculation unit for calculating an expected value of application data applied to the in-vehicle computer;
The first key is encrypted with an initial key stored in advance in the in-vehicle computer to generate first encrypted data, and the second key is encrypted with the first key to generate a second cipher. An encryption processing unit that generates encrypted data and encrypts the expected value with the first key to generate fourth encrypted data, the application data, the first encrypted data, the first encrypted data, 2 encrypted data and the fourth encrypted data are transmitted to the vehicle by the vehicle interface, and the verification result of the measurement value of the application data is received from the vehicle by the vehicle interface,
The in-vehicle computer is
An interface unit for transmitting / receiving data to / from an external device of the in-vehicle computer;
The first encrypted data received from the data providing device by the interface unit is decrypted with the initial key stored in advance by the in-vehicle computer, and the first key is obtained from the data providing device by the interface unit. The received second encrypted data is decrypted with the obtained first key to obtain a second key, and the fourth encrypted data received from the data providing apparatus by the interface unit is obtained. An encryption processing unit that obtains an expected value by decrypting with one key;
A measurement unit that calculates a measurement value of the application data received from the data providing device by the interface unit using the acquired second key, and verifies the measurement value based on the acquired expected value; And the verification result of the measurement value is transmitted to the data providing device by the interface unit.
Management system.
車両とデータを送受する車両インタフェースと、
前記車両に搭載される車載コンピュータに格納される第1の鍵及び第2の鍵を生成する鍵生成部と、
前記第2の鍵を使用して、前記車載コンピュータに適用される適用データの期待値を計算する期待値計算部と、
前記車載コンピュータが予め格納している初期鍵により前記第1の鍵を暗号化して第1の暗号化データを生成し、前記第1の鍵により前記第2の鍵を暗号化して第2の暗号化データを生成し、前記第1の鍵により前記期待値を暗号化して第4の暗号化データを生成する暗号処理部と、を備え、
前記適用データ、前記第1の暗号化データ、前記第2の暗号化データ及び前記第4の暗号化データを前記車両インタフェースにより前記車両に送信し、
前記適用データの測定値の検証結果を前記車両インタフェースにより前記車両から受信する、
データ提供装置。
A vehicle interface for sending and receiving data to and from the vehicle;
A key generation unit for generating a first key and a second key stored in an in-vehicle computer mounted on the vehicle;
Using the second key, an expected value calculation unit for calculating an expected value of application data applied to the in-vehicle computer;
The first key is encrypted with an initial key stored in advance in the in-vehicle computer to generate first encrypted data, and the second key is encrypted with the first key to generate a second cipher. Generating encrypted data, and encrypting the expected value with the first key to generate fourth encrypted data, and
Transmitting the application data, the first encrypted data, the second encrypted data, and the fourth encrypted data to the vehicle by the vehicle interface;
Receiving the verification result of the measurement value of the application data from the vehicle by the vehicle interface;
Data provision device.
車両に搭載される車載コンピュータにおいて、
自車載コンピュータの外部の装置とデータを送受するインタフェース部と、
前記インタフェース部によりデータ提供装置から受信した第1の暗号化データを自車載コンピュータが予め格納している初期鍵により復号して第1の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第2の暗号化データを該取得した第1の鍵により復号して第2の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第4の暗号化データを該取得した第1の鍵により復号して期待値を取得する暗号処理部と、
前記インタフェース部により前記データ提供装置から受信した適用データの測定値を該取得された第2の鍵を使用して計算し、該取得された期待値に基づいて該測定値を検証する測定部と、を備え、
該測定値の検証結果を前記インタフェース部により前記データ提供装置に送信する、
車載コンピュータ。
In an in-vehicle computer mounted on a vehicle,
An interface unit for transmitting / receiving data to / from an external device of the in-vehicle computer;
The first encrypted data received from the data providing device by the interface unit is decrypted with the initial key stored in advance in the in-vehicle computer, and the first key is obtained and received from the data providing device by the interface unit. The second encrypted data is decrypted with the obtained first key to obtain a second key, and the fourth encrypted data received from the data providing device by the interface unit is obtained. An encryption processing unit that obtains an expected value by decrypting with the key of
A measurement unit that calculates a measurement value of the application data received from the data providing device by the interface unit using the acquired second key, and verifies the measurement value based on the acquired expected value; With
The verification result of the measurement value is transmitted to the data providing apparatus by the interface unit.
In-vehicle computer.
データ提供装置と、車両に搭載される車載コンピュータとを備える管理システムの管理方法であって、
前記データ提供装置が、前記車載コンピュータに格納される第1の鍵及び第2の鍵を生成する鍵生成ステップと、
前記データ提供装置が、前記第2の鍵を使用して、前記車載コンピュータに適用される適用データの期待値を計算する期待値計算ステップと、
前記データ提供装置が、前記車載コンピュータが予め格納している初期鍵により前記第1の鍵を暗号化して第1の暗号化データを生成し、前記第1の鍵により前記第2の鍵を暗号化して第2の暗号化データを生成し、前記第1の鍵により前記期待値を暗号化して第4の暗号化データを生成する暗号処理ステップと、
前記データ提供装置が、前記車両とデータを送受する車両インタフェースにより、前記適用データ、前記第1の暗号化データ、前記第2の暗号化データ及び前記第4の暗号化データを前記車両に送信するステップと、
前記車載コンピュータが、自車載コンピュータの外部の装置とデータを送受するインタフェース部により前記データ提供装置から受信した第1の暗号化データを自車載コンピュータが予め格納している初期鍵により復号して第1の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第2の暗号化データを該取得した第1の鍵により復号して第2の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第4の暗号化データを該取得した第1の鍵により復号して期待値を取得する暗号処理ステップと、
前記車載コンピュータが、前記インタフェース部により前記データ提供装置から受信した適用データの測定値を該取得された第2の鍵を使用して計算し、該取得された期待値に基づいて該測定値を検証する測定ステップと、
前記車載コンピュータが、該測定値の検証結果を前記インタフェース部により前記データ提供装置に送信するステップと、
前記データ提供装置が、前記適用データの測定値の検証結果を前記車両インタフェースにより前記車両から受信するステップと、
を含む管理方法。
A management method for a management system comprising a data providing device and an in-vehicle computer mounted on a vehicle,
A key generation step in which the data providing device generates a first key and a second key stored in the in-vehicle computer;
An expected value calculating step in which the data providing device calculates an expected value of application data applied to the in-vehicle computer using the second key;
The data providing apparatus generates first encrypted data by encrypting the first key with an initial key stored in advance in the in-vehicle computer, and encrypts the second key with the first key. Generating second encrypted data, encrypting the expected value with the first key, and generating fourth encrypted data; and
The data providing device transmits the application data, the first encrypted data, the second encrypted data, and the fourth encrypted data to the vehicle by a vehicle interface that transmits and receives data to and from the vehicle. Steps,
The in-vehicle computer decrypts the first encrypted data received from the data providing device by the interface unit that transmits / receives data to / from an external device of the in-vehicle computer with the initial key stored in advance in the in-vehicle computer. 1 is obtained, the second encrypted data received from the data providing device by the interface unit is decrypted by the obtained first key, and a second key is obtained, and the data is obtained by the interface unit. A cryptographic processing step of decrypting the fourth encrypted data received from the providing device with the acquired first key and acquiring an expected value;
The in-vehicle computer calculates the measured value of the application data received from the data providing device by the interface unit using the acquired second key, and calculates the measured value based on the acquired expected value. A measurement step to be verified;
The in-vehicle computer transmitting a verification result of the measurement value to the data providing apparatus by the interface unit;
The data providing device receiving a verification result of the measurement value of the application data from the vehicle by the vehicle interface;
Management method including.
車両とデータを送受する車両インタフェースを備えるデータ提供装置のコンピュータに、
前記車載コンピュータに格納される第1の鍵及び第2の鍵を生成する鍵生成機能と、
前記第2の鍵を使用して、前記車載コンピュータに適用される適用データの期待値を計算する期待値計算機能と、
前記車載コンピュータが予め格納している初期鍵により前記第1の鍵を暗号化して第1の暗号化データを生成し、前記第1の鍵により前記第2の鍵を暗号化して第2の暗号化データを生成し、前記第1の鍵により前記期待値を暗号化して第4の暗号化データを生成する暗号処理機能と、
前記車両インタフェースにより、前記適用データ、前記第1の暗号化データ、前記第2の暗号化データ及び前記第4の暗号化データを前記車両に送信する送信機能と、
前記車両インタフェースにより、前記適用データの測定値の検証結果を前記車両から受信する受信機能と、
を実現させるためのコンピュータプログラム。
In a computer of a data providing device having a vehicle interface for sending and receiving data to and from a vehicle,
A key generation function for generating a first key and a second key stored in the in-vehicle computer;
An expected value calculation function for calculating an expected value of application data applied to the in-vehicle computer using the second key;
The first key is encrypted with an initial key stored in advance in the in-vehicle computer to generate first encrypted data, and the second key is encrypted with the first key to generate a second cipher. Generating encrypted data, encrypting the expected value with the first key, and generating fourth encrypted data; and
A transmission function for transmitting the application data, the first encrypted data, the second encrypted data, and the fourth encrypted data to the vehicle by the vehicle interface;
A reception function for receiving a verification result of the measurement value of the application data from the vehicle by the vehicle interface;
Computer program for realizing.
車両に搭載される車載コンピュータに、
自車載コンピュータの外部の装置とデータを送受するインタフェース部によりデータ提供装置から受信した第1の暗号化データを自車載コンピュータが予め格納している初期鍵により復号して第1の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第2の暗号化データを該取得した第1の鍵により復号して第2の鍵を取得し、前記インタフェース部により前記データ提供装置から受信した第4の暗号化データを該取得した第1の鍵により復号して期待値を取得する暗号処理機能と、
前記インタフェース部により前記データ提供装置から受信した適用データの測定値を該取得された第2の鍵を使用して計算し、該取得された期待値に基づいて該測定値を検証する測定機能と、
該測定値の検証結果を前記インタフェース部により前記データ提供装置に送信する送信機能と、
を実現させるためのコンピュータプログラム。
In-vehicle computers mounted on vehicles
A first key is obtained by decrypting the first encrypted data received from the data providing device by an interface unit that transmits and receives data with a device external to the vehicle-mounted computer, using the initial key stored in advance by the vehicle-mounted computer. The second encrypted data received from the data providing device by the interface unit is decrypted with the acquired first key to obtain a second key, and the second key received from the data providing device by the interface unit An encryption processing function for decrypting the encrypted data of 4 with the acquired first key and acquiring an expected value;
A measurement function for calculating a measurement value of application data received from the data providing apparatus by the interface unit using the acquired second key, and verifying the measurement value based on the acquired expected value; ,
A transmission function of transmitting the verification result of the measurement value to the data providing apparatus by the interface unit;
Computer program for realizing.
JP2017197257A 2017-10-10 2017-10-10 Management system, data providing apparatus, in-vehicle computer, management method, and computer program Active JP6454919B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2017197257A JP6454919B2 (en) 2017-10-10 2017-10-10 Management system, data providing apparatus, in-vehicle computer, management method, and computer program

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2017197257A JP6454919B2 (en) 2017-10-10 2017-10-10 Management system, data providing apparatus, in-vehicle computer, management method, and computer program

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
JP2016156573A Division JP6260067B1 (en) 2016-08-09 2016-08-09 Management system, key generation device, in-vehicle computer, management method, and computer program

Publications (2)

Publication Number Publication Date
JP2018026866A true JP2018026866A (en) 2018-02-15
JP6454919B2 JP6454919B2 (en) 2019-01-23

Family

ID=61194346

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2017197257A Active JP6454919B2 (en) 2017-10-10 2017-10-10 Management system, data providing apparatus, in-vehicle computer, management method, and computer program

Country Status (1)

Country Link
JP (1) JP6454919B2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2019212403A1 (en) * 2018-04-30 2019-11-07 华为国际有限公司 Method for upgrading vehicle-mounted device, and related device

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20010002814A1 (en) * 1999-12-07 2001-06-07 Takeshi Suganuma Control information rewriting system
US20110320089A1 (en) * 2010-06-25 2011-12-29 Toyota Motor Engineering & Manufacturing North America, Inc. Over-the-Air Vehicle Systems Updating and Associate Security Protocols
WO2014002280A1 (en) * 2012-06-29 2014-01-03 富士通株式会社 Communication program, recording medium, communication apparatus, and communication method
US20140181526A1 (en) * 2012-12-20 2014-06-26 GM Global Technology Operations LLC Methods and systems for bypassing authenticity checks for secure control modules
JP2014182571A (en) * 2013-03-19 2014-09-29 Denso Corp On-vehicle electronic control device program rewriting system and on-vehicle relay device
JP2015103163A (en) * 2013-11-27 2015-06-04 株式会社オートネットワーク技術研究所 Program update system and program update method
US9177153B1 (en) * 2005-10-07 2015-11-03 Carnegie Mellon University Verifying integrity and guaranteeing execution of code on untrusted computer platform
JP2016092811A (en) * 2014-10-29 2016-05-23 Kddi株式会社 Key management system, key management server device, management device, vehicle, key management method and computer program

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20010002814A1 (en) * 1999-12-07 2001-06-07 Takeshi Suganuma Control information rewriting system
US9177153B1 (en) * 2005-10-07 2015-11-03 Carnegie Mellon University Verifying integrity and guaranteeing execution of code on untrusted computer platform
US20110320089A1 (en) * 2010-06-25 2011-12-29 Toyota Motor Engineering & Manufacturing North America, Inc. Over-the-Air Vehicle Systems Updating and Associate Security Protocols
WO2014002280A1 (en) * 2012-06-29 2014-01-03 富士通株式会社 Communication program, recording medium, communication apparatus, and communication method
US20140181526A1 (en) * 2012-12-20 2014-06-26 GM Global Technology Operations LLC Methods and systems for bypassing authenticity checks for secure control modules
JP2014182571A (en) * 2013-03-19 2014-09-29 Denso Corp On-vehicle electronic control device program rewriting system and on-vehicle relay device
JP2015103163A (en) * 2013-11-27 2015-06-04 株式会社オートネットワーク技術研究所 Program update system and program update method
JP2016092811A (en) * 2014-10-29 2016-05-23 Kddi株式会社 Key management system, key management server device, management device, vehicle, key management method and computer program

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
竹森 敬祐 ほか: "セキュアエレメントを活用したECU認証とコード認証の鍵管理", 電子情報通信学会技術研究報告, vol. 115, no. 365, JPN6017011703, 10 December 2015 (2015-12-10), JP, pages 227 - 232, ISSN: 0003923503 *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2019212403A1 (en) * 2018-04-30 2019-11-07 华为国际有限公司 Method for upgrading vehicle-mounted device, and related device
US11985238B2 (en) 2018-04-30 2024-05-14 Huawei International Pte. Ltd. Vehicle-mounted device upgrade method and related device

Also Published As

Publication number Publication date
JP6454919B2 (en) 2019-01-23

Similar Documents

Publication Publication Date Title
JP6260067B1 (en) Management system, key generation device, in-vehicle computer, management method, and computer program
US10855460B2 (en) In-vehicle computer system, vehicle, key generation device, management method, key generation method, and computer program
JP6683588B2 (en) Reuse system, server device, reuse method, and computer program
JP6197000B2 (en) System, vehicle, and software distribution processing method
JP6288219B1 (en) Communications system
JP6178390B2 (en) Management device, management system, vehicle, management method, and computer program
US10970398B2 (en) Data provision system, data security device, data provision method, and computer program
WO2018029905A1 (en) Data provision system, data security device, data provision method, and computer program
JP6440334B2 (en) System, vehicle, and software distribution processing method
JP2017046038A (en) On-vehicle computer system, vehicle, management method, and computer program
JP6547180B2 (en) Communications system
JP6454919B2 (en) Management system, data providing apparatus, in-vehicle computer, management method, and computer program
JP2018006782A (en) Data providing system, data providing apparatus, on-vehicle computer, data providing method, and computer program
JP6554704B2 (en) Data providing system and data providing method
JP2018050334A (en) Data provision system, data provision device, on-vehicle computer, data provision method, and computer program
JP6787848B2 (en) Communication system and communication method
JP6354099B2 (en) Data providing system and data providing method
JP2017208731A (en) Management system, management device, on-vehicle computer, management method, and computer program
WO2018131270A1 (en) Communication system, vehicle, server device, communication method, and computer program

Legal Events

Date Code Title Description
TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20181120

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20181127

R150 Certificate of patent or registration of utility model

Ref document number: 6454919

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150