app_easy_wakeup和app_easy_wakeup_set如何运作?

⚠️
嗨,...感谢您来论坛。令人兴奋的消息!我们现在正在迁至我们的新论坛平台,将提供更好的功能,并包含在主对话框网站中。所有帖子和帐户都已迁移。我们现在只接受新论坛上的流量 - 请发布任何新线程https://www.dialog-seminile.com/support.。我们将在未来几天修复错误/优化搜索和标记。
29帖子/ 0新
最后一篇
丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
app_easy_wakeup和app_easy_wakeup_set如何运作?

我在SmartTag和SleepMode源代码中发现了这个功能,但不能在SDK引用中找到用法,它是如何运作的?它醒来核心吗?或者在触发中断之后,核心醒来?

设备:
mt_dialog.
离线
最后一次露面:5个月2周前
职员
加入:2015-06-08 34
嗨Daniel59,

嗨Daniel59,

它只是一个用于在唤醒时使用的api,使用app_easy_wakeup_set(),你将设置一个回调函数,让设备在唤醒消息从app_easy_wakeup函数()发送后立即执行。因此,从唤醒计时器中断中调用app_easy_wakeup()函数(它将一个特定的消息推送到内核中),一旦内核唤醒并将调度消息,您通过app_easy_wakeup_set()设置的函数将被触发。

谢谢mt_dialog.

丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
如果我想打开一个LED灯

所以如果我想打开一个LED与延长睡眠模式。我该如何编写代码?

1.
app_button_press_cb {
turn_on_led();
}
on_init () {
wkupct_register_callback (app_button_press_cb);
wkupct_enable_irq(WKUPCT_PIN_SELECT(GPIO_BUTTON_PORT, GPIO_BUTTON_PIN), //选择pin (GPIO_BUTTON_PORT, GPIO_BUTTON_PIN)
wkupct_pin_polarity(gpio_button_port,gpio_button_pin,wkupct_pin_polarity_low),//极性低
1,// 1事件
40);//恢复时间= 0
}
或2。
wakeup_cb () {
turn_on_led();
}
app_button_press_cb(){
app_easy_wakeup_set (turn_on_led);
app_easy_wakeup ();
}

on_init () {
wkupct_register_callback (app_button_press_cb);
wkupct_enable_irq(WKUPCT_PIN_SELECT(GPIO_BUTTON_PORT, GPIO_BUTTON_PIN), //选择pin (GPIO_BUTTON_PORT, GPIO_BUTTON_PIN)
wkupct_pin_polarity(gpio_button_port,gpio_button_pin,wkupct_pin_polarity_low),//极性低
1,// 1事件
40);//恢复时间= 0
}

我应该在哪里放置Arch_disable_sleep函数?

mt_dialog.
离线
最后一次露面:5个月2周前
职员
加入:2015-06-08 34
嗨Daniel59,

嗨Daniel59,

启动广告时设置唤醒中断(如果设备将在扩展睡眠模式下广告)或者在从.app_On_Adv_Undirect_Complete完成广告过程后立即设置唤醒中断。中断的设置可能如下:

app_easy_wakeup_set (app_wakeup_cb);// app_wakeup_cb是你要打开LED的地方,所以它只包含函数GPIOSetActive()。
wkupct_register_callback (app_button_press_cb);// app_button_press是唤醒中断的回调(如下所述)
wkupct_enable_irq(WKUPCT_PIN_SELECT(GPIO_BUTTON_PORT, GPIO_BUTTON_PIN), //选择pin (GPIO_BUTTON_PORT, GPIO_BUTTON_PIN)
wkupct_pin_polarity(gpio_button_port,gpio_button_pin,wkupct_pin_polarity_low),//极性低
1,// 1事件
40);//恢复时间= 0

