This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

尋找cc2541 睡眠的函數

Other Parts Discussed in Thread: CC2541

hi 各位:

我這邊採用cc2541的advance remote device

我想找關於cc2541進入休眠的點在哪裡?

以及我該如何讓裝至進入休眠?

我已經找了好幾天,關於這個看到類似的幾個地方,不過不知道我是否有誤解?

在 hidadvremote_main.c 中

初始化設置時:

#if defined ( POWER_SAVING )
osal_pwrmgr_device( /*PWRMGR_ALWAYS_ON*/ PWRMGR_BATTERY );
#endif

在追下去:

void osal_pwrmgr_device( uint8 pwrmgr_device )
{
pwrmgr_attribute.pwrmgr_device = pwrmgr_device;


}

這一行是否告訴裝置可進入休眠?

那我要如何得知裝置會進入休眠?

另外詢問一下 CC2541 在 流程中是否採用輪巡方式來讓裝置從休眠進入等待模式?

找了好久找不到哪一個函式是一值在輪詢的(進入休眠一樣進入輪巡?)

  • hi lee:

      进入休眠的函数接口在:

    void osal_pwrmgr_powerconserve( void )

    {

    //···············//

    OSAL_SET_CPU_INTO_SLEEP( next );

    }

    如上红色字体 用宏定义封起来 其实就是调用void halSleep( uint32 osal_timeout ).在这函数中真正进入睡眠的指令HAL_SLEEP_SET_POWER_MODE()。

    脱出低消费其中之一就是原代码设置的定时器:

    void halSleepSetTimer( uint32 sleepTimer, uint32 timeout )
    {
    HAL_SLEEP_TIMER_DISABLE_INT();

    // compute sleep timer compare value
    sleepTimer += timeout;

    // subtract the processing time spent in function halSleep()
    sleepTimer -= HAL_SLEEP_ADJ_TICKS;

    // set sleep timer compare; ST0 must be written last
    ST2 = ((uint8 *)&sleepTimer)[UINT32_NDX2];
    ST1 = ((uint8 *)&sleepTimer)[UINT32_NDX1];
    ST0 = ((uint8 *)&sleepTimer)[UINT32_NDX0];

    HAL_SLEEP_TIMER_CLEAR_INT();
    HAL_SLEEP_TIMER_ENABLE_INT();

    return;
    }

    这也是我这俩天刚看的,不知道理解的对不对,希望对你有帮助


  • T_MAC 说的很好 :)

    记得要define POWER_SAVING, 在IAR 工程选项里面的 preprocessor 里.

  • 非常感謝 T_MAC 協助

    也感謝 Yan 幫忙,不過 define POWER_SAVING 這是甚麼意思呢? 而在 IAR 工程选项里面的 preprocessor 里 這是在哪邊要做甚麼更改?



    不好意思,對這真的還有很大需要摸索,還是很感謝各位先進的協助!!!

    另外  在CC2541 中 是否有函數是 一值再輪詢狀態的呢?(無視 低消費(睡眠)模式)

  • yan的意思就是在osal_run_system函数中如下代码,宏定义POWER_SAVING  控制低消费代码能否执行到。

    #if defined( POWER_SAVING )
    else // Complete pass through all task events with no activity?
    {
    osal_pwrmgr_powerconserve(); // Put the processor/system into sleep
    }

    另外:

    void osal_start_system( void )
    {
    #if !defined ( ZBIT ) && !defined ( UBIT )
    for(;;) // Forever Loop
    #endif
    {
    osal_run_system();
    }
    }

    如上for死循环,就是一直轮训查找event。

  • T_MAC 感謝您的回覆


    由於我之前測試的時候,我在

    for(;;) // Forever Loop
    #endif
    {
    osal_run_system();

    P2_0=~P2_0 <===TP4


    }


    中 加入了 對於  P2_0=~P2_0 這個程式碼   (p2_0 接外部LED)

    發現她好像沒有正確的做切換,因此判斷好像只有跑一次?

  • 另外詢問

    由於我在 code中找不到POWER_SAVING的定義,那代表他不會進入休眠嗎?

  • Hi lee,

    看下面两图, POWER_SAVING 定义 :)

  • YAN 您好,感謝如此淺顯易懂的教學。

    我看了一下我的 POWER SAVING中 原本已經有在裡面了?這樣算是已經有加入對於POWER SAVING的定義了嗎

  • Hi lee,

    是的, 这样就已经定义了.

  • Hi lee,

    关于 P2_0=~P2_0 <===TP4,

    这个很难讲, 因为osal_run_system(); 里面有可能会处理很多事件, 时间上是无法确定的. 必然会影响到 后面的代码.

    而且你这样写的话应该看不到非常明显的现象, 要看到LED 明显变化的话最好是隔一段时间再做切换.

  • 你好

    我使用CC2541 Keyfob,燒錄Keyfobdemo

    preprocessor已經有定義POWER_SAVING

    但有辦法在Keyfob_Main.c的HAL_BOARD_INIT();之前延遲或睡眠一秒嗎???

    使用HalSleep(2000);

    但好像沒有醒來

    要使用甚麼讓他wake up嗎?

  • hi wun,

    你这样就是进入PM3了, 只能用IO口通过中断唤醒, 比如说按键.

  • TI的大牛们,你们好!

    我用串口打印跟踪SimpleBLEPeripheral程序流程,根据串口打印信息,SimpleBLEPeripheral进入了 OSAL_SET_CPU_INTO_SLEEP( next )函数,但是这个时候我用SimpleBLECentral程序和SimpleBLEPeripheral通信依然可以成功,SimpleBLEPeripheral不是进入了OSAL_SET_CPU_INTO_SLEEP函数后就进入低功耗模式了吗?为什么还能和SimpleBLECentral通信呢?

    辛苦您们了。