00001 #ifndef _SYS_THREAD_H_ 00002 #define _SYS_THREAD_H_ 00003 00004 /* 00005 * Copyright (C) 2001-2002 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. All advertising materials mentioning features or use of this 00017 * software must display the following acknowledgement: 00018 * 00019 * This product includes software developed by egnite Software GmbH 00020 * and its contributors. 00021 * 00022 * THIS SOFTWARE IS PROVIDED BY EGNITE SOFTWARE GMBH AND CONTRIBUTORS 00023 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 00024 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 00025 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL EGNITE 00026 * SOFTWARE GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 00027 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 00028 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 00029 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 00030 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 00031 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 00032 * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 00033 * SUCH DAMAGE. 00034 * 00035 * For additional information see http://www.ethernut.de/ 00036 * 00037 * - 00038 * Portions Copyright (C) 2000 David J. Hudson <dave@humbug.demon.co.uk> 00039 * 00040 * This file is distributed in the hope that it will be useful, but WITHOUT 00041 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 00042 * FITNESS FOR A PARTICULAR PURPOSE. 00043 * 00044 * You can redistribute this file and/or modify it under the terms of the GNU 00045 * General Public License (GPL) as published by the Free Software Foundation; 00046 * either version 2 of the License, or (at your discretion) any later version. 00047 * See the accompanying file "copying-gpl.txt" for more details. 00048 * 00049 * As a special exception to the GPL, permission is granted for additional 00050 * uses of the text contained in this file. See the accompanying file 00051 * "copying-liquorice.txt" for details. 00052 */ 00053 00054 /* 00055 * $Log: thread.h,v $ 00056 * Revision 1.2 2003/01/24 12:01:12 przemko 00057 * Obciecie dosowych znakow konca lini 00058 * 00059 * Revision 1.1.1.1 2002/12/07 07:16:52 marwi 00060 * 00061 * 00062 * Revision 1.13 2002/10/29 15:40:50 harald 00063 * *** empty log message *** 00064 * 00065 * Revision 1.12 2002/06/26 17:29:29 harald 00066 * First pre-release with 2.4 stack 00067 * 00068 */ 00069 00070 #include <sys/device.h> 00071 00077 #define DEADBEEF 0xDEADBEEF 00078 00079 00084 00088 typedef struct _NUTTHREADINFO NUTTHREADINFO; 00089 00094 struct _NUTTHREADINFO { 00095 NUTTHREADINFO *volatile td_next; 00096 NUTTHREADINFO *td_qnxt; 00097 u_char td_name[9]; 00098 u_char td_state; 00099 u_short td_sp; 00100 u_char td_priority; 00101 u_char *td_memory; 00102 HANDLE td_timer; 00103 HANDLE td_queue; 00104 }; 00111 #define TDS_TERM 0 00112 #define TDS_RUNNING 1 00113 #define TDS_READY 2 00114 #define TDS_SLEEP 3 00116 00117 00118 extern NUTTHREADINFO* volatile runningThread; 00119 extern NUTTHREADINFO* volatile nutThreadList; 00120 extern NUTTHREADINFO * volatile runQueue; 00121 00122 00123 00124 extern HANDLE NutThreadCreate(u_char *name, void (*fn)(void *), void *arg, u_short stackSize); 00125 extern u_char NutThreadSetPriority(u_char level); 00126 00127 extern void NutThreadResumeAsync(HANDLE th); 00128 extern void NutThreadWake(HANDLE timer, HANDLE th); 00129 extern void NutThreadYield(void); 00130 00131 extern void NutThreadAddPriQueue(NUTTHREADINFO *td, NUTTHREADINFO **tqpp); 00132 extern void NutThreadRemoveQueue(NUTTHREADINFO *td, NUTTHREADINFO *volatile *tqpp); 00133 00134 extern void NutThreadSwitch(void); 00135 extern HANDLE GetThreadByName(u_char *name); 00136 00140 #define THREAD(threadfn, arg) \ 00141 void threadfn(void *arg) __attribute__ ((noreturn)); \ 00142 void threadfn(void *arg) 00143 00144 extern void DumpThreads(HANDLE handle); 00145 00146 #endif