DA14585 - 仅在睡眠中宣传一次

⚠️
嗨,...感谢您来论坛。令人兴奋的消息!我们现在正在迁至我们的新论坛平台,将提供更好的功能,并包含在主对话框网站中。所有帖子和帐户都已迁移。我们现在只接受新论坛上的流量 - 请发布任何新线程//www.xmece.com/support。我们将在未来几天修复错误/优化搜索和标记。
15个员额/ 0个新员额
最后一篇
markdsylva_2277.
离线
最后一次露面:2个月3周前
加入:2019-06-19 04:20
DA14585 - 仅在睡眠中宣传一次

嗨对话小组,

我工作在一个自定义板与'ble_app_nonconn'的例子在misc文件夹在SDk文件夹。我的项目要求如下。

  • 当没有ble或其他活动时,进入睡眠模式(ARCH_EXT_SLEEP_ON)。
  • 当外部传感器提供数据时,对话框芯片将唤醒引脚更改中断并使用计时器0开始从传感器中解码数据。
  • 解码数据并在广告字符串上更新它。
  • 使用'user_app_adv_start()'启动广告,并启动一个易于计时器,将在6秒内过期。直到那时广告数据被宣传。当App_easy Timer到期时,使用'app_easy_gap_advertise_stop()'停止广告,这将使芯片睡眠。
  • 在停止广告之前,当下一个数据准备好时,唤醒引脚将使芯片从睡眠中唤醒。

我在调试模式下填写上述步骤。当我在RAM上运行我的程序并断开调试器时,电流消耗会降低到2.4μA。当外部中断发生时,电流上升到大约50μA,振荡在2.4μA至50μA之间。(我猜这是由于广告Internvals之间的睡眠)。所以我认为上面的概念可以很好地工作。

但我陷入了两个问题。

1)在休眠模式(调试器断开状态),当我的芯片发布时,我认为它只发布一次。因为我在BLE扫描仪应用程序上检查它,我注意到RSSI值只更新一次。它只会传播一次吗?如果只传输一次,为什么电流在2.4µA到50µA之间振荡6秒?

2)上述条件有效期为一段时间和突然间,电流增加到350μA,然后根本没有广告。我的节目停止了吗?

请注意,仅当我断开调试器时,才会出现上述两个条件。

是什么导致了睡眠中的这两个问题?

问候,

马克

设备:
PM_DIALOG.
离线
最后一次露面:1天8小时前
工作人员
加入:2018-02-08 11:03
嗨马克,

嗨马克,

在睡眠模式下执行任何类型的测量时,您不应以调试模式运行固件。否则,该设备无法进入睡眠模式,并且功耗将大大增加。为此,我的建议将成为调试器未连接,因为这可以防止系统睡眠。此外,非常重要的提示是,如果您在您的自定义板中使用SPI Flash,则应将其供电。

你能试着进一步调试它吗?请在调试模式下运行-在这个步骤中功耗并不重要。你说过这是一次广告,第一次广告之后fw做什么?WDOG是否已启用?我建议你启用它,否则如果fw在某个地方卡住了,你将不会收到通知。如果你完全确定fw按照预期运行(没有发生WDOG或NMI),请使用SmartSnippets工具箱的功率分析器来检查它是否没有发布一次。

谢谢,PM_DIALOG.

markdsylva_2277.
离线
最后一次露面:2个月3周前
加入:2019-06-19 04:20
嗨PM_Dialog,

嗨PM_Dialog,

在调试模式下运行时,代码正常通告,固件不会卡住任何地方。我在调试模式下运行了一小时的代码,它可以正常工作。当我断开调试器并运行它时,问题(如第一个帖子中所述)发生。

我还有一个疑问。你的示例代码'ble_app_nonconn'在'misc'文件夹支持扩展睡眠模式?因为它在调试模式连接时工作正常。但是当我断开调试器时,问题开始了。

我是广告6秒钟并停止它。但它仅广告一次,但整个6秒内的当前消耗量有振荡。这意味着它在广告间隔之间唤醒,但为什么不发送数据包。?

问候,

