US20090094349A1 - Device roaming on a zigbee network - Google Patents

Device roaming on a zigbee network Download PDF

Info

Publication number
US20090094349A1
US20090094349A1 US12/075,731 US7573108A US2009094349A1 US 20090094349 A1 US20090094349 A1 US 20090094349A1 US 7573108 A US7573108 A US 7573108A US 2009094349 A1 US2009094349 A1 US 2009094349A1
Authority
US
United States
Prior art keywords
network
zigbee
available
networks
message
Prior art date
Legal status (The legal status 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 status listed.)
Abandoned
Application number
US12/075,731
Inventor
Darin William Smith
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
AMX LLC
Original Assignee
AMX LLC
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 AMX LLC filed Critical AMX LLC
Priority to US12/075,731 priority Critical patent/US20090094349A1/en
Assigned to AMX, LLC reassignment AMX, LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: SMITH, DARIN WILLIAM
Assigned to JPMORGAN CHASE BANK, N.A., AS ADMINISTRATIVE AGENT reassignment JPMORGAN CHASE BANK, N.A., AS ADMINISTRATIVE AGENT SECURITY AGREEMENT Assignors: AMX LLC
Publication of US20090094349A1 publication Critical patent/US20090094349A1/en
Assigned to AMX LLC reassignment AMX LLC RELEASE OF SECURITY AGREEMENT RECORDED AT REEL/FRAME 020941/0884 Assignors: JPMORGAN CHASE BANK, N.A.
Abandoned legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/08Arrangements for detecting or preventing errors in the information received by repeating transmission, e.g. Verdan system
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/66Arrangements for connecting between networks having differing types of switching systems, e.g. gateways
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/12Arrangements for detecting or preventing errors in the information received by using return channel
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/50Queue scheduling
    • H04L47/62Queue scheduling characterised by scheduling criteria
    • H04L47/625Queue scheduling characterised by scheduling criteria for service slots or service orders
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W28/00Network traffic management; Network resource management
    • H04W28/02Traffic management, e.g. flow control or congestion control
    • H04W28/06Optimizing the usage of the radio link, e.g. header compression, information sizing, discarding information
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W28/00Network traffic management; Network resource management
    • H04W28/02Traffic management, e.g. flow control or congestion control
    • H04W28/10Flow control between communication endpoints
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/80Services using short range communication, e.g. near-field communication [NFC], radio-frequency identification [RFID] or low energy communication
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W76/00Connection management
    • H04W76/10Connection setup
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W84/00Network topologies
    • H04W84/18Self-organising networks, e.g. ad-hoc networks or sensor networks
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W88/00Devices specially adapted for wireless communication networks, e.g. terminals, base stations or access point devices
    • H04W88/16Gateway arrangements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W92/00Interfaces specially adapted for wireless communication networks
    • H04W92/02Inter-networking arrangements
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D30/00Reducing energy consumption in communication networks
    • Y02D30/70Reducing energy consumption in communication networks in wireless communication networks

Definitions

  • the present invention relates in general to the field of Zigbee protocols, and, more particularly, the present invention is related to a system, method and computer readable medium for providing enhanced Zigbee related functionality.
  • Zigbee is a suite of protocols, based on the EEE 802.15.4 standard, designed for a low-data-rate, low-power wireless personal area network (“WPAN”). While Zigbee has a lower data transfer rate than that in other wireless LAN or Bluetooth technologies, it has an advantage such that the power consumption is considerably lower. Zigbee may be used to radio-control everything from light illumination to a home security system.
  • WPAN wireless personal area network
  • the IEEE 802.15.4 standard utilizes a 64-bit unique identifying code, known as an extended unique identifier (“EUI”), to uniquely identify each device in the Zigbee network.
  • EUI is similar to an Ethernet media access control (“MAC”) address, which is a unique identifier for a network interface (or a layer of addressing on a network).
  • MAC media access control
  • the EUI is exchanged for a 16-bit short address, known in Zigbee as a node ID.
  • Using a node ID allows messages to be reduced by 48 bits, while still supporting addressing of up to 65,535 devices in the Zigbee network.
  • a node ID is not guaranteed to be unique within a Zigbee network, which may result in conflicts associated with addressing devices within the Zigbee network.
  • a typical Zigbee network 200 such as shown in FIG. 11 has one or more nodes arranged in an appropriate network structure.
  • Common Zigbee network structures include, without limitation, a star structure, mesh structure and cluster tree.
  • the network 200 is illustrated as a tree structure.
  • the parent of all of the nodes in a Zigbee network is known as a Zigbee network coordinator 213 .
  • the Zigbee network coordinator 213 is responsible for maintaining the top-level routing tables for the Zigbee network, and for forming the Zigbee network as new devices join.
  • At the end of the network structure 200 are end-devices 212 .
  • An end device 212 is a device residing in a Zigbee network that performs useful end-user functions within the Zigbee network. Such devices include remote controls, light switches, light fixtures and the like. Typically, an end device will include a processor 217 , memory 214 , transmitter 215 and receiver 216 . The end devices, such as end device 212 a may communicate directly with the network coordinator 210 or may communicate through routers 242 . The routers 242 provide additional message routing between the end-devices and the network coordinator, thereby providing an expanded network.
  • a gateway 214 is a device capable of translating between the Zigbee network 200 and a peripheral network 205 and representing devices from one network to the other.
  • An end device 212 connects to a Zigbee network by scanning a network space for beacons identifying available Zigbee networks, as defined in the Zigbee specification and the IEEE 802.15.4 specification.
  • a network connection routine then follows in which the routing tables of the network coordinator 213 are updated with the end device information.
  • the end device 212 now registered on the network, is then able to perform its intended network functions.
  • a method of roaming on a Zigbee network using a Zigbee end device comprises determining available Zigbee networks within a network space; selecting one of said available Zigbee networks; and joining said end device to said selected Zigbee network.
  • a device for use on a Zigbee network comprises at least one processor, wherein the processor is configured for determining available Zigbee networks within a network space; selecting one of said available Zigbee networks; and joining the device to said selected Zigbee network.
  • a computer readable medium comprises instructions executable on a device of a Zigbee network, the instructions for determining available Zigbee networks within a network space; selecting one of said available Zigbee networks; and joining said device to said selected Zigbee network.
  • FIG. 1 is a block diagram illustrating an end-device request to join a Zigbee network message flow in accordance with an embodiment of the present invention
  • FIG. 2 is a block diagram illustrating an end-device short address check message flow in accordance with an embodiment of the present invention
  • FIG. 3 is a block diagram illustrating a router device short address check message flow in accordance with an embodiment of the present invention
  • FIGS. 4 and 5 are block diagrams illustrating a periodic heartbeat message flow in accordance with an embodiment of the present invention
  • FIGS. 6 and 7 are block diagram illustrating a wake up notification message flow in accordance with an embodiment of the present invention.
  • FIG. 8 is a block diagram illustrating a Zigbee gateway connecting a non-Zigbee external network to a Zigbee network in accordance with an embodiment of the present invention
  • FIGS. 9A-9F are block diagrams illustrating exemplary Zigbee message formats in accordance with an embodiment of the present invention.
  • FIG. 10 is a block diagram illustrating a Zigbee gateway in accordance with an embodiment of the present invention.
  • FIG. 11 represents a typical Zigbee network arrangement
  • FIG. 12 represents a flow diagram for a network time synchronization process
  • FIGS. 13 to 15 represent flow diagrams showing methods for enhancing reliable communication on a Zigbee network
  • FIGS. 16 to 19 show network connections for a device roaming on a Zigbee network
  • FIG. 20 shows a processor and memory of a Zigbee network device executing an instruction set.
  • the gateway 100 may include, without limitation, a main processor 102 having one or more memory devices 104 and/or 106 , a serial port connected to an external processor 108 , a serial port debug header 110 , and an Ethernet connection 112 .
  • the main processor 102 is an AMCC PPC405EP 32-bit PowerPC processor.
  • the 405EP includes an integrated 32-bit wide SDRAM controller, a 32-bit wide PCI bus, 16-bit wide peripheral bus, two 10/100 Ethernet MACs, 32 general purpose I/Os (GPIOs), two serial ports, and an 12C port.
  • the 405EP is clocked using a 33 MHz SYS_CLOCK.
  • the PPC runs at 133 MHz with a 66 MHz SDRAM bus speed.
  • the 405EP includes 16 Mbyte of external SDRAM 106 and 16 Mbyte of external flash 104 .
  • the first MAC is connected to a Micrel KS8721BL 10/100 Ethernet PHY and provides a 10/100 Ethernet port for the gateway 100 .
  • a serial port may optionally be connected to a debug header and used as an interface to an operating system monitor.
  • the external processor 108 is an Ember EM25016-bit XAP2b microprocessor that includes on-board RAM and flash memory.
  • the XAP2b microprocessor runs the Zigbee protocol stack and is customized to run propriety commands from AMX LLC.
  • Serial port zero of the XAP2b microprocessor is used to communicate with the Zigbee processor 102 .
  • the gateway 100 may be configured to allow Zigbee enabled devices to communicate with an ICSP master.
  • the gateway 100 acts as a gateway to these devices, translating message to and from them.
  • a typical Zigbee network provides a network coordinator 213 as the top level device that builds and controls messaging on the network.
  • the network coordinator 213 interfaces with peripheral networks through a gateway 214 .
  • the functions of the network coordinator are provided by the processors and memory of the gateway 100 shown in FIG. 10 . That is, the gateway 100 serves the dual roles of network coordinator and gateway.
  • the network coordinator 12 may be separate from the gateway 14 or may be distributed between the gateway 14 and another end-device.
  • An end-device 12 may connect to the gateway 100 and then be represented as a device to a non-Zigbee network (e.g., devices in an Ethernet network). This virtualization of the end-device 12 allows the end-device 12 to act as a wired device even though it is not connected via a wired interface.
  • a non-Zigbee network device may be configured to send messages to the end-device 12 and the end-device 12 may be configured to reply to the non-Zigbee network device via a translation step in the gateway 100 .
  • the proprietary ICSP protocol may be translated in the gateway 100 for communication with non-Zigbee network devices (e.g., AMX equipment). It is to be understood that this virtualization may be extended to support any protocol.
  • FIG. 1 a block diagram illustrating an end-device request to join a Zigbee network message flow in accordance with an embodiment of the present invention is shown.
  • An end-device 12 joins a Zigbee network by sending a request to join the Zigbee network message 16 to the Zigbee gateway 100 .
  • the Zigbee gateway 100 sends a message 18 requesting device information.
  • the end-device 12 then replies by sending relevant device information to the gateway 100 .
  • the device information may include, without limitation, the EUI of the end-device, port, channel, level and the like, of the end-device 12 .
  • the Zigbee gateway 100 After verifying the device information, the Zigbee gateway 100 sends a message 22 indicating that the end-device 12 has successfully joined the Zigbee network, at which time, a short address or Node ID is assigned to the end device and stored in the gateway 100 . The short address is transmitted to the end device 12 in the message 22 .
  • the functions of the network coordinator and gateway are described independently, though they may be provided by a single device, such as the gateway 100 described above.
  • An end device short address may not be unique on a Zigbee network, which may give rise to device addressing conflicts. In order to address these conflicts, a device may periodically seek to verify its uniqueness on the network, or at least with respect to its parent.
  • FIG. 2 a block diagram illustrating an end-device short address check message flow between an end-device 12 and a parent node 15 in accordance with an embodiment of the present invention is shown. It is to be understood that the parent node 15 is typically either the network coordinator 14 or a router device 42 .
  • an end-device 12 Periodically, an end-device 12 , such as a mobile device, sends a short address request message 32 to its parent node 15 requesting the EUI of the short address that was assigned to the end-device 12 when it joined the Zigbee network. Upon a successful lookup by the parent 15 , the EUI corresponding to the short address is sent to the end-device 12 via short address reply message 34 .
  • the parent node 15 may retrieve the EUI from a lookup table in its own memory. Alternatively, the parent node 15 may retrieve the EUI by requesting the EUI from a higher order parent node, eg. a router may retrieve the EUI from the network coordinator or the gateway.
  • short address request message 32 includes a 2-byte data field 33 that contains the current node ID, ie short address, of the end-device 12 .
  • Reply message 34 includes a 10-byte data field 35 which is separated into a 2-byte node ID 35 a for the end-device 12 and an 8-byte EUI 35 b .
  • the end-device 12 does nothing. If the retrieved EUI does not match the stored EUI, then the short address assigned to the end device is considered not unique on the Zigbee network, at least with respect to the parent node 15 .
  • the end-device 12 therefore performs a network connection routine to attempt to rejoin the network.
  • the end device is assigned a new short address, which is associated with the EUI and stored in a lookup table on the Zigbee network. In performing the network connection routine, the end device 12 may connect through a second parent node.
  • the end-device 12 may request a new parent 15 . It is to be understood that the message formats for the short address request message 32 and the short address reply message 34 are provided for exemplary purposes and that other message formats are possible within the scope of the invention.
  • FIG. 3 a block diagram illustrating a router device short address check message flow in accordance with an embodiment of the present invention is shown.
  • the router device 42 sends a short address request message 32 to its parent 15 requesting the EUI of the short address that was assigned to router device 42 when it joined the Zigbee network.
  • the EUI corresponding to the short address is sent to the router device 42 via message 34 .
  • the router device 42 receives the EUI corresponding to the short address from its parent 15 , the received EUI is compared against the current EUI of the router device 42 . If the EUIs match, the router device 42 does nothing. If the EUIs are different, the router device 42 attempts to find a valid routing path. If no EUI is sent from the parent 15 within a predefined period of time or a specified number of attempts, the router device 42 attempts to find a valid routing path.
  • a periodic heartbeat message 52 is utilized by an end-device 12 to poll a Zigbee gateway 14 for a status.
  • Flags for network states (Zigbee network Present, Device Defined on Network, Master Controller Present, Online with Master, Firmware updates available) are mapped in a binary field as described in Table 1 below.
  • the end-device 12 periodically sends a heartbeat message 52 requesting a current state to the Zigbee network coordinator 13 .
  • the coordinator 13 replies with a binary value containing the most current values for all the flags set via heartbeat reply message 54 .
  • the coordinator 13 If the heartbeat message 52 goes unanswered for a configurable period of time, the connection to the network is considered dead, and the end-device 12 performs a network connection routine to re-acquire the network connection. If the coordinator 13 does not receive a heartbeat message 52 from the end-device 12 within a configurable period of time, the end-device 12 is considered as dead, and the coordinator 13 clears the flags and stops routing traffic from any peripheral non-Zigbee network. In this situation, the coordinator 13 will not answer future heartbeat messages 52 from the end-device 12 . This will force the end-device 12 to formally re-acquire a network connection, at which time the gateway 14 again will represent the end-device 12 to peripheral networks and continue operations as normal.
  • the heartbeat message 52 may be configured to be sent at a different polling rate when the end-device 12 is awake, than when the end-device 12 is in a power save or sleep mode.
  • heartbeat message 52 includes a 9-byte data field 53 which is separated into a 1-byte link quality from parent 53 a , a 1-byte link quality to parent 53 b , a 2-byte node ID 53 c , a 4-byte last round-trip time to gateway 53 d and a 1-byte heartbeat status 53 e .
  • heartbeat reply message 54 includes a 9-byte data field 55 which is separated into a 1-byte link quality from parent 55 a , a 1-byte link quality to parent 55 b , a 2-byte node ID 55 c , a 4-byte last round-trip time to gateway 55 d and a 1-byte heartbeat status 55 e.
  • the heartbeat status fields 53 e and 55 e contain multiple flags as defined in the Table 1:
  • the Zigbee gateway 14 described herein is an aggregator of end-devices 12 and routers 42 in a Zigbee network, and a translator/bridge to non-Zigbee networks 92 or to devices in a non-Zigbee network 92 .
  • Non-Zigbee networks include, without limitation, Ethernet, Token Ring, wireless networks (such as GSM and CDMA networks), fiber optic networks and the like.
  • FIG. 8 a block diagram illustrating a Zigbee gateway 14 connecting a non-Zigbee network 92 to a Zigbee network 94 in accordance with an embodiment of the present invention is shown.
  • Data from the non-Zigbee network 92 is routed to an appropriate end-device 12 within the Zigbee network, through the network coordinator 13 and any routers 42 required, and vice-versa.
  • the gateway 14 may be configured to appear to the non-Zigbee network as a fully-functional and online end device with advertised services. That is, the gateway provides a virtual end device, representing other end devices to peripheral networks.
  • messages bound for an end-device 12 a - 12 e that do not require traffic to be sent to the actual end-device 12 a - 12 e may be directly answered by the gateway 14 and/or network coordinator 13 .
  • the gateway 14 or coordinator 13 may maintain the last-known status, eg online, offline, and advertised services for each end-device 12 a - 12 e , and answer queries for that information from a device in a non-Zigbee network 92 without involving the actual end-device 12 a - 12 e . This reduces the communication over the Zigbee network 94 and the usage of the airtime thereof. Further, when a non-Zigbee network 92 device that is communicably coupled to the gateway 14 sends a message to the gateway 14 , the gateway 14 may be configured to provide appropriate device information to the requesting device without requiring the gateway 14 to directly interact with each end-device 12 a - 12 e .
  • Non-Zigbee network requesting devices include, without limitation, control masters (not shown).
  • the gateway 14 responds to the status request messages without communicating with the end device, the Zigbee network does not get “flooded” with messages, thereby, alleviating bandwidth and efficiency constraints within the Zigbee network.
  • a further advantage of performing end device responses at the gateway is that an end device need not be unnecessarily woken from a sleep or power saving mode.
  • the Zigbee network described herein may be configured to synchronize its timekeeping mechanism (e.g., real-time clock, operating system timer and the like) with a non-Zigbee network clock, such as the time from a network time protocol (“NTP”), a proprietary protocol including ICSP, and the like.
  • NTP network time protocol
  • the gateway 14 or another Zigbee network device, may be configured to act as a time-synchronization agent for a Zigbee end-device 12 in communication with the gateway 14 by servicing any requests for the current time from that end-device 12 , rather than transmitting the time request to the non-Zigbee network clock.
  • Average latency through the Zigbee network may optionally be taken into consideration to provide a closer estimate.
  • the end-devices 12 a - 12 e may be configured to periodically poll for the time.
  • the gateway 14 may be configured to notify each end-device 12 a - 12 e at the next polltime (if in a polling network) for each of the respective end-devices 12 a - 12 e or at the next available time-slot (in a non-polling network), servicing end-devices 12 a - 12 e in a round-robin fashion, ie sequentially.
  • a message flow 120 for synchronizing the end devices is shown in FIG. 12 .
  • the gateway polls a clock of a peripheral network for a time and then synchronizes the network clock to the peripheral network time at step 122 .
  • An end device may poll for the time at step 123 and by synchronized to the Zigbee network clock at step 124 .
  • the Zigbee network may sequentially synchronize the end device clocks to the Zigbee network clock without requiring a polling signal from the end device (step 125 ).
  • gateway 14 has been described as acting as the time synchronization agent, the person skilled in the art will readily understand that other devices on the Zigbee network may similarly act as the time synchronization agent.
  • the sender may be configured to maintain a message to be sent in a queue when the first attempt to send is made.
  • the message is associated with a maximum number of retries. If a MAC-level acknowledge is not received within a timeframe for the network (for example, with Zigbee, approximately 1.2 seconds per hop), the message is allowed to continue to exist in a retry queue.
  • the retry queue may be implemented as a separate thread that runs periodically, and resends the message.
  • the message may then be deleted and, optionally, network statistics may be updated to reflect the failure.
  • the flow diagram 130 of FIG. 13 shows one embodiment of a method for improving reliable communication on the Zigbee network.
  • a message is sent from a device which may be any suitable device on the network having a transmitter, processor and memory, and can include end devices, routers, the coordinator or the gateway.
  • the transmitted message is stored in a re-try queue within the device (step 132 ) while awaiting receipt of a delivery acknowledgement message 133 . If the delivery acknowledgement is received, the message is deleted from the retry queue 134 .
  • the re-try queue can be set to execute at a predetermined period, or at an available time in the communication routines of the device.
  • any messages in the queue are re-sent and if a successful acknowledgement message (step 136 ) is received, the respective message is deleted from the re-try queue (step 134 ).
  • the device increments a re-try counter (step 137 ) for that message.
  • the device checks to see if a maximum number of re-tries has been exceeded (step 138 ), in which case, the message is deleted from the re-try queue. If the message is able to be resent, the message remains in the re-try queue awaiting the next iteration of the re-try queue.
  • a message is processed, at step 141 to determine whether it has a message order requirement. If the message has no message order requirement, the message may be transmitted and transferred to the re-try queue 145 described above thereby allowing the next message to be sent. However, if the message is determined to have a message order requirement, the message is transmitted 142 , and if no acknowledgement is received (step 143 ), the device loops 149 with the message at the head of the send queue.
  • the device checks whether the maximum number of re-tries has been exceeded (step 146 ) before incrementing the re-try counter and re-transmitting the message (step 142 ).
  • the device exits the loop 149 when either a successful acknowledgement message is received or the message has been re-transmitted a maximum number of times.
  • the message is deleted from the send queue (step 144 ) and the device returns to step 141 to process the next message.
  • messages having a related message order requirement may be batched to ensure correct order transmission and reliable communication on the network.
  • a message flow 150 commences by transmitting the lead message in a send queue. Messages that are successfully sent 152 are deleted from the send queue 153 and then the next message is transmitted. If the message is not successfully sent and has no message order requirement 154 , the message may be transferred to a re-try queue 155 as described previously so that attempts to re-send the message can be made when the re-try queue executes. If the unsuccessful message does have a message order requirement, the message is transferred to a batch re-send queue 156 together with any following messages from the batch.
  • the batch re-send queue may execute 157 using the loop 149 described with respect to FIG. 14 , to ensure that the messages from the batch are sent in correct order. That is, each message in the batch is transmitted and re-transmitted until successful or a maximum number of re-tries has been attempted.
  • An advantage of this embodiment is that because the loop only executes on the batch re-send queue, messages in the send queue that are not part of the batch may be sent without being delayed by attempts to re-send the batch messages.
  • the batch re-try queue is described herein as being separate to the re-try queue for the purposes of the example. However, the skilled addressee will readily understand that the two queues may be combined with additional loop processing for messages having a message order requirement.
  • One or more of the end-devices 12 may be configured to periodically operate in a power saving mode to save power.
  • a power saving mode may be, for example, a sleep mode or a reduced functionality mode. It is possible that a non-Zigbee network device may attempt to interact with an end-device 12 while it is in a power saving mode. In some situations, it may be desirable to not wake the end-device 12 while in other situations, it may be desirable to wake the end-device 12 .
  • the gateway 14 may be configured to identify a sleeping end-device 12 as “offline” in status queries from the non-Zigbee network.
  • the gateway 14 maintains at least some of the last reported device information from the end-device 12 .
  • the end-device 12 may be configured to report such device information periodically, for example as the periodic heartbeat messages 52 described above ( FIG. 7 ), and at the time it enters a power saving mode to ensure that the most current device information is maintained in the coordinator 13 and/or gateway 14 .
  • the last reported device information from the end-device may also be used to support fast reconnection times when an end-device 12 wakes up.
  • the gateway 14 may be configured to interact with the non-Zigbee network on behalf of the end-device 12 , as described above, for some or all of the message communication.
  • the non-Zigbee network may believe that it is interacting with an end-device 12 when, in fact, the end-device 12 is in a power save or sleep mode.
  • the non-Zigbee network may never be aware that the end-device 12 was or is in a power save or sleep mode.
  • messages that are required to be sent to the end device 12 while the end device is in a power saving mode are cached in the gateway memory and transmitted to the end device 12 upon receipt of the wake notification from the end device.
  • FIGS. 6 and 7 block diagrams illustrating a wake up notification message flow in accordance with an embodiment of the present invention are shown.
  • the end-device 12 When a sleeping end-device 12 exits power save or sleep mode and enters an online state, the end-device 12 sends a wake notification message 72 to the coordinator 13 . In response, the coordinator 13 sends a wake acknowledgement message 74 .
  • FIGS. 9E and 9F block diagrams illustrating exemplary Zigbee message formats in accordance with an embodiment of the present invention for the wake notification message 72 and the wake acknowledgement message 74 are shown.
  • Wake acknowledgement message 74 includes a 1-byte binary status field 75 which contains multiple flags, as defined in the Table 1 above.
  • end-device 12 Upon receipt of the wake acknowledgement message 74 , end-device 12 evaluates the “defined” flag portion of the status field 35 , as defined in Table 1 above. If the “defined” flag is not set, then the end-device 12 may be required to formally re-acquire the connection as previously discussed.
  • the coordinator 13 may be configured to automatically mark the end-device 12 as “online” upon receipt of the wake notification message 72 . If this is the case, if the “defined” flag is set, then the end-device 12 may possibly do nothing. Otherwise, the end-device 12 may optionally be required to send an additional message to the coordinator 13 in order to inform the coordinator 13 that the end-device 12 is exiting the power save mode and entering an online mode. In either case, upon notification that the end-device 12 is exiting power save mode and entering an online mode, the gateway may be configured to inform the non-Zigbee network of the updated status of the end-device 12 .
  • the gateway 14 and/or coordinator 13 may also resend cached device information to the end-device 12 via message 76 , if necessary.
  • the cached device information may include any messages that were received by the gateway from the non-Zigbee network while the end device 12 was in sleep mode. It is to be understood that the message formats for the wake notification message 72 and the wake acknowledgement message 74 are provided for exemplary purposes and that other message formats are possible within the scope of the invention.
  • FIG. 16 shows an end-device 12 located in a network space having multiple Zigbee networks 161 , 162 , 163 , 164 .
  • the end device 12 is configured to determine a list of Zigbee networks it is interested or authorized to join. The list may be configured either on the end-device 12 itself, or sent from another device utilizing the Zigbee gateway 14 .
  • Such devices may include end-devices 12 or non-Zigbee network devices.
  • the end device 12 is initially connected to network 161 .
  • the end device is portable, and in FIG. 17 , has roamed out of the network space of network 161 .
  • the end device 12 scans the network space for beacons representing available, joinable Zigbee networks.
  • the end device identifies beacons, and associated network identities, for each of the available networks 162 , 163 , 164 .
  • the beacons and their network identities allow the end device to determine which of the available networks is provided within the stored list of networks that the end device is able to join. For example, the end device may determine that network 164 , shown in ghosted outline, is unavailable for joining. Networks 162 , 163 are therefore available for joining, and the device selects one of these eg network 163 and undertakes the remaining connection procedure with that network.
  • the available, joinable Zigbee networks are ordered by connection quality, and the Zigbee network with the best connection quality is automatically selected and joined by the mobile end-device 12 .
  • the connection quality may be measured by bit error rate or by some other quality assessment such as a received signal strength indication.
  • the end device 12 having disconnected from network 161 evaluates the airspace as having networks 162 , 163 , 164 that are each within the list of joinable networks and are presently available to the end device 12 .
  • Network 162 is determined as having the highest connection quality, and so end device 12 connects to network 162 .
  • the list of joinable networks maintained by the end device includes a preference rank.
  • the end device selects the most preferred network, eg the highest ranked network, with a connection quality above a defined threshold. For example, in FIG. 19 , the end device 12 , having disconnected from network 161 evaluates the airspace as having networks 162 , 163 , 164 that each meet the minimum connection quality threshold as indicated by connections 165 , 166 and 167 . Out of these three networks, the network 164 has the highest preference ranking, and therefore the end device selects the connection 167 .
  • the end device may be configured to periodically seek a more preferred network, eg as determined by connection quality or network rank, irrespective of whether the current network connection has fallen below a minimum connection quality.
  • FIG. 20 depicts a processor 96 of the end device 12 operatively associated with a memory 97 .
  • the processor 96 is configured to execute an instruction set as follows.
  • the processor seeks out whether any networks are available within the area for the end device to join.
  • the processor determines whether the end device is authorized to join the available networks by comparing a network identity to a list of authorized network identities stored in memory 97 . The processor then selects one of the available, joinable networks (step 303 ) and then joins the network (step 304 ) in the manner described above.

