grub2: bring back build of aros-side grub2 tools
[AROS.git] / workbench / libs / mesa / src / gallium / auxiliary / util / u_pointer.h
blobcce0c7430e78953ea99cc98838b8dea9d5608c90
1 /**************************************************************************
2 *
3 * Copyright 2007-2008 Tungsten Graphics, Inc., Cedar Park, Texas.
4 * All Rights Reserved.
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the
8 * "Software"), to deal in the Software without restriction, including
9 * without limitation the rights to use, copy, modify, merge, publish,
10 * distribute, sub license, and/or sell copies of the Software, and to
11 * permit persons to whom the Software is furnished to do so, subject to
12 * the following conditions:
14 * The above copyright notice and this permission notice (including the
15 * next paragraph) shall be included in all copies or substantial portions
16 * of the Software.
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
21 * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR
22 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
26 **************************************************************************/
28 #ifndef U_POINTER_H
29 #define U_POINTER_H
31 #include "pipe/p_compiler.h"
33 #ifdef __cplusplus
34 extern "C" {
35 #endif
37 static INLINE intptr_t
38 pointer_to_intptr( const void *p )
40 union {
41 const void *p;
42 intptr_t i;
43 } pi;
44 pi.p = p;
45 return pi.i;
48 static INLINE void *
49 intptr_to_pointer( intptr_t i )
51 union {
52 void *p;
53 intptr_t i;
54 } pi;
55 pi.i = i;
56 return pi.p;
59 static INLINE uintptr_t
60 pointer_to_uintptr( const void *ptr )
62 union {
63 const void *p;
64 uintptr_t u;
65 } pu;
66 pu.p = ptr;
67 return pu.u;
70 static INLINE void *
71 uintptr_to_pointer( uintptr_t u )
73 union {
74 void *p;
75 uintptr_t u;
76 } pu;
77 pu.u = u;
78 return pu.p;
81 /**
82 * Return a pointer aligned to next multiple of N bytes.
84 static INLINE void *
85 align_pointer( const void *unaligned, uintptr_t alignment )
87 uintptr_t aligned = (pointer_to_uintptr( unaligned ) + alignment - 1) & ~(alignment - 1);
88 return uintptr_to_pointer( aligned );
92 /**
93 * Return a pointer aligned to next multiple of 16 bytes.
95 static INLINE void *
96 align16( void *unaligned )
98 return align_pointer( unaligned, 16 );
101 typedef void (*func_pointer)(void);
103 static INLINE func_pointer
104 pointer_to_func( void *p )
106 union {
107 void *p;
108 func_pointer f;
109 } pf;
110 pf.p = p;
111 return pf.f;
114 static INLINE void *
115 func_to_pointer( func_pointer f )
117 union {
118 void *p;
119 func_pointer f;
120 } pf;
121 pf.f = f;
122 return pf.p;
126 #ifdef __cplusplus
128 #endif
130 #endif /* U_POINTER_H */