马克

PM_DIALOG.
离线
最后一次露面:1天8小时前
工作人员
加入:2018-02-08 11:03
嗨马克,

嗨马克,

SDK6.0.12的ble_app_nonconn项目默认不支持休眠模式。但是,您可以更改休眠模式配置。由于它是一个自定义代码和自定义板,是否有可能共享您所做的更改,以便在睡眠模式下配置它?另一种选择是开始调查哪个是路由的原因,可能是开始切换GPIO或打印一些调试消息,因为固件gests只在非调试模式下卡住。在调试模式下,我假设您已经启用了WDOG ..

谢谢,PM_DIALOG.

markdsylva_2277.
离线
最后一次露面:2个月3周前
加入:2019-06-19 04:20
嗨pm_dialog,

嗨pm_dialog,

我的固件不会被卡住。它仅在整个6秒持续时间传输单个广告。但是在调试模式下,它会在6秒持续时间传输4到5次。为什么它只在非调试模式中传输一次?是影响BLE广告的睡眠模式吗?

对于睡眠模式,我做了以下更改。

static const sleep_state_t app_default_sleep_mode = ARCH_EXT_SLEEP_ON;

我在6秒后停止了广告,我的芯片进入了长时间睡眠。

问候,

马克

PM_DIALOG.
离线
最后一次露面:1天8小时前
工作人员
加入:2018-02-08 11:03
嗨马克,

嗨马克,

不确定发生了什么,因为它是自定义板/代码。您能否请在user_app_adv_start()和user_app_adv_nonconn_complete()中使用Arch_Printf()在user_app_adv_nonconn_complete()中?另外,请你发给我一个电力分布器的屏幕截图吗?当调试器附加并取消连接时。

谢谢,PM_DIALOG.

markdsylva_2277.
离线
最后一次露面:2个月3周前
加入:2019-06-19 04:20
你好,

你好,

我没有选择打印消息在我的自定义板。我正在用万用表测量电流消耗。

我认为问题在于当我准备再次发布时调用user_app_adv_start()函数。

我附上以下代码供您参考。