静态孔隙app_button_press_cb(空白)
{
如果(GetBits16 (SYS_STAT_REG PER_IS_DOWN))
{
periph_init ();
}

如果(arch_ble_ext_wakeup_get ())
{
ARCH_SET_SLEEP_MODE(ARCH_SLEEP_OFF);//禁用睡眠模式
ARCH_BLE_FORCE_WAKEUP();//强制摇晃醒来
ARCH_BLE_EXT_WAKEUP_OFF();//禁用外部唤醒(如果您在进入永久睡眠之前设置了ARCH_BLE_EXT_WAKESUP_ON()函数)
app_easy_wakeup ();//一旦BLE唤醒,调用app_easy_wakeup()来执行app_wakeup_cb()函数并打开//LED
}
}

谢谢mt_dialog.

丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
嗨MT_dialog,

嗨MT_dialog,

但是我发现在SMARTTAG源代码中,app_easy_wakeup()就在app_easy_wakeup_set()之后;

你的意思是我必须在app_easy_wakeup之前修改睡眠模式?或者我可以修改睡眠模式在简单的唤醒回调?

我的代码没有关闭BLE,所以我可以直接使用app_easy_wakeup而不需要if (arch_ble_ext_wakeup_get())吗?

如果核心唤醒后我有更多的操作,我应该在哪里放置代码?在WKUPCT回调或简单的唤醒回调中?

什么代码应该在wkupct回调中,什么代码应该在简单的唤醒回调中?

谢谢,
丹尼尔

mt_dialog.
离线
最后一次露面:5个月2周前
职员
加入:2015-06-08 34
嗨Daniel59,

嗨Daniel59,

app_easy_wakeup_set()它设置了回调,当来自app_easy_wakeup()的消息被发送时将执行回调,设置这个消息的时间并不重要,你只需要在调用触发它的app_easy_wakeup()之前设置。关于修改睡眠。你可以在唤醒计时器中断或app_easy回调被执行时改变睡眠模式。

关于你应该在哪里放置额外的操作代码,这取决于你想做什么,对于切换GPIO,你可以使用app_easy_wakeup的回调,但如果有与外部外设的交互,你应该在app_on_ble_powered或app_on_system_powered中唤醒并实现你的代码(如何使用那些回调,你可以在UM-B-051 - da1458x软件平台参考v1.0.pdf中找到更多信息在7.2节)。

关于ARCH_BLE_EXT_WAKEUP_GET()检查完成才能验证用户是否已调用ARCH_BLE_EXT_WAKESUP_ON(),如果您在睡眠前请调用此功能,则不必进行检查。

通常,WKUPCT回调有外围设备的初始化(Periph_init()),迫使BLE唤醒(如果需要),调用ARCH_BLE_EXT_WAKEUP_OFF()如果在进入睡眠前调用了ARCH_BLE_EXT_WAKEUP_ON(),并通过发送消息app_easy_wakeup()才能在BLE唤醒时立即执行一些代码。App_easy_wakeup()回调采用您想要的任何代码,但您应该注意在该函数中执行的代码不需要长时间长期以来,因为有丢失的BLE事件。对于使用外围设备UART,SPI,I2C的长操作,您可以使用前面提到的回调。

谢谢mt_dialog.

丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
嗨MT_dialog,

嗨MT_dialog,

我的产品需要一直连接到手机,所以我没有使用arch_ble_ext_wakeup_on()函数。

我尝试了app_on_system_powered, app_on_ble_powered和user_resume_from_sleep。我觉得他们做不到我想要的。

我用简单的代码尝试了。

ARCH_MAIN_LOOP_CALLBACK_RET_T USER_ON_SYSTEM_POWERED(void)
{
A ++;
返回GOTO_SLEEP;
}
ARCH_MAIN_LOOP_CALLBACK_RET_T USER_ON_BLE_POWERED(void)
{
B ++;
返回GOTO_SLEEP;
}
空白user_resume_from_sleep(空白)
{
c++;
}

并找到一个,B,C将增加,而不会击中定时器。

