Nut/OS  5.0.5
API Reference
thread.h
Go to the documentation of this file.
00001 #ifndef _SYS_THREAD_H_
00002 #define _SYS_THREAD_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 THE COPYRIGHT HOLDERS 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 THE
00024  * COPYRIGHT OWNER 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 
00059 #include <compiler.h>
00060 #include <sys/types.h>
00061 #include <cfg/memory.h>
00062 
00063 #include <stdint.h>
00064 
00065 #define DEADBEEF    0xDEADBEEF
00066 
00138 
00142 typedef struct _NUTTHREADINFO NUTTHREADINFO;
00143 
00150 struct _NUTTHREADINFO {
00151     NUTTHREADINFO *td_next;     
00152     NUTTHREADINFO *td_qnxt;     
00153     volatile unsigned int td_qpec;     
00154     char td_name[9];            
00155     uint8_t td_state;            
00156     uintptr_t td_sp;               
00157     uint8_t td_priority;         
00158     uint8_t *td_memory;          
00159     HANDLE td_timer;            
00160     volatile HANDLE td_queue;   
00161 #ifdef __NUT_EMULATION__
00162     pthread_t td_pthread;       
00163     void (*td_fn) (void *);     
00164     void *td_arg;               
00165     pthread_cond_t td_cv;       
00166     uint16_t td_cs_level;        
00167 #endif
00168 };
00169 
00174 #define TDS_TERM        0       
00175 #define TDS_RUNNING     1       
00176 #define TDS_READY       2       
00177 #define TDS_SLEEP       3       
00179 
00180 #define SLEEP_MODE_NONE 0xff
00181 
00206 #ifndef NUT_THREAD_STACK_MULT
00207 #define NUT_THREAD_STACK_MULT   1
00208 #endif
00209 
00217 #ifndef NUT_THREAD_STACK_ADD
00218 #define NUT_THREAD_STACK_ADD    0
00219 #endif
00220 
00227 extern NUTTHREADINFO *runningThread;
00228 
00237 extern NUTTHREADINFO *nutThreadList;
00238 
00246 extern NUTTHREADINFO *runQueue;
00247 
00248 #ifndef __NUT_EMULATION__
00249 
00255 extern void NutThreadInit(void);
00256 #endif
00257 
00258 #if defined(__GNUC__) && defined (__AVR_ENHANCED__)
00259 extern uint8_t NutThreadSetSleepMode(uint8_t mode);
00260 #endif
00261 
00262 
00284 extern HANDLE NutThreadCreate(char *name, void (*fn) (void *), void *arg, size_t stackSize);
00285 
00313 extern uint8_t NutThreadSetPriority(uint8_t level);
00314 
00322 extern void NutThreadKill(void);
00323 
00333 extern void NutThreadDestroy(void);
00334 
00345 extern void NutThreadExit(void);
00346 
00358 extern void NutThreadResume(void);
00359 
00378 extern void NutThreadWake(HANDLE timer, HANDLE th);
00379 
00388 extern void NutThreadYield(void);
00389 
00401 extern void NutThreadAddPriQueue(NUTTHREADINFO * td, NUTTHREADINFO * volatile *tqpp);
00402 
00414 extern void NutThreadRemoveQueue(NUTTHREADINFO * td, NUTTHREADINFO * volatile *tqpp);
00415 
00428 extern void NutThreadSwitch(void);
00429 
00439 extern HANDLE GetThreadByName(char *name);
00440 
00452 extern NUTTHREADINFO *NutThreadStackCheck(size_t minsiz);
00453 
00475 extern size_t NutThreadStackAvailable(char *name);
00476 
00480 #define THREAD(threadfn, arg) \
00481 void threadfn(void *arg) __attribute__ ((noreturn)); \
00482 void threadfn(void *arg)
00483 
00486 #endif