Void user_app_adv_start(Void) {struct gapm_start_advertise_cmd *cmd = app_easy_gap_non_connectable_advertise_get_active();//存储初始的广告数据和长度initial_adv_data_len = cmd->info.host.adv_data_len;memcpy (initial_adv_data cmd - > info.host。adv_data initial_adv_data_len);//存储初始扫描响应数据和长度initial_scan_rsp_data_len = cmd->info.host.scan_rsp_data_len;memcpy (initial_scan_rsp_data cmd - > info.host。scan_rsp_data initial_scan_rsp_data_len);//改变//初始化数据data_init();//加载广告数据和长度cmd->info.host. cmdadv_data_len = user_adv_data_len;memcpy (cmd - > info.host。adv_data、user_adv_data user_adv_data_len);//加载扫描响应数据和长度cmd->info.host. cmdscan_rsp_data_len = user_scan_rsp_data_len; memcpy(cmd->info.host.scan_rsp_data, user_scan_rsp_data, user_scan_rsp_data_len); //arch_set_extended_sleep(true); app_easy_gap_non_connectable_advertise_start(); //Schedule the next advertising data update app_adv_data_update_timer_used = app_easy_timer(APP_ADV_DATA_UPDATE_TO, adv_data_update_timer_cb); } static void data_init() { // Load initial advertising data and length user_adv_data_len = initial_adv_data_len; memcpy(user_adv_data, initial_adv_data, user_adv_data_len); // Load initial scan response data and length user_scan_rsp_data_len = initial_scan_rsp_data_len; memcpy(user_scan_rsp_data, initial_scan_rsp_data, user_scan_rsp_data_len); //load predefined data user_adv_data_len = ADV_DATA_LEN ; user_scan_rsp_data_len = SCAN_RSP_DATA_LEN ; user_adv_data[12] = 7; user_adv_data[13] = txBuffer[1]; user_adv_data[14] = txBuffer[2]; user_adv_data[15] = txBuffer[3]; user_adv_data[16] = txBuffer[4]; user_adv_data[17] = txBuffer[5]; user_adv_data[18] = txBuffer[6]; user_adv_data[19] = txBuffer[9]; if(user_adv_data[13]==0){ user_adv_data[13]=0xff; } if(user_adv_data[14]==0){ user_adv_data[14]=0xff; } if(user_adv_data[15]==0){ user_adv_data[15]=0xff; } if(user_adv_data[16]==0){ user_adv_data[16]=0xff; } if(user_adv_data[17]==0){ user_adv_data[17]=0xff; } if(user_adv_data[18]==0){ user_adv_data[18]=0xff; } if(user_adv_data[19]==0){ user_adv_data[19]=0xff; } }

markdsylva_2277.
离线
最后一次露面:2个月3周前
加入:2019-06-19 04:20
嗨pm_dialog,

嗨pm_dialog,

正如你建议的那样,我拉下了一个gpioperiph_init()然后在睡前睡觉之前把它拉高Arch_Goto_Sleep(Sleep_Mode)在arch_main.c。附上了示波器输出的截图。我面临的问题是,当我调用user_app_adv_start()时,芯片只传输一次数据。我通过查看android BLE扫描仪应用程序上的RSSI值确认了这一点。我也附上了样本代码。

正如我对我的产品的紧急演示一样,我已经改变了广告间隔到200ms和以某种方式通过调用'user_app_adv_start()'和1秒后我停止它以及在我打电话的广告完整功能之后宣传数据。user_app_adv_start()'再次。我在我的应用中重复了6秒钟,我正在获得多面广告命中。每次我打电话'user_app_adv_start()',我在我的应用程序中只有1个点击,直到我停止广告并再次调用它。

为什么'user_app_adv_start()'只广告数据一次?

请您可以分享我的标志数据的示例代码,用于在外部中断上唤醒并修改广告字符串并传输并睡眠。

问候,

马克

PM_DIALOG.
离线
最后一次露面:1天8小时前
工作人员
加入:2018-02-08 11:03
嗨马克,

嗨马克,

让我查一下,然后给你答复。

谢谢,PM_DIALOG.

PM_DIALOG.
离线
最后一次露面:1天8小时前
工作人员
加入:2018-02-08 11:03
嗨马克,

嗨马克,

arch_main.c是SDK文件,强烈建议不要修改任何SDK文件。所有的修改都应该在应用层,在以user_开头的字段中完成。所有其他SDK相关的文件,如果其中任何一个被修改,我们不能保证应用程序将正常工作。SDK应该使用,因为它是对话框提供的,没有任何其他修改。

关于你的源代码,我不能编译它,因为我得到了一对错误。请参阅下面的diff文件,了解如何停止非连接广告,将设备置于睡眠模式,并唤醒它。我的建议是从ble_app_sleepmode SDK的例子开始,其中包含广告数据更新。如何构建应用程序以及如何更新信标数据由您决定。请按照SDK的ble_app_sleepmode示例中的步骤执行。

/projects/target_apps/ble_examples/ble_app_sleepmode/src/config/user_callback_config.h b/projects/target_apps/ble_examples/ble_app_sleepmode/src/config/user_callback_config.h索引e61bd1b.. .eab8 100644——060 /项目/ target_apps / ble_examples / ble_app_sleepmode / src / config / user_callback_config.h + + + b /项目/ target_apps / ble_examples ble_app_sleepmode / src / config / user_callback_config.h @@ -54年8 + 54岁8 @@静态常量struct app_callbacks user_app_callbacks = {.app_on_update_params_rejected =零,.app_on_update_params_complete = NULL, .app_on_set_dev_config_complete = default_app_on_set_dev_config_complete - .app_on_adv_nonconn_complete = NULL, - .app_on_adv_undirect_complete = user_app_adv_undirect_complete, + .app_on_adv_nonconn_complete = user_app_adv_nonconn_complete, + .app_on_adv_undirect_complete =零,.app_on_adv_direct_complete = NULL, .app_on_db_init_complete = default_app_on_db_init_complete .app_on_scanning_completed = NULL, diff - git /项目/ target_apps / ble_examples / ble_app_sleepmode / src / user_sleepmode.c b /项目/ target_apps / ble_examples / ble_app_sleepmode / src / user_sleepmode.c指数c4b605e . .bf18b3c 100644——/项目/ target_apps / ble_examples / ble_app_sleepmode / src / user_sleepmode.c + + + b /项目/ target_apps / ble_examples / ble_app_sleepmode / src / user_sleepmode.c @@ -240年8 + 240,10 @@空白user_app_adv_start(空白)/ /安排接下来的广告数据更新app_adv_data_update_timer_used = app_easy_timer (APP_ADV_DATA_UPDATE_TO,adv_data_update_timer_cb);- struct gapm_start_advertise_cmd* cmd;- CMD = app_easy_gap_undirected_advertise_get_active();+// struct gapm_start_advertise_cmd* cmd;+// CMD = app_easy_gap_undirected_advertise_get_active(); + + struct gapm_start_advertise_cmd *cmd = app_easy_gap_non_connectable_advertise_get_active(); // Add manufacturer data to initial advertising or scan response data, if there is enough space app_add_ad_struct(cmd, &mnf_data, sizeof(struct mnf_specific_data_ad_structure), 1); @@ -249,7 +251,8 @@ void user_app_adv_start(void) // Set extended sleep with OTP copy during advertising arch_set_extended_sleep(true); - app_easy_gap_undirected_advertise_start(); + //app_easy_gap_undirected_advertise_start(); + app_easy_gap_non_connectable_advertise_start(); } void user_app_connection(uint8_t connection_idx, struct gapc_connection_req_ind const *param) @@ -312,11 +315,13 @@ static void app_button_press_cb(void) */ static void app_wakeup_cb(void) { - // If state is not idle, ignore the message - if (ke_state_get(TASK_APP) == APP_CONNECTABLE) - { - user_app_adv_start(); - } +// // If state is not idle, ignore the message +// if (ke_state_get(TASK_APP) == APP_CONNECTABLE) +// { +// user_app_adv_start(); +// } + + user_app_adv_start(); } /** @@ -335,9 +340,9 @@ static void app_button_enable(void) 40); // debouncing time = 0 } -void user_app_adv_undirect_complete(uint8_t status) +void user_app_adv_nonconn_complete(uint8_t status) { - // Disable wakeup for BLE and timer events. Only external (GPIO) wakeup events can wakeup processor. + // Disable wakeup for BLE and timer events. Only external (GPIO) wakeup events can wakeup processor. if (status == GAP_ERR_CANCELED) { arch_ble_ext_wakeup_on(); @@ -347,6 +352,18 @@ void user_app_adv_undirect_complete(uint8_t status) } } +//void user_app_adv_undirect_complete(uint8_t status) +//{ +// // Disable wakeup for BLE and timer events. Only external (GPIO) wakeup events can wakeup processor. +// if (status == GAP_ERR_CANCELED) +// { +// arch_ble_ext_wakeup_on(); + +// // Configure wakeup button +// app_button_enable(); +// } +//} + void user_app_disconnect(struct gapc_disconnect_ind const *param) { // Cancel the parameter update request timer diff --git a/projects/target_apps/ble_examples/ble_app_sleepmode/src/user_sleepmode.h b/projects/target_apps/ble_examples/ble_app_sleepmode/src/user_sleepmode.h index 8c33892..acae900 100644 --- a/projects/target_apps/ble_examples/ble_app_sleepmode/src/user_sleepmode.h +++ b/projects/target_apps/ble_examples/ble_app_sleepmode/src/user_sleepmode.h @@ -116,7 +116,7 @@ void user_app_connection(uint8_t connection_idx, * @return void **************************************************************************************** */ -void user_app_adv_undirect_complete(uint8_t status); +//void user_app_adv_undirect_complete(uint8_t status); /** **************************************************************************************** @@ -141,6 +141,8 @@ void user_catch_rest_hndl(ke_msg_id_t const msgid, void const *param, ke_task_id_t const dest_id, ke_task_id_t const src_id); + +void user_app_adv_nonconn_complete(uint8_t status); /// @} APP

谢谢,PM_DIALOG.

markdsylva_2277.
离线
最后一次露面:2个月3周前
加入:2019-06-19 04:20
嗨pm_dialog,

嗨pm_dialog,

当你编译我的代码时,你会得到什么样的错误?

2)我修改了你的Arch_main.c文件,因为当我的传感器发送中断时,我必须等待大约20ms来获取数据,但如果我不等待我的代码将恢复入睡,我会错过数据。这就是为什么我修改了ARCH_MAIN.c文件等待我的数据,然后将芯片放入睡眠状态。如何延长芯片的唤醒时间?你能建议一个想法吗?

3)当我开始我的广告,我添加到arch_main.c的大部分代码内容不会执行,因为我在主循环中检查条件,我不会执行它,而我是广告。为什么这会影响你的sdk和广告序列?

