IP Force 特許公報掲載プロジェクト 2022.1.31 β版

知財求人 - 知財ポータルサイト「IP Force」

▶ パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカの特許一覧

特許7588687装置、ファームウェア更新方法及び制御プログラム
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-11-14
(45)【発行日】2024-11-22
(54)【発明の名称】装置、ファームウェア更新方法及び制御プログラム
(51)【国際特許分類】
   G06F 8/65 20180101AFI20241115BHJP
   B60R 16/02 20060101ALI20241115BHJP
【FI】
G06F8/65
B60R16/02 660U
【請求項の数】 12
(21)【出願番号】P 2023111305
(22)【出願日】2023-07-06
(62)【分割の表示】P 2021169991の分割
【原出願日】2016-05-31
(65)【公開番号】P2023126316
(43)【公開日】2023-09-07
【審査請求日】2023-08-04
(31)【優先権主張番号】62/218,074
(32)【優先日】2015-09-14
(33)【優先権主張国・地域又は機関】US
(73)【特許権者】
【識別番号】514136668
【氏名又は名称】パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカ
【氏名又は名称原語表記】Panasonic Intellectual Property Corporation of America
(74)【代理人】
【識別番号】100109210
【弁理士】
【氏名又は名称】新居 広守
(74)【代理人】
【識別番号】100137235
【弁理士】
【氏名又は名称】寺谷 英作
(74)【代理人】
【識別番号】100131417
【弁理士】
【氏名又は名称】道坂 伸一
(72)【発明者】
【氏名】前田 学
(72)【発明者】
【氏名】松島 秀樹
(72)【発明者】
【氏名】芳賀 智之
(72)【発明者】
【氏名】氏家 良浩
(72)【発明者】
【氏名】岸川 剛
【審査官】坂庭 剛史
(56)【参考文献】
【文献】特開2015-103163(JP,A)
【文献】特開2015-079440(JP,A)
【文献】特開2012-091755(JP,A)
【文献】国際公開第2012/017719(WO,A1)
【文献】特開2011-070307(JP,A)
【文献】特開2009-053920(JP,A)
【文献】特開2007-126024(JP,A)
【文献】特開2006-011647(JP,A)
【文献】特開2005-202503(JP,A)
【文献】特開2004-310221(JP,A)
(58)【調査した分野】(Int.Cl.,DB名)
G06F 8/65
B60R 16/02
(57)【特許請求の範囲】
【請求項1】
車両に搭載された複数の電子制御ユニットが通信に用いるネットワークに接続された装置であって、
前記複数の電子制御ユニットのうち、1つの電子制御ユニットを特定する識別情報と、識別情報に特定された電子制御ユニットの更新用ファームウェアと、検証済構成情報とを含むファームウェア更新情報を取得する取得部と、
前記検証済構成情報は、前記更新用ファームウェアの動作検証に用いられた複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを示し、前記複数の電子制御ユニットの各々のファームウェアのバージョンのうち、ファームウェアを更新する対象の電子制御ユニットのファームウェアは、更新前のファームウェアのバージョンを示し、
前記ネットワークに接続される前記複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを含むシステム構成情報を取得する取得部と、
前記システム構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンと、前記検証済構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを比較し、比較結果が一定条件を満たした場合に前記更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理部とを備える
装置
【請求項2】
前記更新処理部における比較結果が一定条件を満たさない場合に、前記ファームウェア更新情報に関する情報と前記システム構成情報とを動作検証要求として送信する送信部をさらに備える
請求項1記載の装置
【請求項3】
前記送信部により前記動作検証要求を送信した後、前記取得部は前記ファームウェア更新情報を再度取得し、
前記更新処理部は、前記システム構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンと、前記検証済構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを比較し、前記比較結果が一定条件を満たした場合に前記更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う
請求項2記載の装置
【請求項4】
前記ネットワークに接続された前記複数の電子制御ユニットは、Controller
Area Network(CAN)プロトコルに従って前記ネットワークを介して通信を行い、
前記更新処理部は、前記更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための前記制御として、前記ネットワークを介して前記該当の電子制御ユニットへの前記更新用ファームウェアの送信を行う
請求項1または2に記載の装置
【請求項5】
前記比較結果が一定条件を満たす場合とは、前記システム構成情報が示す、識別情報に特定された前記複数の電子制御ユニット全ての種類を、前記検証済構成情報が示す、更新前の識別情報に特定された前記複数の電子制御ユニットの種類が包含している場合である
請求項1に記載の装置。
【請求項6】
前記ファームウェア更新情報に複数の更新用ファームウェアが含まれる場合、前記ファームウェア更新情報は、更に動作検証に用いられたファームウェアの更新順序を示す更新順情報が含まれ、
比較結果が一定条件を満たした場合に、前記更新処理部は、前記更新順情報が示す順序に従って前記更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う
請求項1に記載の装置。
【請求項7】
前記ファームウェア更新情報は、前記更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新に必要な時間または更新に必要なメモリサイズを含み、
比較結果が一定条件を満たした場合に、前記更新処理部は、前記更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行うタイミングを判断する、
請求項1に記載の装置。
【請求項8】
更に、前記複数の電子制御ユニットをシミュレートするシミュレーション部を備え、
比較結果が一定条件を満たさない場合に、前記システム構成情報を用いて前記更新用ファームウェアの動作のシミュレーションを、前記シミュレーション部に行わせ、当該シミュレーションによる動作検証がなされた後に当該更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う
請求項1に記載の装置。
【請求項9】
前記比較結果が一定条件を満たす場合とは、前記比較結果が完全一致した場合である、
請求項8に記載の装置。
【請求項10】
電子制御ユニットのファームウェアを更新するためのファームウェア更新方法であって、
車両に搭載された複数の電子制御ユニットが通信に用いるネットワークに接続された装置が、前記複数の電子制御ユニットのうち、1つの電子制御ユニットを特定する識別情報と、識別情報に特定された電子制御ユニットの更新用ファームウェアと、検証済構成情報とを含むファームウェア更新情報を取得する取得ステップと、
前記検証済構成情報は、前記更新用ファームウェアの動作検証に用いられた複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを示し、前記複数の電子制御ユニットの各々のファームウェアのバージョンのうち、ファームウェアを更新する対象の電子制御ユニットのファームウェアは、更新前のファームウェアのバージョンを示し、
前記装置が、前記ネットワークに接続される前記複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンを含むシステム構成情報を取得する取得ステップと、
前記システム構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンと、前記検証済構成情報が示す、識別情報に特定された前記複数の電子制御ユニット各々のファームウェアのバージョンとを比較し、比較結果が一定条件を満たした場合に前記更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理ステップとを含む
ファームウェア更新方法。
【請求項11】
前記ファームウェア更新方法は更に、
前記更新処理ステップにおける前記比較結果が一定条件を満たさない場合に前記ファームウェア更新情報に関する情報と前記システム構成情報とを動作検証要求として送信する送信ステップを含む
請求項10記載のファームウェア更新方法。
【請求項12】
車両に搭載された複数の電子制御ユニットが通信に用いるネットワークに接続された、プロセッサを備える装置にファームウェア更新処理を実行させるための制御プログラムであって、
前記ファームウェア更新処理は、
前記複数の電子制御ユニットのうち、1つの電子制御ユニットを特定する識別情報と、識別情報に特定された電子制御ユニットの更新用ファームウェアと検証済構成情報とを含むファームウェア更新情報を取得する取得ステップと、
前記検証済構成情報は、前記更新用ファームウェアの動作検証に用いられた複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを示し、
前記ネットワークに接続される前記複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンを含むシステム構成情報を取得する取得ステップと、
前記システム構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンと、前記検証済構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを比較し、比較結果が一定条件を満たした場合に前記更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理ステップとを含む
制御プログラム。
【発明の詳細な説明】
【技術分野】
【0001】
本発明は、車載ネットワークで通信する電子制御ユニットのファームウェアを更新(アップデート)する技術に関する。
【背景技術】
【0002】
近年、自動車の中のシステムには、電子制御ユニット(ECU:Electronic Control Unit)と呼ばれる装置が多数配置されている。これらのECUをつなぐネットワークは車
載ネットワークと呼ばれる。車載ネットワークには、多数の規格が存在する。その中でも最も主流な車載ネットワークの一つに、ISO11898-1で規定されているCAN(Controller Area Network)という規格が存在する。
【0003】
CANでは、通信路は2本のバスで構成され、バスに接続されているECUはノードと呼ばれる。バスに接続されている各ノードは、フレームと呼ばれるメッセージを送受信する。またCANでは、送信先や送信元を指す識別子は存在せず、送信ノードはフレーム毎にメッセージIDと呼ばれるIDを付けて送信し(つまりバスに信号を送出し)、各受信ノードは予め定められたメッセージIDのみを受信する(つまりバスから信号を読み取る)。
【0004】
多数のECUがバスを介したメッセージの授受により連携して動作している場合に、あるECUがファームウェアの更新を開始すると、その更新中はメッセージの授受ができない等によって自動車の走行に影響を与える可能性がある。この点に関して、自動車の状態を示す情報から、停車中等といったECUのファームウェアを更新できると判断できた場合にのみファームウェアを更新する技術が知られている(特許文献1参照)。
【先行技術文献】
【特許文献】
【0005】
【文献】特開2010-273181号公報
【発明の概要】
【発明が解決しようとする課題】
【0006】
しかしながら、特許文献1の技術は、ファームウェアの更新を適切(例えば安全)なタイミングで実行するものの、ファームウェアの更新後に自動車等の車両が正常に機能しないことを抑制するものではない。
【0007】
そこで、本発明は、ファームウェアの更新後に車両が正常に機能しなくなる可能性を低減させるファームウェア更新方法を提供する。また、本発明は、ファームウェアの更新後に車両が正常に機能しなくなる可能性を低減させるようにファームウェアの更新のための制御を行うゲートウェイ装置、及び、そのゲートウェイ装置に用いられるファームウェアの更新のための制御プログラムを提供する。
【課題を解決するための手段】
【0008】
上記課題を解決するために本発明の一態様に係るゲートウェイ装置は、車両に搭載された複数の電子制御ユニットが通信に用いるネットワークに接続されたゲートウェイ装置であって、前記複数の電子制御ユニットのうち、1つの電子制御ユニットを特定する識別情報と、識別情報に特定された電子制御ユニットの更新用ファームウェアと、検証済構成情報とを含むファームウェア更新情報を受信する受信部と、前記検証済構成情報は、前記更新用ファームウェアの動作検証に用いられた複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを示し、前記ネットワークに接続される前記複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを含むシステム構成情報を取得する取得部と、前記システム構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンと、前記検証済構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを比較し、比較結果が一定条件を満たした場合に前記更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理部とを備える。
【0009】
また、上記課題を解決するために本発明の一態様に係るファームウェア更新方法は、電子制御ユニットのファームウェアを更新するためのファームウェア更新方法であって、車両に搭載された複数の電子制御ユニットが通信に用いるネットワークに接続されたゲートウェイ装置が、前記複数の電子制御ユニットのうち、1つの電子制御ユニットを特定する識別情報と、識別情報に特定された電子制御ユニットの更新用ファームウェアと、検証済構成情報とを含むファームウェア更新情報を受信する受信ステップと、前記検証済構成情報は、前記更新用ファームウェアの動作検証に用いられた複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを示し、前記ゲートウェイ装置が、前記ネットワークに接続される前記複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンを含むシステム構成情報を取得する取得ステップと、前記システム構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンと、前記検証済構成情報が示す、識別情報に特定された前記複数の電子制御ユニット各々のファームウェアのバージョンとを比較し、比較結果が一定条件を満たした場合に前記更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理ステップとを含む。
【0010】
また、上記課題を解決するために本発明の一態様に係る制御プログラムは、車両に搭載された複数の電子制御ユニットが通信に用いるネットワークに接続された、プロセッサを備えるゲートウェイ装置にファームウェア更新処理を実行させるための制御プログラムであって、前記ファームウェア更新処理は、前記複数の電子制御ユニットのうち、1つの電子制御ユニットを特定する識別情報と、識別情報に特定された電子制御ユニットの更新用ファームウェアと検証済構成情報とを含むファームウェア更新情報を受信する受信ステップと、前記検証済構成情報は、前記更新用ファームウェアの動作検証に用いられた複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを示し、前記ネットワークに接続される前記複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンを含むシステム構成情報を取得する取得ステップと、前記システム構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンと、前記検証済構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを比較し、比較結果が一定条件を満たした場合に前記更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理ステップとを含む。
【0011】
上記課題を解決するために本発明の一態様に係るゲートウェイ装置は、車両に搭載された複数の電子制御ユニットが通信に用いるネットワークに接続されたゲートウェイ装置であって、前記複数の電子制御ユニットのうち、1つの電子制御ユニットを特定する識別情報と、識別情報に特定された電子制御ユニットの更新用ファームウェアと、検証済構成情報とを含むファームウェア更新情報を受信する受信部と、前記検証済構成情報は、前記更新用ファームウェアの動作検証に用いられた複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを示し、前記ネットワークに接続される前記複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを含むシステム構成情報を取得する取得部と、前記複数の電子制御ユニットをシミュレートするシミュレーション部と、前記システム構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンと、前記検証済構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを比較し、比較結果が一定条件を満たさない場合に、前記システム構成情報を用いて前記更新用ファームウェアの動作のシミュレーションを、前記シミュレーション部に行わせ、当該シミュレーションによる動作検証がなされた後に当該更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理部とを備える。
【0012】
また、上記課題を解決するために本発明の一態様に係るファームウェア更新方法は、電子制御ユニットのファームウェアを更新するためのファームウェア更新方法であって、車両に搭載された複数の電子制御ユニットが通信に用いるネットワークに接続されたゲートウェイ装置が、前記複数の電子制御ユニットのうち、1つの電子制御ユニットを特定する識別情報と、識別情報に特定された電子制御ユニットの更新用ファームウェアと、検証済構成情報とを含むファームウェア更新情報を受信する受信ステップと、前記検証済構成情報は、前記更新用ファームウェアの動作検証に用いられた複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを示し、前記ゲートウェイ装置が、前記ネットワークに接続される前記複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンを含むシステム構成情報を取得する取得ステップと、前記複数の電子制御ユニットをシミュレートするシミュレーションステップと、前記システム構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンと、前記検証済構成情報が示す、識別情報に特定された前記複数の電子制御ユニット各々のファームウェアのバージョンとを比較し、比較結果が一定条件を満たさない場合に、前記ゲートウェイ装置が、前記システム構成情報を用いて前記更新用ファームウェアの動作のシミュレーションを、前記シミュレーションステップに行わせ、当該シミュレーションによる動作検証がなされた後に当該更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理ステップとを含む。
【0013】
また、上記課題を解決するために本発明の一態様に係る制御プログラムは、車両に搭載された複数の電子制御ユニットが通信に用いるネットワークに接続された、プロセッサを備えるゲートウェイ装置にファームウェア更新処理を実行させるための制御プログラムであって、前記ファームウェア更新処理は、前記複数の電子制御ユニットのうち、1つの電子制御ユニットを特定する識別情報と、識別情報に特定された電子制御ユニットの更新用ファームウェアと検証済構成情報とを含むファームウェア更新情報を受信する受信ステップと、前記検証済構成情報は、前記更新用ファームウェアの動作検証に用いられた複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを示し、前記ネットワークに接続される前記複数の電子制御ユニットの各々を特定する識別情報と識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンを含むシステム構成情報を取得する取得ステップと、前記複数の電子制御ユニットをシミュレートするシミュレーションステップと、前記システム構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンと、前記検証済構成情報が示す、識別情報に特定された前記複数の電子制御ユニットの各々のファームウェアのバージョンとを比較し、比較結果が一定条件を満たさない場合に、前記システム構成情報を用いて前記更新用ファームウェアの動作のシミュレーションを、前記シミュレーションステップに行わせ、当該シミュレーションによる動作検証がなされた後に当該更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理ステップとを含む。
【0014】
上記課題を解決するために本発明の一態様に係るゲートウェイ装置は、車両に搭載された複数の電子制御ユニットが通信に用いるバスに接続されたゲートウェイ装置であって、前記車両外の外部装置から、前記複数の電子制御ユニットのうち1つの電子制御ユニットの更新用ファームウェアを含むファームウェア更新情報を受信する受信部と、前記バスに接続される前記複数の電子制御ユニット各々の種類を示すシステム構成情報を取得する取得部と、前記システム構成情報が示す各種類の電子制御ユニットを用いて前記更新用ファームウェアの動作検証がなされた後に当該更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理部とを備えるゲートウェイ装置である。
【0015】
また、上記課題を解決するために本発明の一態様に係るファームウェア更新方法は、電子制御ユニットのファームウェアを更新するためのファームウェア更新方法であって、車両に搭載された複数の電子制御ユニットが通信に用いるバスに接続されたゲートウェイ装置が、前記車両外の外部装置から、前記複数の電子制御ユニットのうち1つの電子制御ユニットの更新用ファームウェアを含むファームウェア更新情報を受信する受信ステップと、前記ゲートウェイ装置が、前記バスに接続される前記複数の電子制御ユニット各々の種類を示すシステム構成情報を取得する取得ステップと、前記ゲートウェイ装置が、前記システム構成情報が示す各種類の電子制御ユニットを用いて前記更新用ファームウェアの動作検証がなされた後に当該更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理ステップとを含むファームウェア更新方法である。
【0016】
また、上記課題を解決するために本発明の一態様に係る制御プログラムは、車両に搭載された複数の電子制御ユニットが通信に用いるバスに接続された、プロセッサを備えるゲートウェイ装置にファームウェア更新処理を実行させるための制御プログラムであって、前記ファームウェア更新処理は、前記車両外の外部装置から、前記複数の電子制御ユニットのうち1つの電子制御ユニットの更新用ファームウェアを含むファームウェア更新情報を受信する受信ステップと、前記バスに接続される前記複数の電子制御ユニット各々の種類を示すシステム構成情報を取得する取得ステップと、前記システム構成情報が示す各種類の電子制御ユニットを用いて前記更新用ファームウェアの動作検証がなされた後に当該更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理ステップとを含む制御プログラムである。
【発明の効果】
【0017】
本発明によれば、ファームウェアの更新後に車両が正常に機能しなくなる可能性が低減される。
【図面の簡単な説明】
【0018】
図1】実施の形態1に係る車載ネットワークシステムの全体構成を示す図である。
図2】CANプロトコルで規定されるデータフレームのフォーマットを示す図である。
図3】実施の形態1に係るゲートウェイの構成図である。
図4】受信IDリストの一例を示す図である。
図5】ゲートウェイが用いる転送ルールの一例を示す図である。
図6】実施の形態1に係るシステム構成情報(ECU情報のリスト)の一例を示す図である。
図7】実施の形態1に係るECUの構成図である。
図8】実施の形態1に係るサーバの構成図である。
図9】サーバが保持する車両ECU管理情報の一例を示す図である。
図10】実施の形態1に係るファームウェア(FW)更新情報のフォーマットの一例を示す図である。
図11】実施の形態1におけるファームウェアの更新に係る動作例を示すシーケンス図である(図12に続く)。
図12】実施の形態1におけるファームウェアの更新に係る動作例を示すシーケンス図である(図11から続く)。
図13】実施の形態1に係るゲートウェイによるFW更新制御処理の一例を示すフローチャートである。
図14】実施の形態1に係るECUによるFW更新制御処理の一例を示すフローチャートである。
図15】実施の形態2に係るゲートウェイの構成図である。
図16】実施の形態2に係るFW更新情報のフォーマットの一例を示す図である。
図17】実施の形態2に係るECU構成情報のフォーマットの一例を示す図である。
図18】実施の形態2に係るサーバの構成図である。
図19】実施の形態2に係るECU車両モデル管理テーブルの一例を示す図である。
図20】実施の形態2に係る車両モデルECU管理テーブルの一例を示す図である。
図21】実施の形態2におけるサーバによる更新用ファームウェアの登録に係るFW登録処理を示すフローチャートである。
図22】実施の形態2に係るサーバによるFW動作検証処理の一例を示すフローチャートである。
図23】実施の形態2に係るサーバによる複数のファームウェアの検証に係るFW動作検証処理の一例を示すフローチャートである。
図24】実施の形態2におけるファームウェアの更新に係る動作例を示すシーケンス図である(図25に続く)。
図25】実施の形態2におけるファームウェアの更新に係る動作例を示すシーケンス図である(図24から続く)。
図26】実施の形態2におけるFW動作検証処理に用いられるシミュレータによる仮想環境のソフトウェア構成の一例を示す図である。
【発明を実施するための形態】
【0019】
本発明の一態様に係るゲートウェイ装置は、車両に搭載された複数の電子制御ユニットが通信に用いるバスに接続されたゲートウェイ装置であって、前記車両外の外部装置から、前記複数の電子制御ユニットのうち1つの電子制御ユニットの更新用ファームウェアを含むファームウェア更新情報を受信する受信部と、前記バスに接続される前記複数の電子制御ユニット各々の種類を示すシステム構成情報を取得する取得部と、前記システム構成情報が示す各種類の電子制御ユニットを用いて前記更新用ファームウェアの動作検証がなされた後に当該更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理部とを備えるゲートウェイ装置である。これにより、ファームウェアの更新に際して複数の電子制御ユニットに対応した、更新用ファームウェアの動作検証の実施が確保された後に更新の制御が行われるので、動作検証が行われない場合と比べてファームウェアの更新後に車両が正常に機能しなくなる可能性が低減する。
【0020】
また、前記ファームウェア更新情報は、前記更新用ファームウェアの動作検証に用いられた複数の電子制御ユニット各々の種類を示す検証済構成情報を含み、前記更新処理部は、前記システム構成情報が示す、前記車両に搭載された複数の電子制御ユニット各々の種類と、前記受信部に受信された前記検証済構成情報が示す、前記動作検証に用いられた複数の電子制御ユニット各々の種類とを比較し、比較結果が一定条件を満たした場合に前記更新用ファームウェアに基づく前記更新を行わせるように前記制御を行うこととしても良い。これにより、ゲートウェイ装置が搭載された車両における車載ネットワークの構成(電子制御ユニット群の編成)に対応して有効な動作検証が実行されたか否か等を確認し得るので、適切な動作検証の実施の確保が可能となり得る。
【0021】
また、前記システム構成情報が示す、前記バスに接続される前記複数の電子制御ユニット各々の前記種類は、当該電子制御ユニットが実装しているファームウェアのバージョンを識別し、前記検証済構成情報が示す、前記更新用ファームウェアの動作検証に用いられた複数の電子制御ユニット各々の前記種類は、当該電子制御ユニットが実装しているファームウェアのバージョンを識別することとしても良い。これにより、車載ネットワークに接続された各電子制御ユニットのファームウェアと同じバージョンのファームウェアを実装した動作環境で動作検証がなされたか否か等を確認し得るので、適切な動作検証の実施の確保が可能となり得る。
【0022】
また、前記更新処理部は、前記システム構成情報が示す全ての種類と同じ種類が前記受信部に受信された前記検証済構成情報に示されていることを確認した場合に、前記比較結果が前記一定条件を満たしたとして前記制御を行うこととしても良い。これにより、ファームウェアの更新に際して、ゲートウェイ装置が搭載された車両における車載ネットワークに接続された各電子制御ユニットと同じ種類の電子制御ユニットを用いた更新用ファームウェアの動作検証の実施の確保が可能となり得る。
【0023】
また、前記ゲートウェイ装置は更に、前記システム構成情報を前記外部装置に送信する送信部を備え、前記更新処理部は、前記送信部が前記システム構成情報を前記外部装置に送信した後に、前記外部装置が当該システム構成情報を参照して複数の電子制御ユニットを用いて前記更新用ファームウェアの動作検証を行った後に送信した前記ファームウェア更新情報を、前記受信部により受信した場合に、当該ファームウェア更新情報の前記更新用ファームウェアに基づく前記更新を行わせるように前記制御を行うこととしても良い。これにより、ゲートウェイ装置が搭載された車両における車載ネットワークに接続された各電子制御ユニットと同じ種類の電子制御ユニットを用いた更新用ファームウェアの動作検証を外部装置に行わせてからファームウェアの更新を行うので、ファームウェアの更新後に車両が正常に機能しなくなる可能性が低減する。
【0024】
また、前記システム構成情報は、前記バスに接続される前記複数の電子制御ユニット各々について、前記種類を特定するための、当該電子制御ユニットについての識別情報及び当該電子制御ユニットが実装しているファームウェアのバージョンの識別情報を含むこととしても良い。これにより、外部装置では、車載ネットワークに接続された各電子制御ユニットのファームウェアと同じバージョンのファームウェアを実装した動作環境で動作検証を行うことが可能となり、この結果として、ファームウェアの更新後に車両が正常に機能しなくなる可能性が低減する。
【0025】
また、前記ゲートウェイ装置は、前記システム構成情報を前記外部装置に送信する機能を有する送信部を備え、前記ファームウェア更新情報は、前記更新用ファームウェアの動作検証に用いられた複数の電子制御ユニット各々の種類を示す検証済構成情報を含み、前記更新処理部は、前記システム構成情報が示す全ての種類と同じ種類が前記受信部に受信された前記検証済構成情報に示されていないことを確認した場合に、前記更新用ファームウェアに基づく前記更新を抑止して前記送信部に前記システム構成情報を前記外部装置に送信させるよう制御することとしても良い。これにより、ゲートウェイ装置が搭載された車両における車載ネットワークの構成に対応した適切な、更新用ファームウェアの動作検証が行われていない場合に、適切な動作検証を行わせるために有用な情報を送信するので、更新用ファームウェアの適切な動作検証の実施が確保される可能性が高まる。
【0026】
また、前記ゲートウェイ装置は更に、複数の電子制御ユニットをシミュレートするシミュレーション部を備え、前記ファームウェア更新情報は、前記更新用ファームウェアの動作検証に用いられた複数の電子制御ユニット各々の種類を示す検証済構成情報を含み、前記更新処理部は、前記システム構成情報が示す全ての種類と同じ種類が前記受信部に受信された前記検証済構成情報に示されていないことを確認した場合に、前記システム構成情報が示す全ての種類と同じ種類の各電子制御ユニットを用いた前記更新用ファームウェアの動作のシミュレーションを、前記シミュレーション部に行わせ、当該シミュレーションによる動作検証がなされた後に前記更新用ファームウェアに基づく前記更新を行わせるように前記制御を行うこととしても良い。これにより、車載ネットワークにおける各電子制御ユニットに対応した動作検証が行われていない場合に、シミュレーションにより更新用ファームウェアの動作検証を行った後にファームウェアの更新を行うので、ファームウェアの更新後に車両が正常に機能しなくなる可能性が低減する。なお、例えば、標準的な電子制御ユニットの構成に対応した動作検証がなされて送信されたファームウェアに対して、車両に搭載された電子制御ユニットを交換した或いは追加した後の状態においては、その動作検証では適切でないために、新たに適切な動作検証を行うことは有用である。
【0027】
また、前記ゲートウェイ装置は更に、複数の電子制御ユニットをシミュレートするシミュレーション部を備え、前記更新処理部は、前記システム構成情報が示す全ての種類と同じ種類の各電子制御ユニットを用いた前記更新用ファームウェアの動作のシミュレーションを、前記シミュレーション部に行わせ、当該シミュレーションによる動作検証がなされた後に前記更新用ファームウェアに基づく前記更新を行わせるように前記制御を行うこととしても良い。これにより、シミュレーションにより更新用ファームウェアの動作検証を行った後にファームウェアの更新を行うので、ファームウェアの更新後に車両が正常に機能しなくなる可能性が低減する。
【0028】
また、前記バスに接続された前記複数の電子制御ユニットは、Controller Area Network(CAN)プロトコルに従って前記バスを介して通信を行い、前記更新処理部は、前記更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための前記制御として、前記バスを介して前記該当の電子制御ユニットへの前記更新用ファームウェアの送信を行うこととしても良い。これにより、更新用ファームウェアの動作検証の実施が確保された後に、CANに従う車載ネットワークにおける電子制御ユニットへ更新用ファームウェアを送信してファームウェアを更新させるので、ファームウェアの更新後に車両が正常に機能しなくなる可能性が低減する。
【0029】
また、本発明の一態様に係るファームウェア更新方法は、電子制御ユニットのファームウェアを更新するためのファームウェア更新方法であって、車両に搭載された複数の電子制御ユニットが通信に用いるバスに接続されたゲートウェイ装置が、前記車両外の外部装置から、前記複数の電子制御ユニットのうち1つの電子制御ユニットの更新用ファームウェアを含むファームウェア更新情報を受信する受信ステップと、前記ゲートウェイ装置が、前記バスに接続される前記複数の電子制御ユニット各々の種類を示すシステム構成情報を取得する取得ステップと、前記ゲートウェイ装置が、前記システム構成情報が示す各種類の電子制御ユニットを用いて前記更新用ファームウェアの動作検証がなされた後に当該更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理ステップとを含むファームウェア更新方法である。これにより、ファームウェアの更新に際して複数の電子制御ユニットに対応した、更新用ファームウェアの動作検証の実施が確保された後に更新の制御が行われるので、動作検証が行われない場合と比べてファームウェアの更新後に車両が正常に機能しなくなる可能性が低減する。
【0030】
また、前記ファームウェア更新方法は更に、前記外部装置が、複数の電子制御ユニットを用いて前記更新用ファームウェアの動作検証を行う動作検証ステップと、前記外部装置が、前記動作検証ステップで動作検証に用いた複数の電子制御ユニット各々の種類を示す検証済構成情報を、前記ファームウェア更新情報に含めて送信するファームウェア更新情報送信ステップとを含み、前記更新処理ステップは、前記システム構成情報が示す、前記車両に搭載された複数の電子制御ユニット各々の種類と、前記受信ステップで受信された前記検証済構成情報が示す、前記動作検証に用いられた複数の電子制御ユニット各々の種類とを比較し、比較結果が一定条件を満たした場合に前記更新用ファームウェアに基づく前記更新を行わせるように前記制御を行うこととしても良い。これにより、ゲートウェイ装置が搭載された車両における車載ネットワークの構成(電子制御ユニット群の編成)に対応して有効な動作検証が実行されたか否か等を確認し得るので、適切な動作検証の実施の確保が可能となり得る。
【0031】
また、前記ファームウェア更新方法は更に、前記ゲートウェイ装置が、前記取得ステップで取得した前記システム構成情報を前記外部装置に送信する動作検証要求送信ステップと、前記外部装置が、前記動作検証要求送信ステップで送信された前記システム構成情報を受信して、当該システム構成情報が示す全ての種類と同じ種類の、複数の電子制御ユニットを用いて前記更新用ファームウェアの動作検証を行う動作検証ステップと、前記外部装置が、前記動作検証ステップで動作検証が行われた後に前記ファームウェア更新情報を送信するファームウェア更新情報送信ステップとを含み、前記更新処理ステップは、前記動作検証要求送信ステップでの前記システム構成情報の送信の後に前記受信ステップで前記ファームウェア更新情報が受信された場合に前記更新用ファームウェアに基づく前記更新を行わせるように前記制御を行うこととしても良い。これにより、ゲートウェイ装置が搭載された車両における車載ネットワークに接続された各電子制御ユニットと同じ種類の電子制御ユニットを用いた更新用ファームウェアの動作検証が外部装置により行われてからファームウェアの更新を行うので、ファームウェアの更新後に車両が正常に機能しなくなる可能性が低減する。
【0032】
また、本発明の一態様に係る制御プログラムは、車両に搭載された複数の電子制御ユニットが通信に用いるバスに接続された、プロセッサを備えるゲートウェイ装置にファームウェア更新処理を実行させるための制御プログラムであって、前記ファームウェア更新処理は、前記車両外の外部装置から、前記複数の電子制御ユニットのうち1つの電子制御ユニットの更新用ファームウェアを含むファームウェア更新情報を受信する受信ステップと、前記バスに接続される前記複数の電子制御ユニット各々の種類を示すシステム構成情報を取得する取得ステップと、前記システム構成情報が示す各種類の電子制御ユニットを用いて前記更新用ファームウェアの動作検証がなされた後に当該更新用ファームウェアに基づく該当の電子制御ユニットのファームウェアの更新のための制御を行う更新処理ステップとを含む制御プログラムである。この制御プログラムがプロセッサを有する車両内の装置(例えばゲートウェイ装置)にインストールされ実行されることで、ファームウェアの更新に際して複数の電子制御ユニットに対応した、更新用ファームウェアの動作検証の実施が確保された後に更新の制御が行われるようになる。このため、ファームウェアの更新後に車両が正常に機能しなくなる可能性が低減する。
【0033】
なお、これらの全般的又は具体的な態様は、システム、方法、集積回路、コンピュータプログラム又はコンピュータで読み取り可能なCD-ROM等の記録媒体で実現されても良く、システム、方法、集積回路、コンピュータプログラム又は記録媒体の任意な組み合わせで実現されても良い。
【0034】
以下、実施の形態に係るゲートウェイ装置を含む車載ネットワークシステムについて、図面を参照しながら説明する。ここで示す実施の形態は、いずれも本発明の一具体例を示すものである。従って、以下の実施の形態で示される数値、構成要素、構成要素の配置及び接続形態、並びに、ステップ(工程)及びステップの順序等は、一例であって本発明を限定するものではない。以下の実施の形態における構成要素のうち、独立請求項に記載されていない構成要素については、任意に付加可能な構成要素である。また、各図は、模式図であり、必ずしも厳密に図示されたものではない。
【0035】
(実施の形態1)
以下、本発明の実施の形態として、ゲートウェイ装置を含む複数の電子制御ユニット(ECU)がバスを介して通信する車載ネットワークシステム10において用いられるファームウェア更新方法について、図面を用いて説明する。
【0036】
ファームウェア更新方法は、車両に搭載された各ECUに実装されたファームウェア(FW:Firmware)を、車両の外部に所在するサーバから配信される新たな更新用ファームウェアで更新する(つまり更新用ファームウェアに置き換える)ための方法である。車載ネットワークシステム10では、ファームウェアの更新後に車両が正常に機能しなくなる可能性を低減させるべく、その車両に対応した複数のECUを用いた更新用ファームウェアの動作検証が行われた後にファームウェアの更新を行う方法が用いられる。
【0037】
[1.1 車載ネットワークシステム10の全体構成]
図1は、実施の形態1に係る車載ネットワークシステム10の全体構成を示す図である。
【0038】
車載ネットワークシステム10は、CANプロトコルに従って通信するネットワーク通信システムの一例であり、制御装置、センサ、アクチュエータ、ユーザインタフェース装置等の各種機器が搭載された車両におけるネットワーク通信システムである。車載ネットワークシステム10は、バスを介してフレームに係る通信を行う複数の装置を備え、ファームウェア更新方法を用いる。
【0039】
具体的には図1に示すように車載ネットワークシステム10は、車両に搭載され各種機器に接続されたECU100a~100d、バス200a、200b、ゲートウェイ300と、車両外のネットワーク400とサーバ500とを含んで構成される。なお、車載ネットワークシステム10には、ゲートウェイ300、ECU100a~100d以外にもいくつものECUが含まれ得るが、ここでは、便宜上ゲートウェイ300及びECU100a~100dに注目して説明を行う。ECUは、例えば、プロセッサ(マイクロプロセッサ)、メモリ等のデジタル回路、アナログ回路、通信回路等を含む装置である。メモリは、ROM、RAM等であり、プロセッサにより実行される制御プログラム(ソフトウェアとしてのコンピュータプログラム)を記憶することができる。ファームウェアはこの制御プログラムの全部又は一部であり、例えばEEPROM(Electrically Erasable Programmable Read Only Memory)等の不揮発性メモリ(起動ROMと称する)に記憶される
。例えばプロセッサが、制御プログラム(コンピュータプログラム)に従って動作することにより、ECUは各種機能を実現することになる。なお、コンピュータプログラムは、所定の機能を達成するために、プロセッサに対する指令を示す命令コードが複数個組み合わされて構成されたものである。なお、ファームウェアは、プロセッサ内において命令解釈を行うためのマイクロコードの全部又は一部を含むものであっても良い。
【0040】
ECU100a~100dは、それぞれエンジン101、ブレーキ102、ドア開閉センサ103、窓(ウィンドウ)開閉センサ104といった機器に接続されており、その機器の状態を取得し、周期的に状態を表すフレーム(データフレーム)を、バス200a、バス200b等で構成される車載ネットワークに送信している。
【0041】
ゲートウェイ300は、ECU100aとECU100bとが接続されたバス200a、及び、ECU100cとECU100dとが接続されたバス200bと接続されたゲートウェイ装置としての一種のECUである。ゲートウェイ300は一方のバスから受信したフレームを他方のバスに転送する機能を有し、また、ネットワーク400を介してサーバ500と通信する機能を有する。
【0042】
車両外部に所在する外部装置としてのサーバ500は、ネットワーク400を介して、ECU100a~100dのファームウェアを更新するためのデータであるFW更新情報を配信する機能を有するコンピュータである。ネットワーク400における通信には、無線通信、或いは、有線通信のいかなる通信プロトコルを適用しても良い。
【0043】
車載ネットワークシステム10における各ECUは、CANプロトコルに従ってフレームの授受を行う。CANプロトコルにおけるフレームには、データフレーム、リモートフレーム、オーバーロードフレーム及びエラーフレームがある。
【0044】
[1.2 データフレームフォーマット]
以下、CANプロトコルに従ったネットワークで用いられるフレームの1つであるデータフレームについて説明する。
【0045】
図2は、CANプロトコルで規定されるデータフレームのフォーマットを示す図である。同図には、CANプロトコルで規定される標準IDフォーマットにおけるデータフレームを示している。データフレームは、SOF(Start Of Frame)、IDフィールド、RTR(Remote Transmission Request)、IDE(Identifier Extension)、予約ビット「
r」、DLC(Data Length Code)、データフィールド、CRC(Cyclic Redundancy Check)シーケンス、CRCデリミタ「DEL」、ACK(Acknowledgement)スロット、ACKデリミタ「DEL」、及び、EOF(End Of Frame)の各フィールドで構成される。
【0046】
SOFは、1bitのドミナントで構成される。バスがアイドルの状態はレセシブになっており、SOFによりドミナントへ変更することでフレームの送信開始を通知する。
【0047】
IDフィールドは、11bitで構成される、データの種類を示す値であるID(メッセージID)を格納するフィールドである。複数のノードが同時に送信を開始した場合、このIDフィールドで通信調停を行うために、IDが小さい値を持つフレームが高い優先度となるよう設計されている。
【0048】
RTRは、データフレームとリモートフレームとを識別するための値であり、データフレームにおいてはドミナント1bitで構成される。
【0049】
IDEと「r」とは、両方ドミナント1bitで構成される。
【0050】
DLCは、4bitで構成され、データフィールドの長さを示す値である。なお、IDE、「r」及びDLCを合わせてコントロールフィールドと称する。
【0051】
データフィールドは、最大64bitで構成される送信するデータの内容を示す値である。8bit毎に長さを調整できる。送られるデータの仕様については、CANプロトコルで規定されておらず、車載ネットワークシステム10において定められる。従って、車種、製造者(製造メーカ)等に依存した仕様となる。
【0052】
CRCシーケンスは、15bitで構成される。SOF、IDフィールド、コントロールフィールド及びデータフィールドの送信値より算出される。
【0053】
CRCデリミタは、1bitのレセシブで構成されるCRCシーケンスの終了を表す区切り記号である。なお、CRCシーケンス及びCRCデリミタを合わせてCRCフィールドと称する。
【0054】
ACKスロットは、1bitで構成される。送信ノードはACKスロットをレセシブにして送信を行う。受信ノードはCRCシーケンスまで正常に受信ができていればACKスロットをドミナントとして送信する。レセシブよりドミナントが優先されるため、送信後にACKスロットがドミナントであれば、送信ノードは、いずれかの受信ノードが受信に成功していることを確認できる。
【0055】
ACKデリミタは、1bitのレセシブで構成されるACKの終了を表す区切り記号である。
【0056】
EOFは、7bitのレセシブで構成されており、データフレームの終了を示す。
【0057】
[1.3 ゲートウェイ300の構成]
図3は、ゲートウェイ300の構成図である。ゲートウェイ300は、バス間でのフレーム転送、外部のサーバ500との通信(ECU100a~100d等のファームウェアの更新のためのFW更新情報の受信等)等の機能を実行する。このためゲートウェイ300は、図3に示すように、フレーム送受信部310と、フレーム解釈部320と、受信ID判断部330と、受信IDリスト保持部340と、フレーム処理部350と、転送ルール保持部360と、FW更新処理部370と、ECU情報保持部372と、署名検証部373と、鍵保持部374と、外部通信部375と、フレーム生成部380と、ECU情報取得部390とを含んで構成される。これらの各構成要素は、ゲートウェイ300における通信回路、メモリに格納された制御プログラムを実行するプロセッサ或いはデジタル回路等により実現される。
【0058】
フレーム送受信部310は、バス200a及びバス200bのそれぞれに対して、CANプロトコルに従ったフレームを送受信する。バス200a又はバス200bからフレームを受信し、フレーム解釈部320に転送する。また、フレーム送受信部310は、フレーム生成部380より通知を受けた転送先のバスを示すバス情報及びフレームに基づいて、そのフレームの内容をバス200a又はバス200bに送信する。
【0059】
フレーム解釈部320は、フレーム送受信部310よりフレームの値を受け取り、CANプロトコルで規定されているフレームフォーマットにおける各フィールドにマッピングするよう解釈を行う。フレーム解釈部320は、IDフィールドと判断した値は受信ID判断部330へ転送する。フレーム解釈部320は、受信ID判断部330から通知される判定結果に応じて、IDフィールドの値と、IDフィールド以降に現れるデータフィールド(データ)とを、フレーム処理部350へ転送するか、フレームの受信を中止するかを決定する。また、フレーム解釈部320は、CANプロトコルに則っていないフレームと判断した場合は、エラーフレームを送信するように、フレーム生成部380へ通知する。また、フレーム解釈部320は、エラーフレームを受信した場合には、受信中のフレームについてそれ以降はそのフレームを破棄する、つまりフレームの解釈を中止する。
【0060】
受信ID判断部330は、フレーム解釈部320から通知されるIDフィールドの値を受け取り、受信IDリスト保持部340が保持しているメッセージIDのリストに従い、そのIDフィールド以降のフレームの各フィールドを受信するかどうかの判定を行う。この判定結果を、受信ID判断部330は、フレーム解釈部320へ通知する。
【0061】
受信IDリスト保持部340は、ゲートウェイ300が受信するID(メッセージID)のリストである受信IDリストを保持する。図4は、受信IDリストの一例を示す図である。
【0062】
フレーム処理部350は、転送ルール保持部360が保持する転送ルールに従って、受信したフレームのIDに応じて、転送するバスを決定し、転送するバスのバス情報と、フレーム解釈部320より通知されたメッセージIDと、データとをフレーム生成部380へ通知する。また、フレーム処理部350は、フレーム解釈部320より通知されたファームウェアの更新に係る更新結果のデータを、FW更新処理部370へ通知し、ECU情報に関するデータを、ECU情報取得部390へ通知する。なお、フレーム処理部350は、ファームウェアの更新に係る更新結果のデータ及びECU情報に関するデータを、転送の対象としない。
【0063】
転送ルール保持部360は、バス毎のフレームの転送についてのルールを表す情報である転送ルールを保持する。図5は、転送ルールの一例を示す図である。
【0064】
FW更新処理部370は、外部通信部375から通知された更新用のファームウェア等のFWデータを含むFW更新情報の署名検証を署名検証部373へ依頼し、署名検証に成功した場合に更新用のファームウェアに係るFWデータと、更新対象となるECUが接続されたバスのバス情報とを、フレーム生成部380に通知する。また、FW更新処理部370は、フレーム処理部350から通知された更新結果を外部通信部375に通知する。また、FW更新処理部370は、ECU情報取得部390からの通知等に基づいて、ECU情報保持部372に保持されたECU情報の集合であるシステム構成情報をFW更新要求として外部通信部375に通知する。また、ECU100a~100dとの通信に必要となるデータをフレーム生成部380へ通知する。なお、FW更新処理部370は、システム構成情報が示す各種類のECUを用いて更新用のファームウェアの動作検証がなされた後にその更新用ファームウェア等のFWデータを含むFW更新情報を受けて署名検証に成功した場合に漸く該当のECUのファームウェアの更新のための制御(例えばバスを介してのECUへのFWデータの送信等)を行う更新処理部として機能する。
【0065】
ECU情報保持部372は、バス200a、バス200bに繋がる全てのECU(ECU100a~100d)それぞれに関する情報であるECU情報の集合であるシステム構成情報を保持する。システム構成情報の一例を図6に示す。
【0066】
署名検証部373は、FW更新処理部370から、FW更新情報に係る署名検証対象となるデータを受信し、鍵保持部374より取得した署名検証用の鍵を用いて署名検証を行ってその検証結果をFW更新処理部370へ通知する。
【0067】
鍵保持部374は、サーバ500から受信するFW更新情報の署名検証用の鍵を保持する。
【0068】
外部通信部375は、サーバ500から更新用のファームウェアに係るFWデータを含むFW更新情報を受信する受信部としての機能を有し、受信したFW更新情報をFW更新処理部370へ通知する。また、外部通信部375は、FW更新処理部370から通知された更新結果を、サーバ500へ送信する。また、外部通信部375は、FW更新処理部370から通知されたシステム構成情報をFW更新要求として外部装置であるサーバ500へ送信する送信部としての機能を有する。外部通信部375は、例えば、ネットワーク400を介してサーバ500にアクセスするために必要なサーバ500のアドレス情報等を予め保持している。
【0069】
フレーム生成部380は、フレーム解釈部320から通知されたエラーフレーム送信の要求に従い、エラーフレームを、フレーム送受信部310へ通知して送信させる。また、フレーム生成部380は、フレーム処理部350から通知されたメッセージIDと、データとを用いてフレームを構成し、バス情報とともにフレーム送受信部310へ通知する。また、フレーム生成部380は、FW更新処理部370から通知された更新用のファームウェアに係るFWデータを用いてフレームを構成し、バス情報とともにフレーム送受信部310へ通知する。また、フレーム生成部380は、ECU情報取得部390から通知された要求に従い、ECU情報取得用のフレームを構成して、構成したフレームをフレーム送受信部310へ通知して送信させる。
【0070】
ECU情報取得部390は、バス200a、バス200bに繋がる全てのECUからECU情報を取得するために、例えば周期的に、フレーム生成部380にECU情報取得用のフレーム(データフレーム)を生成して送信するよう要求する。なお、各ECUは、ECU情報取得用のフレームを受信すると予め定められたIDのフレーム(データフレーム)でECU情報を、ゲートウェイ300へ到達するように送信する。このため、ECU情報取得部390は、フレーム処理部350から、各ECUのECU情報に関するデータを通知されて取得し、このECU情報に基づいて、ECU情報保持部372が保持するシステム構成情報のECU情報を必要に応じて更新する。即ち、ECU情報取得部390は、バス200a、200bに接続される複数のECU各々の種類を示すシステム構成情報を取得する取得部としての機能を有する。
【0071】
[1.4 受信IDリスト例]
図4は、ゲートウェイ300の受信IDリスト保持部340に保持される受信IDリストの一例を示す図である。
【0072】
図4に例示する受信IDリストは、ID(メッセージID)の値が「1」、「2」、「3」及び「4」のいずれかであるメッセージIDを含むフレームを選択的に受信して処理するために用いられる。これは一例に過ぎないが、受信IDリストには、ゲートウェイ300が受信すると定められているフレームのメッセージIDが列挙されている。
【0073】
[1.5 転送ルール例]
図5は、ゲートウェイ300の転送ルール保持部360が保持する転送ルールの一例を示す。
【0074】
この転送ルールは、転送元のバスと転送先のバスと転送対象のID(メッセージID)とを対応付けている。図5中の「*」はメッセージIDにかかわらずフレームの転送がなされることを表している。図5の例は、バス200aから受信するフレームはメッセージIDにかかわらず、バス200bに転送するように設定されていることを示している。また、バス200bから受信するフレームのうちメッセージIDが「3」であるフレームのみがバス200aに転送されるように設定されていることを示している。
【0075】
[1.6 システム構成情報例]
図6は、ゲートウェイ300のECU情報保持部372が保持するシステム構成情報(ECU情報の集合)の一例を示す。
【0076】
この例のシステム構成情報は、ECU毎のECU情報のリストである。ECU情報は、ECU-IDと、ECUの機能種別を示すECU種別と、ECUの製造会社と、ECUに実装されたファームウェアのバージョン番号等であるFWバージョンとを含んで構成される。ECU-IDは、例えば各ECUに固有のシリアル番号等の識別子(識別情報)である。このECU-IDとFWバージョンとにより、ECUの種類が識別可能である。種類の同じ複数のECUは、例えばバスを介したデータの授受の動作に関する機能が同一な複数のECUであり、種類の異なる複数のECUは、その動作に関する機能が相互に異なる複数のECUである。図6の例は、エンジン101に接続されたECU100aについてのECU-IDが「0001」であり、ECU種別が「エンジン」で識別されるエンジン制御用という種別であり、製造会社が「A社」であり、ECU-IDのFWバージョンが1.0であること等を示している。システム構成情報の初期値は、製造時に設定されたものであっても良いし、例えばゲートウェイ300に電力の供給が開始された際に、サーバ500等の外部装置からゲートウェイ300が取得したものであっても良い。バス200a、200bに接続されたECUの交換或いはファームウェアの更新等で状態が変化した場合や、車両に新たにECUが導入されてバス200a又はバス200bに接続された場合等において、ECU情報取得部390が周期的に収集するECU情報に基づいてシステム構成情報は車両内の各ECUの最新の状態を示すように逐次更新され得る。
【0077】
[1.7 ECU100aの構成]
図7は、ECU100aの構成図である。ECU100aは、フレーム送受信部110と、フレーム解釈部120と、受信ID判断部130と、受信IDリスト保持部140と、フレーム処理部150と、FW更新処理部160と、FWキャッシュ保持部161と、署名検証部163と、鍵保持部164と、データ取得部170と、フレーム生成部180とを含んで構成される。これらの各構成要素は、ECU100aにおける通信回路、メモリに格納された制御プログラムを実行するプロセッサ或いはデジタル回路等により実現される。
【0078】
フレーム送受信部110は、バス200aに対して、CANプロトコルに従ったフレームを送受信する。バスからフレームを1bitずつ受信し、フレーム解釈部120に転送する。また、フレーム生成部180より通知を受けたフレームの内容をバス200aに送信する。
【0079】
フレーム解釈部120は、フレーム送受信部110よりフレームの値を受け取り、CANプロトコルで規定されているフレームフォーマットにおける各フィールドにマッピングするよう解釈を行う。IDフィールドと判断した値は受信ID判断部130へ転送する。フレーム解釈部120は、受信ID判断部130から通知される判定結果に応じて、IDフィールドの値と、IDフィールド以降に現れるデータフィールドとを、フレーム処理部150へ転送するか、その判定結果を受けた以降においてフレームの受信を中止するかを決定する。また、フレーム解釈部120は、CANプロトコルに則っていないフレームと判断した場合は、エラーフレームを送信するようにフレーム生成部180へ通知する。また、フレーム解釈部120は、エラーフレームを受信した場合には、それ以降はそのフレームを破棄する、つまりフレームの解釈を中止する。
【0080】
受信ID判断部130は、フレーム解釈部120から通知されるIDフィールドの値を受け取り、受信IDリスト保持部140が保持しているメッセージIDのリストに従い、そのIDフィールド以降のフレームの各フィールドを受信するかどうかの判定を行う。この判定結果を、受信ID判断部130は、フレーム解釈部120へ通知する。
【0081】
受信IDリスト保持部140は、ECU100aが受信するメッセージIDのリストである受信IDリストを保持する。この受信IDリストは、例えば上述の図4の例と同様である。
【0082】
フレーム処理部150は、受信したフレームのデータに応じてECU毎に異なる処理を行う。例えば、エンジン101に接続されたECU100aは、時速が30kmを超えた状態でドアが開いている状態だと、アラーム音を鳴らす機能を備える。そして、ECU100aのフレーム処理部150は、他のECUから受信したデータ(例えばドアの状態を示す情報)を管理し、エンジン101から取得された時速に基づいて一定条件下でアラーム音を鳴らす処理等を行う。ECU100cは、ブレーキがかかっていない状況でドアが開くとアラーム音を鳴らす機能を備える。ECU100b、100dでは特に何もしない。なお、ECU100a~100dは上記以外の機能を備えていても良い。また、フレーム処理部150は、ファームウェアの更新用のFWデータを取得した場合及びECU情報取得用のフレームに係るデータを取得した場合には、FW更新処理部160へ通知する。
【0083】
FW更新処理部160は、ゲートウェイ300から受信してフレーム処理部150から通知されたFWデータの署名検証を署名検証部163へ依頼し、署名検証に成功した場合にFWデータに基づいて、ECU100aの起動ROM内のファームウェアを更新する(書き換える)。起動ROMは、例えばECU100aのプロセッサでリセット後に実行されるファームウェアの格納先として設定された不揮発性メモリである。起動ROM内のファームウェアの更新の際には、FW更新処理部160は、更新失敗時に更新前の状態へと復元可能にするために、例えばFWキャッシュ保持部161に既存のファームウェアを格納する。また、FW更新処理部160は、FWデータに基づくファームウェアの更新結果を示すフレームを生成して送信するようにフレーム生成部180へ通知する。ファームウェアの更新結果には、例えば更新後におけるファームウェアのバージョン番号等のFWバージョンを含めても良い。また、FW更新処理部160は、フレーム処理部150からECU情報取得用のフレームに係る通知がなされた場合には、ECU100aのECU-ID及び現在のファームウェアについてのFWバージョンを含むECU構成情報についてのフレームを生成して送信するようにフレーム生成部180に通知する。
【0084】
FWキャッシュ保持部161は、例えばECU100aにおける不揮発性メモリ等の記憶領域で実現され、起動ROM内のファームウェアの更新に際して既存のファームウェアを格納する等のために用いられる。
【0085】
署名検証部163は、FW更新処理部160から、署名検証対象となるFWデータを受信し、鍵保持部164より取得した署名検証用の鍵を用いて署名検証を行ってその検証結果をFW更新処理部160へ通知する。
【0086】
鍵保持部164は、ファームウェアの更新用のFWデータの署名検証用の鍵を保持する。
【0087】
データ取得部170は、ECUにつながっている機器、センサ等の状態を示すデータを取得し、フレーム生成部180に通知する。
【0088】
フレーム生成部180は、フレーム解釈部120から通知されたエラーフレーム送信を指示する通知に従い、エラーフレームを構成し、エラーフレームをフレーム送受信部110へ通知して送信させる。また、フレーム生成部180は、データ取得部170より通知されたデータの値に対して、予め定められたメッセージIDをつけてフレームを構成し、フレーム送受信部110へ通知する。また、フレーム生成部180は、FW更新処理部160によるファームウェアの更新結果のフレーム又はECU構成情報のフレームの生成の指示に応じて、それぞれ予め定められたメッセージIDを付したフレームを構成して、フレーム送受信部110へ通知する。
【0089】
ECU100b~100dもECU100aと概ね同様の構成を備える。
【0090】
[1.8 サーバ500の構成]
サーバ500は、車載ネットワークシステム10が搭載される車両の外部に所在するコンピュータであり、メモリ、ハードディスク等の記憶媒体、プロセッサ、通信回路等を含む。サーバ500は、ユーザインタフェースとしての入力装置(キーボード等)、ディスプレイ等を備えていても良い。複数の車両それぞれに車載ネットワークに係る複数のECUが搭載されていることを前提として、サーバ500は、各種ECUの製造会社等から提供されたファームウェアを管理し、ファームウェアの動作検証を行い、各車両に更新用ファームウェアを含むFW更新情報を配信する機能を有する。
【0091】
図8は、サーバ500の構成図である。サーバ500は、同図に示すように、データ送受信部510と、FW更新制御部520と、FW動作検証部530と、ECU情報保持部531と、全FW保持部532と、配信データ生成部570と、FW保持部571と、ECU管理情報保持部572と、署名生成部590と、鍵保持部591とを含んで構成される。これらの各構成要素は、サーバ500における通信回路、メモリに格納された制御プログラムを実行するプロセッサ等により実現される。
【0092】
データ送受信部510は、ゲートウェイ300と通信し、データを送受信する。データ送受信部510は、ゲートウェイ300からファームウェアの更新の要求(FW更新要求)としてシステム構成情報を受信した場合には、FW更新制御部520へ通知し、FW更新要求に対して更新すべきファームウェアがある場合にFW更新制御部520からFW更新情報を受け取ってゲートウェイ300へと送信する。データ送受信部510は、ゲートウェイ300より、ファームウェアの更新結果を受信した場合には、FW更新制御部520に通知する。
【0093】
FW更新制御部520は、ECUの製造会社等の端末装置から、ECU用の最新のファームウェアがサーバ500へアップロードされた場合に、FW保持部571にファームウェアを格納して、端末装置からの情報に基づいてファームウェアと、そのバージョン番号等を示すFWバージョンと、対象のECUの種類を示す情報等とを対応付けて管理する。FW更新制御部520は、データ送受信部510を経由して、ゲートウェイ300からFW更新要求に係るシステム構成情報を受け取った場合に、システム構成情報に基づいてそのゲートウェイ300に対応して更新すべきファームウェアがある場合には配信データ生成部570に更新用のファームウェアのパッケージとしてのFW更新情報を生成させる。なお、FW更新制御部520は、更新すべきファームウェアがあるか否かを、例えばFW保持部571が保持するファームウェアに係る情報とシステム構成情報とに基づき判断し得る。FW更新制御部520は、そのシステム構成情報に基づいて、更新すべきファームウェアについての動作検証をFW動作検証部530に依頼し、動作検証がなされた後(つまり問題なく適切に動作することが検証された後)においてFW更新情報をデータ送受信部510に送信させる。なお、更新用のファームウェアについての動作検証に際して検証に失敗した場合(つまり適切に動作しなかった場合)には、サーバ500は、更新用のファームウェアを含むFW更新情報をゲートウェイ300に送信しない。また、FW更新制御部520は、ゲートウェイ300からファームウェアの更新結果を受け取った場合に、ECU管理情報保持部572が保持する車両ECU管理情報を更新する。
【0094】
FW動作検証部530は、FW更新制御部520の依頼を受けてシステム構成情報が示す各ECUと同一種類のECUで構成された動作環境において、更新用のファームウェア、及び、動作環境における各ECUのファームウェアが適切(正常)に動作することを検証するためのFW動作検証処理を実行する機能を有する。FW動作検証処理では、例えば、動作環境のうち更新対象となるECUに対して更新用のファームウェアを適用する更新の動作、その更新後に動作環境の各ECUが正常に動作するか否かの動作等が検証される。FW動作検証処理においては、動作環境としての各種ECUのハードウェアを用いて更新用のファームウェアの動作検証を行っても良いし、各種ECUをシミュレート(擬似的に実行)する仮想環境でのシミュレーションにより更新用のファームウェアの動作検証を行っても良い。ここでは、一例として各種ECUをシミュレートする仮想環境でのシミュレーションにより更新用のファームウェアの動作検証を行う例を想定して説明する。
【0095】
ECU情報保持部531は、各種ECUをシミュレートするための情報(ソフトウェア)を保持し、その情報は、各種ECUが使用している最新のファームウェアを含む。
【0096】
全FW保持部532は、各種ECUに対応する最新のファームウェアだけでなく、過去のバージョンのファームウェアを含む全てのファームウェアを保持する。このECU情報保持部531及び全FW保持部532を参照して、FW動作検証部530は、システム構成情報のECU-IDとFWバージョンとにより識別される各ECUの種類と、同一種類のECUをシミュレートする動作環境を構築して、更新用のファームウェアを適用した更新とその後の動作についてシミュレーションを行うことで問題なく適切に動作が行われるかを検証する。
【0097】
配信データ生成部570は、ゲートウェイ300に配信するための更新用のファームウェアのパッケージとしてのFW更新情報を生成し、署名生成部590に依頼してFW更新情報に対する署名を生成させる。FW更新情報のフォーマットについては後述する(図10参照)。
【0098】
FW保持部571は、アップロードされたECU用のファームウェアを保持する。
【0099】
ECU管理情報保持部572は、各車両の車載ネットワークにおける各ECUに関する情報である車両ECU管理情報を保持する。車両ECU管理情報については後述する(図9参照)。
【0100】
署名生成部590は、配信データ生成部570の依頼を受けて、鍵保持部591に保持されている署名用の鍵を用いて、FW更新情報に対する署名を生成して配信データ生成部570に通知する。署名生成部590は、例えば、FW更新情報における各FWデータに対する署名及びFW更新情報全体に対する署名を行い得る。
【0101】
鍵保持部591は、署名生成部590がFW更新情報に署名するために用いる鍵を保持する。
【0102】
[1.9 ECU管理情報例]
図9は、サーバ500のECU管理情報保持部572が保持する車両ECU管理情報(車両別のECU情報の集合)の一例を示す。
【0103】
この例の車両ECU管理情報は、サーバ500の管理対象となる車両毎について車両情報とその車両に搭載される各ECUについてのECU情報とを含んで構成される。車両情報は、車両を識別するための識別子(車両ID)である。車両ECU管理情報において車両情報と対応付けたECU情報は、ECU-IDと、ECUの機能種別を示すECU種別と、ECUの製造会社と、ECUに実装されたファームウェアのバージョン番号等であるFWバージョンと、そのECUに対応する最新のファームウェアのバージョン番号等である最新FWバージョンとを含んで構成される。車両ECU管理情報における、ある車両についての各ECU情報は、例えば、その車両のゲートウェイ300から受信した情報(システム構成情報及びファームウェアの更新結果)と、各種ECUの製造会社からサーバ500にアップロードされたファームウェアについてのFWバージョンとに基づいて設定されている。なお、図9では、一台の車両Aに関する情報のみを例示しているが、車両ECU管理情報は、他の車両についての情報も含み得る。
【0104】
[1.10 FW更新情報のフォーマット例]
図10は、サーバ500が配信する配信データとしてのFW更新情報のフォーマットの一例を示す。
【0105】
FW更新情報は、FWデータの個数を示すFW数F1と、1個以上のFWデータ(図10の例では2つの個別FWデータF10、F20)と、FW更新情報(配信データ)全体に対する署名であるFW更新情報署名F30とを含む。FWデータF10、F20はそれぞれ、更新用のファームウェア(FW)F13、F23と、対象となるECUを識別するECU-IDF11、F21と、ファームウェアのバージョン番号等を示すFWバージョンF12、F22と、これらのデータに対する署名であるFWデータ署名F14、F24を含む。ファームウェアF13、F23は、ファームウェア自体つまりバイナリデータである。
【0106】
[1.11 ゲートウェイ300等によるファームウェアの更新に係る動作例]
以下、車載ネットワークシステム10におけるECUのファームウェアの更新に係る動作について説明する。
【0107】
図11及び図12は、サーバ500、ゲートウェイ300、ECU100a、100b等の装置が連携して行うECUのファームウェアの更新に係る動作例を示すシーケンス図である。ここでの各シーケンスは、各装置における各処理手順(ステップ)を意味する。ここでは、説明の便宜上、一部のECUの動作について図示している。この動作例に示すシーケンスは、例えば一定日数毎等といった周期で繰り返し実行されることが想定されるが、車載ネットワークに新たなECUが追加されたことを検知した時に実行されても良いし、車両内のいずれかのECUへの運転者等の操作に対応して実行されても良い。
【0108】
車両におけるゲートウェイ300は、バス200a、200bにECU情報取得用のフレームを送信することで、車載ネットワークで接続された全てのECU(ECU100a、100b等)に対してECU情報を要求する(ステップS1001)。
【0109】
ECU情報取得用のフレームを受信したECU100aは、ECU100aについてのECU-IDと、実装しているファームウェアに係るFWバージョンとを含んで構成されるECU情報を含むフレームを、バス200aへ送信する(ステップS1002)。これに対応してゲートウェイ300は、バス200aからフレームを受信することで、ECU100aについてのECU情報を受信する。
【0110】
また、ECU100aと同様にECU情報取得用のフレームを受信したECU100bも、ECU100bについてのECU情報を含むフレームをバス200aへ送信する(ステップS1003)。これに対応してゲートウェイ300は、バス200aからフレームを受信することで、ECU100bについてのECU情報を受信する。同様に、ゲートウェイ300は、他の各ECUから送信される各ECU情報を受信し得る。ステップS1002、S1003は、ゲートウェイ300においては、各ECUの種類等を示すシステム構成情報(ECU情報の集合)を取得する取得ステップである。
【0111】
次に、ゲートウェイ300は、ECU情報保持部372が保持するシステム構成情報としてのECU情報群(ECU情報の集合)に対して、各ECUから取得したECU情報の集合が変化している場合には(ステップS1004)、その取得したECU情報により、ECU情報保持部372が保持するシステム構成情報を更新する(ステップS1005)。なお、ゲートウェイ300は、保持しているシステム構成情報に対して、各ECUから取得したECU情報が変化している場合に、車両の運転者等にそのことを報知するための制御を行っても良い。
【0112】
次に、ゲートウェイ300は、ECU情報保持部372が保持する、車載ネットワークに接続された全てのECUの編成をECU情報の集合によって表すシステム構成情報を、FW更新要求として、サーバ500に送信する(ステップS1006)。これに対応してサーバ500はFW更新要求としてのシステム構成情報を受信する。
【0113】
サーバ500は、FW更新要求に対応して、受信したシステム構成情報、及び、ECU管理情報保持部572が保持する車両ECU管理情報等に基づいて、FW更新要求の送信元のゲートウェイ300を搭載する車両の1台以上のECUに対するファームウェアの更新が必要か否かを判別する(ステップS1007)。更新が不要であればサーバ500は、例えばゲートウェイ300に更新が不要の旨を通知する。図11では、更新が不要の場合の説明を省略している。
【0114】
ステップS1007でファームウェアの更新が必要と判別した場合に、サーバ500は、FW更新制御部520で、受信したシステム構成情報、及び、ECU管理情報保持部572が保持する車両ECU管理情報等に基づいて、送信すべき更新用の1つ以上のファームウェアを決定する(ステップS1008)。この決定により更新用のファームウェアの個数も決定される。
【0115】
続いてサーバ500は、FW動作検証部530により、受信したシステム構成情報が示す各ECUと同一種類のECUで構成される環境で、ステップS1008で決定した更新用のファームウェアの動作検証を行う(ステップS1009)。更新用のファームウェアとしては、FW保持部571に保持されているファームウェアが用いられる。サーバ500は、ステップS1009での動作検証を適切に終えた場合、つまりシステム構成情報が示す種類のECUで構成される環境で、更新用のファームウェアを対象となる該当のECUに適用した更新を行い、その更新後において各ECUが適切に動作すると確認された場合に、配信データ生成部570でFW更新情報(図10参照)の生成を行う。即ち、配信データ生成部570は、更新用のファームウェアの個数であるFW数分だけ(ステップS1010)、FW保持部571が保持するファームウェア等のFWデータの取得(ステップS1011)、及び、FWデータに対する署名生成部590で生成したFWデータ署名の付加(ステップS1012)を、繰り返す。また、配信データ生成部570は、署名生成部590によりFW更新情報に対する署名(FW更新情報署名)を生成させて(ステップS1013)、その署名を付加したFW更新情報を生成する。
【0116】
サーバ500では、FW更新情報が生成されると、FW更新制御部520が、そのFW更新情報をデータ送受信部510に送信させる(ステップS1014)。これにより、サーバ500から、FW更新要求としてのシステム構成情報の送信元であるゲートウェイ300へとFW更新情報が送信され、ゲートウェイ300はそのFW更新情報を受信する。ステップS1014は、ゲートウェイ300においては、サーバ500から、少なくとも1つのECUを更新対象とする更新用ファームウェアを含むFW更新情報を受信する受信ステップである。
【0117】
ゲートウェイ300は、FW更新情報を受信すると、署名検証部373により、FW更新情報の署名(FW更新情報署名)を検証する(ステップS1015)。そして、ゲートウェイ300のFW更新処理部370は、署名の検証に成功したか否かを判定し(ステップS1016)、検証に成功しなかった場合には、FW更新情報を破棄し(ステップS1017)、この場合にはFW更新情報に基づくファームウェアの更新が行われない。検証に成功した場合には、ゲートウェイ300は、主としてFW更新処理部370により、更新対象に該当するECUと連携して、FW更新制御処理を行う(ステップS1018)。FW更新制御処理の内容については後述する。ステップS1018等は、システム構成情報が示す各種類のECUを用いて更新用ファームウェアの動作検証がなされた後にゲートウェイ300が、その更新用ファームウェアに基づく該当のECUのファームウェアの更新のための制御を行う更新処理ステップである。
【0118】
ゲートウェイ300は、ステップS1018でのFW更新制御処理を終えた後、或いは、ステップS1017でのFW更新情報の破棄の後において、ファームウェアの更新結果をサーバ500に送信する(ステップS1019)。ファームウェアの更新結果は、例えば更新に成功したか否かを示す情報であり、その情報は例えば更新後におけるファームウェアに係るFWバージョンを含んでも良い。これにより、サーバ500は更新結果を受信する。
【0119】
サーバ500は、ファームウェアの更新結果を受信した場合に、そのファームウェアの更新後の状態を表すように、ECU管理情報保持部572が保持する車両ECU管理情報を更新する(ステップS1020)。
【0120】
[1.12 ゲートウェイ300によるFW更新制御処理例]
図13は、ゲートウェイ300によるFW更新制御処理の一例を示すフローチャートである。
【0121】
以下、上述のステップS1018においてゲートウェイ300により実行されるFW更新制御処理について、図13に即して説明する。
【0122】
ゲートウェイ300は、FW更新処理部370により、FW更新情報(図10参照)におけるFW数を取得し(ステップS1201)、ステップS1203~ステップS1205での処理を、FW数分繰り返す(ステップS1202)。
【0123】
FW更新処理部370は、FW更新情報のFWデータにおけるECU-IDを取得する(ステップS1203)。
【0124】
続いてゲートウェイ300では、FW更新処理部370がECU-IDで識別されるECUに送信するためにFWデータを含むフレームをフレーム生成部380に生成させ、そのフレームをフレーム送受信部310がそのECUが接続されたバスを介してECUに送信する(ステップS1204)。これにより、FWデータにおけるECU-IDで識別されるECUがそのFWデータを受信してファームウェアの更新のための処理を行ってその更新結果をゲートウェイ300に送信する。
【0125】
ゲートウェイ300は、ECUから送信される更新結果を受信する(ステップS1205)。
【0126】
[1.13 ECU100aによるFW更新制御処理例]
図14は、ECU100aによるFW更新制御処理の一例を示すフローチャートである。
【0127】
以下、ゲートウェイ300から上述のステップS1204でFWデータを送信されたECUがECU100aである場合にECU100aが行うFW更新制御処理について、図14に即して説明する。
【0128】
ECU100aでは、フレーム送受信部110がFWデータを含むフレームを受信する(ステップS1301)。
【0129】
ECU100aのFW更新処理部160は、フレーム解釈部120及びフレーム処理部150を介して、ステップS1301で受信されたフレームに係るFWデータを取得し、署名検証部163にFWデータにおけるFWデータ署名を検証させる(ステップS1302)。
【0130】
FW更新処理部160は、FWデータ署名の検証に成功したか否かを判定し(ステップS1303)、成功しなかった場合にはFWデータを破棄して(ステップS1304)、ファームウェアの更新をしない。
【0131】
FWデータ署名の検証に成功した場合には、FW更新処理部160は、ECU100aにおける起動ROMの内容であるファームウェアを、FWキャッシュ保持部161にコピーすることで保存する(ステップS1305)。
【0132】
次にFW更新処理部160は、FWデータにおけるファームウェア(FW)により起動ROM内のファームウェアの更新を行い(ステップS1306)、ECU100aのプロセッサを、リセットすることで再起動する(ステップS1307)。
【0133】
ECU100aでは、起動ROMからの起動に成功しない場合には、FWキャッシュ保持部161の内容による起動がなされるように予め設定されており、ステップS1307での再起動が成功しない場合に(ステップS1308)、FWキャッシュ保持部161に保存されている更新前のファームウェアが起動される(ステップS1309)。そして、その更新前のファームウェアの制御下で、FWキャッシュ保持部161に保存されている更新前のファームウェアを起動ROMへコピーすることで起動ROMの内容を更新前の状態に戻す(ステップS1310)。
【0134】
ECU100aは、ステップS1307での再起動に成功した場合にはファームウェアの更新に成功した旨を示す更新結果を含むフレームをゲートウェイ300へ送信し、ステップS1307での再起動に成功しなかった場合にはステップS1310の後に、ファームウェアの更新に失敗した旨を示す更新結果を含むフレームをゲートウェイ300へ送信する(ステップS1311)。
【0135】
[1.14 実施の形態1の効果]
実施の形態1に係る車載ネットワークシステム10では、ゲートウェイ300が、車載ネットワーク(バス200a、200b)に接続された全てのECUについてのECUの種類等を示すECU情報を収集してシステム構成情報として保持する。そしてゲートウェイ300がシステム構成情報をサーバ500に通知する。これによりサーバ500では、そのゲートウェイ300が搭載された車両の車載ネットワークにおけるECUの1台以上についてファームウェアの更新が必要か否かを判断でき、更新すべきファームウェアを決定することができる。サーバ500では、システム構成情報が示すECUの編成に対応した、同一種類のECUで編成される環境(現実のECUによる環境又はECUのシミュレーションによる環境)で、更新すべきファームウェアの更新に関連した動作検証(ファームウェアの更新が適切に行えるか否かの検証及びその更新後に各ECUが適切に動作するか否かの検証等)を行う。サーバ500では、動作検証を終えた後(適切な動作が確認された後)に、更新すべきファームウェアを含むFW更新情報をゲートウェイ300に送信するので、ゲートウェイ300は、その車両の各ECUで構成された環境に相当する環境で動作検証済のファームウェアを取得可能となる。このため、その車両においてファームウェアの更新後に車両が正常に機能しなくなる可能性が低減される。
【0136】
(実施の形態2)
以下、実施の形態1で示した車載ネットワークシステム10の一部を変形した車載ネットワークシステム11について説明する。
【0137】
本実施の形態に係る車載ネットワークシステム11では、複数の車両それぞれのECUのファームウェアの更新を効率的に行うために、サーバが車両モデル毎に対応した車両内の各ECUでの動作検証を行った後のファームウェアを送信するファームウェア更新方法を用いる。このファームウェア更新方法においては、車両内のゲートウェイ装置では、サーバから送信されたファームウェアについて動作検証に用いられたECUの編成(各ECUの種類等)を示す検証済構成情報(検証済ECU構成情報)をファームウェアと共に受信し、車両内のECUの編成と比較することで自車両に対応した動作検証が行われたか否かを確認する方式が用いられる。
【0138】
[2.1 車載ネットワークシステム11の全体構成]
車載ネットワークシステム11は、車両に搭載され各種機器に接続されたECU100a~100d、バス200a、200b、ゲートウェイ300aと、車両外のネットワーク400とサーバ500aとを含んで構成される。この車載ネットワークシステム11は、実施の形態1で示した車載ネットワークシステム10(図1参照)におけるゲートウェイ300及びサーバ500を、ゲートウェイ300a及びサーバ500aに置き換えたものである。ここで説明しない点については、車載ネットワークシステム11は、車載ネットワークシステム10と同様である。
【0139】
[2.2 ゲートウェイ300aの構成]
ゲートウェイ300aは、ECU100aとECU100bとが接続されたバス200a、及び、ECU100cとECU100dとが接続されたバス200bと接続されたゲートウェイ装置としての一種のECUである。ゲートウェイ300aは一方のバスから受信したフレームを他方のバスに転送する機能を有し、また、ネットワーク400を介してサーバ500aと通信する機能を有する。
【0140】
図15は、ゲートウェイ300aの構成図である。ゲートウェイ300aは、実施の形態1で示したゲートウェイ300におけるFW更新処理部370を、FW更新処理部370aに置き換えたものである。ゲートウェイ300aは、図15に示すように、フレーム送受信部310と、フレーム解釈部320と、受信ID判断部330と、受信IDリスト保持部340と、フレーム処理部350と、転送ルール保持部360と、FW更新処理部370aと、ECU情報保持部372と、署名検証部373と、鍵保持部374と、外部通信部375と、フレーム生成部380と、ECU情報取得部390とを含んで構成される。これらの各構成要素は、ゲートウェイ300aにおける通信回路、メモリに格納された制御プログラムを実行するプロセッサ或いはデジタル回路等により実現される。ゲートウェイ300aの構成要素のうち、上述したゲートウェイ300(図3参照)と同様の構成要素については図15で同じ符号を付しており、ここでは説明を省略する。
【0141】
FW更新処理部370aは、外部通信部375から通知された更新用のファームウェア等のFWデータを含むFW更新情報(図16参照)の署名検証を署名検証部373へ依頼し、署名検証に成功した場合にファームウェアの動作検証が適切になされていることを確認する。動作検証が適切になされていることの確認は、ECU情報取得部390が取得してECU情報保持部372に格納した各ECUのECU情報の集合であるシステム構成情報と、FW更新情報に含まれる検証済ECU構成情報とを比較することで行われる。なお、FW更新処理部370aは、外部通信部375からFW更新情報を通知された場合に、ECU情報取得部390に各ECUのECU情報を収集させてから、動作検証が適切になされていることの確認を行うようにしても良い。検証済ECU構成情報は、サーバ500aにおいて、FW更新情報に含まれるファームウェアの動作検証に用いられた環境を構成する各ECUの種類等を示す情報である。ECUの種類は例えばECU-ID及びECUが実装しているファームウェアのバージョン番号等のFWバージョンにより特定される。
【0142】
FW更新処理部370aは、システム構成情報が示す、車両に搭載された各ECUの種類と、サーバ500aから受信したFW更新情報の検証済ECU構成情報が示す、動作検証に用いられたECU各々の種類とを比較し、比較結果が一定条件を満たした場合に、FW更新情報に含まれる更新用のファームウェアに基づく更新を行わせるための制御を行う。この一定条件は、例えば、システム構成情報が示すECUの種類全てと検証済ECU構成情報が示すECUの種類全てとが完全に一致することである。FW更新処理部370aは、更新用のファームウェアに基づく更新を行わせるための制御として、更新用のファームウェアに係るFWデータと、更新対象となるECUが接続されたバスのバス情報とを、フレーム生成部380に通知する。なお、更新対象となるECUが複数ある場合においては、FW更新情報における検証済ECU構成情報に更新順情報が含まれているので、FW更新処理部370aは、この更新順情報が示す順序に従ってファームウェアの更新を行わせるための制御を行う。
【0143】
また、FW更新処理部370aは、フレーム処理部350から通知された更新結果を外部通信部375に通知する。また、FW更新処理部370aは、システム構成情報が示す各ECUの種類と検証済ECU構成情報が示す各ECUの種類との比較結果が上述の一定条件を満たさなかった場合には、ファームウェアの更新を中止し、そのシステム構成情報を動作検証要求として外部通信部375に通知する。動作検証要求には例えば更新しようとしていたファームウェアを特定する情報が付加される。FW更新処理部370aは、サーバ500aで、動作検証要求に応じた動作検証がなされて、サーバ500aから上述の一定条件を満たす検証済ECU構成情報を含むFW更新情報が送信された場合に、そのFW更新情報を取得してファームウェアの更新を再開する。なお、FW更新処理部370aは、システム構成情報が示す各種類のECUを用いて更新用のファームウェアの動作検証がなされた後にその更新用ファームウェア等のFWデータを含むFW更新情報を受けて署名検証に成功した場合に漸く該当のECUのファームウェアの更新のための制御(例えばバスを介してのECUへのFWデータの送信等)を行う更新処理部として機能する。また、FW更新処理部370aは、ECU100a~100dとの通信に必要となるデータをフレーム生成部380へ通知する。
【0144】
外部通信部375は、サーバ500aから更新用のファームウェアに係るFWデータを含むFW更新情報を受信してFW更新処理部370aへ通知し、FW更新処理部370aから通知された更新結果を、サーバ500aへ送信する。また、外部通信部375は、FW更新処理部370aから通知されたシステム構成情報を動作検証要求としてサーバ500aへ送信する。外部通信部375は、例えば、ネットワーク400を介してサーバ500aにアクセスするために必要なサーバ500aのアドレス情報等を予め保持している。なお、外部通信部375は、ファームウェアの更新の要求をサーバ500aに対して送信しても良い。
【0145】
[2.3 FW更新情報のフォーマット例]
図16は、サーバ500aが配信する配信データとしてのFW更新情報のフォーマットの一例を示す。
【0146】
サーバ500aが配信するFW更新情報は、実施の形態1で示したサーバ500が配信するFW更新情報(図10参照)に、検証済ECU構成情報F40を追加したものである。
【0147】
即ち、サーバ500aが配信するFW更新情報は、FW数F1と、1個以上のFWデータ(図16の例では2つの個別FWデータF10、F20)と、検証済ECU構成情報F40と、FW更新情報全体に対する署名であるFW更新情報署名F30とを含む。
【0148】
[2.4 検証済ECU構成情報のフォーマット例]
図17は、検証済ECU構成情報F40のフォーマットの一例を示す。
【0149】
検証済ECU構成情報F40は、サーバ500aでファームウェアの動作検証に用いられたECUについての情報である。検証済ECU構成情報F40は、車両モデルを識別する車種情報と、動作検証に用いられたファームウェアの更新順序(ファームウェアの更新を問題なく行うことができた更新順序)を示す更新順情報と、動作検証に用いられた各ECUについてのECU-ID、及び、ECUが実装しているファームウェアのバージョン番号等であるFWバージョンとを含む。
【0150】
[2.5 サーバ500aの構成]
サーバ500aは、ネットワーク400を介して、ECU100a~100dのファームウェアを更新するためのデータであるFW更新情報(図16参照)を配信する機能を有するコンピュータである。
【0151】
サーバ500aは、複数の車両それぞれに車載ネットワークに係る複数のECUが搭載されていることを前提として、サーバ500は、各種ECUの製造会社等から提供されたファームウェアを管理し、ファームウェアの動作検証を行い、各車両に更新用ファームウェアを含むFW更新情報を配信する機能を有する。
【0152】
図18は、サーバ500aの構成図である。サーバ500aは、同図に示すように、データ送受信部510aと、FW更新制御部520aと、FW動作検証部530aと、ECU情報保持部531と、全FW保持部532と、配信データ生成部570aと、FW保持部571と、ECU管理情報保持部572と、署名生成部590と、鍵保持部591とを含んで構成される。これらの各構成要素は、サーバ500aにおける通信回路、メモリに格納された制御プログラムを実行するプロセッサ等により実現される。サーバ500aの構成要素のうち、上述したサーバ500(図8参照)と同様の構成要素については図18で同じ符号を付しており、ここでは説明を省略する。
【0153】
データ送受信部510aは、ゲートウェイ300aと通信し、データを送受信する。データ送受信部510aは、ゲートウェイ300aからファームウェアの動作検証の要求(動作検証要求)としてシステム構成情報を受信した場合には、FW更新制御部520aへ通知し、FW更新制御部520aによりファームウェアの配信のためにFW更新情報を受け取った場合にはFW更新情報をゲートウェイ300aへと送信する。データ送受信部510aは、ゲートウェイ300aより、ファームウェアの更新結果を受信した場合には、FW更新制御部520aに通知する。なお、ファームウェアの更新の要求をゲートウェイ300aが行う場合においては、データ送受信部510aは、ゲートウェイ300aより、ファームウェアの更新の要求を受信した場合には、FW更新制御部520aに通知する。
【0154】
FW更新制御部520aは、ECUの製造会社等の端末装置から、ECU用の最新(つまり更新用)のファームウェアがサーバ500aへアップロードされてファームウェアの登録要求がなされた場合に、FW動作検証部530a等と連携して、ファームウェアの動作検証を行ってから登録する処理を行う。動作検証のためにまずFW更新制御部520aは、端末装置からの情報に基づいて、アップロードされた更新用のファームウェアが動作するECUを特定し、更に、その特定したECUを搭載(使用)している車両の車両モデルを特定する。ファームウェアの更新が必要なECUを使用している車両モデルを特定するために、FW更新制御部520aは、例えば、図19に例示するようなECU車両モデル管理テーブルを保持しており、このECU車両モデル管理テーブルを参照することで、ファームウェアの更新が必要なECUのECU-IDに対応する車両モデルを特定する。ECU車両モデル管理テーブルは、ECU-ID等と車両モデルとを対応付けたテーブルである。車両モデルは、車両の構造等の識別情報であり、例えば型式等であっても良い。そして、FW更新制御部520aは、例えば、図20に例示するような車両モデルECU管理テーブルを用いて、ファームウェアの更新が必要なECUを搭載している車両モデルが使用している全てのECUを列挙したリストを生成する。車両モデルECU管理テーブルは、車両モデル毎にその車両モデルの車両が搭載している全てのECUについての識別情報(ECU-ID等)を対応付けたテーブルである。FW更新制御部520aは、FW動作検証部530aに、この生成したリストを通知し、リストに列挙された全てのECUで構成される環境を用いて、ファームウェアの更新の動作検証を行わせる。動作検証が終わり問題なく動作することが確認された後に、FW更新制御部520aは、アップロードされたファームウェアをFW保持部571に格納して、端末装置からの情報に基づいてファームウェアと、そのバージョン番号等を示すFWバージョンと、対象のECUの種類を示す情報等とを対応付けて管理する。また、FW更新制御部520aは、FW動作検証部530aでの動作検証が終わった後に、配信データ生成部570aに、複数の車両(具体的には各車両のゲートウェイ300a)への配信データとなる、動作検証がなされたファームウェアを含む更新用のファームウェアのパッケージとしてのFW更新情報を生成させる。FW更新制御部520aは、配信データ生成部570aにより生成されたFW更新情報を、データ送受信部510aにゲートウェイ300aへと送信させる。
【0155】
また、FW更新制御部520aは、データ送受信部510aを経由して、ゲートウェイ300aからファームウェアの更新の要求を受け取った場合に、FW動作検証部530aで問題なく動作すると検証された後の、そのゲートウェイ300aに対応した更新用のファームウェアを含むFW更新情報を配信データ生成部570aに生成させて、ゲートウェイ300aに送信する。また、FW更新制御部520aは、データ送受信部510aを経由して、ゲートウェイ300aから動作検証要求としてシステム構成情報を取得した場合には、更新用のファームウェアについての動作検証をFW動作検証部530に依頼し、動作検証がなされた後(つまり問題なく適切に動作することが検証された後)においてFW更新情報をデータ送受信部510aに送信させる。なお、サーバ500aがゲートウェイ300aに送信するFW更新情報には、必ず、図16に示すようにFW動作検証部530aで動作検証に用いられたECUの情報を示す検証済ECU構成情報が含まれる。また、FW更新制御部520aは、ゲートウェイ300からファームウェアの更新結果を受け取った場合に、ECU管理情報保持部572が保持する車両ECU管理情報を更新する。
【0156】
FW動作検証部530aは、FW更新制御部520aの要求を受けて、ECUを列挙したリストが示すECUで構成された動作環境において、或いは、システム構成情報が示す各ECUと同一種類のECUで構成された動作環境において、更新用のファームウェア、及び、動作環境における各ECUのファームウェアが適切(正常)に動作することを検証するためのFW動作検証処理を実行する機能を有する。FW動作検証処理では、例えば、動作環境のうち更新対象となるECUに対して更新用のファームウェアを適用する更新の動作、その更新後に動作環境の各ECUが正常に動作するか否かの動作等が検証される。FW動作検証処理においては、動作環境としての各種ECUのハードウェアを用いて更新用のファームウェアの動作検証を行っても良いし、各種ECUをシミュレートする仮想環境でのシミュレーションにより更新用のファームウェアの動作検証を行っても良い。
【0157】
配信データ生成部570aは、ゲートウェイ300aに配信するための更新用のファームウェアのパッケージとしてのFW更新情報(図16参照)を生成し、署名生成部590に依頼してFW更新情報に対する署名を生成させる。なお、配信データ生成部570aは、FW動作検証部530から、適切に動作することが検証されたファームウェアの動作環境として用いられた全てのECUについての情報(ECU-ID、FWバージョン等)を取得して、FW更新情報における検証済ECU構成情報を設定する。
【0158】
FW保持部571は、アップロードされて動作検証を経たECU用のファームウェアを保持する。
【0159】
[2.6 更新用ファームウェアのサーバへの登録に係る動作例]
図21は、サーバ500aによる更新用ファームウェアの登録に係るFW登録処理を示すフローチャートである。以下、同図に即して、サーバ500aによるFW登録処理について説明する。FW登録処理は、サーバ500aの外部の端末装置から、ネットワークを介して、ファームウェアが送信され、ファームウェアの登録要求がなされた場合に実行される。
【0160】
まず、サーバ500aは、ファームウェアのサーバ500aへのアップロードを伴ってなされるファームウェアの登録要求を受信する(ステップS2000)。ファームウェアの登録要求は、例えばファームウェアのバージョン番号等を示すFWバージョンと、ファームウェアの対象のECUのECU-IDとを示す情報を含む。
【0161】
登録要求を受信したサーバ500aは、ファームウェアの更新が必要な車両モデルを特定する(ステップS2001)。即ち、サーバ500aは、受信したファームウェアの登録要求に含まれる情報から、更新が必要なECUのECU-IDを取得し、図19に例示するようなECU車両モデル管理テーブルを参照し、登録要求に含まれるECU-IDで識別されるECUを搭載している車両モデルを特定する。
【0162】
サーバ500aは、ステップS2001で特定した車両モデル毎に、その車両モデルで使用されるECUで構成される動作環境でのファームウェアの動作検証処理(ステップS2003~S2007)を実行する(ステップS2002)。まず、サーバ500aは、該当する車両モデルが搭載しているECUを、車両モデルECU管理テーブル(図20参照)を参照して特定し、特定した全てのECUの情報(ECU-ID)を列挙したリストを生成する(ステップS2003)。そして、そのリストで示されるECUを用いて構成される動作環境で、更新するファームウェアについての動作検証(FW動作検証処理)を行う(ステップS2004)。この動作検証では、更新するファームウェアが該当の車両モデルが搭載するECUで構成される環境において正常に動作するか、及び、更新の対象のECUについてファームウェアの更新を行ったときに、他のECUが正常に動作するかの確認がなされる。
【0163】
動作検証後、サーバ500aは、その動作検証が成功したかどうかを判断する(ステップS2005)。ステップS2005で動作検証が成功したと判断した場合に、サーバ500aは、そのファームウェアをFW保持部571に格納して管理する(ステップS2006)。一方、ステップS2005で動作検証に失敗したと判断した場合には、サーバ500aは、ステップS2000でファームウェアの登録要求を送信した端末装置に、エラーを通知する(ステップS2007)。
【0164】
[2.7 FW動作検証処理]
図22は、サーバ500aによるFW動作検証処理を示すフローチャートである。FW動作検証処理は、主にサーバ500a内のFW動作検証部530a等によって実行され、上述のFW登録処理(図21参照)の一部(ステップS2004)の処理であり、また、別途、ゲートウェイ300aからシステム構成情報に基づく動作検証要求を受けた場合に行われる処理でもある。FW動作検証処理は、概ね、FW更新制御部520aからのリストで示されたECU群、或いは、ゲートウェイ300aから取得したシステム構成情報で示されたECUと同一種類のECU群を用いて構成した環境で、更新用ファームウェアの動作を検証する処理である。以下、図22に即して、FW動作検証処理について説明する。
【0165】
FW動作検証部530aは、受け取ったリストで示されるECU-ID、或いはシステム構成情報が示すECU-ID等を参照して、動作検証に用いられるべき各ECUの情報をシミュレータ800に設定する(ステップS2100)。シミュレータ800は、FW動作検証部530aにより制御可能なコンピュータであり、各種のECUをシミュレート可能に構成されている。FW動作検証部530a及びシミュレータ800による構成は、複数のECUをシミュレートするシミュレーション部として動作する。ステップS2100では、FW動作検証部530aは、ECU情報保持部531に保持されている、各種ECUをシミュレートするための情報(ソフトウェア)、及び、最新のファームウェアに基づいて、動作検証に用いられるべき各ECUの情報をシミュレータ800に設定する。なお、ECU情報保持部531が保持する、各種ECUをシミュレートするための情報には、例えば、ECU内のプロセッサ及びメモリに関する情報(動作周波数、メモリサイズ等)、ECU内のCANコントローラに関する情報(型番、動作周波数等)、ECUに接続されているバス或いはECUが用いる通信路に係る情報、ECUに接続されているセンサやアクチュエータの情報(ロータリーエンコーダ、トルクセンサ、モータ等の情報)等が含まれ得る。これらの情報をシミュレータ800に設定することで、各車両モデルにおけるECUや車載ネットワークのシミュレーションが可能となる。
【0166】
次に、FW動作検証部530aは、全FW保持部532に保持されている、各種ECUに対応する全てのファームウェアとから、シミュレータ800でシミュレートする各ECUに設定するファームウェアを選択してそのファームウェアの情報をシミュレータ800に設定する(ステップS2101)。なお、ファームウェアを更新する対象のECUに対しても、更新前のファームウェアを設定する。
【0167】
次に、FW動作検証部530aは、更新用のファームウェアを対象のECUに設定する更新と、その更新後の各ECUの動作とをシミュレータ800によりシミュレーションすることで、更新用のファームウェアの動作検証を行う(ステップS2102)。これにより、FW更新制御部520aから通知されたリスト或いはシステム構成情報により特定されるECUの種類と、同一種類のECUをシミュレートする動作環境において、シミュレータ800により、更新用のファームウェアを適用した更新とその後の動作についてシミュレーションが実行され、正常に動作するかについて動作検証が実現される。
【0168】
動作検証後、FW動作検証部530aは、その動作検証が成功したかどうかを判断する(ステップS2103)。ステップS2103で動作検証が成功したと判断した場合には、FW動作検証部530aは、動作検証がなされたファームウェアを全FW保持部532へ格納する(ステップS2104)。なお、FW動作検証処理が、ゲートウェイ300aからの動作検証要求に基づいて行われる際にはステップS2104での処理は省略される。
【0169】
更に、FW動作検証部530aは、動作検証に用いた全てのECUについての情報(ECU-ID、FWバージョン等)を、FW更新制御部520aに伝え、FW更新制御部520aでは、配信データ生成部570aにその動作検証に用いられたECUについての情報を検証済ECU構成情報として含み、動作検証がなされたファームウェアのFWデータを含むFW更新情報を生成させる。配信データ生成部570aでは、署名生成部590により、検証済ECU構成情報を含むFW更新情報に対する署名を生成させて、FW更新情報署名としてFW更新情報に含ませる(ステップS2105)。また、ステップS2103で動作検証が成功しなかったと判断した場合には、FW動作検証部530aは、エラーをFW更新制御部520aに通知し(ステップS2106)、これを受けてFW更新制御部520aは、FW更新情報の生成に係る処理を中止する。
【0170】
なお、検証済ECU構成情報には、各ECU自体に関する情報だけではなく、動作検証を行った際の各ECUの状態に関する情報を含めても良い。この情報の例としては、例えば、現行バージョンのファームウェアから新しいファームウェアへ更新する際の書き換え時間(処理の長さ)や、書き換え後に動作可能になるまでの時間、書き換え処理の負荷、センサ情報や車載ネットワーク上のメッセージが受信できなくなる時間、書き換え中に受信できなくなるメッセージのID、書き換え後のファームウェアが利用するメモリサイズ等が挙げられる。これらの情報から、ゲートウェイ300aや、各ECUは、どのタイミングでファームウェアの更新処理を行うかを判断しても良い。例えば、夜間等の車両(自動車)を長時間使わないことが予め分かっている時間帯にファームウェアを更新したり、更新に必要な時間を運転者や自動車の管理者等に通知して許可された場合にのみファームウェアを更新したり、運転者や自動車の管理者等に、自動車を使用しない或いは走行させない時間を問い合わせてその時間に収まる分のファームウェアのみを更新したりする等といった判断を行っても良い。これにより、柔軟なファームウェアの更新が実現可能となる。
【0171】
[2.8 複数の更新用のファームウェアの検証に係るFW動作検証処理]
図23は、サーバ500aによる複数のファームウェアの検証に係るFW動作検証処理の一例を示すフローチャートである。
【0172】
図23では、複数のファームウェアの更新の順序(つまり検証順番)が互いに異なる複数の検証順番パターンのそれぞれについて、動作検証を行って検証が成功した検証順番を特定する処理に注目し、その他の処理は省略している。即ち、図23では、図22に示したステップS2101及びステップS2102の代わりとなる処理を示しているが、その他の処理は省略している。以下、図23に即して、サーバ500aによる複数のファームウェアの検証の動作について説明する。
【0173】
まず、FW動作検証部530aは、図22に示したステップS2100での処理を行った後に、複数の更新用のファームウェアをどの順番で検証を行うかを示す、検証順番のパターンを生成する(ステップS2200)。FW動作検証部530aは、生成した検証順番のパターン毎に、ステップS2201からステップS2204まで処理を繰り返し実行する。繰り返し実行の各回にステップS2201~S2204で使用される検証順番のパターンを、「対象検証順番パターン」と称する。
【0174】
まず、FW動作検証部530aは、シミュレータ800に設定したそれぞれのECU上で動作させるためのファームウェアを全FW保持部532から読み出し、シミュレータ800上のECUへ設定する(ステップS2202)。ステップS2202は、ステップS2101と同じ処理である。その後、複数ある更新用のファームウェア毎にステップS2204の処理を繰り返す(ステップS2203)。このときFW動作検証部530aは、複数ある更新用のファームウェアに対して、対象検証順番パターンで示される順番に従って、ステップS2204での動作検証をそれぞれの更新用ファームウェアに対して行う。ステップS2204では、FW動作検証部530aは、更新用ファームウェアを更新対象のECUへ設定するようにしてシミュレータ800を実行し、正常に動作するかを検証する。FW動作検証部530aは、シミュレータ800において1台のECUに1つの更新用ファームウェアを設定する度に、正常に動作するかを検証する。全ての更新用ファームウェアに対して、ECUへの設定と、動作検証が終了し、全ての動作検証が成功した場合のみ、対象検証順番パターンにおける動作検証が成功したと判断する。
【0175】
全ての検証順番パターンにおいて、動作検証が終了すれば、FW動作検証部530aは、検証した検証順番のパターンの中で、動作検証が成功したと判断した検証順番のパターンがあったかどうかを判断する(ステップS2205)。ステップS2205で、動作検証が成功したパターンがあったと判断した場合には、FW動作検証部530aは、動作検証が成功した検証順番のパターンを更新順情報として記録する(ステップS2206)。そして、更新順情報等を含み、動作検証に用いた全てのECUについての情報(ECU-ID、FWバージョン等)を含み、更に、動作検証に成功したことを示す動作検証結果を、FW更新制御部520aに通知する(ステップS2207)。一方、ステップS2205で、動作検証が成功したパターンがなかった場合には、FW動作検証部530aは、検証失敗をFW更新制御部520aに通知する(ステップS2208)。
【0176】
[2.9 ゲートウェイ300a等によるファームウェアの更新に係る動作例]
以下、車載ネットワークシステム11におけるECUのファームウェアの更新に係る動作について説明する。
【0177】
図24及び図25は、サーバ500a、ゲートウェイ300a、ECU100a、100b等の装置が連携して行うECUのファームウェアの更新に係る動作例を示すシーケンス図である。ここでの各シーケンスは、各装置における各処理手順(ステップ)を意味する。ここでは、説明の便宜上、一部のECUの動作について図示している。この動作例に示すステップS2301~S2304の手順は、例えば一定日数毎等といった周期で繰り返し実行されることが想定されるが、車載ネットワークに新たなECUが追加されたことを検知した時に実行されても良いし、車両内のいずれかのECUへの運転者等の操作に対応して実行されても良い。また、ステップS2306以降の手順は、例えば、サーバ500aが、ファームウェアの登録要求を受けた場合等に開始される。
【0178】
ステップS2301~S2305の手順は、上述したステップS1001~S1005(図11参照)と同一であるので、ここでは説明を省略する。ステップS2301~S2305での処理により、ゲートウェイ300aは、ECU情報保持部372に、車載ネットワークに接続された各ECUの最新のECU情報の集合であるシステム構成情報(図6参照)を保持することができる。なお、ステップS2301でのゲートウェイ300aがECU情報取得用のフレームを送信してECU情報の要求を行う処理を省略して、各ECUが、起動された時、或いは、自機のECU情報(ECU-ID、FWバージョン等)に変更があった時等に、ECU情報を含むフレームをゲートウェイ300aに送信することとしても良い。
【0179】
サーバ500aの外部の端末装置(例えばECUの製造会社等の端末装置)から、ECU用の最新(つまり更新用)のファームウェアがサーバ500aへアップロードされてファームウェアの登録要求がなされた場合に、サーバ500aは、そのファームウェアの登録のためのFW登録処理(図21参照)を行う(ステップS2306)。これにより、更新用のファームウェアが、対応する車両モデルにおけるECU群を用いた環境で動作検証(問題なく適切に動作することの検証)がなされた後にサーバ500aのFW保持部571に格納されて管理される(つまりサーバ500aに登録される)。
【0180】
サーバ500aは、登録した更新用のファームウェア、ファームウェアの動作検証に用いられた各ECUを示す検証済ECU構成情報等を含むFW更新情報を生成して、ゲートウェイ300aへと配信する(ステップS2307)。これにより、ゲートウェイ300aはFW更新情報を受信する。なお、ステップS2307での配信は、1台の車両のゲートウェイ300aに対しての送信であっても良いし、ファームウェアの更新が必要となる複数台の車両それぞれのゲートウェイ300aに対しての送信であっても良い。ステップS2307は、ゲートウェイ300aにおいては、サーバ500aから、少なくとも1つのECUを更新対象とする更新用ファームウェアを含むFW更新情報を受信する受信ステップである。
【0181】
ゲートウェイ300aは、FW更新情報を受信すると、署名検証部373により、FW更新情報の署名(FW更新情報署名)を検証する(ステップS2308)。そして、ゲートウェイ300aのFW更新処理部370aは、署名の検証に成功したか否かを判定し(ステップS2309)、署名の検証に成功しなかった場合にはFW更新情報を破棄し、この場合にはFW更新情報に基づくファームウェアの更新を行わない。
【0182】
署名の検証に成功した場合には、FW更新処理部370aは、FW更新情報に含まれる検証済ECU構成情報と、ECU情報保持部372が保持するシステム構成情報とを比較する(ステップS2310)。
【0183】
ゲートウェイ300aのFW更新処理部370aは、システム構成情報が示す、車両に搭載された複数のECU各々の種類と、検証済ECU構成情報が示す動作検証に用いられた複数のECU各々の種類との比較結果が一定条件を満たすか否か(例えば完全一致するか否か)により、適切な動作検証が行われているか否かを判定する(ステップS2311)。FW更新処理部370aは、例えば、比較結果が完全一致する場合には、適切な動作検証が行われていると判定する。サーバ500aでファームウェアの登録の際に車両モデルで使用されている各ECUを用いたファームウェアの動作検証を行っているが、例えば、ゲートウェイ300aが搭載された車両が、その車両モデルのECUからECUを交換し、或いは、追加している場合には、ステップS2310での比較の結果が一致しない。
【0184】
ゲートウェイ300aは、適切な動作検証が行われていないと判定した場合には、ECU情報保持部372が保持する、車載ネットワークに接続された全てのECUの編成をECU情報の集合によって表すシステム構成情報を、動作検証要求として、サーバ500aに送信する(ステップS2312)。動作検証要求には、例えば、更新用として配信されたファームウェアに関する情報が付加される。これに対応してサーバ500aは動作検証要求としてのシステム構成情報等を受信する。ステップS2312は、ゲートウェイ300aが、システム構成情報を外部装置としてのサーバ500aに送信する動作検証要求送信ステップである。
【0185】
サーバ500aは、動作検証要求を受けると、FW動作検証部530aにより、システム構成情報に応じた環境で、配信したファームウェアの動作検証に係るFW動作検証処理を行う(ステップS2313)。ステップS2312及びステップS2313は、サーバ500aにおいては、システム構成情報を受信して、そのシステム構成情報が示す全ての種類と同じ種類の、複数のECUを用いて更新用のファームウェアの動作検証を行う動作検証ステップである。そして、ファームウェアの動作検証後(適切に動作が行われることが確認された後)にサーバ500aは、ステップS2313での動作検証に用いられた各ECUに関する情報である検証済ECU構成情報を含むFW更新情報を生成して、動作検証要求の送信元である1台の車両のゲートウェイ300aに送信する(ステップS2314)。ステップS2314は、動作検証が行われた後に、FW更新情報を送信するファームウェア更新情報送信ステップである。ファームウェア更新情報送信ステップでは、動作検証に用いた複数のECU各々の種類等を示す検証済ECU構成情報を、FW更新情報に含めて送信し得る。これにより、ゲートウェイ300aは再びFW更新情報を受信する。
【0186】
ゲートウェイ300aは、ステップS2314でサーバ500aが送信したFW更新情報を受信すると、署名検証部373により、FW更新情報の署名(FW更新情報署名)を検証する(ステップS2315)。ステップS2315~S2318での処理はステップS2308~S2311での処理と同様である。
【0187】
ゲートウェイ300aは、システム構成情報が示すECU各々の種類と、検証済ECU構成情報が示すECU各々の種類との比較結果が一定条件を満たすか否か(例えば完全一致するか否か)により、適切な動作検証が行われているか否かを判定し(ステップS2318)、適切な動作検証が行われていないと判定した場合には所定の異常処理を行ってファームウェアの更新を行わない。
【0188】
ゲートウェイ300aは、ステップS2318又はステップS2311で適切な動作検証が行われていると判定した場合には、主としてFW更新処理部370aにより、更新対象に該当するECUと連携して、FW更新制御処理(図13図14参照)を行う(ステップS2319)。ステップS2317~S2319等は、ゲートウェイ300aが、システム構成情報が示す各種類のECUを用いて更新用ファームウェアの動作検証がなされた後にその更新用ファームウェアに基づく該当のECUのファームウェアの更新のための制御を行う更新処理ステップである。
【0189】
ゲートウェイ300aは、ステップS2319でのFW更新制御処理を終えた後に、ファームウェアの更新結果をサーバ500aに送信する(ステップS2320)。これにより、サーバ500aは更新結果を受信する。ファームウェアの更新結果は、例えば更新に成功したか否かを示す情報であり、その情報は、例えば更新後におけるファームウェアに係るFWバージョンを含んでも良いし、例えばシステム構成情報を含んでも良い。なお、ゲートウェイ300aは、ステップS2309、S2316で署名の検証に失敗した場合、或いは、ステップS2318で適切な動作検証が行われていないと判定した場合にも、ファームウェアの更新失敗を示す更新結果をサーバ500aに送信しても良い。
【0190】
サーバ500aは、ファームウェアの更新結果を受信した場合に、そのファームウェアの更新後の状態を表すように、ECU管理情報保持部572が保持する車両ECU管理情報を更新する(ステップS2321)。
【0191】
[2.10 ファームウェアの動作検証の環境]
以下、サーバ500aのFW動作検証部530aによるFW動作検証処理に用いられるシミュレータ800が行うファームウェアの動作検証のためのシミュレーションについて説明する。
【0192】
図26は、FW動作検証処理でシミュレータ800によりファームウェアの動作検証に用いられる仮想環境のソフトウェア構成の一例を示す。
【0193】
シミュレータ800において動作するソフトウェアは、同図に示すように、仮想マシンモニタ801と、仮想マシン802、803、804、805と、仮想ハードウェア810、820、830、840と、汎用OS(オペレーティングシステム)811、821と、RTOS(リアルタイムオペレーティングシステム)831と、ファームウェア841と、アプリ(アプリケーションプログラム)A812と、アプリB813と、アプリC814と、アプリD822と、アプリE832とを含む。
【0194】
シミュレータ800は、コンピュータであり、プロセッサ上でソフトウェア(仮想マシンモニタ801等)を実行する。
【0195】
仮想マシンモニタ801は、その上で互いに独立して動作するように仮想マシン802~805を制御する仮想マシン制御機能、その仮想マシンに対してメモリやCPU等のハードウェアリソースを割り当てて管理するリソース管理機能、仮想マシンからの要求に従ってデバイスへアクセスするデバイスアクセス機能、仮想マシンをスケジューリングするスケジューリング機能等を有する。
【0196】
仮想マシン802~805はそれぞれ、仮想ハードウェア、OS、アプリ、或いは、ファームウェアを含んで構成され、仮想マシンモニタ801によりそれぞれ独立に実行される。
【0197】
仮想ハードウェア810、820、830、840は、それぞれの仮想マシンに仮想的にハードウェアの機能を提供し、また、IPL(Initial Program Loader)、BIOS(Basic Input/Output System)を含み得る。
【0198】
汎用OS811は、アプリ(アプリA812、アプリB813、アプリC814)をメモリ上にロードして実行する、或いは、その各アプリをメモリ上から削除(アンロード)する機能を有し、各アプリに対して、CANプロトコルによるネットワーク通信機能を提供する。汎用OS821も同様である。
【0199】
RTOS831は、リアルタイム性を重視するアプリを動作させるためのOSである。
【0200】
アプリA812、アプリB813、アプリC814、アプリD822、アプリE832は、カーナビゲーション機能、運転支援機能、ステアリング制御機能、エンジン制御機能、ブレーキ制御機能、センサ情報(トルク、角度、速度、回転数等)の取得機能等といった各種の自動車用の機能を有する。これらの自動車用の機能群のそれぞれは、1つのアプリにより実行されても良いし、複数のアプリで実行されていても良い。
【0201】
ファームウェア841は、OSを必要としない機能を動作させるソフトウェア等である。なお、ファームウェア841は、OSを含んでいても良く、他のアプリの動作環境となって他のアプリの実行を制御する機能を有するものであっても良い。
【0202】
なお、図26で示した汎用OS811、821或いはRTOS831上で動作するアプリの数は、一例に過ぎず、より多くのアプリが動作しても良い。また、汎用OSが動作する仮想マシンが2つと、RTOSが動作する仮想マシンが1つ、ファームウェアが動作する仮想マシンが1つの場合を図示しているが、これは一例に過ぎない。仮想環境を、例えば、ファームウェアが動作する仮想マシンだけで構成しても良いし、ファームウェアが動作する仮想マシンとRTOSが動作する仮想マシンとだけで構成しても良い。
【0203】
そして、シミュレータ800では、1つのECUを、上述の仮想マシン802~805等といった1つの仮想マシンでシミュレートする。例えば、仮想マシンモニタ801上で仮想マシン805を複数(動作環境を構成するECUの数分)生成して動作させ、それぞれの仮想マシン805の仮想ハードウェア840で1つのECUのハードウェアの動作をシミュレートし、例えば、ファームウェア841はそのECUに実装されているファームウェアと同一の内容とする。例えば、仮想マシンモニタ801は、その上で動作する複数の仮想ハードウェア間で、ECU間でのバスを介した通信がシミュレートされるように構成される。
【0204】
FW動作検証部530aは、シミュレータ800に、ファームウェアの動作検証のための動作環境を構成する各ECUを設定する場合に、それぞれのECUと同じ動作をするように仮想マシンを設定する。このときに、既にECUの動作をシミュレートするように設定された仮想マシン(言わば仮想ECU)を仮想マシンモニタ801上へロードすることで、動作環境を構成するECUを設定しても良い。
【0205】
[2.11 実施の形態2の効果]
実施の形態2に係る車載ネットワークシステム11では、サーバ500aへファームウェアが登録される場合に、車両モデルのECU構成に対応した環境で、事前に動作検証を行う。そして、サーバ500aは、動作検証を経て登録されたファームウェアについて動作検証に用いられたECUに関する情報を含む検証済ECU構成情報とそのファームウェアとを含めたFW更新情報を各車両のゲートウェイ300aに配信する。これにより、動作検証が実施されているファームウェアが配信されるので、各車両のECUにおいて適切なファームウェアの更新が可能となる。また、動作検証に失敗したファームウェアをサーバ500aに登録しないので、正常に動作しないファームウェアを配信する可能性を低減できる。また、車両モデル毎のECUの構成で、動作検証を行うため、特定の車両モデルでのみ発生する不具合等を事前に検証することが可能となる。
【0206】
また、ある車両のゲートウェイ300aでは、受信したFW更新情報における検証済ECU構成情報と車両内の全てのECUの情報であるシステム構成情報との比較により、その車両に適した動作環境で適切にファームウェアの更新に係る動作検証がなされたか否かを確認して、適切な動作検証がなされていなければ動作検証要求をサーバ500aに対して行う。これにより、実際に車両のECUを更新する前に、ファームウェアの更新により悪影響が起きないかを検証させることができる。そして、ゲートウェイ300aは、その車両に適した動作環境で動作検証が行われた更新用のファームウェアをサーバ500aから受信できるようになる。このため、車両に搭載されたECUが故障して別のECUに交換された場合、新規にECUが追加された場合等においても、ゲートウェイ300aが動作検証済みのファームウェアを取得でき、適切にECUのファームウェアの更新が可能になる。即ち、その車両においてファームウェアの更新後に車両が正常に機能しなくなる可能性が低減される。
【0207】
(他の実施の形態)
以上のように、本発明に係る技術の例示として実施の形態1、2を説明した。しかしながら、本発明に係る技術は、これに限定されず、適宜、変更、置き換え、付加、省略等を行った実施の形態にも適用可能である。例えば、以下のような変形例も本発明の一実施態様に含まれる。
【0208】
(1)上記実施の形態では、外部通信部375(外部通信機能)を有するゲートウェイ300、300aが、車両外のネットワーク400を介してサーバ500、500aと通信したが、これは一例に過ぎない。例えば、ゲートウェイ300、300aは、外部との通信機能を持つ別のECU(例えばヘッドユニット等)を介して、サーバ500、500aと通信することとしても良い。ヘッドユニットは、比較的高性能なプロセッサを備えるECUの一種であり、自動車のインパネ(インストルメントパネル)等に設けられた液晶ディスプレイ等の表示装置を含み、車両の運転者への報知等を行い得る装置である。なお、車載ネットワークには、OBD2(On-Board Diagnostics2)等と呼ばれる、診断ツール等の外部装置と通信するインタフェースである診断ポートが存在し、ECUの診断に利用される。そこで、ゲートウェイ300、300aは、例えば、サーバ500、500aと通信可能でありかつ診断ポートと接続する外部装置と通信することで間接的にサーバ500、500aと通信することとしても良い。これらの場合において、ゲートウェイ300、300aは必ずしも車両外部と通信するための外部通信機能を有さなくても良く、他のECU或いは外部装置を介してゲートウェイ300、300aとサーバ500、500aとの間では、システム構成情報等を伴う動作検証要求或いはFW更新要求、及び、FW更新情報等の授受が可能となる。
【0209】
(2)上記実施の形態で示した各ECUのファームウェアのバージョン番号等を示すFWバージョンは、サーバ500、500a、ゲートウェイ300、300aで管理される例を示したが、別のECU、診断ツール等といった他の機器において管理されても良い。
【0210】
(3)上記実施の形態では、CANプロトコルに従って通信するネットワーク通信システムの例として車載ネットワークを示した。本発明に係る技術は、車載ネットワークに限定されるものではなく、ロボット、産業機器等のネットワークその他、車載ネットワーク以外のCANプロトコルに従って通信するネットワーク通信システムにも適用可能である。また、CANプロトコルは、オートメーションシステム内の組み込みシステム等に用いられるCANOpen、或いは、TTCAN(Time-Triggered CAN)、CANFD(CAN with Flexible Data Rate)等の派生的なプロトコルも包含する広義の意味のものと扱われるべきである。また、上記実施の形態では、CANプロトコルに基づいてバスでファームウェアに関するデータ(フレーム)を送受信する例を示したが、別のプロトコルを適用しても良く、ファームウェアに係るデータを通信するための通信路及び通信方式として任意のものを利用可能である。
【0211】
(4)上記実施の形態では、データ(FWデータ、FW更新情報等)の完全性を担保するために、データに対して署名を付した構成を用いたが、更に、秘匿性を担保するためにデータの暗号化を行っても良い。署名用の鍵と暗号化用の鍵とを別個の鍵としても良い。
【0212】
(5)上記実施の形態では、FW更新情報に対する署名の生成とFWデータに対する署名の生成とに際して、同じ鍵を使用したが、それぞれ別の鍵を用いても良い。例えば、配信データとしてのFW更新情報の全体に対する署名(FW更新情報署名)は、自動車メーカが持つ鍵を用いて生成し、個別のFWデータに対する署名(FWデータ署名)は、そのFWデータに係るファームウェアを実装するECUの製造会社(或いはそのファームウェアの製造会社)が持つ鍵を用いて生成されることとしても良い。なお、上記実施の形態では、各ECUがFWデータ署名の検証を行う例を示したが、ECUはFWデータ署名の検証を行わずに、ゲートウェイ300、300aが予め検証用の鍵を保持してFWデータ署名の検証を行うこととしても良い。
【0213】
(6)上記実施の形態2におけるゲートウェイ300aは、複数のファームウェアを更新する必要がある場合に、サーバ500aがFW更新情報に含ませた、ファームウェアの更新順に関する情報(更新順情報)を受け、更新順情報に従った順に更新することとしたが、必ずしも更新順に更新しなくても良い。また、実施の形態1におけるサーバ500が更新順情報をFW更新情報に含ませて送信して、ゲートウェイ300がその更新順情報に従った順で、ステップS1204でのFWデータの送信を行うことで、順にファームウェアを更新させても良い。
【0214】
(7)上記実施の形態におけるサーバ500、500aの処理の一部は、サーバ500、500aと通信可能でサーバ500、500aと離れた他の装置(コンピュータ等)により実行されても良い。
【0215】
(8)上記実施の形態におけるサーバ500、500aで、ファームウェアの動作検証に失敗した場合において、動作環境を構成したECUの編成(ECUの組み合わせ)に関する情報(不具合情報)を管理しても良い。この場合に、サーバ500、500aは、不具合情報をゲートウェイ300、300aへ通知すると、ゲートウェイ300、300aは、車両内のECUの構成が、この不具合情報で示される構成と一致した場合にファームウェアを更新すべきでないと判断可能になる。
【0216】
(9)上記実施の形態におけるFW動作検証部530は、複数のファームウェアを更新する場合に、検証順番のパターンを生成し、動作検証が成功した検証順番を記録するとしたが、これに限定されるものではなく、複数のファームウェアを同時に更新し、動作検証を行っても良いし、全ての検証順番のパターンで動作検証が失敗した場合に、同時に検証するパターンを生成し、動作検証を行っても良い。
【0217】
(10)上記実施の形態2におけるゲートウェイ300aで、ファームウェアの適切な動作検証が行われているか否かを判定する例として、システム構成情報が示す、車両に搭載された複数のECU各々の種類と、検証済ECU構成情報が示す動作検証に用いられた複数のECU各々の種類との比較結果が例えば完全一致するか否かという一定条件を満たすか否かを判定することを示した。しかし、これは一例に過ぎず、例えば、システム構成情報が示すECU全ての種類を、検証済ECU構成情報が示す動作検証に用いられた複数のECUの種類が包含している場合に、適切な動作検証が行われていると扱う方式等を用いても良い。これらを合わせて、システム構成情報が示すECU全ての種類のECUと同じ種類が、検証済ECU構成情報に示されている場合に適切な動作検証が行われていると扱う方式等を用いても良い。そして、例えば、ゲートウェイ300aのFW更新処理部370aが、システム構成情報が示す全ての種類と同じ種類が検証済構成情報に示されていないことを確認した場合に、FW更新情報に含まれる更新用のファームウェアに基づく更新を抑止して、動作検証要求としてシステム構成情報を外部装置としてのサーバ500aに送信させる制御を行うこととしても良い。
【0218】
(11)上記実施の形態では、ECUの種類が、ECU-ID(ECUの識別情報)とFWバージョン(ファームウェアのバージョンの識別情報)とにより特定可能である例を示したが、ECU-IDだけで特定されるものをECUの種類と規定することも可能である。なお、ECU-IDは、個々のECUを識別可能であると共に、ECUの種類を区別し得る情報である例を示したが、ECU-IDが、ECUの個体それぞれを識別できないがECUの種類を識別可能な情報であることとしても良い。
【0219】
(12)上記実施の形態1で示したサーバ500のFW動作検証部530においても、上記実施の形態2示したシミュレータ800によるファームウェアの動作検証を行っても良い。また、サーバ500、500aが、ある車両における車載ネットワークに接続される各ECUと同じ種類のECU(つまりシステム構成情報が示す各種類のECU)を用いて更新用のファームウェアの動作検証を行う他に、その車両のゲートウェイ300、300aが、動作検証を行う方式を用いることもできる。即ち、ゲートウェイ300、300aは、実施の形態2で示したシミュレータ800と同様のシミュレータを含むシミュレーション部を備え、自ら、システム構成情報が示す各種類のECUをシミュレートする動作環境において、サーバ500、500aから受信したファームウェアの動作検証を行うこととしても良い。この場合には、ゲートウェイ300、300aは、問題なく動作することを検証した後に、ファームウェアの更新を、更新対象に該当するECUに行わせる。例えば、ゲートウェイ300aのFW更新処理部370aは、システム構成情報が示す全ての種類と同じ種類が検証済構成情報に示されていないことを確認した場合に、システム構成情報が示す全ての種類と同じ種類の各ECUを用いた更新用のファームウェアの動作のシミュレーションを、ゲートウェイ300aにおけるシミュレーション部に行わせ、そのシミュレーションによる動作検証がなされた後に更新用ファームウェアに基づく更新を行わせるように制御を行うこととしても良い。なお、ゲートウェイ300、300aがファームウェアの動作検証を行う場合において、実際にゲートウェイ300、300aが車載ネットワークから受信したメッセージ(フレーム)を、シミュレータにより構成される動作環境(仮想環境)内の車載ネットワークへ送信する構成にしても良い。この場合には、ゲートウェイ300、300aが受信したメッセージを仮想環境において、更新用のファームウェアを実行しない仮想マシン(仮想ECU)から送信しても良い。また、ファームウェアの更新対象である1台以上のECUそれぞれが、シミュレート800のような構成のコンピュータにおいて動作する仮想マシンとして実現されていても良い。
【0220】
(13)上記実施の形態で示した更新用のファームウェア(バイナリデータ)は、ECUに実装されるファームウェアの全体であってもその一部であっても良い。更新用のファームウェアがECUに実装されるファームウェアの一部である場合において、ECU内の既存のファームウェアの一部に上書きされる。この場合には、更新用のファームウェアは、差分データ(バイナリデータ)と、どの部分に適用されるかを示す情報(例えばアドレス情報等)とを含んで構成され得る。この場合において、ゲートウェイ300、300a或いは更新対象に該当するECUにおいて、差分データと既存のファームウェアとをマージしてから、ECUの起動ROMにおけるファームウェアの置き換えを行っても良い。
【0221】
(14)上記実施の形態で示した各種処理の手順(例えば図11図14図21図25に示した所定手順等)の実行順序は、必ずしも、上述した通りの順序に制限されるものではなく、発明の要旨を逸脱しない範囲で、実行順序を入れ替えたり、複数の手順を並列に行ったり、その手順の一部を省略したりすることができる。
【0222】
(15)上記実施の形態におけるゲートウェイ300、300aその他のECUは、例えば、プロセッサ、メモリ等のデジタル回路、アナログ回路、通信回路等を含む装置であることとしたが、ハードディスク装置、ディスプレイ、キーボード、マウス等の他のハードウェア構成要素を含んでいても良い。また、メモリに記憶された制御プログラムがプロセッサにより実行されてソフトウェア的に機能を実現する代わりに、専用のハードウェア(デジタル回路等)によりその機能を実現することとしても良い。
【0223】
(16)上記実施の形態における各装置を構成する構成要素の一部又は全部は、1個のシステムLSI(Large Scale Integration:大規模集積回路)から構成されているとし
ても良い。システムLSIは、複数の構成部を1個のチップ上に集積して製造された超多機能LSIであり、具体的には、マイクロプロセッサ、ROM、RAM等を含んで構成されるコンピュータシステムである。前記RAMには、コンピュータプログラムが記録されている。前記マイクロプロセッサが、前記コンピュータプログラムに従って動作することにより、システムLSIは、その機能を達成する。また、上記各装置を構成する構成要素の各部は、個別に1チップ化されていても良いし、一部又は全部を含むように1チップ化されても良い。また、ここでは、システムLSIとしたが、集積度の違いにより、IC、LSI、スーパーLSI、ウルトラLSIと呼称されることもある。また、集積回路化の手法はLSIに限るものではなく、専用回路又は汎用プロセッサで実現しても良い。LSI製造後に、プログラムすることが可能なFPGA(Field Programmable Gate Array)
や、LSI内部の回路セルの接続や設定を再構成可能なリコンフィギュラブル・プロセッサを利用しても良い。さらには、半導体技術の進歩又は派生する別技術によりLSIに置き換わる集積回路化の技術が登場すれば、当然、その技術を用いて機能ブロックの集積化を行っても良い。バイオ技術の適用等が可能性としてあり得る。
【0224】
(17)上記各装置を構成する構成要素の一部又は全部は、各装置に脱着可能なICカード又は単体のモジュールから構成されているとしても良い。前記ICカード又は前記モジュールは、マイクロプロセッサ、ROM、RAM等から構成されるコンピュータシステムである。前記ICカード又は前記モジュールは、上記の超多機能LSIを含むとしても良い。マイクロプロセッサが、コンピュータプログラムに従って動作することにより、前記ICカード又は前記モジュールは、その機能を達成する。このICカード又はこのモジュールは、耐タンパ性を有するとしても良い。
【0225】
(18)本発明の一態様としては、例えば図11図12図24図25等に示す処理手順の全部又は一部を含むファームウェア更新方法であるとしても良い。また、この方法をコンピュータにより実現するコンピュータプログラム(制御プログラム)であるとしても良いし、前記コンピュータプログラムからなるデジタル信号であるとしても良い。例えば、ファームウェア更新方法における受信ステップ、取得ステップ、更新処理ステップを含むファームウェア更新処理を実行するための制御プログラムであることとしても良い。また、本発明の一態様としては、前記コンピュータプログラム又は前記デジタル信号をコンピュータで読み取り可能な記録媒体、例えば、フレキシブルディスク、ハードディスク、CD-ROM、MO、DVD、DVD-ROM、DVD-RAM、BD(Blu-ray(
登録商標) Disc)、半導体メモリ等に記録したものとしても良い。また、これらの記録
媒体に記録されている前記デジタル信号であるとしても良い。また、本発明の一態様としては、前記コンピュータプログラム又は前記デジタル信号を、電気通信回線、無線又は有線通信回線、インターネットを代表とするネットワーク、データ放送等を経由して伝送するものとしても良い。また、本発明の一態様としては、マイクロプロセッサとメモリを備えたコンピュータシステムであって、前記メモリは、上記コンピュータプログラムを記録しており、前記マイクロプロセッサは、前記コンピュータプログラムに従って動作するとしても良い。また、前記プログラム若しくは前記デジタル信号を前記記録媒体に記録して移送することにより、又は、前記プログラム若しくは前記デジタル信号を、前記ネットワーク等を経由して移送することにより、独立した他のコンピュータシステムにより実施するとしても良い。
【0226】
(19)上記実施の形態及び上記変形例で示した各構成要素及び機能を任意に組み合わせることで実現される形態も本発明の範囲に含まれる。
【産業上の利用可能性】
【0227】
本発明は、CANに従う車載ネットワークに接続されたECUのファームウェアの更新を適切に行うために利用可能である。
【符号の説明】
【0228】
10 車載ネットワークシステム
100a~100d 電子制御ユニット(ECU)
101 エンジン
102 ブレーキ
103 ドア開閉センサ
104 窓(ウィンドウ)開閉センサ
110、310 フレーム送受信部
120、320 フレーム解釈部
130、330 受信ID判断部
140、340 受信IDリスト保持部
150、350 フレーム処理部
160、370、370a FW更新処理部
161 FWキャッシュ保持部
163、373 署名検証部
164、374、591 鍵保持部
170 データ取得部
180 フレーム生成部
200a、200b バス
300、300a ゲートウェイ(ゲートウェイ装置)
360 転送ルール保持部
372、531 ECU情報保持部
375 外部通信部
380 フレーム生成部
390 ECU情報取得部
400 ネットワーク
500、500a サーバ
510、510a データ送受信部
520、520a FW更新制御部
530、530a FW動作検証部
532 全FW保持部
570、570a 配信データ生成部
571 FW保持部
572 ECU管理情報保持部
590 署名生成部
800 シミュレータ
801 仮想マシンモニタ
802~805 仮想マシン
810、820、830、840 仮想ハードウェア
841 ファームウェア
図1
図2
図3
図4
図5
図6
図7
図8
図9
図10
図11
図12
図13
図14
図15
図16
図17
図18
図19
図20
図21
図22
図23
図24
図25
図26