Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
APPARATUS AND METHOD FOR ON-PROCESS MIGRATION OF INDUSTRIAL CONTROL AND AUTOMATION SYSTEM ACROSS DISPARATE NETWORK TYPES
Document Type and Number:
WIPO Patent Application WO/2016/036538
Kind Code:
A1
Abstract:
An apparatus includes a first network controller (130) configured to communicate over a higher-level industrial process control network (120), a second network controller (132) configured to communicate over a first lower-level industrial process control network (122), and a third network controller (134) configured to communicate over a second lower-level industrial process control network (124). The first network controller is configured to provide first data messages from the higher-level control network to the second and third network controllers for transmission over the lower-level control networks. The second and third network controllers are configured to provide second data messages from the lower-level control networks to the first network controller for transmission over the higher-level control network. Each of the second and third network controllers is configured to provide third data messages from one of the lower-level control networks to another of the second and third network controllers for transmission over another of the lower-level control networks.

Inventors:
PRALL JOHN M (US)
MCLAUGHLIN PAUL F (US)
NOVAK MICHAEL E (US)
GUSTIN JAY W (US)
Application Number:
PCT/US2015/046730
Publication Date:
March 10, 2016
Filing Date:
August 25, 2015
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
HONEYWELL INT INC (US)
International Classes:
H04L29/06; H04L29/10
Foreign References:
US5146401A1992-09-08
US20070229231A12007-10-04
US20070244571A12007-10-18
US20130297748A12013-11-07
US8705527B12014-04-22
Other References:
See also references of EP 3189647A4
Attorney, Agent or Firm:
BEATUS, Carrie et al. (Patent Services M/S AB/2B101 Columbia Road,P. O. Box 224, Morristown NJ, US)
Download PDF:
Claims:
WHAT IS CLAIMED IS:

1. An apparatus comprising:

a first network controller (130) configured to communicate over a higher-level industrial process control network (120);

a second network controller (132) configured to communicate over a first lower-level industrial process control network (122); and

a third network controller (134) configured to communicate over a second lower-level industrial process control network (124);

wherein the first network controller is configured to provide first data messages from the higher-level industrial process control network to the second and third network controllers for transmission over the lower-level industrial process control networks;

wherein the second and third network controllers are configured to provide second data messages from the lower-level industrial process control networks to the first network controller for transmission over the higher-level industrial process control network; and

wherein each of the second and third network controllers is configured to provide third data messages from one of the lower-level industrial process control networks to another of the second and third network controllers for transmission over another of the lower-level industrial process control networks. 2. The apparatus of Claim 1, further comprising:

a first physical interface (204) coupled to the first network controller and configured to be coupled to the higher-level industrial process control network;

a second physical interface (206) coupled to the second network controller and configured to be coupled to the first lower-level industrial process control network; and

a third physical interface (208) coupled to the third network controller and configured to be coupled to the second lower-level industrial process control network. 3. The apparatus of Claim 1, further comprising:

a first shared memory block (410) configured to buffer the first and second data messages, the first and second network controllers configured to access the first shared memory block.

4. The apparatus of Claim 3, further comprising:

a second shared memory block (420) configured to buffer at least the third data messages, the second and third network controllers configured to access the second shared memory block. 5. The apparatus of Claim 1, wherein:

the second network controller comprises a token bus controller (314) configured to communicate over a token bus of the first lower-level industrial process control network; and

the third network controller comprises a token bus controller emulator (324). 6. The apparatus of Claim 1, wherein:

the second network controller comprises logical link control (LLC) firmware (316) configured to route the second data messages to the first network controller and to route at least some of the third data messages to the third network controller; and the third network controller comprises LLC firmware (326) configured to route the second data messages to the first network controller and to route at least some of the third data messages to the second network controller. 7. The apparatus of Claim 2, wherein:

the first physical interface is configured to be coupled to a redundant coaxial control network;

the second physical interface is configured to be coupled to a coaxial or redundant coaxial control network; and

the third physical interface is configured to be coupled to an Ethernet network or a redundant Ethernet network. 8. The apparatus of Claim 1, wherein the apparatus is configured to provide control devices on the higher-level industrial process control network with concurrent access to control devices on the first and second lower-level industrial process control networks. 9. A method comprising:

receiving (702) first data messages from a higher-level industrial process control network (120) at a first network controller (130) of an interface device (126’); providing (704) the first data messages to second and third network controllers (132-134) of the interface device for transmission over first and second lower-level industrial process control networks (122-124);

receiving (708) second data messages from the lower-level industrial process control networks at the second and third network controllers;

providing (710) the second data messages to the first network controller for transmission over the higher-level industrial process control network;

receiving (714) third data messages from one of the lower-level industrial process control networks at one of the second and third network controllers; and

providing (716) the third data messages to another of the second and third network controllers for transmission over another of the lower-level industrial process control networks. 10. The method of Claim 9, wherein the interface device transports the third messages from the second network controller to the third network controller and from the third network controller to the second network controller. 11. The method of Claim 9, further comprising:

coupling a first physical interface (204) of the interface device to the higher- level industrial process control network, the first physical interface coupled to the first network controller;

coupling a second physical interface (206) of the interface device to the first lower-level industrial process control network, the second physical interface coupled to the second network controller; and

coupling a third physical interface (208) of the interface device to the second lower-level industrial process control network, the third physical interface coupled to the third network controller.

12. The method of Claim 9, further comprising:

