⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tqdata.h

📁 开放源码的嵌入式开发环境
💻 H
字号:
/**  *  @file  rtems/score/tqdata.h * *  This include file contains all the constants and structures *  needed to declare a thread queue. *//* *  COPYRIGHT (c) 1989-2006. *  On-Line Applications Research Corporation (OAR). * *  The license and distribution terms for this file may be *  found in the file LICENSE in this distribution or at *  http://www.rtems.com/license/LICENSE. * *  $Id: tqdata.h,v 1.24 2006/01/16 15:13:58 joel Exp $ */#ifndef _RTEMS_SCORE_TQDATA_H#define _RTEMS_SCORE_TQDATA_H/** *  @defgroup ScoreThreadQData Thread Queue Handler Data Definition * *  This handler defines the data shared between the thread and thread *  queue handlers.  Having this handler define these data structure *  avoids potentially circular references. *//**@{*/#ifdef __cplusplusextern "C" {#endif#include <rtems/score/chain.h>#include <rtems/score/priority.h>#include <rtems/score/states.h>/** *  The following enumerated type details all of the disciplines *  supported by the Thread Queue Handler. */typedef enum {  THREAD_QUEUE_DISCIPLINE_FIFO,     /* FIFO queue discipline */  THREAD_QUEUE_DISCIPLINE_PRIORITY  /* PRIORITY queue discipline */}   Thread_queue_Disciplines;/** *  The following enumerated types indicate what happened while the thread *  queue was in the synchronization window. */typedef enum {  THREAD_QUEUE_SYNCHRONIZED,  THREAD_QUEUE_NOTHING_HAPPENED,  THREAD_QUEUE_TIMEOUT,  THREAD_QUEUE_SATISFIED}  Thread_queue_States;/** *  This is one of the constants used to manage the priority queues. * *  There are four chains used to maintain a priority -- each chain *  manages a distinct set of task priorities.  The number of chains *  is determined by TASK_QUEUE_DATA_NUMBER_OF_PRIORITY_HEADERS. *  The following set must be consistent. * *  The set below configures 4 headers -- each contains 64 priorities. *  Header x manages priority range (x*64) through ((x*64)+63).  If *  the priority is more than half way through the priority range it *  is in, then the search is performed from the rear of the chain. *  This halves the search time to find the insertion point. */#define TASK_QUEUE_DATA_NUMBER_OF_PRIORITY_HEADERS 4/** *  This is one of the constants used to manage the priority queues. *  @ref TASK_QUEUE_DATA_NUMBER_OF_PRIORITY_HEADERS for more details. */#define TASK_QUEUE_DATA_PRIORITIES_PER_HEADER      64/** *  This is one of the constants used to manage the priority queues. *  @ref TASK_QUEUE_DATA_NUMBER_OF_PRIORITY_HEADERS for more details. */#define TASK_QUEUE_DATA_REVERSE_SEARCH_MASK        0x20/** *  This is the structure used to manage sets of tasks which are blocked *  waiting to acquire a resource. */typedef struct {  /** This union contains the data structures used to manage the blocked   *  set of tasks which varies based upon the discipline.   */  union {    /** This is the FIFO discipline list. */    Chain_Control Fifo;    /** This is the set of lists for priority discipline waiting. */    Chain_Control Priority[TASK_QUEUE_DATA_NUMBER_OF_PRIORITY_HEADERS];  } Queues;  /** This field is used to manage the critical section. */  Thread_queue_States      sync_state;  /** This field indicates the thread queue's blocking discipline. */  Thread_queue_Disciplines discipline;  /** This indicates the blocking state for threads waiting on this   *  thread queue.   */  States_Control           state;  /** This is the status value returned to threads which timeout while   *  waiting on this thread queue.   */  uint32_t                 timeout_status;}   Thread_queue_Control;#ifndef __RTEMS_APPLICATION__#include <rtems/score/tqdata.inl>#endif#ifdef __cplusplus}#endif/**@}*/#endif/* end of include file */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -