[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

WO2021044652A1 - マスタ装置、演算処理装置、プログラマブルロジックコントローラ、ネットワーク、および方法 - Google Patents

マスタ装置、演算処理装置、プログラマブルロジックコントローラ、ネットワーク、および方法 Download PDF

Info

Publication number
WO2021044652A1
WO2021044652A1 PCT/JP2020/009127 JP2020009127W WO2021044652A1 WO 2021044652 A1 WO2021044652 A1 WO 2021044652A1 JP 2020009127 W JP2020009127 W JP 2020009127W WO 2021044652 A1 WO2021044652 A1 WO 2021044652A1
Authority
WO
WIPO (PCT)
Prior art keywords
slave
frame
data
command
path
Prior art date
Application number
PCT/JP2020/009127
Other languages
English (en)
French (fr)
Inventor
泰士 福田
Original Assignee
オムロン株式会社
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by オムロン株式会社 filed Critical オムロン株式会社
Priority to CN202080056369.8A priority Critical patent/CN114245978B/zh
Priority to EP20861702.7A priority patent/EP4027591A4/en
Priority to US17/635,381 priority patent/US20220400031A1/en
Publication of WO2021044652A1 publication Critical patent/WO2021044652A1/ja

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/42Loop networks
    • H04L12/437Ring fault isolation or reconfiguration
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/42Loop networks
    • H04L12/423Loop networks with centralised control, e.g. polling
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/42Loop networks
    • H04L12/422Synchronisation for ring networks

Definitions

  • the present disclosure relates to master devices, arithmetic processing units, programmable logic controllers, networks, and methods.
  • a network composed of a master and a slave is known.
  • a line topology (daisy chain), a tree topology, a ring topology, and the like are known.
  • a ring topology for example, a ring-type network system as disclosed in Patent Document 1 (Japanese Unexamined Patent Publication No. 2016-119616) has been proposed.
  • a plurality of slaves are connected in a ring shape by ring wiring, and one of the plurality of slaves operates as a junction (branch) which is a starting point or an ending point of data transfer, that is, a so-called junction. Redundant ring wiring has been proposed.
  • the data transmitted from the start point of the master returns to the end point of the master via multiple slaves.
  • the slave at the cut point performs loopback (return transfer).
  • the inventor states that if the disconnection is subsequently reconnected, the loopbacked data will cycle through the ring wiring, and then again, if the wiring is disconnected, the cyclic data can return to the master, and for the master. Obtained the finding that the returned patrol data may be erroneously entered.
  • An object of the present disclosure is to provide a master device, an arithmetic processing device, a programmable logic controller, a network, and a method for suppressing the generation of cyclic data in ring wiring.
  • a master device that manages a plurality of slave devices connected to a ring wiring.
  • the plurality of slave devices include a first slave device that serves as a start point and an end point of the ring wiring, and a plurality of second slave devices that are connected between the start point and the end point of the first slave device.
  • the master device is provided with a command means for transmitting a command for switching the second path to the first path to the slave device that executes loopback when the route is restored from disconnection, and the ring wiring is propagated from the time when the command is transmitted. After the time based on the delay time has elapsed, the data is sent to the ring wiring.
  • the master device when the ring wiring recovers from the disconnection, the master device sets the first loopback path in the ring wiring when the command reaches the corresponding slave and the command is executed.
  • the time required to switch to the route is estimated from the time based on the propagation delay time, and the master device can send new data to the ring wiring at the timing when the expected time has elapsed.
  • the transmitted new data can be transferred in the first path, and it is possible to suppress the generation of reverse patrol data, which is data that patrols in the loopback direction in the ring wiring.
  • each slave device has a first port and a second port to which a route connecting to an adjacent slave device is connected, and each second slave device is on the starting point side when the first route is configured.
  • the incoming data is received from the 1st port, the received data is transferred from the 2nd port to the end point side, and the command is an open command that enables data reception from the detected 1st port and from the 2nd port.
  • the command means changes the transmission order of the open command of the first port and the open command of the second port according to the position on the ring wiring of the cutting path, including the open command that enables the data reception of the above.
  • the master is an open command from the first port and a second port that allows the slave having the first and second ports connected to the disconnect path to receive data from the first port as a command.
  • the transmission order of this command can be changed according to the position of the cutting path on the ring wiring.
  • the master device further includes means for detecting the first port and the second port of the slave device to which the disconnection route is connected based on the communication with the plurality of slave devices.
  • the master device upon transmitting a command, detects the first port and the second port of the slave device to which the disconnection path is connected based on the communication between the master device and the plurality of slave devices. be able to.
  • the data includes a code indicating whether or not the data has changed from loopback to cyclic transfer
  • the master device is data in which the code indicates a change in the incoming data from the ring wiring. Is detected and the detected data is discarded.
  • the master device transfers the data that has changed from the loopback transfer to the cyclic transfer from the data that reaches the master device, based on the change in the code of the data. It can be detected (extracted) and the detected data can be discarded.
  • the master device sends data to the ring wiring while allocating generations to the data, and when the master device transmits a command, the generation to be assigned to the data thereafter is assigned before the command transmission.
  • the master device detects data that is assigned to a generation different from the one currently assigned to the data among the data that comes in from the ring wiring, and discards the detected data.
  • the master device changes the generation assigned to the data to be sent to the ring wiring before and after sending the command when the route is restored from the disconnection.
  • the master device detects the data that has changed from loopback to cyclic transfer when this command is transmitted, among the data that reaches the master device, based on the assigned generation, and discards the detected data. can do.
  • the master device outputs a notification that a change from loopback transfer to cyclic transfer has occurred for the data.
  • the ring wiring includes an EtherCAT® network.
  • the above configuration of the master device can be applied in the EtherCAT network.
  • An arithmetic processing unit including the master device according to the above disclosure is provided.
  • a programmable logic controller including the arithmetic processing unit according to the above disclosure is provided.
  • a network including ring wiring includes a plurality of slave devices connected to the ring wiring and a master device that manages the plurality of slave devices, and the plurality of slave devices include a first slave device that is a start point and an end point of the ring wiring, and a first slave device.
  • the ring wiring includes a plurality of second slave devices connected between the start point and the end point of one slave device, and each second slave device receives data coming in from the start point side and receives the received data as the end point.
  • the first path for cyclic transfer to the side and the second path for looping back data from the own device when each of the plurality of slave devices disconnects the path between the adjacent slave devices.
  • the master device is configurable and comprises a command means for transmitting a command for switching the second path to the first path to the slave device performing the loopback when the route is recovered from the disconnection, and when the command is transmitted, the master device is provided. After a lapse of time based on the propagation delay time of the ring wiring, data is sent to the ring wiring.
  • the master device when the path of the ring wiring is restored from the disconnection, the master device reaches the slave to which the command corresponds in the ring wiring, and the command is executed by the slave to execute the second path of the loopback.
  • the time required for switching to the first path is estimated as the time based on the propagation delay time.
  • the master device can send new data to the ring wiring at the timing when this expected time has elapsed. As a result, the transmitted new data can be transferred in the first path, and it is possible to suppress the generation of reverse patrol data that patrols in the loopback direction in the ring wiring.
  • a method implemented by a master device that manages a plurality of slave devices connected to a ring wiring includes a first slave device that serves as a start point and an end point of the ring wiring, and a plurality of second slave devices that are connected between the start point and the end point of the first slave device.
  • the first path for the second slave device to receive the incoming data from the starting point side and cyclically transfer the received data to the ending point side, and the path between each of the plurality of slave devices and the adjacent slave devices are It is possible to configure a second path for looping back data from the own device when disconnected, and the method is a command to switch the second path to the first path when the route recovers from the disconnection. Is provided to a slave device that performs loopback, and a step of transmitting data to the ring wiring after a time based on the propagation delay time of the ring wiring has elapsed from the time of transmitting the command.
  • the master device when the method is implemented, when the ring wiring path recovers from disconnection, the master device reaches the slave to which the command corresponds in the ring wiring, and the command is executed by the slave.
  • the time required for the second path of the loopback to switch to the first path is estimated as the time based on the propagation delay time.
  • the master device can send new data to the ring wiring at the timing when the expected time has elapsed. As a result, the transmitted new data can be transferred in the first path, and it is possible to suppress the generation of reverse patrol data that patrols in the loopback direction in the ring wiring.
  • FIG. 5 is a schematic diagram of another example of the functional configuration of the slave according to the present embodiment. It is a figure which shows an example of the flowchart of the process of the "first mode” which concerns on this embodiment. It is a figure which shows the other example of the functional structure of the master which concerns on this embodiment schematically. It is a figure for demonstrating the process of the generation setting part which concerns on this Embodiment.
  • a case applied to a control system centered on a PLC will be illustrated.
  • a control system not only a PLC but also a configuration centered on various industrial computers can be adopted.
  • the target to which the network configuration is applied is not limited to the control system.
  • the control system includes, for example, a master 10 that manages a plurality of slaves connected to ring wirings that make up a field network.
  • EtherCAT can be applied to the ring wiring.
  • the plurality of slaves are a first slave device (branch slave) which is the starting point and ending point of the ring wiring, and a plurality of second slave devices (slave "A") connected between the starting point and the ending point of the first slave device. , Slave "B", slave "C” and slave “D”).
  • the first slave device corresponds to a so-called junction that realizes data exchange between the second slave device connected to the ring wiring and the master 10 while branching data between them.
  • the master 10 corresponds to, for example, a PLC
  • the second slave includes a device for connecting a control target (sensor, switch, relay, etc.) provided in the field.
  • the data includes, for example, a control command transmitted from the master 10 to each slave, and field information transmitted from the second slave to the master 10.
  • the data is composed of, for example, a frame format, but is not limited to the frame format.
  • each second slave device receives data coming in from the starting point side, and the first path 15 (Step 0 in FIG. 5) for transferring the received data to the ending point side, and each of the plurality of slave devices
  • the second path 16 (Step 1 in FIG. 5) for loopback transfer of data from the own slave device can be configured.
  • the ring wiring can form a junction redundancy ring topology in which the first path 15 and the second path 16 can be redundantly configured.
  • the master 10 loops back a command for switching the second route 16 to the original first route 15 when the disconnected portion of the route is connected and the route recovers from the disconnection (Step 2 in FIG. 5).
  • the slave "C” and the slave “D” that perform the loopback transfer receive the command and execute the received command.
  • the command is executed, for example, the input / output ports of the slave "C” and the slave “D” connected to the restored route are opened.
  • the master 10 sends new data to the ring wiring after a predetermined time based on the propagation delay time of the ring wiring has elapsed from the time when the above command is transmitted to the ring wiring. As a result, it is possible to prevent the new data from becoming reverse patrol data described later in the ring wiring.
  • disconnection and connection of ring wiring assumes physical events such as disconnection and connection of cables, but disconnection or connection events are not limited to physical layer events.
  • disconnection or connection events are not limited to physical layer events.
  • the present disclosure can be applied even to a logical disconnection or connection event in a layer higher than the physical layer (for example, a connection layer).
  • Step 3 in FIG. 5 When the route connected in Step 2 is subsequently disconnected (Step 3 in FIG. 5), the second route 16 is configured again in the ring wiring, and the reverse patrol data is sent to the master 10 via the second route 16. Is reached (Step 3 in FIG. 5). For the master 10, the reverse patrol data can be erroneously input.
  • the command corresponds to the corresponding slave device via the ring wiring (for example, the slave "C” and the slave ".
  • a predetermined time based on the propagation delay time until reaching "D" has elapsed, new data is sent to the ring wiring.
  • the master 10 reaches the slave to which the command corresponds in the ring wiring, and the reached command is executed by the slave to execute the second path of the loopback.
  • the time required for 16 to switch to the first path 15 is estimated as the time based on the propagation delay time.
  • the master 10 can send new data to the ring wiring at the timing when the expected time has elapsed. As a result, the transmitted new data can be transferred on the first path 15, and it is possible to suppress the generation of reverse patrol data that patrols in the loopback direction in the ring wiring.
  • FIG. 1 is a schematic view showing the overall configuration of the PLC system 1 according to the present embodiment.
  • the PLC system 1 is a control system for controlling an object, and is an example of a system to which the network according to the present disclosure is applied.
  • the PLC system 1 includes a main processing device 2 and a plurality of remote devices, slaves 40-0, 40-1, 40-2, 40-3, 40-4.
  • the main processing device 2 and the slaves 40-0, 40-1, 40-2, 40-3, 40-4 are devices that form at least a part of the PLC system 1, and are connected via the network 4. ..
  • a bus or network that performs constant periodic communication in which the arrival time of data is guaranteed according to the TSN (Time-sensitive networking) standard.
  • TSN Time-sensitive networking
  • a network related to a known protocol such as EtherCAT, which is an example of a network for machine control, and EtherNet / IP (registered trademark), which is an industrial open network in which a control protocol is implemented on a general-purpose Ethernet (registered trademark). It may be adopted.
  • the main processing device 2 executes an input signal (hereinafter, "field information") from an external switch or sensor (not shown) by executing a program (including a user program and a system program) necessary for controlling the target.
  • field information an input signal
  • a program including a user program and a system program
  • a process of collecting referred to as), a process of performing a control calculation based on the collected field information, a process of giving a command value calculated by the control calculation to a control target such as an external relay or an actuator, and the like are realized.
  • the main processing device 2 corresponds to a PLC, and has a processor unit 10 as an arithmetic processing unit including a CPU (Central Processing Unit) and one or more IO units 20 for performing input / output operations.
  • a power supply unit 30 is provided.
  • the processor unit 10 and the IO unit 20 are connected to each other so as to be capable of data communication via an internal bus (not shown).
  • the power supply unit 30 supplies electric power of an appropriate voltage to the processor unit 10 and the IO unit 20.
  • the processor unit 10 communicates between the arithmetic unit that executes the program necessary for controlling the target and the slaves 40-0,40-1,40-2,40-3,40-4 via the network 4. It includes a communication controller 110 corresponding to a communication processing unit for control. Communication via the network 4 is independently controlled by the main processing device 2. Specifically, the processor unit 10 transmits data sequentially transmitted on the network 4 according to a cycle based on the timer 115 described later, a predetermined timing, or a rule. In the following description, the data sequentially transmitted on the network 4 is also referred to as a "frame". In this sense, the processor unit 10 is hereinafter referred to as a "master 10" that manages slaves 40-0, 40-1, 40-2, 40-3, 40-4.
  • the PLC system 1 of FIG. 1 includes four slaves 40-0, 40-1, 40-2, 40-3, 40-4, but the number of slaves is not limited to four.
  • the slave 40 receives field information from a field device such as an external switch or sensor, and transmits the received field information to the master 10 via the network 4. At the same time, the slave 40 outputs a command value received from the master 10 via the network 4 to an external relay or actuator field device. Alternatively, the slave 40 may operate by itself according to a command value received via the network 4. For example, as the slave 40, a simple IO unit having no arithmetic function, an IO unit having an arithmetic function, a device including an actuator such as a motion controller, and the like are assumed.
  • the communication controller 110 of the master 10 manages the transmission of a data string (corresponding to "frame 50" in the present embodiment) including data handled by the main processing device 2 and one or more slaves 40 on the network 4. It is configured to do.
  • the network (network system) is composed of a master 10 and a plurality of slaves 40.
  • the master 10 manages a plurality of slaves 40-0 to 40-4 constituting a network including a ring topology.
  • the master 10 is communicably connected to a support device 200 which is an external information processing device.
  • the support device 200 includes a display 209.
  • slave 40-0 is referred to as branch slave 40-0
  • slaves 40-1 to 40-4 are slave "A”, slave “B”, slave “C” and slave, respectively. Also referred to as "D”.
  • FIG. 1 as ports possessed by each slave, an input port IN in which the frame 50 mainly enters and an output port OUT in which the frame 50 is transmitted mainly on the network 4 are shown.
  • the branch slave 40-0 is a slave that serves as a starting point and an ending point of the ring topology, and is a slave that constitutes the ring topology.
  • the slave "A”, the slave “B”, the slave “C” and the slave “D” are connected in this order in a daisy chain, and the slave group connected in the daisy chain is the starting point of the branch slave 40-0. It is connected between the corresponding port OUT1 and the corresponding port IN1 at the end point. Further, the master 10 is connected to the input port PO of the branch slave 40-0.
  • the port OUT1 and the port IN1 of the branch slave 40-0 are connected to the input port IN of the slave "A" and the output port OUT of the slave "D", respectively.
  • the output port OUT of each slave 40 is connected to the input port IN of the adjacent slave 40.
  • the frame 50 transmitted from the network 4 from the master 10 passes through the branch slave 40-0, each slave 40 connected in a daisy chain, and then the branch slave 40-0, and then the master 10. Return to. Therefore, the master 10 can exchange data (command value or field information) with each slave 40 via a frame 50 that circulates in the ring topology.
  • the "IN-OUT relationship" is defined between the two slaves 40 connected to each other by the cable of the network 4.
  • the data input from the output port OUT of one slave 40 to the input port IN of the other slave 40 is also referred to as "input from OUT to IN”.
  • the data input from the input port IN of one slave 40 to the output port OUT of the other slave 40 is also referred to as “input from IN to OUT” (hereinafter, “input from IN to OUT”).
  • FIG. 2 is a schematic diagram showing a hardware configuration of the processor unit 10 included in the PLC system 1 according to the present embodiment.
  • the apparatus configuration of the master 10 (that is, the processor unit 10) according to the present embodiment will be described with reference to FIG.
  • the master 10 is an example of a processor 100 which is a calculation unit, a main memory 102 which is an example of a main storage device, and an auxiliary storage device in addition to a communication controller 110 which is a communication processing unit. It includes a non-volatile memory 104, an internal bus controller 106, a timer 115, a memory card interface 114, a USB (Universal Serial Bus) controller 112, and a communication controller 110 to which the network 4 is connected. These components are configured to be data communicable with each other via the internal bus 108.
  • the master 10 further includes an output port 121 for sending the frame 50 to the network 4 and an input port 131 for receiving the frame 50 from the network 4.
  • the main memory 102 is composed of a volatile storage device such as a DRAM (Dynamic Random Access Memory) or a SRAM (Static Random Access Memory).
  • the non-volatile memory 104 is composed of, for example, a non-volatile storage device such as an HDD (Hard Disk Drive) or an SSD (Solid State Drive).
  • the master 10 includes only one processor 100, but a plurality of processors may be mounted. It should be noted that each processor may have a plurality of cores. In the master 10, processor 100 periodically executes one or more tasks.
  • the processor 100 executes a program related to control.
  • the processor 100 reads a necessary program from the non-volatile memory 104 or the like, and expands the read program into the main memory 102 to execute the program.
  • the control program typically includes a user program and a system program.
  • the internal bus controller 106 is connected to the IO unit 20 via the internal bus 109 and mediates the exchange of data between the processor 100 and the IO unit 20.
  • the memory card interface 114 is configured so that the memory card 116 can be attached and detached, and data can be written to the memory card 116 and various data (user programs, data, etc.) can be read from the memory card 116. There is.
  • the user program may be loaded from the memory card 116 into the non-volatile memory 104.
  • the USB controller 112 controls communication between the support device 200 and the master 10.
  • the standard for communication with the support device 200 is not limited to USB, and various communication standards can be applied.
  • the communication controller 110 is connected to the slave 40 via the network 4 and mediates the exchange of data (commands, field information, etc.) between the master 10 and the slave 40. More specifically, the communication controller 110 includes a shared memory 111, a transmission buffer 120, a transmission circuit 122, a reception buffer 130, and a reception circuit 132. The transmitting circuit 122 and the receiving circuit 132 are connected to the output port 121 and the input port 131, respectively, send data onto the network 4 via the connected ports, and receive data coming in from the network 4.
  • the transmission buffer 120 and the transmission circuit 122 realize the processing related to frame transmission from the communication controller 110 to the external device
  • the reception buffer 130 and the reception circuit 132 realize the processing related to frame reception from the external device to the communication controller 110.
  • the communication controller 110 has the shared memory 111, and the processor 100 directly accesses the shared memory 111, writes data (field information, etc.) to the shared memory 111, and data (command) from the shared memory 111. Etc.) to get. That is, the data written in the shared memory 111 is transferred to the transmission buffer 120 and sent from the transmission buffer 120 to the external device. Further, the data acquired from the external device is transferred to the shared memory 111 after being received by the reception buffer 130.
  • the communication controller 110 may realize a part or all of it by using software. Alternatively, a part or all of them may be realized by using a hardware circuit such as an ASIC (Application Specific Integrated Circuit) or an FPGA (Field-Programmable Gate Array).
  • ASIC Application Specific Integrated Circuit
  • FPGA Field-Programmable Gate Array
  • FIG. 3 is a schematic view showing the hardware configuration of the slave 40 according to the present embodiment. The device configuration of the slave 40 according to the present embodiment will be described with reference to FIG.
  • the slave 40 includes a processor 400, a timer 403, an input port 410, an output port 420, a receiving circuit (abbreviated as Rx in the figure) 424 and 433, and a transfer circuit (abbreviated as Tx in the figure). ) 423 and 434 are provided.
  • the processor 400 transmits / receives data to / from the network 4 via the input port 410 or the output port 420, and performs predetermined processing on the transmitted / received data.
  • the processor 400 realizes a predetermined process including the frame process of the frame processing unit 440 by executing the software.
  • the frame processing unit 440 of the slave 40 (excluding the branch slave) mainly exchanges data (command or field information) between the incoming frame 50 and a field device (not shown).
  • the processor 400 may be realized in part or in whole by software, or may be realized as a processor circuit.
  • the circuit may include an ASIC or FPGA.
  • the input port 410 includes a port 411 to which the receiving circuit 424 is connected and a port 412 to which the transfer circuit 434 is connected.
  • the output port 420 includes a port 421 to which the receiving circuit 433 is connected and a port 422 to which the transfer circuit 423 is connected.
  • the processor 400 outputs the switching signals 401 and 402 to the input port 410 and the output port 420, respectively, according to a cycle based on the timer 403, a predetermined timing, or a rule.
  • the input port 410 connects one of the ports 410 and 411 to the network 4 according to the switching signal 401
  • the output port 420 connects one of the ports 422 and 421 to the network 4 according to the switching signal 402.
  • the "IN-OUT relationship" described above is dynamically switched between the two slaves 40 connected to each other by the network 4. Specifically, when the ports 411 and 422 are connected to the network 4, the frame 50 is transferred by "input from OUT to IN", and when the ports 412 and 421 are connected to the network 4, "from IN”. The frame 50 is transferred by "input to OUT”.
  • FIG. 4 is a diagram for schematically explaining an example of a frame flow between two slaves according to the present embodiment.
  • FIG. 4 shows the flow of frame 50 between any two adjacent slaves 40 in the ring topology of FIG. 1, eg, the flow of frame 50 between slave “C” and slave “D”.
  • FIG. 5 is a diagram for schematically explaining an example of a change in the route of the frame 50 in the ring topology according to the present embodiment.
  • the broken line arrow represents the flow (path) of the frame 50.
  • the numbers above and below the broken line arrows ((i), (ii), (iii), ...) Indicates the flow order (route order) of the frame 50. In the following, for convenience of explanation, when the route (i) or the like is described, it means the route of the number (i).
  • the frame processing unit 440 receives the incoming frame 50 and performs a predetermined process on the received frame 50. After that, the frame processing unit 440 sends the processed frame 50 to the output port 420 (see (iii)).
  • the frame 50 is transferred from the output port 420 to the slave "D” via the network 4.
  • the frame 50 is forwarded to the input port 410 of the slave “D” (see (iv)).
  • the input port 410 transmits the incoming frame 50 to the frame processing unit 440 (see (v)).
  • the frame processing unit 440 performs a predetermined process on the received frame 50. After that, the frame processing unit 440 transmits the processed frame 50 to the output port 420 (see (vi)). After that, the frame 50 returns from the output port 420 of the slave “D” to the master 10 via the branching slave 40-0 (not shown).
  • the flow of the frame 50 between the slaves 40 is a flow in one direction according to the “input from OUT to IN” (Step 0 in FIG. 5).
  • the frame 50 is transferred as follows. First, in the above-mentioned normal flow of the frame 50, the frame processing unit 440 of the slave “C” sends the processed frame 50 to the output port 420 (see (vi)), but is connected to the slave “D”. When is disconnected, the slave “C” transmits the frame 50 from the output port 420 of the slave “C” to the input port 410 without going through the frame processing unit 440 (see (ix)). In this way, the slave "C” returns and transfers the frame 50 when the route between the slave "C” and the slave “D” is disconnected.
  • the frame 50 is transferred back at the slave 40 connected to the disconnected location, so that the "input from OUT to IN" is opposite to the normal flow of the frame 50.
  • such transfer of the frame 50 in the slave 40 in the folding direction is also referred to as “loopback” (Step 1 in FIG. 5).
  • the frame 50 looped back by the slave “C” is transferred in the opposite direction of the slave “B” ⁇ slave “A” ⁇ branching slave 40-0 (not shown), so that the frame 50 is transferred to the slave “D”. Is forwarded to the output port 420 of. Since the path between the slave "D” and the slave “C” is disconnected, the slave “D” returns the frame 50 received by the output port 420 to the branch slave 40-0. As a result, the frame 50 is returned from the branch slave 40-0 to the master 10.
  • the slave 40 does not perform the loopback, that is, the frame 50 that was loopbacked and transferred at the time of the route disconnection starts to circulate in the ring topology ((vii), (viii)). , (Ix) and (x)). Since the direction of this patrol is opposite to the direction in which the frame 50 flows in the normal state, it is also referred to as "reverse patrol" in the present embodiment (Step 2 in FIG. 5).
  • the "reverse patrol" reverse patrol frame 50 is transferred in each slave 40 by a route that bypasses the frame processing unit 440. Since the reverse patrol frame 50 does not reach the master 10, the master 10 detects data lost (frame lost) when the reverse patrol frame 50 occurs.
  • the normal frame 50 and the reverse patrol frame 50 are an index 53 that identifies the frame and a datagram that is a data body to be transferred, respectively, as shown in FIG. 6 (B) described later.
  • the master 10 adds an index 53 in a predetermined range for each predetermined cycle based on the control cycle to generate and transfer the frame 50 (Step 3.1 in FIG. 5).
  • the reverse patrol frame 50 is likely to be a frame 50 of a past cycle that is not the current cycle, but has an index 53 in which both the reverse patrol frame 50 that has reached the master 10 and the current normal time frame 50 match. In this case, the master 10 cannot determine which of the two frames 50 is the correct frame, that is, the frame to be processed, which leads to a malfunction.
  • the inventor obtained a new finding that the reverse patrol frame described above occurs when the route is disconnected / connected in the ring topology of junction redundancy, and based on this finding, the above malfunction
  • the process for suppressing the occurrence of the patrol frame will be described below.
  • FIG. 6 is a diagram schematically showing an example of a frame configuration according to the present embodiment.
  • the frame 50 according to the present embodiment basically includes a header 51 and a datagram 52 for storing control information (FIG. 6 (A)).
  • the information stored in the header 51 or the datagram 52 differs depending on the type of frame.
  • the header 51 of the frame 55 (hereinafter, also referred to as the patrol frame 55) transferred while patroling the slave 40 of the ring topology at normal times has an index 53, and it is determined whether or not the frame needs to be discarded.
  • RoundTripBit57, RoundTripBit57 set time 571, and type 58 are stored and each slave 40 (ie, slave "A”, slave "B”, slave “C”" is stored in the area of the datagram 52.
  • each of the data 52A52B, 52C, 52D which is the command value or the field information corresponding to the slave "D" is stored.
  • a message may be stored in this datagram 52.
  • Type 58 indicates the type of frame 50.
  • the type of the frame 50 includes a normal patrol frame 55, a command frame 56 described later, and the like.
  • FIG. 6C shows an example of the command frame 56.
  • the command frame 56 stores the type 58 in the header 51 and has an open command 54 which is a command for opening a port as a datagram 52.
  • the open command 54 includes a port identifier 59 that identifies the port of the slave 40 to be opened.
  • the slave 40 detects that the command frame 56 is a command frame 56 addressed to itself based on the port identifier 59 of the incoming command frame 56, the slave 40 executes the open command 54 of the command frame 56 to execute the port.
  • Perform open processing includes a process of transitioning the state of the slave 40 whose port is closed due to the disconnection of the network 4 route to the port open state.
  • the slave 40 includes shifting the state of the slave 40 to a state (execution permitted state) in which the processing of frame transfer (transmission / reception) via the port can be executed.
  • a state execution permitted state
  • the slave 40 detects that the route of the network 4 is disconnected between the slave 40 and the adjacent slave 40, the slave 40 closes the port connecting the adjacent slave 40 and transfers its own state to a frame. Transition to the state where execution is prohibited.
  • FIG. 7 is a diagram schematically showing an example of the functional configuration of the master 10 according to the present embodiment.
  • the master 10 includes a patrol suppression unit 180, a storage unit 185 corresponding to the non-volatile memory 104, communication processing units 186 and 187, and a frame processing unit in order to suppress the occurrence of a reverse patrol frame. Includes 188.
  • the communication processing unit 187 has a notification unit 1871 that outputs a notification indicating the possibility of a reverse patrol frame occurrence.
  • the storage unit 185 includes network configuration information 1851.
  • the network configuration information 1851 is created in advance by the user in the support device 200, for example, and the created network configuration information 1851 is transferred to the master 10.
  • the network configuration information 1851 includes information indicating the connection relationship between the master 10 and the slave 40 and the connection relationship of the slave 40 connected to the network 4 of the ring topology.
  • the information indicating these connection relationships includes information for identifying an input / output port that connects the master 10 and the slave 40 by a route, and information that identifies an input / output port that connects adjacent slaves 40 by a route. Including.
  • the frame processing unit 188 exchanges a normal frame with the slave 40 via the communication processing unit 186.
  • the frame processing unit 188 generates a patrol frame 55 that stores a command value that is a calculation result of the user program, outputs the generated patrol frame 55 to the communication processing unit 186, and receives the patrol frame 55 from the slave 40. Therefore, the reception process for extracting the field information is performed for the user program.
  • the frame processing unit 188 exchanges a plurality of cyclic frames 55 in the cycle with the ring topology for each cycle based on the control cycle.
  • the patrol suppression unit 180 includes a port control unit 1810 and a detection unit 1820, which are examples of the "command means".
  • the detection unit 1820 includes a recovery detection unit 1821 that detects that the route has been restored from the disconnection by connecting the disconnected route, and a connection state detection unit 1822 that detects the connection state of the network 4 of the ring topology. It includes a mode determination unit 1823 that determines the output mode of the open command 54, and a transmission permission unit 1824 that permits the frame processing unit 188 to transmit frames after the open command 54 is transmitted.
  • the communication processing unit 186 corresponds to the communication controller 110, and is an interface for the master 10 to send and receive data to and from the slave 40.
  • the communication processing unit 187 corresponds to the USB controller 112, and is an interface for the master 10 to send and receive data to and from the support device 200.
  • the notification unit 1871 outputs the above notification to the support device 200.
  • the port control unit 1810 generates a command frame 56 storing the open command 54 based on the output from the detection unit 1820, and outputs the generated command frame 56 to the communication processing unit 186.
  • the open command 54 indicates a command for opening the input port 410 or the output port 420 of the slave 40 connected to the disconnection point of the route when the route recovers from the disconnection.
  • a cable (wiring) is connected to the cut point of the route, for example, by user operation. This restores the route from disconnection.
  • the recovery detection unit 1821 detects that the recovery has been performed, for example, by input from the outside.
  • connection state detection unit 1822 detects the position of the disconnection / connection location of the network 4 on the ring topology. The details will be described later.
  • the mode determination unit 1823 changes the output mode of the open command 54 by the port control unit 1810 according to the position of the disconnection / connection location detected by the connection state detection unit 1822.
  • a "second mode” in which the detection position of the disconnection / connection point is between the end point of the branch slave 40-0 and the adjacent slave "D" and the detection position are Includes another position in the ring topology, i.e. the "first mode", which is the position between the starting point of the branching slave 40-0 and the slave "D".
  • the output mode of the open command 54 according to each mode will be described later.
  • connection state detection unit 1822 detects the configuration of the network 4 of the ring topology by using the predetermined detection data.
  • the detection data includes the first data and the second data for acquiring the time stamp information indicating the time when the first data has passed each slave 40 from each slave 40.
  • the connection state detection unit 1822 first sends the first data to the network 4 of the ring topology.
  • the connection state detection unit 1822 sends the second data to the network 4 after receiving the first data returned via the network 4 of the ring topology. Then, the connection state detection unit 1822 receives the second data returned via the network 4 of the ring topology.
  • the above time stamp information is the time (time) when the data passed through each port.
  • the time stamp information includes the time when the data passes through the input port 410 and the time when the data passes through the output port 420.
  • the identifier of the port ie, a pair of slave 40 identifier and port identifier.
  • the time stamp can be stored in the data processing unit in each slave 40.
  • the connection state detection unit 1822 can specify the passing order, which is the order of the ports through which the data has passed, by using the time stamp. Further, the connection state detection unit 1822 uses the time stamp to perform "OUT to IN input” and "IN to OUT input” between the two slaves 40 connected to each other in the network 4. You can determine which is being done.
  • the connection state detection unit 1822 collates the data indicating the passage order of the ports acquired by the time stamp with the information indicating the connection relationship indicated by the network configuration information 1851, and the data is passed based on the collation result. Each identifier of the port and the port not passing through can be identified.
  • connection state detection unit 1822 can detect the position of the disconnected route in the network 4 of the ring topology, and also detects that the disconnected route has been connected and restored. be able to.
  • the mode determination unit 1823 collates the output of the connection state detection unit 1822 with the network configuration information 1851, identifies the connection / disconnection detection position based on the collation result, and "second mode” based on the specified detection position. ", Or” first mode ".
  • FIG. 8 is a diagram schematically showing an example of the functional configuration of the slave 40 according to the present embodiment.
  • the processor 400 of the slave 40 includes a loopback unit 470, a frame determination unit 430, a frame processing unit 440, and a command execution unit 450 that executes an open command 54.
  • the loopback unit 470 When the loopback unit 470 detects that the path connecting the slave 40 including the loopback unit 470 and the adjacent slave 40 has been disconnected, the loopback unit 470 sets the “input from IN to OUT” of the slave 40 to “OUT”. Loop back to "input from IN to IN”, or loopback "input from OUT to IN” to "input from IN to OUT”.
  • the frame determination unit 430 determines the type of the frame based on the type 58 of the frame coming into the input port 410 or the output port 420.
  • the frame determination unit 430 is a frame that enters and exits the input port 410, and a frame in which the type 58 of the frame indicates "normal", that is, a normal circulation frame 55 is output to the frame processing unit 440, but is output.
  • a frame that enters and exits the port 420 and whose type 58 indicates "normal”, that is, a reverse patrol frame 55 bypasses the frame processing unit 440 and outputs the frame to the input port 410.
  • the frame determination unit 430 identifies a frame whose type 58 indicates a "command", that is, a command frame 56, from among the frames that enter the input port 410 or the output port 420.
  • the frame determination unit 430 determines that the port identifier 59 of the specified command frame 56 indicates the input port 410 or the output port 420 of the slave 40, the frame determination unit 430 outputs the command frame 56 to the command execution unit 450, and also outputs the command frame 56 to the command execution unit 450.
  • the command frame 56 is sent to the network 4 via the input port 410 or the output port 420.
  • the command execution unit 450 executes the open command 54 of the command frame 56 output from the frame determination unit 430. As a result, the port open process for opening the input port 410 or the output port 420 instructed by the open command 54 is executed.
  • the master 10 when the disconnected route is connected, the master 10 sets the opening order of the input port 410 and the output port 420 of the slave 40 connected to the route to the opening order of the route in the ring topology. Optimize according to the position. Specifically, the master 10 determines the open order in such an order that the occurrence of the reverse patrol frame 55 (Step 2 in FIG. 5) is suppressed.
  • the position of the disconnection / connection path according to the present embodiment includes the position of (Case 1) and the position of (Case 2).
  • FIG. 9 is a diagram schematically showing the position of (Case 1) and the position of (Case 2) of the disconnection / connection path according to the present embodiment.
  • FIG. 10 is a flowchart of the process according to the present embodiment.
  • connection state detector 1822 is a route between the output port 420 (port1) of the slave “C” and the input port 410 (port0) of the slave “D”. Detects that is disconnected.
  • connection state detection unit 1822 has a port (pot1) that is the end point of the slave “D” and an output port 420 (port1) of the branch slave 40-0. Detects that the route between them is broken.
  • the cutting point of the route was the position between the slave "C” and the slave "D", but the cutting point is not limited to this position and is for branching. It may be between the origin of slave 40-0 and slave "A”, between slave "A” and slave “B”, and between slave "B” and slave “C”.
  • the connection state detection unit 1822 detects the input port 410 and the output port 420 of the slave 40 connected to the location where the route is cut in the network 4 of the ring topology (step S1).
  • the recovery detection unit 1821 detects that the route has been recovered from the disconnection based on the external input (step S2).
  • the mode determination unit 1823 collates the information of the input port 410 and the output port 420 of the slave 40 detected in step S1 with the network configuration information 1851 and collates them. Based on the result of the above, it is detected whether the disconnected / connected portion (hereinafter referred to as the disconnected / connected portion) corresponds to (Case 1) or (Case 2) in the route.
  • the mode determination unit 1823 determines that the port is opened according to the "first mode” ("first mode” in step S3), and the port control unit 1810 determines.
  • the open command 54 is transmitted according to the "first mode” (step S4).
  • the mode determination unit 1823 determines that the port is opened according to the “second mode” (“second mode” in step S3), and the port control unit 1810 determines that the port is opened according to the “second mode”.
  • the open command 54 is transmitted according to the "second mode” (step S5).
  • the transmission permission unit 1824 outputs a frame transmission permission notification to the frame processing unit 188, for example, when it detects that a predetermined time has elapsed since the open command 54 was transmitted in step S4 or step S5. (Step S6).
  • the frame processing unit 188 starts an operation of transmitting the normal patrol frame 55 to the network 4 of the ring topology (step S7).
  • FIGS. 11 to 14 are diagrams schematically showing the flow of frames in the “first mode” according to the present embodiment (case 1).
  • the thick arrows in FIGS. 11 to 14 indicate the flow direction of the frame 50.
  • the process of step S4 (FIG. 10) will be described with reference to FIGS. 11 to 14.
  • the connection state detection unit 1822 outputs the identifier portY (FIG. 11) of the output port 420 of the branch slave 40-0 and the identifier portX (FIG. 11) of the input port 410 of the slave “A”.
  • the master 10 transmits a normal patrol frame 55 (indicated as a Cyclic frame 55 in the figure) to the network 4 of the ring topology, and subsequently transmits a command frame 56.
  • the port control unit 1810 Based on the output of the connection state detection unit 1822, the port control unit 1810 generates a command frame 56 containing both the portX open command 54 and the portY open command 54, and the generated command frame 56 is used as the ring topology network. It is sent to No. 4 (step S41 in FIG. 11).
  • the master 10 does not transmit a frame such as the normal patrol frame 55.
  • the branch slave 40-0 receives the command frame 56 sent in step S41.
  • the command execution unit 450 of the branch slave 40-0 determines that the open command 54 of the received command frame 56 is addressed to the branch slave 40-0 based on the contents of the received command frame 56, and determines that the open command is addressed to the branch slave 40-0. 54 is executed (step S42 in FIG. 12). As a result, the portY of the branch slave 40-0 is opened. Since the master 10 does not transmit a new frame immediately after transmitting the command frame 56, there is no frame that passes through the opened portY and enters portX.
  • portX is opened, but since the master 10 does not transmit a new frame immediately after the command frame 56 is transmitted, there is no frame that passes through the opened portX and enters portY. That is, the reverse patrol frame does not occur.
  • the transmission permission unit 1824 When the transmission permission unit 1824 detects that a predetermined time has elapsed since the master 10 transmitted the command frame 56, it outputs a transmission permission notification.
  • the frame processing unit 188 receives the transmission permission notification from the transmission permission unit 1824, the frame processing unit 188 generates a normal patrol frame 55 according to the transmission permission, and sends the generated patrol frame 55 to the network 4 of the ring topology (FIG. FIG. Steps S6 and S7) of 10.
  • the above-mentioned predetermined time measured by the transmission permission unit 1824 is based on the propagation delay time of the frame 50 in the network 4 which is the ring wiring. More specifically, the predetermined time is the time required for the command frame 56 to be sent from the master 10 and returned (propagation delay time), or the time required for the command frame 56 to go around the ring topology (propagation delay time). Is based on. This required time is estimated (calculated) in advance.
  • the timing at which the transmission permission unit 1824 outputs the transmission permission notification is based on the propagation delay time of the command frame 56. For example, the master 10 receives the arrival of the command frame 56 returned from the network 4 of the ring topology. It may be when it is detected.
  • FIGS. 15 to 20 are diagrams schematically showing the flow of frames in the “second mode” according to the present embodiment.
  • the thick arrows in FIGS. 15 to 20 indicate the flow direction of the frame 50.
  • the process of (Case 2) in step S5 (FIG. 10) will be described with reference to FIGS. 15 to 20.
  • the connection state detection unit 1822 outputs the identifier portZ (FIG. 15) of the port of the branch slave 40-0 and the identifier portY (FIG. 15) of the output port 420 of the slave “D”.
  • the master 10 transmits a command frame 56 to the network 4 of the ring topology following the normal patrol frame 55.
  • the port control unit 1810 generates a command frame 56 containing only the open command 54 of portY based on the output of the connection state detection unit 1822, and sends the generated command frame 6 to the network 4 of the ring topology (FIG. 15).
  • Step S51 Immediately after transmitting the command frame 56, the master 10 does not transmit a frame such as the normal patrol frame 55.
  • the normal patrol frame 55 and the command frame 56 first reach the branch slave 40-0.
  • the normal patrol frame 55 and the command frame 56 pass through the branch slave 40-0 (FIG. 16). If the open command 54 of portZ of the branch slave 40-0 is stored in the command frame 56, the open command 54 is executed to open portZ, and all of the returned frames 50 are slaves via portZ. It becomes a reverse patrol frame transferred to "D". In order to avoid the occurrence of such a reverse patrol frame, the master 10 does not send the portZ open command 54 at this point.
  • the reverse patrol frame does not occur immediately after the portY is opened.
  • the transmission permission unit 1824 When the transmission permission unit 1824 detects that a predetermined time has elapsed since the master 10 transmitted the command frame 56, it outputs a transmission permission notification.
  • the frame processing unit 188 receives the transmission permission notification from the transmission permission unit 1824, the frame processing unit 188 generates a frame 50 such as a normal patrol frame 55 and sends the generated frame 50 to the network 4 of the ring topology (FIG. 10). Steps S6 and S7).
  • the master 10 transmits a command frame 56 containing a predetermined command to the network 4 of the ring topology.
  • this command frame 56 is transferred in the direction following the "input from IN to OUT" and reaches portZ to the branch slave 40-0 via the port Y of the opened slave "D"
  • the branch slave 40-0 becomes ,
  • the command frame 56 is received, and a predetermined command of the received command frame 56 is executed.
  • portZ is opened, and this command frame 56 disappears in portZ (FIG. 19). This disappearance is indicated by "STOP" in FIG.
  • the process of opening portZ using this predetermined command complies with the EtherCAT ASIC specifications.
  • the master 10 transmits the normal patrol frame 55 of the next cycle to the network 4 of the ring topology.
  • the patrol frame 55 is transferred in the direction following the “input from IN to OUT”, passes through the portY of the opened slave “D” and the portZ of the branching slave 40-0, and returns to the master 10 (FIG. 20).
  • the predetermined time measured by the transmission permission unit 1824 is based on the time based on the propagation delay time of the ring wiring. Specifically, it is based on the time required (propagation delay time) until the command frame 56 of a predetermined command is sent from the master 10 and returned.
  • FIG. 21 to 23 are diagrams schematically showing other flows of the "first mode" frame according to the present embodiment.
  • FIG. 24 is a diagram schematically showing another example of the functional configuration of the master 10 according to the present embodiment.
  • FIG. 25 is a schematic diagram of another example of the functional configuration of the slave 40 according to the present embodiment.
  • FIG. 26 is a diagram showing an example of a flowchart of the process of the “first mode” according to the present embodiment.
  • the processor 400 of the slave 40 includes a bit setting unit 460 in addition to the configuration of FIG.
  • the bit setting unit 460 sets RoundTripBit57 of the circulation frame 55 (that is, the reverse circulation frame) bypassed by the frame processing unit 440 among the circulation frames 55 reaching the slave 40 to “ON” and sends it to the network 4. .
  • the RoundTripBit57 is set to the initial value "OFF".
  • the master 10 includes a frame discarding unit 189 in addition to the configuration of FIG.
  • the frame discard unit 189 detects (extracts) a reverse patrol frame from the frames received by the communication processing unit 186 and outputs to the frame processing unit 188, and discards the detected patrol frame.
  • the frame discarding unit 189 detects (extracts) the patrol frame 55 for which RoundTripBit 57 is "ON" from the patrol frames 55 that have reached the master 10, and discards the detected patrol frame 55.
  • the reverse patrol frame corresponding to the patrol frame 55 of the past cycle which is not the current cycle, is prevented from being output from the communication processing unit 186 to the frame processing unit 188, and is processed by the user program.
  • the reverse patrol frame can be excluded from the frame of.
  • FIGS. 21 to 23 indicate the flow direction of the frame 50.
  • FIGS. 21 to 23 As shown by the cable cutting portion 261, the path between the branching slave 40-0 and the slave “A” is cut. Therefore, the output of the connection state detection unit 1822 indicates the identifier portY (FIG. 21) of the output port 420 of the branch slave 40-0 and the identifier portX (FIG. 21) of the input port 410 of the slave “A”.
  • the master 10 sends two command frames 56 in order to the network 4 of the ring topology, and immediately after the sending, sends the message frame 55.
  • the first command frame 56 to be sent stores the open command 54 of portY
  • the second command frame 56 to be sent stores the open command 54 of portX.
  • the port control unit 1810 generates a first command frame 56 and a second command frame 56 based on the output of the connection state detection unit 1822, and sequentially transfers the generated two command frames 56 to the network 4 of the ring topology. Send out (step S45 in FIG. 21).
  • the slave 40-0 When the branch slave 40-0 receives two frames (called'the first two frames') of the first patrol frame 55 and the command frame 56 storing the open command 54 of portY, the slave 40-0 receives the command.
  • the open command 54 of portY stored in the command frame 56 is executed. According to this execution result, portY opens.
  • the branch slave 40-0 receives two frames (referred to as'the latter two frames') of the command frame 56 of the portX open command 54 and the message frame 55, and after receiving the reception.
  • the two frames of are transferred to the slave "A" via the opened portY. Since portX of slave "A” is not open, the latter two frames disappear in portX of slave "A”. At this time, portX of the slave "A” is opened. This operation follows the EtherCAT ASIC specifications. As a result, the route between the branch slave 40-0 and the slave "A” is restored from the disconnection.
  • the loopback unit 470 loops back the patrol frame 55 because portX is not open. By this loopback, the patrol frame 55 reverse patrols in the direction following the "input from OUT to IN".
  • the bit setting unit 460 sets the RoundTripBit57 of the looped back frame 55 to ON, that is, changes from OFF to ON (step S46 in FIG. 22), that is, The RoundTripBit57 is changed from OFF to ON, and the time 571 indicating the time when the RoundTripBit57 is set to ON is stored in the header 51.
  • the command frame 56 of the portY open command 54 is a reverse patrol frame.
  • the patrol frame 55 transmitted by the master 10 to the network 4 of the ring topology also follows the “input from OUT to IN” in the direction from the branch slave 40-0 to the slave “D”, the slave “C”, and the slave “B”. Is transferred to and reaches the slave "A”.
  • the RoundTripBit57 of the patrol frame 55 is also set to ON, and the patrol frame 55 is looped back. After that, all the patrol frames 55 looped back by the slave "A" reach the master 10.
  • the frame discard unit 189 detects the reverse circulation frame in which RoundTripBit57 indicates ON among the received circulation frames 55, and the detected reverse.
  • the patrol frame 55 is discarded (step S47 in FIG. 23).
  • the frame discarding unit 189 of the master 10 (G1. Detection and discarding of patrol frames) The processing of the frame discarding unit 189 of the master 10 will be described with reference to FIG. 26.
  • the index 53 is also referred to as “Index”.
  • the value of the index 53 indicates a value within a predetermined range that differs for each predetermined cycle.
  • the frame discard unit 189 compares the value of the index 53 of the patrol frame 55 received by the master 10 with the range of the index value of the current cycle, and based on the result of the comparison, the index 53 is the index value of the current cycle. It is determined whether or not the value falls within the range (that is, whether or not it is valid) (step S51). When it is determined that the value of the index 53 does not fall within the range of the current cycle (NO in step S51), the frame discard unit 189 discards the patrol frame 55 (step S59).
  • the frame discarding unit 189 determines whether or not the RoundTripBit57 of the patrol frame 55 indicates ON. Determine (step S53). When it is determined that RoundTripBit57 indicates ON (YES in step S53), the frame discarding unit 189 discards the received circulation frame 55 (step S59). On the other hand, when it is determined that RoundTripBit57 does not show ON (that is, shows OFF) (NO in step S53), the frame discarding unit 189 starts after RoundTripBit57 is set to ON based on the time 571 of the patrol frame 55. It is determined whether or not a predetermined time has elapsed based on the propagation delay time (step S55).
  • the frame discard unit 189 determines that the predetermined time has not yet elapsed since RoundTripBit57 is set to ON (NO in step S55)
  • the frame discard unit 189 discards the circulation frame 55 (step S59).
  • the patrol frame 55 is not discarded by the frame discard unit 189, and the frame processing unit 188 uses the patrol frame 55. (Step S57).
  • the master 10 filters the patrol frame 55 reaching the master 10 stepwise by using the index 53, the RoundTripBit57, and the time 571. As a result, the master 10 improves the certainty of detecting the patrol frame 55 that may correspond to the reverse patrol frame among the patrol frames 55 that reach the master 10 from the network 4 of the ring topology.
  • FIG. 27 is a diagram schematically showing another example of the functional configuration of the master 10 according to the present embodiment.
  • the master 10 includes a generation setting unit 190 and a frame discard unit 191 in addition to the configuration of FIG.
  • FIG. 28 is a diagram for explaining the processing of the generation setting unit 190 according to the present embodiment.
  • 29 to 31 are diagrams schematically showing other flows of the frame according to the present embodiment.
  • FIG. 32 is a diagram showing an example of a flowchart of processing of the frame discarding unit 191.
  • the generation of the frame 50 to be sent is managed at the predetermined cycle.
  • Index 53 for this is set.
  • the generation setting unit 190 has an index for generation management in the header 51 of the frame 50 (command frame 56 or normal patrol frame 55) received from the patrol suppression unit 180 or the frame processing unit 188 by the communication processing unit 186. 53 is set.
  • the communication processing unit 186 sends the frame 50 in which the index 53 is set to the network 4 of the ring topology.
  • the generation setting unit 190 increments the value within the effective range 291 of the index number while synchronizing with the output of the timer 115, and sets the incremented value in the index 53.
  • the effective range 291 can be divided into a plurality of specific effective ranges 293.
  • the generation setting unit 190 increments the value of the index 53 within a specific effective range 293 at predetermined intervals.
  • the frame 50 is sent to the network 4 of the ring topology by assigning an index 53, that is, a generation, which indicates a value of the effective range 293 which is different for each predetermined cycle.
  • the generation setting unit 190 increments the value in the range of 0 to 1022 every predetermined cycle, and when the command frame 56 is output from the port control unit 1810, the generation setting unit 190 detects the patrol frame.
  • the effective range 293 is changed from the next predetermined cycle, that is, the generation assigned to the patrol frame 55 is changed (step S292 in FIG. 28).
  • the generation setting unit 190 starts the effective range 293 from the next predetermined cycle. Is changed from the current "0 to 1022" to "1023 to 2046". Therefore, each time the command frame 56 is transmitted, the frame transmitted in the next predetermined cycle is switched to the next generation frame.
  • the generation setting unit 190 has the effective range 293 of the index 53 of the frame 50 sent to the network 4 of the ring topology from the next predetermined cycle in response to the output of the command frame 56 from the port control unit 1810. Is changed from "A” to "B” (Fig. 30). After that, the master 10 sends the frame 50 of the index 53 whose effective range 293 indicates “B” to the network 4 of the ring topology.
  • the frame discarding unit 191 performs the frame discarding process of FIG. 32.
  • the frame discarding unit 191 determines the value of the index 53 of the frame 50 coming in from the network 4 of the ring topology via the communication processing unit 186 and the current effective range 293 indicated by the generation setting unit 190. The values are compared, and based on the result of the comparison, it is determined whether or not the value of the index 53 of the frame 50 is valid (step S21).
  • the frame discard unit 191 determines that the index 53 is not valid based on the value of the index 53 of the frame 50 not corresponding to the current effective range 293 (NO in step S21), and sets the frame 50 as the frame processing unit. Discard so that it is not output to 188 (step S25).
  • the frame discard unit 191 determines that the index 53 is valid based on the value of the index 53 of the frame 50 that has entered the master 10 corresponds to the current effective range 293 (YES in step S21).
  • the frame discarding unit 191 does not discard the frame 50. Therefore, the frame processing unit 188 executes the reception processing of the frame 50 that has entered the master 10 (step S23).
  • the generation setting unit 190 and the frame discard unit 191 among the frames 50 coming into the master 10 from the network 4 of the ring topology, the index 53 of the frame 50 does not fall under the current effective range 293, that is, the reverse patrol. Only the frame can be detected (extracted) and the detected reverse patrol frame can be discarded.
  • the detection of the patrol frame using the generation (index 53) set by the generation setting unit 190 may be executed in combination with the detection of the patrol frame using the RoundTripBit 57 set by the bit setting unit 460.
  • the notification unit 1871 outputs a notification that the reverse patrol frame may have occurred due to the change from the loopback transfer to the patrol transfer. For example, when the master 10 detects a frame lost in the ring topology, the notification unit 1871 outputs the above notification.
  • the communication processing unit 186 detects the frame lost based on the index 53 of the frame 50 received from the network 4 of the ring topology.
  • the communication processing unit 186 collates the values of the index 53 of the frame 50 sent to the network 4 of the ring topology with the index 53 of the frame 50 coming in from the network 4 of the ring topology. Based on the collation result, the communication processing unit 186 sends out the frame 50 when the value of the index 53 of the frame 50 that has arrived in each predetermined cycle and the value of the index 53 of the frame 50 that has been sent in the predetermined cycle match. Determines that they have all returned to master 10.
  • the notification unit 1871 when the occurrence of the frame lost is detected, the notification unit 1871 generates a notification indicating the possibility of the reverse patrol frame occurrence, and outputs the generated notification to the support device 200 via the communication processing unit 187.
  • FIG. 33 is a diagram showing an example of a screen displayed by the support device 200 according to the present embodiment.
  • the screen of FIG. 33 is based on the notification from the notification unit 1871.
  • the support device 200 receives the notification from the notification unit 1871, the support device 200 outputs a notification indicating the possibility of occurrence of the reverse patrol frame to the display 209 or the like by using the system-defined variable.
  • a message 1091 indicating “a patrol frame may have occurred” based on the notification is displayed in association with an image showing a network configuration including a ring topology based on the network configuration information 1851.
  • a mark indicating the location where the route is cut may be displayed based on the output of the connection state detection unit 1822.
  • the method of detecting the occurrence of the reverse patrol frame is not limited to the method based on the detection of the occurrence of the frame lost, and may be the method based on the frame discarding performed by the frame discarding unit 189 or 191.
  • the plurality of slave devices include a first slave device (40-0) which is a starting point and an ending point of the ring wiring, and a plurality of second slave devices (40-0) connected between the starting point and the ending point of the first slave device. 40-1, 40-2, 40-3, 40-4) and The ring wiring
  • Each of the second slave devices receives the data (50) coming in from the starting point side, and the first path (15) for cyclically transferring the received data to the ending point side.
  • Each of the plurality of slave devices can be configured with a second path (16) for looping back the data from the own device when the path between the plurality of slave devices is disconnected from the adjacent slave device.
  • the master device is A command means (1810) for transmitting a command (56) for switching the second path to the first path to the slave device performing the loopback when the route recovers from the disconnection is provided.
  • a master device that sends data to the ring wiring (1824) after a time based on the propagation delay time of the ring wiring has elapsed from the time of transmitting the command.
  • Each of the slave devices has a first port (410) and a second port (420) to which a route connecting to an adjacent slave device is connected.
  • each second slave device receives data coming in from the starting point side at the first port, and transfers the received data from the second port to the ending point side.
  • the command includes an open command (54,59) that enables data reception from the first port and an open command (54,59) that enables data reception from the second port.
  • the command means is The master device according to configuration 1, wherein the transmission order of the open command of the first port and the open command of the second port is changed according to the position on the ring wiring of the disconnected route. [Structure 3]
  • the master device further The master device according to configuration 2, further comprising means (1822) for detecting the first port and the second port of the slave device to which the disconnected route is connected based on the communication with the plurality of slave devices.
  • the data includes a code (57) indicating whether or not the data has changed from the loopback to the cyclic transfer.
  • the master device according to the configuration 2 or 3, wherein the master device detects data whose code indicates the change among incoming data from the ring wiring and discards the detected data (189).
  • the master device sends the data to the ring wiring while allocating the generation (293) to the data.
  • the master device transmits the command, the generation assigned to the data after that is changed from the generation assigned before the command is transmitted.
  • the master device detects data that is assigned to a generation different from the generation currently assigned to the data among the data that comes in from the ring wiring, and discards the detected data (191). 4.
  • the master device according to any one of 4.
  • [Structure 6] The master device according to any one of configurations 2 to 5, wherein the master device outputs a notification that a change has occurred in the data from loopback transfer to cyclic transfer (1871).
  • [Structure 7] The master device according to any one of configurations 1 to 6, wherein the ring wiring includes an EtherCAT network.
  • [Structure 8] An arithmetic processing unit including the master device according to any one of configurations 1 to 7.
  • [Structure 9] A programmable logic controller including the arithmetic processing unit according to the configuration 8.
  • [Structure 10] A network that includes ring wiring (4). A plurality of slave devices (40) connected to the ring wiring and A master device (10) that manages the plurality of slave devices is provided.
  • the plurality of slave devices include a first slave device (40-0) which is a starting point and an ending point of the ring wiring, and a plurality of second slave devices (40-0) connected between the starting point and the ending point of the first slave device. 40-1, 40-2, 40-3, 40-4) and The ring wiring
  • Each of the second slave devices receives data coming in from the starting point side, and the first path (15) for cyclically transferring the received data to the ending point side.
  • Each of the plurality of slave devices can be configured with a second path (16) for looping back the data from the own device when the path between the plurality of slave devices is disconnected from the adjacent slave device.
  • the master device is A command means (1810) for transmitting a command (56) for switching the second path to the first path when the route recovers from the disconnection is provided to the slave device that performs the loopback. After a lapse of time based on the propagation delay time of the ring wiring from the time of transmitting the command, data is transmitted to the ring wiring (1824), the network.
  • This method is implemented by the master device (10) that manages a plurality of slave devices (40) connected to the ring wiring (4).
  • the plurality of slave devices include a first slave device (40-0) which is a starting point and an ending point of the ring wiring, and a plurality of second slave devices (40-0) connected between the starting point and the ending point of the first slave device.
  • Each of the second slave devices receives data coming in from the starting point side, and the first path (15) for cyclically transferring the received data to the ending point side.
  • Each of the plurality of slave devices can be configured with a second path (16) for looping back the data from the own device when the path between the plurality of slave devices is disconnected from the adjacent slave device.
  • the method is A step (S5, S4) of transmitting a command (56) for switching the second route to the first route to the slave device performing the loopback when the route recovers from the disconnection.
  • a method comprising a step (S6, S7) of transmitting data to the ring wiring after a time based on the propagation delay time of the ring wiring has elapsed from the time of transmitting the command.
  • 209 display, 261 cable cut location, 291,293 effective range, 430 frame discriminator, 450 command execution unit, 460 bit setting unit, 470 loopback unit, 571 time, 1091 message, 1810 port control unit, 1820 detection unit, 1821 recovery detection unit, 1822 connection status detection unit, 1823 mode judgment unit, 1824 transmission permission unit, 1851 network configuration information, 1871 notification unit.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Small-Scale Networks (AREA)
  • Programmable Controllers (AREA)

