-
Version: V12r00
-
Version Date: 2006-04-27
-
Prepared by: HID WG
Revision History
Public versions are listed below. For a complete revision history see 8, Appendix A — Detailed Revision History (Informative). |
Revision |
Date |
Comments |
---|---|---|
1.0 |
January 16, 2003 |
Initial whitepaper release |
1.1 |
October 01, 2003 |
Clarified that VendorID attribute uses Bluetooth CompIDs or USB VendorIDs |
D12r00 |
April 29, 2005 |
Release for committee approval |
V12r00 |
April 27, 2006 |
Adopted by the Bluetooth Board of Directors |
Contributors
Name |
Company |
---|---|
Uma Gadamsetty |
Intel Corporation |
Srikanth Kambhatla |
Intel Corporation |
Ron Mosgrove |
Intel Corporation |
Sridhar Rajagopal |
Intel Corporation |
Robert Hunter |
Intel Corporation |
Kenneth Ray |
Microsoft Corporation |
Doron Holan |
Microsoft Corporation |
Arun Ayyagari |
Microsoft Corporation |
Bob Fruth |
Microsoft Corporation |
Om Sharma |
Microsoft Corporation |
Craig Ranta |
Microsoft Corporation |
Chris Dreher |
Microsoft Corporation |
Wayne King |
Microsoft Corporation |
Peter Hauser |
Microsoft Corporation |
Johannes Elg |
Ericsson Mobile Communications AB |
Roland Meyer |
Logitech |
René Sommer |
Logitech |
Thomas Muller |
Nokia Mobile Phones |
Markus Schetelig |
Nokia Mobile Phones |
Ned Plasson |
3Com |
Dale Farnsworth |
Motorola |
Brent Miller |
IBM Corporation |
Toshiki Kizu |
Toshiba Corporation |
Gary Clemo |
Toshiba Corporation |
Graham Hamilton |
Sun Microsystems |
DISCLAIMER AND COPYRIGHT NOTICE
The copyright in this specification is owned by the Promoter Members of Bluetooth® Special Interest Group (SIG), Inc. (“Bluetooth SIG”). Use of these specifications and any related intellectual property (collectively, the “Specification”), is governed by the Promoters Membership Agreement among the Promoter Members and Bluetooth SIG (the “Promoters Agreement”), certain membership agreements between Bluetooth SIG and its Adopter and Associate Members (the “Membership Agreements”) and the Bluetooth Specification Early Adopters Agreements (1.2 Early Adopters Agreements) among Early Adopter members of the unincorporated Bluetooth SIG and the Promoter Members (the “Early Adopters Agreement”). Certain rights and obligations of the Promoter Members under the Early Adopters Agreements have been assigned to Bluetooth SIG by the Promoter Members.
Use of the Specification by anyone who is not a member of Bluetooth SIG or a party to an Early Adopters Agreement (each such person or party, a “Member”), is prohibited. The legal rights and obligations of each Member are governed by their applicable Membership Agreement, Early Adopters Agreement or Promoters Agreement. No license, express or implied, by estoppel or otherwise, to any intellectual property rights are granted herein.
Any use of the Specification not in compliance with the terms of the applicable Membership Agreement, Early Adopters Agreement or Promoters Agreement is prohibited and any such prohibited use may result in termination of the applicable Membership Agreement or Early Adopters Agreement and other liability permitted by the applicable agreement or by applicable law to Bluetooth SIG or any of its members for patent, copyright and/or trademark infringement.
THE SPECIFICATION IS PROVIDED “AS IS” WITH NO WARRANTIES WHATSOEVER, INCLUDING ANY WARRANTY OF MERCHANTABILITY, NONINFRINGEMENT, FITNESS FOR ANY PARTICULAR PURPOSE, SATISFACTORY QUALITY, OR REASONABLE SKILL OR CARE, OR ANY WARRANTY ARISING OUT OF ANY COURSE OF DEALING, USAGE, TRADE PRACTICE, PROPOSAL, SPECIFICATION OR SAMPLE.
Each Member hereby acknowledges that products equipped with the Bluetooth technology ("Bluetooth products") may be subject to various regulatory controls under the laws and regulations of various governments worldwide. Such laws and regulatory controls may govern, among other things, the combination, operation, use, implementation and distribution of Bluetooth products. Examples of such laws and regulatory controls include, but are not limited to, airline regulatory controls, telecommunications regulations, technology transfer controls and health and safety regulations. Each Member is solely responsible for the compliance by their Bluetooth Products with any such laws and regulations and for obtaining any and all required authorizations, permits, or licenses for their Bluetooth products related to such regulations within the applicable jurisdictions. Each Member acknowledges that nothing in the Specification provides any information or assistance in connection with securing such compliance, authorizations or licenses. NOTHING IN THE SPECIFICATION CREATES ANY WARRANTIES, EITHER EXPRESS OR IMPLIED, REGARDING SUCH LAWS OR REGULATIONS.
ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY INTELLECTUAL PROPERTY RIGHTS OR FOR NONCOMPLIANCE WITH LAWS, RELATING TO USE OF THE SPECIFICATION IS EXPRESSLY DISCLAIMED. BY USE OF THE SPECIFICATION, EACH MEMBER EXPRESSLY WAIVES ANY CLAIM AGAINST BLUETOOTH SIG AND ITS PROMOTER MEMBERS RELATED TO USE OF THE SPECIFICATION.
Bluetooth SIG reserve the right to adopt any changes or alterations to the Specification as it deems necessary or appropriate.
Copyright © 2001, 2002, 2003, 2004, 2005, 2006. Bluetooth SIG Inc. All copyrights in the Bluetooth Specifications themselves are owned by Agere Systems Inc., Ericsson Technology Licensing AB, IBM Corporation, Intel Corporation, Microsoft Corporation, Motorola, Inc., Nokia Mobile Phones and Toshiba Corporation. *Other third-party brands and names are the property of their respective owners.
1. Overview
1.1. Scope
The scope of this document is identification of devices with Bluetooth wireless technology. This document specifies a profile to provide additional information above and beyond the Bluetooth Class of Device.
1.2. Purpose
The purpose of this document is to provide a profile specification for the identification of devices based on brand and device information (such as manufacturer and product identifier). This is important in order to make best use of the features on the device identified. A few examples illustrating possible uses of this information are listed below:
-
In PC-to-PC usage models (such as conference table and file transfer), a PC may use this information to supplement information from other Bluetooth specifications to identify the right device to communicate with.
-
A cellular phone may use this information to identify associated accessories or download Java apps from another device that advertises its availability.
-
In PC to peripheral usage models (such as dial up networking using a cellular phone), the PC may need to download device drivers for that peripheral from a web site. To do this the driver must know the proper identity if the peripheral.
The information contained in this specification enables any device to properly identify other devices that come into range with Bluetooth wireless technology. To facilitate this, this document defines standardized ways in which such device identification (DI) information is exported by devices using the Bluetooth SDP [1] framework. It is assumed that the reader is familiar with the Bluetooth SDP [1] framework specification.
Similar efforts have been undertaken in the past for various bus technologies including Infrared communications [2], USB, 1394, PCI, PnP ISA, and EISA, among others.
2. Normative References
The following standards contain provisions which, through references in this text, constitute provisions of this standard. At the time of publication, the editions indicated were valid. All standards are subject to revision, and parties to agreements based on this standard are encouraged to investigate the possibility of applying the most recent editions of the standards listed below.
Bibliography
[1] Specification of the Bluetooth system – Core, version 1.2 or later
[2] Infrared Data Association Plug and Play Extensions to Link Management Protocol, version 1.1, IrDA Specification
3. Acronyms and Abbreviations
Acronym or Abbreviation |
Definition |
---|---|
DI |
Device Identification |
IrDA |
Infra-red Data Association |
M |
Mandatory |
O |
Optional |
OS |
Operating System |
SDP |
Service Discovery |
UUID |
Universally Unique IDentifier |
SIG |
Special Interest Group |
4. DI Information
DI information for the device is exported in terms of an explicit SDP record on that device. This will be called the DI Service Record, and is identified by a unique UUID – this UUID is called the PNPInformation and is part of the Bluetooth Assigned Numbers document – see Assigned Numbers web pages at http://www.bluetooth.org.
A manufacturer may choose to have more than one DI service record in a device if the device consists of multiple logical devices in a single physical device i.e., if it is a composite device. Only the one DI service record for which the PrimaryRecord attribute[1] is set to TRUE will be used to uniquely identify the device – see 9.
It should be noted that the DI service record is in addition to any other service records already exported by the device for different profiles supported on the device. It is important to distinguish between the device specific information that is available in the DI service record and the service specific information that is available in other Bluetooth SIG profile recommended service records.
5. DI Service Record
The DI Service Record attributes are listed below.
Attribute |
Attribute ID |
Attribute Value Type2 |
Status |
Section |
---|---|---|---|---|
SpecificationID |
0x0200 |
Uint16 |
M |
5.1 |
VendorID |
0x0201 |
Uint16 |
M |
5.2 |
ProductID |
0x0202 |
Uint16 |
M |
5.3 |
Version |
0x0203 |
Uint16 |
M |
5.4 |
PrimaryRecord |
0x0204 |
Boolean |
M |
5.5 |
VendorIDSource |
0x0205 |
Uint16 |
M |
5.6 |
ClientExecutableURL |
0x000B |
URL |
O |
Note 3 |
ServiceDescription |
0x0001 Note 1 |
String |
O |
Note 3 |
DocumentationURL |
0x000A |
URL |
O |
Note 3 |
Notes
-
For national language support for all “displayable” text string attributes, an offset has to be added to the LanguageBaseAttributeIDList value for the selected language (see the SDP Specification [1] for details)
-
Notation: Uint16 = 2 byte Unsigned Integer
-
These attributes are recommended - See 10.
The following sections describe the mandatory attributes present in the DI record. See 10 for a description of the recommended optional attributes.
5.1. SpecificationID Attribute
Attribute Name |
Attribute ID |
Attribute Value Type |
---|---|---|
SpecificationID |
0x0200 |
2 byte unsigned integer |
Description:
This is intended to reflect the version number of the Bluetooth DI specification supported by the device. The two most significant hexadecimal digits will indicate the major number of the Bluetooth DI specification and the two least significant hexadecimal digits will reflect the minor number of the specification.
For example, version 1.2 will be 0x0102.
5.2. VendorID Attribute
Attribute Name |
Attribute ID |
Attribute Value Type |
---|---|---|
VendorID |
0x0201 |
2 byte unsigned integer |
Description:
This is intended to uniquely identify the vendor of the device. Used in conjunction with required attribute 0x0205, VendorIDSource, which determines which organization assigned the VendorID value.
Note: The Bluetooth Special Interest Group assigns Device ID Vendor ID and the USB Implementer’s Forum assigns vendor IDs, either of which can be used for the VendorID value here. Device providers should procure the vendor ID from the USB Implementer’s Forum or the Company Identifier from the Bluetooth SIG.
The VendorID ‘0xFFFF’ is reserved as the default VendorID when no DI record is present in the device.
An example value for a device is 0x23A1.
5.3. ProductID Attribute
Attribute Name |
Attribute ID |
Attribute Value Type |
---|---|---|
ProductID |
0x0202 |
2 byte unsigned integer |
Description:
This is intended to distinguish between different products made by the vendor above. These IDs are managed by the vendors themselves.
An example value for a product is 0x1234.
5.4. Version Attribute
Attribute Name |
Attribute ID |
Attribute Value Type |
---|---|---|
Version |
0x0203 |
2 byte unsigned integer |
Description:
A numeric expression identifying the device release number in Binary-Coded Decimal. This is a vendor-assigned field, which defines the version of the product identified by the VendorID and ProductID attributes. This attribute is intended to differentiate between versions of products with identical VendorIDs and ProductIDs. The value of the field is 0xJJMN for version JJ.M.N (JJ – major version number, M – minor version number, N – sub-minor version number); e.g., version 2.1.3 is represented with value 0x0213 and version 2.0.0 is represented with a value of 0x0200. When upward-compatible changes are made to the device, it is recommended that the minor version number be incremented. If incompatible changes are made to the device, it is recommended that the major version number be incremented.
5.5. PrimaryRecord Attribute
Attribute Name |
Attribute ID |
Attribute Value Type |
---|---|---|
PrimaryRecord |
0x0204 |
Boolean |
Description:
This is intended to designate one particular DI record (in case multiple DI records exist on a device) as the primary DI record for the device – the PrimaryRecord attribute is set to TRUE for that record and FALSE for all other records. The client device can use the primary DI record from the source device for UI purposes.
This field shall be set to TRUE in the case where a single DI record exists in the device.
5.6. VendorIDSource Attribute
Attribute Name |
Attribute ID |
Attribute Value Type |
---|---|---|
VendorIDSource |
0x0205 |
2 byte unsigned integer |
Description:
This attribute designates which organization assigned the VendorID attribute, 0x201.
Defined values:
0x0001 = Bluetooth SIG assigned Device ID Vendor ID value from the Assigned Numbers document
0x0002 = USB Implementer’s Forum assigned Vendor ID value
0x0000, 0x0003 – 0xFFFF = Reserved for future use
5.7. Reserved Attribute IDs
Attribute IDs in the range 0x0206 through 0x02FF are reserved for future use.
5.8. Additional Details
The following should be noted:
-
There is no compatible ID[2] entry in the record similar to some of the earlier technologies.
-
The Product ID should be changed when a new feature is added to the device.
-
Version information in the record is used to capture revisions in the device. Examples include bug fixes or enhancements in existing features. The version number should increase in a strictly monotonical manner.
-
Hardware IDs based on the device information are not specified here since they are OS and implementation dependent.
6. SDP Transactions to Obtain DI Information
The device and function information presented in this document may be present in devices with Bluetooth wireless technology as an SDP service record. This record is identified by a unique service class UUID. This UUID is assigned in the Bluetooth Assigned Numbers document – see Assigned Numbers web pages at http://www.bluetooth.org.
For details on the Transactions see the SDP Protocol Description section in [1] and Appendix C of this document.
7. Conformance
Support for the DI service record in devices with Bluetooth wireless technology is optional; however, when implemented, the attributes shall be implemented as characterized in the table below:
Attribute |
Requirement |
---|---|
SpecificationID |
Mandatory |
VendorID |
Mandatory |
ProductID |
Mandatory |
Version |
Mandatory |
PrimaryRecord |
Mandatory |
VendorIDSource |
Mandatory |
ClientExecutableURL |
Optional |
ServiceDescription |
Optional |
DocumentationURL |
Optional |
8. Appendix A — Detailed Revision History (Informative)
Public versions are in bold in the table below.
Revision |
Date |
Comments |
---|---|---|
0.1 |
April 9, 1999 |
Initial Draft. |
0.2 |
May 17, 1999 |
Added Profile PnP strings. See Section 10. |
0.5 |
March 9, 2000 |
Document revised for SDP 1.0; revised DI record & IDs. |
0.6 |
March 24, 2000 |
Incorporates review comments, several TBDs completed. |
0.7 |
May 4, 2000 |
Added SDP types to the attributes, removed VER and FID from PnP ID, added sample DI record, incorporated review comments. |
0.71 |
May 25, 2000 |
Incorporates comments from ESDP f2f meeting. |
0.72 |
July 17, 2000 |
Added VER back to PnP ID, added VID_ and PID_ prefixes in the PnP ID, added Documentation URL, corrected the AttributeID value for ServiceDescription. |
0.73 |
August 14, 2000 |
Incorporated changes that position the DI record for device identification rather than driver loading. Removed text that was meant for clarification purposes only. Changed the copyright statement. |
0.74 |
August 17, 2000 |
Includes comments from Salt Lake f2f. |
0.75 |
August 24, 2000 |
PrimaryRecord attribute added. Includes comments from Markus. |
0.90 |
September 8, 2000 |
Review comments from team included. |
0.91 |
September 27, 2000 |
Adds a note on use of multiple DI records and some clarifying text on ClientExecutableURL. An edit on Attribute ID in section 5.1.2. |
0.95 |
October 12, 2000 |
Includes comments from North Carolina f2f. |
0.95a |
July 12, 2002 |
Modified by HID working group to add VendorIDSource attribute. Clarifies whether Vendor ID was assigned by USB or Bluetooth. |
0.95b |
July 29, 2002 |
Corrected typographical error in VendorIDSource attribute description. |
1.0_draft |
November 8, 2002 |
Modified the Version attribute in section 5.5 to BCD format to better align with software versioning conventions. |
1.0 |
January 16, 2003 |
Initial whitepaper release. |
1.1_draftA |
August 26, 2003 |
Modified VendorID and VendorIDSource to specifically mention the CompID value listed in the Bluetooth Assigned Numbers document. |
1.1 |
September 18, 2003 |
Updated version field to 1.1 for release. |
1.1 |
October 01, 2003 |
Clarified that VendorID attribute uses Bluetooth CompIDs or USB VendorIDs |
0.9r01 |
August 19, 2004 |
Created draft for specification approval. Note: the Specification Management process requires particular version numbers for first-time specification, even though Device ID previously was a whitepaper. This is why the version number was temporarily rolled back. |
0.9r02 |
September 3, 2004 |
Made ServiceDescription attribute optional |
0.9r04 |
November 3, 2004 |
Add public revision history, moved detailed revision history to appendix A |
0.9r5 |
November 08, 2004 |
Added 1.0 and 1.1 public release dates to Detailed Revision history table |
0.9r6 |
November 24, 2004 |
Editorial comments |
0.9r7 |
January 1, 2005 |
Incorporated editorial feedback from BARB reviews |
0.9r8 |
February 15, 2005 |
Editorial comments |
1.0r01 |
April 19, 2005 |
Editorial changes |
D12r00 |
April 29, 2005 |
Release for committee approval |
D12r01 |
June 28, 2005 |
Removed non-unique acronyms & abbreviations Section 5, Table 1: changed referenced section numbers Appendix C: Corrected referenced Section number to 5.1.11 |
D12r02 |
July 21, 2005 |
Editorial changes |
D12r03 |
October 27, 2005 |
Accepted changes and made editorial changes. |
D12r04 |
March 02, 2006 |
Editorial updates |
V12r00 |
April 27, 2006 |
Adopted by Board of Directors |
9. Appendix B — Example Use of Multiple DI Records (informative)
The way in which drivers are loaded into client operating systems can vary from operating system to operating system. Typical operating systems will understand particular categories of devices (such as printers or VGA projectors) and will know how to plumb device drivers into their standard operating system infrastructure and UI model. So for example, a Java operating environment might understand how to load a Printer Driver and then use it as part of its print services.
However, there can occasionally be physical devices that combine concepts that the operating system has kept logically separate. For example, someone might provide a conference room server that combines the functionality of a VGA projector and a printer.
This might be exposed through two DI records.
For those operating systems that allow arbitrary combinations of drivers, the driver associated with the primary DI record might provide all the functionality of both the printer and the VGA projector.
However, for operating systems that require separate drivers for the separate concepts, the first DI record might identify an arbitrarily selected "primary" device driver, such as the VGA projector. Then the second DI record can identify a secondary device driver, such as a printer driver.
How DI records are processed will depend on the client operating system. If the client operating system expects all device functionality to be exposed via a single driver it need only use the primary DI. If a client operating system expects to see separate drivers for logically distinct functions, then it will check all the available DI records and attempt to load the drivers associated with each DI record.
9.1. Recommended Universal Attributes (informative)
This section lists the SDP universal attributes that are recommended for the DI service record.
ClientExecutableURL Attribute
Attribute Name |
Attribute ID |
Attribute Value Type |
---|---|---|
ClientExecutableURL |
0x000B |
URL |
Description:
See the SDP Specification in [1] for details, Section 5.1.11.
Note
Advertisement of the ClientExecutableURL is optional in a DI record. If advertised, it is meant to be yet another mechanism for distribution of device executables, and it can be referred to in an implementation dependent manner to obtain a desired executable. It is possible that a Bluetooth stack implementation on a particular OS may not find an appropriate executable when the URL is referenced. It is also possible that even if an appropriate executable is available, a Bluetooth stack implementation on a particular OS may not use that executable.
ServiceDescription Attribute
Attribute Name |
Attribute ID Offset |
Attribute Value Type |
---|---|---|
ServiceDescription |
0x0001 |
String |
Description:
See the SDP Specification in [1] for details, Section 5.1.15.
Note
For national language support for all “displayable” text string attributes, an offset has to be added to the LanguageBaseAttributeIDList value for the selected language (see the SDP Specification [1] for details)
DocumentationURL Attribute
Attribute Name |
Attribute ID |
Attribute Value Type |
---|---|---|
DocumentationURL |
0x000A |
URL |
Description:
See the SDP Specification in [1] for details, Section 5.1.15.
Note
This can be instructions on how to install drivers, or an explanation of different drivers available from the ClientExecutableURL.
10. Appendix C — SDP Transactions (informative)
10.1. Requesting the DI Service Record
The DI service record is requested using the standard SDP_ServiceSearchRequest PDU.
PDU Parameters:
-
The ServiceSearchPattern should be a Data Element Sequence containing only the DI service class UUID.
-
The 16-bit MaximumSeviceRecordCount value is the maximum number of service record handles to be based on the search. Remembering that a different DI service record is expected for each function on the device, this value of this parameter should be appropriately large.
10.2. Response to the DI Service Record Request
The requesting device gets back an SDP_ServiceSearchResponse PDU containing handles to the DI service records on the device, if any.
-
The TotalServiceRecordCount parameter returns the number of DI service records in the device
-
A value of zero returned in TotalServiceRecordCount indicates that DI service records are not present in the device fielding the search request. This is possible since inclusion of DI service record information in devices is optional.
10.3. Access to Attributes in DI Service Record
For a given service handle, the individual attributes in the DI service record(s) can be requested using the SDP_ServiceAttributeRequest PDU.
The attributes themselves are returned in the SDP_ServiceAttributeResponse PDU.
SDP_ServiceSearchAttributeRequest PDU can alternatively be used to combine Service search and attribute request PDUs into a single request, as described in the SDP specification [1]. The attributes in this case are returned using the SDP_ServiceSearchAttributeResponse PDU.