4)当我收到中断时,直到我从传感器处理数据时,我就不会启动广告。在我收到数据后,我将开始广告,我相信我的代码都不会在广告期间运行。那么为什么这对SDK给出了任何问题?

谢谢,

马克

markdsylva_2277.
离线
最后一次露面:2个月3周前
加入:2019-06-19 04:20
嗨pm_dialog,

嗨pm_dialog,

请支持上面的积分。正如您所建议的那样,我已经开始在BLE_Examples的SleepMode项目上工作。我最大的怀疑是当我的外部传感器给出中断并仅在20ms后提供数据时,我如何在从睡眠中醒来后,我如何防止芯片进入睡眠。

问候,

马克

PM_DIALOG.
离线
最后一次露面:1天8小时前
工作人员
加入:2018-02-08 11:03
嗨马克,

嗨马克,

请从Keil IDE中找到带有错误的日志文件。指出您正在使用的SDK版本将非常有帮助。不确定SDK版本,但我们强烈建议使用最新版本(SDK6.0.12)。

  • 删除所有未使用的代码行。这使得难以通过代码并理解实现。
  • 所有修改和开发都应在应用层中完成。没有一个SDK应该修改。如果修改SDK文件,我们无法提供任何支持。
  • 请删除SDK文件中的所有代码片段,比如arch_main.c。
  • 所有的应用层文件都以“user_”开头。
  • 请提供我一个工作项目,将其添加到projects\target_apps\misc SDK目录下,并指出SDK版本。
  • 为了开始调试它,我应该在上述路径下复制粘贴项目,打开它并编译它。
  • 请记住,您有一个定制董事会,所以我会尝试在我们的专业开发板上复制这个问题。
  • 在睡眠模式下,设备将在广告间隔之间进入睡眠模式(如果是可连接广告,则为连接间隔)。所有外设域(包括I2C)下电。当传感器有数据要发送时,应首先通过唤醒控制器来唤醒设备。
  • 我的建议是在ble_app_sleepmode示例中开始开发。我已经提供了一个diff文件,里面有需要的更改。
  • 应该启用WDOG,否则如果应用程序卡住,则不会通知您。
  • 如果你运行SDK的默认ble_app_sleepmode示例,你是否能够停止广告并将设备放入睡眠模式?

谢谢,PM_DIALOG.

附件:
markdsylva_2277.
离线
最后一次露面:2个月3周前
加入:2019-06-19 04:20

嗨pm_dialog,

在添加外部32kHz晶体振荡器后,该问题被整理出来。

似乎BLE_APP_SLEEPMODE代码在没有32kHz水晶的情况下不稳定。但是你的数据表说,这32kHz是可选的,这是非常误导的。请纠正数据表,也可以误导别人。我在这个问题上花了3-4个月,没有任何内容,没有任何内容。

无论如何,感谢您的在线支持。

问候,

马克

PM_DIALOG.
离线
最后一次露面:1天8小时前
工作人员
加入:2018-02-08 11:03
嗨马克,

嗨马克,

很高兴你把它修好了。这是我们在之前的电话会议上讨论的内容。也谢谢你的暗示。

问候,PM_Dialog