Abstract

リング配線における巡回データの発生を抑制する。複数スレーブは、リング配線の起点および終点となる第1スレーブと、起点と終点の間に接続される複数の第2スレーブを含み、リング配線は、各第2スレーブが、起点側から受付けたデータを終点側へ巡回転送させる第1経路と、各スレーブが、隣接スレーブとの間の経路が切断される場合に、自装置からデータをループバックするための第2経路を構成し得る。経路が切断から復旧時、マスタは、第2経路を第1経路に切替える指令をループバックを実施するスレーブに送信し、この送信時から伝搬遅延時間に基づく時間が経過後にデータを送出する。

Description

マスタ装置、演算処理装置、プログラマブルロジックコントローラ、ネットワーク、および方法
 本開示は、マスタ装置、演算処理装置、プログラマブルロジックコントローラ、ネットワーク、および方法に関する。
 従来、マスタとスレーブとから構成されるネットワークが知られている。例えば、このようなネットワークとしては、ライントポロジ(ディジーチェーン)、ツリートポロジ、リングトポロジなどが知られている。リングトポロジとしては、例えば、特許文献1(特開2016-119616号公報)にも開示されているようなリング型ネットワークシステムが提案されている。
特開2016-119616号公報
 リングトポロジの1の接続形態として、リング配線により複数のスレーブがリング状に接続されて、これら複数のスレーブのうちの1つがデータ転送の起点または終点となるジャンクション(分岐)として動作する、いわゆるジャンクション冗長化のリング配線が提案されている。
 ジャンクション冗長化リング配線では、通常は、マスタの起点から送信されたデータは複数のスレーブを経由して、マスタの終点に戻る。配線が切断されると、切断箇所のスレーブはループバック(折返し転送)を実施する。発明者は、切断箇所が、その後に再接続されると、ループバックされたデータはリング配線を巡回し、その後、再度、配線が切断されると巡回データがマスタに戻り得ること、およびマスタにとっては戻された巡回データが誤入力となる可能性があるとの知見を得た。
 本開示の目的は、リング配線における巡回データの発生を抑制するマスタ装置、演算処理装置、プログラマブルロジックコントローラ、ネットワーク、および方法を提供することである。
 本開示において、リング配線に接続される複数のスレーブ装置を管理するマスタ装置が提供される。複数のスレーブ装置は、リング配線の起点および終点となる第1スレーブ装置と、第1スレーブ装置の起点と終点との間に接続される複数の第2スレーブ装置とを含み、リング配線は、各第2スレーブ装置が、起点側から入来するデータを受付け、受付けたデータを終点側へ巡回転送させるための第1経路と、各複数のスレーブ装置が、隣接するスレーブ装置との間の経路が切断される場合に、自装置からデータをループバックするための第2経路とを構成可能である。マスタ装置は、経路が切断から復旧する場合に、第2経路を第1経路に切替えるための指令をループバックを実施するスレーブ装置に送信する指令手段を備え、指令の送信時からリング配線の伝搬遅延時間に基づく時間が経過後に、リング配線にデータを送出する。
 上述の開示によれば、リング配線が切断から復旧する場合に、マスタ装置は、リング配線において、指令が該当するスレーブに到達し当該指令が実行されることでループバックの第2経路が第1経路に切替わるまでの所要時間を、伝搬遅延時間に基づく時間から見込み、マスタ装置は、この見込まれた時間が経過したタイミングで、新たなデータをリング配線に送出することができる。この結果、当該送出された新たなデータは、第1経路で転送され得て、リング配線におけるループバック方向に巡回するデータである逆巡回データの発生を抑制することができる。
 上述の開示において、各スレーブ装置は、隣接するスレーブ装置に繋がる経路が接続される第1ポートおよび第2ポートを有し、各第2スレーブ装置は、第1経路が構成される場合、起点側から入来するデータを第1ポートで受付け、受付けたデータを第2ポートから終点側へ転送し、指令は、検出された第1ポートからのデータ受付を可能にするオープン指令および第2ポートからのデータ受付を可能にするオープン指令を含み、指令手段は、切断経路のリング配線上の位置に応じて、第1ポートのオープン指令および第2ポートのオープン指令の送信順序を異ならせる。
 上述の開示によれば、マスタは、切断経路に接続される第1および第2ポートを有したスレーブに、指令として、第1ポートからのデータ受付を可能にするオープン指令および第2ポートからのデータ受付を可能にするオープン指令を送信する場合に、この指令の送信順序を、切断経路のリング配線上の位置に応じて異ならせることができる。
 上述の開示において、マスタ装置は、さらに、複数のスレーブ装置との通信に基づき、切断経路が接続されるスレーブ装置の第1ポートおよび第2ポートを検出する手段を備える。
 上述の開示によれば、マスタ装置は、指令の送信に際して、マスタ装置と複数のスレーブ装置との間の通信に基づき、切断経路が接続されるスレーブ装置の第1ポートおよび第2ポートを検出することができる。
 上述の開示において、データは、当該データがループバックから巡回転送に変化したか否かを示す符号を含み、マスタ装置は、リング配線からの入来データのうち、符号が変化を示しているデータを検出し、検出されたデータを破棄する。
 上述の開示によれば、経路が切断から復旧された場合、マスタ装置は、マスタ装置に到達するデータのうちから、ループバック転送から巡回転送に変化したデータを、データが有する符号の変化に基づき検出(抽出)し、検出されたデータを破棄することができる。
 上述の開示において、マスタ装置は、データに世代を割当てながらデータをリング配線に送出し、マスタ装置は、指令を送信したとき、その後にデータに割当てる世代を、当該指令送信前に割当られてていた世代から変更し、マスタ装置は、リング配線から入来するデータのうち、現在、データに割当てられる世代とは異なる世代が割当てられたデータを検出し、検出されたデータを破棄する。
 上述の開示によれば、マスタ装置は、リング配線に送出するデータに割当てる世代を、経路が切断から復旧される際に指令を送信する前後で変更する。これにより、マスタ装置は、マスタ装置に到達するデータのうち、この指令の送信の際にループバックから巡回転送に変化したデータを、割当てられている世代に基づき検出し、検出されたデータを破棄することができる。
 上述の開示において、マスタ装置は、データについてループバック転送から巡回転送への変化が発生した旨の通知を出力する。
 上述の開示によれば、データについてループバック転送から巡回転送への変化が発生したこと、すなわち逆方向への巡回転送が発生している旨の通知を、ユーザに対し出力することができる。
 上述の開示において、リング配線は、EtherCAT(登録商標)ネットワークを含む。
 上述の開示によれば、EtherCATネットワークにおいて上記のマスタ装置の構成を適用することができる。
 上述の開示に係るマスタ装置を備える演算処理装置が提供される。
 上述の開示に係る演算処理装置を備えた、プログラマブルロジックコントローラが提供される。
 本開示において、リング配線を含むネットワークが提供される。ネットワークは、リング配線に接続される複数のスレーブ装置と、複数のスレーブ装置を管理するマスタ装置と、を備え、複数のスレーブ装置は、リング配線の起点および終点となる第1スレーブ装置と、第1スレーブ装置の起点と終点との間に接続される複数の第2スレーブ装置とを含み、リング配線は、各第2スレーブ装置が、起点側から入来するデータを受付け、受付けたデータを終点側へ巡回転送させるための第1経路と、各複数のスレーブ装置が、隣接するスレーブ装置との間の経路が切断される場合に、自装置からデータをループバックするための第2経路とを構成可能であり、マスタ装置は、経路が切断から復旧する場合に、第2経路を第1経路に切替えるための指令をループバックを実施するスレーブ装置に送信する指令手段を備え、指令の送信時からリング配線の伝搬遅延時間に基づく時間が経過後に、リング配線にデータを送出する。
 上述の開示によれば、リング配線の経路が切断から復旧する場合に、マスタ装置は、リング配線において、指令が該当するスレーブに到達し、当該スレーブによって指令が実行されてループバックの第2経路が第1経路に切替わるまでの所要時間を、伝搬遅延時間に基づく時間として見込む。マスタ装置は、この見込まれた時間が経過したタイミングで、新たなデータをリング配線に送出することができる。この結果、送出された新たなデータは、第1経路で転送され得て、リング配線におけるループバック方向に巡回する逆巡回データの発生を抑制することができる。
 本開示においては、リング配線に接続される複数のスレーブ装置を管理するマスタ装置が実施する方法が提供される。複数のスレーブ装置は、リング配線の起点および終点となる第1スレーブ装置と、第1スレーブ装置の起点と終点との間に接続される複数の第2スレーブ装置とを含み、リング配線は、各第2スレーブ装置が、起点側から入来するデータを受付け、受付けたデータを終点側へ巡回転送させるための第1経路と、各複数のスレーブ装置が、隣接するスレーブ装置との間の経路が切断される場合に、自装置からデータをループバックするための第2経路とを構成可能であり、方法は、経路が切断から復旧する場合に、第2経路を第1経路に切替えるための指令をループバックを実施するスレーブ装置に送信するステップと、指令の送信時からリング配線の伝搬遅延時間に基づく時間が経過後に、リング配線にデータを送出するステップとを備える。
 上述の開示において、方法が実施されると、リング配線の経路が切断から復旧する場合に、マスタ装置は、リング配線において、指令が該当するスレーブに到達し、当該スレーブによって指令が実行されることでループバックの第2経路が第1経路に切替わるまでの所要時間を、伝搬遅延時間に基づく時間として見込む。マスタ装置は、この見込まれた時間が経過したタイミングで、新たなデータをリング配線に送出することが可能となる。この結果、送出された新たなデータは、第1経路で転送され得て、リング配線におけるループバック方向に巡回する逆巡回データの発生を抑制することができる。