我想做的是支安打和SPI传感器FIFO水印中断唤醒定时器是否有幸获得连接,退出所有FIFO数据和计算步数,举个例子,如果一步数大于100开启蜂鸣器和领导,需要禁用睡眠模式的核心。

随着我在唤醒定时器回调中写下所有代码,它可以工作,但由于延长的睡眠模式,并且蜂鸣器无法工作,并且有时它将触发警告显示
if((development_debug)&&(use_power_optimizations))
{
slp_period_retated = slp_period;
//如果此断言命中,则LP ISR持续时间长于时间
//已通过LP_ISR_TIME_XTAL32_CYCLES和LP_ISR_TIME_USEC保留。
if(sleep_lp_cycles &&(sleep_lp_cycles assert_warning(0);
}

我试图把所有的代码放入简单的唤醒回调,它工作一样,但不会触发警告,但我发现我的手机与芯片断开。

如何编写代码?

Chris0409.
离线
最后一次露面:4年1个月前
加入:2017-01-11 05:59
您应该重新配置gpio

您应该重新配置与LED和蜂鸣器相关的GPIO引脚,在唤醒句柄中,因为引脚的所有配置都在睡眠模式下WKUP时丢失。
像这样
if(getBits16(sys_stat_reg,per_is_down))
periph_init ();

丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
嗨,克里斯,

嗨,克里斯,

是的,我重新配置了它们。但在睡眠模式下,LED恰到好处约0.5秒。

mt_dialog.
离线
最后一次露面:5个月2周前
职员
加入:2015-06-08 34
嗨Daniel59,

嗨Daniel59,

当系统通过主循环时,你使用的回调将被执行,因为设备不会进入睡眠,这意味着在唤醒执行连接间隔后,代码会通过所有这些函数并增加变量,直到连接间隔结束,它到达睡眠过程。从那一刻起,它将留在WFI()中,直到下一个连接事件到达。如果你有你的实现在唤醒计时器回调,那么你正在延迟唤醒睡眠和ASSERT_WARNING(),你看到,通知你,设备应该被唤醒,但某些东西一直在延迟过程。

在第二种情况下,通过使用app_easy_wakeup()触发你的代码,本质上你是在发送一条消息,你不干涉连接事件和活动BLE过程,但很明显,你与传感器交互读取数据的时间相当大,或者你的连接间隔太小,所以你错过了连接事件,因此设备认为连接丢失。要么试着独立传感器交互小块(读取数据在更小的部分),580年将能够服务于传感器交互和BLE事件或增加一点的连接超时间隔和延迟设备连接,这样有更多的时间与传感器交互连接的时间间隔occurs, so that your device has more tollerance in missing events in case that helps.

关于LED,它的点亮约0.5秒,当在睡眠模式时,别针保留了它们的状态,所以在睡觉时没有问题,问题是当设备醒来时。在每个唤醒中都会调用Periph_init(),以便配置应用程序使用的引脚,因此当Periph_Init()执行引脚时,还可以重新配置,以及其状态。为了克服您必须存储PIN(活动,非活动)的值,并且在每个唤醒中根据所存储的状态配置PERIPH_INIT()函数中的引脚状态。

谢谢mt_dialog.

丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
嗨MT_dialog,

嗨MT_dialog,

所以我把代码置于哪里有重要吗?

如何增加连接间隔超时和连接延迟?

它是下面的代码吗?
Static const struct connection_param_configuration user_connection_param_conf = {
///在BLE双槽(1.25ms)中测量的连接间隔最小值
///使用宏MS_TO_DOUBLESLOTS从毫秒(ms)转换为双槽
.intv_min = ms_to_doubleslots(10),

///在BLE双槽(1.25ms)中测量的连接间隔最大值
///使用宏MS_TO_DOUBLESLOTS从毫秒(ms)转换为双槽
.intv_max = MS_TO_DOUBLESLOTS (20),

//在连接事件中度量的延迟
.latency = 0,

//监控超时(10毫秒)
///使用宏MS_TO_TIMERUNITS将毫秒(ms)转换为计时器单位
.time_out = ms_to_timerUnits(1250),

///最小连接事件持续时间(1.25ms)
///使用宏MS_TO_DOUBLESLOTS从毫秒(ms)转换为双槽
.ce_len_min = ms_to_doubleslots(0),

///在BLE双槽(1.25ms)中测量的最大连接事件持续时间
///使用宏MS_TO_DOUBLESLOTS从毫秒(ms)转换为双槽
.ce_len_max = MS_TO_DOUBLESLOTS (0)
};

我用RCX20作为睡眠时钟有关系吗?

所以led和蜂鸣器可以在扩展睡眠模式下工作,但我必须在peripher_init()中设置状态?

如果我的产品需要一直连接,睡眠模式能省电吗?因为我发现连接之后,经常会调用peripher_init(),这意味着经常会唤醒核心。

mt_dialog.
离线
最后一次露面:5个月2周前
职员
加入:2015-06-08 34
嗨Daniel59,

嗨Daniel59,

关于您提出代码的重要情况,我想你的意思是接口外部传感器的代码,因为我提到上面,它取决于设备的状态(连接,广告)以及您的代码需要多长时间执行,如果需要足够长,您可能缺少连接间隔和与您的外设有松散的连接。

关于如何提高连接间隔,连接间隔由中央定义,您可以做什么,是发出连接更新请求,中央将决定它是否会接受所请求的连接参数。您已经粘贴的SDK的一部分是设备将与中央连接检查的部分,以及当前参数不匹配将向中央发送请求,以便更新连接参数(请求发送10建立连接后的秒数),因此如果中央接受参数,则连接将在User_connection_param_conf结构中更改为指定的值。

对于连接参数,LP时钟没有任何影响。

如上所述,LED可以工作,因为当设备处于睡眠模式时,引脚保持它们的状态,你只需要记住引脚的状态,并在peripher_init()中相应设置它,因为一旦唤醒,peripher_init()将执行,引脚将被重新配置。关于蜂鸣器,我假设你提供一个PWM,定时器在睡眠模式下关闭,因此,当设备处于睡眠模式时,你不能产生一个PWM来驱动蜂鸣器。

是的,睡眠模式可以节省电量,该设备将睡眠状态下降并以排列的连接间隔唤醒,关于periph_init()以及调用的频率,如上所述在每个连接间隔中调用的频率,以便与中央进行通信,一般来说,连接间隔越长,你应该睡眠时间越长(未考虑外部唤醒),你睡得越少你的消费。

谢谢mt_dialog.

丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
嗨MT_dialog,

嗨MT_dialog,

不,我的意思是将代码放在唤醒定时器回调或轻松唤醒回调中。一个会影响睡眠,一个影响连接事件?和解决两个问题的方法是增加连接间隔?

在常规方式中,代码应该在简单的唤醒回调?

所以在我的应用程序中,需要DA14580一直连接,核心去睡眠和唤醒连接间隔?

我发现Android没有用于更改连接间隔的API,因此我可以使用App_easy_gap_param_update_start在user_on_connection中更新user_config.h中的user_connection_param_conf的连接参数吗?

user_gapm_conf之间的间隔与user_connection_param_conf中的间隔之间有什么区别?他们是同样的吗?如何使用app_easy_gap_dev_configure()使用user_gapm_conf?

在training 04中,它说使用RCX20,它只能在连接时计数2秒,或者在无限的广告时间,这是否意味着连接间隔必须小于2秒?

在SmartTag参考文献中,表10显示,2500 ms间隔使用比500 ms间隔更多的功率,原因是:对于更长的间隔,RF接收器必须是
活动较长时间,以检测来自主服务器的轮询。这和你说的不一样。是连接功耗吗?

谢谢,
丹尼尔

mt_dialog.
离线
最后一次露面:5个月2周前
职员
加入:2015-06-08 34
嗨Daniel59,

嗨Daniel59,

你的意思是,如果您将要将回调放在哪个文件中放置app_easy_wakeup_set()?不,没关系。关于你应该放在上面提到的代码的位置,这取决于事务的长度,如果事务让MCU占用了很长时间,它在代码的情况下无关紧要,它将毁掉你的连接,因为你占据了MCU很长一段时间(这是你应该考虑在较小的碎片中打破交易的情况),如果将代码放在唤醒定时器中,回调将影响系统的醒来,因为与传感器的互动将与传感器进行间隔会影响系统唤醒过程,在App_easy方法中,设备将通过消息同步地开始事务,并且唤醒过程将是可以的,但是,如果过程足够长并延迟从服务延迟设备连接间隔,则可以松开联系。

是的,SDK会根据广告或连接间隔来考虑设备的睡眠时间。

如上所述,是的,您可以向中央发送请求,如果它要接受外围设备所示的参数,以及SDK将需要一些时间以发送请求(约10秒)。

不,BLE指定可实现的最大连接间隔不超过4秒。

在之前的文章中,我提到了一个可以遵循的一般规则,并不是每种设计都适用,Smart Tag上提到的功耗是每次唤醒时的功耗。这意味着,在第一种情况下每次设备会醒来,醒来每500 ms)它将消耗约752 ua和每次在第二种情况下,设备会醒来(2500毫秒),它将消耗约1199,更清楚在第二种情况下设备将消费更多,但醒来更少时间。所以这是一个必须考虑的权衡。

谢谢mt_dialog.

丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
嗨MT_dialog,

嗨MT_dialog,

现在我将MIN连接间隔设置为1秒钟,最大连接间隔为2秒。

我发现如果我把代码放到唤醒计时器回调中,DA14580会死。如果我把代码放在简单的唤醒回调,它也不能工作。

我的想法是:当在唤醒计时器回调时,无论连接间隔多长,代码延迟唤醒过程,所以它死。
但在简单的唤醒回调中,芯片正确地唤醒,间隔足够长,代码运行,它可以工作。

但是DA14580也死了。为什么?所以也许我需要增加睡眠间隔?

丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
嗨MT_dialog,

嗨MT_dialog,

我的问题有什么原因吗?

期待您的来信!

谢谢,
丹尼尔

mt_dialog.
离线
最后一次露面:5个月2周前
职员
加入:2015-06-08 34
嗨Daniel59,

嗨Daniel59,

在一秒钟,虽然间隔的增加不会解决你的问题,我忽略了一个事实,因为你有一个连接,你也被外部中断唤醒,有可能外部中断可能发生在连接事件之前,理论上,如果事务足够小,应该不会影响连接,因为设备有时间进行传感器事务,并通过调用rwip_schedule函数来服务BLE事件。现在在你的情况中apparenty事务很长,如果它发生在连接事件rwip_schedule()(时间表)的消息的函数不会被称为(因为传感器事务正在进行)所以你将错过的事件,会导致断开连接。您可以尝试的是,如前一篇文章所述,在触发app_easy_message时设置一个标志,而不是在处理程序中进行交互。在主循环(使用回调函数我提到app_on_system_powered)你可以检查标志和传感器交互与KEEP_POWERED在每个小块并返回事务以迫使rwip_schedule()函数来运行调度程序和任何upcomming事件。

谢谢mt_dialog.

丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
嗨MT_dialog,

嗨MT_dialog,

所以你的意思是我设置了一个名为samplefull的标志,当传感器使中断时,我在唤醒回调中将标志设置为true,并在app_on_system_powered中编写代码

user_on_system_powered ()
如果samplefull = = true
{
阅读所有样品
做点什么
}
回来睡会儿

而且我不能一次读取所有的样本,如果200个样本造成中断,我必须一次读取20个样本,读取10次,否则芯片会出问题?

所以我必须写:

user_on_system_powered ()
如果Samplenumber> 0
{
阅读20样品
Samplenumber-20.
做点什么
返回保持动力
}
别的
回来睡会儿

我尝试了在空白模板项目中提到的简单代码。

ARCH_MAIN_LOOP_CALLBACK_RET_T USER_ON_SYSTEM_POWERED(void)
{
A ++;
返回GOTO_SLEEP;
}
ARCH_MAIN_LOOP_CALLBACK_RET_T USER_ON_BLE_POWERED(void)
{
B ++;
返回GOTO_SLEEP;
}
空白user_resume_from_sleep(空白)
{
c++;
}

发现在连接之前,a每增加9,b增加8,c增加1。连接后a每增加5,b增加4,c增加1。为什么?

mt_dialog.
离线
最后一次露面:5个月2周前
职员
加入:2015-06-08 34
嗨Daniel59。

嗨Daniel59。

在回调我的意思是,你在app_easy_wakeup_set组()设置一个标志,表明你有数据从传感器接收准备,和有一个检查的app_on_system_powered检查国旗,如果它真的,它开始与传感器的交互。不让外围interraction一下子因为如果你保持580年app_on_system_powered然后当连接事件打你将执行代码从传感器获得数据,你就会继续这样做,直到你的互动结束,这将导致不执行rwip_schedule。因此,在app_on_system_powered中进行交互,并将其分成小块数据,就像你在文章中提到的那样。因此,如果你有一个200个数据事务,那么可以创建10个事务,每个事务包含20个数据,在每个事务之后,使用KEEP_POWERED从app_on_system_powered()返回,以便app_on_ble_powered()再次运行并安排消息(如果有消息的话)。

关于您的实验,每个函数都是根据设备的状态调用,并且根据事件的不同。这些函数尤其是App_On_ble_powered和app_on_system_powered在每个唤醒中运行多次运行(只要设备是活动的,只要服务于BLE事件),App_on_System_Powered运行的事实也比app_on_ble_powered运行更多的时间,它是因为第一个只要BLE核心处于活动状态,核心需要一段时间即可运行,对于user_resume_from_sleep(),它只能在唤醒时立即运行一次。如果您想知道为什么每个广告活动中有更多的交互而不是连接事件是因为广告活动持续时间长于连接事件。

谢谢mt_dialog.

丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
嗨MT_dialog,

嗨MT_dialog,

谢谢你的答案,现在芯片工作很好。我将传感器的所有操作放入动力回调。我会测试它是否处于稳定状态。

还有一个问题,你说增加间隔并不能解决我的问题,你还说这种活动连接间隔太小,所以你错过了连接事件。那么增加间隔有什么帮助呢?降低消费?

问候,
丹尼尔

mt_dialog.
离线
最后一次露面:5个月2周前
职员
加入:2015-06-08 34
嗨Daniel59,

嗨Daniel59,

一开始我对你的实现感到困惑,我提到了增加连接间隔(我认为你在每个连接间隔中与传感器的交互将会唤醒,与传感器的交互将花费太多时间,直到下一个连接间隔)。关于连接间隔的长度,这取决于要实现的应用程序。短连接的间隔意味着你会醒来经常为了传输,因此您将消耗更多的权力,但你将能够发送更多的数据和速度,如果你不感兴趣的sed那么多数据和连接时间间隔较短,没有理由醒来,常常因为不会有数据交换,因此,没有理由经常唤醒设备。正如之前的帖子中提到的,是的,作为一个普遍的规则,一个人可以有更长的连接间隔来节省更多的电力,但这也取决于应用程序,这是一个权衡。

谢谢mt_dialog.

丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
嗨MT_dialog,

嗨MT_dialog,

我测试代码3天,有时它也会死亡。死亡意味着它无法找到,没有从我的手机断开连接。我无法弄清楚为什么。

现在我改变了我的想法,当触发唤醒计时器回调时,我唤醒核心,在简单的唤醒回调中用传感器做所有的事情,然后去睡觉。

这种方式是否具有与使用system_powered的消耗量相同?因为在与传感器交互时,我必须使用System_Power保持电源的电源?

最好的问候,
丹尼尔

mt_dialog.
离线
最后一次露面:5个月2周前
职员
加入:2015-06-08 34
嗨Daniel59,

嗨Daniel59,

我不完全理解情况,你提到的设备去死的意思是没有断开连接,但无法找到(我想你的意思是广告),设备连接时,它也是广告?

关于第二个问题,如果我错了,请纠正我,但是,我认为这是我们在以前的帖子中处理的情况,我提到了在块中做所有的传感器交互,而不是在唤醒回调中有所有的交互。关于GATT错误,你得到133十进制不是一个有效的GATT错误码,如果你提到这到底发生在哪里,在断开回调?你提到的错误是断开的原因吗?

我不认为会有任何显著影响能耗自580年在这两种情况下你保持活着为了从传感器读取,也许方法保持设备在阅读时块会让设备保持清醒一点,但我不认为功耗将意义重大。

谢谢mt_dialog.

丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
嗨MT_dialog,

嗨MT_dialog,

因为Android没有像Lightblue这样的工具,所以我使用nrf连接器来测试我的芯片。

下载代码后,我扫描芯片,连接它,切换通知并查看结果。

过了一段时间,它就断了,再也找不到了,按钮功能也不能用了,所以我认为芯片已经死了。

错误代码来自NRF连接器。

最好的问候,
丹尼尔

mt_dialog.
离线
最后一次露面:5个月2周前
职员
加入:2015-06-08 34
嗨Daniel59,

嗨Daniel59,

对不起,我很困惑,你提到你放弃了我建议的方式,以便在触发APP_EASY_WAKEUP时执行数据并在第一次引起的设备引起的时我提到的原因)。由于连接并通知数据时意味着设备在代码中的某个位置被粘在代码中,因此您必须调试才能检查设备困扰的位置。

