Skip to content
LangRef.html 80.2 KiB
Newer Older
Chris Lattner's avatar
Chris Lattner committed
value if the first operand is greater than or equal to the second
operand.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Example:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = seteq int   4, 5        <i>; yields {bool}:result = false</i>
Chris Lattner's avatar
Chris Lattner committed
  &lt;result&gt; = setne float 4, 5        <i>; yields {bool}:result = true</i>
  &lt;result&gt; = setlt uint  4, 5        <i>; yields {bool}:result = true</i>
  &lt;result&gt; = setgt sbyte 4, 5        <i>; yields {bool}:result = false</i>
  &lt;result&gt; = setle sbyte 4, 5        <i>; yields {bool}:result = true</i>
  &lt;result&gt; = setge sbyte 4, 5        <i>; yields {bool}:result = false</i>
</pre>
Chris Lattner's avatar
Chris Lattner committed
<!-- ======================================================================= -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsection"> <a name="bitwiseops">Bitwise Binary
Operations</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<p>Bitwise binary operators are used to do various forms of
bit-twiddling in a program.  They are generally very efficient
instructions, and can commonly be strength reduced from other
instructions.  They require two operands, execute an operation on them,
and produce a single value.  The resulting value of the bitwise binary
operators is always the same type as its first operand.</p>
Chris Lattner's avatar
Chris Lattner committed
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_and">'<tt>and</tt>'
Instruction</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = and &lt;ty&gt; &lt;var1&gt;, &lt;var2&gt;   <i>; yields {ty}:result</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
<h5>Overview:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>and</tt>' instruction returns the bitwise logical and of
its two operands.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Arguments:</h5>
<p>The two arguments to the '<tt>and</tt>' instruction must be <a
Chris Lattner's avatar
Chris Lattner committed
 href="#t_integral">integral</a> values.  Both arguments must have
identical types.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Semantics:</h5>
<p>The truth table used for the '<tt>and</tt>' instruction is:</p>
Chris Lattner's avatar
Chris Lattner committed
<p> </p>
<center>
<table border="1" cellspacing="0" cellpadding="4">
Chris Lattner's avatar
Chris Lattner committed
  <tbody>
    <tr>
      <td>In0</td>
      <td>In1</td>
      <td>Out</td>
    </tr>
    <tr>
      <td>0</td>
      <td>0</td>
      <td>0</td>
    </tr>
    <tr>
      <td>0</td>
      <td>1</td>
      <td>0</td>
    </tr>
    <tr>
      <td>1</td>
      <td>0</td>
      <td>0</td>
    </tr>
    <tr>
      <td>1</td>
      <td>1</td>
      <td>1</td>
    </tr>
  </tbody>
</table>
</center>
Chris Lattner's avatar
Chris Lattner committed
<h5>Example:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = and int 4, %var         <i>; yields {int}:result = 4 &amp; %var</i>
Chris Lattner's avatar
Chris Lattner committed
  &lt;result&gt; = and int 15, 40          <i>; yields {int}:result = 8</i>
  &lt;result&gt; = and int 4, 8            <i>; yields {int}:result = 0</i>
</pre>
Chris Lattner's avatar
Chris Lattner committed
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_or">'<tt>or</tt>' Instruction</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = or &lt;ty&gt; &lt;var1&gt;, &lt;var2&gt;   <i>; yields {ty}:result</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
Chris Lattner's avatar
Chris Lattner committed
<h5>Overview:</h5>
<p>The '<tt>or</tt>' instruction returns the bitwise logical inclusive
or of its two operands.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Arguments:</h5>
<p>The two arguments to the '<tt>or</tt>' instruction must be <a
Chris Lattner's avatar
Chris Lattner committed
 href="#t_integral">integral</a> values.  Both arguments must have
identical types.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Semantics:</h5>
<p>The truth table used for the '<tt>or</tt>' instruction is:</p>
Chris Lattner's avatar
Chris Lattner committed
<p> </p>
<center>
<table border="1" cellspacing="0" cellpadding="4">
  <tbody>
    <tr>
      <td>In0</td>
      <td>In1</td>
      <td>Out</td>
    </tr>
    <tr>
      <td>0</td>
      <td>0</td>
      <td>0</td>
    </tr>
    <tr>
      <td>0</td>
      <td>1</td>
      <td>1</td>
    </tr>
    <tr>
      <td>1</td>
      <td>0</td>
      <td>1</td>
    </tr>
    <tr>
      <td>1</td>
      <td>1</td>
      <td>1</td>
    </tr>
  </tbody>
