dataqueue.h

説明を見る。
00001 /*
00002  *  TOPPERS/ASP Kernel
00003  *      Toyohashi Open Platform for Embedded Real-Time Systems/
00004  *      Advanced Standard Profile Kernel
00005  * 
00006  *  Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
00007  *                              Toyohashi Univ. of Technology, JAPAN
00008  *  Copyright (C) 2005-2008 by Embedded and Real-Time Systems Laboratory
00009  *              Graduate School of Information Science, Nagoya Univ., JAPAN
00010  * 
00011  *  上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
00012  *  ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
00013  *  変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
00014  *  (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
00015  *      権表示,この利用条件および下記の無保証規定が,そのままの形でソー
00016  *      スコード中に含まれていること.
00017  *  (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
00018  *      用できる形で再配布する場合には,再配布に伴うドキュメント(利用
00019  *      者マニュアルなど)に,上記の著作権表示,この利用条件および下記
00020  *      の無保証規定を掲載すること.
00021  *  (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
00022  *      用できない形で再配布する場合には,次のいずれかの条件を満たすこ
00023  *      と.
00024  *    (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
00025  *        作権表示,この利用条件および下記の無保証規定を掲載すること.
00026  *    (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
00027  *        報告すること.
00028  *  (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
00029  *      害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
00030  *      また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
00031  *      由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
00032  *      免責すること.
00033  * 
00034  *  本ソフトウェアは,無保証で提供されているものである.上記著作権者お
00035  *  よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
00036  *  に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
00037  *  アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
00038  *  の責任を負わない.
00039  * 
00040  *  @(#) $Id: dataqueue.h 748 2008-03-07 17:18:06Z hiro $
00041  */
00042 
00043 /*
00044  *      データキュー機能
00045  */
00046 
00047 #ifndef TOPPERS_DATAQUEUE_H
00048 #define TOPPERS_DATAQUEUE_H
00049 
00050 #include <queue.h>
00051 
00052 /*
00053  *  データキュー初期化ブロック
00054  *
00055  *  この構造体は,同期・通信オブジェクトの初期化ブロックの共通部分
00056  *  (WOBJINIB)を拡張(オブジェクト指向言語の継承に相当)したもので,
00057  *  最初のフィールドが共通になっている.
00058  */
00059 typedef struct dataqueue_initialization_block {
00060     ATR         dtqatr;         /* データキュー属性 */
00061     uint_t      dtqcnt;         /* データキューの容量 */
00062     intptr_t    *p_dtqmb;       /* データキュー管理領域の先頭番地 */
00063 } DTQINIB;
00064 
00065 /*
00066  *  データキュー管理ブロック
00067  *
00068  *  この構造体は,同期・通信オブジェクトの管理ブロックの共通部分(WOBJCB)
00069  *  を拡張(オブジェクト指向言語の継承に相当)したもので,最初の2つの
00070  *  フィールドが共通になっている.
00071  */
00072 typedef struct dataqueue_control_block {
00073     QUEUE       swait_queue;    /* データキュー送信待ちキュー */
00074     const DTQINIB *p_dtqinib;   /* 初期化ブロックへのポインタ */
00075     QUEUE       rwait_queue;    /* データキュー受信待ちキュー */
00076     uint_t      count;          /* データキュー中のデータの数 */
00077     uint_t      head;           /* 最初のデータの格納場所 */
00078     uint_t      tail;           /* 最後のデータの格納場所の次 */
00079 } DTQCB;
00080 
00081 /*
00082  *  データキュー待ち情報ブロックの定義
00083  *
00084  *  この構造体は,同期・通信オブジェクトの待ち情報ブロックの共通部分
00085  *  (WINFO_WOBJ)を拡張(オブジェクト指向言語の継承に相当)したもので,
00086  *  最初の2つのフィールドが共通になっている.
00087  *  データキューへの送信待ちとデータキューからの受信待ちで,同じ待ち情
00088  *  報ブロックを使う.
00089  */
00090 typedef struct dataqueue_waiting_information {
00091     WINFO       winfo;          /* 標準の待ち情報ブロック */
00092     DTQCB       *p_dtqcb;       /* 待っているデータキューの管理ブロック */
00093     intptr_t    data;           /* 送受信データ */
00094 } WINFO_DTQ;
00095 
00096 /*
00097  *  データキューIDの最大値(kernel_cfg.c)
00098  */
00099 extern const ID tmax_dtqid;
00100 
00101 /*
00102  *  データキュー初期化ブロックのエリア(kernel_cfg.c)
00103  */
00104 extern const DTQINIB    dtqinib_table[];
00105 
00106 /*
00107  *  データキュー管理ブロックのエリア(kernel_cfg.c)
00108  */
00109 extern DTQCB    dtqcb_table[];
00110 
00111 /*
00112  *  データキュー管理ブロックからデータキューIDを取り出すためのマクロ
00113  */
00114 #define DTQID(p_dtqcb)  ((ID)(((p_dtqcb) - dtqcb_table) + TMIN_DTQID))
00115 
00116 /*
00117  *  データキュー機能の初期化
00118  */
00119 extern void initialize_dataqueue(void);
00120 
00121 /*
00122  *  データキュー管理領域へのデータの格納
00123  */
00124 extern void enqueue_data(DTQCB *p_dtqcb, intptr_t data);
00125 
00126 /*
00127  *  データキュー管理領域へのデータの強制格納
00128  */
00129 extern void force_enqueue_data(DTQCB *p_dtqcb, intptr_t data);
00130 
00131 /*
00132  *  データキュー管理領域からのデータの取出し
00133  */
00134 extern void dequeue_data(DTQCB *p_dtqcb, intptr_t *p_data);
00135 
00136 /*
00137  *  データキューへのデータ送信
00138  */
00139 extern bool_t   send_data(DTQCB *p_dtqcb, intptr_t data, bool_t *p_reqdsp);
00140 
00141 /*
00142  *  データキューへのデータ強制送信
00143  */
00144 extern bool_t   force_send_data(DTQCB *p_dtqcb, intptr_t data);
00145 
00146 /*
00147  *  データキューからのデータ受信
00148  */
00149 extern bool_t   receive_data(DTQCB *p_dtqcb, intptr_t *p_data,
00150                                                     bool_t *p_reqdsp);
00151 
00152 #endif /* TOPPERS_DATAQUEUE_H */

Copyright © 2008 by Kijineko Inc.

ホームページ制作