Abstract

An end device in a Zigbee network space is configured to roam between available Zigbee networks. When the end device determines that a quality of a current connection has fallen below a minimum threshold, the end device evaluates the network space for available networks. The end device stores a list of Zigbee networks that it is authorized to join and joins the most preferred Zigbee network, as determined by, for example, a signal strength or a stored network ranking.

Description

    CROSS REFERENCE TO RELATED APPLICATIONS
  • The present patent application is related to and claims the benefit of provisional patent application No. 60/618,392, filed 14 Mar. 2007, titled Method and System for Zigbee and Ethernet Gateways, the entire contents of which are incorporated by reference herein.
  • FIELD OF THE INVENTION
  • The present invention relates in general to the field of Zigbee protocols, and, more particularly, the present invention is related to a system, method and computer readable medium for providing enhanced Zigbee related functionality.
  • BACKGROUND OF THE INVENTION
  • Zigbee is a suite of protocols, based on the EEE 802.15.4 standard, designed for a low-data-rate, low-power wireless personal area network (“WPAN”). While Zigbee has a lower data transfer rate than that in other wireless LAN or Bluetooth technologies, it has an advantage such that the power consumption is considerably lower. Zigbee may be used to radio-control everything from light illumination to a home security system.
  • The IEEE 802.15.4 standard utilizes a 64-bit unique identifying code, known as an extended unique identifier (“EUI”), to uniquely identify each device in the Zigbee network. An EUI is similar to an Ethernet media access control (“MAC”) address, which is a unique identifier for a network interface (or a layer of addressing on a network). According to the IEEE 802.15.4 standard, the EUI is exchanged for a 16-bit short address, known in Zigbee as a node ID. Using a node ID allows messages to be reduced by 48 bits, while still supporting addressing of up to 65,535 devices in the Zigbee network. However, a node ID is not guaranteed to be unique within a Zigbee network, which may result in conflicts associated with addressing devices within the Zigbee network.
  • A typical Zigbee network 200 such as shown in FIG. 11 has one or more nodes arranged in an appropriate network structure. Common Zigbee network structures include, without limitation, a star structure, mesh structure and cluster tree. For the purpose of clarity, the network 200 is illustrated as a tree structure. The parent of all of the nodes in a Zigbee network is known as a Zigbee network coordinator 213. The Zigbee network coordinator 213 is responsible for maintaining the top-level routing tables for the Zigbee network, and for forming the Zigbee network as new devices join. At the end of the network structure 200 are end-devices 212. An end device 212 is a device residing in a Zigbee network that performs useful end-user functions within the Zigbee network. Such devices include remote controls, light switches, light fixtures and the like. Typically, an end device will include a processor 217, memory 214, transmitter 215 and receiver 216. The end devices, such as end device 212 a may communicate directly with the network coordinator 210 or may communicate through routers 242. The routers 242 provide additional message routing between the end-devices and the network coordinator, thereby providing an expanded network. A gateway 214 is a device capable of translating between the Zigbee network 200 and a peripheral network 205 and representing devices from one network to the other.
  • An end device 212 connects to a Zigbee network by scanning a network space for beacons identifying available Zigbee networks, as defined in the Zigbee specification and the IEEE 802.15.4 specification. A network connection routine then follows in which the routing tables of the network coordinator 213 are updated with the end device information. The end device 212, now registered on the network, is then able to perform its intended network functions.
  • There currently exists various limitations associated with Zigbee that are known in the prior art. One such limitation is that the end devices are generally limited to use with a single network. As such, what is needed is a system, method, and computer readable medium for providing improved Zigbee related functionality that overcomes these limitations
  • SUMMARY OF THE INVENTION
  • The present invention seeks to provide enhanced end device functionality in a Zigbee environment by enabling roaming of devices between networks. In one embodiment of the disclosure, a method of roaming on a Zigbee network using a Zigbee end device comprises determining available Zigbee networks within a network space; selecting one of said available Zigbee networks; and joining said end device to said selected Zigbee network.
  • In one embodiment of the disclosure, a device for use on a Zigbee network comprises at least one processor, wherein the processor is configured for determining available Zigbee networks within a network space; selecting one of said available Zigbee networks; and joining the device to said selected Zigbee network.
  • In one embodiment of the disclosure a computer readable medium comprises instructions executable on a device of a Zigbee network, the instructions for determining available Zigbee networks within a network space; selecting one of said available Zigbee networks; and joining said device to said selected Zigbee network.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • A more complete appreciation of the present invention and many of the attendant advantages thereof will be readily obtained as the same becomes better understood by reference to the following detailed description when considered in conjunction with the accompanying drawings, wherein:
  • FIG. 1 is a block diagram illustrating an end-device request to join a Zigbee network message flow in accordance with an embodiment of the present invention;
  • FIG. 2 is a block diagram illustrating an end-device short address check message flow in accordance with an embodiment of the present invention;
  • FIG. 3 is a block diagram illustrating a router device short address check message flow in accordance with an embodiment of the present invention;
  • FIGS. 4 and 5 are block diagrams illustrating a periodic heartbeat message flow in accordance with an embodiment of the present invention;
  • FIGS. 6 and 7 are block diagram illustrating a wake up notification message flow in accordance with an embodiment of the present invention;
  • FIG. 8 is a block diagram illustrating a Zigbee gateway connecting a non-Zigbee external network to a Zigbee network in accordance with an embodiment of the present invention;
  • FIGS. 9A-9F are block diagrams illustrating exemplary Zigbee message formats in accordance with an embodiment of the present invention;
  • FIG. 10 is a block diagram illustrating a Zigbee gateway in accordance with an embodiment of the present invention;
  • FIG. 11 represents a typical Zigbee network arrangement;
  • FIG. 12 represents a flow diagram for a network time synchronization process;
  • FIGS. 13 to 15 represent flow diagrams showing methods for enhancing reliable communication on a Zigbee network;
  • FIGS. 16 to 19 show network connections for a device roaming on a Zigbee network; and
  • FIG. 20 shows a processor and memory of a Zigbee network device executing an instruction set.
  • DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
  • Referring now to the drawings, wherein like reference numerals designate identical or corresponding parts throughout the several views, preferred embodiments of the present invention are described.
  • Referring now to FIG. 10, a block diagram illustrating a Zigbee gateway in accordance with an embodiment of the present invention is shown. The gateway 100 may include, without limitation, a main processor 102 having one or more memory devices 104 and/or 106, a serial port connected to an external processor 108, a serial port debug header 110, and an Ethernet connection 112.
  • In one possible implementation, the main processor 102 is an AMCC PPC405EP 32-bit PowerPC processor. The 405EP includes an integrated 32-bit wide SDRAM controller, a 32-bit wide PCI bus, 16-bit wide peripheral bus, two 10/100 Ethernet MACs, 32 general purpose I/Os (GPIOs), two serial ports, and an 12C port. The 405EP is clocked using a 33 MHz SYS_CLOCK. The PPC runs at 133 MHz with a 66 MHz SDRAM bus speed. The 405EP includes 16 Mbyte of external SDRAM 106 and 16 Mbyte of external flash 104. The first MAC is connected to a Micrel KS8721BL 10/100 Ethernet PHY and provides a 10/100 Ethernet port for the gateway 100. A serial port may optionally be connected to a debug header and used as an interface to an operating system monitor. The external processor 108 is an Ember EM25016-bit XAP2b microprocessor that includes on-board RAM and flash memory. The XAP2b microprocessor runs the Zigbee protocol stack and is customized to run propriety commands from AMX LLC. Serial port zero of the XAP2b microprocessor is used to communicate with the Zigbee processor 102. The gateway 100 may be configured to allow Zigbee enabled devices to communicate with an ICSP master. The gateway 100 acts as a gateway to these devices, translating message to and from them.
  • As described above in relation to FIG. 11, a typical Zigbee network provides a network coordinator 213 as the top level device that builds and controls messaging on the network. The network coordinator 213 interfaces with peripheral networks through a gateway 214. In the presently described embodiment, the functions of the network coordinator are provided by the processors and memory of the gateway 100 shown in FIG. 10. That is, the gateway 100 serves the dual roles of network coordinator and gateway. It will be readily understood by the person skilled in the art alternative embodiments are possible. For example, in other embodiments, the network coordinator 12 may be separate from the gateway 14 or may be distributed between the gateway 14 and another end-device.
  • An end-device 12 may connect to the gateway 100 and then be represented as a device to a non-Zigbee network (e.g., devices in an Ethernet network). This virtualization of the end-device 12 allows the end-device 12 to act as a wired device even though it is not connected via a wired interface. A non-Zigbee network device may be configured to send messages to the end-device 12 and the end-device 12 may be configured to reply to the non-Zigbee network device via a translation step in the gateway 100. For instance, the proprietary ICSP protocol may be translated in the gateway 100 for communication with non-Zigbee network devices (e.g., AMX equipment). It is to be understood that this virtualization may be extended to support any protocol.
  • Zigbee Network Registration
  • Referring now to FIG. 1, a block diagram illustrating an end-device request to join a Zigbee network message flow in accordance with an embodiment of the present invention is shown. An end-device 12 joins a Zigbee network by sending a request to join the Zigbee network message 16 to the Zigbee gateway 100. In response, the Zigbee gateway 100 sends a message 18 requesting device information. The end-device 12 then replies by sending relevant device information to the gateway 100. The device information may include, without limitation, the EUI of the end-device, port, channel, level and the like, of the end-device 12. After verifying the device information, the Zigbee gateway 100 sends a message 22 indicating that the end-device 12 has successfully joined the Zigbee network, at which time, a short address or Node ID is assigned to the end device and stored in the gateway 100. The short address is transmitted to the end device 12 in the message 22.
  • In the remainder of the description and for the purposes of clarity, the functions of the network coordinator and gateway are described independently, though they may be provided by a single device, such as the gateway 100 described above.
  • 802.15.4/Zigbee Short AddressS Verification
  • An end device short address may not be unique on a Zigbee network, which may give rise to device addressing conflicts. In order to address these conflicts, a device may periodically seek to verify its uniqueness on the network, or at least with respect to its parent. Referring now to FIG. 2, a block diagram illustrating an end-device short address check message flow between an end-device 12 and a parent node 15 in accordance with an embodiment of the present invention is shown. It is to be understood that the parent node 15 is typically either the network coordinator 14 or a router device 42. Periodically, an end-device 12, such as a mobile device, sends a short address request message 32 to its parent node 15 requesting the EUI of the short address that was assigned to the end-device 12 when it joined the Zigbee network. Upon a successful lookup by the parent 15, the EUI corresponding to the short address is sent to the end-device 12 via short address reply message 34. The parent node 15 may retrieve the EUI from a lookup table in its own memory. Alternatively, the parent node 15 may retrieve the EUI by requesting the EUI from a higher order parent node, eg. a router may retrieve the EUI from the network coordinator or the gateway.
  • Referring now to FIGS. 9A and 9B, block diagrams illustrating exemplary Zigbee message formats in accordance with an embodiment of the present invention for the short address request message 32 and the short address reply message 34 are shown. According to these message formats, short address request message 32 includes a 2-byte data field 33 that contains the current node ID, ie short address, of the end-device 12. Reply message 34 includes a 10-byte data field 35 which is separated into a 2-byte node ID 35 a for the end-device 12 and an 8-byte EUI 35 b. Once the end-device 12 receives the EUI 35 b corresponding to the short address from its parent 15, the received EUI 35 b is compared against the current EUI of the end-device 12. If the EUIs match, the end-device 12 does nothing. If the retrieved EUI does not match the stored EUI, then the short address assigned to the end device is considered not unique on the Zigbee network, at least with respect to the parent node 15. The end-device 12 therefore performs a network connection routine to attempt to rejoin the network. During the network connection routine, the end device is assigned a new short address, which is associated with the EUI and stored in a lookup table on the Zigbee network. In performing the network connection routine, the end device 12 may connect through a second parent node.
  • If no EUI is sent from the parent 15 within a predefined period of time or a specified number of attempts, the end-device 12 may request a new parent 15. It is to be understood that the message formats for the short address request message 32 and the short address reply message 34 are provided for exemplary purposes and that other message formats are possible within the scope of the invention.
  • Referring now to FIG. 3, a block diagram illustrating a router device short address check message flow in accordance with an embodiment of the present invention is shown. Similar to the processing of the end-device 12 described above with respect to FIG. 2, periodically, the router device 42 sends a short address request message 32 to its parent 15 requesting the EUI of the short address that was assigned to router device 42 when it joined the Zigbee network. Upon a successful lookup by the parent 15 the EUI corresponding to the short address is sent to the router device 42 via message 34. Once the router device 42 receives the EUI corresponding to the short address from its parent 15, the received EUI is compared against the current EUI of the router device 42. If the EUIs match, the router device 42 does nothing. If the EUIs are different, the router device 42 attempts to find a valid routing path. If no EUI is sent from the parent 15 within a predefined period of time or a specified number of attempts, the router device 42 attempts to find a valid routing path.
  • Periodic Heartbeat
  • Referring now to FIGS. 4 and 5, block diagrams illustrating a periodic heartbeat message flow are shown. In order to make communications more efficient with a control system, a periodic heartbeat message 52 is utilized by an end-device 12 to poll a Zigbee gateway 14 for a status. Flags for network states (Zigbee network Present, Device Defined on Network, Master Controller Present, Online with Master, Firmware updates available) are mapped in a binary field as described in Table 1 below. The end-device 12 periodically sends a heartbeat message 52 requesting a current state to the Zigbee network coordinator 13. The coordinator 13 replies with a binary value containing the most current values for all the flags set via heartbeat reply message 54. If the heartbeat message 52 goes unanswered for a configurable period of time, the connection to the network is considered dead, and the end-device 12 performs a network connection routine to re-acquire the network connection. If the coordinator 13 does not receive a heartbeat message 52 from the end-device 12 within a configurable period of time, the end-device 12 is considered as dead, and the coordinator 13 clears the flags and stops routing traffic from any peripheral non-Zigbee network. In this situation, the coordinator 13 will not answer future heartbeat messages 52 from the end-device 12. This will force the end-device 12 to formally re-acquire a network connection, at which time the gateway 14 again will represent the end-device 12 to peripheral networks and continue operations as normal. The heartbeat message 52 may be configured to be sent at a different polling rate when the end-device 12 is awake, than when the end-device 12 is in a power save or sleep mode.
  • Referring now to FIGS. 9C and 9D, block diagrams illustrating exemplary Zigbee message formats in accordance with an embodiment of the present invention for the heartbeat message 52 and the heartbeat reply message 54 are shown. According to these message formats, heartbeat message 52 includes a 9-byte data field 53 which is separated into a 1-byte link quality from parent 53 a, a 1-byte link quality to parent 53 b, a 2-byte node ID 53 c, a 4-byte last round-trip time to gateway 53 d and a 1-byte heartbeat status 53 e. Likewise, heartbeat reply message 54 includes a 9-byte data field 55 which is separated into a 1-byte link quality from parent 55 a, a 1-byte link quality to parent 55 b, a 2-byte node ID 55 c, a 4-byte last round-trip time to gateway 55 d and a 1-byte heartbeat status 55 e.
  • The heartbeat status fields 53 e and 55 e contain multiple flags as defined in the Table 1:
  • TABLE 1
    BINARY
    VALUE DESCRIPTION
    0X01 ZIGBEE NETWORK PRESENT
    0X02 DEVICE PREVIOUSLY DEFINED
    0X04 MASTER CONTROLLER PRESENT
    0X08 DEVICE REPRESENTED TO MASTER
    (ONLINE)
    0X10 FIRMWARE UPDATE AVAILABLE
    0X20 RESERVED (FUTURE USE)
    0X40 RESERVED (FUTURE USE)
    0X80 RESERVED (FUTURE USE)
  • It is to be understood that the message formats for the heartbeat message 52 and the heartbeat reply message 54 are provided for exemplary purposes and that other message formats are possible within the scope of the invention.
  • Zugbee Gateway to Other Network Types
  • The Zigbee gateway 14 described herein is an aggregator of end-devices 12 and routers 42 in a Zigbee network, and a translator/bridge to non-Zigbee networks 92 or to devices in a non-Zigbee network 92. Non-Zigbee networks include, without limitation, Ethernet, Token Ring, wireless networks (such as GSM and CDMA networks), fiber optic networks and the like. Referring now to FIG. 8, a block diagram illustrating a Zigbee gateway 14 connecting a non-Zigbee network 92 to a Zigbee network 94 in accordance with an embodiment of the present invention is shown. Data from the non-Zigbee network 92 is routed to an appropriate end-device 12 within the Zigbee network, through the network coordinator 13 and any routers 42 required, and vice-versa. The gateway 14 may be configured to appear to the non-Zigbee network as a fully-functional and online end device with advertised services. That is, the gateway provides a virtual end device, representing other end devices to peripheral networks. In one possible configuration, messages bound for an end-device 12 a- 12 e that do not require traffic to be sent to the actual end-device 12 a- 12 e may be directly answered by the gateway 14 and/or network coordinator 13. For example, the gateway 14 or coordinator 13 may maintain the last-known status, eg online, offline, and advertised services for each end-device 12 a-12 e, and answer queries for that information from a device in a non-Zigbee network 92 without involving the actual end-device 12 a-12 e. This reduces the communication over the Zigbee network 94 and the usage of the airtime thereof. Further, when a non-Zigbee network 92 device that is communicably coupled to the gateway 14 sends a message to the gateway 14, the gateway 14 may be configured to provide appropriate device information to the requesting device without requiring the gateway 14 to directly interact with each end-device 12 a- 12 e. For example, status requests from a peripheral network may be answered by the gateway, rather than being passed on to the end-device. Non-Zigbee network requesting devices include, without limitation, control masters (not shown). By having the gateway 14 respond to the status request messages without communicating with the end device, the Zigbee network does not get “flooded” with messages, thereby, alleviating bandwidth and efficiency constraints within the Zigbee network. A further advantage of performing end device responses at the gateway is that an end device need not be unnecessarily woken from a sleep or power saving mode.
  • Zigbee Network Time Synchronization
  • The Zigbee network described herein may be configured to synchronize its timekeeping mechanism (e.g., real-time clock, operating system timer and the like) with a non-Zigbee network clock, such as the time from a network time protocol (“NTP”), a proprietary protocol including ICSP, and the like. In such a configuration, the gateway 14, or another Zigbee network device, may be configured to act as a time-synchronization agent for a Zigbee end-device 12 in communication with the gateway 14 by servicing any requests for the current time from that end-device 12, rather than transmitting the time request to the non-Zigbee network clock. Average latency through the Zigbee network may optionally be taken into consideration to provide a closer estimate. Two schemes may be employed according to the present invention to synchronize end-devices 12 a- 12 e. First, the end-devices 12 a- 12 e may be configured to periodically poll for the time. Second, the gateway 14 may be configured to notify each end-device 12 a- 12 e at the next polltime (if in a polling network) for each of the respective end-devices 12 a- 12 e or at the next available time-slot (in a non-polling network), servicing end-devices 12 a-12 e in a round-robin fashion, ie sequentially.
  • A message flow 120 for synchronizing the end devices is shown in FIG. 12. At step 121, the gateway polls a clock of a peripheral network for a time and then synchronizes the network clock to the peripheral network time at step 122. An end device may poll for the time at step 123 and by synchronized to the Zigbee network clock at step 124. Alternatively, the Zigbee network may sequentially synchronize the end device clocks to the Zigbee network clock without requiring a polling signal from the end device (step 125).
  • While the gateway 14 has been described as acting as the time synchronization agent, the person skilled in the art will readily understand that other devices on the Zigbee network may similarly act as the time synchronization agent.
  • Zigbee Reliable Communication
  • When not using the Zigbee built-in application-level delivery confirmation, the sender (end-device 12, router device 42, coordinator 13 or gateway 14) may be configured to maintain a message to be sent in a queue when the first attempt to send is made. The message is associated with a maximum number of retries. If a MAC-level acknowledge is not received within a timeframe for the network (for example, with Zigbee, approximately 1.2 seconds per hop), the message is allowed to continue to exist in a retry queue. The retry queue may be implemented as a separate thread that runs periodically, and resends the message. When the message succeeds or the maximum number of retries is exhausted, for example 5 retries, the message may then be deleted and, optionally, network statistics may be updated to reflect the failure.
  • The flow diagram 130 of FIG. 13 shows one embodiment of a method for improving reliable communication on the Zigbee network. At step 131, a message is sent from a device which may be any suitable device on the network having a transmitter, processor and memory, and can include end devices, routers, the coordinator or the gateway. The transmitted message is stored in a re-try queue within the device (step 132) while awaiting receipt of a delivery acknowledgement message 133. If the delivery acknowledgement is received, the message is deleted from the retry queue 134.
  • The re-try queue can be set to execute at a predetermined period, or at an available time in the communication routines of the device. When the re-try executes, at step 135, any messages in the queue are re-sent and if a successful acknowledgement message (step 136) is received, the respective message is deleted from the re-try queue (step 134). If no delivery acknowledgement is received, eg, through timeout or an error message, the device increments a re-try counter (step 137) for that message. The device then checks to see if a maximum number of re-tries has been exceeded (step 138), in which case, the message is deleted from the re-try queue. If the message is able to be resent, the message remains in the re-try queue awaiting the next iteration of the re-try queue.
  • Certain protocols require messages in a specific order. To ensure reliable communication, the device may be configured to enforce that messages are sent in the original order. Under this configuration, until one message either succeeds or is dropped, other messages are held in a send queue. In one embodiment shown in FIG. 14 a message is processed, at step 141 to determine whether it has a message order requirement. If the message has no message order requirement, the message may be transmitted and transferred to the re-try queue 145 described above thereby allowing the next message to be sent. However, if the message is determined to have a message order requirement, the message is transmitted 142, and if no acknowledgement is received (step 143), the device loops 149 with the message at the head of the send queue. In each iteration of the loop 149, the device checks whether the maximum number of re-tries has been exceeded (step 146) before incrementing the re-try counter and re-transmitting the message (step 142). The device exits the loop 149 when either a successful acknowledgement message is received or the message has been re-transmitted a maximum number of times. The message is deleted from the send queue (step 144) and the device returns to step 141 to process the next message.
  • When a message having a message order requirement is deleted from the send queue because it cannot be successfully transmitted, it may become unnecessary to transmit any ensuing messages that are related to the unsuccessful message, for example, sequential messages executing a specified protocol. In this case, the related messages may also be deleted from the send queue.
  • In an alternative embodiment, messages having a related message order requirement, eg messages forming part of a protocol, may be batched to ensure correct order transmission and reliable communication on the network. In FIG. 15, a message flow 150 commences by transmitting the lead message in a send queue. Messages that are successfully sent 152 are deleted from the send queue 153 and then the next message is transmitted. If the message is not successfully sent and has no message order requirement 154, the message may be transferred to a re-try queue 155 as described previously so that attempts to re-send the message can be made when the re-try queue executes. If the unsuccessful message does have a message order requirement, the message is transferred to a batch re-send queue 156 together with any following messages from the batch. The batch re-send queue may execute 157 using the loop 149 described with respect to FIG. 14, to ensure that the messages from the batch are sent in correct order. That is, each message in the batch is transmitted and re-transmitted until successful or a maximum number of re-tries has been attempted. An advantage of this embodiment is that because the loop only executes on the batch re-send queue, messages in the send queue that are not part of the batch may be sent without being delayed by attempts to re-send the batch messages. The batch re-try queue is described herein as being separate to the re-try queue for the purposes of the example. However, the skilled addressee will readily understand that the two queues may be combined with additional loop processing for messages having a message order requirement.
  • Zigbee Gateway Quick Reconnect on Wake
  • One or more of the end-devices 12 may be configured to periodically operate in a power saving mode to save power. A power saving mode may be, for example, a sleep mode or a reduced functionality mode. It is possible that a non-Zigbee network device may attempt to interact with an end-device 12 while it is in a power saving mode. In some situations, it may be desirable to not wake the end-device 12 while in other situations, it may be desirable to wake the end-device 12. In order to support end-device states such as “online” and “offline,” the gateway 14 may be configured to identify a sleeping end-device 12 as “offline” in status queries from the non-Zigbee network. Additionally, the gateway 14 maintains at least some of the last reported device information from the end-device 12. The end-device 12 may be configured to report such device information periodically, for example as the periodic heartbeat messages 52 described above (FIG. 7), and at the time it enters a power saving mode to ensure that the most current device information is maintained in the coordinator 13 and/or gateway 14. The last reported device information from the end-device may also be used to support fast reconnection times when an end-device 12 wakes up. Optionally, the gateway 14 may be configured to interact with the non-Zigbee network on behalf of the end-device 12, as described above, for some or all of the message communication. As such, it is possible that the non-Zigbee network may believe that it is interacting with an end-device 12 when, in fact, the end-device 12 is in a power save or sleep mode. In particular, the non-Zigbee network may never be aware that the end-device 12 was or is in a power save or sleep mode. In one embodiment, messages that are required to be sent to the end device 12 while the end device is in a power saving mode are cached in the gateway memory and transmitted to the end device 12 upon receipt of the wake notification from the end device.
  • Referring now to FIGS. 6 and 7, block diagrams illustrating a wake up notification message flow in accordance with an embodiment of the present invention are shown. When a sleeping end-device 12 exits power save or sleep mode and enters an online state, the end-device 12 sends a wake notification message 72 to the coordinator 13. In response, the coordinator 13 sends a wake acknowledgement message 74.
  • Referring now to FIGS. 9E and 9F, block diagrams illustrating exemplary Zigbee message formats in accordance with an embodiment of the present invention for the wake notification message 72 and the wake acknowledgement message 74 are shown. According to these message formats, no data is required in the data byte 73 of the wake notification message 72. Wake acknowledgement message 74 includes a 1-byte binary status field 75 which contains multiple flags, as defined in the Table 1 above. Upon receipt of the wake acknowledgement message 74, end-device 12 evaluates the “defined” flag portion of the status field 35, as defined in Table 1 above. If the “defined” flag is not set, then the end-device 12 may be required to formally re-acquire the connection as previously discussed. The coordinator 13 may be configured to automatically mark the end-device 12 as “online” upon receipt of the wake notification message 72. If this is the case, if the “defined” flag is set, then the end-device 12 may possibly do nothing. Otherwise, the end-device 12 may optionally be required to send an additional message to the coordinator 13 in order to inform the coordinator 13 that the end-device 12 is exiting the power save mode and entering an online mode. In either case, upon notification that the end-device 12 is exiting power save mode and entering an online mode, the gateway may be configured to inform the non-Zigbee network of the updated status of the end-device 12. The gateway 14 and/or coordinator 13 may also resend cached device information to the end-device 12 via message 76, if necessary. The cached device information may include any messages that were received by the gateway from the non-Zigbee network while the end device 12 was in sleep mode. It is to be understood that the message formats for the wake notification message 72 and the wake acknowledgement message 74 are provided for exemplary purposes and that other message formats are possible within the scope of the invention.
  • Zigbee Network to Zigbee Network Roaming
  • The Zigbee supports roaming of a mobile end-device 12 between coordinators 14 and routers within a single Zigbee network. However, Zigbee does not provide a method of roaming from one Zigbee network to another Zigbee network. In an embodiment of the present disclosure, this deficiency is addressed in Zigbee by providing roaming capability. FIG. 16 shows an end-device 12 located in a network space having multiple Zigbee networks 161, 162, 163, 164. The end device 12 is configured to determine a list of Zigbee networks it is interested or authorized to join. The list may be configured either on the end-device 12 itself, or sent from another device utilizing the Zigbee gateway 14. Such devices may include end-devices 12 or non-Zigbee network devices.
  • As shown in FIG. 16 the end device 12 is initially connected to network 161. The end device is portable, and in FIG. 17, has roamed out of the network space of network 161. When the current connection quality from the end device 12 to the network 161 falls below a user-defined minimum threshold, the end device 12 scans the network space for beacons representing available, joinable Zigbee networks. The end device identifies beacons, and associated network identities, for each of the available networks 162, 163, 164. The beacons and their network identities allow the end device to determine which of the available networks is provided within the stored list of networks that the end device is able to join. For example, the end device may determine that network 164, shown in ghosted outline, is unavailable for joining. Networks 162, 163 are therefore available for joining, and the device selects one of these eg network 163 and undertakes the remaining connection procedure with that network.
  • In one embodiment, the available, joinable Zigbee networks are ordered by connection quality, and the Zigbee network with the best connection quality is automatically selected and joined by the mobile end-device 12. The connection quality may be measured by bit error rate or by some other quality assessment such as a received signal strength indication. For example, in FIG. 18, the end device 12, having disconnected from network 161 evaluates the airspace as having networks 162, 163, 164 that are each within the list of joinable networks and are presently available to the end device 12. Network 162 is determined as having the highest connection quality, and so end device 12 connects to network 162.
  • In one embodiment, the list of joinable networks maintained by the end device includes a preference rank. The end device selects the most preferred network, eg the highest ranked network, with a connection quality above a defined threshold. For example, in FIG. 19, the end device 12, having disconnected from network 161 evaluates the airspace as having networks 162, 163, 164 that each meet the minimum connection quality threshold as indicated by connections 165, 166 and 167. Out of these three networks, the network 164 has the highest preference ranking, and therefore the end device selects the connection 167.
  • In one embodiment, the end device may be configured to periodically seek a more preferred network, eg as determined by connection quality or network rank, irrespective of whether the current network connection has fallen below a minimum connection quality.
  • FIG. 20 depicts a processor 96 of the end device 12 operatively associated with a memory 97. The processor 96 is configured to execute an instruction set as follows. At step 301, the processor seeks out whether any networks are available within the area for the end device to join. At step 302, the processor determines whether the end device is authorized to join the available networks by comparing a network identity to a list of authorized network identities stored in memory 97. The processor then selects one of the available, joinable networks (step 303) and then joins the network (step 304) in the manner described above.
  • Although embodiments of the present invention have been illustrated in the accompanied drawings and described in the foregoing description, it will be understood that the invention is not limited to the embodiments disclosed, but is capable of numerous rearrangements, modifications, and substitutions without departing from the spirit of the invention as set forth and defined by the following claims. For example, the capabilities of the invention can be performed fully and/or partially by one or more of the blocks, modules, processors or memories. Also, these capabilities may be performed in the current manner or in a distributed manner and on, or via, any device able to provide and/or receive information. Further, although depicted in a particular manner, various modules or blocks may be repositioned without departing from the scope of the current invention. Still further, although depicted in a particular manner, a greater or lesser number of modules and connections can be utilized with the present invention in order to accomplish the present invention, to provide additional known features to the present invention, and/or to make the present invention more efficient.