using a first shared memory block (410) to buffer the first and second data messages, the first and second network controllers configured to access the first shared memory block; and

using a second shared memory block (420) to buffer at least the third data messages, the second and third network controllers configured to access the second shared memory block. 13. A system comprising:

first, second, and third network controllers (130-134) configured to communicate over first, second, and third industrial process control networks (120- 124), respectively;

at least one processing device (210, 214, 218) configured to provide a gateway function to allow data messages to be transported between (i) the first industrial process control network and (ii) the second and third industrial process control networks, wherein the second and third network controllers are configured to provide a bridge function to allow data messages to be transported between (i) the second industrial process control network and (ii) the third industrial process control network; and

a bus (222) configured to transport the data messages between the network controllers. 14. The system of Claim 13, wherein:

the second network controller comprises:

a token bus controller (314) configured to communicate over a token bus of the second industrial process control network; and

logical link control (LLC) firmware (316) configured to route some of the data messages to the first and third network controllers; and

the third network controller comprises:

a token bus controller emulator (324); and

LLC firmware (326) configured to route some of the data messages to the first and second network controllers. 15. The system of Claim 13, further comprising:

a first physical interface (204) coupled to the first network controller and configured to be coupled to the first industrial process control network;

a second physical interface (206) coupled to the second network controller and configured to be coupled to the second industrial process control network; and

a third physical interface (208) coupled to the third network controller and configured to be coupled to the third industrial process control network.

Description:
APPARATUS AND METHOD FOR ON-PROCESS MIGRATION OF INDUSTRIAL CONTROL AND AUTOMATION SYSTEM ACROSS DISPARATE NETWORK TYPES

TECHNICAL FIELD

This disclosure relates generally to industrial process control and automation systems. More specifically, this disclosure relates to an apparatus and method for on- process migration of an industrial control and automation system across disparate network types.

BACKGROUND

Industrial process control and automation systems are typically used to monitor and control complex and potentially volatile industrial processes without interruption, often running without scheduled downtime for years. Over time, a need may arise to upgrade one or more components in an industrial process control and automation system. This could be due to various factors, such as the desire to obtain improvements provided by new products or the need to replace obsolete products or address support issues. It is often necessary or desirable to perform an upgrade“on- process,” meaning there are little or no interruptions of the control routines used by the system to control the underlying industrial processes. Ideally, this allows the system to continuously or near-continuously monitor and control the underlying industrial processes during the upgrade.

SUMMARY

This disclosure provides an apparatus and method for on-process migration of an industrial control and automation system across disparate network types.

In a first embodiment, an apparatus includes a first network controller configured to communicate over a higher-level industrial process control network, a second network controller configured to communicate over a first lower-level industrial process control network, and a third network controller configured to communicate over a second lower-level industrial process control network. The first network controller is configured to provide first data messages from the higher-level industrial process control network to the second and third network controllers for transmission over the lower-level industrial process control networks. The second and third network controllers are configured to provide second data messages from the lower- level industrial process control networks to the first network controller for transmission over the higher-level industrial process control network. Each of the second and third network controllers is configured to provide third data messages from one of the lower-level industrial process control networks to another of the second and third network controllers for transmission over another of the lower-level industrial process control networks.

In a second embodiment, a method includes receiving first data messages from a higher-level industrial process control network at a first network controller of an interface device. The method also includes providing the first data messages to second and third network controllers of the interface device for transmission over first and second lower-level industrial process control networks. The method further includes receiving second data messages from the lower-level industrial process control networks at the second and third network controllers. Moreover, the method includes providing the second data messages to the first network controller for transmission over the higher-level industrial process control network. The method also includes receiving third data messages from one of the lower-level industrial process control networks at one of the second and third network controllers. In addition, the method includes providing the third data messages to another of the second and third network controllers for transmission over another of the lower-level industrial process control networks. In a third embodiment, a system includes first, second, and third network controllers configured to communicate over first, second, and third industrial process control networks, respectively. The system also includes at least one processing device configured to provide a gateway function to allow data messages to be transported between (i) the first industrial process control network and (ii) the second and third industrial process control networks. The second and third network controllers are configured to provide a bridge function to allow data messages to be transported between (i) the second industrial process control network and (ii) the third industrial process control network. In addition, the system includes a bus configured to transport the data messages between the network controllers.

Other technical features may be readily apparent to one skilled in the art from the following figures, descriptions, and claims.

BRIEF DESCRIPTION OF THE DRAWINGS For a more complete understanding of this disclosure, reference is now made to the following description, taken in conjunction with the accompanying drawings, in which:

FIGURE 1 illustrates an example on-process migration in an industrial process control and automation system according to this disclosure;

FIGURES 2 through 6 illustrate an example device supporting on-process migration in an industrial process control and automation system and related details according to this disclosure;

FIGURE 7 illustrates an example method for supporting communications between components during an on-process migration in an industrial process control and automation system according to this disclosure; and

FIGURE 8 illustrates an example method for on-process migration in an industrial process control and automation system according to this disclosure.

DETAILED DESCRIPTION

FIGURES 1 through 8, discussed below, and the various embodiments used to describe the principles of the present invention in this patent document are by way of illustration only and should not be construed in any way to limit the scope of the invention. Those skilled in the art will understand that the principles of the invention may be implemented in any type of suitably arranged device or system.

