1 | /* |
1 | /* |
2 | * libecb - http://software.schmorp.de/pkg/libecb |
2 | * libecb - http://software.schmorp.de/pkg/libecb |
3 | * |
3 | * |
4 | * Copyright (©) 2009-2013 Marc Alexander Lehmann <libecb@schmorp.de> |
4 | * Copyright (©) 2009-2014 Marc Alexander Lehmann <libecb@schmorp.de> |
5 | * Copyright (©) 2011 Emanuele Giaquinta |
5 | * Copyright (©) 2011 Emanuele Giaquinta |
6 | * All rights reserved. |
6 | * All rights reserved. |
7 | * |
7 | * |
8 | * Redistribution and use in source and binary forms, with or without modifica- |
8 | * Redistribution and use in source and binary forms, with or without modifica- |
9 | * tion, are permitted provided that the following conditions are met: |
9 | * tion, are permitted provided that the following conditions are met: |
… | |
… | |
142 | || defined __ARM_ARCH_6K__ || defined __ARM_ARCH_6ZK__ |
142 | || defined __ARM_ARCH_6K__ || defined __ARM_ARCH_6ZK__ |
143 | #define ECB_MEMORY_FENCE __asm__ __volatile__ ("mcr p15,0,%0,c7,c10,5" : : "r" (0) : "memory") |
143 | #define ECB_MEMORY_FENCE __asm__ __volatile__ ("mcr p15,0,%0,c7,c10,5" : : "r" (0) : "memory") |
144 | #elif defined __ARM_ARCH_7__ || defined __ARM_ARCH_7A__ \ |
144 | #elif defined __ARM_ARCH_7__ || defined __ARM_ARCH_7A__ \ |
145 | || defined __ARM_ARCH_7M__ || defined __ARM_ARCH_7R__ |
145 | || defined __ARM_ARCH_7M__ || defined __ARM_ARCH_7R__ |
146 | #define ECB_MEMORY_FENCE __asm__ __volatile__ ("dmb" : : : "memory") |
146 | #define ECB_MEMORY_FENCE __asm__ __volatile__ ("dmb" : : : "memory") |
|
|
147 | #elif __aarch64__ |
|
|
148 | #define ECB_MEMORY_FENCE __asm__ __volatile__ ("dmb ish" : : : "memory") |
147 | #elif (__sparc || __sparc__) && !__sparcv8 |
149 | #elif (__sparc || __sparc__) && !__sparcv8 |
148 | #define ECB_MEMORY_FENCE __asm__ __volatile__ ("membar #LoadStore | #LoadLoad | #StoreStore | #StoreLoad" : : : "memory") |
150 | #define ECB_MEMORY_FENCE __asm__ __volatile__ ("membar #LoadStore | #LoadLoad | #StoreStore | #StoreLoad" : : : "memory") |
149 | #define ECB_MEMORY_FENCE_ACQUIRE __asm__ __volatile__ ("membar #LoadStore | #LoadLoad" : : : "memory") |
151 | #define ECB_MEMORY_FENCE_ACQUIRE __asm__ __volatile__ ("membar #LoadStore | #LoadLoad" : : : "memory") |
150 | #define ECB_MEMORY_FENCE_RELEASE __asm__ __volatile__ ("membar #LoadStore | #StoreStore") |
152 | #define ECB_MEMORY_FENCE_RELEASE __asm__ __volatile__ ("membar #LoadStore | #StoreStore") |
151 | #elif defined __s390__ || defined __s390x__ |
153 | #elif defined __s390__ || defined __s390x__ |
… | |
… | |
592 | /* the only noteworthy exception is ancient armle, which uses order 43218765 */ |
594 | /* the only noteworthy exception is ancient armle, which uses order 43218765 */ |
593 | #if 0 \ |
595 | #if 0 \ |
594 | || __i386 || __i386__ \ |
596 | || __i386 || __i386__ \ |
595 | || __amd64 || __amd64__ || __x86_64 || __x86_64__ \ |
597 | || __amd64 || __amd64__ || __x86_64 || __x86_64__ \ |
596 | || __powerpc__ || __ppc__ || __powerpc64__ || __ppc64__ \ |
598 | || __powerpc__ || __ppc__ || __powerpc64__ || __ppc64__ \ |
597 | || defined __arm__ && defined __ARM_EABI__ \ |
|
|
598 | || defined __s390__ || defined __s390x__ \ |
599 | || defined __s390__ || defined __s390x__ \ |
599 | || defined __mips__ \ |
600 | || defined __mips__ \ |
600 | || defined __alpha__ \ |
601 | || defined __alpha__ \ |
601 | || defined __hppa__ \ |
602 | || defined __hppa__ \ |
602 | || defined __ia64__ \ |
603 | || defined __ia64__ \ |
603 | || defined __m68k__ \ |
604 | || defined __m68k__ \ |
604 | || defined __m88k__ \ |
605 | || defined __m88k__ \ |
605 | || defined __sh__ \ |
606 | || defined __sh__ \ |
606 | || defined _M_IX86 || defined _M_AMD64 || defined _M_IA64 |
607 | || defined _M_IX86 || defined _M_AMD64 || defined _M_IA64 \ |
|
|
608 | || (defined __arm__ && (defined __ARM_EABI__ || defined __EABI__ || defined __VFP_FP__ || defined _WIN32_WCE || defined __ANDROID__)) \ |
|
|
609 | || defined __aarch64__ |
607 | #define ECB_STDFP 1 |
610 | #define ECB_STDFP 1 |
608 | #include <string.h> /* for memcpy */ |
611 | #include <string.h> /* for memcpy */ |
609 | #else |
612 | #else |
610 | #define ECB_STDFP 0 |
613 | #define ECB_STDFP 0 |
611 | #endif |
614 | #endif |