Claims (20)

1. A method of roaming on a Zigbee network using a Zigbee end device, the method comprising:
determining available Zigbee networks within a network space;
selecting one of said available Zigbee networks; and
joining said end device to said selected Zigbee network.
2. The method according to claim 1 wherein selecting one of said available Zigbee networks comprises determining whether the end device is authorized to join an available Zigbee network.
3. The method according to claim 2 wherein determining whether the end device is authorized to join the selected Zigbee network comprises comparing a network identity of the selected Zigbee network with a list of authorized network identities stored in the end device.
4. The method according to claim 3 wherein the list of authorized network identities includes a preference rank; wherein selecting one of said available Zigbee networks comprises selecting an available network with a most preferred rank.
5. The method according to claim 1 wherein determining the available Zigbee networks comprises scanning the network space for one or more beacons identifying a Zigbee network.
6. The method according to claim 5 wherein selecting one of said available Zigbee networks comprises comparing a network identity associated with said one or more beacons with a list of authorized network identities stored in the end device.
7. The method according to claim 1 wherein determining the available Zigbee networks within a network space comprises determining a connection quality to the available Zigbee networks; and wherein selecting one of said available Zigbee networks comprises selecting the available Zigbee network with the highest connection quality.
8. The method according to claim 1 wherein the step of determining the available Zigbee networks within a network space is performed in response to determining that a connection quality of the end device to a Zigbee network is below a minimum threshold.
9. A device for use on a Zigbee network, the device comprising at least one processor, wherein the processor is configured for:
determining available Zigbee networks within a network space;
selecting one of said available Zigbee networks; and
joining the device to said selected Zigbee network.
10. The device according to claim 9 further comprising a memory, wherein the memory stores a list of authorized Zigbee networks and wherein the processor is configured for selecting one of said available Zigbee networks by comparing an available Zigbee network with the list of authorized Zigbee networks.
11. The device according to claim 10 wherein the list of authorized networks includes a preference rank.
12. The device according to claim 11 wherein said device is configured to select an available Zigbee network dependent on said preference rank.
13. The device according to claim 9 wherein said device is configured to determine a signal strength to each available Zigbee network.
14. The device according to claim 13 wherein the device is configured to select an available Zigbee network dependent on the determined signal strength.
15. A computer readable medium comprising instructions executable on a device of a Zigbee network, the instructions for:
determining available Zigbee networks within a network space;
selecting one of said available Zigbee networks; and
joining said device to said selected Zigbee network.
16. The computer readable medium according to claim 15, further comprising instructions for determining whether the device is authorized to join an available Zigbee network.
17. The computer readable medium according to claim 16, further comprising instructions for comparing a network identity of the selected Zigbee network with a list of authorized network identities stored in the device.
18. The computer readable medium according to claim 17, wherein the list of authorized network identities includes a preference rank; wherein the computer readable medium further comprises instructions for selecting an available network with a most preferred rank.
19. The computer readable medium according to claim 15 further comprising instructions for determining a connection quality to the available Zigbee networks; and selecting the available Zigbee network with the highest connection quality.
20. The computer readable medium according to claim 15 further comprising instructions for determining that a connection quality of a current connection from the device to a Zigbee network is below a minimum threshold.
US12/075,731 2007-03-14 2008-03-13 Device roaming on a zigbee network Abandoned US20090094349A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US12/075,731 US20090094349A1 (en) 2007-03-14 2008-03-13 Device roaming on a zigbee network

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US91839207P 2007-03-14 2007-03-14
US12/075,731 US20090094349A1 (en) 2007-03-14 2008-03-13 Device roaming on a zigbee network