本実施の形態に係るPLCシステムの全体構成を示す模式図である。 本実施の形態に係るPLCシステムに含まれるプロセッサユニット10のハードウェア構成を示す模式図である。 本実施の形態に係るスレーブのハードウェア構成を示す模式図である。 本実施の形態に係る2つのスレーブ間のフレームの流れの一例を模式的に説明するための図である。 本実施の形態に係るリングトポロジにおけるフレームの経路の変化の一例を模式的に説明するための図である。 本実施の形態に係るフレームの構成の一例を模式的に示す図である。 本実施の形態に係るマスタの機能構成の一例を模式的に示す図である。 本実施の形態に係るスレーブの機能構成の一例を模式的に示す図である。 本実施の形態に係る切断/接続の経路の(ケース1)と(ケース2)の位置を模式的に示す図である。 本実施の形態に係る処理のフローチャートである。 本実施の形態に係る“第1モード”のフレームの流れを模式的に示す図である。 本実施の形態に係る“第1モード”のフレームの流れを模式的に示す図である。 本実施の形態に係る“第1モード”のフレームの流れを模式的に示す図である。 本実施の形態に係る“第1モード”のフレームの流れを模式的に示す図である。 本実施の形態に係る“第2モード”のフレームの流れを模式的に示す図である。 本実施の形態に係る“第2モード”のフレームの流れを模式的に示す図である。 本実施の形態に係る“第2モード”のフレームの流れを模式的に示す図である。 本実施の形態に係る“第2モード”のフレームの流れを模式的に示す図である。 本実施の形態に係る“第2モード”のフレームの流れを模式的に示す図である。 本実施の形態に係る“第2モード”のフレームの流れを模式的に示す図である。 本実施の形態に係る“第1モード”のフレームの他の流れを模式的に示す図である。 本実施の形態に係る“第1モード”のフレームの他の流れを模式的に示す図である。 本実施の形態に係る“第1モード”のフレームの他の流れを模式的に示す図である。 本実施の形態に係るマスタの機能構成の他の例を模式的に示す図である。 本実施の形態に係るスレーブの機能構成の他の例を模式的に図である。 本実施の形態に係る“第1モード”の処理のフローチャートの一例を示す図である。 本実施の形態に係るマスタの機能構成の他の例を模式的に示す図である。 本実施の形態に係る世代設定部の処理を説明するための図である。 本実施の形態に係るフレームの他の流れを模式的に示す図である。 本実施の形態に係るフレームの他の流れを模式的に示す図である。 本実施の形態に係るフレームの他の流れを模式的に示す図である。 本実施の形態に係るフレーム破棄部の処理のフローチャートの一例を示す図である。 本実施の形態に係るサポート装置で表示される画面の一例を示す図である。
 本の実施の形態について、図面を参照しながら詳細に説明する。なお、図中の同一または相当部分については、同一符号を付してその説明は繰り返さない。
 本実施の形態では、ネットワーク構成の一例として、PLC(プログラマブルロジックコントローラ)を中心とする制御システムに適用されるケースを例示する。但し、このような制御システムとしては、PLCだけではなく、各種の産業用コンピュータを中心とした構成を採用することもできる。また、ネットワーク構成を適用する対象は制御システムに限定されない。
 <A.適用例>
 本発明が適用される場面の一例について説明する。図5を参照して、上記の制御システムは、例えばフィールドネットワークを構成するリング配線に接続される複数のスレーブを管理するマスタ10を備える。リング配線には、例えばEtherCATを適用することができる。
 複数のスレーブは、リング配線の起点および終点となる第1スレーブ装置(分岐用スレーブ)と、第1スレーブ装置の起点と終点との間に接続される複数の第2スレーブ装置(スレーブ「A」、スレーブ「B」、スレーブ「C」およびスレーブ「D」)とを含む。第1スレーブ装置は、リング配線に接続された第2スレーブ装置とマスタ10との間でデータを分岐させながら両者間のデータ遣り取りを実現する、いわゆるジャンクションに相当する。マスタ10は、例えばPLCに相当し、第2スレーブはフィールドに備えられる制御対象(センサ、スイッチ、リレーなど)を接続する機器を含む。データは、例えばマスタ10から各スレーブに送信される制御用の指令、および第2スレーブからマスタ10に送信されるフィールド情報を含む。データは、例えばフレーム形式で構成されるが、フレーム形式に限定されない。
 リング配線は、各第2スレーブ装置が、起点側から入来するデータを受付け、受付けたデータを終点側へ転送するための第1経路15(図5のStep0)と、各複数のスレーブ装置が、当該スレーブ装置と隣接するスレーブ装置との間の経路が切断される場合に、自スレーブ装置からデータをループバック転送するための第2経路16(図5のStep1)とを構成可能である。このように、リング配線は、第1経路15と第2経路16とを冗長的に構成可能なジャンクション冗長化のリングトポロジを構成し得る。
 マスタ10は、経路の切断箇所が接続されて経路が切断から復旧する場合に(図5のStep2)、第2経路16を元の第1経路15に切替えるための指令(コマンド)を、ループバック転送を実施するスレーブ装置に送信する。Step1では、ループバック転送を実施するスレーブ「C」とスレーブ「D」は当該指令を受付けて、受付けた指令を実行する。指令が実行されることによって、例えば、復旧された経路に接続されているスレーブ「C」とスレーブ「D」の入出力ポートがオープンする。さらに、マスタ10は、上記の指令をリング配線に送信した時からリング配線の伝搬遅延時間に基づく所定時間が経過した後に、リング配線に新たなデータを送出する。これにより、新たなデータが、リング配線において後述する逆巡回データとなることを防止できる。
 本開示では、リング配線の切断および接続は、ケーブルの切断および接続などの物理的な事象を想定するが、切断または接続の事象は、物理層の事象に限定されない。例えば、物理層よりも上位層(例えば、コネクション層)での論理的な切断または接続の事象であっても本開示を適用することができる。
 ここで、逆巡回データの発生を説明する。上記のように経路の切断箇所が接続されて経路が切断から復旧すると、スレーブ「C」とスレーブ「D」ではループバックは実施されなくなり、経路が切断された時にループバックで転送されていたデータはリング配線内を巡回し始める(図5のStep2)。この巡回の方向は、経路が切断されていない正常時(図5のStep0)におけるデータの流れる方向とは逆であるので、本実施の形態では「逆巡回」とも称する(図5のStep2)。逆巡回データは、マスタ10に到達しない。
 Step2で接続された経路が、その後、切断されると(図5のStep3)、再度、リング配線においては第2経路16が構成されて、逆巡回データは第2経路16を経由してマスタ10に到達する(図5のStep3)。マスタ10にとって、逆巡回データは誤入力となり得る。
 本開示では、指令をリング配線に送信した時からリング配線の伝搬遅延時間に基づく所定時間が経過した後に、例えば指令がリング配線を介して該当するスレーブ装置(例えば、スレーブ「C」とスレーブ「D」)に到達するまでの伝搬遅延時間に基づく所定時間が経過した後に、リング配線に新たなデータが送出される。
 このように、リング配線の経路が切断から復旧する場合に、マスタ10は、リング配線において、指令が該当するスレーブに到達し、到達した指令がスレーブによって実行されることによってループバックの第2経路16が第1経路15に切替わるまでの所要時間を、伝搬遅延時間に基づく時間として見込む。マスタ10は、この見込まれた時間が経過したタイミングで、新たなデータをリング配線に送出することができる。この結果、送出された新たなデータは、第1経路15で転送され得て、リング配線におけるループバック方向に巡回する逆巡回データの発生を抑制することができる。
 以下、本実施の形態のより具体的な応用例について説明する。
 <B.PLCシステムの全体構成>
 まず、制御システムの一形態である、本実施の形態に係るPLCシステム1の全体構成について説明する。図1は、本実施の形態に係るPLCシステム1の全体構成を示す模式図である。
 図1を参照して、PLCシステム1は対象を制御するための制御システムであって、本開示に係るネットワークが適用されるシステムの一例である。PLCシステム1は、メイン処理装置2と、複数のリモート装置であるスレーブ40-0,40-1,40-2,40-3,40-4とを含む。メイン処理装置2およびスレーブ40-0,40-1,40-2,40-3,40-4は、PLCシステム1の少なくとも一部を構成する装置であり、ネットワーク4を介して接続されている。
 ネットワーク4には、例えばTSN(Time-sensitive networking)規格に従いデータの到達時間が保証される、定周期通信を行なうバスまたはネットワークを採用することが好ましい。例えば、マシンコントロール用ネットワークの一例であるEtherCAT、汎用的なEthernet(登録商標)上に制御用プロトコルを実装した産業用オープンネットワークであるEtherNet/IP(登録商標)などの公知のプロトコルに係るネットワークを採用してもよい。
 メイン処理装置2は、対象を制御するために必要なプログラム(ユーザプログラムおよびシステムプログラムなどを含む)を実行することによって、図示しない外部のスイッチまたはセンサなどからの入力信号(以下、「フィールド情報」と称する)を収集する処理、収集したフィールド情報に基づいて制御演算を行なう処理、制御演算によって算出された指令値を、外部のリレーやアクチュエータなどの制御対象へ与える処理などを実現する。
 メイン処理装置2は、PLCに相当し、その装置構成として、CPU(Central Processing Unit)などを含む演算処理装置としてのプロセッサユニット10と、入出力動作を実施する1つ以上のIOユニット20と、電源ユニット30とを備える。プロセッサユニット10およびIOユニット20は、図示しない内部バスを介して互いにデータ通信可能に接続されている。電源ユニット30は、プロセッサユニット10およびIOユニット20へ適切な電圧の電力を供給する。
 プロセッサユニット10は、対象を制御するために必要なプログラムを実行する演算部と、ネットワーク4を介したスレーブ40-0,40-1,40-2,40-3,40-4との通信を制御するための通信処理部に相当する通信コントローラ110とを含む。ネットワーク4を介した通信は、メイン処理装置2によって主体的に制御される。具体的には、プロセッサユニット10は、後述するタイマ115に基づく周期、または予め定められたタイミング、または規則に従って、ネットワーク4上を順次伝送されるデータを送出する。以下の説明においては、ネットワーク4上を順次伝送されるデータを「フレーム」とも称す。このような意味において、プロセッサユニット10を以下ではスレーブ40-0,40-1,40-2,40-3,40-4を管理する「マスタ10」と称する。また、スレーブ40-0,40-1,40-2,40-3,40-4は基本的に同様の構成を備えることから、これらスレーブに共通した構成を説明する場合は、「スレーブ40」と総称する。なお、図1のPLCシステム1では、4台のスレーブ40-0,40-1,40-2,40-3,40-4を備えるが、スレーブの台数は4台に限定されない。
 スレーブ40は、外部のスイッチまたはセンサなどのフィールド機器からのフィールド情報を受信し、ネットワーク4を介して、その受信したフィールド情報をマスタ10へ送信する。併せて、スレーブ40は、マスタ10からネットワーク4を介して受信した指令値を、外部のリレーやアクチュエータのフィールド機器へ出力する。あるいは、スレーブ40は、ネットワーク4を介して受信した指令値に従って自身で動作するものであってもよい。例えば、スレーブ40としては、演算機能を持たない単純なIOユニット、演算機能を有するIOユニット、モーションコントローラのようなアクチュエータを含む装置、などが想定される。
 マスタ10の通信コントローラ110は、メイン処理装置2および1つ以上のスレーブ40が扱うデータを含むデータ列(本実施の形態では、「フレーム50」に相当する)のネットワーク4上での伝送を管理するように構成されている。
 図1に示されるように、ネットワーク(ネットワークシステム)は、マスタ10と複数のスレーブ40とで構成されている。マスタ10は、リングトポロジを含むネットワークを構成する複数のスレーブ40-0~40-4を管理する。また、マスタ10は、外部の情報処理装置であるサポート装置200に通信可能に接続されている。サポート装置200は、ディスプレイ209を備える。
 リングトポロジを説明するために、スレーブ40-0を分岐用スレーブ40-0と称し、スレーブ40-1~40-4を、それぞれ、スレーブ「A」、スレーブ「B」、スレーブ「C」およびスレーブ「D」とも称する。また、図1では、各スレーブが有するポートとして、主にフレーム50が入来する入力ポートINおよび主にネットワーク4上にフレーム50を送出する出力ポートOUTが示される。
 分岐用スレーブ40-0は、リングトポロジの起点および終点となるスレーブであって、リングトポロジを構成するスレーブである。スレーブ「A」、スレーブ「B」、スレーブ「C」およびスレーブ「D」は、この順番でディジーチェーンで接続されて、ディジーチェーン接続されたスレーブ群は、分岐用スレーブ40-0が有する起点に対応のポートOUT1および終点に対応のポートIN1との間に接続される。さらに、分岐用スレーブ40-0の入力ポートPOには、マスタ10が接続される。
 分岐用スレーブ40-0のポートOUT1およびポートIN1は、それぞれ、スレーブ「A」の入力ポートINおよびスレーブ「D」の出力ポートOUTに接続される。ディジーチェーンで接続されたスレーブ群において、各スレーブ40の出力ポートOUTは、隣接するスレーブ40の入力ポートINに接続される。これにより、マスタ10からネットワーク4の送出されたフレーム50は、分岐用スレーブ40-0を経て、ディジーチェーン接続された各スレーブ40を経由し、その後、分岐用スレーブ40-0を経て、マスタ10に戻る。したがって、マスタ10は、リングトポロジを巡回するフレーム50を介して各スレーブ40との間でデータ(指令値またはフィールド情報)を遣り取りすることができる。
 以下では、互いにネットワーク4のケーブルで接続された2つのスレーブ40の間で「IN-OUT関係」が規定される。具体的には、一方のスレーブ40の出力ポートOUTから他方のスレーブ40の入力ポートINへのデータ入力を、「OUTからINへの入力」とも称する。また、互いにケーブルで接続された2つのスレーブ40のうち、一方のスレーブ40の入力ポートINから他方のスレーブ40の出力ポートOUTへのデータ入力を、(以下、「INからOUTへの入力」とも称する。
 <C.プロセッサユニット10のハードウェア構成>
 図2は、本実施の形態に係るPLCシステム1に含まれるプロセッサユニット10のハードウェア構成を示す模式図である。図2を参照して、本実施の形態に係るマスタ10(すなわち、プロセッサユニット10)の装置構成について説明する。
 図2を参照して、マスタ10は、通信処理部である通信コントローラ110に加えて、演算部であるプロセッサ100と、主記憶装置の一例である主メモリ102と、補助記憶装置の一例である不揮発性メモリ104と、内部バスコントローラ106と、タイマ115と、メモリカードインターフェイス114およびUSB(Universal Serial Bus)コントローラ112と、ネットワーク4が繋がる通信コントローラ110とを含む。これらのコンポーネントは、内部バス108を介して、互いにデータ通信可能に構成される。マスタ10は、さらに、ネットワーク4にフレーム50を送出するための出力ポート121およびネットワーク4からフレーム50が入来する入力ポート131を含む。主メモリ102は、DRAM(Dynamic Random Access Memory)またはSRAM(Static Random Access Memory)などの揮発性記憶装置などで構成される。不揮発性メモリ104は、例えば、HDD(Hard Disk Drive)またはSSD(Solid State Drive)などの不揮発性記憶装置などで構成される。
 説明の便宜上、マスタ10は、1つのプロセッサ100のみを備えるが、複数のプロセッサが実装されてもよい。なお、各プロセッサは、複数のコアを有していてもよい。マスタ10においては、プロセッサ100が1または複数のタスクを周期的に実行する。
 プロセッサ100は、制御に係るプログラムを実行する。プロセッサ100は、不揮発性メモリ104などから必要なプログラムを読み出すとともに、読出されたプログラムを主メモリ102に展開して実行する。制御に係るプログラムは、典型的には、ユーザプログラムおよびシステムプログラムを含む。
 内部バスコントローラ106は、内部バス109を介してIOユニット20と接続され、プロセッサ100とIOユニット20との間のデータの遣り取りを仲介する。
 メモリカードインターフェイス114は、メモリカード116を脱着可能に構成されており、メモリカード116に対してデータを書込み、メモリカード116から各種データ(ユーザプログラムまたはデータなど)を読出すことが可能になっている。ユーザプログラムは、メモリカード116から不揮発性メモリ104にロードされてもよい。
 USBコントローラ112は、サポート装置200とマスタ10との通信を制御する。なお、サポート装置200との通信のための規格は、USBに限定されず、各種の通信規格を適用することができる。
 通信コントローラ110は、ネットワーク4を介してスレーブ40と接続され、マスタ10とスレーブ40との間のデータ(指令およびフィールド情報など)の遣り取りを仲介する。より具体的には、通信コントローラ110は、共有メモリ111と、送信バッファ120と、送信回路122と、受信バッファ130と、受信回路132とを含む。送信回路122および受信回路132は、それぞれ、出力ポート121および入力ポート131に接続されて、接続されたポートを介してネットワーク4上にデータを送出し、ネットワーク4から入来するデータを受信する。
 送信バッファ120および送信回路122は、通信コントローラ110から外部装置へのフレーム送出に係る処理を実現し、受信バッファ130および受信回路132は、外部装置から通信コントローラ110へのフレーム受信に係る処理を実現する。通信コントローラ110は共有メモリ111を有しており、プロセッサ100は、直接的に、共有メモリ111にアクセスして、共有メモリ111にデータ(フィールド情報など)を書き込むとともに、共有メモリ111からデータ(指令など)を取得する。つまり、共有メモリ111に書き込まれたデータは、送信バッファ120へ転送されて、送信バッファ120から外部装置へ送出される。また、外部装置から取得されたデータは、受信バッファ130で受信された後、共有メモリ111へ転送される。
 通信コントローラ110は、ソフトウェアを用いて、その一部または全部を実現してもよい。あるいは、ASIC(Application Specific Integrated Circuit:特定用途向集積回路)やFPGA(Field-Programmable Gate Array)などのハードウェア回路を用いて、その一部または全部を実現してもよい。
 <D.スレーブ40の装置構成>
 図3は、本実施の形態に係るスレーブ40のハードウェア構成を示す模式図である。図3を参照して、本実施の形態に係るスレーブ40の装置構成について説明する。
 図3を参照して、スレーブ40は、プロセッサ400、タイマ403、入力ポート410、出力ポート420、受信回路(図中は、Rxと略す)424および433、転送回路(図中は、Txと略す)423および434を備える。
 プロセッサ400は、入力ポート410または出力ポート420を介してネットワーク4とデータを送受信し、送受信するデータに所定処理を実施する。プロセッサ400は、ソフトウェアを実行することによりフレーム処理部440のフレーム処理を含む所定処理を実現する。スレーブ40(分岐用スレーブは除く)のフレーム処理部440は、主に、入来するフレーム50と図示しないフィールド機器との間でのデータ(指令またはフィールド情報)の遣り取りを実施する。なお、プロセッサ400は、その一部または全部をソフトウェアで実現してもよく、プロセッサ回路として実現されてもよい。回路は、ASICまたはFPGAを含み得る。
 入力ポート410は、受信回路424が接続されるポート411と、転送回路434が接続されるポート412とを含む。同様に、出力ポート420は、受信回路433が接続されるポート421と、転送回路423が接続されるポート422とを含む。プロセッサ400は、タイマ403に基づく周期、または予め定められたタイミング、または規則に従って、切替信号401と402を、それぞれ、入力ポート410および出力ポート420に出力する。入力ポート410は、切替信号401に従い、ポート410および411の一方をネットワーク4に接続し、出力ポート420は、切替信号402に従い、ポート422および421の一方をネットワーク4に接続する。
 このような切替信号401と402によって、互いにネットワーク4で接続された2つのスレーブ40の間で上記に述べた「IN-OUT関係」が動的に切替られる。具体的には、ポート411と422がネットワーク4に接続される場合、「OUTからINへの入力」でフレーム50が転送されて、ポート412と421がネットワーク4に接続される場合、「INからOUTへの入力」でフレーム50が転送される。
 <E.スレーブ間のデータの流れ>
 図4は、本実施の形態に係る2つのスレーブ間のフレームの流れの一例を模式的に説明するための図である。図4は、図1のリングトポロジにおいて隣接する任意の2つのスレーブ40の間のフレーム50の流れを示す、例えばスレーブ「C」とスレーブ「D」間のフレーム50の流れを示す。図5は、本実施の形態に係るリングトポロジにおけるフレーム50の経路の変化の一例を模式的に説明するための図である。
 図4では、破線の矢印は、フレーム50の流れ(経路)を表している。また、破線の矢印の上下の番号((i),(ii),(iii),…)は、フレーム50の流れの順序(経路の順序)を示している。以下では、説明の便宜上、経路(i)等と記載した場合には、番号(i)の経路を指すものとする。
 図4と図5を参照して、ネットワーク4の経路が切断されていない正常な場合のフレーム50の流れと、ネットワーク4の経路が切断/接続がされたときのフレーム50の流れとを説明する。この“切断/接続”は、経路が切断された後に当該経路が接続されることを示す。
 まず、正常な場合のフレーム50の流れを説明する。マスタ10からのフレーム50が、分岐用スレーブ40-0の起点側からスレーブ「C」の入力ポート410に入来すると(図4の(i)参照)、入力ポート410からフレーム処理部440にフレーム50が送られる(ii)参照)。フレーム処理部440は、入来するフレーム50を受付けて、受け付けたフレーム50に所定の処理を施す。その後、フレーム処理部440は、処理後のフレーム50を出力ポート420に送る((iii)参照)。
 フレーム50は、出力ポート420から、ネットワーク4を介してスレーブ「D」に転送される。フレーム50は、スレーブ「D」の入力ポート410に転送される((iv)参照)。スレーブ「D」の入力ポート410にフレーム50が入来すると、入力ポート410は入来したフレーム50をフレーム処理部440に送信する((v)参照)。フレーム処理部440は、受信したフレーム50に対して所定の処理を行なう。その後、フレーム処理部440は、処理後のフレーム50を出力ポート420に送信する((vi)参照)。その後、フレーム50は、スレーブ「D」の出力ポート420から、図示されない分岐用スレーブ40-0を介してマスタ10に戻る。
 このように、正常時は、スレーブ40間のフレーム50の流れは「OUTからINへの入力」に従う一方向への流れとなる(図5のStep0)。
 これに対して、ネットワーク4がスレーブ「C」とスレーブ「D」の間で切断された場合、フレーム50は次のように転送される。まず、上記の正常時のフレーム50の流れにおいて、スレーブ「C」のフレーム処理部440は、処理後のフレーム50を出力ポート420に送る((vi)参照)が、スレーブ「D」との接続が切断されている場合は、スレーブ「C」は、フレーム50を、スレーブ「C」の出力ポート420からフレーム処理部440を介することなく、入力ポート410に送信する((ix)参照)。このように、スレーブ「C」は、スレーブ「C」とスレーブ「D」と間の経路が切断されている場合は、フレーム50を折返し転送する。ネットワーク4の経路が切断された時は、切断箇所に接続されていたスレーブ40においてフレーム50が折返し転送されることで、正常時のフレーム50の流れとは逆向きの「OUTからINへの入力」に従う方向の流れが生じ得る。本実施の形態では、このようなスレーブ40におけるフレーム50の折返し方向への転送を「ループバック」とも称する(図5のStep1)。
 スレーブ「C」でループバックされたフレーム50は、図示しないスレーブ「B」→スレーブ「A」→分岐用スレーブ40-0と逆方向に転送されることによって、当該フレーム50は、スレーブ「D」の出力ポート420に転送される。スレーブ「D」は、スレーブ「D」とスレーブ「C」との間の経路が切断されていることから、出力ポート420で受付けたフレーム50を、分岐用スレーブ40-0に折返し転送する。これによって、フレーム50は分岐用スレーブ40-0からマスタ10に戻される。
 その後、経路の切断箇所が接続されると、スレーブ40では折返しが実施されなくなって、すなわち経路の切断時に折返し転送されていたフレーム50はリングトポロジ内を巡回し始める((vii)、(viii)、(ix)および(x)参照)。この巡回の方向は、正常時にフレーム50が流れる方向とは逆であるので、本実施の形態では「逆巡回」とも称する(図5のStep2)。「逆巡回」する逆巡回フレーム50は、各スレーブ40においてはフレーム処理部440をバイパスする経路で転送される。逆巡回フレーム50は、マスタ10に到達しないために、マスタ10は、逆巡回フレーム50が生じたとき、データロスト(フレームロスト)を検出する。
 その後、経路の接続された箇所が再度切断されると、通常時のフレーム50と巡回フレーム50との両者の流れる方向は一致することになるために、マスタ10に通常のフレーム50と巡回フレーム50の両方が到達する(図5のStep3)。
 (発明者の知見)
 本実施の形態では、通常時のフレーム50および逆巡回フレーム50は、後述の図6(B)に示されるように、それぞれ、当該フレームを識別するインデックス53と転送するべきデータ本体であるデータグラム52とを含む。マスタ10は、制御周期に基づく所定周期毎に所定範囲のインデックス53を付加してフレーム50を生成し転送する(図5のStep3.1)。逆巡回フレーム50は現在周期ではない過去の周期のフレーム50である可能性が高いが、マスタ10に到達した逆巡回フレーム50と現在の通常時のフレーム50との両者が一致したインデックス53を有する場合は、マスタ10は、両フレーム50のうちどちらが正しいフレームであるか、すなわち処理すべきフレームであるかを判別できなくなり、誤動作に繋がる。
 発明者は、ジャンクション冗長化のリングトポロジでは、経路の切断/接続がなされた場合に、上記に述べた逆巡回フレームが発生するとの新たな知見を得て、この知見のもと、上記の誤動作を回避するためには巡回フレーム50の発生を抑制する必要があるとの課題を見いだした。巡回フレーム発生の抑制に関する処理を以下に説明する。
 (フレームの構成例)
 本実施の形態に係るフレームの構成例を説明する。図6は、本実施の形態に係るフレームの構成の一例を模式的に示す図である。本実施の形態に係るフレーム50は、基本的に、コントロール情報を格納するためのヘッダ51とデータグラム52を含む(図6(A))。フレームの種類に応じて、ヘッダ51またはデータグラム52に格納される情報は異なる。
 図6(B)を参照して通常時にリングトポロジのスレーブ40を巡回しながら転送されるフレーム55(以下、巡回フレーム55とも称する)のヘッダ51にはインデックス53、フレームの破棄の要否を判定するために参照されるRoundTripBit57、RoundTripBit57が設定された時間571、およびタイプ58が格納されて、データグラム52の領域に各スレーブ40(すなわち、スレーブ「A」、スレーブ「B」、スレーブ「C」およびスレーブ「D」)に対応の指令値またはフィールド情報であるデータ52A52B,52C,52Dのそれぞれが格納される。このデータグラム52には、メッセージが格納されてもよい。RoundTripBit57は、初期値は「OFF」であって、巡回フレーム55がループバックされる場合に、スレーブ40によって「ON」が設定(書換)される。タイプ58は、フレーム50の種類を示す。本実施の形態では、フレーム50の種類は、通常の巡回フレーム55、後述するコマンドフレーム56などを含む。
 図6(C)は、コマンドフレーム56の一例を示す。コマンドフレーム56は、ヘッダ51にタイプ58を格納し、データグラム52としてポートを開けるための指令であるオープンコマンド54を有する。オープンコマンド54は、オープンするべきスレーブ40のポートを識別するポート識別子59を含む。スレーブ40は、入来したコマンドフレーム56のポート識別子59に基づき、当該コマンドフレーム56は自己宛てのコマンドフレーム56であると検出すると、当該コマンドフレーム56のオープンコマンド54を実行することによって、当該ポートのオープン処理を実施する。オープン処理は、ネットワーク4の経路の切断によってポートが閉じたスレーブ40の状態を、ポート開の状態に遷移させる処理を含む。より具体的には、スレーブ40の状態を、当該ポートを介したフレーム転送(送受信)の処理を実行可能な状態(実行許可状態)に遷移させることを含む。なお、スレーブ40は、当該スレーブ40と隣接するスレーブ40との間でネットワーク4の経路が切断されたことを検出すると、隣接するスレーブ40を接続するポートを閉じて、自己の状態をフレーム転送の処理を実行禁止する状態に遷移させる。
 <F.巡回フレーム発生の抑制>
 本実施の形態では、リングトポロジの経路におけるスレーブ40間の切断箇所が接続し直されて経路が切断から復旧した場合に、マスタ10は、復旧した箇所に接続されているスレーブ40の入出力ポートをオープンするためのコマンドフレーム56を送信し、当該送信の直後ではなく、コマンドフレーム56の送信時から所定時間が経過したときに、通常時の巡回フレーム55をリングトポロジのネットワーク4へ送出(転送)する動作を開始する。
 (F1.マスタ10の機能構成)
 図7は、本実施の形態に係るマスタ10の機能構成の一例を模式的に示す図である。図7を参照して、マスタ10は、逆巡回フレームの発生を抑制するために巡回抑制部180と、不揮発性メモリ104に対応する記憶部185と、通信処理部186および187と、フレーム処理部188を含む。通信処理部187は、逆巡回フレーム発生の可能性を示す通知を出力する通知部1871を有する。
 記憶部185は、ネットワーク構成情報1851を含む。ネットワーク構成情報1851は、例えば、サポート装置200においてユーザによって事前に作成され、作成されたネットワーク構成情報1851はマスタ10に転送される。ネットワーク構成情報1851は、マスタ10とスレーブ40との間の接続関係、およびリングトポロジのネットワーク4に接続されるスレーブ40の接続関係を示す情報を含む。これら接続関係を示す情報は、マスタ10とスレーブ40との間を経路によって接続する入出力ポートを識別する情報、および隣接するスレーブ40どうしの間を経路によって接続する入出力ポートを識別する情報を含む。
 フレーム処理部188は、通信処理部186を介してスレーブ40と通常時のフレームを遣り取りする。フレーム処理部188は、ユーザプログラムの演算結果である指令値を格納した巡回フレーム55を生成し、生成された巡回フレーム55を通信処理部186に出力するとともに、スレーブ40から受信された巡回フレーム55から、ユーザプログラムのために、フィールド情報を抽出する受信処理を実施する。具体的には、フレーム処理部188は、制御周期に基づく周期毎に、当該周期における複数の巡回フレーム55をリングトポロジとの間で遣り取りする。
 巡回抑制部180は、「指令手段」の一実施例であるポート制御部1810と、検出部1820とを備える。検出部1820は、切断された経路が接続されることによって、経路が切断から復旧したことを検出する復旧検出部1821と、リングトポロジのネットワーク4の接続状態を検出する接続状態検出部1822と、オープンコマンド54の出力態様(モード)を判定するモード判定部1823と、オープンコマンド54が送信された後に、フレーム処理部188にフレーム送信を許可する送信許可部1824とを備える。
 通信処理部186は、通信コントローラ110に対応し、マスタ10がスレーブ40との間でデータの送受信を行うためのインターフェイスである。通信処理部187は、USBコントローラ112に対応し、マスタ10がサポート装置200との間でデータの送受信を行うためのインターフェイスである。通知部1871は、サポート装置200に上記の通知を出力する。
 ポート制御部1810は、検出部1820からの出力に基づき、オープンコマンド54を格納したコマンドフレーム56を生成し、生成されたコマンドフレーム56を通信処理部186に出力する。オープンコマンド54は、経路の切断箇所に接続されているスレーブ40の入力ポート410または出力ポート420を、当該経路が切断から復旧した場合にオープンするための指令を示す。
 経路の切断箇所には、例えばユーザ操作によりケーブル(配線)が接続される。これによって、経路は切断から復旧する。復旧検出部1821は、当該復旧したことを、例えば外部からの入力によって検出する。
 接続状態検出部1822は、ネットワーク4の切断/接続箇所のリングトポロジ上の位置を検出する。この詳細は後述する。
 モード判定部1823は、接続状態検出部1822が検出した切断/接続箇所の位置に応じて、ポート制御部1810によるオープンコマンド54の出力態様を異ならせる。ここでは、オープンコマンド54の出力態様として、切断/接続箇所の検出位置が、分岐用スレーブ40-0の終点と隣接するスレーブ「D」との間である「第2モード」と、当該検出位置がリングトポロジの他の位置、すなわち、分岐用スレーブ40-0の起点~スレーブ「D」までの間の位置である「第1モード」とを含む。各モードに応じたオープンコマンド54の出力態様については後述する。
 (F2.リングトポロジの切断箇所の検出)
 接続状態検出部1822は、予め定められた検出用データを用いて、リングトポロジのネットワーク4の構成を検出する。
 具体的には、検出用データは、第1のデータと、第1のデータが各スレーブ40を通過した時刻を示すタイムスタンプ情報を各スレーブ40から取得するための第2のデータとを含む。接続状態検出部1822は、先に第1のデータをリングトポロジのネットワーク4に送出する。接続状態検出部1822は、リングトポロジのネットワーク4を介して戻ってきた第1のデータを受信した後に、第2のデータをネットワーク4に送出する。そして、接続状態検出部1822は、リングトポロジのネットワーク4を介して戻ってきた第2のデータを受信する。
 上記のタイムスタンプ情報は、各ポートをデータが通過したときの時間(時刻)である。たとえば、入力ポート410に入来するデータが出力ポート420から出力される場合、タイムスタンプ情報は、入力ポート410をデータが通過したときの時間と、出力ポート420をデータが通過したときの時間と、当該ポートの識別子(すなわち、スレーブ40の識別子とポートの識別子の組)とを含む。タイムスタンプは、各スレーブ40内のデータ処理部で記憶され得る。
 接続状態検出部1822は、タイムスタンプを利用することにより、データが通過したポートの順番である通過順序を特定できる。また、接続状態検出部1822は、タイムスタンプを利用することにより、ネットワーク4で互いに接続された2つのスレーブ40の間において、「OUTからINへの入力」および「INからOUTへの入力」のいずれが行われているかを判断できる。接続状態検出部1822は、タイムスタンプによって取得されたポートの通過順序を示すデータと、ネットワーク構成情報1851が示す接続関係を示す情報とを照合し、照合の結果に基づき、データが通過しているポートおよび通過していないポートの各識別子を特定することができる。
 特定されたポート識別子に基づき、接続状態検出部1822は、リングトポロジのネットワーク4において切断された経路の位置を検出することができ、また、切断された経路が接続されて復旧したことも検出することができる。
 モード判定部1823は、接続状態検出部1822の出力と、ネットワーク構成情報1851とを照合し、照合の結果に基づき、接続/切断の検出位置を特定し、特定した検出位置に基づき「第2モード」であるか、または「第1モード」であるかを判定する。
 (F3.スレーブ40の機能構成)
 図8は、本実施の形態に係るスレーブ40の機能構成の一例を模式的に示す図である。図8を参照して、スレーブ40のプロセッサ400は、ループバック部470、フレーム判別部430、フレーム処理部440、およびオープンコマンド54を実行するコマンド実行部450を備える。
 ループバック部470は、当該ループバック部470を備えるスレーブ40と隣接するスレーブ40とを接続する経路が切断されたことを検出したとき、当該スレーブ40の「INからOUTへの入力」を「OUTからINへの入力」にループバックし、または「OUTからINへの入力」を「INからOUTへの入力」にループバックする。
 フレーム判別部430は、入力ポート410または出力ポート420に入来するフレームのタイプ58に基づき、当該フレームの種類を判別する。フレーム判別部430は、入力ポート410に入来するフレームであって、当該フレームのタイプ58が“通常”を示すフレーム、すなわち通常時の巡回フレーム55は、フレーム処理部440に出力するが、出力ポート420に入来するフレームであって、当該フレームのタイプ58が“通常”を示すフレーム、すなわち逆巡回フレーム55はフレーム処理部440をバイパスさせて入力ポート410に出力する。
 さらに、フレーム判別部430は、入力ポート410または出力ポート420に入来するフレームのうちから、そのタイプ58が“コマンド”を示すフレーム、すなわちコマンドフレーム56を特定する。フレーム判別部430は、特定されたコマンドフレーム56のポート識別子59が当該スレーブ40の入力ポート410または出力ポート420を示すと判定した場合は、コマンドフレーム56をコマンド実行部450に出力するとともに、当該コマンドフレーム56を入力ポート410または出力ポート420を介してネットワーク4に送出する。
 コマンド実行部450は、フレーム判別部430から出力されたコマンドフレーム56のオープンコマンド54を実行する。これにより、オープンコマンド54で指示される入力ポート410または出力ポート420をオープンするためのポートオープン処理が実施される。
 (F4.ポートオープンの実現方法)
 本実施の形態では、切断された経路が接続されるときは、マスタ10は、当該経路に接続されているスレーブ40の入力ポート410および出力ポート420のオープン順序を、リングトポロジ内の当該経路の位置に応じて適正化する。具体的には、マスタ10は、当該オープン順序を、逆巡回フレーム55(図5のStep2)の発生が抑制されるような順序に決定する。本実施の形態に係る切断/接続の経路の位置は、(ケース1)の位置と(ケース2)の位置とを含む。図9は、本実施の形態に係る切断/接続の経路の(ケース1)の位置と(ケース2)の位置とを模式的に示す図である。図10は、本実施の形態に係る処理のフローチャートである。
 図9(A)を参照して(ケース1)では、接続状態検出部1822は、スレーブ「C」の出力ポート420(port1)とスレーブ「D」の入力ポート410(port0)との間の経路が切断されていることを検出する。図9(B)を参照して(ケース2)では、接続状態検出部1822は、スレーブ「D」の終点となるポート(pot1)と分岐用スレーブ40-0の出力ポート420(port1)との間の経路が切断されていることを検出する。図9(A)の(ケース1)では、経路の切断箇所は、スレーブ「C」とスレーブ「D」との間の位置であったが、切断箇所は、この位置に限定されず、分岐用スレーブ40-0の起点とスレーブ「A」との間、スレーブ「A」とスレーブ「B」との間、およびスレーブ「B」とスレーブ「C」との間のいずれであってもよい。
 図10を参照して、接続状態検出部1822はリングトポロジのネットワーク4における経路が切断された箇所に接続されているスレーブ40の入力ポート410と出力ポート420を検出する(ステップS1)。復旧検出部1821は、外部入力に基づき、経路が切断から復旧したことを検出する(ステップS2)。モード判定部1823は、経路が切断から復旧したことが検出されたとき、ステップS1で検出されていたスレーブ40の入力ポート410と出力ポート420の情報と、ネットワーク構成情報1851とを照合し、照合の結果に基づき、経路において切断/接続された箇所(以下、切断/接続箇所ともうい)は(ケース1)および(ケース2)のいずれにあたるかを検出する。切断/接続箇所は(ケース1)にあたると検出されると、モード判定部1823はポートオープンを「第1モード」に従い実施すると判定し(ステップS3で“第1モード”)、ポート制御部1810は“第1モード”に従いオープンコマンド54を送信する(ステップS4)。
 切断/接続箇所は(ケース2)にあたると検出されると、モード判定部1823はポートオープンを「第2モード」に従い実施すると判定し(ステップS3で“第2モード”)、ポート制御部1810は“第2モード”に従いオープンコマンド54を送信する(ステップS5)。
 送信許可部1824は、ステップS4またはステップS5においてオープンコマンド54が送信された時から、例えば所定時間が経過したことを検出したことに応じて、フレーム送信許可の通知をフレーム処理部188に出力する(ステップS6)。フレーム処理部188は、送信許可部1824からの送信許可の通知を受信したことに応じて、通常時の巡回フレーム55をリングトポロジのネットワーク4へ送信する動作を開始する(ステップS7)。
 (F4-1.「第1モード」におけるポートのオープン順序)
 図11~図14は、本実施の形態に係る(ケース1)の“第1モード”のフレームの流れを模式的に示す図である。図11~図14の太線矢印は、フレーム50の流れる方向を示している。図11~図14を参照して、ステップS4(図10)の処理を説明する。図11~図14では、分岐用スレーブ40-0とスレーブ「A」との間の経路が切断されている。したがって、接続状態検出部1822は、分岐用スレーブ40-0の出力ポート420の識別子portY(図11)とスレーブ「A」の入力ポート410の識別子portX(図11)を出力する。
 図11では、マスタ10は、通常時の巡回フレーム55(図中はCyclicフレーム55として示される)をリングトポロジのネットワーク4に送信し、続いて、コマンドフレーム56を送信する。ポート制御部1810は、接続状態検出部1822の出力に基づき、portXのオープンコマンド54とportYのオープンコマンド54の両方を格納したコマンドフレーム56を生成し、生成されたコマンドフレーム56をリングトポロジのネットワーク4に送出する(図11のステップS41)。マスタ10は、当該コマンドフレーム56を送信した直後に、通常時の巡回フレーム55などのフレームを送信しない。
 分岐用スレーブ40-0は、ステップS41で送出されたコマンドフレーム56を受信する。分岐用スレーブ40-0のコマンド実行部450は、受信したコマンドフレーム56の内容に基づき、受信されたコマンドフレーム56のオープンコマンド54は分岐用スレーブ40-0宛であると判定し、当該オープンコマンド54を実行する(図12のステップS42)。これにより、分岐用スレーブ40-0のportYはオープンする。マスタ10は、コマンドフレーム56を送信した直後に新たなフレームを送信しないので、オープンしたportYを通過してportXに入来するフレームは存在しない。
 portYがオープンされると、通常時の巡回フレーム55とコマンドフレーム56は、「OUTからINへの入力」に従う一方向への流れに従い、分岐用スレーブ40-0のポート410、スレーブ「D」、スレーブ「C」、スレーブ「B」およびスレーブ「A」に到達する。スレーブ「A」のコマンド実行部450は、受信したコマンドフレーム56の内容に基づき、コマンドフレーム56はスレーブ「A」宛のフレームであると判定し、コマンドフレーム56のオープンコマンド54を実行する(図13のステップS43)。このとき、スレーブ「A」は、コマンドフレーム56および巡回フレーム55をループバックする(図13)。ループバックされた巡回フレーム55とコマンドフレーム56は、マスタ10に戻される(図14)。
 これにより、portXはオープンするが、マスタ10は、コマンドフレーム56の送信直後に新たなフレームを送信していないので、オープンしたportXを通過してportYに入来するフレームは存在しない。すなわち、逆巡回フレームは発生しない。
 送信許可部1824は、マスタ10がコマンドフレーム56を送信した時から所定時間経過したことを検出すると、送信許可の通知を出力する。フレーム処理部188は、送信許可部1824から送信許可の通知を受付けると、送信許可に従い、通常時の巡回フレーム55を生成し、生成された巡回フレーム55をリングトポロジのネットワーク4に送出する(図10のステップS6,S7)。
 送信許可部1824が計時する上記の所定時間は、リング配線であるネットワーク4におけるフレーム50の伝搬遅延時間に基づいている。より具体的には、所定時間は、コマンドフレーム56がマスタ10から送出されて戻ってくるまでの所要時間(伝搬遅延時間)、またはコマンドフレーム56がリングトポロジを一巡する所要時間(伝搬遅延時間)に基づいている。この所要時間は予め推定(計算)されている。なお、送信許可部1824が送信許可の通知を出力するタイミングは、コマンドフレーム56の伝播遅延時間に基づいており、例えば、マスタ10が、リングトポロジのネットワーク4から戻されたコマンドフレーム56の到達を検出したときであってもよい。
 (F4-2.「第2モード」におけるポートのオープン順序)
 図15~図20は、本実施の形態に係る“第2モード”のフレームの流れを模式的に示す図である。図15~図20の太い矢印は、フレーム50の流れる方向を示している。図15~図20を参照して、ステップS5(図10)の(ケース2)の処理を説明する。図15~図20は、分岐用スレーブ40-0の終点のportZとスレーブ「D」の出力ポート420であるportYとの間の経路が切断されている。したがって、接続状態検出部1822は分岐用スレーブ40-0のポートの識別子portZ(図15)とスレーブ「D」の出力ポート420の識別子portY(図15)を出力する。
 図15では、マスタ10は、通常の巡回フレーム55に続いて、コマンドフレーム56をリングトポロジのネットワーク4に送信する。ポート制御部1810は、接続状態検出部1822の出力に基づき、portYのオープンコマンド54のみを格納したコマンドフレーム56を生成し、生成されたコマンドフレーム6をリングトポロジのネットワーク4に送出する(図15のステップS51)。マスタ10は、当該コマンドフレーム56を送信した直後に、通常時の巡回フレーム55などのフレームを送信しない。
 通常時の巡回フレーム55とコマンドフレーム56とは、まず、分岐用スレーブ40-0に到達する。通常時の巡回フレーム55とコマンドフレーム56は分岐用スレーブ40-0を通過する(図16)。仮に、コマンドフレーム56に分岐用スレーブ40-0のportZのオープンコマンド54が格納されていると、当該オープンコマンド54が実行されてportZが開き、戻ってくるフレーム50の全てはportZを介してスレーブ「D」に転送される逆巡回フレームとなってしまう。このような逆巡回フレームの発生を回避するために、マスタ10は、この時点でportZのオープンコマンド54を送信しない。
 通常時の巡回フレーム55とコマンドフレーム56とは、分岐用スレーブ40-0を通過すると、スレーブ「A」、スレーブ「B」およびスレーブ「C」を通過しスレーブ「D」に到達する。コマンドフレーム56がスレーブ「D」に到着すると、スレーブ「D」のコマンド実行部450は、コマンドフレーム56の内容に基づき、コマンドフレーム56はスレーブ「D」宛のフレームであると判定し、判定結果に基づきコマンドフレーム56のオープンコマンド54を実行する(図17のステップS61)。これにより、スレーブ「D」のportYがオープンする。
 portYがオープンすると、通常時の巡回フレーム55とコマンドフレーム56は、「OUTからINへの入力」に従う一方向への流れに従い、スレーブ「D」の入力ポート410、スレーブ「C」、スレーブ「B」、スレーブ「A」および分岐用スレーブ40-0を介してマスタ10に到達する(図18)。
 マスタ10は、コマンドフレーム56を送信した直後にフレームを送信していないので、portYのオープン直後に逆巡回フレームは発生しない。
 送信許可部1824は、マスタ10がコマンドフレーム56を送信した時から所定時間経過したことを検出すると、送信許可の通知を出力する。フレーム処理部188は、送信許可部1824から送信許可の通知を受付けると、通常時の巡回フレーム55などのフレーム50を生成し、生成されたフレーム50をリングトポロジのネットワーク4に送出する(図10のステップS6,S7)。
 次の周期において、マスタ10は所定コマンドを格納したコマンドフレーム56をリングトポロジのネットワーク4に送信する。このコマンドフレーム56は「INからOUTへの入力」に従う方向に転送されて、オープンされたスレーブ「D」のportYを経て分岐用スレーブ40-0にportZに到達すると、分岐用スレーブ40-0は、当該コマンドフレーム56を受信し、受信したコマンドフレーム56の所定コマンドを実行する。実行結果に従い、portZはオープンして、このコマンドフレーム56はportZで消失する(図19)。この消失は、図19では“STOP”で示されている。この所定コマンドを用いたportZをオープンする処理は、EtherCATのASICの仕様に従っている。
 さらに送信許可部1824が上記の所定時間の経過を計時した後に、マスタ10は次の周期の通常の巡回フレーム55をリングトポロジのネットワーク4に送信する。当該巡回フレーム55は「INからOUTへの入力」に従う方向に転送されて、オープンされたスレーブ「D」のportYおよび分岐用スレーブ40-0のportZを経て、マスタ10に戻る(図20)。
 送信許可部1824が計時する当該所定時間は、リング配線の伝搬遅延時間に基づく時間に基づいている。具体的には、所定コマンドのコマンドフレーム56がマスタ10から送出されて戻ってくるまでの所要時間(伝搬遅延時間)に基づいている。
 <G.巡回フレームの検出と破棄>
 本実施の形態では、マスタ10は、逆巡回フレームが到達したことを検出すると、到達した逆巡回フレームを破棄する。この方法は、(ケース1)に適用することができる。
 図21~図23は、本実施の形態に係る“第1モード”のフレームの他の流れを模式的に示す図である。図24は、本実施の形態に係るマスタ10の機能構成の他の例を模式的に示す図である。図25は、本実施の形態に係るスレーブ40の機能構成の他の例を模式的に図である。図26は、本実施の形態に係る“第1モード”の処理のフローチャートの一例を示す図である。
 図25を参照して、スレーブ40のプロセッサ400は、図8の構成に追加してビット設定部460を備える。ビット設定部460は、スレーブ40に到達する巡回フレーム55のうち、フレーム処理部440をバイパスされる巡回フレーム55(すなわち、逆巡回フレーム)のRoundTripBit57を「ON」に設定し、ネットワーク4に送出する。なお、マスタ10はコマンドフレーム56をリントポロジのネットワーク4に送出するとき、RoundTripBit57に初期値の「OFF」を設定している。
 図24を参照して、マスタ10は図7の構成に追加して、フレーム破棄部189を備える。フレーム破棄部189は、通信処理部186が受信しフレーム処理部188に出力するフレームのうちから逆巡回フレームを検出(抽出)し、検出された巡回フレームを破棄する。具体的には、フレーム破棄部189は、マスタ10に到達した巡回フレーム55のうちから、RoundTripBit57が「ON」である巡回フレーム55を検出(抽出)し、検出された巡回フレーム55を破棄する。これにより、例えば、現在の周期ではない、過去の周期の巡回フレーム55に相当する逆巡回フレームが、通信処理部186からフレーム処理部188へ出力されることが防止されて、ユーザプログラムの処理対象のフレームから逆巡回フレームを排除することができる。
 図21~図23の太線矢印は、フレーム50の流れる方向を示している。図21~図23を参照して、ステップS4(図10)の処理の他の例を説明する。図21~図23では、ケーブル切断箇所261が示すように、分岐用スレーブ40-0とスレーブ「A」との間の経路が切断されている。したがって、接続状態検出部1822の出力は、分岐用スレーブ40-0の出力ポート420の識別子portY(図21)とスレーブ「A」の入力ポート410の識別子portX(図21)とを示す。
 マスタ10は、通常の巡回フレーム55に続いて、2つのコマンドフレーム56をリングトポロジのネットワーク4に順に送出し、当該送出の直後にメッセージのフレーム55を送信する。この2つのコマンドフレーム56のううち、1番目に送出されるコマンドフレーム56はportYのオープンコマンド54を格納し、2番目に送出されるコマンドフレーム56はportXのオープンコマンド54を格納している。
 ポート制御部1810は、接続状態検出部1822の出力に基づき、1番目のコマンドフレーム56と2番目のコマンドフレーム56とを生成し、生成された2つのコマンドフレーム56をリングトポロジのネットワーク4に順に送出する(図21のステップS45)。
 分岐用スレーブ40-0は、1番目の巡回フレーム55とportYのオープンコマンド54を格納したコマンドフレーム56との2つのフレーム(これを、‘先の2つのフレーム’と呼ぶ)を受信すると、受信したコマンドフレーム56に格納されたportYのオープンコマンド54を実行する。この実行結果に従い、portYはオープンする。
 そして、先の2つのフレームは、「OUTからINへの入力」に従い分岐用スレーブ40-0からスレーブ「D」、スレーブ「C」およびスレーブ「B」の方向に転送されてスレーブ「A」に到達する。また、分岐用スレーブ40-0は、portXのオープンコマンド54のコマンドフレーム56およびメッセージのフレーム55の2つのフレーム(これを、‘後の2つのフレーム’と呼ぶ)を受信して、受信した後の2つのフレームを、オープンしたportYを介して、スレーブ「A」に転送する。スレーブ「A」のportXはオープンしていないために、後の2つのフレームはスレーブ「A」のportXで消失する。このとき、スレーブ「A」のportXはオープンする。この動作は、EtherCATのASICの仕様に従っている。これにより、分岐用スレーブ40-0とスレーブ「A」との間の経路は切断から復旧する。
 スレーブ「A」では、先の2つのフレームのうち巡回フレーム55が受信されると、ループバック部470は、portXがオープンしていないために当該巡回フレーム55をループバックする。このループバックにより、巡回フレーム55は、「OUTからINへの入力」に従う方向に逆巡回する。ループバック部470によってループバックが実施されるとき、ビット設定部460は、ループバックされた巡回フレーム55のRoundTripBit57にONに設定する、すなわちOFFからONに変更する(図22のステップS46)、すなわちRoundTripBit57をOFFからONに変更するとともに、ヘッダ51にRoundTripBit57にONを設定した時間を示す時間571を格納する。なお、portYのオープンコマンド54のコマンドフレーム56は逆巡回フレームとなる。
 以降、マスタ10がリングトポロジのネットワーク4に送出する巡回フレーム55も、「OUTからINへの入力」に従い分岐用スレーブ40-0からスレーブ「D」、スレーブ「C」およびスレーブ「B」の方向に転送されてスレーブ「A」に到達する。スレーブ「A」において、この巡回フレーム55のRoundTripBit57もONに設定されて、巡回フレーム55はループバックされる。その後、スレーブ「A」でループバックされた全ての巡回フレーム55は、マスタ10に到達する。
 また、上記のEtherCATのASICの仕様によりportXがオープンした後に、先の2つのフレーム(すなわち、「OUTからINへの入力」に従い分岐用スレーブ40-0からスレーブ「D」、スレーブ「C」およびスレーブ「B」の方向に転送され先の2つのフレーム)がスレーブ「A」に到達するケースを説明する。このケースでは、当該先の2つのフレームは、オープンしているportXを介して、「OUTからINへの入力」に従い、スレーブ「A」から分岐用スレーブ40-0、スレーブ「D」、スレーブ「C」、スレーブ「B」およびスレーブ「A」と逆巡回する。その後、再度、分岐用スレーブ40-0とスレーブ「A」との間の経路が切断されたとき、逆巡回していた先の2つのフレームは、スレーブ「A」でループバックされマスタ10に到達する。このループバック時に、先の2つのフレームは、スレーブ「A」でRoundTripBit57がONに設定される。
 マスタ10では、リングトポロジのネットワーク4から巡回フレーム55が受信されると、フレーム破棄部189は、受信された巡回フレーム55のうちRoundTripBit57がONを示す逆巡回フレームを検出して、検出された逆巡回フレーム55を破棄する(図23のステップS47)。
 (G1.巡回フレームの検出と破棄)
 図26を参照して、マスタ10のフレーム破棄部189の処理を説明する。なお、図26以降の図では、インデックス53を“Index”とも表記する。インデックス53の値は、所定周期毎に異なる所定範囲内の値を示す。まず、フレーム破棄部189は、マスタ10が受信した巡回フレーム55のインデックス53の値と、現在周期のインデックス値の範囲とを比較し、比較の結果に基づき、インデックス53が現在周期のインデックス値の範囲内の値に該当するか否か(すなわち、有効であるか否か)を判断する(ステップS51)。インデックス53の値が現在周期の範囲内に該当しないと判定される場合(ステップS51でNO)、フレーム破棄部189は当該巡回フレーム55を破棄する(ステップS59)。
 インデックス53の値が現在周期の範囲内に該当する(すなわち、有効である)と判定された場合(ステップS51でYES)、フレーム破棄部189は巡回フレーム55のRoundTripBit57がONを示すか否かを判定する(ステップS53)。RoundTripBit57がONを示すと判定した場合(ステップS53でYES)、フレーム破棄部189は受付けた巡回フレーム55を破棄する(ステップS59)。一方、RoundTripBit57がONを示さない(すなわち、OFFを示す)と判定された場合(ステップS53でNO)、フレーム破棄部189は、巡回フレーム55の時間571に基づき、RoundTripBit57がONに設定されてから伝搬遅延時間に基づく所定時間が経過したか否かを判定する(ステップS55)。
 フレーム破棄部189は、RoundTripBit57がONに設定されてから未だ所定時間が経過していないと判定すると(ステップS55でNO)、巡回フレーム55を破棄する(ステップS59)。一方、RoundTripBit57がONに設定されてから所定時間が経過したと判定されると(ステップS55でYES)、巡回フレーム55はフレーム破棄部189によって破棄されずに、フレーム処理部188は当該巡回フレーム55の受信処理を実行する(ステップS57)。
 図26の処理によれば、マスタ10は、マスタ10に到達する巡回フレーム55を、インデックス53、RoundTripBit57および時間571を用いて、段階的にフィルタリングする。これにより、マスタ10では、リングトポロジのネットワーク4からマスタ10に到達する巡回フレーム55のうち、逆巡回フレームに該当する可能性がある巡回フレーム55を検出することの確実性が向上する。
 (G2.巡回フレームの検出と破棄の他の例)
 マスタ10が、到達する逆巡回フレームを検出するためのインデックス53の値(番号)の採番方法を説明する。この方法は、(ケース1)と(ケース2)の両方に適用することができる。図27は、本実施の形態に係るマスタ10の機能構成の他の例を模式的に示す図である。図27を参照して、マスタ10は、図7の構成に追加して、世代設定部190およびフレーム破棄部191を備える。図28は、本実施の形態に係る世代設定部190の処理を説明するための図である。図29~図31は、本実施の形態に係るフレームの他の流れを模式的に示す図である。図32は、フレーム破棄部191の処理のフローチャートの一例を示す図である。
 本実施の形態では、マスタ10が、所定周期、例えば制御周期に基づくに所定周期毎にフレーム50をリングトポロジのネットワーク4に送出するとき、送出されるフレーム50の世代を所定周期毎に管理するためのインデックス53を設定する。具体的には、世代設定部190は、通信処理部186が巡回抑制部180またはフレーム処理部188から受付けるフレーム50(コマンドフレーム56または通常の巡回フレーム55)のヘッダ51に世代管理のためのインデックス53を設定する。通信処理部186は、インデックス53が設定されたフレーム50をリングトポロジのネットワーク4に送出する。
 図28を参照して、世代設定部190は、タイマ115の出力に同期しながら値をインデックス番号の有効範囲291内でインクリメントし、インクリメントした値をインデックス53に設定する。有効範囲291は、複数の特定の有効範囲293に分割され得る。世代設定部190は、所定周期毎に特定の有効範囲293内でインデックス53の値をインクリメントする。これにより、フレーム50は、所定周期毎に異なる有効範囲293の値を示すインデックス53、すなわち世代が割当てられてリングトポロジのネットワーク4に送出される。
 世代設定部190は、例えば、所定周期毎に値を0~1022の範囲でインクリメントするとともに、ポート制御部1810からコマンドフレーム56が出力されたとき、世代設定部190は、巡回フレームを検出するために、次の所定周期から有効範囲293を変更する、すなわち巡回フレーム55に割当てる世代を変更する(図28のステップS292)。例えば、有効範囲293が「0~1022」でインクリメントされたインデックス53がフレーム50に割当てられる場合に、コマンドフレーム56が出力されたとき、世代設定部190は、次の所定周期から、有効範囲293を現在の「0~1022」から「1023~2046」に変更する。したがって、コマンドフレーム56が送出される毎に、次の所定周期で送出されるフレームは次の世代のフレームに切替えられる。
 図29~図31のフレームの流れを参照して、逆巡回フレームの検出を説明する。マスタ10が、ある所定周期において有効範囲293が「A」(例えば、0~1022)である通常の巡回フレーム55を送信中に、分岐用スレーブ40-0のportYとスレーブ「A」のportXの間で経路が切断されると、通常の巡回フレーム55は切断箇所でループバックされる。マスタ10は、図30の経路切断301を検出すると、ポート制御部1810がportYのオープンコマンド54のコマンドフレーム56と、portXのオープンコマンド54のコマンドフレーム56を順番に送信し、続いてメッセージの巡回フレーム55を送信する(図29)。この場合、portYのオープンコマンド54のコマンドフレーム56が分岐用スレーブ40-0に到達するとportYはオープンするが、portXは未だオープンしていない。そのため、以降に続くportXのオープンコマンド54のコマンドフレーム56とメッセージの巡回フレーム55は分岐用スレーブ40-0,スレーブ「D」、スレーブ「C」、スレーブ「B」およびスレーブ「A」の方向に転送される。portXのオープンコマンド54のコマンドフレーム56がスレーブ「A」に到達すると、スレーブ「A」においてportXのオープンコマンド54が実行されてportXがオープンする。これにより、ループバックされていた有効範囲「A」のコマンドフレーム56は、リングトポロジ内で逆巡回を開始する(図29)。
 マスタ10では、世代設定部190は、ポート制御部1810からコマンドフレーム56が出力されたことに応じて、次の所定周期からリングトポロジのネットワーク4に送出されるフレーム50のインデックス53の有効範囲293を「A」から「B」に変更する(図30)。その後は、マスタ10は、有効範囲293が「B」を示すインデックス53のフレーム50をリングトポロジのネットワーク4に送出する。
 図31のケーブル切断箇所321が示すように、再度、経路が切断されると、逆巡回していた有効範囲293の「A」を示すインデックス53を有したフレーム50は、切断箇所でループバックされて、マスタ10に到達する(図31)。このとき、フレーム破棄部191は、図32のフレーム破棄の処理を実施する。
 図32を参照して、フレーム破棄部191は、通信処理部186を介してリングトポロジのネットワーク4から入来するフレーム50のインデックス53の値と、世代設定部190が示す現在の有効範囲293の値とを比較し、比較の結果に基づき、当該フレーム50のインデックス53の値が有効であるか否かを判定する(ステップS21)。
 図31の場合、マスタ10に入来するフレーム50のインデックス53は有効範囲293の「A」の値を示すのに対して、世代設定部190が示す現在の有効範囲293は「B」の値である。したがって、フレーム破棄部191は、フレーム50のインデックス53の値は現在の有効範囲293に該当しないことに基づき、インデックス53は有効でないと判定し(ステップS21でNO)、当該フレーム50をフレーム処理部188に出力されないように破棄する(ステップS25)。
 一方、フレーム破棄部191は、マスタ10に入来したフレーム50のインデックス53の値は現在の有効範囲293に該当することに基づき、インデックス53は有効であると判定すると(ステップS21でYES)、フレーム破棄部191は当該フレーム50を破棄しない。したがって、フレーム処理部188は、マスタ10に入来したフレーム50の受信処理を実行する(ステップS23)。
 世代設定部190およびフレーム破棄部191によれば、マスタ10にリングトポロジのネットワーク4から入来するフレーム50のうち、当該フレーム50のインデックス53が現在の有効範囲293に該当しないフレーム、すなわち逆巡回フレームのみを検出(抽出)して、検出された逆巡回フレームを破棄することができる。
 なお、世代設定部190により設定された世代(インデックス53)を用いた巡回フレームの検出は、ビット設定部460によって設定されるRoundTripBit57を用いた巡回フレームの検出と組合わせて実行されてもよい。
 <H.巡回フレーム発生の通知>
 本実施の形態では、通知部1871は、ループバック転送から巡回転送への変化により逆巡回フレームが発生した可能性がある旨の通知を出力する。例えば、マスタ10が、リングトポロジにおけるフレームロストを検出したとき、通知部1871は、上記の通知を出力する。
 具体的には、通信処理部186は、リングトポロジのネットワーク4から受信するフレーム50のインデックス53に基づきフレームロストを検出する。通信処理部186は、リングトポロジのネットワーク4に送出したフレーム50のインデックス53と、リングトポロジのネットワーク4から入来するフレーム50のインデックス53との値どうしを照合する。通信処理部186は、照合の結果に基づき、各所定周期において入来したフレーム50のインデックス53の値と当該所定周期において送出したフレーム50のインデックス53の値とが一致したとき、送出したフレーム50は全てマスタ10に戻ったことを判定する。これに対して、当該所定周期において入来したフレーム50のインデックス53の値が当該所定周期において送出したフレーム50のインデックス値と不一致であったときは、送出したフレーム50は全てがマスタ10に戻っていないことを判定する。すなわち、フレームロストの発生を検出する。フレームロストの原因の1つは、逆巡回フレームの発生である。したがって、通知部1871は、フレームロストの発生が検出されたとき、逆巡回フレーム発生の可能性を示す通知を生成し、生成された通知を通信処理部187を介してサポート装置200に出力する。
 図33は、本実施の形態に係るサポート装置200で表示される画面の一例を示す図である。図33の画面は、通知部1871からの通知に基づいている。サポート装置200は、通知部1871から通知を受信すると、システム定義変数を用いて逆巡回フレームの発生の可能性を示す通知をディスプレイ209などに出力する。図33では、ネットワーク構成情報1851に基づくリングトポロジを含むネットワーク構成を示す画像に関連付けて、通知に基づいた「巡回フレームが発生した可能性がある」旨のメッセージ1091が表示される。
 また、図33の画面では、リングトポロジのネットワーク構成の画像において、接続状態検出部1822の出力に基づき、経路が切断され箇所を指示するマークを表示してもよい。
 なお、逆巡回フレームの発生の検出方法は、フレームロストの発生を検出したこと基づく方法に限定されず、フレーム破棄部189または191によりフレーム破棄が実施されたことに基づく方法であってもよい。
 <I.付記>
 上述したような本実施の形態は、以下のような技術思想を含む。
