Lines Matching +full:get +full:- +full:conclusion
2 Kaleidoscope: Conclusion and other useful LLVM tidbits
8 Tutorial Conclusion
14 being a semi-interesting (but probably still useless) toy. :)
18 interactive run-loop (with a JIT!), and emitted debug information in
19 standalone executables - all in under 1000 lines of (non-comment/non-blank)
33 - **global variables** - While global variables have questional value
41 - **typed variables** - Kaleidoscope currently only supports variables
48 - **arrays, structs, vectors, etc** - Once you add types, you can start
52 LLVM `getelementptr <../LangRef.html#getelementptr-instruction>`_ instruction
55 - **standard runtime** - Our current language allows the user to access
57 and "putchard". As you extend the language to add higher-level
59 lowered to calls into a language-supplied runtime. For example, if
62 - **memory management** - Currently we can only access the stack in
69 - **exception handling support** - LLVM supports generation of `zero
75 - **object orientation, generics, database access, complex numbers,
76 geometric programming, ...** - Really, there is no end of crazy
78 - **unusual domains** - We've been talking about applying LLVM to a
87 Have fun - try doing something crazy and unusual. Building a language
89 little crazy or off the wall and seeing how it turns out. If you get
90 stuck or want to talk about it, feel free to email the `llvm-dev mailing
91 list <http://lists.llvm.org/mailman/listinfo/llvm-dev>`_: it has lots
103 We have a couple of common questions about code in the LLVM IR form -
104 let's just get these out of the way right now, shall we?
107 -------------------
117 Kaleidoscope-compiled program and run it on any target that LLVM
120 compiler generates target-independent code because it never queries for
121 any target-specific information when generating code.
123 The fact that LLVM provides a compact, target-independent,
129 course, C source code is not actually portable in general either - ever
130 port a really old application from 32- to 64-bits?).
134 preprocessor often destructively removes target-independence from the
137 .. code-block:: c
151 32-bits, and long = 64-bits), don't care about ABI compatibility with
154 such as an in-kernel language.
157 -----------------
167 casts, use after free bugs, buffer over-runs, and a variety of other
169 conveniently, several groups have investigated this. Ask on the `llvm-dev
170 mailing list <http://lists.llvm.org/mailman/listinfo/llvm-dev>`_ if
173 Language-Specific Optimizations
174 -------------------------------
180 high-level language-specific optimization: LLVM "loses too much
189 SSA-value came from a C "int" or a C "long" on an ILP32 machine (other
190 than debug info). Both get compiled down to an 'i32' value and the
194 have two types in a high-level language that have the same structure
205 user-driven: people want LLVM to include some specific feature, so they
208 Third, it is *possible and easy* to add language-specific optimizations,
210 example, it is easy to add language-specific optimization passes that
218 variety of other language-specific information into the LLVM IR. If you
220 the llvm-dev list. At the very worst, you can always treat LLVM as if it
221 were a "dumb code generator" and implement the high-level optimizations
222 you desire in your front-end, on the language-specific AST.
233 -------------------------------------
242 width of a pointer is trivially target-specific. However, there is a
244 instruction <http://nondot.org/sabre/LLVMNotes/SizeOf-OffsetOf-VariableSizedStructs.txt>`_
248 ------------------------------
255 if you want. It requires your front-end to convert the code into
257 Style <http://en.wikipedia.org/wiki/Continuation-passing_style>`_ and