jack1 codebase
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

77 lines
2.6KB

  1. // Low-level functions for atomic operations: Alpha version -*- C++ -*-
  2. // Copyright (C) 1999, 2000, 2001, 2003 Free Software Foundation, Inc.
  3. //
  4. // This file is part of the GNU ISO C++ Library. This library is free
  5. // software; you can redistribute it and/or modify it under the
  6. // terms of the GNU General Public License as published by the
  7. // Free Software Foundation; either version 2, or (at your option)
  8. // any later version.
  9. // This library is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU General Public License for more details.
  13. // You should have received a copy of the GNU General Public License along
  14. // with this library; see the file COPYING. If not, write to the Free
  15. // Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
  16. // USA.
  17. // As a special exception, you may use this file as part of a free software
  18. // library without restriction. Specifically, if other files instantiate
  19. // templates or use macros or inline functions from this file, or you compile
  20. // this file and link it with other files to produce an executable, this
  21. // file does not by itself cause the resulting executable to be covered by
  22. // the GNU General Public License. This exception does not however
  23. // invalidate any other reasons why the executable file might be covered by
  24. // the GNU General Public License.
  25. #ifndef _GLIBCXX_ATOMICITY_H
  26. #define _GLIBCXX_ATOMICITY_H 1
  27. /* @@@ With gas we can play nice .subsection games to get the
  28. non-predicted branch pointing forward. But Digital assemblers
  29. don't understand those directives. This isn't a terribly
  30. important issue, so just ignore it. */
  31. typedef int _Atomic_word;
  32. static inline _Atomic_word
  33. __attribute__ ((__unused__))
  34. __exchange_and_add(volatile _Atomic_word* __mem, int __val)
  35. {
  36. register int __result, __tmp;
  37. __asm__ __volatile__ (
  38. "\n$Lxadd_%=:\n\t"
  39. "ldl_l %0,%3\n\t"
  40. "addl %0,%4,%1\n\t"
  41. "stl_c %1,%2\n\t"
  42. "beq %1,$Lxadd_%=\n\t"
  43. "mb"
  44. : "=&r"(__result), "=&r"(__tmp), "=m"(*__mem)
  45. : "m" (*__mem), "r"(__val));
  46. return __result;
  47. }
  48. static inline void
  49. __attribute__ ((__unused__))
  50. __atomic_add(volatile _Atomic_word* __mem, int __val)
  51. {
  52. register _Atomic_word __result;
  53. __asm__ __volatile__ (
  54. "\n$Ladd_%=:\n\t"
  55. "ldl_l %0,%2\n\t"
  56. "addl %0,%3,%0\n\t"
  57. "stl_c %0,%1\n\t"
  58. "beq %0,$Ladd_%=\n\t"
  59. "mb"
  60. : "=&r"(__result), "=m"(*__mem)
  61. : "m" (*__mem), "r"(__val));
  62. }
  63. #endif /* atomicity.h */