WO2018230084A1 - 更新制御装置、制御方法、およびコンピュータプログラム - Google Patents
更新制御装置、制御方法、およびコンピュータプログラム Download PDFInfo
- Publication number
- WO2018230084A1 WO2018230084A1 PCT/JP2018/012073 JP2018012073W WO2018230084A1 WO 2018230084 A1 WO2018230084 A1 WO 2018230084A1 JP 2018012073 W JP2018012073 W JP 2018012073W WO 2018230084 A1 WO2018230084 A1 WO 2018230084A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- update
- control
- vehicle
- program
- ecu
- Prior art date
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/65—Updates
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B60—VEHICLES IN GENERAL
- B60W—CONJOINT CONTROL OF VEHICLE SUB-UNITS OF DIFFERENT TYPE OR DIFFERENT FUNCTION; CONTROL SYSTEMS SPECIALLY ADAPTED FOR HYBRID VEHICLES; ROAD VEHICLE DRIVE CONTROL SYSTEMS FOR PURPOSES NOT RELATED TO THE CONTROL OF A PARTICULAR SUB-UNIT
- B60W50/00—Details of control systems for road vehicle drive control not related to the control of a particular sub-unit, e.g. process diagnostic or vehicle driver interfaces
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B60—VEHICLES IN GENERAL
- B60W—CONJOINT CONTROL OF VEHICLE SUB-UNITS OF DIFFERENT TYPE OR DIFFERENT FUNCTION; CONTROL SYSTEMS SPECIALLY ADAPTED FOR HYBRID VEHICLES; ROAD VEHICLE DRIVE CONTROL SYSTEMS FOR PURPOSES NOT RELATED TO THE CONTROL OF A PARTICULAR SUB-UNIT
- B60W50/00—Details of control systems for road vehicle drive control not related to the control of a particular sub-unit, e.g. process diagnostic or vehicle driver interfaces
- B60W2050/0062—Adapting control system settings
- B60W2050/0075—Automatic parameter input, automatic initialising or calibrating means
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B60—VEHICLES IN GENERAL
- B60W—CONJOINT CONTROL OF VEHICLE SUB-UNITS OF DIFFERENT TYPE OR DIFFERENT FUNCTION; CONTROL SYSTEMS SPECIALLY ADAPTED FOR HYBRID VEHICLES; ROAD VEHICLE DRIVE CONTROL SYSTEMS FOR PURPOSES NOT RELATED TO THE CONTROL OF A PARTICULAR SUB-UNIT
- B60W50/00—Details of control systems for road vehicle drive control not related to the control of a particular sub-unit, e.g. process diagnostic or vehicle driver interfaces
- B60W2050/0062—Adapting control system settings
- B60W2050/0075—Automatic parameter input, automatic initialising or calibrating means
- B60W2050/0083—Setting, resetting, calibration
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B60—VEHICLES IN GENERAL
- B60W—CONJOINT CONTROL OF VEHICLE SUB-UNITS OF DIFFERENT TYPE OR DIFFERENT FUNCTION; CONTROL SYSTEMS SPECIALLY ADAPTED FOR HYBRID VEHICLES; ROAD VEHICLE DRIVE CONTROL SYSTEMS FOR PURPOSES NOT RELATED TO THE CONTROL OF A PARTICULAR SUB-UNIT
- B60W2556/00—Input parameters relating to data
- B60W2556/45—External transmission of data to or from the vehicle
Definitions
- the present invention relates to an update control device, a control method, and a computer program.
- This application claims priority based on Japanese Patent Application No. 2017-116109 filed on June 13, 2017, and incorporates all the description content described in the above Japanese application.
- ECUs Electronic Control Units
- the types of ECUs include, for example, those related to the traveling system that controls the engine, brakes, EPS (Electric Power Steering), etc.
- body-type ECUs that control the turning on / off of lights and the sounding of alarm devices
- meter-type ECUs that control the operation of meters arranged near the driver's seat.
- the ECU is configured by an arithmetic processing device such as a microcomputer, and the control of the in-vehicle device is realized by reading and executing a control program stored in a ROM (Read Only Memory).
- the ECU control program needs to be rewritten from the old version of the control program to the new version of the control program in response to a version upgrade of the control program for the purpose of improving functions or preventing crimes. Further, it is necessary to rewrite data necessary for execution of the control program such as map information and control parameters.
- Patent Document 1 discloses a technique (online update function) for downloading an update program via a network and updating the program.
- the update control device when the communication unit that communicates with the in-vehicle control device via a transmission path including the in-vehicle communication line and the following target device cannot execute the update process of the control program,
- An update control apparatus comprising: a control unit that causes a communication unit to transmit a request message for requesting an alternative device that is a non-target device to substitute part of the update processing.
- Target device In-vehicle control device subject to control program update
- Non-target device In-vehicle control device not subject to control program update
- control method is a control method in an update control device that communicates with an in-vehicle control device via a transmission line including an in-vehicle communication line, and the following target device performs control program update processing.
- a control method comprising a step of transmitting a request message for requesting replacement of a part of update processing to an alternative device, which is a non-target device described below, when it cannot be executed.
- Target device In-vehicle control device subject to control program update
- Non-target device In-vehicle control device not subject to control program update
- the computer program is a computer program for causing a computer to function as an update control device that communicates with the in-vehicle control device via a transmission line including an in-vehicle communication line. If the communication device that communicates with the communication line including the in-vehicle communication line and the following target device cannot execute the update process of the control program, a part of the update processing is replaced with the following non-target device alternative device A computer program that functions as a control unit that causes a communication unit to transmit a request message for requesting a message.
- Target device In-vehicle control device subject to control program update
- Non-target device In-vehicle control device not subject to control program update
- FIG. 1 is an overall configuration diagram of a program update system.
- FIG. 2 is a block diagram showing the internal configuration of the gateway.
- FIG. 3 is a block diagram showing an internal configuration of the ECU.
- FIG. 4 is a block diagram showing the internal configuration of the management server.
- FIG. 5 is a sequence diagram showing an example of the flow of online update of the control program executed in the program update system of the comparative example.
- FIG. 6 is a sequence diagram illustrating an example of a flow of online update of the control program executed in the program update system according to the first embodiment.
- FIG. 7 is a flowchart showing specific contents of the update control process.
- FIG. 8 is a flowchart showing the flow of the determination process in step S103 of FIG. FIG.
- FIG. 9 is a sequence diagram illustrating an example of the online update flow of the control program executed in the program update system according to the second embodiment.
- FIG. 10 is a sequence diagram illustrating an example of the online update flow of the control program executed in the program update system according to the third embodiment.
- the update program downloaded via the network is a gateway control or the like. Once stored in the device and ready to be updated, it is assumed that the update is started by being transferred from the control device.
- the state in which the control program cannot be updated is, for example, an ECU in which the target ECU controls functions related to traveling, such as a state in which the vehicle is traveling or a state in which the target ECU is not activated.
- the memory is pressed to save the update program in the memory.
- the size of the update program is large, or since there are a plurality of ECUs that need to be updated at the same timing, the memory may be greatly compressed.
- the update is performed after the ECU is ready to perform the update.
- the period until the completion is increased.
- the update is started after each ECU is ready to be updated. become longer.
- An object of an aspect of the present disclosure is to provide an update control device, a control method, and a computer program that control an update in the in-vehicle control device when the in-vehicle control device cannot update the control program. .
- This embodiment includes at least the following. That is, (1) The update control device included in the present embodiment is used when a communication unit that communicates with a vehicle-mounted control device via a transmission path including an in-vehicle communication line and the following target device cannot execute a control program update process. And a control unit that causes the communication unit to transmit a request message for requesting a replacement of a part of the update process to the replacement device that is the following non-target device.
- Target device In-vehicle control device that is an update target of the control program
- Non-target device In-vehicle control device that is not the update target of the control program
- control unit causes the communication unit to transmit an inquiry message addressed to the non-target device that inquires about the possibility of substitution, and sets the non-target device as the substitute device according to the content of the response message from the non-target device. Determine whether or not.
- an alternative apparatus can be determined according to the response content of a non-target apparatus.
- control unit inquires a plurality of non-target devices as to whether or not substitution is possible according to the priority. Thereby, a vehicle-mounted control apparatus with high priority can be determined as an alternative apparatus.
- the control unit determines that the non-target device that is the transmission source of the response message is an alternative device.
- the vehicle-mounted control apparatus with a high dynamic processing capability can be determined as an alternative apparatus.
- a control part determines an alternative apparatus according to a priority from several non-target apparatus of the transmission source of a response message.
- a suitable vehicle-mounted control apparatus can be determined as an alternative apparatus.
- the control unit when a plurality of in-vehicle communication lines are terminated in the communication unit, and the communication unit does not have a function of selectively starting a device connected to the in-vehicle communication line, the control unit The non-target device connected to the same in-vehicle communication line is given higher priority than the non-target device connected to the in-vehicle communication line different from the target device.
- the communication unit does not have a function of selectively activating a device connected to the in-vehicle communication line, when data is transferred through one in-vehicle communication line, all on-vehicle control devices connected to the in-vehicle communication line are activated.
- a control part makes higher priority the non-target apparatus which bears the control function irrelevant to vehicle travel over the non-target apparatus which bears other functions.
- a part of the update process replaced by the non-target device may affect the process originally executed by the non-target device, the influence on the vehicle travel can be prevented.
- the update process includes a plurality of processes
- the control unit determines a process for requesting replacement from an alternative device among the plurality of processes.
- the control method included in the present embodiment is a method for controlling the update of the control program in the in-vehicle control device in the update control device according to any one of (1) to (8).
- Such a control method has the same effects as the update control devices (1) to (8) described above.
- a computer program included in the present embodiment causes a computer to function as the update control device described in any one of (1) to (8).
- Such a computer program has the same effects as the update control apparatuses (1) to (8).
- FIG. 1 is an overall configuration diagram of a program update system according to an embodiment.
- the program update system of this embodiment includes a vehicle 1, a management server 5, and a DL (download) server 6 that can communicate via a communication network that is a wide area communication network 2 as an example.
- the management server 5 manages update information of the vehicle 1.
- the DL server 6 stores an update program.
- the management server 5 and the DL server 6 are operated by, for example, a car manufacturer of the vehicle 1 and can communicate with a large number of vehicles 1 owned by users who are registered as members in advance.
- the vehicle 1 includes an in-vehicle network (communication network) 4 including a plurality of ECUs 30 and gateways 10 connected by an in-vehicle communication line 16, a wireless communication unit 15, and various in-vehicle devices controlled by each ECU 30 (see FIG. (Not shown).
- the in-vehicle network 4 has a plurality of in-vehicle communication lines 16A and 16B.
- the in-vehicle network 4 includes a plurality of communication groups, which are ECUs 30A to 30C connected to the in-vehicle communication line 16A by bus and ECUs 30D and 30E connected to the in-vehicle communication line 16B by bus.
- the gateway 10 relays communication between communication groups. For this reason, in-vehicle communication lines 16A and 16B are connected to the gateway 10.
- the in-vehicle communication lines 16A and 16B are also collectively referred to as the in-vehicle communication line 16.
- the wireless communication unit 15 is communicably connected to a wide area communication network 2 such as a mobile phone network, and is connected to the gateway 10 via an in-vehicle communication line.
- the gateway 10 transmits information received by the wireless communication unit 15 from the external devices such as the management server 5 and the DL server 6 through the wide area communication network 2 to the ECU 30 via the in-vehicle communication line.
- the gateway 10 transmits information acquired from the ECU 30 to the wireless communication unit 15, and the wireless communication unit 15 transmits the information to an external device such as the management server 5.
- ECU30 transmits / receives information via an in-vehicle communication line.
- the wireless communication unit 15 mounted on the vehicle 1 in addition to the in-vehicle dedicated communication terminal, devices such as a mobile phone, a smartphone, a tablet terminal, and a notebook computer (Personal Computer) owned by the user can be considered.
- the gateway 10 communicates with an external device via the wireless communication unit 15 is illustrated, but when the gateway 10 has a wireless communication function, the gateway 10 itself is a management server 5 or the like. It is good also as a structure which performs wireless communication with an external apparatus.
- the management server 5 and the DL server 6 are configured as separate servers, but these servers 5 and 6 may be configured as one server device. Further, both the management server 5 and the DL server 6 may be composed of a plurality of devices.
- the program update system may include an external device that stores the update program and can communicate with the gateway 10 via wired or wireless communication instead of (or in addition to) the DL server 6.
- FIG. 2 is a block diagram showing the internal configuration of the gateway 10.
- the gateway 10 includes a CPU 11, a RAM (Random Access Memory) 12, a storage unit 13, an in-vehicle communication unit 14, and the like.
- the gateway 10 is connected to the wireless communication unit 15 via the in-vehicle communication line, but these may be configured by a single device.
- the CPU 11 causes the gateway 10 to function as a relay device for various types of information by reading one or more programs stored in the storage unit 13 into the RAM 12 and executing them.
- the CPU 11 can execute a plurality of programs in parallel, for example, by switching and executing a plurality of programs in a time division manner.
- the CPU 11 may represent a plurality of CPU groups. In this case, the functions realized by the CPU 11 are realized by the cooperation of a plurality of CPU groups.
- the RAM 12 is composed of a memory element such as SRAM (Static RAM) or DRAM (Dynamic RAM), and temporarily stores a program executed by the CPU 11, data necessary for execution, and the like.
- the computer program realized by the CPU 11 can be transferred while being recorded on a known recording medium such as a CD-ROM or DVD-ROM, or can be transferred by information transmission from a computer device such as a server computer.
- the transfer (transmission) of data from the upper apparatus to the lower apparatus is also referred to as “downloading”.
- the storage unit 13 includes a nonvolatile memory element such as a flash memory or an EEPROM.
- the storage unit 13 stores a program executed by the CPU 11 and data necessary for the execution, and stores an update program for each ECU 30 to be downloaded received from the DL server 6.
- a plurality of ECUs 30 are connected to the in-vehicle communication unit 14 via an in-vehicle communication line 16 disposed in the vehicle 1.
- the in-vehicle communication unit 14 communicates with the ECU 30 according to, for example, a CAN (Controller Area Network) standard.
- the communication standard adopted by the in-vehicle communication unit 14 is not limited to CAN, but is CANFD (CAN with Flexible Data Rate), LIN (Local Interconnect Network), Ethernet (registered trademark), or MOST (Media Oriented Systems Transport: MOST is a registered trademark). ) Or the like.
- the plurality of in-vehicle communication lines 16A and 16B may include different communication standards.
- the in-vehicle communication unit 14 transmits the information given from the CPU 11 to the target ECU 30 and gives the information received from the ECU 30 to the CPU 11.
- the in-vehicle communication unit 14 may perform communication according to other communication standards used for the in-vehicle network 4 as well as the above communication standards.
- the wireless communication unit 15 includes a wireless communication device including an antenna and a communication circuit that performs transmission / reception of a wireless signal from the antenna.
- the wireless communication unit 15 can communicate with an external device by being connected to a wide area communication network 2 such as a mobile phone network.
- the wireless communication unit 15 transmits information given from the CPU 11 to an external device such as the management server 5 via the wide area communication network 2 formed by a base station (not shown), and receives information received from the external device to the CPU 11. give.
- a communication unit that functions as a relay device in the vehicle 1 may be employed.
- This communication unit has a connector to which a communication cable conforming to a standard such as USB (Universal Serial Bus) or RS232C is connected, and may perform wired communication with another communication device connected via the communication cable.
- this communication unit has an interface according to a standard such as Bluetooth (registered trademark) or Wi-Fi (Wireless Fidelity: registered trademark), and performs wireless communication with another communication device connected via short-range wireless communication. May be performed.
- the external device When another communication device and an external device such as the management server 5 can perform wireless communication through the wide area communication network 2, the external device is determined by the communication path of the external device ⁇ the other communication device ⁇ the communication unit ⁇ the gateway 10. And the gateway 10 can communicate with each other.
- FIG. 3 is a block diagram showing an internal configuration of the ECU 30.
- the ECU 30 includes a CPU 31, a RAM 32, a storage unit 33, a communication unit 34, and the like.
- the ECU 30 is an in-vehicle control device that individually controls target devices mounted on the vehicle 1. Examples of the ECU 30 include a power supply control ECU, an engine control ECU, a steering control ECU, and a door lock control ECU.
- the CPU 31 controls the operation of the target device that it is in charge of by reading one or more programs stored in advance in the storage unit 33 into the RAM 32 and executing them.
- the CPU 31 may also represent a plurality of CPU groups, and the control by the CPU 31 may be control by cooperation of a plurality of CPU groups.
- the RAM 32 is configured by a memory element such as SRAM or DRAM, and temporarily stores programs executed by the CPU 31, data necessary for execution, and the like.
- the storage unit 33 is configured by a nonvolatile memory element such as a flash memory or an EEPROM, or a magnetic storage device such as a hard disk.
- the storage unit 33 stores a program that the CPU 31 reads and executes.
- a computer program for causing the CPU 31 to execute information processing for controlling a target device that is a control target in the vehicle, or a program such as a parameter or map information is executed.
- a control program which is data used at the time is included.
- the communication unit 34 is connected to the gateway 10 via an in-vehicle communication line disposed in the vehicle 1.
- the communication unit 34 communicates with the gateway 10 according to a standard such as CAN, Ethernet, or MOST.
- the communication unit 34 transmits the information given from the CPU 31 to the gateway 10 and gives the information received from the gateway 10 to the CPU 31.
- the communication unit 34 may communicate according to other communication standards used for the in-vehicle network, in addition to the above communication standards.
- the CPU 31 of the ECU 30 includes an activation unit 35 that switches the control mode by the CPU 31 to either “normal mode” or “reprogramming mode” (hereinafter also referred to as “repro mode”).
- the normal mode is a control mode in which the CPU 31 of the ECU 30 executes an original control for the target device (for example, engine control for the fuel engine, door lock control for the door lock motor, etc.).
- the reprogramming mode is a control mode in which a control program used for controlling the target device is updated. That is, the reprogramming mode is a control mode in which the CPU 31 erases or rewrites data of the control program in the ROM area of the storage unit 33. Only in this control mode, the CPU 31 can update the control program stored in the ROM area of the storage unit 33 to a new version.
- the activation unit 35 When the CPU 31 writes the new version of the control program in the storage unit 33 in the repro mode, the activation unit 35 once restarts (resets) the ECU 30 and executes the verify process on the storage area in which the new version of the control program is written. .
- the activation unit 35 causes the CPU 31 to operate according to the updated control program after the above-described verification processing is completed. Downloading an update program from the DL server 6 to the ECU 30 via the gateway 10 and updating the control program using the update program is also referred to as online update.
- FIG. 4 is a block diagram showing the internal configuration of the management server 5.
- the management server 5 includes a CPU 51, a ROM 52, a RAM 53, a storage unit 54, a communication unit 55, and the like.
- the CPU 51 reads out one or more programs stored in advance in the ROM 52 to the RAM 53 and executes them, thereby controlling the operation of each hardware and causing the management server 5 to function as an external device that can communicate with the gateway 10.
- the CPU 51 may also represent a plurality of CPU groups, and the functions realized by the CPU 51 may be realized by the cooperation of a plurality of CPU groups.
- the RAM 53 is configured by a memory element such as SRAM or DRAM, and temporarily stores programs executed by the CPU 51 and data necessary for execution.
- the storage unit 54 includes a nonvolatile memory element such as a flash memory or an EEPROM, or a magnetic storage device such as a hard disk.
- the communication unit 55 includes a communication device that executes communication processing in accordance with a predetermined communication standard, and is connected to the wide area communication network 2 such as a mobile phone network to execute the communication processing.
- the communication unit 55 transmits the information given from the CPU 51 to the external device via the wide area communication network 2 and gives the information received via the wide area communication network 2 to the CPU 51.
- FIG. 5 is a sequence diagram showing an example of the flow of online update of the control program executed in the program update system of the comparative example.
- an ECU also referred to as a target ECU
- the management server 5 determines the timing for updating the control program of the ECU of the vehicle 1 for the vehicle 1 registered in advance.
- the update timing may be set by, for example, the car manufacturer of the vehicle 1.
- the control program includes not only the program itself but also data used when executing the program, such as parameters and map information. These are represented as “control programs”. Therefore, the update program includes not only a program for updating the program but also data for updating data used when the program is executed.
- the management server 5 When the timing for updating the control program is reached, the management server 5 notifies the gateway 10 of the vehicle 1 of the update.
- the gateway 10 that has received the update notification from the management server 5 requests the DL server 6 to download the update program.
- the DL server 6 requested to download from the gateway 10 transmits an update program to be downloaded to the gateway 10 (step S1).
- the gateway 10 When the gateway 10 downloads the update program, the gateway 10 temporarily stores it in the storage unit 13 (step S2). Thereafter, an inquiry is made to the ECU 30A (abbreviated as the object ECU 30A in this description) that is the target ECU as to whether or not the control program can be updated (step S3A).
- the ECU 30A abbreviated as the object ECU 30A in this description
- the period T1 refers to a period in which the target ECU 30A cannot update the control program (also referred to as an impossible state), and the period T2 is a state in which the target ECU 30A can execute an update (also referred to as an enabled state). It refers to a certain period.
- the period T1 is a period during which the vehicle 1 is traveling, for example, and the period T2 is a period during which the vehicle 1 is stopped, for example.
- step S3A If there is an inquiry in step S3A within the period T1, the target ECU 30A answers a disabled state (step S3B).
- the gateway 10 holds the update program in the storage unit 13 and repeats the update request to the target ECU 30A at a predetermined interval.
- the target ECU 30A When the period T1 ends and the period T2 is reached, the target ECU 30A is enabled. Therefore, when an inquiry is made during that period, the target ECU 30A answers the enabled status.
- the gateway 10 that has obtained a reply indicating that the target ECU 30A is ready transmits an update program to the target ECU 30A and requests an update of the control program (step S4). In response to this request, the target ECU 30A performs an update process (step S5), and the control program is updated.
- the update process executed in the ECU 30 is started after the update program is received from the gateway 10, and the updated (new version) control program is completed in the storage area of the control program in the storage unit 33 and ends. And includes a plurality of processes from the start to the end of the process. As an example, the following five processes are included. The plurality of processes included in the update process are not limited to the following processes # 1 to # 5.
- Process # 1 Save the file (update program) in the storage unit 33
- Process # 2 Decrypt the encrypted file to obtain a compressed file
- Process # 3 Decompress the compressed file after decryption
- Process # 4 Apply the update program to the control program before update (old version) and build the control program after update (new version)
- Process # 5 Control the storage unit 33 Overwrite the control program of the old version by overwriting the new version of the control program in the program storage area.
- the target ECU 30A that has received the update request in step S4 starts the process from the process # 1 and sequentially executes the process to the process # 5 to complete the update process.
- the processing time D is the period from the transition of the period T1 to the period T2 until the target ECU 30A becomes ready and the completion of the update process in the target ECU 30A, that is, the period during which the update process is performed in the target ECU 30A.
- the processing time D1 in the example is a time (t2-t1) from the timing t1 when the period T1 shifts to the period T2 to the timing t2 when the update process of step S5 is completed in the target ECU 30A.
- FIG. 6 is a sequence diagram illustrating an example of a flow of online update of the control program executed in the program update system according to the first embodiment.
- the same operation as the online update flow of the comparative example of FIG. 5 is represented by the same step number.
- gateway 10 functions as an update control device that controls the update of the control program in target ECU 30A.
- the gateway 10 obtains a reply indicating that the target ECU 30A is disabled in response to the inquiry in step S3A within the period T1 (step S3B)
- the gateway 10 executes an update control process to control the update of the control program in the target ECU 30A ( Step S20).
- the update control process is a process for substituting at least a part of the update process using the update program with an ECU (also referred to as an alternative ECU) different from the target ECU 30A when the target ECU 30A is in a disabled state.
- ECU also referred to as an alternative ECU
- the alternative ECU is the ECU 30B shown in FIG. If not particularly limited, the alternative ECU is not limited to the ECU 30B, and may be any ECU 30 other than the target ECU.
- gateway 10 inquires whether or not the update process can be executed to ECU 30 ⁇ / b> B (abbreviated as alternative ECU 30 ⁇ / b> B in this description) that is an alternative ECU (step S ⁇ b> 21 ⁇ / b> A).
- ECU 30 ⁇ / b> B abbreviated as alternative ECU 30 ⁇ / b> B in this description
- step S21B an update program is transmitted to the alternative ECU 30B to request a first update process that is an update process of at least a part of the processes # 1 to # 5 (step S22).
- the alternative ECU 30B executes the first update process (step S23).
- the processing result of the first update process is stored in the storage unit 33 of the alternative ECU 30B.
- the gateway 10 requests the alternative ECU 30B to transmit the processing result of the first update process (step S24), and the alternative The processing result of the first update process is acquired from the ECU 30B (step S25).
- the gateway 10 transmits the processing result of the first update process to the target ECU 30A, and requests the second update process, which is the remaining update process of the processes # 1 to # 5 (step S4 ').
- the target ECU 30A executes the second update process (step S5 '), and the control program is updated.
- the processing time D2 in the target ECU 30A of the program update system is the time from the timing t1 when the period T1 has shifted to the period T2 to the timing t3 when the updating process of step S5 ′ is completed in the target ECU 30A (t3- t1).
- a part of the update process is executed in the alternative ECU 30B in the period T1, and therefore the processing time D2 in the target ECU 30A is longer than the processing time D1 in the target ECU 30A in the comparative example. Can be shortened.
- the CPU 11 of the gateway 10 includes an update control unit 111 as a function for executing the update control process.
- the update control process includes a determination process. Therefore, the update control unit 111 includes a determination unit 112 as a function for executing the determination process.
- These functions are functions realized in the CPU 11 when the CPU 11 reads and executes one or more programs stored in the storage unit 13. However, at least a part of these functions may be realized by hardware such as an electronic circuit.
- the determination process includes a first process for determining an alternative ECU and a second process for determining a process to be replaced by the alternative ECU.
- the determination unit 112 selects an ECU 30 that has a dynamic processing capability that is greater than or equal to a predetermined value among a plurality of ECUs 30 that are non-target devices other than the target ECU. Decide on an alternative ECU. Thereby, the overburden in alternative ECU can be avoided.
- the determination unit 112 acquires the usage rate of the CPU 31 of each ECU 30. As an example, the determination unit 112 inquires each ECU 30 about the usage rate of the CPU 31 as the availability of the update process. The determination unit 112 generates an inquiry frame (message) including an inquiry command in a frame that is a format of transmission information in CAN communication, and transmits the frame to the ECU 30 from the in-vehicle communication line 14.
- an inquiry frame messages including an inquiry command in a frame that is a format of transmission information in CAN communication
- the determination unit 112 determines the ECU 30 having the lowest usage rate of the CPU 31 among the plurality of ECUs 30 as an alternative ECU. Thereby, ECU30 with the largest dynamic processing capability is made into alternative ECU.
- the determination unit 112 determines an alternative ECU according to priority from among a plurality of ECUs 30 whose usage rate of the CPU 31 is equal to or less than a threshold value.
- the priority is set higher for an ECU that controls functions not related to running, such as an in-vehicle media player, than an ECU that controls functions that are not.
- the alternative ECU substitutes a part of the update process, there is a possibility that a part of the update process may affect the process originally executed by the ECU. In this case, when the alternative ECU controls functions related to vehicle travel, the vehicle travel may be affected. Therefore, by giving high priority to the ECU that controls the functions related to the vehicle travel, the influence on the vehicle travel can be prevented.
- the priority of the ECU connected to the same in-vehicle communication line 16 as the in-vehicle communication line 16 connecting the gateway 10 and the target ECU is higher than that of the ECU connected to a different in-vehicle communication line 16. Is also set high. Specifically, when the in-vehicle network 4 has the configuration of FIG. 1 and the target ECU is the ECU 30A, the ECUs 30B and 30C connected to the same in-vehicle communication line 16A as the ECU 30A have different in-vehicle communication lines 16B. The priority is set higher than the connected 30D and 30E.
- the in-vehicle communication is CAN communication and does not have a function (so-called partial wake-up function) that selectively activates a plurality of devices connected to each in-vehicle communication line 16, which is a function called a so-called partial network.
- a function so-called partial wake-up function
- all ECUs connected to the in-vehicle communication line 16 are activated. Therefore, if the ECU 30 connected to the in-vehicle communication line 16 different from the target ECU is used as an alternative ECU, the ECU 30 is started even when the ECU 30 connected to the same in-vehicle communication line 16 is not started. It is.
- FIG. 6 and FIG. 9 and FIG. 10, which will be described later, show an example in which the alternative ECU is an ECU 30B as an example. This can be said to be because the ECU 30B has been determined as an alternative ECU because it has a higher priority than the ECUs 30D and 30E. Even if the alternative ECU 30 is a low priority ECUD, 30E, the same operation as that described in these drawings is performed.
- the determination unit 112 may make an inquiry to all of the ECUs 30 mounted on the vehicle 1 other than the target ECU (for example, the ECU 30A). Thereby, the optimal alternative ECU can be determined. Alternatively, the determination unit 112 may make an inquiry only to an ECU with a higher priority (e.g., a predetermined priority or higher) among ECUs other than the target ECU. Thereby, an alternative ECU can be determined efficiently.
- a higher priority e.g., a predetermined priority or higher
- the determination unit 112 determines one or more processes to be replaced by the alternative ECU among the plurality of processes (# 1 to # 5) of the update process. Therefore, the determination unit 112 compares the processing amount required for each process with the dynamic processing capability of the alternative ECU. Then, the determination unit 112 determines, in order from the process # 1, a process in which the process amount is within the specified range of the dynamic processing capability of the alternative ECU as a process that causes the alternative ECU to substitute.
- the processing amount for each process depends on the data size of the update program, for example, by storing the correspondence between the data size and the processing amount in advance, it can be calculated based on the data size.
- the data size of the update program can be acquired from the DL server 6.
- the update control unit 111 generates a frame (message) including a command for requesting execution of the determined process in order to request the first update process from the alternative ECU, and sends the frame to the in-vehicle communication unit 14 as the alternative ECU. To send to.
- FIG. 7 is a flowchart showing a specific example of the update control process.
- the processing shown in the flowchart of FIG. 7 is performed by the CPU 11 of the gateway 10 by reading one or more programs stored in the storage unit 13 onto the RAM 12 and executing them, thereby executing the functions of the determination unit 112 and the update control unit 111. It is executed by realizing.
- the process in FIG. 7 is started when the gateway 10 downloads the update program from the DL server 6.
- CPU 11 inquires of the target ECU (for example, ECU 30A) whose control program is to be updated using the update program, and identifies whether the enabled state is an unusable state.
- the target ECU is in a ready state (YES in step S101)
- the CPU 11 transmits an update program to the target ECU and requests an update (step S102).
- step S101 When the target ECU is in a disabled state (NO in step S101), the CPU 11 executes a determination process (step S103). Then, the CPU 11 transmits the update program to the determined alternative ECU (for example, ECU 30B), and executes the first update process, which is the process of the determined process among the update processes using the update program. An instruction is given (step S105). In step S105, the CPU 11 generates a necessary frame and causes the in-vehicle communication unit 14 to transmit the frame to the alternative ECU.
- the determined alternative ECU for example, ECU 30B
- the CPU 11 inquires about the state of the target ECU after that. Then, when it becomes possible (YES in step S107), the CPU 11 requests the processing result of the first update process from the alternative ECU, transmits the acquired process result to the target ECU, and performs the remaining update process. A second update process is requested (step S109). In step S109, the CPU 11 generates a necessary frame and causes the in-vehicle communication unit 14 to transmit the frame to the alternative ECU.
- FIG. 8 is a flowchart showing the flow of the determination process in step S103 of FIG.
- the CPU 11 executes a first process (steps S201 to S205) of the determination process to determine an alternative ECU.
- CPU 11 inquires a plurality of ECUs 30 other than the target ECU about dynamic processing capability (usage rate of CPU 31) (step S201).
- the CPU 11 generates a necessary frame and causes the in-vehicle communication unit 14 to transmit the frame to a plurality of ECUs 30 other than the target ECU.
- the CPU 11 inquires a plurality of ECUs other than the target ECU according to the priority stored in advance.
- step S203 If there is an ECU 30 that has answered the inquiry in step S201 (YES in step S203), the CPU 11 determines the ECU 30 that has answered the dynamic processing capability as an alternative ECU (step S205).
- the CPU 11 executes a second process of the determination process to determine a process to be replaced by the alternative ECU (step S207).
- the gateway 10 holds the update program until the period T1 elapses and the target ECU becomes ready for update processing. Therefore, the memory of the gateway 10 is compressed as the period T1 becomes longer. In particular, when a plurality of update programs for a plurality of ECUs are downloaded and all of the plurality of target ECUs are disabled, the pressure on the memory of the gateway 10 becomes serious.
- the update program is transmitted from the gateway 10 to another ECU within the period T1. That is, the update program is distributed and stored. Therefore, memory pressure at the gateway 10 can be avoided.
- the program update system according to the first embodiment, at least a part of the update process (first update process) is performed in the alternative ECU within the period T1. Then, after the period T1 elapses, the remaining update process (second update process) is performed in the target ECU. Therefore, the processing time D2 at the target ECU is shorter than the processing time D1. As a result, it is possible to suppress a delay in completion of online update.
- ⁇ Modification 1> In the example of FIG. 6, when the target ECU becomes ready, the gateway 10 acquires the processing result of the first update process in the alternative ECU and transmits it to the target ECU. Transmission of the processing result to the target ECU is not limited to this method. The gateway 10 may instruct the alternative ECU to transmit the processing result of the first update process to the target ECU. Thereby, data transmission can be made efficient. The same applies to the following embodiments.
- the alternative ECU may be a plurality of ECUs. That is, in the first process of the determination process, the determination unit 112 may determine a plurality of ECUs for which the usage rate of the CPU 31 is equal to or less than the threshold as alternative ECUs. In this case, the determination unit 112 determines a process to be replaced by each of the plurality of alternative ECUs in the second process. Then, the update control unit 111 transmits the processing result in the alternative ECU that executed the previous process to the alternative ECU that substitutes the process according to the order of the processes, and requests the processing.
- the gateway 10 functions as an update control device and executes the update control process described above.
- the update control device is not limited to the gateway 10.
- the target ECU may function as an update control process and execute an update control process for controlling the update by itself.
- the CPU 31 of the target ECU includes an update control unit 311 corresponding to the update control unit 111 in order to execute the update control process.
- the update control unit 311 includes a determination unit 312 corresponding to the determination unit 112.
- FIG. 9 is a sequence diagram illustrating an example of a flow of online update of the control program executed in the program update system according to the second embodiment. 9, the same operation as the online update flow of FIG. 6 is represented by the same step number.
- gateway 10 downloads an update program from DL server 6 (step S1), it transmits the update program to the target ECU for update. Is requested (step S1 ′).
- the target ECU stores the received update program in the storage unit 33 (step S2).
- the target ECU executes an update control process in the period T1 (step S30). That is, in the second embodiment, when the target ECU inquires of another ECU 30 about the dynamic processing capability (the usage rate of the CPU 31) (step S31A) and obtains an answer (step S31B), an alternative ECU is selected from the inquiry. decide. Further, a process for requesting processing from the alternative ECU is determined. Then, the target ECU transmits an update program to the alternative ECU, and requests the first update process (step S33).
- the target ECU requests the processing result of the first update process from the alternative ECU (step S37), and acquires the processing result (step S39).
- the target ECU executes the second update process using the process result acquired from the alternative ECU (step S5 ').
- memory compression in the target ECU can be avoided as compared with the case where the target ECU stores the update program from the disabled state to the enabled state. Further, since the processing time in the target ECU can be shortened as in the program update system according to the first embodiment, the delay of completion of online update can be suppressed.
- the management server 5 may function as an update control device.
- the CPU 51 of the management server 5 performs the update control corresponding to the update control unit 111 in order to execute the update control process, as shown in FIG. Part 511.
- the update control unit 511 includes a determination unit 512 corresponding to the determination unit 112.
- FIG. 10 is a sequence diagram illustrating an example of a flow of online update of the control program executed in the program update system according to the third embodiment.
- the same operations as those in the online update flow of FIG. 6 are represented by the same step numbers.
- step S1 when gateway 10 downloads the update program from DL server 6 (step S1), it is the same as the online update of the first embodiment. Then, the target ECU is inquired about the state (step S3A). This inquiry may be made in response to a request from the management server 5. When the target ECU is in a disabled state (step S3B), the gateway 10 notifies the management server 5 that the target ECU is in a disabled state (step S41).
- the management server 5 that has received the notification from the gateway 10 executes an update control process (step S30).
- the management server 5 requests the gateway 10 for a dynamic processing capability inquiry (step S42).
- the gateway 10 inquires of the ECUs other than the target ECU about the dynamic processing capacity (the usage rate of the CPU 31) according to the request (step S43A). When an answer is obtained, the gateway 10 notifies the management server 5 (step S44).
- the management server 5 executes the first determination process based on the notification from the gateway 10 and determines an alternative ECU. In addition, the management server 5 executes the second process of the determination process, and determines a process for requesting the process to the alternative ECU. Then, the management server 5 requests the gateway 10 to request the first update process using the ECU 30 as an alternative ECU (step S45). The gateway 10 transmits the update program to the alternative ECU according to the request, and requests the first update process (step S46).
- the gateway 10 When the answer to the target ECU is obtained during the period T2, the gateway 10 notifies the management server 5 (step S48). Upon receiving this notification, the management server 5 requests the gateway 10 to request the target ECU for the second update process (step S45). The gateway 10 requests a processing result from the alternative ECU according to the request of the management server 5 (step S50), and acquires the processing result from the alternative ECU (step S51). The gateway 10 transmits the process result to the target ECU and requests the second update process (step S4 '). Thus, the second update process is executed in the target ECU (step S5 ').
- the disclosed features are realized by one or more modules.
- the feature can be realized by a circuit element or other hardware module, by a software module that defines processing for realizing the feature, or by a combination of a hardware module and a software module.
- a program that is a combination of one or more software modules for causing a computer to execute the above-described operation.
- a program is recorded on a computer-readable recording medium such as a flexible disk attached to the computer, a CD-ROM (Compact Disk-Read Only Memory), a ROM, a RAM, and a memory card, and provided as a program product. You can also.
- the program can be provided by being recorded on a recording medium such as a hard disk built in the computer.
- a program can also be provided by downloading via a network.
- the program according to the present disclosure is a program module that is provided as a part of a computer operating system (OS) and calls necessary modules in a predetermined arrangement at a predetermined timing to execute processing. Also good. In that case, the program itself does not include the module, and the process is executed in cooperation with the OS. Such a program that does not include a module may also be included in the program according to the present disclosure.
- OS computer operating system
- the program according to the present disclosure may be provided by being incorporated in a part of another program. Even in this case, the program itself does not include the module included in the other program, and the process is executed in cooperation with the other program.
- a program incorporated in such another program may also be included in the program according to the present disclosure.
- the provided program product is installed in a program storage unit such as a hard disk and executed.
- the program product includes the program itself and a recording medium on which the program is recorded.
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Automation & Control Theory (AREA)
- Human Computer Interaction (AREA)
- Transportation (AREA)
- Mechanical Engineering (AREA)
- Stored Programmes (AREA)
Abstract
車載制御装置と車内通信線を含む伝送路を介して通信する通信部と、下記の対象装置が制御プログラムの更新処理を実行できない場合に、下記の非対象装置である代替装置に更新処理の一部の代替を要求する要求メッセージを、通信部に送信させる制御部と、を備える、更新制御装置。 対象装置:制御プログラムの更新対象である車載制御装置 非対象装置:制御プログラムの更新対象ではない車載制御装置
Description
この発明は更新制御装置、制御方法、およびコンピュータプログラムに関する。
本出願は、2017年6月13日出願の日本出願第2017-116109号に基づく優先権を主張し、前記日本出願に記載された全ての記載内容を援用するものである。
本出願は、2017年6月13日出願の日本出願第2017-116109号に基づく優先権を主張し、前記日本出願に記載された全ての記載内容を援用するものである。
近年、自動車の技術分野においては、車両の高機能化が進行しており、多種多様な車載機器が車両に搭載されている。従って、車両には、各車載機器を制御するための制御装置である、所謂ECU(Electronic Control Unit)が多数搭載されている。
ECUの種類には、例えば、アクセル、ブレーキ、ハンドルの操作に対してエンジンやブレーキ、EPS(Electric Power Steering)等の制御を行う走行系に関わるもの、乗員によるスイッチ操作に応じて車内照明やヘッドライトの点灯/消灯と警報器の吹鳴等の制御を行うボディ系ECU、運転席近傍に配設されるメータ類の動作を制御するメータ系ECUなどがある。
ECUの種類には、例えば、アクセル、ブレーキ、ハンドルの操作に対してエンジンやブレーキ、EPS(Electric Power Steering)等の制御を行う走行系に関わるもの、乗員によるスイッチ操作に応じて車内照明やヘッドライトの点灯/消灯と警報器の吹鳴等の制御を行うボディ系ECU、運転席近傍に配設されるメータ類の動作を制御するメータ系ECUなどがある。
一般的にECUは、マイクロコンピュータ等の演算処理装置によって構成されており、ROM(Read Only Memory)に記憶した制御プログラムを読み出して実行することにより、車載機器の制御が実現される。
ECUの制御プログラムは、機能向上や防犯対策などを目的とした制御プログラムのバージョンアップに対応して、旧バージョンの制御プログラムを新バージョンの制御プログラムに書き換える必要がある。また、たとえば地図情報や制御用のパラメータなど、制御プログラムの実行に必要なデータも書き換える必要がある。
ECUの制御プログラムは、機能向上や防犯対策などを目的とした制御プログラムのバージョンアップに対応して、旧バージョンの制御プログラムを新バージョンの制御プログラムに書き換える必要がある。また、たとえば地図情報や制御用のパラメータなど、制御プログラムの実行に必要なデータも書き換える必要がある。
たとえば、特許文献1には、ネットワークを介して更新用プログラムをダウンロードし、プログラムの更新を行う技術(オンライン更新機能)が開示されている。
ある実施の形態に従うと、更新制御装置は、車載制御装置と車内通信線を含む伝送路を介して通信する通信部と、下記の対象装置が制御プログラムの更新処理を実行できない場合に、下記の非対象装置である代替装置に更新処理の一部の代替を要求する要求メッセージを、通信部に送信させる制御部と、を備える、更新制御装置。
対象装置:制御プログラムの更新対象である車載制御装置
非対象装置:制御プログラムの更新対象ではない車載制御装置
対象装置:制御プログラムの更新対象である車載制御装置
非対象装置:制御プログラムの更新対象ではない車載制御装置
他の実施の形態に従うと、制御方法は、車載制御装置と車内通信線を含む伝送路を介して通信する更新制御装置での制御方法であって、下記の対象装置が制御プログラムの更新処理を実行できない場合に、下記の非対象装置である代替装置に更新処理の一部の代替を要求する要求メッセージを送信するステップを備える、制御方法。
対象装置:制御プログラムの更新対象である車載制御装置
非対象装置:制御プログラムの更新対象ではない車載制御装置
対象装置:制御プログラムの更新対象である車載制御装置
非対象装置:制御プログラムの更新対象ではない車載制御装置
他の実施の形態に従うと、コンピュータプログラムは、車載制御装置と車内通信線を含む伝送路を介して通信する更新制御装置としてコンピュータを機能させるためのコンピュータプログラムであって、コンピュータを、車載制御装置と車内通信線を含む伝送路を介して通信する通信部と、下記の対象装置が制御プログラムの更新処理を実行できない場合に、下記の非対象装置である代替装置に更新処理の一部の代替を要求する要求メッセージを、通信部に送信させる制御部と、として機能させる、コンピュータプログラム。
対象装置:制御プログラムの更新対象である車載制御装置
非対象装置:制御プログラムの更新対象ではない車載制御装置
対象装置:制御プログラムの更新対象である車載制御装置
非対象装置:制御プログラムの更新対象ではない車載制御装置
<本開示が解決しようとする課題>
特許文献1に開示されているようなオンライン更新では、制御プログラムの更新を指示されたECUが更新を実行できない状態である場合には、ネットワークを介してダウンロードされた更新用プログラムはゲートウェイなどの制御装置にいったん保存され、更新を実行できる状態になると、制御装置から転送されて更新が開始されることが想定される。制御プログラムの更新を実行できない状態とは、たとえば、対象のECUが走行に関わる機能を制御するECUであって、車両が走行中の状態や、対象のECUが起動していない状態などである。
特許文献1に開示されているようなオンライン更新では、制御プログラムの更新を指示されたECUが更新を実行できない状態である場合には、ネットワークを介してダウンロードされた更新用プログラムはゲートウェイなどの制御装置にいったん保存され、更新を実行できる状態になると、制御装置から転送されて更新が開始されることが想定される。制御プログラムの更新を実行できない状態とは、たとえば、対象のECUが走行に関わる機能を制御するECUであって、車両が走行中の状態や、対象のECUが起動していない状態などである。
この場合、制御装置は更新用プログラムをメモリに保存するために、メモリが圧迫される。特に、昨今のECUの高機能化に鑑みると、更新用プログラムのサイズが大きかったり、同じタイミングに更新が必要なECUが複数であったりするため、メモリが大きく圧迫されるおそれがある。
また、対象のECUが更新を実行できる状態となるのを待って制御装置が更新用プログラムを転送して当該ECUにおいて更新が開始されると、当該ECUが更新を実行できる状態となってから更新が完了するまでの期間が長くなる。特に、同じタイミングに更新が必要なECUが複数ある場合には、それぞれのECUが更新を実行できる状態となってから更新が開始されるために、すべてのECUの更新が完了するまでの期間が長くなる。
本開示のある局面における目的は、車載制御装置が制御プログラムの更新ができない状態である場合における当該車載制御装置での更新を制御する更新制御装置、制御方法、およびコンピュータプログラムを提供することである。
<本開示の効果>
この開示によると、車載制御装置が制御プログラムの更新ができない状態である場合における当該車載制御装置での更新を制御することができる。
この開示によると、車載制御装置が制御プログラムの更新ができない状態である場合における当該車載制御装置での更新を制御することができる。
[実施の形態の説明]
本実施の形態には、少なくとも以下のものが含まれる。すなわち、
(1)本実施の形態に含まれる更新制御装置は、車載制御装置と車内通信線を含む伝送路を介して通信する通信部と、下記の対象装置が制御プログラムの更新処理を実行できない場合に、下記の非対象装置である代替装置に更新処理の一部の代替を要求する要求メッセージを、通信部に送信させる制御部と、を備える。
対象装置:制御プログラムの更新対象である車載制御装置
非対象装置:制御プログラムの更新対象ではない車載制御装置
これにより、更新対象の車載制御装置が制御プログラムの更新処理を実行できない状態であっても、代替装置によって更新処理の少なくとも一部が実行される。そのため、更新対象の車載制御装置が制御プログラムの更新処理実行できる状態になるまで1台の装置で更新用プログラムを保存しておく場合と比較して、更新用プログラムの保存先を分散することができ、当該1台の装置のメモリの圧迫を回避することができる。また、更新制御処理の開始を早めることができ、その結果、更新対象の車載制御装置での更新完了の遅延を抑えることができる。
本実施の形態には、少なくとも以下のものが含まれる。すなわち、
(1)本実施の形態に含まれる更新制御装置は、車載制御装置と車内通信線を含む伝送路を介して通信する通信部と、下記の対象装置が制御プログラムの更新処理を実行できない場合に、下記の非対象装置である代替装置に更新処理の一部の代替を要求する要求メッセージを、通信部に送信させる制御部と、を備える。
対象装置:制御プログラムの更新対象である車載制御装置
非対象装置:制御プログラムの更新対象ではない車載制御装置
これにより、更新対象の車載制御装置が制御プログラムの更新処理を実行できない状態であっても、代替装置によって更新処理の少なくとも一部が実行される。そのため、更新対象の車載制御装置が制御プログラムの更新処理実行できる状態になるまで1台の装置で更新用プログラムを保存しておく場合と比較して、更新用プログラムの保存先を分散することができ、当該1台の装置のメモリの圧迫を回避することができる。また、更新制御処理の開始を早めることができ、その結果、更新対象の車載制御装置での更新完了の遅延を抑えることができる。
(2)好ましくは、制御部は、代替の可否を問い合わせる非対象装置宛の問い合わせメッセージを通信部に送信させ、非対象装置からの応答メッセージの内容に応じて、非対象装置を代替装置とするか否かを決定する。
これにより、非対象装置の応答内容に応じて代替装置を決定することができる。
これにより、非対象装置の応答内容に応じて代替装置を決定することができる。
(3)好ましくは、制御部は、複数の非対象装置に、優先度に従って代替の可否を問い合わせる。
これにより、優先度の高い車載制御装置を代替装置と決定することができる。
これにより、優先度の高い車載制御装置を代替装置と決定することができる。
(4)好ましくは、制御部は、動的な処理能力が所定値以上であることを含む応答メッセージを受信した場合は、当該応答メッセージの送信元の非対象装置を代替装置と決定する。
これにより、動的な処理能力が高い車載制御装置を代替装置と決定することができる。その結果、代替装置と決定された車載制御装置の過負荷を回避できる。
これにより、動的な処理能力が高い車載制御装置を代替装置と決定することができる。その結果、代替装置と決定された車載制御装置の過負荷を回避できる。
(5)好ましくは、制御部は、応答メッセージの送信元の複数の非対象装置から優先度に従って代替装置を決定する。
これにより、適切な車載制御装置を代替装置と決定することができる。
これにより、適切な車載制御装置を代替装置と決定することができる。
(6)好ましくは、通信部に複数の車内通信線が終端し、かつ、通信部が車内通信線に接続された機器を選択的に起動する機能を有しない場合は、制御部は、対象装置と同じ車内通信線に繋がる非対象装置を、対象装置と異なる車内通信線に繋がる非対象装置よりも高優先とする。
通信部が車内通信線に接続された機器を選択的に起動する機能を有しない場合、1つの車内通信線でデータを転送すると当該車内通信線に接続されたすべての車載制御装置が起動する。この場合に、更新対象の車載制御装置と異なる車内通信線に接続された車載制御装置を代替装置とすることによって当該代替装置と同一の車内通信線に接続された他の車載制御装置が起動していない場合にも起動させてしまう、という事態を回避できる。
通信部が車内通信線に接続された機器を選択的に起動する機能を有しない場合、1つの車内通信線でデータを転送すると当該車内通信線に接続されたすべての車載制御装置が起動する。この場合に、更新対象の車載制御装置と異なる車内通信線に接続された車載制御装置を代替装置とすることによって当該代替装置と同一の車内通信線に接続された他の車載制御装置が起動していない場合にも起動させてしまう、という事態を回避できる。
(7)好ましくは、制御部は、車両走行に無関係な制御機能を担う非対象装置を、その他の機能を担う非対象装置よりも高優先とする。
これにより、非対象装置が代替する更新処理の一部が、当該非対象装置が本来実行する処理に影響を及ぼす可能性がある場合であっても、車両走行への当該影響を防止できる。
これにより、非対象装置が代替する更新処理の一部が、当該非対象装置が本来実行する処理に影響を及ぼす可能性がある場合であっても、車両走行への当該影響を防止できる。
(8)好ましくは、更新処理は複数のプロセスを含み、制御部は、複数のプロセスのうちの代替装置に代替を要求するプロセスを決定する。
これにより、代替車載制御処理の過負荷を抑えながら、更新対象の車載制御装置での更新の完了を早めることができる。
これにより、代替車載制御処理の過負荷を抑えながら、更新対象の車載制御装置での更新の完了を早めることができる。
(9)本実施の形態に含まれる制御方法は、(1)~(8)のいずれか1つに記載の更新制御装置において、車載制御装置での制御プログラムの更新を制御する方法である。
かかる制御方法は、上記(1)~(8)の更新制御装置と同様の効果を奏する。
かかる制御方法は、上記(1)~(8)の更新制御装置と同様の効果を奏する。
(10)本実施の形態に含まれるコンピュータプログラムは、コンピュータを、(1)~(8)のいずれか1つに記載の更新制御装置として機能させる。
かかるコンピュータプログラムは、上記(1)~(8)の更新制御装置と同様の効果を奏する。
かかるコンピュータプログラムは、上記(1)~(8)の更新制御装置と同様の効果を奏する。
[実施の形態の詳細]
以下に、図面を参照しつつ、好ましい実施の形態について説明する。以下の説明では、同一の部品および構成要素には同一の符号を付してある。それらの名称および機能も同じである。したがって、これらの説明は繰り返さない。
以下に、図面を参照しつつ、好ましい実施の形態について説明する。以下の説明では、同一の部品および構成要素には同一の符号を付してある。それらの名称および機能も同じである。したがって、これらの説明は繰り返さない。
<第1の実施の形態>
〔システムの全体構成〕
図1は、実施形態にかかるプログラム更新システムの全体構成図である。
図1に示すように、本実施形態のプログラム更新システムは、一例として広域通信網2である通信ネットワークを介して通信可能な車両1、管理サーバ5およびDL(ダウンロード)サーバ6を含む。
管理サーバ5は、車両1の更新情報を管理する。DLサーバ6は、更新用プログラムを保存する。管理サーバ5およびDLサーバ6は、たとえば、車両1のカーメーカーにより運営されており、予め会員登録されたユーザが所有する多数の車両1と通信可能である。
〔システムの全体構成〕
図1は、実施形態にかかるプログラム更新システムの全体構成図である。
図1に示すように、本実施形態のプログラム更新システムは、一例として広域通信網2である通信ネットワークを介して通信可能な車両1、管理サーバ5およびDL(ダウンロード)サーバ6を含む。
管理サーバ5は、車両1の更新情報を管理する。DLサーバ6は、更新用プログラムを保存する。管理サーバ5およびDLサーバ6は、たとえば、車両1のカーメーカーにより運営されており、予め会員登録されたユーザが所有する多数の車両1と通信可能である。
車両1には、車内通信線16で接続された複数のECU30とゲートウェイ10とを含む車内ネットワーク(通信ネットワーク)4と、無線通信部15と、各ECU30によりそれぞれ制御される各種の車載機器(図示せず)と、が搭載されている。
車内ネットワーク4は複数の車内通信線16A,16Bを有する。車内ネットワーク4は、車内通信線16Aにバス接続されたECU30A~30C、車内通信線16Bにバス接続されたECU30D,30Eである、複数の通信グループを含む。ゲートウェイ10は、通信グループ間の通信を中継している。このため、ゲートウェイ10には車内通信線16A,16Bが接続されている。車内通信線16A,16Bを車内通信線16とも総称する。
車内ネットワーク4は複数の車内通信線16A,16Bを有する。車内ネットワーク4は、車内通信線16Aにバス接続されたECU30A~30C、車内通信線16Bにバス接続されたECU30D,30Eである、複数の通信グループを含む。ゲートウェイ10は、通信グループ間の通信を中継している。このため、ゲートウェイ10には車内通信線16A,16Bが接続されている。車内通信線16A,16Bを車内通信線16とも総称する。
無線通信部15は、携帯電話網などの広域通信網2に通信可能に接続され、車内通信線によりゲートウェイ10に接続されている。ゲートウェイ10は、広域通信網2を通じて管理サーバ5およびDLサーバ6などの車外装置から無線通信部15が受信した情報を、車内通信線を介してECU30に送信する。
ゲートウェイ10は、ECU30から取得した情報を無線通信部15に送信し、無線通信部15は、その情報を管理サーバ5などの車外装置に送信する。
また、ECU30同士は、車内通信線を介して情報を送受信する。
ゲートウェイ10は、ECU30から取得した情報を無線通信部15に送信し、無線通信部15は、その情報を管理サーバ5などの車外装置に送信する。
また、ECU30同士は、車内通信線を介して情報を送受信する。
車両1に搭載される無線通信部15としては、車載の専用通信端末の他に、たとえば、ユーザが所有する携帯電話機、スマートフォン、タブレット型端末、ノートPC(Personal Computer)等の装置が考えられる。
図1では、ゲートウェイ10が無線通信部15を介して車外装置と通信を行う場合が例示されているが、ゲートウェイ10が無線通信の機能を有する場合には、ゲートウェイ10自身が管理サーバ5などの車外装置と無線通信を行う構成としてもよい。
図1では、ゲートウェイ10が無線通信部15を介して車外装置と通信を行う場合が例示されているが、ゲートウェイ10が無線通信の機能を有する場合には、ゲートウェイ10自身が管理サーバ5などの車外装置と無線通信を行う構成としてもよい。
また、図1のプログラム更新システムでは、管理サーバ5とDLサーバ6とが別個のサーバで構成されているが、これらのサーバ5,6を1つのサーバ装置で構成してもよい。また、管理サーバ5およびDLサーバ6は、いずれも、複数の装置からなるものであってもよい。
なお、プログラム更新システムには、DLサーバ6に替えて(または加えて)、更新用プログラムを保存し、ゲートウェイ10と有線または無線通信で通信可能な車外装置が含まれてもよい。
〔ゲートウェイの内部構成〕
図2は、ゲートウェイ10の内部構成を示すブロック図である。
図2に示すように、ゲートウェイ10は、CPU11、RAM(Random Access Memory)12、記憶部13、および車内通信部14などを備える。ゲートウェイ10は、無線通信部15と車内通信線を介して接続されているが、これらは一つの装置で構成してもよい。
図2は、ゲートウェイ10の内部構成を示すブロック図である。
図2に示すように、ゲートウェイ10は、CPU11、RAM(Random Access Memory)12、記憶部13、および車内通信部14などを備える。ゲートウェイ10は、無線通信部15と車内通信線を介して接続されているが、これらは一つの装置で構成してもよい。
CPU11は、記憶部13に記憶された一または複数のプログラムをRAM12に読み出して実行することにより、ゲートウェイ10を各種情報の中継装置として機能させる。
CPU11は、たとえば時分割で複数のプログラムを切り替えて実行することにより、複数のプログラムを並列的に実行可能である。なお、CPU11は複数のCPU群を代表するものであってもよい。この場合、CPU11の実現する機能は、複数のCPU群が協働して実現するものである。RAM12は、SRAM(Static RAM)またはDRAM(Dynamic RAM)等のメモリ素子で構成され、CPU11が実行するプログラムおよび実行に必要なデータ等が一時的に記憶される。
CPU11は、たとえば時分割で複数のプログラムを切り替えて実行することにより、複数のプログラムを並列的に実行可能である。なお、CPU11は複数のCPU群を代表するものであってもよい。この場合、CPU11の実現する機能は、複数のCPU群が協働して実現するものである。RAM12は、SRAM(Static RAM)またはDRAM(Dynamic RAM)等のメモリ素子で構成され、CPU11が実行するプログラムおよび実行に必要なデータ等が一時的に記憶される。
CPU11が実現するコンピュータプログラムは、CD-ROMやDVD-ROMなどの周知の記録媒体に記録した状態で譲渡することもできるし、サーバコンピュータなどのコンピュータ装置からの情報伝送によって譲渡することもできる。
この点は、後述のECU30のCPU31(図3参照)が実行するコンピュータプログラム、および、後述の管理サーバ5のCPU51(図4参照)が実行するコンピュータプログラムについても同様である。
なお、以降の説明において、上位装置が下位装置にデータを転送(送信)することを「ダウンロードする」ともいう。
この点は、後述のECU30のCPU31(図3参照)が実行するコンピュータプログラム、および、後述の管理サーバ5のCPU51(図4参照)が実行するコンピュータプログラムについても同様である。
なお、以降の説明において、上位装置が下位装置にデータを転送(送信)することを「ダウンロードする」ともいう。
記憶部13は、フラッシュメモリ若しくはEEPROM等の不揮発性のメモリ素子などにより構成されている。記憶部13は、CPU11が実行するプログラムおよび実行に必要なデータ等を記憶するとともに、DLサーバ6から受信した、ダウンロード対象の各ECU30の更新用プログラムなどを記憶する。
車内通信部14には、車両1に配設された車内通信線16を介して複数のECU30が接続されている。車内通信部14は、たとえばCAN(Controller Area Network)の規格に応じて、ECU30との通信を行う。車内通信部14の採用する通信規格はCANに限定されず、CANFD(CAN with Flexible Data Rate)、LIN(Local Interconnect Network)、Ethernet(登録商標)、またはMOST(Media Oriented Systems Transport:MOSTは登録商標)等の規格であってもよい。複数の車内通信線16A,16Bの中には、通信規格の異なるものが含まれていてもよい。
車内通信部14は、CPU11から与えられた情報を対象のECU30へ送信するとともに、ECU30から受信した情報をCPU11に与える。車内通信部14は、上記の通信規格だけでなく、車内ネットワーク4に用いる他の通信規格によって通信してもよい。
車内通信部14は、CPU11から与えられた情報を対象のECU30へ送信するとともに、ECU30から受信した情報をCPU11に与える。車内通信部14は、上記の通信規格だけでなく、車内ネットワーク4に用いる他の通信規格によって通信してもよい。
無線通信部15は、アンテナと、アンテナからの無線信号の送受信を実行する通信回路とを含む無線通信機よりなる。無線通信部15は、携帯電話網等の広域通信網2に接続されることにより車外装置との通信が可能である。
無線通信部15は、図示しない基地局により形成される広域通信網2を介して、CPU11から与えられた情報を管理サーバ5等の車外装置に送信するとともに、車外装置から受信した情報をCPU11に与える。
無線通信部15は、図示しない基地局により形成される広域通信網2を介して、CPU11から与えられた情報を管理サーバ5等の車外装置に送信するとともに、車外装置から受信した情報をCPU11に与える。
図2に示す無線通信部15に代えて、車両1内の中継装置として機能する通信部を採用してもよい。この通信部は、USB(Universal Serial Bus)またはRS232C等の規格に応じた通信ケーブルが接続されるコネクタを有し、通信ケーブルを介して接続された別の通信装置と有線通信を行ってもよい。また、この通信部は、Bluetooth(登録商標)またはWi-Fi(Wireless Fidelity:登録商標)等の規格に応じたインタフェースを有し、近距離無線を介して接続された別の通信装置と無線通信を行ってもよい。
別の通信装置と管理サーバ5等の車外装置とが広域通信網2を通じた無線通信が可能である場合には、車外装置→別の通信装置→通信部→ゲートウェイ10の通信経路により、車外装置とゲートウェイ10とが通信可能になる。
別の通信装置と管理サーバ5等の車外装置とが広域通信網2を通じた無線通信が可能である場合には、車外装置→別の通信装置→通信部→ゲートウェイ10の通信経路により、車外装置とゲートウェイ10とが通信可能になる。
〔ECUの内部構成〕
図3は、ECU30の内部構成を示すブロック図である。
図3に示すように、ECU30は、CPU31、RAM32、記憶部33、および通信部34などを備える。ECU30は、車両1に搭載された対象機器を個別に制御する車載制御装置である。ECU30の種類には、たとえば、電源制御ECU、エンジン制御ECU、ステアリング制御ECU、およびドアロック制御ECUなどがある。
図3は、ECU30の内部構成を示すブロック図である。
図3に示すように、ECU30は、CPU31、RAM32、記憶部33、および通信部34などを備える。ECU30は、車両1に搭載された対象機器を個別に制御する車載制御装置である。ECU30の種類には、たとえば、電源制御ECU、エンジン制御ECU、ステアリング制御ECU、およびドアロック制御ECUなどがある。
CPU31は、記憶部33に予め記憶された一または複数のプログラムをRAM32に読み出して実行することにより、自身が担当する対象機器の動作を制御する。CPU31もまた複数のCPU群を代表するものであってもよく、CPU31による制御は、複数のCPU群が協働することによる制御であってもよい。
RAM32は、SRAMまたはDRAM等のメモリ素子で構成され、CPU31が実行するプログラムおよび実行に必要なデータ等が一時的に記憶される。
RAM32は、SRAMまたはDRAM等のメモリ素子で構成され、CPU31が実行するプログラムおよび実行に必要なデータ等が一時的に記憶される。
記憶部33は、フラッシュメモリ若しくはEEPROM等の不揮発性のメモリ素子、或いは、ハードディスクなどの磁気記憶装置等により構成されている。
記憶部33は、CPU31が読み出して実行するプログラムを格納する。記憶部33が記憶する情報には、たとえば、車内の制御対象である対象機器を制御するための情報処理をCPU31に実行させるためのコンピュータプログラムや、パラメータや地図情報などの、当該プログラムを実行する際に用いるデータである制御プログラムが含まれる。
記憶部33は、CPU31が読み出して実行するプログラムを格納する。記憶部33が記憶する情報には、たとえば、車内の制御対象である対象機器を制御するための情報処理をCPU31に実行させるためのコンピュータプログラムや、パラメータや地図情報などの、当該プログラムを実行する際に用いるデータである制御プログラムが含まれる。
通信部34には、車両1に配設された車内通信線を介してゲートウェイ10が接続されている。通信部34は、たとえばCAN、Ethernet、またはMOST等の規格に応じて、ゲートウェイ10との通信を行う。
通信部34は、CPU31から与えられた情報をゲートウェイ10へ送信するとともに、ゲートウェイ10から受信した情報をCPU31に与える。通信部34は、上記の通信規格だけなく、車載ネットワークに用いる他の通信規格によって通信してもよい。
通信部34は、CPU31から与えられた情報をゲートウェイ10へ送信するとともに、ゲートウェイ10から受信した情報をCPU31に与える。通信部34は、上記の通信規格だけなく、車載ネットワークに用いる他の通信規格によって通信してもよい。
ECU30のCPU31には、当該CPU31による制御モードを、「通常モード」または「リプログラミングモード」(以下、「リプロモード」ともいう。)のいずれかに切り替える起動部35が含まれる。
ここで、通常モードとは、ECU30のCPU31が、対象機器に対する本来的な制御(たとえば、燃料エンジンに対するエンジン制御や、ドアロックモータに対するドアロック制御など)を実行する制御モードのことである。
ここで、通常モードとは、ECU30のCPU31が、対象機器に対する本来的な制御(たとえば、燃料エンジンに対するエンジン制御や、ドアロックモータに対するドアロック制御など)を実行する制御モードのことである。
リプログラミングモードとは、対象機器の制御に用いる制御プログラムを更新する制御モードである。
すなわち、リプログラミングモードは、CPU31が、記憶部33のROM領域に対して、制御プログラムのデータの消去や書き換えを行う制御モードのことである。CPU31は、この制御モードのときにのみ、記憶部33のROM領域に格納された制御プログラムを新バージョンに更新することが可能となる。
すなわち、リプログラミングモードは、CPU31が、記憶部33のROM領域に対して、制御プログラムのデータの消去や書き換えを行う制御モードのことである。CPU31は、この制御モードのときにのみ、記憶部33のROM領域に格納された制御プログラムを新バージョンに更新することが可能となる。
リプロモードにおいてCPU31が新バージョンの制御プログラムを記憶部33に書き込むと、起動部35は、ECU30をいったん再起動(リセット)させ、新バージョンの制御プログラムが書き込まれた記憶領域についてベリファイ処理を実行する。
起動部35は、上記のベリファイ処理の完了後に、CPU31を更新後の制御プログラムによって動作させる。
DLサーバ6からゲートウェイ10を介してECU30に更新用プログラムがダウンロードされ、当該更新用プログラムを用いて制御プログラムを更新することを、オンライン更新とも称する。
起動部35は、上記のベリファイ処理の完了後に、CPU31を更新後の制御プログラムによって動作させる。
DLサーバ6からゲートウェイ10を介してECU30に更新用プログラムがダウンロードされ、当該更新用プログラムを用いて制御プログラムを更新することを、オンライン更新とも称する。
〔管理サーバの内部構成〕
図4は、管理サーバ5の内部構成を示すブロック図である。
図4に示すように、管理サーバ5は、CPU51、ROM52、RAM53、記憶部54、および通信部55などを備える。
図4は、管理サーバ5の内部構成を示すブロック図である。
図4に示すように、管理サーバ5は、CPU51、ROM52、RAM53、記憶部54、および通信部55などを備える。
CPU51は、ROM52に予め記憶された一または複数のプログラムをRAM53に読み出して実行することにより、各ハードウェアの動作を制御し、管理サーバ5をゲートウェイ10と通信可能な車外装置として機能させる。CPU51もまた複数のCPU群を代表するものであってもよく、CPU51の実現する機能は、複数のCPU群が協働して実現するものであってもよい。
RAM53は、SRAMまたはDRAM等のメモリ素子で構成され、CPU51が実行するプログラムおよび実行に必要なデータ等が一時的に記憶される。
RAM53は、SRAMまたはDRAM等のメモリ素子で構成され、CPU51が実行するプログラムおよび実行に必要なデータ等が一時的に記憶される。
記憶部54は、フラッシュメモリ若しくはEEPROM等の不揮発性のメモリ素子、または、ハードディスクなどの磁気記憶装置等により構成されている。
通信部55は、所定の通信規格に則って通信処理を実行する通信装置よりなり、携帯電話網等の広域通信網2に接続されて当該通信処理を実行する。通信部55は、CPU51から与えられた情報を、広域通信網2を介して外部装置に送信するとともに、広域通信網2を介して受信した情報をCPU51に与える。
通信部55は、所定の通信規格に則って通信処理を実行する通信装置よりなり、携帯電話網等の広域通信網2に接続されて当該通信処理を実行する。通信部55は、CPU51から与えられた情報を、広域通信網2を介して外部装置に送信するとともに、広域通信網2を介して受信した情報をCPU51に与える。
〔比較例の制御プログラムの更新シーケンス〕
図5は、比較例のプログラム更新システムにおいて実行される、制御プログラムのオンライン更新の流れの一例を示すシーケンス図である。比較例の制御プログラムの更新シーケンスおよび後述する実施の形態にかかる制御プログラムの更新シーケンスでは、いずれも、図1に示されたECU30Aの制御プログラムを更新するECU(対象ECUとも称する)とする場合を例に説明する。対象ECUが図1に示された他のECU30である場合も、同じ動作が行われる。DLサーバ6に1または複数の更新用プログラムが格納され、一例として、管理サーバ5が、予め登録された車両1について、当該車両1のECUの制御プログラムを更新するタイミングを決定する。更新のタイミングは、たとえば、車両1のカーメーカーなどによって設定されてもよい。
図5は、比較例のプログラム更新システムにおいて実行される、制御プログラムのオンライン更新の流れの一例を示すシーケンス図である。比較例の制御プログラムの更新シーケンスおよび後述する実施の形態にかかる制御プログラムの更新シーケンスでは、いずれも、図1に示されたECU30Aの制御プログラムを更新するECU(対象ECUとも称する)とする場合を例に説明する。対象ECUが図1に示された他のECU30である場合も、同じ動作が行われる。DLサーバ6に1または複数の更新用プログラムが格納され、一例として、管理サーバ5が、予め登録された車両1について、当該車両1のECUの制御プログラムを更新するタイミングを決定する。更新のタイミングは、たとえば、車両1のカーメーカーなどによって設定されてもよい。
なお、制御プログラムは、プログラムそのもののみならず、パラメータや地図情報などの、当該プログラムを実行する際に用いるデータも含む。それらを代表させて「制御プログラム」と表現している。そのため、更新用プログラムは、プログラムの更新用のプログラムのみならず、当該プログラムを実行する際に用いるデータの更新用のデータを含む。
制御プログラムを更新するタイミングに達すると、管理サーバ5は、該当する車両1のゲートウェイ10宛てに、更新を通知する。管理サーバ5から更新の通知を受信したゲートウェイ10は、DLサーバ6に対して更新用プログラムのダウンロードを要求する。ゲートウェイ10からダウンロードが要求されたDLサーバ6は、ダウンロード対象の更新用プログラムをゲートウェイ10に送信する(ステップS1)。
ゲートウェイ10は、更新用プログラムをダウンロードすると、記憶部13にいったん記憶する(ステップS2)。その後、対象ECUであるECU30A(この説明において対象ECU30Aと略する)に制御プログラムの更新が可能な状態であるか否かの状態を問い合わせる(ステップS3A)。
この説明において、期間T1は、対象ECU30Aが制御プログラムの更新を実行できない状態(不可状態とも称する)である期間を指し、期間T2は、対象ECU30Aが更新を実行できる状態(可状態とも称する)である期間を指す。期間T1は、たとえば、車両1が走行中の期間であり、期間T2は、たとえば、車両1が停車中の期間である。
期間T1内にステップS3Aの問い合わせがあった場合、対象ECU30Aは不可状態を回答する(ステップS3B)。この場合、ゲートウェイ10は、更新用プログラムを記憶部13に保持して、所定の間隔で対象ECU30Aへの更新の要求を繰り返す。
期間T1が終了して期間T2となると、対象ECU30Aは可状態になるため、その期間に問い合わせがあった場合、対象ECU30Aは可状態を回答する。対象ECU30Aから可状態の回答を得たゲートウェイ10は、対象ECU30Aに更新用プログラムを送信して、制御プログラムの更新を要求する(ステップS4)。この要求に応じて、対象ECU30Aでは更新処理が実行され(ステップS5)、制御プログラムが更新される。
ECU30において実行される更新処理は、ゲートウェイ10から更新用プログラムを受信してから開始され、記憶部33の制御プログラムの保存領域に更新後(新バージョン)の制御プログラムが完了して終了する、一連の処理を指し、当該処理の開始から終了までの間に複数プロセスを含む。一例として、次の5つのプロセスを含む。更新処理に含まれる複数のプロセスは下のプロセス#1~#5に限定されない。
プロセス#1:ファイル(更新用プログラム)を記憶部33に保存する
プロセス#2:暗号化されたファイルを復号処理して圧縮ファイルを取得する
プロセス#3:復号後の、圧縮ファイルを解凍処理して更新用プログラムを取得する
プロセス#4:更新前(旧バージョン)の制御プログラムに更新用プログラムを適用して、更新後(新バージョン)の制御プログラムを構築する
プロセス#5:記憶部33の制御プログラムの保存領域に新バージョンの制御プログラムを上書きすることで、旧バージョンの制御プログラムを書き換える
プロセス#1:ファイル(更新用プログラム)を記憶部33に保存する
プロセス#2:暗号化されたファイルを復号処理して圧縮ファイルを取得する
プロセス#3:復号後の、圧縮ファイルを解凍処理して更新用プログラムを取得する
プロセス#4:更新前(旧バージョン)の制御プログラムに更新用プログラムを適用して、更新後(新バージョン)の制御プログラムを構築する
プロセス#5:記憶部33の制御プログラムの保存領域に新バージョンの制御プログラムを上書きすることで、旧バージョンの制御プログラムを書き換える
ステップS4で更新の要求を受けた対象ECU30Aは、プロセス#1から処理を開始して、プロセス#5まで順に実行して、更新処理を完了する。期間T1が期間T2に移行して対象ECU30Aが可状態となってから対象ECU30Aにおいて更新処理が完了するまでの期間、つまり、対象ECU30Aにおいて更新処理を行っていた期間を処理時間Dとすると、比較例の処理時間D1は、期間T1が期間T2に移行したタイミングt1から対象ECU30AでステップS5の更新処理が完了するタイミングt2までの時間(t2-t1)となる。
[実施の形態の制御プログラムの更新シーケンス]
図6は、第1の実施の形態にかかるプログラム更新システムにおいて実行される、制御プログラムのオンライン更新の流れの一例を示すシーケンス図である。図6において、図5の比較例のオンライン更新の流れと同じ動作については、同じステップ番号で表されている。
図6は、第1の実施の形態にかかるプログラム更新システムにおいて実行される、制御プログラムのオンライン更新の流れの一例を示すシーケンス図である。図6において、図5の比較例のオンライン更新の流れと同じ動作については、同じステップ番号で表されている。
図6を参照して、実施の形態にかかるプログラム更新システムでは、ゲートウェイ10が、対象ECU30Aでの制御プログラムの更新を制御する更新制御装置として機能する。ゲートウェイ10は、期間T1内のステップS3Aの問い合わせに対して対象ECU30Aから不可状態の回答を得ると(ステップS3B)、対象ECU30Aでの制御プログラムの更新を制御するために更新制御処理を実行する(ステップS20)。
更新制御処理は、対象ECU30Aが不可状態である場合に、当該更新用プログラムを用いた更新処理の少なくとも一部を、対象ECU30Aとは異なるECU(代替ECUとも称する)に代替させるための処理である。図6の例では、代替ECUが図1に示されたECU30Bであるものとしている。特に限定されない場合には代替ECUはECU30Bに限定されず、対象ECU以外のいずれのECU30であってもよい。これは、後述する第2の実施の形態および第3の実施の形態にかかるプログラム更新システムの動作(図9、図10)でも同様である。他のECU30が代替ECUとなる場合であっても、図6と同じ動作が行われる。具体的には、図6を参照して、ゲートウェイ10は、代替ECUであるECU30B(この説明において代替ECU30Bと略する)に更新処理の実行の可否を問い合わせ(ステップS21A)、代替ECU30Bから可状態の回答を得ると(ステップS21B)、代替ECU30Bに更新用プログラムを送信して、プロセス#1~#5の少なくとも一部の更新処理である第1の更新処理を要求する(ステップS22)。この要求に応じて、代替ECU30Bでは、第1の更新処理が実行される(ステップS23)。第1の更新処理の処理結果は、代替ECU30Bの記憶部33に保存される。
期間T1が終了して期間T2となって対象ECU30Aから可状態の回答を得ると、ゲートウェイ10は、代替ECU30Bに対して第1の更新処理の処理結果の送信を要求し(ステップS24)、代替ECU30Bから第1の更新処理の処理結果を取得する(ステップS25)。ゲートウェイ10は、対象ECU30Aに第1の更新処理の処理結果を送信して、プロセス#1~#5の残りの更新処理である第2の更新処理を要求する(ステップS4’)。この要求に応じて、対象ECU30Aでは第2の更新処理が実行され(ステップS5’)、制御プログラムが更新される。
本実施の形態にかかるプログラム更新システムの対象ECU30Aでの処理時間D2は、期間T1が期間T2に移行したタイミングt1から対象ECU30AでステップS5’の更新処理が完了するタイミングt3までの時間(t3-t1)となる。実施の形態の制御プログラムの更新シーケンスでは、期間T1のうちの代替ECU30Bにおいて更新処理の一部が実行されるため、対象ECU30Aでの処理時間D2は比較例における対象ECU30Aでの処理時間D1よりも短くできる。
[ゲートウェイの機能構成]
図2を参照して、ゲートウェイ10のCPU11は、更新制御処理を実行するための機能として更新制御部111を含む。更新制御処理は、決定処理を含む。そこで、更新制御部111は、決定処理を実行するための機能として決定部112を含む。これらの機能は、CPU11が記憶部13に記憶されている1つまたは複数のプログラムを読み出して実行することによって、CPU11において実現される機能である。しかしながら、これら機能の少なくとも一部が、電子回路などのハードウェアによって実現されてもよい。
図2を参照して、ゲートウェイ10のCPU11は、更新制御処理を実行するための機能として更新制御部111を含む。更新制御処理は、決定処理を含む。そこで、更新制御部111は、決定処理を実行するための機能として決定部112を含む。これらの機能は、CPU11が記憶部13に記憶されている1つまたは複数のプログラムを読み出して実行することによって、CPU11において実現される機能である。しかしながら、これら機能の少なくとも一部が、電子回路などのハードウェアによって実現されてもよい。
(決定処理)
決定処理は、代替ECUを決定する第1の処理と、当該代替ECUが代替するプロセスを決定する第2の処理と、を含む。決定部112は、第1の処理において、対象ECU以外の非対象装置である複数のECU30のうち、動的な処理能力が所定値以上ある、たとえば、CPU31の使用率が閾値以下であるECU30を代替ECUに決定する。これにより、代替ECUでの過負担を回避できる。
決定処理は、代替ECUを決定する第1の処理と、当該代替ECUが代替するプロセスを決定する第2の処理と、を含む。決定部112は、第1の処理において、対象ECU以外の非対象装置である複数のECU30のうち、動的な処理能力が所定値以上ある、たとえば、CPU31の使用率が閾値以下であるECU30を代替ECUに決定する。これにより、代替ECUでの過負担を回避できる。
第1の処理のために、決定部112は、各ECU30のCPU31の使用率を取得する。一例として、決定部112は、各ECU30に更新処理の可否として、CPU31の使用率を問い合わせる。決定部112は、CAN通信における送信情報のフォーマットであるフレームに問い合わせコマンドを含めた問い合わせ用のフレーム(メッセージ)を生成し、車内通信線14から各ECU30に送信させる。
決定部112は、一例として、複数のECU30のうちのCPU31の使用率が最も低いECU30を代替ECUに決定する。これにより、動的な処理能力が最も大きいECU30が代替ECUとされる。
他の例として、決定部112は、CPU31の使用率が閾値以下の複数のECU30の中から優先度に従って代替ECUに決定する。優先度は、一例として、車載メディアプレイヤーなどの走行に関連しない機能を制御するECUの方が、そうでない機能を制御するECUよりも高く設定されている。代替ECUが更新処理の一部を代替する場合、その更新処理の一部が当該ECUが本来実行する処理に影響を及ぼす可能性がある場合もある。この場合、代替ECUが車両走行に関連する機能を制御するものである場合、車両走行に当該影響が生じるおそれもある。そのため、車両走行に関連する機能を制御するECUを高優先とすることによって、車両走行への当該影響を防止できる。
また、優先度は、他の例として、ゲートウェイ10と対象ECUとを繋ぐ車内通信線16と同一の車載通信線16に接続されたECUの方が、異なる車内通信線16に接続されたECUよりも高く設定されている。具体的には、車内ネットワーク4が図1の構成であって、対象ECUがECU30Aである場合、ECU30Aと同じ車内通信線16Aに接続されているECU30B,30Cの方が、異なる車内通信線16Bに接続されている30D,30Eよりも優先度が高く設定されている。車内通信がCAN通信であって、いわゆるパーシャルネットワークと呼ばれる機能である、各車載通信線16に接続された複数の機器を選択的に起動する機能(いわゆるパーシャルウェイクアップ機能)を有さない場合、1つの車内通信線16でデータを転送すると当該車内通信線16に接続されたすべてのECUが起動する。そのため、対象ECUと異なる車内通信線16に接続されたECU30を代替ECUとすると、当該代替ECUと同一の車内通信線16に接続されたECU30が起動していない場合にも起動させることになるためである。
なお、図6、および後述する図9ならびに図10では、代替ECUが一例としてECU30Bである例が示されている。これは、ECU30D,30Eよりも高優先度であるためにECU30Bが代替ECUに決定されたためとも言える。なお、代替ECU30が優先度の低いECUD,30Eであった場合であっても、これら図で説明された動作と同じ動作が行われる。
決定部112は、車両1に搭載されているすべてのECU30のうちの対象ECU(たとえばECU30A)以外のすべてに問い合わせてもよい。これにより、最適な代替ECUを決定することができる。または、決定部112は、対象ECU以外のECUのうちの優先度の高い(たとえば所定優先度以上の)ECUのみに問い合わせてもよい。これにより、効率的に代替ECUを決定できる。
決定部112は、第2の処理において、更新処理の複数のプロセス(#1~#5)のうちの代替ECUに代替させる1つ以上のプロセスを決定する。そのために、決定部112は、プロセスごとに必要な処理量と、代替ECUの動的な処理能力とを比較する。そして、決定部112は、プロセス#1から順に、処理量が代替ECUの動的な処理能力の規定範囲内であるまでのプロセスを、代替ECUに代替させるプロセスと決定する。
プロセスごとの処理量は更新用プログラムのデータサイズに依存するため、一例として、データサイズと処理量との対応を予め記憶しておくことで、データサイズに基づいて算出することができる。更新用プログラムのデータサイズは、DLサーバ6から取得することができる。
更新制御部111は、代替ECUに第1の更新処理を要求するために、決定したプロセスの実行を要求するコマンドを含んだフレーム(メッセージ)を生成し、車内通信部14に当該フレームを代替ECUに送信させる。
[更新制御処理]
図7は、更新制御処理の具体例を表したフローチャートである。図7のフローチャートに表された処理は、ゲートウェイ10のCPU11が、記憶部13に記憶された1つまたは複数のプログラムをRAM12上に読み出して実行することによって決定部112および更新制御部111の機能を実現することで実行される。図7の処理は、ゲートウェイ10がDLサーバ6から更新用プログラムをダウンロードすると開始される。
図7は、更新制御処理の具体例を表したフローチャートである。図7のフローチャートに表された処理は、ゲートウェイ10のCPU11が、記憶部13に記憶された1つまたは複数のプログラムをRAM12上に読み出して実行することによって決定部112および更新制御部111の機能を実現することで実行される。図7の処理は、ゲートウェイ10がDLサーバ6から更新用プログラムをダウンロードすると開始される。
図7を参照して、CPU11は、当該更新用プログラムを用いて制御プログラムを更新する対象ECU(たとえばECU30A)に状態を問い合わせ、可状態が不可状態かを特定する。対象ECUが可状態である場合には(ステップS101でYES)、CPU11は、対象ECUに更新用プログラムを送信し、更新を要求する(ステップS102)。
対象ECUが不可状態であった場合(ステップS101でNO)、CPU11は決定処理を実行する(ステップS103)。そして、CPU11は、決定した代替ECU(たとえばECU30B)に、更新用プログラムを送信し、当該更新用プログラムを用いた更新処理のうちの決定されたプロセスの処理である第1の更新処理の実行を指示する(ステップS105)。ステップS105でCPU11は、必要なフレームを生成し、車内通信部14に当該フレームを代替ECUに対して送信させる。
CPU11は、その後も、対象ECUの状態を問い合わせる。そして、可状態となると(ステップS107でYES)、CPU11は、代替ECUに対して第1の更新処理の処理結果を要求し、取得した処理結果を対象ECUに送信して残りの更新処理である第2の更新処理を要求する(ステップS109)。ステップS109でCPU11は、必要なフレームを生成し、車内通信部14に当該フレームを代替ECUに対して送信させる。
図8は、図7のステップS103の決定処理の流れを表したフローチャートである。始めに、CPU11は、決定処理の第1の処理(ステップS201~S205)を実行して、代替ECUを決定する。図8を参照して、CPU11は、対象ECU以外の複数のECU30に対して、動的な処理能力(CPU31の使用率)を問い合わせる(ステップS201)。ステップS201でCPU11は、必要なフレームを生成し、車内通信部14に当該フレームを対象ECU以外の複数のECU30対して送信させる。好ましくは、CPU11は、対象ECU以外の複数のECUに対して、予め記憶している優先度に応じて問い合わせる。
ステップS201の問い合わせに対して回答したECU30があった場合(ステップS203でYES)、CPU11は、動的な処理能力を回答したECU30を代替ECUに決定する(ステップS205)。
代替ECUが決定されると、CPU11は、決定処理の第2の処理を実行して、当該代替ECUが代替するプロセスを決定する(ステップS207)。
[第1の実施の形態の効果]
第1の実施の形態にかかるプログラム更新システムでは、ゲートウェイ10がDLサーバ6から更新用プログラムをダウンロードした際に、対象ECUが更新処理が不可状態であった場合に、他のECU30が当該更新用プログラムを受信し、更新処理の少なくとも一部のプロセスを代替する。
第1の実施の形態にかかるプログラム更新システムでは、ゲートウェイ10がDLサーバ6から更新用プログラムをダウンロードした際に、対象ECUが更新処理が不可状態であった場合に、他のECU30が当該更新用プログラムを受信し、更新処理の少なくとも一部のプロセスを代替する。
比較例のプログラム更新システムでは、期間T1が経過し、対象ECUが更新処理が可状態となるまで、ゲートウェイ10が更新用プログラムを保持する。そのため、期間T1が長くなるほどゲートウェイ10のメモリが圧迫される。特に、複数のECU用の複数の更新用プログラムがダウンロードされ、当該複数の対象ECUがいずれも不可状態である場合には、ゲートウェイ10のメモリの圧迫が深刻になる。
これに対して、第1の実施の形態にかかるプログラム更新システムでは、期間T1内ではゲートウェイ10から他のECUに更新用プログラムが送信される。つまり、更新用プログラムが分散して保存される。そのため、ゲートウェイ10でのメモリの圧迫を回避できる。
また、比較例のプログラム更新システムでは、期間T1が期間T2に移行して、対象ECUが可状態となってから更新処理が開始されるため、対象ECUでの処理時間D1が長くなる。その結果、オンライン更新の完了が遅延する。
これに対して、第1の実施の形態にかかるプログラム更新システムでは、期間T1内で代替ECUにおいて更新処理の少なくとも一部(第1の更新処理)が行われる。そして、期間T1の経過後、対象ECUにおいて残りの更新処理(第2の更新処理)が行われる。そのため、対象ECUでの処理時間D2は処理時間D1に比べて短い。その結果、オンライン更新の完了の遅延を抑えることができる。
<変形例1>
なお、図6の例では、対象ECUが可状態となると、ゲートウェイ10が代替ECUでの第1の更新処理の処理結果を取得して対象ECUに送信するものとしている。対象ECUへの処理結果の送信は、この方法に限定されない。ゲートウェイ10は、代替ECUに対して対象ECUに第1の更新処理の処理結果を送信することを指示してもよい。これにより、データ送信を効率化することができる。これは、以降の実施の形態でも同様である。
なお、図6の例では、対象ECUが可状態となると、ゲートウェイ10が代替ECUでの第1の更新処理の処理結果を取得して対象ECUに送信するものとしている。対象ECUへの処理結果の送信は、この方法に限定されない。ゲートウェイ10は、代替ECUに対して対象ECUに第1の更新処理の処理結果を送信することを指示してもよい。これにより、データ送信を効率化することができる。これは、以降の実施の形態でも同様である。
<変形例2>
代替ECUは、複数のECUであってもよい。つまり、決定部112は、決定処理の第1の処理において、CPU31の使用率が閾値以下である複数のECUを代替ECUに決定してもよい。この場合、決定部112は、第2の処理において、複数の代替ECUそれぞれが代替するプロセスを決定する。そして、更新制御部111は、プロセスの順に従って、当該プロセスを代替する代替ECUに、先のプロセスを実行した代替ECUでの処理結果を送信して、処理を要求する。
代替ECUは、複数のECUであってもよい。つまり、決定部112は、決定処理の第1の処理において、CPU31の使用率が閾値以下である複数のECUを代替ECUに決定してもよい。この場合、決定部112は、第2の処理において、複数の代替ECUそれぞれが代替するプロセスを決定する。そして、更新制御部111は、プロセスの順に従って、当該プロセスを代替する代替ECUに、先のプロセスを実行した代替ECUでの処理結果を送信して、処理を要求する。
複数のECUを代替ECUとすることで、代替ECUそれぞれの処理の負担を軽減させることができる。
<第2の実施の形態>
第1の実施の形態にかかるプログラム更新システムでは、ゲートウェイ10が更新制御装置として機能して、上記の更新制御処理を実行する。しかしながら、更新制御装置はゲートウェイ10に限定されない。他の例として、対象ECUが更新制御処理として機能して、自身が更新を制御するための更新制御処理を実行してもよい。この場合、対象ECUのCPU31は、図3に表されたように、更新制御処理を実行するために更新制御部111に相当する更新制御部311を含む。さらに、更新制御部311は、決定部112に相当する決定部312を含む。
第1の実施の形態にかかるプログラム更新システムでは、ゲートウェイ10が更新制御装置として機能して、上記の更新制御処理を実行する。しかしながら、更新制御装置はゲートウェイ10に限定されない。他の例として、対象ECUが更新制御処理として機能して、自身が更新を制御するための更新制御処理を実行してもよい。この場合、対象ECUのCPU31は、図3に表されたように、更新制御処理を実行するために更新制御部111に相当する更新制御部311を含む。さらに、更新制御部311は、決定部112に相当する決定部312を含む。
図9は、第2の実施の形態にかかるプログラム更新システムにおいて実行される、制御プログラムのオンライン更新の流れの一例を示すシーケンス図である。図9において、図6のオンライン更新の流れと同じ動作については、同じステップ番号で表されている。
図9を参照して、第2の実施の形態にかかるプログラム更新システムでは、ゲートウェイ10は、DLサーバ6から更新用プログラムをダウンロードすると(ステップS1)、対象ECUに更新用プログラムを送信して更新を要求する(ステップS1’)。
対象ECUは、受信した更新用プログラムを記憶部33に保存する(ステップS2)。対象ECUは、期間T1において更新制御処理を実行する(ステップS30)。すなわち、第2の実施の形態では、対象ECUが他のECU30に動的な処理能力(CPU31の使用率)を問い合わせ(ステップS31A)、回答を得ると(ステップS31B)、その中から代替ECUを決定する。また、代替ECUに処理を要求するプロセスを決定する。そして、対象ECUは代替ECUに対して更新用プログラムを送信して、第1の更新処理を要求する(ステップS33)。
期間T2となって可状態となると、対象ECUは、代替ECUに第1の更新処理の処理結果を要求し(ステップS37)、処理結果を取得する(ステップS39)。対象ECUは、代替ECUから取得した処理結果を用いて第2の更新処理を実行する(ステップS5’)。
第2の実施の形態にかかるプログラム更新システムでは、対象ECUにおいて、不可状態から可状態になるまで更新用プログラムを記憶しておく場合と比較して、対象ECUでのメモリの圧迫を回避できる。また、第1の実施の形態にかかるプログラム更新システムと同様に対象ECUでの処理時間を短くすることができるため、オンライン更新の完了の遅延を抑えることができる。
<第3の実施の形態>
更新制御装置のさらに他の例として、管理サーバ5が更新制御装置として機能してもよい。このため、第3の実施の形態にかかるプログラム更新システムでは、管理サーバ5のCPU51は、図4に表わされたように、更新制御処理を実行するために更新制御部111に相当する更新制御部511を含む。さらに、更新制御部511は、決定部112に相当する決定部512を含む。
更新制御装置のさらに他の例として、管理サーバ5が更新制御装置として機能してもよい。このため、第3の実施の形態にかかるプログラム更新システムでは、管理サーバ5のCPU51は、図4に表わされたように、更新制御処理を実行するために更新制御部111に相当する更新制御部511を含む。さらに、更新制御部511は、決定部112に相当する決定部512を含む。
図10は、第3の実施の形態にかかるプログラム更新システムにおいて実行される、制御プログラムのオンライン更新の流れの一例を示すシーケンス図である。図10において、図6のオンライン更新の流れと同じ動作については、同じステップ番号で表されている。
図10を参照して、第3の実施の形態にかかるプログラム更新システムでは、ゲートウェイ10は、DLサーバ6から更新用プログラムをダウンロードすると(ステップS1)、第1の実施の形態のオンライン更新と同様に、対象ECUに状態を問い合わせる(ステップS3A)。この問い合わせは、管理サーバ5からの要求に応じて行われてもよい。対象ECUが不可状態である場合(ステップS3B)、ゲートウェイ10は、対象ECUが不可状態であることを管理サーバ5に通知する(ステップS41)。
ゲートウェイ10から通知を受けた管理サーバ5は、更新制御処理を実行する(ステップS30)。管理サーバ5は、ゲートウェイ10に動的な処理能力の問い合わせを要求する(ステップS42)。ゲートウェイ10は、要求に従って対象ECU以外のECUに、動的な処理能力(CPU31の使用率)を問い合わせる(ステップS43A)。そして、回答が得られると、ゲートウェイ10は管理サーバ5に通知する(ステップS44)。
管理サーバ5は、ゲートウェイ10からの通知に基づいて決定処理の第1の処理を実行し、代替ECUを決定する。また、管理サーバ5は、決定処理の第2の処理を実行し、代替ECUに処理を要求するプロセスを決定する。そして、管理サーバ5は、ゲートウェイ10に、当該ECU30を代替ECUとして第1の更新処理を要求することを要求する(ステップS45)。ゲートウェイ10は、要求に従って代替ECUに更新用プログラムを送信して、第1の更新処理を要求する(ステップS46)。
期間T2となって対象ECUから可状態の回答を得ると、ゲートウェイ10は、管理サーバ5に通知する(ステップS48)。この通知を受けた管理サーバ5は、ゲートウェイ10に、対象ECUに第2の更新処理を要求することを要求する(ステップS45)。ゲートウェイ10は、管理サーバ5の要求に従って代替ECUに処理結果を要求し(ステップS50)、代替ECUから処理結果を取得する(ステップS51)。ゲートウェイ10は、対象ECUに当該処理結果を送信して、第2の更新処理を要求する(ステップS4’)。これにより、対象ECUにおいて、第2の更新処理が実行される(ステップS5’)。
第3の実施の形態にかかるプログラム更新システムでも、比較例のオンライン更新と比較して、ゲートウェイ10でのメモリの圧迫を回避できる。また、第1の実施の形態にかかるプログラム更新システムと同様に対象ECUでの処理時間を短くすることができるため、オンライン更新の完了の遅延を抑えることができる。
開示された特徴は、1つ以上のモジュールによって実現される。たとえば、当該特徴は、回路素子その他のハードウェアモジュールによって、当該特徴を実現する処理を規定したソフトウェアモジュールによって、または、ハードウェアモジュールとソフトウェアモジュールとの組み合わせによって実現され得る。
上述の動作をコンピュータに実行させるための、1つ以上のソフトウェアモジュールの組み合わせであるプログラムとして提供することもできる。このようなプログラムは、コンピュータに付属するフレキシブルディスク、CD-ROM(Compact Disk-Read Only Memory)、ROM、RAMおよびメモリカードなどのコンピュータ読取り可能な記録媒体にて記録させて、プログラム製品として提供することもできる。あるいは、コンピュータに内蔵するハードディスクなどの記録媒体にて記録させて、プログラムを提供することもできる。また、ネットワークを介したダウンロードによって、プログラムを提供することもできる。
なお、本開示にかかるプログラムは、コンピュータのオペレーティングシステム(OS)の一部として提供されるプログラムモジュールのうち、必要なモジュールを所定の配列で所定のタイミングで呼出して処理を実行させるものであってもよい。その場合、プログラム自体には上記モジュールが含まれずOSと協働して処理が実行される。このようなモジュールを含まないプログラムも、本開示にかかるプログラムに含まれ得る。
また、本開示にかかるプログラムは他のプログラムの一部に組込まれて提供されるものであってもよい。その場合にも、プログラム自体には上記他のプログラムに含まれるモジュールが含まれず、他のプログラムと協働して処理が実行される。このような他のプログラムに組込まれたプログラムも、本開示にかかるプログラムに含まれ得る。提供されるプログラム製品は、ハードディスクなどのプログラム格納部にインストールされて実行される。なお、プログラム製品は、プログラム自体と、プログラムが記録された記録媒体とを含む。
今回開示された実施の形態はすべての点で例示であって制限的なものではないと考えられるべきである。本発明の範囲は上記した説明ではなくて請求の範囲によって示され、請求の範囲と均等の意味および範囲内でのすべての変更が含まれることが意図される。
1 車両
2 広域通信網
4 車内ネットワーク
5 管理サーバ
6 DLサーバ
10 ゲートウェイ
11 CPU
12 RAM
13 記憶部
14 車内通信部
15 無線通信部
16,16A,16B 車内通信線
30 ECU
31 CPU
32 RAM
33 記憶部
34 通信部
35 起動部
51 CPU
52 ROM
53 RAM
54 記憶部
55 通信部
111 更新制御部
112 決定部
311 更新制御部
312 決定部
511 更新制御部
512 決定部
2 広域通信網
4 車内ネットワーク
5 管理サーバ
6 DLサーバ
10 ゲートウェイ
11 CPU
12 RAM
13 記憶部
14 車内通信部
15 無線通信部
16,16A,16B 車内通信線
30 ECU
31 CPU
32 RAM
33 記憶部
34 通信部
35 起動部
51 CPU
52 ROM
53 RAM
54 記憶部
55 通信部
111 更新制御部
112 決定部
311 更新制御部
312 決定部
511 更新制御部
512 決定部
Claims (10)
- 車載制御装置と車内通信線を含む伝送路を介して通信する通信部と、
下記の対象装置が制御プログラムの更新処理を実行できない場合に、下記の非対象装置である代替装置に前記更新処理の一部の代替を要求する要求メッセージを、前記通信部に送信させる制御部と、を備える、更新制御装置。
対象装置:制御プログラムの更新対象である車載制御装置
非対象装置:制御プログラムの更新対象ではない車載制御装置 - 前記制御部は、
前記代替の可否を問い合わせる前記非対象装置宛の問い合わせメッセージを前記通信部に送信させ、前記非対象装置からの応答メッセージの内容に応じて、前記非対象装置を前記代替装置とするか否かを決定する、請求項1に記載の更新制御装置。 - 前記制御部は、
複数の前記非対象装置に、優先度に従って前記代替の可否を問い合わせる、請求項2に記載の更新制御装置。 - 前記制御部は、
動的な処理能力が所定値以上であることを含む前記応答メッセージを受信した場合は、当該応答メッセージの送信元の前記非対象装置を前記代替装置と決定する、請求項2または3に記載の更新制御装置。 - 前記制御部は、
前記応答メッセージの送信元の複数の前記非対象装置から優先度に従って前記代替装置を決定する、請求項4に記載の更新制御装置。 - 前記通信部に複数の前記車内通信線が終端し、かつ、前記通信部が前記車内通信線に接続された機器を選択的に起動する機能を有しない場合は、前記制御部は、
前記対象装置と同じ前記車内通信線に繋がる前記非対象装置を、前記対象装置と異なる前記車内通信線に繋がる前記非対象装置よりも高優先とする、請求項2~請求項5のいずれか一項に記載の更新制御装置。 - 前記制御部は、車両走行に無関係な制御機能を担う前記非対象装置を、その他の機能を担う前記非対象装置よりも高優先とする、請求項2~請求項6のいずれか一項に記載の更新制御装置。
- 前記更新処理は複数のプロセスを含み、
前記制御部は、前記複数のプロセスのうちの前記代替装置に代替を要求するプロセスを決定する、請求項1~請求項7のいずれか一項に記載の更新制御装置。 - 車載制御装置と車内通信線を含む伝送路を介して通信する更新制御装置での制御方法であって、
下記の対象装置が制御プログラムの更新処理を実行できない場合に、下記の非対象装置である代替装置に前記更新処理の一部の代替を要求する要求メッセージを送信するステップを備える、制御方法。
対象装置:制御プログラムの更新対象である車載制御装置
非対象装置:制御プログラムの更新対象ではない車載制御装置 - 車載制御装置と車内通信線を含む伝送路を介して通信する更新制御装置としてコンピュータを機能させるためのコンピュータプログラムであって、
前記コンピュータを、
車載制御装置と車内通信線を含む伝送路を介して通信する通信部と、
下記の対象装置が制御プログラムの更新処理を実行できない場合に、下記の非対象装置である代替装置に前記更新処理の一部の代替を要求する要求メッセージを、前記通信部に送信させる制御部と、として機能させる、コンピュータプログラム。
対象装置:制御プログラムの更新対象である車載制御装置
非対象装置:制御プログラムの更新対象ではない車載制御装置
Priority Applications (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US16/614,920 US11537382B2 (en) | 2017-06-13 | 2018-03-26 | Updating control device, control method, and computer program |
JP2019525106A JP7207301B2 (ja) | 2017-06-13 | 2018-03-26 | 更新制御装置、制御方法、およびコンピュータプログラム |
CN201880039525.2A CN110753906B (zh) | 2017-06-13 | 2018-03-26 | 更新控制装置、控制方法以及计算机程序 |
DE112018002998.0T DE112018002998T5 (de) | 2017-06-13 | 2018-03-26 | Aktualisierungssteuervorrichtung, Steuerverfahren und Computerprogramm |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2017-116109 | 2017-06-13 | ||
JP2017116109 | 2017-06-13 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2018230084A1 true WO2018230084A1 (ja) | 2018-12-20 |
Family
ID=64660101
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/JP2018/012073 WO2018230084A1 (ja) | 2017-06-13 | 2018-03-26 | 更新制御装置、制御方法、およびコンピュータプログラム |
Country Status (5)
Country | Link |
---|---|
US (1) | US11537382B2 (ja) |
JP (1) | JP7207301B2 (ja) |
CN (1) | CN110753906B (ja) |
DE (1) | DE112018002998T5 (ja) |
WO (1) | WO2018230084A1 (ja) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2020140636A (ja) * | 2019-03-01 | 2020-09-03 | 株式会社デンソー | アプリケーションサーバ装置及び電子制御装置 |
CN112882742A (zh) * | 2019-11-30 | 2021-06-01 | 华为技术有限公司 | 软件更新方法以及相关设备 |
WO2021181828A1 (ja) * | 2020-03-10 | 2021-09-16 | 日立Astemo株式会社 | 車両制御装置及び車両制御システム |
WO2023171307A1 (ja) * | 2022-03-09 | 2023-09-14 | 株式会社オートネットワーク技術研究所 | 車載装置、プログラム、及びプログラムの更新方法 |
Families Citing this family (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP7042417B2 (ja) * | 2018-09-03 | 2022-03-28 | 株式会社オートネットワーク技術研究所 | 通信装置、送信方法及びコンピュータプログラム |
US20220283798A1 (en) * | 2019-08-06 | 2022-09-08 | Nec Corporation | Mobility control system, method, and program |
JP7419992B2 (ja) * | 2020-07-02 | 2024-01-23 | トヨタ自動車株式会社 | ソフトウェア更新装置、方法、プログラムおよび車両 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2015212880A (ja) * | 2014-05-02 | 2015-11-26 | キヤノン株式会社 | 情報処理装置及びその制御方法、並びにプログラム |
WO2016047312A1 (ja) * | 2014-09-26 | 2016-03-31 | 日立オートモティブシステムズ株式会社 | 車両制御装置、リプログラミングシステム |
Family Cites Families (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8713551B2 (en) * | 2006-01-03 | 2014-04-29 | International Business Machines Corporation | Apparatus, system, and method for non-interruptively updating firmware on a redundant hardware controller |
JP2010218070A (ja) * | 2009-03-16 | 2010-09-30 | Toyota Motor Corp | 管理装置 |
US20100318666A1 (en) * | 2009-06-10 | 2010-12-16 | International Business Machines Corporation | Expediting adapter failover |
US20150363210A1 (en) * | 2014-06-12 | 2015-12-17 | Ford Global Technologies, Llc | Vehicle download by remote mobile device |
JP5997740B2 (ja) | 2014-09-17 | 2016-09-28 | クラリオン株式会社 | 車載機のオンライン更新方法 |
US9529580B2 (en) * | 2015-01-21 | 2016-12-27 | Ford Global Technologies, Llc | Vehicle control update methods and systems |
JP6675271B2 (ja) | 2015-09-14 | 2020-04-01 | パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカPanasonic Intellectual Property Corporation of America | ゲートウェイ装置、車載ネットワークシステム及びファームウェア更新方法 |
JP6678548B2 (ja) | 2015-11-13 | 2020-04-08 | 株式会社東芝 | 中継装置、中継方法およびプログラム |
US10228930B2 (en) * | 2016-01-28 | 2019-03-12 | Microsoft Technology Licensing, Llc | Offloading network connectivity and execution tasks to an assistant device |
JP6417348B2 (ja) * | 2016-03-07 | 2018-11-07 | 日立建機株式会社 | 建設機械のプログラム書換え装置 |
US10140116B2 (en) * | 2016-09-26 | 2018-11-27 | Ford Global Technologies, Llc | In-vehicle auxiliary memory storage |
-
2018
- 2018-03-26 DE DE112018002998.0T patent/DE112018002998T5/de active Pending
- 2018-03-26 WO PCT/JP2018/012073 patent/WO2018230084A1/ja active Application Filing
- 2018-03-26 JP JP2019525106A patent/JP7207301B2/ja active Active
- 2018-03-26 US US16/614,920 patent/US11537382B2/en active Active
- 2018-03-26 CN CN201880039525.2A patent/CN110753906B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2015212880A (ja) * | 2014-05-02 | 2015-11-26 | キヤノン株式会社 | 情報処理装置及びその制御方法、並びにプログラム |
WO2016047312A1 (ja) * | 2014-09-26 | 2016-03-31 | 日立オートモティブシステムズ株式会社 | 車両制御装置、リプログラミングシステム |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2020140636A (ja) * | 2019-03-01 | 2020-09-03 | 株式会社デンソー | アプリケーションサーバ装置及び電子制御装置 |
CN112882742A (zh) * | 2019-11-30 | 2021-06-01 | 华为技术有限公司 | 软件更新方法以及相关设备 |
WO2021181828A1 (ja) * | 2020-03-10 | 2021-09-16 | 日立Astemo株式会社 | 車両制御装置及び車両制御システム |
JPWO2021181828A1 (ja) * | 2020-03-10 | 2021-09-16 | ||
JP7320126B2 (ja) | 2020-03-10 | 2023-08-02 | 日立Astemo株式会社 | 車両制御装置及び車両制御システム |
WO2023171307A1 (ja) * | 2022-03-09 | 2023-09-14 | 株式会社オートネットワーク技術研究所 | 車載装置、プログラム、及びプログラムの更新方法 |
Also Published As
Publication number | Publication date |
---|---|
US11537382B2 (en) | 2022-12-27 |
CN110753906B (zh) | 2023-08-08 |
CN110753906A (zh) | 2020-02-04 |
DE112018002998T5 (de) | 2020-02-20 |
US20200192656A1 (en) | 2020-06-18 |
JP7207301B2 (ja) | 2023-01-18 |
JPWO2018230084A1 (ja) | 2020-04-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
WO2018230084A1 (ja) | 更新制御装置、制御方法、およびコンピュータプログラム | |
JP6376312B1 (ja) | 制御装置、プログラム更新方法、およびコンピュータプログラム | |
JP6620891B2 (ja) | 中継装置、中継方法、およびコンピュータプログラム | |
JP6525105B2 (ja) | 制御装置、プログラム更新方法、およびコンピュータプログラム | |
US11704104B2 (en) | Control apparatus, control method, and computer program | |
JP6525109B2 (ja) | 制御装置、転送方法、およびコンピュータプログラム | |
US20200133812A1 (en) | Control apparatus, control method, and computer program | |
WO2019202965A1 (ja) | 車載更新装置、車載更新システム、更新処理方法及び更新処理プログラム | |
JP6465258B1 (ja) | 制御装置、制御方法、およびコンピュータプログラム | |
CN111051139B (zh) | 控制设备、控制方法和计算机程序 | |
WO2018154949A1 (ja) | プログラム更新システム、制御装置、プログラム更新方法、及びコンピュータプログラム | |
WO2018142749A1 (ja) | 制御装置、プログラム更新方法、およびコンピュータプログラム | |
CN115454462A (zh) | Ota管理器、系统、方法、非暂时性存储介质以及车辆 | |
CN115514742A (zh) | Ota管理器、中心、系统、方法、非暂时性存储介质 | |
JP2022041194A (ja) | 車載機器、情報生成方法、情報生成プログラム、および、車両 | |
CN115248695A (zh) | 中心、ota管理器、分发方法、非暂时性存储介质 | |
CN115509567A (zh) | 中心、ota管理器、系统、方法、非暂时性存储介质 | |
JP2023001993A (ja) | Otaマスタ、システム、方法、プログラム、及び車両 | |
CN114968316A (zh) | Ota管理器、中心、更新方法、非暂时性存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 18817487 Country of ref document: EP Kind code of ref document: A1 |
|
ENP | Entry into the national phase |
Ref document number: 2019525106 Country of ref document: JP Kind code of ref document: A |
|
122 | Ep: pct application non-entry in european phase |
Ref document number: 18817487 Country of ref document: EP Kind code of ref document: A1 |