Confusion in Properties permission in the DA1469x_Custom_BLE_Service example

学到更多常见问题解答教程

10 posts / 0 new
最后发表
prasanna
离线
Last seen:3 days 7 hours ago
加入:2020-09-29 56
Confusion in Properties permission in the DA1469x_Custom_BLE_Service example

Hello Dialog,

我正在测试e examples "BLE_Central" and the "DA1469x_Custom_BLE_Service" to achieve some communication between the GATT client and server. In the custom service example, in the peripheral_task.c, there are two services defined with one and thee characteristics respectively. Here, I have set some random permissions for the characteristics of the both services. Please find the log file attached below.

ÿÿð@BLE中央应用程序启动BLE中央应用程序启动@BLE中央应用程序启动@ble中央应用程序启动@ble中央应用程序启动@ vt_gap_connected:conn_idx = 0000 supple_evt_gattc_discover_svc:conn_idx = 0000 uuid = 0x1800 start_h = 0001 end_h = 0007 handle_evt_gattc_discover_svc:conn_idx = 0000UUID = 0x1801 start_h = 0008 end_h = 0008 handle_evt_gattc_discover_svc:conn_idx = 0000 UUID = 11111111-0000-0000-0000-111111111111 start_h = 0009 end_h = 000D handle_evt_gattc_discover_svc:conn_idx = 0000 UUID = 22222222-0000-0000-0000-222222222222 start_h = 000Eend_h = 0016 handle_evt_gattc_discover_completed:conn_idx = 0000 type = 0 status = 0 shower_t_gattc_discover_char:conn_idx = 0000 uuid = 0x2a00句柄= 0002 value_handle = 0003属性= 02(-----)supple_evt_gattc_discover_char:conn_idx = 0000 uuid = 0x2a01句柄= 0004 value_handle = 0005属性= 02(-----)supple_evt_gattc_discover_char:conn_idx = 0000 uuid = 0x2a04句柄= 0006 value_handle = 0007属性= 02(-----)hange_evt_gattc_discover_completed:conn_idx = 0000类型= 2 status = 0 shower_evt_gattc_read_completed:conn_idx = 0000把手= 0003 status = 0 43 75 75 73 74 6f 6d 20 42 4c 45 20 53 6f 6d 20 42 4c 45 20 53 65 72 76 69定制ble servi 63 65 ce handle_evt_gattc_discover_completed:conn_idx = 0000type = 2 status = 0 shower_evt_gattc_discover_char:conn_idx = 0000 uuid = 11111111-0000-0000-0000-00000000/0000-0000-000000000001句柄= 000a value_handle = 000b属性= 22(-R --- i--)supple_evt_gattc_discover_completed:conn_idx = 0000类型= 2状态= 0 handle_evt_gattc_discover_desc:conn_idx = 0000 UUID = 0x2901手柄= 000C handle_evt_gattc_discover_desc:conn_idx = 0000 UUID = 0x2902手柄= 000D handle_evt_gattc_discover_completed:conn_idx = 0000类型= 3个状态= 0 handle_evt_gattc_discover_char:conn_idx = 0000 UUID = 22222222-0000-0000-0000-000000000001 handle=000f value_handle=0010 properties=0a (-R-W----) handle_evt_gattc_discover_char: conn_idx=0000 uuid=22222222-0000-0000-0000-000000000002 handle=0012 value_handle=0013 properties=02 (-R------) handle_evt_gattc_discover_char: conn_idx=0000 uuid=22222222-0000-0000-0000-000000000003 handle=0015 value_handle=0016 properties=02 (-R------) handle_evt_gattc_discover_completed: conn_idx=0000 type=2 status=0 handle_evt_gattc_discover_desc: conn_idx=0000 uuid=0x2901 handle=0011 handle_evt_gattc_discover_completed: conn_idx=0000 type=3 status=0 handle_evt_gattc_discover_desc: conn_idx=0000 uuid=0x2901 handle=0014 handle_evt_gattc_discover_completed: conn_idx=0000 type=3 status=0 handle_evt_gap_disconnected: conn_idx=0000 address=06:06:06:01:01:01 reason=8 handle_evt_gap_connected: conn_idx=0000 handle_evt_gattc_discover_svc: conn_idx=0000 uuid=0x1800 start_h=0001 end_h=0007 handle_evt_gattc_discover_svc: conn_idx=0000 uuid=0x1801 start_h=0008 end_h=0008 handle_evt_gattc_discover_svc: conn_idx=0000 uuid=11111111-0000-0000-0000-111111111111 start_h=0009 end_h=000d handle_evt_gattc_discover_svc: conn_idx=0000 uuid=22222222-0000-0000-0000-222222222222 start_h=000e end_h=0016 handle_evt_gattc_discover_completed: conn_idx=0000 type=0 status=0 handle_evt_gattc_discover_char: conn_idx=0000 uuid=0x2a00 handle=0002 value_handle=0003 properties=02 (-R------) handle_evt_gattc_discover_char: conn_idx=0000 uuid=0x2a01 handle=0004 value_handle=0005 properties=02 (-R------) handle_evt_gattc_discover_char: conn_idx=0000 uuid=0x2a04 handle=0006 value_handle=0007 properties=02 (-R------) handle_evt_gattc_discover_completed: conn_idx=0000 type=2 status=0 handle_evt_gattc_read_completed: conn_idx=0000 handle=0003 status=0 43 75 73 74 6f 6d 20 42 4c 45 20 53 65 72 76 69 Custom BLE Servi 63 65 ce handle_evt_gattc_discover_completed: conn_idx=0000 type=2 status=0 handle_evt_gattc_discover_char: conn_idx=0000 uuid=11111111-0000-0000-0000-000000000001 handle=000a value_handle=000b properties=22 (-R---I--) handle_evt_gattc_discover_completed: conn_idx=0000 type=2 status=0 handle_evt_gattc_discover_desc: conn_idx=0000 uuid=0x2901 handle=000c handle_evt_gattc_discover_desc: conn_idx=0000 uuid=0x2902 handle=000d handle_evt_gattc_discover_completed: conn_idx=0000 type=3 status=0 handle_evt_gattc_discover_char: conn_idx=0000 uuid=22222222-0000-0000-0000-000000000001 handle=000f value_handle=0010 properties=0a (-R-W----) handle_evt_gattc_discover_char: conn_idx=0000 uuid=22222222-0000-0000-0000-000000000002 handle=0012 value_handle=0013 properties=02 (-R------) handle_evt_gattc_discover_char: conn_idx=0000 uuid=22222222-0000-0000-0000-000000000003 handle=0015 value_handle=0016 properties=02 (-R------) handle_evt_gattc_discover_completed: conn_idx=0000 type=2 status=0 handle_evt_gattc_discover_desc: conn_idx=0000 uuid=0x2901 handle=0011 handle_evt_gattc_discover_completed: conn_idx=0000 type=3 status=0