</table>
</center>
Chris Lattner's avatar
Chris Lattner committed
<h5>Example:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = or int 4, %var         <i>; yields {int}:result = 4 | %var</i>
Chris Lattner's avatar
Chris Lattner committed
  &lt;result&gt; = or int 15, 40          <i>; yields {int}:result = 47</i>
  &lt;result&gt; = or int 4, 8            <i>; yields {int}:result = 12</i>
</pre>
Chris Lattner's avatar
Chris Lattner committed
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_xor">'<tt>xor</tt>'
Instruction</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = xor &lt;ty&gt; &lt;var1&gt;, &lt;var2&gt;   <i>; yields {ty}:result</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
<h5>Overview:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>xor</tt>' instruction returns the bitwise logical exclusive
or of its two operands.  The <tt>xor</tt> is used to implement the
"one's complement" operation, which is the "~" operator in C.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Arguments:</h5>
<p>The two arguments to the '<tt>xor</tt>' instruction must be <a
Chris Lattner's avatar
Chris Lattner committed
 href="#t_integral">integral</a> values.  Both arguments must have
identical types.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Semantics:</h5>
<p>The truth table used for the '<tt>xor</tt>' instruction is:</p>
Chris Lattner's avatar
Chris Lattner committed
<p> </p>
<center>
<table border="1" cellspacing="0" cellpadding="4">
  <tbody>
    <tr>
      <td>In0</td>
      <td>In1</td>
      <td>Out</td>
    </tr>
    <tr>
      <td>0</td>
      <td>0</td>
      <td>0</td>
    </tr>
    <tr>
      <td>0</td>
      <td>1</td>
      <td>1</td>
    </tr>
    <tr>
      <td>1</td>
      <td>0</td>
      <td>1</td>
    </tr>
    <tr>
      <td>1</td>
      <td>1</td>
      <td>0</td>
    </tr>
  </tbody>
</table>
</center>
<p> </p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Example:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = xor int 4, %var         <i>; yields {int}:result = 4 ^ %var</i>
Chris Lattner's avatar
Chris Lattner committed
  &lt;result&gt; = xor int 15, 40          <i>; yields {int}:result = 39</i>
  &lt;result&gt; = xor int 4, 8            <i>; yields {int}:result = 12</i>
  &lt;result&gt; = xor int %V, -1          <i>; yields {int}:result = ~%V</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
Chris Lattner's avatar
Chris Lattner committed
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_shl">'<tt>shl</tt>'
Instruction</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = shl &lt;ty&gt; &lt;var1&gt;, ubyte &lt;var2&gt;   <i>; yields {ty}:result</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
<h5>Overview:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>shl</tt>' instruction returns the first operand shifted to
the left a specified number of bits.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Arguments:</h5>
<p>The first argument to the '<tt>shl</tt>' instruction must be an <a
Chris Lattner's avatar
Chris Lattner committed
 href="#t_integer">integer</a> type.  The second argument must be an '<tt>ubyte</tt>'
type.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Semantics:</h5>
<p>The value produced is <tt>var1</tt> * 2<sup><tt>var2</tt></sup>.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Example:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = shl int 4, ubyte %var   <i>; yields {int}:result = 4 &lt;&lt; %var</i>
Chris Lattner's avatar
Chris Lattner committed
  &lt;result&gt; = shl int 4, ubyte 2      <i>; yields {int}:result = 16</i>
  &lt;result&gt; = shl int 1, ubyte 10     <i>; yields {int}:result = 1024</i>
</pre>
Chris Lattner's avatar
Chris Lattner committed
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_shr">'<tt>shr</tt>'
Instruction</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = shr &lt;ty&gt; &lt;var1&gt;, ubyte &lt;var2&gt;   <i>; yields {ty}:result</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
<h5>Overview:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>shr</tt>' instruction returns the first operand shifted to
the right a specified number of bits.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Arguments:</h5>
<p>The first argument to the '<tt>shr</tt>' instruction must be an <a
Chris Lattner's avatar
Chris Lattner committed
 href="#t_integer">integer</a> type.  The second argument must be an '<tt>ubyte</tt>'
type.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Semantics:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>If the first argument is a <a href="#t_signed">signed</a> type, the
most significant bit is duplicated in the newly free'd bit positions. 
If the first argument is unsigned, zero bits shall fill the empty
positions.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Example:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = shr int 4, ubyte %var   <i>; yields {int}:result = 4 &gt;&gt; %var</i>
Chris Lattner's avatar
Chris Lattner committed
  &lt;result&gt; = shr uint 4, ubyte 1     <i>; yields {uint}:result = 2</i>
Chris Lattner's avatar
Chris Lattner committed
  &lt;result&gt; = shr int 4, ubyte 2      <i>; yields {int}:result = 1</i>
