Transient errors, triggered by alpha particles or cosmic radiation, are an increasing problem for integrated semiconductor circuits. Due to declining structure widths, decreasing voltages and higher clock frequencies, there is an increasing probability that a voltage spike, caused by an alpha particle or cosmic radiation, will falsify a logic value in an integrated circuit. The effect can be a false calculation result. Therefore, in safety-related systems, especially in the motor vehicle, such errors must be reliably detected.
In safety-related systems such as an ABS control system in a motor vehicle in which malfunctions of the electronic equipment must be detected with certainty, usually redundancies for error detection are used in the corresponding control devices of such systems. So, for instance, in conventional ABS systems, in each case the complete microcontroller is duplicated, the total ABS functions being calculated redundantly and checked for agreement. If a discrepancy appears in the results, the ABS system is switched off.
Essential components of a microcontroller include, on one hand, storage modules (e.g., RAM, ROM, cache), the core and the input/output interfaces, the so-called peripherals (e.g., analog-digital converter, CAN interface). Since storage elements can be effectively monitored using test codes (parity or ECC), and peripherals are often monitored specific to the application as part of a sensor signal path or actuator signal path, a further redundancy approach lies in solely doubling the core of a microcontroller.
Such microcontrollers having two integrated cores are also known as dual-core architectures. Both cores execute the same program segment redundantly and in clock-controlled synchronism (lockstep mode), the results of the two cores are compared and an error will then be detected in the comparison for agreement. This configuration of a dual-core system may be denoted as a comparison mode.
Dual-core architectures are also used in other applications to increase output, thus for performance enhancement. Both cores execute different programs, program segments and commands, whereby an increase of output can be attained, which is why this configuration of a dual-core system may be denoted as a performance mode. This system is also called a symmetrical multiprocessor system (SMP).
An expansion of these systems is a switchover by software between these two modes by way of an access to a special address and specialized hardware devices. In comparison mode, the output signals of the cores are compared to each other. In performance mode, the two cores operate as a symmetrical multiprocessor system (SMP) and execute different programs, program segments or commands.
In such systems, it is a problem when changing between the modes, to also change the bus-access possibilities in coordinated fashion. Therefore, an object of the present invention is to provide methods and means which make it possible to also change the bus-access possibilities in coordinated fashion when changing the mode.
In accordance with an example embodiment of the present invention, a method is used for switching over in a computer system having at least two execution units, switching being carried out between at least two operating modes, a first operating mode corresponding to a comparison mode and a second operating mode corresponding to a performance mode, characterized in that the execution units are connectable to an internal bus of the computer system, at least two execution units being connected in performance mode to the internal bus, and in response to the switchover from the performance mode to the comparison mode, at least one execution unit is separated from the internal bus by a switch controlled by the changeover switch.
Advantageously, an example method may be used in which a comparator may be provided, the comparator being activated in the comparison mode.
Advantageously, an example method may be used in which a comparator is provided, the comparator being deactivated in the performance mode.
An example method may be used in which a comparator is provided that compares this data, and in response to disparity, outputs a fault signal, the fault signal being masked in the performance mode.
Advantageously, an example method may be used in which the at least two execution units, whose data is compared in the comparison mode, are handled in this mode as one logical execution unit at the internal bus.
An example method may be used in which, in comparison mode, at least one execution unit is separated from the internal bus, and input data of the at least one execution unit not separated is duplicated, and is supplied to the at least one separated execution unit.
An example method may be used in which, in comparison mode, all except for one execution unit are separated from the internal bus, and input data of the execution unit not separated is duplicated, and is supplied to all separated execution units.
Advantageously, an example device may be used for switching over in a computer system having at least two execution units, a changeover switch being provided which switches between at least two operating modes, a first operating mode corresponding to a comparison mode and a second operating mode corresponding to a performance mode, characterized in that the execution units are connectable to an internal bus of the computer system, the execution units being connected to the internal bus in performance mode, and in comparison mode, only one execution unit being connected to the internal bus, and the at least second execution unit being separated from the internal bus by a switch controlled by the changeover switch.
Advantageously, an example device may be used in which a comparator is provided that is deactivated in the performance mode.
Advantageously, an example device may be used in which a comparator is provided that is activated in the comparison mode.
Advantageously, an example device may be used in which the changeover switch and the comparator are combined in one component as a switchover and comparison unit.
In the following, a processor, a core, a CPU, as well as an FPU (floating point unit), a DSP (digital signal processor), a coprocessor or an ALU (arithmetic logical unit) may be denoted as execution unit.
The present invention relates to a multiprocessor system G60, examples of which are shown in
In the performance mode, different commands, program segments or programs are executed in parallel in the different execution units. In this operating mode, comparison unit G20 is deactivated. In this operating mode, switchover unit G50 is configured in such a way that each execution unit G10a, G10b is connected to a system interface G30a, G30b. In this context, execution unit G10a is connected to system interface G30a, and execution unit G10b is connected to system interface G30b.
In the comparison mode, identical or substantially identical commands, program segments or programs are processed in both execution units G10a, G10b. These commands are advantageously processed in clock-controlled synchronism, but processing with asynchronism or a defined clock pulse offset is also possible. The output signals of execution units G10a, G10b are compared in comparison unit G20. In response to a difference, a fault is imposed and suitable measures can be taken. These measures may include the triggering of a fault signal, initiating a fault-handling procedure, the actuation of switches, or may be a combination of these and other possible measures. In one variation, switchover unit G50 is configured in such a way that only one signal is put through to system interfaces G30a, G30b. In another configuration, the switchover unit causes only the compared and therefore identical signals to be put through to system interfaces G30a, G30b.
Independently of the mode active at the moment, switchover-request recognition unit G40 detects a desire to switch to another mode.
In one specific embodiment, switchover unit G50 and comparison unit G20 may be combined to form one common switchover and comparison unit (SCU) G70, as shown in
In another specific embodiment as shown in
If not otherwise indicated, below, it is assumed that a switchover request recognition unit G40 and a combined switchover and comparison unit G70 are present.
A general case of the switchover and comparison component, also for use for more than two execution units, is shown in
Using this figure, it is possible to explain how the various possible modes can come about. To that end, this figure contains the logical component of a switching circuit logic N110. This component does not have to exist as a separate component. It is crucial that the functions described be realized in the system. Switching circuit logic N110 first of all determines how many output signals there actually are. It also determines which of the input signals contribute to which of the output signals. In this context, one input signal can contribute to exactly one output signal. Thus, phrased differently in mathematical form, the switching circuit logic defines a function which assigns one element of quantity {N160, . . . , N16n} to each element of quantity {N140, . . . , N14n}. Processing logic N120 then determines for each of the outputs N161, in what form the inputs contribute to this output signal. This component also does not have to exist as a separate component. Again, it is crucial that the functions described be realized in the system. To describe the different variation possibilities by way of example, let us assume, without limiting the universality, that output N160 is produced by signals N14l, . . . , N14m. If m=1, this corresponds simply to a through-connection of the signal; if m=2, then signals N141, N142 are compared as described, for example, in the comparator in
If m>=3, there are several possibilities.
A first possibility is to compare all signals and, given the presence of at least two different values, to detect a fault which optionally may be signaled.
A second possibility is to make a k from m-selection (k>m/2). This may be implemented by using comparators. Optionally, a fault signal may be generated when one of the signals is recognized as deviating. A fault signal, possibly different from it, may be generated when all three signals are different.
A third possibility is to supply these values to an algorithm. For example, this may represent the formation of a mean, a median or the use of a fault-tolerant algorithm (FTA). Such an FTA is based on discarding extreme values of the input values and performing a type of averaging over the remaining values.
This averaging may be carried out over the entire quantity of remaining values, or preferably over a partial quantity to be formed easily in HW. In this case, it is not always necessary to actually compare the values. For example, in determining the average, it is only necessary to add and divide; FTM, FTA or median require a partial sorting. Given sufficiently large extreme values, as an option, a fault signal may be output here as well, if desired.
These various indicated possibilities for processing a plurality of signals to form one signal are known for short as comparison operations.
The task of the processing logic is thus to determine the exact form of the comparison operation for each output signal—and therefore also for the associated input signals. The combination of the information from switching circuit logic N110 (i.e., the aforesaid function) and from the processing logic (i.e., the determination of the comparison operation per output signal, that is, per functional value) constitutes the mode information, and it determines the mode. In the general case, this information is naturally multi-valued, that is, it is not representable via only one logic bit. Not all theoretically possible modes are useful in a given implementation; preferably one will limit the number of modes allowed. It should be emphasized that in the case of only two execution units, where there is only one comparison mode, the total information can be condensed onto only one logic bit.
In the general case, a switchover from a performance mode to a comparison mode is characterized in that execution units, which are mapped to various outputs in the performance mode, are mapped to the same output in the comparison mode. Preferably, this is realized in that there is a subsystem of execution units in which, in the performance mode, all input signals N14i which are to be taken into account in the subsystem are switched directly to corresponding output signals N16i, while in the comparison mode, they are all mapped to one output. Alternatively, such a switchover may also be implemented by altering pairings. It is thereby clarified that, in the general case, one cannot speak of the one performance mode and the one comparison mode, although in a given form of the present invention, it is possible to limit the quantity of modes allowed, so that this is the case. However, one can always speak of a switchover from a performance mode to a comparison mode (and vice versa).
Controlled by software, it is possible to switch dynamically between these modes during operation. In this context, the switchover is triggered either by the execution of special switchover instructions, special instruction sequences, explicitly identified instructions or by the access to specific addresses by at least one of the execution units of the multiprocessor system.
Fault circuit logic N130 collects the fault signals generated, for example, by the comparators, and optionally, can switch outputs N16i to passive by interrupting them via a switch, for instance.
However, for the most part, the following examples concentrate on the case of two execution units, based on which most concepts can be presented more easily.
The switchover between the modes may be coded by various methods. In one possible method, special switchover commands may be used, which are detected by the unit for recognizing a switchover request G40. Another possible method for coding the switchover is defined by the access to a special memory area, which is again detected by the unit for recognizing a switchover request G40. A further method interprets an external signal, which signals a switchover, in the unit for recognizing a switchover request G40. In the following, a method is described which utilizes bit combinations not used in the existing instruction set of the processor. A special advantage of this method is that existing program development environments (assembler, compiler, linker, debugger) may continue to be used.
Therefore, the existing program development environment as it exists for single-processor systems may be used for the software development. This can be realized, for example, by defining a macro “SWITCH MODE TO PM” and a macro “SWITCH MODE TO CM” which inserts corresponding bit combinations, undefined in the sense defined above, at a suitable place in the code.
The use of this combination is then defined as a general “SWITCH” macro. Depending on the present mode, this macro then brings about a change to the respective other mode. If more than two different modes exist in the system, more such combinations must be available to use this method; preferably one per mode may then be used for the switchover identification.
According to an example embodiment of the present invention, the switchover request is coded by a bit combination not defined in the instruction set. It must not be processed within an execution unit G210a G210b in the usual manner. For this reason, an additional pipeline level (REPLACE level) G230a, G230b is provided, which recognizes the corresponding bit combinations and replaces them by neutral bit combinations for further processing. The “NOP” (No Operation) instruction is advantageously used for that purpose. A NOP instruction has the feature that it does not alter the internal state of the execution unit, except for the instruction pointer. In this context, REPLACE level G230a, G230b is inserted after the usual first level, the FETCH level G220a, G220b, and before remaining pipeline levels G240a, G240b, become bit combinations not defined in the assembler which are combined here in one unit.
According to an example embodiment of the present invention, the implementation shown here of a unit for recognizing a switchover request G40 as a special pipeline level G230a, G230b in a pipeline unit G215a, G215b will generate an additional signal G250a, G250b when a corresponding bit combination for a switchover has been detected, that signals to a separate switchover unit and comparison unit G260 that the processing mode is to be changed.
REP levels G230a, G230b are preferably disposed between FET levels G220a, G220b and remaining pipeline levels G240a, G240b in pipeline units G215a, G215b of execution units G210a, G210b. REP levels G230a, G230b recognize the corresponding bit combinations and, in this case, relay NOP instructions to remaining levels G240a, G240b. At the same time, respective signal G250a or G250b is activated. In all other cases, REP levels G230a, G230b behave neutrally, that is, all other instructions are passed on unchanged to remaining levels G240a, G240b.
A prerequisite for the suggestion described here is a unit (known as ID unit) or method via which each execution unit is able to ascertain its individual number or unit ID. For example, in a system having two execution units, one execution unit may ascertain for itself the number 0, the other the number 1. In a system having more than 2 execution units, the numbers are assigned or ascertained correspondingly. This ID does not differentiate between a comparison mode and a performance mode, but rather denotes an execution unit with one-to-one correspondence. The ID unit may be contained in the respective execution units, for example, implemented as a bit or bit combination in the processor status register or as a separate register or as a single bit or as a unit external to the execution units, which supplies a corresponding ID upon request.
After the execution units have switched to the performance mode in accordance with a switchover request, the comparison unit is indeed no longer active, but the execution units still execute the same instructions. This is due to the fact that the instruction pointers, which indicate the place in the program at which an execution unit will work in the next step or is working at present, are not influenced by the switchover. To permit the execution units to subsequently execute different SW modules, the program run of the execution units must be separated. Depending on the task, generally the instruction pointers have different values in the performance mode, since according to an example embodiment of the present invention, independent instructions, program segments or programs are processed. In the proposal described here, the program flows are separated by ascertaining the respective execution unit number. Depending upon which ID an execution unit possesses, the execution unit executes a specific software module. Since each execution unit has an individual number or ID, in this way the program flow of the participant execution units may be separated reliably.
In
This example method may also be used for multiprocessor systems having more than 3 execution units.
When there is a switch from performance mode to comparison mode, several things must be taken into consideration. In the switch from performance mode to comparison mode, it must be ensured that after the switchover, the internal states of the execution units are similar; otherwise, in the comparison mode, a fault would possibly be imposed if the different starting states lead to different outputs. This may be accomplished by hardware, by software, by firmware or in a combination of all three. A prerequisite for this is that all execution units execute identical or similar instructions, programs or program segments after the switchover to the comparison mode. An example synchronization method is described below which is usable when the comparison mode has the feature that identical instructions are processed and a bit-by-bit comparison is carried out.
Step G610: If the two execution units have separate caches, then the contents of the caches must also be adapted prior to the switchover to prevent a cache hit from occurring for the one execution unit and a cache miss from occurring for the other execution unit for one address in the comparison mode. If this is not implemented independently by the cache hardware, it can be accomplished, for example, by marking all cache lines as invalid. In this embodiment, it is necessary to wait until the cache (or the caches) are completely invalid. If necessary, this may be ensured by a wait loop in the program code. It may also be achieved by other means; in this embodiment, it is crucial that the caches be in the same state after this step.
In step G620, the write buffers of the execution units are emptied, so that after the switchover, no activities of the execution units take place which still stem from the performance mode.
In step G630, the state of the pipeline levels of the execution units is synchronized. For this purpose, for example, a suitable number of NOP (no operation) instructions are executed prior to the switchover sequence/switchover command. The number of NOP instructions is a function of the number of pipeline levels, and is therefore dependent on the specific architecture. Which instruction is suitable as a NOP instruction is likewise a function of the architecture. If the execution units have an instruction cache, then in this case it must be ensured that this instruction sequence is aligned at the boundaries of a cache line (alignment). Since the instruction cache has been marked as invalid prior to the execution of these NOPs, these NOPs must first be loaded into the cache. If this instruction sequence begins at a cache line boundary, then the data transfer from the memory (e.g., RAM/ROM/flash) to the cache will be completed before the command for the switchover takes place. This must also be taken into account when determining the necessary number of NOPs.
In step G640, the command step for the switchover to the comparison mode is actually carried out.
In step G650, the contents of the respective register files of each execution unit are adapted. For this purpose, the registers must be loaded with identical contents before or after the switchover. In so doing, it is important that after the switchover, the contents of a register in the execution units are identical before the register contents are transferred to the outside and therefore compared by the comparison unit.
In step G660, the interrupt controllers are reprogrammed, so that an external interrupt signal triggers the same interrupt for all interconnected execution units.
In step G670, the interrupts are enabled again.
If it is not clear from the program run when it is intended to switch to the comparison mode, then the participant execution units must be informed about the intended switchover. To that end, preferably an interrupt is initiated, for instance, by SW in the interrupt controllers belonging to the respective execution units. The handling of the interrupt then induces the execution of the sequence for the interconnection described above.
It is then ensured by hardware that state G700 is always assumed after a reset or power on. This is ensured in that, for example, the reset signal or the “power on” signal is conducted to the reset input or the set input of the flip-flop or of the register.
In state G700, the system operates in a performance mode. Execution units G10a, G10b thus process different commands, programs or program pieces. A switchover request can be recognized by the fact that, for example, one execution unit G10a, G10b executes a special switchover command. Other possibilities are a recognition due to the access to a special memory address, by an internal signal or also by an external signal. As long as there is no switchover request, multiprocessor system G60, and thus also switchover and comparison unit G70, remains in state G700. In the following, the switchover request denotes the recognition of a switchover condition which is characterized the way a switchover request is characterized in this special system.
The fact of remaining in state G700 is represented by transition G810. If execution unit G10a detects a switchover request, then switchover and comparison unit G70 is transferred into state G710 via transition G820. State G710 therefore denotes the situation when execution unit G10a has recognized a switchover request and is waiting until execution unit Glob likewise recognizes a switchover request. As long as this is not the case, switchover and comparison unit G70 remains in state G710, which is shown by transition G830.
Transition G840 takes place when, in state G710, execution unit G10b likewise detects a switchover request. Switchover and comparison unit G70 thereby assumes state G730. This state denotes the situation when both execution units G10a, Glob have recognized a switchover request. In state G730, the synchronization methods are carried out, by which the two execution units G10a, Glob are synchronized relative to each other, to subsequently operate in comparison mode. During this process, switchover and comparison unit G70 remains in state G730, which is shown by transition G890.
If, in state G700, a switchover request is first recognized by execution unit Glob, then there is a switch to state G720 via transition G860. State G720 therefore denotes the situation when execution unit Glob has recognized a switchover request and is waiting until execution unit G10a likewise recognizes a switchover request. As long as this is not the case, switchover and comparison unit G70 remains in state G720, which is shown by transition G870. Transition G880 takes place when, in state G720, execution unit G10a likewise recognizes a switchover request. The switchover and comparison unit thereby assumes state G730.
If, in state G700, both execution units G10a, Glob recognize a switchover request at the same time, then there is an immediate change to state G730. This case represents transition G850.
When switchover and comparison unit G70 is in state G730, both execution units G10a, Glob have recognized a switchover request. In this state, the internal states of execution units G10a, G10b are synchronized, in order to operate in comparison mode after these synchronization processes have ended. With the termination of this synchronization work, transition G900 takes place. This transition indicates the end of the synchronization. In state G740, execution units G10a, Glob operate in comparison mode. The completion of the synchronization work may be signaled by execution units G10a, Glob themselves. This means that transition G900 takes place when both execution units G10a, Glob have signaled that they are ready to operate in comparison mode. The termination may also be signaled via a fixed set time. This means that the length of time to remain in state G730 is permanently coded in switchover and comparison unit G70. This time is set in such a way that, with certainty, both execution units G10a, Glob have completed their synchronization work. After this time has expired, transition G900 is then initiated. In another variation, switchover and comparison unit G70 may monitor the states of execution units G10a, Glob and recognize itself when both execution units G10a, Glob have ended their synchronization work. After this recognition, transition G900 is then initiated.
As long as no switchover request is recognized, multiprocessor system G60 remains in comparison mode, represented by transition G910. When, in state G740, a switchover request is detected, the switchover and comparison unit is shifted via transition G920 to state G700. As already described, in state G700, the system operates in performance mode. The separation of the program flows upon transition from state G740 to state G700 may then be carried out as in the method described.
Advantageously, each execution unit G410a, G410b has its own interrupt controller G420a, G420b, to be able to handle two interrupts simultaneously in performance mode. This is especially advantageous in systems in which the interrupt handling represents a bottleneck in the system performance. In this context, interrupt sources G440a through G440n are each advantageously connected the same to both interrupt controllers G420a, G420b. The result of this type of connection is that, without further measures, the same interrupt is triggered at both execution units G410a, G410b. In performance mode, interrupt controllers G420a, G420b are programmed in such a way that corresponding interrupt sources G440a through G440n are suitably distributed to the different execution units G410a, G410b depending upon the application. This is accomplished by suitable programming of interrupt masking registers G430a, G430b. The masking registers provide for one bit in the register for each interrupt source G440a through G440n. If this bit is set, the interrupt is blocked, thus it is not routed to connected execution unit G410a, G410b. Advantageously, in a performance mode, a given interrupt source G440a through G440n is processed by exactly one execution unit G410a or G410b. Expediently, this holds true at least for some of the interrupt sources. In this way, a plurality of interrupt sources G440a through G440n may be processed simultaneously without an interrupt nesting (processing of an interrupt is interrupted by a second interrupt) or interrupt pending (the processing of the second is postponed until the processing of the first is completed) taking place.
In comparison mode, it must be ensured that interrupt controllers G420a, G420b trigger the same interrupt simultaneously at all execution units G410a, G410b; otherwise, in accordance with a comparison mode, a fault would be imposed. This means that in the synchronization phase during the switchover from performance mode to comparison mode, it is necessary to ensure that interrupt masking registers G430a, G430b are identical. This synchronization is described in
In
Register records G1040a, G1040b are used in the performance mode. In this case, interrupt controller G1030 operates exactly like two interrupt controllers G420a, G420b. This behavior is illustrated and described in
Starting from this basic system, a multitude of specific embodiments are possible. First of all, component M500 may be realized as a so-called TSC (totally self checking) component. In this case, fault signal M530 is conducted to the outside on at least two lines (“dual rail”), and internal design and fault-discovery measures ensure that in any possible case of fault of the comparison component, this signal exists correctly or recognizably incorrectly. In this context, a dual rail signal makes a binary signal available via two lines, preferably so that in a faultless case, the two lines are inverted relative to each other. One preferred variant in the utilization of the system according to the present invention is to use such a TSC comparator.
A second class of specific embodiments may be differentiated with respect to what degree of synchronism the two inputs M510, M511 (or M610, M611) must have. One possible specific embodiment is characterized by synchronism with clock-pulse timing, that is, the data may be compared in a clock pulse.
A slight change is obtained in that, given a fixed phase shift between the inputs, a synchronous delay element is used which delays the corresponding signals, for example, by half-integral or integral clock-pulse periods. Such a phase shift is useful to avoid common cause faults, that is, those causes of faults which are able to influence several processing units similarly and simultaneously.
Alternatively or additionally, temporary buffers M650, M651 may be placed into the input chain, to likewise be able to tolerate those asynchronisms which do not present themselves as pure clock pulse offset or phase shift. These temporary buffers are preferably designed as FIFO (first-in, first-out) memories. Such a memory has one input and one output, and is able to store several memory words. An incoming memory word is displaced in its position upon arrival of a new memory word. After the last position (the depth of the buffer), it is moved “out of the memory.” If such a buffer is present, it is also possible to tolerate asynchronisms up to the maximum depth of the buffer. In this case, a fault signal must also be output when the buffer overflows.
Further, in the comparator it is possible to differentiate specific embodiments according to how signal M520 (or M620) is generated. One preferred specific embodiment provides for connecting input signals M510, M511 (or M610, M611) to the output, and making the connection interruptible by switches. The particular advantage of this specific embodiment is that these same switches may be used for switching between performance mode and possible different comparison modes. Alternatively, the signals may also be generated from buffers internal to the comparator.
Another class of specific embodiments can be differentiated with respect to how many inputs exist at the comparator and how the comparator is intended to react. In the case of three inputs, a majority voting, a comparison of all three or a comparison of only two signals may be performed. In the case of four or more inputs, correspondingly more specific embodiments are possible. A detailed description of the possible specific embodiments is contained in the description of
The precise selection of the specific embodiments is preferably to be coupled to the various operating modes of the overall system. That is to say, if there are several different performance or comparison modes, then preferably they are coupled to the corresponding mode of the comparator.
At a few points in the example embodiments of the present invention, it may be necessary or advantageous to deactivate a comparator or a more general voting/processing/sort element (for the sake of simplicity, hereinafter always known as comparator), or to make it passive. There are many possibilities for that. First of all, a signal may be carried to the comparator, which activates or deactivates it. To that end, an additional logic which is able to accomplish this must be inserted in the comparator. Another possibility is to supply no data to be compared to the comparator. A third possibility is to ignore the fault signal of the comparator on the system level. Moreover, one may also interrupt the fault signal itself. What all the possibilities share in common is that it plays no role in the system, that two or more data, which potentially are compared, are different. If this is the case, the comparator is regarded as passive or deactivated.
Below, an implementation of a changeover switch in conjunction with a comparator, thus a switchover and comparison unit G70 is considered. This implementation is particularly favorable if it is realized together with execution units G10a, G10b within a chip.
By combining the comparator and changeover switch components, only a very small hardware overhead results upon implementation within a chip. One preferred variant of the implementation is therefore to combine these two parts in one component. This is a component having at least the input signals (output execution unit 1, output execution unit 2), at least the output signals (output 1, output 2), a logical output signal “output overall” (can agree physically with output 1 or output 2) and a comparator. The component has the ability to switch the mode, to let through all signals in the performance mode, and in a comparison mode, to compare a plurality of signals and, if applicable, let one through. Additionally, still further input and output signals are advantageous: A fault signal to signal a detected fault, a mode signal to signal the mode in which this component finds itself, and control signals from and to the component.
In one preferred exemplary embodiment, in performance mode, the two or more execution units are connected as master to a bus internal to the processor. The comparison unit is deactivated, or the fault signal, which is generated in response to a different behavior of the execution units in one of the possible comparison modes, is masked. This means that the switchover and comparison unit is transparent for the software. In the comparison mode considered, the physical execution units to be compared are handled as one logical execution unit at the bus, that is, only one master appears at the bus. The fault signal of the comparator is activated. In addition, the switchover and comparison unit separates all except for one execution unit via switch from the bus internal to the processor, duplicates the inputs of the one logical execution unit and makes them available to all execution units participant in the comparison mode. In the case of writing to the bus, the outputs are compared in the comparison unit, and, given equality, this data is written via the one available access to the bus.
In
In the illustrations described, it is possible to conduct the mode or fault signals to the outside without extra work. Furthermore, it is easily possible, especially for generating the internal mode state, for further signals to go to the component.
In summary, a preferred implementation of this component is thus characterized in that there is a plurality of processing units, which are able to write output signals onto the bus (e.g., address/data bus). In this embodiment, it is essential that the component be able to process at least two of the output signals of the execution units (e.g., compare, but possibly also vote or sort), and that the component be able to influence at least one switch by which at least one of the direct bus accesses is interrupted. This is especially useful when the execution units are processor cores. Moreover, it is advantageous if the state of the influenceable switches characterizes the operating mode of the arithmetic unit.
The system properties, particularly the possible comparison modes, are implemented particularly well when the component is able to place a signal on the address-data bus. Advantageously, this is a through-connection of one of the output signals of one of the execution units. Alternatively, it may be obtained from the processing of various output signals of the various execution units.
As has been shown, for example, in connection with
In the general case, the behavior according to the example embodiment of the present invention may be clarified with reference to
This mode signal is preferably protected. One implementation in the dual system based, for example, on the implementation shown in
The mode signal may be used outside of the component. First of all, it may be used for self-monitoring of the operating system. From the SW standpoint, it is responsible for a switchover and should always know the mode the system is in and should also bring the system into this mode. A check of this signal may thus be used for the protection. First of all, this may be done directly. However, an alternative possibility is also, via timers or other “independent” units, to determine the plausibility of a query in the operating system with this signal.
In general, as an option, this signal may also be used in other data sinks of a μC (or more general arithmetic unit). For example, an MPU (memory protection unit) may be programmed in such a way that it allows specific memory accesses (of specific execution units) only in specific modes. In this context, a MPU is a unit which is able to ensure that only allowed accesses to the data/address bus are implemented; for example, for certain program parts, it prevents access to certain address spaces. An additional protection may be provided by directing the mode signal to the MPU, suitable configuration and programming of this MPU, and evaluation of this configuration data and of the mode signal. This may possibly even simplify the programming, in the event the mode signal already constitutes sufficient information for the check test. A quasi-static programming at the initialization time of the μC then suffices. The equivalent may hold true for peripheral units. Here as well, there are applications in which an access to a corresponding peripheral element is allowed only in certain modes. An additional protection may be provided by directing the mode signal to the peripheral element, suitable configuration and programming of the peripheral element, and evaluation of this configuration data and of the mode signal. This may possibly even simplify the programming, in the event the mode signal already constitutes sufficient information for the check test. A quasi-static programming at the initialization time of the μC then suffices. In an analogous manner, the evaluation of this signal may also be used at the interrupt controller. Such monitoring operations can then make up the basis or an essential part of the safety concept. By suitable design and SW structuring, it may be possible to base the safety concept for an entire class of faults on this mode signal in the practical application considered. This is particularly advantageous when the mode signal in a suitable form, as described above, is intrinsically safe. In this case, it is then further advantageous if the component considered has the possibility of sending a fault signal or activating a shutdown path if it detects an inconsistency between the mode signal and the access to itself.
Another important use is the evaluation of the mode signal outside of the arithmetic unit. A direct practical application is the evaluation in a decrementing watchdog. Such a watchdog is made up of at least one (counter-) register, which can be set to an integer value by the microprocessor. After this register has been set, the watchdog independently decrements the value of the register with a fixed period. If the value of the register is zero or if an overflow occurs, the watchdog generates a fault signal. If the fault signal is not to be generated, then the microprocessor must reset the value of the register again in good time. It is thereby possible to check (within limits), whether the microprocessor is executing the software correctly. If the microprocessor is no longer executing the software correctly, it is assumed that in this case, the watchdog is also no longer being operated correctly, and therefore a fault signal is generated by the watchdog. The integrity of the hardware and of the data structures may be checked reliably in a comparison mode; to that end, however, it is necessary to ensure that the microprocessor switches back again at regular intervals into this mode. Therefore, the task of the watchdog described here is to generate a fault signal not only when it is no longer reset within a defined period of time, but also when the microprocessor no longer switches back to the defined comparison mode within a defined period of time. For example, the watchdog can be reset only when the mode signal indicates the defined comparison mode of the arithmetic unit. It is thereby ensured that the arithmetic unit switches back to this mode at regular intervals. Alternatively or additionally, the value in the register of the watchdog is only decremented when specific interrupts are triggered in the microprocessor. To that end, the external interrupt signals of the PC must also be coupled to the watchdog. The watchdog stores which interrupts switch the PC to the defined comparison mode. The watchdog is “wound up” as soon as such an interrupt arrives; it is reset by the presence of the correct mode signal.
Quite generally, it is useful, especially in the application to a safety concept, to evaluate the mode signal in a source external to the μC. An important point in safeguarding the correct execution of the software on a computer, as it is described in connection with the present invention, is the correct change between the various allowed modes. First of all, the change capability itself should be checked, preferably also the correct change. As described above, one may also take an interest that a special mode is assumed at regular intervals. Such a method is always especially advantageous when the mode signal itself is implemented to be intrinsically safe.
One possibility is to conduct the mode signal to an ASIC or another μC. Using this signal, via timers and simple logic, it is able to check at least the following points:
Does the arithmetic unit come sufficiently often (e.g., at the latest every 1000 μs) into one or several defined modes?
Is a specific signal always output in response to the change to a mode?
Does the arithmetic unit regularly go out of a mode?
Are certain simple patterns of the sequence of the modes valid:?
Is a general time pattern valid (e.g., on average <70% in mode 1 and <50% in mode 2)?
Any combination of logical, temporal properties of the mode signal, possibly supplemented by utilization of additional signals.
In this context,
A further application of this idea is the evaluation of the mode signal in an actuator drive circuit. In many applications in the automotive sector, there is a trend today to so-called intelligent actuators. They are actuators having a minimal amount of electronics which are sufficient to receive an actuator control command and to then drive the actuator in such a way that this control command is then also executed.
The basic idea is illustrated in
Number | Date | Country | Kind |
---|---|---|---|
10 2004 051 937.4 | Oct 2004 | DE | national |
10 2004 051 992.7 | Oct 2004 | DE | national |
10 2005 037 229.5 | Aug 2005 | DE | national |
10 2004 051 952.8 | Oct 2004 | DE | national |
10 2004 051 950.1 | Oct 2004 | DE | national |
10 2004 051 964.1 | Oct 2004 | DE | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP05/55495 | 10/25/2005 | WO | 4/25/2007 |