Publications (1)

Publication Number Publication Date
US20090094349A1 true US20090094349A1 (en) 2009-04-09

Family

ID=39759846

Family Applications (11)

Application Number Title Priority Date Filing Date
US12/075,743 Active 2030-03-08 US7961661B2 (en) 2007-03-14 2008-03-13 System, method and computer readable medium for re-connecting to a Zigbee network
US12/075,742 Active 2030-12-02 US8780917B2 (en) 2007-03-14 2008-03-13 System, method and computer readable medium for communication on a Zigbee network
US12/075,728 Active 2028-07-18 US8085660B2 (en) 2007-03-14 2008-03-13 System, method and computer readable medium for communicating with a zigbee device from a peripheral network
US12/075,731 Abandoned US20090094349A1 (en) 2007-03-14 2008-03-13 Device roaming on a zigbee network
US13/103,476 Active 2028-12-13 US8553602B2 (en) 2007-03-14 2011-05-09 System, method and computer readable medium for re-connecting to a Zigbee network
US13/302,609 Active 2028-05-22 US8644145B2 (en) 2007-03-14 2011-11-22 System, method and computer readable medium for communicating with a zigbee device from a peripheral network
US14/023,839 Active US9036527B2 (en) 2007-03-14 2013-09-11 System, method and computer readable medium for re-connecting to a zigbee network
US14/160,112 Active 2028-08-05 US9749774B2 (en) 2007-03-14 2014-01-21 System, method and computer readable medium for communicating with a zigbee device from a peripheral network
US14/325,952 Active US9232344B2 (en) 2007-03-14 2014-07-08 Device, method and computer readable medium for communication on a ZigBee network
US14/960,406 Active US9554242B2 (en) 2007-03-14 2015-12-06 Device, method and computer readable medium for communication on a zigbee network
US15/378,895 Active US9912446B2 (en) 2007-03-14 2016-12-14 Device, method and computer readable medium for communication on a ZigBee network