谢谢mt_dialog.

丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
嗨MT_dialog,

嗨MT_dialog,

我尝试了3种方式,

1.与传感器交互并在简单的唤醒回调中读取数据,不需要disable_sleep_mode(),只有当蜂鸣器打开时disable_sleep_mode()。
2.与传感器交互,并使用禁用唤醒呼叫中的读取数据删除→sleep_mode()。
3.与传感器和读取数据相互作用,在user_on_system_powered()中读取数据,只读取传感器状态并在Easy Wakeup回调中设置标志,并在蜂​​鸣器打开时使用disable_sleep_mode()。

他们都失败了。

虽然我把代码放在易于唤醒回调的时候,但UVISION不会触发断言,所以我找不到出错的地方。

最好的问候,
丹尼尔

mt_dialog.
离线
最后一次露面:5个月2周前
职员
加入:2015-06-08 34
嗨Daniel59,

嗨Daniel59,

对不起,但是,通过您提供的信息,我无法弄清楚设备摊位的位置,您必须在不同的情况下测试这一点,以便给我更多的线索来弄清楚什么可能出错。如果在设备从User_on_System_Powered()唤醒时读取传感器,并且您返回Keep_Power后,才能让设备在阅读时保持清醒,然后我不认为您错过了任何BLE事件。如果在调试模式下设备不会停止,那么您可以做的是将设备留下在无睡眠模式下运行,并且当发生调试器时,当该问题发生时,通过执行以下操作,检查设备停顿的位置:

