summaryrefslogtreecommitdiffstats
path: root/src/corelib/arch/arch.pri
diff options
context:
space:
mode:
authorBradley T. Hughes <bradley.hughes@nokia.com>2010-09-22 13:16:28 (GMT)
committerBradley T. Hughes <bradley.hughes@nokia.com>2010-09-23 09:21:21 (GMT)
commit82b4fff07dc21382274bc92e480a9eff897dabf1 (patch)
tree344f16f71baabf35e4536b6faf0dd5f38645f9dc /src/corelib/arch/arch.pri
parent6d1fb317f53017aee99ec191cc8740e7e668ba0e (diff)
downloadQt-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.pri1
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 \