[構成1]
 リング配線(4)に接続される複数のスレーブ装置(40)を管理するマスタ装置(10)であって、
 前記複数のスレーブ装置は、前記リング配線の起点および終点となる第1スレーブ装置(40-0)と、前記第1スレーブ装置の起点と終点との間に接続される複数の第2スレーブ装置(40-1、40-2、40-3、40-4)とを含み、
 前記リング配線は、
 各前記第2スレーブ装置が、起点側から入来するデータ(50)を受付け、受付けたデータを終点側へ巡回転送させるための第1経路(15)と、
 各前記複数のスレーブ装置が、隣接するスレーブ装置との間の経路が切断される場合に、自装置から前記データをループバックするための第2経路(16)とを構成可能であり、
 前記マスタ装置は、
 経路が前記切断から復旧する場合に、前記第2経路を前記第1経路に切替えるための指令(56)を前記ループバックを実施するスレーブ装置に送信する指令手段(1810)を備え、
 前記指令の送信時から前記リング配線の伝搬遅延時間に基づく時間が経過後に、前記リング配線にデータを送出する(1824)、マスタ装置。
[構成2]
 前記各スレーブ装置は、隣接するスレーブ装置に繋がる経路が接続される第1ポート(410)および第2ポート(420)を有し、
 各第2スレーブ装置は、前記第1経路が構成される場合、起点側から入来するデータを前記第1ポートで受付け、受付けたデータを前記第2ポートから終点側へ転送し、
 前記指令は、検出された前記第1ポートからのデータ受付を可能にするオープン指令(54、59)および前記第2ポートからのデータ受付を可能にするオープン指令(54,59)を含み、
 前記指令手段は、
 切断された経路のリング配線上の位置に応じて、前記第1ポートのオープン指令および前記第2ポートのオープン指令の送信順序を異ならせる、構成1に記載のマスタ装置。
