1 --- uClibc-0.9.27/libc/sysdeps/linux/arm/bits/atomicity.h.orig 2005-08-09 13:12:59.663734027 -0700
2 +++ uClibc-0.9.27/libc/sysdeps/linux/arm/bits/atomicity.h 2005-08-09 17:54:14.581605661 -0700
7 +#if defined(__thumb__)
13 "0:\tldr\t%0,[%3]\n\t"
17 "swpne\t%1,%2,[%3]\n\t"
19 +#if defined(__thumb__)
20 + "\torr %1, pc, #1\n"
24 : "=&r" (result), "=&r" (tmp1), "=&r" (tmp2)
31 +#if defined(__thumb__)
37 "0:\tldr\t%0,[%3]\n\t"
41 "swpne\t%1,%2,[%3]\n\t"
43 +#if defined(__thumb__)
44 + "\torr %1, pc, #1\n"
48 : "=&r" (tmp1), "=&r" (tmp2), "=&r" (tmp3)
55 +#if defined(__thumb__)
61 "0:\tldr\t%1,[%2]\n\t"
68 +#if defined(__thumb__)
69 + "\torr %1, pc, #1\n"
73 : "=&r" (result), "=&r" (tmp)
74 : "r" (p), "r" (newval), "r" (oldval)
76 --- uClibc-0.9.27/libpthread/linuxthreads/sysdeps/arm/pt-machine.h.orig 2005-08-09 14:16:50.204774778 -0700
77 +++ uClibc-0.9.27/libpthread/linuxthreads/sysdeps/arm/pt-machine.h 2005-08-09 17:55:54.027863420 -0700
80 register unsigned int ret;
82 +#if defined(__thumb__)
84 + __asm__ __volatile__(
89 + "\tswp %0, %2, [%3]\n"
90 + "\torr %1, pc, #1\n"
93 + : "=r"(ret), "=r"(pc)
94 + : "0"(1), "r"(spinlock));
96 __asm__ __volatile__("swp %0, %1, [%2]"
98 : "0"(1), "r"(spinlock));