Family Applications Before (3)

Application Number Title Priority Date Filing Date
US12/075,743 Active 2030-03-08 US7961661B2 (en) 2007-03-14 2008-03-13 System, method and computer readable medium for re-connecting to a Zigbee network
US12/075,742 Active 2030-12-02 US8780917B2 (en) 2007-03-14 2008-03-13 System, method and computer readable medium for communication on a Zigbee network
US12/075,728 Active 2028-07-18 US8085660B2 (en) 2007-03-14 2008-03-13 System, method and computer readable medium for communicating with a zigbee device from a peripheral network

Family Applications After (7)

Application Number Title Priority Date Filing Date
US13/103,476 Active 2028-12-13 US8553602B2 (en) 2007-03-14 2011-05-09 System, method and computer readable medium for re-connecting to a Zigbee network
US13/302,609 Active 2028-05-22 US8644145B2 (en) 2007-03-14 2011-11-22 System, method and computer readable medium for communicating with a zigbee device from a peripheral network
US14/023,839 Active US9036527B2 (en) 2007-03-14 2013-09-11 System, method and computer readable medium for re-connecting to a zigbee network
US14/160,112 Active 2028-08-05 US9749774B2 (en) 2007-03-14 2014-01-21 System, method and computer readable medium for communicating with a zigbee device from a peripheral network
US14/325,952 Active US9232344B2 (en) 2007-03-14 2014-07-08 Device, method and computer readable medium for communication on a ZigBee network
US14/960,406 Active US9554242B2 (en) 2007-03-14 2015-12-06 Device, method and computer readable medium for communication on a zigbee network
US15/378,895 Active US9912446B2 (en) 2007-03-14 2016-12-14 Device, method and computer readable medium for communication on a ZigBee network

Country Status (2)

Country Link
US (11) US7961661B2 (en)
WO (1) WO2008112248A1 (en)

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090119785A1 (en) * 2007-11-05 2009-05-07 David Carroll Challener System and Method for Secure Usage of Peripheral Devices Using Shared Secrets
US20100082789A1 (en) * 2007-09-28 2010-04-01 Samsung Electronics Co., Ltd. Ip address assignment method and apparatus for providing ip service in a zigbee network system
US20120066369A1 (en) * 2009-05-13 2012-03-15 Koninklijke Philips Electronics N.V. Method for assigning a network address for communicating in a segmented network
US20120155471A1 (en) * 2010-12-15 2012-06-21 Electronics And Telecommunications Research Institute Method and apparatus for routing
WO2013060299A1 (en) * 2011-10-27 2013-05-02 华为技术有限公司 Method and device for setting the location of network node
US20140344946A1 (en) * 2013-05-20 2014-11-20 Location Sentry Corp Emission control for wireless location management
US9264238B2 (en) 2011-11-29 2016-02-16 At&T Intellectual Property I, Lp Facilitating virtual personal area networks
US20170289272A1 (en) * 2015-05-13 2017-10-05 Arris Enterprises Llc Content Streaming Apparatus for Transferring a Streaming Session to Another Apparatus
US10772028B2 (en) * 2009-02-13 2020-09-08 Signify Holding B.V. Method for communicating in a network comprising a batteryless ZigBee device, network and device therefor
US11438777B2 (en) * 2017-12-26 2022-09-06 Sengled Co., Ltd. Method and apparatus for monitoring Zigbee node network status

