diff options
author | Bradley T. Hughes <bradley.hughes@nokia.com> | 2010-09-22 13:16:28 (GMT) |
---|---|---|
committer | Bradley T. Hughes <bradley.hughes@nokia.com> | 2010-09-23 09:21:21 (GMT) |
commit | 82b4fff07dc21382274bc92e480a9eff897dabf1 (patch) | |
tree | 344f16f71baabf35e4536b6faf0dd5f38645f9dc /src/corelib/arch/arch.pri | |
parent | 6d1fb317f53017aee99ec191cc8740e7e668ba0e (diff) | |
download | Qt-82b4fff07dc21382274bc92e480a9eff897dabf1.zip Qt-82b4fff07dc21382274bc92e480a9eff897dabf1.tar.gz Qt-82b4fff07dc21382274bc92e480a9eff897dabf1.tar.bz2 |
Add support for ARMv7 atomic operations
ARMv7 adds the DMB (data memory barrier) instruction which we can use to
enforce memory barriers in QAtomicInt and QAtomicPointer. Other than
that, ARMv7 is identical to ARMv6.
Adjust the ARMv6 code to relax the compiler memory barriers on the
*Relaxed() operations, and use *Relaxed() functions together the
appropriate compiler barriers in the *Acquire(), *Release(), and
*Ordered() functions. For "pure" ARMv6 code, the barriers are only
compiler barriers, but for ARMv7, we also emit the DMB instruction.
Reviewed-by: thiago
Diffstat (limited to 'src/corelib/arch/arch.pri')
-rw-r--r-- | src/corelib/arch/arch.pri | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/src/corelib/arch/arch.pri b/src/corelib/arch/arch.pri index 046ecdf..971069f 100644 --- a/src/corelib/arch/arch.pri +++ b/src/corelib/arch/arch.pri @@ -23,6 +23,7 @@ vxworks:HEADERS += arch/qatomic_vxworks.h arch/qatomic_arm.h \ arch/qatomic_armv5.h \ arch/qatomic_armv6.h \ + arch/qatomic_armv7.h \ arch/qatomic_i386.h \ arch/qatomic_mips.h \ arch/qatomic_s390.h \ |