The present invention relates to an in-vehicle electronic control device, control software and a development tool for the control software. In particular, the present invention relates to a method of combining software components.
A micro-controller including a CPU (Central Processing Unit), a ROM, a RAM, an input/output signal processing unit, etc. is used as a control device for automobile engine control, etc. Software installed in the micro-controller generally includes an application program for executing a control process, device drivers for executing input/output, an operating system (OS), etc. so that the target of the control can perform intended control operations.
Meanwhile, with the enlargement in the scale of software in recent years, it has become difficult to totally develop all of the application programs and device control programs (executing input/output) for each individual control system. Therefore, various techniques such as designing each piece of software as a small unit (component) and thereafter reusing already-developed components, hierarchizing the components and thereby localizing (limiting) the software's part that needs to be changed, etc. are employed today. In a technique employed recently, such software components are accumulated as assets and software development of an electronic system is conducted by combining appropriate software components in accordance with the configuration of the network of the electronic system as the target of the development (see Patent Literature 1, for example).
In a method commonly employed for improving efficiency of the development of control systems, software's part that needs to be changed according to the configurations of the micro-controller (in which the software is installed), sensor (used by the software), actuator (used by the software), etc. is localized (limited) by segmenting the software into a basic software layer and a control application layer. The basic software layer is a layer for absorbing the difference in the hardware and the network configuration. The control application layer is a layer for executing logical processes relating to the control (see Patent Literature 2, for example). By further segmenting the basic software layer into components corresponding to elements (micro-controller, network, storage device, etc.), further localization is made possible, as well as promoting the reuse of already-existing software in units of components and parallel software development by multiple developers.
It is also possible in the above configuration to define interfaces between components, let developers share information on the interfaces for development of software components, and link the software components supplied by the developers in an object format in the phase of system integration (see Non-Patent Literature 1, for example). With this technique, the development of a control system can be conducted while avoiding disclosure of source codes (design assets of the developers) and handling the source codes as black boxes. This enables cooperative development by multiple independent enterprising bodies based on the division of labor. In another technique, parameters are set in control software based on information inputted by the user (see Non-Patent Literature 2, for example).
However, in the case where the source codes are not disclosed in the development of such software (having the above configuration) by integrating the accomplishments of separate enterprising bodies, difficulties arise in debugging, maintenance and performance measurement. For example, while failure analysis of ordinary software is conducted by successively verifying the validity of data between software components in the order of the data flow, it is impossible to acquire internal information on parts whose design information has not been disclosed. Further, while measurement of processing time of each individual component is necessary in performance analysis, timing analysis, etc., it is difficult to analyze the execution time, etc. of a black-boxed component. Furthermore, in the development of each individual software component, changing data or timing (that will be necessary in the stage of integration into the entire software) at each product development results in the need of changing/checking all the software components. This is incompatible with the improvement of development efficiency through the reuse of the software components. Moreover, total disclosure of data and timing having the possibility to be used (which leads to disclosure of information on the software design of each enterprising body) poses an obstacle to the cooperative development by multiple independent enterprising bodies while maintaining their design assets.
In addition, in the middle of the attempt to standardize the in-vehicle software, the degree of conformance to the standardization varies depending on the customer, product, etc. Thus, in order to achieve high development efficiency, it is necessary in the phase of combining software assets of separate enterprising bodies to flexibly switch the degree of conformance to the standardization and the method of connecting (combining) the software components well adapting to the requests of the customer.
As above, in the development of software hierarchized and segmented into components, it is difficult to freely combine and reuse software assets. It is therefore an object of the present invention to provide means capable of effectively selecting the method of combining software assets.
In order to resolve the above problem, in an in-vehicle electronic control device in accordance with the present invention comprising a basic software unit for executing input/output from/to in-vehicle instruments, the basic software unit includes a plurality of processing units and a template interface unit having a template retaining input/output relationship among the processing units.
With the present invention, effective selection of the method of combining software assets is facilitated in the phase of system integration of the software assets.
Referring now to the drawings, a description will be given in detail of preferred embodiments in accordance with the present invention.
Various types of sensors 211 are connected to the control unit 201 via a signal input circuit 213. Meanwhile, an actuator 212 is connected to the control unit 201 via a drive circuit 210. These components are controlled by the control unit 201. The control is carried out by the CPU etc. by reading/writing data from/to registers of the input/output port.
Software describing methods of vehicle control is installed in storage means (ROM 206, RAM 205, etc.) of the control unit and executed by the CPU 204 so that intended control is performed. While the CPU, RAM and ROM are installed in the micro-controller in this example, implementation of the present invention is not restricted to this example. For example, the CPU, RAM and ROM in the control unit may also be implemented by separate IC chips.
In the present invention, software shown in
In conventional software configurations, the connection between processing units (combination of processing units) is described in each standard interface unit (standard I/F). Since the standard I/F is disclosed to other companies and becomes accessible as a part of the basic software, it is difficult to selectively leave out or alter a part of the interface. Therefore, it has been difficult to flexibly change the input/output relationship among processing units adapting to the design change of the software. In the present invention, flexible selection of the method of combining software components is made possible by using template description for the input/output relationship among processing units.
Here, an example of the hardware of the in-vehicle electronic control device and the flow of the process and data of the software is shown in
The control software 101 installed in the storage means of the micro-controller first calculates a throttle angle 414, an intake pipe pressure 415, an intake air flow 416 and an engine rotational position 417 (as input data having logical meanings corresponding to physical values) through a sensor reading correction process 412 and a pulse input process 413. Based on the calculated input data, the control software 101 calculates output values through a control application 418 (ignition control 419, fuel injection control 420), drives the timer/pulse control circuit 405 (hardware) by using the output values through a pulse output process 421, and thereby outputs the spark plug driving pulses 410 and the fuel injector driving pulses 411 as final outputs.
Multiple pieces of application software for controlling an inlet pipe pressure physical value calculation application 502, an inlet flow physical value calculation application 503 and a fuel injection quantity calculation application 504, respectively, are connected together in a connection layer 509 by the software 501. Input signals from the hardware are also connected to the connection layer 509. The input from the hardware is taken in by an A/D converter control driver 508. The values taken in are separated by a signal control unit into individual A/D conversion results of separate channels. The A/D conversion results of the channels undergo filter processes (#1) 505 and (#2) 506, respectively, for removing noise in the input signals and blocking abnormal values. The results of the filter processes 505 and 506 are supplied to the physical value calculation applications 502 and 503, respectively.
In the aforementioned fuel injection quantity calculation application 504, measurement time errors in the input values 502 and 503 as the base of the control calculation have nonnegligible effects on the quality of the control from the viewpoints of fuel consumption efficiency (mileage), etc. Control calculations like those by the fuel injection quantity calculation application 504 are carried out according to a particular sampling period (fixed time constant), on the assumption that the input values are taken in at fixed periods. However, since each control system installed in the control controller utilizes the limited calculation resources of the mounted CPU by scheduling processes, the calculation applications (which are scheduled and executed according to their priority orders) are not necessarily capable of carrying out their processes with desired timing. Therefore, it is necessary in the verification, inspection, etc. (hereinafter referred to as “verification”) of the system to confirm whether each of the control calculation values (as final output values) is outputted as a correct value within a desired accuracy range or not by measuring/checking the relationship between the time error and the control calculation output in the system.
Here, an embodiment of the present invention, as a configuration enabling the measurement of the aforementioned periodic time error, is shown in
An example of interface description of a software component employing the template description explained referring to
A template processing unit 1003 properly embeds various parameters set by the developer in the software by using a velocity compiler as an internal or external command. Here, the various parameters include various set values in regard to the vehicle control (braking force, ignition timing of the engine, etc.). Software components 1004 in the C language obtained as above are converted by a compiler processing unit 1005 into software components 1006 in an object format. By use of the software components 1006 in the object format, an implementation file 1008 of the control software to be written to the actual in-vehicle electronic control device is created by a linker processing unit 1007. As above, according to this embodiment, the control software can be created by properly selecting and combining previously-developed software components based on information set by the user.
In this example, “PA03” (line 1204) in
As above, according to this embodiment, by just rewriting the template I/F of the basic software based on the setting information inputted by the user, the input/output relationship among the layers can be selected automatically, as well as providing the means for maintenance and verification while reducing the rewriting of the body of the source code. Therefore, the disclosure of a software component while keeping its source code body as a black box is facilitated by this embodiment.
While the selection of sensors and the insertion of the observation point have been taken as examples of the contents of the setting information 1001 inputted in this embodiment, the setting information 1001 is not restricted to these examples; any kind of information useful for the combination of software components may be inputted as the setting information 1001. For example, conformance class information requested by customers or other companies (in cooperative relationship based on the division of labor) may be inputted as the setting information 1001. The “conformance class” represents the degree of conformance to standardization which is defined in standard specifications issued in the standardization of software. The contents of a software asset disclosed by each company (cooperating for development based on the division of labor) and the scale of a software asset to be black-boxed vary according to the conformance class. While software assets disclosed by each company increase with the increase in the degree of conformance to the standardization, measurement of intermediate data and timing in black-boxed software becomes more and more important from the viewpoints of performance verification, maintenance, etc. Also from the viewpoints of the overheads and software performance, the progress of standardization is making it difficult to carry out the combination of layers and the arrangement of software components with flexibility.
Therefore, incorporating the know-how of each company into the software being developed by cooperating companies while black-boxing the know-how according to the degree of conformance to the standardization becomes extremely important in terms of the profit and the securement of technology of each company. By selecting the method of combining software layers and software components by changing the template description according to the conformance class in this embodiment, the effects of software development by the division of labor (among cooperating companies, etc.) can be enhanced with the capability for inserting an appropriate observation point in a black-boxed part (whose scale changes depending on the degree of conformance to the standardization), flexibly integrating software components, etc.
As described above, by the present invention, flexible design changes are made possible through the selection of the input/output relationship among the layers in the basic software by use of the template description. In the integration of software assets into a system, it becomes possible to flexibly change/switch the output of information necessary for the verification and performance measurement while reducing the disclosure of the source code (detailed design of each individual software module). This facilitates the maintenance, verification and performance measurement in the phase of system integration, making it possible to reduce the number of verification steps in the software development based on the division of labor. Therefore, the segmentation of software into components, the reuse of already-developed software and the cooperation of multiple enterprising bodies can be promoted.
The method of combining components can differ in the performance, program size, etc. according to the method of implementation (implementation as a function call in the C language, implementation by embedding the process body in the caller, implementation leaving unnecessary interfaces behind, etc.), functions used between the components, and the number of such functions. Such a method can vary widely, greatly reflecting the knowledge, findings, etc. of the developer. However, since it is possible as in the above embodiment to effectively select the method of combining software components by just rewriting the template I/F by use of a development tool supporting the control software, the effect of the developer's knowledge, findings, etc. on the degree of perfection of the control software can be reduced significantly.
Further, development costs of vehicle control software are showing a notable tendency to rise in recent years with the rapid progress of electronic control in terms of safety, fuel saving performance, comfortability, etc. Each enterprising body has independently developed even the basic software as its own software asset and that has been a cause of the cost rise. The present invention serves for the progress of standardization (through the promotion of the division of labor), the enhancement of development efficiency and the reduction of specification changes necessary for adaptation to each vehicle (in which the software is installed), while also contributing to the reduction of production costs of automobiles, etc.
Number | Date | Country | Kind |
---|---|---|---|
2009-083998 | Mar 2009 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2010/051448 | 2/2/2010 | WO | 00 | 11/14/2011 |