[構成3]
 前記マスタ装置は、さらに、
 前記複数のスレーブ装置との通信に基づき、切断された経路が接続されるスレーブ装置の第1ポートおよび第2ポートを検出する手段(1822)を備える、構成2に記載のマスタ装置。
[構成4]
 前記データは、当該データが前記ループバックから前記巡回転送に変化したか否かを示す符号(57)を含み、
 前記マスタ装置は、前記リング配線からの入来データのうち、前記符号が前記変化を示すデータを検出し、検出されたデータを破棄する(189)、構成2または3に記載のマスタ装置。
[構成5]
 前記マスタ装置は、世代(293)をデータに割当てながら当該データをリング配線に送出し、
 前記マスタ装置は、前記指令を送信したとき、その後にデータに割当てる世代を、当該指令送信前に割当てられていた世代から変更し、
 前記マスタ装置は、前記リング配線から入来するデータのうち、現在、データに割当てられる世代とは異なる世代が割当てられたデータを検出し、検出されたデータを破棄する(191)、構成2から4のいずれか1に記載のマスタ装置。
[構成6]
 前記マスタ装置は、データがループバック転送から巡回転送への変化が発生した旨の通知を出力する(1871)、構成2から5のいずれか1に記載のマスタ装置。
[構成7]
 前記リング配線は、EtherCATネットワークを含む、構成1から6のいずれか1に記載のマスタ装置。
