System and methods of installing and operating devices without explicit network addresses

Information

  • Patent Grant
  • 9641484
  • Patent Number
    9,641,484
  • Date Filed
    Monday, April 18, 2016
    8 years ago
  • Date Issued
    Tuesday, May 2, 2017
    7 years ago
Abstract
A method of discovering addressing information of one or more upstream devices to respond to specific messages by a second device on behalf of the one or more upstream devices in a network includes acquiring the addressing information in an upstream direction from one or more downstream devices to the one or more upstream devices. The method further includes acquiring the addressing information in a downstream direction from the one or more upstream devices to the one or more downstream devices. The method further includes responding to specific messages using the acquired addressing information about the one or more upstream devices.
Description

This application incorporates by reference in their entireties the following applications, all of which have the same filing date as the present application: U.S. application Ser. No. 13/551,804, “Programmable Small Form-Factor Pluggable Module,” by Robitaille and Ostiguy; U.S. application Ser. No. 13/551,998 “Systems and Methods of Detecting and Assigning IP Addresses to Devices with ARP Requests,” by Robitaille and Lemieux; U.S. application Ser. No. 13/552,022, “Systems and Methods of Using Beacon Messages to Discover Devices Across Subnets,” by Robitaille and Bouffard and U.S. application Ser. No. 13/552,063, “Systems and Methods of Discovering and Controlling Devices without Explicit Addressing,” by Robitaille and Bouffard.


TECHNICAL FIELD

This invention is directed towards addressing the need for installing and operating, without prior configuration or knowledge and without network addresses, devices in a network for handling service requests on behalf of other upstream or downstream devices.


BACKGROUND

Some devices in a network may not be able to perform Service Operations Administration and Maintenance (SOAM) and other functions on their own. Network operators are looking to deploy SOAM devices at different points inside their network infrastructure.


BRIEF SUMMARY

There is a need to install devices that can perform such SOAM and other functions on behalf of other upstream or downstream devices. These SOAM capable devices may or may not be permanently installed inside a network. By allowing their installation and operation without the need for an explicit network address, it is possible to reduce or eliminate the need for an explicit configuration resulting in easier and more efficient deployment and use of these devices. Since such devices are not assigned a network address, there is a need to be able to discover the devices in a network where it may not actively participate in the normal network protocols that are in use. With some networks, the IDs or labels used by the protocols are not necessarily the same in both directions. If the devices are not participating in the underlying protocols (ex. MPLS, L2TPv3, GTP-U, etc.), the devices may not readily know what ID or label to use to communicate.


The devices must also be able to be discovered without (but not excluding) being pre-programmed with information specific to the network or the control infrastructure.


One aspect of the present invention relates to a method of discovering addressing information of one or more upstream devices to respond to specific messages by a second device on behalf of the one or more upstream devices in a network. The method includes acquiring the addressing information in an upstream direction from one or more downstream devices to the one or more upstream devices. The method further includes acquiring the addressing information in a downstream direction from the one or more upstream devices to the one or more downstream devices. The method further includes responding to specific messages using the acquired addressing information about the one or more upstream devices.


Additional aspect of the present invention relates to a method of discovering addressing information of one or more upstream devices to respond to specific messages by a second device on behalf of the one or more upstream devices in a network. The method includes pre-programming the second device with test packets that include addressing information in an upstream direction for the one or more upstream devices in each test packet. The method additionally includes using upstream test packets for triggering one of the one or more upstream devices to respond with a packet including the addressing information in a downstream direction to one of one or more downstream devices from one of the one or more upstream devices. The method further includes responding to specific messages including requests for functions that the one or more upstream devices are unable to perform using the acquired addressing information about one of the one or more upstream devices.


An additional aspect of the present invention relates to a system of discovering addressing information of one or more upstream devices to respond to specific messages by a second device on behalf of the one or more upstream devices in a network. The system includes at least one downstream device coupled to a first processor; at least one upstream device coupled to a second processor; and a second device coupled to a third processor, the second device located between the at least one downstream device and the at least one upstream device. The second device is configured to acquire addressing information in an upstream direction from the at least one downstream device and in a downstream direction from the at least one upstream device in order for the second device to respond on behalf of the at least one upstream device to the specific messages including requests for functions that the one or more upstream devices are unable to perform.





