DA14585型sleepmode code get stuck after OTP

⚠️
嗨,...感谢您来论坛。令人兴奋的消息!我们现在正在迁至我们的新论坛平台,将提供更好的功能,并包含在主对话框网站中。所有帖子和帐户都已迁移。我们现在只接受新论坛上的流量 - 请发布任何新线程//www.wsdof.com/support. 我们将在未来几天内修复bug/优化搜索和标记。
39帖子/ 0新
最后一篇文章
markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
DA14585型sleepmode code get stuck after OTP

您好对话团队,

我正在使用我的项目自定义板。

该项目具有压力传感器,通过GPIO每30秒发送曼彻斯特编码数据。我的对话框芯片对数据进行解码并将其加载到广告字符串中。我有一个电池,用于向上电我的电路。我可以睡觉以节省电池寿命。

到目前为止,我已经完成了以下内容。由于我们正在开发自定义硬件,因此我对示例(BLE_APP_SLEEPMODE)程序进行了以下更改,如下所示。

1) 根据user\u periph\u setup.h中的示意图更改了led端口和按钮引脚

2) 在da1458x_config_advanced.h中将#define CFG_LP_CLK LP_CLK XTAL32更改为#define CFG_LP_CLK LP_CLK_RCX20,因为我们没有32Khz外部晶体。

3)因点2而将#define cfg_xtal16m_adaptive_settling更改为#undef cfg_xtal16m_adaptive_settling。

4) #undef CFG_CODE_LOCATION_EXT and #define CFG_CODE_LOCATION_OTP in da1458x_config_advanced.h

我已成功使用585devkit调试项目,而且没有任何问题。我现在面临以下问题。由于我的调试会话正常运行,我计划执行OTP。在我做了OTP之后,程序不会运行很长时间。它运行了一段时间,然后暂停停止。不知道为什么。

问候,

Mark

Device:
markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
I am attaching the project

我也在附加项目文件夹。

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨Kuda,

嗨Kuda,

谢谢你的问题。

>>>>我现在正面临以下问题。由于我的调试会话正常运行,我计划执行OTP。

你的意思是说你附加了调试器?如果是,这将阻止系统进入睡眠模式。您完全确定您的应用程序正在我们的DK中运行吗?

如果您的定制板,您是否尝试在调试模式下运行您的应用程序?例如,您是否尝试将FW下载到System-RAM?

谢谢,下午好

markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
Hi PM_Dialog,

Hi PM_Dialog,

Yes. I downloaded the code to sys-RAM and it worked perfectly without any problems.

将代码下载到OTP后,我断开了调试器的连接。我把电池取下来插回去。它跑了几分钟就卡住了。

问候,

Mark

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
hi markdsylva_2277.

hi markdsylva_2277.

您能否导出和分享您正在使用的OTP标题?

谢谢,下午好

markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
Hi PM_Dialog,

Hi PM_Dialog,

如何导出OTP头?

问候,

Mark

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
hi markdsylva_2277.

hi markdsylva_2277.

From the SmartSnippets Toolbox. You need to connect to the OTP Header and export it to file.

谢谢,下午好

markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
Hi PM_Dialog,

Hi PM_Dialog,

我在阅读时犯了很多错误。

我正在附上日志。

问候,

Mark

附件:
markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
嗨,PM\U对话,

嗨,PM\U对话,

我设法拿到了头球。附于此。

问候,

Mark

附件:
markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
Hi PM_Dialog,

Hi PM_Dialog,

Please update me on the status as I am waiting for your reply for further development in my project.

问候,

Mark

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨马克,

嗨马克,

Both application flags are set to “Yes” which is correct. What the package are you using? WLCSP34, QFN40 or QFN48 ? I the OTP header you have selected the QFN40. Additionally, the clock source is selected to the external Crystal oscillator, but in your initial post you are using the interval RCX. What changes have you done in the OTP Header? Have you burnt the “Device and Package” and ”Sleep Clock Source” or it is the default configuration?

