EFFICIENT HYBRID RESOURCE AND SCHEDULE MANAGEMENT IN TIME SLOTTED CHANNEL HOPPING NETWORKS
20170273002 · 2017-09-21
Inventors
- Zhuo Chen (Claymont, DE)
- Lijun DONG, IV (San Diego, CA, US)
- Chonggang Wang (Princeton, NJ)
- Quang LY, IV (North Wales, PA, US)
- Xu Li (Plainsboro, NJ)
- Guang Lu (Thornhill, CA)
- Yanyan Han (Lafayette, LA, US)
- Shamim Akbar Rahman (Cote St. Luc, CA)
Cpc classification
Y02D30/70
GENERAL 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
International classification
H04W40/24
ELECTRICITY
Abstract
The present application is directed to a computer-implemented device for reserving a path in a network. The device includes a non-transitory memory operably coupled to a processor. The processor is configured to perform the instruction of sending a path computation request to a backbone router via a routing protocol path. The processor is also configured to perform the instruction of receiving a computation reply from the backbone router path based upon the request. The processor is also configured to perform the instruction of assigning a soft cell on the path between the source and the destination device. The application is also directed to a computer-implemented device for reserving a path between a source device and destination device.
Claims
1. A computer-implemented device comprising: a non-transitory memory having instructions stored thereon for reserving a path in a network; and a processor, operably coupled to the memory, the processor configured to perform the instructions of: sending a path computation request to a backbone router via a routing protocol path; receiving a computation reply from the backbone router path based upon the request; and assigning a soft cell on the path between the source and the destination device.
2. The device of claim 1, wherein the processor is further configured to perform the instructions of sending topology information including neighbor addresses to the backbone router.
3. The device of claim 1, wherein a soft cell is sequentially reserved between the source device, an intermediate device and the destination device.
4. The device of claim 1, wherein the assigning step includes: sending a path assignment request message to an intermediate device; and receiving a path assignment confirmation from the intermediate device.
5. The device of claim 4, wherein the assigning step further includes receiving a path assignment reply from the destination device.
6. The device of claim 4, wherein the path assignment request message or the path assignment confirmation includes a field selected from a transmitter address, a receiver address, a source address, path identification, lifetime, address of the intermediate device, requested slots, unscheduled slot information, a decision, confirmed cell information and combinations thereof.
7. The device of claim 6, wherein the path assignment reply includes a field selected from a transmitter address, a receiver address, a source address, a path ID, a decision, an address of failure devices along the path and combinations thereof.
8. The device of claim 1, wherein the memory stores information selected from a transmitter address, a receiver address, a source address, path identification, lifetime, address of the intermediate device, requested slots, unscheduled slot information, a decision, confirmed cell information and combinations thereof.
9. A computer-implemented device comprising: a non-transitory memory having instructions stored thereon for reserving a path in a network; and a processor, operably coupled to the memory, the processor configured to perform the instructions of: receiving a path reservation request from the source device to reserve soft cells along the path; sending a unicast path assignment query message to an intermediate device and the destination device on the path to obtain unscheduled slot information; receiving a path assignment query reply message from the intermediate device and the destination device on the path; and a transceiver for sending and receiving data.
10. The device of claim 9, wherein the processor is further configured to perform the instructions of determining feasibility for reserving the path based upon information in the path reservation request and the received path assignment query reply messages.
11. The device of claim 10, wherein the processor is further configured to perform the instructions of: sending a path assignment indication message to the intermediate and destination devices; and receiving a path assignment confirmation from the intermediate and destination devices.
12. The device of claim 11, wherein the processor is further configured to perform the instructions of: sending a path reservation reply to the source device; and receiving a path reservation confirmation from the source device confirming the soft cells.
13. The device of claim 12, further comprising: receiving a path assignment confirmation message from the intermediate device in the path indicating an acceptable or unacceptable allocation of non-overlapped soft cells.
14. A computer-implemented device comprising: a non-transitory memory having instructions stored thereon for reserving a path between a source and a destination device; and a processor, operably coupled to the memory, the processor configured to perform the instructions of: receiving a path reservation request from the source device to reserve soft cells along the path; sending a unicast path assignment query message to an intermediate device and the destination device on the path to obtain unscheduled slot information; receiving a path assignment query reply message from the intermediate device and the destination device on the path; and determining feasibility for reserving the path based upon information in the path reservation request and the received path assignment query reply messages.
15. The method of claim 14, further comprising: sending a path assignment indication message to the intermediate and destination devices; and receiving a path assignment confirmation from the intermediate and destination devices.
16. The method of claim 14, further comprising: sending a path reservation reply to the source device; and receiving a path reservation confirmation from the source device confirming the soft cells.
17. A computer-implemented method for reserving a path between a source and a destination device comprising: providing a source device; sending a path computation request to a backbone router via a routing protocol path; receiving a computation reply from the backbone router based upon the request; and assigning a soft cell on the path between the source and the destination device.
18. A computer-implemented method for reserving a path between a source and a destination device comprising: providing a source device; sending a path computation request from the source device to a backbone router via a routing protocol path; receiving a computation reply from the backbone router based upon the request; sending a path assignment request to the destination device including unscheduled slot information of intermediate devices in the path; and receiving a path assignment confirmation message from the destination device indicating an acceptable allocation of non-overlapped soft cells.
19. A computer-implemented method for reserving a path between a source and a destination device comprising: receiving a path reservation request from the source device to reserve soft cells along the path; sending a unicast path assignment query message to an intermediate device and the destination device on the path to obtain unscheduled slot information; receiving a path assignment query reply message from the intermediate device and the destination device on the path; determining feasibility for reserving the path based upon information in the path reservation request and the received path assignment query reply messages; sending a path assignment indication message to the intermediate and destination devices; and receiving a path assignment confirmation from the intermediate and destination devices.
20. The method of claim 19, further comprising: sending a path reservation reply to the source device; and receiving a path reservation confirmation from the source device confirming the soft cells.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
[0012] In order to facilitate a more robust understanding of the application, reference is now made to the accompanying drawings, in which like elements are referenced with like numerals. These drawings should not be construed to limit the application and are intended only to be illustrative.
[0013]
[0014]
[0015]
[0016]
[0017]
[0018]
[0019]
[0020]
[0021]
[0022]
[0023]
[0024]
[0025]
[0026]
[0027]
[0028]
[0029]
[0030]
[0031]
[0032]
[0033]
[0034]
DETAILED DESCRIPTION OF THE ILLUSTRATIVE EMBODIMENTS
[0035] A detailed description of the illustrative embodiment will be discussed in reference to various figures, embodiments and aspects herein. Although this description provides detailed examples of possible implementations, it should be understood that the details are intended to be examples and thus do not limit the scope of the application.
[0036] Reference in this specification to “one embodiment,” “an embodiment,” “one or more embodiments,” “an aspect” or the like means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the disclosure. Moreover, the term “embodiment” in various places in the specification is not necessarily referring to the same embodiment. That is, various features are described which may be exhibited by some embodiments and not by the other.
[0037] According to the application, a novel technique is provided that allows the source LLN device to reserve resources along the shortest track, otherwise known as a path, to a destination LLN device. Moreover, the application describes a low overhead procedure for LLN devices to proactively report their neighbor information to their BR by enhancing RPLs in order to locate the shortest track between the source and destination. Further, novel schemes are described to reserve resources along a path in a 6TiSCH network.
TSCH Mode of IEEE 82.15.4e
[0038] Time Slotted Channel Hopping (TSCH) is one of the medium access modes specified in IEEE 802.15.4e. The following properties exist in the TSCH mode of IEEE 802.15.4e: (i) time is divided into several Timeslots; (ii) timeslots are grouped into one or more Slot frames; and (iii) a Slot frame continuously repeats over time. For instance, Table 1 shows a TSCH Schedule. The x-axis is the Timeslot offset and the y-axis is the Channel Offset. Accordingly, a LLN device may use different channels in different Timeslots. A single element in the TSCH Slot frame, named as a “Cell”, is identified by a Timeslot Offset value and a Channel Offset value. Typically, a given cell may be a scheduled cell, e.g., Tx, Rx, or TxRx, or an unscheduled cell as shown in Table 1. Moreover, a “Hard cell” is a scheduled cell that is configured by a centralized controller in the network meaning the cell cannot be further configured and/or modified by the LLN device itself. Alternatively, a “Soft cell” is a scheduled cell that is only configured by the LLN device itself and can be further configured by either the LLN device or by the centralized controller. However, once a soft cell is configured by the centralized controller, it will become a hard cell.
[0039] In order to receive or transmit packets, a LLN device needs to obtain a Schedule. Primarily, the LLN device may transmit a packet at Timeslot 0 using Channel 0. Next, the LLN device turns on its radio to receive an incoming packet at Timeslot 1 over Channel 1. The LLN device may transmit or receive a packet simultaneously at Timeslot 2 using Channel 15. The LLN device may turn off its radio in an unscheduled cell at Timeslot 99.
TABLE-US-00001 TABLE 1 Offset Channel Timeslot Offset 0 1 2 . . . 99 0 TxRxShare Unscheduled 1 Rx Unscheduled . . . Unscheduled 15 TxRx Unscheduled
6TiSCH Network
[0040] A 6TiSCH network architecture generally includes a plurality of constrained devices that use TSCH mode of 802.15.4e as a Medium Access Control (MAC) protocol. The IETF 6TiSCH Working Group specifies protocols for addressing network layer issues of 6TiSCH networks. To manage a TSCH Schedule, a 6TiSCH Operation Sublayer (6top) is employed in a 6TiSCH Working Group. As shown in
[0041] As illustrated in
[0042] Centralized and decentralized schemes may be employed to solve the resource and schedule management issue for multi-hop communications. In the centralized scheme, the central controller can setup Hard Cells in the TSCH Schedule of LLN devices. This enables the multi-hop communications between LLN devices. Alternatively, in decentralized schemes, LLN devices may negotiate and setup Soft Cells in their TSCH Schedule to communicate with each other. The decentralized schemes are more scalable and robust than centralized scheme for resource and schedule management since it does not rely on the central controller of the network.
[0043] By configuring the TSCH Schedule of LLN devices on a route, e.g., from LLN device 1 to LLN device 4 as shown in
TABLE-US-00002 TABLE 2(a) TSCH Schedule of LLN device 1 Offset Channel Timeslot Offset 0 1 2 . . . 99 0 track 1 Tx to LLN device 2 1 . . . 15
TABLE-US-00003 TABLE 2(b) TSCH Schedule of LLN device 2 Offset Channel Timeslot Offset 0 1 2 . . . 99 0 track 1 Rx from LLN device 1 1 . . . 15 track 1 Tx to LLN device 3
TABLE-US-00004 TABLE 2(c) TSCH Schedule of LLN device 3 Offset Channel Timeslot Offset 0 1 2 . . . 99 0 1 . . . 15 track 1 track 1 Rx from LLN Tx to LLN device 2 device 4
TABLE-US-00005 TABLE 2(d) TSCH Schedule of LLN device 4 Offset Channel Timeslot Offset 0 1 2 . . . 99 0 1 . . . 15 track 1 Rx from LLN device 3
[0044] As illustrated in
General Architecture
[0045]
[0046] As shown in
[0047] As shown in
[0048] Referring to
[0049] Similar to the illustrated M2M service layer 22, there is the M2M service layer 22′ in the Infrastructure Domain. M2M service layer 22′ provides services for the M2M application 20′ and the underlying communication network 12′ in the infrastructure domain. M2M service layer 22′ also provides services for the M2M gateway devices 14 and M2M terminal devices 18 in the field domain. It will be understood that the M2M service layer 22′ may communicate with any number of M2M applications, M2M gateway devices and M2M terminal devices. The M2M service layer 22′ may interact with a service layer by a different service provider. The M2M service layer 22′ may be implemented by one or more servers, computers, virtual machines, e.g., cloud/compute/storage farms, etc., or the like.
[0050] Referring also to
[0051] The M2M applications 20 and 20′ may include applications in various industries such as, without limitation, transportation, health and wellness, connected home, energy management, asset tracking, and security and surveillance. As mentioned above, the M2M service layer, running across the devices, gateways, and other servers of the system, supports functions such as, for example, data collection, device management, security, billing, location tracking/geo-fencing, device/service discovery, and legacy systems integration, and provides these functions as services to the M2M applications 20 and 20′. Moreover, the M2M service layer may also be configured to interface with other devices such as LLN devices, backbone routers and PCEs as discussed in this application and illustrated in the figures.
[0052] The method of reserving a track as discussed in the present application may be implemented as part of a service layer. The service layer is a software middleware layer that supports value-added service capabilities through a set of Application Programming Interfaces (APIs) and underlying networking interfaces. Both ETSI M2M and oneM2M use a service layer that may contain this method of reserving a track. ETSI M2M's service layer is referred to as the Service Capability Layer (SCL). The SCL may be implemented within an M2M device (where it is referred to as a device SCL (DSCL)), a gateway (where it is referred to as a gateway SCL (GSCL)) and/or a network node (where it is referred to as a network SCL (NSCL)). The oneM2M service layer supports a set of Common Service Functions (CSFs), e.g., service capabilities. An instantiation of a set of one or more particular types of CSFs is referred to as a Common Services Entity (CSE) which can be hosted on different types of network nodes, e.g., infrastructure node, middle node, application-specific node. Further, the method of reserving a track as described in the present application can be implemented as part of an M2M network that uses a Service Oriented Architecture (SOA) and/or a resource-oriented architecture (ROA) to access services such as the reserving a track according to the present application.
[0053]
[0054] The processor 32 may be a general purpose processor, a special purpose processor, a conventional processor, a digital signal processor (DSP), a plurality of microprocessors, one or more microprocessors in association with a DSP core, a controller, a microcontroller, Application Specific Integrated Circuits (ASICs), Field Programmable Gate Array (FPGAs) circuits, any other type of integrated circuit (IC), a state machine, and the like. The processor 32 may perform signal coding, data processing, power control, input/output processing, and/or any other functionality that enables the M2M device 30 to operate in a wireless environment. The processor 32 may be coupled to the transceiver 34, which may be coupled to the transmit/receive element 36. While
[0055] The transmit/receive element 36 may be configured to transmit signals to, or receive signals from, an M2M service platform 22. For example, in an embodiment, the transmit/receive element 36 may be an antenna configured to transmit and/or receive RF signals. The transmit/receive element 36 may support various networks and air interfaces, such as WLAN, WPAN, cellular, and the like. In an embodiment, the transmit/receive element 36 may be an emitter/detector configured to transmit and/or receive IR, UV, or visible light signals, for example. In yet another embodiment, the transmit/receive element 36 may be configured to transmit and receive both RF and light signals. It will be appreciated that the transmit/receive element 36 may be configured to transmit and/or receive any combination of wireless or wired signals.
[0056] In addition, although the transmit/receive element 36 is depicted in
[0057] The transceiver 34 may be configured to modulate the signals that are to be transmitted by the transmit/receive element 36 and to demodulate the signals that are received by the transmit/receive element 36. As noted above, the M2M device 30 may have multi-mode capabilities. Thus, the transceiver 34 may include multiple transceivers for enabling the M2M device 30 to communicate via multiple RATs, such as UTRA and IEEE 802.11, for example.
[0058] The processor 32 may access information from, and store data in, any type of suitable memory, such as the non-removable memory 44 and/or the removable memory 46. The non-removable memory 44 may include random-access memory (RAM), read-only memory (ROM), a hard disk, or any other type of memory storage device. The removable memory 46 may include a subscriber identity module (SIM) card, a memory stick, a secure digital (SD) memory card, and the like. In other embodiments, the processor 32 may access information from, and store data in, memory that is not physically located on the M2M device 30, such as on a server or a home computer.
[0059] The processor 32 may receive power from the power source 48, and may be configured to distribute and/or control the power to the other components in the M2M device 30. The power source 48 may be any suitable device for powering the M2M device 30. For example, the power source 48 may include one or more dry cell batteries, e.g., nickel-cadmium (NiCd), nickel-zinc (NiZn), nickel metal hydride (NiMH), lithium-ion (Li-ion), etc.), solar cells, fuel cells, and the like.
[0060] The processor 32 may also be coupled to the GPS chipset 50, which is configured to provide location information, e.g., longitude and latitude, regarding the current location of the M2M device 30. It will be appreciated that the M2M device 30 may acquire location information by way of any suitable location-determination method while remaining consistent with an embodiment.
[0061] The processor 32 may further be coupled to other peripherals 52, which may include one or more software and/or hardware modules that provide additional features, functionality and/or wired or wireless connectivity. For example, the peripherals 52 may include an accelerometer, an e-compass, a satellite transceiver, a sensor, a digital camera (for photographs or video), a universal serial bus (USB) port, a vibration device, a television transceiver, a hands free headset, a Bluetooth® module, a frequency modulated (FM) radio unit, a digital music player, a media player, a video game player module, an Internet browser, and the like.
[0062]
[0063] Computing system 90 may comprise a computer or server and may be controlled primarily by computer readable instructions, which may be in the form of software, wherever, or by whatever means such software is stored or accessed. Such computer readable instructions may be executed within central processing unit (CPU) 91 to cause computing system 90 to do work. In many known workstations, servers, and personal computers, central processing unit 91 is implemented by a single-chip CPU called a microprocessor. In other machines, the central processing unit 91 may comprise multiple processors. Coprocessor 81 is an optional processor, distinct from main CPU 91 that performs additional functions or assists CPU 91. CPU 91 and/or coprocessor 81 may receive, generate, and process data related to the disclosed systems and methods for embedded semantic naming, such as queries for sensory data with embedded semantic names.
[0064] In operation, CPU 91 fetches, decodes, and executes instructions, and transfers information to and from other resources via the computer's main data-transfer path, system bus 80. Such a system bus connects the components in computing system 90 and defines the medium for data exchange. System bus 80 typically includes data lines for sending data, address lines for sending addresses, and control lines for sending interrupts and for operating the system bus. An example of such a system bus 80 is the PCI (Peripheral Component Interconnect) bus.
[0065] Memory devices coupled to system bus 80 include random access memory (RAM) 82 and read only memory (ROM) 93. Such memories include circuitry that allows information to be stored and retrieved. ROMs 93 generally contain stored data that cannot easily be modified. Data stored in RAM 82 can be read or changed by CPU 91 or other hardware devices. Access to RAM 82 and/or ROM 93 may be controlled by memory controller 92. Memory controller 92 may provide an address translation function that translates virtual addresses into physical addresses as instructions are executed. Memory controller 92 may also provide a memory protection function that isolates processes within the system and isolates system processes from user processes. Thus, a program running in a first mode can access only memory mapped by its own process virtual address space; it cannot access memory within another process's virtual address space unless memory sharing between the processes has been set up.
[0066] In addition, computing system 90 may contain peripherals controller 83 responsible for communicating instructions from CPU 91 to peripherals, such as printer 94, keyboard 84, mouse 95, and disk drive 85.
[0067] Display 86, which is controlled by display controller 96, is used to display visual output generated by computing system 90. Such visual output may include text, graphics, animated graphics, and video. Display 86 may be implemented with a CRT-based video display, an LCD-based flat-panel display, gas plasma-based flat-panel display, or a touch-panel. Display controller 96 includes electronic components required to generate a video signal that is sent to display 86. Display 86, may display sensory data in files or folders using embedded semantics names. Further, computing system 90 may contain network adaptor 97 that may be used to connect computing system 90 to an external communications network, such as network 12 of
[0068] According to an embodiment, the display 86 includes a graphical user interface (GUI) for a central controller as shown in
[0069] According to the present application, it is understood that any or all of the systems, methods and processes described herein may be embodied in the form of computer executable instructions, e.g., program code, stored on a computer-readable storage medium which instructions, when executed by a machine, such as a computer, server, M2M terminal device, M2M gateway device, or the like, perform and/or implement the systems, methods and processes described herein. Specifically, any of the steps, operations or functions described above may be implemented in the form of such computer executable instructions. Computer readable storage media include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information, but such computer readable storage media do not includes signals. Computer readable storage media include, but are not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other physical medium which can be used to store the desired information and which can be accessed by a computer.
ICMPv6 Protocol
[0070] Internet Control Message Protocol version 6 (ICMPv6) is used by hosts and routers to communicate network layer information to each other. ICMP is often considered as part of the IP. ICMP messages are carried inside IP datagrams. Each ICMP message contains three fields that define its purpose and provide a checksum. They are Type, Code, and Checksum fields. The Type field identifies the ICMP message, the Code field provides further information about the associated Type field, and the Checksum provides a method for determining the integrity of the message. According Internet Assigned Numbers Authority (IRNA), the type numbers of 159-199 are unassigned.
IPv6 Routing Protocol for Low-Power and Lossy Networks
[0071] According to an embodiment, IETF 6TiSCH Working Group IPv6 Routing Protocol for Low-Power and Lossy Networks (RPL) is the default routing protocol in 6TiSCH network. RPL is a gradient routing protocol that organizes routers along a Destination Oriented Directed Acyclic Graph (DODAG) root at the BR. For example, three DODAGs are rooted at BRs.
[0072] In particular, the RPL Control Message includes an ICMPv6 header followed by a message body. The message body is comprised of a message base and a number of options. The RPL control message is an ICMPv6 information message with a Type of 155. The Code field identifies the type of RPL control message, e.g., the broadcasting DODAG Information Object (DIO) message and a Destination Advertisement Object (DAO) message discussed in more detail below. The base field contains the basic information of control message such as flags and sequence number. The Options contain contents to be delivered.
[0073] The DODAG root BR initiates the DODAG formation by periodically broadcasting DODAG Information Object (DIO) messages. DIO messages carry information such as the DODAG root's identity, the routing metrics in use, as well as the originating router's depth, e.g., rank, in the DODAG. A LLN device joins the DODAG by choosing the neighbor that has the smallest rank as its parent. After joining the DODAG, a LLN device determines its own rank in the DODAG based on the information advertised by its parent DIO. Once a LLN device has joined the DODAG, it has a path to the root through its parent(s), and can then originate its own DIO messages and broadcast it to other LLN devices.
[0074] RPLs provide a path from a LLN device to its root while requiring routers only to store information about its parent in the DODAG. A path is also required for traffic to flow in the downward direction, i.e., traffic originates from outside the LLN network, at the root or at any intermediate nodes and destined to a LLN device. To build a downward path, each LLN device broadcasts a Destination Advertisement Object (DAO) message. A DAO messages usually contains a set of one or more RPL Target options and Transit Information options. These may include, for example, a target IPv6 address, prefix or multicast group. The Field and descriptions are provided in Table 3 below.
TABLE-US-00006 TABLE 3 Fields Name Description Option Type Always set to 0x05. Option Length Variable, length of the option in octets excluding the Type and Length fields. Flags 8-bit unused field reserved for flags. The field MUST be initialized to zero by the sender and MUST be ignored by the receiver. Prefix Length 8-bit unsigned integer. Number of valid leading bits in the IPv6 Prefix. Target Prefix Variable-length field identifying an IPv6 destination address, prefix, or multicast group.
[0075] In addition, the Transit Information option is provided in Table 4 below and is used for a node to indicate attributes for a path to one or more destinations. The destinations are indicated by one or more Target options that immediately precede the Transit Information option. The fields in the options are captured in Table 3.
TABLE-US-00007 TABLE 4 Fields Name Description Option Type Always set to 0x06 Option Length Variable, depending on whether or not the DODAG Parent Address subfield is present. External (E) 1-bit flag. The ‘E’ flag is set to indicate that the parent router redistributes external targets into the RPL network. Flags The 7 bits remaining unused in the Flags field are reserved for flags. Path Control 8-bit bit field. The Path Control field limits the number of DAO parents to which a DAO message advertising connectivity to a specific destination may be sent, as well as providing some indication of relative preference. Path Sequence 8-bit unsigned integer. When a RPL Target option is issued by the node that owns the Target prefix (i.e., in a DAO message), that node sets the Path Sequence and increments the Path Sequence each time it issues a RPL Target option with updated information. Path Lifetime 8-bit unsigned integer. The length of time in Lifetime Units (obtained from the Configuration option) that the prefix is valid for route determination. Parent Address (optional) IPv6 address of the DODAG parent of the node originally issuing the Transit Information option. This field may not be present, as according to the DODAG Mode of Operation (Storing or Non- Storing) and indicated by the Transit Information option length.
[0076] According to another embodiment of the application, two routing modes are supported in RPL. These include a storing mode and a non-storing mode. In the storing mode, each LLN device in the network unicasts DAO messages to all parent LLN devices which maintain additional downward routing tables as illustrated in
[0077] Conversely, in a non-storing mode, a LLN device reports its DAO message through its parent all the way to the BR as illustrated in
[0078] Further, a track from the source LLN device to the destination LLN device along the DODAG may be employed. For example, the track marked with the dashed line in
Reactive Discovery of Point-to-Point Routes in Low-Power and Lossy Networks
[0079] According to yet another embodiment, Reactive Discovery of Point-to-Point Routes in Low-Power and Lossy Networks, e.g., P2P-RPL, describes a reactive scheme that can provide well performed paths on-demand from the source to the destination without having to go through the BR. Using P2P-RPL, when a source LLN device needs to discover a path to a destination LLN device, the source originates a Route-Request message indicating it seeks a path to the destination. This message is piggy-backed on DIO messages and disseminated throughout the network. This creates a temporary DODAG rooted at the source. Upon receiving such a message, the destination sends a P2P Discovery Reply Object Acknowledgement message back to the source, thus establishing a path between the source and destination as illustrated, for example, in
Hybrid Track Reservation
[0080] According to another embodiment, a proactive technique employs the power of a BR. This technique brings less overhead to the LLN devices in the network while enabling BRs to obtain topology information for the network. The reason to choose the BR to store the topology information of the network is because the BR is usually more powerful than LLN devices and has pre-built RPL paths to all LLN devices in the network. The source LLN device can inquire with its BR to obtain a well performed, e.g., the shortest, path to the destination. Subsequently, the source LLN device may use different reactive procedures discussed in more detail in this application to reserve resources along the path. The described procedures are better able to operate with the dynamically changing schedule of a LLN device due to traffic and channel conditions.
[0081] In an exemplary embodiment, the procedure of P2P track reservation scheme is illustrated in the call flow shown in
TABLE-US-00008 TABLE 5 Field Name Description Source Address The IP/MAC address of the source LLN device that sends the request. Destination Address The IP/MAC address of the destination LLN device on the track. Address of the all LLN The IP/MAC address of the all LLN devices devices that does not that should be bypassed due to insufficient have enough resource resource. The source can obtain this (optional) information from the Track Assignment Reply message received.
[0082] In Step 2, the BR calculates the path for the track according to the topology information and the information in the track Computation Request. The BR will avoid choosing LLN devices that do not have enough resource listed in the Path Computation Request. Next, the BR sends a “Path Computation Reply message” to source LLN device (Step 3). In the message, BR indicates a success if it finds a path that satisfies the requirement in the Path Computation Request message. Otherwise, the BR indicates a failure. The “Path Computation Reply message” may include but is not limited to the fields provided in Table 6 below.
TABLE-US-00009 TABLE 6 Field Name Description Source Address The IP/MAC address of the source LLN device on the track. Destination Address The IP/MAC address of the destination LLN device on the track. Address of the 1.sup.st LLN The IP address of the LLN device that is device on the Track selected as 1.sup.st hop on the track. Address of the The IP address of the LLN devices that are subsequent LLN devices selected as subsequent hops on the track. on the Track
[0083] In Step 4, the Soft Cell reservation procedure is initiated by the source LLN device to reserve resources on the track. These may be reactive schemes to reserve Soft Cells along the track. If the Soft Cell reservation process fails, e.g., a LLN device on the path does not have enough resources, the source LLN device will send a “new Path Computation Request message” which contains the address of LLN devices that do not have enough resources. By so doing, the BR may avoid choosing those LLN devices when it calculates another path.
Proactive Procedure for Reporting Topology Information
[0084] According to an aspect of the application, a proactive procedure is described for reporting topology information from the LLN device to the BR. In RPL schemes, all LLN devices periodically send DAO messages upward along the DODAG. However, in these messages, LLN devices only report its parents' set (in non-storing mode), or alternatively, sub-DAG information (in storing mode). It will not report neighbor information. LLN devices may generate a new type of message to report its neighbor information. While this may bring extra overhead to LLN devices in the network to generate and forward these messages, a low-cost procedure for collecting topology information is provided by adding neighbor information in existing RPL DAO messages without requiring extra messages.
[0085] An exemplary embodiment of the call flow is illustrated in
TABLE-US-00010 TABLE 7 Field Name Description Reporting Address The IP/MAC address of the LLN device that sends the message. Address of all The IP/MAC address of all neighbors. Neighbors
[0086] In Step 2, after receiving a DAO message, a parent LLN device, e.g., LLN device 4 in
Hop by Hop P2P Track Assignment
[0087] As mentioned above in this application, after the BR calculates the path from the source LLN device to the destination LLN device, Soft Cells may be reserved for LLN devices on the path. According to one embodiment, in hop-by-hop track assignment procedures, each LLN device on the track negotiates with its previous-hop LLN device and next-hop LLN device to set up Soft cells as illustrated, for example, in
[0088] According to an exemplary embodiment, each LLN device on the track negotiates with its previous and next hop LLN device to assign Soft Cells. All negotiation messages are transmitted in the shared broadcasting slots in a Slotframe, e.g., Slot 0, as illustrated in Table 5. The Soft Cells of each hop are sequentially reserved along the path. For example, the Soft Cells between LLN device 2 and LLN device 3 are reserved after Soft Cells between LLN device 1 and 2 have been reserved.
[0089] The basic hop by hop track assignment procedure is shown in the exemplary embodiment in
[0090] Thereafter, the source LLN device sends a “Track Assignment Request message” to LLN device 2 (Step 3). The “Track Assignment Request message” may include but is not limited to the fields provided in Table 8 below. For example, in the message, LLN device 1 will notify LLN device 2 that the remaining LLN devices on track are LLN device 3 and 4. Moreover, LLN device 1 also includes its unscheduled slots that may be reserved for LLN device 2 in the message. LLN device 2 will check its unscheduled slots which overlap with unscheduled slots of LLN device 1 (Step 4). LLN device 2 makes a decision whether to accept the track assignment based on its resources. For example, if LLN device 2 has fewer unscheduled slots which overlap with LLN device 1 than the requested slots, LLN device 2 will indicate a failure in a “Track Assignment Confirmation message” subsequently sent to LLN device 1. Otherwise, LLN device 2 determines the cells reserved for the communication and sends the information of these cells to LLN device 1 via the “Track Assignment Confirmation message.” The “Track Assignment Confirmation message” may include but is not limited to the fields listed in Table 9 below.
TABLE-US-00011 TABLE 8 Field Name Description Transmitter Address The IP/MAC address of the LLN device that sends Track Assignment Request. Receiver Address The IP/MAC address of the LLN devices on the track that receives Track Assignment Request. Source Address The IP/MAC address of the source LLN device on the track. Track ID The ID of the Track generated by the source. Lifetime The lifetime or duration of the Track. LLN devices can release the resource reserved for a Track when the Track expires. Address of LLN devices The IP/MAC address of LLN devices on the on the rest of the Track rest of the track. Requested slots The minimum number of slots requested for each hop of communication on the track. All unscheduled slots The Slot Offset of all unscheduled slots of info the transmitter that can be reserved for the receiver.
TABLE-US-00012 TABLE 9 Field Name Description Transmitter Address The IP/MAC address of the source LLN device that sends Track Assignment Confirmation. Receiver Address The IP/MAC address of the LLN devices on the track that receives Track Assignment Confirmation. Source Address The IP/MAC address of the source LLN device on the track. Track ID The ID of the Track. Decision The decision of the track assignment. The value is true if the transmitter has unscheduled slots that meet the request and is false otherwise. All confirmed cells info The Slot Offset and Channel Offset of the all (optional) cells reserved for communication between the transmitter and the receiver. These fields are valid only if the Decision field is true.
[0091] Similar to LLN device 1 in Step 3 recited above, LLN device 2 sends a “Track Assignment Request” to its next hop on the track, e.g., LLN device 3 (Step 5). Thereafter, in Step 6, and similar to LLN device 2 in Step 4 recited above, LLN device 3 checks its unscheduled slots that have the same slot offset with LLN device 2. LLN device 3 determines whether it accepts the track assignment based on its resources. If LLN device 3 has fewer unscheduled slots overlapping with LLN device 2 than the requested slots, LLN device 2 will indicate a failure in a “Track Assignment Confirmation message” it subsequently sends on to LLN device 2. Thereafter, LLN device 2 will send a “Track Assignment Reply Message” to LLN device 1 to indicate LLN device 3 does not have enough resources for the track reservation. Both LLN devices 1 and 2 will release the reserved resource for the track. Otherwise, LLN device 3 decides the cells reserved for the communication and sends the information of these cells to LLN device 2 via the track Assignment Confirmation message and proceeds to the next step. The track Assignment Confirmation message may include but is not limited to the fields listed in Table 9.
[0092] According to Step 7, and similar as LLN device 1 in Step 3, the LLN device 3 sends a “Track Assignment Request message” to its next hop on the track, i.e., LLN device 4. The “Track Assignment Request message” may include but is not limited to the fields listed in Table 8. Next, similar to LLN device 2 in Step 4, the LLN device 4 will check its unscheduled cells that have the same slot offset with LLN device 3 (Step 8). LLN device 4 makes a decision to accept the track assignment based on its resources. Namely, if LLN device 4 has fewer unscheduled slots overlapping with LLN device 3 than the requested slots, LLN device 4 will indicate a failure in a track assignment confirmation message. It will then send the message to LLN device 3. LLN device 3 will send a “Track Assignment Reply Message” to LLN device 2 to indicate LLN device 4 does not have enough resources. The “Track Assignment Reply message” will be forwarded back to LLN device 1. LLN devices 1, 2 and 3 will release the reserved resources for the track.
[0093] On the other hand, if LLN device 4 decides the cells should be reserved for the communication. LLN device 4 sends the information of these cells to LLN device 3 via the “Track Assignment Confirmation message” and proceeds to the next step. The “Track Assignment Confirmation message” may include but is not limited to the fields listed in Table 10 below.
TABLE-US-00013 TABLE 10 Field Name Description Transmitter Address The IP/MAC address of the LLN device that sends the Track Assignment Confirmation. Receiver Address The IP/MAC address of the LLN devices on the Track that receives the Track Assignment Confirmation. Source Address The IP/MAC address of the source LLN device on the track. Track ID The ID of the track. Decision The decision of the Track assignment. The value is true if the track is reserved successfully and is false otherwise. Addresses of failure LLN The IP/MAC address of the LLN devices that devices (optional) does not have enough resource. These fields are valid only when the Decision field is false.
[0094] According to Step 9, the destination LLN device, e.g., LLN device 4, sends a “Track Assignment Reply message” to LLN device 3. The “Track Assignment Reply message” may include but is not limited to the fields listed in Table 10. Subsequently, LLN device 3 forwards the “Track Assignment Reply Message” to LLN device 2 (Step 10). Further, the LLN device 2 forwards the “Track Assignment Reply Message” to LLN device 1 (Step 11).
Enhanced Hop by Hop Track Assignment
[0095] According to another aspect of the application, an improved track assignment procedure is described to overcome inefficiencies in track reservation failure including for example, large delays for response failures and high overhead for reserving unused resources. In terms of delays, for instance, if there are not enough resources between LLN devices 3 and 4, the failure response will not be sent until the Soft Cells reservation is accomplished by LLN devices 1, 2 and 3. In terms of high overhead, for instance, when LLN devices 1 and 2 are reserving resources for the Track, they are not aware if there are enough resources between LLN devices 3 and 4. Accordingly, these negotiation messages become overhead when the track reservation between LLN devices 3 and 4 fails. Further, LLN devices 1 and 2 have to release these resources after receiving the failure response.
[0096] According to another embodiment of the application, the improved track assignment procedure also improves the probability to successfully reserve a track along a path. In particular, LLN devices on the path are generally not aware of the TSCH schedule of other LLN devices on the path. This may be the case when LLN devices 1 and 2 both have slots 1 and slot 2 available, and LLN device 3 only has slot 1 available. LLN devices 1 and 2 may choose to reserve slot 1 for their communication without knowing the TSCH schedule information of LLN device 3. This will result in a failure to reserve the track along LLN devices 1, 2 and 3. In addition, the enhanced Track Assignment Request contains extra information, e.g., unscheduled slot information of the LLN device on the previous hop, to increase the probability of successfully reserving a Track along a path.
[0097] According to another embodiment, the enhanced “Track Assignment Request Message” is forwarded to the destination before reserving any Soft Cells. Accordingly, if a LLN device in the middle of the track determines it does not have enough resources when receiving the message, it can send a response to the source LLN device and immediately inform it of the failure. This helps to reduce delays in the overall process. This also helps improve throughput.
[0098] In an exemplary embodiment, a hop by hop track reservation procedure is illustrated in
[0099] Next, the source LLN device 1 sends an enhanced “Track Assignment Request message” to LLN device 2 that includes its unscheduled cells. The enhanced “Track Assignment Request message” may include but is not limited to the fields listed in Table 11 below.
TABLE-US-00014 TABLE 11 Field Name Description Transmitter Address The IP/MAC address of the LLN device that sends the message. Receiver Address The IP/MAC address of the LLN devices on the track that receives the message. Track ID The ID of the track generated by the source. Requested slots The minimum number of slots requested for each hop of communication on the track. Unscheduled slots info The Slot Offset of the unscheduled slots of the LLN device. Unscheduled slots info The Slot Offset of the unscheduled slots of the of the LLN device on LLN device on the previous hop of the track. the previous hop(optional)
[0100] Next, after receiving the enhanced “Track Assignment Request message,” the second LLN device on the Track, e.g., LLN device 2, check whether it has enough unscheduled slots that overlap with the unscheduled slots of LLN device 1. According to an exemplary embodiment, a procedure with O(min(|S.sub.1|,|S.sub.2|) complexity is illustrated in
TABLE-US-00015 TABLE 12 Field Name Description Source Address The IP/MAC address of the source LLN device that sends Track Computation Request. Destination Address The IP/MAC address of the destination LLN device on the track. Track ID The ID of the Track generated by the source. Lifetime The lifetime or duration of the Track. LLN devices can release the resource reserved for a track when the track expires. Requested slots The minimum number of slots requested for each hop of communication on the track. Unscheduled slots info The Slot Offset of the all unscheduled slots of the source that can be reserved.
[0101] In Step 5, and similar to LLN device 2 in Step 4 above, after receiving the enhanced “Track Assignment Request message,” the third LLN device on the Track, e.g., LLN device 3, checks if it has enough resources to reserve the track. In an exemplary embodiment as illustrated in
[0102] Subsequently in Step (v), the LLN device 3 checks if it can allocate k non-overlapped soft cells for a Hop between LLN device 1 and LLN device 2 and/or a Hop between LLN device 2 and LLN device 3. The formula employed for checking is |S.sub.i-1∩S.sub.i-2|≧2k−|S.sub.i∩S.sub.i-1−S.sub.i∩S.sub.i-1∩S.sub.i-2|. If so, LLN device 3 will send an enhanced “Track Assignment Request message” to LLN device 4 that includes the unscheduled cells of LLN device 2 and itself as provided in Table 12. Otherwise, it will send a “Track Assignment Confirmation message” to LLN device 2 with a decision field marked as false as provided in Table 9. This indicates LLN device 2 does not have enough resources after reserving k Soft Cells with LLN device 3. The “Track Assignment confirmation message” will be forwarded back to the source LLN device.
[0103] Thereafter, in Step 6, after receiving the enhanced “Track Assignment Request message,” the destination LLN device on the track, e.g., LLN device 4, extracts information from the message. The message includes, for example, the number of requested slots k for the track, Unscheduled slot info of LLN device 2, and Unscheduled slot info of LLN device 3. Then, LLN device 4 checks whether it can allocate k non-overlapped Soft Cells for a Hop between LLN device 2 and LLN device 3 and/or a Hop between LLN device 3 and LLN device 4. If this is not possible, it will send a “Track Assignment Confirmation message” to LLN device 3 with a decision field marked as false as provided in Table 9, which indicates LLN device 3 does not have enough resources after reserving k Soft Cells with LLN device 4. Otherwise, LLN device 4 will reserve the k Soft Cells between LLN device 3. LLN device 4 also sends a “Track Assignment Confirmation message” to LLN device 3 with its decision and reserved soft cell information. The “Track Assignment Confirmation message” may include but is not limited to the fields listed in Table 9.
[0104] According to Step 7, and similar to LLN device 4 in Step 6, LLN device 3 checks if it can allocate k non-overlapped soft cells for a link between LLN device 1 and LLN device 2 and/or a link between LLN device 2 and LLN device 3. If not, it will send a “Track Assignment Confirmation message” to LLN device 2 immediately with a decision field marked as false as in Table 8, which indicates LLN device 3 does not have enough resources after reserving k soft cells with LLN device 2. Otherwise, LLN device 3 will reserve the k soft cells between LLN device 2 and send a “Track Assignment Confirmation message” to LLN device 2 with its decision and reserved soft cells information. The “Track Assignment Request message” may include but is not limited to the fields listed in Table 8.
[0105] Next, and similar as LLN device 4 in Step 6, LLN device 3 will check if it can allocate k soft cells for a link between LLN device 1 and LLN device 2 (Step 8). If not, it will send a “Track Assignment Confirmation message” to LLN device 1 immediately with a decision field marked as false as provided in Table 9 indicating LLN device 2 does not have enough resources after reserving k soft cells with LLN device 1. Otherwise, LLN device 2 will reserve the k soft cells between LLN device 1 and sends a “Track Assignment Confirmation message” to LLN device 1 with its decision and reserved soft cell information. The “Track Assignment Request message” may include but is not limited to the fields listed in Table 8. It is envisaged according to this application that a LLN device may receive a new request from other source LLN devices when it is waiting for the response of a previous request. Moreover, the LLN device may hold the new request until it receives the response from a previous request
[0106] According to yet another aspect of the application, a new track assignment procedure is described that employs a RPL-assisted hop by hop track assignment procedure using RPL paths to transmit “Track Assignment Messages.” By using the RPL path, the interference of the network may be reduced since messages are transmitted using non-overlapped channel selecting a RPL as the default routing algorithm in the 6TiSCH network. Each LLN device has reserved resources to communicate with their parents.
Backbone Router Assisted Track Assignment
[0107] According to a further aspect of the application, a BR assisted track assignment scheme is proposed. Namely, the BR is able to determine the information of each LLN device on the track and process the information to assess a feasible soft cell reservation. By contrast with conventional hop by hop track assignment schemes, the BR calculates a path from source to the destination in addition to helping the source reserve resources along the path. The BR also queries the resource of each LLN device on the track path on demand and checks the feasibility to reserve the Track before sending Cell assignment request.
[0108] An exemplary embodiment of the BR assisted track assignment procedure is illustrated in
TABLE-US-00016 TABLE 13 Fields Name Description Reporting Address The IP/MAC address of the LLN device that sends Track Assignment Query Reply. All unscheduled slots The Slot Offset of the all its unscheduled info slots.
[0109] According to Step 8, the BR will check if it can reserve requested slots along the path. If the BR cannot, it will calculate another path and return to Steps 2-8 as previously discussed. Otherwise, the BR fulfils the following steps. Namely, according to Steps 9, 11 and 13, the BR will send a “Track Assignment Indication” to all LLN devices on the track. In particular, the “Cell Assignment Request message” may include but is not limited to fields provided in Table 14 below.
TABLE-US-00017 TABLE 14 Field Name Description Track ID The ID of the track Source address The source address of the track Lifetime The lifetime or duration of the track. LLN devices can release the resource reserved for a track when the track expires. Device address The IP/MAC address of the LLN device to be configured. Address of the The IP/MAC address of the LLN device that is previous hop the previous hop on the track. Income Cells The Timeslot Offset, Channel Offset of cells information that are used to receive packets from previous hop. Address of the next The IP/MAC address of the LLN device that is hop the next hop on the track. Outgoing Cells The Timeslot Offset, Channel Offset of cells information that are used to send packets to the next hop.
[0110] According to Steps 10, 12 and 14, the LLN devices which receive the “Track Assignment Indication Message” will send a “Track Assignment Confirmation message” to the BR to confirm the reserved cells. Thereafter, the BR will send a “Track Reservation Reply Message” to the source LLN device to indicate the results of the track reservation procedure (Step 15). The “Cell Assignment Request message” may include but is not limited to fields Table 15 below. If the BR has reserved resources for all LLN devices on the track except the source LLN device, it will mark the decision field as a success and contain the reserved cell information. Further, in Step 16, the source LLN device that receives the “Track Reservation Reply Message” will send a “Track Assignment Confirmation message” to the BR to confirm the reserved cells.
TABLE-US-00018 TABLE 15 Field Name Description Source address The source address of the track Track ID The ID of the track Decision The result of the track reservation procedure Source address The IP/MAC address of the source LLN device on the track Next hop address The IP/MAC address of the next hop LLN device (optional) on the track Outgoing Cells The Timeslot Offset and Channel Offset of Cells (optional) that are used to send packets to the next hop.
Neighbor Information Option in RPL
[0111] According to another embodiment of the application, there is described a method of inserting the proposed neighbor information in the DAO messages sent by LLN devices. By so doing, existing Transmit Information option proceeded by RPL Target option may be updated and/or replaced. The descriptions for each field are provided below in Table 16. It is envisaged according to this application that the proposed neighbor information option may also contain multiple pairs of Neighbor Lifetime and Neighbor Address information.
TABLE-US-00019 TABLE 16 Field Name Description Option Type Always set to an unreserved value range from 0x0a-0xff, e.g. 0x0a. Option Length Variable, indicate the length of the option. Parent (P) 1-bit flag. The ‘P’ flag is set to indicate if the neighbor is also a parent of the LLN device. Flags The 7 bits remaining unused in the Flags field are reserved for flags. Neighbor 8-bit unsigned integer. When a RPL Target option Sequence is issued by the node that owns the Target prefix, e.g., in a DAO message, that node sets the Neighbor Sequence and increments the Neighbor Sequence each time it issues a RPL Target option with updated information. Neighbor 8-bit unsigned integer. The length of time in Lifetime Lifetime Units that the Neighbor is valid. Neighbor IPv6 address of the neighbor of the node originally Address issuing the Transit Information option.
ICMPv6 6TiSCH Control Messages
[0112] According to a further embodiment of the application, the 6TiSCH control messages used within 6TiSCH network may be carried by the ICMPv6 message. According to
TABLE-US-00020 TABLE 17 Code Message 0x01 Path Computation Request Message. 0x02 Path Computation Reply Message. 0x03 Track Assignment Request Message. 0x04 Track Assignment Confirmation Message. 0x05 Track Assignment Reply Message. 0x06 Track Reservation Request Message. 0x07 Track Reservation Reply Message. 0x08 Track Assignment Query Message. 0x09 Track Assignment Query Reply Message. 0x0a Track Assignment Indication Message.
6TiSCH Control Messages in 802.15.4e Information Element
[0113] According to another embodiment, the proposed 6TiSCH control messages as previously discussed may be carried by a 802.15.4e header as a payload Information Element (IE) if the destination of the message is one hop away from the sender. The fields in 6TiSCH Control IE are described in Table 18 to transmit one hop enhanced “Track Assignment Requests” and “Track Assignment Confirmation messages” in an “Enhanced Hop by Hop Track Assignment Scheme” as discussed above in the present application.
TABLE-US-00021 TABLE 18 Field Name Description Length The length of the IE. Group ID The Group ID can be set as an unreserved value between 0x2-0x9, e.g. 0x2. T Set to 1 to indicate this is a long format packet. 6TiSCH Control This field indicates the type of the 6TiSCH Message Code control messages. The message code and type mapping can be the same as in Table 17. 6TiSCH Control The fields of each 6TiSCH control messages. Message Fields
6TiSCH Control Messages in CoAP
[0114] According to yet even a further embodiment, 6TiSCH Control Messages may also be transmitted using CoAP. Namely, each control message has an associated URI path as defined in Table 19 below and/or LLN devices. To send a control message to a destination, the sender needs to issue a RESTful method, e.g., POST method, to the destination with the address set to the corresponding URI path. The destination maintains the corresponding URI path.
TABLE-US-00022 TABLE 19 6TiSCH Control Message CoAP Resource URI path Path Computation Path Request /PathRequest Request Message Path Computation Path Reply /PathReply Reply Message Track Assignment Track Request /TrackRequest Request Message Track Assignment Track /TrackConfirm Confirmation Confirm Message Track Assignment Track Reply /TrackReply Reply Message Track Reservation Track /TrackReservation Request Message Reservation Track Reservation Track /TrackReservationReply Reply Message Reservation Reply Track Assignment Track Query /TrackQuery Query Message Track Assignment Track Query /TrackQueryReply Query Reply Message Reply Track Assignment Track /TrackAssigmentIndication Indication Message Assignment Indication
[0115] According to yet another aspect of the application, non-transitory computer-readable or executable storage medium for storing computer-readable or executable instructions is disclosed. The medium may include one or more computer-executable instructions such as disclosed above in the plural call flows according to
[0116] While the systems and methods have been described in terms of what are presently considered to be specific aspects, the application need not be limited to the disclosed aspects. It is intended to cover various modifications and similar arrangements included within the spirit and scope of the claims, the scope of which should be accorded the broadest interpretation so as to encompass all such modifications and similar structures. The present disclosure includes any and all aspects of the following claims.