BRIEF DESCRIPTION OF THE DRAWINGS

The foregoing and other advantages of the present disclosure will become apparent upon reading the following detailed description and upon reference to the drawings.



FIG. 1 illustrates a Multiprotocol Label Switching Network (MPLS) network with an upstream device unable to perform SOAM functions, a device capable of performing SOAM functions on behalf of the upstream device and a downstream device capable of requesting SOAM functions;



FIG. 2 shows the flow of messages through a device that is capable of passively discovering labels or IDs for a network when it is not configured with any prior knowledge of other devices or of the network and is not assigned any unique addressing information inside that network;



FIG. 3 shows the flow of messages through a device that is capable of actively triggering the discovery of labels or IDs for a network when it is configured with some prior knowledge about other devices and is not assigned any unique addressing information inside that network;



FIG. 4 shows the flow of messages where a device handles SOAM functions using acquired information on behalf of an upstream device that is not capable of performing the requested SOAM functions.





While the invention is susceptible to various modifications and alternative forms, specific embodiments have been shown by way of example in the drawings and will be described in detail herein. It should be understood, however, that the invention is not intended to be limited to the particular forms disclosed. Rather, the invention is to cover all modifications, equivalents, and alternatives falling within the spirit and scope of the invention as defined by the appended claims.


DETAILED DESCRIPTION

In order for a SOAM capable device to be inserted into a network and perform SOAM and other functions of behalf of an upstream device or a plurality of upstream devices unable to perform such SOAM functions, the device must be able to learn or acquire information about the addressing of the other devices for which it needs to perform the SOAM functions. This learning or acquiring shall be transparent to other devices in the network and must not interfere with normal operation of the network.



FIG. 1 illustrates a generic portion of a MPLS network. Downstream device 101 is a network device capable of requesting SOAM functions from other devices inside the network. The downstream device 101 may be a testing unit, a router or a remote node that is local or external to a subnet where a device 102 that is configured to perform SOAM functions is located. Device 104 is an upstream device inside the same network that is unable to perform SOAM functions. The upstream device 104 may be a router or a remote node that is local or external to a subnet where the device 102 is located. The device 102 is therefore inserted in front of the upstream device 104 in order to perform the SOAM functions on behalf of the upstream device 104. The device 102 incorporates a field programmable gate array (FPGA). According to another embodiment of the present invention, the device 102 incorporates an application specific integrated circuit (ASIC). The SOAM functions include monitoring traffic and diagnosing issues, performing remote in-service layer 1-4 loopback, ITU-T Y.1564, ITU-T Y.1731 and RFC 2544 performance testing and monitoring actual customer or user and network statistics via a management interface, and other functions.


In one embodiment, in order to learn, discover or acquire the required addressing information about the upstream device, the SOAM device may take a passive role. Referring now to FIG. 2, this can be achieved by inspecting particular messages sent to an upstream device 204 behind the device 202 using a tunneling protocol such as MPLS. The upstream device 204 could be for example a handset or an LTE EnodeB and needs to be in the tunnel of interest and capable to respond. Sometimes it is difficult to respond because of firewalls or lack of service for the message. One solution to this problem is to make sure that the device 202 is pre-programmed to passively look at any packets to and from the upstream device 204. Responses from the upstream device 204 are identified by using the IP address in the tunnel or in the label stack of packets originating from the upstream device 204. Other identifiers could also be used. The device 202 looks at the messages from the upstream device 204 and registers one or more labels or IDs that are useful.


