Nut/OS  4.10.3
API Reference
msg.h
Go to the documentation of this file.
00001 #ifndef _SYS_MSG_H
00002 #define _SYS_MSG_H
00003 
00004 /*
00005  * Copyright (C) 2001-2003 by Telogis.com. All rights reserved.
00006  *
00007  * Redistribution and use in source and binary forms, with or without
00008  * modification, are permitted provided that the following conditions
00009  * are met:
00010  *
00011  * 1. Redistributions of source code must retain the above copyright
00012  *    notice, this list of conditions and the following disclaimer.
00013  * 2. Redistributions in binary form must reproduce the above copyright
00014  *    notice, this list of conditions and the following disclaimer in the
00015  *    documentation and/or other materials provided with the distribution.
00016  * 3. Neither the name of the copyright holders nor the names of
00017  *    contributors may be used to endorse or promote products derived
00018  *    from this software without specific prior written permission.
00019  *
00020  * THIS SOFTWARE IS PROVIDED BY EGNITE SOFTWARE GMBH AND CONTRIBUTORS
00021  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00022  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00023  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL EGNITE
00024  * SOFTWARE GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00025  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00026  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
00027  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
00028  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
00029  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
00030  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
00031  * SUCH DAMAGE.
00032  *
00033  * For additional information see http://www.ethernut.de/
00034  *
00035  * This code was kindly provided by Ralph Mason.
00036  *
00037  */
00038 
00039 /*
00040  * $Log$
00041  * Revision 1.3  2008/08/11 07:00:25  haraldkipp
00042  * BSD types replaced by stdint types (feature request #1282721).
00043  *
00044  * Revision 1.2  2004/03/08 11:20:36  haraldkipp
00045  * Not all compilers like arrays of size zero.
00046  *
00047  * Revision 1.1  2004/02/04 18:05:04  drsung
00048  * First version of message queueing  implemented. Thanks to Ralph Mason, who provided this code.
00049  * Still contains some debug functions.
00050  *
00051  */
00052 
00053 #include <sys/timer.h>
00054 #include <stdint.h>
00055 
00056 #ifdef _PC
00057 #pragma warning (disable:4200)
00058 #endif
00059 
00060 typedef struct _NUTMSG NUTMSG;
00061 struct _NUTMSG {
00062     uint8_t id;
00063     int param;
00064     void *data;
00065 };
00066 
00067 typedef struct _NUTMSGTMR NUTMSGTMR;
00068 struct _NUTMSGTMR;
00069 
00070 typedef struct _NUTMSGQ NUTMSGQ;
00071 struct _NUTMSGQ {
00072     HANDLE mq_wait;             /* Wait for a message */
00073     NUTMSGTMR *mq_timers;
00074     NUTMSGQ *mq_next;
00075     uint8_t mq_read;
00076     uint8_t mq_write;
00077     uint8_t mq_mask;
00078     NUTMSG mq_que[1];
00079 };
00080 
00081 
00082 extern NUTMSGQ *NutMsgQCreate(uint8_t len);
00083 extern int NutMsgQBroadcast(uint8_t id, int param, void *data);
00084 extern int NutMsgQPost(NUTMSGQ * que, uint8_t id, int param, void *data);
00085 extern int NutMsgQSend(NUTMSGQ * que, uint8_t id, int param, void *data);
00086 extern int NutMsgQGetMessage(NUTMSGQ * que, NUTMSG * msg, uint32_t timeout);
00087 extern int NutMsgQFull(NUTMSGQ * que);
00088 extern void NutMsgQFlush(NUTMSGQ * que);
00089 extern HANDLE NutMsgQStartTimer(NUTMSGQ * que, uint32_t ms, int param, void *data, uint8_t flags);
00090 extern void NutMsgQStopTimer(HANDLE timer);
00091 
00092 #define MSG_TIMER       0xfe
00093 #define MSG_NULL        0xff
00094 
00095 #endif