>>>After I downloaded the code to OTP, I disconnected the debugger. I removed the battery and inserted it back. It runs for a few minutes and then it gets stuck.

由于它运行几分钟,这意味着设备从OTP正确启动。可能这个问题可能与SW相关。设备是否突然宣传和停止?您是否能够将其与对等设备连接?

谢谢,下午好

markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
Hi PM_Dialog,

Hi PM_Dialog,

---> What the package are you using? WLCSP34, QFN40 or QFN48 ? I the OTP header you have selected the QFN40.

是的,它是qfn40。

----> Additionally, the clock source is selected to the external Crystal oscillator, but in your initial post you are using the interval RCX. What changes have you done in the OTP Header? Have you burnt the “Device and Package” and ”Sleep Clock Source” or it is the default configuration?

我有一个外部水晶连接。但是对于低功耗水晶选择,我没有32kHz外部水晶连接到我的对话框芯片。所以我将其从#define cfg_lp_clk lp_clk_xtal32更改为#define cfg_lp_clk lp_clk_rcx20。我没有改变标题中的任何东西。我只将应用程序标志更改为是。

---->由于它运行了几分钟,这意味着设备从OTP正确启动。可能这个问题可能与SW相关。设备是否突然宣传和停止?您是否能够将其与对等设备连接?

这些设备运行几分钟,当它从睡眠停止时醒来。应用程序的运行时间变化很大。Somtips它在2分钟内停止或可能需要15分钟。由于我的项目仅与广告有关,因此我并没有将其与对等设备连接。如果问题与软件有关,为什么在调试期间会出现它?

---------------------------------------------------------------------------------------------------------------------------------------

->我最大的疑问是,如果应用程序中有一个bug,为什么它会运行一段时间然后停止呢。

- >我有一个移动应用程序,用系统时间记录广告数据。根据我的项目,广告间隔是150ms,它在广告停止后5秒钟完成。根据我的日志,芯片在广告停止前5秒钟之间唤醒并停止。

->我还从你们网站上的在线教程中读到,下面的一行应该是rwip.c的注释。如果不使用32Khz外部crstal

//DA14585/586不支持Boost mode+RCX
if(GetBits16(ANA\u STATUS\u REG,BOOST\u SELECTED)==1)

assert_warning(0);

我没有尝试评论这一点,因为我们没有许多筹码,因为我们在Covid-19锁定时锁定。我的代码在调试中跑了超过一周的直线。在我做了OTP之后,我开始面对问题。请支持我,因为它非常紧急。

------------------------------------------------------------------------------------

It would be better if you can guide me on certain aspects because I am using a custom board and I simply cant waste chips after finding out bugs after doing the OTP. I will be asked question from my mangement on how many chips will u waste for this?.

问候,

Mark

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨马克,

嗨马克,

You mentioned that you tested your project in development mode. Please keep in mind that when the debugger is attached, this prevents the system to go into sleep mode. Have you ever tested without the debugger attached?

Portably your issue is related with the waking up from sleep mode.

For example, if you download the same FW into the Sys-Ram (without the debugger attached) or into SPI Flash, is that running correctly?

关于OTP标题似乎是正确的。如果OTP标题和OTP图像未正确刻录,则设备将无法启动!在您的情况下,DA14585正在正确启动并开始广告。

谢谢,下午好

markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
Hi PM_Dialog,

Hi PM_Dialog,

——>你提到你测试项目development mode. Please keep in mind that when the debugger is attached, this prevents the system to go into sleep mode. Have you ever tested without the debugger attached?

I tried to start the debug session from keil and stopped the debug session by pressing the same debug button. The code didnt run.

正如我在上面的帖子中所说的,我认为代码挂在广告过程的某个地方(即在广告间隔期间醒来和睡觉)。我的代码在user\u sleepmode.c文件中,在这里我处理外部中断和数据解码。收到数据后,我启动广告并设置一个app\u easy\u计时器5秒……然后我停止广告。中间我什么都没有。我要怎么检查代码挂在哪里?。有什么想法吗?

问候,

Mark

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨马克,

嗨马克,

So the problem is related to the SW. Let’s try to investigate what might be the root cause. If you run the application code in your custom board with the debugger attached, does it stop anywhere? If yes, can you please share a screenshot where it gets stuck? Is the watchdog enabled ore disabled?

谢谢,下午好

markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
Hi PM_Dialog,

Hi PM_Dialog,

- >否。代码不停止任何地方。它没有任何问题。

-->我把看门狗弄坏了。

问候,

Mark

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨马克,

嗨马克,

您能用WDOG运行它吗?现在,如果在调试模式下运行它,代码在任何地方粘在一起?请定义CFG_WDOG宏并再次运行它。

谢谢,下午好

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨马克,

嗨马克,

此外,您正在使用的SDK是什么?我无法在SDK中构建提供的示例代码。

谢谢,下午好

markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
Hi PM_Dialog,

Hi PM_Dialog,

我使用的SDK是6.0.12

问候,

Mark

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨马克,

嗨马克,

我的建议是将启用WDOG并在调试模式下运行代码。此外,请启用CFG_Development_debug标志。这允许您热连接调试器,并且如果发生硬盘或NMI,则获取调试信息。所以,通过启用这2个宏,在调试模式下毁了它时会粘在任何地方?另外,不需要禁止OTP才能调试它 - 只需将固件下载到系统内通过Keil IDE。

In the meanwhile, I will try to run the attached project in our development boards.

谢谢,下午好

markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
Hi PM_Dialog,

Hi PM_Dialog,

我说你所说的。

I #defined both the macros and uploaded the code by pressing the debug button and then pressed the same button again. The code got stuck again.

问候,

Mark

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨马克,

嗨马克,

哪里卡住了?你能分享一个截图吗?

谢谢,下午好

markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
Hi PM_Dialog,

Hi PM_Dialog,

我已断开调试器的连接。所以我不知道它卡在哪里了。

但是当我使用调试器运行时,代码正常运行。

----------------------------------------------------------------------

我有一个截止日期,以完成该项目的明天,因为代码是陷入广告之间的间隔,我正在考虑消除otp复制睡眠之间的广告间隔通过传递假到拱\设置\扩展\睡眠(假)和改变静态常量睡眠\状态\应用程序\默认\睡眠\模式=拱\扩展\睡眠\开。。。

这能暂时解决我的问题吗?。

问候,

Mark

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨马克,

嗨马克,

我已经使用CFG_Wdog和CFG_Development_debug宏运行附加项目。我正在研究一个QFN40女儿板和我们的新款Pro-DK主板。为了使用板载按钮唤醒设备,我正在使用LED的P1_1。

在调试模式下运行代码时,它会在以下行中的GPIO.C文件中陷入GPIO_SETPINFUNCTION()。

