ck_pr: Add ck_pr_fas_double for {ppc,x86_}64 and ck_pr_cas_double{_2} for x86_64.

ck_pring
Samy Al Bahra 13 years ago
parent 5e7adf5983
commit e8a96f4fb8

@ -34,6 +34,7 @@
#define CK_F_PR_FAS_INT #define CK_F_PR_FAS_INT
#define CK_F_PR_FAS_PTR #define CK_F_PR_FAS_PTR
#define CK_F_PR_FAS_UINT #define CK_F_PR_FAS_UINT
#define CK_F_PR_FAS_DOUBLE
#define CK_F_PR_FENCE_LOAD #define CK_F_PR_FENCE_LOAD
#define CK_F_PR_FENCE_LOAD_DEPENDS #define CK_F_PR_FENCE_LOAD_DEPENDS
#define CK_F_PR_FENCE_MEMORY #define CK_F_PR_FENCE_MEMORY

@ -294,6 +294,7 @@ CK_PR_CAS(int, int)
CK_PR_FAS(64, uint64_t, uint64_t, "d") CK_PR_FAS(64, uint64_t, uint64_t, "d")
CK_PR_FAS(32, uint32_t, uint32_t, "w") CK_PR_FAS(32, uint32_t, uint32_t, "w")
CK_PR_FAS(double, double, double, "d")
CK_PR_FAS(ptr, void, void *, "d") CK_PR_FAS(ptr, void, void *, "d")
CK_PR_FAS(int, int, int, "w") CK_PR_FAS(int, int, int, "w")
CK_PR_FAS(uint, unsigned int, unsigned int, "w") CK_PR_FAS(uint, unsigned int, unsigned int, "w")

@ -61,6 +61,9 @@
#define CK_F_PR_CAS_PTR_2 #define CK_F_PR_CAS_PTR_2
#define CK_F_PR_CAS_PTR_2_VALUE #define CK_F_PR_CAS_PTR_2_VALUE
#define CK_F_PR_CAS_PTR_VALUE #define CK_F_PR_CAS_PTR_VALUE
#define CK_F_PR_CAS_DOUBLE
#define CK_F_PR_CAS_DOUBLE_2
#define CK_F_PR_CAS_DOUBLE_VALUE
#define CK_F_PR_CAS_UINT #define CK_F_PR_CAS_UINT
#define CK_F_PR_CAS_UINT_4 #define CK_F_PR_CAS_UINT_4
#define CK_F_PR_CAS_UINT_4_VALUE #define CK_F_PR_CAS_UINT_4_VALUE
@ -97,6 +100,7 @@
#define CK_F_PR_FAS_INT #define CK_F_PR_FAS_INT
#define CK_F_PR_FAS_PTR #define CK_F_PR_FAS_PTR
#define CK_F_PR_FAS_UINT #define CK_F_PR_FAS_UINT
#define CK_F_PR_FAS_DOUBLE
#define CK_F_PR_FENCE_LOAD #define CK_F_PR_FENCE_LOAD
#define CK_F_PR_FENCE_LOAD_DEPENDS #define CK_F_PR_FENCE_LOAD_DEPENDS
#define CK_F_PR_FENCE_MEMORY #define CK_F_PR_FENCE_MEMORY

@ -106,6 +106,7 @@ CK_PR_FAS(ptr, void, void *, char, "xchgq")
#define CK_PR_FAS_S(S, T, I) CK_PR_FAS(S, T, T, T, I) #define CK_PR_FAS_S(S, T, I) CK_PR_FAS(S, T, T, T, I)
CK_PR_FAS_S(double, double, "xchgq")
CK_PR_FAS_S(char, char, "xchgb") CK_PR_FAS_S(char, char, "xchgb")
CK_PR_FAS_S(uint, unsigned int, "xchgl") CK_PR_FAS_S(uint, unsigned int, "xchgl")
CK_PR_FAS_S(int, int, "xchgl") CK_PR_FAS_S(int, int, "xchgl")
@ -364,6 +365,7 @@ CK_PR_CAS(ptr, void, void *, char, "cmpxchgq")
CK_PR_CAS_S(char, char, "cmpxchgb") CK_PR_CAS_S(char, char, "cmpxchgb")
CK_PR_CAS_S(int, int, "cmpxchgl") CK_PR_CAS_S(int, int, "cmpxchgl")
CK_PR_CAS_S(uint, unsigned int, "cmpxchgl") CK_PR_CAS_S(uint, unsigned int, "cmpxchgl")
CK_PR_CAS_S(double, double, "cmpxchgq")
CK_PR_CAS_S(64, uint64_t, "cmpxchgq") CK_PR_CAS_S(64, uint64_t, "cmpxchgq")
CK_PR_CAS_S(32, uint32_t, "cmpxchgl") CK_PR_CAS_S(32, uint32_t, "cmpxchgl")
CK_PR_CAS_S(16, uint16_t, "cmpxchgw") CK_PR_CAS_S(16, uint16_t, "cmpxchgw")
@ -400,6 +402,7 @@ CK_PR_CAS_O(ptr, void, void *, char, "q", "rax")
CK_PR_CAS_O_S(char, char, "b", "al") CK_PR_CAS_O_S(char, char, "b", "al")
CK_PR_CAS_O_S(int, int, "l", "eax") CK_PR_CAS_O_S(int, int, "l", "eax")
CK_PR_CAS_O_S(uint, unsigned int, "l", "eax") CK_PR_CAS_O_S(uint, unsigned int, "l", "eax")
CK_PR_CAS_O_S(double, double, "q", "rax")
CK_PR_CAS_O_S(64, uint64_t, "q", "rax") CK_PR_CAS_O_S(64, uint64_t, "q", "rax")
CK_PR_CAS_O_S(32, uint32_t, "l", "eax") CK_PR_CAS_O_S(32, uint32_t, "l", "eax")
CK_PR_CAS_O_S(16, uint16_t, "w", "ax") CK_PR_CAS_O_S(16, uint16_t, "w", "ax")
@ -479,6 +482,7 @@ ck_pr_cas_##S##_##W##_value(T *t, T c[W], T s[W], T *v) \
(uint64_t *)v); \ (uint64_t *)v); \
} }
CK_PR_CAS_V(double, 2, double)
CK_PR_CAS_V(char, 16, char) CK_PR_CAS_V(char, 16, char)
CK_PR_CAS_V(int, 4, int) CK_PR_CAS_V(int, 4, int)
CK_PR_CAS_V(uint, 4, unsigned int) CK_PR_CAS_V(uint, 4, unsigned int)

Loading…
Cancel
Save