Chris Lattner's avatar
Chris Lattner committed
  &lt;result&gt; = shr sbyte 4, ubyte 3    <i>; yields {sbyte}:result = 0</i>
  &lt;result&gt; = shr sbyte -2, ubyte 1   <i>; yields {sbyte}:result = -1</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
Chris Lattner's avatar
Chris Lattner committed
<!-- ======================================================================= -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsection"> <a name="memoryops">Memory Access
Operations</a></div>
Chris Lattner's avatar
Chris Lattner committed
<p>A key design point of an SSA-based representation is how it
represents memory.  In LLVM, no memory locations are in SSA form, which
makes things very simple.  This section describes how to read, write,
allocate and free memory in LLVM.</p>
Chris Lattner's avatar
Chris Lattner committed
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_malloc">'<tt>malloc</tt>'
Instruction</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = malloc &lt;type&gt;, uint &lt;NumElements&gt;     <i>; yields {type*}:result</i>
  &lt;result&gt; = malloc &lt;type&gt;                         <i>; yields {type*}:result</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
<h5>Overview:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>malloc</tt>' instruction allocates memory from the system
heap and returns a pointer to it.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Arguments:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The the '<tt>malloc</tt>' instruction allocates <tt>sizeof(&lt;type&gt;)*NumElements</tt>
bytes of memory from the operating system, and returns a pointer of the
appropriate type to the program.  The second form of the instruction is
a shorter version of the first instruction that defaults to allocating
one element.</p>
<p>'<tt>type</tt>' must be a sized type.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Semantics:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>Memory is allocated using the system "<tt>malloc</tt>" function, and
a pointer is returned.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Example:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  %array  = malloc [4 x ubyte ]                    <i>; yields {[%4 x ubyte]*}:array</i>
Chris Lattner's avatar
Chris Lattner committed
  %size   = <a
 href="#i_add">add</a> uint 2, 2                          <i>; yields {uint}:size = uint 4</i>
  %array1 = malloc ubyte, uint 4                   <i>; yields {ubyte*}:array1</i>
  %array2 = malloc [12 x ubyte], uint %size        <i>; yields {[12 x ubyte]*}:array2</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
Chris Lattner's avatar
Chris Lattner committed
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_free">'<tt>free</tt>'
Instruction</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  free &lt;type&gt; &lt;value&gt;                              <i>; yields {void}</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
<h5>Overview:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>free</tt>' instruction returns memory back to the unused
memory heap, to be reallocated in the future.</p>
<p> </p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Arguments:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>'<tt>value</tt>' shall be a pointer value that points to a value
that was allocated with the '<tt><a href="#i_malloc">malloc</a></tt>'
instruction.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Semantics:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>Access to the memory pointed to by the pointer is not longer defined
after this instruction executes.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Example:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  %array  = <a href="#i_malloc">malloc</a> [4 x ubyte]                    <i>; yields {[4 x ubyte]*}:array</i>
Chris Lattner's avatar
Chris Lattner committed
            free   [4 x ubyte]* %array
</pre>
Chris Lattner's avatar
Chris Lattner committed
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_alloca">'<tt>alloca</tt>'
Instruction</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = alloca &lt;type&gt;, uint &lt;NumElements&gt;  <i>; yields {type*}:result</i>
  &lt;result&gt; = alloca &lt;type&gt;                      <i>; yields {type*}:result</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
<h5>Overview:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>alloca</tt>' instruction allocates memory on the current
stack frame of the procedure that is live until the current function
returns to its caller.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Arguments:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The the '<tt>alloca</tt>' instruction allocates <tt>sizeof(&lt;type&gt;)*NumElements</tt>
bytes of memory on the runtime stack, returning a pointer of the
appropriate type to the program.  The second form of the instruction is
a shorter version of the first that defaults to allocating one element.</p>
<p>'<tt>type</tt>' may be any sized type.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Semantics:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>Memory is allocated, a pointer is returned.  '<tt>alloca</tt>'d
memory is automatically released when the function returns.  The '<tt>alloca</tt>'
instruction is commonly used to represent automatic variables that must
have an address available.  When the function returns (either with the <tt><a
 href="#i_ret">ret</a></tt> or <tt><a href="#i_invoke">invoke</a></tt>
instructions), the memory is reclaimed.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Example:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  %ptr = alloca int                              <i>; yields {int*}:ptr</i>
  %ptr = alloca int, uint 4                      <i>; yields {int*}:ptr</i>
</pre>
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_load">'<tt>load</tt>'
Instruction</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = load &lt;ty&gt;* &lt;pointer&gt;<br>  &lt;result&gt; = volatile load &lt;ty&gt;* &lt;pointer&gt;<br></pre>
<p>The '<tt>load</tt>' instruction is used to read from memory.</p>
Chris Lattner's avatar
Chris Lattner committed
<p>The argument to the '<tt>load</tt>' instruction specifies the memory
address to load from.  The pointer must point to a <a
 href="t_firstclass">first class</a> type.  If the <tt>load</tt> is
