2009-07-01 06:56:43 +08:00
|
|
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
|
|
|
|
"http://www.w3.org/TR/html4/strict.dtd">
|
|
|
|
<!-- Material used from: HTML 4.01 specs: http://www.w3.org/TR/html401/ -->
|
|
|
|
<html>
|
|
|
|
<head>
|
|
|
|
<META http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
|
2009-07-02 01:16:20 +08:00
|
|
|
<title>"compiler-rt" Runtime Library</title>
|
2009-07-01 06:56:43 +08:00
|
|
|
<link type="text/css" rel="stylesheet" href="menu.css">
|
|
|
|
<link type="text/css" rel="stylesheet" href="content.css">
|
|
|
|
</head>
|
2009-07-03 05:34:35 +08:00
|
|
|
|
2009-07-01 06:56:43 +08:00
|
|
|
<body>
|
|
|
|
<!--#include virtual="menu.html.incl"-->
|
|
|
|
<div id="content">
|
|
|
|
<!--*********************************************************************-->
|
2009-07-02 01:16:20 +08:00
|
|
|
<h1>"compiler-rt" Runtime Library</h1>
|
2009-07-01 06:56:43 +08:00
|
|
|
<!--*********************************************************************-->
|
|
|
|
|
2009-07-02 01:16:20 +08:00
|
|
|
<p>The compiler-rt project is a simple library that provides an implementation
|
2009-07-01 06:56:43 +08:00
|
|
|
of the low-level target-specific hooks required by code generation and
|
|
|
|
other runtime components. For example, when compiling for a 32-bit target,
|
|
|
|
converting a double to a 64-bit unsigned integer is compiling into a runtime
|
2009-07-02 01:16:20 +08:00
|
|
|
call to the "__fixunsdfdi" function. The compiler-rt library provides
|
2009-07-01 06:56:43 +08:00
|
|
|
optimized implementations of this and other low-level routines.</p>
|
2009-07-03 05:29:19 +08:00
|
|
|
|
|
|
|
<p>All of the code in the compiler-rt project is available under the standard
|
|
|
|
<a href="http://llvm.org/docs/DeveloperPolicy.html#license">LLVM
|
|
|
|
License</a>, a "BSD-style" license.</p>
|
2009-07-01 06:56:43 +08:00
|
|
|
|
|
|
|
<!--=====================================================================-->
|
|
|
|
<h2 id="goals">Goals</h2>
|
|
|
|
<!--=====================================================================-->
|
|
|
|
|
2009-07-02 01:16:20 +08:00
|
|
|
<p>Different targets require different routines. The compiler-rt project aims
|
2009-07-01 06:56:43 +08:00
|
|
|
to implement these routines in both target-independent C form as well as
|
|
|
|
providing heavily optimized assembly versions of the routines in some
|
2009-07-02 01:16:20 +08:00
|
|
|
cases. It should be very easy to bring compiler-rt to support a new
|
2009-07-01 06:56:43 +08:00
|
|
|
target by adding the new routines needed by that target.</p>
|
|
|
|
|
2009-07-02 01:16:20 +08:00
|
|
|
<p>Where it make sense, the compiler-rt project aims to implement interfaces
|
2009-07-01 06:56:43 +08:00
|
|
|
that are drop-in compatible with the libgcc interfaces.</p>
|
|
|
|
|
|
|
|
<!--=====================================================================-->
|
|
|
|
<h2 id="features">Features</h2>
|
|
|
|
<!--=====================================================================-->
|
|
|
|
|
2009-07-02 01:16:20 +08:00
|
|
|
<p>The current feature set of compiler-rt is:</p>
|
2009-07-01 06:56:43 +08:00
|
|
|
|
|
|
|
<ul>
|
2009-08-04 12:48:38 +08:00
|
|
|
<li>Full support for the libgcc interfaces on supported targets.</li>
|
2009-07-01 06:56:43 +08:00
|
|
|
<li>High performance hand tuned implementations of commonly used functions
|
|
|
|
like __floatundidf in assembly that are dramatically faster than the
|
|
|
|
libgcc implementations.</li>
|
|
|
|
<li>A target-independent implementation of the Apple "Blocks" runtime
|
|
|
|
interfaces.</li>
|
|
|
|
</ul>
|
2009-08-03 09:26:42 +08:00
|
|
|
|
2009-08-04 12:48:38 +08:00
|
|
|
<!--=====================================================================-->
|
|
|
|
<h2 id="requirements">Platform Support</h2>
|
|
|
|
<!--=====================================================================-->
|
|
|
|
|
|
|
|
<p>Compiler-RT is known to work on the following platforms:</p>
|
|
|
|
|
|
|
|
<li>Machine Architectures:
|
|
|
|
<ul>
|
|
|
|
<li>i386</li>
|
|
|
|
<li>X86-64</li>
|
|
|
|
<li>PowerPC</li>
|
|
|
|
<li>PowerPC 64</li>
|
|
|
|
</ul></li>
|
|
|
|
|
|
|
|
<table cellpadding="3" summary="Known Compiler-RT platforms">
|
|
|
|
<tr>
|
|
|
|
<th>OS</th>
|
|
|
|
<th>Arch</th>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>AuroraUX</td>
|
|
|
|
<td>All<sup>
|
|
|
|
</tr>
|
2009-09-03 19:13:06 +08:00
|
|
|
<tr>
|
|
|
|
<td>FreeBSD</td>
|
|
|
|
<td>All<sup>
|
|
|
|
</tr>
|
2009-08-04 12:48:38 +08:00
|
|
|
<tr>
|
|
|
|
<td>Linux</td>
|
|
|
|
<td>All<sup>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>Darwin</td>
|
|
|
|
<td>All<sup>
|
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
|
2009-08-03 09:26:42 +08:00
|
|
|
<!--=====================================================================-->
|
|
|
|
<h2 id="dir-structure">Source Structure</h2>
|
|
|
|
<!--=====================================================================-->
|
|
|
|
|
|
|
|
<p>A short explanation of the directory structure of compiler-rt:</p>
|
|
|
|
|
|
|
|
<p>For testing it is possible to build a generic library and an optimized library.
|
|
|
|
The optimized library is formed by overlaying the optimized versions onto the generic library.
|
|
|
|
Of course, some architectures have additional functions,
|
|
|
|
so the optimized library may have functions not found in the generic version.</p>
|
|
|
|
|
|
|
|
<ul>
|
|
|
|
<li> lib/ Is a generic portable implementations.</li>
|
2009-08-03 09:29:04 +08:00
|
|
|
<li> lib/(arch) has optimized version for the following supported architectures:
|
2009-08-03 09:26:42 +08:00
|
|
|
<ul>
|
|
|
|
<li>i386</li>
|
|
|
|
<li>X86-64</li>
|
|
|
|
<li>PowerPC</li>
|
|
|
|
<li>PowerPC 64</li>
|
|
|
|
</ul></li>
|
|
|
|
</ul>
|
|
|
|
|
2009-07-01 06:56:43 +08:00
|
|
|
<!--=====================================================================-->
|
|
|
|
<h2>Get it and get involved!</h2>
|
|
|
|
<!--=====================================================================-->
|
|
|
|
|
2009-07-02 01:16:20 +08:00
|
|
|
<p>To check out the code, use:</p>
|
|
|
|
|
|
|
|
<ul>
|
|
|
|
<li>svn co http://llvm.org/svn/llvm-project/compiler-rt/trunk compiler-rt</li>
|
|
|
|
<li>cd compiler-rt</li>
|
|
|
|
<li>make</li>
|
|
|
|
</ul>
|
|
|
|
|
|
|
|
<p>Note that the library will probably only build out of the box on Darwin,
|
|
|
|
but patches to improve portability are definitely welcome.</p>
|
|
|
|
|
|
|
|
<p>compiler-rt doesn't have its own mailing list, if you have questions please
|
|
|
|
email the <a
|
|
|
|
href="http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev">llvmdev</a> mailing
|
|
|
|
list. Commits to the compiler-rt SVN module are automatically sent to the
|
|
|
|
<a
|
|
|
|
href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits">llvm-commits</a>
|
|
|
|
mailing list.</p>
|
2009-07-01 06:56:43 +08:00
|
|
|
</div>
|
|
|
|
</body>
|
|
|
|
</html>
|