Families Citing this family (63)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8099343B1 (en) 2006-04-20 2012-01-17 At&T Intellectual Property I, L.P. Distribution schemes and related payment models for subscriber-created content
US7961661B2 (en) * 2007-03-14 2011-06-14 Amx, Llc System, method and computer readable medium for re-connecting to a Zigbee network
KR100899809B1 (en) * 2007-12-11 2009-05-27 한국전자통신연구원 Coordinator, gateway and transmission method for ipv6 in wireless sensor network
US20090154478A1 (en) * 2007-12-13 2009-06-18 Alcatel Lucent Scalable Ethernet OAM Connectivity Check in an Access Network
KR20100019947A (en) 2008-08-11 2010-02-19 엘지전자 주식회사 Method of transmitting information in wireless communication system
CN101677267B (en) * 2008-09-17 2013-03-27 中兴通讯股份有限公司 Method for retransmitting protocol frames in transannular way and sharing nodes in multiple rings of Ethernet
US20110182278A1 (en) * 2008-10-03 2011-07-28 Leonard Tsai Eui based remote database for dynamic device control
US8811965B2 (en) * 2008-10-14 2014-08-19 Todd Michael Cohan System and method for automatic data security back-up and control for mobile devices
US8194600B2 (en) * 2008-11-24 2012-06-05 Qualcomm Incorporated Air interface selection between nodes in peer-to-peer/ad-hoc networks
US20100128636A1 (en) * 2008-11-25 2010-05-27 Patrick Seeling Sensor network with rapid, intuitive configuration
CN102687488B (en) * 2009-11-27 2016-05-04 皇家飞利浦电子股份有限公司 The address conflict with enhancing solves functional Radio Network System
US20110149983A1 (en) * 2009-12-21 2011-06-23 Electronics And Telecommunications Research Institute Ami gateway apparatus for processing large ami data and various application profiles and method thereof
KR101317178B1 (en) * 2009-12-21 2013-10-15 한국전자통신연구원 ZigBee Gateway and method for identifying message of the same
CN102164432A (en) * 2010-02-20 2011-08-24 天津津亚电子有限公司 Intelligent illuminating system and implementing method
EP2543175B1 (en) * 2010-03-01 2018-05-02 InterDigital Patent Holdings, Inc. Machine-to-machine gateway architecture and functionality
JP5041257B2 (en) * 2010-04-22 2012-10-03 横河電機株式会社 Field communication system and field communication method
US8923182B2 (en) 2010-06-23 2014-12-30 Arm Finland Oy Method and apparatus for providing IPv6 link-layer adaptation over a wireless channel
US20120140748A1 (en) * 2010-12-07 2012-06-07 John Carruthers End point control method
US20120198083A1 (en) * 2011-01-27 2012-08-02 Openpeak, Inc. Client device and method for finding and binding to a home connection
CA2834370A1 (en) 2011-04-26 2012-11-01 Crane Merchandising Systems, Inc. Synchronization of time critical activities across vending machine networks
US9232342B2 (en) * 2011-10-24 2016-01-05 Interdigital Patent Holdings, Inc. Methods, systems and apparatuses for application service layer (ASL) inter-networking
KR101828412B1 (en) * 2011-12-13 2018-02-13 삼성전자주식회사 Communication method, communication apparatus and communication system
CN103209136A (en) * 2012-01-11 2013-07-17 中兴通讯股份有限公司 Network load control method and register server
CN102595575B (en) * 2012-02-27 2014-08-13 杭州星纬物联技术有限公司 Full-network low-power-consumption algorithm using active and passive nodes by turns
US9231892B2 (en) * 2012-07-09 2016-01-05 Vmware, Inc. Distributed virtual switch configuration and state management
CN104509216B (en) * 2012-08-07 2017-03-22 皇家飞利浦有限公司 Timed lighting control
GB2506367B (en) 2012-09-26 2015-01-07 Imagination Tech Ltd Method and system for wirelessly transmitting data
CN102946670B (en) * 2012-11-12 2015-06-10 华中科技大学 Multifunctional mining LED (Light Emitting Diode) road lamp system based on Zigbee and power line carrier
WO2014144419A2 (en) * 2013-03-15 2014-09-18 Master Lock Company Networked security system
US9571345B2 (en) 2013-03-20 2017-02-14 Infosys Limited System and method for locally optimized managing of network appliances in a closed area network
IN2013CH01206A (en) 2013-03-20 2015-08-14 Infosys Ltd
US9191209B2 (en) * 2013-06-25 2015-11-17 Google Inc. Efficient communication for devices of a home network
US9336113B2 (en) * 2013-07-29 2016-05-10 Bose Corporation Method and device for selecting a networked media device
CN104574919A (en) * 2013-10-14 2015-04-29 光宝电子(广州)有限公司 Wireless transmission device and connecting device
EP3075206B1 (en) 2013-11-29 2017-11-01 Philips Lighting Holding B.V. Zigbee light link network commissioning
KR20150070637A (en) * 2013-12-17 2015-06-25 한국전자통신연구원 Apparatus and Method for Stopping Transmitting Sensor Data in MAC Layer of Wireless Sensor Network
KR20150113570A (en) * 2014-03-31 2015-10-08 주식회사 케이엠더블유 Street light management system
US10666735B2 (en) 2014-05-19 2020-05-26 Auerbach Michael Harrison Tretter Dynamic computer systems and uses thereof
CN104320877A (en) * 2014-10-23 2015-01-28 华南理工大学 Intelligent led control terminal
TWI577154B (en) * 2014-10-31 2017-04-01 宏碁股份有限公司 Method for keeping remote connection, electronic device and sever
TWI551179B (en) * 2014-12-25 2016-09-21 台達電子工業股份有限公司 Establishing method for self-organization network of wireless nodes
CN106304014B (en) * 2015-05-22 2019-07-05 中国科学院沈阳计算技术研究所有限公司 For reducing the communication means of ZigBee wireless sensor network isolated point
CN104994600B (en) * 2015-07-15 2018-09-11 成都傅立叶电子科技有限公司 Gateway and its operation method for the interconnection of more ZigBee-networks
JP6460940B2 (en) * 2015-08-06 2019-01-30 東芝メモリ株式会社 Storage device and data saving method
CN105391806B (en) * 2015-12-21 2019-03-08 联想(北京)有限公司 A kind of equipment long-range control method and system
US10728164B2 (en) 2016-02-12 2020-07-28 Microsoft Technology Licensing, Llc Power-aware network communication
US9713180B1 (en) * 2016-03-15 2017-07-18 Qualcomm Incorporated Relay centric mobility management in a mesh network
US9717110B1 (en) 2016-03-15 2017-07-25 Qualcomm Incorporated User equipment centric mobility management in a mesh network
US10511542B2 (en) 2016-06-10 2019-12-17 Microsoft Technology Licensing, Llc Multi-interface power-aware networking
EP3340539B1 (en) * 2016-12-22 2022-01-26 Netatmo Commissioning and personalizing devices in a local area network
US10572344B2 (en) * 2017-04-27 2020-02-25 Texas Instruments Incorporated Accessing error statistics from DRAM memories having integrated error correction
CN107172573B (en) * 2017-05-11 2020-01-31 四川长虹电器股份有限公司 zigbee terminal communication data processing method
US10499196B2 (en) 2017-06-17 2019-12-03 Link Labs, Inc. BLE networking systems and methods providing central and peripheral role reversal with enhanced peripheral location determination
US10244373B2 (en) 2017-06-17 2019-03-26 Link Labs, Inc. BLE networking systems and methods providing central and peripheral role reversal
US10244377B2 (en) 2017-06-17 2019-03-26 Link Labs, Inc. BLE networking systems and methods providing central and peripheral role reversal according to network provisioned timing therefor
US10237913B2 (en) * 2017-06-17 2019-03-19 Link Labs, Inc. BLE networking systems and methods providing central and peripheral role reversal thereof while movable between locations
US10484932B2 (en) 2017-06-17 2019-11-19 Link Labs, Inc. BLE networking systems and methods providing central and peripheral role reversal with enhanced peripheral location determination using ultrasonic waveform
US10708970B2 (en) 2017-06-17 2020-07-07 Link Labs, Inc. BLE networking systems and methods providing central and peripheral role reversal with enhanced peripheral location determination using constant tone extension analysis for a same channel
US10506498B1 (en) 2018-11-01 2019-12-10 Link Labs, Inc. BLE networking systems and methods providing central and peripheral role reversal with enhanced peripheral location determination using ultrasonic waveform and correlation therefor
CN107820277B (en) 2017-10-27 2021-09-21 三星(中国)半导体有限公司 Parent node device for wireless network, terminal device and data transmission method thereof
CN108023938B (en) * 2017-11-13 2020-10-16 联动优势科技有限公司 Message sending method and server
US10264436B1 (en) 2018-05-29 2019-04-16 Link Labs, Inc. BLE networking systems and methods providing central and peripheral role reversal with independent peripheral network connectivity
US11778540B1 (en) 2022-10-12 2023-10-03 Link Labs, Inc. BLE networking systems and methods including filtering for selectively collecting and processing advertisement data