这些是我所设定的冒充特征权限。

const mcs_characteristic_config_t custom_service_1[] = { /* Initialized Characteristic Attribute */ CHARACTERISTIC_DECLARATION(11111111-0000-0000-0000-000000000001, CHARACTERISTIC_ATTR_VALUE_MAX_BYTES, CHAR_WRITE_PROP_DIS, CHAR_READ_PROP_DIS, CHAR_NOTIF_INDIC_EN, Initialized Characteristic, NULL, NULL, event_sent_cb), }; const mcs_characteristic_config_t custom_service_2[] = { CHARACTERISTIC_DECLARATION(22222222-0000-0000-0000-000000000001, CHARACTERISTIC_ATTR_VALUE_MAX_BYTES, CHAR_WRITE_PROP_EN, CHAR_READ_PROP_DIS, CHAR_NOTIF_NONE, Hello World, NULL, set_var_value_cb, NULL), CHARACTERISTIC_DECLARATION(22222222-0000-0000-0000-000000000002, CHARACTERISTIC_ATTR_VALUE_MAX_BYTES, CHAR_WRITE_PROP_DIS, CHAR_READ_PROP_EN, CHAR_NOTIF_NONE, Hello Dialog, get_var_value_cb, NULL, NULL), CHARACTERISTIC_DECLARATION(22222222-0000-0000-0000-000000000003, 0, CHAR_WRITE_PROP_DIS, CHAR_READ_PROP_DIS, CHAR_NOTIF_NONE, NULL, NULL, NULL, NULL), };