marked as <tt>volatile</tt> then the optimizer is not allowed to modify
the number or order of execution of this <tt>load</tt> with other
volatile <tt>load</tt> and <tt><a href="#i_store">store</a></tt>
instructions. </p>
<p>The location of memory pointed to is loaded.</p>
<h5>Examples:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  %ptr = <a href="#i_alloca">alloca</a> int                               <i>; yields {int*}:ptr</i>
  <a
 href="#i_store">store</a> int 3, int* %ptr                          <i>; yields {void}</i>
  %val = load int* %ptr                           <i>; yields {int}:val = int 3</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
Chris Lattner's avatar
Chris Lattner committed
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_store">'<tt>store</tt>'
Instruction</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  store &lt;ty&gt; &lt;value&gt;, &lt;ty&gt;* &lt;pointer&gt;                   <i>; yields {void}</i>
  volatile store &lt;ty&gt; &lt;value&gt;, &lt;ty&gt;* &lt;pointer&gt;                   <i>; yields {void}</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
<h5>Overview:</h5>
<p>The '<tt>store</tt>' instruction is used to write to memory.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Arguments:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>There are two arguments to the '<tt>store</tt>' instruction: a value
to store and an address to store it into.  The type of the '<tt>&lt;pointer&gt;</tt>'
operand must be a pointer to the type of the '<tt>&lt;value&gt;</tt>'
operand. If the <tt>store</tt> is marked as <tt>volatile</tt> then the
optimizer is not allowed to modify the number or order of execution of
this <tt>store</tt> with other volatile <tt>load</tt> and <tt><a
 href="#i_store">store</a></tt> instructions.</p>
<h5>Semantics:</h5>
<p>The contents of memory are updated to contain '<tt>&lt;value&gt;</tt>'
at the location specified by the '<tt>&lt;pointer&gt;</tt>' operand.</p>
<h5>Example:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  %ptr = <a href="#i_alloca">alloca</a> int                               <i>; yields {int*}:ptr</i>
  <a
 href="#i_store">store</a> int 3, int* %ptr                          <i>; yields {void}</i>
Chris Lattner's avatar
Chris Lattner committed
  %val = load int* %ptr                           <i>; yields {int}:val = int 3</i>
</pre>
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_getelementptr">'<tt>getelementptr</tt>'
Instruction</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = getelementptr &lt;ty&gt;* &lt;ptrval&gt;{, long &lt;aidx&gt;|, ubyte &lt;sidx&gt;}*<br></pre>
Chris Lattner's avatar
Chris Lattner committed
<h5>Overview:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>getelementptr</tt>' instruction is used to get the address
of a subelement of an aggregate data structure.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Arguments:</h5>
<p>This instruction takes a list of <tt>long</tt> values and <tt>ubyte</tt>
Chris Lattner's avatar
Chris Lattner committed
constants that indicate what form of addressing to perform.  The actual
types of the arguments provided depend on the type of the first pointer
argument.  The '<tt>getelementptr</tt>' instruction is used to index
down through the type levels of a structure.</p>
<p>For example, let's consider a C code fragment and how it gets
compiled to LLVM:</p>
<pre>struct RT {<br>  char A;<br>  int B[10][20];<br>  char C;<br>};<br>struct ST {<br>  int X;<br>  double Y;<br>  struct RT Z;<br>};<br><br>int *foo(struct ST *s) {<br>  return &amp;s[1].Z.B[5][13];<br>}<br></pre>
<p>The LLVM code generated by the GCC frontend is:</p>
Chris Lattner's avatar
Chris Lattner committed
<pre>%RT = type { sbyte, [10 x [20 x int]], sbyte }<br>%ST = type { int, double, %RT }<br><br>int* "foo"(%ST* %s) {<br>  %reg = getelementptr %ST* %s, long 1, ubyte 2, ubyte 1, long 5, long 13<br>  ret int* %reg<br>}<br></pre>
Chris Lattner's avatar
Chris Lattner committed
<h5>Semantics:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The index types specified for the '<tt>getelementptr</tt>'
instruction depend on the pointer type that is being index into. <a
 href="t_pointer">Pointer</a> and <a href="t_array">array</a> types
