The present invention relates generally to data transfer in networks. It also relates to wireless personal area networks (PAN). More specifically the invention relates to a simple method to optimize data transfer of data flows in a Bluetooth Network. Additional information about local area wireless networking can be downloaded from http://www.bluetooth.org.
Currently the IP (Internet Protocol) networking over Bluetooth is defined by the Bluetooth PAN profile. The PAN profile emulates an Ethernet interface to IP, through BNEP (Bluetooth Network Encapsulation Protocol). A BNEP connection is identified by a specific, fixed Protocol/Service Multiplexer (PSM) value (see http://www.bluetooth.org/assigned-numbers/12cap.htm). It is specified that there can be only one BNEP connection between two devices, which (currently) means that there can be only one L2CAP (Logical Link and Adaptation Protocol) connection with the reserved PSM value for BNEP. BNEP multiplexes all BNEP traffic (and thus IP traffic) over one logical (L2CAP) channel according to the logical link control and adaptation protocol (L2CAP). Bluetooth provides a quality of service (QoS) differentiation on top of L2CAP i.e. L2CAP channels can be configured with specific QoS parameters. Currently, prioritization of IP packets is possible within the PAN profile by using priority tags in BNEP packets according to the IEEE 802.1p specification (part of IEEE 802.1d specification). This allows relative prioritization of IP packets over one L2CAP connection for BNEP. Actually BNEP uses only one L2CAP channel between a pair of devices, therefore a differentiation of different IP flows over BNEP is currently not possible.
Quality of Service will receive another boost when Third Generation Partnership Project (3GPP) Release 5 compatible networks will include Internet Multimedia Subsystem (IMS). When a mobile terminal (MT) provides IMS connectivity to some terminal equipment (TE), such as a notebook or personal digital assistant (PDA), using Bluetooth, several IP connections may be multiplexed over the same Bluetooth link. In order to satisfy the QoS requirements of those IP connections for accessing multimedia services (such as provided by IMS), packets belonging to those IP connections have to be handled separately at lower Bluetooth layers as well. This way the specific latency and/or bandwidth requirements can be met, and they are differentiated from best-effort traffic such as web browsing, which may also occur over the same Bluetooth link. In addition to accessing multimedia applications through a cellular network, Bluetooth devices participating in ad-hoc networks may also host applications that require specific QoS handling.
Presently, the PAN profile has a limitation to one L2CAP channel for the BNEP connection between a pair of PAN-enabled devices. This restricts the differentiation of data flows over a Bluetooth PAN connection and thus single Baseband connection. It also restricts resource reservation for flows with conflicting QoS parameters.
Therefore it would be desirable to have a mechanism for mapping data flow-dependent QoS behavior to Bluetooth L2CAP channels through BNEP to enable resource reservation and/or prioritization for the data flow.
It is further desirable to improve the present Bluetooth (ONEP and L2CAP) protocols to allow and improve multiple baseband connections between a pair of Bluetooth devices.
According a first embodiment of the present invention a method for transferring data flows or signals via a Bluetooth connection between two devices according to the Bluetooth Network Encapsulation Protocol (BNEP) is provided. Said data flow is transferred in addition to other data flows on said BNEP connection. The method comprises the operation of detecting a data flow to be transferred, and is characterized by detecting and/or determining a quality of service requirement of said data flow, and establishing a (Logical Link Control and Adaptation) protocol (L2CAP) channel dedicated for said data flow which at least meets said determined quality of service requirement.
An aspect of the invention can be explained by the example of e.g. an IP flow. The main idea of this example is to set up a L2CAP channel for an IP flow when establishing the flow. This flow co-exists with other L2CAP channels, including the main BNEP connection. Within the Bluetooth PAN profile, IP traffic is mapped onto the BNEP connection. Therefore the additional L2CAP channels for specific IP flows are part of the BNEP connection between two devices. The presented invention also provides a framework for mapping IP-based QoS mechanisms to Bluetooth-specific QoS mechanisms.
The establishment of the data flow is signaled using BNEP control packets to indicate which flow belongs to the L2CAP channel, to indicate the source and destination of the flow within the Bluetooth domain, and to negotiate the QoS parameters for the L2CAP connection. The invention overcomes the current limitation of the PAN profile of having only one L2CAP channel for the BNEP connection between a pair of PAN-enabled devices. This restricts differentiation of IP flows over a Bluetooth PAN connection and thus single Baseband connection. It also restricts resource reservation for flows with conflicting QoS parameters.
The invention may be understood as the establishment of multiple different L2CAP connections between two Bluetooth devices to be able to provide a Quality of Service (QoS) dedicated to certain types of data flows. In difference to the present state of the art, wherein all data is time multiplexed via a single L2CAP channel, the multiple L2CAP connections between different devices are established to be able to offer different QoS parameters. So instead of offering a certain data transfer schedule on transferring different data flows over a single channel, for each data flow a single custom channel is established to be able to grant the QoS parameters for each data flow. It may be noted that the different data packets of all different channels are transferred via one and the same physical transceiver elements in the Bluetooth devices. It may be noted that the number of data flows and/or L2CAP channels is not restricted in principle, but the overall QoS may be restricted by the physical layer of the Bluetooth connection.
Further it may be noted that in the state of the art there has been no specific solution for setting up L2CAP channels for specific IP QoS flows through BNEP. Neither has the state of the art offered a specific solution for reserving resources at link layer for more than one flow other than aggregating the QoS parameters i.e. there has been no way to reserve and maintain link layer resources independently for independent flows.
It may further be noted that the connection between such devices or applications may happen over a single Bluetooth connection, or may require forwarding of data packets so that correct handling of the connection is necessary for multiple Bluetooth links in the end-to-end application connection.
In contrast to the present invention, the prioritization scheme of 802.1p does not offer a mechanism for setting up flow-specific channels, nor does it provide any anticipation of IP QoS flows (e.g. bandwidth reservation, specification of minimum delay requirements). Bluetooth offers resource allocation for L2CAP channels with specific QoS parameters, but currently a state of the art BNEP only allows for one L2CAP channel (for BNEP) between a pair of Bluetooth devices. The present invention offers the advantage of setting up dedicated L2CAP channels for specific IP flows or traffic classes, while still maintaining the concept of a BNEP connection by allowing control over the additional connections through BNEP. The invention also provides a framework for mapping IP-based QoS mechanisms to Bluetooth QoS mechanisms.
The presented invention introduces the possibility to establish additional L2CAP connections for specific IP flows. Each such L2CAP connection is identified by a dynamically assigned PSM value (which is within the range of 0x1001-0xFFFF). This L2CAP channel is tied to the specific flow, or flows, it is set up for. Packets belonging to this flow are identified by a higher layer flow or packet identifier (e.g. the IP flow label, source and destination addresses and port numbers, or the 802.1p priority tag). The L2CAP channel is configured with specific QoS parameters that meet the demand of the IP flow. The information for setting up this specific L2CAP channel is exchanged using BNEP signaling packets. This information consists of at least the dynamic PSM value, type and value of the identification of packets belonging to the flow, and the set of QoS parameters for the L2CAP channel. Also, said newly established L2CAP channel can be kept free of control packets. In addition BNEP keeps control over the establishment of L2CAP channels.
Preferably, a control signaling necessary for establishing said logical channel and necessary for the operating/maintaining of said logical channel is transferred via said Bluetooth network encapsulation protocol (BNEP) data connection. In contrast to simply generating an additional L2CAP channel for a detected data flow, which would correspond to just setting up a new L2CAP channel, or an additional Bluetooth connection, the control signaling for the new L2CAP is still transferred via said BNEP connection. Thereby said newly established L2CAP channel can be kept free of control packets. In addition BNEP keeps control over the establishment of L2CAP channels. Instead of offering a certain data transfer schedule on transferring different data flows over a single channel, for each data flow a single custom channel is established to be able to grant the QoS parameters for each data flow, wherein the “administrative” signaling traffic is transferred via the standard BNEP connection. This leads to a separation of said data flow from signaling traffic of the L2CAP channel dedicated for said data flow.
Advantageously, said control signaling further includes identifying of said data flow. The identification can include the basic information such as the address of said data flow, but can naturally include the identification of Protocol/Service Multiplexer (PSM) values of said IP flow, as a BNEP L2CAP connection is identified by a specific, fixed PSM value.
Preferably, said control signaling includes the transfer of quality of service parameters according to said quality of service requirements. This is just to emphasize that the control packets transferred via said BNEP connection also include said QoS parameters to be met by said L2CAP channel.
Advantageously, said method further comprises evaluating said required quality of service. It may be noted, that the QoS value of the data flow and the QoS value of the BNBP connection/L2CAP channel may be different as e.g. the data rates may be related to the packed data stream or to the net data rate. The QoS requirements may have to be converted to grant the required net QoS in each part of the transmission. The evaluation may even use additional information of e.g. adjacent transfer channels to provide e.g. a predetermined overall QoS for e.g. a multi-hop connection. A step of evaluating said required QoS value, can help to decide, if a dedicated L2CAP channel is required or not. So according to said evaluation a L2CAP channel is set up, or is allocated to other data traffic via the BNEP connection. The evaluation may include a monitoring of the data traffic of the BNEP connection to optimize the number of L2CAP channels used.
Preferably, said establishing of said L2CAP channel includes negotiating the quality of service between said two devices. As illustrative example of the presented invention, a BNEP connection between two Bluetooth devices exists, and one of the devices wishes to reserve link resources for a specific (IP) application for a single-hop (Bluetooth) connection.
The device dispatches the following data to the peer device:
The signaling information is carried in a specific BNEP signaling packet or extension header. The peer device may reply with a confirmation of these parameters, or suggest alternative values (for the QoS parameters), or reject the request. If confirmed, a L2CAP channel is set up and configured using the negotiated QoS parameters, and subsequently all packets belonging to the QoS flow are sent over the newly established L2CAP channel. The packets are sent as normal BNEP packets conforming to the BNEP specification. Each packet sent over this L2CAP channel carries the identifier indicated in the signaling packet.
It may be noted that the negotiation of the QoS parameters can result in a L2CAP connection with higher or better QoS parameters than required, if e.g. the present data traffic between said two devices allows it. It may further be noted that the present invention can be combined with methods to optimize the data traffic in Bluetooth piconets or in scatternets, as all the QoS requirements are transferred via a single BNEP connection, so it is not necessary to determine the overall QoS requirements bit by bit.
In accordance with the invention, the method further comprises the transfer of said data flow via said dedicated L2CAP connection.
Advantageously, said data flow is an internet protocol IP) data flow. In the case of multiple L2CAP channels between two Bluetooth devices, or even multiple Baseband connections between two Bluetooth devices, different L2CAP channels (and possibly Baseband connections) have different QoS parameters, depending of the QoS requirements of their respective data flows.
Preferably, data packets of said internet based data flow are mapped to said L2CAP channel based on the identifiers of said data packets. This enables an unambiguous mapping of the IP data packets to the L2CAP channel, simplifying the mapping of the data flow from IP to L2CAP. It may be noted that this can be operated vice versa to provide a fully fledged bi-directional data communication between said data flow and the L2CAP channel, e.g. between the internet and a piconet.
Advantageously, said QoS requirement is selected from a group comprising specific latency, delay, error rate, data rate, priority, packet length, payload length, packet order, and bandwidth. The specification of the QoS parameters and the QoS parameters itself depend on the characteristics of the data flow. The term “specific latency” describes a value of an average delay of packets. The delay describes a usually constant hold up of data packets during the transmission.
According to another embodiment of the present invention, said data flow is transferred via more than one single Bluetooth connection. The data flow can be transferred via more than one L2CAP channels for each BNEP connection. The data flow can be transferred via more than one Bluetooth device by means of indicating the source and the destination addresses (at BNEP level) of the flow. Thereby in scatternets a multihop connection over multiple Bluetooth devices can be established fulfilling said QoS requirements.
Another embodiment of the present invention provides a computer program tool comprising program code means for carrying out the method for transferring data flows between two Bluetooth devices connected via a BNEP data connection on dedicated L2CAP channels. The software tool comprises program code means for performing all the steps described in the preceding description when said program is run on a computer or a network device.
According to yet another embodiment of the invention, a computer program is provided. The computer program comprises program code means stored on a computer readable medium for carrying out the method for transferring data flows between two Bluetooth devices connected via a BNEP data connection. The execution of the program on a computer or a network device leads to establishing dedicated L2CAP channels dedicated to data flows, according to the preceding description.
According to yet another embodiment the invention a computer program product is provided that comprises program code means stored on a computer readable medium for carrying out the method for transferring data flows between two Bluetooth devices connected via a BNEP data connection of the preceding description when said program product is run on a computer or a network device.
According to another embodiment of the present invention, a network device for transferring at least one data flow or signal via a Bluetooth connection between two network devices is provided. The Bluetooth connection corresponds to the Bluetooth network encapsulation protocol (BNEP). The device comprises a component for detecting at least one data flow to be transferred, and is characterized by a component for detecting a quality of service (QoS) requirement of said at least one data flow, and a component for establishing a logical (L2CAP) channel dedicated for said data flow, said channel providing a logical link control and adaptation protocol, wherein said channel is meeting at least said detected quality of service (QoS) requirement. The device transfers said at least one data flow according to the method described in the preceding description, wherein for each data flow a dedicated L2CAP channel is used for the data transfer.
In the following, the invention will be described in detail by referring to the enclosed drawings in which:
It is to be noted that the examples of
The source IP hosts and the destination IP hosts of the IP flow could identify that a packet belongs to a specific flow without including an identifier in IP packets, when passing on the packet to the BNEP layer, and the BNEP implementation could still send the packet over the correct L2CAP channel. This applies only when the end-to-end IP connection maps to a single Bluetooth connection (e.g. between NAP 36 and GN 38). If this is not the case, it is essential that an identifier is included in the packet, so that the return traffic can also be mapped to the corresponding L2CAP connection. Optionally, the source of an IP packet belonging to such a flow could identify the packet by inserting a flow label in a BNEP extension header of specific type. This has the advantage that forwarding Bluetooth devices do not have to look in higher layer protocol packet headers.
The presented method could be used in conjunction with IP-based resource reservation protocols. For example, the Resource Reservation Protocol (RSVP) could be used to trigger the link resource reservation. On the other hand, the presented invention could also be used with traffic classification or prioritization schemes, by reserving the necessary resources at link layer in order to meet the QoS parameters defined for the traffic class. This could be a formal (standardized) definition, or an application/device-specific mapping of QoS parameters to a priority level at a level higher than Bluetooth, which is subsequently mapped to a set link QoS parameters. In either way the link reservation can help to achieve (a ‘minimum’) performance expected for the traffic class/priority level or to help differentiating higher priority traffic flows from other flows (with lower priority). The link-layer resource reservation can also be used to transport multiple flows belonging to the same class/priority.
Multi-hop resource reservation could be achieved by hop-by-hop initiation of the reservation (and subsequently establishment of a dedicated L2CAP connection), e.g. by using RSVP. The presented invention could also be enhanced by providing multi-hop resource reservation at the BNEP level. When the destination address of the flow indicated in the BNEP signaling packet is not the address of the recipient of the packet (i.e. the packet is received by an intermediate node that will take care of forwarding traffic between source and destination), and the intermediate node has knowledge of the path towards the destination, this intermediate node can establish a dedicated L2CAP channel with destination (or the next hop in case there are multiple forwarders in the path) in addition to the L2CAP channel that will be established with the source. Both L2CAP channels can be configured with the same QoS parameters to provide end-to-end QoS within the multi-hop path (within the Bluetooth domain). Such forwarding device could be the GN 38 in one of the preceding examples. The nature of BNEP is such that it hides the Bluetooth topology from the link layer, therefore justifying the approach to hide the link layer QoS resource reservation from the IP layer of forwarding nodes.
It is to be noted that the implementation of the inventive method is Operating System-dependent. The API (Application Protocol Interface) between the IP layer and BNEP layer should include a mechanism to initiate/indicate link layer resource reservation and/or packet classification/priority. The L2CAP API should include a mechanism to configure a L2CAP channel with QoS parameters.
It is to be noted that the expression “data flow” is to describe any data signal comprising more than one data packet, and requiring a predetermined quality of service.
This application contains the description of implementations and embodiments of the present invention with the help of examples. It will be appreciated by a person skilled in the art that the present invention is not restricted to details of the embodiments presented above, and that the invention can also be implemented in another form without deviating from the characteristics of the invention. The embodiments presented above should be considered illustrative, but not restricting. Thus the possibilities of implementing and using the invention are only restricted by the enclosed claims. Consequently various options of implementing the invention as determined by the claims, including equivalent implementations, also belong to the scope of the invention.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/IB02/01656 | 5/15/2002 | WO | 11/15/2004 |