EP0645028A1 - Secure front end communication system and method for process control computers - Google Patents
Secure front end communication system and method for process control computersInfo
- Publication number
- EP0645028A1 EP0645028A1 EP93914299A EP93914299A EP0645028A1 EP 0645028 A1 EP0645028 A1 EP 0645028A1 EP 93914299 A EP93914299 A EP 93914299A EP 93914299 A EP93914299 A EP 93914299A EP 0645028 A1 EP0645028 A1 EP 0645028A1
- Authority
- EP
- European Patent Office
- Prior art keywords
- computer
- process control
- data
- computers
- network
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 238000004886 process control Methods 0.000 title claims abstract description 255
- 230000006854 communication Effects 0.000 title claims abstract description 118
- 238000004891 communication Methods 0.000 title claims abstract description 118
- 238000000034 method Methods 0.000 title claims description 109
- 230000005540 biological transmission Effects 0.000 claims abstract description 33
- 230000004044 response Effects 0.000 claims abstract description 10
- 230000009466 transformation Effects 0.000 claims abstract description 7
- 230000008569 process Effects 0.000 claims description 59
- 230000008859 change Effects 0.000 claims description 15
- 238000012986 modification Methods 0.000 claims description 11
- 230000004048 modification Effects 0.000 claims description 11
- 230000015654 memory Effects 0.000 description 189
- 239000000872 buffer Substances 0.000 description 184
- TVZRAEYQIKYCPH-UHFFFAOYSA-N 3-(trimethylsilyl)propane-1-sulfonic acid Chemical compound C[Si](C)(C)CCCS(O)(=O)=O TVZRAEYQIKYCPH-UHFFFAOYSA-N 0.000 description 50
- 238000012546 transfer Methods 0.000 description 49
- 101100368149 Mus musculus Sync gene Proteins 0.000 description 36
- 241000196324 Embryophyta Species 0.000 description 22
- 239000000835 fiber Substances 0.000 description 22
- 238000010586 diagram Methods 0.000 description 18
- 230000036541 health Effects 0.000 description 16
- 238000012545 processing Methods 0.000 description 16
- 229910003460 diamond Inorganic materials 0.000 description 13
- 239000010432 diamond Substances 0.000 description 13
- 238000000750 constant-initial-state spectroscopy Methods 0.000 description 11
- 240000007320 Pinus strobus Species 0.000 description 10
- 230000006870 function Effects 0.000 description 9
- 239000013307 optical fiber Substances 0.000 description 9
- 230000008901 benefit Effects 0.000 description 7
- 230000000694 effects Effects 0.000 description 7
- 101710185016 Proteasome-activating nucleotidase 1 Proteins 0.000 description 6
- 101710185022 Proteasome-activating nucleotidase 2 Proteins 0.000 description 5
- 238000013475 authorization Methods 0.000 description 5
- 230000007704 transition Effects 0.000 description 5
- 238000010200 validation analysis Methods 0.000 description 5
- 101000654674 Homo sapiens Semaphorin-6A Proteins 0.000 description 4
- 102100032795 Semaphorin-6A Human genes 0.000 description 4
- 241000283899 Gazella Species 0.000 description 3
- 230000002411 adverse Effects 0.000 description 3
- 239000013256 coordination polymer Substances 0.000 description 3
- 238000001514 detection method Methods 0.000 description 3
- 230000009977 dual effect Effects 0.000 description 3
- 238000007726 management method Methods 0.000 description 3
- 238000004519 manufacturing process Methods 0.000 description 3
- 241001522296 Erithacus rubecula Species 0.000 description 2
- 101710108416 Robin Proteins 0.000 description 2
- 238000006243 chemical reaction Methods 0.000 description 2
- 239000003795 chemical substances by application Substances 0.000 description 2
- 238000004590 computer program Methods 0.000 description 2
- 230000003111 delayed effect Effects 0.000 description 2
- 230000001419 dependent effect Effects 0.000 description 2
- 230000007717 exclusion Effects 0.000 description 2
- PWPJGUXAGUPAHP-UHFFFAOYSA-N lufenuron Chemical compound C1=C(Cl)C(OC(F)(F)C(C(F)(F)F)F)=CC(Cl)=C1NC(=O)NC(=O)C1=C(F)C=CC=C1F PWPJGUXAGUPAHP-UHFFFAOYSA-N 0.000 description 2
- 230000000737 periodic effect Effects 0.000 description 2
- 230000008054 signal transmission Effects 0.000 description 2
- JBRZTFJDHDCESZ-UHFFFAOYSA-N AsGa Chemical compound [As]#[Ga] JBRZTFJDHDCESZ-UHFFFAOYSA-N 0.000 description 1
- 229910001218 Gallium arsenide Inorganic materials 0.000 description 1
- 208000003035 Pierre Robin syndrome Diseases 0.000 description 1
- JDZPLYBLBIKFHJ-UHFFFAOYSA-N Sulfamoyldapsone Chemical group C1=CC(N)=CC=C1S(=O)(=O)C1=CC=C(N)C=C1S(N)(=O)=O JDZPLYBLBIKFHJ-UHFFFAOYSA-N 0.000 description 1
- 238000013459 approach Methods 0.000 description 1
- 230000007175 bidirectional communication Effects 0.000 description 1
- 125000004122 cyclic group Chemical group 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 238000013524 data verification Methods 0.000 description 1
- 230000001934 delay Effects 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 238000011156 evaluation Methods 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 230000002452 interceptive effect Effects 0.000 description 1
- 238000012544 monitoring process Methods 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 239000002674 ointment Substances 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 238000010223 real-time analysis Methods 0.000 description 1
- 238000011084 recovery Methods 0.000 description 1
- 230000002441 reversible effect Effects 0.000 description 1
- 230000000630 rising effect Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 238000000926 separation method Methods 0.000 description 1
- 238000004350 spin decoupling difference spectroscopy Methods 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 239000000126 substance Substances 0.000 description 1
- 238000012360 testing method Methods 0.000 description 1
- 238000012795 verification Methods 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/30—Authentication, i.e. establishing the identity or authorisation of security principals
- G06F21/31—User authentication
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B19/00—Programme-control systems
- G05B19/02—Programme-control systems electric
- G05B19/418—Total factory control, i.e. centrally controlling a plurality of machines, e.g. direct or distributed numerical control [DNC], flexible manufacturing systems [FMS], integrated manufacturing systems [IMS] or computer integrated manufacturing [CIM]
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01R—MEASURING ELECTRIC VARIABLES; MEASURING MAGNETIC VARIABLES
- G01R31/00—Arrangements for testing electric properties; Arrangements for locating electric faults; Arrangements for electrical testing characterised by what is being tested not provided for elsewhere
- G01R31/28—Testing of electronic circuits, e.g. by signal tracer
- G01R31/317—Testing of digital circuits
- G01R31/3181—Functional testing
- G01R31/3183—Generation of test inputs, e.g. test vectors, patterns or sequences
- G01R31/318385—Random or pseudo-random test pattern
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B19/00—Programme-control systems
- G05B19/02—Programme-control systems electric
- G05B19/04—Programme control other than numerical control, i.e. in sequence controllers or logic controllers
- G05B19/042—Programme control other than numerical control, i.e. in sequence controllers or logic controllers using digital processors
- G05B19/0421—Multiprocessor system
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B19/00—Programme-control systems
- G05B19/02—Programme-control systems electric
- G05B19/04—Programme control other than numerical control, i.e. in sequence controllers or logic controllers
- G05B19/042—Programme control other than numerical control, i.e. in sequence controllers or logic controllers using digital processors
- G05B19/0423—Input/output
- G05B19/0425—Safety, monitoring
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B19/00—Programme-control systems
- G05B19/02—Programme-control systems electric
- G05B19/04—Programme control other than numerical control, i.e. in sequence controllers or logic controllers
- G05B19/042—Programme control other than numerical control, i.e. in sequence controllers or logic controllers using digital processors
- G05B19/0428—Safety, monitoring
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B19/00—Programme-control systems
- G05B19/02—Programme-control systems electric
- G05B19/418—Total factory control, i.e. centrally controlling a plurality of machines, e.g. direct or distributed numerical control [DNC], flexible manufacturing systems [FMS], integrated manufacturing systems [IMS] or computer integrated manufacturing [CIM]
- G05B19/4185—Total factory control, i.e. centrally controlling a plurality of machines, e.g. direct or distributed numerical control [DNC], flexible manufacturing systems [FMS], integrated manufacturing systems [IMS] or computer integrated manufacturing [CIM] characterised by the network communication
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B19/00—Programme-control systems
- G05B19/02—Programme-control systems electric
- G05B19/418—Total factory control, i.e. centrally controlling a plurality of machines, e.g. direct or distributed numerical control [DNC], flexible manufacturing systems [FMS], integrated manufacturing systems [IMS] or computer integrated manufacturing [CIM]
- G05B19/4185—Total factory control, i.e. centrally controlling a plurality of machines, e.g. direct or distributed numerical control [DNC], flexible manufacturing systems [FMS], integrated manufacturing systems [IMS] or computer integrated manufacturing [CIM] characterised by the network communication
- G05B19/41855—Total factory control, i.e. centrally controlling a plurality of machines, e.g. direct or distributed numerical control [DNC], flexible manufacturing systems [FMS], integrated manufacturing systems [IMS] or computer integrated manufacturing [CIM] characterised by the network communication by local area network [LAN], network structure
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B2219/00—Program-control systems
- G05B2219/20—Pc systems
- G05B2219/24—Pc safety
- G05B2219/24167—Encryption, password, user access privileges
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B2219/00—Program-control systems
- G05B2219/20—Pc systems
- G05B2219/24—Pc safety
- G05B2219/24182—Redundancy
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/16—Error detection or correction of the data by redundancy in hardware
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2221/00—Indexing scheme relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F2221/21—Indexing scheme relating to G06F21/00 and subgroups addressing additional information or applications relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F2221/2103—Challenge-response
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2221/00—Indexing scheme relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F2221/21—Indexing scheme relating to G06F21/00 and subgroups addressing additional information or applications relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F2221/2129—Authenticate client device independently of the user
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02P—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN THE PRODUCTION OR PROCESSING OF GOODS
- Y02P90/00—Enabling technologies with a potential contribution to greenhouse gas [GHG] emissions mitigation
- Y02P90/02—Total factory control, e.g. smart factories, flexible manufacturing systems [FMS] or integrated manufacturing systems [IMS]
Definitions
- the present invention generally relates to "front-end" communication techniques between process control computers and a plant/local area network. or'- specifically, the present invention relates to a front-end communication system which is capable of securely handling messages from the plant area network which could affect the
- redundant process control computers are employed to enhance the reliability of the plant control and monitoring system.
- the Fiebig et. al U.S. Patent No. 5,008,805 shows a networked control system which includes a "hot standby" redundant processor that synchronously processes a control schedule table for comparison with control messages from a
- the redundant listener processor maintains a duplicate configuration in its memory ready to take over control of the system in the event of a failure of the sender processor.
- McLaughlin et. ai U.S. Patent No. 4,958,270 shows a networked control system which employs a primary controller and a secondary controller. In order to maintain consistency
- control over the input/output devices is exclusively carried out by the primary processor.
- the primary processor periodically transfers status data relating to its operation in tne control of the inDut/outDut devices to tne oac -uD ⁇ ata processor via a ⁇ ual porte ⁇ memory connected between the two processors.
- the present invention provides a secure front-end communication system wnicn is interposed between a plurality of actively redundant orocess control computers and a computer network.
- the secure front-end communication system includes a front end computer which is capable of establishing time limited communication contracts with one or more computer entity on the computer network.
- each of these time limited communication contracts is based upon an acceptable response to the transmission of an unpreoicable signal from the front en ⁇ computer. More particularly, the acceptable response is preferably in the form of an encrypted transformation of a psuedo-random number generated by the front end computer.
- the front end computer will negotiate a new time limited communication contract with the computer entity on the computer network using a new psuedo-random number.
- the front end computer also includes at least one permissive table which is used to determined whether a write command message from the network entity should be transmitted to the process control computer for which the message was intended.
- a security server is also included on the computer network for transmitting a security table to the front end computer. The security table is used to identify the network entities that are permitted to send write command messages to the process control computers to which the front end computer is connected.
- Figure 1 is a block diagram of an intelligent front-end communication system for a plurality of actively redundant process control computers which utilizes a stealth interface according to the oresent invention
- Figures 2A and 2B provide a diagrammatic representation of the data tables stored in a time aligned reflective memory buffer and the Correlate buffer shown in Figure 1.
- FIG 3 is a block diagram of the stealth interface shown in Figure 1
- F'gures 4A and 4B comprise a schematic diagram of the stealth interface of Figures 1 and 2
- FIGS 5A and 5B illustrate two timing diagrams for the stealth interface
- Figures 6A-6E comprise a set of flow charts illustrating particular aspects of the security and validation methods according to the present invention
- Figure 8 is a diagrammatic illustration of the configuration for the front end computers
- Figure 9 is a a diagrammatic illustration of the relationship between the reflective memory buffers in the front end computers, the transfer map in the IFS circuit and the data memory in the process control computers
- Figure 10 is a block diagram of the IFS circuit shown in Figure 1
- Figure 1 1 is a block diagram of the IFQ circuit shown in Figure 1 5
- FIG. 1 a block diagram is shown of an intelligent front-end communication system 10 which is coupled to a pair of actively redundant process control computers 12a- 12b.
- Each of the process control computers 12a- 12b receive common input data 0 from field computer units (not shown) or other suitable field instrumentation
- the Glaser et. al. U.S. Patent Application Serial No. 07/864,931 describes in detail the communication and control links between a pair of actively redundant process control computers, such as process control computers 12a-12b, and the input/output devices directly associated with the physical process being controlled.
- the process control computers 12a- 12b preferably operate concurrently on all of the signals transmitted from one or more field computer units
- each of the process control computers 12a- 12b are capable of making independent decisions based upon the data received by these redundant computers from the
- corresponding input value tables in each of the process control computers 12a- 12b could be compared during a preset time period, and one of the values could be chosen for each input value signal to be subjected to the process control program
- This selection of input values could be made on a suitable criteria to the process being controlled, such as the use of the value determined by the Left process control computer 12a when the value determined by the Right process control computer 12b is within a certain predetermined percentage limit (for example, 2.5%) Otherwise, the distinct input values of both the Left and Right process control computers could each De employed when these values are found to be outside the predetermined percentage limit
- the selection of different input/output values from the Left and Right process control computers could be made on the basis of a software implemented preference. Thus, for example, under certain process conditions, it may be considered more appropriate to select either the high or low value, regardless of whether the value was determined by the Left or Right process control computer
- a parallel communication link 14 is provided between the process control computers 12a-12b
- Parallel communication link 14 is referred to as the "major” link, as it permits a direct transfer of data and timing signals between the process control computers
- the Left process control computer 12a is labeled “fox '
- the Right process control computer 12b is labeled “dog”
- the process control computer in the fox mode While each of the process control computers 12a- 12b make independent decisions, which may be subject to arbitration, the process control computer currently in the fox mode has the ability to force the process control computer in the dog mode to move to a subsequent step in a programmed sequence in or ⁇ er to keep the cooperative efforts of the two process control computers in relative synchronization Additionally, the process control computer in the fox mode will transmit a timing signal to the process control computer in the dog mode at the beginning of its process control program cycle (for example, a one second period), so that the process control computer in the dog mode will know to begin a new process control program cycle as well As the process control computers 12a- 12b operate under their own clock oscillators, the detection and interpretation of this program cycle timing signal bv the process control computer in tne ⁇ og mo ⁇ e will help to pe ⁇ o ⁇ icallv keep these process control computers in relative synchronization However, it should be appreciated that the program cycle of the process control computer in the dog mode will typically follow the program cycle of the process control computer
- process control computers 12a- 12b are temporarily not able to communicate over the major link 14, each of these process control computers will continue their operations in a mode wnich assumes that they are operating alone In this mode of o operation, it should be appreciated that the program cycles of the process control computers 12a- 12b may gradually drift apart in time relative to each other Nevertheless, as will be seen from the discussion below, the front end communication system 10 is designed to enable data received from the process control computers 12a- 12b to be time aligned for real-time analysis As illustrated in Figure 1 , eacn of the process control computers 12a- 12b includes 5 a stealth interface according to the present invention In particular, process control computer 12a includes stealth interface circuit 16a, wnile process control computer 12b includes stealth interface circuit 16b.
- stealth interface circuit 16a- 16b comprise identical circuits
- these stealth interface circuits are sometimes referred to generally herein as stealth interface circuit 16. Due to the redundant nature of the front end communication system 10, a general 0 reference number will also be used for other dup cative components in the system
- the stealth interface 16 provides transparent data transfers between the process control computer to which it is connected and external communication devices In this regard, the data transfers are transparent to the pVocess control computer 12 in that the operation of the process control computer is not delayed or otherwise adversely affected by a transfer of its 5 data to one or more external communication devices.
- the stealth interface 16 also enables the transfer of messages from an external communication device without affecting the operation of the process control computer 2.
- the primary example of such an external communication device is shown in Figure 1 to be comprised of a pair of redundant front end computers 18a- 18b.
- the front end computers 18a- 18b are redundant, because communication paths are 0 provided for enabling each of these front end computers to exchange data and messages with both of the stealth interface circuits 16a- 16b
- Each of the front end computers 18a-18b provide a highly intelligent interface between the stealth interface circuits 16a-16b and a plant local area network, which is generally designated by reference numeral 20.
- each of the redundant front 5 end computers 18a-18b are capable of communicating with each of the stealth interface circuits 16a-16b, it should be appreciated that this redundancy is not required, and that a single front end computer could be utilized in the appropriate application.
- each of the stealth interface circuits are capable of exchanging ⁇ ata and messages with other external communication devices, as well as the front en ⁇ computers 18a- 18b.
- the stealth interface circuit 16 features a dual-ported memory "DPM" 22 which resides on the bus structure of the process control computer 12. c Indeed, in the embodiment disclosed herein, the dual- ported memory 22 provides the primary or only data memory for the process control computer 12. Thus, in accordance with the present invention, the stealth interface circuit 16 will selectively grant external devices direct access to the data memory of the process control computer itself.
- the dual-ported memory 22 includes an internal port which is connected to the bus structure of the process control computer 12 and
- the dual-ported memory 22 could be configured to provide additional ports, the dual-ported memory preferably includes an arbitration circuit which enables a plurality of external communication devices to have alternative access to the stealth port. In other words, only one external device will be able to use the data and address lines of the stealth port at any given time when access
- the stealth interface arbitration circuit employs a first-come, first- serve approach to granting access rights.
- the machine cycle of the process control computer 12 is utilized to
- the central process unit of any computer must fetch and decode one or more programmed instructions in order to operate on one or more data words.
- computers based upon the von Neumann architecture it typically takes several computer clock cycles to fetch, decode and execute an instruction.
- the process control computer 12 is based on the Harvard architecture,
- the dual-ported data memory 22 may be accessed from the stealth port. Then, during the portion of the clock cycle for the process control computer 12 that is devoted to fetching the operand from the data store, the process control computer will have access to the dual- ported data memory 22 from the internal port.
- the stealth interface circuit 16 watches ;or a specific transition in the memory clock signal of the process control computer 12 in order :o determine wnen tne stealth port may have access to the dual-ported data memory 16
- the process control computer itself is not affected by this external access, as external access is permitted by the stealth interface circuit 16 only during those time periods when the process control computer 12 will not need to access the dual- Dorted data memory 22
- the process control computer 12 does not even have to know that externally generated read/write activity is actually occurring with respect to its data store.
- the dual-ported data memory 22 will store not only dynamic data associated with the physical process being controlled, but it may also store other process control variables, such as analog and digital constants.
- the dual-ported memory 22 includes two " logical " memory sections, namely variable section 24 and mailbox section 26. These memory sections are logically distinct, because they are treated separately, even though they may both reside in the same physical memory circuit chip or chip set.
- the mailbox section 26 is comprised of a set of 256 memory word locations (16 bits each) in the dual-ported data memory 22
- the variable section 24 is comprised of the remaining memory locations in the dual- ported data memory 22 (for example, a block of 64k memory word locations).
- the variable section 24 may also include a message area for holding system messages from the process control computer 12 to the front end computer 18.
- the mailbox section 26 is used to provide a specific region in memory for storing messages from external devices, such as the front end computers 18a-18b.
- the memory locations of the mailbox section 26 do not need to be physically contiguous. While the mailbox section 26 may be configured to hold more than one message at any one time, depending upon the message transmission protocol employed, the mailbox section need only be large enough to hold one complete message. These messages may be as simple as an external request for the process control computer 12 to gather and transmit health/status data from a remote field computer unit that it may obtain less frequently. A message may also include a command to change a particular variable stored in the dual-ported data memory 22. Additionally, the mailbox section 26 of the dual-ported data memory 22 may also be used to electronically convey a program revision to the process control computer 12.
- tne stealth interface circuit 16 includes a guardian circuit which prevents any external entity from writing to any memory iocations in the variable section 24 of the dual-ported data memory 22.
- a guardian circuit which prevents any external entity from writing to any memory iocations in the variable section 24 of the dual-ported data memory 22.
- an external entity is only permitted to write to the memory Iocations in the mailbox section 26 of the dual-ported memory 22.
- This feature of the present invention provides a hardware safe ⁇ guard at the process control computer 12 which insures that no external entity will be able to inadvertently interfere with the data processing operations of the process control computer 12.
- this feature of the present invention could o aiso be employed to grant or deny external write access to any particular memory location or set of memory Iocations in the dual-ported data memory 22.
- the front end communication system 10 of Figure 1 is also shown to include an interface to stealth "IFS" circuit 28, an interface to Q-bus " IFQ” circuit 30, and a set of fiber optic cables 32 interposed 5 therebetween.
- the IFS circuit 28 is connected to the stealth port of the dual-ported data memory 22, while the IFQ circuit 30 resides on the "Q bus" of the front end computer 12. Due to the redundant nature of the front end communication system 10, it should be appreciated that the IFS circuit 28a is connected to the stealth port of dual-ported data memory 22a, while IFS circuit 28b is connected to the stealth port of dual- ported data memory 22b.
- the 0 IFQ circuit 30a is connected to the Q bus of the front end computer 18a, while the IFQ circuit 30b is connected to the Q bus of the front end computer 18b.
- the front end computer 18 is preferably comprised of a MICROVAX 3400 computer using the real-time ELN operating system from the Digital Equipment Corporation "DEC". While the VAX family of computers from DEC offer considerable speed and networking
- the fiber optic cables 32 actually include two sets of send and receive optical fibers (for example,
- fiber optic channel 34a includes a separate optical fiber for sending information from the front end computer 18a to the stealth interface circuit 22a and an optical fiber for receiving information from the stealth interface circuit 22a.
- fiber optic channel 36a includes a separate optical fiber for sending information from the front end computer 18a to the stealth interface circuit 22a and an optical fiber for receiving information from the stealth interface circuit 22a.
- the comoination o ⁇ the IFS circuit 28, the IFQ circuit 30 and the fiber optic cables 32 provide an optical transmission interface which permits the front end computers 18a- 18b to be remoted located from the process control computers 12a- 12b For example, in this emoooi mem it is possiDle ⁇ or the front end computers 18a- 18b to be located upto 2 km from the process control computers 12a-12b Additionally, it should be noted that the Fiber Distributed Data Interface " FDDI" protocol may be used to transmit information between the IFQ and IFS circuits overthe fiber optic cables 32
- the IFS circuit 28 includes the appropriate address and data buffer circuits (not shown) for trans f erring information to and from the stealth port of the dual-ported data
- the IFS circuit 28 also includes a transfer map 37 which enables data from selected locations in the dual-ported data memory 22 to be gathered and transferred as one contiguous block of data
- the transfer map 37 may be comprised of a static RAM with sufficient address storage capability to gather data from all of the available memory locations in the dual- ported data memory 22
- the IFS circuit 28 includes a separate transmitter and receiver circuit for each of the two front end computers 18a- 18b, such as transmitter 38a and receiver 40a.
- the transmitter 38a is adapted to convert parallel data words (for example, 16 bits) from the stealth port into a serial bit stream suitable for transmission over one of the fiber optic cables 32.
- the receiver 40a is adapted to convert a serial bit stream from the front end computer
- the IFS circuit 28a is capable of simultaneously transmitting data acquired from the process control computer 12a to both of the front end computers 18a-18b. While not shown for illustration simplicity, it should appreciated that a laser or LED light source is interposed between each of the transmitters (for example, transmitters 38a- 38b) and their respective optical fibers Similarly, a photo- detector is also interposed between the transmitters (for example, transmitters 38a- 38b) and their respective optical fibers Similarly, a photo- detector is also interposed between the transmitters (for example, transmitters 38a- 38b) and their respective optical fibers Similarly, a photo- detector is also interposed between the transmitters (for example, transmitters 38a- 38b) and their respective optical fibers Similarly, a photo- detector is also interposed between the transmitters (for example, transmitters 38a- 38b) and their respective optical fibers Similarly, a photo- detector is also interposed between the transmitters (for example, transmitters 38a- 38b) and their respective optical fibers Similarly, a photo
- each of the receivers for example, receivers 40a- 40b
- these light converters may be comprised of a oair of AT&T ODL200 series converters
- fiber optic cables are preferred for their speed, low error rate and security advantages over mediums such as coaxial cable, it should be understood that that other suitable data transmission medium could be employed in the appropriate application
- the transmitters and receivers in the IFS and IFQ circuits are preferably comprised of a high-performance Gallium Arsenide chipset, such as the "Gazelle" GA901 1 transmitter and GA9012 receiver from T ⁇ quint Semiconductor, Inc., 2300 Owens St., Santa Clara, CA These particular transmitters and receivers permit data transmission rates in excess of 200 M bits/second
- These transmitters ana receivers utilize a 40- Di ⁇ wide parallel bus wnicn enables data to be encoded into a 50-baud word using FDDI- standard 4B/5B encoding
- 4-b ⁇ t data nibbles are translated into a 5-baud code svmool
- tne 4B/5B encoding produces ten 5-bauo symools from ten 4-b ⁇ t data niobles in order to como ⁇ se a data frame.
- the GA901 1 transmitters also convert the serial stream from a Non-Return to Zero ' NRZ" format to a Non-Return to Zero, Invert on ones ' NRZI" format, wnich combines the transmission of data and CIOCK signals into a single waveform
- the NRZI waveform denotes a logical one with a polarity transition and a logical zero with no transition within the bit-time-frame These logical ones and zeros are called o bauds, and each group of five bauds are called a symbol.
- the GA9012 5 receivers have built in clock and data recovery (for example, NRZI to NRZ conversion), and they also monitor the incoming 5B symbols for validity.
- the 4B/5B encoding creates a number of invalid symbols which may be checked for at the GA9012 receivers As the presence of noise or jitter across the fiber optic link could cause one or more of the bauds to change to an unintended value, the detection of invalid symbols reduces the possibility of a transmission 0 error going undetected.
- data transmissions from the IFS circuit 28 are formed into complete data frames, which are comprised of the data to be transferred (that is, the 40-b ⁇ t input data frame), a 16-b ⁇ t destination address field, a 4-b ⁇ t control code field and a 4-b ⁇ t error detection code field.
- These complete data frames are 5 preferably separated from each other on the fiber optic link by at least one sync frame.
- potential physical link errors may have a burst or clustering nature, the error code needs to be able to detect up to four contiguous bit errors.
- LRC Longitudinal Redundancy Check
- a 4-b ⁇ t nibble composed of parity bits is generated and inserted into the encoded data stream for a predetermined number of data nibbles in the encoded data stream, as shown below: b4 b3 b2 b1 data nibble 1 x x x x 5 data nibble 2 x x x x data nibble 3 x x x x x data nibble 8 I x x x x I ⁇ ata nibble 9
- the ith bit of this parity check character checks the ith information bit position in data nibbles 1 through 9 under even parity conditions
- the combination of the LRC error checking, the 4B/5B encoding and the NZRI conversion enable the front end communication system 10 to provide a targeted Baud Error Rate "BER" of 1 E- 12 While a Cyclic Redundancy Check "CRC" code could be employed in lieu o ⁇ the LRC code, the more complicated CRC code would also increase the complexity of the IFQ and IFS circuits Additionally, the LRC coding more readily permits dual fiber optic channel signal transmissions between the IFS and IFQ circuits, and the intrinsic synchronization features o ⁇ the the Gazelle transmitters 38a-38b and receivers 40a-40b may be used to frame the LRC based protocols The
- a command message transmission will start with a W ⁇ te-Lock request to the IFS circuit 28 Assuming that incoming buffer is free, the IFS circuit 28 will assert a Write-Lock on the mailbox section 26 of the dual-ported data memory 22, and return a positive acknowledgement to the IFQ circuit 30 The IFQ circuit 30 may then transmit its message with the assurance that no other device will be able to write to the mailbox section 26 until its message has been completely stored and preferably read by the process control computer 12 - ⁇ owever, a time limit may be imposed on the Write LOCK to ensure that the flow of communications is not impeded by one of the external entities connected to the stealth interface circuit 16.
- the IFQ circuit 30 will cause the IFS circuit 28 to read back a message transmitted to and stored in the mailbox section 26 of the dual-ported data memory 22 in order to be sure that the message was transmitted and stored correctly. Once the IFQ circuit 30 determines that the message has been accurately received and stored, then the IFQ circuit will cause a flag to be set which will signal the process control computer 12 to pick up the new message. In the event that this data verification fails, then the entire message transmission process will be repeated.
- the IFQ circuit 30 also includes a process data buffer 44, which is shown as block in Figure 1 for illustration simplicity.
- the process data buffer 44 should include sufficient memory capacity to store a separate data table for each of the process control computers 12a-12b (for example, 262, 144 bytes). Each of these data tables will include both the SDS5 and DSS data transmissions.
- a DMA buffer (not shown) may also be provided to allow some elasticity in processing the data being received.
- the both the IFS circuit 28 and the IFQ circuit 30 are configured to facilitate bi ⁇ directional Direct Memory Access "DMA" transfers between the IFQ circuit 30 and the Q-bus of the front end computer 18.
- the central processing unit 45 of the front end computer 18 does not need to devote substantial time to processing data transfers to and from the IFQ circuit 30.
- the DMA buffer is preferably used as a bucket brigade area to perform DMA transfers on blocks of data from the process data buffer 44 (for example, 8K bytes at a time) to a suitable memory residing on the Q-bus of the front end computer 18.
- the use of DMA transfers also enhances the ability of the front end communication system 10 to achieve the goal of making available real-time data from the process control computers 12a- 12b to one or more computers on the network 20.
- the front end communication system 10 is designed to request, receive and answer network queries on both pre-link and post- arbitrated data from each of the process control computers 12a-12b within a one- second time resolution.
- each of the process control computers 12a- 12b will issue a Sequence Data Stable Strobe "SDDS" signal in every one-second program cycle, which indicates that approximately 1024 (16 bit) words of pre-link dynamic analog/digital input data is stable and available in the dual-ported data memory 22.
- SDDS Sequence Data Stable Strobe
- each of the process control computers 12a- 12b will issue a Data Stable Strobe " DDS" signal, which indicates that a complete set of post-arbitrated input and output data is stable and available in the dual-oorted data memorv 22
- DDS Data Stable Strobe
- This oata set is reTerred to as post-aroitrated, as tne input values w ⁇ l have been arbitrated or resolved by this point in the program cycle
- this post- arbitrated oata set mav be comprised of uo to 65,536 (16-b ⁇ t) ords, as it will include both input and output values (and any other variables stored in the dual- ported data memory 22)
- one of the first functions in the program cycle of the process control computers 12a- 12b is to make output value decisions from the post- aroitrated input data obtained in the immediately preceding program cycle Accordingly, it should be appreciated that the post- arbitrated data set will include the arbitrated input values o from the current program cycle ana the output values from the immediately previous program cycle
- the front end communication system 10 5 must be sufficiently fast to obtain a copy of the Dre-lmk data sets before the process control computers 12a-12b need to have the ability to change one or more of these data values through the arbitration process. Accordingly, in the context of the present embodiment, the front end communication system 10 needs to be able to acquire a pre-link data set within ten milliseconds of the time that the SDSS signal was initially asserted in order to have the 0 assurance of data stability.
- the front end communication system 10 needs to be able to acquire a post-arbitrated data set within fifty milliseconds of the time that the DSS signal was initially asserted.
- each of these data sets need to be independently acquired from both of the process control computers 12a- 12b by each of the front end computers 18a-18b. Additionally, each of the front end computers 18a-18b must be independently acquired from both of the process control computers 12a- 12b by each of the front end computers 18a-18b. Additionally, each of the front end computers 18a-18b must be independently acquired from both of the process control computers 12a- 12b by each of the front end computers 18a-18b. Additionally, each of the front end computers 18a-18b must
- each of the front end computers In order to further facilitate the ability of the front end communication system to acquire the SDSS and DSS data sets without any data transfer blocknecks, and also provide the ability to group and time align the data sets being received, each of the front end computers
- the set of reflective buffers contained in the front end computer 18a is generally comprised of a ZERO buffer "ZL" 46a for the Left process control computer 12a, a ZERO buffer
- the iFQ circuit 30 writes to these left ano ⁇ gnt buffers in a round robin" fashion using DMA data transfers
- the IFQ circuit 30 will fill the ZERO buffer 46a with ore-link and post-arbitrated data of a particular process control cycle from the Left process control computer 12a Tnen, wnen pre-link and post-arbitrated oata for the next process control cycle is received from the Left process control computer 12a, the IFQ circuit will increment to the ONE buffer 50a in order to store this data
- the IFQ circuit 30 will turn to the TWO buffer 54a when pre-link and post-arbitrated data for the third process control cycle is received from the Left process control computer 12a in order to store this data
- the IFQ circuit 30 will return to address the ZERO buffer 46a for data storage.
- the IFQ circuit 30 will employ the same round robin sequence for individually transferring ore-link and post- aroitrated data to the three reflective buffers 48a, 52a and 56a that are used for the Right process control computer 12b
- Figure 1 shows three reflective memory buffers (46a, 50a and 54a) for the Left process control computer 12a, and three reflective memory buffers (48a, 52a and 56a) for the Right process control computer 12b
- the reflective memory buffers preferably include distinct reflective memory buffers for each of these events. Accordingly, a total of twelve reflective memory buffers are preferably provided in the front end computer 18. Additionally, each of these reflective memory buffers are individually tracked, so that the ordering of these buffers do not necessarily have to follow the regimen snown below: Second N: (ZERO-SDSS-L ZERO-DSS-L ZERO-SDDS- ZERO-DSS-R)
- Second N + 1 (ONE-SDSS-L ONE-DSS-L ONE-SDDS-R ONE-DSS-R)
- Second N (ONE-SDSS-L TWO-DSS-L ZERO-SDDS-R ONE-DSS-R)
- the delays required to transfer this information to the IFQ crcuit 30 and then transfer this information into the appropriate reflective memories may result in a wioertime sxew between these events as seen by the application software of the front end computer 18 than as seen by the process control computer and IFS circuit hardware.
- the application software of the front end computer 18 includes a procedure, referred to as "Ml Sync", which groups individual data transfer events into a cohesive set of buffers that represent a "snapshot" of the pre-link and post- arbitrated data for a particular process control cycle
- the Ml Sync procedure uses a set of reflective memory buffer management structures (Ml RMBMS) to track the status of incoming data transfers
- Ml RMBMS reflective memory buffer management structures
- Ml Sync records the required information in the appropriate Ml RMBMS data structure.
- Ml Sync determines that a complete set of buffers has been received and stored (that is, left SDSS, right SDSS, left DSS and right DSS)
- MI_RM_DATA global data structure
- Ml RM DATA includes the pointers to the currently available
- the most current time aligned set of reflective memory buffers may be TWO buffers 54a and 56a at one time interval, the ONE ouffers 50a and 52a at the next time interval, and the ZERO buffers 46a and 48a at the following time interval.
- Ml Sync will still maintain time alignment by using an appropriate timeout (for example, 700 milliseconds) for updating the Ml RM DATA pointers An indication will also be provided as to which buffer or buffers are unavailable.
- the buffer pointers within Ml RM DATA are protected by a mutual exclusion semaphore or "mutex" .
- Ml SYNC requests this mutex before copying the new pointers to
- Ml RM DATA releases it immediately after the copy is comolete
- a copy of the Ml RM DATA pointers is made by reouesting the mutex, copying these buffer pointers to a local data structure, and then releasing the mutex Since the application for querying or reading the data uses a copy of the pointer, contention for the mutex is minimized, and Ml Sync will be able to update
- Ml RM DATA with new pointers as soon as the next complete set of data has been stored.
- this method will enable the reading application to still access the same set of reflective memory buffers while Ml Sync updates Ml RM DATA with new pointers. Since reading apDlications will access the most current time aligned set of reflective memory buffers, it should be understood that a reading application could be accessing one set of reflective memory buffers (for example, the TWO buffers 54a and 56a), while a subsequent reading application could be given access to another set of reflective memory buffers (for example, the ONE buffers 50a and 52a) once Ml Sync updates Ml RM DATA with new pointers.
- applications which access the reflective memories will be able to run to completion before the referenced buffers are overwritten with new incoming data.
- applications requiring reflective memory data are assigned execution priorities high enough to allow them to run to completion in less than one second.
- the front end computer 18 could be configured with additional sets of buffers to allow the development of an application that may take longer to run to completion.
- the use of the front end computers 18a-18b also enables the communication system 10 to have the necessary intelligence to answer specific data requests.
- the use of the front end computers 18a-18b also permit a rapid check to be made that the process control computers 12a-12b are in fact continuing to send real-time data.
- the front end computers 18a-18b are also preferably programmed to make determinations as to whether read or write requests from the process control computers 12a- 12b should be granted with respect to the entity on the computer network 20 which has forwarded the request.
- the front end computers 18a- 18b contain both a security table and two permissive tables in their memories for facilitating these determinations.
- the security table is used determine whether communications will be permitted at all with various entities on the computer network 20, while the permissive tables are used to evaluate write command messages from an entity on the computer network which could affect specific Iocations in the dual-ported data memories 22a-22b.
- the front end computers 18a- 18b may also utilize at least one set of additional reflective buffers, such as Correlate buffers 58a and 60a.
- Correlate buffers 58a and 60a In light of the fact that the DSS data set will contain the post-arbitrated input value data from the current program cycle and the output value data that was based upon the post-arbitrated input values of the immediately preceding program cycle, it may be desirable to correlate into one data table the output values for a particular program cycie with the input values used to decide these output values.
- the front end computer 18a may employ the Correlate buffers 58a and 60a to store a copy of the post-arbitrated input values from the current DSS data set, and then wait for the alignment of the next DSS data set in order to store a copy of the output values from this suPsequent data set in the same Correlate Duffers in this regard, it should be appreciated that tnis copying procedure will be made from the most current time aligned set of reflective memory buffers
- Figure 2A shows a diagrammatic example of a data table in a time aligned buffer
- Figure 2B shows a similar example of a data table in the Correlate buffer CL.
- the time alignment capabilities of the front end computers 18a- 18b provide a powerful diagnostic tool for analyzing both the o p eration of the process control computers 12a-12b and the physical process being controlled. For example, the arbitration performed with respect to the input data values may be analyzed for both of the process control computers 12a- 12b, as ore-link and post-arbitrated input data values are time aligned and made available by the front end computers 18a-18b.
- the computer network 20 is shown in Figure 1 to generally include a direct control segment, a process information segment and a connection to a Wide Area Network "WAN". Each of these network segments preferably employ Ethernet compliant mediums and IEEE 802.3 compatible communication protocols.
- the direct control segment is comprised of dual Plant Area Networks "PAN-1 " and "PAN-2”
- wnile the process information segment is comprised of Plant Area Network "PAN-3”
- At least one bridge 62 is used to interconnect the PAN-1 and PAN-2 segments.
- at least one bridge 64 is used to interconnect the PAN-2 segment with the PAN-3 segment.
- Another bridge may be used to interconnect the PAN-1 segment with the PAN-3 segment.
- One or more bridges 66 may also be used to interconnect the PAN-3 segment with the WAN
- the front end computer 18a is coupled to the PAN-1 segment, while front end computer 18b is coupled to the PAN-2 segment. While a single plant area network could be provided, the use of dual plant area networks shown herein have certain communication and redundancy advantages over a single plant area network.
- the bridges will typically filter communications by Ethernet hardware addresses to reduce the amount of traffic on each of the network segments. For example, a communication between the security server 68 and the operator station 70 will not be transmitted across the bridge 62 to the PAN-1 segment.
- the bridges 62-66 also provide a layer of physical separation between the network segments, so that if a fault occurs on one of the network segments, then the fault will be prevented from adversely affecting the other network segments.
- one or more of the bridges are also used to filter communications on the basis of specific data communication protocol identifications to enhance the overall security of the network 20.
- the bridge 64 may be used to prevent the transmission of messages employing the Ethernet compliant protocol used by the security server 68 from one of the PAN- 2 and PAN-3 segments to the other.
- the bridge 64 may be use ⁇ to prevent the transmission of messages employing the Ethernet compliant protocol used to write information into the mailbox section 26 of the dual-ported data memory.
- the computer network 20 also includes a plurality of operator workstations, such as operator workstations 70 and 72. As shown in Figure 1 , these operator workstations may be located on different network segments, and the number of operator workstations will be dependent upon the particular process control application.
- One or more of these operator worKstations may be used to view or analyze data recei ed from the front end computers 18a- 18b. Additionally, these operator workstations may be used by an authorized control room operator to transmit the appropriate instructions to the front end computers 18a- 18b which will cause a command message to be conveyed to the process control computers 12a- 12b.
- the network 20 further includes a process information computer 74 which may o perform a variety of functions.
- the process information computer may be used to store a history of process data received from the front end computers 12a-12b.
- the process information computer 74 may be used to store the compilers needed to change the computer programs residing in the front end computers 18a- 18b, as well as the programs residing in the process control computers 12a-12b.
- the process information computer 74 may 5 also include loading assistant software for transferring operating program revisions to the process control computers 12a-12b.
- the network also includes a control room data manager computer 76, which may be used to perform various file serving and tracking functions among the computers connected to the network.
- An expert download assistant 78 is also provided to facilitate program revisions in 0 the front end computers 18a-18b.
- the loading assistant software in the process information computer 74 may be used to cause a new computer program to be downloaded to one of the process control computers 12a- 12b through at least one of the front end computers 18a-18b and the mailbox section 26 of the dual-ported data memory 22.
- the download assistant 78 may be resident in its own network computer, the download assistant could also 5 reside in a suitable network computer, such as the process information system computer 74.
- the loading assistant may also be used to cause the process control computer with the revised program to start operating in a mode which will enable real-time testing of the revised program.
- the process control computer will receive input data and make output decisions, but these output decisions will not be transmitted to the field 0 instrumentation devices. This will permit the plant engineer to evaluate the revisions, and even make further revisions if necessary before instructing the process control computer to assume an active mode of operation, such as the fox or dog modes.
- the revised program for the process control computers 12a-12b must be compiled from the the source programming language to an executable file or set of dynamically linked files.
- a unique identifier is embedded into the executable code during the compile procedure. This identifier represents (or is otherwise associated with) the version of the revised software for the process control computers 12a-12b Tne program version identifier is used to ensure proper alignment between the version of the program being executed by the process control computers 12a- 12b and the files/tables in the *r ont eno computers 18a- 18b used to evaluate write command messages to these process control computers
- each of the front end computers 18a-18b include two permissive tables, such as the "PL" permissive table 80a for the Left process control computer 12a, and the "PR" permissive table 82a for the Right process control computer 12b These permissive tables are used by the front end computers 18a- 18b to determine whether any o entity on the computer network 20 should be permitted to change the contents of s ⁇ ecific iocations in the dual- ported data memories 22a-22b.
- the data structure of the permissive table could be constructed to protect the contents of any memory location or area in the process control computers 12a-12b which could altered from a write command message 5
- a message is recei ed by a front end computer 18 from an entity on the network which uses the write command protocol, sucn as a write comman ⁇ message from one of the operator workstations 70-72
- a 'data write check" sub- routine will be called by the central process unit of front end computer
- the data write check routine will perform a comparison between the variable elements identified in the write command message and the 0 variable elements in the permissive table for which changes should be authorized or denied
- the front end computer 18a receives a write command message which seeks to increase/decrease an analog gain "AG" factor used by the program being executed by the Left process control computer 12a, the front end computer 18a will look up the element word for this particular AG factor in permissive table 80a and determine if a bit has been set to deny the 5 authorization needed to change
- the front end computer 18a will preferably send a reply message to the host entity on the computer network 20 that originally sent the write command message, to inform the host entity that a write error has occurred 0
- the PL and PR permissive tables stored in the front end computers 18a-18b need to be closely coordinated with the version of the program being executed by each of the process control computers 12a-12b
- the program version identifier 5 discussed above is also embedded into these permissive tables when they are compiled
- This program version identifier may then be sent to the process control computer 12 along with a verified write command message, so that the process control computer 12 will be able to confirm that the commanded variable change is appropriate to its program version
- the program version identifier from the permissive table is preferably altered by a suitable encryption algorithm before it is transmitted with the write command message to the
- the process control computer 12 receiving the write command message will then decode this version identifier, and compare it with the program version identifier embe ⁇ ded in its program to determine if their is a match. If the program version identifiers match, then the process control computer 12 will perform the commanded variable change. Otherwise, the process control computer 12 will respond by discarding the write command message and transmitting an approp ⁇ ate error message to the o front end computer 18.
- the PL and PR permissive tables are also preferably provided with a data structure which permits write command authorization determinations to be made for specific host entities on the computer network 20.
- the permissive table 80a may permit particular variable changes to be made from operator workstation 70 that are not allowed to 5 be made from operator workstation 72.
- the permissive tables may have several station specific table sections, as well as a default table section. Nevertheless, the ability may also be provided to bypass a check of the appropriate permissive table, through the use of a suitable password at a host entity on the computer network 20. However, in this event, a log should be created and stored in the front end computer 18 whicn will identify this transaction and the 0 identity of the host entity (for example, a CPU identifier).
- a passive operating mode may be used for the process control computer with the revised program while the other process control computer is in an active control mode, in such an event, the plant engineer may use the download assistant 78 during final program testing to issue write command messages for the passive process 5 control computer, while another plant engineer issues write command messages to the active process control computer through the same front end computer 18.
- the security server 68 is used to inform each of the computers residing on the network 20 who they may communicate with on the network.
- the security server stores a specific security table ⁇ or each o ⁇ the valid entities on the network
- Each of these security tables will ⁇ dent ⁇ y which ot the network computer entities a particular network computer may conduct bi- directional communications
- the security server 68 is shown in Figure 1 to store a security table "S1 " for the front end computer 18a, and a security table "S2" for the front end computer 18b
- the security server could also be used to send the PL and PR permissive tables discussed above to the front end computers 18, it is preferred that newly compiled permissive tables be received from the download assistant 78
- the download assistant is also preferably used to send the transfer map 37 intended for the IFS circuit 28
- the front end computer 18 will embed a random or pseudo-random number in a broadcast network message to request that the security server 68 identify itself as a prelude to sending the appropriate security table
- the security server will respond to this request with an acknowledgement message that utilizes a security protocol identifier which is different than that used with other types of network 0 messages
- this acknowledgement message will include the random number from the front end computer 18 in a transformed state
- a suitable encryption algorithm may be used to alter the random number, and the random number should have a bit length which will make it difficult for any unauthorized entity to decode (for example, 32 bits)
- the front end computer 18 will then either 5 reverse the encryption process to obtain the random number or encrypt its original random number to make a comparison between the transmitted and received random numbers Assuming that these random numbers match
- an additional validation procedure is preferably implemented More specifically, this additional validation procedure is utilized to permit communication between the front end computers 18a- 18b and any network entity for which a write command message may be recognized
- the front end computer 18 will send a contract offer message on a periodic basis to the Ethernet address of each host entities on the network 20 which it recognizes as having a write message capability
- Each of these contract offer messages will include a random or pseudo-random number or other suitably unpredicable message component In or ⁇ er for a nost entity to aole to nave its write command messages recognized, t must respond to its contract o ⁇ fer message within a predetermined period of time (tor example, 10 seconds) with a contract acceptance message that includes a transformed version o ⁇ this unpredicable message component
- any appropriate encryption algorithm be used for this purpose, it is preferred that this encryption algorithm be different than the encryption algorithm used to validate the transfer of a security table
- the front en ⁇ comouter 18 will then decrypt the random number embedded in the contract acceptance message to determine if a time limited communication contract will be established between the front end computer and this host entity at the specific Ethernet address for the host entity that was contained in the security table This time limited communication contract will ensure that a write command message link between a front end comouter 18 and a particular host entity will be reliable and specific
- the front end computer 18a will send a contract offer message to the Ethernet address of the operator workstation 72 which will contain a new random number (for example, 32 bits in length)
- the operator workstation 72 will respond with a contract acceptance message that includes an encrypted version of this particular random number
- the front end computer 18a will either decrypt this number with the contract algorithm key stored in its memory for this purpose or use the same encryption algorithm to compare the offer and acceptance numbers If these numbers match, then the front end computer 18a will be process write command messages from the operator workstation 72 for a predetermined period of time. Otherwise, if the numbers do not match, fhen the front end computer 18
- the communication contract established for write command messages is time limited to enhance the transmission security of these particular messages.
- the communication contract will automatically expire within twenty seconds after Deing initiated Nevertheless, in order to ensure that the ability to send write command messages is not interrupted, the contract offer messages should be sent from the front end computer 18 to each of the appropriate host entities on the network 20 on a periodic basis which will provide this continuity For example, with a communication contract of twenty seconds, it is preferred that the contract offers be transmitted at a rate of approximately every ten seconds.
- each of the host entities that are capable of transmitting recognizable write command messages will receive a new random number from each of the front end computers 18
- the front end computer will preferably make tnree tries to establish or maintain a time limited communication contract If no response is received from these three tries, then the the front eno comouter 18 will disable the write command authorization bit for the Ethernet address of this host entity from its security table In such an event, the affected host entity will not be able to have its write command messages processed by the front end computer 18 until the security server 68 transmits a new security table to the front end computer 18.
- Additional protection is also substantially provided by the guardian circuit in the stealth 0 interface circuit 16, the embedding of a program version identifier in the PL and PR permissive tables, and the encryption of the these program version identifiers by the front end computers 18a- 18b when a verified write command message is transmitted to the process control computer 12a-12b.
- the encryption algorithm used by the front end computers 18a- 18b for the program version identifiers is preferably different than 5 the encryption algorithm used for security table transfers or the encryption algorithm used to establish the time limited communication contracts for write command messages.
- FIG. 3 a block diagram of the stealth interface circuit 16 is shown. Reference will also be made to the schematic diagram of the stealth interface circuit 16,wh ⁇ ch is shown in Figures 4A-4B.
- the stealth interface circuit 16 is interposed between the internal bus 0 structure 100 of the process control computer 12 and the externally directed stealth port 102.
- the stealth interface circuit 16 is connected to bus structure 100 via a set of suitable buffers.
- buffer block 104 includes two 8-b ⁇ t buffer circuits U 17- U 18, which receive address information from the address bus on the process control computer 12
- buffer block 106 includes two 8-b ⁇ t buffer circuits U6-U7, which receive data information from the data bus 5 of the process control computer 12
- the stealth interface circuit 16 also includes a data control block 108, which is also connected to the bus structure 100 of the process control computer 12 As indicated in Figure 4A, the data control block 108 is preferably comprised of a Programmable Array Logic "PAL" circuit U 1 5 (for example, EP512) wnich is used to detect the SDSS and DSS signals from the process control comouter 12 As well known in the art, a PAL circuit has fusible links which may oe programmed so tnat a plurality of internal AND gates and OR gates will be configured to oerrormed a desired logic Tunction While a PAL circuit provides a relatively low cost way of implementing logic functions, it should be understood that other suitable circuit devices may oe used for this application It should also be noted that the PAL circuit is programmed to detect two extra strobe signals that may be generated by the process control computer 12, namely the "EXS1 " and " EXS2 ' signals One or both of these extra strobe signals may be used oy the process control
- the stealth interface circuit 16 also receives four control signals from the process control computer 12 which are used to access the dual-ported data memory 22 These signals are "/EN_DATAMEM”, “/EMR” , " R/W” and "MEMCLK The first three of these signals relate to whether the process control computer 12 seeks to read or write to the dual-ported data 5 memory 22
- MEMCLK is the memory clock signal referred to aoove which effe ⁇ ively divides the time in the machine cycle of the process control 12 available for accessing the dual- ported data memory 22
- the MEMCLK signal is a fifty percent duty clock signal, as shown in the timing diagram of Figure 5A
- the dual-ported data memory 22 may be accessed from the internal process control computer o port 100 when MEMCLK is Low Then, when MEMCLK undergoes a transition to a High state, the dual- ported data memory 22 may be accessed from the external stealth port 102.
- buffer block 1 10 includes two 8-b ⁇ t buffer circuits U 1-U2, which receive address information from the external stealth port 102
- buffer block 1 12 includes two 8-b ⁇ t buffer circuits U4-U5, which are capable of transmitting and receiving data information between the dual-ported 0 data memory 22 and the stealth port 102
- the stealth interface circuit 16 includes a arbitration circuit 1 14 which receives bus request signals from external entities on the stealth port 102 As shown in Figure 5B, the present embodiment provides four individual channel lines for the incoming bus request signals "/BR1. /BR4" Thus, the stealth interface circuit 16 enables up to four different 5 external entities to be connected to the stealth port 102
- the arbitration circuit 1 14 is shown in Figure 4B to comprise a four input asynchronous bus arbiter circuit U9 which will grant bus access to the first bus request signal received In this regard, a specific bus grant signal 7BG 1.
- the arbitration circuit 1 14 also nas an internal AND gate which will oroduce the any-ous-request signal ' /ANY BR" shown in the timing diagram of Figure 5A
- the stealth interface circuit 16 furtner includes a stealth oort control circuit 1 16, which is used to control access to the dual-ported data memory 22.
- the control circuit 1 16 is shown in Figures 4A-4B to como ⁇ se a PAL circuit U 16, a timer circuit U 10 and a set of t ⁇ -state buffers which are contained in chip U8.
- the PAL circuit U 16 will transmit the chip select signal "/CS" to the buffers 104 and 106 to latch or capture address and data information from the internal bus.
- the PAL circuit U 16 will also send the enable memory read signal "/B EMR" to the buffer 106 when the process control computer 12 needs to latch or capture data from the data bus 1 18 of the stealth interface circuit 16.
- the PAL circuit U 16 is responsive to both the MEMCLK signal and the central process unit clock signal "CP" of the process control computer 12. In the case of memory access from the external stealth port 102, the PAL circuit
- the PAL circuit U 16 will transmit the enable signal "/SP EN” to the buffers 1 10 and 1 12 to latch or capture address and data information from the external bus.
- the PAL circuit U 16 will also send the enable memory read signal "SW/R" to the buffer 1 12 when an external entity is permitted to latch or capture data from the data bus 1 18 of the stealth interface circuit 16
- the SW/R signal is received at the stealth port bus 102, and it provides an indication from the external entity the direction of data flow desired.
- the SR/W signal is active High for a read cycle and active Low for a write cycle.
- the SR/W signal is common to all four potential external users, and it should be held in a t ⁇ -state until the external user winning the bus receives its active Low /BR signal.
- the PAL U 16 also transmits the SW/R signal to the check point guardian circuit 120
- PAL circuit U 13 to initiate an evaluation to be made on the address of the dual-ported data memory 22 selected by the external entity for a write operation.
- the guardian circuit 120 is programmed to inhibit the transition needed in the chip enable signal 7CE" for accessing the dual- Dorted data memory chips U 1 1 -U 14, whenever the address is outside of the mailbox section 26.
- a memory read/write cycle from the stealth port 102 must be initiated by the external entity seeking to access the dual-ported data memory 22.
- This cycle is begun with the transmission of a bus request signal /BR from the external entity, such as front end computer 18a.
- the arbitrator circuit 1 14 Upon the receipt of any bus request signals, the arbitrator circuit 1 14 will transmit an active Low any-bus-request signal /ANY BR to the PAL circuit U 16.
- the any-bus- request signal is directed to an internal flip-flop of the PAL circuit U 16, which operates under the clock signal CP.
- the any-bus- request signal needs to be present before the -ailing edge of the ciock signal CP in order for stealth port access to occur when MEMCLK goes ⁇ gn, as shown in the timing ⁇ iagram o ⁇ Figure 5A If the latched any-bus-request signal is active, the stealth interface circuit 16 will begin a stealth port memory cycle Otherwise, the stealth interface circuit 16 win not initiate a stealth port memory cycle until the next MEMCLK signal period
- the /SP EN signal is generated from tne PAL circuit U 16 As indicated above, tnis signal will enable the address and data buffers on the stealth port The /SP EN signal will also enable the arbitration circuit 1 14, which issues a specific bus grant signal /BG for the external user which wins the bus Once the external entity o detects its bus grant signal, then it may transmit either the memory address it seeks to read or the address and data necessary for a write operation
- the chip enable signal /CE is delayed by the PAL circuit U 13 to allow for the delay introduced from the address buffer 1 10, as the address needs to be stable before the RAM chips U 1 1- U 14 are actually accessed
- the a ⁇ dress lines on the address bus 122 will be monitored by the 0 guardian circuit 120 to ultimately permit or deny write access to the stealth port 102
- the guardian circuit will not generate the active Low chip enable signal /CE, and thereby restrict an external entity on the stealth port 102 from writing to the particular address location in the dual-ported data memory 22 that it has selected In this event, the guardian circuit 120 will also generate a write address valid signal "WR AD VAL"
- the PAL circuit U 16 will respond by generating a write address error signal "WR AD ERR" for transmission to the external entity
- the write a ⁇ dress error signal is active High and valid only during the current memory access cycle, and this signal is common to all external entities
- guardian circuit 120 For stealth port accesses to valid write addresses, the guardian circuit 120 will
- the PAL U 16 will also cause the write enable signal /WE for the RAM chips U 1 1-U 14 of the dual-ported data memory 22 to become active, and the rising edge of the /WE signal is used to write data into these RAM chips
- the control circuit 1 16 also includes a timer circuit U 10, which will generate a
- FIG. 6A-6E a set of flow charts is shown to furtner illustrate various aspects of the security and validation methods discussed above
- Figure 6A shows the part of the boot up procedure of the front end computer 18 which is directed to a search for the security server 68
- Figure 6B shows the orocedure for transferring the security table (for example, security table 51 )
- Figure 6C shows the procedure for establishing a time limited communication contract with each of the operator stations identified in the security table as having write command ability
- Figures 6D-6E combine to illustrate the procedure for validating
- block 200 indicates that the front end computer " FEC" sends a broadcast message over the computer network 20 to request that the security server 68 identify itself to this front end computer
- This message preferably utilizes the Ethernet protocol for security messages
- the content of this broadcast network message is generally 5 shown in block 202
- the network message includes a destination address "FF-FF- FF- FF-FF-FF" which will cause the message to be sent to every entity that is operatively coupled to the PAN-1 and PAN-2 segments of the computer network 20.
- the network message also includes the source address of the front end computer
- the network message also includes a type indication, namely " REQUE5T_SECURITY_SERVER"
- the CPU identification is given for the process control computer 12 to which the front end computer 18 is connected
- the data portion of the network message also includes an unpredicable key, such as a 32 bit random number. As discussed above, this random key is used to verify the identity of the security server 68
- Block 204 shows that the security server 68 will check all of the information in the 5 broadcast network message, sucn as the physical Ethernet address of the front end computer and the CPU ID of its process control computer 12. Assuming that this information corresponds to the information stored in the security server for this front end computer, an acknowledgement message 206 will be sent back to the physical Ethernet address of the front end computer In order to enable the front end computer to verify the identity of the security 0 server 68, the acknowledgement message 206 includes a transformation of the random key sent from the front end computer 18 As indicated above, this transformation is performed with an encryption algorithm which is unique to messages from the security server 68
- Diamond 208 shows that the front end computer 18 will wait a predetermined amount of time to receive the acknowledgement message. If the acknowledgement message is 5 not received within this timeout perrod, then the front end computer will use the last security table stored in its memory or the default security table if this is the first time the front end computer 18 is being brought into operation (block 210). However, if the acknowledgement message 206 is received in time, then the front end computer 18 will check its random key against the transformed version of the key wnich was contained in the acknowledgement message (block 212).
- this comparison may be accomplished by either performing a transformation on the random key using the encryption algorithm for security messages or using a corresponding decryption algorithm If the transformed key matches the expected key number (diamond 214), then the front end computer 18 will proceed to the procedure shown in Figure 6B for transferring a copy of the current security table from the security server 68 (block 216). Otherwise, the front end computer will exit this portion of the boot up procedure and stop accumulating further network communication capability (block 218) In one form of the present invention, the front end computer 18 may be permitted to o conduct network communications at this point, but not process any write command messages received from an entity on the computer network 20, until such time as a security table is successfully transferred to the front end computer
- block 220 shows that the front end computer 18 starts the procedure for transferring a cooy of the security table by sending a request message to the 5 specific (logical or physical) Ethernet address of the security server 68.
- This physical Ethernet address is the address learned and stored through the boot up procedure discussed above in connection with Figure 6A.
- Block 222 indicates that this request message includes an identification of the CPU ID for the process control computer being serviced by the front end computer 18. Additionally, the front end computer 18 will also inform the security server 68 as 0 to wnether this CPU ID is for the Left process control computer 12a or the Right process control computer 12b through the Mode data (for example, ML for the Left process control computer).
- the security server Once the security server receives this request message, it will check the data contained in the message, and build a control message for the front end computer 18 (block 224) As shown in block 226, this control message will inform the front end computer 18 how 5 many bytes are contained in the security table for the process control computer identified in the request message. The front end computer 18 will respond with an acknowledgement message that will contain a new random key (blocks 228-230). The security server will then transmit the security table (for example, secu ⁇ ty table S 1 for the Left process control computer 12a) with the transformed random key (blocks 232-234). The front end computer 18 will then 0 determine if the transformed key matches the expected key (diamond 236).
- the security table for example, secu ⁇ ty table S 1 for the Left process control computer 12a
- the front end computer 18 will use the old or existing security table stored in its memory (block 238). Otherwise, the front end computer 18 will store the new security table for use, and sen ⁇ an acknowledgement message back to the security server (blocks 240-244). While the front end computer 18 could also be provided with the editing capability to create its 5 own security table, it is preferre ⁇ that a separate network security server be employed in order that the front end computer be dedicated to the functions identified above.
- the front end computer 18 begins by creating a new watch- oog key, wnich is represented bv a 32 bit random numoer (block 246) The front end computer 18 will then send a watch-dog message in turn to tne physical Ethernet address of each of the operator stations (identified in the security table as having write command message capability) In this regard, it should oe aboreciated that these are individual watch-dog messages which include a new watch-dog key for eacn message (block 248) Each operator station which receives such a watch-dog message will respond with a watch-dog reply message that includes a transformation of the watch-dog key (blocks 250-252)
- the front end computer 18 will preferably wait for a suitable timeout period for a reply, such as ten seconds (diamond 254) If the operator station does not reply to the watch-dog request message 248 within this timeout period, the front end computer 18 will make additional attempts to make contact (diamond 256 and block 258) If a reply is not received from this operator station after all of these attempts, then the front end computer 18 will disable the write command ability of this particular operator station (block 260) However, it should be appreciated that this write command ability may subsequently be re-established, sucn as wnen an updated security table is transferred to the front end computer 18 In this regard, it should be noted that the security server 68 may initiate the security table transfer procedure discussed above through a suitable network message to the front end computer 18.
- the front end computer 18 will determine whether the transformed watch-dog key contained in the reply message matches the expected key number (diamond 262). If a match is not found through this comparison (as discussed above), then the front end computer 18 will ignore the reply message (264) At this point, the front end computer 18 could again attempt to establish a time limited communication contract with this operator station or disable its write command abilities. In the event that a match was found, then the front end computer 18 will copy the previous, valid watch-dog key of this operator station from the current key position to the old key position (block 266) Then, the front end computer 18 will save the transformed watch-dog key received in the reply message in the current key position.
- Tnis message ore ⁇ erabiy utilizes the standard Ethernet protocol for communication between the front end comouter 18 and other entities on the computer network 20
- tne write command message will include not only the var ⁇ able(s) sought to changed, but also the watch ⁇ dog key from the time limited communication contract, the CPU identification of the recipient process control computer, and the program version identification of this process control computer 12
- the front end computer 18 will then perform several checks on this write command message For example, the front end computer 18 will examine the security tabie to
- the front eno computer will check the security table to determine if the write command bit was set
- the security table contains not only the Ethernet address of every valid entity on the computer network 20 who can communicate with the front end computer, but also an indication of whether these entities have write command privileges
- the security table may contain additional information pertaining to each of these entities, such as a CPU identification and whether or not these
- 20 entities may request specific types of information from the process control computer, such as alarm messages. If the security table does not have the bit set to indicate write command privileges, then the front end computer will return the write command message to the operator station (or other source entity), and log this error (block 276).
- the front end computer will determine whether or not the watch- dog key (contained in the write command message) matches either the current or old watch- ⁇ og keys (diamond 278). If a match is not found, then the front end computer will return an invalid watch-dog message to the operator station (block 280). If a match was found, then the front end computer will preferably check to see if the program version identification contained in the write command
- the front end computer 18 will also check to see if the write command message
- the ability to bypass the permissive table may be considered a special privilege which should require the use of a password or physical key which is assigned to the operator with this privilege.
- the front end comouter will still oreferably creek the permissive table (for example, permissive table 80a) to determine if a bypass is permitted for the specific permissive table or table section that would otherwise oe addressed (diamond 288) If a bypass of this oermissive table is not permitted, then the front end computer will return a message to the oDerator station to indicate that no write access is available in this way (block 290) If a bypass of the permissive table is permitted, then the front end comouter will transmit the write command message to the reciDient process control computer with a transformed version of the program version identification stored in the permissive table of the front end computer (block 292) The recipient process control comouter 12 may then determine whether this transformed o program version identification matches the program version identification of its operating program before deciding to change the va ⁇ able(s) iisted in the write command message.
- the permissive table for example, permissive table 80a
- the front end computer 18 will examine the permissive table to determine if the the va ⁇ able(s) to be changed have their write command bit set (diamond 294) If the write 5 command bit is not set for any one of these variables, then the front end computer will return a no write access message to the operator station (block 296) Otherwise, if the front end computer determines that the write command message is acceptable, then it will transmit the message to the recipient process control computer as discussed above (block 292).
- FIG. 7 a block diagram of the application software 300 for the 0 front end computer 18 is shown
- Figure 7 shows the interaction of the application software with the Q-bus 302 of the front end computer 18 and with the Ethernet services 304 for the computer network 20
- a bi-directional line is provided between the Q-bus 302 and the IFQ driver 308
- the IFQ driver 308 represents the device driver software for controlling the communicating with the CPU of the front end computer 18.
- IFQ driver 308 is coupled to the "Ml Sync" subsystem 310 through a data store event 312
- the Ml Sync subsystem receives notification of DMA completions from the IFQ driver 308, such as when the SDSS data from one of the process control computers 12a- 12b has been completely received in the appropriate Interim buffer (for example, Interim buffer 46a or 48b)
- Interim buffer 46a or 48b The reflective memories 46a-56a from Figure 1 are shown in Figure 7 as reflective memories
- FIG. 30 314 Figure 7 also illustrates that the reflective memories 314 are operatively coupled to the Q- ous 302 of the front end computer 18
- the Ml Sync subsystem 310 represents that portion of the application software 300 which is responsible for synchronizing the incoming SDSS and DSS data frames from each of the process control computers 12a- 12b through the operation of the reflective memories 314,
- the Ml Sync subsystem also notifies the " Ml MOD Health” module 316 and “System Messages” module 318 when a data frame is available for processing Additionally, the Ml Sync subsystem 310 is also used to detect whether or not reflective memory updates are not occurring, such as when one of the process control computers has stopped sending data to tne front eno computer 18 This procedure is implemented through the "MOD Status ' module 320 and the "Ml Watchdog ' module 322.
- the Ml Watchdog module 322 uses a two-second timer to detect if the front end comouter 18 has stopped receiving data from either of the process control comouters 12a-12b
- the Ml MOD Health module 316 processes health bit changes in the data being received by the front end computer 18 from the process control computers 12a- 12b. In this regard, the Ml MOD Health module 316 sends these changes to the " EVT Event Handler" module 324.
- the Ml System Messages module 318 processes incoming system messages from the process control computers, and it queues any requests to the EVT Event o Handler module 324
- the EVT Event Handler module 324 processes event buffers, formats text for output to the Print Services module 326, and records errors and other events in an event log
- the reflective memories 314 are coupled to the "Ml CISS Memory Read " module 328, which performs read operations on the reflective memories
- the Ml CISS 5 Memory Read module 328 formats ⁇ uery responses into the standard Ethernet protocol for transferring data/messages, and directs the response to the requesting network entity via port 330.
- the "Nl CISS" module 332 receives incoming query requests from a network entity using the standard protocol for transferring data/messages.
- the Nl CISS module 332 performs an initial security check on the message, and routes the request to the appropriate process es 0 determined by the message type For example, the Nl CISS module 332 will route a read data message to the Ml CISS Memory Read module 328. Additionally, the Nl CISS module 332 will route program download requests to the "Ml Download Handler" module 334. Other request messages will be routed to the "Ml Message Services” module 334.
- the application software 300 also includes modules which facilitate 5 communication with a User Interface
- the User Interface is used to provide a window into the operation of the front end computer 18, as opposed to an interface to one of the process control computers 12a-12b.
- the User Interface software may be accessed "locally” through a terminal connected directly to the front end computer 18
- the User Interface software may also be accessed “remotely” through an application that could be run from the 0 security server 68
- the User Interface is used to disable or re-enable network communications for a specific protocol, perform diagnostic functions, re-boot the front end computer 18, monitor reflective memory updates, monitor network activity, and otherwise manage access to privileged front end computer functions.
- the application software modules that handle User Interface requests are the "Nl 5 Remote User” module 338, the " Ul Local” module 340 and the “ Ul Services” module 342.
- the Nl Remote User module 338 receives all messages having the protocol for User Interface communications, and it forwards valid requests to the Ul Services module 342.
- the Ul Services module 342 provides a data server for both local and remote user requests.
- the U I Local ⁇ nodule 340 handles tne local User interface display screens in order to oisolay responses on the 'ocal terminal.
- the aopiication software 300 also includes an " Nl Transmit Done” module 344, wnicn receives notification of Ethernet-write completions and maintains a free queue of network interface transmit message buffers. Additionally, an " EVT File Mai ⁇ t” module 346 is used to delete aged event log files. Furthermore, an " Nl Watchdog” module 348 and an “ Nl SCSP” module 350 to implement the watchdog security process discussed above. In this regard, the Nl Watchdog module 348 sends watchdog request messages to the operator stations, and the Nl SCSP module 350 processes the reply messages (as well as all other network messages
- the Nl Watchdog module 348 also checks to see if reply messages were received to each of the watchdog request messages.
- the Nl SCSP module 350 forwards all other security protocol messages to the "CFG Config Manager" module 352.
- the CFG Config Manager module 352 processes the security requests and performs the initial loading of the
- the CFG Config Manager module 352 also performs the loading of a memory map to be discussed below in connection with Figure 8.
- the application software 300 also includes a "MIF Master Process” module 354, which performs the basic initialization routines to create all of the other front end computer processes.
- the MIF Master Process module 354 is also used to detect an unexpected termination of any of these processes.
- FIG. 8 a diagrammatic illustration of the configuration for the front end computer 18a is shown. Specifically, Figure 8 illustrates that the CFG Config Manager module 352 interacts with the security server 68 and the download assistant 78 to obtain the information necessary to configure the front end computer 18a on boot up. In this regard, the CFG Config Manager module 352 is responsive to requests from the MIF Master Process module
- the CFG Config Manager module 352 will locate the security server 68 through the broadcast network message (as described above) and load the security table SI which is ultimately received from the security server. Additionally, the CFG Config Manager module 352 will also load both of the permissive tables 80a-82a from the download assistant 78. The CFG Config Manager module 352 also receives a
- each of the process control computers 12a-12b such as the memory map 356 shown in Figure 8
- the memory maps are used to enable the front end computer 18a to build the transfer tables (for example, transfer table 37) and interpret the data received in each of the reflective memory buffers 314.
- each of the memory maps identify the data which is stored in each addressable location of the dual-ported data memory 22 for each of the
- the memory map divides the dual- ported data memory 22 of the process control computer 12 into logical segments.
- the first set of segments are used for SDSS data values, while the DSS data values include the SDSS memory segments, as well as additional segments.
- the Ml Sync subsystem 310 is resDonsible for grouomg the DMA comoletion events relative to the transfer of SDSS and DSS data for both process control comouters 12a- 12b into a cohesive Dair of data tables that reoresent data for a given process control cycle snap-snot F or purposes of this discussion these DMA completion events will be referred to as the Left SDSS buffer, the Right SDSS buffer, the Left DSS buffer and the Right DSS buffer The exact order in wnich these data buffers are received may vary, but the SDSS buffers will precede the DSS buffers
- the MI Svnc suPsystem 310 is responsive to the above identified DMA events In tms regard, the Ml Sync subsystem 310 will wait for the completion of a DMA event, and then o check the status to determine the type of buffer received If the buffer received is an SDSS buffer and the front end computer 18 has already received a corresponding DSS buffer, then final completion processing will be performed Likewise, if the buffer for this type has already oeen received, final completion processing will be performed If the buffer received is not the first buffer, then the Ml Sync subsystem 310 will check the time difference between the current 5 time and the time at which the first buffer was received If this difference exceeds a predetermined tolerance, sucn as 0 7 seconds, then the steps for final completion processing will be performed If this is the first buffer (for example, the Left SDSS buffer), then the time that this buffer was received will be recorded If this buffer was not expected at this point, then its status will be changed to expected The pointer to this buffer will also be recorded, 0 and the buffer will be marked as received
- the Ml Sync subsystem 310 will also check to see if all expected buffers have been received (for example, the Left Right SDSS and Left/Right DSS buffers) If all the expected buffers have been received, then final completion processing will be performed During final completion processing, the buffer pointers for the received buffers will be copied to a system 5 ⁇ ata structure which will allow other applications to access this data This procedure is protected by a mutual exclusion semaphore, which is referred to as the "mutex" Additionally, the error counters will be zeroed for all received buffers If any expected buffers were not received, the associated error counters will be incremented If the error counters exceed the allowed threshold, then the affected buffers will be marked as not expected Then all buffers 0 will be marked as not received in order to set up the processing for the next set of buffers
- RM_ STATUS Word Indicates current reflective memory status
- LEFT_SDSS_PTR Pointer to current left SDSS reflective memory buffer
- FOX_DSS_PTR Pointer to current fox DSS reflective memory buffer
- DOG_DSS_PTR Pointer to current dog DSS reflective memory buffer
- DOG MAP PTR Pointer Pointer to current memory map (left or right) for the current dog buffer
- Info byte for outbound CISS requests satisfied from the left buffer Includes fox/dog status.
- Info byte for outbound CISS requests satisfied from the fox buffer Includes left/right status.
- Info byte for outbound CISS requests satisfied from the dog buffer Includes left/right status.
- Ml RMBMS Reflective Memory Buffer Management Structure
- MI_RMB_STATUS_TYPE defined below data structures.
- Each RMBMS entry is used to keep track of a specific r ef iective memory type (left/right SDSS and DSS). Symbolic indices are defined to access this array: Ml RM_L_SDSS,
- DMA EVENT Object Contains the VAXELN object ID for the event signaled
- PEND BUFF PTR Pointer Contains a pointer to the DMA buffer received for this memory type in the current time window. Reset to null by Ml Sync upon copying pointers to Ml RM DATA.
- RMB_STS Longword Longword bit masks indicating the status of this reflective memory buffer.
- the individual bit fields are listed below.
- RMB_STS__V Bit Bit in RMB_STS that indicated that EXPECTED the associated strobe for this reflective memory type is enabled, thus indicating that DMA completions are expected.
- RMB_STS_V_ Bit Bit in RMB_STS used by Ml Sync RECEIVED to indicate that a DMA completion for this reflective memory type has occurred in the current DMA time window Cleared wnenever a complete set of buffers has been received, and then set for each individual buffer type as it is received
- DSS BUFF completion for this reflective memory type has occurred in the current DMA time window Cleared whenever a complete set of buffers has been received, and then set for each individual buffer type as it is received Indicates if the reflective buffer type in question is either for the left or right DSS reflective memory buffer
- RMB_STS_ V_ Bit Indicates if the associated strobe
- CONS ERR COUNT Longword Specifies the number of consecutive receive failures for this buffer type.
- ADSB Structure Specifies the Asynchronous Data Status Block used by the drive to indicated DMA completion status
- This structure is of the IFQ$ ADSB type and includes a status field and a buffer number field
- BUFFER PTR Pointer The BUFFER PTR array the addresses of up to eight
- BUFF HIST IDX Longword Index to the BUFF HIST PTR array Indicates the most recently updates buffer.
- Array(8] Indicates the buffers received in the last eight seconds.
- BUFF HIST IDX points to the most recent entry.
- MOD TASK Longword Indicates the PCC task state as indicated by the most recent reflective memory update. Valid only if RMB STS V DSS BUFF is set.
- DMA_BUFFER_ Longword Specifies the number of DMA buffers currently in use. COUNT Copied from MIF_MP.NUM_DMA_BUFFERS on startup.
- ABSTRACT Synchronizes receipt of in-incoming DMA buffers
- Indices to the MI_RMBMS array are M1_RM_L_DSS, MI_RM_R_DSS, MI_RM_L_SDSS and Ml RM R SDSS.
- MI_TM_AUX Signaled to tell Ml System Messages to process
- MI_TASK_STATE_R to determine FOX/DOG status.
- MI_RM_AUX Set to 1 to indicate receipt of data.
- CONS_ERR_COUNT *.CONS_ERR_COUNT + 1 IF *.CONS_ERR_COU NT ⁇ 5 Then
- rm__buffer_ptr *.BUFFER_PTR[*.ADSB.buffer_number - 1]
- MI_RM_AUX.LEFT_RM_PTR rm_buffer_ptr Signal MI_RM_AUX.HEALTH_L_EVENT
- MI_RM_AUX.RIGHT_RM_PTR rm_buffer_ptr Signal MI_RM_AUX.HEALTH_R_EVENT Signal MI_RM_AUX.SYSMSG_R_EVENT ENDIF ENDIF
- MI_RM_DATA.RM_STATUS - state 5
- MI_RMBMS MI_SDSS_L_IDX.
- MI_RM_DATA.LEFT_DSS_PTR
- MI-RMBMS MI_DSS_R_IDX.PEND_BUFF_PTR 5
- MI_RM_DATA.FOX_DSS_PTR null
- MI_RM_DATA.DOG_DSS_PTR null
- MI_RM_DATA.FOX_MAP_PTR null 0
- MI_RM_DATA.DOG_MAP_PTR null
- MI_RMBMS MI-DSS-L-IDX.
- OD_STATUS fox status or eagle status
- MI_RMBMS MI_DSS_L_IDX.PEND_BUFF_PTR
- MI_RM_DATA.FOX_MAP_PTR Addr (M EMORY_MAP_L_TABLE) Set MI_RM_DATA.FOX_INFO_BYTE left/right bit /* bit 0 7 Set MI_RM_DATA.LEFT_I NFO_BYTE prime bit /* bit 2 */
- MI_RM_DATA.FOX_SIDE 0 /* Left */ IF MI RMBMS (Ml DSS. R IDX).
- MOD STATUS dog status or "task B"
- MI_RM_DATA.DOG_DSS_PTR
- MI_RMBMS MI_DSS_R_IDX.
- MI_RM_DATA.DOG_I FO_BYTE left/right bit MI_RM_DATA.DOG_SIDE 1 /* Right 7 ENDIF
- MI_RM_DATA.FOX_DSS_PTR
- MI_RM_DATA.DOG_DSS_PTR
- MI_RM_DATA.DOG_SIDE 0 /* Left 7
- FIG. 9 a diagrammatic illustration is shown of the relationship between the reflective memory buffers 314 in the front end computer 18a, the transfer map 37 in the IFS circuit 28 and the dual-ported data memory 22 in the process control computers 12a- 12b.
- the data memory 22 is shown to include only two segments.
- the transfer map 37 indicates that data memory addresses 2000 to 2002 (hex) in the first segment, and data memory addresses 4100 to 4105 (hex)in the second segment are to be transferred to the reflective memory buffer 46a. More specifically, it should be observed that the transfer map 37 creates a block of contiguous data elements from memory Iocations in the data memory 22 which are not necessa ⁇ iy contiguous.
- a block diagram of the IFS circuit 28 is shown.
- the individual transmitters and receivers for example, transmitter 38a and receiver 40a
- the IFS circuit 28 also includes control blocks 402-404 which govern the transfer of data/address signals to and from the transmitter/receiver block 400.
- the IFS circuit 28 includes both an address buffer 406 and a data buffer 408 to facilitate these signal transfers.
- An address latch 410 is also provided for sending a data memory address to the stealth port Similarly, a transceiver 412 is provided to enable the IFS circuit 28 to send or r ece ⁇ ve data information via the oata bus of the steaitn interface circuit 16
- the IFS circuit 28 also includes a stealth timing and control circuit 414
- the stealth timing and control circuit 414 includes one or more Programmable Array Logic circuits to implement a state macnine for processing specific signals to or from the stealth interface circuit 16 For example, when the SDSS signal is received, it provides an indication to the the IFS circuit 28 that a valid window exists for reading from the data memory 22 Assuming that the arbitration circuit on the stealth interface ci rcuit 16 also grants access to the data memory 22, then the stealth timing and control circuit 414 will appropriately set the control status register 416 The data out control circuit 404 will respond by causing a DMA counter circuit 418 to start counting down to zero from a pre-set value.
- the DMA counter 418 will decrement with each data word read from the data memory 22
- the DMA counter 418 in turn controls a DMA word count circuit 420 which generates an address in the transfer map 37
- the DMA word count circuit 420 points to an address in the transfer map 37, which in turn points to an address in the data memory 22
- the IFS circuit 28 will read each of the locations of the data memory 22 that are specified in the transfer map 37 for the particular window permitted by the process control computer 12 through the stealth interface circuit 16.
- the IFQ circuit 30 includes the Intel 80186 microprocessor, as discussed above, and the program for this microprocessor is stored in EPROM 420. Additionally, an address latch 422 is coupled to the address bus 424 of the microprocessor 42 Similarly, a data buffer 426 is connected to the data bus 428 of the microprocessor 42 A 64Kb RAM circuit 430 is also coupled to both the address bus 424 and the data bus 428 The RAM circuit 430 is used to store system data, such as one or more stacks and other operational data structures for the microprocessor 42
- the IFQ circuit 30 also includes a fiber interface "daughter" board 432, which contains the circuits directly responsible for transmitting and receiving signals over the fiber optic cables 32
- block 434 includes the two channels of light converters and receiver circuits
- block 436 includes the two channels of light converters and transmitter/receiver circuits, as discussed above.
- Block 44 represents the two 128Kb data buffers used for initially storing SDSS and DSS data which is asynchronously received from the process control computers 12a-12b, as discussed in connection with Figure 1
- These "link" data buffers are preferably implemented using two independent memories in a dual-port configuration, one for each fiber optic channel, in order to provide real-time uninterrupted gathering of process data and messages from the IFS circuits
- the block 438 represents the provision of at least one word register (for each fiber ODtic cnannei) used to hold serial data to be transmitted to one of the process control computers 12a-12b
- the block 440 represent the logic circuits for controlling the storing of information into tne oata buffers 44 and tne word register 438
- Tne logic circuits 440 includes one or more Programmable Array Logic ("PAL") circuits for imDlementmg a state machine for handling these data write operations For example, wnen a forty bit data frame is received from one of the process control computers 12a- 12b, the logic circuits 440 will decode the address and control bit in order to steer the data bits to the appropriate memory location in the data buffers 44
- the fiber interface daughter board 432 also includes an interrupt circuit block 442 which contains the interrupt logic for helping the microprocessor 42 understand the state of the data write activities In this regard, at least two separate interrupt lines are used to interconnect the interrupt circuit block 442 with the microprocessor 42 (one per fiber optic channel).
- Both the IFS circuit 28 and the fiber interface daughter board 432 of the IFQ circuit 30 also include a PAL state machine which examines incoming frames for errors (for example, parity errors and 4B/5B link errors).
- a PAL state machine which examines incoming frames for errors (for example, parity errors and 4B/5B link errors).
- all of the state machines on the IFQ circuit 30 operate from a 20MHz clock signal which is derived from the 10M Hz clock signal of the microprocessor 42.
- the microprocessor 42 is programmed to provide at least two DMA engines for moving data
- the microprocessor 42 will respond to appropriate interrupt signals from the interrupt circuit block 442 by moving data from the data buffers 44 to a dual-ported 64Kb RAM circuit 444, which acts to provide a bucket brigade storage medium.
- the dual-ported RAM circuit 444 for example, 8Kb
- the DMA state machine in the first in, first out (“FIFO") DMA control block 446 will move this data over the Q-bus 302 of the front end computer 18.
- Memory cycles are oreferably interleaved between both the microprocessor 42 system bus and the Q-bus, with the system bus of the microprocessor 42 given top priority.
- a status register circuit 448 and a CSR circuit 450 are provided to transfer status and control information. Additionally, as shown in Figure 1 1, an address buffer 452 and a DMA/FIFO counter 454 are also coupled to the address lines of the dual-ported RAM circuit 444. Similarly, a DMA/FIFO data buffer 456 for the Q-bus 302 and a data buffer for the microprocessor 42 are also coupled to the data lines of the dual-ported RAM circuit 444.
Landscapes
- Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Automation & Control Theory (AREA)
- General Engineering & Computer Science (AREA)
- Quality & Reliability (AREA)
- Manufacturing & Machinery (AREA)
- Computer Security & Cryptography (AREA)
- Theoretical Computer Science (AREA)
- Computer Hardware Design (AREA)
- Software Systems (AREA)
- Hardware Redundancy (AREA)
- Computer And Data Communications (AREA)
- Multi Processors (AREA)
- Communication Control (AREA)
Abstract
Description
Claims
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP97109414A EP0810499B1 (en) | 1992-06-12 | 1993-06-01 | Secure front end communication system and method for process control computers |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US89892392A | 1992-06-12 | 1992-06-12 | |
US898923 | 1992-06-12 | ||
PCT/US1993/005208 WO1993025948A1 (en) | 1992-06-12 | 1993-06-01 | Secure front end communication system and method for process control computers |
Related Child Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP97109414A Division EP0810499B1 (en) | 1992-06-12 | 1993-06-01 | Secure front end communication system and method for process control computers |
EP97109414.9 Division-Into | 1997-06-10 |
Publications (2)
Publication Number | Publication Date |
---|---|
EP0645028A1 true EP0645028A1 (en) | 1995-03-29 |
EP0645028B1 EP0645028B1 (en) | 1997-12-29 |
Family
ID=25410232
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP97109414A Expired - Lifetime EP0810499B1 (en) | 1992-06-12 | 1993-06-01 | Secure front end communication system and method for process control computers |
EP93914299A Expired - Lifetime EP0645028B1 (en) | 1992-06-12 | 1993-06-01 | Secure front end communication system and method for process control computers |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP97109414A Expired - Lifetime EP0810499B1 (en) | 1992-06-12 | 1993-06-01 | Secure front end communication system and method for process control computers |
Country Status (9)
Country | Link |
---|---|
US (2) | US5428745A (en) |
EP (2) | EP0810499B1 (en) |
JP (1) | JPH07507893A (en) |
KR (2) | KR100302222B1 (en) |
AU (1) | AU4400993A (en) |
CA (1) | CA2137464C (en) |
DE (2) | DE69316009T2 (en) |
ES (2) | ES2162659T3 (en) |
WO (1) | WO1993025948A1 (en) |
Families Citing this family (87)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5964835A (en) * | 1992-12-17 | 1999-10-12 | Tandem Computers Incorporated | Storage access validation to data messages using partial storage address data indexed entries containing permissible address range validation for message source |
US5631897A (en) * | 1993-10-01 | 1997-05-20 | Nec America, Inc. | Apparatus and method for incorporating a large number of destinations over circuit-switched wide area network connections |
US5544077A (en) * | 1994-01-19 | 1996-08-06 | International Business Machines Corporation | High availability data processing system and method using finite state machines |
DE59407059D1 (en) * | 1994-10-25 | 1998-11-12 | Rieter Ingolstadt Spinnerei | Backplane control for spinning machine |
US5872917A (en) * | 1995-06-07 | 1999-02-16 | America Online, Inc. | Authentication using random challenges |
US5870473A (en) * | 1995-12-14 | 1999-02-09 | Cybercash, Inc. | Electronic transfer system and method |
US5758060A (en) * | 1996-03-05 | 1998-05-26 | Dallas Semiconductor Corp | Hardware for verifying that software has not skipped a predetermined amount of code |
US5727142A (en) * | 1996-05-03 | 1998-03-10 | International Business Machines Corporation | Method for a non-disruptive host connection switch after detection of an error condition or during a host outage or failure |
US8229844B2 (en) | 1996-06-05 | 2012-07-24 | Fraud Control Systems.Com Corporation | Method of billing a purchase made over a computer network |
US20030195848A1 (en) | 1996-06-05 | 2003-10-16 | David Felger | Method of billing a purchase made over a computer network |
US7555458B1 (en) | 1996-06-05 | 2009-06-30 | Fraud Control System.Com Corporation | Method of billing a purchase made over a computer network |
US6039245A (en) * | 1996-06-10 | 2000-03-21 | Diebold, Incorporated | Financial transaction processing system and method |
US7167924B1 (en) | 1996-06-10 | 2007-01-23 | Diebold, Incorporated | Financial transaction processing system and method |
US5822434A (en) * | 1996-06-19 | 1998-10-13 | Sun Microsystems, Inc. | Scheme to allow two computers on a network to upgrade from a non-secured to a secured session |
EP0972247B1 (en) * | 1996-08-02 | 2004-03-17 | Hewlett-Packard Company | Method and apparatus for allowing distributed control of shared resources |
EP0825506B1 (en) * | 1996-08-20 | 2013-03-06 | Invensys Systems, Inc. | Methods and apparatus for remote process control |
US6912652B2 (en) * | 1996-11-08 | 2005-06-28 | Monolith Co., Ltd. | Method and apparatus for imprinting ID information into a digital content and for reading out the same |
US5978918A (en) * | 1997-01-17 | 1999-11-02 | Secure.Net Corporation | Security process for public networks |
US5826015A (en) * | 1997-02-20 | 1998-10-20 | Digital Equipment Corporation | Method and apparatus for secure remote programming of firmware and configurations of a computer over a network |
US5935249A (en) * | 1997-02-26 | 1999-08-10 | Sun Microsystems, Inc. | Mechanism for embedding network based control systems in a local network interface device |
US6151686A (en) * | 1997-06-06 | 2000-11-21 | Fmr Corp. | Managing an information retrieval problem |
US7290288B2 (en) | 1997-06-11 | 2007-10-30 | Prism Technologies, L.L.C. | Method and system for controlling access, by an authentication server, to protected computer resources provided via an internet protocol network |
US7743247B1 (en) * | 1997-08-08 | 2010-06-22 | Synectic Design LLC | Method and apparatus for secure communications |
AUPO856797A0 (en) * | 1997-08-15 | 1997-09-04 | AAV Australia Pty. Limited | Computer system having fixed computers and mobile computers |
DE19745994A1 (en) * | 1997-10-20 | 1999-04-22 | Cit Alcatel | Process for the exchange of data between application processes in a secure multi-computer system |
US6092110A (en) * | 1997-10-23 | 2000-07-18 | At&T Wireless Svcs. Inc. | Apparatus for filtering packets using a dedicated processor |
US6158008A (en) * | 1997-10-23 | 2000-12-05 | At&T Wireless Svcs. Inc. | Method and apparatus for updating address lists for a packet filter processor |
US6834388B1 (en) | 1998-03-13 | 2004-12-21 | Iconics, Inc. | Process control |
JP3687373B2 (en) * | 1998-12-04 | 2005-08-24 | 株式会社日立製作所 | Highly reliable distributed system |
US6748451B2 (en) | 1998-05-26 | 2004-06-08 | Dow Global Technologies Inc. | Distributed computing environment using real-time scheduling logic and time deterministic architecture |
US6253321B1 (en) * | 1998-06-19 | 2001-06-26 | Ssh Communications Security Ltd. | Method and arrangement for implementing IPSEC policy management using filter code |
US6154849A (en) * | 1998-06-30 | 2000-11-28 | Sun Microsystems, Inc. | Method and apparatus for resource dependency relaxation |
US6272400B1 (en) | 1998-07-13 | 2001-08-07 | Helix Technology Corporation | Vacuum network controller |
US6311276B1 (en) * | 1998-08-25 | 2001-10-30 | 3Com Corporation | Secure system for remote management and wake-up commands |
DE69915661T2 (en) | 1998-10-16 | 2005-03-24 | Iconics, Inc., Foxborough | PROCESS CONTROL |
JP3223355B2 (en) * | 1998-11-12 | 2001-10-29 | 株式会社エヌ・ティ・ティ・ドコモ | Communication control method, communication control device, recording medium, and data terminal |
US7017116B2 (en) | 1999-01-06 | 2006-03-21 | Iconics, Inc. | Graphical human-machine interface on a portable device |
US6192477B1 (en) * | 1999-02-02 | 2001-02-20 | Dagg Llc | Methods, software, and apparatus for secure communication over a computer network |
FI990715A (en) * | 1999-03-31 | 2000-10-01 | Valmet Corp | Service arrangements at a production facility |
US6647301B1 (en) | 1999-04-22 | 2003-11-11 | Dow Global Technologies Inc. | Process control system with integrated safety control system |
US7089530B1 (en) | 1999-05-17 | 2006-08-08 | Invensys Systems, Inc. | Process control configuration system with connection validation and configuration |
WO2000070531A2 (en) | 1999-05-17 | 2000-11-23 | The Foxboro Company | Methods and apparatus for control configuration |
US6788980B1 (en) * | 1999-06-11 | 2004-09-07 | Invensys Systems, Inc. | Methods and apparatus for control using control devices that provide a virtual machine environment and that communicate via an IP network |
US6535937B1 (en) * | 2000-02-15 | 2003-03-18 | International Business Machines Corporation | Write command verification across a PCI bus system |
EP1130600A1 (en) * | 2000-03-01 | 2001-09-05 | Hewlett-Packard Company, A Delaware Corporation | Data balancing scheme in solid state storage devices |
US6424874B1 (en) * | 2000-06-29 | 2002-07-23 | Honeywell International Inc. | Automated configuration of communications for an ordered collection of devices |
AUPQ916600A0 (en) | 2000-08-03 | 2000-08-24 | James Hardie Research Pty Limited | Automated manufactured apparatus for aluminium window/door systems |
US20020061107A1 (en) * | 2000-09-25 | 2002-05-23 | Tham Terry K. | Methods and apparatus for implementing a cryptography engine |
US20020078342A1 (en) * | 2000-09-25 | 2002-06-20 | Broadcom Corporation | E-commerce security processor alignment logic |
US6968242B1 (en) * | 2000-11-07 | 2005-11-22 | Schneider Automation Inc. | Method and apparatus for an active standby control system on a network |
GB2372346A (en) | 2001-02-19 | 2002-08-21 | Moy Park Ltd | Tracing components of a production chain |
CA2357931A1 (en) * | 2001-09-27 | 2003-03-27 | Alcatel Canada Inc. | System and method of selecting sources for a network element having redundant sources |
US7467290B2 (en) * | 2001-10-19 | 2008-12-16 | Kingston Technology Corporation | Method and system for providing a modular server on USB flash storage |
US6829660B2 (en) * | 2001-12-12 | 2004-12-07 | Emulex Design & Manufacturing Corporation | Supercharge message exchanger |
DE10229704A1 (en) * | 2002-07-02 | 2004-01-29 | Endress + Hauser Process Solutions Ag | Process for protection against unauthorized access to a field device in process automation technology |
US7289861B2 (en) * | 2003-01-28 | 2007-10-30 | Fisher-Rosemount Systems, Inc. | Process control system with an embedded safety system |
DE10240584A1 (en) | 2002-08-28 | 2004-03-11 | Pilz Gmbh & Co. | Safety control system for fault protected operation of critical process such as occurs in machine system operation |
US7333918B2 (en) * | 2002-09-05 | 2008-02-19 | Strategic Power Systems, Inc. | System and method for calculating part life |
US6813527B2 (en) * | 2002-11-20 | 2004-11-02 | Honeywell International Inc. | High integrity control system architecture using digital computing platforms with rapid recovery |
DE10304903A1 (en) * | 2003-02-06 | 2004-10-28 | Siemens Ag | Device for the automation and / or control of machine tools or production machines |
US7281187B2 (en) * | 2003-11-20 | 2007-10-09 | Intellon Corporation | Using error checking bits to communicated an address or other bits |
US7761923B2 (en) | 2004-03-01 | 2010-07-20 | Invensys Systems, Inc. | Process control methods and apparatus for intrusion detection, protection and network hardening |
US8015154B1 (en) * | 2004-06-07 | 2011-09-06 | Teradata Us, Inc. | Starting database software in response to a broadcast message |
US20060090012A1 (en) * | 2004-10-22 | 2006-04-27 | Linden Cornett | Modular SDD (scalable device driver) framework |
EP1806869A4 (en) * | 2004-10-28 | 2009-05-27 | Mitsubishi Electric Corp | Communication device, and communication method |
US20060155770A1 (en) * | 2004-11-11 | 2006-07-13 | Ipdev Co. | System and method for time-based allocation of unique transaction identifiers in a multi-server system |
US20060155753A1 (en) * | 2004-11-11 | 2006-07-13 | Marc Asher | Global asynchronous serialized transaction identifier |
US20060123098A1 (en) * | 2004-11-11 | 2006-06-08 | Ipdev | Multi-system auto-failure web-based system with dynamic session recovery |
EP1889163A1 (en) * | 2005-05-27 | 2008-02-20 | Delphi Technologies, Inc. | System and method for bypassing execution of an algorithm |
US8874477B2 (en) | 2005-10-04 | 2014-10-28 | Steven Mark Hoffberg | Multifactorial optimization system and method |
WO2007123753A2 (en) | 2006-03-30 | 2007-11-01 | Invensys Systems, Inc. | Digital data processing apparatus and methods for improving plant performance |
US8719128B2 (en) * | 2006-12-15 | 2014-05-06 | Tcf Financial Corporation | Computer-facilitated secure account-transaction |
WO2008098302A1 (en) | 2007-02-16 | 2008-08-21 | Orica Explosives Technology Pty Ltd | Method of communication at a blast site, and corresponding blasting apparatus |
US20090186344A1 (en) * | 2008-01-23 | 2009-07-23 | Caliper Life Sciences, Inc. | Devices and methods for detecting and quantitating nucleic acids using size separation of amplicons |
CN104407518B (en) | 2008-06-20 | 2017-05-31 | 因文西斯系统公司 | The system and method interacted to the reality and Simulation Facility for process control |
US8463964B2 (en) | 2009-05-29 | 2013-06-11 | Invensys Systems, Inc. | Methods and apparatus for control configuration with enhanced change-tracking |
US8127060B2 (en) | 2009-05-29 | 2012-02-28 | Invensys Systems, Inc | Methods and apparatus for control configuration with control objects that are fieldbus protocol-aware |
DE102009027369A1 (en) * | 2009-07-01 | 2011-01-05 | Robert Bosch Gmbh | Method and system for controlling at least one actuator |
CN102566527B (en) * | 2010-12-30 | 2015-06-10 | 中国科学院沈阳自动化研究所 | Method for realizing transmission control platformization of semiconductor manufacturing equipment front end module |
US8762528B2 (en) * | 2011-05-31 | 2014-06-24 | General Electric Company | Systems and methods for write protecting foundation fieldbus linking devices |
US8850200B1 (en) | 2011-06-21 | 2014-09-30 | Synectic Design, LLC | Method and apparatus for secure communications through a trusted intermediary server |
US9855698B2 (en) * | 2013-08-07 | 2018-01-02 | Massachusetts Institute Of Technology | Automatic process control of additive manufacturing device |
IN2013MU02890A (en) * | 2013-09-05 | 2015-07-03 | Tata Consultancy Services Ltd | |
JP6658000B2 (en) * | 2016-01-27 | 2020-03-04 | 株式会社リコー | Information processing apparatus, image output control method, and program |
KR102141169B1 (en) * | 2018-04-10 | 2020-08-05 | 한국전자통신연구원 | Human body communication system including security filter device |
WO2021194464A1 (en) * | 2020-03-23 | 2021-09-30 | Btblock Llc | Management system and method for user authentication on password based systems |
CN114356828B (en) * | 2021-12-23 | 2024-05-24 | 中国航空工业集团公司西安航空计算技术研究所 | Asynchronous cross transmission method between double-redundancy flight control computers |
Family Cites Families (87)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4212057A (en) * | 1976-04-22 | 1980-07-08 | General Electric Company | Shared memory multi-microprocessor computer system |
US4074119A (en) * | 1976-06-08 | 1978-02-14 | Licentia Patent-Verwaltungs-G.M.B.H. | Code word determination |
US4227253A (en) * | 1977-12-05 | 1980-10-07 | International Business Machines Corporation | Cryptographic communication security for multiple domain networks |
US4310720A (en) * | 1978-03-31 | 1982-01-12 | Pitney Bowes Inc. | Computer accessing system |
US4215398A (en) * | 1978-08-24 | 1980-07-29 | Texas Instruments Incorporated | Dual microprocessor intelligent programmable process control system with communication link |
US4325120A (en) * | 1978-12-21 | 1982-04-13 | Intel Corporation | Data processing system |
US4402046A (en) * | 1978-12-21 | 1983-08-30 | Intel Corporation | Interprocessor communication system |
US4264782A (en) * | 1979-06-29 | 1981-04-28 | International Business Machines Corporation | Method and apparatus for transaction and identity verification |
US4479179A (en) * | 1979-07-30 | 1984-10-23 | International Business Machines Corporation | Synchronous cycle steal mechanism for transferring data between a processor storage unit and a separate data handling unit |
US4304001A (en) * | 1980-01-24 | 1981-12-01 | Forney Engineering Company | Industrial control system with interconnected remotely located computer control units |
NL183862C (en) * | 1980-02-04 | 1989-02-01 | Philips Nv | TELECOMMUNICATIONS SYSTEM WITH CODED MESSAGE TRANSMISSION. |
US4578530A (en) * | 1981-06-26 | 1986-03-25 | Visa U.S.A., Inc. | End-to-end encryption system and method of operation |
US4593353A (en) * | 1981-10-26 | 1986-06-03 | Telecommunications Associates, Inc. | Software protection method and apparatus |
US4493028A (en) * | 1982-02-02 | 1985-01-08 | International Business Machines Corporation | Dual mode I/O |
US4685125A (en) * | 1982-06-28 | 1987-08-04 | American Telephone And Telegraph Company | Computer system with tasking |
US4539652A (en) * | 1982-07-16 | 1985-09-03 | At&T Bell Laboratories | Networks for data communication |
US4723284A (en) * | 1983-02-14 | 1988-02-02 | Prime Computer, Inc. | Authentication system |
US4670890A (en) * | 1983-03-04 | 1987-06-02 | Research Corporation | Method of and/or apparatus for encoding and decoding sequential information in data handling systems |
US4872106A (en) * | 1983-04-06 | 1989-10-03 | New Forney Corp. | Industrial process control system with back-up data processors to take over from failed primary data processors |
US4607256A (en) * | 1983-10-07 | 1986-08-19 | Honeywell, Inc. | Plant management system |
US4652990A (en) * | 1983-10-27 | 1987-03-24 | Remote Systems, Inc. | Protected software access control apparatus and method |
US4622630A (en) * | 1983-10-28 | 1986-11-11 | Data General Corporation | Data processing system having unique bus control protocol |
US4660141A (en) * | 1983-12-06 | 1987-04-21 | Tri Sigma Corporation | Self configuring computer network with automatic bus exchange of module identification numbers and processor assigned module numbers |
US4609777A (en) * | 1984-02-22 | 1986-09-02 | Gordian Systems, Inc. | Solid state key for controlling access to computer software |
US4596898A (en) * | 1984-03-14 | 1986-06-24 | Computer Security Systems, Inc. | Method and apparatus for protecting stored and transmitted data from compromise or interception |
US4625076A (en) * | 1984-03-19 | 1986-11-25 | Nippon Telegraph & Telephone Public Corporation | Signed document transmission system |
US4672572A (en) * | 1984-05-21 | 1987-06-09 | Gould Inc. | Protector system for computer access and use |
US4663704A (en) * | 1984-12-03 | 1987-05-05 | Westinghouse Electric Corp. | Universal process control device and method for developing a process control loop program |
US4672533A (en) * | 1984-12-19 | 1987-06-09 | Noble Richard G | Electronic linkage interface control security system and method |
US4800590A (en) * | 1985-01-14 | 1989-01-24 | Willis E. Higgins | Computer key and computer lock system |
JPS61166668A (en) * | 1985-01-19 | 1986-07-28 | Panafacom Ltd | Multi-processor control system |
US4713753A (en) * | 1985-02-21 | 1987-12-15 | Honeywell Inc. | Secure data processing system architecture with format control |
US4779224A (en) * | 1985-03-12 | 1988-10-18 | Moseley Donald R | Identity verification method and apparatus |
US4683968A (en) * | 1985-09-03 | 1987-08-04 | Burroughs Corporation | System for preventing software piracy employing multi-encrypted keys and single decryption circuit modules |
US4885777A (en) * | 1985-09-04 | 1989-12-05 | Hitachi, Ltd. | Electronic transaction system |
US4825354A (en) * | 1985-11-12 | 1989-04-25 | American Telephone And Telegraph Company, At&T Bell Laboratories | Method of file access in a distributed processing computer network |
US4864494A (en) * | 1986-03-21 | 1989-09-05 | Computerized Data Ssytems For Mfg., Inc. | Software usage authorization system with key for decrypting/re-encrypting/re-transmitting moving target security codes from protected software |
US4882752A (en) * | 1986-06-25 | 1989-11-21 | Lindman Richard S | Computer security system |
US4809327A (en) * | 1986-09-02 | 1989-02-28 | Unisys Corporation | Encrtption of messages employing unique control words and randomly chosen encryption keys |
US4839890A (en) * | 1986-10-31 | 1989-06-13 | Ncr Corporation | Data bit synchronizer |
US4916738A (en) * | 1986-11-05 | 1990-04-10 | International Business Machines Corp. | Remote access terminal security |
JPH0632047B2 (en) * | 1987-01-30 | 1994-04-27 | 株式会社東芝 | Data collection device |
US4771462A (en) * | 1987-02-18 | 1988-09-13 | Hannan Forrest A | Communication port encryption/decryption method and apparatus |
GB8704920D0 (en) * | 1987-03-03 | 1987-04-08 | Hewlett Packard Co | Secure messaging system |
JPS63255759A (en) * | 1987-04-14 | 1988-10-24 | Mitsubishi Electric Corp | Control system |
JPS63278438A (en) * | 1987-05-11 | 1988-11-16 | Hitachi Ltd | Cryptographic system by secret cryptograph procedure |
US4930073A (en) * | 1987-06-26 | 1990-05-29 | International Business Machines Corporation | Method to prevent use of incorrect program version in a computer system |
US4881263A (en) * | 1987-09-25 | 1989-11-14 | Digital Equipment Corporation | Apparatus and method for secure transmission of data over an unsecure transmission channel |
US4924513A (en) * | 1987-09-25 | 1990-05-08 | Digital Equipment Corporation | Apparatus and method for secure transmission of data over an unsecure transmission channel |
US4796232A (en) * | 1987-10-20 | 1989-01-03 | Contel Corporation | Dual port memory controller |
US4937736A (en) * | 1987-11-30 | 1990-06-26 | International Business Machines Corporation | Memory controller for protected memory with automatic access granting capability |
US4853962A (en) * | 1987-12-07 | 1989-08-01 | Universal Computer Consulting, Inc. | Encryption system |
US4868851A (en) * | 1988-01-26 | 1989-09-19 | Harris Corporation | Signal processing apparatus and method |
US4944008A (en) * | 1988-02-18 | 1990-07-24 | Motorola, Inc. | Electronic keying scheme for locking data |
JPH0783337B2 (en) * | 1988-03-01 | 1995-09-06 | 日本電気株式会社 | Scramble-descramble method |
US4964163A (en) * | 1988-04-04 | 1990-10-16 | Motorola, Inc. | Method and apparatus for controlling access to a communication system |
US4897777A (en) * | 1988-04-11 | 1990-01-30 | Square D Company | Peer-to-peer register exchange controller for PLCS |
US4956769A (en) * | 1988-05-16 | 1990-09-11 | Sysmith, Inc. | Occurence and value based security system for computer databases |
US4969189A (en) * | 1988-06-25 | 1990-11-06 | Nippon Telegraph & Telephone Corporation | Authentication system and apparatus therefor |
US4932054A (en) * | 1988-09-16 | 1990-06-05 | Chou Wayne W | Method and apparatus for protecting computer software utilizing coded filter network in conjunction with an active coded hardware device |
US4926481A (en) * | 1988-12-05 | 1990-05-15 | The United States Of America As Represented By The Administrator Of The National Aeronautics And Space Administration | Computer access security code system |
US4919545A (en) * | 1988-12-22 | 1990-04-24 | Gte Laboratories Incorporated | Distributed security procedure for intelligent networks |
US4958270A (en) * | 1989-01-23 | 1990-09-18 | Honeywell Inc. | Method for control data base updating of a redundant processor in a process control system |
US4995040A (en) * | 1989-02-03 | 1991-02-19 | Rockwell International Corporation | Apparatus for management, comparison, and correction of redundant digital data |
US4996655A (en) * | 1989-02-16 | 1991-02-26 | Micron Technology, Inc. | Real time monitoring of remote signals in an industrial environment |
US5006976A (en) * | 1989-02-23 | 1991-04-09 | Fisher Controls International, Inc. | Process control terminal |
US5065429A (en) * | 1989-04-03 | 1991-11-12 | Lang Gerald S | Method and apparatus for protecting material on storage media |
US5191611A (en) * | 1989-04-03 | 1993-03-02 | Lang Gerald S | Method and apparatus for protecting material on storage media and for transferring material on storage media to various recipients |
US4926418A (en) * | 1989-04-11 | 1990-05-15 | International Business Machines Corporation | Fairness algorithm for full-duplex buffer insertion ring |
US4956863A (en) * | 1989-04-17 | 1990-09-11 | Trw Inc. | Cryptographic method and apparatus for public key exchange with authentication |
US4975865A (en) * | 1989-05-31 | 1990-12-04 | Mitech Corporation | Method and apparatus for real-time control |
US5003593A (en) * | 1989-06-05 | 1991-03-26 | Motorola, Inc. | Teleconferencing method for a secure key management system |
GB8916586D0 (en) * | 1989-07-20 | 1989-09-06 | Int Computers Ltd | Distributed data processing system |
US5008805A (en) * | 1989-08-03 | 1991-04-16 | International Business Machines Corporation | Real time, fail safe process control system and method |
US5056140A (en) * | 1990-02-22 | 1991-10-08 | Blanton Kimbell | Communication security accessing system and process |
US5204966A (en) * | 1990-03-09 | 1993-04-20 | Digital Equipment Corporation | System for controlling access to a secure system by verifying acceptability of proposed password by using hashing and group of unacceptable passwords |
NL9000968A (en) * | 1990-04-23 | 1991-11-18 | Paul Broertjes | SECURITY SYSTEM FOR A MAIN COMPUTER. |
JP2703391B2 (en) * | 1990-06-18 | 1998-01-26 | 株式会社東芝 | Bridge device |
US5204961A (en) * | 1990-06-25 | 1993-04-20 | Digital Equipment Corporation | Computer network operating with multilevel hierarchical security with selectable common trust realms and corresponding security protocols |
JPH04133102A (en) * | 1990-09-26 | 1992-05-07 | Mitsubishi Electric Corp | Programmable controller and its control method |
US5224163A (en) * | 1990-09-28 | 1993-06-29 | Digital Equipment Corporation | Method for delegating authorization from one entity to another through the use of session encryption keys |
US5196840A (en) * | 1990-11-05 | 1993-03-23 | International Business Machines Corporation | Secure communications system for remotely located computers |
US5379426A (en) * | 1991-01-25 | 1995-01-03 | Sun Microsystems, Inc. | Method and apparatus for object oriented interprocess message switching |
US5347633A (en) * | 1991-04-30 | 1994-09-13 | International Business Machines, Inc. | System for selectively intercepting and rerouting data network traffic |
US5319760A (en) * | 1991-06-28 | 1994-06-07 | Digital Equipment Corporation | Translation buffer for virtual machines with address space match |
US5191610A (en) * | 1992-02-28 | 1993-03-02 | United Technologies Automotive, Inc. | Remote operating system having secure communication of encoded messages and automatic re-synchronization |
US5392399A (en) * | 1992-05-18 | 1995-02-21 | 3Com Corporation | Bridge system for selectively routing frame with ordering parameter identifying ordering of identifiers only based upon its source identifier |
-
1993
- 1993-06-01 DE DE69316009T patent/DE69316009T2/en not_active Expired - Fee Related
- 1993-06-01 WO PCT/US1993/005208 patent/WO1993025948A1/en active IP Right Grant
- 1993-06-01 EP EP97109414A patent/EP0810499B1/en not_active Expired - Lifetime
- 1993-06-01 EP EP93914299A patent/EP0645028B1/en not_active Expired - Lifetime
- 1993-06-01 AU AU44009/93A patent/AU4400993A/en not_active Abandoned
- 1993-06-01 CA CA002137464A patent/CA2137464C/en not_active Expired - Fee Related
- 1993-06-01 KR KR1019940704581A patent/KR100302222B1/en not_active IP Right Cessation
- 1993-06-01 ES ES97109414T patent/ES2162659T3/en not_active Expired - Lifetime
- 1993-06-01 ES ES93914299T patent/ES2110613T3/en not_active Expired - Lifetime
- 1993-06-01 JP JP6501551A patent/JPH07507893A/en active Pending
- 1993-06-01 DE DE69330970T patent/DE69330970T2/en not_active Expired - Fee Related
-
1994
- 1994-07-25 US US08/279,697 patent/US5428745A/en not_active Expired - Fee Related
-
1995
- 1995-02-21 US US08/391,521 patent/US5561770A/en not_active Expired - Fee Related
-
2000
- 2000-11-28 KR KR1020007013418A patent/KR100314387B1/en not_active IP Right Cessation
Non-Patent Citations (1)
Title |
---|
See references of WO9325948A1 * |
Also Published As
Publication number | Publication date |
---|---|
EP0810499B1 (en) | 2001-10-17 |
EP0810499A2 (en) | 1997-12-03 |
ES2110613T3 (en) | 1998-02-16 |
US5428745A (en) | 1995-06-27 |
AU4400993A (en) | 1994-01-04 |
US5561770A (en) | 1996-10-01 |
DE69316009D1 (en) | 1998-02-05 |
EP0645028B1 (en) | 1997-12-29 |
JPH07507893A (en) | 1995-08-31 |
CA2137464A1 (en) | 1993-12-23 |
DE69330970D1 (en) | 2001-11-22 |
KR100302222B1 (en) | 2001-11-22 |
KR100314387B1 (en) | 2001-11-17 |
EP0810499A3 (en) | 1999-01-07 |
CA2137464C (en) | 2001-07-03 |
WO1993025948A1 (en) | 1993-12-23 |
DE69330970T2 (en) | 2002-04-04 |
ES2162659T3 (en) | 2002-01-01 |
DE69316009T2 (en) | 1998-04-23 |
KR950702046A (en) | 1995-05-17 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US5428745A (en) | Secure communication system for re-establishing time limited communication between first and second computers before communication time period expiration using new random number | |
US5519603A (en) | Intelligent process control communication system and method having capability to time align corresponding data sets | |
WO1993025948A9 (en) | Secure front end communication system and method for process control computers | |
EP0196911B1 (en) | Local area networks | |
US4607256A (en) | Plant management system | |
US7003698B2 (en) | Method and apparatus for transport of debug events between computer system components | |
CA1226370A (en) | Multicomputer network | |
US8041961B2 (en) | Storage system | |
US8185934B2 (en) | Programmable data protection device, secure programming manager system and process for controlling access to an interconnect network for an integrated circuit | |
EP0645026B1 (en) | Stealth interface for process control computers | |
US8543774B2 (en) | Programmable logic apparatus employing shared memory, vital processor and non-vital communications processor, and system including the same | |
JPH0654911B2 (en) | Method and apparatus for transferring mastership | |
US6959352B1 (en) | System and method for allowing non-trusted processors to interrupt a processor safely | |
KR100317740B1 (en) | Intelligent Process Control Communication System and Method | |
CA2334499A1 (en) | Secure front end communication system and method for process control computers | |
CA1303696B (en) | Plant management system | |
JPH09205470A (en) | Alarm collection system |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
17P | Request for examination filed |
Effective date: 19941214 |
|
AK | Designated contracting states |
Kind code of ref document: A1 Designated state(s): BE DE ES FR GB IT NL |
|
17Q | First examination report despatched |
Effective date: 19960126 |
|
GRAG | Despatch of communication of intention to grant |
Free format text: ORIGINAL CODE: EPIDOS AGRA |
|
GRAG | Despatch of communication of intention to grant |
Free format text: ORIGINAL CODE: EPIDOS AGRA |
|
GRAG | Despatch of communication of intention to grant |
Free format text: ORIGINAL CODE: EPIDOS AGRA |
|
GRAH | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOS IGRA |
|
GRAH | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOS IGRA |
|
GRAA | (expected) grant |
Free format text: ORIGINAL CODE: 0009210 |
|
RAP3 | Party data changed (applicant data changed or rights of an application transferred) |
Owner name: DOW BENELUX N.V. Owner name: THE DOW CHEMICAL COMPANY |
|
AK | Designated contracting states |
Kind code of ref document: B1 Designated state(s): BE DE ES FR GB IT NL |
|
DX | Miscellaneous (deleted) | ||
REF | Corresponds to: |
Ref document number: 69316009 Country of ref document: DE Date of ref document: 19980205 |
|
ET | Fr: translation filed | ||
REG | Reference to a national code |
Ref country code: ES Ref legal event code: FG2A Ref document number: 2110613 Country of ref document: ES Kind code of ref document: T3 |
|
ITF | It: translation for a ep patent filed | ||
PLBE | No opposition filed within time limit |
Free format text: ORIGINAL CODE: 0009261 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT |
|
26N | No opposition filed | ||
REG | Reference to a national code |
Ref country code: GB Ref legal event code: IF02 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: FR Payment date: 20030312 Year of fee payment: 11 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: NL Payment date: 20030314 Year of fee payment: 11 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: GB Payment date: 20030331 Year of fee payment: 11 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: BE Payment date: 20030425 Year of fee payment: 11 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: DE Payment date: 20030527 Year of fee payment: 11 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: ES Payment date: 20030602 Year of fee payment: 11 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: GB Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20040601 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: ES Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20040602 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: BE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20040630 |
|
BERE | Be: lapsed |
Owner name: *DOW BENELUX N.V. Effective date: 20040630 Owner name: THE *DOW CHEMICAL CY Effective date: 20040630 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: NL Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20050101 Ref country code: DE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20050101 |
|
GBPC | Gb: european patent ceased through non-payment of renewal fee | ||
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: FR Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20050228 |
|
NLV4 | Nl: lapsed or anulled due to non-payment of the annual fee |
Effective date: 20050101 |
|
REG | Reference to a national code |
Ref country code: FR Ref legal event code: ST |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IT Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES;WARNING: LAPSES OF ITALIAN PATENTS WITH EFFECTIVE DATE BEFORE 2007 MAY HAVE OCCURRED AT ANY TIME BEFORE 2007. THE CORRECT EFFECTIVE DATE MAY BE DIFFERENT FROM THE ONE RECORDED. Effective date: 20050601 |
|
REG | Reference to a national code |
Ref country code: ES Ref legal event code: FD2A Effective date: 20040602 |