[U-Boot] strex/ldrex compilation error while using atomic_inc u-boot
akshay ts
takshays at yahoo.co.in
Mon Nov 2 09:26:53 CET 2009
Hi all,
I am getting the following error while building using ARMV7 toolchain.
{standard input}:599: Error: selected processor does not support `ldrex r1,[r2]'
{standard input}:601: Error: selected processor does not support `strex r3,r1,[r2]'
For example the following code uses strex and ldrex but it is not specified which register to use.
atomic_inc in turn uses ->
static inline int atomic_add_return(int i, atomic_t *v)
{
unsigned long tmp;
int result;
__asm__ __volatile__("@ atomic_add_return\n"
"1: ldrex %0, [%2]\n"
" add %0, %0, %3\n"
" strex %1, %0, [%2]\n"
" teq %1, #0\n"
" bne 1b"
: "=&r" (result), "=&r" (tmp)
: "r" (&v->counter), "Ir" (i)
: "cc");
return result;
}
According to arm architecture reference manual strex/ldrex are valid for ARMV6 and above.
The above code i copied from kernel and it is building in kernel.
I dont know how to solve this issue Any toolchain specific CFLAGS/attributes i need to set/unset. Please Help
Warm Regards,
Akshay
Yahoo! India has a new look. Take a sneak peek http://in.yahoo.com/trynew
More information about the U-Boot
mailing list