aboutsummaryrefslogtreecommitdiff
path: root/docs/FAQ.html
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2006-07-19 18:19:59 +0000
committerChris Lattner <sabre@nondot.org>2006-07-19 18:19:59 +0000
commitaf7fd20b54a88e60f5a6420de3f37588215434d9 (patch)
treef2d4efeb3986a2dcdc44cde9262e0ab2217b6319 /docs/FAQ.html
parentf19807cecb3a6f440acb34a90fb3614f17afd308 (diff)
Answer the FAQ: "can llvm convert C++ code to C?"
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@29212 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'docs/FAQ.html')
-rw-r--r--docs/FAQ.html57
1 files changed, 57 insertions, 0 deletions
diff --git a/docs/FAQ.html b/docs/FAQ.html
index e015f91df5..2ab00ac7e9 100644
--- a/docs/FAQ.html
+++ b/docs/FAQ.html
@@ -79,6 +79,8 @@
How can I disable all optimizations when compiling code using the LLVM GCC front end?
</li>
+ <li><a href="#translatec++">Can I use LLVM to convert C++ code to C code?</a></li>
+
</ol>
</li>
@@ -501,6 +503,61 @@ code that you desire.
</p>
</div>
+
+<div class="question">
+<p>
+<a name="translatec++">Can I use LLVM to convert C++ code to C code?</a>
+</p>
+</div>
+
+<div class="answer">
+<p>Yes, you can use LLVM to convert code from any language LLVM supports to C.
+Note that the generated C code will be very low level (all loops are lowered
+to gotos, etc) and not very pretty (comments are stripped, original source
+formatting is totally lost, variables are renamed, expressions are regrouped),
+so this may not be what you're looking for. However, this is a good way to add
+C++ support for a processor that does not otherwise have a C++ compiler.
+</p>
+
+<p>Use commands like this:</p>
+
+<ol>
+<li><p>Compile your program as normal with llvm-g++:</p></li>
+
+<div class="doc_code">$ llvm-g++ x.cpp -o program</div>
+
+<p>or:</p>
+
+<div class="doc_code">
+ llvm-g++ a.cpp -c
+ llvm-g++ b.cpp -c
+ llvm-g++ a.o b.o -o program
+</div>
+
+<p>With llvm-gcc3, this will generate program and program.bc. The .bc file is
+the LLVM version of the program all linked together.</p>
+
+<li><p>Convert the LLVM code to C code, using the LLC tool with the C
+backend:</p></li>
+
+<div class="doc_code">$ llc -march=c program.bc -o program.c</div>
+
+<li><p>Finally, compile the c file:</p></li>
+
+<div class="doc_code">$ cc x.c</div>
+
+</ol>
+
+<p>Note that, by default, the C backend does not support exception handling.
+If you want/need it for a certain program, you can enable it by passing
+"-enable-correct-eh-support" to the llc program. The resultant code will
+use setjmp/longjmp to implement exception support that is correct but
+relatively slow.
+</p>
+</div>
+
+
+
<!-- *********************************************************************** -->
<div class="doc_section">
<a name="cfe_code">Questions about code generated by the GCC front-end</a>