diff options
author | wilson <wilson@138bc75d-0d04-0410-961f-82ee72b054a4> | 2000-03-09 00:26:04 +0000 |
---|---|---|
committer | wilson <wilson@138bc75d-0d04-0410-961f-82ee72b054a4> | 2000-03-09 00:26:04 +0000 |
commit | ac445222719fb55c55fa5838c01217869e92b024 (patch) | |
tree | 4497d3e80c79da1bcf1a62991162605a8eb6a303 /gcc/config/ia64/ia64intrin.h | |
parent | 07c967f908bcefff491dd9200630d4428446c332 (diff) | |
download | gcc-ac445222719fb55c55fa5838c01217869e92b024.tar.gz |
Add ia64 port.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@32438 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/config/ia64/ia64intrin.h')
-rw-r--r-- | gcc/config/ia64/ia64intrin.h | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/gcc/config/ia64/ia64intrin.h b/gcc/config/ia64/ia64intrin.h new file mode 100644 index 00000000000..c75f18504d8 --- /dev/null +++ b/gcc/config/ia64/ia64intrin.h @@ -0,0 +1,60 @@ +#ifndef _IA64INTRIN_H_INCLUDED +#define _IA64INTRIN_H_INCLUDED + +void __sync_synchronize (void); + +int __sync_val_compare_and_swap_si (int *, int, int); +long __sync_val_compare_and_swap_di (long *, long, long); +#define __sync_val_compare_and_swap(A,B,C) ((sizeof (*(A)) == sizeof(int)) ? __sync_val_compare_and_swap_si((int *)(A),(int)(B),(int)(C)) : __sync_val_compare_and_swap_di((long *)(A),(long)(B),(long)(C))) + +int __sync_bool_compare_and_swap_si (int *, int, int); +long __sync_bool_compare_and_swap_di (long *, long, long); +#define __sync_bool_compare_and_swap(A,B,C) ((sizeof (*(A)) == sizeof(int)) ? __sync_bool_compare_and_swap_si((int *)(A),(int)(B),(int)(C)) : __sync_bool_compare_and_swap_di((long *)(A),(long)(B),(long)(C))) + +void __sync_lock_release_si (int *); +void __sync_lock_release_di (long *); +#define __sync_lock_release(A) ((sizeof (*(A)) == sizeof(int)) ? __sync_lock_release_si((int *)(A)) : __sync_lock_release_di((long *)(A))) + +int __sync_lock_test_and_set_si (int *, int); +long __sync_lock_test_and_set_di (long *, long); +#define __sync_lock_test_and_set(A,B) ((sizeof (*(A)) == sizeof(int)) ? __sync_lock_test_and_set_si((int *)(A),(int)(B)) : __sync_lock_test_and_set_di((long *)(A),(long)(B))) + +int __sync_fetch_and_add_si (int *, int); +int __sync_fetch_and_sub_si (int *, int); +int __sync_fetch_and_and_si (int *, int); +int __sync_fetch_and_or_si (int *, int); +int __sync_fetch_and_xor_si (int *, int); +int __sync_fetch_and_nand_si (int *, int); +long __sync_fetch_and_add_di (long *, long); +long __sync_fetch_and_sub_di (long *, long); +long __sync_fetch_and_and_di (long *, long); +long __sync_fetch_and_or_di (long *, long); +long __sync_fetch_and_xor_di (long *, long); +long __sync_fetch_and_nand_di (long *, long); +#define __sync_fetch_and_add(A,B) ((sizeof (*(A)) == sizeof(int)) ? __sync_fetch_and_add_si((int *)(A),(int)(B)) : __sync_fetch_and_add_di((long *)(A),(long)(B))) +#define __sync_fetch_and_sub(A,B) ((sizeof (*(A)) == sizeof(int)) ? __sync_fetch_and_sub_si((int *)(A),(int)(B)) : __sync_fetch_and_sub_di((long *)(A),(long)(B))) +#define __sync_fetch_and_and(A,B) ((sizeof (*(A)) == sizeof(int)) ? __sync_fetch_and_and_si((int *)(A),(int)(B)) : __sync_fetch_and_and_di((long *)(A),(long)(B))) +#define __sync_fetch_and_or(A,B) ((sizeof (*(A)) == sizeof(int)) ? __sync_fetch_and_or_si((int *)(A),(int)(B)) : __sync_fetch_and_or_di((long *)(A),(long)(B))) +#define __sync_fetch_and_xor(A,B) ((sizeof (*(A)) == sizeof(int)) ? __sync_fetch_and_xor_si((int *)(A),(int)(B)) : __sync_fetch_and_xor_di((long *)(A),(long)(B))) +#define __sync_fetch_and_nand(A,B) ((sizeof (*(A)) == sizeof(int)) ? __sync_fetch_and_nand_si((int *)(A),(int)(B)) : __sync_fetch_and_nand_di((long *)(A),(long)(B))) + +int __sync_add_and_fetch_si (int *, int); +int __sync_sub_and_fetch_si (int *, int); +int __sync_and_and_fetch_si (int *, int); +int __sync_or_and_fetch_si (int *, int); +int __sync_xor_and_fetch_si (int *, int); +int __sync_nand_and_fetch_si (int *, int); +long __sync_add_and_fetch_di (long *, long); +long __sync_sub_and_fetch_di (long *, long); +long __sync_and_and_fetch_di (long *, long); +long __sync_or_and_fetch_di (long *, long); +long __sync_xor_and_fetch_di (long *, long); +long __sync_nand_and_fetch_di (long *, long); +#define __sync_add_and_fetch(A,B) ((sizeof (*(A)) == sizeof(int)) ? __sync_add_and_fetch_si((int *)(A),(int)(B)) : __sync_add_and_fetch_di((long *)(A),(long)(B))) +#define __sync_sub_and_fetch(A,B) ((sizeof (*(A)) == sizeof(int)) ? __sync_sub_and_fetch_si((int *)(A),(int)(B)) : __sync_sub_and_fetch_di((long *)(A),(long)(B))) +#define __sync_and_and_fetch(A,B) ((sizeof (*(A)) == sizeof(int)) ? __sync_and_and_fetch_si((int *)(A),(int)(B)) : __sync_and_and_fetch_di((long *)(A),(long)(B))) +#define __sync_or_and_fetch(A,B) ((sizeof (*(A)) == sizeof(int)) ? __sync_or_and_fetch_si((int *)(A),(int)(B)) : __sync_or_and_fetch_di((long *)(A),(long)(B))) +#define __sync_xor_and_fetch(A,B) ((sizeof (*(A)) == sizeof(int)) ? __sync_xor_and_fetch_si((int *)(A),(int)(B)) : __sync_xor_and_fetch_di((long *)(A),(long)(B))) +#define __sync_nand_and_fetch(A,B) ((sizeof (*(A)) == sizeof(int)) ? __sync_nand_and_fetch_si((int *)(A),(int)(B)) : __sync_nand_and_fetch_di((long *)(A),(long)(B))) + +#endif |