搜索
bottom↓
回复: 1

CC3200 RTC 和UDPC发送问题

[复制链接]

出0入0汤圆

发表于 2016-3-3 12:54:44 | 显示全部楼层 |阅读模式
各位大神好,

我最近在用LDPS模式,所以在iddleprofile里修改了一下,用rtc 定时器来做UDP发送的定时器(开始把cc_idle_task_pm()函数屏蔽掉了,其实进不进LDPS都会出现这个问题)

我把发送任务放到大循环里,利用标志位每50ms发送一次,一开始发送任务可以进行,但是当发送了几百几千次(有时候是几十次,随机性很强)之后,sl_sendto停止发送,又经过几个循环之后,sl_sendto返回SL_EAGAIN11 手册上标注的try again),之后就一直返回-11.

如果换一个timer,比如timer0,timer1都没用这个问题。

SetTimerAsWkUp()是iddleprofile里原来就有的,创建唤醒定时器,SetTimerAsWkUp2()是我用论坛行看见的,把中间四句删掉(在timercallback里只是重设timer而不是重新创建)。这个RTC 的timer运行一直没问题,就是发送函数有问题。

void TimerCallback(void *vParam)
{

LPDS_Flag2=1;
SetTimerAsWkUp2();

}

cc_hndl SetTimerAsWkUp()
{
    cc_hndl tTimerHndl;
    struct cc_timer_cfg sRealTimeTimer;
    struct u64_time sInitTime, sIntervalTimer;
    //
    // setting up Timer as a wk up source and other timer configurations
    //
    sInitTime.secs = 0;
    sInitTime.nsec = 0;
    cc_rtc_set(&sInitTime);

    sRealTimeTimer.source = HW_REALTIME_CLK;
    sRealTimeTimer.timeout_cb = TimerCallback;
    sRealTimeTimer.cb_param = NULL;

    tTimerHndl = cc_timer_create(&sRealTimeTimer);

    sIntervalTimer.secs = LPDS_DUR_SEC;
    sIntervalTimer.nsec = LPDS_DUR_NSEC;
    cc_timer_start(tTimerHndl, &sIntervalTimer,OPT_TIME_ABS_VALUE);
    return(tTimerHndl);
}
cc_hndl SetTimerAsWkUp2()
{
    cc_hndl tTimerHndl;
    struct cc_timer_cfg sRealTimeTimer;
    struct u64_time sInitTime, sIntervalTimer;
    //
    // setting up Timer as a wk up source and other timer configurations
    //
    sInitTime.secs = 0;
    sInitTime.nsec = 0;

cc_rtc_set(&sInitTime);

/*

    sRealTimeTimer.source = HW_REALTIME_CLK;
    sRealTimeTimer.timeout_cb = TimerCallback;
    sRealTimeTimer.cb_param = NULL;

   
    tTimerHndl = cc_timer_create(&sRealTimeTimer); */
    timer_created++;
    sIntervalTimer.secs = LPDS_DUR_SEC;
    sIntervalTimer.nsec = LPDS_DUR_NSEC;
    cc_timer_start(tTimerHndl, &sIntervalTimer,OPT_TIME_ABS_VALUE);
    return(tTimerHndl);
}


//udpclient main loop
while(1)
{
  if(LPDS_Flag2==1)
  {
  
GPIO_IF_LedToggle(MCU_RED_LED_GPIO);   
iStatus= sl_SendTo( 0,  &wifi_send_buf, 1, 0,( SlSockAddr_t *)&sAddr_Flag, iAddrSize_Flag);
GPIO_IF_LedToggle(MCU_RED_LED_GPIO);

LPDS_Flag2=0;
UART_PRINT("istatus is %d",iStatus);



  }
}

socket我设置成了nonblock模式

sl_SetSockOpt(iSockID,SOL_SOCKET,SL_SO_NONBLOCKING, &enableOption,sizeof(enableOption));

如果不这样设置的话,从sl_sendto这里就直接阻塞了,调到idle task里面回不来了了

阿莫论坛20周年了!感谢大家的支持与爱护!!

一只鸟敢站在脆弱的枝条上歇脚,它依仗的不是枝条不会断,而是自己有翅膀,会飞。

出0入0汤圆

发表于 2016-4-13 15:12:34 | 显示全部楼层
这种问题直接上TI的e2e,阿莫上是解决不了的
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-5-20 12:20

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表