[構成8]
 構成1から7のいずれか1に記載のマスタ装置を備える演算処理装置。
[構成9]
 構成8に記載の演算処理装置を備えた、プログラマブルロジックコントローラ。
[構成10]
 リング配線(4)を含むネットワークであって、
 前記リング配線に接続される複数のスレーブ装置(40)と、
 前記複数のスレーブ装置を管理するマスタ装置(10)と、を備え、
 前記複数のスレーブ装置は、前記リング配線の起点および終点となる第1スレーブ装置(40-0)と、前記第1スレーブ装置の起点と終点との間に接続される複数の第2スレーブ装置(40-1,40-2、40-3、40-4)とを含み、
 前記リング配線は、
 各前記第2スレーブ装置が、起点側から入来するデータを受付け、受付けたデータを終点側へ巡回転送させるための第1経路(15)と、
 各前記複数のスレーブ装置が、隣接するスレーブ装置との間の経路が切断される場合に、自装置から前記データをループバックするための第2経路(16)とを構成可能であり、
 前記マスタ装置は、
 経路が前記切断から復旧する場合に、前記第2経路を前記第1経路に切替えるための指令(56)を、前記ループバックを実施するスレーブ装置に送信する指令手段(1810)を備え、
 前記指令の送信時から前記リング配線の伝搬遅延時間に基づく時間が経過後に、前記リング配線にデータを送出する(1824)、ネットワーク。
