Subversion Repositories Kolibri OS

Rev

Go to most recent revision | Blame | Last modification | View Log | RSS feed

  1. // Low-level type for atomic operations -*- C++ -*-
  2.  
  3. // Copyright (C) 2004-2013 Free Software Foundation, Inc.
  4. //
  5. // This file is part of the GNU ISO C++ Library.  This library is free
  6. // software; you can redistribute it and/or modify it under the
  7. // terms of the GNU General Public License as published by the
  8. // Free Software Foundation; either version 3, or (at your option)
  9. // any later version.
  10.  
  11. // This library is distributed in the hope that it will be useful,
  12. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  14. // GNU General Public License for more details.
  15.  
  16. // Under Section 7 of GPL version 3, you are granted additional
  17. // permissions described in the GCC Runtime Library Exception, version
  18. // 3.1, as published by the Free Software Foundation.
  19.  
  20. // You should have received a copy of the GNU General Public License and
  21. // a copy of the GCC Runtime Library Exception along with this program;
  22. // see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
  23. // <http://www.gnu.org/licenses/>.
  24.  
  25. /** @file atomic_word.h
  26.  *  This file is a GNU extension to the Standard C++ Library.
  27.  */
  28.  
  29. #ifndef _GLIBCXX_ATOMIC_WORD_H
  30. #define _GLIBCXX_ATOMIC_WORD_H  1
  31.  
  32. typedef int _Atomic_word;
  33.  
  34. // Define these two macros using the appropriate memory barrier for the target.
  35. // The commented out versions below are the defaults.
  36. // See ia64/atomic_word.h for an alternative approach.
  37.  
  38. // This one prevents loads from being hoisted across the barrier;
  39. // in other words, this is a Load-Load acquire barrier.
  40. // This is necessary iff TARGET_RELAXED_ORDERING is defined in tm.h.  
  41. // #define _GLIBCXX_READ_MEM_BARRIER __asm __volatile ("":::"memory")
  42.  
  43. // This one prevents stores from being sunk across the barrier; in other
  44. // words, a Store-Store release barrier.
  45. // #define _GLIBCXX_WRITE_MEM_BARRIER __asm __volatile ("":::"memory")
  46.  
  47. #endif
  48.