嗨,对话框中,
我的客户想使用通用访问(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,
好吧,似乎在回调函数eapc_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),您必须处理接收应用程序中的名称并决定接受或拒绝新名称,然后通过相应的状态发送填充填充_set_dev_info_cfm,以便正确发送确认您必须从task_gapm转换为task_gapc。
由于MT_dialog