The present invention relates to industrial controllers used for real time control of industrial processes, and in particular to an industrial controller architecture for implementing safety integrity levels (SIL) of 2 or more.
Industrial controllers are special-purpose computers used in controlling industrial processes. Under the direction of a stored control program, an industrial controller examines a series of inputs reflecting the status of the controlled process and changes a series of outputs controlling the process. The inputs and outputs may be binary, that is, on or off, or analog, providing a value within a substantially continuous range. The inputs may be obtained from sensors attached to the controlled process, and the outputs may be signals to actuators on the controlled process.
“Safety industrial, control systems” are industrial control systems intended to ensure the safety of humans working in the environment of an industrial process. Such systems may include the electronics associated with emergency-stop buttons, light curtains. and other machine lockouts. Safety industrial control systems are not optimized for “availability”, that is being able to function for long periods of time without error, but rather for “safety” which is being able to accurately detect error to shut down. Safety industrial controllers normally provide a predetermined safe state for their outputs upon a safety shutdown, the predetermined values of these outputs being intended to put the industrial process into its safest static mode.
Safety industrial control systems may be associated with a “safety integrity level” (SIL) indicating a given amount of risk reduction. Standard IEC EN 61508 defines four SIL levels of SIL-1 to SIL-4 with higher numbers representing higher amounts of risk reduction.
Industrial controllers that are part of a system providing SIL-2 and higher normally use diagnostic programs that run concurrently with the industrial controller to diagnose the operation of the hardware of the industrial controller to ensure that it is working correctly.
The process of developing diagnostic programs for industrial controllers has become increasingly difficult as more sophisticated processor architectures are adopted in the industrial controller industry. Advanced processor architectures include techniques such as out-of-order execution, speculative execution, cache snooping and the like which can greatly increase the speed of execution of the processor but which are extremely difficult to diagnose in real time.
Safety industrial control systems providing SIL-3 and higher preferably provide “full redundancy” in hardware, for example, using two different industrial controllers having separate microprocessors, memory systems, communication systems and the like. In such full redundancy systems, the industrial controllers execute in parallel and their results are compared. If these results do not match, a “safety fault” can be indicated, causing the control system to move to the safe state.
Full redundancy safety industrial control systems may also implement diversity in the hardware and software. Hardware diversity can be obtained, for example, using different microprocessor architectures. This hardware diversity helps to reduce the chance that a common mode failure of the microprocessors (for example, a design flaw) would occur providing matching erroneous outputs from the two microprocessors which would not be detected as a safety fault. Similarly, software diversity can be obtained by preparing two different control programs having the same functional specification using two different programming teams who each then produce programs with substantial variations in approach and logic.
Providing safety systems is relatively expensive and accordingly there is considerable interest in lowering the price point of such systems such as could increase their relative availability and thus overall safety of the community. One significant source of cost is the need for multiple microprocessors. Recent processor architectures used in industrial controllers have moved to “multicore” architectures in which multiple processing cores are contained inexpensively on a single integrated circuit die. These cores which share features such as an L2 cache, cache control circuitry and memory channels, however, are not sufficiently isolated for the purpose of “full redundancy” desirable to meet SIL-3 standards.
Preparing diverse software is also costly. While the approach of using separate development teams can be practical for commonly used programs having many users, many industrial control applications require custom written unique control programs where using this approach for single program cannot be cost justified.
The present invention provides a safety industrial controller that uses programs running on different cores on the same microprocessor to help detect safety faults. While this approach does not meet the full redundancy standards, the present inventor has recognized that the second core can effectively provide a real-time diagnostic for errors in the first core thus fulfilling a diagnostic rather than a redundancy function, The ability to create a diagnostic function in this way is particularly critical for the diagnosis of errors on sophisticated modem processors that would be difficult to detect using normal diagnostic programs.
The use of two cores, one of which provides a diagnostic feature, can provide a component of a “full redundancy” system, the latter including two processing platforms each having two cores where one core serves in a diagnostic capacity.
The present invention further provides a method of automatically generating diverse software without the need for separate development teams. The invention creates diverse software by modifying a given control program to execute on inverted data, thereby providing a mechanistic way of generating high diversity in the computer instructions expressing the desired control function without the need for human intervention.
Specifically, in one embodiment, the invention provides a safety industrial controller for an industrial system having sensors and actuators, and including a multicore processor having at least two cores and the computer memory. The computer memory holds: (a) an input data table holding data representing, inputs from sensors; (b) an output data table holding data representing outputs to actuators; (c) a control program implementing a control logic for control of the industrial system reading the input data of the input table to provide output data for the output table; and (d) a safety operating system. The safety industrial controller further includes I/O interface circuitry adapted to attach to the sensors and actuators to transfer data from the sensors to the input data table and from the output data table to the actuators. The safety operating system dedicates a first core to execute a first version of the control program and dedicates a second core to execute a second version of the control program in parallel and to compare output data of the first and second versions of the control program to detect failure of the safety industrial controller.
It is thus a feature of at least one embodiment of the invention to make use of cores of a multicore processor to implement diagnostic functions in the safety controller even though these cores arc not sufficiently diverse for a full redundancy system.
The control program may execute cyclically to process all input data once per cycle and the safety operating system may provide a predetermined assignment of the first and second core to the first and second versions of the control program during all portions of the cycle.
It is thus a feature of at least one embodiment of the invention to provide a quasi-static assignment of the cores (in contrast to typical core usage) in enlisting the cores to provide dedicated diagnostic functions to a second companion core.
In some embodiments, the safety industrial controller may further include a second multicore processor having at least two cores and the second computer memory. The second computer memory may store: (a) a second input data table holding data representing inputs from the sensors; (b) a second output data table holding data representing outputs to the actuators; (c) a second control program implementing the control logic for control of the industrial system reading the second input data of the input table to provide output data for the second output table; and (d) a second safety operating system. The safety industrial controller may further include second I/O interface circuitry adapted to attach to the sensors and actuators to transfer data from the sensors to the input data table and from the output data table to the actuators, and the second safety operating system may dedicate a first core of the second multicore processor to execute a first version of the second control program and a second core of the second multicore processor to execute a second version of the second control program in parallel and to compare output data of the first and second versions of the second control program to detect failure of the safety industrial controller.
It is thus a feature of at least one embodiment of the invention to provide a subcomponent of a processor plus diagnostics that can be incorporated into a full redundancy system by duplication.
In one embodiment, the invention provides a method of operating a safety industrial controller for an industrial system having sensors and actuators, the safety industrial controller including multiple processors, and a memory storing: an input data table holding data representing inputs from sensors, an output data table holding data representing outputs from actuators, and a control program implementing a control logic for the control of the industrial system reading the input data of the input table to provide output data for the output table. The safety industrial controller further includes I/O interface circuitry adapted to attach to the sensors and actuators to transfer data from the sensors to the input data table and from the output data table to the actuators. The invention prepares a diverse first and second version of a control program providing identical control of the industrial system through the use of different sequences of program instructions and loads the first and second diverse versions on a first, and second separate processor. The first and second diverse versions on the first and second processors are then in parallel, and output data of the first and second versions of the control program are compared to detect failure of the safety industrial controller. The execution of the first and second diverse versions of the control program operate on first and second sets of input data in the input data table wherein the first set of input data is the logical inverse of the second set of data.
It is thus a feature of at least one embodiment of the invention to provide a mechanistic way of creating diverse software by modifying one program to operate on inverted data.
The operating system may also invert the output data from the second version of the control program prior to comparing the output data to the output data from the first version of the control program to indicate failure when this comparison indicates a difference.
It is thus a feature of at least one embodiment of the invention to provide an input and output inversion such as permits simple diversity generation through the use of DeMorgan's theorem.
The first version of the control program and second version of the control program may provide, respectively, first and second sets of sequentially executing statements wherein functionally identical portions of the first set of sequentially executing statements are not identical to functionally identical portions of the second set of sequentially executing statements.
It is thus a feature of at least one embodiment of the invention to provide different control programs that are unlikely to fail in the same way on a given hardware error.
These particular objects and advantages may apply to only some embodiments falling within the claims and thus do not define the scope of the invention.
Referring now to
Generally, the safety controller 12 provides multiple ports 14 communicating using high-speed serial links with a workstation 15 and being of conventional design providing an independent processor, memory, display screen, keyboard, and the like, as well as one or more remote 110 modules 16a and 16b.
The remote I/O modules 16 may include input and output circuits for receiving or outputting analog or digital signals directly between the I/O modules 16 and sensors and actuators of an industrial process 18 according to commands received from the safety controller 12. In this example, I/O module 16a may provide for multiple connections 20 with general (nonsafety) aspects of the industrial process to monitor and control that process, whereas I/O module 16b may provide for multiple connections 20′ that communicate with safety portions of the industrial process 18, for example, including an emergency stop button 22, a remote lockout station 24 (together with an electrically controlled lockout switch 24′) and access control such as a light curtain 26. The I/O module 16b may also communicate, for example. with a machine tool 28 (here a robotic manipulator) for the purpose of putting it in a safe state if necessary.
Referring now to
The cores of the multicore processor 30 may communicate with a common memory 42, for example, composed of random access memory including a mixture of volatile and nonvolatile memory types. Importantly, the memory 42 holds a control program set 44 implementing the logic necessary to control the industrial process 18 of
In this regard, each of the programs 46a and 46b will be composed logically of a set of machine code statements 47 (for example, mapping to assembly language mnemonics) having an execution order. The selection and ordering of the machine code statements 47 in each of the programs 46a and 46b are such that less than 10 percent of the machine code statements 47 in a sequence of at least 10 statements in the programs 46a have matching counterparts in program 46b. More generally, a side-by-side comparison of the programs 46a and 46b shows little or no apparent matching between sequences of machine code statements 47. Generally, a machine code statements 47 is considered to include an operator and one or more memory or register references holding operands. Normally even sequences of operators are highly diverse, but where similar sequences of operators exist, the register references will typically be diverse.
The memory 42 may also include an input table 48 and an output table 50, respectively, with the input table 48 holding values received, from sensors in the industrial process 18 and the output table 50 holding values to be output to actuators in the industrial process 18 (for example, including components of the machine tool 28). As with the control program set 44, each of the input table 48 and output table 50 are divided into two redundant components (labeled A and B) providing separate input or output values for the programs 46a and 46b as will be discussed below.
The memory 42 will also hold a safety operating system 52 which coordinates the execution of the program set 44 as will be discussed below. The memory 42 further holds a set of certified library routines 54 providing general functions used by a wide range of different types of application programs 46.
The operating system 52, executed by the multicore processor 30 operating in conjunction with additional dedicated circuitry 56 of the type generally understood in the art, implements I/O interface circuitry providing, for example, the ports 14 discussed above for communication with the workstation 15 and the remote I/O modules 16. In one embodiment, the I/O interface circuitry operates to regularly scan the sensors on the industrial process 18 to load the input table 48. The programs 46a and 46b are executed in one cycle on the data of the input table 48 to provide outputs stored in the output table 50. The I/O interface circuitry then reads the output table 50 sending this data, to the necessary actuators of the industrial process 18. This process is then repeated. By enforcing separate scan and execution phases, the operating system 52 provides more deterministic execution of the programs.
Referring still to
Referring now to
At succeeding process block 74, the diversity generation program 66 may further modify the source code of control program 64 (program A) by performing selected logical inversions on the program instructions.
Referring now to
These two implementations of a primitive and its inversion will be functionally equivalent if the data received by an output from the primitive are also inverted. In the present example case of AND-gate 76′, the input data associated with contacts 78a and 78b of AND-gate 76′ are inverted with respect to the input data associated with contacts 78a and 78b of OR-gate 76, and the output data output from coil 80 of AND-gate 76′ is again inverted. The net, result of inverting the functional primitive and its input and output data is to provide an identical logical function according to De Morgan's law. This process can be generally extended to logic elements of AND, NOR and by extension NAND and NOR computer instructions. Thus, this logical inversion can occur with not only AND gates and OR gates but also NAND gates and NOR gates found in program 46a as well as any simple stateless combinations of such gates.
As noted, changing logical inversion as indicated in
Referring again to
For example. referring again to
Referring still to
Generally, elements such as timer 84 and multiplier 96 will call identical library routines 54 that are not diverse and for this reason these portions of the programs will not be diverse. The inventors have determined that this is acceptable because of the greater scrutiny given to these library routines 54 and the additional diversity implementation of, process block 100; however, the invention also contemplates that specific diverse library routines 54 may be used in the programs 46a and 46b generated by conventional means.
Referring still to
As is understood in the art, compilers include compiler option settings that change compiler optimizations without affecting the correctness of the compilation process. For example, different compiler optimization settings may optimize the speed of execution of the program or minimize the amount of memory used. When these optimizations are changed, the underlying machine code instructions 47 are substantially altered without changing logical function. As an example, consider a compiler optimization for speed that replaces a multiplication of a value by two with a left shifting of that value or by adding the value to itself. Left shifting or addition are faster than multiplication in most cases and accordingly this would be a speed optimization. Nevertheless, it will be appreciated that the instructions used for multiplication are diverse (different) from the instructions used for either left shifting or addition.
Accordingly, the compilation of the programs 46a and 46b will also use different optimizations settings of the same compiler. The invention contemplates that a wide variety of different optimizations may be different between the two compilations. Some optimizations relate to particular architectures which would not be relevant for the identical cores 32 but could also be used by simply artificially indicating that functionality is missing in one core causing, a change in the compilation process. A nonlimiting list of compiler optimizations that may be varied include optimization for speed, optimization for compiled code size, constant folding, dead store elimination, loop unrolling, and the like.
Referring now to
As indicated by process block 104, at the conclusion of the scan, the inputs of A are then propagated to the B side of input table 48 by inverting those values which represent Boolean states, for example, such as will provide inputs to contacts in the program shown in
Referring momentarily to
Referring again to
At process block 110, the digital data of side B of the output table 50 is then inverted and as inverted is compared to the data of output table 50 at side A per decision block 112. It should be understood that this description is intended to be functional and does not necessarily require inverting of the data of side B of the output table 50 for comparison. Alternatively, the data of side B of output table 50 may be compared to the data of side A of the data table 50 using an exclusive or (XOR) which will generate values of zero if there is a match.
In all cases, this data matches, suggesting that the hardware associated with two different cores 32 are functioning correctly, the program proceeds to, process block 114 and the data of output table 50 at side A is output by the I/O circuitry to the actuators of the safety controller 12, The steps of process blocks 102-114 are then repeated indefinitely during execution of the control process.
If at decision block 112, an error is indicated (in a failure of the data to match), the safety controller 12 moves to a safe state indicated by process block 116 where the output values revert to predetermined safe output values, for example, values of zero or according to a safe state file (not shown).
Referring now to
Referring now to
Referring to
If the comparison of comparison blocks 120 is successful (meaning that the two programs show the same outputs at comparison block 112 of
Certain terminology is used herein for purposes of reference only, and thus is not intended to be limiting. For example, terms such as “upper”, “lower”, “above”, and “below” refer to directions in the drawings to which reference is made. Terms such as “front”, “back”, “rear”, “bottom” and “side”, describe the orientation of portions of the component within a consistent but arbitrary frame of reference which is made clear by reference to the text and the associated drawings describing the component under discussion, Such terminology may include the words specifically mentioned above, derivatives thereof, and words of similar import. Similarly, the terms “first” “second” and other such numerical terms referring to structures do not imply a sequence or order unless clearly indicated by the context.
When introducing elements or features of the present disclosure and the exemplary embodiments, the articles “a”, “an”, “the” and “said” are intended to mean that there are one or more of such elements or features. The terms “comprising”, “including” and “having” are intended to be inclusive and mean that there may be additional elements or features other than those specifically noted. It is further to be understood that the method steps, processes, and operations described herein are not to be construed as necessarily requiring their performance in the particular order discussed or illustrated, unless specifically identified as an order of performance. It is also to be understood that additional or alternative steps may be employed.
References to “a microprocessor” and “a processor” or “the microprocessor” and “the processor,” can be understood to include one or more microprocessors that can communicate in a stand-alone and/or a distributed environment(s), and can thus be configured to communicate via wired or wireless communications with other processors, where such one or more processor can be configured to operate on one or more processor-controlled devices that can be similar or different devices. Furthermore, references to memory, unless otherwise specified, can include one or more processor-readable and accessible memory elements and/or components that can be internal to the processor-controlled device, external to the processor controlled device, and can be accessed via a wired or wireless network.
It is, specifically intended that the present invention not be limited to the embodiments and illustrations contained herein and the claims should be understood to include modified forms of those embodiments including portions of the embodiments and combinations of elements of different embodiments as come within the scope, of the following claims. All of the publications described herein, including patents and non-patent publications, are hereby incorporated herein by reference in their entireties.