require '<tt>long</tt>' values, and <a href="t_struct">structure</a>
types require '<tt>ubyte</tt>' <b>constants</b>.</p>
<p>In the example above, the first index is indexing into the '<tt>%ST*</tt>'
Chris Lattner's avatar
Chris Lattner committed
type, which is a pointer, yielding a '<tt>%ST</tt>' = '<tt>{ int,
double, %RT }</tt>' type, a structure.  The second index indexes into
the third element of the structure, yielding a '<tt>%RT</tt>' = '<tt>{
sbyte, [10 x [20 x int]], sbyte }</tt>' type, another structure.  The
third index indexes into the second element of the structure, yielding
a '<tt>[10 x [20 x int]]</tt>' type, an array.  The two dimensions of
the array are subscripted into, yielding an '<tt>int</tt>' type.  The '<tt>getelementptr</tt>'
instruction return a pointer to this element, thus yielding a '<tt>int*</tt>'
type.</p>
<p>Note that it is perfectly legal to index partially through a
structure, returning a pointer to an inner element.  Because of this,
the LLVM code for the given testcase is equivalent to:</p>
<pre>int* "foo"(%ST* %s) {<br>  %t1 = getelementptr %ST* %s , long 1                        <i>; yields %ST*:%t1</i>
  %t2 = getelementptr %ST* %t1, long 0, ubyte 2               <i>; yields %RT*:%t2</i>
  %t3 = getelementptr %RT* %t2, long 0, ubyte 1               <i>; yields [10 x [20 x int]]*:%t3</i>
  %t4 = getelementptr [10 x [20 x int]]* %t3, long 0, long 5  <i>; yields [20 x int]*:%t4</i>
  %t5 = getelementptr [20 x int]* %t4, long 0, long 13        <i>; yields int*:%t5</i>
Chris Lattner's avatar
Chris Lattner committed
<h5>Example:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  <i>; yields [12 x ubyte]*:aptr</i>
  %aptr = getelementptr {int, [12 x ubyte]}* %sptr, long 0, ubyte 1<br></pre>
<h5>&nbsp;Note To The Novice:</h5>
When using indexing into global arrays with the  '<tt>getelementptr</tt>'
instruction, you must remember that the&nbsp; </div>
Chris Lattner's avatar
Chris Lattner committed
<!-- ======================================================================= -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsection"> <a name="otherops">Other Operations</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<p>The instructions in this catagory are the "miscellaneous"
instructions, which defy better classification.</p>
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_phi">'<tt>phi</tt>'
Instruction</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = phi &lt;ty&gt; [ &lt;val0&gt;, &lt;label0&gt;], ...<br></pre>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>phi</tt>' instruction is used to implement the &#966; node in
the SSA graph representing the function.</p>
Chris Lattner's avatar
Chris Lattner committed
<p>The type of the incoming values are specified with the first type
field. After this, the '<tt>phi</tt>' instruction takes a list of pairs
as arguments, with one pair for each predecessor basic block of the
current block.  Only values of <a href="#t_firstclass">first class</a>
type may be used as the value arguments to the PHI node.  Only labels
may be used as the label arguments.</p>
<p>There must be no non-phi instructions between the start of a basic
block and the PHI instructions: i.e. PHI instructions must be first in
a basic block.</p>
Chris Lattner's avatar
Chris Lattner committed
<p>At runtime, the '<tt>phi</tt>' instruction logically takes on the
value specified by the parameter, depending on which basic block we
came from in the last <a href="#terminators">terminator</a> instruction.</p>
Chris Lattner's avatar
Chris Lattner committed
<pre>Loop:       ; Infinite loop that counts from 0 on up...<br>  %indvar = phi uint [ 0, %LoopHeader ], [ %nextindvar, %Loop ]<br>  %nextindvar = add uint %indvar, 1<br>  br label %Loop<br></pre>
Chris Lattner's avatar
Chris Lattner committed
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_cast">'<tt>cast .. to</tt>'
Instruction</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = cast &lt;ty&gt; &lt;value&gt; to &lt;ty2&gt;             <i>; yields ty2</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
<h5>Overview:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>cast</tt>' instruction is used as the primitive means to
convert integers to floating point, change data type sizes, and break
type safety (by casting pointers).</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Arguments:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>cast</tt>' instruction takes a value to cast, which must be
a first class value, and a type to cast it to, which must also be a <a
 href="#t_firstclass">first class</a> type.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Semantics:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>This instruction follows the C rules for explicit casts when
determining how the data being cast must change to fit in its new
container.</p>
<p>When casting to bool, any value that would be considered true in the
context of a C '<tt>if</tt>' condition is converted to the boolean '<tt>true</tt>'
values, all else are '<tt>false</tt>'.</p>
Chris Lattner's avatar
Chris Lattner committed
<p>When extending an integral value from a type of one signness to
another (for example '<tt>sbyte</tt>' to '<tt>ulong</tt>'), the value
is sign-extended if the <b>source</b> value is signed, and
zero-extended if the source value is unsigned. <tt>bool</tt> values
are always zero extended into either zero or one.</p>
Chris Lattner's avatar
Chris Lattner committed
<pre>  %X = cast int 257 to ubyte              <i>; yields ubyte:1</i>
  %Y = cast int 123 to bool               <i>; yields bool:true</i>
Chris Lattner's avatar
Chris Lattner committed
</pre>
Chris Lattner's avatar
Chris Lattner committed
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_call">'<tt>call</tt>'
Instruction</a> </div>
Chris Lattner's avatar
Chris Lattner committed
<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;result&gt; = call &lt;ty&gt;* &lt;fnptrval&gt;(&lt;param list&gt;)<br></pre>
Chris Lattner's avatar
Chris Lattner committed
<h5>Overview:</h5>
<p>The '<tt>call</tt>' instruction represents a simple function call.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Arguments:</h5>
<p>This instruction requires several arguments:</p>
Chris Lattner's avatar
Chris Lattner committed
  <li>
    <p>'<tt>ty</tt>': shall be the signature of the pointer to function
value   being invoked.  The argument types must match the types implied
by this   signature.</p>
  </li>
  <li>
    <p>'<tt>fnptrval</tt>': An LLVM value containing a pointer to a
function   to be invoked. In most cases, this is a direct function
invocation, but   indirect <tt>call</tt>s are just as possible,
calling an arbitrary pointer to   function values.</p>
  </li>
  <li>
    <p>'<tt>function args</tt>': argument list whose types match the
function   signature argument types.  If the function signature
indicates the function   accepts a variable number of arguments, the
extra arguments can be   specified.</p>
  </li>
Chris Lattner's avatar
Chris Lattner committed
<h5>Semantics:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>call</tt>' instruction is used to cause control flow to
transfer to a specified function, with its incoming arguments bound to
the specified values. Upon a '<tt><a href="#i_ret">ret</a></tt>'
instruction in the called function, control flow continues with the
instruction after the function call, and the return value of the
function is bound to the result argument.  This is a simpler case of
the <a href="#i_invoke">invoke</a> instruction.</p>
Chris Lattner's avatar
Chris Lattner committed
<h5>Example:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  %retval = call int %test(int %argc)<br>  call int(sbyte*, ...) *%printf(sbyte* %msg, int 12, sbyte 42);<br></pre>
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_vanext">'<tt>vanext</tt>'
Instruction</a> </div>
<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;resultarglist&gt; = vanext &lt;va_list&gt; &lt;arglist&gt;, &lt;argty&gt;<br></pre>
<h5>Overview:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>vanext</tt>' instruction is used to access arguments passed
through the "variable argument" area of a function call.  It is used to
implement the <tt>va_arg</tt> macro in C.</p>
<h5>Arguments:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>This instruction takes a <tt>valist</tt> value and the type of the
argument. It returns another <tt>valist</tt>.</p>
<h5>Semantics:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>vanext</tt>' instruction advances the specified <tt>valist</tt>
past an argument of the specified type.  In conjunction with the <a
 href="#i_vaarg"><tt>vaarg</tt></a> instruction, it is used to implement
the <tt>va_arg</tt> macro available in C.  For more information, see
the variable argument handling <a href="#int_varargs">Intrinsic
Functions</a>.</p>
<p>It is legal for this instruction to be called in a function which
does not take a variable number of arguments, for example, the <tt>vfprintf</tt>
function.</p>
<p><tt>vanext</tt> is an LLVM instruction instead of an <a
Chris Lattner's avatar
Chris Lattner committed
 href="#intrinsics">intrinsic function</a> because it takes an type as
an argument.</p>
<h5>Example:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>See the <a href="#int_varargs">variable argument processing</a>
section.</p>
<!-- _______________________________________________________________________ -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_subsubsection"> <a name="i_vaarg">'<tt>vaarg</tt>'
Instruction</a> </div>
<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  &lt;resultval&gt; = vaarg &lt;va_list&gt; &lt;arglist&gt;, &lt;argty&gt;<br></pre>
<h5>Overview:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>vaarg</tt>' instruction is used to access arguments passed
through the "variable argument" area of a function call.  It is used to
implement the <tt>va_arg</tt> macro in C.</p>
<h5>Arguments:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>This instruction takes a <tt>valist</tt> value and the type of the
argument. It returns a value of the specified argument type.</p>
<h5>Semantics:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>vaarg</tt>' instruction loads an argument of the specified
type from the specified <tt>va_list</tt>.  In conjunction with the <a
 href="#i_vanext"><tt>vanext</tt></a> instruction, it is used to
implement the <tt>va_arg</tt> macro available in C.  For more
information, see the variable argument handling <a href="#int_varargs">Intrinsic
Functions</a>.</p>
<p>It is legal for this instruction to be called in a function which
does not take a variable number of arguments, for example, the <tt>vfprintf</tt>
function.</p>
<p><tt>vaarg</tt> is an LLVM instruction instead of an <a
Chris Lattner's avatar
Chris Lattner committed
 href="#intrinsics">intrinsic function</a> because it takes an type as
an argument.</p>
<h5>Example:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>See the <a href="#int_varargs">variable argument processing</a>
section.</p>
<!-- *********************************************************************** -->
Chris Lattner's avatar
Chris Lattner committed
<div class="doc_section"> <a name="intrinsics">Intrinsic Functions</a> </div>
<!-- *********************************************************************** -->

<p>LLVM supports the notion of an "intrinsic function".  These functions have
well known names and semantics, and are required to follow certain
restrictions. Overall, these instructions represent an extension mechanism for
the LLVM language that does not require changing all of the transformations in
LLVM to add to the language (or the bytecode reader/writer, the parser,
etc...).</p>

<p>Intrinsic function names must all start with an "<tt>llvm.</tt>" prefix, this
prefix is reserved in LLVM for intrinsic names, thus functions may not be named
this.  Intrinsic functions must always be external functions: you cannot define
the body of intrinsic functions.  Intrinsic functions may only be used in call
or invoke instructions: it is illegal to take the address of an intrinsic
function.  Additionally, because intrinsic functions are part of the LLVM
language, it is required that they all be documented here if any are added.</p>


<p>
Adding an intrinsic to LLVM is straight-forward if it is possible to express the
concept in LLVM directly (ie, code generator support is not _required_).  To do
this, extend the default implementation of the IntrinsicLowering class to handle
the intrinsic.  Code generators use this class to lower intrinsics they do not
understand to raw LLVM instructions that they do.
</p>

<!-- ======================================================================= -->
<div class="doc_subsection">
  <a name="int_varargs">Variable Argument Handling Intrinsics</a>
</div>

<div class="doc_text">
<p>Variable argument support is defined in LLVM with the <a
Chris Lattner's avatar
Chris Lattner committed
 href="#i_vanext"><tt>vanext</tt></a> instruction and these three
intrinsic functions.  These functions are related to the similarly
named macros defined in the <tt>&lt;stdarg.h&gt;</tt> header file.</p>
<p>All of these functions operate on arguments that use a
target-specific value type "<tt>va_list</tt>".  The LLVM assembly
language reference manual does not define what this type is, so all
transformations should be prepared to handle intrinsics with any type
used.</p>
<p>This example shows how the <a href="#i_vanext"><tt>vanext</tt></a>
Chris Lattner's avatar
Chris Lattner committed
instruction and the variable argument handling intrinsic functions are
used.</p>
<pre>
int %test(int %X, ...) {
  ; Initialize variable argument processing
  %ap = call sbyte* %<a href="#i_va_start">llvm.va_start</a>()

  ; Read a single integer argument
  %tmp = vaarg sbyte* %ap, int

  ; Advance to the next argument
  %ap2 = vanext sbyte* %ap, int

  ; Demonstrate usage of llvm.va_copy and llvm.va_end
  %aq = call sbyte* %<a href="#i_va_copy">llvm.va_copy</a>(sbyte* %ap2)
  call void %<a href="#i_va_end">llvm.va_end</a>(sbyte* %aq)

  ; Stop processing of arguments.
  call void %<a href="#i_va_end">llvm.va_end</a>(sbyte* %ap2)
  ret int %tmp
}
</pre>
<!-- _______________________________________________________________________ -->
<div class="doc_subsubsection">
  <a name="i_va_start">'<tt>llvm.va_start</tt>' Intrinsic</a>
</div>


<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  call va_list ()* %llvm.va_start()<br></pre>
<h5>Overview:</h5>
<p>The '<tt>llvm.va_start</tt>' intrinsic returns a new <tt>&lt;arglist&gt;</tt>
for subsequent use by the variable argument intrinsics.</p>
<h5>Semantics:</h5>
<p>The '<tt>llvm.va_start</tt>' intrinsic works just like the <tt>va_start</tt>
Chris Lattner's avatar
Chris Lattner committed
macro available in C.  In a target-dependent way, it initializes and
returns a <tt>va_list</tt> element, so that the next <tt>vaarg</tt>
will produce the first variable argument passed to the function.  Unlike
the C <tt>va_start</tt> macro, this intrinsic does not need to know the
last argument of the function, the compiler can figure that out.</p>
<p>Note that this intrinsic function is only legal to be called from
within the body of a variable argument function.</p>
<!-- _______________________________________________________________________ -->
<div class="doc_subsubsection">
 <a name="i_va_end">'<tt>llvm.va_end</tt>' Intrinsic</a>
</div>

<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  call void (va_list)* %llvm.va_end(va_list &lt;arglist&gt;)<br></pre>
<h5>Overview:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>llvm.va_end</tt>' intrinsic destroys <tt>&lt;arglist&gt;</tt>
which has been initialized previously with <tt><a href="#i_va_start">llvm.va_start</a></tt>
or <tt><a href="#i_va_copy">llvm.va_copy</a></tt>.</p>
<h5>Arguments:</h5>
<p>The argument is a <tt>va_list</tt> to destroy.</p>
<h5>Semantics:</h5>
<p>The '<tt>llvm.va_end</tt>' intrinsic works just like the <tt>va_end</tt>
Chris Lattner's avatar
Chris Lattner committed
macro available in C.  In a target-dependent way, it destroys the <tt>va_list</tt>.
Calls to <a href="#i_va_start"><tt>llvm.va_start</tt></a> and <a
 href="#i_va_copy"><tt>llvm.va_copy</tt></a> must be matched exactly
with calls to <tt>llvm.va_end</tt>.</p>
<!-- _______________________________________________________________________ -->
<div class="doc_subsubsection">
  <a name="i_va_copy">'<tt>llvm.va_copy</tt>' Intrinsic</a>
</div>

<h5>Syntax:</h5>
Chris Lattner's avatar
Chris Lattner committed
<pre>  call va_list (va_list)* %llvm.va_copy(va_list &lt;destarglist&gt;)<br></pre>
<h5>Overview:</h5>
Chris Lattner's avatar
Chris Lattner committed
<p>The '<tt>llvm.va_copy</tt>' intrinsic copies the current argument
position from the source argument list to the destination argument list.</p>
<h5>Arguments:</h5>
<p>The argument is the <tt>va_list</tt> to copy.</p>
<h5>Semantics:</h5>
<p>The '<tt>llvm.va_copy</tt>' intrinsic works just like the <tt>va_copy</tt>
Chris Lattner's avatar
Chris Lattner committed
macro available in C.  In a target-dependent way, it copies the source <tt>va_list</tt>
element into the returned list.  This intrinsic is necessary because the <tt><a
 href="i_va_start">llvm.va_start</a></tt> intrinsic may be arbitrarily
complex and require memory allocation, for example.</p>
<!-- ======================================================================= -->
<div class="doc_subsection">
  <a name="int_libc">Standard C Library Intrinsics</a>
</div>

<div class="doc_text">
<p>

</p>

</div>

<!-- _______________________________________________________________________ -->
<div class="doc_subsubsection">
  <a name="i_memcpy">'<tt>llvm.memcpy</tt>' Intrinsic</a>
</div>

<div class="doc_text">

<h5>Syntax:</h5>
<pre>
  call void (sbyte*, sbyte*, uint, uint)* %llvm.memcpy(sbyte* &lt;dest&gt;, sbyte* &lt;src&gt;,
                                                       uint &lt;len&gt;, uint &lt;align&gt;)
</pre>

<h5>Overview:</h5>

<p>
The '<tt>llvm.memcpy</tt>' intrinsic copies a block of memory from the source
location to the destination location.
</p>

<p>
Note that, unlike the standard libc function, the <tt>llvm.memcpy</tt> intrinsic
does not return a value, and takes an extra alignment argument.
</p>

<h5>Arguments:</h5>

<p>
The first argument is a pointer to the destination, the second is a pointer to
the source.  The third argument is an (arbitrarily sized) integer argument
specifying the number of bytes to copy, and the fourth argument is the alignment
of the source and destination locations.
</p>

<h5>Semantics:</h5>

<p>
The '<tt>llvm.memcpy</tt>' intrinsic copies a block of memory from the source
location to the destination location, which are not allowed to overlap.  It
copies "len" bytes of memory over.  If the argument is known to be aligned to
some boundary, this can be specified as the fourth argument, otherwise it should
be set to 0 or 1.
</p>
</div>



<!-- ======================================================================= -->
<div class="doc_subsection">
  <a name="int_debugger">Debugger Intrinsics</a>
</div>

<div class="doc_text">
<p>
The LLVM debugger intrinsics (which all start with <tt>llvm.dbg.</tt> prefix),
are described in the <a
href="SourceLevelDebugging.html#format_common_intrinsics">LLVM Source Level
Debugging</a> document.
</p>
</div>


Chris Lattner's avatar
Chris Lattner committed
<!-- *********************************************************************** -->
<hr>
Chris Lattner's avatar
Chris Lattner committed
<address><a href="mailto:sabre@nondot.org">Chris Lattner</a></address>
<a href="http://llvm.cs.uiuc.edu">The LLVM Compiler Infrastructure</a> <br>
Last modified: $Date$ </div>