__asm(“BKPT#0\n”);//此pin以前未被保留!

在user\u periph\u setup.c中,您将所有GPIO配置为下拉输入。这是不需要的,因为默认状态是INPUT\u PULLDOWN。您可以很容易地读取GPIOs寄存器来澄清它。此外,这种代码的和平重新配置所有gpio,这是不推荐的。

此外,在user_sleepmode.c文件中,您正在使用永不保留的GPIO!

请找到附加的差异文件与修改我在您的代码。有了这些修改,我可以在我们的DKs运行您的项目。

The OTP stand for One Time Programmable, so you should make sure that your project is totally running before burning it!

In development stage, it is recommended to have the WDOG and the development debug enabled, Otherwise, if the code gets stuck somewhere you will be never notified for this! In conclusion, burning the OTP image and OTP header requires that the application code is running 100%. Otherwise, the chip will never boot form OTP!

您正在使用的DA14585的包是什么?

谢谢,下午好

附件:
markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
Hi PM_Dialog,

Hi PM_Dialog,

好的。我会按你说的话。

我正在使用qfn40包。

GPIO预留问题会导致代码挂起OTP后挂起吗?

问候,

Mark

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
既然你在管理

由于您在调试模式下运行项目,因此您应该定义CFG_Development_debug。这允许您模拟从OTP到系统RAM的OPT镜像。

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
I would suggest to run the

我建议在DK中运行项目。它是否正确运行?

如果是的话,那么使用你的定制板并将固件下载到系统RAM中。请确保OTP为空。100%有效吗?

markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
Hi PM_Dialog,

Hi PM_Dialog,

I took a fresh copy of sleepmode example from your skd and tried to download it to the ram in the 585 daughter board. I didnt modify anything in any of the code. When I pressed the debug button and started the code it immediately got stopped at the nmi_handler. Will your example code work as such without modification in the 585 daughter board?.

问候,

Mark

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨Mark,请下载

嗨,马克,请先把fw放到RAM里-现在可以了吗?

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨,马克,你能忘吗

嗨,马克,你能忘吗indicate which DK are you using? Which daughter board and which mother board? yes, the example is working correctly..

markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
你好,

你好,

套件为DA14580DevKT-P\U VC

子板是DA14585。

Regards

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨,马克,是的,ble\u应用程序

你好,马克,是的,ble\u app\u睡眠模式在这个板上运行正常。我可以在我身边跑。是否可以与跳线配置共享一个phote?

markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
你好,

你好,

照片附加了。

问候,

Mark

附件:
PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨,马克,刚刚测试了ble

你好,马克,刚刚在我们的DK上测试了bleèappèsleepmode示例-我和你使用的是同一个DK和同一个跳线配置。你有备用的DK测试吗?我建议也在一个干净的SDK目录上工作。此外,与修改我昨天分享你,我可以运行在我们的DK你的项目。。。你在为DA14585做项目吗?谢谢,下午好

markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20
Hi PM_Dialog,

Hi PM_Dialog,

--->你有备用的DK测试吗?

No. I dont have one.

- >我也建议在干净的SDK目录上工作。

我从6.0.12.1020.2..zip文件中提出了SDK文件夹,然后打开BLE_APP_SLEEPMODE项目并建立并启动调试会话。我没有修改里面的任何东西。但我面临着同样的问题。我附上了截图。

问候,

Mark

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨,马克,你能跑吗

嗨,马克,你能跑吗any of the other SDK project? For example, the ble_app_barebone. All the SDK examples are running in our DKs out-of-the-box and as provided by the SDK. In this specific device, have you burnt the OTP?

markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20

你好,

我不能举出任何不可靠的例子。我试过布林奇的计划。效果不错。

问候,

Mark

PM\U对话框
离线
最后一次见到:19小时3分钟前
工作人员
已加入:2018-02-08 11:03
嗨马克,

嗨马克,

请找到我的跳线配置附件。所有BLE示例都按预期运行。在ble\u app\u睡眠模式的情况下,我可以使用附加的配置运行它。所以,请尝试将SDK解压到一个新文件夹中,然后再试一次。我建议使用一个短的SDK路径——可能在C:\下解压。如果它没有再次运行,可能是电路板损坏了。你在那台设备上写过OTP吗?

谢谢,下午好

附件:
markdsylva_2277.
离线
最后一次见到:3个月1周前
已加入:2019-06-19 04:20

Hi PM_Dialog,

I tried as you said.

1)我拍出了SDK的新鲜副本,并在D驱动器中创建了一个文件夹。我在没有修改任何内容的情况下运行sleepMode示例。一旦我开始调试会话,它就被困在NMI处理程序。

2) I connected the smart snippets tool and checked reading the OTP memory. It read only zeros.

问候,

Mark