atom.h 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. /*
  2. * Copyright (C) 2001-2005 by egnite Software GmbH. All rights reserved.
  3. *
  4. * Redistribution and use in source and binary forms, with or without
  5. * modification, are permitted provided that the following conditions
  6. * are met:
  7. *
  8. * 1. Redistributions of source code must retain the above copyright
  9. * notice, this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright
  11. * notice, this list of conditions and the following disclaimer in the
  12. * documentation and/or other materials provided with the distribution.
  13. * 3. Neither the name of the copyright holders nor the names of
  14. * contributors may be used to endorse or promote products derived
  15. * from this software without specific prior written permission.
  16. *
  17. * THIS SOFTWARE IS PROVIDED BY EGNITE SOFTWARE GMBH AND CONTRIBUTORS
  18. * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  19. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  20. * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL EGNITE
  21. * SOFTWARE GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
  22. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
  23. * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
  24. * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
  25. * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  26. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
  27. * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  28. * SUCH DAMAGE.
  29. *
  30. * For additional information see http://www.ethernut.de/
  31. *
  32. */
  33. /*
  34. * $Log: atom.h,v $
  35. * Revision 1.2 2006/01/26 15:34:49 going_nuts
  36. * adapted to new interrupt handling scheme for unix emulation
  37. * now uses Unix timer and runs without interrupts unless you emulate other hardware
  38. *
  39. * Revision 1.1 2005/06/06 10:49:35 haraldkipp
  40. * Building outside the source tree failed. All header files moved from
  41. * arch/cpu/include to include/arch/cpu.
  42. *
  43. * Revision 1.1 2005/05/27 17:41:52 drsung
  44. * Moved the file.
  45. *
  46. * Revision 1.1 2005/05/26 10:08:42 drsung
  47. * Moved the platform dependend code from include/sys/atom.h to this file.
  48. *
  49. *
  50. */
  51. #ifndef _SYS_ATOM_H_
  52. #error "Do not include this file directly. Use sys/atom.h instead!"
  53. #endif
  54. __BEGIN_DECLS
  55. #include <pthread.h>
  56. #include <signal.h>
  57. #include <sys/thread.h>
  58. #include <stdio.h>
  59. #include <stdlib.h>
  60. extern u_short main_cs_level;
  61. extern sigset_t irq_signal;
  62. extern pthread_cond_t irq_cv;
  63. extern u_short int_disabled;
  64. extern FILE *__os_trs;
  65. extern u_char __os_trf;
  66. #define AtomicInc(p) (++(*p))
  67. #define AtomicDec(p) (--(*p))
  68. extern void NutExitCritical(void);
  69. extern void NutEnterCritical(void);
  70. // uncommenting the following causes a segmentation fault because stdout isn't defined at startup.
  71. // #define CRITSECT_TRACE
  72. #ifndef CRITSECT_TRACE
  73. #define NutEnterCritical() \
  74. pthread_sigmask(SIG_BLOCK, &irq_signal, 0); \
  75. int_disabled = 1; \
  76. if (runningThread) { \
  77. runningThread->td_cs_level++; \
  78. } else { \
  79. main_cs_level++; \
  80. } \
  81. pthread_sigmask(SIG_UNBLOCK, &irq_signal, 0);
  82. #define NutExitCritical() \
  83. pthread_sigmask(SIG_BLOCK, &irq_signal, 0); \
  84. if (runningThread) { \
  85. if (--runningThread->td_cs_level == 0) { \
  86. int_disabled = 0; \
  87. pthread_cond_signal(&irq_cv); \
  88. } \
  89. } else { \
  90. if (--main_cs_level == 0) { \
  91. int_disabled = 0; \
  92. pthread_cond_signal(&irq_cv); \
  93. } \
  94. } \
  95. pthread_sigmask(SIG_UNBLOCK, &irq_signal, 0);
  96. #else
  97. #define NutEnterCritical() \
  98. pthread_sigmask(SIG_BLOCK, &irq_signal, 0); \
  99. int_disabled = 1; \
  100. if (runningThread) { \
  101. if (runningThread->td_cs_level==0) \
  102. printf("Entered a: %s.%d - %s\n", __FILE__, __LINE__, runningThread->td_name); \
  103. runningThread->td_cs_level++; \
  104. } else { \
  105. if (main_cs_level==0) \
  106. printf("Entered b: %s.%d - %s\n", __FILE__, __LINE__, "ROOT"); \
  107. main_cs_level++; \
  108. } \
  109. pthread_sigmask(SIG_UNBLOCK, &irq_signal, 0);
  110. #define NutExitCritical() \
  111. pthread_sigmask(SIG_BLOCK, &irq_signal, 0); \
  112. if (runningThread) { \
  113. if (--runningThread->td_cs_level == 0) { \
  114. int_disabled = 0; \
  115. printf("Left a: %s.%d - %s\n", __FILE__, __LINE__, runningThread->td_name); \
  116. pthread_cond_signal(&irq_cv); \
  117. } \
  118. } else { \
  119. if (--main_cs_level == 0) { \
  120. int_disabled = 0; \
  121. printf("Left a: %s.%d - %s\n", __FILE__, __LINE__, "ROOT"); \
  122. pthread_cond_signal(&irq_cv); \
  123. } \
  124. } \
  125. pthread_sigmask(SIG_UNBLOCK, &irq_signal, 0);
  126. #endif
  127. #define NutJumpOutCritical() NutExitCritical()
  128. __END_DECLS