Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056 #ifndef _SYS_ATOM_H_
00057 #error "Do not include this file directly. Use sys/atom.h instead!"
00058 #endif
00059
00060 #include <pthread.h>
00061 #include <signal.h>
00062 #include <sys/thread.h>
00063 #include <stdio.h>
00064 #include <stdlib.h>
00065
00066 extern uint16_t main_cs_level;
00067 extern sigset_t irq_signal;
00068 extern pthread_cond_t irq_cv;
00069 extern uint16_t int_disabled;
00070
00071 extern FILE *__os_trs;
00072 extern uint8_t __os_trf;
00073
00074 #define AtomicInc(p) (++(*p))
00075 #define AtomicDec(p) (--(*p))
00076
00077 extern void NutExitCritical(void);
00078 extern void NutEnterCritical(void);
00079
00080
00081
00082
00083
00084 #ifndef CRITSECT_TRACE
00085 #define NutEnterCritical() \
00086 pthread_sigmask(SIG_BLOCK, &irq_signal, 0); \
00087 int_disabled = 1; \
00088 if (runningThread) { \
00089 runningThread->td_cs_level++; \
00090 } else { \
00091 main_cs_level++; \
00092 } \
00093 pthread_sigmask(SIG_UNBLOCK, &irq_signal, 0);
00094
00095
00096 #define NutExitCritical() \
00097 pthread_sigmask(SIG_BLOCK, &irq_signal, 0); \
00098 if (runningThread) { \
00099 if (--runningThread->td_cs_level == 0) { \
00100 int_disabled = 0; \
00101 pthread_cond_signal(&irq_cv); \
00102 } \
00103 } else { \
00104 if (--main_cs_level == 0) { \
00105 int_disabled = 0; \
00106 pthread_cond_signal(&irq_cv); \
00107 } \
00108 } \
00109 pthread_sigmask(SIG_UNBLOCK, &irq_signal, 0);
00110
00111 #else
00112
00113 #define NutEnterCritical() \
00114 pthread_sigmask(SIG_BLOCK, &irq_signal, 0); \
00115 int_disabled = 1; \
00116 if (runningThread) { \
00117 if (runningThread->td_cs_level==0) \
00118 printf("Entered a: %s.%d - %s\n", __FILE__, __LINE__, runningThread->td_name); \
00119 runningThread->td_cs_level++; \
00120 } else { \
00121 if (main_cs_level==0) \
00122 printf("Entered b: %s.%d - %s\n", __FILE__, __LINE__, "ROOT"); \
00123 main_cs_level++; \
00124 } \
00125 pthread_sigmask(SIG_UNBLOCK, &irq_signal, 0);
00126
00127 #define NutExitCritical() \
00128 pthread_sigmask(SIG_BLOCK, &irq_signal, 0); \
00129 if (runningThread) { \
00130 if (--runningThread->td_cs_level == 0) { \
00131 int_disabled = 0; \
00132 printf("Left a: %s.%d - %s\n", __FILE__, __LINE__, runningThread->td_name); \
00133 pthread_cond_signal(&irq_cv); \
00134 } \
00135 } else { \
00136 if (--main_cs_level == 0) { \
00137 int_disabled = 0; \
00138 printf("Left a: %s.%d - %s\n", __FILE__, __LINE__, "ROOT"); \
00139 pthread_cond_signal(&irq_cv); \
00140 } \
00141 } \
00142 pthread_sigmask(SIG_UNBLOCK, &irq_signal, 0);
00143 #endif
00144
00145 #define NutJumpOutCritical() NutExitCritical()