As noted above, there is often a need or desire to upgrade one or more components in an industrial process control and automation system, ideally using an “on-process” migration so that monitoring and control of one or more underlying industrial processes is continuous or near-continuous. However, this is often difficult to achieve when a new control network is being installed that is incompatible with a legacy control network. For example, it may be necessary or desirable to minimize the disturbances to control devices being migrated onto the new control network and control devices staying on the legacy control network. Communications between the devices ideally would be maintained at all times to prevent the loss of control or view of the underlying processes throughout the migration. In addition, it is common for a migration to occur over an extended period of time since it is typically rare for all devices to be scheduled for an upgrade at the same time.

In the following description, a“legacy” device refers to a device being replaced by a more recent, enhanced, or other device. A“legacy” protocol refers to a protocol used by a legacy device, a“legacy” interface refers to an interface that supports the use of a legacy protocol, and a“legacy” network refers to a network that supports the use of a legacy protocol. A“new” or“enhanced” device refers to a device that is replacing a legacy device. An“enhanced” protocol refers to a protocol used by a new or enhanced device, an“enhanced” interface refers to an interface that supports the use of an enhanced protocol, and an“enhanced” network refers to a network that supports the use of an enhanced protocol. Note that the terms“migration” and “replacement” (and their derivatives), when used with reference to a legacy device, include both a physical replacement of the legacy device with a new or enhanced device and an upgrade of the legacy device to have one or more features of a new or enhanced device.

FIGURE 1 illustrates an example on-process migration in an industrial process control and automation system according to this disclosure. As shown in FIGURE 1 , an industrial process control and automation system 100 is being modified during the migration to create an updated industrial process control and automation system 100’.

The system 100 here includes two distributed control system (DCS) nodes 102- 104. The DCS nodes 102-104 generally represent higher-level controllers or other components in an industrial process control and automation system. For example, the DCS nodes 102-104 could be used to optimize the control logic used by various lower-level process controllers 106-116 or to interact with and use data from the process controllers 106-116. In particular embodiments, the DCS nodes 102-104 reside at“Level 2” or higher in the Purdue model of industrial control. Each DCS node 102-104 represents any suitable structure for performing higher-level functions in an industrial process control and automation system. For instance, each DCS node 102-104 could represent a computing device executing a WINDOWS operating system or other operating system.

The process controllers 106-116 generally represent lower-level controllers that perform lower-level functions in an industrial process control and automation system. For example, the process controllers 106-116 could receive measurements of various characteristics of an industrial process from a number of sensors. The process controllers 106-116 could use the measurements to generate control signals for a number of actuators in the industrial process control and automation system. In particular embodiments, the process controllers 106-116 reside at“Level 1” in the Purdue model of industrial control. Each process controller 106-116 represents any suitable structure for performing process control functions or other lower-level functions in an industrial process control and automation system. For instance, each process controller 106-116 could represent a computing device executing a real-time operating system.

In this example, the process controllers 106 and 116 denote stand-alone controllers, while the process controllers 108-110 and 112-114 denote redundant pairs of controllers. In each redundant pair, one process controller operates in a primary mode, and another process controller operates in a secondary or redundant mode. When in the primary mode, a process controller actively monitors or controls the underlying industrial process(es). When in the secondary mode, a process controller can be synchronized with the primary process controller, which allows the secondary process controller to take over and enter the primary mode if and when the primary process controller fails or another switchover event occurs (such as a user-initiated switchover). A dedicated communication link 118 can be used to couple and allow synchronization of the process controllers in a redundant configuration. The communication link 118 can represent a dedicated point-to-point link and be independent of any other communication or control network in the system.

Different types of control networks 120-124 are used in the system to support communications between controllers and other devices coupled to the networks 120- 124. The control network 120 denotes a network supporting communications to and from the DCS nodes 102-104 or other higher-level components of the system. The control network 122 denotes a legacy network supporting communications to and from legacy process controllers 106-110 and other legacy lower-level components of the system. The control network 124 denotes an enhanced network supporting communications to and from enhanced process controllers 112-116 and other enhanced lower-level components of the system.

Each control network 120-124 represents any suitable type of industrial control network. In particular embodiments, the control network 120 denotes a supervisory redundant coaxial network, such as a LOCAL CONTROL NETWORK (LCN) from HONEYWELL INTERNATIONAL INC. Also, in particular embodiments, the control network 122 denotes a legacy coaxial or redundant coaxial network, such as a UNIVERSAL CONTROL NETWORK (UCN) from HONEYWELL INTERNATIONAL INC. In addition, in particular embodiments, the control network 124 denotes one or more Ethernet networks, such as a FAULT TOLERANT ETHERNET (FTE) network from HONEYWELL INTERNATIONAL INC.

The DCS nodes 102-104 cannot communicate and interact with the process controllers 106-116 directly because of the presence of the different control networks 120-124. Instead, various network interface modules (NIMs) 126-128 sit between the DCS nodes 102-104 and the process controllers 106-116. Each NIM 126-128 generally allows devices on one network to communicate with devices on another network.

It may become necessary or desirable to migrate one or more of the legacy process controllers 106-110 onto the enhanced control network 124. In this example, the legacy process controller 110 is being replaced by an enhanced process controller 110’. As noted above, this could be due to various factors, such as the desire to obtain improvements provided by enhanced devices or the need to replace obsolete legacy devices or address support issues with the legacy devices.

