X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fadt%2Futil.h;h=eab86cff70da99e2db42b5f1bbeefcd2ef02612d;hb=3db23eee84cbabb3f399f1ca820948114a9c837c;hp=c8acb56525345da6531aeccebc2d8d13e67a6dca;hpb=863d31d7a5c8210432fef88b30fc3e8353131538;p=libfirm diff --git a/ir/adt/util.h b/ir/adt/util.h index c8acb5652..eab86cff7 100644 --- a/ir/adt/util.h +++ b/ir/adt/util.h @@ -1,25 +1,32 @@ -/** - * @file util.h - * @date 31.05.2005 - * @author Sebastian Hack +/* + * Copyright (C) 1995-2008 University of Karlsruhe. All right reserved. + * + * This file is part of libFirm. * - * Some utility macros. + * This file may be distributed and/or modified under the terms of the + * GNU General Public License version 2 as published by the Free Software + * Foundation and appearing in the file LICENSE.GPL included in the + * packaging of this file. * - * Copyright (C) 2005 Universitaet Karlsruhe - * Released under the GPL + * Licensees holding valid libFirm Professional Edition licenses may use + * this file in accordance with the libFirm Commercial License. + * Agreement provided with the Software. + * + * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE + * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE. */ -#ifndef _UTIL_H -#define _UTIL_H - /** - * Get the offset of a member of a struct. - * @param type The type of the struct member is in. - * @param member The name of the member. - * @return The offset of member in type in bytes. + * @file + * @date 31.05.2005 + * @author Sebastian Hack + * @brief Miscellaneous utility macros. */ -#define offset_of(type, member) \ - ((char *) &(((type *) 0)->member) - (char *) 0) +#ifndef FIRM_ADT_UTIL_H +#define FIRM_ADT_UTIL_H + +#include /** * Make pointer to the struct from a pointer to a member of that struct. @@ -28,43 +35,38 @@ * @param member The name of the member. * @return A pointer to the struct member is in. */ -#define container_of(ptr, type, member) \ - ((type *) ((char *) (ptr) - offset_of(type, member))) +#define firm_container_of(ptr, type, member) \ + ((type *) ((char *) (ptr) - offsetof(type, member))) /** - * Get the number of elements of a static array. - * @param arr The static array. - * @return The number of elements in that array. + * Returns size of a static array. Warning: This returns invalid values for + * dynamically allocated arrays. + * + * @param a static array */ -#define array_size(arr) \ - (sizeof(arr) / sizeof((arr)[0])) +#define ARRAY_SIZE(a) (sizeof(a)/sizeof((a)[0])) + +#undef MIN +#undef MAX +#define MAX(x, y) ((x) > (y) ? (x) : (y)) +#define MIN(x, y) ((x) < (y) ? (x) : (y)) /** - * Asserts that the constant expression x is not zero at compiletime. name has - * to be a unique identifier. - * - * @note This uses the fact, that double case labels are not allowed. + * Three valued compare as demanded by e.g. qsort(3) + * @param c A number. + * @param d Another number. + * @return 0 if c == d, -1 if c < d, 1 if c > d. */ -#define COMPILETIME_ASSERT(x, name) \ - static __attribute__((unused)) void compiletime_assert_##name (int h) { \ - switch(h) { case 0: case (x): ; } \ - } +#define QSORT_CMP(c, d) (((c) > (d)) - ((c) < (d))) -#ifdef __GNUC__ /** - * Indicates to the compiler that the value of x is very likely 1 - * @note Only use this in speed critical code and when you are sure x is often 1 + * convert an integer into pointer */ -#define LIKELY(x) __builtin_expect((x), 1) +#define INT_TO_PTR(v) ((void *)((char *)0 + (v))) /** - * Indicates to the compiler that it's very likely that x is 0 - * @note Only use this in speed critical code and when you are sure x is often 0 + * convert a pointer into an integer */ -#define UNLIKELY(x) __builtin_expect((x), 0) -#else -#define LIKELY(x) x -#define UNLIKELY(x) x -#endif +#define PTR_TO_INT(v) (((char *)(v) - (char *)0)) -#endif /* _UTIL_H */ +#endif