Main Page   Modules   Data Structures   File List   Data Fields   Globals   Related Pages   Examples  

atom.h

00001 #ifndef _SYS_ATOM_H_
00002 #define _SYS_ATOM_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 
00039 /*
00040  * $Log: atom.h,v $
00041  * Revision 1.2  2003/01/24 12:01:11  przemko
00042  * Obciecie dosowych znakow konca lini
00043  *
00044  * Revision 1.1.1.1  2002/12/07 07:16:52  marwi
00045  *
00046  *
00047  * Revision 1.4  2002/06/26 17:29:28  harald
00048  * First pre-release with 2.4 stack
00049  *
00050  */
00051 
00052 #include <sys/types.h>
00053 
00054 #ifdef __IMAGECRAFT__
00055 
00056 #define AtomicInc(p)     (++(*p))
00057 #define AtomicDec(p)     (--(*p))
00058 
00059 #else
00060 
00061 static inline void AtomicInc(volatile u_char *p)
00062 {
00063     asm volatile(
00064         "in  __tmp_reg__, __SREG__" "\n\t"
00065         "cli"                       "\n\t"
00066         "ld r24, %a0"               "\n\t"
00067         "subi r24, lo8(-1)"         "\n\t"
00068         "st %a0, r24"               "\n\t"
00069         "out __SREG__, __tmp_reg__" "\n\t"
00070         :
00071         : "z" (p)
00072         : "r24"
00073     );
00074 }
00075 
00076 static inline void AtomicDec(volatile u_char *p)
00077 {
00078     asm volatile(
00079         "in  __tmp_reg__, __SREG__" "\n\t"
00080         "cli"                       "\n\t"
00081         "ld r24, %a0"               "\n\t"
00082         "subi r24, lo8(1)"          "\n\t"
00083         "st %a0, r24"               "\n\t"
00084         "out __SREG__, __tmp_reg__" "\n\t"
00085         :
00086         : "z" (p)
00087         : "r24"
00088     );
00089 }
00090 
00091 #endif
00092 
00093 
00094 #ifdef __IMAGECRAFT__
00095 
00096 #define NutEnterCritical()  \
00097 {                           \
00098     asm("in R0, 0x3F\n"     \
00099         "push R0\n"         \
00100         "cli\n");           \
00101 }
00102 
00103 #define NutExitCritical()   \
00104 {                           \
00105     asm("pop R0\n"          \
00106         "out 0x3F, R0\n");  \
00107 }
00108 
00109 #else
00110 
00111 static inline void NutEnterCritical(void)
00112 {
00113     asm volatile(
00114         "in  __tmp_reg__, __SREG__" "\n\t"
00115         "push __tmp_reg__"          "\n\t"
00116         "cli"                       "\n\t"
00117     );
00118 }
00119 
00120 static inline void NutExitCritical(void)
00121 {
00122     asm volatile(
00123         "pop __tmp_reg__"           "\n\t"
00124         "out __SREG__, __tmp_reg__" "\n\t"
00125     );
00126 }
00127 
00128 #endif
00129 
00130 
00131 #endif

Generated on Thu Jan 30 22:30:44 2003 for EduNet by doxygen1.2.18