/* * Copyright (c) 2017 Intel Corporation. All rights reserved. * * This software is available to you under a choice of one of two * licenses. You may choose to be licensed under the terms of the GNU * General Public License (GPL) Version 2, available from the file * COPYING in the main directory of this source tree, or the * BSD license below: * * Redistribution and use in source and binary forms, with or * without modification, are permitted provided that the following * conditions are met: * * - Redistibutions of source code must retain the above * copyright notice, this list of conditions and the following * disclaimer. * * - Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following * disclaimer in the documentation and/or other materials * provided with the distribution. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ #ifndef _OFI_ATOMIC_H_ #define _OFI_ATOMIC_H_ #include "fabtest.h" #ifdef __cplusplus extern "C" { #endif typedef long double long_double; typedef float complex ofi_complex_float; typedef double complex ofi_complex_double; typedef long double complex ofi_complex_long_double; #define OFI_WRITE_OP_START FI_MIN #define OFI_WRITE_OP_LAST (FI_ATOMIC_WRITE + 1) #define OFI_WRITE_OP_CNT (OFI_WRITE_OP_LAST - OFI_WRITE_OP_START) #define OFI_READWRITE_OP_START FI_MIN #define OFI_READWRITE_OP_LAST (FI_ATOMIC_WRITE + 1) #define OFI_READWRITE_OP_CNT (OFI_READWRITE_OP_LAST - OFI_READWRITE_OP_START) #define OFI_SWAP_OP_START FI_CSWAP #define OFI_SWAP_OP_LAST (FI_MSWAP + 1) #define OFI_SWAP_OP_CNT (OFI_SWAP_OP_LAST - OFI_SWAP_OP_START) #define ofi_atomic_iswrite_op(op) \ (op >= OFI_WRITE_OP_START && op < OFI_WRITE_OP_LAST && op != FI_ATOMIC_READ) #define ofi_atomic_isreadwrite_op(op) \ (op >= OFI_READWRITE_OP_START && op < OFI_READWRITE_OP_LAST) #define ofi_atomic_isswap_op(op) \ (op >= OFI_SWAP_OP_START && op < OFI_SWAP_OP_LAST) extern void (*ofi_atomic_write_handlers[OFI_WRITE_OP_CNT][OFI_DATATYPE_CNT]) (void *dst, const void *src, size_t cnt); extern void (*ofi_atomic_readwrite_handlers[OFI_READWRITE_OP_CNT][OFI_DATATYPE_CNT]) (void *dst, const void *src, void *res, size_t cnt); extern void (*ofi_atomic_swap_handlers[OFI_SWAP_OP_CNT][OFI_DATATYPE_CNT]) (void *dst, const void *src, const void *cmp, void *res, size_t cnt); #define ofi_atomic_write_handler(op, datatype) \ ofi_atomic_write_handlers[op][datatype] #define ofi_atomic_readwrite_handler(op, datatype) \ ofi_atomic_readwrite_handlers[op][datatype] #define ofi_atomic_swap_handler(op, datatype) \ ofi_atomic_swap_handlers[op - OFI_SWAP_OP_START][datatype] #define ofi_atomic_write_op(op, datatype, dst, src, cnt) \ ofi_atomic_write_handler(op, datatype)(dst, src, cnt) #define ofi_atomic_readwrite_op(op, datatype, dst, src, res, cnt) \ ofi_atomic_readwrite_handler(op, datatype)(dst, src, res, cnt) #define ofi_atomic_swap_op(op, datatype, dst, src, cmp, res, cnt) \ ofi_atomic_swap_handler(op, datatype)(dst, src, cmp, res, cnt) #define OFI_DEF_COMPLEX_OPS(type) \ static inline int ofi_complex_eq_## type \ (ofi_complex_## type a, ofi_complex_## type b) \ { \ return a == b; \ } \ static inline ofi_complex_## type ofi_complex_sum_## type \ (ofi_complex_## type a, ofi_complex_## type b) \ { \ return a + b; \ } \ static inline ofi_complex_## type ofi_complex_prod_## type \ (ofi_complex_## type a, ofi_complex_## type b) \ { \ return a * b; \ } \ static inline ofi_complex_## type ofi_complex_land_## type \ (ofi_complex_## type a, ofi_complex_## type b) \ { \ return a && b; \ } \ static inline ofi_complex_## type ofi_complex_lor_## type \ (ofi_complex_## type a, ofi_complex_## type b) \ { \ return a || b; \ } \ static inline int ofi_complex_lxor_## type \ (ofi_complex_## type a, ofi_complex_## type b) \ { \ return (a && !b) || (!a && b); \ } \ OFI_DEF_COMPLEX_OPS(float) OFI_DEF_COMPLEX_OPS(double) OFI_DEF_COMPLEX_OPS(long_double) #ifdef __cplusplus } #endif #endif /* _OFI_ATOMIC_H_ */