When attempting to migrate a redundant pair of process controllers (such as the controllers 108-110), one could simply migrate the secondary legacy process controller 110 to an enhanced process controller 110’ on the enhanced network 124. Later, after operation of the enhanced process controller 110’ is verified, the other legacy process controller 108 can be migrated onto the enhanced network 124. The enhanced process controller 110’ and the legacy process controller 108 could still communicate over their dedicated communication link 118 and be synchronized, but the enhanced process controller 110’ no longer has the ability to communicate with other devices (such as the process controller 106) on the legacy control network 122 via peer-to-peer communications. In addition, various data references used by the DCS nodes 102-104 may no longer function properly without modifications that redirect the DCS nodes 102-104 to the enhanced process controller 110’. This breakage in data references in the DCS nodes 102-104 results in a loss of control and view over the industrial process and can make on-process migration of devices on the control network 122 to devices on the control network 124 virtually impossible.

In accordance with this disclosure, at least one NIM 126 is replaced with at least one NIM 126’, which can be used to both (i) support communications between a supervisory control network 120 and multiple lower-level control networks 122-124 and (ii) support communications between the multiple lower-level control networks 122-124. The NIM 126’ effectively operates as a gateway with respect to the first function since it supports communications between multiple levels of a control and automation system. The NIM 126’ effectively operates as a bridge with respect to the second function since it supports communications between components coupled to different networks on the same level of a control and automation system.

As shown in FIGURE 1, the NIM 126’ includes three network controllers 130- 134. Each network controller 130-134 supports communications using the appropriate protocol over one of the control networks 120-124. The network controllers 130-134 also support the gateway and bridge functions of the NIM 126’. For example, the network controller 130 could receive data messages, identify the destinations of the data messages, and send the data messages to the network controllers 132-134 for communication over the appropriate control networks 122-124. The network controllers 132-134 could support similar functions for sending data messages to other network controllers for delivery to the appropriate destinations.

The NIM 126’ supports on-process migration in a control and automation system across disparate control network types, such as during the migration of a system from a legacy (generally obsolete) control network 122 to an enhanced control network 124. The NIM 126’ generally supports communications over the three disparate networks, each with a different physical implementation. The NIM 126’ also supports incremental migration by allowing interaction between higher-level components in the system and both legacy and enhanced devices. This allows the legacy devices to be replaced with enhanced devices over an extended period of time. In addition, the DCS nodes 102-104 can continue to interact with an enhanced device that replaces a legacy device using the same data references since the NIM 126’ can be used to access both the legacy device and the enhanced device.

Additional details regarding the use of a NIM 126’ to support on-process migration are provided below. Note that while described as being implemented in a NIM, this approach could be used in any other suitable devices, such as a network gateway or other device. Also note that while the NIM 128 is shown here as a standard NIM, the NIM 128 could be upgraded in the same manner as the NIM 126’ to communicate over the three control networks 120-124. This could allow the use of a redundant pair of NIMs in the updated industrial process control and automation system 100’.

Although FIGURE 1 illustrates one example of an on-process migration in an industrial process control and automation system, various changes may be made to FIGURE 1. For example, various components in FIGURE 1 could be combined, further subdivided, moved, or omitted and additional components could be added according to particular needs. Also, the system could include any number of each component shown in FIGURE 1. Control and automation systems come in a wide variety of configurations, and FIGURE 1 does not limit the scope of this disclosure to any particular configuration. In addition, FIGURE 1 illustrates one example operational environment in which on-process migration could be supported. This functionality could be used in any other suitable industrial process control and automation system.

FIGURES 2 through 6 illustrate an example device supporting on-process migration in an industrial process control and automation system and related details according to this disclosure. More specifically, FIGURES 2 through 6 illustrate example implementation details of the NIM 126’ supporting on-process migration. For ease of explanation, the NIM 126’ in FIGURES 2 through 6 is described as being used in the system of FIGURE 1. The NIM 126’ could be used in any other suitable system to support migration from any suitable legacy devices to any suitable enhanced devices.

As shown in FIGURE 2, the NIM 126’ includes a housing 202. The housing 202 generally denotes a structure that protects, encases, or holds other components of the NIM 126’. The housing 202 includes any suitable structure in which other components can be placed. The housing 202 could also be formed from any suitable material(s) and in any suitable manner. In particular embodiments, the housing 202 includes a chassis into which printed circuit board (PCB) cards can be inserted and coupled to a backplane or other structure.

The NIM 126’ also includes the three network controllers 130-134, which are coupled to three network physical interfaces 204-208. The network controller 130 supports communications over a supervisory network 120, such as an LCN. For example, the network controller 130 can receive data from and transmit data to various DCS nodes 102-104 coupled to the supervisory network 120 using at least one standard or proprietary protocol. The network controller 130 represents any suitable controller for interacting with a supervisory control network. In some embodiments, the network controller 130 includes at least one processing device 210 and at least one memory 212. In particular embodiments, the network controller 130 represents a K4LCN interface card from HONEYWELL INTERNATIONAL INC., with modifications made to the firmware of the card to support various functions of the NIM 126’. The physical interface 204 could represent an Ethernet port or other suitable structure configured to be coupled to the supervisory network 120. The network controller 132 supports communications over a legacy control network 122, such as a UCN or other coaxial network. For example, the network controller 132 can receive data from and transmit data to various process controllers 106-110 using at least one standard or proprietary legacy protocol. The network controller 132 represents any suitable controller for interacting with a legacy control network. In some embodiments, the network controller 132 includes at least one processing device 214 and at least one memory 216. The physical interface 206 could represent a coaxial cable interface or other suitable structure configured to be coupled to the control network 122.

