1bf215546Sopenharmony_ci/**************************************************************************
2bf215546Sopenharmony_ci *
3bf215546Sopenharmony_ci * Copyright 2010 VMware, Inc.
4bf215546Sopenharmony_ci * All Rights Reserved.
5bf215546Sopenharmony_ci *
6bf215546Sopenharmony_ci * Permission is hereby granted, free of charge, to any person obtaining a
7bf215546Sopenharmony_ci * copy of this software and associated documentation files (the
8bf215546Sopenharmony_ci * "Software"), to deal in the Software without restriction, including
9bf215546Sopenharmony_ci * without limitation the rights to use, copy, modify, merge, publish,
10bf215546Sopenharmony_ci * distribute, sub license, and/or sell copies of the Software, and to
11bf215546Sopenharmony_ci * permit persons to whom the Software is furnished to do so, subject to
12bf215546Sopenharmony_ci * the following conditions:
13bf215546Sopenharmony_ci *
14bf215546Sopenharmony_ci * The above copyright notice and this permission notice (including the
15bf215546Sopenharmony_ci * next paragraph) shall be included in all copies or substantial portions
16bf215546Sopenharmony_ci * of the Software.
17bf215546Sopenharmony_ci *
18bf215546Sopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19bf215546Sopenharmony_ci * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20bf215546Sopenharmony_ci * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
21bf215546Sopenharmony_ci * IN NO EVENT SHALL VMWARE AND/OR ITS SUPPLIERS BE LIABLE FOR
22bf215546Sopenharmony_ci * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23bf215546Sopenharmony_ci * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24bf215546Sopenharmony_ci * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
25bf215546Sopenharmony_ci *
26bf215546Sopenharmony_ci **************************************************************************/
27bf215546Sopenharmony_ci
28bf215546Sopenharmony_ci#include "util/u_debug.h"
29bf215546Sopenharmony_ci#include "util/u_memory.h"
30bf215546Sopenharmony_ci#include "lp_bld_assert.h"
31bf215546Sopenharmony_ci#include "lp_bld_init.h"
32bf215546Sopenharmony_ci#include "lp_bld_const.h"
33bf215546Sopenharmony_ci#include "lp_bld_printf.h"
34bf215546Sopenharmony_ci
35bf215546Sopenharmony_ci
36bf215546Sopenharmony_ci/**
37bf215546Sopenharmony_ci * A call to lp_build_assert() will build a function call to this function.
38bf215546Sopenharmony_ci */
39bf215546Sopenharmony_cistatic void
40bf215546Sopenharmony_cilp_assert(int condition, const char *msg)
41bf215546Sopenharmony_ci{
42bf215546Sopenharmony_ci   if (!condition) {
43bf215546Sopenharmony_ci      debug_printf("LLVM assertion '%s' failed!\n", msg);
44bf215546Sopenharmony_ci      assert(condition);
45bf215546Sopenharmony_ci   }
46bf215546Sopenharmony_ci}
47bf215546Sopenharmony_ci
48bf215546Sopenharmony_ci
49bf215546Sopenharmony_ci
50bf215546Sopenharmony_ci/**
51bf215546Sopenharmony_ci * lp_build_assert.
52bf215546Sopenharmony_ci *
53bf215546Sopenharmony_ci * Build an assertion in LLVM IR by building a function call to the
54bf215546Sopenharmony_ci * lp_assert() function above.
55bf215546Sopenharmony_ci *
56bf215546Sopenharmony_ci * \param condition should be an 'i1' or 'i32' value
57bf215546Sopenharmony_ci * \param msg  a string to print if the assertion fails.
58bf215546Sopenharmony_ci */
59bf215546Sopenharmony_civoid
60bf215546Sopenharmony_cilp_build_assert(struct gallivm_state *gallivm,
61bf215546Sopenharmony_ci                LLVMValueRef condition,
62bf215546Sopenharmony_ci                const char *msg)
63bf215546Sopenharmony_ci{
64bf215546Sopenharmony_ci   LLVMBuilderRef builder = gallivm->builder;
65bf215546Sopenharmony_ci   LLVMContextRef context = gallivm->context;
66bf215546Sopenharmony_ci   LLVMTypeRef arg_types[2];
67bf215546Sopenharmony_ci   LLVMTypeRef ret_type;
68bf215546Sopenharmony_ci   LLVMValueRef function;
69bf215546Sopenharmony_ci   LLVMValueRef args[2];
70bf215546Sopenharmony_ci   LLVMValueRef msg_string;
71bf215546Sopenharmony_ci
72bf215546Sopenharmony_ci   msg_string = lp_build_const_string(gallivm, msg);
73bf215546Sopenharmony_ci
74bf215546Sopenharmony_ci   ret_type = LLVMVoidTypeInContext(context);
75bf215546Sopenharmony_ci   arg_types[0] = LLVMInt32TypeInContext(context);
76bf215546Sopenharmony_ci   arg_types[1] = LLVMPointerType(LLVMInt8TypeInContext(context), 0);
77bf215546Sopenharmony_ci
78bf215546Sopenharmony_ci   LLVMTypeRef function_type = LLVMFunctionType(ret_type, arg_types, 2, 0);
79bf215546Sopenharmony_ci
80bf215546Sopenharmony_ci   function = lp_build_const_func_pointer_from_type(gallivm,
81bf215546Sopenharmony_ci                                          func_to_pointer((func_pointer)lp_assert),
82bf215546Sopenharmony_ci                                          function_type,
83bf215546Sopenharmony_ci                                          "assert");
84bf215546Sopenharmony_ci
85bf215546Sopenharmony_ci   /* build function call param list */
86bf215546Sopenharmony_ci   args[0] = LLVMBuildZExt(builder, condition, arg_types[0], "");
87bf215546Sopenharmony_ci   args[1] = msg_string;
88bf215546Sopenharmony_ci
89bf215546Sopenharmony_ci   /* check arg types */
90bf215546Sopenharmony_ci   assert(LLVMTypeOf(args[0]) == arg_types[0]);
91bf215546Sopenharmony_ci   assert(LLVMTypeOf(args[1]) == arg_types[1]);
92bf215546Sopenharmony_ci   LLVMBuildCall2(builder, function_type, function, args, ARRAY_SIZE(args), "");
93bf215546Sopenharmony_ci}
94