你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

STM32F107+CubeMX+FreeRTOS+LWIP 连接成功后,信号量无法使用

[复制链接]
darrensun687df3 提问时间:2019-5-12 11:24 /
本帖最后由 darrensun687df3 于 2019-5-12 14:41 编辑

各位大哥,遇到一个在FreeRTOS+LWIP使用信号量的问题。
项目工程是通过CubeMX生成的,使用FreeRTOS + LWIP。
简化代码,FreeRTOS初始化两个任务,一个默认任务、一个等待信号量任务。在默认任务中和PC上面的TCP server建立连接。在另外一个等待信号量。

信号量任务
extern osSemaphoreId EthBinSemHandle;
void task_usart_function()
{
    osSemaphoreWait(EthBinSemHandle, 0); //消耗第一次初始化之后的信号量
    UsrLog("Usart Task Start");
    for (;;)
    {
        if (osSemaphoreWait(EthBinSemHandle, osWaitForever) == osOK)
        {UsrLog("Processing");}
        else
        {UsrLog("Wait Failed");}
    }
}


默认任务
static volatile uint8_t sec_tic = 1;
extern osSemaphoreId EthBinSemHandle;
void task_default_function(void)
{
    // Application init code
    connect_server(get_connect_state(CLIENT_SERVER));
    for (;;)
    {
        HAL_IWDG_Refresh(&hiwdg);
        if ((sec_tic + 15) % 15 == 0)
        {
            //每隔15秒释放一次信号量
            osSemaphoreRelease(EthBinSemHandle);
        }
        sec_tic++;
        osDelay(1000);
    }
}

void connect_server(conn_state_t* conn_state)
{
    if (get_link_state() == TRUE && conn_state->connected == FALSE)
    {
        connect_init(conn_state, get_config_local_port(CLIENT_SERVER));
/* 在connect_init()里面主要操作了netconn_new以及netconn_bind.
    local_server->conn = netconn_new(NETCONN_TCP);
    if ((ret = netconn_bind(local_server->conn, NULL, port)) == ERR_OK)

*/
        connect_connect(conn_state, &(get_server_data(CLIENT_SERVER)->ip_addr), get_server_data(CLIENT_SERVER)->port);
/*在connect_connect()里面主要是
        ret = netconn_connect(conn_state->conn, ip_addr, port);
        一旦执行了netconn_connect()之后,信号量的使用就没办法用了。
*/
    }
}



TCP通信没有问题,也可以PING通。如果注释掉//connect_connect()函数,每隔15秒,可以在串口看到一个打印,说明信号量释放成功。
如果使用connect_connect函数,在PC上TCP客户端可以发现,链接已经链接成功。
此时,如果执行osSemaphoreRelease(EthBinSemHandle);整个系统会死机。如果不执行osSemaphoreRelease(EthBinSemHandle);,可以进行正常的TCP通信。

问题出在TCP建立连接之后,osSemaphoreRelease(EthBinSemHandle);函数会hang住,尝试暂停debug了一下,发现是在queue.c中,
configASSERT( !( ( pvItemToQueue == NULL ) && ( pxQueue->uxItemSize != ( UBaseType_t ) 0U ) ) );导致整体系统处于for循环的情况。
检查了一下pxQueue->uxItemSize的数值为0x10000000.

不知道应该怎么搞了。不知道还有朋友遇到这样的问题吗??

整个工程代码:
链接:https://pan.baidu.com/s/1aqnbbdeGwony7RVt-V_d7w
提取码:y7gg



收藏 评论1 发布时间:2019-5-12 11:24

举报

1个回答
butterflyspring 回答时间:2019-6-6 12:09:52
这里有几个官方的例程,应用场景差不多,也是用FREERTOS。不过是F4芯片的。参考一下,希望能帮到你
stm32cube_fw_f4_v1210\STM32Cube_FW_F4_V1.21.0\Projects\STM324xG_EVAL\Applications\LwIP
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新和工艺
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版