This application claims priority under 35 U.S.C. §119 to Taiwan Patent Application No. 096119841, filed on Jun. 1, 2007, in the Taiwan Intellectual Property Office, the entire contents of which are hereby incorporated by reference.
1. Field of the Invention
The present invention relates to a micro controller system, in particular, to a control device and a method thereof for increasing stability of the micro controller system.
2. Description of Related Art
In the past, micro controllers were mainly used in consumer electronics with low requirements for resistance to large temperature ranges and for resistance to electronic noise. However, in the fields of industrial control and automobile electronics, electronic noise is becoming stronger and denser and thus the components applied in these fields must possess higher electronic noise resistance, ensuring stable operations of the entire system.
When noise interferes with power lines and unstable power occurs, it is prone to have bad signals input to the devices in a system, causing wrong actions of the device and erroneous output signals, further negatively affecting operations made by other devices; or the noise interferences become so serious that the whole device may fail, causing the entire system to break down with unpredictable conditions. Common situations are: data process errors, program failure of infinite loop, system crashes.
In a conventional micro controller system, two devices are usually employed to prevent the occurrences of erroneous system actions. The first type of device is a watch dog timer (WDT) device, which is often used for detecting error conditions in a micro controller. The main detection approach of the watchdog device is to check if the micro controller works normally once every a certain period of time, and in case that an unknown error occurs, the device will immediately perform error recovery. For example, when a program runs to an unexpected process position without executing according to a designated action, then after a period of time, the WDT device detects such an error condition, it will generate an Overflow signal to notify the system for resetting, enabling the system to be reinstated in the normal operations. The second type of device is Low Voltage Detect device, which is frequently used for ensuring the voltage stability of the system. In case that a low voltage situation occurs, which may result in system instability, the Low Voltage Detect device will beforehand send a voltage error signal for performing system reset to stop system operations, so as to retain system stability.
However, the aforementioned two types of devices are still not able to handle certain more complicated erroneous conditions and errors. For example, when a program runs to an unexpected process position, therein coincidentally contains a Clear WDT instruction, thus continuously prolonging process time, or due to execution of unexpected program blocks by the erroneous actions of the system, which unfortunately shuts down the WDT device, thereby unable to use the WDT device to detect erroneous conditions and to restore the system by means of the Overflow function. Furthermore, although the voltage, for example, did drop too low, but this condition was transient and existed so short that the Low Voltage Detect device missed such an erroneous phenomenon, which, however, may have already caused unfavorable influences to the system stability; as a result, it is very likely that the system may fail and cannot be recovered.
In a traditional system, if noise or voltage has reached a status that errors may occur, but the system breaks down or even is unable to be restored back to normal operations because that such an erroneous condition was not detected, then the component is very improper and unpractical to be applied in an environment of high noise. Therefore, for the micro controller to be used in an environment of high noise, it should present not only robust anti-noise ability, but also possess powerful system self-restoration function, so as to increase the stability of the system.
In view of the aforementioned issues, the present invention provides a method for increasing stability of a micro controller (MCU) system, which, through the error detecting device provided by the system, detects first various error conditions, then according to the error conditions detected, sends signals to notify the error processing device for proper handling, thereby reducing the chance of occurrences of system erroneous actions due to error conditions, further increasing the stability of the system.
To achieve the above-mentioned objectives, the present invention provides a control device, including a system error detection unit, which is used for detecting whether a micro controller system operates normally, and when the micro controller system operates abnormally, it outputs a system error signal; a system resetting unit, which is used for resetting the micro controller system; and an error signal processing unit, which is used for receiving the system error signal so as to output a system reset signal; wherein, if the error signal processing unit receives the system error signal, then the error signal processing unit will output the system reset signal to the system resetting unit for resetting the micro controller system.
To achieve the above-mentioned objectives, the present invention further provides a control device, including a memory unit, used for data storage; a data error detection unit, which is used to perform error detection on data from the memory unit, and upon the detection of error in the data transferred from the memory unit, it outputs a data error signal; a system resetting unit, which is used for resetting a micro controller system; and an error signal processing unit, which is used to receive the data error signal, so as to output a system resetting signal or to correct the error data from the memory unit; wherein if the error signal processing unit receives the data error signal, then the error signal processing unit will correct the error data from the memory unit, or output the system reset signal to the system resetting unit for resetting the micro controller system.
To achieve the above-mentioned objectives, the present invention further provides a control method of increasing the stability of a micro controller system, including the following steps: to provide a system error detection unit to determine whether there is an error in the micro controller system; to provide an error signal processing unit, in which, based on the determination of the system error detection unit, if an error occurs in the micro controller system, it issues a system reset request; and to provide a system resetting unit for performing the system reset request issued by the error signal processing unit.
To achieve the above-mentioned objectives, the present invention further provides a control method of increasing the stability of a micro controller system, including the following steps: to provide a data error detection unit for detecting whether there is an error in the data transferred from the memory unit of the micro controller system; to provide an error signal processing unit, which, based on the determination of the data error detection unit, if an error occurs in the data transferred from the memory unit, it issues a system reset request or corrects the data transferred from the memory unit of the micro controller system; and to provide a system resetting unit for performing the system reset request issued by the error signal processing unit.
In order to further understand the techniques, means and effects the present invention takes for achieving the prescribed objectives, the following detailed descriptions and appended drawings are hereby referred, such that, through which, the purposes, features and aspects of the present invention can be thoroughly and concretely appreciated; however, the appended drawings are merely provided for reference and illustration, without any intention to be used for limiting the present invention.
Referring now to
The control device 1 employs the system error detection unit 11 to determine if a micro controller system (not shown) is in a stable condition. When the system error detection unit 11 detects any system instability, it sends a signal to notify the error signal processing unit 14, instructing the system resetting unit 15 to perform system reset, thus preventing any possible occurrences of system error or breakdown in case that the system continues to operate under unstable system condition.
When the system power becomes unstable or noise interference deteriorates, the data acquired from the memory unit 13 by the micro controller system (not shown) probably contains errors, and in case that the data errs, program codes or the data to be processed possibly become unpredictable. Hence, suppose the system happens to execute the erroneous program codes, it will result in system breakdown or even unrecoverable crash.
Regarding to the above-mentioned issues, the present invention adds information of error check and error correction functions for the data stored in the memory unit 13, so as to, upon reading, first perform determination on data correctness, and in case that any data error should be found, it is possible to recover originally correct data by means of this additional information. Therefore, each data acquired from the memory unit 13 will be subject to a confirmation action executed by the data error detection unit 12 for determining if an error exists therein, and in case the existence of any data error is detected, the data will be sent to the error signal processing unit 14 for data correction. Suppose there are too many data errors to handle, the system will be notified to execute re-send instruction in terms of this piece of data, requesting the memory unit 13 to send the data again.
Besides, when the data error detection unit 12 performs confirming operation on the data acquired from the memory unit 13, if it finds that the address range to which the data corresponds exceeds the border, then it will notify the error signal processing unit 14 about the occurrence of error, and the error signal processing unit 14 will instruct the system resetting unit 15 to perform an action of system reset. By means of the error detection on transferred data, and further through the data error correction or system reset, it is possible to avoid sending wrong data into the system for execution, which may result in occurrences of unpredictable conditions.
Next, the operation principles and relations of each unit in the control device 1 according to the present invention will be described.
Referring to
Since, when the system is unstable, the behavior of the check code generating circuit 111 will be accordingly unstable; thus once the existence of check code error is detected, it can determine that the system needs to stop working. Therefore, when the check code is found to be erroneous, the system error detection unit 11 will output a system error signal for notifying the error signal processing unit 14 to perform the system reset request, enabling the system resetting unit 15 to reset the system; after the system reset this check code will be checked again to determine whether the system has been restored to normal condition; if not normal yet, the error signal processing unit 14 will be constantly notified to request the system resetting unit 15 to perform system reset, until the system is back to be normal.
Referring again to
Referring now to
The data output by the memory unit 13, including the data in the ROM 131, the RAM 132 as well as the data registering device 133, will be subject to the data error check performed by the data error detection unit 12. If the data error detection unit 12 finds that the address range to which the data transferred from the memory unit 13 corresponds exceeds a predetermined range (e.g. the accessible data range is set to be in 00H˜6FH but a value of 70H is found, which means an action of crossing beyond the border), it can determine the occurrence of error, the data error detection unit 12 will then send a data error signal to the error signal processing unit 14, and the error signal processing unit 14 will send a system reset signal to the system resetting unit 15, requesting the system resetting unit 15 to perform system reset action so as to fix this error.
Besides, in terms of each data from the memory unit 13, the data error detection unit 12 uses error correction codes to check whether the input data is correct, and once the occurrence of data error is found, the data error detection unit 12 will send a data error signal to notify the error signal processing unit 14, requesting the error signal processing unit 14 to perform data restoration action.
Thus, when the error signal processing unit 14 has learned, based on the data error signal, that errors have been found in the data transferred from the memory unit 13 after the error correction code check, it will first use the error correction code to attempt to fix the error data, if this renders successful correction, then the system can continue to operate without being interrupted by the error. If, however, such a correction does not work, then a data error re-get signal will inevitably be sent to the system, so as to request the memory unit 13 to send again the data. In case the error signal processing unit 14 has learned, based on the data error signal, that the reason for the data error is the accessed data range is beyond the system predetermined range, it will accordingly determine the existence of system errors and immediately notify the system resetting unit 15 to reset the system.
When the error signal processing unit 14 receives the data error signal, the error signal processing unit 14 will first perform the data correction. However, for the structure of a general micro controller, suppose a program is found to have errors, the corrected result will be directly put in the instruction bus to replace the wrong program, and the corrected operation data will be placed on the data bus, thus accomplishing the data correction.
As described supra, it can be seen that, in the control device 1 according to the present invention, when the system instability is detected, the system resetting unit 15 will be notified to immediately reset the system to ensure the system stability. While the function of the above-mentioned system resetting unit 15 is to reset the system, in the situation of system reset, the system will not perform any program and internal operations, which is similar to a stop status.
Finally, referring to
After that the error signal processing unit 14 has received the data error signal, it will, based on whether such a data error signal is generated in step S503 or in step S505, determine whether the data error correction should be performed (as step S509). Suppose the data error signal is generated in step S503, then the error signal processing unit 14 needs not to perform the error data correction, but outputs a system reset signal to the system resetting unit 15 (as step S517); if, whereas, the data error signal is generated in step S505, then the error signal processing unit 14 performs the error data correction (as step S511), and determines based on whether the data correction is successful (as step S513); if the data correction is successful, then the system continues to operate normally (as step S515); but in case that the data correction fails, the error signal processing unit 14 will output a system reset signal to the system resetting unit 15 (as step S517).
At last, upon the reception of the system reset signal at the system resetting unit 15, the system reset action will be performed for ensuring the stability of system operation (as step S519).
In summary, through the error detecting device provided by the system, it detects first various error conditions, then, according to the error conditions detected, sends signals to notify the error processing device for proper processes, thereby reducing the chance of occurrences of system erroneous actions due to error conditions, further increasing the stability of the system.
The above-mentioned descriptions represent merely the preferred embodiment of the present invention, without any intention to limit the scope of the present invention thereto. Various equivalent changes, alternations or modifications based on the claims of present invention are all consequently viewed as being embraced by the scope of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
096119841 | Jun 2007 | TW | national |