In FIG. 2, the downstream device 201 sends a packet 205 with a frame 206 to the upstream device 204 which will require a response. The device 202 is in the tunnel of interest and inspects the packet 205, registering labels or IDs that are useful and then forwards the packet 205 with the frame 206 on to the upstream device 204. These labels and IDs may or may not have specific fields that are intended to aid in discovery of the addressing information of the upstream device 204. The upstream device 204 receives packet 205 with frame 206 and responds to the downstream device 201 with a packet 207 that contains a frame 208. The device 202 receives the packet 207 with the frame 208. The device 202 inspects the packet 207, registering labels and IDs that are useful and forwards the packet 207 on to the downstream device 201. The device 202 now has the required addressing information about the upstream device 204 to perform SOAM functions on behalf of the upstream device 204.


In another embodiment, in order to learn, discover or acquire the required addressing information about the upstream device, the SOAM device may take an active role. Referring now to FIG. 3, device 302 is pre-programmed with a first test message 306 aimed at triggering a response from an upstream device 304. According to one aspect of the present invention, the pre-programming includes providing, via configuration or other means, addressing information about the labels or IDs needed to address each of the upstream devices 304. The device 302 transmits a packet 306 with a frame 307 to the upstream device 304. The upstream device 304 receives the packet 306 with the frame 307. The upstream device 304 either has special software for the explicit purpose to handle the special packet 306 or the packet 306 is addressed to a service known as already active on upstream device 304. The upstream device 304 then responds to the device 302 with a packet 308 with a frame 309. The device 302 analyzes the packet 308 and registers one or more labels or IDs, and then discards the packet 308 (without forwarding it) to avoid disrupting the operation of the network. The device 302 now has the required addressing information about the upstream device 304 to perform SOAM functions on behalf of the upstream device 304.


Once the SOAM device has obtained the required addressing information about the upstream device as per the method illustrated by FIG. 2 or 3, it may begin to provide SOAM and other functions on behalf of the upstream device while letting other traffic flow transparently to and from the upstream device. Referring now to FIG. 4, a protocol flow diagram illustrates how downstream device 401 can request a SOAM function from upstream device 404 and how it is transparently handled by device 402.


The downstream device 401 transmits a SOAM packet 409 to device 402. The device 402 receives the packet 409. The device 402 determines whether the packet 409 is for a SOAM function that the device 402 needs to handle on behalf of an upstream device 404. If the packet 409 is for a SOAM function, the device 402 performs the requested SOAM function using the addressing information collected for the upstream device 404 and prepares a valid response packet 410. The response packet 410 is then received by the downstream device 401 and is handled as the response to the SOAM request in packet 409.


In another embodiment, it should be noted that the SOAM capable device may handle the SOAM function on behalf of a plurality of devices located upstream or downstream from the SOAM capable device. When providing SOAM functions on behalf of a plurality of other devices, the SOAM capable device will learn and store the labels or IDs for each flow direction for each of the learned devices.


The device to discover and the discoverer node are each coupled to a processor. The present invention includes systems having processors to provide various functionality to process information, and to determine results based on inputs. Generally, the processing may be achieved with a combination of hardware and software elements. The hardware aspects may include combinations of operatively coupled hardware components including microprocessors, logical circuitry, communication/networking ports, digital filters, memory, or logical circuitry. The processors may be adapted to perform operations specified by a computer-executable code, which may be stored on a computer readable medium.


The steps of the methods described herein may be achieved via an appropriate programmable processing device, such as an external conventional computer or an on-board field programmable gate array (FPGA) or digital signal processor (DSP), that executes software, or stored instructions. In general, physical processors and/or machines employed by embodiments of the present invention for any processing or evaluation may include one or more networked or non-networked general purpose computer systems, microprocessors, field programmable gate arrays (FPGA's), digital signal processors (DSP's), micro-controllers, and the like, programmed according to the teachings of the exemplary embodiments of the present invention, as is appreciated by those skilled in the computer and software arts. Appropriate software can be readily prepared by programmers of ordinary skill based on the teachings of the exemplary embodiments, as is appreciated by those skilled in the software arts. In addition, the devices and subsystems of the exemplary embodiments can be implemented by the preparation of application-specific integrated circuits or by interconnecting an appropriate network of conventional component circuits, as is appreciated by those skilled in the electrical arts. Thus, the exemplary embodiments are not limited to any specific combination of hardware circuitry and/or software.


