1. Field of the Invention
The present invention relates to a method for permanently loading calibration data into a flash memory for electronic control of an engine. More specifically, the present invention allows a user the ability to immediately assess engine performance when new calibration data has been loaded into an engine electronic control unit. Additionally, the method provides for a permanent means of storing the new calibration data from RAM into flash memory by monitoring vehicle level inputs signals.
2. Description of the Related Art
Modern day fuel injected fuel engines are controlled by an electronic control unit (ECU). The ECU is a computer that executes a program which controls various engine outputs in response to vehicle level input signals. The ECU contains a microcontroller which further comprises of a memory and a plurality of input or output pins. The memory is placed either external or internal to the microcontroller. The memory is connected to the microcontroller through address or data buses where data is communicated between the microcontroller and memory. The number of input or output pins located on the ECU depends on the vehicle line or engine type involved. The input and output pins are connected to various key components related to the operation of the engine and comprises of either analog or digital signals.
The main software control program or executable code is stored in a fixed memory device and typically consists of one of the following types; a UV erasable programmable read only memory (EPROM), a read only memory (ROM), an electrically erasable programmable read only memory (EEPROM), and more recently the use of a flash memory. The fixed memory devices are non-volatile meaning that the data stored is not lost when power is removed from the ECU. Depending on the fixed memory type used, a fixed memory device can be reprogrammed to accept a new software control program. A temporary memory location such as a random access memory (RAM) is used to store dynamic variables and for performing calculations. RAM is volatile, meaning it loses its data when power is removed from the engine ECU.
The prior trend in ECU's designs was to use EEPROM's for storing engine calibration data. The calibration data comprises of data used to control emissions, engine performance, drivability and fuel consumption. The EEPROM was preferred because it could be erased and reprogrammed byte wide many times. If a single calibration needs to be changed, it can be erased and reprogrammed without erasing and reprogramming the entire memory.
Typically, when erasing and reprogramming the EEPROM, the main software control program executes a subroutine located within the program that would erase the contents in the EEPROM in a background loop while the engine was running. While in the reprogramming mode, access to the EEPROM was prohibited, as a result, a user reprogramming the EEPROM would have to wait for the reprogramming procedure to terminate. Once the reprogramming procedure was complete, the main software control program was allowed to access the EEPROM again and only then could the user assess the impact of the new calibration data with respect to engine functionality. The problem with erasing and reprogramming the EEPROM was that the process slow and it increased development time. Additionally, the costs of using EEPROM's were becoming prohibitive when compared to the cheaper costs associated with using flash memory. With flash memory, memory storage capability is increased dramatically. It is no longer unheard of for a programmer to find a microcontroller having a flash memory which allows for data storage in excess of eight megabytes. Likewise, RAM packaged with microcontrollers which are equipped with flash memory will allow for data storage of up to several kilobytes of data if needed.
Although the use of flash memory in engine ECU's provides commercial benefits in addition to increased data storage capacity, there are some drawbacks. The problem with flash memory, particularly for flash memory packaged external to the microcontroller, is that a single value located in the calibration data cannot be erased and reprogrammed one byte at a time. If flash memory is used, the entire memory sector has to be first erased then reprogrammed. As a result, a user would have to wait for the erase/reprogram operation to be completed. This delay prevents the user from immediately assessing engine performance when new changes are made to calibration data.
The objective of the present invention is to capitalize on the benefits associated with using flash memory on engine ECU's and to also provide the user with the capability of immediately assessing engine performance when a new calibration data has been downloaded into an ECU.
The objective of the present invention is to allow a user to instantaneously assess engine performance when new calibration data is downloaded into an engine ECU. The engine ECU comprises of two memory storage devices. The first memory storage device is the flash memory or main memory, and it includes both a main software control program and calibration data. The main software control program and calibration data are stored in a plurality of sectors disposed within memory locations in the flash memory. The second memory storage device is RAM, which serves as a temporary memory location and it is utilized to store temporary data. On engine startup, the ECU runs an initialization routine and sends the calibration data to RAM where the calibration data interfaces with the main software control program. By interfacing the calibration data with the main software control program, the engine ECU is able to monitor and operate various functions related to the engine.
New calibration data can be inserted into the engine ECU through the use of an external device which is compatible with the ECU for sending calibration data. Generally, a personal computer is used to send the calibration data, however various types of hand held diagnostic tools may be used for sending new calibration data. An RS-232 serial communications link is connected between the personal computer and the engine ECU. The user modifies the calibration data through a user interface on a personal computer where the data is sent to the engine ECU. The new calibration data is uploaded into the RAM of the engine ECU where it interfaces with the main software control program and immediately allows the user to monitor the impact of the new calibration data with respect to engine control. Once the desired function or desired engine control is achieved, the next step is to permanently store the new calibration data in the flash memory. The ECU monitors the ignition line input to detect a specific voltage range. Once the corresponding voltage has been detected by the ECU, an erase/reprogram subroutine which was part of the main software control program is uploaded from flash memory into RAM. After uploading the erase/reprogram subroutine into RAM, the erase/reprogram subroutine is executed from RAM where it erases the previously stored calibration data and reprograms the new calibration data into the corresponding sectors of the flash memory. The motivation for utilizing the erase/reprogram subroutine is to compensate for the limitations associated with using external flash. Primarily, the limitation of not being able to execute code out of one sector when data in another sector is being replaced and reprogrammed with new data.
The present method allows a user to continuously modify the calibration data until the desired engine control is achieved without having to wait for a permanent download of the new calibration data into the flash memory. The invention as described provides a significant advantage for users because of the flexibility offered in modifying calibration data. It allows users to make changes in a shorter amount of time which reduces overall development time. Additionally, the present invention requires less software overhead, eliminates additional components and requires no special memory to execute.
Other advantages of the present invention will be readily appreciated as the same becomes better understood by reference to the following detailed description when considered in connection with the accompanying drawings wherein:
Referring to
The engine ECU 10 has the capability of receiving new calibration data from an external device or personal computer (PC) 18. A user can upload new calibration data from the personal computer 18 into the engine ECU 10 for modifying or varying various engine ECU controls. The new calibration data is sent from the PC 18 to the engine ECU 10 via a communication link 20 or more specifically a RS-232 serial connection. The PC 18 and the engine ECU 10 share a common protocol which is designed to allow the new calibration data to be sent from the PC 18 and received by the engine ECU 10. In first updating the calibration data in the PC 18, the user would input the desired value or set of values in a calibration table. The PC 18 sends and encodes a sequence of bytes which correspond to the new calibration data. The engine ECU 10 receives and then decodes the encoded data.
Referring to
Although
Referring to
In step 104, the main software control program stored in flash memory would interface with the calibration data stored in RAM for controlling the engine. In step 106, if new calibration data was sent from an external device or PC 18, the method would move onto step 108 where the new calibration data would be stored in RAM 30. If the new calibration data was not sent from an external device 18, the method would stay in step 104 where the main software control program in the flash memory would continue to interface with the calibration data initially stored in RAM 30.
In step 110, the main software control program in the flash memory interfaces with the new calibration data stored in the RAM 30 for operating the engine in accordance with the new parameters as set forth by the user. The next step is to permanently store the new calibration data into the flash memory. In step 112, the engine ECU continuously polls the ignition input line to check engine status. If the engine remains running, the main software control program will continue to interface with the new calibration data stored in RAM. If on the other hand, while polling the ignition level input, a voltage of 5 volts or less is detected by the engine ECU 10, the method moves to step 114. After a voltage of 5 volts or less is detected by the engine ECU 10, the erase/reprogram subroutine that is currently stored in the flash memory, is uploaded into RAM and then executed for permanently downloading new calibration data into the flash memory.
By executing the erase/reprogram program, the old calibration data is erased and the new calibration data is stored into sector (SA3) 36 in the first memory location 40 and sector (SA3) 37 in the second memory location 42. After step 114 is complete, the method returns to step 100 where the engine ECU remains in sleep mode until a voltage level of greater than 5 volts is detected again by the engine ECU 10. The method allows for reprogramming new calibration data into flash memory an infinite amount of times.
Obviously, many modifications and variations of the present invention are possible in light of the above teachings. The invention may be practiced otherwise than as specifically within the scope of the appended claims.
This application claims the benefit of U.S. Provisional Application No. 60/476,789, filed Jun. 6, 2003.
Number | Name | Date | Kind |
---|---|---|---|
5091858 | Paielli | Feb 1992 | A |
5697339 | Esposito | Dec 1997 | A |
5835706 | Hikichi et al. | Nov 1998 | A |
6127947 | Uchida et al. | Oct 2000 | A |
6138059 | Ozeki et al. | Oct 2000 | A |
6144887 | Kamiya et al. | Nov 2000 | A |
6272587 | Irons | Aug 2001 | B1 |
6430716 | Hiramatsu | Aug 2002 | B1 |
6535811 | Rowland et al. | Mar 2003 | B1 |
6643572 | Kohge et al. | Nov 2003 | B2 |
Number | Date | Country | |
---|---|---|---|
20040249558 A1 | Dec 2004 | US |
Number | Date | Country | |
---|---|---|---|
60476789 | Jun 2003 | US |