请将附加输出日志的权限进行比较。您可以看到服务1的唯一特征的属性打印为( - --- i--),即使我已禁用read属性。

Coming to the second service characteristics, They are printed as (-R-W----), (-R------) and (-R------) for the three characteristics respectively which are in contrast with the permissions which I actually gave.

仅根据我给出的内容正确打印第二服务的第二个特征权限。

I request you to investigate about why this happens and suggest me what can I do to avoid this conditions. This is very important for my application as I have to exchange data between the GATT client and the Server.

提前致谢。

Regards,

普拉斯坦娜

设备:
PM_Dialog
离线
Last seen:2 days 12 hours ago
职员
加入:2018-02-08 11:03
Hi Prasanna,

Hi Prasanna,

让我检查一下,我会回复你。

Thanks, PM_Dialog

prasanna
离线
Last seen:3 days 7 hours ago
加入:2020-09-29 56
你好pm_dialog,

你好pm_dialog,

Is there any update about this issue. I have checked this with two characterisitics with one read disabled and the other write disabled. The write properties are working fine , I found there is problem with read permissions. Have you found the same?

2. Also, i am getting the status sometimes that is not defined. For example, when I tried to read a characteristic value, I am getting the output as "handle_evt_gattc_read_completed: conn_idx=0000 handle=000a status=67". Here you can see the status as 67. What does this behaviour mean since there is no error value declared for value 67 in the enum att_error_t in ble_att.h file.

Regards,

普拉斯坦娜

PM_Dialog
离线
Last seen:2 days 12 hours ago
职员
加入:2018-02-08 11:03
Hi Prasanna,

Hi Prasanna,

因此,如果我理解正确的问题,问题只在自定义服务1中,其中错误的属性似乎没有正确看起来。

Can you please try to connect with a generic BLE mobile application and check also the permissions ?

Additionally, can you please share which modifications have you done in the example except from the characteristics database? Are you using the example as provided by dialog or have you done any change?

Thanks, PM_Dialog

prasanna
离线
Last seen:3 days 7 hours ago
加入:2020-09-29 56
你好pm_dialog,

你好pm_dialog,

我也使用NRF Connect应用程序检查。即使我禁用了读取特性,我也可以在应用程序中看到read属性。读的财产似乎有问题。我们可以读取禁用或启用的读取。

除了更改权限之外,我没有在自定义服务示例中修改代码。

PM_Dialog
离线
Last seen:2 days 12 hours ago
职员
加入:2018-02-08 11:03
H Prasanna,

H Prasanna,

我们正在研究本教程,并将在本周末发布更新的版本。一旦新版本可供下载,我会通知您。

Thanks, PM_Dialog

prasanna
离线
Last seen:3 days 7 hours ago
加入:2020-09-29 56
你好pm_dialog,

你好pm_dialog,

感谢更新。

Regards,

普拉斯坦娜

prasanna
离线
Last seen:3 days 7 hours ago
加入:2020-09-29 56
Hello Dialog,

Hello Dialog,

新版本可用时是否有任何更新?

Regards,

普拉斯坦娜

Annamarie
离线
Last seen:3天13小时前
加入:2021-01-27 11:14
Pleased to see your issue as

很高兴看到你的问题,因为我想我有同样的问题,我也很困惑,需要在同样的问题上轻松。需要帮忙。

myaarpmedicare登录

PM_Dialog
离线
Last seen:2 days 12 hours ago
职员
加入:2018-02-08 11:03
大家好,

大家好,

我会在内部检查状态并很快恢复给您。

Thanks, PM_Dialog