Stored on any one or on a combination of computer readable media, the exemplary embodiments of the present invention may include software for controlling the devices and subsystems of the exemplary embodiments, for driving the devices and subsystems of the exemplary embodiments, for processing data and signals, for enabling the devices and subsystems of the exemplary embodiments to interact with a human user, and the like. Such software can include, but is not limited to, device drivers, firmware, operating systems, development tools, applications software, and the like. Such computer readable media further can include the computer program product of an embodiment of the present invention for performing all or a portion (if processing is distributed) of the processing performed in implementations. Computer code devices of the exemplary embodiments of the present invention can include any suitable interpretable or executable code mechanism, including but not limited to scripts, interpretable programs, dynamic link libraries (DLLs), Java classes and applets, complete executable programs, and the like. Moreover, parts of the processing of the exemplary embodiments of the present invention can be distributed for better performance, reliability, cost, and the like.


Common forms of computer-readable media may include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, any other suitable magnetic medium, a CD-ROM, CDRW, DVD, any other suitable optical medium, punch cards, paper tape, optical mark sheets, any other suitable physical medium with patterns of holes or other optically recognizable indicia, a RAM, a PROM, an EPROM, a FLASH-EPROM, any other suitable memory chip or cartridge, a carrier wave or any other suitable medium from which a computer can read.


While particular implementations and applications of the present disclosure have been illustrated and described, it is to be understood that the present disclosure is not limited to the precise construction and compositions disclosed herein and that various modifications, changes, and variations can be apparent from the foregoing descriptions without departing from the spirit and scope of the invention as defined in the appended claims.

Claims
  • 1. A method of discovering addressing information of one or more first devices to respond to specific messages by a second device on behalf of the one or more first devices in a network, the method comprising: acquiring, by a second device, addressing information in an upstream direction from one or more third devices to the one or more first devices;acquiring, by the second device, addressing information in a downstream direction from the one or more first devices to the one or more third devices; andresponding, by the second device on behalf of the one or more first devices, to specific messages that include requests for functions from the one or more first devices.
  • 2. A method of discovering addressing information of one or more first devices to respond to specific messages by a second device on behalf of the one or more first devices in a network, the method comprising: pre-programming a second device with test packets that include addressing information in an upstream direction for the one or more first devices in each test packet;using upstream test packets for triggering one of the one or more first devices to respond with a packet including the addressing information in a downstream direction to one of one or more third devices from one of the one or more first devices; andresponding to specific messages including requests for functions from the one or more first devices using the included addressing information about one of the one or more first devices.
  • 3. A system of discovering addressing information of one or more first devices to respond to specific messages by a second device on behalf of the one or more first devices in a network, the system comprising: at least one third device coupled to a first processor;at least one first device coupled to a second processor; anda second device coupled to a third processor, the second device located between the at least one third device and the at least one first device,wherein the second device is configured to acquire addressing information in an upstream direction from the at least one third device and in a downstream direction from the at least one first device in order for the second device to respond on behalf of the at least one first device to the specific messages including requests for functions from the at least one first device.
  • 4. A method of discovering addressing information of one or more first devices to respond to specific messages by a second device on behalf of the one or more first devices in a network, the method comprising: pre-programming a second device with addressing information for addressing the one or more first devices;using at least one upstream test packet with the addressing information for triggering one of the one or more first devices to respond with a packet including addressing information about the one of the one or more first devices for performing functions on behalf of the one of the one or more first devices.
  • 5. A system of discovering addressing information of one or more first devices to respond to specific messages by a second device on behalf of the one or more first devices in a network, the system comprising: a device coupled to a processor, the device located between at least one second device and at least one third device and configured to acquire addressing information in an upstream direction from the at least one third device and in a downstream direction from the at least one second device in order for the device to respond on behalf of the at least one second device to the specific messages including requests for functions from the at least one third device.
  • 6. A method of performing functions on behalf of one or more first devices by a second device in a network, the method comprising: acquiring, by a second device, addressing information in an upstream direction from one or more third devices to the one or more first devices;acquiring, by the second device, addressing information in a downstream direction from the one or more first devices to the one or more third devices; andperforming, by the second device, a function on behalf of the one or more first devices in response to requests for functions that the one or more first devices are unable to perform.
CROSS-REFERENCE TO RELATED APPLICATIONS

This application is a continuation of U.S. patent application Ser. No. 14/480,673, filed Sep. 8, 2014, now allowed, which is a continuation of and claims priority to U.S. patent application Ser. No. 13/551,984, filed Jul. 18, 2012, now U.S. Pat. No. 8,862,702, each of which is hereby incorporated by reference herein in its entirety.

US Referenced Citations (76)
Number Name Date Kind
6166688 Cromer et al. Dec 2000 A
6367037 Remer et al. Apr 2002 B1
6601093 Peters Jul 2003 B1
6865602 Nijemcevic et al. Mar 2005 B1
6987743 Chen et al. Jan 2006 B2
7039688 Matsuda et al. May 2006 B2
7103275 Fujiwara Sep 2006 B2
7225243 Wilson May 2007 B1
7317926 Cloutier et al. Jan 2008 B1
7440781 Beach et al. Oct 2008 B2
7570657 Lo Aug 2009 B1
7778162 Yu Aug 2010 B2
7787455 Cherchall et al. Aug 2010 B2
7899929 Beser Mar 2011 B1
7912075 Holland et al. Mar 2011 B1
7953097 Hart May 2011 B2
8023465 Prehofer Sep 2011 B2
8072975 Weilnau Dec 2011 B2
8098671 Deruijter et al. Jan 2012 B1
8233437 Tazaki Jul 2012 B2
8254272 Vasseur Aug 2012 B1
8315626 Huotari et al. Nov 2012 B2
8509072 Lee et al. Aug 2013 B2
8537661 Yoshimura Sep 2013 B2
8571029 Aggarwal et al. Oct 2013 B1
8588751 Rinta-Aho et al. Nov 2013 B2
8862702 Robitaille Oct 2014 B2
9344400 Robitaille May 2016 B2
20020077117 Cloutier et al. Jun 2002 A1
20020112004 Reid et al. Aug 2002 A1
20030053421 Yoshimura Mar 2003 A1
20030056008 Russell et al. Mar 2003 A1
20030212772 Harris Nov 2003 A1
20030212795 Harris Nov 2003 A1
20030225864 Gardiner et al. Dec 2003 A1
20030229809 Wexler et al. Dec 2003 A1
20040249906 Olbricht et al. Dec 2004 A1
20050114141 Grody May 2005 A1
20050135306 McAllen et al. Jun 2005 A1
20050138428 McAllen et al. Jun 2005 A1
20050238058 Peirce Oct 2005 A1
20050281256 Taipale et al. Dec 2005 A1
20060215583 Castagnoli Sep 2006 A1
20060274671 Budampati et al. Dec 2006 A1
20070019598 Prehofer Jan 2007 A1
20070033622 Kim Feb 2007 A1
20080019367 Ito Jan 2008 A1
20080140815 Brant et al. Jun 2008 A1
20080153477 Cloutier et al. Jun 2008 A1
20080205341 Koh et al. Aug 2008 A1
20080215756 Lee Sep 2008 A1
20080261574 Rinta-Aho et al. Oct 2008 A1
20080285466 Salam Nov 2008 A1
20090085806 Piersol et al. Apr 2009 A1
20090201886 Lee et al. Aug 2009 A1
20090251867 Sharma Oct 2009 A1
20100054154 Lambert et al. Mar 2010 A1
20100080248 Aweya et al. Apr 2010 A1
20100246425 Hachiya Sep 2010 A1
20100274917 Cherchali et al. Oct 2010 A1
20100280858 Bugenhagen Nov 2010 A1
20110283140 Stevens et al. Nov 2011 A1
20110305150 Haver et al. Dec 2011 A1
20120014383 Geromel et al. Jan 2012 A1
20120102239 Huang Apr 2012 A1
20120105877 Wakamatsu May 2012 A1
20120230186 Lee et al. Sep 2012 A1
20120284517 Lambert Nov 2012 A1
20120320751 Zhu Dec 2012 A1
20120327768 Sarwar et al. Dec 2012 A1
20130077968 Yang Mar 2013 A1
20130346591 Carroll et al. Dec 2013 A1
20140024255 Robitaille et al. Jan 2014 A1
20140025789 Robitaille Jan 2014 A1
20140025790 Robitaille et al. Jan 2014 A1
20140071855 Robitaille et al. Mar 2014 A1
Foreign Referenced Citations (8)
Number Date Country
103685452 Mar 2014 CN
2 421 200 Feb 2012 EP
20090004239 Jan 2009 KR
WO 2010097514 Sep 2010 WO
WO 2011054006 May 2011 WO
WO 2014013317 Jan 2014 WO
WO 2014013318 Jan 2014 WO
WO 2014013320 Jan 2014 WO
Non-Patent Literature Citations (17)
Entry
Avago Technologies. “1000BASE-T Interface and Functionality of ABCU-57xxRZ Gigabit Ethernet Small Form Puggable Electrical Transceivers Over Category 5 Unshielded Twisted Pair Cable—Application Note 5286.” XP055091424, Sep. 14, 2010 [online] [retrieved on Dec. 4, 2013]. Retrieved from the Internet <URL: http://www.avagotech.com/docs/AV02-2643EN&#x200E> (16 pages).
Cheshire, et al. “Dynamic Configuration of IPv4 Link-Local Addresses,” May 2005, 33 pages.
Cyclone IV Device Handbook, vol. 1, Altera, Dec. 2010 (478 pages).
Drimer and Kuhn, “A Protocol for Secure Remote Updates of FPGA Configurations”, pp. 50-61, 2009, Lecture Notes in Computer Science vol. 5453, 12 pages.
IEEE Standard for Information Technology, Part 3: Carrier Sense Multiple Access with Collision Detection (CSMA/CD) access method and Physical Layer specifications, 2008 (315 pages).
Gigabit Ethernet Auto-Negotiation, by Rich Hernandez, www.dell.com/powersolutions, 1999 (6 pages).
Malkin, “Traceroute Using an IP Option,” Jan. 1993, 7 pages.
Plummer, “An Ethernet Address Resolution Protocol—or—Converting Network Protocol Addresses to 48.bit Ethernet Address for Transmission on Ethernet Hardware,” Nov. 1982, 10 pages.
Rad Data Communications, Rad & Miniature & SFP-S & SFF 8439 Specifications, Dec. 2007, 48 pages.
Rad Data Communications, Data Sheet—MIRICI-155 Intelligent Miniature GbE over STM-1/OC-3 NTU, 2007-2010, 4 pages.
Sosnoski, “Classworking toolkit: Combining source and bytecode generation,” Oct. 4, 2005, 9 pages.
Thomas, G. “Incorporating Media Converters.” Contemporary Control Systems, Inc. The Extension. vol. 7, No. 6, Nov. 2006 [online] [retrieved on Dec. 4, 2013]. Retrieved from the Internet: <URL: http://www.ccontrols.com/pdf/Extv7n6.pdf> (4 pages).
https://lkml.org/lkml/2005/10/19/46 on Oct. 16, 2012, Ingo Molnar, Oct. 19, 2005, 7 pages.
International Search Report and Written Opinion mailed Nov. 26, 2013 which issued in International Patent Application No. PCT/IB2013/001559 (8 pages).
International Search Report and Written Opinion mailed Dec. 4, 2013 which issued in International Patent Application No. PCT/IB2013/001557 (9 pages).
International Search Report and Written Opinion mailed Dec. 9, 2013 which issued in International Patent Application No. PCT/IB2013/001556 (7 pages).
Extended European Search Report mailed Dec. 18, 2013 which issued in European Patent Application No. 13183360.0 (11 pages).
Related Publications (1)
Number Date Country
20160234166 A1 Aug 2016 US
Continuations (2)
Number Date Country
Parent 14480673 Sep 2014 US
Child 15131627 US
Parent 13551984 Jul 2012 US
Child 14480673 US