[構成11]
 リング配線(4)に接続される複数のスレーブ装置(40)を管理するマスタ装置(10)が実施する方法であって、
 前記複数のスレーブ装置は、前記リング配線の起点および終点となる第1スレーブ装置(40-0)と、前記第1スレーブ装置の起点と終点との間に接続される複数の第2スレーブ装置(40-1,40-2、40-3、40-4)とを含み、
 前記リング配線は、
 各前記第2スレーブ装置が、起点側から入来するデータを受付け、受付けたデータを前記終点側へ巡回転送させるための第1経路(15)と、
 各前記複数のスレーブ装置が、隣接するスレーブ装置との間の経路が切断される場合に、自装置から前記データをループバックするための第2経路(16)とを構成可能であり、
 前記方法は、
 経路が前記切断から復旧する場合に、前記第2経路を前記第1経路に切替えるための指令(56)を前記ループバックを実施するスレーブ装置に送信するステップ(S5、S4)と、
 前記指令の送信時から前記リング配線の伝搬遅延時間に基づく時間が経過後に、前記リング配線にデータを送出するステップ(S6、S7)とを備える、方法。
 今回開示された実施の形態は全ての点で例示であって制限的なものではないと考えられるべきである。本発明の範囲は上記した説明ではなくて請求の範囲によって示され、請求の範囲と均等の意味および範囲内での全ての変更が含まれることが意図される。
