1*d6b92ffaSHans Petter Selasky /* 2*d6b92ffaSHans Petter Selasky * Copyright (c) 2004, 2005 Voltaire, Inc. All rights reserved. 3*d6b92ffaSHans Petter Selasky * Copyright (c) 2002-2005 Mellanox Technologies LTD. All rights reserved. 4*d6b92ffaSHans Petter Selasky * Copyright (c) 1996-2003 Intel Corporation. All rights reserved. 5*d6b92ffaSHans Petter Selasky * 6*d6b92ffaSHans Petter Selasky * This software is available to you under a choice of one of two 7*d6b92ffaSHans Petter Selasky * licenses. You may choose to be licensed under the terms of the GNU 8*d6b92ffaSHans Petter Selasky * General Public License (GPL) Version 2, available from the file 9*d6b92ffaSHans Petter Selasky * COPYING in the main directory of this source tree, or the 10*d6b92ffaSHans Petter Selasky * OpenIB.org BSD license below: 11*d6b92ffaSHans Petter Selasky * 12*d6b92ffaSHans Petter Selasky * Redistribution and use in source and binary forms, with or 13*d6b92ffaSHans Petter Selasky * without modification, are permitted provided that the following 14*d6b92ffaSHans Petter Selasky * conditions are met: 15*d6b92ffaSHans Petter Selasky * 16*d6b92ffaSHans Petter Selasky * - Redistributions of source code must retain the above 17*d6b92ffaSHans Petter Selasky * copyright notice, this list of conditions and the following 18*d6b92ffaSHans Petter Selasky * disclaimer. 19*d6b92ffaSHans Petter Selasky * 20*d6b92ffaSHans Petter Selasky * - Redistributions in binary form must reproduce the above 21*d6b92ffaSHans Petter Selasky * copyright notice, this list of conditions and the following 22*d6b92ffaSHans Petter Selasky * disclaimer in the documentation and/or other materials 23*d6b92ffaSHans Petter Selasky * provided with the distribution. 24*d6b92ffaSHans Petter Selasky * 25*d6b92ffaSHans Petter Selasky * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 26*d6b92ffaSHans Petter Selasky * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 27*d6b92ffaSHans Petter Selasky * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 28*d6b92ffaSHans Petter Selasky * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS 29*d6b92ffaSHans Petter Selasky * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN 30*d6b92ffaSHans Petter Selasky * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 31*d6b92ffaSHans Petter Selasky * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 32*d6b92ffaSHans Petter Selasky * SOFTWARE. 33*d6b92ffaSHans Petter Selasky * 34*d6b92ffaSHans Petter Selasky */ 35*d6b92ffaSHans Petter Selasky 36*d6b92ffaSHans Petter Selasky /* 37*d6b92ffaSHans Petter Selasky * Abstract: 38*d6b92ffaSHans Petter Selasky * Defines standard math related macros and functions. 39*d6b92ffaSHans Petter Selasky */ 40*d6b92ffaSHans Petter Selasky 41*d6b92ffaSHans Petter Selasky #ifndef _CL_MATH_H_ 42*d6b92ffaSHans Petter Selasky #define _CL_MATH_H_ 43*d6b92ffaSHans Petter Selasky 44*d6b92ffaSHans Petter Selasky #include <complib/cl_types.h> 45*d6b92ffaSHans Petter Selasky 46*d6b92ffaSHans Petter Selasky #ifdef __cplusplus 47*d6b92ffaSHans Petter Selasky # define BEGIN_C_DECLS extern "C" { 48*d6b92ffaSHans Petter Selasky # define END_C_DECLS } 49*d6b92ffaSHans Petter Selasky #else /* !__cplusplus */ 50*d6b92ffaSHans Petter Selasky # define BEGIN_C_DECLS 51*d6b92ffaSHans Petter Selasky # define END_C_DECLS 52*d6b92ffaSHans Petter Selasky #endif /* __cplusplus */ 53*d6b92ffaSHans Petter Selasky 54*d6b92ffaSHans Petter Selasky BEGIN_C_DECLS 55*d6b92ffaSHans Petter Selasky /****d* Component Library: Math/MAX 56*d6b92ffaSHans Petter Selasky * NAME 57*d6b92ffaSHans Petter Selasky * MAX 58*d6b92ffaSHans Petter Selasky * 59*d6b92ffaSHans Petter Selasky * DESCRIPTION 60*d6b92ffaSHans Petter Selasky * The MAX macro returns the greater of two values. 61*d6b92ffaSHans Petter Selasky * 62*d6b92ffaSHans Petter Selasky * SYNOPSIS 63*d6b92ffaSHans Petter Selasky * MAX( x, y ); 64*d6b92ffaSHans Petter Selasky * 65*d6b92ffaSHans Petter Selasky * PARAMETERS 66*d6b92ffaSHans Petter Selasky * x 67*d6b92ffaSHans Petter Selasky * [in] First of two values to compare. 68*d6b92ffaSHans Petter Selasky * 69*d6b92ffaSHans Petter Selasky * y 70*d6b92ffaSHans Petter Selasky * [in] Second of two values to compare. 71*d6b92ffaSHans Petter Selasky * 72*d6b92ffaSHans Petter Selasky * RETURN VALUE 73*d6b92ffaSHans Petter Selasky * Returns the greater of the x and y parameters. 74*d6b92ffaSHans Petter Selasky * 75*d6b92ffaSHans Petter Selasky * SEE ALSO 76*d6b92ffaSHans Petter Selasky * MIN, ROUNDUP 77*d6b92ffaSHans Petter Selasky *********/ 78*d6b92ffaSHans Petter Selasky #ifndef MAX 79*d6b92ffaSHans Petter Selasky #define MAX(x,y) ((x) > (y) ? (x) : (y)) 80*d6b92ffaSHans Petter Selasky #endif 81*d6b92ffaSHans Petter Selasky /****d* Component Library: Math/MIN 82*d6b92ffaSHans Petter Selasky * NAME 83*d6b92ffaSHans Petter Selasky * MIN 84*d6b92ffaSHans Petter Selasky * 85*d6b92ffaSHans Petter Selasky * DESCRIPTION 86*d6b92ffaSHans Petter Selasky * The MIN macro returns the greater of two values. 87*d6b92ffaSHans Petter Selasky * 88*d6b92ffaSHans Petter Selasky * SYNOPSIS 89*d6b92ffaSHans Petter Selasky * MIN( x, y ); 90*d6b92ffaSHans Petter Selasky * 91*d6b92ffaSHans Petter Selasky * PARAMETERS 92*d6b92ffaSHans Petter Selasky * x 93*d6b92ffaSHans Petter Selasky * [in] First of two values to compare. 94*d6b92ffaSHans Petter Selasky * 95*d6b92ffaSHans Petter Selasky * y 96*d6b92ffaSHans Petter Selasky * [in] Second of two values to compare. 97*d6b92ffaSHans Petter Selasky * 98*d6b92ffaSHans Petter Selasky * RETURN VALUE 99*d6b92ffaSHans Petter Selasky * Returns the lesser of the x and y parameters. 100*d6b92ffaSHans Petter Selasky * 101*d6b92ffaSHans Petter Selasky * SEE ALSO 102*d6b92ffaSHans Petter Selasky * MAX, ROUNDUP 103*d6b92ffaSHans Petter Selasky *********/ 104*d6b92ffaSHans Petter Selasky #ifndef MIN 105*d6b92ffaSHans Petter Selasky #define MIN(x,y) ((x) < (y) ? (x) : (y)) 106*d6b92ffaSHans Petter Selasky #endif 107*d6b92ffaSHans Petter Selasky /****d* Component Library: Math/ROUNDUP 108*d6b92ffaSHans Petter Selasky * NAME 109*d6b92ffaSHans Petter Selasky * ROUNDUP 110*d6b92ffaSHans Petter Selasky * 111*d6b92ffaSHans Petter Selasky * DESCRIPTION 112*d6b92ffaSHans Petter Selasky * The ROUNDUP macro rounds a value up to a given multiple. 113*d6b92ffaSHans Petter Selasky * 114*d6b92ffaSHans Petter Selasky * SYNOPSIS 115*d6b92ffaSHans Petter Selasky * ROUNDUP( val, align ); 116*d6b92ffaSHans Petter Selasky * 117*d6b92ffaSHans Petter Selasky * PARAMETERS 118*d6b92ffaSHans Petter Selasky * val 119*d6b92ffaSHans Petter Selasky * [in] Value that is to be rounded up. The type of the value is 120*d6b92ffaSHans Petter Selasky * indeterminate, but must be at most the size of a natural integer 121*d6b92ffaSHans Petter Selasky * for the platform. 122*d6b92ffaSHans Petter Selasky * 123*d6b92ffaSHans Petter Selasky * align 124*d6b92ffaSHans Petter Selasky * [in] Multiple to which the val parameter must be rounded up. 125*d6b92ffaSHans Petter Selasky * 126*d6b92ffaSHans Petter Selasky * RETURN VALUE 127*d6b92ffaSHans Petter Selasky * Returns a value that is the input value specified by val rounded up to 128*d6b92ffaSHans Petter Selasky * the nearest multiple of align. 129*d6b92ffaSHans Petter Selasky * 130*d6b92ffaSHans Petter Selasky * NOTES 131*d6b92ffaSHans Petter Selasky * The value provided must be of a type at most the size of a natural integer. 132*d6b92ffaSHans Petter Selasky *********/ 133*d6b92ffaSHans Petter Selasky #ifndef ROUNDUP 134*d6b92ffaSHans Petter Selasky #define ROUNDUP(val, align) \ 135*d6b92ffaSHans Petter Selasky ((((val) / (align))*(align)) + (((val) % (align)) ? (align) : 0)) 136*d6b92ffaSHans Petter Selasky #endif 137*d6b92ffaSHans Petter Selasky END_C_DECLS 138*d6b92ffaSHans Petter Selasky #endif /* _CL_MATH_H_ */ 139