Nut/OS  4.10.3
API Reference
event.h
Go to the documentation of this file.
00001 #ifndef _SYS_EVENT_H_
00002 #define _SYS_EVENT_H_
00003 
00004 /*
00005  * Copyright (C) 2001-2006 by egnite Software GmbH. 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  * -
00036  * Portions Copyright (C) 2000 David J. Hudson <dave@humbug.demon.co.uk>
00037  *
00038  * This file is distributed in the hope that it will be useful, but WITHOUT
00039  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
00040  * FITNESS FOR A PARTICULAR PURPOSE.
00041  *
00042  * You can redistribute this file and/or modify it under the terms of the GNU
00043  * General Public License (GPL) as published by the Free Software Foundation;
00044  * either version 2 of the License, or (at your discretion) any later version.
00045  * See the accompanying file "copying-gpl.txt" for more details.
00046  *
00047  * As a special exception to the GPL, permission is granted for additional
00048  * uses of the text contained in this file.  See the accompanying file
00049  * "copying-liquorice.txt" for details.
00050  */
00051 
00052 /*
00053  * $Log$
00054  * Revision 1.9  2008/08/11 07:00:25  haraldkipp
00055  * BSD types replaced by stdint types (feature request #1282721).
00056  *
00057  * Revision 1.8  2006/10/08 16:48:22  haraldkipp
00058  * Documentation fixed
00059  *
00060  * Revision 1.7  2006/08/01 07:39:12  haraldkipp
00061  * Missing typecast in NutEventPostFromIrq() fixed. Thanks to Matthias Wilde.
00062  *
00063  * Revision 1.6  2006/06/28 14:34:02  haraldkipp
00064  * Event/thread/timer re-design.
00065  * A new macro NutEventPostFromIrq() replaces the routine with the same name.
00066  * In opposite to the previous routine, no result will be returned by this
00067  * macro, which may break your existing code.
00068  * The SIGNALED definition had been replaced by a less platform dependent
00069  * variant.
00070  *
00071  * Revision 1.5  2005/01/24 21:11:46  freckle
00072  * renamed NutEventPostFromIRQ into NutEventPostFromIrq
00073  *
00074  * Revision 1.4  2005/01/21 16:49:44  freckle
00075  * Seperated calls to NutEventPostAsync between Threads and IRQs
00076  *
00077  * Revision 1.3  2004/03/16 16:48:44  haraldkipp
00078  * Added Jan Dubiec's H8/300 port.
00079  *
00080  * Revision 1.2  2003/07/20 18:28:54  haraldkipp
00081  * Explain how to disable timeout.
00082  *
00083  * Revision 1.1.1.1  2003/05/09 14:41:19  haraldkipp
00084  * Initial using 3.2.1
00085  *
00086  * Revision 1.8  2003/02/04 18:00:52  harald
00087  * Version 3 released
00088  *
00089  * Revision 1.7  2003/01/14 16:37:58  harald
00090  * Return number of woken up threads
00091  *
00092  * Revision 1.6  2002/06/26 17:29:28  harald
00093  * First pre-release with 2.4 stack
00094  *
00095  */
00096 
00097 #include <sys/thread.h>
00098 
00108 
00120 #define SIGNALED    ((void *)-1)
00121 
00128 #define NUT_WAIT_INFINITE   0
00129 
00147 #define NutEventPostFromIrq(qp)     \
00148 {                                   \
00149     if (*qp == 0) {                 \
00150         *qp = SIGNALED;             \
00151     }                               \
00152     else if (*qp != SIGNALED) {     \
00153         NUTTHREADINFO *tp = (NUTTHREADINFO *)(*qp);    \
00154         tp->td_qpec++;              \
00155     }                               \
00156 }
00157 
00160 __BEGIN_DECLS
00161 /* Function prototypes. */
00162 
00163 extern void NutEventTimeout(HANDLE timer, void *arg);
00164 
00165 extern int NutEventWait(volatile HANDLE *qhp, uint32_t ms);
00166 extern int NutEventWaitNext(volatile HANDLE *qhp, uint32_t ms);
00167 extern int NutEventPostAsync(volatile HANDLE *qhp);
00168 extern int NutEventPost(volatile HANDLE *qhp);
00169 extern int NutEventBroadcastAsync(volatile HANDLE *qhp);
00170 extern int NutEventBroadcast(volatile HANDLE *qhp);
00171 
00172 __END_DECLS
00173 /* */
00174 
00175 #endif