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,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; U.S. application Ser. No. 13/552,063, “Systems and Methods of Discovering and Controlling devices without Explicit Addressing,” by Robitaille and Bouffard, and U.S. application Ser. No. 13/551,984, “Systems and Methods of Installing and Operating Devices without Explicit Network Addresses,” by Robitaille and Lemieux.
This invention is directed towards addressing the need for discovering when a device has been connected on a network. The discovery process shall be carried without the need for specific layer-2 or layer-3 addressing information about the device(s) to discover. This discovery process can be carried out by a discoverer/tester that is located in the network. The discoverer could either be implemented in a centralized manner or in a distributed manner.
There is a need to be able to discover any number of devices in any directly or indirectly reachable networks when they may not have any layer-2 and/or layer-3 addressing information since they do not actively participate in any of the normal network protocols in use.
Often the IDs or labels used by the protocols are not the same in both directions. If the device is not participating in the underlying protocols (e.g., MPLS, L2TPv3, GTP-U, etc.), the device (Small Form-Factor Pluggable (SFP) with a Field Programmable Gate Array (FPGA), Network Interface Device (NID), module or other platform) does not know what ID or label to use to communicate.
The device to be discovered must be able to be discovered without (but not excluding) being pre-programmed with information specific to the network or the control infrastructure.
After the discovery of a device, the discovered device can notify the discoverer of its presence via an Advertisement message. Once the server specified by the discoverer receives a valid Advertisement message, it can proceed with assigning a Layer-2 and/or Layer-3 address to the discovered device as required. Alternatively, the discoverer can provide information to the discovered device on how to obtain a layer-2 and/or layer-3 address from other services available on the network where the discovered device is located.
In one embodiment, the discovery process is used to enable an initial management access where a newly discovered device can be put in a state where it can receive further configuration, control, management or even new firmware information from a remote management entity, the management entity not necessarily being the same as the discoverer.
According to one aspect of the present invention, a method of discovering a device to be discovered in a communication network having multiple interconnected nodes includes transmitting, by a discoverer, at least one beacon signal including an IP address to the network. The device to be discovered receives the at least one beacon signal. The device to be discovered configures the IP address located in the at least one beacon signal. Additionally, the device to be discovered transmits an advertisement to a server specified by the discoverer.
According to a further aspect of the present invention, a system for discovering a device to be discovered in a communication network having multiple interconnected nodes includes the device to be discovered and a discoverer, The discoverer is coupled to a first processor and is configured to transmit at least one beacon message including an IP address to the communication network. The device to be discovered is coupled to a second processor and is configured to receive the at least one beacon message transmitted by the discoverer and to configure the IP address from the at least one beacon signal. The device to be discovered transmits an advertisement to a server specified by the discoverer in the at least one beacon signal.
The foregoing and other advantages of the present disclosure will become apparent upon reading the following detailed description and upon reference to the drawings.
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.
Different types of devices can be discovered in the network using one of the embodiments of the present invention. The term discoverer is used to describe a system (e.g., testing unit, router, remote node, etc.) that has direct or indirect access to the subnet where a device to be discovered is located. Since the discoverer is not necessarily directly located on the same subnet as the device(s) to be discovered, necessary addressing information about the discoverer is included in a beaconing message to allow the newly discovered device(s) to reply with an Advertisement message that will reach the discoverer.
When the device to discover is on the same IP subnet as the discoverer, layer-2 broadcast techniques may be used to facilitate the discovery process. Techniques based on layer-2 (broadcast or unicast) cannot be used when the device to discover is not located on the same IP subnet as the discoverer. For simplicity of installation and deployment, the device to discover needs to be discovered without any prior configuration settings in the device to discover. This means that the device to discover does not have any information about reaching a DHCP server located on a different IP subnet and is not allowed to proactively take steps to be discovered by a discoverer unless it is prompted to do so with a communication from a discoverer node. Such a restriction is needed since the device to discover may be embodied in a variety of systems that are not permanently installed in a network and may need to be activated only under specific circumstances and for a limited period of time. The discovery process therefore needs to be initiated by a discoverer node and needs to operate across one or more IP subnet.
In order for the discovery process to operate seamlessly across subnet boundaries, the discoverer needs to be able to craft a stateless packet that can be broadcast across one or more IP subnet and reach the device(s) to be discovered. Since there is no way to control the IP routers, gateways or firewall that may be installed at the boundaries of an IP subnet, the choice of the packet encoding used needs to be completely transparent to any router, gateway or firewall and must not conflict with the proper operation of the network and of the devices inside the network. The Dynamic Host Configuration Protocol (DHCP—RFC 2131) has been selected as the basis for this invention since it is widely supported by routers, gateways and firewalls and is stateless as far as these devices are concerned. Furthermore, DHCP messages are well suited for the discovery process since they are encapsulated as User Datagram Protocol (UDP) packets and can be broadcast on any subnet. When the discoverer is not located on the same subnet as the device to be discovered, the DHCP Relay function (RFC 3046) can be used to reach remote subnets in order to reach any undetected devices.
The DHCP protocol exchange is usually initiated by a device looking for an IP address it can use. The standard prior art DHCP message exchange is illustrated by
According to systems and methods of the present invention, the device to be discovered is passively waiting to be discovered. The discovery process therefore needs to be initiated by the discoverer and the traditional 4-way DHCP exchange cannot be applied as defined in the art. However, according to the present invention, the DHCP OFFER message, if modified, may be used by the discoverer as an unsolicited message or beacon. The DHCP OFFER message is modified in such a way as to be rejected by any other device that supports the traditional 4-way DHCP message handshake. The modified DHCP OFFER shall also carry information to allow the device to be detected or discovered to determine whether the DHCP OFFER message originates from a valid discoverer and is not part of the 4-way DHCP handshake. Finally, the modified DHCP OFFER message shall still be able to be relayed to other subnets by a standard implementation of the DHCP RELAY function supported by popular Routers, Switches, Gateways and other devices.
Each DHCP messages share a common format, as shown below. DHCP uses Uniform Data Protocol (UDP) as the transport layer protocol. Referring now to
Looking at the above format for DHCP messages, the following fields are modified or interpreted differently when used by the discoverer to detect new devices: Transaction identifier: this field is normally set by a DHCP client device. When used as part of the modified DHCP OFFER, this 32-bit field includes a unique encryption key that is used to encrypt select portions of the modified DHCP OFFER message. This optional cryptographic information can be used to protect (encrypt) critical elements of the DHCP OFFER message including, but not limited to the siaddr and the giaddr fields. Flags: the broadcast bit shall be set to 1. All other bits are typically ignored and should be set to zero (0) for future compatibility.
Ciadd: the client IP address field should be set to 0.
Yiaddr: this field shall be set to 0. In a normal DHCP OFFER message, this field is used by a DHCP Server to inform a client of the IP address that has been reserved for it.
Siaddr: this is the IP address of the management device that will handle the management functions for the detected device.
Chaddr: this field shall be set to 0. In a normal DHCP OFFER message, this field is used to carry the hardware (for example Ethernet MAC) address of the client.
Sname: this field shall be set to 0.
File: this field shall be set to 0.
The modified DHCP OFFER 201 (in
Server ID (option 54): this option shall include the discoverer IP address. This will be used by the detected device to return the ADVERTISEMENT message.
Vendor ID (option 43): this option shall be set to a unique string identifying the vendor and used by the detected device to filter out other DHCP OFFER it could inadvertently receive.
Vendor Information (option 60, also known as Vendor Class Identifier): this option field is used to carry additional information about the discoverer as well as information of interest to a detected device. Among others, this option field typically includes the following information: IP address configuration mode, Organizational Unique Identifier (OUI), rate of transmission, Time to Live (TTL), Supported Type-Length-Value, and other information. The IP address configuration mode is used to indicate to the detected device how it should obtain an IP address. Typical choices include (but are not limited to): using a static IP address, obtaining an IP address via the normal 4-way DHCP message handshake or the detected device automatically generating its own IP address based on an IP subnet provided by the detector/discoverer or specified in the default (or current) configuration settings for the detected/discovered device. The OUI is a unique value assigned to the Vendor by the Internet Assigned Numbers Authority (IANA) and is used to filter out improper messages. The rate of transmission is the rate at which a detected device shall repeatedly transmit an Advertisement message to indicate it is still present in the network. TTL is the field that is decremented by a detected device. Supported TLV may contain a number of fields depending on the range of information to be exchanged between the discoverer and the detected device.
Referring now to
In order for the discovered device to begin to transmit the Advertisement message, the device should obtain a valid IP address as specified in the beacon message. Once the device has obtained a valid IP address, the transmission of the Advertisement message can begin.
The content of the Advertisement message 311 includes information about the detected or discovered device 302, including but not limited to: port identifier, device name, device description, IP address of the device (if known), serial number, firmware/software revision, base MAC address, configuration status, platform identifier, slot identifier, module information, and so on. The information may be encoded using the popular Type-Length-Value (TLV) format. In another embodiment, the information of the Advertisement packet may be encoded as a sequence of position dependent fields with pre-agreed lengths.
In another embodiment, the detected or discovered device may enable access to other undetected devices downstream from the device. When this is the case, the TTL value specified in option 60 of the beacon should be decremented by a value of 1 and if not zero (0), the newly detected device may elect to forward the beacon to other devices only reachable through the detected device.
As disclosed earlier, the modified DHCP OFFER message (beacon) is broadcast by the discoverer as an unsolicited message in order to reach as many undetected devices as possible. In another embodiment, the DHCP OFFER message (beacon) may be transmitted as a directed unicast packet to a specific previously detected device when the detected device cannot be reached using a valid destination IP address. This may occur when a device is in an unknown state and needs to be reset to a previously defined state (such as a factory default state) or when a detected device needs to receive additional information before it can obtain a valid IP address for further communication. A typical unicast packet includes the IP address of the remote device. In this embodiment, the detected device does not yet have a valid IP address and cannot therefore be reached using this method. In order to make sure the beacon is only valid for that specific device, as would a standard unicast UDP packet, the modified DHCP OFFER message should include other information that is unique to this device to be discovered. This information may include (but is not limited to): serial number, MAC address, device name or any other unique identifier where the unique identifier may be a combination of any of these individual identifiers.
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.
This application is a continuation of and claims priority to U.S. patent application Ser. No. 14/789,066, filed Jul. 1, 2015, now allowed, which is a continuation of U.S. patent application Ser. No. 13/552,022, filed Jul. 18, 2012, now U.S. Pat. No. 9,106,706, each of which is hereby incorporated by reference herein in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
6166688 | Cromer | Dec 2000 | A |
6367037 | Remer | Apr 2002 | B1 |
6865602 | Nijemcevic et al. | Mar 2005 | B1 |
6987743 | Chen et al. | Jan 2006 | B2 |
7039688 | Matsuda | May 2006 | B2 |
7225243 | Wilson | May 2007 | B1 |
7440781 | Beach | Oct 2008 | B2 |
7570657 | Lo | Aug 2009 | B1 |
7778162 | Yu | Aug 2010 | B2 |
7787455 | Cherchall et al. | Aug 2010 | B2 |
7912075 | Holland et al. | Mar 2011 | B1 |
7969346 | Franceschini | Jun 2011 | B2 |
8023465 | Prehofer | Sep 2011 | B2 |
8089405 | Piersol | Jan 2012 | B2 |
8098671 | Deruijter et al. | Jan 2012 | B1 |
8116233 | Lambert | Feb 2012 | B2 |
8218502 | Liu | Jul 2012 | B1 |
8233437 | Tazaki | Jul 2012 | B2 |
8315626 | Huotari | Nov 2012 | B2 |
8332541 | Park | Dec 2012 | B2 |
8360975 | Schwieterman | Jan 2013 | B1 |
8482183 | Liu | Jul 2013 | B2 |
8509072 | Lee et al. | Aug 2013 | B2 |
8571029 | Aggarwal et al. | Oct 2013 | B1 |
8588751 | Rinta-Aho | Nov 2013 | B2 |
8614989 | Liu | Dec 2013 | B2 |
9106706 | Robitaille | Aug 2015 | B2 |
9450779 | Narasappa | Sep 2016 | B2 |
9491137 | Robitaille | Nov 2016 | B2 |
20020013807 | Richard | Jan 2002 | A1 |
20030053421 | Yoshimura | Mar 2003 | A1 |
20030056008 | Russell et al. | Mar 2003 | A1 |
20030225864 | Gardiner et al. | Dec 2003 | A1 |
20030229809 | Wexler et al. | Dec 2003 | A1 |
20040249906 | Olbricht et al. | Dec 2004 | A1 |
20050089041 | Idnani | Apr 2005 | A1 |
20050135306 | McAllen | Jun 2005 | A1 |
20050138428 | McAllen | Jun 2005 | A1 |
20050257248 | Kegel | Nov 2005 | A1 |
20050281256 | Taipale et al. | Dec 2005 | A1 |
20060084417 | Melpignano | Apr 2006 | A1 |
20060209852 | Wakumoto | Sep 2006 | A1 |
20060274671 | Budampati | Dec 2006 | A1 |
20070019598 | Prehofer | Jan 2007 | A1 |
20070147261 | Schumacher | Jun 2007 | A1 |
20070177554 | Yang | Aug 2007 | A1 |
20070211691 | Barber | Sep 2007 | A1 |
20080091812 | Lev-Ran | Apr 2008 | A1 |
20080140815 | Brant et al. | Jun 2008 | A1 |
20080205341 | Koh | Aug 2008 | A1 |
20080261574 | Rinta-Aho | Oct 2008 | A1 |
20080298373 | Lapuh | Dec 2008 | A1 |
20090085806 | Piersol | Apr 2009 | A1 |
20090088183 | Piersol | Apr 2009 | A1 |
20090201886 | Lee | Aug 2009 | A1 |
20090210932 | Balakrishnan | Aug 2009 | A1 |
20090303020 | Greenlee | Dec 2009 | A1 |
20090303049 | Greenlee | Dec 2009 | A1 |
20090303061 | Greenlee | Dec 2009 | A1 |
20090327395 | Park | Dec 2009 | A1 |
20100054154 | Lambert | Mar 2010 | A1 |
20100085236 | Franceschini | Apr 2010 | A1 |
20100091732 | Roeder | Apr 2010 | A1 |
20100274917 | Cherchali et al. | Oct 2010 | A1 |
20100280858 | Bugenhagen | Nov 2010 | A1 |
20110283140 | Stevens et al. | Nov 2011 | A1 |
20110304583 | Kruglick | Dec 2011 | A1 |
20110305150 | Haver | Dec 2011 | A1 |
20110317703 | Dunbar | Dec 2011 | A1 |
20120014383 | Geromel et al. | Jan 2012 | A1 |
20120014386 | Xiong | Jan 2012 | A1 |
20120014387 | Dunbar | Jan 2012 | A1 |
20120105877 | Wakamatsu | May 2012 | A1 |
20120162013 | Piersol | Jun 2012 | A1 |
20120201201 | Liu | Aug 2012 | A1 |
20120230186 | Lee et al. | Sep 2012 | A1 |
20120281630 | Liu | Nov 2012 | A1 |
20120284517 | Lambert | Nov 2012 | A1 |
20120320751 | Zhu | Dec 2012 | A1 |
20130172036 | Miklos | Jul 2013 | A1 |
20130346591 | Carroll | Dec 2013 | A1 |
Number | Date | Country |
---|---|---|
2421200 | Feb 2012 | EP |
20090004239 | Jan 2009 | KR |
2011054006 | May 2011 | WO |
Entry |
---|
Cyclone IV Device Handbook, vol. 1, Altera, Dec. 2010 (478 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). |
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). |
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‎> (16 pages). |
Cheshire, et al. “Dynamic Configuration of IPv4 Link-Local Addresses,” May 2005, 33 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. |
Malkin, “Traceroute Using an IP Option,” Jan. 1993, 7 pages. |
https://lkml.org/lkml/2005/10/19/46 on Oct. 16, 2012, Ingo Molnar, Oct. 19, 2005, 7 pages. |
Sosnoski, “Classworking toolkit: Combining source and bytecode generation,” Oct. 4, 2005, 9 pages. |
International Search Report and Written Opinion dated Nov. 26, 2013 which issued in International Patent Application No. PCT/IB2013/001559 (8 pages). |
International Search Report and Written Opinion dated Dec. 4, 2013 which issued in International Patent Application No. PCT/IB2013/001557 (9 pages). |
International Search Report and Written Opinion dated Dec. 9, 2013 which issued in International Patent Application No. PCT/IB2013/001556 (7 pages). |
Extended European Search Report dated Dec. 18, 2013 which issued in European Patent Application No. 13183360.0 (11 pages). |
Number | Date | Country | |
---|---|---|---|
20170026336 A1 | Jan 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14789066 | Jul 2015 | US |
Child | 15289137 | US | |
Parent | 13552022 | Jul 2012 | US |
Child | 14789066 | US |