The network controller 134 supports communications over an enhanced control network 124, such as an FTE network. For example, the network controller 134 can receive data from and transmit data to various process controllers 112-116 using at least one standard or proprietary enhanced protocol. The network controller 134 represents any suitable controller for interacting with an enhanced control network. In some embodiments, the network controller 134 includes at least one processing device 218 and at least one memory 220. The physical interface 208 could represent an FTE interface or other suitable structure configured to be coupled to the control network 124.

Among other things, the NIM 126’ can translate between the protocols used by the supervisory network 120, the legacy control network 122, and the enhanced control network 124. This allows legacy devices (such as the process controller 108) to be used while an enhanced device (such as the process controller 110’) is being installed, commissioned, and brought online.

The processing device 210 controls the overall operation of the NIM 126’. For example, the processing device 210 could control the operations of the network controllers 130-132 to thereby control the transmission and reception of data by the NIM 126’. Each processing device 210, 214, 218 also supports translation, address resolution, or other operations needed to support the flow of data between different control networks 120-124. For instance, the processing device 210, 214, 218 of each network controller 130-134 can receive incoming data messages at the NIM 126’, determine how specific message destinations are to be contacted, and initiate communications to and from other network controllers if needed. Each processing device 210, 214, 218 includes any suitable computing or processing device, such as at least one microprocessor, microcontroller, digital signal processor, field programmable gate array, application specific integrated circuit, or discrete logic device.

Each memory 212, 216, 220 stores instructions or data used, generated, or collected by its associated processing device(s). For example, each memory 212, 216, 220 could store software or firmware instructions executed by its associated processing device(s). Each memory 212, 216, 220 could also store data being transported through the NIM 126’. Each memory 212, 216, 220 includes any suitable volatile and/or non-volatile storage and retrieval device(s), such as at least one random access memory and at least one Flash or other read-only memory.

A bus 222 facilitates communications between the network controllers 130-132. For example, the bus 222 could transport data between different controllers 130-132 to support the exchange of data between multiple control networks 120-124. The bus 222 includes any suitable structure for transporting data between network controllers.

A particular implementation of the network controllers 130-134 is shown in FIGURE 3. As shown in FIGURE 3, the network controller 130 can include a module RAM 302, which could represent at least part of the memory 212 in the controller 130. The network controller 130 can also include a NIM personality 304 and a network interface controller 306. The NIM personality 304 represents an application or other logic executed by the NIM 126’ to provide the desired gateway functionality. The NIM personality 304 could, for instance, represent the code executed by the processing device(s) 210 in the controller 130. The network interface controller 306 supports interactions with the physical interface 204 in order to facilitate communications over an LCN or other supervisory control network 120. The network controller 130 can further include two interfaces 308-310, which facilitate communications with the other network controllers 132-134 via the bus 222. The interfaces 308-310 can denote any suitable interfaces, such as Enhanced Process Network Interface (EPNI) interfaces (where the network controllers 132-134 are implemented using EPNI cards).

The network controller 132 can include a network interface controller 312, which supports interactions with the physical interface 206 in order to facilitate communications over a legacy control network 122. For example, the network interface controller 312 could represent an analog modem that communicates over a coaxial legacy network. The network controller 132 can also include a token bus controller 314, which supports the function of network management and message processing on a UCN or other token bus. In some embodiments, the token bus controller 314 can be placed into a so-called“promiscuous” or other mode of operation in which the token bus controller 314 is able to receive and handle data messages with destination addresses other than the NIM’s address (to enable routing of peer-to-peer messages not addressed to the NIM). The network controller 132 can further include logical link control (LLC) firmware 316, which represents code that includes support for the gateway and bridging functions described above. That is, the LLC firmware 316 allows the network controller 132 to exchange data with the network controllers 130, 134 in order to transport data amongst the control networks. In addition, the network controller 132 can include various forms of memory 318, such as registers on a PCB and a shared RAM (which can be accessible by other network controllers).

The network controller 134 can include a network interface controller 320, which supports interactions with the physical interface 208 in order to facilitate communications over an enhanced control network 124. For example, the interface controller 320 could include a network stack and interface supporting communications over an FTE network. The network controller 134 can also include logic 322 supporting various functions related to the enhanced control network 124. For example, UCN interface (UCNIF) logic can help map UCN addresses associated with the control network 122 into Internet Protocol (IP) addresses associated with the control network 124. Address resolution, authentication, and FTE status (heartbeat) functionality could also be used to support the use of an FTE network. A token bus controller emulator 324 emulates the function of network management and message processing on a UCN or other token bus so that the network controller 134 can interact directly with the network controller 132. The network controller 134 can further include LLC firmware 326, which represents code that supports the gateway and bridging functions described above and allows the network controller 134 to exchange data with the network controllers 130-132 in order to transport data amongst the control networks. In addition, the network controller 134 can include various forms of memory 328, such as registers on a PCB and a shared RAM (which can be accessible by other network controllers).

