From ebd7f69c417c11e488c59808748ac729ac7940df Mon Sep 17 00:00:00 2001 From: Joel Dice Date: Fri, 3 Aug 2012 20:00:27 -0600 Subject: [PATCH] fix a couple of QNX/ARM issues On QNX, we need to use msync to sync the instruction cache. Also, even though the compiler doesn't define __SOFTFP__, QNX uses the softfp ABI on ARM. --- src/arm.S | 4 ++-- src/arm.h | 9 ++++++++- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/src/arm.S b/src/arm.S index e62c0a60e0..01d0839079 100644 --- a/src/arm.S +++ b/src/arm.S @@ -57,7 +57,7 @@ LOCAL(loop): // setup argument registers if necessary tst r6, r6 ldmneia r6, {r0-r3} -#if defined(__VFP_FP__) && (! defined(__SOFTFP__)) +#if defined(__VFP_FP__) && (! defined(__SOFTFP__)) && (! defined(__QNX__)) // and VFP registers vldmia r7, {d0-d7} #endif @@ -65,7 +65,7 @@ LOCAL(loop): blx r4 // call function add sp, sp, r5 // deallocate stack -#if defined(__VFP_FP__) && (! defined(__SOFTFP__)) +#if defined(__VFP_FP__) && (! defined(__SOFTFP__)) && (! defined(__QNX__)) cmp r8,#FLOAT_TYPE bne LOCAL(double) fmrs r0,s0 diff --git a/src/arm.h b/src/arm.h index 8be28f5bb2..8ae057d610 100644 --- a/src/arm.h +++ b/src/arm.h @@ -45,6 +45,9 @@ # define LINK_REGISTER(context) \ THREAD_STATE_LINK(context->uc_mcontext->FIELD(ss)) #elif (defined __QNX__) +# include "arm/smpxchg.h" +# include "sys/mman.h" + # define IP_REGISTER(context) (context->uc_mcontext.cpu.gpr[ARM_REG_PC]) # define STACK_REGISTER(context) (context->uc_mcontext.cpu.gpr[ARM_REG_SP]) # define THREAD_REGISTER(context) (context->uc_mcontext.cpu.gpr[ARM_REG_IP]) @@ -100,6 +103,8 @@ syncInstructionCache(const void* start, unsigned size) { #ifdef __APPLE__ sys_icache_invalidate(const_cast(start), size); +#elif (defined __QNX__) + msync(const_cast(start), size, MS_INVALIDATE_ICACHE); #else __clear_cache (const_cast(start), @@ -117,6 +122,8 @@ atomicCompareAndSwap32(uint32_t* p, uint32_t old, uint32_t new_) { #ifdef __APPLE__ return OSAtomicCompareAndSwap32(old, new_, reinterpret_cast(p)); +#elif (defined __QNX__) + return old == _smp_cmpxchg(p, old, new_); #else int r = __kernel_cmpxchg(static_cast(old), static_cast(new_), reinterpret_cast(p)); return (!r ? true : false); @@ -156,7 +163,7 @@ dynamicCall(void* function, uintptr_t* arguments, uint8_t* argumentTypes, for (unsigned ati = 0; ati < argumentCount; ++ ati) { switch (argumentTypes[ati]) { case DOUBLE_TYPE: -#if (defined(__VFP_FP__) && !defined(__SOFTFP__)) +#if (defined(__VFP_FP__) && !defined(__SOFTFP__)) && !defined(__QNX__) { if (vfpIndex + Alignment <= VfpCount) { if (vfpIndex % Alignment) {