The present disclosure relates generally to wireless communication systems, and more particularly, to methods and apparatus for distributing link-state information associated with a wireless mesh network.
Link-state routing protocols such as Open Shortest Path First (OSPF) protocol and Optimized Link State Routing (OLSR) protocol may be used to identify routes in wired and/or wireless networks (e.g., multi-hop wireless mesh networks). In one example, nodes in a network may identify the best path between a source and a destination in the network. Typically in accordance with a link-state routing protocol, each node in the network may periodically report a full set of link-state metrics to all nodes in the network. For example, a link-state metric may include information indicative of link characteristics such as quality of a link between two nodes in the network. Each node may also generate a link-state table of the network topology based on the reports from other nodes in the network (e.g., hello messages). Accordingly, the node may execute a path algorithm (e.g., Dijkstra's algorithm) on the link-state table to identify the optimal route from a source to one or more destinations in the network.
In general, methods and apparatus for distributing link-state information associated with a wireless mesh network having a plurality of mesh nodes are described herein. According to one example embodiment, a primary relay node of the wireless mesh network may identify one or more links of a neighborhood associated with the primary relay node. The primary relay node may be selected by one or more neighboring nodes relative to the primary relay node. The primary relay node may generate a link-state message having link-state information associated with each of the one or more links identified by the primary relay node. As a result, the primary relay node may reduce the overhead required to distribute the link-state information across the wireless mesh network to the plurality of mesh nodes. The methods and apparatus described herein are not limited in this regard.
Referring to
The plurality of nodes 102 may operate in accordance with one or more of several wireless communication protocols to communicate with each other and/or other wireless devices (e.g., a laptop computer, a handheld computer, a tablet computer, a cellular telephone a wireless peripheral, etc.). In particular, these wireless communication protocols may be based on analog, digital, and/or dual-mode communication system standards such as the Global System for Mobile Communications (GSM) standard, the Frequency Division Multiple Access (FDMA) standard, the Time Division Multiple Access (TDMA) standard, the Code Division Multiple Access (CDMA) standard, the Wideband CDMA (WCDMA) standard, the General Packet Radio Services (GPRS) standard, the Enhanced Data GSM Environment (EDGE) standard, the Universal Mobile Telecommunications System (UMTS) standard, variations and evolutions of these standards, and/or other suitable wireless communication standards.
The plurality of nodes 102 may also communicate with other components associated with the wireless mesh network 100 such as wireless local area network (WLAN) devices and/or wireless wide area network (WWAN) devices (not shown) including network interface devices and peripherals (e.g., network interface cards (NICs)), access points (APs), gateways, bridges, hubs, etc. to implement a cellular telephone system, a satellite system, a personal communication system (PCS), a two-way radio system, a one-way pager system, a two-way pager system, a personal computer (PC) system, a personal data assistant (PDA) system, a personal computing accessory (PCA) system, and/or any other suitable communication system.
The plurality of nodes 102 may use a variety of modulation techniques such as spread spectrum modulation (e.g., direct sequence code division multiple access (DS-CDMA) and/or frequency hopping code division multiple access (FH-CDMA)), time-division multiplexing (TDM) modulation, frequency-division multiplexing (FDM) modulation, orthogonal frequency-division multiplexing (OFDM) modulation, multi-carrier modulation (MDM), and/or other suitable modulation techniques to communicate with each other. In particular, the plurality of nodes 102 may use OFDM modulation as described in the 802.xx family of standards developed by the Institute of Electrical and Electronic Engineers (IEEE) and/or variations and evolutions of these standards (e.g., 802.11 x, 802.15, 802.16x, etc.) to communicate via the wireless communication links with each other. The plurality of nodes 102 may also operate in accordance with other suitable wireless communication protocols that require very low power such as Bluetooth, Ultra Wideband (UWB), and/or radio frequency identification (RFID) to communicate with each other. The methods and apparatus described herein are not limited in this regard.
To reduce the overhead required to distribute link-state information across the wireless mesh network 100, primary relay nodes may be selected to generate and forward the link-state information as described herein. The primary relay nodes may be a subset of relay nodes of the wireless mesh network 100. The link-state information may include metric associated with each link of the wireless mesh network 100. For example, the link-state information may include information indicative of quality (e.g., signal-to-noise ratio), available bandwidth (e.g., data rate), and/or other characteristics associated with each link. As a result, the plurality of mesh nodes 102 may identify the best route between a source and a destination in the wireless mesh network 100 based on the link-state information from the primary relay nodes.
In particular, the plurality of nodes 102 may include one or more non-relay nodes (NR), generally shown as 105, 110, 120, 135, 145, 150, 155, and 165. The plurality of mesh nodes 102 may also include one or more relay nodes (R), generally shown as 125 and 130. Further, the plurality of mesh nodes 102 may include one or more primary relay nodes (PR), generally shown as 115, 140, and 160.
The primary relay nodes of the wireless mesh network 100 may be selected from the relay nodes by primary relay selector (PRS) nodes based on a backbone selection protocol such as a reorganization (ReOrg) protocol, a multipoint relay (MPR) protocol, a link cluster algorithm (LCA) protocol, and/or other suitable selection protocols. For example, the primary relay nodes 115, 140, and 160 may be selected as described in Conner et al., U.S. patent application Ser. No. 10/132,947 (U.S. Publication No. 2003/0202524). The PRS nodes of a primary relay node may include relay nodes and/or non-relay nodes in a neighborhood associated with the primary relay node.
As indicated by black arrows, for example, the non-relay nodes 155 and 165 may select the mesh node 115 to operate as the primary relay node associated with a neighborhood 170 including the mesh nodes 115, 125, 135, 155, and 165. In another example, the non-relay nodes 135, 145, and 150 and the relay node 130 may select the mesh node 140 to operate as the primary relay node associated with a neighborhood 180 including the nodes 130, 135, 140, 145, and 150. In yet another example, the non-relay nodes 105, 110, and 120 and the relay node 125 may select the mesh node 160 as the primary relay node associated with a neighborhood 190 including the nodes 105, 110, 120, 125, and 160. The methods and apparatus described herein are not limited in this regard.
Turning to
A hello message from a neighboring node may include node address information associated with the neighboring node such as a Media Access Control (MAC) address, an Internet Protocol (IP) address, etc. As described in detail below, a neighboring node of the primary relay node 200 may be either a PRS node or a non-PRS node relative to the primary relay node 200. As noted above, a PRS node may be a mesh node (e.g., a relay node or a non-relay node) that selects a relay node to operate as its primary relay node. Accordingly, the hello message may include information indicative of whether the neighboring node is a PRS node associated with the primary relay node 200. The hello message may also include metric of a link between the primary relay node 200 and the neighboring node (e.g., available bandwidth, energy, and/or other link characteristics). Further, the hello message may include a neighbor list of the neighboring node. That is, the neighbor list may include node address information and metric information associated with one or more neighboring nodes relative to the mesh node transmitting the hello message.
The identifier 230 may identify one or more links of a neighborhood associated with the primary relay node 200 to report corresponding link-state information to all mesh nodes of a wireless mesh network. For example, the primary relay node 200 may identify a link associated with the primary relay node 200 and a PRS node relative to the primary relay node 200 (e.g., a mesh node that selected the primary relay node 200). The primary relay node 200 may also identify a link associated with the primary relay node 200 and a non-PRS node having a node address larger than a node address of the primary relay node 200 (e.g., a mesh node that selected another relay node as the primary relay node corresponding to that particular mesh node). In another example, the primary relay node 200 may identify a link associated with two PRS nodes relative to the primary relay node 200. Further, the primary relay node 200 may identify a link associated with a PRS node and a non-PRS node having a node address greater than a node address of the PRS node.
Based on the neighbor list stored in the memory 220, the generator 240 may generate a link-state message having link-state information associated with each of the links identified by the identifier 230 as noted above. In particular, the generator 240 may generate a raw link-state list (e.g., the raw link-state list 500 of
While the components shown in
To distribute link-state information associated with the wireless mesh network 100, a primary relay node (e.g., the primary relay nodes 115, 140, and 160) may identify one or more links of a neighborhood associated with the primary relay node. Referring to
In one example, the primary relay node 115 may identify links associated with the neighboring nodes 125, 135, 155, and 165 (e.g., the mesh nodes associated with the neighborhood 170). The neighboring nodes 155 and 165 may be PRS nodes and the neighboring nodes 125 and 135 may be non-PRS nodes relative to the primary relay node 115. In particular, the primary relay node 115 may identify a link 321 between the primary relay node 115 (e.g., node address 3) and the PRS node 155 (e.g., node address 11), and a link 322 between the primary relay node 115 and the PRS node 165 (e.g., node address 13) because the neighboring nodes 155 and 165 are PRS nodes relative to the primary relay node 115 (e.g., the mesh nodes 155 and 165 selected the mesh node 115 to operate as their primary relay node). Further, the primary relay node 115 may identify a link 325 between the PRS nodes 155 and 165 because the link 325 is a link associated with two PRS nodes that selected the mesh node 115 to operate as their corresponding primary relay node.
As noted above, the neighboring nodes 125 and 135 may be non-PRS nodes relative to the primary relay node 115 (e.g., mesh nodes that did not select the mesh node 115 to operate their primary relay node). The primary relay node 115 may also identify a link 323 between the primary relay node 115 and the non-PRS node 125 (e.g., node address 5), and a link 324 between the primary relay node 115 and the non-PRS node 135 (e.g., node address 7) because the node address of each of the non-PRS nodes 125 and 135 is greater than the node address of the primary relay node 115. In particular, the node address of the primary relay node 115 is 3, and the node addresses of the non-PRS nodes 125 and 135 are 5 and 7, respectively. Thus, each of the node addresses of the non-PRS nodes 125 and 135 is greater than the node address of the primary relay node 115. Otherwise if the node address of a non-PRS node is less than the node address of the primary relay node 115, the primary relay node 115 may not report the link-state information associated with the particular non-PRS node. As noted above, the node address may be a MAC address, an IP address, and/or other suitable address to identify a mesh node. For example, if the node addresses are MAC addresses or IP addresses, the MAC addresses or IP addresses may be converted to numerical values for comparison of the node addresses.
In another example, the primary relay node 140 may identify links associated with the neighboring nodes 130, 135, 145, 150, and 165 (e.g., the mesh nodes associated with the neighborhood 180). The neighboring nodes 130, 135, 145, and 150 may be PRS nodes and the neighboring node 165 may be a non-PRS node relative to the primary relay node 140. In contrast to the above example, the neighboring node 135 (e.g., node address 7) may be a PRS node relative to the primary relay node 140 and a non-PRS node relative to the primary relay node 115. In a similar manner, the neighboring node 165 (e.g., node address 13) may be a PRS node relative to the primary relay node 115 and a non-PRS node relative to the primary relay node 140.
The primary relay node 140 may identify a link 341 between the primary relay node 140 and the PRS node 130 (e.g., node address 6), a link 342 between the primary relay node 140 and the PRS node 135 (e.g., node address 7), a link 343 between the primary relay node 140 and the PRS node 145 (e.g., node address 9), and a link 344 between the primary relay node 140 and the PRS node 150 (e.g., node address 10) because the mesh nodes 130, 135, 145, and 150 are PRS nodes relative to the primary relay node 115 (e.g., the mesh nodes 130, 135, 145, and 150 selected the mesh node 115 to operate as their primary relay node). The primary relay node 140 may also identify a link 345 between the PRS nodes 130 and 135, a link 346 between the PRS nodes 135 and 145, and a link 347 between the PRS nodes 145 and 150 because each of the links 345, 346, and 347 is a link associated with two PRS nodes that selected the mesh node 140 to operate as their corresponding primary relay node.
Further, the primary relay node 140 may identify a link 348 between the neighboring nodes 135 and 165 and a link 349 between the neighboring nodes 145 and 165 because each of the links 348 and 349 is a link associated with a PRS node and a non-PRS node having an address greater than a node address of the PRS node. That is, the address of the non-PRS node 165 is 13, and the node addresses of the PRS nodes 135 and 145 are 7 and 9, respectively. Thus, the node address of the non-PRS node 165 is greater than each of the node addresses of the PRS nodes 135 and 145.
In yet another example, the primary relay node 160 may identify links associated with the neighboring nodes 105, 110, 120, 125, 130, and 135 (e.g., the mesh nodes associated with the neighborhood 190). The neighboring nodes 105, 110, 120, and 125 may be PRS nodes and the neighboring nodes 130 and 135 may be non-PRS nodes relative to the primary relay node 160. In contrast to the above examples, the neighboring node 125 (e.g., node address 5) may be a PRS node relative to the primary relay node 160 and a non-PRS node relative to the primary relay node 115. In a similar manner, the neighboring node 130 (e.g., node address 6) may be a PRS node relative to the primary relay node 140 and a non-PRS node relative to the primary relay node 160. Further, the neighboring node 135 (e.g., node address 7) may be a PRS node to the primary relay node 140 and a non-PRS node relative to the primary relay nodes 115 and 160.
The primary relay node 160 may identify a link 361 between the primary relay node 160 and the neighboring node 105 (e.g., node address 1), a link 362 between the primary relay node 160 and the neighboring node 110 (e.g., node address 2), a link 363 between the primary relay node 160 and the neighboring node 120 (e.g., node address 4), and a link 364 between the primary relay node 160 and the neighboring node 125 (e.g., node address 5) because the neighboring nodes 105, 110, 120, and 125 selected the mesh node 160 to operate as their corresponding primary relay node. The primary relay node 160 may also identify a link 365 between the PRS nodes 105 and 110, a link 366 between the PRS nodes 110 and 120, and a link 367 between the PRS nodes 120 and 125 because each of the links 365, 366, and 367 is a link associated with two PRS nodes that selected the mesh node .160 to operate as their corresponding primary relay node.
In addition, the primary relay node 160 may identify a link 368 between the PRS node 120 and the non-PRS node 130, a link 369 between the PRS node 125 and the non-PRS node 130, and a link 370 between the PRS node 125 and the non-PRS node 135 because each of the links 368, 369, and 370 is a link associated with a PRS node and a non-PRS node having a node address greater than a node address of the PRS node. That is, the node addresses of the non-PRS nodes 130 and 135 are 6 and 7, respectively, and the node addresses of the relay selector nodes 120 and 125 are 4 and 5, respectively. Thus, each of the node addresses of the non-PRS nodes 130 and 135 is greater than each of the node addresses of the PRS nodes 120 and 125.
As a result, each link of the wireless mesh network 100 may be identified and link-state information associated with each link may reported by one primary relay node. Thus, the primary relay nodes 115, 140, and 160 may reduce the overhead required to distribute the link-state information across the wireless mesh network 100 to the plurality of mesh nodes 102 as described herein.
In
The primary relay nodes 115, 140, and 160 may avoid reporting duplicate link-state information by identifying links as described above. The primary relay nodes 115, 140, and 160 may also reduce the overhead to distribute the link-state information associated with the wireless mesh network 100. For example, the primary relay node 115 may generate a raw link-state list (e.g., one shown as 500 in
Based on the raw link-state list 500, the primary relay node 115 may generate an adjacent bit array (e.g., one shown as 600 in
Each link of the neighborhood 170 may correspond to a one-bit box in the adjacent bit array 600. For example, a numeral one (“1”) may be used to indicate a link between two nodes. In one example, the link 323 between the nodes 115 and 125 (e.g., addresses 3 and 5, respectively) may be indicated in the box (3, 5) with a numeral one (“1”). In another example, the link 325 between the nodes 155 and 165 (e.g., node addresses 11 and 13, respectively) may be indicated in the box (11, 13) with a numeral one (“1”). Otherwise, a numeral zero (“0”) may be used to indicate a lack of a link between two node addresses. For example, the box (5, 7) may include a zero to indicate that a link fails to exist between the nodes 125 and 135 (e.g., node addresses 5 and 7, respectively). Likewise, the box (7, 13) may include a zero to indicate that a link fails to exist between the nodes 135 and 165 (e.g., node addresses 7 and 13, respectively).
To avoid reporting duplicate link-state information, some links may not be indicated in the adjacency bit array 600 (e.g., shown as shaded boxes). For example, a link between the nodes 125 and 115 (e.g., addresses 5 and 3, respectively) may be the same as the link 323 between the nodes 115 and 125. Thus, the box (5, 3) may be shaded because the box (3, 5) may represent the link 323. In a similar manner, the box (13, 7) may be shaded because the box (7, 13) may represent the same combination of node addresses. The methods and apparatus described herein are not limited in this regard.
Based on the adjacency bit array 600, the primary relay node 115 may generate a link-state message (e.g., one shown as 700 in
The adjacency bit array field 720 may correspond to the adjacency bit array 600. For example, the adjacency bit array 600 may be represented by a hexadecimal value based on the one-bit boxes in the matrix. That is, the adjacency bit array 600 may be represented by a binary value of 1000001111 with the least significant bit represented by the box (3, 5) (e.g., “1O”) and the most significant bit represented by the box (11, 13) (e.g., “19”). Accordingly, the binary value 1000001111 may be represented by a hexadecimal value of 020F.
The metric field 730 may include a metric associated with each link of the neighborhood associated with the primary relay node 115. For example, the metric field 730 may include the metrics m(323), m(324), m(321), m(322), and m(325) as indicated by the raw link-state list 500 (
Although the examples in connections with
In particular,
Further, although a particular order of actions is illustrated in
In the example of
Based on the neighbor table, the primary relay node 200 (e.g., via the identifier 230) may identify one or more links of a neighborhood associated with the primary relay node 200 (block 820). For example, the primary relay node 200 may identify: (1) a link associated with the primary relay node and a relay selector node that selected the mesh node 200 to operate as a primary relay node where the mesh node 200 may not be the primary relay selector of a neighboring node or the mesh node 200 may have an address smaller than an address of the neighboring node, (2) a link associated with the primary relay node and a non-relay selector node having an address greater than an address of the primary relay node where the mesh node 200 may not be the primary relay selector of a neighboring node, (3) a link associated with two relay selector nodes that selected the mesh node 200 to operate as a primary relay node, and (4) a link associated with a relay selector node that selected the mesh node 200 to operate as a primary relay node and a non-relay selector node having a node address greater than a node address of the relay selector node where the relay selector node is not a primary relay node.
Accordingly, the primary relay node 200 (e.g., via the generator 240) may generate a link-state message having link-state information associated with each of the identified links (block 830). For example, the primary relay node 200 may generate a raw link-state list (e.g., the raw link-state list 500 of
The primary relay node 200 may transmit the link-state message to the plurality of mesh nodes 102 in the wireless mesh network 100 (block 840). As a result, the primary relay nodes such as 115, 140, and 160 of the wireless mesh network 100 may avoid distributing duplicate link-state information. The methods and apparatus described herein are not limited in this regard;
Although the methods and apparatus disclosed herein are well suited for wireless mesh networks, the methods and apparatus disclosed herein are readily applicable to many other types of communication networks. For example, the methods and apparatus disclosed herein may be used to implement wireless personal area networks (WPANs), wireless local area networks (WLANs), wireless metropolitan area networks (WMANs), and/or wireless wide area networks (WWANs).
The processor system 2000 illustrated in
The memory controller 2012 may perform functions that enable the processor 2020 to access and communicate with a main memory 2030 including a volatile memory 2032 and a non-volatile memory 2034 via a bus 2040. The volatile memory 2032 may be implemented by Synchronous Dynamic Random Access Memory (SDRAM), Dynamic Random Access Memory (DRAM), RAMBUS Dynamic Random Access Memory (RDRAM), and/or any other type of random access memory device. The non-volatile memory 2034 may be implemented using flash memory, Read Only Memory (ROM), Electrically Erasable Programmable Read Only Memory (EEPROM), and/or any other desired type of memory device.
The processor system 2000 may also include an interface circuit 2050 that is coupled to the bus 2040. The interface circuit 2050 may be implemented using any type of interface standard such as an Ethernet interface, a universal serial bus (USB), a third generation input/output interface (3GIO) interface, and/or any other suitable type of interface.
One or more input devices 2060 may be connected to the interface circuit 2050. The input device(s) 2060 permit an individual to enter data and commands into the processor 2020. For example, the input device(s) 2060 may be implemented by a keyboard, a mouse, a touch-sensitive display, a track pad, a track ball, an isopoint, and/or a voice recognition system.
One or more output devices 2070 may also be connected to the interface circuit 2050. For example, the output device(s) 2070 may be implemented by display devices (e.g., a light emitting display (LED), a liquid crystal display (LCD), a cathode ray tube (CRT) display, a printer and/or speakers). The interface circuit 2050 may include, among other things, a graphics driver card.
The processor system 2000 may also include one or more mass storage devices 2080 to store software and data. Examples of such mass storage device(s) 2080 include floppy disks and drives, hard disk drives, compact disks and drives, and digital versatile disks (DVD) and drives.
The interface circuit 2050 may also include a communication device such as a modem or a network interface card to facilitate exchange of data with external computers via a network. The communication link between the processor system 2000 and the network may be any type of network connection such as an Ethernet connection, a digital subscriber line (DSL), a telephone line, a cellular telephone system, a coaxial cable, etc.
Access to the input device(s) 2060, the output device(s) 2070, the mass storage device(s) 2080 and/or the network may be controlled by the I/O controller 2014. In particular, the I/O controller 2014 may perform functions that enable the processor 2020 to communicate with the input device(s) 2060, the output device(s) 2070, the mass storage device(s) 2080 and/or the network via the bus 2040 and the interface circuit 2050.
While the components shown in
Although certain example methods, apparatus, and articles of manufacture have been described herein, the scope of coverage of this disclosure is not limited thereto. On the contrary, this disclosure covers all methods, apparatus, and articles of manufacture fairly falling within the scope of the appended claims either literally or under the doctrine of equivalents. For example, although the above discloses example systems including, among other components, software or firmware executed on hardware, it should be noted that such systems are merely illustrative and should not be considered as limiting. In particular, it is contemplated that any or all of the disclosed hardware, software, and/or firmware components could be embodied exclusively in hardware, exclusively in software, exclusively in firmware or in some combination of hardware, software, and/or firmware.