FIGURE 4 illustrates example data flows between components of the NIM 126’. As shown in FIGURE 4, the network controller 132 includes buffers 402-404, which are used to buffer data transmitted to and received from the control network 122. The data received from the control network 122 could be destined for one or more devices in any of the control networks 120-124. Similarly, the network controller 134 includes buffers 406-408, which are used to buffer data transmitted to and received from the control network 124. Again, the data received from the control network 124 could be destined for one or more devices in any of the control networks 120-124. In addition, a first shared memory block 410 includes buffers 412-414, which are used to buffer data transmitted to and received from the control network 120. Once again, the data received from the control network 120 could be destined for one or more devices in any of the control networks 120-124. Communications with the control network 120 occur via a driver 416, the NIM personality 304 (shown here as an application), a supervisory network LLC layer 418, and the network interface controller 306. The memory block 410 is shared in that it is accessible by both network controllers 130- 132. The shared memory block 410 could reside within the network controller 130, such as in a shared RAM of the network controller 130.

A second shared memory block 420 facilitates the exchange of data between the network controllers 132-134 (and indirectly the network controller 130). For example, a buffer 422 is used to buffer data going from the control networks 120-122 to the control network 124, and a buffer 424 is used to buffer data going from the control network 124 to the control networks 120-122. The NIM personality 304 could monitor these buffers 422-424 to identify their status, but it need not process any messages contained in these buffers 422-424 that are being transported between the control networks 122-124. The shared memory block 420 could reside within the network controller 130, such as in a shared RAM of the network controller 130.

The second shared memory block 420 is also used to store a network management database 428 and a network status database 430. The network management database 428 can be used to store various information used by the network controllers 130-134 or other components of a control and automation system, such as information used to map different addresses in different network spaces. The network status database 430 can also be used to store various information used by the network controllers 130-134 or other components of a control and automation system, such as information identifying the status of various components or communication links of the control and automation system.

In some embodiments, the NIM personality 304 can periodically request (via the network controller 132) the status of all legacy devices coupled to the control network 122 and assigned to the NIM 126’. For example, this request could be sent as a UCN Type 3 data request for the AUX STATUS Service Access Point (SAP). A Read Data Response (RDR) from each legacy device contains the current node status of that legacy device. These messages can be used to maintain a first Route Table in the network management database 428 or the network status database 430. Also, the network controller 134 can listen for periodic or on-change IP multicast or other annunciations of the node status for enhanced devices on the control network 124. These annunciations can be used to populate a second Route Table in the network management database 428 or the network status database 430.

In some embodiments, one or both of the databases 428-430 can be maintained in multiple locations within the NIM 126’. For example, one or more address resolution tables that identify the nodes identified on the enhanced network 124 can be maintained in the memory of the network controller 134 and copied to the second shared memory block 420 for use by the network controller 132. Similarly, the LLC layer 316 of the network controller 132 can maintain a list of nodes on the control network 122 and can copy this list to the second shared memory block 420 for use by the network controller 134.

Note that in this example, traffic between the control networks 120 and 124 appears to pass through the network controller 132 for the control network 122. This is done so that the enhanced process controllers 112-116 appear (from the perspective of DCS nodes 102-104 or other higher-level devices) to reside on the legacy network. This also allows the network controller 132 to function as the“master” for network communications over the control networks 122-124. This may be beneficial since it allows the network controller 132 to control cable swapping and time synchronization on the control network 122 while transferring data messages into and out of various buffers between the network controllers 132-134 (where communications on the control network 124 are less time-stringent). However, this need not be the case.

FIGURE 5 illustrates an example top-level context model 500 of a portion of a control and automation system that includes the NIM 126’. This context model 500 illustrates various communication paths used in the system and depicts the relationships between the NIM 126’ and other devices. Note that specific protocols or networks are shown in FIGURE 5, such as LCN, UCN, and enhanced UCN or “EUCN” (which could represent an FTE network). However, these specific protocols are examples only.

As shown in FIGURE 5, the NIM 126’ communicates with a redundant NIM 128’, which could represent the NIM 128 shown in FIGURE 1 after updating to include the functionality as the NIM 126’. The NIM 128’ could operate in the secondary mode to monitor and synchronize with the NIM 126’ while the NIM 126’ operates in the primary mode.

The NIM 126’ also communicates with various LCN nodes 502 over the supervisory control network 120. The LCN nodes 502 could include the DCS nodes 102-104. Specific examples of LCN nodes 502 include HISTORY MODULES (HMs), APPLICATION MODULES (AMs), and UNIVERSAL STATIONS (USs) from HONEYWELL INTERNATIONAL INC.

The NIM 126’ further communicates with various legacy process manager (PM) nodes 504, logic manager (LM) nodes 506, and safety manager (SM) nodes 508 over the legacy control network 122. The PM nodes 504 could include standard token bus process controllers. The LM nodes 506 could include classic UCN token bus controllers. The SM nodes 508 could include classic safety controllers on a UCN token bus.

In addition, the NIM 126’ communicates with various high-performance process managers (HPMs) 510 over the control network 122 and enhanced HPMs (EHPMs) 512 over the control network 124. The HPM 510 here represents a legacy device in a redundant pair of devices (such as the process controller 108), while the EHPM 512 here represents an enhanced device in a redundant pair of devices (such as the process controller 110’). The HPM 510 and EHPM 512 communicate via different control networks 122-124, and the NIM 126’ supports the concurrent access to these devices. Moreover, various ones of the nodes 504-508 often need to engage in peer-to-peer communications with the HPM 510 and the EHPM 512, and the bridging function of the NIM 126’ helps to enable these peer-to-peer communications.

