OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 2684|回复: 1

ucos-ii创建信号量的一个奇怪问题?求解释~~~~~

[复制链接]

21

主题

71

帖子

0

精华

初级会员

Rank: 2

积分
167
金钱
167
注册时间
2013-12-1
在线时间
88 小时
发表于 2016-5-25 10:28:50 | 显示全部楼层 |阅读模式
本帖最后由 ssis909 于 2016-5-25 10:31 编辑

这是我的测试代码:
//************************************************************************************
void delay_ms(u32 delay_num)
{
        u32 a,b;
        
        for(a = delay_num;a > 0;a--)
        {
                for(b = 5000;b > 0;b--);
        }
}
//************************************************************************************
void Test_Init(void)
{
        delay_ms(8);
}

//************************************************************************************
void Hello(void)
{
        OS_EVENT  *p;
        p = OSSemCreate(0);
        if(p == (OS_EVENT  *)0)
        {
                printf("\r\n SEM-FAIL \r\n");
        }
        else
        {
                printf("\r\n SEM-OK \r\n");
        }
}
//************************************************************************************
void FuncDisplay(void *pdata)
{
        pdata = pdata;

        while(1)
        {
                OSTimeDlyHMSM(0,0,0,100);
        }
}
//************************************************************************************
int main(void)
{
        Initial_BSP();
        
        SysTick_Config(SystemCoreClock / OS_TICKS_PER_SEC);

        OSInit();
        
        Test_Init();
        Hello();
        
        OSTaskCreate(FuncDisplay        ,(void *)0,(OS_STK *)&StkRunDisplay[TASK_SIZE_DISPLAY - 1], 1);
        
        OSStart();
}

    我调试遇到这样的奇怪问题:
函数Test_Init中,延迟改为1~7之间的数,打印 "SEM-OK" ,表明创建信号量成功;
但是延迟改为大于7的数后,打印 "SEM-FAIL" ,表明信号量创建失败,真是x了狗了,弄半天找不到原因,什么情况?求解释~



正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

21

主题

71

帖子

0

精华

初级会员

Rank: 2

积分
167
金钱
167
注册时间
2013-12-1
在线时间
88 小时
 楼主| 发表于 2016-5-25 10:47:44 | 显示全部楼层
已经解决,代码需要临界段保护
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-9 14:59

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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