5e359ceaa2053ae306967621d7da321eb7c62987
1 /**************************************************************************
3 * Copyright 2010 VMware, Inc.
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
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 VMWARE 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 **************************************************************************/
30 #include "util/u_debug.h"
31 #include "util/u_memory.h"
32 #include "util/u_string.h"
33 #include "lp_bld_const.h"
34 #include "lp_bld_init.h"
35 #include "lp_bld_const.h"
36 #include "lp_bld_printf.h"
40 lp_get_printf_arg_count(const char *fmt
)
56 if (p
[1] == '*' && p
[2] == 's') {
72 * Build printf call in LLVM IR. The output goes to stdout.
73 * The additional variable arguments need to have type
77 lp_build_printf(struct gallivm_state
*gallivm
, const char *fmt
, ...)
81 int argcount
= lp_get_printf_arg_count(fmt
);
82 LLVMBuilderRef builder
= gallivm
->builder
;
83 LLVMContextRef context
= gallivm
->context
;
84 LLVMValueRef params
[50];
85 LLVMValueRef fmtarg
= lp_build_const_string(gallivm
, fmt
);
86 LLVMTypeRef printf_type
;
87 LLVMValueRef func_printf
;
89 assert(Elements(params
) >= argcount
+ 1);
91 printf_type
= LLVMFunctionType(LLVMIntTypeInContext(context
, 32), NULL
, 0, 1);
93 func_printf
= lp_build_const_int_pointer(gallivm
, func_to_pointer((func_pointer
)debug_printf
));
95 func_printf
= LLVMBuildBitCast(gallivm
->builder
, func_printf
,
96 LLVMPointerType(printf_type
, 0),
101 va_start(arglist
, fmt
);
102 for (i
= 1; i
<= argcount
; i
++) {
103 LLVMValueRef val
= va_arg(arglist
, LLVMValueRef
);
104 LLVMTypeRef type
= LLVMTypeOf(val
);
105 /* printf wants doubles, so lets convert so that
106 * we can actually print them */
107 if (LLVMGetTypeKind(type
) == LLVMFloatTypeKind
)
108 val
= LLVMBuildFPExt(builder
, val
, LLVMDoubleTypeInContext(context
), "");
113 return LLVMBuildCall(builder
, func_printf
, params
, argcount
+ 1, "");
119 * Print a float[4] vector.
122 lp_build_print_vec4(struct gallivm_state
*gallivm
,
123 const char *msg
, LLVMValueRef vec
)
125 LLVMBuilderRef builder
= gallivm
->builder
;
127 LLVMValueRef x
, y
, z
, w
;
129 x
= LLVMBuildExtractElement(builder
, vec
, lp_build_const_int32(gallivm
, 0), "");
130 y
= LLVMBuildExtractElement(builder
, vec
, lp_build_const_int32(gallivm
, 1), "");
131 z
= LLVMBuildExtractElement(builder
, vec
, lp_build_const_int32(gallivm
, 2), "");
132 w
= LLVMBuildExtractElement(builder
, vec
, lp_build_const_int32(gallivm
, 3), "");
134 util_snprintf(format
, sizeof(format
), "%s %%f %%f %%f %%f\n", msg
);
135 return lp_build_printf(gallivm
, format
, x
, y
, z
, w
);
140 * Print a intt[4] vector.
143 lp_build_print_ivec4(struct gallivm_state
*gallivm
,
144 const char *msg
, LLVMValueRef vec
)
146 LLVMBuilderRef builder
= gallivm
->builder
;
148 LLVMValueRef x
, y
, z
, w
;
150 x
= LLVMBuildExtractElement(builder
, vec
, lp_build_const_int32(gallivm
, 0), "");
151 y
= LLVMBuildExtractElement(builder
, vec
, lp_build_const_int32(gallivm
, 1), "");
152 z
= LLVMBuildExtractElement(builder
, vec
, lp_build_const_int32(gallivm
, 2), "");
153 w
= LLVMBuildExtractElement(builder
, vec
, lp_build_const_int32(gallivm
, 3), "");
155 util_snprintf(format
, sizeof(format
), "%s %%i %%i %%i %%i\n", msg
);
156 return lp_build_printf(gallivm
, format
, x
, y
, z
, w
);
161 * Print a uint8[16] vector.
164 lp_build_print_uvec16(struct gallivm_state
*gallivm
,
165 const char *msg
, LLVMValueRef vec
)
167 LLVMBuilderRef builder
= gallivm
->builder
;
169 LLVMValueRef args
[16];
172 for (i
= 0; i
< 16; ++i
) {
173 args
[i
] = LLVMBuildExtractElement(builder
, vec
, lp_build_const_int32(gallivm
, i
), "");
176 util_snprintf(format
, sizeof(format
), "%s %%u %%u %%u %%u %%u %%u %%u %%u %%u %%u %%u %%u %%u %%u %%u %%u\n", msg
);
178 return lp_build_printf(
180 args
[ 0], args
[ 1], args
[ 2], args
[ 3],
181 args
[ 4], args
[ 5], args
[ 6], args
[ 7],
182 args
[ 8], args
[ 9], args
[10], args
[11],
183 args
[12], args
[13], args
[14], args
[15]);