In FIGURE 5, the following data types are identified as being used between devices. Note that these data types are for illustration only.“UCN” traffic can denote data contained in IEEE 802.4 token bus frames, which are passed between classic UCN nodes on the control network 122.“EUCN” traffic can denote FTE or other EUCN data contained in IEEE 802.3 Ethernet frames, which are passed between FTE or other EUCN nodes on the control network 124.“Routed UCN” traffic can denote messages received on the control network 122 and retransmitted on the control network 124.“Routed EUCN” traffic can denote messages received on the control network 124 and retransmitted on the control network 122.“UCN Redundancy” can denote messages that are passed on the control network 122 between redundant legacy nodes and can be retransmitted on the control network 124 as EUCN messages. “EUCN Redundancy” can denote messages that are passed over the control network 124 between redundant enhanced nodes and can be retransmitted on the control network 122 as UCN messages.“LCN” can denote messages that are passed to and from the NIM 126’ over the control network 120.

FIGURE 6 illustrates an example functional division amongst the network controllers 130-134 within the NIM 126’. Note that specific protocols or networks are shown in FIGURE 6, such as LCN, UCN, and EUCN/FTE. However, these specific protocols are examples only.

As shown in FIGURE 6, the network controller 130 is implemented here using a K4LCN interface card, and the control network 120 is accessed using an LCN token ring interface. Here, the network controller 130 provides a console debugger, which can be useful during development and debugging. The network controller 130 also supports quality logic testing (QLT) of the NIM 126’ and runs the NIM personality 304. In addition, the network controller 130 provides a shared memory (such as the shared memory blocks 410 and 420) and supports interfaces to the network controllers 132-134.

The network controller 132 is implemented here using an EPNI card, and the control network 122 is accessed using a UCN token bus modem. Here, the network controller 132 processes UCN messages, performs UCN cable state management, and supports UCN time synchronization messaging. These are standard functions for UCN devices. The network controller 132 also routes messages for specific enhanced devices to the network controller 134 and copies multicast messages for multiple enhanced devices to the network controller 134. The network controller 132 further routes received UCN messages to the network controller 134 for delivery over the enhanced network 124, thereby supporting peer-to-peer communications via its bridging function.

The network controller 134 is implemented here using another EPNI card, and the control network 124 is accessed using an FTE interface. Here, the network controller 134 routes messages for specific enhanced devices over the enhanced network 124 and multicast messages for multiple enhanced devices over the enhanced network 124. The network controller 134 also routes messages for the control network 120 to the network controller 132. The network controller 134 further routes messages for the control network 122 to the network controller 132, thereby supporting peer-to- peer communications via its bridging function. In addition, the network controller 134 supports the encapsulation of time synchronization information, which can be used to support time synchronization within the enhanced network 124.

Although FIGURES 2 through 6 illustrate one example of a device supporting on-process migration in an industrial process control and automation system, various changes may be made to FIGURES 2 through 6. For example, the specific implementations of the NIM 126’ shown here are for illustration only. Various other implementations of the NIM 126’, such as those that couple to different types of control networks 120-126, could be supported.

FIGURE 7 illustrates an example method 700 for supporting communications between components during an on-process migration in an industrial process control and automation system according to this disclosure. For ease of explanation, the method 700 is described with respect to the NIM 126’ operating in the system of FIGURE 1. However, the method 700 could be used by any suitable device and in any suitable system.

As shown in FIGURE 7, first data messages are received from a supervisory control network at a first network controller of a NIM at step 702. This could include, for example, the network controller 130 receiving the first data messages from the DCS nodes 102-104 or other higher-level components over the supervisory control network 120. The first data messages are provided to second and third network controllers of the NIM at step 704. This could include, for example, the network controller 130 providing the first data messages to the network controllers 132-134 via the memory blocks 410, 420 of the shared RAM. The first data messages are routed over legacy and enhanced control networks at step 706. This could include, for example, the network controllers 132-134 mapping the addresses of the first data messages into suitable address spaces for the control networks 122-124. This could also include the network controllers 132-134 transmitting the first data messages to the legacy and enhanced process controllers 106-116. In this way, the NIM provides a gateway function and allows higher-level devices to transmit data messages to lower- level devices in the control and automation system.

Second data messages are received from the legacy and enhanced control networks at the second and third network controllers of the NIM at step 708. This could include, for example, the network controllers 132-134 receiving the second data messages from the process controllers 106-116 or other lower-level components over the control networks 122-124. The second data messages are provided to first network controller of the NIM at step 710. This could include, for example, the network controllers 132-134 providing the second data messages to the network controller 130 via the memory blocks 410, 420 of the shared RAM. The second data messages are routed over the supervisory control network at step 712. This could include, for example, the network controller 130 transmitting the second data messages to the DCS nodes 102-104. In this way, the NIM provides a gateway function and allows lower-level devices to transmit data messages to higher-level devices in the control and automation system.

Third data messages are received from the legacy control network or the enhanced control network at the second network controller or the third network controller of the NIM at step 714. This could include, for example, the network controller 132 or 134 receiving the third data messages from the process controllers 106-110 or 112-116 over the control network 122 or 124. The third data messages are provided to the third or second network controllers of the NIM at step 716. This could include, for example, the network controller 132 providing the third data messages to the network controller 134 (or vice versa) via the memory block 420 of the shared RAM. The third data messages are routed over the enhanced control network or the legacy control network at step 718. This could include, for example, the network controller 132 transmitting the third data messages to the process controllers 106-110, or the network controller 134 transmitting the third data messages to the process controllers 112-116. In this way, the NIM provides a bridge function and allows lower-level devices on one control network to exchange data messages with other lower-level devices on another control network in the control and automation system.

