aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.9/gcc/testsuite/gcc.target/mips/20140928.c
blob: 1b55bdd357cd4fc233acccb743136215a1497f67 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
/* { dg-do compile } */

NOMIPS16 int NoBarrier_AtomicIncrement(volatile int* ptr, int increment) {
  int temp, temp2;
  __asm__ __volatile__(".set push\n"
                       ".set noreorder\n"
                       "1:\n"
                       "ll %0, 0(%3)\n"
                       "addu %1, %0, %2\n"
                       "sc %1, 0(%3)\n"
                       "beqz %1, 1b\n"
                       "nop\n"
                       "addu %1, %0, %2\n"
                       ".set pop\n"
                       : "=&r" (temp), "=&r" (temp2)
                       : "Ir" (increment), "r" (ptr)
                       : "memory");

  return temp2;
}