1)在项目的所有文件中搜索“SetBits16(SYS_CTRL_REG, DEBUGGER_ENABLE, 0);”,并到处注释。//如果你正在使用SDK5,这应该已经完成了
2)创建xxx的副本。在你的项目的应用程序文件夹中,并将其命名为xxx_attach.uvprojx
3)运行附加项目,转到项目选项
4)在“调试”页签禁用“启动时加载应用程序”复选框,并擦除到初始化文件的链接
5)单击调试器的设置按钮,禁用“连接后重启”复选框
6)单击“确定”并再次确定以关闭项目选项
7)回到原来的项目,编译你的代码,就像你总是做的
8)附加调试器下载代码(在RAM中)
9)分离调试器以启动代码的执行

------------------------- 运行代码,一旦问题发生 ------------------

10)在不下载代码的情况下再次加载(热加载),请转到加载项目并启动调试器。如果cpu处于一个断点,那么您可以找到已经停止的代码行。

谢谢mt_dialog.

丹尼尔59.
离线
最后一次露面:1年8个月前
加入:2016-01-08 04:34
嗨MT_dialog,

嗨MT_dialog,

我尝试了所提到的方式,(无法找到任何“setbits16(sys_ctrl_reg,debugger_enable,0);”,但查找“setbits16(sys_ctrl_reg,debugger_enable,1);”)复制项目文件,修改选项,并首先启动调试会话并在xxx.uvprojx中运行代码。然后等待芯片出错,然后运行xxx_attach.uvprojx并开始调试会话。

