从函数上也看得出来,这里有一个set_option的选项,主要是为了供调用者选择是进行and设置还是or设置,细节如下所示,

  (1)判断参数合法性;

  (2)判断set_option合法性;

  (3)如果选项为and,在设置完flags之后函数返回;

  (4)设置flags标志位,开始遍历每一个等待线程;

  (5)如果存在合适的线程,不管是等待多个事件还是一个事件,都将它们唤醒,设置重新调度标志;

  (6)如果重新调度标志为1,调用系统调度函数切换到其他线程运行;

  (7)当前线程再次获取到运行的机会,函数返回。

  转眼之间,我们到了事件的删除过程了。其实事件的删除非常简单,它是把所有的等待线程唤醒,这么简单,不知道我说清楚了没?当然了,这中间可能会有高优先级的线程被加入到ready队列里面,所以重新schedule一下也是很有必要的。

 

RAW_U16 raw_event_delete(RAW_EVENT *event_ptr)
 {
  LIST *block_list_head;
  
    RAW_SR_ALLOC();
  
  #if (RAW_EVENT_FUNCTION_CHECK > 0)
 
  if (event_ptr == 0) {
   return RAW_NULL_OBJECT;
  } 
  
  #endif
  
  block_list_head = &event_ptr->common_block_obj.block_list;
  
    RAW_CRITICAL_ENTER();
 
  /*All task blocked on this queue is waken up until list is empty*/
  while (!is_list_empty(block_list_head)) {
   delete_pend_obj(list_entry(block_list_head->next, RAW_TASK_OBJ, task_list)); 
  }   
 
  event_ptr->flags = 0;
  
  RAW_CRITICAL_EXIT();
  
     raw_sched(); 
 
  return RAW_SUCCESS;
 }