1 システム、2 メイン処理装置、4 ネットワーク、10 マスタ、15 第1経路、16 第2経路、40 スレーブ、40-0 分岐用スレーブ、50 フレーム、55 巡回フレーム、51 ヘッダ、52 データグラム、53 インデックス、54 オープンコマンド、56 コマンドフレーム、58 タイプ、59 ポート識別子、180 巡回抑制部、186,187 通信処理部、188,440 フレーム処理部、189,191 フレーム破棄部、190 世代設定部、200 サポート装置、209 ディスプレイ、261 ケーブル切断箇所、291,293 有効範囲、430 フレーム判別部、450 コマンド実行部、460 ビット設定部、470 ループバック部、571 時間、1091 メッセージ、1810 ポート制御部、1820 検出部、1821 復旧検出部、1822 接続状態検出部、1823 モード判定部、1824 送信許可部、1851 ネットワーク構成情報、1871 通知部。

Claims (11)

  1.  リング配線に接続される複数のスレーブ装置を管理するマスタ装置であって、
     前記複数のスレーブ装置は、前記リング配線の起点および終点となる第1スレーブ装置と、前記第1スレーブ装置の起点と終点との間に接続される複数の第2スレーブ装置とを含み、
     前記リング配線は、
     各前記第2スレーブ装置が、起点側から入来するデータを受付け、受付けたデータを終点側へ巡回転送させるための第1経路と、
     各前記複数のスレーブ装置が、隣接するスレーブ装置との間の経路が切断される場合に、自装置から前記データをループバックするための第2経路とを構成可能であり、
     前記マスタ装置は、
     経路が前記切断から復旧する場合に、前記第2経路を前記第1経路に切替えるための指令を、前記ループバックを実施するスレーブ装置に送信する指令手段を備え、
     前記指令の送信時から前記リング配線の伝搬遅延時間に基づく時間が経過後に、前記リング配線にデータを送出する、マスタ装置。
  2.  前記各スレーブ装置は、隣接するスレーブ装置に繋がる経路が接続される第1ポートおよび第2ポートを有し、
     各第2スレーブ装置は、前記第1経路が構成される場合、起点側から入来するデータを前記第1ポートで受付け、受付けたデータを前記第2ポートから終点側へ転送し、
     前記指令は、検出された前記第1ポートからのデータ受付を可能にするオープン指令および前記第2ポートからのデータ受付を可能にするオープン指令を含み、
     前記指令手段は、
     切断された経路のリング配線上の位置に応じて、前記第1ポートのオープン指令および前記第2ポートのオープン指令の送信順序を異ならせる、請求項1に記載のマスタ装置。
  3.  前記マスタ装置は、さらに、
     当該マスタ装置と前記複数のスレーブ装置との間の通信に基づき、切断された経路が接続されるスレーブ装置の第1ポートおよび第2ポートを検出する手段を備える、請求項2に記載のマスタ装置。
  4.  前記データは、当該データが前記ループバックから前記巡回転送に変化したか否かを示す符号を含み、
     前記マスタ装置は、前記リング配線からの入来データのうち、前記符号が前記変化を示すデータを検出し、検出されたデータを破棄する、請求項2または3に記載のマスタ装置。
  5.  前記マスタ装置は、データに世代を割当てながら当該データをリング配線に送出し、
     前記マスタ装置は、前記指令を送信したとき、その後にデータに割当てる世代を、当該指令送信前に割当てられていた世代から変更し、
     前記マスタ装置は、前記リング配線から入来するデータのうち、現在、データに割当てられる世代とは異なる世代が割当てられたデータを検出し、検出されたデータを破棄する、請求項2から4のいずれか1項に記載のマスタ装置。
  6.  前記マスタ装置は、データがループバック転送から巡回転送への変化が発生した旨の通知を出力する、請求項2から5のいずれか1項に記載のマスタ装置。
  7.  前記リング配線は、EtherCATネットワークを含む、請求項1から6のいずれか1項に記載のマスタ装置。
  8.  請求項1から7のいずれか1項に記載のマスタ装置を備える演算処理装置。
  9.  請求項8に記載の演算処理装置を備えた、プログラマブルロジックコントローラ。
  10.  リング配線を含むネットワークであって、
     前記リング配線に接続される複数のスレーブ装置と、
     前記複数のスレーブ装置を管理するマスタ装置と、を備え、
     前記複数のスレーブ装置は、前記リング配線の起点および終点となる第1スレーブ装置と、前記第1スレーブ装置の起点と終点との間に接続される複数の第2スレーブ装置とを含み、
     前記リング配線は、
     各前記第2スレーブ装置が、起点側から入来するデータを受付け、受付けたデータを終点側へ巡回転送させるための第1経路と、
     各前記複数のスレーブ装置が、隣接するスレーブ装置との間の経路が切断される場合に、自装置から前記データをループバックするための第2経路とを構成可能であり、
     前記マスタ装置は、
     経路が前記切断から復旧する場合に、前記第2経路を前記第1経路に切替えるための指令を前記ループバックを実施するスレーブ装置に送信する指令手段を備え、
     前記指令の送信時から前記リング配線の伝搬遅延時間に基づく時間が経過後に、前記リング配線にデータを送出する、ネットワーク。
  11.  リング配線に接続される複数のスレーブ装置を管理するマスタ装置が実施する方法であって、
     前記複数のスレーブ装置は、前記リング配線の起点および終点となる第1スレーブ装置と、前記第1スレーブ装置の起点と終点との間に接続される複数の第2スレーブ装置とを含み、
     前記リング配線は、
     各前記第2スレーブ装置が、起点側から入来するデータを受付け、受付けたデータを前記終点側へ巡回転送させるための第1経路と、
     各前記複数のスレーブ装置が、隣接するスレーブ装置との間の経路が切断される場合に、自装置から前記データをループバックするための第2経路とを構成可能であり、
     前記方法は、
     経路が前記切断から復旧する場合に、前記第2経路を前記第1経路に切替えるための指令を、前記ループバックを実施するスレーブ装置に送信するステップと、
     前記指令の送信時から前記リング配線の伝搬遅延時間に基づく時間が経過後に、前記リング配線にデータを送出するステップと、を備える、方法。
PCT/JP2020/009127 2019-09-05 2020-03-04 マスタ装置、演算処理装置、プログラマブルロジックコントローラ、ネットワーク、および方法 WO2021044652A1 (ja)

Priority Applications (3)

Application Number Priority Date Filing Date Title
CN202080056369.8A CN114245978B (zh) 2019-09-05 2020-03-04 主机装置、运算处理装置、控制器、网络系统以及方法
EP20861702.7A EP4027591A4 (en) 2019-09-05 2020-03-04 MASTER DEVICE, ARITHMETIC PROCESSING DEVICE, PROGRAMMABLE LOGIC CONTROLLER, NETWORK, AND METHOD
US17/635,381 US20220400031A1 (en) 2019-09-05 2020-03-04 Master device, arithmetic processing device, programmable logic controller, network, and method

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP2019162181A JP7327017B2 (ja) 2019-09-05 2019-09-05 マスタ装置、演算処理装置、プログラマブルロジックコントローラ、ネットワーク、および方法
JP2019-162181 2019-09-05

Publications (1)

Publication Number Publication Date
WO2021044652A1 true WO2021044652A1 (ja) 2021-03-11

Family

ID=74847456

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/JP2020/009127 WO2021044652A1 (ja) 2019-09-05 2020-03-04 マスタ装置、演算処理装置、プログラマブルロジックコントローラ、ネットワーク、および方法

Country Status (5)

Country Link
US (1) US20220400031A1 (ja)
EP (1) EP4027591A4 (ja)
JP (1) JP7327017B2 (ja)
CN (1) CN114245978B (ja)
WO (1) WO2021044652A1 (ja)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2023276350A1 (ja) * 2021-06-30 2023-01-05 オムロン株式会社 通信装置、通信制御方法、および通信制御プログラム

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2010062861A (ja) * 2008-09-03 2010-03-18 Fuji Electric Systems Co Ltd リング型ネットワークシステム及びリング型ネットワークシステムの復旧方法
JP2016119616A (ja) 2014-12-22 2016-06-30 富士電機株式会社 リング型ネットワークシステム、そのマスタノード

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2000196640A (ja) * 1998-12-25 2000-07-14 Toshiba Corp ル―プ型デ―タ伝送システム
US8072999B1 (en) * 2007-05-08 2011-12-06 Motion Engineering Inc. Method and system for removing and returning nodes in a synchronous network
JP5527086B2 (ja) * 2010-07-29 2014-06-18 富士電機株式会社 ネットワークシステム
CN102594582B (zh) * 2011-01-14 2017-12-15 中兴通讯股份有限公司 一种报文环回方法及系统
CN103918238B (zh) * 2011-11-04 2018-07-31 恩智浦美国有限公司 实时分布式网络模块、实时分布式网络及其方法
US9621483B2 (en) * 2012-07-02 2017-04-11 Nxp Usa, Inc. Ethercat packet forwarding with distributed clocking
WO2014083381A1 (en) * 2012-11-27 2014-06-05 Freescale Semiconductor, Inc. Redundant packet forwarding system

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2010062861A (ja) * 2008-09-03 2010-03-18 Fuji Electric Systems Co Ltd リング型ネットワークシステム及びリング型ネットワークシステムの復旧方法
JP2016119616A (ja) 2014-12-22 2016-06-30 富士電機株式会社 リング型ネットワークシステム、そのマスタノード

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2023276350A1 (ja) * 2021-06-30 2023-01-05 オムロン株式会社 通信装置、通信制御方法、および通信制御プログラム

Also Published As

Publication number Publication date
EP4027591A1 (en) 2022-07-13
US20220400031A1 (en) 2022-12-15
JP7327017B2 (ja) 2023-08-16
CN114245978A (zh) 2022-03-25
EP4027591A4 (en) 2023-08-09
JP2021040288A (ja) 2021-03-11
CN114245978B (zh) 2023-08-01

Similar Documents

Publication Publication Date Title
US7907516B2 (en) Node setting apparatus, network system, node setting method, and computer product
JP4437984B2 (ja) ネットワーク中継装置及びその制御方法
US8244838B2 (en) Industrial controller employing the network ring topology
US7391719B2 (en) Redundant network interface for ethernet devices
US9166922B2 (en) Communication device for an industrial communication network which can be operated in a redundant manner and method for operating a communication device
TW201517579A (zh) 冗餘環路節點、網路節點及實現支援環路保護協定之冗餘節點之方法
CN104067256A (zh) 用于支持相同的物理连接上的两种不同的协议的系统和方法
JP4074631B2 (ja) 伝送路システム、および同システムにおけるフレーム伝送装置、ならびに伝送路切り替え方法
GB2383508A (en) Cascade control system using loopback for network units
JP4895972B2 (ja) リングプロトコル高速切替方法およびその装置
JP6933183B2 (ja) セーフティ制御システムおよびセーフティ制御ユニット
WO2021044652A1 (ja) マスタ装置、演算処理装置、プログラマブルロジックコントローラ、ネットワーク、および方法
JP2007174119A (ja) レイヤ2ネットワーク
US8824333B2 (en) Method and apparatus for full duplex serial shifting mode and switch mode data transmission
JP6554405B2 (ja) リングネットワークシステム、及び、ネットワークノード
JP2011223172A (ja) リング型ネットワークシステム、通信装置および障害検出方法
JP4944986B2 (ja) 伝送路システムおよび伝送路構築方法
JP4585560B2 (ja) ネットワーク障害検知方法、データ通信ネットワークシステムおよびノード装置
JP2011188414A (ja) リング型スイッチ、リング型イーサネットシステム、リング型スイッチ制御方法、およびリング型イーサネットシステム制御方法
US11757799B2 (en) Line monitor device and network switch
JP4653800B2 (ja) 伝送路システム、フレーム伝送装置、伝送路システムにおける伝送路切り替え方法およびプログラム
JP2011101113A (ja) Mac回路
JP5085479B2 (ja) ネットワークシステム
KR20230084123A (ko) 원자력 발전소 및 기타 산업 시설의 자동 모니터링 및 제어 시스템을 위한 이중 버스
JP6559390B2 (ja) 転送装置、転送方法および転送プログラム

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 20861702

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

ENP Entry into the national phase

Ref document number: 2020861702

Country of ref document: EP

Effective date: 20220405