但它显示了一个错误。日志如下:

加载"F:\ Dialog\ 5.0.4\\projects\\target_apps\\template\ v2 - ledwake\ Keil_5\\out_580\\empty_peripheral_template_580.axf"
设置JLink项目文件为"F:\Dialog\5.0.4\projects\target_apps\template\v2 - ledwake\Keil_5\JLinkSettings.ini"
* JLINK INFO:选择“Cortex-M0”所选的。

jlink信息:
-------------
DLL: V5.12e,编译Apr 29 2016 15:03:58
固件:J-Link ARM-OB STM32编译2012年8月22日19:52:04
硬件:V7.00
S / N:20090928
特性:RDI、FlashDL FlashBP, JFlash GDBFull

* JLINK信息:找到了带ID 0x0BB11477的SWD-DP
* JLink Info: Found Cortex-M0 r0p0, Little endian。
* JLink Info: FPUnit: 4代码(BP)槽和0文字槽
* jlink信息:coresight组件:
* jlink信息:romtbl 0 @ E00FF000
* JLink Info: ROMTbl 0 [0]: FFF0F000, CID: B105E00D, PID: 000BB008 SCS
* jlink信息:romtbl 0 [1]:fff02000,cid:b105e00d,pid:000bb00a dwt
* jlink信息:romtbl 0 [2]:fff03000,cid:b105e00d,pid:000bb00b fpb
ROMTableAddr = 0 xe00ff000

目标信息:
-------------
设备:ARMCM0
VTarget = 3.300 v
销状态:
Tck: 0, tdi: 0, tdo: 1, tms: 0, tres: 1, trst: 0
硬件断点:4
软件断点:8192
观察点:2
JTAG速度:4000 kHz

没有找到:20000000H - 2000009FH的算法
没有找到:20000160H - 20000323H的算法
没有找到:20000340H - 200003E3H的算法
没有找到算法:20000440H - 20005803H
擦除跳过!
错误:Flash下载失败 - “Cortex-M0”
闪存负荷在15:40:09完成

最好的问候,
丹尼尔

mt_dialog.
离线
最后一次露面:5个月2周前
职员
加入:2015-06-08 34
嗨Daniel59,

嗨Daniel59,

如果您使用的是使用最新的SDK16(sys_ctrl_reg,debugger_enable,0),则在上面提到的方向上提到。完成后,SDK5.0.4当设备睡眠时不会禁用调试器模块(SDK的旧版本)。关于您所看到的错误是因为您尚未在Keil中指定,您将在“目标选项”中的“实用程序”选项卡中“使用Flash编程”中的“使用外部工具”。

谢谢mt_dialog.