lp_bld_misc.cpp revision 95aa0e5d84a4f46f2f0809b26f5899b8e39f5afc
1/**************************************************************************
2 *
3 * Copyright 2010 VMware, Inc.
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:
13 *
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL
17 * THE COPYRIGHT HOLDERS, AUTHORS AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM,
18 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
19 * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
20 * USE OR OTHER DEALINGS IN THE SOFTWARE.
21 *
22 * The above copyright notice and this permission notice (including the
23 * next paragraph) shall be included in all copies or substantial portions
24 * of the Software.
25 *
26 **************************************************************************/
27
28
29#ifndef __STDC_LIMIT_MACROS
30#define __STDC_LIMIT_MACROS
31#endif
32
33#ifndef __STDC_CONSTANT_MACROS
34#define __STDC_CONSTANT_MACROS
35#endif
36
37#include <stddef.h>
38
39#include <llvm-c/Core.h>
40#include <llvm-c/ExecutionEngine.h>
41#include <llvm/Target/TargetOptions.h>
42#include <llvm/ExecutionEngine/ExecutionEngine.h>
43#include <llvm/ExecutionEngine/JITEventListener.h>
44#include <llvm/Support/CommandLine.h>
45#include <llvm/Support/PrettyStackTrace.h>
46
47#include "pipe/p_config.h"
48#include "util/u_debug.h"
49
50
51/**
52 * Register the engine with oprofile.
53 *
54 * This allows to see the LLVM IR function names in oprofile output.
55 *
56 * To actually work LLVM needs to be built with the --with-oprofile configure
57 * option.
58 *
59 * Also a oprofile:oprofile user:group is necessary. Which is not created by
60 * default on some distributions.
61 */
62extern "C" void
63lp_register_oprofile_jit_event_listener(LLVMExecutionEngineRef EE)
64{
65   llvm::unwrap(EE)->RegisterJITEventListener(llvm::createOProfileJITEventListener());
66}
67
68
69extern "C" void
70lp_set_target_options(void)
71{
72#if HAVE_LLVM <= 0x0300
73#if defined(DEBUG)
74#if HAVE_LLVM >= 0x0207
75   llvm::JITEmitDebugInfo = true;
76#endif
77#endif
78
79   /*
80    * LLVM revision 123367 switched the default stack alignment to 16 bytes on
81    * Linux (and several other Unices in later revisions), to match recent gcc
82    * versions.
83    *
84    * However our drivers can be loaded by old binary applications, still
85    * maintaining a 4 bytes stack alignment.  Therefore we must tell LLVM here
86    * to only assume a 4 bytes alignment for backwards compatibility.
87    */
88#if defined(PIPE_ARCH_X86)
89#if HAVE_LLVM >= 0x0300
90   llvm::StackAlignmentOverride = 4;
91#else
92   llvm::StackAlignment = 4;
93#endif
94#endif
95
96#if defined(DEBUG) || defined(PROFILE)
97   llvm::NoFramePointerElim = true;
98#endif
99
100   llvm::NoExcessFPPrecision = false;
101
102   /* XXX: Investigate this */
103#if 0
104   llvm::UnsafeFPMath = true;
105#endif
106#endif  /* HAVE_LLVM <= 0x0300 */
107
108#if HAVE_LLVM < 0x0209
109   /*
110    * LLVM will generate MMX instructions for vectors <= 64 bits, leading to
111    * innefficient code, and in 32bit systems, to the corruption of the FPU
112    * stack given that it expects the user to generate the EMMS instructions.
113    *
114    * See also:
115    * - http://llvm.org/bugs/show_bug.cgi?id=3287
116    * - http://l4.me.uk/post/2009/06/07/llvm-wrinkle-3-configuration-what-configuration/
117    *
118    * The -disable-mmx global option can be specified only once  since we
119    * dynamically link against LLVM it will reside in a separate shared object,
120    * which may or not be delete when this shared object is, so we use the
121    * llvm::DisablePrettyStackTrace variable (which we set below and should
122    * reside in the same shared library) to determine whether the -disable-mmx
123    * option has been set or not.
124    *
125    * Thankfully this ugly hack is not necessary on LLVM 2.9 onwards.
126    */
127   if (!llvm::DisablePrettyStackTrace) {
128      static boolean first = TRUE;
129      static const char* options[] = {
130         "prog",
131         "-disable-mmx"
132      };
133      assert(first);
134      llvm::cl::ParseCommandLineOptions(2, const_cast<char**>(options));
135      first = FALSE;
136   }
137#endif
138
139   /*
140    * By default LLVM adds a signal handler to output a pretty stack trace.
141    * This signal handler is never removed, causing problems when unloading the
142    * shared object where the gallium driver resides.
143    */
144   llvm::DisablePrettyStackTrace = true;
145}
146
147
148extern "C" void
149lp_func_delete_body(LLVMValueRef FF)
150{
151   llvm::Function *func = llvm::unwrap<llvm::Function>(FF);
152   func->deleteBody();
153}
154
155
156extern "C"
157LLVMValueRef
158lp_build_load_volatile(LLVMBuilderRef B, LLVMValueRef PointerVal,
159                       const char *Name)
160{
161   return llvm::wrap(llvm::unwrap(B)->CreateLoad(llvm::unwrap(PointerVal), true, Name));
162}
163
164