Although FIGURE 7 illustrates one example of a method 700 for supporting communications between components during an on-process migration in an industrial process control and automation system, various changes may be made to FIGURE 7. For example, while shown as a series of steps, various steps in FIGURE 7 could overlap, occur in parallel, occur in a different order, or occur multiple times.

FIGURE 8 illustrates an example method 800 for on-process migration in an industrial process control and automation system according to this disclosure. For ease of explanation, the method 800 is described with respect to the system of FIGURE 1. However, the method 800 could be used in any suitable system.

As shown in FIGURE 8, existing nodes in an industrial process control and automation system are updated to a software release that supports on-process migration at step 802. The existing nodes represent legacy nodes, such as those coupled to a legacy control network 122 or those coupled to the supervisory control network 120.

A first NIM in a redundant pair of NIMs is upgraded and coupled to an advanced control network at step 804. This could include, for example, installing the network controller 134 in the NIM 126 to create the NIM 126’. This could also include coupling the network controller 134 in the NIM 126’ to the control network 124. The NIM being upgraded here denotes the backup NIM in the redundant pair. A failover is performed from an un-upgraded second NIM to the upgraded first NIM at step 806. This could include, for example, causing the NIM 128 to enter the backup mode while the NIM 126’ enters the primary mode. The second NIM is upgraded and coupled to the advanced control network at step 808. This could include, for example, installing the network controller 134 in the NIM 128 to create the NIM 128’. This could also include coupling the network controller 134 in the NIM 128’ to the control network 124.

A first controller in a redundant pair of controllers is upgraded and a new personality is loaded onto the upgraded first controller at step 810. This could include, for example, installing a new controller module and a new network interface board into the controller 110 and coupling the new interface board to the advanced control network 124. The controller being upgraded here denotes the backup controller in the redundant pair. A verification is made that the upgraded first controller can synchronize with an un-upgraded second controller of the redundant pair at step 812. This could include, for example, verifying that the upgraded first controller 110’ (operating in the backup mode) can synchronize with the controller 108 (operating in the primary mode). If so, a failover is performed from the un-upgraded second controller to the upgraded first controller at step 814. This could include, for example, causing the controller 108 to enter the backup mode while the controller 110’ enters the primary mode. A verification is made that the un-upgraded second controller can synchronize with the upgraded first controller at step 816. This could include, for example, verifying that the controller 108 (now operating in the backup mode) can synchronize with the controller 110’ (now operating in the primary mode). If so, the second controller is upgraded and a new personality is loaded onto the upgraded second controller at step 818, and a verification is made that the upgraded second controller can synchronize with the upgraded first controller at step 820.

Although FIGURE 8 illustrates one example of a method 800 for on-process migration in an industrial process control and automation system, various changes may be made to FIGURE 8. For example, while shown as a series of steps, various steps in FIGURE 8 could overlap, occur in parallel, occur in a different order, or occur multiple times. Also, note that each NIM and controller can be upgraded either by physically updating a legacy NIM or controller or by installing a new NIM or controller. While FIGURE 8 indicates that the former option is being used, the latter option is also available. In addition, while the upgrading of controllers is shown in steps 810-820, any suitable legacy device(s) could be upgraded using the technique shown in FIGURE 8.

In some embodiments, various functions described in this patent document are implemented or supported by a computer program that is formed from computer readable program code and that is embodied in a computer readable medium. The phrase “computer readable program code” includes any type of computer code, including source code, object code, and executable code. The phrase“computer readable medium” includes any type of medium capable of being accessed by a computer, such as read only memory (ROM), random access memory (RAM), a hard disk drive, a compact disc (CD), a digital video disc (DVD), or any other type of memory. A“non-transitory” computer readable medium excludes wired, wireless, optical, or other communication links that transport transitory electrical or other signals. A non-transitory computer readable medium includes media where data can be permanently stored and media where data can be stored and later overwritten, such as a rewritable optical disc or an erasable memory device.

It may be advantageous to set forth definitions of certain words and phrases used throughout this patent document. The terms“application” and“program” refer to one or more computer programs, software components, sets of instructions, procedures, functions, objects, classes, instances, related data, or a portion thereof adapted for implementation in a suitable computer code (including source code, object code, or executable code). The terms“transmit,”“receive,” and“communicate,” as well as derivatives thereof, encompasses both direct and indirect communication. The term “couple” and its derivatives refer to any direct or indirect connection between two or more components. The terms“include” and“comprise,” as well as derivatives thereof, mean inclusion without limitation. The term“or” is inclusive, meaning and/or. The phrase“associated with,” as well as derivatives thereof, may mean to include, be included within, interconnect with, contain, be contained within, connect to or with, couple to or with, be communicable with, cooperate with, interleave, juxtapose, be proximate to, be bound to or with, have, have a property of, have a relationship to or with, or the like. The phrase“at least one of,” when used with a list of items, means that different combinations of one or more of the listed items may be used, and only one item in the list may be needed. For example,“at least one of: A, B, and C” includes any of the following combinations: A, B, C, A and B, A and C, B and C, and A and B and C.

While this disclosure has described certain embodiments and generally associated methods, alterations and permutations of these embodiments and methods will be apparent to those skilled in the art. Accordingly, the above description of example embodiments does not define or constrain this disclosure. Other changes, substitutions, and alterations are also possible without departing from the spirit and scope of this disclosure, as defined by the following claims.