summaryrefslogtreecommitdiffstats
path: root/llvm/docs
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2011-11-29 19:08:23 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2011-11-29 19:08:23 +0000
commit866a22aba71aa17287da6e9da8ae8b69d43ca3a2 (patch)
treeb1ee2e0f1c7ec4ac176a85e0339bfabb3c52cdf5 /llvm/docs
parent514b636adab8c9934f82ba9a4beb600e2b3072e7 (diff)
downloadbcm5719-llvm-866a22aba71aa17287da6e9da8ae8b69d43ca3a2.tar.gz
bcm5719-llvm-866a22aba71aa17287da6e9da8ae8b69d43ca3a2.zip
Release notes for segmented stacks.
Patch by Sanjoy Das. llvm-svn: 145416
Diffstat (limited to 'llvm/docs')
-rw-r--r--llvm/docs/ReleaseNotes.html5
-rw-r--r--llvm/docs/SegmentedStacks.html8
2 files changed, 5 insertions, 8 deletions
diff --git a/llvm/docs/ReleaseNotes.html b/llvm/docs/ReleaseNotes.html
index c6657b94d66..faf9a4bd2b3 100644
--- a/llvm/docs/ReleaseNotes.html
+++ b/llvm/docs/ReleaseNotes.html
@@ -936,7 +936,10 @@ be used to verify some algorithms.
make it run faster:</p>
<ul>
-<li>XXX: Segmented stacks.</li>
+<li>LLVM can now produce code that works with libgcc
+ to <a href="SegmentedStacks.html">dynamically allocate stack
+ segments</a>, as opposed to allocating a worst-case chunk of
+ virtual memory for each thread.</li>
<li>LLVM generates substantially better code for indirect gotos due to a new
tail duplication pass, which can be a substantial performance win for
interpreter loops that use them.</li>
diff --git a/llvm/docs/SegmentedStacks.html b/llvm/docs/SegmentedStacks.html
index a91b109308a..16f55074732 100644
--- a/llvm/docs/SegmentedStacks.html
+++ b/llvm/docs/SegmentedStacks.html
@@ -20,18 +20,12 @@
<li><a href="#alloca">Variable Sized Allocas</a></li>
</ol>
</li>
- <li><a href="#results">Results</a>
- <ol>
- <li><a href="#go">Go on LLVM</a></li>
- <li><a href="#abi">Runtime ABI</a></li>
- </ol>
- </li>
</ol>
<h2><a name="intro">Introduction</a></h2>
<div>
<p>
- Segmented stack allows stack space to be allocated incrementally than as a monolithic chunk (of some worst case size) at thread initialization. This is done by allocating stack blocks (henceforth called <em>stacklets</em>) and linking them into a doubly linked list. The function prologue is responsible for checking if the current stacklet has enough space for the function to execute; and if not, call into the libgcc runtime to allocate more stack space. Support for segmented stacks on x86 / Linux is currently being worked on.
+ Segmented stack allows stack space to be allocated incrementally than as a monolithic chunk (of some worst case size) at thread initialization. This is done by allocating stack blocks (henceforth called <em>stacklets</em>) and linking them into a doubly linked list. The function prologue is responsible for checking if the current stacklet has enough space for the function to execute; and if not, call into the libgcc runtime to allocate more stack space. When using <tt>llc</tt>, segmented stacks can be enabled by adding <tt>-segmented-stacks</tt> to the command line.
</p>
<p>
The runtime functionality is <a href="http://gcc.gnu.org/wiki/SplitStacks">already there in libgcc</a>.
OpenPOWER on IntegriCloud