gatttool之间的区别--char-desc和 - 特性

时间:2017-04-03 07:49:05

标签: bluetooth-lowenergy gatttool

gatttool --help-all说明如下:

Usage:
  gatttool [OPTION...]

Help Options:
  -h, --help                                Show help options
  --help-all                                Show all help options
  --help-gatt                               Show all GATT commands
  --help-params                             Show all Primary Services/Characteristics arguments
  --help-char-read-write                    Show all Characteristics Value/Descriptor Read/Write arguments

GATT commands
  --primary                                 Primary Service Discovery
  --characteristics                         Characteristics Discovery
  --char-read                               Characteristics Value/Descriptor Read
  --char-write                              Characteristics Value Write Without Response (Write Command)
  --char-write-req                          Characteristics Value Write (Write Request)
  --char-desc                               Characteristics Descriptor Discovery
  --listen                                  Listen for notifications and indications

Primary Services/Characteristics arguments
  -s, --start=0x0001                        Starting handle(optional)
  -e, --end=0xffff                          Ending handle(optional)
  -u, --uuid=0x1801                         UUID16 or UUID128(optional)

Characteristics Value/Descriptor Read/Write arguments
  -a, --handle=0x0001                       Read/Write characteristic by handle(required)
  -n, --value=0x0001                        Write characteristic value (required for write operation)

Application Options:
  -i, --adapter=hciX                        Specify local adapter interface
  -b, --device=MAC                          Specify remote Bluetooth address
  -t, --addr-type=[public | random]         Set LE address type. Default: public
  -m, --mtu=MTU                             Specify the MTU size
  -p, --psm=PSM                             Specify the PSM for GATT/ATT over BR/EDR
  -l, --sec-level=[low | medium | high]     Set security level. Default: low
  -I, --interactive                         Use interactive mode

--characteristicsCharacteristics Discovery--char-descCharacteristics Descriptor现在有什么不同?

如果我在同一个BLE设备上运行它们,我会得到同一个uuid的不同手柄? 例如:

gatttool --device=C4:7C:8D:62:D3:19 --characteristics
...
handle = 0x0032, char properties = 0x0a, char value handle = 0x0033, uuid = 00001a00-0000-1000-8000-00805f9b34fb
...

gatttool --device=C4:7C:8D:62:D3:19 --char-desc
...
handle = 0x0033, uuid = 00001a00-0000-1000-8000-00805f9b34fb
...

在使用--characteristics时,我应该使用--char-desc的句柄还是read/write (-a parameter)的句柄?

1 个答案:

答案 0 :(得分:1)

将描述符视为关于特征的元数据,或描述特征值的定义属性"。例如,您可能具有一个包含某些测量值的特征,然后该特征还具有描述该值的可接受范围的描述符。

如果您阅读了这个特征,那么您将获得自己的价值;读取范围描述符然后您将获得有效范围。

蓝牙规范中已采用了一些描述符并分配了数字,有些描述符可能是自定义的,没有一般文档。

一个体面的参考: https://www.bluetooth.com/specifications/gatt/descriptors

更具体的上述范围示例: https://www.bluetooth.com/specifications/gatt/viewer?attributeXmlFile=org.bluetooth.descriptor.valid_range.xml