首页 > 其他 > 详细

μCOS-II系统之事件(event)的使用规则及Semaphore的互斥量用法

时间:2014-06-01 09:07:31      阅读:451      评论:0      收藏:0      [点我收藏+]

***************************************************************************************************************************
作者:EasyWave                                                时间:2014.05.31

类别:μC/OS-II-操作系统                                  声明:转载,请保留链接

注意:如有错误,欢迎指正。这些是我学习的日志文章......

***************************************************************************************************************************

一:μC/OS-II系统Semaphore事件简介

在实时多任务系统中,信号量被广泛用于:任务间对共享资源的互斥、任务和中断服务程序之间的同步、任务之间的同步。当任务调用OSSemPost()函数发送信号量时:

bubuko.com,布布扣

当信号量值大于0,任务调用OSSemPend()函数接收信号量时:

bubuko.com,布布扣

当信号量值等于0,任务调用OSSemPend()函数接收信号量时:

bubuko.com,布布扣

二:Semaphore用作互斥量实例及代码

那么如何使用Semaphore来用作互斥量来使用呢,只需要在建立Semaphore时,设置SemMutex = OSSemCreate(1);,如下:

bubuko.com,布布扣

下面以Nuvoton的NUC140为例说明Semaphore用作互斥量的使用:

bubuko.com,布布扣

主函数里面只有做一些简单的初始化和OS环境建立。下面是Semaphore的实例代码:

#ifndef	_TASK_C
#define	_TASK_C

/*-----------------------------------------------------------------------------------------*/
/*                                                                                         */
/* Copyright (c)EasyWave. All rights reserved.                                             */
/*                                                                                         */
/*-----------------------------------------------------------------------------------------*/


//===========================================================================================
// 						INCLUDE FILES														 
//===========================================================================================
#include "SYS_Header.H"
#include "BSP_Header.H"
#include "DRV_Header.H"
#include "UOS_Header.H"
#include "Task.H"

/* *************************************************************************************** */
/* 					 	         PUBLIC VARIABLE                               			   */
/* *************************************************************************************** */
#define	TASK1_PRIO 				1	 	// TASK1_PRIO < OS_LOWEST_PRIO
#define	TASK2_PRIO				2		// TASK2_PRIO < OS_LOWEST_PRIO

OS_STK	Task1Stack[OS_MAX_STACK];      	// for task1 stack size
OS_STK	Task2Stack[OS_MAX_STACK];      	// for task2 stack size
OS_EVENT	*SemMutex;
UINT32	Critical1, Critical2;

/* *************************************************************************************** */
/* 					 	         DEBUG MARCO                                  			   */
/* *************************************************************************************** */
#ifdef ENABLE_DEBUG
    #define	TASK_DEBUG(x)	  x
#else
    #define	TASK_DEBUG(x)
#endif

/*-----------------------------------------------------------------------------------------*/
/*                      PUBLIC FUNCTION                                                    */
/*-----------------------------------------------------------------------------------------*/
//===========================================================================================
// Function		: OSTaskInitial
// Purpose		: None
// Input		: None
// Rteurn		: None
// External		: None
// History		: EasyWave 2011-11-16 Create
//
// Modify		: None
//===========================================================================================
VOID OSTaskInitial(VOID)
{
	OSTaskCreate( MainTask1, (void*)0, &Task1Stack[OS_MAX_STACK-1], TASK1_PRIO );
	OSTaskCreate( MainTask2, (void*)0, &Task2Stack[OS_MAX_STACK-1], TASK2_PRIO );

	Critical1 = 0x00;
	Critical2 = 0x00;
}

//===========================================================================================
// Function		: MainTask1
// Purpose		: None
// Input		: None
// Rteurn		: None
// External		: None
// History		: EasyWave 2011-11-16 Create
//
// Modify		: None
//===========================================================================================
VOID MainTask1(VOID *pdata)
{
	INT8U	err;

	(VOID)pdata; 

	SemMutex = OSSemCreate(1);		//Create semaphore with 1 tokens
 
	while(TRUE)
	{
		OSSemPend(SemMutex, INFINITE, &err);
		TASK_DEBUG(DrvSIO_printf("%s is Running.\r\n",__FUNCTION__));
 		Critical1 ++;
		OSTimeDly(20);
		Critical2 ++;
		OSSemPost(SemMutex);
	}
}

//===========================================================================================
// Function		: MainTask2
// Purpose		: None
// Input		: None
// Rteurn		: None
// External		: None
// History		: EasyWave 2011-11-16 Create
//
// Modify		: None
//===========================================================================================
VOID MainTask2(VOID *pdata)
{
	INT8U	err;

	(VOID)pdata; 

	while(TRUE)
	{
		TASK_DEBUG(DrvSIO_printf("%s is Running.\r\n",__FUNCTION__));
		OSSemPend(SemMutex, INFINITE, &err);
		if(Critical1 != Critical2)
		{
			TASK_DEBUG(DrvSIO_printf("Mutex error\n"));
			while(TRUE);
		}
		else
		{
			TASK_DEBUG(DrvSIO_printf("Mutex Works Well.\r\n"));
		}
		Critical1 ++;
		Critical2 ++;
		OSSemPost(SemMutex);
	}
}



#endif	//_TASK_C
代码的意思,自行分析吧,这个博文已经分析的很清楚了。


μCOS-II系统之事件(event)的使用规则及Semaphore的互斥量用法,布布扣,bubuko.com

μCOS-II系统之事件(event)的使用规则及Semaphore的互斥量用法

原文:http://blog.csdn.net/wavemcu/article/details/27798493

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!