The present invention is drawn to a method for recovering control of a continually resetting control module.
Occasionally, a control module hardware or software failure occurs that causes the processor to continually reset. During a continual reset the boot program executes a startup command and thereafter transfers control to an application program, then an event causes the processor to reset which transfers control back to the boot program such that the sequence continually repeats. This sequence of events is difficult to stop, and since it is a very rapid cycle, the control module cannot communicate with an external tool to allow diagnosis of the issue and/or reprogramming of the problem area. This problem is particularly difficult to diagnose in sealed control modules or control modules that are inaccessible such as those mounted inside an engine or transmission.
According to a preferred embodiment of the present invention, control of a continually resetting control module is recovered by monitoring the communication links for a very short period each time the boot program starts and before control is passed to the application program. If a unique recovery message is received within the time period, then the boot program continues monitoring communications for an additional time period. If a second recovery message is received on the same communications link within the second time period, the boot program enters the monitor communications mode. A response is preferably sent for each recovery message acknowledging receipt thereof. Accordingly, the control module can communicate with an external tool to diagnose and/or reprogram the control module.
According to an alternate embodiment of the present invention, control of a continually resetting control module is recovered using a running reset counter (RSC) that increments every time an unexpected event causes the control module to reset. The RSC is preferably located in SRAM and includes built-in validity checking by requiring that the RSC's compliment (RSCC) is stored in a separate SRAM location. The RSC and RSCC are compared against a value that is preferably located in the application program header each time the boot program starts. If the RSC exceeds the limit programmed into the application program header, the boot program enters the monitor communications mode instead of transferring control to the application program. In this manner, the control module can communicate with an external tool to diagnose and/or reprogram the control module.
The above features and advantages and other features and advantages of the present invention are readily apparent from the following detailed description of the best modes for carrying out the invention when taken in connection with the accompanying drawings.
a is a detailed schematic illustration of a memory device of the control module of
Referring to the drawings, wherein like reference numerals refer to like components,
Referring to
Referring to
At step 66, the algorithm 50 monitors one of the vehicle communication links 20 for a first predetermined amount of time to allow for recovery message transmission. At step 68, the algorithm 50 determines whether a first valid recovery message has been received. If the first valid recovery message has not been received at step 68, the algorithm 50 proceeds to step 70 at which the recover mode is set to inactive. If the first valid recovery message has been received, the algorithm 50 proceeds to step 71. At step 71, a response is sent to the tool 26 indicating that the first recovery message has been received. This response may be sent on the vehicle's internal communication links if the control module 10 is otherwise inaccessible. At step 72, the algorithm 50 monitors one of the vehicle communication links 20 for a second predetermined amount of time to allow the tool 26 to respond. At step 74, the algorithm 50 determines whether a second valid recovery message has been received. If the second valid recovery message has not been received, the algorithm 50 proceeds to step 70 at which the recover mode is set to inactive. If the second valid recovery message has been received, the algorithm 50 proceeds to step 76. At step 76, a response to the second valid recovery message is transmitted to the tool 26. At step 78, the recover mode is set to active.
Referring to
Referring to
At step 94, the algorithm 80 determines if the most recent reset was caused by an unexpected event. An “unexpected event” for purposes of this disclosure includes any event not identified by the microprocessor 12 as being included in a predefined list of expected events such as, for example, turning off the vehicle. If the last reset was not caused by an unexpected event, the algorithm 80 proceeds to step 102 wherein the recover mode is set to inactive. If the last reset was caused by an unexpected event, the algorithm 80 proceeds to step 96 wherein the RSC 22 is incremented by a predefined amount. At step 98, the algorithm 80 determines whether the value of the RSC 22 is greater than a predefined RSC limit that is preferably located in the application program header. The RSC limit is preferably set at a relatively high value, for example one thousand, to minimize the risk of inadvertent recover mode activation. If the value of the RSC 22 is greater than the predefined RSC limit, the algorithm 80 proceeds to step 100 wherein the recover mode is set to active. If the value of the RSC 22 is not greater than the predefined RSC limit, the algorithm 80 proceeds to step 102 wherein the recover mode is set to inactive.
The steps shown in
While the best modes for carrying out the invention have been described in detail, those familiar with the art to which this invention relates will recognize various alternative designs and embodiments for practicing the invention within the scope of the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
3899772 | Mead et al. | Aug 1975 | A |
4245315 | Barman et al. | Jan 1981 | A |
6639511 | Haruna et al. | Oct 2003 | B2 |
6957135 | Okada et al. | Oct 2005 | B2 |
7012993 | Alton | Mar 2006 | B2 |
7149915 | Matsuoka et al. | Dec 2006 | B2 |
20050203673 | El-Hajj et al. | Sep 2005 | A1 |
20060168468 | Robinson et al. | Jul 2006 | A1 |
Number | Date | Country | |
---|---|---|---|
20060168468 A1 | Jul 2006 | US |