Citations (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5526376A (en) * 1992-06-29 1996-06-11 Kellenberger; Jane A. Intelligent repeater interface
US6198920B1 (en) * 1995-06-01 2001-03-06 Padcom, Inc. Apparatus and method for intelligent routing of data between a remote device and a host system
US20030224787A1 (en) * 2001-11-28 2003-12-04 Gandolfo Pierre T. System and method of communication between multiple point-coordinated wireless networks
US20040030777A1 (en) * 2001-09-07 2004-02-12 Reedy Dennis G. Systems and methods for providing dynamic quality of service for a distributed system
US6982962B1 (en) * 2000-04-10 2006-01-03 3Com Corporation System and method for selecting a network access provider using a portable information device
US20060031497A1 (en) * 2004-05-21 2006-02-09 Bea Systems, Inc. Systems and methods for collaborative content storage
US7065367B2 (en) * 2002-07-11 2006-06-20 Oliver Michaelis Interface selection in a wireless communication network
US20060227718A1 (en) * 2005-04-07 2006-10-12 Wang Michael M Selective network switching in a wireless broadcast network
US20060271805A1 (en) * 2001-02-09 2006-11-30 Motion Engineering, Inc. System for motion control, method of using the system for motion control, and computer readable instructions for use with the system for motion control
US20070011271A1 (en) * 2005-05-20 2007-01-11 Baker David V Multi-source data retrieval system
US7181213B2 (en) * 2004-03-19 2007-02-20 Micro-Star Int'l. Co., Ltd. Wireless network service provider and associated channel-searching method
US20070198728A1 (en) * 2002-03-28 2007-08-23 Franceschelli Anthony J Jr Generating and launching remote method invocation servers for individual client applications
US20080184030A1 (en) * 2005-09-30 2008-07-31 Blue Coat Systems, Inc. Method and System for Authentication Among Peer Appliances Within a Computer Network
US20090088152A1 (en) * 2007-09-28 2009-04-02 Mark Orlassino System and Method for Adaptive/Predictive Location-Based Roaming Optimization
US20100080146A1 (en) * 2008-10-01 2010-04-01 Digi International Inc. Joining a mesh network in a multiple network environment
US20100203834A1 (en) * 2007-06-28 2010-08-12 Telecom Italia S.P.A. Method and system for detecting a moving vehicle within a predetermined area

Family Cites Families (41)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0503545B1 (en) * 1991-03-08 1997-06-11 Matsushita Electric Industrial Co., Ltd. Data transfer device
GB2311443A (en) * 1996-03-23 1997-09-24 Ibm Data message transfer in batches with retransmission
EP1111874A1 (en) * 1999-12-20 2001-06-27 Telefonaktiebolaget L M Ericsson Routing in mobile-IP Ad-Hoc networks
US7058691B1 (en) * 2000-06-12 2006-06-06 Trustees Of Princeton University System for wireless push and pull based services
US7016296B2 (en) * 2000-10-16 2006-03-21 Broadcom Corporation Adaptive modulation for fixed wireless link in cable transmission system
JP3990115B2 (en) * 2001-03-12 2007-10-10 株式会社東芝 Server-side proxy device and program
US20050171662A1 (en) * 2001-06-13 2005-08-04 Strege Timothy A. Method and apparatus for wireless networks in wheel alignment systems
US20030212738A1 (en) * 2002-05-10 2003-11-13 Wookey Michael J. Remote services system message system to support redundancy of data flow
US7015817B2 (en) * 2002-05-14 2006-03-21 Shuan Michael Copley Personal tracking device
US7986687B2 (en) * 2002-09-27 2011-07-26 Nokia Corporation Multicast data transfer
GB0227287D0 (en) * 2002-11-22 2002-12-31 Koninkl Philips Electronics Nv Robust communication system
US7370087B1 (en) * 2003-02-04 2008-05-06 Cisco Technology, Inc. Method and apparatus for providing access to a peripheral device management interface
US7774506B2 (en) * 2003-08-19 2010-08-10 Cisco Technology, Inc. Systems and methods for alleviating client over-subscription in ring networks
GB0402739D0 (en) * 2004-02-09 2004-03-10 Saviso Group Ltd Methods and apparatus for routing in a network
US8539783B1 (en) * 2004-02-11 2013-09-24 Supermarket Energy Technologies, LLC System for preventing condensation on refrigerator doors and frames
KR100667318B1 (en) * 2004-02-12 2007-01-12 삼성전자주식회사 Method of multicast in ZigBee network
GB0413334D0 (en) * 2004-06-15 2004-07-21 Koninkl Philips Electronics Nv Gateway for a local networking system
ATE421218T1 (en) * 2004-06-29 2009-01-15 Nokia Siemens Networks Gmbh METHOD FOR SELECTING A SERVER FROM A SET OF SERVERS
CA2573017A1 (en) * 2004-07-15 2006-02-23 Hunter Douglas Inc. System and method for adaptively controlling a network of distributed devices
US7370129B2 (en) * 2004-12-15 2008-05-06 Microsoft Corporation Retry strategies for use in a streaming environment
US7747922B2 (en) * 2005-06-01 2010-06-29 Telecommunications Research Laboratories Adaptive hybrid ARQ systems with BCJR decoding
KR100724886B1 (en) * 2005-07-18 2007-06-04 삼성전자주식회사 Packet Based Re-Trnasporting System For DMB Service And Its Apparatus
GB0517113D0 (en) * 2005-08-20 2005-09-28 Ibm Methods, apparatus and computer programs for data communication efficiency
US7908649B1 (en) * 2005-09-20 2011-03-15 Netapp, Inc. Method and apparatus for providing efficient authorization services in a web cache
US8516135B2 (en) * 2005-09-30 2013-08-20 Qurio Holdings, Inc. Providing and receiving content for computer networks using a gateway and server
US7761767B2 (en) * 2005-10-21 2010-07-20 Interdigital Technology Corporation Method and apparatus for retransmission management for reliable hybrid ARQ process
KR100761019B1 (en) * 2005-12-30 2007-09-21 삼성전자주식회사 Method for Management Of Food Stuff Using RF Communication Network of Refrigerator in Smart Communicator
US20070192706A1 (en) * 2006-02-14 2007-08-16 International Business Machines Corporation Service gateway for providing a scalable and loosely coupled service oriented architecture
US7705743B2 (en) * 2006-03-01 2010-04-27 L-3 Communications Corporation Self-assembling wireless network, vehicle communications system, railroad wheel and bearing monitoring system and methods therefor
US7801129B2 (en) * 2006-04-27 2010-09-21 Alcatel-Lucent Usa Inc. Method and apparatus for SIP message prioritization
US20070255126A1 (en) * 2006-04-28 2007-11-01 Moberg Sheldon B Data communication in networked fluid infusion systems
US8149849B2 (en) * 2006-08-31 2012-04-03 Sony Ericsson Mobile Communications Ab Zigbee/IP gateway
US20080084836A1 (en) * 2006-10-04 2008-04-10 Bluewave Security, Inc. Low power wireless communication method
US20080120414A1 (en) * 2006-11-17 2008-05-22 Nandakishore Kushalnagar Representing resource constrained devices in a network
KR100822706B1 (en) * 2006-12-08 2008-04-17 한국전자통신연구원 Apparatus and method of controlling home appliance using zigbee wireless communication
EP1933507A1 (en) * 2006-12-15 2008-06-18 Ubiwave Low-power multi-hop networks
WO2008085205A2 (en) * 2006-12-29 2008-07-17 Prodea Systems, Inc. System and method for providing network support services and premises gateway support infrastructure
US7961661B2 (en) * 2007-03-14 2011-06-14 Amx, Llc System, method and computer readable medium for re-connecting to a Zigbee network
US8458320B2 (en) * 2007-08-27 2013-06-04 International Business Machines Corporation Alerting a user to an occurrence of a specified event
US20100293263A1 (en) * 2007-12-28 2010-11-18 Giovanni Caire Method and system for managing a network of distributed entities
US8850052B2 (en) * 2008-09-30 2014-09-30 Apple Inc. System and method for simplified resource sharing

Patent Citations (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5526376A (en) * 1992-06-29 1996-06-11 Kellenberger; Jane A. Intelligent repeater interface
US6198920B1 (en) * 1995-06-01 2001-03-06 Padcom, Inc. Apparatus and method for intelligent routing of data between a remote device and a host system
US6982962B1 (en) * 2000-04-10 2006-01-03 3Com Corporation System and method for selecting a network access provider using a portable information device
US20060271805A1 (en) * 2001-02-09 2006-11-30 Motion Engineering, Inc. System for motion control, method of using the system for motion control, and computer readable instructions for use with the system for motion control
US20040030777A1 (en) * 2001-09-07 2004-02-12 Reedy Dennis G. Systems and methods for providing dynamic quality of service for a distributed system
US20030224787A1 (en) * 2001-11-28 2003-12-04 Gandolfo Pierre T. System and method of communication between multiple point-coordinated wireless networks
US20070198728A1 (en) * 2002-03-28 2007-08-23 Franceschelli Anthony J Jr Generating and launching remote method invocation servers for individual client applications
US7065367B2 (en) * 2002-07-11 2006-06-20 Oliver Michaelis Interface selection in a wireless communication network
US7181213B2 (en) * 2004-03-19 2007-02-20 Micro-Star Int'l. Co., Ltd. Wireless network service provider and associated channel-searching method
US20060031497A1 (en) * 2004-05-21 2006-02-09 Bea Systems, Inc. Systems and methods for collaborative content storage
US20060227718A1 (en) * 2005-04-07 2006-10-12 Wang Michael M Selective network switching in a wireless broadcast network
US20070011271A1 (en) * 2005-05-20 2007-01-11 Baker David V Multi-source data retrieval system
US20080184030A1 (en) * 2005-09-30 2008-07-31 Blue Coat Systems, Inc. Method and System for Authentication Among Peer Appliances Within a Computer Network
US20100203834A1 (en) * 2007-06-28 2010-08-12 Telecom Italia S.P.A. Method and system for detecting a moving vehicle within a predetermined area
US20090088152A1 (en) * 2007-09-28 2009-04-02 Mark Orlassino System and Method for Adaptive/Predictive Location-Based Roaming Optimization
US20100080146A1 (en) * 2008-10-01 2010-04-01 Digi International Inc. Joining a mesh network in a multiple network environment

Cited By (20)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100082789A1 (en) * 2007-09-28 2010-04-01 Samsung Electronics Co., Ltd. Ip address assignment method and apparatus for providing ip service in a zigbee network system
US8046431B2 (en) * 2007-09-28 2011-10-25 Samsung Electronics Co., Ltd. IP address assignment method and apparatus for providing IP service in a ZIGBEE network system
US8539572B2 (en) * 2007-11-05 2013-09-17 Lenovo (Singapore) Pte. Ltd. System and method for secure usage of peripheral devices using shared secrets
US20090119785A1 (en) * 2007-11-05 2009-05-07 David Carroll Challener System and Method for Secure Usage of Peripheral Devices Using Shared Secrets
US10772028B2 (en) * 2009-02-13 2020-09-08 Signify Holding B.V. Method for communicating in a network comprising a batteryless ZigBee device, network and device therefor
US20120066369A1 (en) * 2009-05-13 2012-03-15 Koninklijke Philips Electronics N.V. Method for assigning a network address for communicating in a segmented network
US20120155471A1 (en) * 2010-12-15 2012-06-21 Electronics And Telecommunications Research Institute Method and apparatus for routing
US9391838B2 (en) 2011-10-27 2016-07-12 Huaewei Technologies Co., Ltd. Method and apparatus for setting network node location
WO2013060299A1 (en) * 2011-10-27 2013-05-02 华为技术有限公司 Method and device for setting the location of network node
US10306446B2 (en) 2011-11-29 2019-05-28 At&T Intellectual Property I, L.P. Facilitating virtual personal area networks
US9699598B2 (en) 2011-11-29 2017-07-04 At&T Intellectual Property I, L.P. Facilitating virtual personal area networks
US9986372B2 (en) 2011-11-29 2018-05-29 At&T Intellectual Property I, L.P. Facilitating virtual personal area networks
US9264238B2 (en) 2011-11-29 2016-02-16 At&T Intellectual Property I, Lp Facilitating virtual personal area networks
US10547997B2 (en) 2011-11-29 2020-01-28 At&T Intellectual Property I, L.P. Facilitating virtual personal area networks
US9467804B2 (en) * 2013-05-20 2016-10-11 Location Sentry Corp. Emission control for wireless location management
US9693286B2 (en) * 2013-05-20 2017-06-27 Location Sentry Corp. Emission control for wireless location management
US20140344946A1 (en) * 2013-05-20 2014-11-20 Location Sentry Corp Emission control for wireless location management
US20170289272A1 (en) * 2015-05-13 2017-10-05 Arris Enterprises Llc Content Streaming Apparatus for Transferring a Streaming Session to Another Apparatus
US10419549B2 (en) * 2015-05-13 2019-09-17 Arris Enterprises Llc Content streaming apparatus for transferring a streaming session to another apparatus
US11438777B2 (en) * 2017-12-26 2022-09-06 Sengled Co., Ltd. Method and apparatus for monitoring Zigbee node network status

Also Published As

Publication number Publication date
US8085660B2 (en) 2011-12-27
US20090092146A1 (en) 2009-04-09
US20140328336A1 (en) 2014-11-06
US20140010137A1 (en) 2014-01-09
US9036527B2 (en) 2015-05-19
US8553602B2 (en) 2013-10-08
US20140133301A1 (en) 2014-05-15
US9912446B2 (en) 2018-03-06
US9554242B2 (en) 2017-01-24
US9749774B2 (en) 2017-08-29
US20090092108A1 (en) 2009-04-09
US20160100281A1 (en) 2016-04-07
US8644145B2 (en) 2014-02-04
US20090092049A1 (en) 2009-04-09
US20170093531A1 (en) 2017-03-30
WO2008112248A1 (en) 2008-09-18
US7961661B2 (en) 2011-06-14
US20110211532A1 (en) 2011-09-01
US8780917B2 (en) 2014-07-15
US9232344B2 (en) 2016-01-05
US20120069736A1 (en) 2012-03-22

Similar Documents

Publication Publication Date Title
US9912446B2 (en) Device, method and computer readable medium for communication on a ZigBee network
KR101543448B1 (en) Topology discovery in a hybrid network
US7406061B2 (en) Method to sustain TCP connection
US7500119B2 (en) Power saving techniques for use in communication systems, networks, and devices
US7251235B2 (en) Event-based multichannel direct link
US20140269474A1 (en) Power saving for low latency deterministic networks in wireless personal area networks
US20120106418A1 (en) Client' device power reduction in wireless networks having network-computed client' location
JP2009515401A (en) Multicast and / or broadcast acknowledgment mechanism
JP6637198B2 (en) Technology for assigning short addresses to network devices
US20090225731A1 (en) Wireless network including request to trigger function
USRE45212E1 (en) Event-based multichannel direct link
US7289518B2 (en) Method and apparatus for reducing power consumption in a wireless network station
JP2008092129A (en) Substitute processor, wireless lan terminal, wireless communication system and substitute processing method
TW202044910A (en) A method and apparatus for synchronization of client and access point
WO2014135003A1 (en) Terminal device and method for sending and receiving frames
US20050270993A1 (en) Efficient partitioning of MAC (media access control) functions
TWI462618B (en) Method for negotiating power management mode between mobile device and access point, and mobile device
WO2014146440A1 (en) Service discovery method, access point, and station
JP2009038659A (en) Information communication terminal, radio communication apparatus, and radio communication network
US8774803B2 (en) Idle mode transition control method in a wireband wireless communication system

Legal Events

Date Code Title Description
AS Assignment

Owner name: AMX, LLC, TEXAS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SMITH, DARIN WILLIAM;REEL/FRAME:020698/0618

Effective date: 20080313

AS Assignment

Owner name: JPMORGAN CHASE BANK, N.A., AS ADMINISTRATIVE AGENT

Free format text: SECURITY AGREEMENT;ASSIGNOR:AMX LLC;REEL/FRAME:020941/0884

Effective date: 20080513

AS Assignment

Owner name: AMX LLC, TEXAS

Free format text: RELEASE OF SECURITY AGREEMENT RECORDED AT REEL/FRAME 020941/0884;ASSIGNOR:JPMORGAN CHASE BANK, N.A.;REEL/FRAME:029442/0483

Effective date: 20100723

STCB Information on status: application discontinuation

Free format text: ABANDONED -- AFTER EXAMINER'S ANSWER OR BOARD OF APPEALS DECISION