嗨,对话框中,
我的客户想使用通用访问(0x1800)的设备名称(0x2A00)特性来修改设备名称。
我将user_config.h中的user_gapm_conf修改如下……
.att_cfg = GAPM_MASK_ATT_SVC_CHG_EN | GAPM_MASK_ATT_NAME_PERM,
我还在“default_app_on_set_dev_info”函数中添加了一些调试日志,但它似乎不工作。
有什么不对吗?
我的设备信息。DA14585 SDK: 6.0.4
谢谢。
设备:
嗨stanley_yeh,
似乎有一个问题在回调函数gapc_set_dev_info_req_ind_handler()确认发送的任务应该TASK_GAPC而不是TASK_GAPM也回调实际上并不改变设备的名称,所以一旦回调你应该更改设备名称的应用程序的回调。我正在和SDK团队核对这个,一旦我有一些反馈,我会让你知道。
由于MT_dialog
非常感谢!
嗨MT_dialog,
我试图在app_entry_point_handler和gapc_set_dev_info_req_ind_handler函数中打印一些消息。
然而,似乎DA14585没有收到任何事件。
我能自己解决这个问题吗?这个问题是否必须更新system_library。lib,我不能修复它?
谢谢。
嗨stanley_yeh,
当前的实现允许您有一个回调通知您,当有人编写特定的特征时,但没有实际的实现来更改数据库中的名称,这是SDK团队正在研究的。所以,如果你只是想获得回调,当某人写在特定的特征,所有你需要做的是做以下更改:
在上面的改变之后,你应该看到default_app_on_set_dev_info()回调发生,但这只是中央写了这个特征,这不会改变数据库中的名称。
由于MT_dialog
嗨MT_Dialog,
非常感谢。我现在可以接收事件了。
很抱歉,我不明白下面这句话的意思:
1.“这不会改变数据库中的名称。”
你能告诉我如果数据库中的名称无法更改会有什么风险和后果吗?
你的意思是设备名是SDK中的定义(#define USER_DEVICE_NAME "DA14585"),所以没有实际的实现来改变它?
实际上,我已经实现了一个函数,可以存储设备名到外部闪存。所以你说的判决对我的案子没有影响,对吗?
2."对特定特征进行无安全性的写入。"
我的客户说写的特点必须是安全的。我不明白为什么GAPM_MASK_ATT_NAME_PERM不能工作?
非常感谢。
嗨stanley_yeh,
1)将会发生什么,因为SDK,此刻无论你写的设备提供的SDK不会存储名称你它就值发送到设备,你就能得到它,但设备一旦你看阿甘的名字不会改变,设备将报告相同的名称。所以,在SDK中没有实际的实现来改变它。我不知道你说你已经实现了一个在外部闪存中存储设备名称的函数是什么意思。但是为了能够通过这个特性改变设备的名称,你必须对SDK本身应用改变,显然,你必须分配一个指向USER_DEVICE_NAME的指针,而不是固定的名称,指针将显示一个数组,将用于存储实际设备的名称,无论何时通过写入改变名称的特征,你将不得不复制数据从写入到该数组。
2)如果启用,每个特性都有一些安全特性。这意味着如果您将0x03 (GAPM_MASK_ATT_NAME_PERM)的值分配给设备的名称特征,这意味着为了能够写入该特征,设备要求通过身份验证来保护链接。因此,如果链接没有身份验证,这意味着该设备不允许您写入该特定特征,因为您不符合该设备设置的要求。另一方面,如果您应用了0x01的值,这意味着您启用了写入特征,但没有额外的安全性,这意味着连接到设备的任何人都能够写入特征。
由于MT_dialog
嗨MT_dialog,
非常感谢您提供的详细信息。
对于第一个问题,我可以自己保存设备名称。没问题。
第二个问题,我还需要安全特性,如果有新的SDK版本请告诉我。
多谢。
嗨stanley_yeh,
SDK的最新版本是6.0.6,有一个项目已经实现了安全性(ble_app_security),我不太明白到底是什么问题。如果您应用值GAPM_MASK_ATT_SVC_CHG_EN|0x03,那么为了写入特征将需要安全性,如果没有初始化配对,那么您将不能写入特征。如果您不希望对该特征进行保护,那么.att_cfg的GAPM_MASK_ATT_SVC_CHG_EN|0x01将允许您在没有安全保护的情况下写入该特征。
由于MT_dialog
嗨MT_Dialog,
我现在使用SDK 6.0.6,我也设置“。att_cfg = (GAPM_MASK_ATT_SVC_CHG_EN | 0x03)"
我第一次写一个字符串的特征,应用程序显示他们的关系。
绑定后,我仍然不能设置设备名称。应用程序显示“错误0x5: GATT INSUF认证”
是否将“gapc_set_dev_info_req_ind_handler”函数中的参数TASK_GAPM修改为TASK_GAPC,如下所示?
struct gapc_set_dev_info_cfm* cfm = KE_MSG_ALLOC(gapc_set_dev_info_cfm,
/ * TASK_GAPM TASK_GAPC, * /
TASK_APP,
gapc_set_dev_info_cfm);
你能给我一些建议吗?
非常感谢。
嗨stanley_yeh,
正如我在前一篇文章中所述,SDK没有实现更改设备名称,但它会在应用级别触发你的指示,所以我认为你已经应用了自定义修改,你还必须从TASK_GAPM改为TASK_GAPC,以便向你接受或不接受改变的对等设备发回验证。关于GATT_INSUF_AUTHENTICATION,这是你第一次尝试设置名称和中央启动绑定时应该得到的(在ble_app_security的情况下),绑定完成后,将发生回调(default_app_on_set_dev_info),您必须在应用程序中处理名称的接收,决定接受还是拒绝新名称,并返回带有适当状态的GAPC_SET_DEV_INFO_CFM,为了正确地发送回确认,你必须从TASK_GAPM改为TASK_GAPC。
由于MT_dialog