[www-releases] r368037 - Add 8.0.1 LLVM docs
Tom Stellard via llvm-commits
llvm-commits at lists.llvm.org
Tue Aug 6 06:51:06 PDT 2019
Added: www-releases/trunk/8.0.1/docs/LangRef.html
URL: http://llvm.org/viewvc/llvm-project/www-releases/trunk/8.0.1/docs/LangRef.html?rev=368037&view=auto
==============================================================================
--- www-releases/trunk/8.0.1/docs/LangRef.html (added)
+++ www-releases/trunk/8.0.1/docs/LangRef.html Tue Aug 6 06:51:02 2019
@@ -0,0 +1,16541 @@
+
+
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+
+<html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <meta http-equiv="X-UA-Compatible" content="IE=Edge" />
+ <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+ <title>LLVM Language Reference Manual — LLVM 8 documentation</title>
+ <link rel="stylesheet" href="_static/llvm-theme.css" type="text/css" />
+ <link rel="stylesheet" href="_static/pygments.css" type="text/css" />
+ <script type="text/javascript" id="documentation_options" data-url_root="./" src="_static/documentation_options.js"></script>
+ <script type="text/javascript" src="_static/jquery.js"></script>
+ <script type="text/javascript" src="_static/underscore.js"></script>
+ <script type="text/javascript" src="_static/doctools.js"></script>
+ <link rel="index" title="Index" href="genindex.html" />
+ <link rel="search" title="Search" href="search.html" />
+ <link rel="next" title="Building LLVM with CMake" href="CMake.html" />
+ <link rel="prev" title="Overview" href="index.html" />
+<style type="text/css">
+ table.right { float: right; margin-left: 20px; }
+ table.right td { border: 1px solid #ccc; }
+</style>
+
+ </head><body>
+<div class="logo">
+ <a href="index.html">
+ <img src="_static/logo.png"
+ alt="LLVM Logo" width="250" height="88"/></a>
+</div>
+
+ <div class="related" role="navigation" aria-label="related navigation">
+ <h3>Navigation</h3>
+ <ul>
+ <li class="right" style="margin-right: 10px">
+ <a href="genindex.html" title="General Index"
+ accesskey="I">index</a></li>
+ <li class="right" >
+ <a href="CMake.html" title="Building LLVM with CMake"
+ accesskey="N">next</a> |</li>
+ <li class="right" >
+ <a href="index.html" title="Overview"
+ accesskey="P">previous</a> |</li>
+ <li><a href="http://llvm.org/">LLVM Home</a> | </li>
+ <li><a href="index.html">Documentation</a>»</li>
+
+ </ul>
+ </div>
+
+
+ <div class="document">
+ <div class="documentwrapper">
+ <div class="body" role="main">
+
+ <div class="section" id="llvm-language-reference-manual">
+<h1>LLVM Language Reference Manual<a class="headerlink" href="#llvm-language-reference-manual" title="Permalink to this headline">¶</a></h1>
+<div class="contents local topic" id="contents">
+<ul class="simple">
+<li><a class="reference internal" href="#abstract" id="id947">Abstract</a></li>
+<li><a class="reference internal" href="#introduction" id="id948">Introduction</a><ul>
+<li><a class="reference internal" href="#well-formedness" id="id949">Well-Formedness</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#identifiers" id="id950">Identifiers</a></li>
+<li><a class="reference internal" href="#high-level-structure" id="id951">High Level Structure</a><ul>
+<li><a class="reference internal" href="#module-structure" id="id952">Module Structure</a></li>
+<li><a class="reference internal" href="#linkage-types" id="id953">Linkage Types</a></li>
+<li><a class="reference internal" href="#calling-conventions" id="id954">Calling Conventions</a></li>
+<li><a class="reference internal" href="#visibility-styles" id="id955">Visibility Styles</a></li>
+<li><a class="reference internal" href="#dll-storage-classes" id="id956">DLL Storage Classes</a></li>
+<li><a class="reference internal" href="#thread-local-storage-models" id="id957">Thread Local Storage Models</a></li>
+<li><a class="reference internal" href="#runtime-preemption-specifiers" id="id958">Runtime Preemption Specifiers</a></li>
+<li><a class="reference internal" href="#structure-types" id="id959">Structure Types</a></li>
+<li><a class="reference internal" href="#non-integral-pointer-type" id="id960">Non-Integral Pointer Type</a></li>
+<li><a class="reference internal" href="#global-variables" id="id961">Global Variables</a></li>
+<li><a class="reference internal" href="#functions" id="id962">Functions</a></li>
+<li><a class="reference internal" href="#aliases" id="id963">Aliases</a></li>
+<li><a class="reference internal" href="#ifuncs" id="id964">IFuncs</a></li>
+<li><a class="reference internal" href="#comdats" id="id965">Comdats</a></li>
+<li><a class="reference internal" href="#named-metadata" id="id966">Named Metadata</a></li>
+<li><a class="reference internal" href="#parameter-attributes" id="id967">Parameter Attributes</a></li>
+<li><a class="reference internal" href="#garbage-collector-strategy-names" id="id968">Garbage Collector Strategy Names</a></li>
+<li><a class="reference internal" href="#prefix-data" id="id969">Prefix Data</a></li>
+<li><a class="reference internal" href="#prologue-data" id="id970">Prologue Data</a></li>
+<li><a class="reference internal" href="#personality-function" id="id971">Personality Function</a></li>
+<li><a class="reference internal" href="#attribute-groups" id="id972">Attribute Groups</a></li>
+<li><a class="reference internal" href="#function-attributes" id="id973">Function Attributes</a></li>
+<li><a class="reference internal" href="#global-attributes" id="id974">Global Attributes</a></li>
+<li><a class="reference internal" href="#operand-bundles" id="id975">Operand Bundles</a><ul>
+<li><a class="reference internal" href="#deoptimization-operand-bundles" id="id976">Deoptimization Operand Bundles</a></li>
+<li><a class="reference internal" href="#funclet-operand-bundles" id="id977">Funclet Operand Bundles</a></li>
+<li><a class="reference internal" href="#gc-transition-operand-bundles" id="id978">GC Transition Operand Bundles</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#module-level-inline-assembly" id="id979">Module-Level Inline Assembly</a></li>
+<li><a class="reference internal" href="#data-layout" id="id980">Data Layout</a></li>
+<li><a class="reference internal" href="#target-triple" id="id981">Target Triple</a></li>
+<li><a class="reference internal" href="#pointer-aliasing-rules" id="id982">Pointer Aliasing Rules</a></li>
+<li><a class="reference internal" href="#volatile-memory-accesses" id="id983">Volatile Memory Accesses</a></li>
+<li><a class="reference internal" href="#memory-model-for-concurrent-operations" id="id984">Memory Model for Concurrent Operations</a></li>
+<li><a class="reference internal" href="#atomic-memory-ordering-constraints" id="id985">Atomic Memory Ordering Constraints</a></li>
+<li><a class="reference internal" href="#floating-point-environment" id="id986">Floating-Point Environment</a></li>
+<li><a class="reference internal" href="#fast-math-flags" id="id987">Fast-Math Flags</a></li>
+<li><a class="reference internal" href="#use-list-order-directives" id="id988">Use-list Order Directives</a></li>
+<li><a class="reference internal" href="#source-filename" id="id989">Source Filename</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#type-system" id="id990">Type System</a><ul>
+<li><a class="reference internal" href="#void-type" id="id991">Void Type</a></li>
+<li><a class="reference internal" href="#function-type" id="id992">Function Type</a></li>
+<li><a class="reference internal" href="#first-class-types" id="id993">First Class Types</a><ul>
+<li><a class="reference internal" href="#single-value-types" id="id994">Single Value Types</a><ul>
+<li><a class="reference internal" href="#integer-type" id="id995">Integer Type</a></li>
+<li><a class="reference internal" href="#floating-point-types" id="id996">Floating-Point Types</a></li>
+<li><a class="reference internal" href="#x86-mmx-type" id="id997">X86_mmx Type</a></li>
+<li><a class="reference internal" href="#pointer-type" id="id998">Pointer Type</a></li>
+<li><a class="reference internal" href="#vector-type" id="id999">Vector Type</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#label-type" id="id1000">Label Type</a></li>
+<li><a class="reference internal" href="#token-type" id="id1001">Token Type</a></li>
+<li><a class="reference internal" href="#metadata-type" id="id1002">Metadata Type</a></li>
+<li><a class="reference internal" href="#aggregate-types" id="id1003">Aggregate Types</a><ul>
+<li><a class="reference internal" href="#array-type" id="id1004">Array Type</a></li>
+<li><a class="reference internal" href="#structure-type" id="id1005">Structure Type</a></li>
+<li><a class="reference internal" href="#opaque-structure-types" id="id1006">Opaque Structure Types</a></li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#constants" id="id1007">Constants</a><ul>
+<li><a class="reference internal" href="#simple-constants" id="id1008">Simple Constants</a></li>
+<li><a class="reference internal" href="#complex-constants" id="id1009">Complex Constants</a></li>
+<li><a class="reference internal" href="#global-variable-and-function-addresses" id="id1010">Global Variable and Function Addresses</a></li>
+<li><a class="reference internal" href="#undefined-values" id="id1011">Undefined Values</a></li>
+<li><a class="reference internal" href="#poison-values" id="id1012">Poison Values</a></li>
+<li><a class="reference internal" href="#addresses-of-basic-blocks" id="id1013">Addresses of Basic Blocks</a></li>
+<li><a class="reference internal" href="#constant-expressions" id="id1014">Constant Expressions</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#other-values" id="id1015">Other Values</a><ul>
+<li><a class="reference internal" href="#inline-assembler-expressions" id="id1016">Inline Assembler Expressions</a><ul>
+<li><a class="reference internal" href="#inline-asm-constraint-string" id="id1017">Inline Asm Constraint String</a><ul>
+<li><a class="reference internal" href="#output-constraints" id="id1018">Output constraints</a></li>
+<li><a class="reference internal" href="#input-constraints" id="id1019">Input constraints</a></li>
+<li><a class="reference internal" href="#indirect-inputs-and-outputs" id="id1020">Indirect inputs and outputs</a></li>
+<li><a class="reference internal" href="#clobber-constraints" id="id1021">Clobber constraints</a></li>
+<li><a class="reference internal" href="#constraint-codes" id="id1022">Constraint Codes</a></li>
+<li><a class="reference internal" href="#supported-constraint-code-list" id="id1023">Supported Constraint Code List</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#asm-template-argument-modifiers" id="id1024">Asm template argument modifiers</a></li>
+<li><a class="reference internal" href="#inline-asm-metadata" id="id1025">Inline Asm Metadata</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#metadata" id="id1026">Metadata</a><ul>
+<li><a class="reference internal" href="#metadata-nodes-and-metadata-strings" id="id1027">Metadata Nodes and Metadata Strings</a><ul>
+<li><a class="reference internal" href="#specialized-metadata-nodes" id="id1028">Specialized Metadata Nodes</a><ul>
+<li><a class="reference internal" href="#dicompileunit" id="id1029">DICompileUnit</a></li>
+<li><a class="reference internal" href="#difile" id="id1030">DIFile</a></li>
+<li><a class="reference internal" href="#dibasictype" id="id1031">DIBasicType</a></li>
+<li><a class="reference internal" href="#disubroutinetype" id="id1032">DISubroutineType</a></li>
+<li><a class="reference internal" href="#diderivedtype" id="id1033">DIDerivedType</a></li>
+<li><a class="reference internal" href="#dicompositetype" id="id1034">DICompositeType</a></li>
+<li><a class="reference internal" href="#disubrange" id="id1035">DISubrange</a></li>
+<li><a class="reference internal" href="#dienumerator" id="id1036">DIEnumerator</a></li>
+<li><a class="reference internal" href="#ditemplatetypeparameter" id="id1037">DITemplateTypeParameter</a></li>
+<li><a class="reference internal" href="#ditemplatevalueparameter" id="id1038">DITemplateValueParameter</a></li>
+<li><a class="reference internal" href="#dinamespace" id="id1039">DINamespace</a></li>
+<li><a class="reference internal" href="#diglobalvariable" id="id1040">DIGlobalVariable</a></li>
+<li><a class="reference internal" href="#disubprogram" id="id1041">DISubprogram</a></li>
+<li><a class="reference internal" href="#dilexicalblock" id="id1042">DILexicalBlock</a></li>
+<li><a class="reference internal" href="#dilexicalblockfile" id="id1043">DILexicalBlockFile</a></li>
+<li><a class="reference internal" href="#dilocation" id="id1044">DILocation</a></li>
+<li><a class="reference internal" href="#dilocalvariable" id="id1045">DILocalVariable</a></li>
+<li><a class="reference internal" href="#diexpression" id="id1046">DIExpression</a></li>
+<li><a class="reference internal" href="#diobjcproperty" id="id1047">DIObjCProperty</a></li>
+<li><a class="reference internal" href="#diimportedentity" id="id1048">DIImportedEntity</a></li>
+<li><a class="reference internal" href="#dimacro" id="id1049">DIMacro</a></li>
+<li><a class="reference internal" href="#dimacrofile" id="id1050">DIMacroFile</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#tbaa-metadata" id="id1051">â<code class="docutils literal notranslate"><span class="pre">tbaa</span></code>â Metadata</a><ul>
+<li><a class="reference internal" href="#semantics" id="id1052">Semantics</a></li>
+<li><a class="reference internal" href="#representation" id="id1053">Representation</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#tbaa-struct-metadata" id="id1054">â<code class="docutils literal notranslate"><span class="pre">tbaa.struct</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#noalias-and-alias-scope-metadata" id="id1055">â<code class="docutils literal notranslate"><span class="pre">noalias</span></code>â and â<code class="docutils literal notranslate"><span class="pre">alias.scope</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#fpmath-metadata" id="id1056">â<code class="docutils literal notranslate"><span class="pre">fpmath</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#range-metadata" id="id1057">â<code class="docutils literal notranslate"><span class="pre">range</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#absolute-symbol-metadata" id="id1058">â<code class="docutils literal notranslate"><span class="pre">absolute_symbol</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#callees-metadata" id="id1059">â<code class="docutils literal notranslate"><span class="pre">callees</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#unpredictable-metadata" id="id1060">â<code class="docutils literal notranslate"><span class="pre">unpredictable</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop" id="id1061">â<code class="docutils literal notranslate"><span class="pre">llvm.loop</span></code>â</a></li>
+<li><a class="reference internal" href="#llvm-loop-disable-nonforced" id="id1062">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.disable_nonforced</span></code>â</a></li>
+<li><a class="reference internal" href="#llvm-loop-vectorize-and-llvm-loop-interleave" id="id1063">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize</span></code>â and â<code class="docutils literal notranslate"><span class="pre">llvm.loop.interleave</span></code>â</a></li>
+<li><a class="reference internal" href="#llvm-loop-interleave-count-metadata" id="id1064">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.interleave.count</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-vectorize-enable-metadata" id="id1065">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize.enable</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-vectorize-width-metadata" id="id1066">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize.width</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-vectorize-followup-vectorized-metadata" id="id1067">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize.followup_vectorized</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-vectorize-followup-epilogue-metadata" id="id1068">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize.followup_epilogue</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-vectorize-followup-all-metadata" id="id1069">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize.followup_all</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll" id="id1070">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll</span></code>â</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-count-metadata" id="id1071">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.count</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-disable-metadata" id="id1072">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.disable</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-runtime-disable-metadata" id="id1073">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.runtime.disable</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-enable-metadata" id="id1074">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.enable</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-full-metadata" id="id1075">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.full</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-followup-metadata" id="id1076">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.followup</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-followup-remainder-metadata" id="id1077">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.followup_remainder</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-and-jam" id="id1078">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam</span></code>â</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-and-jam-count-metadata" id="id1079">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.count</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-and-jam-disable-metadata" id="id1080">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.disable</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-and-jam-enable-metadata" id="id1081">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.enable</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-and-jam-followup-outer-metadata" id="id1082">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.followup_outer</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-and-jam-followup-inner-metadata" id="id1083">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.followup_inner</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-and-jam-followup-remainder-outer-metadata" id="id1084">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.followup_remainder_outer</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-and-jam-followup-remainder-inner-metadata" id="id1085">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.followup_remainder_inner</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-unroll-and-jam-followup-all-metadata" id="id1086">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.followup_all</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-licm-versioning-disable-metadata" id="id1087">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.licm_versioning.disable</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-distribute-enable-metadata" id="id1088">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.distribute.enable</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-distribute-followup-coincident-metadata" id="id1089">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.distribute.followup_coincident</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-distribute-followup-sequential-metadata" id="id1090">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.distribute.followup_sequential</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-distribute-followup-fallback-metadata" id="id1091">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.distribute.followup_fallback</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-distribute-followup-all-metadata" id="id1092">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.distribute.followup_all</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-access-group-metadata" id="id1093">â<code class="docutils literal notranslate"><span class="pre">llvm.access.group</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#llvm-loop-parallel-accesses-metadata" id="id1094">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.parallel_accesses</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#irr-loop-metadata" id="id1095">â<code class="docutils literal notranslate"><span class="pre">irr_loop</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#invariant-group-metadata" id="id1096">â<code class="docutils literal notranslate"><span class="pre">invariant.group</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#type-metadata" id="id1097">â<code class="docutils literal notranslate"><span class="pre">type</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#associated-metadata" id="id1098">â<code class="docutils literal notranslate"><span class="pre">associated</span></code>â Metadata</a></li>
+<li><a class="reference internal" href="#prof-metadata" id="id1099">â<code class="docutils literal notranslate"><span class="pre">prof</span></code>â Metadata</a><ul>
+<li><a class="reference internal" href="#branch-weights" id="id1100">branch_weights</a></li>
+<li><a class="reference internal" href="#function-entry-count" id="id1101">function_entry_count</a></li>
+<li><a class="reference internal" href="#vp" id="id1102">VP</a></li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#module-flags-metadata" id="id1103">Module Flags Metadata</a><ul>
+<li><a class="reference internal" href="#objective-c-garbage-collection-module-flags-metadata" id="id1104">Objective-C Garbage Collection Module Flags Metadata</a></li>
+<li><a class="reference internal" href="#c-type-width-module-flags-metadata" id="id1105">C type width Module Flags Metadata</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#automatic-linker-flags-named-metadata" id="id1106">Automatic Linker Flags Named Metadata</a></li>
+<li><a class="reference internal" href="#thinlto-summary" id="id1107">ThinLTO Summary</a><ul>
+<li><a class="reference internal" href="#module-path-summary-entry" id="id1108">Module Path Summary Entry</a></li>
+<li><a class="reference internal" href="#global-value-summary-entry" id="id1109">Global Value Summary Entry</a><ul>
+<li><a class="reference internal" href="#function-summary" id="id1110">Function Summary</a></li>
+<li><a class="reference internal" href="#global-variable-summary" id="id1111">Global Variable Summary</a></li>
+<li><a class="reference internal" href="#alias-summary" id="id1112">Alias Summary</a></li>
+<li><a class="reference internal" href="#function-flags" id="id1113">Function Flags</a></li>
+<li><a class="reference internal" href="#calls" id="id1114">Calls</a></li>
+<li><a class="reference internal" href="#refs" id="id1115">Refs</a></li>
+<li><a class="reference internal" href="#typeidinfo" id="id1116">TypeIdInfo</a><ul>
+<li><a class="reference internal" href="#typetests" id="id1117">TypeTests</a></li>
+<li><a class="reference internal" href="#typetestassumevcalls" id="id1118">TypeTestAssumeVCalls</a></li>
+<li><a class="reference internal" href="#typecheckedloadvcalls" id="id1119">TypeCheckedLoadVCalls</a></li>
+<li><a class="reference internal" href="#typetestassumeconstvcalls" id="id1120">TypeTestAssumeConstVCalls</a></li>
+<li><a class="reference internal" href="#typecheckedloadconstvcalls" id="id1121">TypeCheckedLoadConstVCalls</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#type-id-summary-entry" id="id1122">Type ID Summary Entry</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#intrinsic-global-variables" id="id1123">Intrinsic Global Variables</a><ul>
+<li><a class="reference internal" href="#the-llvm-used-global-variable" id="id1124">The â<code class="docutils literal notranslate"><span class="pre">llvm.used</span></code>â Global Variable</a></li>
+<li><a class="reference internal" href="#the-llvm-compiler-used-global-variable" id="id1125">The â<code class="docutils literal notranslate"><span class="pre">llvm.compiler.used</span></code>â Global Variable</a></li>
+<li><a class="reference internal" href="#the-llvm-global-ctors-global-variable" id="id1126">The â<code class="docutils literal notranslate"><span class="pre">llvm.global_ctors</span></code>â Global Variable</a></li>
+<li><a class="reference internal" href="#the-llvm-global-dtors-global-variable" id="id1127">The â<code class="docutils literal notranslate"><span class="pre">llvm.global_dtors</span></code>â Global Variable</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#instruction-reference" id="id1128">Instruction Reference</a><ul>
+<li><a class="reference internal" href="#terminator-instructions" id="id1129">Terminator Instructions</a><ul>
+<li><a class="reference internal" href="#ret-instruction" id="id1130">â<code class="docutils literal notranslate"><span class="pre">ret</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#syntax" id="id1131">Syntax:</a></li>
+<li><a class="reference internal" href="#overview" id="id1132">Overview:</a></li>
+<li><a class="reference internal" href="#arguments" id="id1133">Arguments:</a></li>
+<li><a class="reference internal" href="#id25" id="id1134">Semantics:</a></li>
+<li><a class="reference internal" href="#example" id="id1135">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#br-instruction" id="id1136">â<code class="docutils literal notranslate"><span class="pre">br</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id26" id="id1137">Syntax:</a></li>
+<li><a class="reference internal" href="#id27" id="id1138">Overview:</a></li>
+<li><a class="reference internal" href="#id28" id="id1139">Arguments:</a></li>
+<li><a class="reference internal" href="#id29" id="id1140">Semantics:</a></li>
+<li><a class="reference internal" href="#id30" id="id1141">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#switch-instruction" id="id1142">â<code class="docutils literal notranslate"><span class="pre">switch</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id31" id="id1143">Syntax:</a></li>
+<li><a class="reference internal" href="#id32" id="id1144">Overview:</a></li>
+<li><a class="reference internal" href="#id33" id="id1145">Arguments:</a></li>
+<li><a class="reference internal" href="#id34" id="id1146">Semantics:</a></li>
+<li><a class="reference internal" href="#implementation" id="id1147">Implementation:</a></li>
+<li><a class="reference internal" href="#id35" id="id1148">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#indirectbr-instruction" id="id1149">â<code class="docutils literal notranslate"><span class="pre">indirectbr</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id36" id="id1150">Syntax:</a></li>
+<li><a class="reference internal" href="#id37" id="id1151">Overview:</a></li>
+<li><a class="reference internal" href="#id38" id="id1152">Arguments:</a></li>
+<li><a class="reference internal" href="#id39" id="id1153">Semantics:</a></li>
+<li><a class="reference internal" href="#id40" id="id1154">Implementation:</a></li>
+<li><a class="reference internal" href="#id41" id="id1155">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#invoke-instruction" id="id1156">â<code class="docutils literal notranslate"><span class="pre">invoke</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id42" id="id1157">Syntax:</a></li>
+<li><a class="reference internal" href="#id43" id="id1158">Overview:</a></li>
+<li><a class="reference internal" href="#id44" id="id1159">Arguments:</a></li>
+<li><a class="reference internal" href="#id45" id="id1160">Semantics:</a></li>
+<li><a class="reference internal" href="#id46" id="id1161">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#resume-instruction" id="id1162">â<code class="docutils literal notranslate"><span class="pre">resume</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id47" id="id1163">Syntax:</a></li>
+<li><a class="reference internal" href="#id48" id="id1164">Overview:</a></li>
+<li><a class="reference internal" href="#id49" id="id1165">Arguments:</a></li>
+<li><a class="reference internal" href="#id50" id="id1166">Semantics:</a></li>
+<li><a class="reference internal" href="#id51" id="id1167">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#catchswitch-instruction" id="id1168">â<code class="docutils literal notranslate"><span class="pre">catchswitch</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id52" id="id1169">Syntax:</a></li>
+<li><a class="reference internal" href="#id53" id="id1170">Overview:</a></li>
+<li><a class="reference internal" href="#id54" id="id1171">Arguments:</a></li>
+<li><a class="reference internal" href="#id55" id="id1172">Semantics:</a></li>
+<li><a class="reference internal" href="#id56" id="id1173">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#catchret-instruction" id="id1174">â<code class="docutils literal notranslate"><span class="pre">catchret</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id57" id="id1175">Syntax:</a></li>
+<li><a class="reference internal" href="#id58" id="id1176">Overview:</a></li>
+<li><a class="reference internal" href="#id59" id="id1177">Arguments:</a></li>
+<li><a class="reference internal" href="#id60" id="id1178">Semantics:</a></li>
+<li><a class="reference internal" href="#id61" id="id1179">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#cleanupret-instruction" id="id1180">â<code class="docutils literal notranslate"><span class="pre">cleanupret</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id62" id="id1181">Syntax:</a></li>
+<li><a class="reference internal" href="#id63" id="id1182">Overview:</a></li>
+<li><a class="reference internal" href="#id64" id="id1183">Arguments:</a></li>
+<li><a class="reference internal" href="#id67" id="id1184">Semantics:</a></li>
+<li><a class="reference internal" href="#id68" id="id1185">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#unreachable-instruction" id="id1186">â<code class="docutils literal notranslate"><span class="pre">unreachable</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id69" id="id1187">Syntax:</a></li>
+<li><a class="reference internal" href="#id70" id="id1188">Overview:</a></li>
+<li><a class="reference internal" href="#id71" id="id1189">Semantics:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#unary-operations" id="id1190">Unary Operations</a><ul>
+<li><a class="reference internal" href="#fneg-instruction" id="id1191">â<code class="docutils literal notranslate"><span class="pre">fneg</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id72" id="id1192">Syntax:</a></li>
+<li><a class="reference internal" href="#id73" id="id1193">Overview:</a></li>
+<li><a class="reference internal" href="#id74" id="id1194">Arguments:</a></li>
+<li><a class="reference internal" href="#id75" id="id1195">Semantics:</a></li>
+<li><a class="reference internal" href="#id76" id="id1196">Example:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#binary-operations" id="id1197">Binary Operations</a><ul>
+<li><a class="reference internal" href="#add-instruction" id="id1198">â<code class="docutils literal notranslate"><span class="pre">add</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id77" id="id1199">Syntax:</a></li>
+<li><a class="reference internal" href="#id78" id="id1200">Overview:</a></li>
+<li><a class="reference internal" href="#id79" id="id1201">Arguments:</a></li>
+<li><a class="reference internal" href="#id80" id="id1202">Semantics:</a></li>
+<li><a class="reference internal" href="#id81" id="id1203">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#fadd-instruction" id="id1204">â<code class="docutils literal notranslate"><span class="pre">fadd</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id82" id="id1205">Syntax:</a></li>
+<li><a class="reference internal" href="#id83" id="id1206">Overview:</a></li>
+<li><a class="reference internal" href="#id84" id="id1207">Arguments:</a></li>
+<li><a class="reference internal" href="#id85" id="id1208">Semantics:</a></li>
+<li><a class="reference internal" href="#id86" id="id1209">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#sub-instruction" id="id1210">â<code class="docutils literal notranslate"><span class="pre">sub</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id87" id="id1211">Syntax:</a></li>
+<li><a class="reference internal" href="#id88" id="id1212">Overview:</a></li>
+<li><a class="reference internal" href="#id89" id="id1213">Arguments:</a></li>
+<li><a class="reference internal" href="#id90" id="id1214">Semantics:</a></li>
+<li><a class="reference internal" href="#id91" id="id1215">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#fsub-instruction" id="id1216">â<code class="docutils literal notranslate"><span class="pre">fsub</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id92" id="id1217">Syntax:</a></li>
+<li><a class="reference internal" href="#id93" id="id1218">Overview:</a></li>
+<li><a class="reference internal" href="#id94" id="id1219">Arguments:</a></li>
+<li><a class="reference internal" href="#id95" id="id1220">Semantics:</a></li>
+<li><a class="reference internal" href="#id96" id="id1221">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#mul-instruction" id="id1222">â<code class="docutils literal notranslate"><span class="pre">mul</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id97" id="id1223">Syntax:</a></li>
+<li><a class="reference internal" href="#id98" id="id1224">Overview:</a></li>
+<li><a class="reference internal" href="#id99" id="id1225">Arguments:</a></li>
+<li><a class="reference internal" href="#id100" id="id1226">Semantics:</a></li>
+<li><a class="reference internal" href="#id101" id="id1227">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#fmul-instruction" id="id1228">â<code class="docutils literal notranslate"><span class="pre">fmul</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id102" id="id1229">Syntax:</a></li>
+<li><a class="reference internal" href="#id103" id="id1230">Overview:</a></li>
+<li><a class="reference internal" href="#id104" id="id1231">Arguments:</a></li>
+<li><a class="reference internal" href="#id105" id="id1232">Semantics:</a></li>
+<li><a class="reference internal" href="#id106" id="id1233">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#udiv-instruction" id="id1234">â<code class="docutils literal notranslate"><span class="pre">udiv</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id107" id="id1235">Syntax:</a></li>
+<li><a class="reference internal" href="#id108" id="id1236">Overview:</a></li>
+<li><a class="reference internal" href="#id109" id="id1237">Arguments:</a></li>
+<li><a class="reference internal" href="#id110" id="id1238">Semantics:</a></li>
+<li><a class="reference internal" href="#id111" id="id1239">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#sdiv-instruction" id="id1240">â<code class="docutils literal notranslate"><span class="pre">sdiv</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id112" id="id1241">Syntax:</a></li>
+<li><a class="reference internal" href="#id113" id="id1242">Overview:</a></li>
+<li><a class="reference internal" href="#id114" id="id1243">Arguments:</a></li>
+<li><a class="reference internal" href="#id115" id="id1244">Semantics:</a></li>
+<li><a class="reference internal" href="#id116" id="id1245">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#fdiv-instruction" id="id1246">â<code class="docutils literal notranslate"><span class="pre">fdiv</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id117" id="id1247">Syntax:</a></li>
+<li><a class="reference internal" href="#id118" id="id1248">Overview:</a></li>
+<li><a class="reference internal" href="#id119" id="id1249">Arguments:</a></li>
+<li><a class="reference internal" href="#id120" id="id1250">Semantics:</a></li>
+<li><a class="reference internal" href="#id121" id="id1251">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#urem-instruction" id="id1252">â<code class="docutils literal notranslate"><span class="pre">urem</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id122" id="id1253">Syntax:</a></li>
+<li><a class="reference internal" href="#id123" id="id1254">Overview:</a></li>
+<li><a class="reference internal" href="#id124" id="id1255">Arguments:</a></li>
+<li><a class="reference internal" href="#id125" id="id1256">Semantics:</a></li>
+<li><a class="reference internal" href="#id126" id="id1257">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#srem-instruction" id="id1258">â<code class="docutils literal notranslate"><span class="pre">srem</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id127" id="id1259">Syntax:</a></li>
+<li><a class="reference internal" href="#id128" id="id1260">Overview:</a></li>
+<li><a class="reference internal" href="#id129" id="id1261">Arguments:</a></li>
+<li><a class="reference internal" href="#id130" id="id1262">Semantics:</a></li>
+<li><a class="reference internal" href="#id131" id="id1263">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#frem-instruction" id="id1264">â<code class="docutils literal notranslate"><span class="pre">frem</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id132" id="id1265">Syntax:</a></li>
+<li><a class="reference internal" href="#id133" id="id1266">Overview:</a></li>
+<li><a class="reference internal" href="#id134" id="id1267">Arguments:</a></li>
+<li><a class="reference internal" href="#id135" id="id1268">Semantics:</a></li>
+<li><a class="reference internal" href="#id136" id="id1269">Example:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#bitwise-binary-operations" id="id1270">Bitwise Binary Operations</a><ul>
+<li><a class="reference internal" href="#shl-instruction" id="id1271">â<code class="docutils literal notranslate"><span class="pre">shl</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id137" id="id1272">Syntax:</a></li>
+<li><a class="reference internal" href="#id138" id="id1273">Overview:</a></li>
+<li><a class="reference internal" href="#id139" id="id1274">Arguments:</a></li>
+<li><a class="reference internal" href="#id140" id="id1275">Semantics:</a></li>
+<li><a class="reference internal" href="#id141" id="id1276">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#lshr-instruction" id="id1277">â<code class="docutils literal notranslate"><span class="pre">lshr</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id142" id="id1278">Syntax:</a></li>
+<li><a class="reference internal" href="#id143" id="id1279">Overview:</a></li>
+<li><a class="reference internal" href="#id144" id="id1280">Arguments:</a></li>
+<li><a class="reference internal" href="#id145" id="id1281">Semantics:</a></li>
+<li><a class="reference internal" href="#id146" id="id1282">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#ashr-instruction" id="id1283">â<code class="docutils literal notranslate"><span class="pre">ashr</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id147" id="id1284">Syntax:</a></li>
+<li><a class="reference internal" href="#id148" id="id1285">Overview:</a></li>
+<li><a class="reference internal" href="#id149" id="id1286">Arguments:</a></li>
+<li><a class="reference internal" href="#id150" id="id1287">Semantics:</a></li>
+<li><a class="reference internal" href="#id151" id="id1288">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#and-instruction" id="id1289">â<code class="docutils literal notranslate"><span class="pre">and</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id152" id="id1290">Syntax:</a></li>
+<li><a class="reference internal" href="#id153" id="id1291">Overview:</a></li>
+<li><a class="reference internal" href="#id154" id="id1292">Arguments:</a></li>
+<li><a class="reference internal" href="#id155" id="id1293">Semantics:</a></li>
+<li><a class="reference internal" href="#id156" id="id1294">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#or-instruction" id="id1295">â<code class="docutils literal notranslate"><span class="pre">or</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id157" id="id1296">Syntax:</a></li>
+<li><a class="reference internal" href="#id158" id="id1297">Overview:</a></li>
+<li><a class="reference internal" href="#id159" id="id1298">Arguments:</a></li>
+<li><a class="reference internal" href="#id160" id="id1299">Semantics:</a></li>
+<li><a class="reference internal" href="#id161" id="id1300">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#xor-instruction" id="id1301">â<code class="docutils literal notranslate"><span class="pre">xor</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id162" id="id1302">Syntax:</a></li>
+<li><a class="reference internal" href="#id163" id="id1303">Overview:</a></li>
+<li><a class="reference internal" href="#id164" id="id1304">Arguments:</a></li>
+<li><a class="reference internal" href="#id165" id="id1305">Semantics:</a></li>
+<li><a class="reference internal" href="#id166" id="id1306">Example:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#vector-operations" id="id1307">Vector Operations</a><ul>
+<li><a class="reference internal" href="#extractelement-instruction" id="id1308">â<code class="docutils literal notranslate"><span class="pre">extractelement</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id167" id="id1309">Syntax:</a></li>
+<li><a class="reference internal" href="#id168" id="id1310">Overview:</a></li>
+<li><a class="reference internal" href="#id169" id="id1311">Arguments:</a></li>
+<li><a class="reference internal" href="#id170" id="id1312">Semantics:</a></li>
+<li><a class="reference internal" href="#id171" id="id1313">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#insertelement-instruction" id="id1314">â<code class="docutils literal notranslate"><span class="pre">insertelement</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id172" id="id1315">Syntax:</a></li>
+<li><a class="reference internal" href="#id173" id="id1316">Overview:</a></li>
+<li><a class="reference internal" href="#id174" id="id1317">Arguments:</a></li>
+<li><a class="reference internal" href="#id175" id="id1318">Semantics:</a></li>
+<li><a class="reference internal" href="#id176" id="id1319">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#shufflevector-instruction" id="id1320">â<code class="docutils literal notranslate"><span class="pre">shufflevector</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id177" id="id1321">Syntax:</a></li>
+<li><a class="reference internal" href="#id178" id="id1322">Overview:</a></li>
+<li><a class="reference internal" href="#id179" id="id1323">Arguments:</a></li>
+<li><a class="reference internal" href="#id180" id="id1324">Semantics:</a></li>
+<li><a class="reference internal" href="#id181" id="id1325">Example:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#aggregate-operations" id="id1326">Aggregate Operations</a><ul>
+<li><a class="reference internal" href="#extractvalue-instruction" id="id1327">â<code class="docutils literal notranslate"><span class="pre">extractvalue</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id182" id="id1328">Syntax:</a></li>
+<li><a class="reference internal" href="#id183" id="id1329">Overview:</a></li>
+<li><a class="reference internal" href="#id184" id="id1330">Arguments:</a></li>
+<li><a class="reference internal" href="#id185" id="id1331">Semantics:</a></li>
+<li><a class="reference internal" href="#id186" id="id1332">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#insertvalue-instruction" id="id1333">â<code class="docutils literal notranslate"><span class="pre">insertvalue</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id187" id="id1334">Syntax:</a></li>
+<li><a class="reference internal" href="#id188" id="id1335">Overview:</a></li>
+<li><a class="reference internal" href="#id189" id="id1336">Arguments:</a></li>
+<li><a class="reference internal" href="#id190" id="id1337">Semantics:</a></li>
+<li><a class="reference internal" href="#id191" id="id1338">Example:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#memory-access-and-addressing-operations" id="id1339">Memory Access and Addressing Operations</a><ul>
+<li><a class="reference internal" href="#alloca-instruction" id="id1340">â<code class="docutils literal notranslate"><span class="pre">alloca</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id192" id="id1341">Syntax:</a></li>
+<li><a class="reference internal" href="#id193" id="id1342">Overview:</a></li>
+<li><a class="reference internal" href="#id194" id="id1343">Arguments:</a></li>
+<li><a class="reference internal" href="#id195" id="id1344">Semantics:</a></li>
+<li><a class="reference internal" href="#id196" id="id1345">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#load-instruction" id="id1346">â<code class="docutils literal notranslate"><span class="pre">load</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id197" id="id1347">Syntax:</a></li>
+<li><a class="reference internal" href="#id198" id="id1348">Overview:</a></li>
+<li><a class="reference internal" href="#id199" id="id1349">Arguments:</a></li>
+<li><a class="reference internal" href="#id200" id="id1350">Semantics:</a></li>
+<li><a class="reference internal" href="#id201" id="id1351">Examples:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#store-instruction" id="id1352">â<code class="docutils literal notranslate"><span class="pre">store</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id202" id="id1353">Syntax:</a></li>
+<li><a class="reference internal" href="#id203" id="id1354">Overview:</a></li>
+<li><a class="reference internal" href="#id204" id="id1355">Arguments:</a></li>
+<li><a class="reference internal" href="#id205" id="id1356">Semantics:</a></li>
+<li><a class="reference internal" href="#id206" id="id1357">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#fence-instruction" id="id1358">â<code class="docutils literal notranslate"><span class="pre">fence</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id207" id="id1359">Syntax:</a></li>
+<li><a class="reference internal" href="#id208" id="id1360">Overview:</a></li>
+<li><a class="reference internal" href="#id209" id="id1361">Arguments:</a></li>
+<li><a class="reference internal" href="#id210" id="id1362">Semantics:</a></li>
+<li><a class="reference internal" href="#id211" id="id1363">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#cmpxchg-instruction" id="id1364">â<code class="docutils literal notranslate"><span class="pre">cmpxchg</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id212" id="id1365">Syntax:</a></li>
+<li><a class="reference internal" href="#id213" id="id1366">Overview:</a></li>
+<li><a class="reference internal" href="#id214" id="id1367">Arguments:</a></li>
+<li><a class="reference internal" href="#id215" id="id1368">Semantics:</a></li>
+<li><a class="reference internal" href="#id216" id="id1369">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#atomicrmw-instruction" id="id1370">â<code class="docutils literal notranslate"><span class="pre">atomicrmw</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id217" id="id1371">Syntax:</a></li>
+<li><a class="reference internal" href="#id218" id="id1372">Overview:</a></li>
+<li><a class="reference internal" href="#id219" id="id1373">Arguments:</a></li>
+<li><a class="reference internal" href="#id220" id="id1374">Semantics:</a></li>
+<li><a class="reference internal" href="#id221" id="id1375">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#getelementptr-instruction" id="id1376">â<code class="docutils literal notranslate"><span class="pre">getelementptr</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id222" id="id1377">Syntax:</a></li>
+<li><a class="reference internal" href="#id223" id="id1378">Overview:</a></li>
+<li><a class="reference internal" href="#id224" id="id1379">Arguments:</a></li>
+<li><a class="reference internal" href="#id225" id="id1380">Semantics:</a></li>
+<li><a class="reference internal" href="#id226" id="id1381">Example:</a></li>
+<li><a class="reference internal" href="#vector-of-pointers" id="id1382">Vector of pointers:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#conversion-operations" id="id1383">Conversion Operations</a><ul>
+<li><a class="reference internal" href="#trunc-to-instruction" id="id1384">â<code class="docutils literal notranslate"><span class="pre">trunc</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id227" id="id1385">Syntax:</a></li>
+<li><a class="reference internal" href="#id228" id="id1386">Overview:</a></li>
+<li><a class="reference internal" href="#id229" id="id1387">Arguments:</a></li>
+<li><a class="reference internal" href="#id230" id="id1388">Semantics:</a></li>
+<li><a class="reference internal" href="#id231" id="id1389">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#zext-to-instruction" id="id1390">â<code class="docutils literal notranslate"><span class="pre">zext</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id232" id="id1391">Syntax:</a></li>
+<li><a class="reference internal" href="#id233" id="id1392">Overview:</a></li>
+<li><a class="reference internal" href="#id234" id="id1393">Arguments:</a></li>
+<li><a class="reference internal" href="#id235" id="id1394">Semantics:</a></li>
+<li><a class="reference internal" href="#id236" id="id1395">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#sext-to-instruction" id="id1396">â<code class="docutils literal notranslate"><span class="pre">sext</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id237" id="id1397">Syntax:</a></li>
+<li><a class="reference internal" href="#id238" id="id1398">Overview:</a></li>
+<li><a class="reference internal" href="#id239" id="id1399">Arguments:</a></li>
+<li><a class="reference internal" href="#id240" id="id1400">Semantics:</a></li>
+<li><a class="reference internal" href="#id241" id="id1401">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#fptrunc-to-instruction" id="id1402">â<code class="docutils literal notranslate"><span class="pre">fptrunc</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id242" id="id1403">Syntax:</a></li>
+<li><a class="reference internal" href="#id243" id="id1404">Overview:</a></li>
+<li><a class="reference internal" href="#id244" id="id1405">Arguments:</a></li>
+<li><a class="reference internal" href="#id245" id="id1406">Semantics:</a></li>
+<li><a class="reference internal" href="#id246" id="id1407">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#fpext-to-instruction" id="id1408">â<code class="docutils literal notranslate"><span class="pre">fpext</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id247" id="id1409">Syntax:</a></li>
+<li><a class="reference internal" href="#id248" id="id1410">Overview:</a></li>
+<li><a class="reference internal" href="#id249" id="id1411">Arguments:</a></li>
+<li><a class="reference internal" href="#id250" id="id1412">Semantics:</a></li>
+<li><a class="reference internal" href="#id251" id="id1413">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#fptoui-to-instruction" id="id1414">â<code class="docutils literal notranslate"><span class="pre">fptoui</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id252" id="id1415">Syntax:</a></li>
+<li><a class="reference internal" href="#id253" id="id1416">Overview:</a></li>
+<li><a class="reference internal" href="#id254" id="id1417">Arguments:</a></li>
+<li><a class="reference internal" href="#id255" id="id1418">Semantics:</a></li>
+<li><a class="reference internal" href="#id256" id="id1419">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#fptosi-to-instruction" id="id1420">â<code class="docutils literal notranslate"><span class="pre">fptosi</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id257" id="id1421">Syntax:</a></li>
+<li><a class="reference internal" href="#id258" id="id1422">Overview:</a></li>
+<li><a class="reference internal" href="#id259" id="id1423">Arguments:</a></li>
+<li><a class="reference internal" href="#id260" id="id1424">Semantics:</a></li>
+<li><a class="reference internal" href="#id261" id="id1425">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#uitofp-to-instruction" id="id1426">â<code class="docutils literal notranslate"><span class="pre">uitofp</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id262" id="id1427">Syntax:</a></li>
+<li><a class="reference internal" href="#id263" id="id1428">Overview:</a></li>
+<li><a class="reference internal" href="#id264" id="id1429">Arguments:</a></li>
+<li><a class="reference internal" href="#id265" id="id1430">Semantics:</a></li>
+<li><a class="reference internal" href="#id266" id="id1431">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#sitofp-to-instruction" id="id1432">â<code class="docutils literal notranslate"><span class="pre">sitofp</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id267" id="id1433">Syntax:</a></li>
+<li><a class="reference internal" href="#id268" id="id1434">Overview:</a></li>
+<li><a class="reference internal" href="#id269" id="id1435">Arguments:</a></li>
+<li><a class="reference internal" href="#id270" id="id1436">Semantics:</a></li>
+<li><a class="reference internal" href="#id271" id="id1437">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#ptrtoint-to-instruction" id="id1438">â<code class="docutils literal notranslate"><span class="pre">ptrtoint</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id272" id="id1439">Syntax:</a></li>
+<li><a class="reference internal" href="#id273" id="id1440">Overview:</a></li>
+<li><a class="reference internal" href="#id274" id="id1441">Arguments:</a></li>
+<li><a class="reference internal" href="#id275" id="id1442">Semantics:</a></li>
+<li><a class="reference internal" href="#id276" id="id1443">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#inttoptr-to-instruction" id="id1444">â<code class="docutils literal notranslate"><span class="pre">inttoptr</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id277" id="id1445">Syntax:</a></li>
+<li><a class="reference internal" href="#id278" id="id1446">Overview:</a></li>
+<li><a class="reference internal" href="#id279" id="id1447">Arguments:</a></li>
+<li><a class="reference internal" href="#id280" id="id1448">Semantics:</a></li>
+<li><a class="reference internal" href="#id281" id="id1449">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#bitcast-to-instruction" id="id1450">â<code class="docutils literal notranslate"><span class="pre">bitcast</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id282" id="id1451">Syntax:</a></li>
+<li><a class="reference internal" href="#id283" id="id1452">Overview:</a></li>
+<li><a class="reference internal" href="#id284" id="id1453">Arguments:</a></li>
+<li><a class="reference internal" href="#id285" id="id1454">Semantics:</a></li>
+<li><a class="reference internal" href="#id286" id="id1455">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#addrspacecast-to-instruction" id="id1456">â<code class="docutils literal notranslate"><span class="pre">addrspacecast</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id287" id="id1457">Syntax:</a></li>
+<li><a class="reference internal" href="#id288" id="id1458">Overview:</a></li>
+<li><a class="reference internal" href="#id289" id="id1459">Arguments:</a></li>
+<li><a class="reference internal" href="#id290" id="id1460">Semantics:</a></li>
+<li><a class="reference internal" href="#id291" id="id1461">Example:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#other-operations" id="id1462">Other Operations</a><ul>
+<li><a class="reference internal" href="#icmp-instruction" id="id1463">â<code class="docutils literal notranslate"><span class="pre">icmp</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id292" id="id1464">Syntax:</a></li>
+<li><a class="reference internal" href="#id293" id="id1465">Overview:</a></li>
+<li><a class="reference internal" href="#id294" id="id1466">Arguments:</a></li>
+<li><a class="reference internal" href="#id295" id="id1467">Semantics:</a></li>
+<li><a class="reference internal" href="#id296" id="id1468">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#fcmp-instruction" id="id1469">â<code class="docutils literal notranslate"><span class="pre">fcmp</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id297" id="id1470">Syntax:</a></li>
+<li><a class="reference internal" href="#id298" id="id1471">Overview:</a></li>
+<li><a class="reference internal" href="#id299" id="id1472">Arguments:</a></li>
+<li><a class="reference internal" href="#id300" id="id1473">Semantics:</a></li>
+<li><a class="reference internal" href="#id301" id="id1474">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#phi-instruction" id="id1475">â<code class="docutils literal notranslate"><span class="pre">phi</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id302" id="id1476">Syntax:</a></li>
+<li><a class="reference internal" href="#id303" id="id1477">Overview:</a></li>
+<li><a class="reference internal" href="#id304" id="id1478">Arguments:</a></li>
+<li><a class="reference internal" href="#id305" id="id1479">Semantics:</a></li>
+<li><a class="reference internal" href="#id306" id="id1480">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#select-instruction" id="id1481">â<code class="docutils literal notranslate"><span class="pre">select</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id307" id="id1482">Syntax:</a></li>
+<li><a class="reference internal" href="#id308" id="id1483">Overview:</a></li>
+<li><a class="reference internal" href="#id309" id="id1484">Arguments:</a></li>
+<li><a class="reference internal" href="#id310" id="id1485">Semantics:</a></li>
+<li><a class="reference internal" href="#id311" id="id1486">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#call-instruction" id="id1487">â<code class="docutils literal notranslate"><span class="pre">call</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id312" id="id1488">Syntax:</a></li>
+<li><a class="reference internal" href="#id313" id="id1489">Overview:</a></li>
+<li><a class="reference internal" href="#id314" id="id1490">Arguments:</a></li>
+<li><a class="reference internal" href="#id315" id="id1491">Semantics:</a></li>
+<li><a class="reference internal" href="#id316" id="id1492">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#va-arg-instruction" id="id1493">â<code class="docutils literal notranslate"><span class="pre">va_arg</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id317" id="id1494">Syntax:</a></li>
+<li><a class="reference internal" href="#id318" id="id1495">Overview:</a></li>
+<li><a class="reference internal" href="#id319" id="id1496">Arguments:</a></li>
+<li><a class="reference internal" href="#id320" id="id1497">Semantics:</a></li>
+<li><a class="reference internal" href="#id321" id="id1498">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#landingpad-instruction" id="id1499">â<code class="docutils literal notranslate"><span class="pre">landingpad</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id322" id="id1500">Syntax:</a></li>
+<li><a class="reference internal" href="#id323" id="id1501">Overview:</a></li>
+<li><a class="reference internal" href="#id325" id="id1502">Arguments:</a></li>
+<li><a class="reference internal" href="#id326" id="id1503">Semantics:</a></li>
+<li><a class="reference internal" href="#id327" id="id1504">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#catchpad-instruction" id="id1505">â<code class="docutils literal notranslate"><span class="pre">catchpad</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id328" id="id1506">Syntax:</a></li>
+<li><a class="reference internal" href="#id329" id="id1507">Overview:</a></li>
+<li><a class="reference internal" href="#id331" id="id1508">Arguments:</a></li>
+<li><a class="reference internal" href="#id332" id="id1509">Semantics:</a></li>
+<li><a class="reference internal" href="#id334" id="id1510">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#cleanuppad-instruction" id="id1511">â<code class="docutils literal notranslate"><span class="pre">cleanuppad</span></code>â Instruction</a><ul>
+<li><a class="reference internal" href="#id335" id="id1512">Syntax:</a></li>
+<li><a class="reference internal" href="#id336" id="id1513">Overview:</a></li>
+<li><a class="reference internal" href="#id338" id="id1514">Arguments:</a></li>
+<li><a class="reference internal" href="#id339" id="id1515">Semantics:</a></li>
+<li><a class="reference internal" href="#id341" id="id1516">Example:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#intrinsic-functions" id="id1517">Intrinsic Functions</a><ul>
+<li><a class="reference internal" href="#variable-argument-handling-intrinsics" id="id1518">Variable Argument Handling Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-va-start-intrinsic" id="id1519">â<code class="docutils literal notranslate"><span class="pre">llvm.va_start</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id342" id="id1520">Syntax:</a></li>
+<li><a class="reference internal" href="#id343" id="id1521">Overview:</a></li>
+<li><a class="reference internal" href="#id344" id="id1522">Arguments:</a></li>
+<li><a class="reference internal" href="#id345" id="id1523">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-va-end-intrinsic" id="id1524">â<code class="docutils literal notranslate"><span class="pre">llvm.va_end</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id346" id="id1525">Syntax:</a></li>
+<li><a class="reference internal" href="#id347" id="id1526">Overview:</a></li>
+<li><a class="reference internal" href="#id348" id="id1527">Arguments:</a></li>
+<li><a class="reference internal" href="#id349" id="id1528">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-va-copy-intrinsic" id="id1529">â<code class="docutils literal notranslate"><span class="pre">llvm.va_copy</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id350" id="id1530">Syntax:</a></li>
+<li><a class="reference internal" href="#id351" id="id1531">Overview:</a></li>
+<li><a class="reference internal" href="#id352" id="id1532">Arguments:</a></li>
+<li><a class="reference internal" href="#id353" id="id1533">Semantics:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#accurate-garbage-collection-intrinsics" id="id1534">Accurate Garbage Collection Intrinsics</a><ul>
+<li><a class="reference internal" href="#experimental-statepoint-intrinsics" id="id1535">Experimental Statepoint Intrinsics</a></li>
+<li><a class="reference internal" href="#llvm-gcroot-intrinsic" id="id1536">â<code class="docutils literal notranslate"><span class="pre">llvm.gcroot</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id355" id="id1537">Syntax:</a></li>
+<li><a class="reference internal" href="#id356" id="id1538">Overview:</a></li>
+<li><a class="reference internal" href="#id357" id="id1539">Arguments:</a></li>
+<li><a class="reference internal" href="#id358" id="id1540">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-gcread-intrinsic" id="id1541">â<code class="docutils literal notranslate"><span class="pre">llvm.gcread</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id359" id="id1542">Syntax:</a></li>
+<li><a class="reference internal" href="#id360" id="id1543">Overview:</a></li>
+<li><a class="reference internal" href="#id361" id="id1544">Arguments:</a></li>
+<li><a class="reference internal" href="#id362" id="id1545">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-gcwrite-intrinsic" id="id1546">â<code class="docutils literal notranslate"><span class="pre">llvm.gcwrite</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id363" id="id1547">Syntax:</a></li>
+<li><a class="reference internal" href="#id364" id="id1548">Overview:</a></li>
+<li><a class="reference internal" href="#id365" id="id1549">Arguments:</a></li>
+<li><a class="reference internal" href="#id366" id="id1550">Semantics:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#code-generator-intrinsics" id="id1551">Code Generator Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-returnaddress-intrinsic" id="id1552">â<code class="docutils literal notranslate"><span class="pre">llvm.returnaddress</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id367" id="id1553">Syntax:</a></li>
+<li><a class="reference internal" href="#id368" id="id1554">Overview:</a></li>
+<li><a class="reference internal" href="#id369" id="id1555">Arguments:</a></li>
+<li><a class="reference internal" href="#id370" id="id1556">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-addressofreturnaddress-intrinsic" id="id1557">â<code class="docutils literal notranslate"><span class="pre">llvm.addressofreturnaddress</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id371" id="id1558">Syntax:</a></li>
+<li><a class="reference internal" href="#id372" id="id1559">Overview:</a></li>
+<li><a class="reference internal" href="#id373" id="id1560">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-sponentry-intrinsic" id="id1561">â<code class="docutils literal notranslate"><span class="pre">llvm.sponentry</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id374" id="id1562">Syntax:</a></li>
+<li><a class="reference internal" href="#id375" id="id1563">Overview:</a></li>
+<li><a class="reference internal" href="#id376" id="id1564">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-frameaddress-intrinsic" id="id1565">â<code class="docutils literal notranslate"><span class="pre">llvm.frameaddress</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id377" id="id1566">Syntax:</a></li>
+<li><a class="reference internal" href="#id378" id="id1567">Overview:</a></li>
+<li><a class="reference internal" href="#id379" id="id1568">Arguments:</a></li>
+<li><a class="reference internal" href="#id380" id="id1569">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-localescape-and-llvm-localrecover-intrinsics" id="id1570">â<code class="docutils literal notranslate"><span class="pre">llvm.localescape</span></code>â and â<code class="docutils literal notranslate"><span class="pre">llvm.localrecover</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id381" id="id1571">Syntax:</a></li>
+<li><a class="reference internal" href="#id382" id="id1572">Overview:</a></li>
+<li><a class="reference internal" href="#id383" id="id1573">Arguments:</a></li>
+<li><a class="reference internal" href="#id384" id="id1574">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-read-register-and-llvm-write-register-intrinsics" id="id1575">â<code class="docutils literal notranslate"><span class="pre">llvm.read_register</span></code>â and â<code class="docutils literal notranslate"><span class="pre">llvm.write_register</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id385" id="id1576">Syntax:</a></li>
+<li><a class="reference internal" href="#id386" id="id1577">Overview:</a></li>
+<li><a class="reference internal" href="#id387" id="id1578">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-stacksave-intrinsic" id="id1579">â<code class="docutils literal notranslate"><span class="pre">llvm.stacksave</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id388" id="id1580">Syntax:</a></li>
+<li><a class="reference internal" href="#id389" id="id1581">Overview:</a></li>
+<li><a class="reference internal" href="#id390" id="id1582">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-stackrestore-intrinsic" id="id1583">â<code class="docutils literal notranslate"><span class="pre">llvm.stackrestore</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id391" id="id1584">Syntax:</a></li>
+<li><a class="reference internal" href="#id392" id="id1585">Overview:</a></li>
+<li><a class="reference internal" href="#id393" id="id1586">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-get-dynamic-area-offset-intrinsic" id="id1587">â<code class="docutils literal notranslate"><span class="pre">llvm.get.dynamic.area.offset</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id394" id="id1588">Syntax:</a></li>
+<li><a class="reference internal" href="#id395" id="id1589">Overview:</a></li>
+<li><a class="reference internal" href="#id396" id="id1590">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-prefetch-intrinsic" id="id1591">â<code class="docutils literal notranslate"><span class="pre">llvm.prefetch</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id397" id="id1592">Syntax:</a></li>
+<li><a class="reference internal" href="#id398" id="id1593">Overview:</a></li>
+<li><a class="reference internal" href="#id399" id="id1594">Arguments:</a></li>
+<li><a class="reference internal" href="#id400" id="id1595">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-pcmarker-intrinsic" id="id1596">â<code class="docutils literal notranslate"><span class="pre">llvm.pcmarker</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id401" id="id1597">Syntax:</a></li>
+<li><a class="reference internal" href="#id402" id="id1598">Overview:</a></li>
+<li><a class="reference internal" href="#id403" id="id1599">Arguments:</a></li>
+<li><a class="reference internal" href="#id404" id="id1600">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-readcyclecounter-intrinsic" id="id1601">â<code class="docutils literal notranslate"><span class="pre">llvm.readcyclecounter</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id405" id="id1602">Syntax:</a></li>
+<li><a class="reference internal" href="#id406" id="id1603">Overview:</a></li>
+<li><a class="reference internal" href="#id407" id="id1604">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-clear-cache-intrinsic" id="id1605">â<code class="docutils literal notranslate"><span class="pre">llvm.clear_cache</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id408" id="id1606">Syntax:</a></li>
+<li><a class="reference internal" href="#id409" id="id1607">Overview:</a></li>
+<li><a class="reference internal" href="#id410" id="id1608">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-instrprof-increment-intrinsic" id="id1609">â<code class="docutils literal notranslate"><span class="pre">llvm.instrprof.increment</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id411" id="id1610">Syntax:</a></li>
+<li><a class="reference internal" href="#id412" id="id1611">Overview:</a></li>
+<li><a class="reference internal" href="#id413" id="id1612">Arguments:</a></li>
+<li><a class="reference internal" href="#id414" id="id1613">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-instrprof-increment-step-intrinsic" id="id1614">â<code class="docutils literal notranslate"><span class="pre">llvm.instrprof.increment.step</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id415" id="id1615">Syntax:</a></li>
+<li><a class="reference internal" href="#id416" id="id1616">Overview:</a></li>
+<li><a class="reference internal" href="#id417" id="id1617">Arguments:</a></li>
+<li><a class="reference internal" href="#id418" id="id1618">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-instrprof-value-profile-intrinsic" id="id1619">â<code class="docutils literal notranslate"><span class="pre">llvm.instrprof.value.profile</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id419" id="id1620">Syntax:</a></li>
+<li><a class="reference internal" href="#id420" id="id1621">Overview:</a></li>
+<li><a class="reference internal" href="#id421" id="id1622">Arguments:</a></li>
+<li><a class="reference internal" href="#id422" id="id1623">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-thread-pointer-intrinsic" id="id1624">â<code class="docutils literal notranslate"><span class="pre">llvm.thread.pointer</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id423" id="id1625">Syntax:</a></li>
+<li><a class="reference internal" href="#id424" id="id1626">Overview:</a></li>
+<li><a class="reference internal" href="#id425" id="id1627">Semantics:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#standard-c-library-intrinsics" id="id1628">Standard C Library Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-memcpy-intrinsic" id="id1629">â<code class="docutils literal notranslate"><span class="pre">llvm.memcpy</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id426" id="id1630">Syntax:</a></li>
+<li><a class="reference internal" href="#id427" id="id1631">Overview:</a></li>
+<li><a class="reference internal" href="#id428" id="id1632">Arguments:</a></li>
+<li><a class="reference internal" href="#id429" id="id1633">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-memmove-intrinsic" id="id1634">â<code class="docutils literal notranslate"><span class="pre">llvm.memmove</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id430" id="id1635">Syntax:</a></li>
+<li><a class="reference internal" href="#id431" id="id1636">Overview:</a></li>
+<li><a class="reference internal" href="#id432" id="id1637">Arguments:</a></li>
+<li><a class="reference internal" href="#id433" id="id1638">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-memset-intrinsics" id="id1639">â<code class="docutils literal notranslate"><span class="pre">llvm.memset.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id434" id="id1640">Syntax:</a></li>
+<li><a class="reference internal" href="#id435" id="id1641">Overview:</a></li>
+<li><a class="reference internal" href="#id436" id="id1642">Arguments:</a></li>
+<li><a class="reference internal" href="#id437" id="id1643">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-sqrt-intrinsic" id="id1644">â<code class="docutils literal notranslate"><span class="pre">llvm.sqrt.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id438" id="id1645">Syntax:</a></li>
+<li><a class="reference internal" href="#id439" id="id1646">Overview:</a></li>
+<li><a class="reference internal" href="#id440" id="id1647">Arguments:</a></li>
+<li><a class="reference internal" href="#id441" id="id1648">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-powi-intrinsic" id="id1649">â<code class="docutils literal notranslate"><span class="pre">llvm.powi.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id442" id="id1650">Syntax:</a></li>
+<li><a class="reference internal" href="#id443" id="id1651">Overview:</a></li>
+<li><a class="reference internal" href="#id444" id="id1652">Arguments:</a></li>
+<li><a class="reference internal" href="#id445" id="id1653">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-sin-intrinsic" id="id1654">â<code class="docutils literal notranslate"><span class="pre">llvm.sin.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id446" id="id1655">Syntax:</a></li>
+<li><a class="reference internal" href="#id447" id="id1656">Overview:</a></li>
+<li><a class="reference internal" href="#id448" id="id1657">Arguments:</a></li>
+<li><a class="reference internal" href="#id449" id="id1658">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-cos-intrinsic" id="id1659">â<code class="docutils literal notranslate"><span class="pre">llvm.cos.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id450" id="id1660">Syntax:</a></li>
+<li><a class="reference internal" href="#id451" id="id1661">Overview:</a></li>
+<li><a class="reference internal" href="#id452" id="id1662">Arguments:</a></li>
+<li><a class="reference internal" href="#id453" id="id1663">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-pow-intrinsic" id="id1664">â<code class="docutils literal notranslate"><span class="pre">llvm.pow.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id454" id="id1665">Syntax:</a></li>
+<li><a class="reference internal" href="#id455" id="id1666">Overview:</a></li>
+<li><a class="reference internal" href="#id456" id="id1667">Arguments:</a></li>
+<li><a class="reference internal" href="#id457" id="id1668">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-exp-intrinsic" id="id1669">â<code class="docutils literal notranslate"><span class="pre">llvm.exp.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id458" id="id1670">Syntax:</a></li>
+<li><a class="reference internal" href="#id459" id="id1671">Overview:</a></li>
+<li><a class="reference internal" href="#id460" id="id1672">Arguments:</a></li>
+<li><a class="reference internal" href="#id461" id="id1673">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-exp2-intrinsic" id="id1674">â<code class="docutils literal notranslate"><span class="pre">llvm.exp2.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id462" id="id1675">Syntax:</a></li>
+<li><a class="reference internal" href="#id463" id="id1676">Overview:</a></li>
+<li><a class="reference internal" href="#id464" id="id1677">Arguments:</a></li>
+<li><a class="reference internal" href="#id465" id="id1678">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-log-intrinsic" id="id1679">â<code class="docutils literal notranslate"><span class="pre">llvm.log.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id466" id="id1680">Syntax:</a></li>
+<li><a class="reference internal" href="#id467" id="id1681">Overview:</a></li>
+<li><a class="reference internal" href="#id468" id="id1682">Arguments:</a></li>
+<li><a class="reference internal" href="#id469" id="id1683">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-log10-intrinsic" id="id1684">â<code class="docutils literal notranslate"><span class="pre">llvm.log10.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id470" id="id1685">Syntax:</a></li>
+<li><a class="reference internal" href="#id471" id="id1686">Overview:</a></li>
+<li><a class="reference internal" href="#id472" id="id1687">Arguments:</a></li>
+<li><a class="reference internal" href="#id473" id="id1688">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-log2-intrinsic" id="id1689">â<code class="docutils literal notranslate"><span class="pre">llvm.log2.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id474" id="id1690">Syntax:</a></li>
+<li><a class="reference internal" href="#id475" id="id1691">Overview:</a></li>
+<li><a class="reference internal" href="#id476" id="id1692">Arguments:</a></li>
+<li><a class="reference internal" href="#id477" id="id1693">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-fma-intrinsic" id="id1694">â<code class="docutils literal notranslate"><span class="pre">llvm.fma.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id478" id="id1695">Syntax:</a></li>
+<li><a class="reference internal" href="#id479" id="id1696">Overview:</a></li>
+<li><a class="reference internal" href="#id480" id="id1697">Arguments:</a></li>
+<li><a class="reference internal" href="#id481" id="id1698">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-fabs-intrinsic" id="id1699">â<code class="docutils literal notranslate"><span class="pre">llvm.fabs.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id482" id="id1700">Syntax:</a></li>
+<li><a class="reference internal" href="#id483" id="id1701">Overview:</a></li>
+<li><a class="reference internal" href="#id484" id="id1702">Arguments:</a></li>
+<li><a class="reference internal" href="#id485" id="id1703">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-minnum-intrinsic" id="id1704">â<code class="docutils literal notranslate"><span class="pre">llvm.minnum.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id486" id="id1705">Syntax:</a></li>
+<li><a class="reference internal" href="#id487" id="id1706">Overview:</a></li>
+<li><a class="reference internal" href="#id488" id="id1707">Arguments:</a></li>
+<li><a class="reference internal" href="#id489" id="id1708">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-maxnum-intrinsic" id="id1709">â<code class="docutils literal notranslate"><span class="pre">llvm.maxnum.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id490" id="id1710">Syntax:</a></li>
+<li><a class="reference internal" href="#id491" id="id1711">Overview:</a></li>
+<li><a class="reference internal" href="#id492" id="id1712">Arguments:</a></li>
+<li><a class="reference internal" href="#id493" id="id1713">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-minimum-intrinsic" id="id1714">â<code class="docutils literal notranslate"><span class="pre">llvm.minimum.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id494" id="id1715">Syntax:</a></li>
+<li><a class="reference internal" href="#id495" id="id1716">Overview:</a></li>
+<li><a class="reference internal" href="#id496" id="id1717">Arguments:</a></li>
+<li><a class="reference internal" href="#id497" id="id1718">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-maximum-intrinsic" id="id1719">â<code class="docutils literal notranslate"><span class="pre">llvm.maximum.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id498" id="id1720">Syntax:</a></li>
+<li><a class="reference internal" href="#id499" id="id1721">Overview:</a></li>
+<li><a class="reference internal" href="#id500" id="id1722">Arguments:</a></li>
+<li><a class="reference internal" href="#id501" id="id1723">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-copysign-intrinsic" id="id1724">â<code class="docutils literal notranslate"><span class="pre">llvm.copysign.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id502" id="id1725">Syntax:</a></li>
+<li><a class="reference internal" href="#id503" id="id1726">Overview:</a></li>
+<li><a class="reference internal" href="#id504" id="id1727">Arguments:</a></li>
+<li><a class="reference internal" href="#id505" id="id1728">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-floor-intrinsic" id="id1729">â<code class="docutils literal notranslate"><span class="pre">llvm.floor.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id506" id="id1730">Syntax:</a></li>
+<li><a class="reference internal" href="#id507" id="id1731">Overview:</a></li>
+<li><a class="reference internal" href="#id508" id="id1732">Arguments:</a></li>
+<li><a class="reference internal" href="#id509" id="id1733">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-ceil-intrinsic" id="id1734">â<code class="docutils literal notranslate"><span class="pre">llvm.ceil.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id510" id="id1735">Syntax:</a></li>
+<li><a class="reference internal" href="#id511" id="id1736">Overview:</a></li>
+<li><a class="reference internal" href="#id512" id="id1737">Arguments:</a></li>
+<li><a class="reference internal" href="#id513" id="id1738">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-trunc-intrinsic" id="id1739">â<code class="docutils literal notranslate"><span class="pre">llvm.trunc.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id514" id="id1740">Syntax:</a></li>
+<li><a class="reference internal" href="#id515" id="id1741">Overview:</a></li>
+<li><a class="reference internal" href="#id516" id="id1742">Arguments:</a></li>
+<li><a class="reference internal" href="#id517" id="id1743">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-rint-intrinsic" id="id1744">â<code class="docutils literal notranslate"><span class="pre">llvm.rint.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id518" id="id1745">Syntax:</a></li>
+<li><a class="reference internal" href="#id519" id="id1746">Overview:</a></li>
+<li><a class="reference internal" href="#id520" id="id1747">Arguments:</a></li>
+<li><a class="reference internal" href="#id521" id="id1748">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-nearbyint-intrinsic" id="id1749">â<code class="docutils literal notranslate"><span class="pre">llvm.nearbyint.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id522" id="id1750">Syntax:</a></li>
+<li><a class="reference internal" href="#id523" id="id1751">Overview:</a></li>
+<li><a class="reference internal" href="#id524" id="id1752">Arguments:</a></li>
+<li><a class="reference internal" href="#id525" id="id1753">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-round-intrinsic" id="id1754">â<code class="docutils literal notranslate"><span class="pre">llvm.round.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id526" id="id1755">Syntax:</a></li>
+<li><a class="reference internal" href="#id527" id="id1756">Overview:</a></li>
+<li><a class="reference internal" href="#id528" id="id1757">Arguments:</a></li>
+<li><a class="reference internal" href="#id529" id="id1758">Semantics:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#bit-manipulation-intrinsics" id="id1759">Bit Manipulation Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-bitreverse-intrinsics" id="id1760">â<code class="docutils literal notranslate"><span class="pre">llvm.bitreverse.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id530" id="id1761">Syntax:</a></li>
+<li><a class="reference internal" href="#id531" id="id1762">Overview:</a></li>
+<li><a class="reference internal" href="#id532" id="id1763">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-bswap-intrinsics" id="id1764">â<code class="docutils literal notranslate"><span class="pre">llvm.bswap.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id533" id="id1765">Syntax:</a></li>
+<li><a class="reference internal" href="#id534" id="id1766">Overview:</a></li>
+<li><a class="reference internal" href="#id535" id="id1767">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-ctpop-intrinsic" id="id1768">â<code class="docutils literal notranslate"><span class="pre">llvm.ctpop.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id536" id="id1769">Syntax:</a></li>
+<li><a class="reference internal" href="#id537" id="id1770">Overview:</a></li>
+<li><a class="reference internal" href="#id538" id="id1771">Arguments:</a></li>
+<li><a class="reference internal" href="#id539" id="id1772">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-ctlz-intrinsic" id="id1773">â<code class="docutils literal notranslate"><span class="pre">llvm.ctlz.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id540" id="id1774">Syntax:</a></li>
+<li><a class="reference internal" href="#id541" id="id1775">Overview:</a></li>
+<li><a class="reference internal" href="#id542" id="id1776">Arguments:</a></li>
+<li><a class="reference internal" href="#id543" id="id1777">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-cttz-intrinsic" id="id1778">â<code class="docutils literal notranslate"><span class="pre">llvm.cttz.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id544" id="id1779">Syntax:</a></li>
+<li><a class="reference internal" href="#id545" id="id1780">Overview:</a></li>
+<li><a class="reference internal" href="#id546" id="id1781">Arguments:</a></li>
+<li><a class="reference internal" href="#id547" id="id1782">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-fshl-intrinsic" id="id1783">â<code class="docutils literal notranslate"><span class="pre">llvm.fshl.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id548" id="id1784">Syntax:</a></li>
+<li><a class="reference internal" href="#id549" id="id1785">Overview:</a></li>
+<li><a class="reference internal" href="#id550" id="id1786">Arguments:</a></li>
+<li><a class="reference internal" href="#id551" id="id1787">Example:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-fshr-intrinsic" id="id1788">â<code class="docutils literal notranslate"><span class="pre">llvm.fshr.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id552" id="id1789">Syntax:</a></li>
+<li><a class="reference internal" href="#id553" id="id1790">Overview:</a></li>
+<li><a class="reference internal" href="#id554" id="id1791">Arguments:</a></li>
+<li><a class="reference internal" href="#id555" id="id1792">Example:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#arithmetic-with-overflow-intrinsics" id="id1793">Arithmetic with Overflow Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-sadd-with-overflow-intrinsics" id="id1794">â<code class="docutils literal notranslate"><span class="pre">llvm.sadd.with.overflow.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id556" id="id1795">Syntax:</a></li>
+<li><a class="reference internal" href="#id557" id="id1796">Overview:</a></li>
+<li><a class="reference internal" href="#id558" id="id1797">Arguments:</a></li>
+<li><a class="reference internal" href="#id559" id="id1798">Semantics:</a></li>
+<li><a class="reference internal" href="#id560" id="id1799">Examples:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-uadd-with-overflow-intrinsics" id="id1800">â<code class="docutils literal notranslate"><span class="pre">llvm.uadd.with.overflow.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id561" id="id1801">Syntax:</a></li>
+<li><a class="reference internal" href="#id562" id="id1802">Overview:</a></li>
+<li><a class="reference internal" href="#id563" id="id1803">Arguments:</a></li>
+<li><a class="reference internal" href="#id564" id="id1804">Semantics:</a></li>
+<li><a class="reference internal" href="#id565" id="id1805">Examples:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-ssub-with-overflow-intrinsics" id="id1806">â<code class="docutils literal notranslate"><span class="pre">llvm.ssub.with.overflow.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id566" id="id1807">Syntax:</a></li>
+<li><a class="reference internal" href="#id567" id="id1808">Overview:</a></li>
+<li><a class="reference internal" href="#id568" id="id1809">Arguments:</a></li>
+<li><a class="reference internal" href="#id569" id="id1810">Semantics:</a></li>
+<li><a class="reference internal" href="#id570" id="id1811">Examples:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-usub-with-overflow-intrinsics" id="id1812">â<code class="docutils literal notranslate"><span class="pre">llvm.usub.with.overflow.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id571" id="id1813">Syntax:</a></li>
+<li><a class="reference internal" href="#id572" id="id1814">Overview:</a></li>
+<li><a class="reference internal" href="#id573" id="id1815">Arguments:</a></li>
+<li><a class="reference internal" href="#id574" id="id1816">Semantics:</a></li>
+<li><a class="reference internal" href="#id575" id="id1817">Examples:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-smul-with-overflow-intrinsics" id="id1818">â<code class="docutils literal notranslate"><span class="pre">llvm.smul.with.overflow.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id576" id="id1819">Syntax:</a></li>
+<li><a class="reference internal" href="#id577" id="id1820">Overview:</a></li>
+<li><a class="reference internal" href="#id578" id="id1821">Arguments:</a></li>
+<li><a class="reference internal" href="#id579" id="id1822">Semantics:</a></li>
+<li><a class="reference internal" href="#id580" id="id1823">Examples:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-umul-with-overflow-intrinsics" id="id1824">â<code class="docutils literal notranslate"><span class="pre">llvm.umul.with.overflow.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id581" id="id1825">Syntax:</a></li>
+<li><a class="reference internal" href="#id582" id="id1826">Overview:</a></li>
+<li><a class="reference internal" href="#id583" id="id1827">Arguments:</a></li>
+<li><a class="reference internal" href="#id584" id="id1828">Semantics:</a></li>
+<li><a class="reference internal" href="#id585" id="id1829">Examples:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#saturation-arithmetic-intrinsics" id="id1830">Saturation Arithmetic Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-sadd-sat-intrinsics" id="id1831">â<code class="docutils literal notranslate"><span class="pre">llvm.sadd.sat.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id586" id="id1832">Syntax</a></li>
+<li><a class="reference internal" href="#id587" id="id1833">Overview</a></li>
+<li><a class="reference internal" href="#id588" id="id1834">Arguments</a></li>
+<li><a class="reference internal" href="#id589" id="id1835">Semantics:</a></li>
+<li><a class="reference internal" href="#id590" id="id1836">Examples</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-uadd-sat-intrinsics" id="id1837">â<code class="docutils literal notranslate"><span class="pre">llvm.uadd.sat.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id591" id="id1838">Syntax</a></li>
+<li><a class="reference internal" href="#id592" id="id1839">Overview</a></li>
+<li><a class="reference internal" href="#id593" id="id1840">Arguments</a></li>
+<li><a class="reference internal" href="#id594" id="id1841">Semantics:</a></li>
+<li><a class="reference internal" href="#id595" id="id1842">Examples</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-ssub-sat-intrinsics" id="id1843">â<code class="docutils literal notranslate"><span class="pre">llvm.ssub.sat.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id596" id="id1844">Syntax</a></li>
+<li><a class="reference internal" href="#id597" id="id1845">Overview</a></li>
+<li><a class="reference internal" href="#id598" id="id1846">Arguments</a></li>
+<li><a class="reference internal" href="#id599" id="id1847">Semantics:</a></li>
+<li><a class="reference internal" href="#id600" id="id1848">Examples</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-usub-sat-intrinsics" id="id1849">â<code class="docutils literal notranslate"><span class="pre">llvm.usub.sat.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id601" id="id1850">Syntax</a></li>
+<li><a class="reference internal" href="#id602" id="id1851">Overview</a></li>
+<li><a class="reference internal" href="#id603" id="id1852">Arguments</a></li>
+<li><a class="reference internal" href="#id604" id="id1853">Semantics:</a></li>
+<li><a class="reference internal" href="#id605" id="id1854">Examples</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#fixed-point-arithmetic-intrinsics" id="id1855">Fixed Point Arithmetic Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-smul-fix-intrinsics" id="id1856">â<code class="docutils literal notranslate"><span class="pre">llvm.smul.fix.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id606" id="id1857">Syntax</a></li>
+<li><a class="reference internal" href="#id607" id="id1858">Overview</a></li>
+<li><a class="reference internal" href="#id608" id="id1859">Arguments</a></li>
+<li><a class="reference internal" href="#id609" id="id1860">Semantics:</a></li>
+<li><a class="reference internal" href="#id610" id="id1861">Examples</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#specialised-arithmetic-intrinsics" id="id1862">Specialised Arithmetic Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-canonicalize-intrinsic" id="id1863">â<code class="docutils literal notranslate"><span class="pre">llvm.canonicalize.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id611" id="id1864">Syntax:</a></li>
+<li><a class="reference internal" href="#id612" id="id1865">Overview:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-fmuladd-intrinsic" id="id1866">â<code class="docutils literal notranslate"><span class="pre">llvm.fmuladd.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id613" id="id1867">Syntax:</a></li>
+<li><a class="reference internal" href="#id614" id="id1868">Overview:</a></li>
+<li><a class="reference internal" href="#id615" id="id1869">Arguments:</a></li>
+<li><a class="reference internal" href="#id616" id="id1870">Semantics:</a></li>
+<li><a class="reference internal" href="#id617" id="id1871">Examples:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#experimental-vector-reduction-intrinsics" id="id1872">Experimental Vector Reduction Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-experimental-vector-reduce-add-intrinsic" id="id1873">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.vector.reduce.add.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id618" id="id1874">Syntax:</a></li>
+<li><a class="reference internal" href="#id619" id="id1875">Overview:</a></li>
+<li><a class="reference internal" href="#id620" id="id1876">Arguments:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-vector-reduce-fadd-intrinsic" id="id1877">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.vector.reduce.fadd.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id621" id="id1878">Syntax:</a></li>
+<li><a class="reference internal" href="#id622" id="id1879">Overview:</a></li>
+<li><a class="reference internal" href="#id623" id="id1880">Arguments:</a></li>
+<li><a class="reference internal" href="#id624" id="id1881">Examples:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-vector-reduce-mul-intrinsic" id="id1882">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.vector.reduce.mul.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id625" id="id1883">Syntax:</a></li>
+<li><a class="reference internal" href="#id626" id="id1884">Overview:</a></li>
+<li><a class="reference internal" href="#id627" id="id1885">Arguments:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-vector-reduce-fmul-intrinsic" id="id1886">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.vector.reduce.fmul.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id628" id="id1887">Syntax:</a></li>
+<li><a class="reference internal" href="#id629" id="id1888">Overview:</a></li>
+<li><a class="reference internal" href="#id630" id="id1889">Arguments:</a></li>
+<li><a class="reference internal" href="#id631" id="id1890">Examples:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-vector-reduce-and-intrinsic" id="id1891">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.vector.reduce.and.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id632" id="id1892">Syntax:</a></li>
+<li><a class="reference internal" href="#id633" id="id1893">Overview:</a></li>
+<li><a class="reference internal" href="#id634" id="id1894">Arguments:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-vector-reduce-or-intrinsic" id="id1895">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.vector.reduce.or.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id635" id="id1896">Syntax:</a></li>
+<li><a class="reference internal" href="#id636" id="id1897">Overview:</a></li>
+<li><a class="reference internal" href="#id637" id="id1898">Arguments:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-vector-reduce-xor-intrinsic" id="id1899">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.vector.reduce.xor.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id638" id="id1900">Syntax:</a></li>
+<li><a class="reference internal" href="#id639" id="id1901">Overview:</a></li>
+<li><a class="reference internal" href="#id640" id="id1902">Arguments:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-vector-reduce-smax-intrinsic" id="id1903">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.vector.reduce.smax.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id641" id="id1904">Syntax:</a></li>
+<li><a class="reference internal" href="#id642" id="id1905">Overview:</a></li>
+<li><a class="reference internal" href="#id643" id="id1906">Arguments:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-vector-reduce-smin-intrinsic" id="id1907">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.vector.reduce.smin.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id644" id="id1908">Syntax:</a></li>
+<li><a class="reference internal" href="#id645" id="id1909">Overview:</a></li>
+<li><a class="reference internal" href="#id646" id="id1910">Arguments:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-vector-reduce-umax-intrinsic" id="id1911">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.vector.reduce.umax.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id647" id="id1912">Syntax:</a></li>
+<li><a class="reference internal" href="#id648" id="id1913">Overview:</a></li>
+<li><a class="reference internal" href="#id649" id="id1914">Arguments:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-vector-reduce-umin-intrinsic" id="id1915">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.vector.reduce.umin.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id650" id="id1916">Syntax:</a></li>
+<li><a class="reference internal" href="#id651" id="id1917">Overview:</a></li>
+<li><a class="reference internal" href="#id652" id="id1918">Arguments:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-vector-reduce-fmax-intrinsic" id="id1919">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.vector.reduce.fmax.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id653" id="id1920">Syntax:</a></li>
+<li><a class="reference internal" href="#id654" id="id1921">Overview:</a></li>
+<li><a class="reference internal" href="#id655" id="id1922">Arguments:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-vector-reduce-fmin-intrinsic" id="id1923">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.vector.reduce.fmin.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id656" id="id1924">Syntax:</a></li>
+<li><a class="reference internal" href="#id657" id="id1925">Overview:</a></li>
+<li><a class="reference internal" href="#id658" id="id1926">Arguments:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#half-precision-floating-point-intrinsics" id="id1927">Half Precision Floating-Point Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-convert-to-fp16-intrinsic" id="id1928">â<code class="docutils literal notranslate"><span class="pre">llvm.convert.to.fp16</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id659" id="id1929">Syntax:</a></li>
+<li><a class="reference internal" href="#id660" id="id1930">Overview:</a></li>
+<li><a class="reference internal" href="#id661" id="id1931">Arguments:</a></li>
+<li><a class="reference internal" href="#id662" id="id1932">Semantics:</a></li>
+<li><a class="reference internal" href="#id663" id="id1933">Examples:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-convert-from-fp16-intrinsic" id="id1934">â<code class="docutils literal notranslate"><span class="pre">llvm.convert.from.fp16</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id664" id="id1935">Syntax:</a></li>
+<li><a class="reference internal" href="#id665" id="id1936">Overview:</a></li>
+<li><a class="reference internal" href="#id666" id="id1937">Arguments:</a></li>
+<li><a class="reference internal" href="#id667" id="id1938">Semantics:</a></li>
+<li><a class="reference internal" href="#id668" id="id1939">Examples:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#debugger-intrinsics" id="id1940">Debugger Intrinsics</a></li>
+<li><a class="reference internal" href="#exception-handling-intrinsics" id="id1941">Exception Handling Intrinsics</a></li>
+<li><a class="reference internal" href="#trampoline-intrinsics" id="id1942">Trampoline Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-init-trampoline-intrinsic" id="id1943">â<code class="docutils literal notranslate"><span class="pre">llvm.init.trampoline</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id669" id="id1944">Syntax:</a></li>
+<li><a class="reference internal" href="#id670" id="id1945">Overview:</a></li>
+<li><a class="reference internal" href="#id671" id="id1946">Arguments:</a></li>
+<li><a class="reference internal" href="#id672" id="id1947">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-adjust-trampoline-intrinsic" id="id1948">â<code class="docutils literal notranslate"><span class="pre">llvm.adjust.trampoline</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id673" id="id1949">Syntax:</a></li>
+<li><a class="reference internal" href="#id674" id="id1950">Overview:</a></li>
+<li><a class="reference internal" href="#id675" id="id1951">Arguments:</a></li>
+<li><a class="reference internal" href="#id676" id="id1952">Semantics:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#masked-vector-load-and-store-intrinsics" id="id1953">Masked Vector Load and Store Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-masked-load-intrinsics" id="id1954">â<code class="docutils literal notranslate"><span class="pre">llvm.masked.load.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id677" id="id1955">Syntax:</a></li>
+<li><a class="reference internal" href="#id678" id="id1956">Overview:</a></li>
+<li><a class="reference internal" href="#id679" id="id1957">Arguments:</a></li>
+<li><a class="reference internal" href="#id680" id="id1958">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-masked-store-intrinsics" id="id1959">â<code class="docutils literal notranslate"><span class="pre">llvm.masked.store.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id681" id="id1960">Syntax:</a></li>
+<li><a class="reference internal" href="#id682" id="id1961">Overview:</a></li>
+<li><a class="reference internal" href="#id683" id="id1962">Arguments:</a></li>
+<li><a class="reference internal" href="#id684" id="id1963">Semantics:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#masked-vector-gather-and-scatter-intrinsics" id="id1964">Masked Vector Gather and Scatter Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-masked-gather-intrinsics" id="id1965">â<code class="docutils literal notranslate"><span class="pre">llvm.masked.gather.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id685" id="id1966">Syntax:</a></li>
+<li><a class="reference internal" href="#id686" id="id1967">Overview:</a></li>
+<li><a class="reference internal" href="#id687" id="id1968">Arguments:</a></li>
+<li><a class="reference internal" href="#id688" id="id1969">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-masked-scatter-intrinsics" id="id1970">â<code class="docutils literal notranslate"><span class="pre">llvm.masked.scatter.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id689" id="id1971">Syntax:</a></li>
+<li><a class="reference internal" href="#id690" id="id1972">Overview:</a></li>
+<li><a class="reference internal" href="#id691" id="id1973">Arguments:</a></li>
+<li><a class="reference internal" href="#id692" id="id1974">Semantics:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#masked-vector-expanding-load-and-compressing-store-intrinsics" id="id1975">Masked Vector Expanding Load and Compressing Store Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-masked-expandload-intrinsics" id="id1976">â<code class="docutils literal notranslate"><span class="pre">llvm.masked.expandload.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id693" id="id1977">Syntax:</a></li>
+<li><a class="reference internal" href="#id694" id="id1978">Overview:</a></li>
+<li><a class="reference internal" href="#id695" id="id1979">Arguments:</a></li>
+<li><a class="reference internal" href="#id696" id="id1980">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-masked-compressstore-intrinsics" id="id1981">â<code class="docutils literal notranslate"><span class="pre">llvm.masked.compressstore.*</span></code>â Intrinsics</a><ul>
+<li><a class="reference internal" href="#id697" id="id1982">Syntax:</a></li>
+<li><a class="reference internal" href="#id698" id="id1983">Overview:</a></li>
+<li><a class="reference internal" href="#id699" id="id1984">Arguments:</a></li>
+<li><a class="reference internal" href="#id700" id="id1985">Semantics:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#memory-use-markers" id="id1986">Memory Use Markers</a><ul>
+<li><a class="reference internal" href="#llvm-lifetime-start-intrinsic" id="id1987">â<code class="docutils literal notranslate"><span class="pre">llvm.lifetime.start</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id701" id="id1988">Syntax:</a></li>
+<li><a class="reference internal" href="#id702" id="id1989">Overview:</a></li>
+<li><a class="reference internal" href="#id703" id="id1990">Arguments:</a></li>
+<li><a class="reference internal" href="#id704" id="id1991">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-lifetime-end-intrinsic" id="id1992">â<code class="docutils literal notranslate"><span class="pre">llvm.lifetime.end</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id705" id="id1993">Syntax:</a></li>
+<li><a class="reference internal" href="#id706" id="id1994">Overview:</a></li>
+<li><a class="reference internal" href="#id707" id="id1995">Arguments:</a></li>
+<li><a class="reference internal" href="#id708" id="id1996">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-invariant-start-intrinsic" id="id1997">â<code class="docutils literal notranslate"><span class="pre">llvm.invariant.start</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id709" id="id1998">Syntax:</a></li>
+<li><a class="reference internal" href="#id710" id="id1999">Overview:</a></li>
+<li><a class="reference internal" href="#id711" id="id2000">Arguments:</a></li>
+<li><a class="reference internal" href="#id712" id="id2001">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-invariant-end-intrinsic" id="id2002">â<code class="docutils literal notranslate"><span class="pre">llvm.invariant.end</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id713" id="id2003">Syntax:</a></li>
+<li><a class="reference internal" href="#id714" id="id2004">Overview:</a></li>
+<li><a class="reference internal" href="#id715" id="id2005">Arguments:</a></li>
+<li><a class="reference internal" href="#id716" id="id2006">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-launder-invariant-group-intrinsic" id="id2007">â<code class="docutils literal notranslate"><span class="pre">llvm.launder.invariant.group</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id717" id="id2008">Syntax:</a></li>
+<li><a class="reference internal" href="#id718" id="id2009">Overview:</a></li>
+<li><a class="reference internal" href="#id719" id="id2010">Arguments:</a></li>
+<li><a class="reference internal" href="#id720" id="id2011">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-strip-invariant-group-intrinsic" id="id2012">â<code class="docutils literal notranslate"><span class="pre">llvm.strip.invariant.group</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id721" id="id2013">Syntax:</a></li>
+<li><a class="reference internal" href="#id722" id="id2014">Overview:</a></li>
+<li><a class="reference internal" href="#id723" id="id2015">Arguments:</a></li>
+<li><a class="reference internal" href="#id724" id="id2016">Semantics:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#constrained-floating-point-intrinsics" id="id2017">Constrained Floating-Point Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-experimental-constrained-fadd-intrinsic" id="id2018">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.fadd</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id725" id="id2019">Syntax:</a></li>
+<li><a class="reference internal" href="#id726" id="id2020">Overview:</a></li>
+<li><a class="reference internal" href="#id727" id="id2021">Arguments:</a></li>
+<li><a class="reference internal" href="#id728" id="id2022">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-fsub-intrinsic" id="id2023">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.fsub</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id729" id="id2024">Syntax:</a></li>
+<li><a class="reference internal" href="#id730" id="id2025">Overview:</a></li>
+<li><a class="reference internal" href="#id731" id="id2026">Arguments:</a></li>
+<li><a class="reference internal" href="#id732" id="id2027">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-fmul-intrinsic" id="id2028">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.fmul</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id733" id="id2029">Syntax:</a></li>
+<li><a class="reference internal" href="#id734" id="id2030">Overview:</a></li>
+<li><a class="reference internal" href="#id735" id="id2031">Arguments:</a></li>
+<li><a class="reference internal" href="#id736" id="id2032">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-fdiv-intrinsic" id="id2033">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.fdiv</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id737" id="id2034">Syntax:</a></li>
+<li><a class="reference internal" href="#id738" id="id2035">Overview:</a></li>
+<li><a class="reference internal" href="#id739" id="id2036">Arguments:</a></li>
+<li><a class="reference internal" href="#id740" id="id2037">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-frem-intrinsic" id="id2038">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.frem</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id741" id="id2039">Syntax:</a></li>
+<li><a class="reference internal" href="#id742" id="id2040">Overview:</a></li>
+<li><a class="reference internal" href="#id743" id="id2041">Arguments:</a></li>
+<li><a class="reference internal" href="#id744" id="id2042">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-fma-intrinsic" id="id2043">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.fma</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id745" id="id2044">Syntax:</a></li>
+<li><a class="reference internal" href="#id746" id="id2045">Overview:</a></li>
+<li><a class="reference internal" href="#id747" id="id2046">Arguments:</a></li>
+<li><a class="reference internal" href="#id748" id="id2047">Semantics:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#constrained-libm-equivalent-intrinsics" id="id2048">Constrained libm-equivalent Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-experimental-constrained-sqrt-intrinsic" id="id2049">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.sqrt</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id749" id="id2050">Syntax:</a></li>
+<li><a class="reference internal" href="#id750" id="id2051">Overview:</a></li>
+<li><a class="reference internal" href="#id751" id="id2052">Arguments:</a></li>
+<li><a class="reference internal" href="#id752" id="id2053">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-pow-intrinsic" id="id2054">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.pow</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id753" id="id2055">Syntax:</a></li>
+<li><a class="reference internal" href="#id754" id="id2056">Overview:</a></li>
+<li><a class="reference internal" href="#id755" id="id2057">Arguments:</a></li>
+<li><a class="reference internal" href="#id756" id="id2058">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-powi-intrinsic" id="id2059">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.powi</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id757" id="id2060">Syntax:</a></li>
+<li><a class="reference internal" href="#id758" id="id2061">Overview:</a></li>
+<li><a class="reference internal" href="#id759" id="id2062">Arguments:</a></li>
+<li><a class="reference internal" href="#id760" id="id2063">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-sin-intrinsic" id="id2064">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.sin</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id761" id="id2065">Syntax:</a></li>
+<li><a class="reference internal" href="#id762" id="id2066">Overview:</a></li>
+<li><a class="reference internal" href="#id763" id="id2067">Arguments:</a></li>
+<li><a class="reference internal" href="#id764" id="id2068">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-cos-intrinsic" id="id2069">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.cos</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id765" id="id2070">Syntax:</a></li>
+<li><a class="reference internal" href="#id766" id="id2071">Overview:</a></li>
+<li><a class="reference internal" href="#id767" id="id2072">Arguments:</a></li>
+<li><a class="reference internal" href="#id768" id="id2073">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-exp-intrinsic" id="id2074">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.exp</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id769" id="id2075">Syntax:</a></li>
+<li><a class="reference internal" href="#id770" id="id2076">Overview:</a></li>
+<li><a class="reference internal" href="#id771" id="id2077">Arguments:</a></li>
+<li><a class="reference internal" href="#id772" id="id2078">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-exp2-intrinsic" id="id2079">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.exp2</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id773" id="id2080">Syntax:</a></li>
+<li><a class="reference internal" href="#id774" id="id2081">Overview:</a></li>
+<li><a class="reference internal" href="#id775" id="id2082">Arguments:</a></li>
+<li><a class="reference internal" href="#id776" id="id2083">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-log-intrinsic" id="id2084">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.log</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id777" id="id2085">Syntax:</a></li>
+<li><a class="reference internal" href="#id778" id="id2086">Overview:</a></li>
+<li><a class="reference internal" href="#id779" id="id2087">Arguments:</a></li>
+<li><a class="reference internal" href="#id780" id="id2088">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-log10-intrinsic" id="id2089">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.log10</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id781" id="id2090">Syntax:</a></li>
+<li><a class="reference internal" href="#id782" id="id2091">Overview:</a></li>
+<li><a class="reference internal" href="#id783" id="id2092">Arguments:</a></li>
+<li><a class="reference internal" href="#id784" id="id2093">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-log2-intrinsic" id="id2094">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.log2</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id785" id="id2095">Syntax:</a></li>
+<li><a class="reference internal" href="#id786" id="id2096">Overview:</a></li>
+<li><a class="reference internal" href="#id787" id="id2097">Arguments:</a></li>
+<li><a class="reference internal" href="#id788" id="id2098">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-rint-intrinsic" id="id2099">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.rint</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id789" id="id2100">Syntax:</a></li>
+<li><a class="reference internal" href="#id790" id="id2101">Overview:</a></li>
+<li><a class="reference internal" href="#id791" id="id2102">Arguments:</a></li>
+<li><a class="reference internal" href="#id792" id="id2103">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-nearbyint-intrinsic" id="id2104">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.nearbyint</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id793" id="id2105">Syntax:</a></li>
+<li><a class="reference internal" href="#id794" id="id2106">Overview:</a></li>
+<li><a class="reference internal" href="#id795" id="id2107">Arguments:</a></li>
+<li><a class="reference internal" href="#id796" id="id2108">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-maxnum-intrinsic" id="id2109">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.maxnum</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id797" id="id2110">Syntax:</a></li>
+<li><a class="reference internal" href="#id798" id="id2111">Overview:</a></li>
+<li><a class="reference internal" href="#id799" id="id2112">Arguments:</a></li>
+<li><a class="reference internal" href="#id800" id="id2113">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-minnum-intrinsic" id="id2114">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.minnum</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id801" id="id2115">Syntax:</a></li>
+<li><a class="reference internal" href="#id802" id="id2116">Overview:</a></li>
+<li><a class="reference internal" href="#id803" id="id2117">Arguments:</a></li>
+<li><a class="reference internal" href="#id804" id="id2118">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-ceil-intrinsic" id="id2119">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.ceil</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id805" id="id2120">Syntax:</a></li>
+<li><a class="reference internal" href="#id806" id="id2121">Overview:</a></li>
+<li><a class="reference internal" href="#id807" id="id2122">Arguments:</a></li>
+<li><a class="reference internal" href="#id808" id="id2123">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-floor-intrinsic" id="id2124">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.floor</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id809" id="id2125">Syntax:</a></li>
+<li><a class="reference internal" href="#id810" id="id2126">Overview:</a></li>
+<li><a class="reference internal" href="#id811" id="id2127">Arguments:</a></li>
+<li><a class="reference internal" href="#id812" id="id2128">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-round-intrinsic" id="id2129">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.round</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id813" id="id2130">Syntax:</a></li>
+<li><a class="reference internal" href="#id814" id="id2131">Overview:</a></li>
+<li><a class="reference internal" href="#id815" id="id2132">Arguments:</a></li>
+<li><a class="reference internal" href="#id816" id="id2133">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-constrained-trunc-intrinsic" id="id2134">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.constrained.trunc</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id817" id="id2135">Syntax:</a></li>
+<li><a class="reference internal" href="#id818" id="id2136">Overview:</a></li>
+<li><a class="reference internal" href="#id819" id="id2137">Arguments:</a></li>
+<li><a class="reference internal" href="#id820" id="id2138">Semantics:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#general-intrinsics" id="id2139">General Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-var-annotation-intrinsic" id="id2140">â<code class="docutils literal notranslate"><span class="pre">llvm.var.annotation</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id821" id="id2141">Syntax:</a></li>
+<li><a class="reference internal" href="#id822" id="id2142">Overview:</a></li>
+<li><a class="reference internal" href="#id823" id="id2143">Arguments:</a></li>
+<li><a class="reference internal" href="#id824" id="id2144">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-ptr-annotation-intrinsic" id="id2145">â<code class="docutils literal notranslate"><span class="pre">llvm.ptr.annotation.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id825" id="id2146">Syntax:</a></li>
+<li><a class="reference internal" href="#id826" id="id2147">Overview:</a></li>
+<li><a class="reference internal" href="#id827" id="id2148">Arguments:</a></li>
+<li><a class="reference internal" href="#id828" id="id2149">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-annotation-intrinsic" id="id2150">â<code class="docutils literal notranslate"><span class="pre">llvm.annotation.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id829" id="id2151">Syntax:</a></li>
+<li><a class="reference internal" href="#id830" id="id2152">Overview:</a></li>
+<li><a class="reference internal" href="#id831" id="id2153">Arguments:</a></li>
+<li><a class="reference internal" href="#id832" id="id2154">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-codeview-annotation-intrinsic" id="id2155">â<code class="docutils literal notranslate"><span class="pre">llvm.codeview.annotation</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id833" id="id2156">Syntax:</a></li>
+<li><a class="reference internal" href="#id834" id="id2157">Arguments:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-trap-intrinsic" id="id2158">â<code class="docutils literal notranslate"><span class="pre">llvm.trap</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id835" id="id2159">Syntax:</a></li>
+<li><a class="reference internal" href="#id836" id="id2160">Overview:</a></li>
+<li><a class="reference internal" href="#id837" id="id2161">Arguments:</a></li>
+<li><a class="reference internal" href="#id838" id="id2162">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-debugtrap-intrinsic" id="id2163">â<code class="docutils literal notranslate"><span class="pre">llvm.debugtrap</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id839" id="id2164">Syntax:</a></li>
+<li><a class="reference internal" href="#id840" id="id2165">Overview:</a></li>
+<li><a class="reference internal" href="#id841" id="id2166">Arguments:</a></li>
+<li><a class="reference internal" href="#id842" id="id2167">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-stackprotector-intrinsic" id="id2168">â<code class="docutils literal notranslate"><span class="pre">llvm.stackprotector</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id843" id="id2169">Syntax:</a></li>
+<li><a class="reference internal" href="#id844" id="id2170">Overview:</a></li>
+<li><a class="reference internal" href="#id845" id="id2171">Arguments:</a></li>
+<li><a class="reference internal" href="#id846" id="id2172">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-stackguard-intrinsic" id="id2173">â<code class="docutils literal notranslate"><span class="pre">llvm.stackguard</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id847" id="id2174">Syntax:</a></li>
+<li><a class="reference internal" href="#id848" id="id2175">Overview:</a></li>
+<li><a class="reference internal" href="#id849" id="id2176">Arguments:</a></li>
+<li><a class="reference internal" href="#id850" id="id2177">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objectsize-intrinsic" id="id2178">â<code class="docutils literal notranslate"><span class="pre">llvm.objectsize</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id851" id="id2179">Syntax:</a></li>
+<li><a class="reference internal" href="#id852" id="id2180">Overview:</a></li>
+<li><a class="reference internal" href="#id853" id="id2181">Arguments:</a></li>
+<li><a class="reference internal" href="#id854" id="id2182">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-expect-intrinsic" id="id2183">â<code class="docutils literal notranslate"><span class="pre">llvm.expect</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id855" id="id2184">Syntax:</a></li>
+<li><a class="reference internal" href="#id856" id="id2185">Overview:</a></li>
+<li><a class="reference internal" href="#id857" id="id2186">Arguments:</a></li>
+<li><a class="reference internal" href="#id858" id="id2187">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-assume-intrinsic" id="id2188">â<code class="docutils literal notranslate"><span class="pre">llvm.assume</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id859" id="id2189">Syntax:</a></li>
+<li><a class="reference internal" href="#id860" id="id2190">Overview:</a></li>
+<li><a class="reference internal" href="#id861" id="id2191">Arguments:</a></li>
+<li><a class="reference internal" href="#id862" id="id2192">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-ssa-copy-intrinsic" id="id2193">â<code class="docutils literal notranslate"><span class="pre">llvm.ssa_copy</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id863" id="id2194">Syntax:</a></li>
+<li><a class="reference internal" href="#id864" id="id2195">Arguments:</a></li>
+<li><a class="reference internal" href="#id865" id="id2196">Overview:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-type-test-intrinsic" id="id2197">â<code class="docutils literal notranslate"><span class="pre">llvm.type.test</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id866" id="id2198">Syntax:</a></li>
+<li><a class="reference internal" href="#id867" id="id2199">Arguments:</a></li>
+<li><a class="reference internal" href="#id868" id="id2200">Overview:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-type-checked-load-intrinsic" id="id2201">â<code class="docutils literal notranslate"><span class="pre">llvm.type.checked.load</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id869" id="id2202">Syntax:</a></li>
+<li><a class="reference internal" href="#id870" id="id2203">Arguments:</a></li>
+<li><a class="reference internal" href="#id871" id="id2204">Overview:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-donothing-intrinsic" id="id2205">â<code class="docutils literal notranslate"><span class="pre">llvm.donothing</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id872" id="id2206">Syntax:</a></li>
+<li><a class="reference internal" href="#id873" id="id2207">Overview:</a></li>
+<li><a class="reference internal" href="#id874" id="id2208">Arguments:</a></li>
+<li><a class="reference internal" href="#id875" id="id2209">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-deoptimize-intrinsic" id="id2210">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.deoptimize</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id876" id="id2211">Syntax:</a></li>
+<li><a class="reference internal" href="#id877" id="id2212">Overview:</a></li>
+<li><a class="reference internal" href="#id878" id="id2213">Arguments:</a></li>
+<li><a class="reference internal" href="#id879" id="id2214">Semantics:</a></li>
+<li><a class="reference internal" href="#lowering" id="id2215">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-guard-intrinsic" id="id2216">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.guard</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id880" id="id2217">Syntax:</a></li>
+<li><a class="reference internal" href="#id881" id="id2218">Overview:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-experimental-widenable-condition-intrinsic" id="id2219">â<code class="docutils literal notranslate"><span class="pre">llvm.experimental.widenable.condition</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id882" id="id2220">Syntax:</a></li>
+<li><a class="reference internal" href="#id883" id="id2221">Overview:</a></li>
+<li><a class="reference internal" href="#id884" id="id2222">Arguments:</a></li>
+<li><a class="reference internal" href="#id885" id="id2223">Semantics:</a></li>
+<li><a class="reference internal" href="#guard-widening" id="id2224">Guard widening:</a></li>
+<li><a class="reference internal" href="#id886" id="id2225">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-load-relative-intrinsic" id="id2226">â<code class="docutils literal notranslate"><span class="pre">llvm.load.relative</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id887" id="id2227">Syntax:</a></li>
+<li><a class="reference internal" href="#id888" id="id2228">Overview:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-sideeffect-intrinsic" id="id2229">â<code class="docutils literal notranslate"><span class="pre">llvm.sideeffect</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id889" id="id2230">Syntax:</a></li>
+<li><a class="reference internal" href="#id890" id="id2231">Overview:</a></li>
+<li><a class="reference internal" href="#id891" id="id2232">Arguments:</a></li>
+<li><a class="reference internal" href="#id892" id="id2233">Semantics:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-is-constant-intrinsic" id="id2234">â<code class="docutils literal notranslate"><span class="pre">llvm.is.constant.*</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id893" id="id2235">Syntax:</a></li>
+<li><a class="reference internal" href="#id894" id="id2236">Overview:</a></li>
+<li><a class="reference internal" href="#id895" id="id2237">Semantics:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#stack-map-intrinsics" id="id2238">Stack Map Intrinsics</a></li>
+<li><a class="reference internal" href="#element-wise-atomic-memory-intrinsics" id="id2239">Element Wise Atomic Memory Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-memcpy-element-unordered-atomic-intrinsic" id="id2240">â<code class="docutils literal notranslate"><span class="pre">llvm.memcpy.element.unordered.atomic</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id896" id="id2241">Syntax:</a></li>
+<li><a class="reference internal" href="#id897" id="id2242">Overview:</a></li>
+<li><a class="reference internal" href="#id898" id="id2243">Arguments:</a></li>
+<li><a class="reference internal" href="#id899" id="id2244">Semantics:</a></li>
+<li><a class="reference internal" href="#id900" id="id2245">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-memmove-element-unordered-atomic-intrinsic" id="id2246">â<code class="docutils literal notranslate"><span class="pre">llvm.memmove.element.unordered.atomic</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id901" id="id2247">Syntax:</a></li>
+<li><a class="reference internal" href="#id902" id="id2248">Overview:</a></li>
+<li><a class="reference internal" href="#id903" id="id2249">Arguments:</a></li>
+<li><a class="reference internal" href="#id904" id="id2250">Semantics:</a></li>
+<li><a class="reference internal" href="#id905" id="id2251">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-memset-element-unordered-atomic-intrinsic" id="id2252">â<code class="docutils literal notranslate"><span class="pre">llvm.memset.element.unordered.atomic</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id906" id="id2253">Syntax:</a></li>
+<li><a class="reference internal" href="#id907" id="id2254">Overview:</a></li>
+<li><a class="reference internal" href="#id908" id="id2255">Arguments:</a></li>
+<li><a class="reference internal" href="#id909" id="id2256">Semantics:</a></li>
+<li><a class="reference internal" href="#id910" id="id2257">Lowering:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#objective-c-arc-runtime-intrinsics" id="id2258">Objective-C ARC Runtime Intrinsics</a><ul>
+<li><a class="reference internal" href="#llvm-objc-autorelease-intrinsic" id="id2259">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.autorelease</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id911" id="id2260">Syntax:</a></li>
+<li><a class="reference internal" href="#id912" id="id2261">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-autoreleasepoolpop-intrinsic" id="id2262">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.autoreleasePoolPop</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id913" id="id2263">Syntax:</a></li>
+<li><a class="reference internal" href="#id914" id="id2264">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-autoreleasepoolpush-intrinsic" id="id2265">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.autoreleasePoolPush</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id915" id="id2266">Syntax:</a></li>
+<li><a class="reference internal" href="#id916" id="id2267">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-autoreleasereturnvalue-intrinsic" id="id2268">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.autoreleaseReturnValue</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id917" id="id2269">Syntax:</a></li>
+<li><a class="reference internal" href="#id918" id="id2270">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-copyweak-intrinsic" id="id2271">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.copyWeak</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id919" id="id2272">Syntax:</a></li>
+<li><a class="reference internal" href="#id920" id="id2273">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-destroyweak-intrinsic" id="id2274">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.destroyWeak</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id921" id="id2275">Syntax:</a></li>
+<li><a class="reference internal" href="#id922" id="id2276">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-initweak-intrinsic" id="id2277">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.initWeak</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id923" id="id2278">Syntax:</a></li>
+<li><a class="reference internal" href="#id924" id="id2279">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-loadweak-intrinsic" id="id2280">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.loadWeak</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id925" id="id2281">Syntax:</a></li>
+<li><a class="reference internal" href="#id926" id="id2282">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-loadweakretained-intrinsic" id="id2283">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.loadWeakRetained</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id927" id="id2284">Syntax:</a></li>
+<li><a class="reference internal" href="#id928" id="id2285">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-moveweak-intrinsic" id="id2286">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.moveWeak</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id929" id="id2287">Syntax:</a></li>
+<li><a class="reference internal" href="#id930" id="id2288">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-release-intrinsic" id="id2289">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.release</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id931" id="id2290">Syntax:</a></li>
+<li><a class="reference internal" href="#id932" id="id2291">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-retain-intrinsic" id="id2292">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.retain</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id933" id="id2293">Syntax:</a></li>
+<li><a class="reference internal" href="#id934" id="id2294">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-retainautorelease-intrinsic" id="id2295">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.retainAutorelease</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id935" id="id2296">Syntax:</a></li>
+<li><a class="reference internal" href="#id936" id="id2297">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-retainautoreleasereturnvalue-intrinsic" id="id2298">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.retainAutoreleaseReturnValue</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id937" id="id2299">Syntax:</a></li>
+<li><a class="reference internal" href="#id938" id="id2300">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-retainautoreleasedreturnvalue-intrinsic" id="id2301">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.retainAutoreleasedReturnValue</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id939" id="id2302">Syntax:</a></li>
+<li><a class="reference internal" href="#id940" id="id2303">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-retainblock-intrinsic" id="id2304">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.retainBlock</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id941" id="id2305">Syntax:</a></li>
+<li><a class="reference internal" href="#id942" id="id2306">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-storestrong-intrinsic" id="id2307">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.storeStrong</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id943" id="id2308">Syntax:</a></li>
+<li><a class="reference internal" href="#id944" id="id2309">Lowering:</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#llvm-objc-storeweak-intrinsic" id="id2310">â<code class="docutils literal notranslate"><span class="pre">llvm.objc.storeWeak</span></code>â Intrinsic</a><ul>
+<li><a class="reference internal" href="#id945" id="id2311">Syntax:</a></li>
+<li><a class="reference internal" href="#id946" id="id2312">Lowering:</a></li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+<div class="section" id="abstract">
+<h2><a class="toc-backref" href="#id947">Abstract</a><a class="headerlink" href="#abstract" title="Permalink to this headline">¶</a></h2>
+<p>This document is a reference manual for the LLVM assembly language. LLVM
+is a Static Single Assignment (SSA) based representation that provides
+type safety, low-level operations, flexibility, and the capability of
+representing âallâ high-level languages cleanly. It is the common code
+representation used throughout all phases of the LLVM compilation
+strategy.</p>
+</div>
+<div class="section" id="introduction">
+<h2><a class="toc-backref" href="#id948">Introduction</a><a class="headerlink" href="#introduction" title="Permalink to this headline">¶</a></h2>
+<p>The LLVM code representation is designed to be used in three different
+forms: as an in-memory compiler IR, as an on-disk bitcode representation
+(suitable for fast loading by a Just-In-Time compiler), and as a human
+readable assembly language representation. This allows LLVM to provide a
+powerful intermediate representation for efficient compiler
+transformations and analysis, while providing a natural means to debug
+and visualize the transformations. The three different forms of LLVM are
+all equivalent. This document describes the human readable
+representation and notation.</p>
+<p>The LLVM representation aims to be light-weight and low-level while
+being expressive, typed, and extensible at the same time. It aims to be
+a âuniversal IRâ of sorts, by being at a low enough level that
+high-level ideas may be cleanly mapped to it (similar to how
+microprocessors are âuniversal IRâsâ, allowing many source languages to
+be mapped to them). By providing type information, LLVM can be used as
+the target of optimizations: for example, through pointer analysis, it
+can be proven that a C automatic variable is never accessed outside of
+the current function, allowing it to be promoted to a simple SSA value
+instead of a memory location.</p>
+<div class="section" id="well-formedness">
+<span id="wellformed"></span><h3><a class="toc-backref" href="#id949">Well-Formedness</a><a class="headerlink" href="#well-formedness" title="Permalink to this headline">¶</a></h3>
+<p>It is important to note that this document describes âwell formedâ LLVM
+assembly language. There is a difference between what the parser accepts
+and what is considered âwell formedâ. For example, the following
+instruction is syntactically okay, but not well formed:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%x</span> <span class="p">=</span> <span class="k">add</span> <span class="k">i32</span> <span class="m">1</span><span class="p">,</span> <span class="nv">%x</span>
+</pre></div>
+</div>
+<p>because the definition of <code class="docutils literal notranslate"><span class="pre">%x</span></code> does not dominate all of its uses. The
+LLVM infrastructure provides a verification pass that may be used to
+verify that an LLVM module is well formed. This pass is automatically
+run by the parser after parsing input assembly and by the optimizer
+before it outputs bitcode. The violations pointed out by the verifier
+pass indicate bugs in transformation passes or input to the parser.</p>
+</div>
+</div>
+<div class="section" id="identifiers">
+<span id="id1"></span><h2><a class="toc-backref" href="#id950">Identifiers</a><a class="headerlink" href="#identifiers" title="Permalink to this headline">¶</a></h2>
+<p>LLVM identifiers come in two basic types: global and local. Global
+identifiers (functions, global variables) begin with the <code class="docutils literal notranslate"><span class="pre">'@'</span></code>
+character. Local identifiers (register names, types) begin with the
+<code class="docutils literal notranslate"><span class="pre">'%'</span></code> character. Additionally, there are three different formats for
+identifiers, for different purposes:</p>
+<ol class="arabic simple">
+<li>Named values are represented as a string of characters with their
+prefix. For example, <code class="docutils literal notranslate"><span class="pre">%foo</span></code>, <code class="docutils literal notranslate"><span class="pre">@DivisionByZero</span></code>,
+<code class="docutils literal notranslate"><span class="pre">%a.really.long.identifier</span></code>. The actual regular expression used is
+â<code class="docutils literal notranslate"><span class="pre">[%@][-a-zA-Z$._][-a-zA-Z$._0-9]*</span></code>â. Identifiers that require other
+characters in their names can be surrounded with quotes. Special
+characters may be escaped using <code class="docutils literal notranslate"><span class="pre">"\xx"</span></code> where <code class="docutils literal notranslate"><span class="pre">xx</span></code> is the ASCII
+code for the character in hexadecimal. In this way, any character can
+be used in a name value, even quotes themselves. The <code class="docutils literal notranslate"><span class="pre">"\01"</span></code> prefix
+can be used on global values to suppress mangling.</li>
+<li>Unnamed values are represented as an unsigned numeric value with
+their prefix. For example, <code class="docutils literal notranslate"><span class="pre">%12</span></code>, <code class="docutils literal notranslate"><span class="pre">@2</span></code>, <code class="docutils literal notranslate"><span class="pre">%44</span></code>.</li>
+<li>Constants, which are described in the section <a class="reference internal" href="#constants">Constants</a> below.</li>
+</ol>
+<p>LLVM requires that values start with a prefix for two reasons: Compilers
+donât need to worry about name clashes with reserved words, and the set
+of reserved words may be expanded in the future without penalty.
+Additionally, unnamed identifiers allow a compiler to quickly come up
+with a temporary variable without having to avoid symbol table
+conflicts.</p>
+<p>Reserved words in LLVM are very similar to reserved words in other
+languages. There are keywords for different opcodes (â<code class="docutils literal notranslate"><span class="pre">add</span></code>â,
+â<code class="docutils literal notranslate"><span class="pre">bitcast</span></code>â, â<code class="docutils literal notranslate"><span class="pre">ret</span></code>â, etcâ¦), for primitive type names (â<code class="docutils literal notranslate"><span class="pre">void</span></code>â,
+â<code class="docutils literal notranslate"><span class="pre">i32</span></code>â, etcâ¦), and others. These reserved words cannot conflict
+with variable names, because none of them start with a prefix character
+(<code class="docutils literal notranslate"><span class="pre">'%'</span></code> or <code class="docutils literal notranslate"><span class="pre">'@'</span></code>).</p>
+<p>Here is an example of LLVM code to multiply the integer variable
+â<code class="docutils literal notranslate"><span class="pre">%X</span></code>â by 8:</p>
+<p>The easy way:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%result</span> <span class="p">=</span> <span class="k">mul</span> <span class="k">i32</span> <span class="nv">%X</span><span class="p">,</span> <span class="m">8</span>
+</pre></div>
+</div>
+<p>After strength reduction:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%result</span> <span class="p">=</span> <span class="k">shl</span> <span class="k">i32</span> <span class="nv">%X</span><span class="p">,</span> <span class="m">3</span>
+</pre></div>
+</div>
+<p>And the hard way:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">%0</span> <span class="p">=</span> <span class="k">add</span> <span class="k">i32</span> <span class="nv">%X</span><span class="p">,</span> <span class="nv">%X</span> <span class="c">; yields i32:%0</span>
+<span class="nv nv-Anonymous">%1</span> <span class="p">=</span> <span class="k">add</span> <span class="k">i32</span> <span class="nv nv-Anonymous">%0</span><span class="p">,</span> <span class="nv nv-Anonymous">%0</span> <span class="c">; yields i32:%1</span>
+<span class="nv">%result</span> <span class="p">=</span> <span class="k">add</span> <span class="k">i32</span> <span class="nv nv-Anonymous">%1</span><span class="p">,</span> <span class="nv nv-Anonymous">%1</span>
+</pre></div>
+</div>
+<p>This last way of multiplying <code class="docutils literal notranslate"><span class="pre">%X</span></code> by 8 illustrates several important
+lexical features of LLVM:</p>
+<ol class="arabic simple">
+<li>Comments are delimited with a â<code class="docutils literal notranslate"><span class="pre">;</span></code>â and go until the end of line.</li>
+<li>Unnamed temporaries are created when the result of a computation is
+not assigned to a named value.</li>
+<li>Unnamed temporaries are numbered sequentially (using a per-function
+incrementing counter, starting with 0). Note that basic blocks and unnamed
+function parameters are included in this numbering. For example, if the
+entry basic block is not given a label name and all function parameters are
+named, then it will get number 0.</li>
+</ol>
+<p>It also shows a convention that we follow in this document. When
+demonstrating instructions, we will follow an instruction with a comment
+that defines the type and name of value produced.</p>
+</div>
+<div class="section" id="high-level-structure">
+<h2><a class="toc-backref" href="#id951">High Level Structure</a><a class="headerlink" href="#high-level-structure" title="Permalink to this headline">¶</a></h2>
+<div class="section" id="module-structure">
+<h3><a class="toc-backref" href="#id952">Module Structure</a><a class="headerlink" href="#module-structure" title="Permalink to this headline">¶</a></h3>
+<p>LLVM programs are composed of <code class="docutils literal notranslate"><span class="pre">Module</span></code>âs, each of which is a
+translation unit of the input programs. Each module consists of
+functions, global variables, and symbol table entries. Modules may be
+combined together with the LLVM linker, which merges function (and
+global variable) definitions, resolves forward declarations, and merges
+symbol table entries. Here is an example of the âhello worldâ module:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="c">; Declare the string constant as a global constant.</span>
+<span class="vg">@.str</span> <span class="p">=</span> <span class="k">private</span> <span class="k">unnamed_addr</span> <span class="k">constant</span> <span class="p">[</span><span class="m">13</span> <span class="k">x</span> <span class="k">i8</span><span class="p">]</span> <span class="k">c</span><span class="s">"hello world\0A\00"</span>
+
+<span class="c">; External declaration of the puts function</span>
+<span class="k">declare</span> <span class="k">i32</span> <span class="vg">@puts</span><span class="p">(</span><span class="k">i8</span><span class="p">*</span> <span class="k">nocapture</span><span class="p">)</span> <span class="k">nounwind</span>
+
+<span class="c">; Definition of main function</span>
+<span class="k">define</span> <span class="k">i32</span> <span class="vg">@main</span><span class="p">()</span> <span class="p">{</span> <span class="c">; i32()*</span>
+ <span class="c">; Convert [13 x i8]* to i8*...</span>
+ <span class="nv">%cast210</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="p">[</span><span class="m">13</span> <span class="k">x</span> <span class="k">i8</span><span class="p">],</span> <span class="p">[</span><span class="m">13</span> <span class="k">x</span> <span class="k">i8</span><span class="p">]*</span> <span class="vg">@.str</span><span class="p">,</span> <span class="k">i64</span> <span class="m">0</span><span class="p">,</span> <span class="k">i64</span> <span class="m">0</span>
+
+ <span class="c">; Call puts function to write out the string to stdout.</span>
+ <span class="k">call</span> <span class="k">i32</span> <span class="vg">@puts</span><span class="p">(</span><span class="k">i8</span><span class="p">*</span> <span class="nv">%cast210</span><span class="p">)</span>
+ <span class="k">ret</span> <span class="k">i32</span> <span class="m">0</span>
+<span class="p">}</span>
+
+<span class="c">; Named metadata</span>
+<span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="k">i32</span> <span class="m">42</span><span class="p">,</span> <span class="k">null</span><span class="p">,</span> <span class="nv">!"string"</span><span class="p">}</span>
+<span class="nv">!foo</span> <span class="p">=</span> <span class="p">!{</span><span class="nv nv-Anonymous">!0</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>This example is made up of a <a class="reference internal" href="#globalvars"><span class="std std-ref">global variable</span></a> named
+â<code class="docutils literal notranslate"><span class="pre">.str</span></code>â, an external declaration of the â<code class="docutils literal notranslate"><span class="pre">puts</span></code>â function, a
+<a class="reference internal" href="#functionstructure"><span class="std std-ref">function definition</span></a> for â<code class="docutils literal notranslate"><span class="pre">main</span></code>â and
+<a class="reference internal" href="#namedmetadatastructure"><span class="std std-ref">named metadata</span></a> â<code class="docutils literal notranslate"><span class="pre">foo</span></code>â.</p>
+<p>In general, a module is made up of a list of global values (where both
+functions and global variables are global values). Global values are
+represented by a pointer to a memory location (in this case, a pointer
+to an array of char, and a pointer to a function), and have one of the
+following <a class="reference internal" href="#linkage"><span class="std std-ref">linkage types</span></a>.</p>
+</div>
+<div class="section" id="linkage-types">
+<span id="linkage"></span><h3><a class="toc-backref" href="#id953">Linkage Types</a><a class="headerlink" href="#linkage-types" title="Permalink to this headline">¶</a></h3>
+<p>All Global Variables and Functions have one of the following types of
+linkage:</p>
+<dl class="docutils">
+<dt><code class="docutils literal notranslate"><span class="pre">private</span></code></dt>
+<dd>Global values with â<code class="docutils literal notranslate"><span class="pre">private</span></code>â linkage are only directly
+accessible by objects in the current module. In particular, linking
+code into a module with a private global value may cause the
+private to be renamed as necessary to avoid collisions. Because the
+symbol is private to the module, all references can be updated. This
+doesnât show up in any symbol table in the object file.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">internal</span></code></dt>
+<dd>Similar to private, but the value shows as a local symbol
+(<code class="docutils literal notranslate"><span class="pre">STB_LOCAL</span></code> in the case of ELF) in the object file. This
+corresponds to the notion of the â<code class="docutils literal notranslate"><span class="pre">static</span></code>â keyword in C.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">available_externally</span></code></dt>
+<dd>Globals with â<code class="docutils literal notranslate"><span class="pre">available_externally</span></code>â linkage are never emitted into
+the object file corresponding to the LLVM module. From the linkerâs
+perspective, an <code class="docutils literal notranslate"><span class="pre">available_externally</span></code> global is equivalent to
+an external declaration. They exist to allow inlining and other
+optimizations to take place given knowledge of the definition of the
+global, which is known to be somewhere outside the module. Globals
+with <code class="docutils literal notranslate"><span class="pre">available_externally</span></code> linkage are allowed to be discarded at
+will, and allow inlining and other optimizations. This linkage type is
+only allowed on definitions, not declarations.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">linkonce</span></code></dt>
+<dd>Globals with â<code class="docutils literal notranslate"><span class="pre">linkonce</span></code>â linkage are merged with other globals of
+the same name when linkage occurs. This can be used to implement
+some forms of inline functions, templates, or other code which must
+be generated in each translation unit that uses it, but where the
+body may be overridden with a more definitive definition later.
+Unreferenced <code class="docutils literal notranslate"><span class="pre">linkonce</span></code> globals are allowed to be discarded. Note
+that <code class="docutils literal notranslate"><span class="pre">linkonce</span></code> linkage does not actually allow the optimizer to
+inline the body of this function into callers because it doesnât
+know if this definition of the function is the definitive definition
+within the program or whether it will be overridden by a stronger
+definition. To enable inlining and other optimizations, use
+â<code class="docutils literal notranslate"><span class="pre">linkonce_odr</span></code>â linkage.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">weak</span></code></dt>
+<dd>â<code class="docutils literal notranslate"><span class="pre">weak</span></code>â linkage has the same merging semantics as <code class="docutils literal notranslate"><span class="pre">linkonce</span></code>
+linkage, except that unreferenced globals with <code class="docutils literal notranslate"><span class="pre">weak</span></code> linkage may
+not be discarded. This is used for globals that are declared âweakâ
+in C source code.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">common</span></code></dt>
+<dd>â<code class="docutils literal notranslate"><span class="pre">common</span></code>â linkage is most similar to â<code class="docutils literal notranslate"><span class="pre">weak</span></code>â linkage, but they
+are used for tentative definitions in C, such as â<code class="docutils literal notranslate"><span class="pre">int</span> <span class="pre">X;</span></code>â at
+global scope. Symbols with â<code class="docutils literal notranslate"><span class="pre">common</span></code>â linkage are merged in the
+same way as <code class="docutils literal notranslate"><span class="pre">weak</span> <span class="pre">symbols</span></code>, and they may not be deleted if
+unreferenced. <code class="docutils literal notranslate"><span class="pre">common</span></code> symbols may not have an explicit section,
+must have a zero initializer, and may not be marked
+â<a class="reference internal" href="#globalvars"><span class="std std-ref">constant</span></a>â. Functions and aliases may not have
+common linkage.</dd>
+</dl>
+<dl class="docutils" id="linkage-appending">
+<dt><code class="docutils literal notranslate"><span class="pre">appending</span></code></dt>
+<dd><p class="first">â<code class="docutils literal notranslate"><span class="pre">appending</span></code>â linkage may only be applied to global variables of
+pointer to array type. When two global variables with appending
+linkage are linked together, the two global arrays are appended
+together. This is the LLVM, typesafe, equivalent of having the
+system linker append together âsectionsâ with identical names when
+.o files are linked.</p>
+<p class="last">Unfortunately this doesnât correspond to any feature in .o files, so it
+can only be used for variables like <code class="docutils literal notranslate"><span class="pre">llvm.global_ctors</span></code> which llvm
+interprets specially.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">extern_weak</span></code></dt>
+<dd>The semantics of this linkage follow the ELF object file model: the
+symbol is weak until linked, if not linked, the symbol becomes null
+instead of being an undefined reference.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">linkonce_odr</span></code>, <code class="docutils literal notranslate"><span class="pre">weak_odr</span></code></dt>
+<dd>Some languages allow differing globals to be merged, such as two
+functions with different semantics. Other languages, such as
+<code class="docutils literal notranslate"><span class="pre">C++</span></code>, ensure that only equivalent globals are ever merged (the
+âone definition ruleâ â âODRâ). Such languages can use the
+<code class="docutils literal notranslate"><span class="pre">linkonce_odr</span></code> and <code class="docutils literal notranslate"><span class="pre">weak_odr</span></code> linkage types to indicate that the
+global will only be merged with equivalent globals. These linkage
+types are otherwise the same as their non-<code class="docutils literal notranslate"><span class="pre">odr</span></code> versions.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">external</span></code></dt>
+<dd>If none of the above identifiers are used, the global is externally
+visible, meaning that it participates in linkage and can be used to
+resolve external symbol references.</dd>
+</dl>
+<p>It is illegal for a function <em>declaration</em> to have any linkage type
+other than <code class="docutils literal notranslate"><span class="pre">external</span></code> or <code class="docutils literal notranslate"><span class="pre">extern_weak</span></code>.</p>
+</div>
+<div class="section" id="calling-conventions">
+<span id="callingconv"></span><h3><a class="toc-backref" href="#id954">Calling Conventions</a><a class="headerlink" href="#calling-conventions" title="Permalink to this headline">¶</a></h3>
+<p>LLVM <a class="reference internal" href="#functionstructure"><span class="std std-ref">functions</span></a>, <a class="reference internal" href="#i-call"><span class="std std-ref">calls</span></a> and
+<a class="reference internal" href="#i-invoke"><span class="std std-ref">invokes</span></a> can all have an optional calling convention
+specified for the call. The calling convention of any pair of dynamic
+caller/callee must match, or the behavior of the program is undefined.
+The following calling conventions are supported by LLVM, and more may be
+added in the future:</p>
+<dl class="docutils">
+<dt>â<code class="docutils literal notranslate"><span class="pre">ccc</span></code>â - The C calling convention</dt>
+<dd>This calling convention (the default if no other calling convention
+is specified) matches the target C calling conventions. This calling
+convention supports varargs function calls and tolerates some
+mismatch in the declared prototype and implemented declaration of
+the function (as does normal C).</dd>
+<dt>â<code class="docutils literal notranslate"><span class="pre">fastcc</span></code>â - The fast calling convention</dt>
+<dd>This calling convention attempts to make calls as fast as possible
+(e.g. by passing things in registers). This calling convention
+allows the target to use whatever tricks it wants to produce fast
+code for the target, without having to conform to an externally
+specified ABI (Application Binary Interface). <a class="reference external" href="CodeGenerator.html#id80">Tail calls can only
+be optimized when this, the GHC or the HiPE convention is
+used.</a> This calling convention does not
+support varargs and requires the prototype of all callees to exactly
+match the prototype of the function definition.</dd>
+<dt>â<code class="docutils literal notranslate"><span class="pre">coldcc</span></code>â - The cold calling convention</dt>
+<dd>This calling convention attempts to make code in the caller as
+efficient as possible under the assumption that the call is not
+commonly executed. As such, these calls often preserve all registers
+so that the call does not break any live ranges in the caller side.
+This calling convention does not support varargs and requires the
+prototype of all callees to exactly match the prototype of the
+function definition. Furthermore the inliner doesnât consider such function
+calls for inlining.</dd>
+<dt>â<code class="docutils literal notranslate"><span class="pre">cc</span> <span class="pre">10</span></code>â - GHC convention</dt>
+<dd><p class="first">This calling convention has been implemented specifically for use by
+the <a class="reference external" href="http://www.haskell.org/ghc">Glasgow Haskell Compiler (GHC)</a>.
+It passes everything in registers, going to extremes to achieve this
+by disabling callee save registers. This calling convention should
+not be used lightly but only for specific situations such as an
+alternative to the <em>register pinning</em> performance technique often
+used when implementing functional programming languages. At the
+moment only X86 supports this convention and it has the following
+limitations:</p>
+<ul class="simple">
+<li>On <em>X86-32</em> only supports up to 4 bit type parameters. No
+floating-point types are supported.</li>
+<li>On <em>X86-64</em> only supports up to 10 bit type parameters and 6
+floating-point parameters.</li>
+</ul>
+<p class="last">This calling convention supports <a class="reference external" href="CodeGenerator.html#id80">tail call
+optimization</a> but requires both the
+caller and callee are using it.</p>
+</dd>
+<dt>â<code class="docutils literal notranslate"><span class="pre">cc</span> <span class="pre">11</span></code>â - The HiPE calling convention</dt>
+<dd>This calling convention has been implemented specifically for use by
+the <a class="reference external" href="http://www.it.uu.se/research/group/hipe/">High-Performance Erlang
+(HiPE)</a> compiler, <em>the</em>
+native code compiler of the <a class="reference external" href="http://www.erlang.org/download.shtml">Ericssonâs Open Source Erlang/OTP
+system</a>. It uses more
+registers for argument passing than the ordinary C calling
+convention and defines no callee-saved registers. The calling
+convention properly supports <a class="reference external" href="CodeGenerator.html#id80">tail call
+optimization</a> but requires that both the
+caller and the callee use it. It uses a <em>register pinning</em>
+mechanism, similar to GHCâs convention, for keeping frequently
+accessed runtime components pinned to specific hardware registers.
+At the moment only X86 supports this convention (both 32 and 64
+bit).</dd>
+<dt>â<code class="docutils literal notranslate"><span class="pre">webkit_jscc</span></code>â - WebKitâs JavaScript calling convention</dt>
+<dd>This calling convention has been implemented for <a class="reference external" href="https://trac.webkit.org/wiki/FTLJIT">WebKit FTL JIT</a>. It passes arguments on the
+stack right to left (as cdecl does), and returns a value in the
+platformâs customary return register.</dd>
+<dt>â<code class="docutils literal notranslate"><span class="pre">anyregcc</span></code>â - Dynamic calling convention for code patching</dt>
+<dd>This is a special convention that supports patching an arbitrary code
+sequence in place of a call site. This convention forces the call
+arguments into registers but allows them to be dynamically
+allocated. This can currently only be used with calls to
+llvm.experimental.patchpoint because only this intrinsic records
+the location of its arguments in a side table. See <a class="reference internal" href="StackMaps.html"><span class="doc">Stack maps and patch points in LLVM</span></a>.</dd>
+<dt>â<code class="docutils literal notranslate"><span class="pre">preserve_mostcc</span></code>â - The <cite>PreserveMost</cite> calling convention</dt>
+<dd><p class="first">This calling convention attempts to make the code in the caller as
+unintrusive as possible. This convention behaves identically to the <cite>C</cite>
+calling convention on how arguments and return values are passed, but it
+uses a different set of caller/callee-saved registers. This alleviates the
+burden of saving and recovering a large register set before and after the
+call in the caller. If the arguments are passed in callee-saved registers,
+then they will be preserved by the callee across the call. This doesnât
+apply for values returned in callee-saved registers.</p>
+<ul class="simple">
+<li>On X86-64 the callee preserves all general purpose registers, except for
+R11. R11 can be used as a scratch register. Floating-point registers
+(XMMs/YMMs) are not preserved and need to be saved by the caller.</li>
+</ul>
+<p>The idea behind this convention is to support calls to runtime functions
+that have a hot path and a cold path. The hot path is usually a small piece
+of code that doesnât use many registers. The cold path might need to call out to
+another function and therefore only needs to preserve the caller-saved
+registers, which havenât already been saved by the caller. The
+<cite>PreserveMost</cite> calling convention is very similar to the <cite>cold</cite> calling
+convention in terms of caller/callee-saved registers, but they are used for
+different types of function calls. <cite>coldcc</cite> is for function calls that are
+rarely executed, whereas <cite>preserve_mostcc</cite> function calls are intended to be
+on the hot path and definitely executed a lot. Furthermore <cite>preserve_mostcc</cite>
+doesnât prevent the inliner from inlining the function call.</p>
+<p class="last">This calling convention will be used by a future version of the ObjectiveC
+runtime and should therefore still be considered experimental at this time.
+Although this convention was created to optimize certain runtime calls to
+the ObjectiveC runtime, it is not limited to this runtime and might be used
+by other runtimes in the future too. The current implementation only
+supports X86-64, but the intention is to support more architectures in the
+future.</p>
+</dd>
+<dt>â<code class="docutils literal notranslate"><span class="pre">preserve_allcc</span></code>â - The <cite>PreserveAll</cite> calling convention</dt>
+<dd><p class="first">This calling convention attempts to make the code in the caller even less
+intrusive than the <cite>PreserveMost</cite> calling convention. This calling
+convention also behaves identical to the <cite>C</cite> calling convention on how
+arguments and return values are passed, but it uses a different set of
+caller/callee-saved registers. This removes the burden of saving and
+recovering a large register set before and after the call in the caller. If
+the arguments are passed in callee-saved registers, then they will be
+preserved by the callee across the call. This doesnât apply for values
+returned in callee-saved registers.</p>
+<ul class="simple">
+<li>On X86-64 the callee preserves all general purpose registers, except for
+R11. R11 can be used as a scratch register. Furthermore it also preserves
+all floating-point registers (XMMs/YMMs).</li>
+</ul>
+<p>The idea behind this convention is to support calls to runtime functions
+that donât need to call out to any other functions.</p>
+<p class="last">This calling convention, like the <cite>PreserveMost</cite> calling convention, will be
+used by a future version of the ObjectiveC runtime and should be considered
+experimental at this time.</p>
+</dd>
+<dt>â<code class="docutils literal notranslate"><span class="pre">cxx_fast_tlscc</span></code>â - The <cite>CXX_FAST_TLS</cite> calling convention for access functions</dt>
+<dd><p class="first">Clang generates an access function to access C++-style TLS. The access
+function generally has an entry block, an exit block and an initialization
+block that is run at the first time. The entry and exit blocks can access
+a few TLS IR variables, each access will be lowered to a platform-specific
+sequence.</p>
+<p>This calling convention aims to minimize overhead in the caller by
+preserving as many registers as possible (all the registers that are
+perserved on the fast path, composed of the entry and exit blocks).</p>
+<p>This calling convention behaves identical to the <cite>C</cite> calling convention on
+how arguments and return values are passed, but it uses a different set of
+caller/callee-saved registers.</p>
+<p>Given that each platform has its own lowering sequence, hence its own set
+of preserved registers, we canât use the existing <cite>PreserveMost</cite>.</p>
+<ul class="last simple">
+<li>On X86-64 the callee preserves all general purpose registers, except for
+RDI and RAX.</li>
+</ul>
+</dd>
+<dt>â<code class="docutils literal notranslate"><span class="pre">swiftcc</span></code>â - This calling convention is used for Swift language.</dt>
+<dd><ul class="first last simple">
+<li>On X86-64 RCX and R8 are available for additional integer returns, and
+XMM2 and XMM3 are available for additional FP/vector returns.</li>
+<li>On iOS platforms, we use AAPCS-VFP calling convention.</li>
+</ul>
+</dd>
+<dt>â<code class="docutils literal notranslate"><span class="pre">cc</span> <span class="pre"><n></span></code>â - Numbered convention</dt>
+<dd>Any calling convention may be specified by number, allowing
+target-specific calling conventions to be used. Target specific
+calling conventions start at 64.</dd>
+</dl>
+<p>More calling conventions can be added/defined on an as-needed basis, to
+support Pascal conventions or any other well-known target-independent
+convention.</p>
+</div>
+<div class="section" id="visibility-styles">
+<span id="visibilitystyles"></span><h3><a class="toc-backref" href="#id955">Visibility Styles</a><a class="headerlink" href="#visibility-styles" title="Permalink to this headline">¶</a></h3>
+<p>All Global Variables and Functions have one of the following visibility
+styles:</p>
+<dl class="docutils">
+<dt>â<code class="docutils literal notranslate"><span class="pre">default</span></code>â - Default style</dt>
+<dd>On targets that use the ELF object file format, default visibility
+means that the declaration is visible to other modules and, in
+shared libraries, means that the declared entity may be overridden.
+On Darwin, default visibility means that the declaration is visible
+to other modules. Default visibility corresponds to âexternal
+linkageâ in the language.</dd>
+<dt>â<code class="docutils literal notranslate"><span class="pre">hidden</span></code>â - Hidden style</dt>
+<dd>Two declarations of an object with hidden visibility refer to the
+same object if they are in the same shared object. Usually, hidden
+visibility indicates that the symbol will not be placed into the
+dynamic symbol table, so no other module (executable or shared
+library) can reference it directly.</dd>
+<dt>â<code class="docutils literal notranslate"><span class="pre">protected</span></code>â - Protected style</dt>
+<dd>On ELF, protected visibility indicates that the symbol will be
+placed in the dynamic symbol table, but that references within the
+defining module will bind to the local symbol. That is, the symbol
+cannot be overridden by another module.</dd>
+</dl>
+<p>A symbol with <code class="docutils literal notranslate"><span class="pre">internal</span></code> or <code class="docutils literal notranslate"><span class="pre">private</span></code> linkage must have <code class="docutils literal notranslate"><span class="pre">default</span></code>
+visibility.</p>
+</div>
+<div class="section" id="dll-storage-classes">
+<span id="dllstorageclass"></span><h3><a class="toc-backref" href="#id956">DLL Storage Classes</a><a class="headerlink" href="#dll-storage-classes" title="Permalink to this headline">¶</a></h3>
+<p>All Global Variables, Functions and Aliases can have one of the following
+DLL storage class:</p>
+<dl class="docutils">
+<dt><code class="docutils literal notranslate"><span class="pre">dllimport</span></code></dt>
+<dd>â<code class="docutils literal notranslate"><span class="pre">dllimport</span></code>â causes the compiler to reference a function or variable via
+a global pointer to a pointer that is set up by the DLL exporting the
+symbol. On Microsoft Windows targets, the pointer name is formed by
+combining <code class="docutils literal notranslate"><span class="pre">__imp_</span></code> and the function or variable name.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">dllexport</span></code></dt>
+<dd>â<code class="docutils literal notranslate"><span class="pre">dllexport</span></code>â causes the compiler to provide a global pointer to a pointer
+in a DLL, so that it can be referenced with the <code class="docutils literal notranslate"><span class="pre">dllimport</span></code> attribute. On
+Microsoft Windows targets, the pointer name is formed by combining
+<code class="docutils literal notranslate"><span class="pre">__imp_</span></code> and the function or variable name. Since this storage class
+exists for defining a dll interface, the compiler, assembler and linker know
+it is externally referenced and must refrain from deleting the symbol.</dd>
+</dl>
+</div>
+<div class="section" id="thread-local-storage-models">
+<span id="tls-model"></span><h3><a class="toc-backref" href="#id957">Thread Local Storage Models</a><a class="headerlink" href="#thread-local-storage-models" title="Permalink to this headline">¶</a></h3>
+<p>A variable may be defined as <code class="docutils literal notranslate"><span class="pre">thread_local</span></code>, which means that it will
+not be shared by threads (each thread will have a separated copy of the
+variable). Not all targets support thread-local variables. Optionally, a
+TLS model may be specified:</p>
+<dl class="docutils">
+<dt><code class="docutils literal notranslate"><span class="pre">localdynamic</span></code></dt>
+<dd>For variables that are only used within the current shared library.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">initialexec</span></code></dt>
+<dd>For variables in modules that will not be loaded dynamically.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">localexec</span></code></dt>
+<dd>For variables defined in the executable and only used within it.</dd>
+</dl>
+<p>If no explicit model is given, the âgeneral dynamicâ model is used.</p>
+<p>The models correspond to the ELF TLS models; see <a class="reference external" href="http://people.redhat.com/drepper/tls.pdf">ELF Handling For
+Thread-Local Storage</a> for
+more information on under which circumstances the different models may
+be used. The target may choose a different TLS model if the specified
+model is not supported, or if a better choice of model can be made.</p>
+<p>A model can also be specified in an alias, but then it only governs how
+the alias is accessed. It will not have any effect in the aliasee.</p>
+<p>For platforms without linker support of ELF TLS model, the -femulated-tls
+flag can be used to generate GCC compatible emulated TLS code.</p>
+</div>
+<div class="section" id="runtime-preemption-specifiers">
+<span id="runtime-preemption-model"></span><h3><a class="toc-backref" href="#id958">Runtime Preemption Specifiers</a><a class="headerlink" href="#runtime-preemption-specifiers" title="Permalink to this headline">¶</a></h3>
+<p>Global variables, functions and aliases may have an optional runtime preemption
+specifier. If a preemption specifier isnât given explicitly, then a
+symbol is assumed to be <code class="docutils literal notranslate"><span class="pre">dso_preemptable</span></code>.</p>
+<dl class="docutils">
+<dt><code class="docutils literal notranslate"><span class="pre">dso_preemptable</span></code></dt>
+<dd>Indicates that the function or variable may be replaced by a symbol from
+outside the linkage unit at runtime.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">dso_local</span></code></dt>
+<dd>The compiler may assume that a function or variable marked as <code class="docutils literal notranslate"><span class="pre">dso_local</span></code>
+will resolve to a symbol within the same linkage unit. Direct access will
+be generated even if the definition is not within this compilation unit.</dd>
+</dl>
+</div>
+<div class="section" id="structure-types">
+<span id="namedtypes"></span><h3><a class="toc-backref" href="#id959">Structure Types</a><a class="headerlink" href="#structure-types" title="Permalink to this headline">¶</a></h3>
+<p>LLVM IR allows you to specify both âidentifiedâ and âliteralâ <a class="reference internal" href="#t-struct"><span class="std std-ref">structure
+types</span></a>. Literal types are uniqued structurally, but identified types
+are never uniqued. An <a class="reference internal" href="#t-opaque"><span class="std std-ref">opaque structural type</span></a> can also be used
+to forward declare a type that is not yet available.</p>
+<p>An example of an identified structure specification is:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%mytype</span> <span class="p">=</span> <span class="k">type</span> <span class="p">{</span> <span class="nv">%mytype</span><span class="p">*,</span> <span class="k">i32</span> <span class="p">}</span>
+</pre></div>
+</div>
+<p>Prior to the LLVM 3.0 release, identified types were structurally uniqued. Only
+literal types are uniqued in recent versions of LLVM.</p>
+</div>
+<div class="section" id="non-integral-pointer-type">
+<span id="nointptrtype"></span><h3><a class="toc-backref" href="#id960">Non-Integral Pointer Type</a><a class="headerlink" href="#non-integral-pointer-type" title="Permalink to this headline">¶</a></h3>
+<p>Note: non-integral pointer types are a work in progress, and they should be
+considered experimental at this time.</p>
+<p>LLVM IR optionally allows the frontend to denote pointers in certain address
+spaces as ânon-integralâ via the <a class="reference internal" href="#langref-datalayout"><span class="std std-ref">datalayout string</span></a>.
+Non-integral pointer types represent pointers that have an <em>unspecified</em> bitwise
+representation; that is, the integral representation may be target dependent or
+unstable (not backed by a fixed integer).</p>
+<p><code class="docutils literal notranslate"><span class="pre">inttoptr</span></code> instructions converting integers to non-integral pointer types are
+ill-typed, and so are <code class="docutils literal notranslate"><span class="pre">ptrtoint</span></code> instructions converting values of
+non-integral pointer types to integers. Vector versions of said instructions
+are ill-typed as well.</p>
+</div>
+<div class="section" id="global-variables">
+<span id="globalvars"></span><h3><a class="toc-backref" href="#id961">Global Variables</a><a class="headerlink" href="#global-variables" title="Permalink to this headline">¶</a></h3>
+<p>Global variables define regions of memory allocated at compilation time
+instead of run-time.</p>
+<p>Global variable definitions must be initialized.</p>
+<p>Global variables in other translation units can also be declared, in which
+case they donât have an initializer.</p>
+<p>Either global variable definitions or declarations may have an explicit section
+to be placed in and may have an optional explicit alignment specified. If there
+is a mismatch between the explicit or inferred section information for the
+variable declaration and its definition the resulting behavior is undefined.</p>
+<p>A variable may be defined as a global <code class="docutils literal notranslate"><span class="pre">constant</span></code>, which indicates that
+the contents of the variable will <strong>never</strong> be modified (enabling better
+optimization, allowing the global data to be placed in the read-only
+section of an executable, etc). Note that variables that need runtime
+initialization cannot be marked <code class="docutils literal notranslate"><span class="pre">constant</span></code> as there is a store to the
+variable.</p>
+<p>LLVM explicitly allows <em>declarations</em> of global variables to be marked
+constant, even if the final definition of the global is not. This
+capability can be used to enable slightly better optimization of the
+program, but requires the language definition to guarantee that
+optimizations based on the âconstantnessâ are valid for the translation
+units that do not include the definition.</p>
+<p>As SSA values, global variables define pointer values that are in scope
+(i.e. they dominate) all basic blocks in the program. Global variables
+always define a pointer to their âcontentâ type because they describe a
+region of memory, and all memory objects in LLVM are accessed through
+pointers.</p>
+<p>Global variables can be marked with <code class="docutils literal notranslate"><span class="pre">unnamed_addr</span></code> which indicates
+that the address is not significant, only the content. Constants marked
+like this can be merged with other constants if they have the same
+initializer. Note that a constant with significant address <em>can</em> be
+merged with a <code class="docutils literal notranslate"><span class="pre">unnamed_addr</span></code> constant, the result being a constant
+whose address is significant.</p>
+<p>If the <code class="docutils literal notranslate"><span class="pre">local_unnamed_addr</span></code> attribute is given, the address is known to
+not be significant within the module.</p>
+<p>A global variable may be declared to reside in a target-specific
+numbered address space. For targets that support them, address spaces
+may affect how optimizations are performed and/or what target
+instructions are used to access the variable. The default address space
+is zero. The address space qualifier must precede any other attributes.</p>
+<p>LLVM allows an explicit section to be specified for globals. If the
+target supports it, it will emit globals to the section specified.
+Additionally, the global can placed in a comdat if the target has the necessary
+support.</p>
+<p>External declarations may have an explicit section specified. Section
+information is retained in LLVM IR for targets that make use of this
+information. Attaching section information to an external declaration is an
+assertion that its definition is located in the specified section. If the
+definition is located in a different section, the behavior is undefined.</p>
+<p>By default, global initializers are optimized by assuming that global
+variables defined within the module are not modified from their
+initial values before the start of the global initializer. This is
+true even for variables potentially accessible from outside the
+module, including those with external linkage or appearing in
+<code class="docutils literal notranslate"><span class="pre">@llvm.used</span></code> or dllexported variables. This assumption may be suppressed
+by marking the variable with <code class="docutils literal notranslate"><span class="pre">externally_initialized</span></code>.</p>
+<p>An explicit alignment may be specified for a global, which must be a
+power of 2. If not present, or if the alignment is set to zero, the
+alignment of the global is set by the target to whatever it feels
+convenient. If an explicit alignment is specified, the global is forced
+to have exactly that alignment. Targets and optimizers are not allowed
+to over-align the global if the global has an assigned section. In this
+case, the extra alignment could be observable: for example, code could
+assume that the globals are densely packed in their section and try to
+iterate over them as an array, alignment padding would break this
+iteration. The maximum alignment is <code class="docutils literal notranslate"><span class="pre">1</span> <span class="pre"><<</span> <span class="pre">29</span></code>.</p>
+<p>Globals can also have a <a class="reference internal" href="#dllstorageclass"><span class="std std-ref">DLL storage class</span></a>,
+an optional <a class="reference internal" href="#runtime-preemption-model"><span class="std std-ref">runtime preemption specifier</span></a>,
+an optional <a class="reference internal" href="#glattrs"><span class="std std-ref">global attributes</span></a> and
+an optional list of attached <a class="reference internal" href="#metadata"><span class="std std-ref">metadata</span></a>.</p>
+<p>Variables and aliases can have a
+<a class="reference internal" href="#tls-model"><span class="std std-ref">Thread Local Storage Model</span></a>.</p>
+<p>Syntax:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span>@<GlobalVarName> = [Linkage] [PreemptionSpecifier] [Visibility]
+ [DLLStorageClass] [ThreadLocal]
+ [(unnamed_addr|local_unnamed_addr)] [AddrSpace]
+ [ExternallyInitialized]
+ <global | constant> <Type> [<InitializerConstant>]
+ [, section "name"] [, comdat [($name)]]
+ [, align <Alignment>] (, !name !N)*
+</pre></div>
+</div>
+<p>For example, the following defines a global in a numbered address space
+with an initializer, section, and alignment:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="vg">@G</span> <span class="p">=</span> <span class="k">addrspace</span><span class="p">(</span><span class="m">5</span><span class="p">)</span> <span class="k">constant</span> <span class="kt">float</span> <span class="m">1.0</span><span class="p">,</span> <span class="k">section</span> <span class="s">"foo"</span><span class="p">,</span> <span class="k">align</span> <span class="m">4</span>
+</pre></div>
+</div>
+<p>The following example just declares a global variable</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="vg">@G</span> <span class="p">=</span> <span class="k">external</span> <span class="k">global</span> <span class="k">i32</span>
+</pre></div>
+</div>
+<p>The following example defines a thread-local global with the
+<code class="docutils literal notranslate"><span class="pre">initialexec</span></code> TLS model:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="vg">@G</span> <span class="p">=</span> <span class="k">thread_local</span><span class="p">(</span><span class="k">initialexec</span><span class="p">)</span> <span class="k">global</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="k">align</span> <span class="m">4</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="functions">
+<span id="functionstructure"></span><h3><a class="toc-backref" href="#id962">Functions</a><a class="headerlink" href="#functions" title="Permalink to this headline">¶</a></h3>
+<p>LLVM function definitions consist of the â<code class="docutils literal notranslate"><span class="pre">define</span></code>â keyword, an
+optional <a class="reference internal" href="#linkage"><span class="std std-ref">linkage type</span></a>, an optional <a class="reference internal" href="#runtime-preemption-model"><span class="std std-ref">runtime preemption
+specifier</span></a>, an optional <a class="reference internal" href="BitCodeFormat.html#visibility"><span class="std std-ref">visibility
+style</span></a>, an optional <a class="reference internal" href="#dllstorageclass"><span class="std std-ref">DLL storage class</span></a>,
+an optional <a class="reference internal" href="#callingconv"><span class="std std-ref">calling convention</span></a>,
+an optional <code class="docutils literal notranslate"><span class="pre">unnamed_addr</span></code> attribute, a return type, an optional
+<a class="reference internal" href="#paramattrs"><span class="std std-ref">parameter attribute</span></a> for the return type, a function
+name, a (possibly empty) argument list (each with optional <a class="reference internal" href="#paramattrs"><span class="std std-ref">parameter
+attributes</span></a>), optional <a class="reference internal" href="#fnattrs"><span class="std std-ref">function attributes</span></a>,
+an optional address space, an optional section, an optional alignment,
+an optional <a class="reference internal" href="#langref-comdats"><span class="std std-ref">comdat</span></a>,
+an optional <a class="reference internal" href="#gc"><span class="std std-ref">garbage collector name</span></a>, an optional <a class="reference internal" href="#prefixdata"><span class="std std-ref">prefix</span></a>,
+an optional <a class="reference internal" href="#prologuedata"><span class="std std-ref">prologue</span></a>,
+an optional <a class="reference internal" href="#personalityfn"><span class="std std-ref">personality</span></a>,
+an optional list of attached <a class="reference internal" href="#metadata"><span class="std std-ref">metadata</span></a>,
+an opening curly brace, a list of basic blocks, and a closing curly brace.</p>
+<p>LLVM function declarations consist of the â<code class="docutils literal notranslate"><span class="pre">declare</span></code>â keyword, an
+optional <a class="reference internal" href="#linkage"><span class="std std-ref">linkage type</span></a>, an optional <a class="reference internal" href="BitCodeFormat.html#visibility"><span class="std std-ref">visibility style</span></a>, an optional <a class="reference internal" href="#dllstorageclass"><span class="std std-ref">DLL storage class</span></a>, an
+optional <a class="reference internal" href="#callingconv"><span class="std std-ref">calling convention</span></a>, an optional <code class="docutils literal notranslate"><span class="pre">unnamed_addr</span></code>
+or <code class="docutils literal notranslate"><span class="pre">local_unnamed_addr</span></code> attribute, an optional address space, a return type,
+an optional <a class="reference internal" href="#paramattrs"><span class="std std-ref">parameter attribute</span></a> for the return type, a function name, a possibly
+empty list of arguments, an optional alignment, an optional <a class="reference internal" href="#gc"><span class="std std-ref">garbage
+collector name</span></a>, an optional <a class="reference internal" href="#prefixdata"><span class="std std-ref">prefix</span></a>, and an optional
+<a class="reference internal" href="#prologuedata"><span class="std std-ref">prologue</span></a>.</p>
+<p>A function definition contains a list of basic blocks, forming the CFG (Control
+Flow Graph) for the function. Each basic block may optionally start with a label
+(giving the basic block a symbol table entry), contains a list of instructions,
+and ends with a <a class="reference internal" href="#terminators"><span class="std std-ref">terminator</span></a> instruction (such as a branch or
+function return). If an explicit label is not provided, a block is assigned an
+implicit numbered label, using the next value from the same counter as used for
+unnamed temporaries (<a class="reference internal" href="#identifiers"><span class="std std-ref">see above</span></a>). For example, if a function
+entry block does not have an explicit label, it will be assigned label â%0â,
+then the first unnamed temporary in that block will be â%1â, etc.</p>
+<p>The first basic block in a function is special in two ways: it is
+immediately executed on entrance to the function, and it is not allowed
+to have predecessor basic blocks (i.e. there can not be any branches to
+the entry block of a function). Because the block can have no
+predecessors, it also cannot have any <a class="reference internal" href="#i-phi"><span class="std std-ref">PHI nodes</span></a>.</p>
+<p>LLVM allows an explicit section to be specified for functions. If the
+target supports it, it will emit functions to the section specified.
+Additionally, the function can be placed in a COMDAT.</p>
+<p>An explicit alignment may be specified for a function. If not present,
+or if the alignment is set to zero, the alignment of the function is set
+by the target to whatever it feels convenient. If an explicit alignment
+is specified, the function is forced to have at least that much
+alignment. All alignments must be a power of 2.</p>
+<p>If the <code class="docutils literal notranslate"><span class="pre">unnamed_addr</span></code> attribute is given, the address is known to not
+be significant and two identical functions can be merged.</p>
+<p>If the <code class="docutils literal notranslate"><span class="pre">local_unnamed_addr</span></code> attribute is given, the address is known to
+not be significant within the module.</p>
+<p>If an explicit address space is not given, it will default to the program
+address space from the <a class="reference internal" href="#langref-datalayout"><span class="std std-ref">datalayout string</span></a>.</p>
+<p>Syntax:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span>define [linkage] [PreemptionSpecifier] [visibility] [DLLStorageClass]
+ [cconv] [ret attrs]
+ <ResultType> @<FunctionName> ([argument list])
+ [(unnamed_addr|local_unnamed_addr)] [AddrSpace] [fn Attrs]
+ [section "name"] [comdat [($name)]] [align N] [gc] [prefix Constant]
+ [prologue Constant] [personality Constant] (!name !N)* { ... }
+</pre></div>
+</div>
+<p>The argument list is a comma separated sequence of arguments where each
+argument is of the following form:</p>
+<p>Syntax:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="nb">type</span><span class="o">></span> <span class="p">[</span><span class="n">parameter</span> <span class="n">Attrs</span><span class="p">]</span> <span class="p">[</span><span class="n">name</span><span class="p">]</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="aliases">
+<span id="langref-aliases"></span><h3><a class="toc-backref" href="#id963">Aliases</a><a class="headerlink" href="#aliases" title="Permalink to this headline">¶</a></h3>
+<p>Aliases, unlike function or variables, donât create any new data. They
+are just a new symbol and metadata for an existing position.</p>
+<p>Aliases have a name and an aliasee that is either a global value or a
+constant expression.</p>
+<p>Aliases may have an optional <a class="reference internal" href="#linkage"><span class="std std-ref">linkage type</span></a>, an optional
+<a class="reference internal" href="#runtime-preemption-model"><span class="std std-ref">runtime preemption specifier</span></a>, an optional
+<a class="reference internal" href="BitCodeFormat.html#visibility"><span class="std std-ref">visibility style</span></a>, an optional <a class="reference internal" href="#dllstorageclass"><span class="std std-ref">DLL storage class</span></a> and an optional <a class="reference internal" href="#tls-model"><span class="std std-ref">tls model</span></a>.</p>
+<p>Syntax:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o">@<</span><span class="n">Name</span><span class="o">></span> <span class="o">=</span> <span class="p">[</span><span class="n">Linkage</span><span class="p">]</span> <span class="p">[</span><span class="n">PreemptionSpecifier</span><span class="p">]</span> <span class="p">[</span><span class="n">Visibility</span><span class="p">]</span> <span class="p">[</span><span class="n">DLLStorageClass</span><span class="p">]</span> <span class="p">[</span><span class="n">ThreadLocal</span><span class="p">]</span> <span class="p">[(</span><span class="n">unnamed_addr</span><span class="o">|</span><span class="n">local_unnamed_addr</span><span class="p">)]</span> <span class="n">alias</span> <span class="o"><</span><span class="n">AliaseeTy</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">AliaseeTy</span><span class="o">>*</span> <span class="o">@<</span><span class="n">Aliasee</span><span class="o">></span>
+</pre></div>
+</div>
+<p>The linkage must be one of <code class="docutils literal notranslate"><span class="pre">private</span></code>, <code class="docutils literal notranslate"><span class="pre">internal</span></code>, <code class="docutils literal notranslate"><span class="pre">linkonce</span></code>, <code class="docutils literal notranslate"><span class="pre">weak</span></code>,
+<code class="docutils literal notranslate"><span class="pre">linkonce_odr</span></code>, <code class="docutils literal notranslate"><span class="pre">weak_odr</span></code>, <code class="docutils literal notranslate"><span class="pre">external</span></code>. Note that some system linkers
+might not correctly handle dropping a weak symbol that is aliased.</p>
+<p>Aliases that are not <code class="docutils literal notranslate"><span class="pre">unnamed_addr</span></code> are guaranteed to have the same address as
+the aliasee expression. <code class="docutils literal notranslate"><span class="pre">unnamed_addr</span></code> ones are only guaranteed to point
+to the same content.</p>
+<p>If the <code class="docutils literal notranslate"><span class="pre">local_unnamed_addr</span></code> attribute is given, the address is known to
+not be significant within the module.</p>
+<p>Since aliases are only a second name, some restrictions apply, of which
+some can only be checked when producing an object file:</p>
+<ul class="simple">
+<li>The expression defining the aliasee must be computable at assembly
+time. Since it is just a name, no relocations can be used.</li>
+<li>No alias in the expression can be weak as the possibility of the
+intermediate alias being overridden cannot be represented in an
+object file.</li>
+<li>No global value in the expression can be a declaration, since that
+would require a relocation, which is not possible.</li>
+</ul>
+</div>
+<div class="section" id="ifuncs">
+<span id="langref-ifunc"></span><h3><a class="toc-backref" href="#id964">IFuncs</a><a class="headerlink" href="#ifuncs" title="Permalink to this headline">¶</a></h3>
+<p>IFuncs, like as aliases, donât create any new data or func. They are just a new
+symbol that dynamic linker resolves at runtime by calling a resolver function.</p>
+<p>IFuncs have a name and a resolver that is a function called by dynamic linker
+that returns address of another function associated with the name.</p>
+<p>IFunc may have an optional <a class="reference internal" href="#linkage"><span class="std std-ref">linkage type</span></a> and an optional
+<a class="reference internal" href="BitCodeFormat.html#visibility"><span class="std std-ref">visibility style</span></a>.</p>
+<p>Syntax:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o">@<</span><span class="n">Name</span><span class="o">></span> <span class="o">=</span> <span class="p">[</span><span class="n">Linkage</span><span class="p">]</span> <span class="p">[</span><span class="n">Visibility</span><span class="p">]</span> <span class="n">ifunc</span> <span class="o"><</span><span class="n">IFuncTy</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">ResolverTy</span><span class="o">>*</span> <span class="o">@<</span><span class="n">Resolver</span><span class="o">></span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="comdats">
+<span id="langref-comdats"></span><h3><a class="toc-backref" href="#id965">Comdats</a><a class="headerlink" href="#comdats" title="Permalink to this headline">¶</a></h3>
+<p>Comdat IR provides access to COFF and ELF object file COMDAT functionality.</p>
+<p>Comdats have a name which represents the COMDAT key. All global objects that
+specify this key will only end up in the final object file if the linker chooses
+that key over some other key. Aliases are placed in the same COMDAT that their
+aliasee computes to, if any.</p>
+<p>Comdats have a selection kind to provide input on how the linker should
+choose between keys in two different object files.</p>
+<p>Syntax:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span>$<Name> = comdat SelectionKind
+</pre></div>
+</div>
+<p>The selection kind must be one of the following:</p>
+<dl class="docutils">
+<dt><code class="docutils literal notranslate"><span class="pre">any</span></code></dt>
+<dd>The linker may choose any COMDAT key, the choice is arbitrary.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">exactmatch</span></code></dt>
+<dd>The linker may choose any COMDAT key but the sections must contain the
+same data.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">largest</span></code></dt>
+<dd>The linker will choose the section containing the largest COMDAT key.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">noduplicates</span></code></dt>
+<dd>The linker requires that only section with this COMDAT key exist.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">samesize</span></code></dt>
+<dd>The linker may choose any COMDAT key but the sections must contain the
+same amount of data.</dd>
+</dl>
+<p>Note that the Mach-O platform doesnât support COMDATs, and ELF and WebAssembly
+only support <code class="docutils literal notranslate"><span class="pre">any</span></code> as a selection kind.</p>
+<p>Here is an example of a COMDAT group where a function will only be selected if
+the COMDAT keyâs section is the largest:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>$foo = comdat largest
+ at foo = global i32 2, comdat($foo)
+
+define void @bar() comdat($foo) {
+ ret void
+}
+</pre></div>
+</div>
+<p>As a syntactic sugar the <code class="docutils literal notranslate"><span class="pre">$name</span></code> can be omitted if the name is the same as
+the global name:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>$foo = comdat any
+ at foo = global i32 2, comdat
+</pre></div>
+</div>
+<p>In a COFF object file, this will create a COMDAT section with selection kind
+<code class="docutils literal notranslate"><span class="pre">IMAGE_COMDAT_SELECT_LARGEST</span></code> containing the contents of the <code class="docutils literal notranslate"><span class="pre">@foo</span></code> symbol
+and another COMDAT section with selection kind
+<code class="docutils literal notranslate"><span class="pre">IMAGE_COMDAT_SELECT_ASSOCIATIVE</span></code> which is associated with the first COMDAT
+section and contains the contents of the <code class="docutils literal notranslate"><span class="pre">@bar</span></code> symbol.</p>
+<p>There are some restrictions on the properties of the global object.
+It, or an alias to it, must have the same name as the COMDAT group when
+targeting COFF.
+The contents and size of this object may be used during link-time to determine
+which COMDAT groups get selected depending on the selection kind.
+Because the name of the object must match the name of the COMDAT group, the
+linkage of the global object must not be local; local symbols can get renamed
+if a collision occurs in the symbol table.</p>
+<p>The combined use of COMDATS and section attributes may yield surprising results.
+For example:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>$foo = comdat any
+$bar = comdat any
+ at g1 = global i32 42, section "sec", comdat($foo)
+ at g2 = global i32 42, section "sec", comdat($bar)
+</pre></div>
+</div>
+<p>From the object file perspective, this requires the creation of two sections
+with the same name. This is necessary because both globals belong to different
+COMDAT groups and COMDATs, at the object file level, are represented by
+sections.</p>
+<p>Note that certain IR constructs like global variables and functions may
+create COMDATs in the object file in addition to any which are specified using
+COMDAT IR. This arises when the code generator is configured to emit globals
+in individual sections (e.g. when <cite>-data-sections</cite> or <cite>-function-sections</cite>
+is supplied to <cite>llc</cite>).</p>
+</div>
+<div class="section" id="named-metadata">
+<span id="namedmetadatastructure"></span><h3><a class="toc-backref" href="#id966">Named Metadata</a><a class="headerlink" href="#named-metadata" title="Permalink to this headline">¶</a></h3>
+<p>Named metadata is a collection of metadata. <a class="reference internal" href="#metadata"><span class="std std-ref">Metadata
+nodes</span></a> (but not metadata strings) are the only valid
+operands for a named metadata.</p>
+<ol class="arabic simple">
+<li>Named metadata are represented as a string of characters with the
+metadata prefix. The rules for metadata names are the same as for
+identifiers, but quoted names are not allowed. <code class="docutils literal notranslate"><span class="pre">"\xx"</span></code> type escapes
+are still valid, which allows any character to be part of a name.</li>
+</ol>
+<p>Syntax:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span>; Some unnamed metadata nodes, which are referenced by the named metadata.
+!0 = !{!"zero"}
+!1 = !{!"one"}
+!2 = !{!"two"}
+; A named metadata.
+!name = !{!0, !1, !2}
+</pre></div>
+</div>
+</div>
+<div class="section" id="parameter-attributes">
+<span id="paramattrs"></span><h3><a class="toc-backref" href="#id967">Parameter Attributes</a><a class="headerlink" href="#parameter-attributes" title="Permalink to this headline">¶</a></h3>
+<p>The return type and each parameter of a function type may have a set of
+<em>parameter attributes</em> associated with them. Parameter attributes are
+used to communicate additional information about the result or
+parameters of a function. Parameter attributes are considered to be part
+of the function, not of the function type, so functions with different
+parameter attributes can have the same function type.</p>
+<p>Parameter attributes are simple keywords that follow the type specified.
+If multiple parameter attributes are needed, they are space separated.
+For example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">declare</span> <span class="k">i32</span> <span class="vg">@printf</span><span class="p">(</span><span class="k">i8</span><span class="p">*</span> <span class="k">noalias</span> <span class="k">nocapture</span><span class="p">,</span> <span class="p">...)</span>
+<span class="k">declare</span> <span class="k">i32</span> <span class="vg">@atoi</span><span class="p">(</span><span class="k">i8</span> <span class="k">zeroext</span><span class="p">)</span>
+<span class="k">declare</span> <span class="k">signext</span> <span class="k">i8</span> <span class="vg">@returns_signed_char</span><span class="p">()</span>
+</pre></div>
+</div>
+<p>Note that any attributes for the function result (<code class="docutils literal notranslate"><span class="pre">nounwind</span></code>,
+<code class="docutils literal notranslate"><span class="pre">readonly</span></code>) come immediately after the argument list.</p>
+<p>Currently, only the following parameter attributes are defined:</p>
+<dl class="docutils">
+<dt><code class="docutils literal notranslate"><span class="pre">zeroext</span></code></dt>
+<dd>This indicates to the code generator that the parameter or return
+value should be zero-extended to the extent required by the targetâs
+ABI by the caller (for a parameter) or the callee (for a return value).</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">signext</span></code></dt>
+<dd>This indicates to the code generator that the parameter or return
+value should be sign-extended to the extent required by the targetâs
+ABI (which is usually 32-bits) by the caller (for a parameter) or
+the callee (for a return value).</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">inreg</span></code></dt>
+<dd>This indicates that this parameter or return value should be treated
+in a special target-dependent fashion while emitting code for
+a function call or return (usually, by putting it in a register as
+opposed to memory, though some targets use it to distinguish between
+two different kinds of registers). Use of this attribute is
+target-specific.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">byval</span></code></dt>
+<dd><p class="first">This indicates that the pointer parameter should really be passed by
+value to the function. The attribute implies that a hidden copy of
+the pointee is made between the caller and the callee, so the callee
+is unable to modify the value in the caller. This attribute is only
+valid on LLVM pointer arguments. It is generally used to pass
+structs and arrays by value, but is also valid on pointers to
+scalars. The copy is considered to belong to the caller not the
+callee (for example, <code class="docutils literal notranslate"><span class="pre">readonly</span></code> functions should not write to
+<code class="docutils literal notranslate"><span class="pre">byval</span></code> parameters). This is not a valid attribute for return
+values.</p>
+<p class="last">The byval attribute also supports specifying an alignment with the
+align attribute. It indicates the alignment of the stack slot to
+form and the known alignment of the pointer specified to the call
+site. If the alignment is not specified, then the code generator
+makes a target-specific assumption.</p>
+</dd>
+</dl>
+<p id="attr-inalloca"><code class="docutils literal notranslate"><span class="pre">inalloca</span></code></p>
+<blockquote>
+<div><p>The <code class="docutils literal notranslate"><span class="pre">inalloca</span></code> argument attribute allows the caller to take the
+address of outgoing stack arguments. An <code class="docutils literal notranslate"><span class="pre">inalloca</span></code> argument must
+be a pointer to stack memory produced by an <code class="docutils literal notranslate"><span class="pre">alloca</span></code> instruction.
+The alloca, or argument allocation, must also be tagged with the
+inalloca keyword. Only the last argument may have the <code class="docutils literal notranslate"><span class="pre">inalloca</span></code>
+attribute, and that argument is guaranteed to be passed in memory.</p>
+<p>An argument allocation may be used by a call at most once because
+the call may deallocate it. The <code class="docutils literal notranslate"><span class="pre">inalloca</span></code> attribute cannot be
+used in conjunction with other attributes that affect argument
+storage, like <code class="docutils literal notranslate"><span class="pre">inreg</span></code>, <code class="docutils literal notranslate"><span class="pre">nest</span></code>, <code class="docutils literal notranslate"><span class="pre">sret</span></code>, or <code class="docutils literal notranslate"><span class="pre">byval</span></code>. The
+<code class="docutils literal notranslate"><span class="pre">inalloca</span></code> attribute also disables LLVMâs implicit lowering of
+large aggregate return values, which means that frontend authors
+must lower them with <code class="docutils literal notranslate"><span class="pre">sret</span></code> pointers.</p>
+<p>When the call site is reached, the argument allocation must have
+been the most recent stack allocation that is still live, or the
+behavior is undefined. It is possible to allocate additional stack
+space after an argument allocation and before its call site, but it
+must be cleared off with <a class="reference internal" href="#int-stackrestore"><span class="std std-ref">llvm.stackrestore</span></a>.</p>
+<p>See <a class="reference internal" href="InAlloca.html"><span class="doc">Design and Usage of the InAlloca Attribute</span></a> for more information on how to use this
+attribute.</p>
+</div></blockquote>
+<dl class="docutils">
+<dt><code class="docutils literal notranslate"><span class="pre">sret</span></code></dt>
+<dd>This indicates that the pointer parameter specifies the address of a
+structure that is the return value of the function in the source
+program. This pointer must be guaranteed by the caller to be valid:
+loads and stores to the structure may be assumed by the callee not
+to trap and to be properly aligned. This is not a valid attribute
+for return values.</dd>
+</dl>
+<dl class="docutils" id="attr-align">
+<dt><code class="docutils literal notranslate"><span class="pre">align</span> <span class="pre"><n></span></code></dt>
+<dd><p class="first">This indicates that the pointer value may be assumed by the optimizer to
+have the specified alignment.</p>
+<p class="last">Note that this attribute has additional semantics when combined with the
+<code class="docutils literal notranslate"><span class="pre">byval</span></code> attribute.</p>
+</dd>
+</dl>
+<dl class="docutils" id="noalias">
+<dt><code class="docutils literal notranslate"><span class="pre">noalias</span></code></dt>
+<dd><p class="first">This indicates that objects accessed via pointer values
+<a class="reference internal" href="#pointeraliasing"><span class="std std-ref">based</span></a> on the argument or return value are not also
+accessed, during the execution of the function, via pointer values not
+<em>based</em> on the argument or return value. The attribute on a return value
+also has additional semantics described below. The caller shares the
+responsibility with the callee for ensuring that these requirements are met.
+For further details, please see the discussion of the NoAlias response in
+<a class="reference internal" href="AliasAnalysis.html#must-may-or-no"><span class="std std-ref">alias analysis</span></a>.</p>
+<p>Note that this definition of <code class="docutils literal notranslate"><span class="pre">noalias</span></code> is intentionally similar
+to the definition of <code class="docutils literal notranslate"><span class="pre">restrict</span></code> in C99 for function arguments.</p>
+<p class="last">For function return values, C99âs <code class="docutils literal notranslate"><span class="pre">restrict</span></code> is not meaningful,
+while LLVMâs <code class="docutils literal notranslate"><span class="pre">noalias</span></code> is. Furthermore, the semantics of the <code class="docutils literal notranslate"><span class="pre">noalias</span></code>
+attribute on return values are stronger than the semantics of the attribute
+when used on function arguments. On function return values, the <code class="docutils literal notranslate"><span class="pre">noalias</span></code>
+attribute indicates that the function acts like a system memory allocation
+function, returning a pointer to allocated storage disjoint from the
+storage for any other object accessible to the caller.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">nocapture</span></code></dt>
+<dd>This indicates that the callee does not make any copies of the
+pointer that outlive the callee itself. This is not a valid
+attribute for return values. Addresses used in volatile operations
+are considered to be captured.</dd>
+</dl>
+<dl class="docutils" id="nest">
+<dt><code class="docutils literal notranslate"><span class="pre">nest</span></code></dt>
+<dd>This indicates that the pointer parameter can be excised using the
+<a class="reference internal" href="#int-trampoline"><span class="std std-ref">trampoline intrinsics</span></a>. This is not a valid
+attribute for return values and can only be applied to one parameter.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">returned</span></code></dt>
+<dd>This indicates that the function always returns the argument as its return
+value. This is a hint to the optimizer and code generator used when
+generating the caller, allowing value propagation, tail call optimization,
+and omission of register saves and restores in some cases; it is not
+checked or enforced when generating the callee. The parameter and the
+function return type must be valid operands for the
+<a class="reference internal" href="#i-bitcast"><span class="std std-ref">bitcast instruction</span></a>. This is not a valid attribute for
+return values and can only be applied to one parameter.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">nonnull</span></code></dt>
+<dd>This indicates that the parameter or return pointer is not null. This
+attribute may only be applied to pointer typed parameters. This is not
+checked or enforced by LLVM; if the parameter or return pointer is null,
+the behavior is undefined.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">dereferenceable(<n>)</span></code></dt>
+<dd>This indicates that the parameter or return pointer is dereferenceable. This
+attribute may only be applied to pointer typed parameters. A pointer that
+is dereferenceable can be loaded from speculatively without a risk of
+trapping. The number of bytes known to be dereferenceable must be provided
+in parentheses. It is legal for the number of bytes to be less than the
+size of the pointee type. The <code class="docutils literal notranslate"><span class="pre">nonnull</span></code> attribute does not imply
+dereferenceability (consider a pointer to one element past the end of an
+array), however <code class="docutils literal notranslate"><span class="pre">dereferenceable(<n>)</span></code> does imply <code class="docutils literal notranslate"><span class="pre">nonnull</span></code> in
+<code class="docutils literal notranslate"><span class="pre">addrspace(0)</span></code> (which is the default address space).</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">dereferenceable_or_null(<n>)</span></code></dt>
+<dd>This indicates that the parameter or return value isnât both
+non-null and non-dereferenceable (up to <code class="docutils literal notranslate"><span class="pre"><n></span></code> bytes) at the same
+time. All non-null pointers tagged with
+<code class="docutils literal notranslate"><span class="pre">dereferenceable_or_null(<n>)</span></code> are <code class="docutils literal notranslate"><span class="pre">dereferenceable(<n>)</span></code>.
+For address space 0 <code class="docutils literal notranslate"><span class="pre">dereferenceable_or_null(<n>)</span></code> implies that
+a pointer is exactly one of <code class="docutils literal notranslate"><span class="pre">dereferenceable(<n>)</span></code> or <code class="docutils literal notranslate"><span class="pre">null</span></code>,
+and in other address spaces <code class="docutils literal notranslate"><span class="pre">dereferenceable_or_null(<n>)</span></code>
+implies that a pointer is at least one of <code class="docutils literal notranslate"><span class="pre">dereferenceable(<n>)</span></code>
+or <code class="docutils literal notranslate"><span class="pre">null</span></code> (i.e. it may be both <code class="docutils literal notranslate"><span class="pre">null</span></code> and
+<code class="docutils literal notranslate"><span class="pre">dereferenceable(<n>)</span></code>). This attribute may only be applied to
+pointer typed parameters.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">swiftself</span></code></dt>
+<dd>This indicates that the parameter is the self/context parameter. This is not
+a valid attribute for return values and can only be applied to one
+parameter.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">swifterror</span></code></dt>
+<dd><p class="first">This attribute is motivated to model and optimize Swift error handling. It
+can be applied to a parameter with pointer to pointer type or a
+pointer-sized alloca. At the call site, the actual argument that corresponds
+to a <code class="docutils literal notranslate"><span class="pre">swifterror</span></code> parameter has to come from a <code class="docutils literal notranslate"><span class="pre">swifterror</span></code> alloca or
+the <code class="docutils literal notranslate"><span class="pre">swifterror</span></code> parameter of the caller. A <code class="docutils literal notranslate"><span class="pre">swifterror</span></code> value (either
+the parameter or the alloca) can only be loaded and stored from, or used as
+a <code class="docutils literal notranslate"><span class="pre">swifterror</span></code> argument. This is not a valid attribute for return values
+and can only be applied to one parameter.</p>
+<p>These constraints allow the calling convention to optimize access to
+<code class="docutils literal notranslate"><span class="pre">swifterror</span></code> variables by associating them with a specific register at
+call boundaries rather than placing them in memory. Since this does change
+the calling convention, a function which uses the <code class="docutils literal notranslate"><span class="pre">swifterror</span></code> attribute
+on a parameter is not ABI-compatible with one which does not.</p>
+<p class="last">These constraints also allow LLVM to assume that a <code class="docutils literal notranslate"><span class="pre">swifterror</span></code> argument
+does not alias any other memory visible within a function and that a
+<code class="docutils literal notranslate"><span class="pre">swifterror</span></code> alloca passed as an argument does not escape.</p>
+</dd>
+</dl>
+</div>
+<div class="section" id="garbage-collector-strategy-names">
+<span id="gc"></span><h3><a class="toc-backref" href="#id968">Garbage Collector Strategy Names</a><a class="headerlink" href="#garbage-collector-strategy-names" title="Permalink to this headline">¶</a></h3>
+<p>Each function may specify a garbage collector strategy name, which is simply a
+string:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">define</span> <span class="kt">void</span> <span class="vg">@f</span><span class="p">()</span> <span class="k">gc</span> <span class="s">"name"</span> <span class="p">{</span> <span class="p">...</span> <span class="p">}</span>
+</pre></div>
+</div>
+<p>The supported values of <em>name</em> includes those <a class="reference internal" href="GarbageCollection.html#builtin-gc-strategies"><span class="std std-ref">built in to LLVM</span></a> and any provided by loaded plugins. Specifying a GC
+strategy will cause the compiler to alter its output in order to support the
+named garbage collection algorithm. Note that LLVM itself does not contain a
+garbage collector, this functionality is restricted to generating machine code
+which can interoperate with a collector provided externally.</p>
+</div>
+<div class="section" id="prefix-data">
+<span id="prefixdata"></span><h3><a class="toc-backref" href="#id969">Prefix Data</a><a class="headerlink" href="#prefix-data" title="Permalink to this headline">¶</a></h3>
+<p>Prefix data is data associated with a function which the code
+generator will emit immediately before the functionâs entrypoint.
+The purpose of this feature is to allow frontends to associate
+language-specific runtime metadata with specific functions and make it
+available through the function pointer while still allowing the
+function pointer to be called.</p>
+<p>To access the data for a given function, a program may bitcast the
+function pointer to a pointer to the constantâs type and dereference
+index -1. This implies that the IR symbol points just past the end of
+the prefix data. For instance, take the example of a function annotated
+with a single <code class="docutils literal notranslate"><span class="pre">i32</span></code>,</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">define</span> <span class="kt">void</span> <span class="vg">@f</span><span class="p">()</span> <span class="k">prefix</span> <span class="k">i32</span> <span class="m">123</span> <span class="p">{</span> <span class="p">...</span> <span class="p">}</span>
+</pre></div>
+</div>
+<p>The prefix data can be referenced as,</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">%0</span> <span class="p">=</span> <span class="k">bitcast</span> <span class="kt">void</span><span class="p">*</span> <span class="p">()</span> <span class="vg">@f</span> <span class="k">to</span> <span class="k">i32</span><span class="p">*</span>
+<span class="nv">%a</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="k">inbounds</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv nv-Anonymous">%0</span><span class="p">,</span> <span class="k">i32</span> <span class="m">-1</span>
+<span class="nv">%b</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%a</span>
+</pre></div>
+</div>
+<p>Prefix data is laid out as if it were an initializer for a global variable
+of the prefix dataâs type. The function will be placed such that the
+beginning of the prefix data is aligned. This means that if the size
+of the prefix data is not a multiple of the alignment size, the
+functionâs entrypoint will not be aligned. If alignment of the
+functionâs entrypoint is desired, padding must be added to the prefix
+data.</p>
+<p>A function may have prefix data but no body. This has similar semantics
+to the <code class="docutils literal notranslate"><span class="pre">available_externally</span></code> linkage in that the data may be used by the
+optimizers but will not be emitted in the object file.</p>
+</div>
+<div class="section" id="prologue-data">
+<span id="prologuedata"></span><h3><a class="toc-backref" href="#id970">Prologue Data</a><a class="headerlink" href="#prologue-data" title="Permalink to this headline">¶</a></h3>
+<p>The <code class="docutils literal notranslate"><span class="pre">prologue</span></code> attribute allows arbitrary code (encoded as bytes) to
+be inserted prior to the function body. This can be used for enabling
+function hot-patching and instrumentation.</p>
+<p>To maintain the semantics of ordinary function calls, the prologue data must
+have a particular format. Specifically, it must begin with a sequence of
+bytes which decode to a sequence of machine instructions, valid for the
+moduleâs target, which transfer control to the point immediately succeeding
+the prologue data, without performing any other visible action. This allows
+the inliner and other passes to reason about the semantics of the function
+definition without needing to reason about the prologue data. Obviously this
+makes the format of the prologue data highly target dependent.</p>
+<p>A trivial example of valid prologue data for the x86 architecture is <code class="docutils literal notranslate"><span class="pre">i8</span> <span class="pre">144</span></code>,
+which encodes the <code class="docutils literal notranslate"><span class="pre">nop</span></code> instruction:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>define void @f() prologue i8 144 { ... }
+</pre></div>
+</div>
+<p>Generally prologue data can be formed by encoding a relative branch instruction
+which skips the metadata, as in this example of valid prologue data for the
+x86_64 architecture, where the first two bytes encode <code class="docutils literal notranslate"><span class="pre">jmp</span> <span class="pre">.+10</span></code>:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>%0 = type <{ i8, i8, i8* }>
+
+define void @f() prologue %0 <{ i8 235, i8 8, i8* @md}> { ... }
+</pre></div>
+</div>
+<p>A function may have prologue data but no body. This has similar semantics
+to the <code class="docutils literal notranslate"><span class="pre">available_externally</span></code> linkage in that the data may be used by the
+optimizers but will not be emitted in the object file.</p>
+</div>
+<div class="section" id="personality-function">
+<span id="personalityfn"></span><h3><a class="toc-backref" href="#id971">Personality Function</a><a class="headerlink" href="#personality-function" title="Permalink to this headline">¶</a></h3>
+<p>The <code class="docutils literal notranslate"><span class="pre">personality</span></code> attribute permits functions to specify what function
+to use for exception handling.</p>
+</div>
+<div class="section" id="attribute-groups">
+<span id="attrgrp"></span><h3><a class="toc-backref" href="#id972">Attribute Groups</a><a class="headerlink" href="#attribute-groups" title="Permalink to this headline">¶</a></h3>
+<p>Attribute groups are groups of attributes that are referenced by objects within
+the IR. They are important for keeping <code class="docutils literal notranslate"><span class="pre">.ll</span></code> files readable, because a lot of
+functions will use the same set of attributes. In the degenerative case of a
+<code class="docutils literal notranslate"><span class="pre">.ll</span></code> file that corresponds to a single <code class="docutils literal notranslate"><span class="pre">.c</span></code> file, the single attribute
+group will capture the important command line flags used to build that file.</p>
+<p>An attribute group is a module-level object. To use an attribute group, an
+object references the attribute groupâs ID (e.g. <code class="docutils literal notranslate"><span class="pre">#37</span></code>). An object may refer
+to more than one attribute group. In that situation, the attributes from the
+different groups are merged.</p>
+<p>Here is an example of attribute groups for a function that should always be
+inlined, has a stack alignment of 4, and which shouldnât use SSE instructions:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="c">; Target-independent attributes:</span>
+<span class="k">attributes</span> <span class="vg">#0</span> <span class="p">=</span> <span class="p">{</span> <span class="k">alwaysinline</span> <span class="k">alignstack</span><span class="p">=</span><span class="m">4</span> <span class="p">}</span>
+
+<span class="c">; Target-dependent attributes:</span>
+<span class="k">attributes</span> <span class="vg">#1</span> <span class="p">=</span> <span class="p">{</span> <span class="s">"no-sse"</span> <span class="p">}</span>
+
+<span class="c">; Function @f has attributes: alwaysinline, alignstack=4, and "no-sse".</span>
+<span class="k">define</span> <span class="kt">void</span> <span class="vg">@f</span><span class="p">()</span> <span class="vg">#0</span> <span class="vg">#1</span> <span class="p">{</span> <span class="p">...</span> <span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="function-attributes">
+<span id="fnattrs"></span><h3><a class="toc-backref" href="#id973">Function Attributes</a><a class="headerlink" href="#function-attributes" title="Permalink to this headline">¶</a></h3>
+<p>Function attributes are set to communicate additional information about
+a function. Function attributes are considered to be part of the
+function, not of the function type, so functions with different function
+attributes can have the same function type.</p>
+<p>Function attributes are simple keywords that follow the type specified.
+If multiple attributes are needed, they are space separated. For
+example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">define</span> <span class="kt">void</span> <span class="vg">@f</span><span class="p">()</span> <span class="k">noinline</span> <span class="p">{</span> <span class="p">...</span> <span class="p">}</span>
+<span class="k">define</span> <span class="kt">void</span> <span class="vg">@f</span><span class="p">()</span> <span class="k">alwaysinline</span> <span class="p">{</span> <span class="p">...</span> <span class="p">}</span>
+<span class="k">define</span> <span class="kt">void</span> <span class="vg">@f</span><span class="p">()</span> <span class="k">alwaysinline</span> <span class="k">optsize</span> <span class="p">{</span> <span class="p">...</span> <span class="p">}</span>
+<span class="k">define</span> <span class="kt">void</span> <span class="vg">@f</span><span class="p">()</span> <span class="k">optsize</span> <span class="p">{</span> <span class="p">...</span> <span class="p">}</span>
+</pre></div>
+</div>
+<dl class="docutils">
+<dt><code class="docutils literal notranslate"><span class="pre">alignstack(<n>)</span></code></dt>
+<dd>This attribute indicates that, when emitting the prologue and
+epilogue, the backend should forcibly align the stack pointer.
+Specify the desired alignment, which must be a power of two, in
+parentheses.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">allocsize(<EltSizeParam>[,</span> <span class="pre"><NumEltsParam>])</span></code></dt>
+<dd>This attribute indicates that the annotated function will always return at
+least a given number of bytes (or null). Its arguments are zero-indexed
+parameter numbers; if one argument is provided, then itâs assumed that at
+least <code class="docutils literal notranslate"><span class="pre">CallSite.Args[EltSizeParam]</span></code> bytes will be available at the
+returned pointer. If two are provided, then itâs assumed that
+<code class="docutils literal notranslate"><span class="pre">CallSite.Args[EltSizeParam]</span> <span class="pre">*</span> <span class="pre">CallSite.Args[NumEltsParam]</span></code> bytes are
+available. The referenced parameters must be integer types. No assumptions
+are made about the contents of the returned block of memory.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">alwaysinline</span></code></dt>
+<dd>This attribute indicates that the inliner should attempt to inline
+this function into callers whenever possible, ignoring any active
+inlining size threshold for this caller.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">builtin</span></code></dt>
+<dd>This indicates that the callee function at a call site should be
+recognized as a built-in function, even though the functionâs declaration
+uses the <code class="docutils literal notranslate"><span class="pre">nobuiltin</span></code> attribute. This is only valid at call sites for
+direct calls to functions that are declared with the <code class="docutils literal notranslate"><span class="pre">nobuiltin</span></code>
+attribute.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">cold</span></code></dt>
+<dd>This attribute indicates that this function is rarely called. When
+computing edge weights, basic blocks post-dominated by a cold
+function call are also considered to be cold; and, thus, given low
+weight.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">convergent</span></code></dt>
+<dd><p class="first">In some parallel execution models, there exist operations that cannot be
+made control-dependent on any additional values. We call such operations
+<code class="docutils literal notranslate"><span class="pre">convergent</span></code>, and mark them with this attribute.</p>
+<p>The <code class="docutils literal notranslate"><span class="pre">convergent</span></code> attribute may appear on functions or call/invoke
+instructions. When it appears on a function, it indicates that calls to
+this function should not be made control-dependent on additional values.
+For example, the intrinsic <code class="docutils literal notranslate"><span class="pre">llvm.nvvm.barrier0</span></code> is <code class="docutils literal notranslate"><span class="pre">convergent</span></code>, so
+calls to this intrinsic cannot be made control-dependent on additional
+values.</p>
+<p>When it appears on a call/invoke, the <code class="docutils literal notranslate"><span class="pre">convergent</span></code> attribute indicates
+that we should treat the call as though weâre calling a convergent
+function. This is particularly useful on indirect calls; without this we
+may treat such calls as though the target is non-convergent.</p>
+<p class="last">The optimizer may remove the <code class="docutils literal notranslate"><span class="pre">convergent</span></code> attribute on functions when it
+can prove that the function does not execute any convergent operations.
+Similarly, the optimizer may remove <code class="docutils literal notranslate"><span class="pre">convergent</span></code> on calls/invokes when it
+can prove that the call/invoke cannot call a convergent function.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">inaccessiblememonly</span></code></dt>
+<dd>This attribute indicates that the function may only access memory that
+is not accessible by the module being compiled. This is a weaker form
+of <code class="docutils literal notranslate"><span class="pre">readnone</span></code>. If the function reads or writes other memory, the
+behavior is undefined.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">inaccessiblemem_or_argmemonly</span></code></dt>
+<dd>This attribute indicates that the function may only access memory that is
+either not accessible by the module being compiled, or is pointed to
+by its pointer arguments. This is a weaker form of <code class="docutils literal notranslate"><span class="pre">argmemonly</span></code>. If the
+function reads or writes other memory, the behavior is undefined.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">inlinehint</span></code></dt>
+<dd>This attribute indicates that the source code contained a hint that
+inlining this function is desirable (such as the âinlineâ keyword in
+C/C++). It is just a hint; it imposes no requirements on the
+inliner.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">jumptable</span></code></dt>
+<dd>This attribute indicates that the function should be added to a
+jump-instruction table at code-generation time, and that all address-taken
+references to this function should be replaced with a reference to the
+appropriate jump-instruction-table function pointer. Note that this creates
+a new pointer for the original function, which means that code that depends
+on function-pointer identity can break. So, any function annotated with
+<code class="docutils literal notranslate"><span class="pre">jumptable</span></code> must also be <code class="docutils literal notranslate"><span class="pre">unnamed_addr</span></code>.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">minsize</span></code></dt>
+<dd>This attribute suggests that optimization passes and code generator
+passes make choices that keep the code size of this function as small
+as possible and perform optimizations that may sacrifice runtime
+performance in order to minimize the size of the generated code.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">naked</span></code></dt>
+<dd>This attribute disables prologue / epilogue emission for the
+function. This can have very system-specific consequences.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">no-jump-tables</span></code></dt>
+<dd>When this attribute is set to true, the jump tables and lookup tables that
+can be generated from a switch case lowering are disabled.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">nobuiltin</span></code></dt>
+<dd>This indicates that the callee function at a call site is not recognized as
+a built-in function. LLVM will retain the original call and not replace it
+with equivalent code based on the semantics of the built-in function, unless
+the call site uses the <code class="docutils literal notranslate"><span class="pre">builtin</span></code> attribute. This is valid at call sites
+and on function declarations and definitions.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">noduplicate</span></code></dt>
+<dd><p class="first">This attribute indicates that calls to the function cannot be
+duplicated. A call to a <code class="docutils literal notranslate"><span class="pre">noduplicate</span></code> function may be moved
+within its parent function, but may not be duplicated within
+its parent function.</p>
+<p class="last">A function containing a <code class="docutils literal notranslate"><span class="pre">noduplicate</span></code> call may still
+be an inlining candidate, provided that the call is not
+duplicated by inlining. That implies that the function has
+internal linkage and only has one call site, so the original
+call is dead after inlining.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">noimplicitfloat</span></code></dt>
+<dd>This attributes disables implicit floating-point instructions.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">noinline</span></code></dt>
+<dd>This attribute indicates that the inliner should never inline this
+function in any situation. This attribute may not be used together
+with the <code class="docutils literal notranslate"><span class="pre">alwaysinline</span></code> attribute.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">nonlazybind</span></code></dt>
+<dd>This attribute suppresses lazy symbol binding for the function. This
+may make calls to the function faster, at the cost of extra program
+startup time if the function is not called during program startup.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">noredzone</span></code></dt>
+<dd>This attribute indicates that the code generator should not use a
+red zone, even if the target-specific ABI normally permits it.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">indirect-tls-seg-refs</span></code></dt>
+<dd>This attribute indicates that the code generator should not use
+direct TLS access through segment registers, even if the
+target-specific ABI normally permits it.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">noreturn</span></code></dt>
+<dd>This function attribute indicates that the function never returns
+normally. This produces undefined behavior at runtime if the
+function ever does dynamically return.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">norecurse</span></code></dt>
+<dd>This function attribute indicates that the function does not call itself
+either directly or indirectly down any possible call path. This produces
+undefined behavior at runtime if the function ever does recurse.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">nounwind</span></code></dt>
+<dd>This function attribute indicates that the function never raises an
+exception. If the function does raise an exception, its runtime
+behavior is undefined. However, functions marked nounwind may still
+trap or generate asynchronous exceptions. Exception handling schemes
+that are recognized by LLVM to handle asynchronous exceptions, such
+as SEH, will still provide their implementation defined semantics.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">"null-pointer-is-valid"</span></code></dt>
+<dd>If <code class="docutils literal notranslate"><span class="pre">"null-pointer-is-valid"</span></code> is set to <code class="docutils literal notranslate"><span class="pre">"true"</span></code>, then <code class="docutils literal notranslate"><span class="pre">null</span></code> address
+in address-space 0 is considered to be a valid address for memory loads and
+stores. Any analysis or optimization should not treat dereferencing a
+pointer to <code class="docutils literal notranslate"><span class="pre">null</span></code> as undefined behavior in this function.
+Note: Comparing address of a global variable to <code class="docutils literal notranslate"><span class="pre">null</span></code> may still
+evaluate to false because of a limitation in querying this attribute inside
+constant expressions.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">optforfuzzing</span></code></dt>
+<dd>This attribute indicates that this function should be optimized
+for maximum fuzzing signal.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">optnone</span></code></dt>
+<dd><p class="first">This function attribute indicates that most optimization passes will skip
+this function, with the exception of interprocedural optimization passes.
+Code generation defaults to the âfastâ instruction selector.
+This attribute cannot be used together with the <code class="docutils literal notranslate"><span class="pre">alwaysinline</span></code>
+attribute; this attribute is also incompatible
+with the <code class="docutils literal notranslate"><span class="pre">minsize</span></code> attribute and the <code class="docutils literal notranslate"><span class="pre">optsize</span></code> attribute.</p>
+<p class="last">This attribute requires the <code class="docutils literal notranslate"><span class="pre">noinline</span></code> attribute to be specified on
+the function as well, so the function is never inlined into any caller.
+Only functions with the <code class="docutils literal notranslate"><span class="pre">alwaysinline</span></code> attribute are valid
+candidates for inlining into the body of this function.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">optsize</span></code></dt>
+<dd>This attribute suggests that optimization passes and code generator
+passes make choices that keep the code size of this function low,
+and otherwise do optimizations specifically to reduce code size as
+long as they do not significantly impact runtime performance.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">"patchable-function"</span></code></dt>
+<dd><p class="first">This attribute tells the code generator that the code
+generated for this function needs to follow certain conventions that
+make it possible for a runtime function to patch over it later.
+The exact effect of this attribute depends on its string value,
+for which there currently is one legal possibility:</p>
+<blockquote>
+<div><ul>
+<li><p class="first"><code class="docutils literal notranslate"><span class="pre">"prologue-short-redirect"</span></code> - This style of patchable
+function is intended to support patching a function prologue to
+redirect control away from the function in a thread safe
+manner. It guarantees that the first instruction of the
+function will be large enough to accommodate a short jump
+instruction, and will be sufficiently aligned to allow being
+fully changed via an atomic compare-and-swap instruction.
+While the first requirement can be satisfied by inserting large
+enough NOP, LLVM can and will try to re-purpose an existing
+instruction (i.e. one that would have to be emitted anyway) as
+the patchable instruction larger than a short jump.</p>
+<p><code class="docutils literal notranslate"><span class="pre">"prologue-short-redirect"</span></code> is currently only supported on
+x86-64.</p>
+</li>
+</ul>
+</div></blockquote>
+<p class="last">This attribute by itself does not imply restrictions on
+inter-procedural optimizations. All of the semantic effects the
+patching may have to be separately conveyed via the linkage type.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">"probe-stack"</span></code></dt>
+<dd><p class="first">This attribute indicates that the function will trigger a guard region
+in the end of the stack. It ensures that accesses to the stack must be
+no further apart than the size of the guard region to a previous
+access of the stack. It takes one required string value, the name of
+the stack probing function that will be called.</p>
+<p class="last">If a function that has a <code class="docutils literal notranslate"><span class="pre">"probe-stack"</span></code> attribute is inlined into
+a function with another <code class="docutils literal notranslate"><span class="pre">"probe-stack"</span></code> attribute, the resulting
+function has the <code class="docutils literal notranslate"><span class="pre">"probe-stack"</span></code> attribute of the caller. If a
+function that has a <code class="docutils literal notranslate"><span class="pre">"probe-stack"</span></code> attribute is inlined into a
+function that has no <code class="docutils literal notranslate"><span class="pre">"probe-stack"</span></code> attribute at all, the resulting
+function has the <code class="docutils literal notranslate"><span class="pre">"probe-stack"</span></code> attribute of the callee.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">readnone</span></code></dt>
+<dd><p class="first">On a function, this attribute indicates that the function computes its
+result (or decides to unwind an exception) based strictly on its arguments,
+without dereferencing any pointer arguments or otherwise accessing
+any mutable state (e.g. memory, control registers, etc) visible to
+caller functions. It does not write through any pointer arguments
+(including <code class="docutils literal notranslate"><span class="pre">byval</span></code> arguments) and never changes any state visible
+to callers. This means while it cannot unwind exceptions by calling
+the <code class="docutils literal notranslate"><span class="pre">C++</span></code> exception throwing methods (since they write to memory), there may
+be non-<code class="docutils literal notranslate"><span class="pre">C++</span></code> mechanisms that throw exceptions without writing to LLVM
+visible memory.</p>
+<p>On an argument, this attribute indicates that the function does not
+dereference that pointer argument, even though it may read or write the
+memory that the pointer points to if accessed through other pointers.</p>
+<p class="last">If a readnone function reads or writes memory visible to the program, or
+has other side-effects, the behavior is undefined. If a function reads from
+or writes to a readnone pointer argument, the behavior is undefined.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">readonly</span></code></dt>
+<dd><p class="first">On a function, this attribute indicates that the function does not write
+through any pointer arguments (including <code class="docutils literal notranslate"><span class="pre">byval</span></code> arguments) or otherwise
+modify any state (e.g. memory, control registers, etc) visible to
+caller functions. It may dereference pointer arguments and read
+state that may be set in the caller. A readonly function always
+returns the same value (or unwinds an exception identically) when
+called with the same set of arguments and global state. This means while it
+cannot unwind exceptions by calling the <code class="docutils literal notranslate"><span class="pre">C++</span></code> exception throwing methods
+(since they write to memory), there may be non-<code class="docutils literal notranslate"><span class="pre">C++</span></code> mechanisms that throw
+exceptions without writing to LLVM visible memory.</p>
+<p>On an argument, this attribute indicates that the function does not write
+through this pointer argument, even though it may write to the memory that
+the pointer points to.</p>
+<p class="last">If a readonly function writes memory visible to the program, or
+has other side-effects, the behavior is undefined. If a function writes to
+a readonly pointer argument, the behavior is undefined.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">"stack-probe-size"</span></code></dt>
+<dd><p class="first">This attribute controls the behavior of stack probes: either
+the <code class="docutils literal notranslate"><span class="pre">"probe-stack"</span></code> attribute, or ABI-required stack probes, if any.
+It defines the size of the guard region. It ensures that if the function
+may use more stack space than the size of the guard region, stack probing
+sequence will be emitted. It takes one required integer value, which
+is 4096 by default.</p>
+<p class="last">If a function that has a <code class="docutils literal notranslate"><span class="pre">"stack-probe-size"</span></code> attribute is inlined into
+a function with another <code class="docutils literal notranslate"><span class="pre">"stack-probe-size"</span></code> attribute, the resulting
+function has the <code class="docutils literal notranslate"><span class="pre">"stack-probe-size"</span></code> attribute that has the lower
+numeric value. If a function that has a <code class="docutils literal notranslate"><span class="pre">"stack-probe-size"</span></code> attribute is
+inlined into a function that has no <code class="docutils literal notranslate"><span class="pre">"stack-probe-size"</span></code> attribute
+at all, the resulting function has the <code class="docutils literal notranslate"><span class="pre">"stack-probe-size"</span></code> attribute
+of the callee.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">"no-stack-arg-probe"</span></code></dt>
+<dd>This attribute disables ABI-required stack probes, if any.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">writeonly</span></code></dt>
+<dd><p class="first">On a function, this attribute indicates that the function may write to but
+does not read from memory.</p>
+<p>On an argument, this attribute indicates that the function may write to but
+does not read through this pointer argument (even though it may read from
+the memory that the pointer points to).</p>
+<p class="last">If a writeonly function reads memory visible to the program, or
+has other side-effects, the behavior is undefined. If a function reads
+from a writeonly pointer argument, the behavior is undefined.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">argmemonly</span></code></dt>
+<dd><p class="first">This attribute indicates that the only memory accesses inside function are
+loads and stores from objects pointed to by its pointer-typed arguments,
+with arbitrary offsets. Or in other words, all memory operations in the
+function can refer to memory only using pointers based on its function
+arguments.</p>
+<p>Note that <code class="docutils literal notranslate"><span class="pre">argmemonly</span></code> can be used together with <code class="docutils literal notranslate"><span class="pre">readonly</span></code> attribute
+in order to specify that function reads only from its arguments.</p>
+<p class="last">If an argmemonly function reads or writes memory other than the pointer
+arguments, or has other side-effects, the behavior is undefined.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">returns_twice</span></code></dt>
+<dd>This attribute indicates that this function can return twice. The C
+<code class="docutils literal notranslate"><span class="pre">setjmp</span></code> is an example of such a function. The compiler disables
+some optimizations (like tail calls) in the caller of these
+functions.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">safestack</span></code></dt>
+<dd><p class="first">This attribute indicates that
+<a class="reference external" href="http://clang.llvm.org/docs/SafeStack.html">SafeStack</a>
+protection is enabled for this function.</p>
+<p class="last">If a function that has a <code class="docutils literal notranslate"><span class="pre">safestack</span></code> attribute is inlined into a
+function that doesnât have a <code class="docutils literal notranslate"><span class="pre">safestack</span></code> attribute or which has an
+<code class="docutils literal notranslate"><span class="pre">ssp</span></code>, <code class="docutils literal notranslate"><span class="pre">sspstrong</span></code> or <code class="docutils literal notranslate"><span class="pre">sspreq</span></code> attribute, then the resulting
+function will have a <code class="docutils literal notranslate"><span class="pre">safestack</span></code> attribute.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">sanitize_address</span></code></dt>
+<dd>This attribute indicates that AddressSanitizer checks
+(dynamic address safety analysis) are enabled for this function.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">sanitize_memory</span></code></dt>
+<dd>This attribute indicates that MemorySanitizer checks (dynamic detection
+of accesses to uninitialized memory) are enabled for this function.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">sanitize_thread</span></code></dt>
+<dd>This attribute indicates that ThreadSanitizer checks
+(dynamic thread safety analysis) are enabled for this function.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">sanitize_hwaddress</span></code></dt>
+<dd>This attribute indicates that HWAddressSanitizer checks
+(dynamic address safety analysis based on tagged pointers) are enabled for
+this function.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">speculative_load_hardening</span></code></dt>
+<dd><p class="first">This attribute indicates that
+<a class="reference external" href="https://llvm.org/docs/SpeculativeLoadHardening.html">Speculative Load Hardening</a>
+should be enabled for the function body.</p>
+<p>Speculative Load Hardening is a best-effort mitigation against
+information leak attacks that make use of control flow
+miss-speculation - specifically miss-speculation of whether a branch
+is taken or not. Typically vulnerabilities enabling such attacks are
+classified as âSpectre variant #1â. Notably, this does not attempt to
+mitigate against miss-speculation of branch target, classified as
+âSpectre variant #2â vulnerabilities.</p>
+<p class="last">When inlining, the attribute is sticky. Inlining a function that carries
+this attribute will cause the caller to gain the attribute. This is intended
+to provide a maximally conservative model where the code in a function
+annotated with this attribute will always (even after inlining) end up
+hardened.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">speculatable</span></code></dt>
+<dd>This function attribute indicates that the function does not have any
+effects besides calculating its result and does not have undefined behavior.
+Note that <code class="docutils literal notranslate"><span class="pre">speculatable</span></code> is not enough to conclude that along any
+particular execution path the number of calls to this function will not be
+externally observable. This attribute is only valid on functions
+and declarations, not on individual call sites. If a function is
+incorrectly marked as speculatable and really does exhibit
+undefined behavior, the undefined behavior may be observed even
+if the call site is dead code.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">ssp</span></code></dt>
+<dd><p class="first">This attribute indicates that the function should emit a stack
+smashing protector. It is in the form of a âcanaryâ â a random value
+placed on the stack before the local variables thatâs checked upon
+return from the function to see if it has been overwritten. A
+heuristic is used to determine if a function needs stack protectors
+or not. The heuristic used will enable protectors for functions with:</p>
+<ul class="simple">
+<li>Character arrays larger than <code class="docutils literal notranslate"><span class="pre">ssp-buffer-size</span></code> (default 8).</li>
+<li>Aggregates containing character arrays larger than <code class="docutils literal notranslate"><span class="pre">ssp-buffer-size</span></code>.</li>
+<li>Calls to alloca() with variable sizes or constant sizes greater than
+<code class="docutils literal notranslate"><span class="pre">ssp-buffer-size</span></code>.</li>
+</ul>
+<p>Variables that are identified as requiring a protector will be arranged
+on the stack such that they are adjacent to the stack protector guard.</p>
+<p class="last">If a function that has an <code class="docutils literal notranslate"><span class="pre">ssp</span></code> attribute is inlined into a
+function that doesnât have an <code class="docutils literal notranslate"><span class="pre">ssp</span></code> attribute, then the resulting
+function will have an <code class="docutils literal notranslate"><span class="pre">ssp</span></code> attribute.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">sspreq</span></code></dt>
+<dd><p class="first">This attribute indicates that the function should <em>always</em> emit a
+stack smashing protector. This overrides the <code class="docutils literal notranslate"><span class="pre">ssp</span></code> function
+attribute.</p>
+<p>Variables that are identified as requiring a protector will be arranged
+on the stack such that they are adjacent to the stack protector guard.
+The specific layout rules are:</p>
+<ol class="arabic simple">
+<li>Large arrays and structures containing large arrays
+(<code class="docutils literal notranslate"><span class="pre">>=</span> <span class="pre">ssp-buffer-size</span></code>) are closest to the stack protector.</li>
+<li>Small arrays and structures containing small arrays
+(<code class="docutils literal notranslate"><span class="pre"><</span> <span class="pre">ssp-buffer-size</span></code>) are 2nd closest to the protector.</li>
+<li>Variables that have had their address taken are 3rd closest to the
+protector.</li>
+</ol>
+<p class="last">If a function that has an <code class="docutils literal notranslate"><span class="pre">sspreq</span></code> attribute is inlined into a
+function that doesnât have an <code class="docutils literal notranslate"><span class="pre">sspreq</span></code> attribute or which has an
+<code class="docutils literal notranslate"><span class="pre">ssp</span></code> or <code class="docutils literal notranslate"><span class="pre">sspstrong</span></code> attribute, then the resulting function will have
+an <code class="docutils literal notranslate"><span class="pre">sspreq</span></code> attribute.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">sspstrong</span></code></dt>
+<dd><p class="first">This attribute indicates that the function should emit a stack smashing
+protector. This attribute causes a strong heuristic to be used when
+determining if a function needs stack protectors. The strong heuristic
+will enable protectors for functions with:</p>
+<ul class="simple">
+<li>Arrays of any size and type</li>
+<li>Aggregates containing an array of any size and type.</li>
+<li>Calls to alloca().</li>
+<li>Local variables that have had their address taken.</li>
+</ul>
+<p>Variables that are identified as requiring a protector will be arranged
+on the stack such that they are adjacent to the stack protector guard.
+The specific layout rules are:</p>
+<ol class="arabic simple">
+<li>Large arrays and structures containing large arrays
+(<code class="docutils literal notranslate"><span class="pre">>=</span> <span class="pre">ssp-buffer-size</span></code>) are closest to the stack protector.</li>
+<li>Small arrays and structures containing small arrays
+(<code class="docutils literal notranslate"><span class="pre"><</span> <span class="pre">ssp-buffer-size</span></code>) are 2nd closest to the protector.</li>
+<li>Variables that have had their address taken are 3rd closest to the
+protector.</li>
+</ol>
+<p>This overrides the <code class="docutils literal notranslate"><span class="pre">ssp</span></code> function attribute.</p>
+<p class="last">If a function that has an <code class="docutils literal notranslate"><span class="pre">sspstrong</span></code> attribute is inlined into a
+function that doesnât have an <code class="docutils literal notranslate"><span class="pre">sspstrong</span></code> attribute, then the
+resulting function will have an <code class="docutils literal notranslate"><span class="pre">sspstrong</span></code> attribute.</p>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">strictfp</span></code></dt>
+<dd>This attribute indicates that the function was called from a scope that
+requires strict floating-point semantics. LLVM will not attempt any
+optimizations that require assumptions about the floating-point rounding
+mode or that might alter the state of floating-point status flags that
+might otherwise be set or cleared by calling this function.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">"thunk"</span></code></dt>
+<dd>This attribute indicates that the function will delegate to some other
+function with a tail call. The prototype of a thunk should not be used for
+optimization purposes. The caller is expected to cast the thunk prototype to
+match the thunk target prototype.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">uwtable</span></code></dt>
+<dd>This attribute indicates that the ABI being targeted requires that
+an unwind table entry be produced for this function even if we can
+show that no exceptions passes by it. This is normally the case for
+the ELF x86-64 abi, but it can be disabled for some compilation
+units.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">nocf_check</span></code></dt>
+<dd>This attribute indicates that no control-flow check will be performed on
+the attributed entity. It disables -fcf-protection=<> for a specific
+entity to fine grain the HW control flow protection mechanism. The flag
+is target independent and currently appertains to a function or function
+pointer.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">shadowcallstack</span></code></dt>
+<dd>This attribute indicates that the ShadowCallStack checks are enabled for
+the function. The instrumentation checks that the return address for the
+function has not changed between the function prolog and eiplog. It is
+currently x86_64-specific.</dd>
+</dl>
+</div>
+<div class="section" id="global-attributes">
+<span id="glattrs"></span><h3><a class="toc-backref" href="#id974">Global Attributes</a><a class="headerlink" href="#global-attributes" title="Permalink to this headline">¶</a></h3>
+<p>Attributes may be set to communicate additional information about a global variable.
+Unlike <a class="reference internal" href="#fnattrs"><span class="std std-ref">function attributes</span></a>, attributes on a global variable
+are grouped into a single <a class="reference internal" href="#attrgrp"><span class="std std-ref">attribute group</span></a>.</p>
+</div>
+<div class="section" id="operand-bundles">
+<span id="opbundles"></span><h3><a class="toc-backref" href="#id975">Operand Bundles</a><a class="headerlink" href="#operand-bundles" title="Permalink to this headline">¶</a></h3>
+<p>Operand bundles are tagged sets of SSA values that can be associated
+with certain LLVM instructions (currently only <code class="docutils literal notranslate"><span class="pre">call</span></code> s and
+<code class="docutils literal notranslate"><span class="pre">invoke</span></code> s). In a way they are like metadata, but dropping them is
+incorrect and will change program semantics.</p>
+<p>Syntax:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">operand</span> <span class="n">bundle</span> <span class="nb">set</span> <span class="p">::</span><span class="o">=</span> <span class="s1">'['</span> <span class="n">operand</span> <span class="n">bundle</span> <span class="p">(,</span> <span class="n">operand</span> <span class="n">bundle</span> <span class="p">)</span><span class="o">*</span> <span class="s1">']'</span>
+<span class="n">operand</span> <span class="n">bundle</span> <span class="p">::</span><span class="o">=</span> <span class="n">tag</span> <span class="s1">'('</span> <span class="p">[</span> <span class="n">bundle</span> <span class="n">operand</span> <span class="p">]</span> <span class="p">(,</span> <span class="n">bundle</span> <span class="n">operand</span> <span class="p">)</span><span class="o">*</span> <span class="s1">')'</span>
+<span class="n">bundle</span> <span class="n">operand</span> <span class="p">::</span><span class="o">=</span> <span class="n">SSA</span> <span class="n">value</span>
+<span class="n">tag</span> <span class="p">::</span><span class="o">=</span> <span class="n">string</span> <span class="n">constant</span>
+</pre></div>
+</div>
+<p>Operand bundles are <strong>not</strong> part of a functionâs signature, and a
+given function may be called from multiple places with different kinds
+of operand bundles. This reflects the fact that the operand bundles
+are conceptually a part of the <code class="docutils literal notranslate"><span class="pre">call</span></code> (or <code class="docutils literal notranslate"><span class="pre">invoke</span></code>), not the
+callee being dispatched to.</p>
+<p>Operand bundles are a generic mechanism intended to support
+runtime-introspection-like functionality for managed languages. While
+the exact semantics of an operand bundle depend on the bundle tag,
+there are certain limitations to how much the presence of an operand
+bundle can influence the semantics of a program. These restrictions
+are described as the semantics of an âunknownâ operand bundle. As
+long as the behavior of an operand bundle is describable within these
+restrictions, LLVM does not need to have special knowledge of the
+operand bundle to not miscompile programs containing it.</p>
+<ul class="simple">
+<li>The bundle operands for an unknown operand bundle escape in unknown
+ways before control is transferred to the callee or invokee.</li>
+<li>Calls and invokes with operand bundles have unknown read / write
+effect on the heap on entry and exit (even if the call target is
+<code class="docutils literal notranslate"><span class="pre">readnone</span></code> or <code class="docutils literal notranslate"><span class="pre">readonly</span></code>), unless theyâre overridden with
+callsite specific attributes.</li>
+<li>An operand bundle at a call site cannot change the implementation
+of the called function. Inter-procedural optimizations work as
+usual as long as they take into account the first two properties.</li>
+</ul>
+<p>More specific types of operand bundles are described below.</p>
+<div class="section" id="deoptimization-operand-bundles">
+<span id="deopt-opbundles"></span><h4><a class="toc-backref" href="#id976">Deoptimization Operand Bundles</a><a class="headerlink" href="#deoptimization-operand-bundles" title="Permalink to this headline">¶</a></h4>
+<p>Deoptimization operand bundles are characterized by the <code class="docutils literal notranslate"><span class="pre">"deopt"</span></code>
+operand bundle tag. These operand bundles represent an alternate
+âsafeâ continuation for the call site theyâre attached to, and can be
+used by a suitable runtime to deoptimize the compiled frame at the
+specified call site. There can be at most one <code class="docutils literal notranslate"><span class="pre">"deopt"</span></code> operand
+bundle attached to a call site. Exact details of deoptimization is
+out of scope for the language reference, but it usually involves
+rewriting a compiled frame into a set of interpreted frames.</p>
+<p>From the compilerâs perspective, deoptimization operand bundles make
+the call sites theyâre attached to at least <code class="docutils literal notranslate"><span class="pre">readonly</span></code>. They read
+through all of their pointer typed operands (even if theyâre not
+otherwise escaped) and the entire visible heap. Deoptimization
+operand bundles do not capture their operands except during
+deoptimization, in which case control will not be returned to the
+compiled frame.</p>
+<p>The inliner knows how to inline through calls that have deoptimization
+operand bundles. Just like inlining through a normal call site
+involves composing the normal and exceptional continuations, inlining
+through a call site with a deoptimization operand bundle needs to
+appropriately compose the âsafeâ deoptimization continuation. The
+inliner does this by prepending the parentâs deoptimization
+continuation to every deoptimization continuation in the inlined body.
+E.g. inlining <code class="docutils literal notranslate"><span class="pre">@f</span></code> into <code class="docutils literal notranslate"><span class="pre">@g</span></code> in the following example</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">define</span> <span class="kt">void</span> <span class="vg">@f</span><span class="p">()</span> <span class="p">{</span>
+ <span class="k">call</span> <span class="kt">void</span> <span class="vg">@x</span><span class="p">()</span> <span class="c">;; no deopt state</span>
+ <span class="k">call</span> <span class="kt">void</span> <span class="vg">@y</span><span class="p">()</span> <span class="p">[</span> <span class="s">"deopt"</span><span class="p">(</span><span class="k">i32</span> <span class="m">10</span><span class="p">)</span> <span class="p">]</span>
+ <span class="k">call</span> <span class="kt">void</span> <span class="vg">@y</span><span class="p">()</span> <span class="p">[</span> <span class="s">"deopt"</span><span class="p">(</span><span class="k">i32</span> <span class="m">10</span><span class="p">),</span> <span class="s">"unknown"</span><span class="p">(</span><span class="k">i8</span><span class="p">*</span> <span class="k">null</span><span class="p">)</span> <span class="p">]</span>
+ <span class="k">ret</span> <span class="kt">void</span>
+<span class="p">}</span>
+
+<span class="k">define</span> <span class="kt">void</span> <span class="vg">@g</span><span class="p">()</span> <span class="p">{</span>
+ <span class="k">call</span> <span class="kt">void</span> <span class="vg">@f</span><span class="p">()</span> <span class="p">[</span> <span class="s">"deopt"</span><span class="p">(</span><span class="k">i32</span> <span class="m">20</span><span class="p">)</span> <span class="p">]</span>
+ <span class="k">ret</span> <span class="kt">void</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+<p>will result in</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">define</span> <span class="kt">void</span> <span class="vg">@g</span><span class="p">()</span> <span class="p">{</span>
+ <span class="k">call</span> <span class="kt">void</span> <span class="vg">@x</span><span class="p">()</span> <span class="c">;; still no deopt state</span>
+ <span class="k">call</span> <span class="kt">void</span> <span class="vg">@y</span><span class="p">()</span> <span class="p">[</span> <span class="s">"deopt"</span><span class="p">(</span><span class="k">i32</span> <span class="m">20</span><span class="p">,</span> <span class="k">i32</span> <span class="m">10</span><span class="p">)</span> <span class="p">]</span>
+ <span class="k">call</span> <span class="kt">void</span> <span class="vg">@y</span><span class="p">()</span> <span class="p">[</span> <span class="s">"deopt"</span><span class="p">(</span><span class="k">i32</span> <span class="m">20</span><span class="p">,</span> <span class="k">i32</span> <span class="m">10</span><span class="p">),</span> <span class="s">"unknown"</span><span class="p">(</span><span class="k">i8</span><span class="p">*</span> <span class="k">null</span><span class="p">)</span> <span class="p">]</span>
+ <span class="k">ret</span> <span class="kt">void</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+<p>It is the frontendâs responsibility to structure or encode the
+deoptimization state in a way that syntactically prepending the
+callerâs deoptimization state to the calleeâs deoptimization state is
+semantically equivalent to composing the callerâs deoptimization
+continuation after the calleeâs deoptimization continuation.</p>
+</div>
+<div class="section" id="funclet-operand-bundles">
+<span id="ob-funclet"></span><h4><a class="toc-backref" href="#id977">Funclet Operand Bundles</a><a class="headerlink" href="#funclet-operand-bundles" title="Permalink to this headline">¶</a></h4>
+<p>Funclet operand bundles are characterized by the <code class="docutils literal notranslate"><span class="pre">"funclet"</span></code>
+operand bundle tag. These operand bundles indicate that a call site
+is within a particular funclet. There can be at most one
+<code class="docutils literal notranslate"><span class="pre">"funclet"</span></code> operand bundle attached to a call site and it must have
+exactly one bundle operand.</p>
+<p>If any funclet EH pads have been âenteredâ but not âexitedâ (per the
+<a class="reference external" href="ExceptionHandling.html#wineh-constraints">description in the EH doc</a>),
+it is undefined behavior to execute a <code class="docutils literal notranslate"><span class="pre">call</span></code> or <code class="docutils literal notranslate"><span class="pre">invoke</span></code> which:</p>
+<ul class="simple">
+<li>does not have a <code class="docutils literal notranslate"><span class="pre">"funclet"</span></code> bundle and is not a <code class="docutils literal notranslate"><span class="pre">call</span></code> to a nounwind
+intrinsic, or</li>
+<li>has a <code class="docutils literal notranslate"><span class="pre">"funclet"</span></code> bundle whose operand is not the most-recently-entered
+not-yet-exited funclet EH pad.</li>
+</ul>
+<p>Similarly, if no funclet EH pads have been entered-but-not-yet-exited,
+executing a <code class="docutils literal notranslate"><span class="pre">call</span></code> or <code class="docutils literal notranslate"><span class="pre">invoke</span></code> with a <code class="docutils literal notranslate"><span class="pre">"funclet"</span></code> bundle is undefined behavior.</p>
+</div>
+<div class="section" id="gc-transition-operand-bundles">
+<h4><a class="toc-backref" href="#id978">GC Transition Operand Bundles</a><a class="headerlink" href="#gc-transition-operand-bundles" title="Permalink to this headline">¶</a></h4>
+<p>GC transition operand bundles are characterized by the
+<code class="docutils literal notranslate"><span class="pre">"gc-transition"</span></code> operand bundle tag. These operand bundles mark a
+call as a transition between a function with one GC strategy to a
+function with a different GC strategy. If coordinating the transition
+between GC strategies requires additional code generation at the call
+site, these bundles may contain any values that are needed by the
+generated code. For more details, see <a class="reference internal" href="Statepoints.html#gc-transition-args"><span class="std std-ref">GC Transitions</span></a>.</p>
+</div>
+</div>
+<div class="section" id="module-level-inline-assembly">
+<span id="moduleasm"></span><h3><a class="toc-backref" href="#id979">Module-Level Inline Assembly</a><a class="headerlink" href="#module-level-inline-assembly" title="Permalink to this headline">¶</a></h3>
+<p>Modules may contain âmodule-level inline asmâ blocks, which corresponds
+to the GCC âfile scope inline asmâ blocks. These blocks are internally
+concatenated by LLVM and treated as a single unit, but may be separated
+in the <code class="docutils literal notranslate"><span class="pre">.ll</span></code> file if desired. The syntax is very simple:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">module</span> <span class="k">asm</span> <span class="s">"inline asm code goes here"</span>
+<span class="k">module</span> <span class="k">asm</span> <span class="s">"more can go here"</span>
+</pre></div>
+</div>
+<p>The strings can contain any character by escaping non-printable
+characters. The escape sequence used is simply â\xxâ where âxxâ is the
+two digit hex code for the number.</p>
+<p>Note that the assembly string <em>must</em> be parseable by LLVMâs integrated assembler
+(unless it is disabled), even when emitting a <code class="docutils literal notranslate"><span class="pre">.s</span></code> file.</p>
+</div>
+<div class="section" id="data-layout">
+<span id="langref-datalayout"></span><h3><a class="toc-backref" href="#id980">Data Layout</a><a class="headerlink" href="#data-layout" title="Permalink to this headline">¶</a></h3>
+<p>A module may specify a target specific data layout string that specifies
+how data is to be laid out in memory. The syntax for the data layout is
+simply:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">target</span> <span class="k">datalayout</span> <span class="p">=</span> <span class="s">"layout specification"</span>
+</pre></div>
+</div>
+<p>The <em>layout specification</em> consists of a list of specifications
+separated by the minus sign character (â-â). Each specification starts
+with a letter and may include other information after the letter to
+define some aspect of the data layout. The specifications accepted are
+as follows:</p>
+<dl class="docutils">
+<dt><code class="docutils literal notranslate"><span class="pre">E</span></code></dt>
+<dd>Specifies that the target lays out data in big-endian form. That is,
+the bits with the most significance have the lowest address
+location.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">e</span></code></dt>
+<dd>Specifies that the target lays out data in little-endian form. That
+is, the bits with the least significance have the lowest address
+location.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">S<size></span></code></dt>
+<dd>Specifies the natural alignment of the stack in bits. Alignment
+promotion of stack variables is limited to the natural stack
+alignment to avoid dynamic stack realignment. The stack alignment
+must be a multiple of 8-bits. If omitted, the natural stack
+alignment defaults to âunspecifiedâ, which does not prevent any
+alignment promotions.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">P<address</span> <span class="pre">space></span></code></dt>
+<dd>Specifies the address space that corresponds to program memory.
+Harvard architectures can use this to specify what space LLVM
+should place things such as functions into. If omitted, the
+program memory space defaults to the default address space of 0,
+which corresponds to a Von Neumann architecture that has code
+and data in the same space.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">A<address</span> <span class="pre">space></span></code></dt>
+<dd>Specifies the address space of objects created by â<code class="docutils literal notranslate"><span class="pre">alloca</span></code>â.
+Defaults to the default address space of 0.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">p[n]:<size>:<abi>:<pref>:<idx></span></code></dt>
+<dd>This specifies the <em>size</em> of a pointer and its <code class="docutils literal notranslate"><span class="pre"><abi></span></code> and
+<code class="docutils literal notranslate"><span class="pre"><pref></span></code>erred alignments for address space <code class="docutils literal notranslate"><span class="pre">n</span></code>. The fourth parameter
+<code class="docutils literal notranslate"><span class="pre"><idx></span></code> is a size of index that used for address calculation. If not
+specified, the default index size is equal to the pointer size. All sizes
+are in bits. The address space, <code class="docutils literal notranslate"><span class="pre">n</span></code>, is optional, and if not specified,
+denotes the default address space 0. The value of <code class="docutils literal notranslate"><span class="pre">n</span></code> must be
+in the range [1,2^23).</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">i<size>:<abi>:<pref></span></code></dt>
+<dd>This specifies the alignment for an integer type of a given bit
+<code class="docutils literal notranslate"><span class="pre"><size></span></code>. The value of <code class="docutils literal notranslate"><span class="pre"><size></span></code> must be in the range [1,2^23).</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">v<size>:<abi>:<pref></span></code></dt>
+<dd>This specifies the alignment for a vector type of a given bit
+<code class="docutils literal notranslate"><span class="pre"><size></span></code>.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">f<size>:<abi>:<pref></span></code></dt>
+<dd>This specifies the alignment for a floating-point type of a given bit
+<code class="docutils literal notranslate"><span class="pre"><size></span></code>. Only values of <code class="docutils literal notranslate"><span class="pre"><size></span></code> that are supported by the target
+will work. 32 (float) and 64 (double) are supported on all targets; 80
+or 128 (different flavors of long double) are also supported on some
+targets.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">a:<abi>:<pref></span></code></dt>
+<dd>This specifies the alignment for an object of aggregate type.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">m:<mangling></span></code></dt>
+<dd><p class="first">If present, specifies that llvm names are mangled in the output. Symbols
+prefixed with the mangling escape character <code class="docutils literal notranslate"><span class="pre">\01</span></code> are passed through
+directly to the assembler without the escape character. The mangling style
+options are</p>
+<ul class="last simple">
+<li><code class="docutils literal notranslate"><span class="pre">e</span></code>: ELF mangling: Private symbols get a <code class="docutils literal notranslate"><span class="pre">.L</span></code> prefix.</li>
+<li><code class="docutils literal notranslate"><span class="pre">m</span></code>: Mips mangling: Private symbols get a <code class="docutils literal notranslate"><span class="pre">$</span></code> prefix.</li>
+<li><code class="docutils literal notranslate"><span class="pre">o</span></code>: Mach-O mangling: Private symbols get <code class="docutils literal notranslate"><span class="pre">L</span></code> prefix. Other
+symbols get a <code class="docutils literal notranslate"><span class="pre">_</span></code> prefix.</li>
+<li><code class="docutils literal notranslate"><span class="pre">x</span></code>: Windows x86 COFF mangling: Private symbols get the usual prefix.
+Regular C symbols get a <code class="docutils literal notranslate"><span class="pre">_</span></code> prefix. Functions with <code class="docutils literal notranslate"><span class="pre">__stdcall</span></code>,
+<code class="docutils literal notranslate"><span class="pre">__fastcall</span></code>, and <code class="docutils literal notranslate"><span class="pre">__vectorcall</span></code> have custom mangling that appends
+<code class="docutils literal notranslate"><span class="pre">@N</span></code> where N is the number of bytes used to pass parameters. C++ symbols
+starting with <code class="docutils literal notranslate"><span class="pre">?</span></code> are not mangled in any way.</li>
+<li><code class="docutils literal notranslate"><span class="pre">w</span></code>: Windows COFF mangling: Similar to <code class="docutils literal notranslate"><span class="pre">x</span></code>, except that normal C
+symbols do not receive a <code class="docutils literal notranslate"><span class="pre">_</span></code> prefix.</li>
+</ul>
+</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">n<size1>:<size2>:<size3>...</span></code></dt>
+<dd>This specifies a set of native integer widths for the target CPU in
+bits. For example, it might contain <code class="docutils literal notranslate"><span class="pre">n32</span></code> for 32-bit PowerPC,
+<code class="docutils literal notranslate"><span class="pre">n32:64</span></code> for PowerPC 64, or <code class="docutils literal notranslate"><span class="pre">n8:16:32:64</span></code> for X86-64. Elements of
+this set are considered to support most general arithmetic operations
+efficiently.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">ni:<address</span> <span class="pre">space0>:<address</span> <span class="pre">space1>:<address</span> <span class="pre">space2>...</span></code></dt>
+<dd>This specifies pointer types with the specified address spaces
+as <a class="reference internal" href="#nointptrtype"><span class="std std-ref">Non-Integral Pointer Type</span></a> s. The <code class="docutils literal notranslate"><span class="pre">0</span></code>
+address space cannot be specified as non-integral.</dd>
+</dl>
+<p>On every specification that takes a <code class="docutils literal notranslate"><span class="pre"><abi>:<pref></span></code>, specifying the
+<code class="docutils literal notranslate"><span class="pre"><pref></span></code> alignment is optional. If omitted, the preceding <code class="docutils literal notranslate"><span class="pre">:</span></code>
+should be omitted too and <code class="docutils literal notranslate"><span class="pre"><pref></span></code> will be equal to <code class="docutils literal notranslate"><span class="pre"><abi></span></code>.</p>
+<p>When constructing the data layout for a given target, LLVM starts with a
+default set of specifications which are then (possibly) overridden by
+the specifications in the <code class="docutils literal notranslate"><span class="pre">datalayout</span></code> keyword. The default
+specifications are given in this list:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">E</span></code> - big endian</li>
+<li><code class="docutils literal notranslate"><span class="pre">p:64:64:64</span></code> - 64-bit pointers with 64-bit alignment.</li>
+<li><code class="docutils literal notranslate"><span class="pre">p[n]:64:64:64</span></code> - Other address spaces are assumed to be the
+same as the default address space.</li>
+<li><code class="docutils literal notranslate"><span class="pre">S0</span></code> - natural stack alignment is unspecified</li>
+<li><code class="docutils literal notranslate"><span class="pre">i1:8:8</span></code> - i1 is 8-bit (byte) aligned</li>
+<li><code class="docutils literal notranslate"><span class="pre">i8:8:8</span></code> - i8 is 8-bit (byte) aligned</li>
+<li><code class="docutils literal notranslate"><span class="pre">i16:16:16</span></code> - i16 is 16-bit aligned</li>
+<li><code class="docutils literal notranslate"><span class="pre">i32:32:32</span></code> - i32 is 32-bit aligned</li>
+<li><code class="docutils literal notranslate"><span class="pre">i64:32:64</span></code> - i64 has ABI alignment of 32-bits but preferred
+alignment of 64-bits</li>
+<li><code class="docutils literal notranslate"><span class="pre">f16:16:16</span></code> - half is 16-bit aligned</li>
+<li><code class="docutils literal notranslate"><span class="pre">f32:32:32</span></code> - float is 32-bit aligned</li>
+<li><code class="docutils literal notranslate"><span class="pre">f64:64:64</span></code> - double is 64-bit aligned</li>
+<li><code class="docutils literal notranslate"><span class="pre">f128:128:128</span></code> - quad is 128-bit aligned</li>
+<li><code class="docutils literal notranslate"><span class="pre">v64:64:64</span></code> - 64-bit vector is 64-bit aligned</li>
+<li><code class="docutils literal notranslate"><span class="pre">v128:128:128</span></code> - 128-bit vector is 128-bit aligned</li>
+<li><code class="docutils literal notranslate"><span class="pre">a:0:64</span></code> - aggregates are 64-bit aligned</li>
+</ul>
+<p>When LLVM is determining the alignment for a given type, it uses the
+following rules:</p>
+<ol class="arabic simple">
+<li>If the type sought is an exact match for one of the specifications,
+that specification is used.</li>
+<li>If no match is found, and the type sought is an integer type, then
+the smallest integer type that is larger than the bitwidth of the
+sought type is used. If none of the specifications are larger than
+the bitwidth then the largest integer type is used. For example,
+given the default specifications above, the i7 type will use the
+alignment of i8 (next largest) while both i65 and i256 will use the
+alignment of i64 (largest specified).</li>
+<li>If no match is found, and the type sought is a vector type, then the
+largest vector type that is smaller than the sought vector type will
+be used as a fall back. This happens because <128 x double> can be
+implemented in terms of 64 <2 x double>, for example.</li>
+</ol>
+<p>The function of the data layout string may not be what you expect.
+Notably, this is not a specification from the frontend of what alignment
+the code generator should use.</p>
+<p>Instead, if specified, the target data layout is required to match what
+the ultimate <em>code generator</em> expects. This string is used by the
+mid-level optimizers to improve code, and this only works if it matches
+what the ultimate code generator uses. There is no way to generate IR
+that does not embed this target-specific detail into the IR. If you
+donât specify the string, the default specifications will be used to
+generate a Data Layout and the optimization phases will operate
+accordingly and introduce target specificity into the IR with respect to
+these default specifications.</p>
+</div>
+<div class="section" id="target-triple">
+<span id="langref-triple"></span><h3><a class="toc-backref" href="#id981">Target Triple</a><a class="headerlink" href="#target-triple" title="Permalink to this headline">¶</a></h3>
+<p>A module may specify a target triple string that describes the target
+host. The syntax for the target triple is simply:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">target</span> <span class="k">triple</span> <span class="p">=</span> <span class="s">"x86_64-apple-macosx10.7.0"</span>
+</pre></div>
+</div>
+<p>The <em>target triple</em> string consists of a series of identifiers delimited
+by the minus sign character (â-â). The canonical forms are:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">ARCHITECTURE</span><span class="o">-</span><span class="n">VENDOR</span><span class="o">-</span><span class="n">OPERATING_SYSTEM</span>
+<span class="n">ARCHITECTURE</span><span class="o">-</span><span class="n">VENDOR</span><span class="o">-</span><span class="n">OPERATING_SYSTEM</span><span class="o">-</span><span class="n">ENVIRONMENT</span>
+</pre></div>
+</div>
+<p>This information is passed along to the backend so that it generates
+code for the proper architecture. Itâs possible to override this on the
+command line with the <code class="docutils literal notranslate"><span class="pre">-mtriple</span></code> command line option.</p>
+</div>
+<div class="section" id="pointer-aliasing-rules">
+<span id="pointeraliasing"></span><h3><a class="toc-backref" href="#id982">Pointer Aliasing Rules</a><a class="headerlink" href="#pointer-aliasing-rules" title="Permalink to this headline">¶</a></h3>
+<p>Any memory access must be done through a pointer value associated with
+an address range of the memory access, otherwise the behavior is
+undefined. Pointer values are associated with address ranges according
+to the following rules:</p>
+<ul class="simple">
+<li>A pointer value is associated with the addresses associated with any
+value it is <em>based</em> on.</li>
+<li>An address of a global variable is associated with the address range
+of the variableâs storage.</li>
+<li>The result value of an allocation instruction is associated with the
+address range of the allocated storage.</li>
+<li>A null pointer in the default address-space is associated with no
+address.</li>
+<li>An integer constant other than zero or a pointer value returned from
+a function not defined within LLVM may be associated with address
+ranges allocated through mechanisms other than those provided by
+LLVM. Such ranges shall not overlap with any ranges of addresses
+allocated by mechanisms provided by LLVM.</li>
+</ul>
+<p>A pointer value is <em>based</em> on another pointer value according to the
+following rules:</p>
+<ul class="simple">
+<li>A pointer value formed from a scalar <code class="docutils literal notranslate"><span class="pre">getelementptr</span></code> operation is <em>based</em> on
+the pointer-typed operand of the <code class="docutils literal notranslate"><span class="pre">getelementptr</span></code>.</li>
+<li>The pointer in lane <em>l</em> of the result of a vector <code class="docutils literal notranslate"><span class="pre">getelementptr</span></code> operation
+is <em>based</em> on the pointer in lane <em>l</em> of the vector-of-pointers-typed operand
+of the <code class="docutils literal notranslate"><span class="pre">getelementptr</span></code>.</li>
+<li>The result value of a <code class="docutils literal notranslate"><span class="pre">bitcast</span></code> is <em>based</em> on the operand of the
+<code class="docutils literal notranslate"><span class="pre">bitcast</span></code>.</li>
+<li>A pointer value formed by an <code class="docutils literal notranslate"><span class="pre">inttoptr</span></code> is <em>based</em> on all pointer
+values that contribute (directly or indirectly) to the computation of
+the pointerâs value.</li>
+<li>The â<em>based</em> onâ relationship is transitive.</li>
+</ul>
+<p>Note that this definition of <em>âbasedâ</em> is intentionally similar to the
+definition of <em>âbasedâ</em> in C99, though it is slightly weaker.</p>
+<p>LLVM IR does not associate types with memory. The result type of a
+<code class="docutils literal notranslate"><span class="pre">load</span></code> merely indicates the size and alignment of the memory from
+which to load, as well as the interpretation of the value. The first
+operand type of a <code class="docutils literal notranslate"><span class="pre">store</span></code> similarly only indicates the size and
+alignment of the store.</p>
+<p>Consequently, type-based alias analysis, aka TBAA, aka
+<code class="docutils literal notranslate"><span class="pre">-fstrict-aliasing</span></code>, is not applicable to general unadorned LLVM IR.
+<a class="reference internal" href="#metadata"><span class="std std-ref">Metadata</span></a> may be used to encode additional information
+which specialized optimization passes may use to implement type-based
+alias analysis.</p>
+</div>
+<div class="section" id="volatile-memory-accesses">
+<span id="volatile"></span><h3><a class="toc-backref" href="#id983">Volatile Memory Accesses</a><a class="headerlink" href="#volatile-memory-accesses" title="Permalink to this headline">¶</a></h3>
+<p>Certain memory accesses, such as <a class="reference internal" href="#i-load"><span class="std std-ref">load</span></a>âs,
+<a class="reference internal" href="#i-store"><span class="std std-ref">store</span></a>âs, and <a class="reference internal" href="#int-memcpy"><span class="std std-ref">llvm.memcpy</span></a>âs may be
+marked <code class="docutils literal notranslate"><span class="pre">volatile</span></code>. The optimizers must not change the number of
+volatile operations or change their order of execution relative to other
+volatile operations. The optimizers <em>may</em> change the order of volatile
+operations relative to non-volatile operations. This is not Javaâs
+âvolatileâ and has no cross-thread synchronization behavior.</p>
+<p>IR-level volatile loads and stores cannot safely be optimized into
+llvm.memcpy or llvm.memmove intrinsics even when those intrinsics are
+flagged volatile. Likewise, the backend should never split or merge
+target-legal volatile load/store instructions.</p>
+<div class="admonition-rationale admonition">
+<p class="first admonition-title">Rationale</p>
+<p class="last">Platforms may rely on volatile loads and stores of natively supported
+data width to be executed as single instruction. For example, in C
+this holds for an l-value of volatile primitive type with native
+hardware support, but not necessarily for aggregate types. The
+frontend upholds these expectations, which are intentionally
+unspecified in the IR. The rules above ensure that IR transformations
+do not violate the frontendâs contract with the language.</p>
+</div>
+</div>
+<div class="section" id="memory-model-for-concurrent-operations">
+<span id="memmodel"></span><h3><a class="toc-backref" href="#id984">Memory Model for Concurrent Operations</a><a class="headerlink" href="#memory-model-for-concurrent-operations" title="Permalink to this headline">¶</a></h3>
+<p>The LLVM IR does not define any way to start parallel threads of
+execution or to register signal handlers. Nonetheless, there are
+platform-specific ways to create them, and we define LLVM IRâs behavior
+in their presence. This model is inspired by the C++0x memory model.</p>
+<p>For a more informal introduction to this model, see the <a class="reference internal" href="Atomics.html"><span class="doc">LLVM Atomic Instructions and Concurrency Guide</span></a>.</p>
+<p>We define a <em>happens-before</em> partial order as the least partial order
+that</p>
+<ul class="simple">
+<li>Is a superset of single-thread program order, and</li>
+<li>When a <em>synchronizes-with</em> <code class="docutils literal notranslate"><span class="pre">b</span></code>, includes an edge from <code class="docutils literal notranslate"><span class="pre">a</span></code> to
+<code class="docutils literal notranslate"><span class="pre">b</span></code>. <em>Synchronizes-with</em> pairs are introduced by platform-specific
+techniques, like pthread locks, thread creation, thread joining,
+etc., and by atomic instructions. (See also <a class="reference internal" href="#ordering"><span class="std std-ref">Atomic Memory Ordering
+Constraints</span></a>).</li>
+</ul>
+<p>Note that program order does not introduce <em>happens-before</em> edges
+between a thread and signals executing inside that thread.</p>
+<p>Every (defined) read operation (load instructions, memcpy, atomic
+loads/read-modify-writes, etc.) R reads a series of bytes written by
+(defined) write operations (store instructions, atomic
+stores/read-modify-writes, memcpy, etc.). For the purposes of this
+section, initialized globals are considered to have a write of the
+initializer which is atomic and happens before any other read or write
+of the memory in question. For each byte of a read R, R<sub>byte</sub>
+may see any write to the same byte, except:</p>
+<ul class="simple">
+<li>If write<sub>1</sub> happens before write<sub>2</sub>, and
+write<sub>2</sub> happens before R<sub>byte</sub>, then
+R<sub>byte</sub> does not see write<sub>1</sub>.</li>
+<li>If R<sub>byte</sub> happens before write<sub>3</sub>, then
+R<sub>byte</sub> does not see write<sub>3</sub>.</li>
+</ul>
+<p>Given that definition, R<sub>byte</sub> is defined as follows:</p>
+<ul class="simple">
+<li>If R is volatile, the result is target-dependent. (Volatile is
+supposed to give guarantees which can support <code class="docutils literal notranslate"><span class="pre">sig_atomic_t</span></code> in
+C/C++, and may be used for accesses to addresses that do not behave
+like normal memory. It does not generally provide cross-thread
+synchronization.)</li>
+<li>Otherwise, if there is no write to the same byte that happens before
+R<sub>byte</sub>, R<sub>byte</sub> returns <code class="docutils literal notranslate"><span class="pre">undef</span></code> for that byte.</li>
+<li>Otherwise, if R<sub>byte</sub> may see exactly one write,
+R<sub>byte</sub> returns the value written by that write.</li>
+<li>Otherwise, if R is atomic, and all the writes R<sub>byte</sub> may
+see are atomic, it chooses one of the values written. See the <a class="reference internal" href="#ordering"><span class="std std-ref">Atomic
+Memory Ordering Constraints</span></a> section for additional
+constraints on how the choice is made.</li>
+<li>Otherwise R<sub>byte</sub> returns <code class="docutils literal notranslate"><span class="pre">undef</span></code>.</li>
+</ul>
+<p>R returns the value composed of the series of bytes it read. This
+implies that some bytes within the value may be <code class="docutils literal notranslate"><span class="pre">undef</span></code> <strong>without</strong>
+the entire value being <code class="docutils literal notranslate"><span class="pre">undef</span></code>. Note that this only defines the
+semantics of the operation; it doesnât mean that targets will emit more
+than one instruction to read the series of bytes.</p>
+<p>Note that in cases where none of the atomic intrinsics are used, this
+model places only one restriction on IR transformations on top of what
+is required for single-threaded execution: introducing a store to a byte
+which might not otherwise be stored is not allowed in general.
+(Specifically, in the case where another thread might write to and read
+from an address, introducing a store can change a load that may see
+exactly one write into a load that may see multiple writes.)</p>
+</div>
+<div class="section" id="atomic-memory-ordering-constraints">
+<span id="ordering"></span><h3><a class="toc-backref" href="#id985">Atomic Memory Ordering Constraints</a><a class="headerlink" href="#atomic-memory-ordering-constraints" title="Permalink to this headline">¶</a></h3>
+<p>Atomic instructions (<a class="reference internal" href="#i-cmpxchg"><span class="std std-ref">cmpxchg</span></a>,
+<a class="reference internal" href="#i-atomicrmw"><span class="std std-ref">atomicrmw</span></a>, <a class="reference internal" href="#i-fence"><span class="std std-ref">fence</span></a>,
+<a class="reference internal" href="#i-load"><span class="std std-ref">atomic load</span></a>, and <a class="reference internal" href="#i-store"><span class="std std-ref">atomic store</span></a>) take
+ordering parameters that determine which other atomic instructions on
+the same address they <em>synchronize with</em>. These semantics are borrowed
+from Java and C++0x, but are somewhat more colloquial. If these
+descriptions arenât precise enough, check those specs (see spec
+references in the <a class="reference internal" href="Atomics.html"><span class="doc">atomics guide</span></a>).
+<a class="reference internal" href="#i-fence"><span class="std std-ref">fence</span></a> instructions treat these orderings somewhat
+differently since they donât take an address. See that instructionâs
+documentation for details.</p>
+<p>For a simpler introduction to the ordering constraints, see the
+<a class="reference internal" href="Atomics.html"><span class="doc">LLVM Atomic Instructions and Concurrency Guide</span></a>.</p>
+<dl class="docutils">
+<dt><code class="docutils literal notranslate"><span class="pre">unordered</span></code></dt>
+<dd>The set of values that can be read is governed by the happens-before
+partial order. A value cannot be read unless some operation wrote
+it. This is intended to provide a guarantee strong enough to model
+Javaâs non-volatile shared variables. This ordering cannot be
+specified for read-modify-write operations; it is not strong enough
+to make them atomic in any interesting way.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">monotonic</span></code></dt>
+<dd>In addition to the guarantees of <code class="docutils literal notranslate"><span class="pre">unordered</span></code>, there is a single
+total order for modifications by <code class="docutils literal notranslate"><span class="pre">monotonic</span></code> operations on each
+address. All modification orders must be compatible with the
+happens-before order. There is no guarantee that the modification
+orders can be combined to a global total order for the whole program
+(and this often will not be possible). The read in an atomic
+read-modify-write operation (<a class="reference internal" href="#i-cmpxchg"><span class="std std-ref">cmpxchg</span></a> and
+<a class="reference internal" href="#i-atomicrmw"><span class="std std-ref">atomicrmw</span></a>) reads the value in the modification
+order immediately before the value it writes. If one atomic read
+happens before another atomic read of the same address, the later
+read must see the same value or a later value in the addressâs
+modification order. This disallows reordering of <code class="docutils literal notranslate"><span class="pre">monotonic</span></code> (or
+stronger) operations on the same address. If an address is written
+<code class="docutils literal notranslate"><span class="pre">monotonic</span></code>-ally by one thread, and other threads <code class="docutils literal notranslate"><span class="pre">monotonic</span></code>-ally
+read that address repeatedly, the other threads must eventually see
+the write. This corresponds to the C++0x/C1x
+<code class="docutils literal notranslate"><span class="pre">memory_order_relaxed</span></code>.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">acquire</span></code></dt>
+<dd>In addition to the guarantees of <code class="docutils literal notranslate"><span class="pre">monotonic</span></code>, a
+<em>synchronizes-with</em> edge may be formed with a <code class="docutils literal notranslate"><span class="pre">release</span></code> operation.
+This is intended to model C++âs <code class="docutils literal notranslate"><span class="pre">memory_order_acquire</span></code>.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">release</span></code></dt>
+<dd>In addition to the guarantees of <code class="docutils literal notranslate"><span class="pre">monotonic</span></code>, if this operation
+writes a value which is subsequently read by an <code class="docutils literal notranslate"><span class="pre">acquire</span></code>
+operation, it <em>synchronizes-with</em> that operation. (This isnât a
+complete description; see the C++0x definition of a release
+sequence.) This corresponds to the C++0x/C1x
+<code class="docutils literal notranslate"><span class="pre">memory_order_release</span></code>.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">acq_rel</span></code> (acquire+release)</dt>
+<dd>Acts as both an <code class="docutils literal notranslate"><span class="pre">acquire</span></code> and <code class="docutils literal notranslate"><span class="pre">release</span></code> operation on its
+address. This corresponds to the C++0x/C1x <code class="docutils literal notranslate"><span class="pre">memory_order_acq_rel</span></code>.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">seq_cst</span></code> (sequentially consistent)</dt>
+<dd>In addition to the guarantees of <code class="docutils literal notranslate"><span class="pre">acq_rel</span></code> (<code class="docutils literal notranslate"><span class="pre">acquire</span></code> for an
+operation that only reads, <code class="docutils literal notranslate"><span class="pre">release</span></code> for an operation that only
+writes), there is a global total order on all
+sequentially-consistent operations on all addresses, which is
+consistent with the <em>happens-before</em> partial order and with the
+modification orders of all the affected addresses. Each
+sequentially-consistent read sees the last preceding write to the
+same address in this global order. This corresponds to the C++0x/C1x
+<code class="docutils literal notranslate"><span class="pre">memory_order_seq_cst</span></code> and Java volatile.</dd>
+</dl>
+<p id="syncscope">If an atomic operation is marked <code class="docutils literal notranslate"><span class="pre">syncscope("singlethread")</span></code>, it only
+<em>synchronizes with</em> and only participates in the seq_cst total orderings of
+other operations running in the same thread (for example, in signal handlers).</p>
+<p>If an atomic operation is marked <code class="docutils literal notranslate"><span class="pre">syncscope("<target-scope>")</span></code>, where
+<code class="docutils literal notranslate"><span class="pre"><target-scope></span></code> is a target specific synchronization scope, then it is target
+dependent if it <em>synchronizes with</em> and participates in the seq_cst total
+orderings of other operations.</p>
+<p>Otherwise, an atomic operation that is not marked <code class="docutils literal notranslate"><span class="pre">syncscope("singlethread")</span></code>
+or <code class="docutils literal notranslate"><span class="pre">syncscope("<target-scope>")</span></code> <em>synchronizes with</em> and participates in the
+seq_cst total orderings of other operations that are not marked
+<code class="docutils literal notranslate"><span class="pre">syncscope("singlethread")</span></code> or <code class="docutils literal notranslate"><span class="pre">syncscope("<target-scope>")</span></code>.</p>
+</div>
+<div class="section" id="floating-point-environment">
+<span id="floatenv"></span><h3><a class="toc-backref" href="#id986">Floating-Point Environment</a><a class="headerlink" href="#floating-point-environment" title="Permalink to this headline">¶</a></h3>
+<p>The default LLVM floating-point environment assumes that floating-point
+instructions do not have side effects. Results assume the round-to-nearest
+rounding mode. No floating-point exception state is maintained in this
+environment. Therefore, there is no attempt to create or preserve invalid
+operation (SNaN) or division-by-zero exceptions.</p>
+<p>The benefit of this exception-free assumption is that floating-point
+operations may be speculated freely without any other fast-math relaxations
+to the floating-point model.</p>
+<p>Code that requires different behavior than this should use the
+<a class="reference internal" href="#constrainedfp"><span class="std std-ref">Constrained Floating-Point Intrinsics</span></a>.</p>
+</div>
+<div class="section" id="fast-math-flags">
+<span id="fastmath"></span><h3><a class="toc-backref" href="#id987">Fast-Math Flags</a><a class="headerlink" href="#fast-math-flags" title="Permalink to this headline">¶</a></h3>
+<p>LLVM IR floating-point operations (<a class="reference internal" href="#i-fadd"><span class="std std-ref">fadd</span></a>,
+<a class="reference internal" href="#i-fsub"><span class="std std-ref">fsub</span></a>, <a class="reference internal" href="#i-fmul"><span class="std std-ref">fmul</span></a>, <a class="reference internal" href="#i-fdiv"><span class="std std-ref">fdiv</span></a>,
+<a class="reference internal" href="#i-frem"><span class="std std-ref">frem</span></a>, <a class="reference internal" href="#i-fcmp"><span class="std std-ref">fcmp</span></a>) and <a class="reference internal" href="#i-call"><span class="std std-ref">call</span></a>
+may use the following flags to enable otherwise unsafe
+floating-point transformations.</p>
+<dl class="docutils">
+<dt><code class="docutils literal notranslate"><span class="pre">nnan</span></code></dt>
+<dd>No NaNs - Allow optimizations to assume the arguments and result are not
+NaN. If an argument is a nan, or the result would be a nan, it produces
+a <a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a> instead.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">ninf</span></code></dt>
+<dd>No Infs - Allow optimizations to assume the arguments and result are not
++/-Inf. If an argument is +/-Inf, or the result would be +/-Inf, it
+produces a <a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a> instead.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">nsz</span></code></dt>
+<dd>No Signed Zeros - Allow optimizations to treat the sign of a zero
+argument or result as insignificant.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">arcp</span></code></dt>
+<dd>Allow Reciprocal - Allow optimizations to use the reciprocal of an
+argument rather than perform division.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">contract</span></code></dt>
+<dd>Allow floating-point contraction (e.g. fusing a multiply followed by an
+addition into a fused multiply-and-add).</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">afn</span></code></dt>
+<dd>Approximate functions - Allow substitution of approximate calculations for
+functions (sin, log, sqrt, etc). See floating-point intrinsic definitions
+for places where this can apply to LLVMâs intrinsic math functions.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">reassoc</span></code></dt>
+<dd>Allow reassociation transformations for floating-point instructions.
+This may dramatically change results in floating-point.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">fast</span></code></dt>
+<dd>This flag implies all of the others.</dd>
+</dl>
+</div>
+<div class="section" id="use-list-order-directives">
+<span id="uselistorder"></span><h3><a class="toc-backref" href="#id988">Use-list Order Directives</a><a class="headerlink" href="#use-list-order-directives" title="Permalink to this headline">¶</a></h3>
+<p>Use-list directives encode the in-memory order of each use-list, allowing the
+order to be recreated. <code class="docutils literal notranslate"><span class="pre"><order-indexes></span></code> is a comma-separated list of
+indexes that are assigned to the referenced valueâs uses. The referenced
+valueâs use-list is immediately sorted by these indexes.</p>
+<p>Use-list directives may appear at function scope or global scope. They are not
+instructions, and have no effect on the semantics of the IR. When theyâre at
+function scope, they must appear after the terminator of the final basic block.</p>
+<p>If basic blocks have their address taken via <code class="docutils literal notranslate"><span class="pre">blockaddress()</span></code> expressions,
+<code class="docutils literal notranslate"><span class="pre">uselistorder_bb</span></code> can be used to reorder their use-lists from outside their
+functionâs scope.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Syntax:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">uselistorder</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span><span class="p">,</span> <span class="p">{</span> <span class="o"><</span><span class="n">order</span><span class="o">-</span><span class="n">indexes</span><span class="o">></span> <span class="p">}</span>
+<span class="n">uselistorder_bb</span> <span class="nd">@function</span><span class="p">,</span> <span class="o">%</span><span class="n">block</span> <span class="p">{</span> <span class="o"><</span><span class="n">order</span><span class="o">-</span><span class="n">indexes</span><span class="o">></span> <span class="p">}</span>
+</pre></div>
+</div>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Examples:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">define</span> <span class="n">void</span> <span class="nd">@foo</span><span class="p">(</span><span class="n">i32</span> <span class="o">%</span><span class="n">arg1</span><span class="p">,</span> <span class="n">i32</span> <span class="o">%</span><span class="n">arg2</span><span class="p">)</span> <span class="p">{</span>
+<span class="n">entry</span><span class="p">:</span>
+ <span class="p">;</span> <span class="o">...</span> <span class="n">instructions</span> <span class="o">...</span>
+<span class="n">bb</span><span class="p">:</span>
+ <span class="p">;</span> <span class="o">...</span> <span class="n">instructions</span> <span class="o">...</span>
+
+ <span class="p">;</span> <span class="n">At</span> <span class="n">function</span> <span class="n">scope</span><span class="o">.</span>
+ <span class="n">uselistorder</span> <span class="n">i32</span> <span class="o">%</span><span class="n">arg1</span><span class="p">,</span> <span class="p">{</span> <span class="mi">1</span><span class="p">,</span> <span class="mi">0</span><span class="p">,</span> <span class="mi">2</span> <span class="p">}</span>
+ <span class="n">uselistorder</span> <span class="n">label</span> <span class="o">%</span><span class="n">bb</span><span class="p">,</span> <span class="p">{</span> <span class="mi">1</span><span class="p">,</span> <span class="mi">0</span> <span class="p">}</span>
+<span class="p">}</span>
+
+<span class="p">;</span> <span class="n">At</span> <span class="k">global</span> <span class="n">scope</span><span class="o">.</span>
+<span class="n">uselistorder</span> <span class="n">i32</span><span class="o">*</span> <span class="nd">@global</span><span class="p">,</span> <span class="p">{</span> <span class="mi">1</span><span class="p">,</span> <span class="mi">2</span><span class="p">,</span> <span class="mi">0</span> <span class="p">}</span>
+<span class="n">uselistorder</span> <span class="n">i32</span> <span class="mi">7</span><span class="p">,</span> <span class="p">{</span> <span class="mi">1</span><span class="p">,</span> <span class="mi">0</span> <span class="p">}</span>
+<span class="n">uselistorder</span> <span class="n">i32</span> <span class="p">(</span><span class="n">i32</span><span class="p">)</span> <span class="nd">@bar</span><span class="p">,</span> <span class="p">{</span> <span class="mi">1</span><span class="p">,</span> <span class="mi">0</span> <span class="p">}</span>
+<span class="n">uselistorder_bb</span> <span class="nd">@foo</span><span class="p">,</span> <span class="o">%</span><span class="n">bb</span><span class="p">,</span> <span class="p">{</span> <span class="mi">5</span><span class="p">,</span> <span class="mi">1</span><span class="p">,</span> <span class="mi">3</span><span class="p">,</span> <span class="mi">2</span><span class="p">,</span> <span class="mi">0</span><span class="p">,</span> <span class="mi">4</span> <span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="source-filename">
+<span id="id3"></span><h3><a class="toc-backref" href="#id989">Source Filename</a><a class="headerlink" href="#source-filename" title="Permalink to this headline">¶</a></h3>
+<p>The <em>source filename</em> string is set to the original module identifier,
+which will be the name of the compiled source file when compiling from
+source through the clang front end, for example. It is then preserved through
+the IR and bitcode.</p>
+<p>This is currently necessary to generate a consistent unique global
+identifier for local functions used in profile data, which prepends the
+source file name to the local function name.</p>
+<p>The syntax for the source file name is simply:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>source_filename = "/path/to/source.c"
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="type-system">
+<span id="typesystem"></span><h2><a class="toc-backref" href="#id990">Type System</a><a class="headerlink" href="#type-system" title="Permalink to this headline">¶</a></h2>
+<p>The LLVM type system is one of the most important features of the
+intermediate representation. Being typed enables a number of
+optimizations to be performed on the intermediate representation
+directly, without having to do extra analyses on the side before the
+transformation. A strong type system makes it easier to read the
+generated code and enables novel analyses and transformations that are
+not feasible to perform on normal three address code representations.</p>
+<div class="section" id="void-type">
+<span id="t-void"></span><h3><a class="toc-backref" href="#id991">Void Type</a><a class="headerlink" href="#void-type" title="Permalink to this headline">¶</a></h3>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Overview:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<p>The void type does not represent any value and has no size.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Syntax:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">void</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="function-type">
+<span id="t-function"></span><h3><a class="toc-backref" href="#id992">Function Type</a><a class="headerlink" href="#function-type" title="Permalink to this headline">¶</a></h3>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Overview:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<p>The function type can be thought of as a function signature. It consists of a
+return type and a list of formal parameter types. The return type of a function
+type is a void type or first class type â except for <a class="reference internal" href="#t-label"><span class="std std-ref">label</span></a>
+and <a class="reference internal" href="#t-metadata"><span class="std std-ref">metadata</span></a> types.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Syntax:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">returntype</span><span class="o">></span> <span class="p">(</span><span class="o"><</span><span class="n">parameter</span> <span class="nb">list</span><span class="o">></span><span class="p">)</span>
+</pre></div>
+</div>
+<p>â¦where â<code class="docutils literal notranslate"><span class="pre"><parameter</span> <span class="pre">list></span></code>â is a comma-separated list of type
+specifiers. Optionally, the parameter list may include a type <code class="docutils literal notranslate"><span class="pre">...</span></code>, which
+indicates that the function takes a variable number of arguments. Variable
+argument functions can access their arguments with the <a class="reference internal" href="#int-varargs"><span class="std std-ref">variable argument
+handling intrinsic</span></a> functions. â<code class="docutils literal notranslate"><span class="pre"><returntype></span></code>â is any type
+except <a class="reference internal" href="#t-label"><span class="std std-ref">label</span></a> and <a class="reference internal" href="#t-metadata"><span class="std std-ref">metadata</span></a>.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Examples:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<table border="1" class="docutils">
+<colgroup>
+<col width="17%" />
+<col width="83%" />
+</colgroup>
+<tbody valign="top">
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">i32</span> <span class="pre">(i32)</span></code></td>
+<td>function taking an <code class="docutils literal notranslate"><span class="pre">i32</span></code>, returning an <code class="docutils literal notranslate"><span class="pre">i32</span></code></td>
+</tr>
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre">float</span> <span class="pre">(i16,</span> <span class="pre">i32</span> <span class="pre">*)</span> <span class="pre">*</span></code></td>
+<td><a class="reference internal" href="#t-pointer"><span class="std std-ref">Pointer</span></a> to a function that takes an <code class="docutils literal notranslate"><span class="pre">i16</span></code> and a <a class="reference internal" href="#t-pointer"><span class="std std-ref">pointer</span></a> to <code class="docutils literal notranslate"><span class="pre">i32</span></code>, returning <code class="docutils literal notranslate"><span class="pre">float</span></code>.</td>
+</tr>
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">i32</span> <span class="pre">(i8*,</span> <span class="pre">...)</span></code></td>
+<td>A vararg function that takes at least one <a class="reference internal" href="#t-pointer"><span class="std std-ref">pointer</span></a> to <code class="docutils literal notranslate"><span class="pre">i8</span></code> (char in C), which returns an integer. This is the signature for <code class="docutils literal notranslate"><span class="pre">printf</span></code> in LLVM.</td>
+</tr>
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre">{i32,</span> <span class="pre">i32}</span> <span class="pre">(i32)</span></code></td>
+<td>A function taking an <code class="docutils literal notranslate"><span class="pre">i32</span></code>, returning a <a class="reference internal" href="#t-struct"><span class="std std-ref">structure</span></a> containing two <code class="docutils literal notranslate"><span class="pre">i32</span></code> values</td>
+</tr>
+</tbody>
+</table>
+</div>
+<div class="section" id="first-class-types">
+<span id="t-firstclass"></span><h3><a class="toc-backref" href="#id993">First Class Types</a><a class="headerlink" href="#first-class-types" title="Permalink to this headline">¶</a></h3>
+<p>The <a class="reference internal" href="#t-firstclass"><span class="std std-ref">first class</span></a> types are perhaps the most important.
+Values of these types are the only ones which can be produced by
+instructions.</p>
+<div class="section" id="single-value-types">
+<span id="t-single-value"></span><h4><a class="toc-backref" href="#id994">Single Value Types</a><a class="headerlink" href="#single-value-types" title="Permalink to this headline">¶</a></h4>
+<p>These are the types that are valid in registers from CodeGenâs perspective.</p>
+<div class="section" id="integer-type">
+<span id="t-integer"></span><h5><a class="toc-backref" href="#id995">Integer Type</a><a class="headerlink" href="#integer-type" title="Permalink to this headline">¶</a></h5>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Overview:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<p>The integer type is a very simple type that simply specifies an
+arbitrary bit width for the integer type desired. Any bit width from 1
+bit to 2<sup>23</sup>-1 (about 8 million) can be specified.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Syntax:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">iN</span>
+</pre></div>
+</div>
+<p>The number of bits the integer will occupy is specified by the <code class="docutils literal notranslate"><span class="pre">N</span></code>
+value.</p>
+<div class="section" id="examples">
+<h6>Examples:<a class="headerlink" href="#examples" title="Permalink to this headline">¶</a></h6>
+<table border="1" class="docutils">
+<colgroup>
+<col width="25%" />
+<col width="75%" />
+</colgroup>
+<tbody valign="top">
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">i1</span></code></td>
+<td>a single-bit integer.</td>
+</tr>
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre">i32</span></code></td>
+<td>a 32-bit integer.</td>
+</tr>
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">i1942652</span></code></td>
+<td>a really big integer of over 1 million bits.</td>
+</tr>
+</tbody>
+</table>
+</div>
+</div>
+<div class="section" id="floating-point-types">
+<span id="t-floating"></span><h5><a class="toc-backref" href="#id996">Floating-Point Types</a><a class="headerlink" href="#floating-point-types" title="Permalink to this headline">¶</a></h5>
+<table border="1" class="docutils">
+<colgroup>
+<col width="50%" />
+<col width="50%" />
+</colgroup>
+<thead valign="bottom">
+<tr class="row-odd"><th class="head">Type</th>
+<th class="head">Description</th>
+</tr>
+</thead>
+<tbody valign="top">
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre">half</span></code></td>
+<td>16-bit floating-point value</td>
+</tr>
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">float</span></code></td>
+<td>32-bit floating-point value</td>
+</tr>
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre">double</span></code></td>
+<td>64-bit floating-point value</td>
+</tr>
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">fp128</span></code></td>
+<td>128-bit floating-point value (112-bit mantissa)</td>
+</tr>
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre">x86_fp80</span></code></td>
+<td>80-bit floating-point value (X87)</td>
+</tr>
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">ppc_fp128</span></code></td>
+<td>128-bit floating-point value (two 64-bits)</td>
+</tr>
+</tbody>
+</table>
+<p>The binary format of half, float, double, and fp128 correspond to the
+IEEE-754-2008 specifications for binary16, binary32, binary64, and binary128
+respectively.</p>
+</div>
+<div class="section" id="x86-mmx-type">
+<h5><a class="toc-backref" href="#id997">X86_mmx Type</a><a class="headerlink" href="#x86-mmx-type" title="Permalink to this headline">¶</a></h5>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Overview:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<p>The x86_mmx type represents a value held in an MMX register on an x86
+machine. The operations allowed on it are quite limited: parameters and
+return values, load and store, and bitcast. User-specified MMX
+instructions are represented as intrinsic or asm calls with arguments
+and/or results of this type. There are no arrays, vectors or constants
+of this type.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Syntax:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">x86_mmx</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="pointer-type">
+<span id="t-pointer"></span><h5><a class="toc-backref" href="#id998">Pointer Type</a><a class="headerlink" href="#pointer-type" title="Permalink to this headline">¶</a></h5>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Overview:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<p>The pointer type is used to specify memory locations. Pointers are
+commonly used to reference objects in memory.</p>
+<p>Pointer types may have an optional address space attribute defining the
+numbered address space where the pointed-to object resides. The default
+address space is number zero. The semantics of non-zero address spaces
+are target-specific.</p>
+<p>Note that LLVM does not permit pointers to void (<code class="docutils literal notranslate"><span class="pre">void*</span></code>) nor does it
+permit pointers to labels (<code class="docutils literal notranslate"><span class="pre">label*</span></code>). Use <code class="docutils literal notranslate"><span class="pre">i8*</span></code> instead.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Syntax:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="nb">type</span><span class="o">></span> <span class="o">*</span>
+</pre></div>
+</div>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Examples:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<table border="1" class="docutils">
+<colgroup>
+<col width="19%" />
+<col width="81%" />
+</colgroup>
+<tbody valign="top">
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">[4</span> <span class="pre">x</span> <span class="pre">i32]*</span></code></td>
+<td>A <a class="reference internal" href="#t-pointer"><span class="std std-ref">pointer</span></a> to <a class="reference internal" href="#t-array"><span class="std std-ref">array</span></a> of four <code class="docutils literal notranslate"><span class="pre">i32</span></code> values.</td>
+</tr>
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre">i32</span> <span class="pre">(i32*)</span> <span class="pre">*</span></code></td>
+<td>A <a class="reference internal" href="#t-pointer"><span class="std std-ref">pointer</span></a> to a <a class="reference internal" href="#t-function"><span class="std std-ref">function</span></a> that takes an <code class="docutils literal notranslate"><span class="pre">i32*</span></code>, returning an <code class="docutils literal notranslate"><span class="pre">i32</span></code>.</td>
+</tr>
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">i32</span> <span class="pre">addrspace(5)*</span></code></td>
+<td>A <a class="reference internal" href="#t-pointer"><span class="std std-ref">pointer</span></a> to an <code class="docutils literal notranslate"><span class="pre">i32</span></code> value that resides in address space #5.</td>
+</tr>
+</tbody>
+</table>
+</div>
+<div class="section" id="vector-type">
+<span id="t-vector"></span><h5><a class="toc-backref" href="#id999">Vector Type</a><a class="headerlink" href="#vector-type" title="Permalink to this headline">¶</a></h5>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Overview:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<p>A vector type is a simple derived type that represents a vector of
+elements. Vector types are used when multiple primitive data are
+operated in parallel using a single instruction (SIMD). A vector type
+requires a size (number of elements) and an underlying primitive data
+type. Vector types are considered <a class="reference internal" href="#t-firstclass"><span class="std std-ref">first class</span></a>.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Syntax:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span> <span class="o"><</span><span class="c1"># elements> x <elementtype> ></span>
+</pre></div>
+</div>
+<p>The number of elements is a constant integer value larger than 0;
+elementtype may be any integer, floating-point or pointer type. Vectors
+of size zero are not allowed.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Examples:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<table border="1" class="docutils">
+<colgroup>
+<col width="28%" />
+<col width="72%" />
+</colgroup>
+<tbody valign="top">
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre"><4</span> <span class="pre">x</span> <span class="pre">i32></span></code></td>
+<td>Vector of 4 32-bit integer values.</td>
+</tr>
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre"><8</span> <span class="pre">x</span> <span class="pre">float></span></code></td>
+<td>Vector of 8 32-bit floating-point values.</td>
+</tr>
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre"><2</span> <span class="pre">x</span> <span class="pre">i64></span></code></td>
+<td>Vector of 2 64-bit integer values.</td>
+</tr>
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre"><4</span> <span class="pre">x</span> <span class="pre">i64*></span></code></td>
+<td>Vector of 4 pointers to 64-bit integer values.</td>
+</tr>
+</tbody>
+</table>
+</div>
+</div>
+<div class="section" id="label-type">
+<span id="t-label"></span><h4><a class="toc-backref" href="#id1000">Label Type</a><a class="headerlink" href="#label-type" title="Permalink to this headline">¶</a></h4>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Overview:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<p>The label type represents code labels.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Syntax:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">label</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="token-type">
+<span id="t-token"></span><h4><a class="toc-backref" href="#id1001">Token Type</a><a class="headerlink" href="#token-type" title="Permalink to this headline">¶</a></h4>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Overview:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<p>The token type is used when a value is associated with an instruction
+but all uses of the value must not attempt to introspect or obscure it.
+As such, it is not appropriate to have a <a class="reference internal" href="#i-phi"><span class="std std-ref">phi</span></a> or
+<a class="reference internal" href="#i-select"><span class="std std-ref">select</span></a> of type token.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Syntax:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">token</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="metadata-type">
+<span id="t-metadata"></span><h4><a class="toc-backref" href="#id1002">Metadata Type</a><a class="headerlink" href="#metadata-type" title="Permalink to this headline">¶</a></h4>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Overview:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<p>The metadata type represents embedded metadata. No derived types may be
+created from metadata except for <a class="reference internal" href="#t-function"><span class="std std-ref">function</span></a> arguments.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Syntax:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">metadata</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="aggregate-types">
+<span id="t-aggregate"></span><h4><a class="toc-backref" href="#id1003">Aggregate Types</a><a class="headerlink" href="#aggregate-types" title="Permalink to this headline">¶</a></h4>
+<p>Aggregate Types are a subset of derived types that can contain multiple
+member types. <a class="reference internal" href="#t-array"><span class="std std-ref">Arrays</span></a> and <a class="reference internal" href="#t-struct"><span class="std std-ref">structs</span></a> are
+aggregate types. <a class="reference internal" href="#t-vector"><span class="std std-ref">Vectors</span></a> are not considered to be
+aggregate types.</p>
+<div class="section" id="array-type">
+<span id="t-array"></span><h5><a class="toc-backref" href="#id1004">Array Type</a><a class="headerlink" href="#array-type" title="Permalink to this headline">¶</a></h5>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Overview:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<p>The array type is a very simple derived type that arranges elements
+sequentially in memory. The array type requires a size (number of
+elements) and an underlying data type.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Syntax:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="p">[</span><span class="o"><</span><span class="c1"># elements> x <elementtype>]</span>
+</pre></div>
+</div>
+<p>The number of elements is a constant integer value; <code class="docutils literal notranslate"><span class="pre">elementtype</span></code> may
+be any type with a size.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Examples:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<table border="1" class="docutils">
+<colgroup>
+<col width="32%" />
+<col width="68%" />
+</colgroup>
+<tbody valign="top">
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">[40</span> <span class="pre">x</span> <span class="pre">i32]</span></code></td>
+<td>Array of 40 32-bit integer values.</td>
+</tr>
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre">[41</span> <span class="pre">x</span> <span class="pre">i32]</span></code></td>
+<td>Array of 41 32-bit integer values.</td>
+</tr>
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">[4</span> <span class="pre">x</span> <span class="pre">i8]</span></code></td>
+<td>Array of 4 8-bit integer values.</td>
+</tr>
+</tbody>
+</table>
+<p>Here are some examples of multidimensional arrays:</p>
+<table border="1" class="docutils">
+<colgroup>
+<col width="33%" />
+<col width="67%" />
+</colgroup>
+<tbody valign="top">
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">[3</span> <span class="pre">x</span> <span class="pre">[4</span> <span class="pre">x</span> <span class="pre">i32]]</span></code></td>
+<td>3x4 array of 32-bit integer values.</td>
+</tr>
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre">[12</span> <span class="pre">x</span> <span class="pre">[10</span> <span class="pre">x</span> <span class="pre">float]]</span></code></td>
+<td>12x10 array of single precision floating-point values.</td>
+</tr>
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">[2</span> <span class="pre">x</span> <span class="pre">[3</span> <span class="pre">x</span> <span class="pre">[4</span> <span class="pre">x</span> <span class="pre">i16]]]</span></code></td>
+<td>2x3x4 array of 16-bit integer values.</td>
+</tr>
+</tbody>
+</table>
+<p>There is no restriction on indexing beyond the end of the array implied
+by a static type (though there are restrictions on indexing beyond the
+bounds of an allocated object in some cases). This means that
+single-dimension âvariable sized arrayâ addressing can be implemented in
+LLVM with a zero length array type. An implementation of âpascal style
+arraysâ in LLVM could use the type â<code class="docutils literal notranslate"><span class="pre">{</span> <span class="pre">i32,</span> <span class="pre">[0</span> <span class="pre">x</span> <span class="pre">float]}</span></code>â, for
+example.</p>
+</div>
+<div class="section" id="structure-type">
+<span id="t-struct"></span><h5><a class="toc-backref" href="#id1005">Structure Type</a><a class="headerlink" href="#structure-type" title="Permalink to this headline">¶</a></h5>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Overview:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<p>The structure type is used to represent a collection of data members
+together in memory. The elements of a structure may be any type that has
+a size.</p>
+<p>Structures in memory are accessed using â<code class="docutils literal notranslate"><span class="pre">load</span></code>â and â<code class="docutils literal notranslate"><span class="pre">store</span></code>â by
+getting a pointer to a field with the â<code class="docutils literal notranslate"><span class="pre">getelementptr</span></code>â instruction.
+Structures in registers are accessed using the â<code class="docutils literal notranslate"><span class="pre">extractvalue</span></code>â and
+â<code class="docutils literal notranslate"><span class="pre">insertvalue</span></code>â instructions.</p>
+<p>Structures may optionally be âpackedâ structures, which indicate that
+the alignment of the struct is one byte, and that there is no padding
+between the elements. In non-packed structs, padding between field types
+is inserted as defined by the DataLayout string in the module, which is
+required to match what the underlying code generator expects.</p>
+<p>Structures can either be âliteralâ or âidentifiedâ. A literal structure
+is defined inline with other types (e.g. <code class="docutils literal notranslate"><span class="pre">{i32,</span> <span class="pre">i32}*</span></code>) whereas
+identified types are always defined at the top level with a name.
+Literal types are uniqued by their contents and can never be recursive
+or opaque since there is no way to write one. Identified types can be
+recursive, can be opaqued, and are never uniqued.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Syntax:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o">%</span><span class="n">T1</span> <span class="o">=</span> <span class="nb">type</span> <span class="p">{</span> <span class="o"><</span><span class="nb">type</span> <span class="nb">list</span><span class="o">></span> <span class="p">}</span> <span class="p">;</span> <span class="n">Identified</span> <span class="n">normal</span> <span class="n">struct</span> <span class="nb">type</span>
+<span class="o">%</span><span class="n">T2</span> <span class="o">=</span> <span class="nb">type</span> <span class="o"><</span><span class="p">{</span> <span class="o"><</span><span class="nb">type</span> <span class="nb">list</span><span class="o">></span> <span class="p">}</span><span class="o">></span> <span class="p">;</span> <span class="n">Identified</span> <span class="n">packed</span> <span class="n">struct</span> <span class="nb">type</span>
+</pre></div>
+</div>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Examples:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<table border="1" class="docutils">
+<colgroup>
+<col width="14%" />
+<col width="86%" />
+</colgroup>
+<tbody valign="top">
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">{</span> <span class="pre">i32,</span> <span class="pre">i32,</span> <span class="pre">i32</span> <span class="pre">}</span></code></td>
+<td>A triple of three <code class="docutils literal notranslate"><span class="pre">i32</span></code> values</td>
+</tr>
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre">{</span> <span class="pre">float,</span> <span class="pre">i32</span> <span class="pre">(i32)</span> <span class="pre">*</span> <span class="pre">}</span></code></td>
+<td>A pair, where the first element is a <code class="docutils literal notranslate"><span class="pre">float</span></code> and the second element is a <a class="reference internal" href="#t-pointer"><span class="std std-ref">pointer</span></a> to a <a class="reference internal" href="#t-function"><span class="std std-ref">function</span></a> that takes an <code class="docutils literal notranslate"><span class="pre">i32</span></code>, returning an <code class="docutils literal notranslate"><span class="pre">i32</span></code>.</td>
+</tr>
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre"><{</span> <span class="pre">i8,</span> <span class="pre">i32</span> <span class="pre">}></span></code></td>
+<td>A packed struct known to be 5 bytes in size.</td>
+</tr>
+</tbody>
+</table>
+</div>
+<div class="section" id="opaque-structure-types">
+<span id="t-opaque"></span><h5><a class="toc-backref" href="#id1006">Opaque Structure Types</a><a class="headerlink" href="#opaque-structure-types" title="Permalink to this headline">¶</a></h5>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Overview:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<p>Opaque structure types are used to represent named structure types that
+do not have a body specified. This corresponds (for example) to the C
+notion of a forward declared structure.</p>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Syntax:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o">%</span><span class="n">X</span> <span class="o">=</span> <span class="nb">type</span> <span class="n">opaque</span>
+<span class="o">%</span><span class="mi">52</span> <span class="o">=</span> <span class="nb">type</span> <span class="n">opaque</span>
+</pre></div>
+</div>
+<table class="docutils field-list" frame="void" rules="none">
+<col class="field-name" />
+<col class="field-body" />
+<tbody valign="top">
+<tr class="field-odd field"><th class="field-name">Examples:</th><td class="field-body"></td>
+</tr>
+</tbody>
+</table>
+<table border="1" class="docutils">
+<colgroup>
+<col width="42%" />
+<col width="58%" />
+</colgroup>
+<tbody valign="top">
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">opaque</span></code></td>
+<td>An opaque type.</td>
+</tr>
+</tbody>
+</table>
+</div>
+</div>
+</div>
+</div>
+<div class="section" id="constants">
+<span id="id4"></span><h2><a class="toc-backref" href="#id1007">Constants</a><a class="headerlink" href="#constants" title="Permalink to this headline">¶</a></h2>
+<p>LLVM has several different basic types of constants. This section
+describes them all and their syntax.</p>
+<div class="section" id="simple-constants">
+<h3><a class="toc-backref" href="#id1008">Simple Constants</a><a class="headerlink" href="#simple-constants" title="Permalink to this headline">¶</a></h3>
+<dl class="docutils">
+<dt><strong>Boolean constants</strong></dt>
+<dd>The two strings â<code class="docutils literal notranslate"><span class="pre">true</span></code>â and â<code class="docutils literal notranslate"><span class="pre">false</span></code>â are both valid constants
+of the <code class="docutils literal notranslate"><span class="pre">i1</span></code> type.</dd>
+<dt><strong>Integer constants</strong></dt>
+<dd>Standard integers (such as â4â) are constants of the
+<a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> type. Negative numbers may be used with
+integer types.</dd>
+<dt><strong>Floating-point constants</strong></dt>
+<dd>Floating-point constants use standard decimal notation (e.g.
+123.421), exponential notation (e.g. 1.23421e+2), or a more precise
+hexadecimal notation (see below). The assembler requires the exact
+decimal value of a floating-point constant. For example, the
+assembler accepts 1.25 but rejects 1.3 because 1.3 is a repeating
+decimal in binary. Floating-point constants must have a
+<a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> type.</dd>
+<dt><strong>Null pointer constants</strong></dt>
+<dd>The identifier â<code class="docutils literal notranslate"><span class="pre">null</span></code>â is recognized as a null pointer constant
+and must be of <a class="reference internal" href="#t-pointer"><span class="std std-ref">pointer type</span></a>.</dd>
+<dt><strong>Token constants</strong></dt>
+<dd>The identifier â<code class="docutils literal notranslate"><span class="pre">none</span></code>â is recognized as an empty token constant
+and must be of <a class="reference internal" href="#t-token"><span class="std std-ref">token type</span></a>.</dd>
+</dl>
+<p>The one non-intuitive notation for constants is the hexadecimal form of
+floating-point constants. For example, the form
+â<code class="docutils literal notranslate"><span class="pre">double</span> <span class="pre">0x432ff973cafa8000</span></code>â is equivalent to (but harder to read
+than) â<code class="docutils literal notranslate"><span class="pre">double</span> <span class="pre">4.5e+15</span></code>â. The only time hexadecimal floating-point
+constants are required (and the only time that they are generated by the
+disassembler) is when a floating-point constant must be emitted but it
+cannot be represented as a decimal floating-point number in a reasonable
+number of digits. For example, NaNâs, infinities, and other special
+values are represented in their IEEE hexadecimal format so that assembly
+and disassembly do not cause any bits to change in the constants.</p>
+<p>When using the hexadecimal form, constants of types half, float, and
+double are represented using the 16-digit form shown above (which
+matches the IEEE754 representation for double); half and float values
+must, however, be exactly representable as IEEE 754 half and single
+precision, respectively. Hexadecimal format is always used for long
+double, and there are three forms of long double. The 80-bit format used
+by x86 is represented as <code class="docutils literal notranslate"><span class="pre">0xK</span></code> followed by 20 hexadecimal digits. The
+128-bit format used by PowerPC (two adjacent doubles) is represented by
+<code class="docutils literal notranslate"><span class="pre">0xM</span></code> followed by 32 hexadecimal digits. The IEEE 128-bit format is
+represented by <code class="docutils literal notranslate"><span class="pre">0xL</span></code> followed by 32 hexadecimal digits. Long doubles
+will only work if they match the long double format on your target.
+The IEEE 16-bit format (half precision) is represented by <code class="docutils literal notranslate"><span class="pre">0xH</span></code>
+followed by 4 hexadecimal digits. All hexadecimal formats are big-endian
+(sign bit at the left).</p>
+<p>There are no constants of type x86_mmx.</p>
+</div>
+<div class="section" id="complex-constants">
+<span id="complexconstants"></span><h3><a class="toc-backref" href="#id1009">Complex Constants</a><a class="headerlink" href="#complex-constants" title="Permalink to this headline">¶</a></h3>
+<p>Complex constants are a (potentially recursive) combination of simple
+constants and smaller complex constants.</p>
+<dl class="docutils">
+<dt><strong>Structure constants</strong></dt>
+<dd>Structure constants are represented with notation similar to
+structure type definitions (a comma separated list of elements,
+surrounded by braces (<code class="docutils literal notranslate"><span class="pre">{}</span></code>)). For example:
+â<code class="docutils literal notranslate"><span class="pre">{</span> <span class="pre">i32</span> <span class="pre">4,</span> <span class="pre">float</span> <span class="pre">17.0,</span> <span class="pre">i32*</span> <span class="pre">@G</span> <span class="pre">}</span></code>â, where â<code class="docutils literal notranslate"><span class="pre">@G</span></code>â is declared as
+â<code class="docutils literal notranslate"><span class="pre">@G</span> <span class="pre">=</span> <span class="pre">external</span> <span class="pre">global</span> <span class="pre">i32</span></code>â. Structure constants must have
+<a class="reference internal" href="#t-struct"><span class="std std-ref">structure type</span></a>, and the number and types of elements
+must match those specified by the type.</dd>
+<dt><strong>Array constants</strong></dt>
+<dd>Array constants are represented with notation similar to array type
+definitions (a comma separated list of elements, surrounded by
+square brackets (<code class="docutils literal notranslate"><span class="pre">[]</span></code>)). For example:
+â<code class="docutils literal notranslate"><span class="pre">[</span> <span class="pre">i32</span> <span class="pre">42,</span> <span class="pre">i32</span> <span class="pre">11,</span> <span class="pre">i32</span> <span class="pre">74</span> <span class="pre">]</span></code>â. Array constants must have
+<a class="reference internal" href="#t-array"><span class="std std-ref">array type</span></a>, and the number and types of elements must
+match those specified by the type. As a special case, character array
+constants may also be represented as a double-quoted string using the <code class="docutils literal notranslate"><span class="pre">c</span></code>
+prefix. For example: â<code class="docutils literal notranslate"><span class="pre">c"Hello</span> <span class="pre">World\0A\00"</span></code>â.</dd>
+<dt><strong>Vector constants</strong></dt>
+<dd>Vector constants are represented with notation similar to vector
+type definitions (a comma separated list of elements, surrounded by
+less-than/greater-thanâs (<code class="docutils literal notranslate"><span class="pre"><></span></code>)). For example:
+â<code class="docutils literal notranslate"><span class="pre"><</span> <span class="pre">i32</span> <span class="pre">42,</span> <span class="pre">i32</span> <span class="pre">11,</span> <span class="pre">i32</span> <span class="pre">74,</span> <span class="pre">i32</span> <span class="pre">100</span> <span class="pre">></span></code>â. Vector constants
+must have <a class="reference internal" href="#t-vector"><span class="std std-ref">vector type</span></a>, and the number and types of
+elements must match those specified by the type.</dd>
+<dt><strong>Zero initialization</strong></dt>
+<dd>The string â<code class="docutils literal notranslate"><span class="pre">zeroinitializer</span></code>â can be used to zero initialize a
+value to zero of <em>any</em> type, including scalar and
+<a class="reference internal" href="#t-aggregate"><span class="std std-ref">aggregate</span></a> types. This is often used to avoid
+having to print large zero initializers (e.g. for large arrays) and
+is always exactly equivalent to using explicit zero initializers.</dd>
+<dt><strong>Metadata node</strong></dt>
+<dd>A metadata node is a constant tuple without types. For example:
+â<code class="docutils literal notranslate"><span class="pre">!{!0,</span> <span class="pre">!{!2,</span> <span class="pre">!0},</span> <span class="pre">!"test"}</span></code>â. Metadata can reference constant values,
+for example: â<code class="docutils literal notranslate"><span class="pre">!{!0,</span> <span class="pre">i32</span> <span class="pre">0,</span> <span class="pre">i8*</span> <span class="pre">@global,</span> <span class="pre">i64</span> <span class="pre">(i64)*</span> <span class="pre">@function,</span> <span class="pre">!"str"}</span></code>â.
+Unlike other typed constants that are meant to be interpreted as part of
+the instruction stream, metadata is a place to attach additional
+information such as debug info.</dd>
+</dl>
+</div>
+<div class="section" id="global-variable-and-function-addresses">
+<h3><a class="toc-backref" href="#id1010">Global Variable and Function Addresses</a><a class="headerlink" href="#global-variable-and-function-addresses" title="Permalink to this headline">¶</a></h3>
+<p>The addresses of <a class="reference internal" href="#globalvars"><span class="std std-ref">global variables</span></a> and
+<a class="reference internal" href="#functionstructure"><span class="std std-ref">functions</span></a> are always implicitly valid
+(link-time) constants. These constants are explicitly referenced when
+the <a class="reference internal" href="#identifiers"><span class="std std-ref">identifier for the global</span></a> is used and always have
+<a class="reference internal" href="#t-pointer"><span class="std std-ref">pointer</span></a> type. For example, the following is a legal LLVM
+file:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="vg">@X</span> <span class="p">=</span> <span class="k">global</span> <span class="k">i32</span> <span class="m">17</span>
+<span class="vg">@Y</span> <span class="p">=</span> <span class="k">global</span> <span class="k">i32</span> <span class="m">42</span>
+<span class="vg">@Z</span> <span class="p">=</span> <span class="k">global</span> <span class="p">[</span><span class="m">2</span> <span class="k">x</span> <span class="k">i32</span><span class="p">*]</span> <span class="p">[</span> <span class="k">i32</span><span class="p">*</span> <span class="vg">@X</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="vg">@Y</span> <span class="p">]</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="undefined-values">
+<span id="undefvalues"></span><h3><a class="toc-backref" href="#id1011">Undefined Values</a><a class="headerlink" href="#undefined-values" title="Permalink to this headline">¶</a></h3>
+<p>The string â<code class="docutils literal notranslate"><span class="pre">undef</span></code>â can be used anywhere a constant is expected, and
+indicates that the user of the value may receive an unspecified
+bit-pattern. Undefined values may be of any type (other than â<code class="docutils literal notranslate"><span class="pre">label</span></code>â
+or â<code class="docutils literal notranslate"><span class="pre">void</span></code>â) and be used anywhere a constant is permitted.</p>
+<p>Undefined values are useful because they indicate to the compiler that
+the program is well defined no matter what value is used. This gives the
+compiler more freedom to optimize. Here are some examples of
+(potentially surprising) transformations that are valid (in pseudo IR):</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span> <span class="nv">%A</span> <span class="p">=</span> <span class="k">add</span> <span class="nv">%X</span><span class="p">,</span> <span class="k">undef</span>
+ <span class="nv">%B</span> <span class="p">=</span> <span class="k">sub</span> <span class="nv">%X</span><span class="p">,</span> <span class="k">undef</span>
+ <span class="nv">%C</span> <span class="p">=</span> <span class="k">xor</span> <span class="nv">%X</span><span class="p">,</span> <span class="k">undef</span>
+<span class="nl">Safe:</span>
+ <span class="nv">%A</span> <span class="p">=</span> <span class="k">undef</span>
+ <span class="nv">%B</span> <span class="p">=</span> <span class="k">undef</span>
+ <span class="nv">%C</span> <span class="p">=</span> <span class="k">undef</span>
+</pre></div>
+</div>
+<p>This is safe because all of the output bits are affected by the undef
+bits. Any output bit can have a zero or one depending on the input bits.</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span> <span class="nv">%A</span> <span class="p">=</span> <span class="k">or</span> <span class="nv">%X</span><span class="p">,</span> <span class="k">undef</span>
+ <span class="nv">%B</span> <span class="p">=</span> <span class="k">and</span> <span class="nv">%X</span><span class="p">,</span> <span class="k">undef</span>
+<span class="nl">Safe:</span>
+ <span class="nv">%A</span> <span class="p">=</span> <span class="m">-1</span>
+ <span class="nv">%B</span> <span class="p">=</span> <span class="m">0</span>
+<span class="nl">Safe:</span>
+ <span class="nv">%A</span> <span class="p">=</span> <span class="nv">%X</span> <span class="c">;; By choosing undef as 0</span>
+ <span class="nv">%B</span> <span class="p">=</span> <span class="nv">%X</span> <span class="c">;; By choosing undef as -1</span>
+<span class="nl">Unsafe:</span>
+ <span class="nv">%A</span> <span class="p">=</span> <span class="k">undef</span>
+ <span class="nv">%B</span> <span class="p">=</span> <span class="k">undef</span>
+</pre></div>
+</div>
+<p>These logical operations have bits that are not always affected by the
+input. For example, if <code class="docutils literal notranslate"><span class="pre">%X</span></code> has a zero bit, then the output of the
+â<code class="docutils literal notranslate"><span class="pre">and</span></code>â operation will always be a zero for that bit, no matter what
+the corresponding bit from the â<code class="docutils literal notranslate"><span class="pre">undef</span></code>â is. As such, it is unsafe to
+optimize or assume that the result of the â<code class="docutils literal notranslate"><span class="pre">and</span></code>â is â<code class="docutils literal notranslate"><span class="pre">undef</span></code>â.
+However, it is safe to assume that all bits of the â<code class="docutils literal notranslate"><span class="pre">undef</span></code>â could be
+0, and optimize the â<code class="docutils literal notranslate"><span class="pre">and</span></code>â to 0. Likewise, it is safe to assume that
+all the bits of the â<code class="docutils literal notranslate"><span class="pre">undef</span></code>â operand to the â<code class="docutils literal notranslate"><span class="pre">or</span></code>â could be set,
+allowing the â<code class="docutils literal notranslate"><span class="pre">or</span></code>â to be folded to -1.</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span> <span class="nv">%A</span> <span class="p">=</span> <span class="k">select</span> <span class="k">undef</span><span class="p">,</span> <span class="nv">%X</span><span class="p">,</span> <span class="nv">%Y</span>
+ <span class="nv">%B</span> <span class="p">=</span> <span class="k">select</span> <span class="k">undef</span><span class="p">,</span> <span class="m">42</span><span class="p">,</span> <span class="nv">%Y</span>
+ <span class="nv">%C</span> <span class="p">=</span> <span class="k">select</span> <span class="nv">%X</span><span class="p">,</span> <span class="nv">%Y</span><span class="p">,</span> <span class="k">undef</span>
+<span class="nl">Safe:</span>
+ <span class="nv">%A</span> <span class="p">=</span> <span class="nv">%X</span> <span class="p">(</span><span class="k">or</span> <span class="nv">%Y</span><span class="p">)</span>
+ <span class="nv">%B</span> <span class="p">=</span> <span class="m">42</span> <span class="p">(</span><span class="k">or</span> <span class="nv">%Y</span><span class="p">)</span>
+ <span class="nv">%C</span> <span class="p">=</span> <span class="nv">%Y</span>
+<span class="nl">Unsafe:</span>
+ <span class="nv">%A</span> <span class="p">=</span> <span class="k">undef</span>
+ <span class="nv">%B</span> <span class="p">=</span> <span class="k">undef</span>
+ <span class="nv">%C</span> <span class="p">=</span> <span class="k">undef</span>
+</pre></div>
+</div>
+<p>This set of examples shows that undefined â<code class="docutils literal notranslate"><span class="pre">select</span></code>â (and conditional
+branch) conditions can go <em>either way</em>, but they have to come from one
+of the two operands. In the <code class="docutils literal notranslate"><span class="pre">%A</span></code> example, if <code class="docutils literal notranslate"><span class="pre">%X</span></code> and <code class="docutils literal notranslate"><span class="pre">%Y</span></code> were
+both known to have a clear low bit, then <code class="docutils literal notranslate"><span class="pre">%A</span></code> would have to have a
+cleared low bit. However, in the <code class="docutils literal notranslate"><span class="pre">%C</span></code> example, the optimizer is
+allowed to assume that the â<code class="docutils literal notranslate"><span class="pre">undef</span></code>â operand could be the same as
+<code class="docutils literal notranslate"><span class="pre">%Y</span></code>, allowing the whole â<code class="docutils literal notranslate"><span class="pre">select</span></code>â to be eliminated.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span> %A = xor undef, undef
+
+ %B = undef
+ %C = xor %B, %B
+
+ %D = undef
+ %E = icmp slt %D, 4
+ %F = icmp gte %D, 4
+
+Safe:
+ %A = undef
+ %B = undef
+ %C = undef
+ %D = undef
+ %E = undef
+ %F = undef
+</pre></div>
+</div>
+<p>This example points out that two â<code class="docutils literal notranslate"><span class="pre">undef</span></code>â operands are not
+necessarily the same. This can be surprising to people (and also matches
+C semantics) where they assume that â<code class="docutils literal notranslate"><span class="pre">X^X</span></code>â is always zero, even if
+<code class="docutils literal notranslate"><span class="pre">X</span></code> is undefined. This isnât true for a number of reasons, but the
+short answer is that an â<code class="docutils literal notranslate"><span class="pre">undef</span></code>â âvariableâ can arbitrarily change
+its value over its âlive rangeâ. This is true because the variable
+doesnât actually <em>have a live range</em>. Instead, the value is logically
+read from arbitrary registers that happen to be around when needed, so
+the value is not necessarily consistent over time. In fact, <code class="docutils literal notranslate"><span class="pre">%A</span></code> and
+<code class="docutils literal notranslate"><span class="pre">%C</span></code> need to have the same semantics or the core LLVM âreplace all
+uses withâ concept would not hold.</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span> <span class="nv">%A</span> <span class="p">=</span> <span class="k">sdiv</span> <span class="k">undef</span><span class="p">,</span> <span class="nv">%X</span>
+ <span class="nv">%B</span> <span class="p">=</span> <span class="k">sdiv</span> <span class="nv">%X</span><span class="p">,</span> <span class="k">undef</span>
+<span class="nl">Safe:</span>
+ <span class="nv">%A</span> <span class="p">=</span> <span class="m">0</span>
+<span class="nl">b:</span> <span class="k">unreachable</span>
+</pre></div>
+</div>
+<p>These examples show the crucial difference between an <em>undefined value</em>
+and <em>undefined behavior</em>. An undefined value (like â<code class="docutils literal notranslate"><span class="pre">undef</span></code>â) is
+allowed to have an arbitrary bit-pattern. This means that the <code class="docutils literal notranslate"><span class="pre">%A</span></code>
+operation can be constant folded to â<code class="docutils literal notranslate"><span class="pre">0</span></code>â, because the â<code class="docutils literal notranslate"><span class="pre">undef</span></code>â
+could be zero, and zero divided by any value is zero.
+However, in the second example, we can make a more aggressive
+assumption: because the <code class="docutils literal notranslate"><span class="pre">undef</span></code> is allowed to be an arbitrary value,
+we are allowed to assume that it could be zero. Since a divide by zero
+has <em>undefined behavior</em>, we are allowed to assume that the operation
+does not execute at all. This allows us to delete the divide and all
+code after it. Because the undefined operation âcanât happenâ, the
+optimizer can assume that it occurs in dead code.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>a: store undef -> %X
+b: store %X -> undef
+Safe:
+a: <deleted>
+b: unreachable
+</pre></div>
+</div>
+<p>A store <em>of</em> an undefined value can be assumed to not have any effect;
+we can assume that the value is overwritten with bits that happen to
+match what was already there. However, a store <em>to</em> an undefined
+location could clobber arbitrary memory, therefore, it has undefined
+behavior.</p>
+</div>
+<div class="section" id="poison-values">
+<span id="poisonvalues"></span><h3><a class="toc-backref" href="#id1012">Poison Values</a><a class="headerlink" href="#poison-values" title="Permalink to this headline">¶</a></h3>
+<p>Poison values are similar to <a class="reference internal" href="#undefvalues"><span class="std std-ref">undef values</span></a>, however
+they also represent the fact that an instruction or constant expression
+that cannot evoke side effects has nevertheless detected a condition
+that results in undefined behavior.</p>
+<p>There is currently no way of representing a poison value in the IR; they
+only exist when produced by operations such as <a class="reference internal" href="#i-add"><span class="std std-ref">add</span></a> with
+the <code class="docutils literal notranslate"><span class="pre">nsw</span></code> flag.</p>
+<p>Poison value behavior is defined in terms of value <em>dependence</em>:</p>
+<ul class="simple">
+<li>Values other than <a class="reference internal" href="#i-phi"><span class="std std-ref">phi</span></a> nodes depend on their operands.</li>
+<li><a class="reference internal" href="#i-phi"><span class="std std-ref">Phi</span></a> nodes depend on the operand corresponding to
+their dynamic predecessor basic block.</li>
+<li>Function arguments depend on the corresponding actual argument values
+in the dynamic callers of their functions.</li>
+<li><a class="reference internal" href="#i-call"><span class="std std-ref">Call</span></a> instructions depend on the <a class="reference internal" href="#i-ret"><span class="std std-ref">ret</span></a>
+instructions that dynamically transfer control back to them.</li>
+<li><a class="reference internal" href="#i-invoke"><span class="std std-ref">Invoke</span></a> instructions depend on the
+<a class="reference internal" href="#i-ret"><span class="std std-ref">ret</span></a>, <a class="reference internal" href="#i-resume"><span class="std std-ref">resume</span></a>, or exception-throwing
+call instructions that dynamically transfer control back to them.</li>
+<li>Non-volatile loads and stores depend on the most recent stores to all
+of the referenced memory addresses, following the order in the IR
+(including loads and stores implied by intrinsics such as
+<a class="reference internal" href="#int-memcpy"><span class="std std-ref">@llvm.memcpy</span></a>.)</li>
+<li>An instruction with externally visible side effects depends on the
+most recent preceding instruction with externally visible side
+effects, following the order in the IR. (This includes <a class="reference internal" href="#volatile"><span class="std std-ref">volatile
+operations</span></a>.)</li>
+<li>An instruction <em>control-depends</em> on a <a class="reference internal" href="#terminators"><span class="std std-ref">terminator
+instruction</span></a> if the terminator instruction has
+multiple successors and the instruction is always executed when
+control transfers to one of the successors, and may not be executed
+when control is transferred to another.</li>
+<li>Additionally, an instruction also <em>control-depends</em> on a terminator
+instruction if the set of instructions it otherwise depends on would
+be different if the terminator had transferred control to a different
+successor.</li>
+<li>Dependence is transitive.</li>
+</ul>
+<p>Poison values have the same behavior as <a class="reference internal" href="#undefvalues"><span class="std std-ref">undef values</span></a>,
+with the additional effect that any instruction that has a <em>dependence</em>
+on a poison value has undefined behavior.</p>
+<p>Here are some examples:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nl">entry:</span>
+ <span class="nv">%poison</span> <span class="p">=</span> <span class="k">sub</span> <span class="k">nuw</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="m">1</span> <span class="c">; Results in a poison value.</span>
+ <span class="nv">%still_poison</span> <span class="p">=</span> <span class="k">and</span> <span class="k">i32</span> <span class="nv">%poison</span><span class="p">,</span> <span class="m">0</span> <span class="c">; 0, but also poison.</span>
+ <span class="nv">%poison_yet_again</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="vg">@h</span><span class="p">,</span> <span class="k">i32</span> <span class="nv">%still_poison</span>
+ <span class="k">store</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%poison_yet_again</span> <span class="c">; memory at @h[0] is poisoned</span>
+
+ <span class="k">store</span> <span class="k">i32</span> <span class="nv">%poison</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="vg">@g</span> <span class="c">; Poison value stored to memory.</span>
+ <span class="nv">%poison2</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="vg">@g</span> <span class="c">; Poison value loaded back from memory.</span>
+
+ <span class="k">store</span> <span class="k">volatile</span> <span class="k">i32</span> <span class="nv">%poison</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="vg">@g</span> <span class="c">; External observation; undefined behavior.</span>
+
+ <span class="nv">%narrowaddr</span> <span class="p">=</span> <span class="k">bitcast</span> <span class="k">i32</span><span class="p">*</span> <span class="vg">@g</span> <span class="k">to</span> <span class="k">i16</span><span class="p">*</span>
+ <span class="nv">%wideaddr</span> <span class="p">=</span> <span class="k">bitcast</span> <span class="k">i32</span><span class="p">*</span> <span class="vg">@g</span> <span class="k">to</span> <span class="k">i64</span><span class="p">*</span>
+ <span class="nv">%poison3</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i16</span><span class="p">,</span> <span class="k">i16</span><span class="p">*</span> <span class="nv">%narrowaddr</span> <span class="c">; Returns a poison value.</span>
+ <span class="nv">%poison4</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i64</span><span class="p">,</span> <span class="k">i64</span><span class="p">*</span> <span class="nv">%wideaddr</span> <span class="c">; Returns a poison value.</span>
+
+ <span class="nv">%cmp</span> <span class="p">=</span> <span class="k">icmp</span> <span class="k">slt</span> <span class="k">i32</span> <span class="nv">%poison</span><span class="p">,</span> <span class="m">0</span> <span class="c">; Returns a poison value.</span>
+ <span class="k">br</span> <span class="k">i1</span> <span class="nv">%cmp</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%true</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%end</span> <span class="c">; Branch to either destination.</span>
+
+<span class="nl">true:</span>
+ <span class="k">store</span> <span class="k">volatile</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="vg">@g</span> <span class="c">; This is control-dependent on %cmp, so</span>
+ <span class="c">; it has undefined behavior.</span>
+ <span class="k">br</span> <span class="kt">label</span> <span class="nv">%end</span>
+
+<span class="nl">end:</span>
+ <span class="nv">%p</span> <span class="p">=</span> <span class="k">phi</span> <span class="k">i32</span> <span class="p">[</span> <span class="m">0</span><span class="p">,</span> <span class="nv">%entry</span> <span class="p">],</span> <span class="p">[</span> <span class="m">1</span><span class="p">,</span> <span class="nv">%true</span> <span class="p">]</span>
+ <span class="c">; Both edges into this PHI are</span>
+ <span class="c">; control-dependent on %cmp, so this</span>
+ <span class="c">; always results in a poison value.</span>
+
+ <span class="k">store</span> <span class="k">volatile</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="vg">@g</span> <span class="c">; This would depend on the store in %true</span>
+ <span class="c">; if %cmp is true, or the store in %entry</span>
+ <span class="c">; otherwise, so this is undefined behavior.</span>
+
+ <span class="k">br</span> <span class="k">i1</span> <span class="nv">%cmp</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%second_true</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%second_end</span>
+ <span class="c">; The same branch again, but this time the</span>
+ <span class="c">; true block doesn't have side effects.</span>
+
+<span class="nl">second_true:</span>
+ <span class="c">; No side effects!</span>
+ <span class="k">ret</span> <span class="kt">void</span>
+
+<span class="nl">second_end:</span>
+ <span class="k">store</span> <span class="k">volatile</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="vg">@g</span> <span class="c">; This time, the instruction always depends</span>
+ <span class="c">; on the store in %end. Also, it is</span>
+ <span class="c">; control-equivalent to %end, so this is</span>
+ <span class="c">; well-defined (ignoring earlier undefined</span>
+ <span class="c">; behavior in this example).</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="addresses-of-basic-blocks">
+<span id="blockaddress"></span><h3><a class="toc-backref" href="#id1013">Addresses of Basic Blocks</a><a class="headerlink" href="#addresses-of-basic-blocks" title="Permalink to this headline">¶</a></h3>
+<p><code class="docutils literal notranslate"><span class="pre">blockaddress(@function,</span> <span class="pre">%block)</span></code></p>
+<p>The â<code class="docutils literal notranslate"><span class="pre">blockaddress</span></code>â constant computes the address of the specified
+basic block in the specified function, and always has an <code class="docutils literal notranslate"><span class="pre">i8*</span></code> type.
+Taking the address of the entry block is illegal.</p>
+<p>This value only has defined behavior when used as an operand to the
+â<a class="reference internal" href="#i-indirectbr"><span class="std std-ref">indirectbr</span></a>â instruction, or for comparisons
+against null. Pointer equality tests between labels addresses results in
+undefined behavior â though, again, comparison against null is ok, and
+no label is equal to the null pointer. This may be passed around as an
+opaque pointer sized value as long as the bits are not inspected. This
+allows <code class="docutils literal notranslate"><span class="pre">ptrtoint</span></code> and arithmetic to be performed on these values so
+long as the original value is reconstituted before the <code class="docutils literal notranslate"><span class="pre">indirectbr</span></code>
+instruction.</p>
+<p>Finally, some targets may provide defined semantics when using the value
+as the operand to an inline assembly, but that is target specific.</p>
+</div>
+<div class="section" id="constant-expressions">
+<span id="constantexprs"></span><h3><a class="toc-backref" href="#id1014">Constant Expressions</a><a class="headerlink" href="#constant-expressions" title="Permalink to this headline">¶</a></h3>
+<p>Constant expressions are used to allow expressions involving other
+constants to be used as constants. Constant expressions may be of any
+<a class="reference internal" href="#t-firstclass"><span class="std std-ref">first class</span></a> type and may involve any LLVM operation
+that does not have side effects (e.g. load and call are not supported).
+The following is the syntax for constant expressions:</p>
+<dl class="docutils">
+<dt><code class="docutils literal notranslate"><span class="pre">trunc</span> <span class="pre">(CST</span> <span class="pre">to</span> <span class="pre">TYPE)</span></code></dt>
+<dd>Perform the <a class="reference internal" href="#i-trunc"><span class="std std-ref">trunc operation</span></a> on constants.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">zext</span> <span class="pre">(CST</span> <span class="pre">to</span> <span class="pre">TYPE)</span></code></dt>
+<dd>Perform the <a class="reference internal" href="#i-zext"><span class="std std-ref">zext operation</span></a> on constants.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">sext</span> <span class="pre">(CST</span> <span class="pre">to</span> <span class="pre">TYPE)</span></code></dt>
+<dd>Perform the <a class="reference internal" href="#i-sext"><span class="std std-ref">sext operation</span></a> on constants.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">fptrunc</span> <span class="pre">(CST</span> <span class="pre">to</span> <span class="pre">TYPE)</span></code></dt>
+<dd>Truncate a floating-point constant to another floating-point type.
+The size of CST must be larger than the size of TYPE. Both types
+must be floating-point.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">fpext</span> <span class="pre">(CST</span> <span class="pre">to</span> <span class="pre">TYPE)</span></code></dt>
+<dd>Floating-point extend a constant to another type. The size of CST
+must be smaller or equal to the size of TYPE. Both types must be
+floating-point.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">fptoui</span> <span class="pre">(CST</span> <span class="pre">to</span> <span class="pre">TYPE)</span></code></dt>
+<dd>Convert a floating-point constant to the corresponding unsigned
+integer constant. TYPE must be a scalar or vector integer type. CST
+must be of scalar or vector floating-point type. Both CST and TYPE
+must be scalars, or vectors of the same number of elements. If the
+value wonât fit in the integer type, the result is a
+<a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a>.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">fptosi</span> <span class="pre">(CST</span> <span class="pre">to</span> <span class="pre">TYPE)</span></code></dt>
+<dd>Convert a floating-point constant to the corresponding signed
+integer constant. TYPE must be a scalar or vector integer type. CST
+must be of scalar or vector floating-point type. Both CST and TYPE
+must be scalars, or vectors of the same number of elements. If the
+value wonât fit in the integer type, the result is a
+<a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a>.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">uitofp</span> <span class="pre">(CST</span> <span class="pre">to</span> <span class="pre">TYPE)</span></code></dt>
+<dd>Convert an unsigned integer constant to the corresponding
+floating-point constant. TYPE must be a scalar or vector floating-point
+type. CST must be of scalar or vector integer type. Both CST and TYPE must
+be scalars, or vectors of the same number of elements.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">sitofp</span> <span class="pre">(CST</span> <span class="pre">to</span> <span class="pre">TYPE)</span></code></dt>
+<dd>Convert a signed integer constant to the corresponding floating-point
+constant. TYPE must be a scalar or vector floating-point type.
+CST must be of scalar or vector integer type. Both CST and TYPE must
+be scalars, or vectors of the same number of elements.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">ptrtoint</span> <span class="pre">(CST</span> <span class="pre">to</span> <span class="pre">TYPE)</span></code></dt>
+<dd>Perform the <a class="reference internal" href="#i-ptrtoint"><span class="std std-ref">ptrtoint operation</span></a> on constants.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">inttoptr</span> <span class="pre">(CST</span> <span class="pre">to</span> <span class="pre">TYPE)</span></code></dt>
+<dd>Perform the <a class="reference internal" href="#i-inttoptr"><span class="std std-ref">inttoptr operation</span></a> on constants.
+This one is <em>really</em> dangerous!</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">bitcast</span> <span class="pre">(CST</span> <span class="pre">to</span> <span class="pre">TYPE)</span></code></dt>
+<dd>Convert a constant, CST, to another TYPE.
+The constraints of the operands are the same as those for the
+<a class="reference internal" href="#i-bitcast"><span class="std std-ref">bitcast instruction</span></a>.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">addrspacecast</span> <span class="pre">(CST</span> <span class="pre">to</span> <span class="pre">TYPE)</span></code></dt>
+<dd>Convert a constant pointer or constant vector of pointer, CST, to another
+TYPE in a different address space. The constraints of the operands are the
+same as those for the <a class="reference internal" href="#i-addrspacecast"><span class="std std-ref">addrspacecast instruction</span></a>.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">getelementptr</span> <span class="pre">(TY,</span> <span class="pre">CSTPTR,</span> <span class="pre">IDX0,</span> <span class="pre">IDX1,</span> <span class="pre">...)</span></code>, <code class="docutils literal notranslate"><span class="pre">getelementptr</span> <span class="pre">inbounds</span> <span class="pre">(TY,</span> <span class="pre">CSTPTR,</span> <span class="pre">IDX0,</span> <span class="pre">IDX1,</span> <span class="pre">...)</span></code></dt>
+<dd>Perform the <a class="reference internal" href="#i-getelementptr"><span class="std std-ref">getelementptr operation</span></a> on
+constants. As with the <a class="reference internal" href="#i-getelementptr"><span class="std std-ref">getelementptr</span></a>
+instruction, the index list may have one or more indexes, which are
+required to make sense for the type of âpointer to TYâ.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">select</span> <span class="pre">(COND,</span> <span class="pre">VAL1,</span> <span class="pre">VAL2)</span></code></dt>
+<dd>Perform the <a class="reference internal" href="#i-select"><span class="std std-ref">select operation</span></a> on constants.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">icmp</span> <span class="pre">COND</span> <span class="pre">(VAL1,</span> <span class="pre">VAL2)</span></code></dt>
+<dd>Perform the <a class="reference internal" href="#i-icmp"><span class="std std-ref">icmp operation</span></a> on constants.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">fcmp</span> <span class="pre">COND</span> <span class="pre">(VAL1,</span> <span class="pre">VAL2)</span></code></dt>
+<dd>Perform the <a class="reference internal" href="#i-fcmp"><span class="std std-ref">fcmp operation</span></a> on constants.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">extractelement</span> <span class="pre">(VAL,</span> <span class="pre">IDX)</span></code></dt>
+<dd>Perform the <a class="reference internal" href="#i-extractelement"><span class="std std-ref">extractelement operation</span></a> on
+constants.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">insertelement</span> <span class="pre">(VAL,</span> <span class="pre">ELT,</span> <span class="pre">IDX)</span></code></dt>
+<dd>Perform the <a class="reference internal" href="#i-insertelement"><span class="std std-ref">insertelement operation</span></a> on
+constants.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">shufflevector</span> <span class="pre">(VEC1,</span> <span class="pre">VEC2,</span> <span class="pre">IDXMASK)</span></code></dt>
+<dd>Perform the <a class="reference internal" href="#i-shufflevector"><span class="std std-ref">shufflevector operation</span></a> on
+constants.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">extractvalue</span> <span class="pre">(VAL,</span> <span class="pre">IDX0,</span> <span class="pre">IDX1,</span> <span class="pre">...)</span></code></dt>
+<dd>Perform the <a class="reference internal" href="#i-extractvalue"><span class="std std-ref">extractvalue operation</span></a> on
+constants. The index list is interpreted in a similar manner as
+indices in a â<a class="reference internal" href="#i-getelementptr"><span class="std std-ref">getelementptr</span></a>â operation. At
+least one index value must be specified.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">insertvalue</span> <span class="pre">(VAL,</span> <span class="pre">ELT,</span> <span class="pre">IDX0,</span> <span class="pre">IDX1,</span> <span class="pre">...)</span></code></dt>
+<dd>Perform the <a class="reference internal" href="#i-insertvalue"><span class="std std-ref">insertvalue operation</span></a> on constants.
+The index list is interpreted in a similar manner as indices in a
+â<a class="reference internal" href="#i-getelementptr"><span class="std std-ref">getelementptr</span></a>â operation. At least one index
+value must be specified.</dd>
+<dt><code class="docutils literal notranslate"><span class="pre">OPCODE</span> <span class="pre">(LHS,</span> <span class="pre">RHS)</span></code></dt>
+<dd>Perform the specified operation of the LHS and RHS constants. OPCODE
+may be any of the <a class="reference internal" href="#binaryops"><span class="std std-ref">binary</span></a> or <a class="reference internal" href="#bitwiseops"><span class="std std-ref">bitwise
+binary</span></a> operations. The constraints on operands are
+the same as those for the corresponding instruction (e.g. no bitwise
+operations on floating-point values are allowed).</dd>
+</dl>
+</div>
+</div>
+<div class="section" id="other-values">
+<h2><a class="toc-backref" href="#id1015">Other Values</a><a class="headerlink" href="#other-values" title="Permalink to this headline">¶</a></h2>
+<div class="section" id="inline-assembler-expressions">
+<span id="inlineasmexprs"></span><h3><a class="toc-backref" href="#id1016">Inline Assembler Expressions</a><a class="headerlink" href="#inline-assembler-expressions" title="Permalink to this headline">¶</a></h3>
+<p>LLVM supports inline assembler expressions (as opposed to <a class="reference internal" href="#moduleasm"><span class="std std-ref">Module-Level
+Inline Assembly</span></a>) through the use of a special value. This value
+represents the inline assembler as a template string (containing the
+instructions to emit), a list of operand constraints (stored as a string), a
+flag that indicates whether or not the inline asm expression has side effects,
+and a flag indicating whether the function containing the asm needs to align its
+stack conservatively.</p>
+<p>The template string supports argument substitution of the operands using â<code class="docutils literal notranslate"><span class="pre">$</span></code>â
+followed by a number, to indicate substitution of the given register/memory
+location, as specified by the constraint string. â<code class="docutils literal notranslate"><span class="pre">${NUM:MODIFIER}</span></code>â may also
+be used, where <code class="docutils literal notranslate"><span class="pre">MODIFIER</span></code> is a target-specific annotation for how to print the
+operand (See <a class="reference internal" href="#inline-asm-modifiers"><span class="std std-ref">Asm template argument modifiers</span></a>).</p>
+<p>A literal â<code class="docutils literal notranslate"><span class="pre">$</span></code>â may be included by using â<code class="docutils literal notranslate"><span class="pre">$$</span></code>â in the template. To include
+other special characters into the output, the usual â<code class="docutils literal notranslate"><span class="pre">\XX</span></code>â escapes may be
+used, just as in other strings. Note that after template substitution, the
+resulting assembly string is parsed by LLVMâs integrated assembler unless it is
+disabled â even when emitting a <code class="docutils literal notranslate"><span class="pre">.s</span></code> file â and thus must contain assembly
+syntax known to LLVM.</p>
+<p>LLVM also supports a few more substitions useful for writing inline assembly:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">${:uid}</span></code>: Expands to a decimal integer unique to this inline assembly blob.
+This substitution is useful when declaring a local label. Many standard
+compiler optimizations, such as inlining, may duplicate an inline asm blob.
+Adding a blob-unique identifier ensures that the two labels will not conflict
+during assembly. This is used to implement <a class="reference external" href="https://gcc.gnu.org/onlinedocs/gcc/Extended-Asm.html">GCCâs %= special format
+string</a>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">${:comment}</span></code>: Expands to the comment character of the current targetâs
+assembly dialect. This is usually <code class="docutils literal notranslate"><span class="pre">#</span></code>, but many targets use other strings,
+such as <code class="docutils literal notranslate"><span class="pre">;</span></code>, <code class="docutils literal notranslate"><span class="pre">//</span></code>, or <code class="docutils literal notranslate"><span class="pre">!</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">${:private}</span></code>: Expands to the assembler private label prefix. Labels with
+this prefix will not appear in the symbol table of the assembled object.
+Typically the prefix is <code class="docutils literal notranslate"><span class="pre">L</span></code>, but targets may use other strings. <code class="docutils literal notranslate"><span class="pre">.L</span></code> is
+relatively popular.</li>
+</ul>
+<p>LLVMâs support for inline asm is modeled closely on the requirements of Clangâs
+GCC-compatible inline-asm support. Thus, the feature-set and the constraint and
+modifier codes listed here are similar or identical to those in GCCâs inline asm
+support. However, to be clear, the syntax of the template and constraint strings
+described here is <em>not</em> the same as the syntax accepted by GCC and Clang, and,
+while most constraint letters are passed through as-is by Clang, some get
+translated to other codes when converting from the C source to the LLVM
+assembly.</p>
+<p>An example inline assembler expression is:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">i32</span> <span class="p">(</span><span class="k">i32</span><span class="p">)</span> <span class="k">asm</span> <span class="s">"bswap $0"</span><span class="p">,</span> <span class="s">"=r,r"</span>
+</pre></div>
+</div>
+<p>Inline assembler expressions may <strong>only</strong> be used as the callee operand
+of a <a class="reference internal" href="#i-call"><span class="std std-ref">call</span></a> or an <a class="reference internal" href="#i-invoke"><span class="std std-ref">invoke</span></a> instruction.
+Thus, typically we have:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%X</span> <span class="p">=</span> <span class="k">call</span> <span class="k">i32</span> <span class="k">asm</span> <span class="s">"bswap $0"</span><span class="p">,</span> <span class="s">"=r,r"</span><span class="p">(</span><span class="k">i32</span> <span class="nv">%Y</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>Inline asms with side effects not visible in the constraint list must be
+marked as having side effects. This is done through the use of the
+â<code class="docutils literal notranslate"><span class="pre">sideeffect</span></code>â keyword, like so:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">call</span> <span class="kt">void</span> <span class="k">asm</span> <span class="k">sideeffect</span> <span class="s">"eieio"</span><span class="p">,</span> <span class="s">""</span><span class="p">()</span>
+</pre></div>
+</div>
+<p>In some cases inline asms will contain code that will not work unless
+the stack is aligned in some way, such as calls or SSE instructions on
+x86, yet will not contain code that does that alignment within the asm.
+The compiler should make conservative assumptions about what the asm
+might contain and should generate its usual stack alignment code in the
+prologue if the â<code class="docutils literal notranslate"><span class="pre">alignstack</span></code>â keyword is present:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">call</span> <span class="kt">void</span> <span class="k">asm</span> <span class="k">alignstack</span> <span class="s">"eieio"</span><span class="p">,</span> <span class="s">""</span><span class="p">()</span>
+</pre></div>
+</div>
+<p>Inline asms also support using non-standard assembly dialects. The
+assumed dialect is ATT. When the â<code class="docutils literal notranslate"><span class="pre">inteldialect</span></code>â keyword is present,
+the inline asm is using the Intel dialect. Currently, ATT and Intel are
+the only supported dialects. An example is:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">call</span> <span class="kt">void</span> <span class="k">asm</span> <span class="k">inteldialect</span> <span class="s">"eieio"</span><span class="p">,</span> <span class="s">""</span><span class="p">()</span>
+</pre></div>
+</div>
+<p>If multiple keywords appear the â<code class="docutils literal notranslate"><span class="pre">sideeffect</span></code>â keyword must come
+first, the â<code class="docutils literal notranslate"><span class="pre">alignstack</span></code>â keyword second and the â<code class="docutils literal notranslate"><span class="pre">inteldialect</span></code>â
+keyword last.</p>
+<div class="section" id="inline-asm-constraint-string">
+<h4><a class="toc-backref" href="#id1017">Inline Asm Constraint String</a><a class="headerlink" href="#inline-asm-constraint-string" title="Permalink to this headline">¶</a></h4>
+<p>The constraint list is a comma-separated string, each element containing one or
+more constraint codes.</p>
+<p>For each element in the constraint list an appropriate register or memory
+operand will be chosen, and it will be made available to assembly template
+string expansion as <code class="docutils literal notranslate"><span class="pre">$0</span></code> for the first constraint in the list, <code class="docutils literal notranslate"><span class="pre">$1</span></code> for the
+second, etc.</p>
+<p>There are three different types of constraints, which are distinguished by a
+prefix symbol in front of the constraint code: Output, Input, and Clobber. The
+constraints must always be given in that order: outputs first, then inputs, then
+clobbers. They cannot be intermingled.</p>
+<p>There are also three different categories of constraint codes:</p>
+<ul class="simple">
+<li>Register constraint. This is either a register class, or a fixed physical
+register. This kind of constraint will allocate a register, and if necessary,
+bitcast the argument or result to the appropriate type.</li>
+<li>Memory constraint. This kind of constraint is for use with an instruction
+taking a memory operand. Different constraints allow for different addressing
+modes used by the target.</li>
+<li>Immediate value constraint. This kind of constraint is for an integer or other
+immediate value which can be rendered directly into an instruction. The
+various target-specific constraints allow the selection of a value in the
+proper range for the instruction you wish to use it with.</li>
+</ul>
+<div class="section" id="output-constraints">
+<h5><a class="toc-backref" href="#id1018">Output constraints</a><a class="headerlink" href="#output-constraints" title="Permalink to this headline">¶</a></h5>
+<p>Output constraints are specified by an â<code class="docutils literal notranslate"><span class="pre">=</span></code>â prefix (e.g. â<code class="docutils literal notranslate"><span class="pre">=r</span></code>â). This
+indicates that the assembly will write to this operand, and the operand will
+then be made available as a return value of the <code class="docutils literal notranslate"><span class="pre">asm</span></code> expression. Output
+constraints do not consume an argument from the call instruction. (Except, see
+below about indirect outputs).</p>
+<p>Normally, it is expected that no output locations are written to by the assembly
+expression until <em>all</em> of the inputs have been read. As such, LLVM may assign
+the same register to an output and an input. If this is not safe (e.g. if the
+assembly contains two instructions, where the first writes to one output, and
+the second reads an input and writes to a second output), then the â<code class="docutils literal notranslate"><span class="pre">&</span></code>â
+modifier must be used (e.g. â<code class="docutils literal notranslate"><span class="pre">=&r</span></code>â) to specify that the output is an
+âearly-clobberâ output. Marking an output as âearly-clobberâ ensures that LLVM
+will not use the same register for any inputs (other than an input tied to this
+output).</p>
+</div>
+<div class="section" id="input-constraints">
+<h5><a class="toc-backref" href="#id1019">Input constraints</a><a class="headerlink" href="#input-constraints" title="Permalink to this headline">¶</a></h5>
+<p>Input constraints do not have a prefix â just the constraint codes. Each input
+constraint will consume one argument from the call instruction. It is not
+permitted for the asm to write to any input register or memory location (unless
+that input is tied to an output). Note also that multiple inputs may all be
+assigned to the same register, if LLVM can determine that they necessarily all
+contain the same value.</p>
+<p>Instead of providing a Constraint Code, input constraints may also âtieâ
+themselves to an output constraint, by providing an integer as the constraint
+string. Tied inputs still consume an argument from the call instruction, and
+take up a position in the asm template numbering as is usual â they will simply
+be constrained to always use the same register as the output theyâve been tied
+to. For example, a constraint string of â<code class="docutils literal notranslate"><span class="pre">=r,0</span></code>â says to assign a register for
+output, and use that register as an input as well (it being the 0âth
+constraint).</p>
+<p>It is permitted to tie an input to an âearly-clobberâ output. In that case, no
+<em>other</em> input may share the same register as the input tied to the early-clobber
+(even when the other input has the same value).</p>
+<p>You may only tie an input to an output which has a register constraint, not a
+memory constraint. Only a single input may be tied to an output.</p>
+<p>There is also an âinterestingâ feature which deserves a bit of explanation: if a
+register class constraint allocates a register which is too small for the value
+type operand provided as input, the input value will be split into multiple
+registers, and all of them passed to the inline asm.</p>
+<p>However, this feature is often not as useful as you might think.</p>
+<p>Firstly, the registers are <em>not</em> guaranteed to be consecutive. So, on those
+architectures that have instructions which operate on multiple consecutive
+instructions, this is not an appropriate way to support them. (e.g. the 32-bit
+SparcV8 has a 64-bit load, which instruction takes a single 32-bit register. The
+hardware then loads into both the named register, and the next register. This
+feature of inline asm would not be useful to support that.)</p>
+<p>A few of the targets provide a template string modifier allowing explicit access
+to the second register of a two-register operand (e.g. MIPS <code class="docutils literal notranslate"><span class="pre">L</span></code>, <code class="docutils literal notranslate"><span class="pre">M</span></code>, and
+<code class="docutils literal notranslate"><span class="pre">D</span></code>). On such an architecture, you can actually access the second allocated
+register (yet, still, not any subsequent ones). But, in that case, youâre still
+probably better off simply splitting the value into two separate operands, for
+clarity. (e.g. see the description of the <code class="docutils literal notranslate"><span class="pre">A</span></code> constraint on X86, which,
+despite existing only for use with this feature, is not really a good idea to
+use)</p>
+</div>
+<div class="section" id="indirect-inputs-and-outputs">
+<h5><a class="toc-backref" href="#id1020">Indirect inputs and outputs</a><a class="headerlink" href="#indirect-inputs-and-outputs" title="Permalink to this headline">¶</a></h5>
+<p>Indirect output or input constraints can be specified by the â<code class="docutils literal notranslate"><span class="pre">*</span></code>â modifier
+(which goes after the â<code class="docutils literal notranslate"><span class="pre">=</span></code>â in case of an output). This indicates that the asm
+will write to or read from the contents of an <em>address</em> provided as an input
+argument. (Note that in this way, indirect outputs act more like an <em>input</em> than
+an output: just like an input, they consume an argument of the call expression,
+rather than producing a return value. An indirect output constraint is an
+âoutputâ only in that the asm is expected to write to the contents of the input
+memory location, instead of just read from it).</p>
+<p>This is most typically used for memory constraint, e.g. â<code class="docutils literal notranslate"><span class="pre">=*m</span></code>â, to pass the
+address of a variable as a value.</p>
+<p>It is also possible to use an indirect <em>register</em> constraint, but only on output
+(e.g. â<code class="docutils literal notranslate"><span class="pre">=*r</span></code>â). This will cause LLVM to allocate a register for an output
+value normally, and then, separately emit a store to the address provided as
+input, after the provided inline asm. (Itâs not clear what value this
+functionality provides, compared to writing the store explicitly after the asm
+statement, and it can only produce worse code, since it bypasses many
+optimization passes. I would recommend not using it.)</p>
+</div>
+<div class="section" id="clobber-constraints">
+<h5><a class="toc-backref" href="#id1021">Clobber constraints</a><a class="headerlink" href="#clobber-constraints" title="Permalink to this headline">¶</a></h5>
+<p>A clobber constraint is indicated by a â<code class="docutils literal notranslate"><span class="pre">~</span></code>â prefix. A clobber does not
+consume an input operand, nor generate an output. Clobbers cannot use any of the
+general constraint code letters â they may use only explicit register
+constraints, e.g. â<code class="docutils literal notranslate"><span class="pre">~{eax}</span></code>â. The one exception is that a clobber string of
+â<code class="docutils literal notranslate"><span class="pre">~{memory}</span></code>â indicates that the assembly writes to arbitrary undeclared
+memory locations â not only the memory pointed to by a declared indirect
+output.</p>
+<p>Note that clobbering named registers that are also present in output
+constraints is not legal.</p>
+</div>
+<div class="section" id="constraint-codes">
+<h5><a class="toc-backref" href="#id1022">Constraint Codes</a><a class="headerlink" href="#constraint-codes" title="Permalink to this headline">¶</a></h5>
+<p>After a potential prefix comes constraint code, or codes.</p>
+<p>A Constraint Code is either a single letter (e.g. â<code class="docutils literal notranslate"><span class="pre">r</span></code>â), a â<code class="docutils literal notranslate"><span class="pre">^</span></code>â character
+followed by two letters (e.g. â<code class="docutils literal notranslate"><span class="pre">^wc</span></code>â), or â<code class="docutils literal notranslate"><span class="pre">{</span></code>â register-name â<code class="docutils literal notranslate"><span class="pre">}</span></code>â
+(e.g. â<code class="docutils literal notranslate"><span class="pre">{eax}</span></code>â).</p>
+<p>The one and two letter constraint codes are typically chosen to be the same as
+GCCâs constraint codes.</p>
+<p>A single constraint may include one or more than constraint code in it, leaving
+it up to LLVM to choose which one to use. This is included mainly for
+compatibility with the translation of GCC inline asm coming from clang.</p>
+<p>There are two ways to specify alternatives, and either or both may be used in an
+inline asm constraint list:</p>
+<ol class="arabic simple">
+<li>Append the codes to each other, making a constraint code set. E.g. â<code class="docutils literal notranslate"><span class="pre">im</span></code>â
+or â<code class="docutils literal notranslate"><span class="pre">{eax}m</span></code>â. This means âchoose any of the options in the setâ. The
+choice of constraint is made independently for each constraint in the
+constraint list.</li>
+<li>Use â<code class="docutils literal notranslate"><span class="pre">|</span></code>â between constraint code sets, creating alternatives. Every
+constraint in the constraint list must have the same number of alternative
+sets. With this syntax, the same alternative in <em>all</em> of the items in the
+constraint list will be chosen together.</li>
+</ol>
+<p>Putting those together, you might have a two operand constraint string like
+<code class="docutils literal notranslate"><span class="pre">"rm|r,ri|rm"</span></code>. This indicates that if operand 0 is <code class="docutils literal notranslate"><span class="pre">r</span></code> or <code class="docutils literal notranslate"><span class="pre">m</span></code>, then
+operand 1 may be one of <code class="docutils literal notranslate"><span class="pre">r</span></code> or <code class="docutils literal notranslate"><span class="pre">i</span></code>. If operand 0 is <code class="docutils literal notranslate"><span class="pre">r</span></code>, then operand 1
+may be one of <code class="docutils literal notranslate"><span class="pre">r</span></code> or <code class="docutils literal notranslate"><span class="pre">m</span></code>. But, operand 0 and 1 cannot both be of type m.</p>
+<p>However, the use of either of the alternatives features is <em>NOT</em> recommended, as
+LLVM is not able to make an intelligent choice about which one to use. (At the
+point it currently needs to choose, not enough information is available to do so
+in a smart way.) Thus, it simply tries to make a choice thatâs most likely to
+compile, not one that will be optimal performance. (e.g., given â<code class="docutils literal notranslate"><span class="pre">rm</span></code>â, itâll
+always choose to use memory, not registers). And, if given multiple registers,
+or multiple register classes, it will simply choose the first one. (In fact, it
+doesnât currently even ensure explicitly specified physical registers are
+unique, so specifying multiple physical registers as alternatives, like
+<code class="docutils literal notranslate"><span class="pre">{r11}{r12},{r11}{r12}</span></code>, will assign r11 to both operands, not at all what was
+intended.)</p>
+</div>
+<div class="section" id="supported-constraint-code-list">
+<h5><a class="toc-backref" href="#id1023">Supported Constraint Code List</a><a class="headerlink" href="#supported-constraint-code-list" title="Permalink to this headline">¶</a></h5>
+<p>The constraint codes are, in general, expected to behave the same way they do in
+GCC. LLVMâs support is often implemented on an âas-neededâ basis, to support C
+inline asm code which was supported by GCC. A mismatch in behavior between LLVM
+and GCC likely indicates a bug in LLVM.</p>
+<p>Some constraint codes are typically supported by all targets:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>: A register in the targetâs general purpose register class.</li>
+<li><code class="docutils literal notranslate"><span class="pre">m</span></code>: A memory address operand. It is target-specific what addressing modes
+are supported, typical examples are register, or register + register offset,
+or register + immediate offset (of some target-specific size).</li>
+<li><code class="docutils literal notranslate"><span class="pre">i</span></code>: An integer constant (of target-specific width). Allows either a simple
+immediate, or a relocatable value.</li>
+<li><code class="docutils literal notranslate"><span class="pre">n</span></code>: An integer constant â <em>not</em> including relocatable values.</li>
+<li><code class="docutils literal notranslate"><span class="pre">s</span></code>: An integer constant, but allowing <em>only</em> relocatable values.</li>
+<li><code class="docutils literal notranslate"><span class="pre">X</span></code>: Allows an operand of any kind, no constraint whatsoever. Typically
+useful to pass a label for an asm branch or call.</li>
+<li><code class="docutils literal notranslate"><span class="pre">{register-name}</span></code>: Requires exactly the named physical register.</li>
+</ul>
+<p>Other constraints are target-specific:</p>
+<p>AArch64:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">z</span></code>: An immediate integer 0. Outputs <code class="docutils literal notranslate"><span class="pre">WZR</span></code> or <code class="docutils literal notranslate"><span class="pre">XZR</span></code>, as appropriate.</li>
+<li><code class="docutils literal notranslate"><span class="pre">I</span></code>: An immediate integer valid for an <code class="docutils literal notranslate"><span class="pre">ADD</span></code> or <code class="docutils literal notranslate"><span class="pre">SUB</span></code> instruction,
+i.e. 0 to 4095 with optional shift by 12.</li>
+<li><code class="docutils literal notranslate"><span class="pre">J</span></code>: An immediate integer that, when negated, is valid for an <code class="docutils literal notranslate"><span class="pre">ADD</span></code> or
+<code class="docutils literal notranslate"><span class="pre">SUB</span></code> instruction, i.e. -1 to -4095 with optional left shift by 12.</li>
+<li><code class="docutils literal notranslate"><span class="pre">K</span></code>: An immediate integer that is valid for the âbitmask immediate 32â of a
+logical instruction like <code class="docutils literal notranslate"><span class="pre">AND</span></code>, <code class="docutils literal notranslate"><span class="pre">EOR</span></code>, or <code class="docutils literal notranslate"><span class="pre">ORR</span></code> with a 32-bit register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">L</span></code>: An immediate integer that is valid for the âbitmask immediate 64â of a
+logical instruction like <code class="docutils literal notranslate"><span class="pre">AND</span></code>, <code class="docutils literal notranslate"><span class="pre">EOR</span></code>, or <code class="docutils literal notranslate"><span class="pre">ORR</span></code> with a 64-bit register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">M</span></code>: An immediate integer for use with the <code class="docutils literal notranslate"><span class="pre">MOV</span></code> assembly alias on a
+32-bit register. This is a superset of <code class="docutils literal notranslate"><span class="pre">K</span></code>: in addition to the bitmask
+immediate, also allows immediate integers which can be loaded with a single
+<code class="docutils literal notranslate"><span class="pre">MOVZ</span></code> or <code class="docutils literal notranslate"><span class="pre">MOVL</span></code> instruction.</li>
+<li><code class="docutils literal notranslate"><span class="pre">N</span></code>: An immediate integer for use with the <code class="docutils literal notranslate"><span class="pre">MOV</span></code> assembly alias on a
+64-bit register. This is a superset of <code class="docutils literal notranslate"><span class="pre">L</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">Q</span></code>: Memory address operand must be in a single register (no
+offsets). (However, LLVM currently does this for the <code class="docutils literal notranslate"><span class="pre">m</span></code> constraint as
+well.)</li>
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>: A 32 or 64-bit integer register (W* or X*).</li>
+<li><code class="docutils literal notranslate"><span class="pre">w</span></code>: A 32, 64, or 128-bit floating-point/SIMD register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">x</span></code>: A lower 128-bit floating-point/SIMD register (<code class="docutils literal notranslate"><span class="pre">V0</span></code> to <code class="docutils literal notranslate"><span class="pre">V15</span></code>).</li>
+</ul>
+<p>AMDGPU:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>: A 32 or 64-bit integer register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">[0-9]v</span></code>: The 32-bit VGPR register, number 0-9.</li>
+<li><code class="docutils literal notranslate"><span class="pre">[0-9]s</span></code>: The 32-bit SGPR register, number 0-9.</li>
+</ul>
+<p>All ARM modes:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">Q</span></code>, <code class="docutils literal notranslate"><span class="pre">Um</span></code>, <code class="docutils literal notranslate"><span class="pre">Un</span></code>, <code class="docutils literal notranslate"><span class="pre">Uq</span></code>, <code class="docutils literal notranslate"><span class="pre">Us</span></code>, <code class="docutils literal notranslate"><span class="pre">Ut</span></code>, <code class="docutils literal notranslate"><span class="pre">Uv</span></code>, <code class="docutils literal notranslate"><span class="pre">Uy</span></code>: Memory address
+operand. Treated the same as operand <code class="docutils literal notranslate"><span class="pre">m</span></code>, at the moment.</li>
+</ul>
+<p>ARM and ARMâs Thumb2 mode:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">j</span></code>: An immediate integer between 0 and 65535 (valid for <code class="docutils literal notranslate"><span class="pre">MOVW</span></code>)</li>
+<li><code class="docutils literal notranslate"><span class="pre">I</span></code>: An immediate integer valid for a data-processing instruction.</li>
+<li><code class="docutils literal notranslate"><span class="pre">J</span></code>: An immediate integer between -4095 and 4095.</li>
+<li><code class="docutils literal notranslate"><span class="pre">K</span></code>: An immediate integer whose bitwise inverse is valid for a
+data-processing instruction. (Can be used with template modifier â<code class="docutils literal notranslate"><span class="pre">B</span></code>â to
+print the inverted value).</li>
+<li><code class="docutils literal notranslate"><span class="pre">L</span></code>: An immediate integer whose negation is valid for a data-processing
+instruction. (Can be used with template modifier â<code class="docutils literal notranslate"><span class="pre">n</span></code>â to print the negated
+value).</li>
+<li><code class="docutils literal notranslate"><span class="pre">M</span></code>: A power of two or a integer between 0 and 32.</li>
+<li><code class="docutils literal notranslate"><span class="pre">N</span></code>: Invalid immediate constraint.</li>
+<li><code class="docutils literal notranslate"><span class="pre">O</span></code>: Invalid immediate constraint.</li>
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>: A general-purpose 32-bit integer register (<code class="docutils literal notranslate"><span class="pre">r0-r15</span></code>).</li>
+<li><code class="docutils literal notranslate"><span class="pre">l</span></code>: In Thumb2 mode, low 32-bit GPR registers (<code class="docutils literal notranslate"><span class="pre">r0-r7</span></code>). In ARM mode, same
+as <code class="docutils literal notranslate"><span class="pre">r</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">h</span></code>: In Thumb2 mode, a high 32-bit GPR register (<code class="docutils literal notranslate"><span class="pre">r8-r15</span></code>). In ARM mode,
+invalid.</li>
+<li><code class="docutils literal notranslate"><span class="pre">w</span></code>: A 32, 64, or 128-bit floating-point/SIMD register: <code class="docutils literal notranslate"><span class="pre">s0-s31</span></code>,
+<code class="docutils literal notranslate"><span class="pre">d0-d31</span></code>, or <code class="docutils literal notranslate"><span class="pre">q0-q15</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">x</span></code>: A 32, 64, or 128-bit floating-point/SIMD register: <code class="docutils literal notranslate"><span class="pre">s0-s15</span></code>,
+<code class="docutils literal notranslate"><span class="pre">d0-d7</span></code>, or <code class="docutils literal notranslate"><span class="pre">q0-q3</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">t</span></code>: A low floating-point/SIMD register: <code class="docutils literal notranslate"><span class="pre">s0-s31</span></code>, <code class="docutils literal notranslate"><span class="pre">d0-d16</span></code>, or
+<code class="docutils literal notranslate"><span class="pre">q0-q8</span></code>.</li>
+</ul>
+<p>ARMâs Thumb1 mode:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">I</span></code>: An immediate integer between 0 and 255.</li>
+<li><code class="docutils literal notranslate"><span class="pre">J</span></code>: An immediate integer between -255 and -1.</li>
+<li><code class="docutils literal notranslate"><span class="pre">K</span></code>: An immediate integer between 0 and 255, with optional left-shift by
+some amount.</li>
+<li><code class="docutils literal notranslate"><span class="pre">L</span></code>: An immediate integer between -7 and 7.</li>
+<li><code class="docutils literal notranslate"><span class="pre">M</span></code>: An immediate integer which is a multiple of 4 between 0 and 1020.</li>
+<li><code class="docutils literal notranslate"><span class="pre">N</span></code>: An immediate integer between 0 and 31.</li>
+<li><code class="docutils literal notranslate"><span class="pre">O</span></code>: An immediate integer which is a multiple of 4 between -508 and 508.</li>
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>: A low 32-bit GPR register (<code class="docutils literal notranslate"><span class="pre">r0-r7</span></code>).</li>
+<li><code class="docutils literal notranslate"><span class="pre">l</span></code>: A low 32-bit GPR register (<code class="docutils literal notranslate"><span class="pre">r0-r7</span></code>).</li>
+<li><code class="docutils literal notranslate"><span class="pre">h</span></code>: A high GPR register (<code class="docutils literal notranslate"><span class="pre">r0-r7</span></code>).</li>
+<li><code class="docutils literal notranslate"><span class="pre">w</span></code>: A 32, 64, or 128-bit floating-point/SIMD register: <code class="docutils literal notranslate"><span class="pre">s0-s31</span></code>,
+<code class="docutils literal notranslate"><span class="pre">d0-d31</span></code>, or <code class="docutils literal notranslate"><span class="pre">q0-q15</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">x</span></code>: A 32, 64, or 128-bit floating-point/SIMD register: <code class="docutils literal notranslate"><span class="pre">s0-s15</span></code>,
+<code class="docutils literal notranslate"><span class="pre">d0-d7</span></code>, or <code class="docutils literal notranslate"><span class="pre">q0-q3</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">t</span></code>: A low floating-point/SIMD register: <code class="docutils literal notranslate"><span class="pre">s0-s31</span></code>, <code class="docutils literal notranslate"><span class="pre">d0-d16</span></code>, or
+<code class="docutils literal notranslate"><span class="pre">q0-q8</span></code>.</li>
+</ul>
+<p>Hexagon:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">o</span></code>, <code class="docutils literal notranslate"><span class="pre">v</span></code>: A memory address operand, treated the same as constraint <code class="docutils literal notranslate"><span class="pre">m</span></code>,
+at the moment.</li>
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>: A 32 or 64-bit register.</li>
+</ul>
+<p>MSP430:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>: An 8 or 16-bit register.</li>
+</ul>
+<p>MIPS:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">I</span></code>: An immediate signed 16-bit integer.</li>
+<li><code class="docutils literal notranslate"><span class="pre">J</span></code>: An immediate integer zero.</li>
+<li><code class="docutils literal notranslate"><span class="pre">K</span></code>: An immediate unsigned 16-bit integer.</li>
+<li><code class="docutils literal notranslate"><span class="pre">L</span></code>: An immediate 32-bit integer, where the lower 16 bits are 0.</li>
+<li><code class="docutils literal notranslate"><span class="pre">N</span></code>: An immediate integer between -65535 and -1.</li>
+<li><code class="docutils literal notranslate"><span class="pre">O</span></code>: An immediate signed 15-bit integer.</li>
+<li><code class="docutils literal notranslate"><span class="pre">P</span></code>: An immediate integer between 1 and 65535.</li>
+<li><code class="docutils literal notranslate"><span class="pre">m</span></code>: A memory address operand. In MIPS-SE mode, allows a base address
+register plus 16-bit immediate offset. In MIPS mode, just a base register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">R</span></code>: A memory address operand. In MIPS-SE mode, allows a base address
+register plus a 9-bit signed offset. In MIPS mode, the same as constraint
+<code class="docutils literal notranslate"><span class="pre">m</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">ZC</span></code>: A memory address operand, suitable for use in a <code class="docutils literal notranslate"><span class="pre">pref</span></code>, <code class="docutils literal notranslate"><span class="pre">ll</span></code>, or
+<code class="docutils literal notranslate"><span class="pre">sc</span></code> instruction on the given subtarget (details vary).</li>
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>, <code class="docutils literal notranslate"><span class="pre">d</span></code>, <code class="docutils literal notranslate"><span class="pre">y</span></code>: A 32 or 64-bit GPR register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">f</span></code>: A 32 or 64-bit FPU register (<code class="docutils literal notranslate"><span class="pre">F0-F31</span></code>), or a 128-bit MSA register
+(<code class="docutils literal notranslate"><span class="pre">W0-W31</span></code>). In the case of MSA registers, it is recommended to use the <code class="docutils literal notranslate"><span class="pre">w</span></code>
+argument modifier for compatibility with GCC.</li>
+<li><code class="docutils literal notranslate"><span class="pre">c</span></code>: A 32-bit or 64-bit GPR register suitable for indirect jump (always
+<code class="docutils literal notranslate"><span class="pre">25</span></code>).</li>
+<li><code class="docutils literal notranslate"><span class="pre">l</span></code>: The <code class="docutils literal notranslate"><span class="pre">lo</span></code> register, 32 or 64-bit.</li>
+<li><code class="docutils literal notranslate"><span class="pre">x</span></code>: Invalid.</li>
+</ul>
+<p>NVPTX:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">b</span></code>: A 1-bit integer register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">c</span></code> or <code class="docutils literal notranslate"><span class="pre">h</span></code>: A 16-bit integer register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>: A 32-bit integer register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">l</span></code> or <code class="docutils literal notranslate"><span class="pre">N</span></code>: A 64-bit integer register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">f</span></code>: A 32-bit float register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">d</span></code>: A 64-bit float register.</li>
+</ul>
+<p>PowerPC:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">I</span></code>: An immediate signed 16-bit integer.</li>
+<li><code class="docutils literal notranslate"><span class="pre">J</span></code>: An immediate unsigned 16-bit integer, shifted left 16 bits.</li>
+<li><code class="docutils literal notranslate"><span class="pre">K</span></code>: An immediate unsigned 16-bit integer.</li>
+<li><code class="docutils literal notranslate"><span class="pre">L</span></code>: An immediate signed 16-bit integer, shifted left 16 bits.</li>
+<li><code class="docutils literal notranslate"><span class="pre">M</span></code>: An immediate integer greater than 31.</li>
+<li><code class="docutils literal notranslate"><span class="pre">N</span></code>: An immediate integer that is an exact power of 2.</li>
+<li><code class="docutils literal notranslate"><span class="pre">O</span></code>: The immediate integer constant 0.</li>
+<li><code class="docutils literal notranslate"><span class="pre">P</span></code>: An immediate integer constant whose negation is a signed 16-bit
+constant.</li>
+<li><code class="docutils literal notranslate"><span class="pre">es</span></code>, <code class="docutils literal notranslate"><span class="pre">o</span></code>, <code class="docutils literal notranslate"><span class="pre">Q</span></code>, <code class="docutils literal notranslate"><span class="pre">Z</span></code>, <code class="docutils literal notranslate"><span class="pre">Zy</span></code>: A memory address operand, currently
+treated the same as <code class="docutils literal notranslate"><span class="pre">m</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>: A 32 or 64-bit integer register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">b</span></code>: A 32 or 64-bit integer register, excluding <code class="docutils literal notranslate"><span class="pre">R0</span></code> (that is:
+<code class="docutils literal notranslate"><span class="pre">R1-R31</span></code>).</li>
+<li><code class="docutils literal notranslate"><span class="pre">f</span></code>: A 32 or 64-bit float register (<code class="docutils literal notranslate"><span class="pre">F0-F31</span></code>), or when QPX is enabled, a
+128 or 256-bit QPX register (<code class="docutils literal notranslate"><span class="pre">Q0-Q31</span></code>; aliases the <code class="docutils literal notranslate"><span class="pre">F</span></code> registers).</li>
+<li><code class="docutils literal notranslate"><span class="pre">v</span></code>: For <code class="docutils literal notranslate"><span class="pre">4</span> <span class="pre">x</span> <span class="pre">f32</span></code> or <code class="docutils literal notranslate"><span class="pre">4</span> <span class="pre">x</span> <span class="pre">f64</span></code> types, when QPX is enabled, a
+128 or 256-bit QPX register (<code class="docutils literal notranslate"><span class="pre">Q0-Q31</span></code>), otherwise a 128-bit
+altivec vector register (<code class="docutils literal notranslate"><span class="pre">V0-V31</span></code>).</li>
+<li><code class="docutils literal notranslate"><span class="pre">y</span></code>: Condition register (<code class="docutils literal notranslate"><span class="pre">CR0-CR7</span></code>).</li>
+<li><code class="docutils literal notranslate"><span class="pre">wc</span></code>: An individual CR bit in a CR register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">wa</span></code>, <code class="docutils literal notranslate"><span class="pre">wd</span></code>, <code class="docutils literal notranslate"><span class="pre">wf</span></code>: Any 128-bit VSX vector register, from the full VSX
+register set (overlapping both the floating-point and vector register files).</li>
+<li><code class="docutils literal notranslate"><span class="pre">ws</span></code>: A 32 or 64-bit floating-point register, from the full VSX register
+set.</li>
+</ul>
+<p>Sparc:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">I</span></code>: An immediate 13-bit signed integer.</li>
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>: A 32-bit integer register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">f</span></code>: Any floating-point register on SparcV8, or a floating-point
+register in the âlowâ half of the registers on SparcV9.</li>
+<li><code class="docutils literal notranslate"><span class="pre">e</span></code>: Any floating-point register. (Same as <code class="docutils literal notranslate"><span class="pre">f</span></code> on SparcV8.)</li>
+</ul>
+<p>SystemZ:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">I</span></code>: An immediate unsigned 8-bit integer.</li>
+<li><code class="docutils literal notranslate"><span class="pre">J</span></code>: An immediate unsigned 12-bit integer.</li>
+<li><code class="docutils literal notranslate"><span class="pre">K</span></code>: An immediate signed 16-bit integer.</li>
+<li><code class="docutils literal notranslate"><span class="pre">L</span></code>: An immediate signed 20-bit integer.</li>
+<li><code class="docutils literal notranslate"><span class="pre">M</span></code>: An immediate integer 0x7fffffff.</li>
+<li><code class="docutils literal notranslate"><span class="pre">Q</span></code>: A memory address operand with a base address and a 12-bit immediate
+unsigned displacement.</li>
+<li><code class="docutils literal notranslate"><span class="pre">R</span></code>: A memory address operand with a base address, a 12-bit immediate
+unsigned displacement, and an index register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">S</span></code>: A memory address operand with a base address and a 20-bit immediate
+signed displacement.</li>
+<li><code class="docutils literal notranslate"><span class="pre">T</span></code>: A memory address operand with a base address, a 20-bit immediate
+signed displacement, and an index register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code> or <code class="docutils literal notranslate"><span class="pre">d</span></code>: A 32, 64, or 128-bit integer register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">a</span></code>: A 32, 64, or 128-bit integer address register (excludes R0, which in an
+address context evaluates as zero).</li>
+<li><code class="docutils literal notranslate"><span class="pre">h</span></code>: A 32-bit value in the high part of a 64bit data register
+(LLVM-specific)</li>
+<li><code class="docutils literal notranslate"><span class="pre">f</span></code>: A 32, 64, or 128-bit floating-point register.</li>
+</ul>
+<p>X86:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">I</span></code>: An immediate integer between 0 and 31.</li>
+<li><code class="docutils literal notranslate"><span class="pre">J</span></code>: An immediate integer between 0 and 64.</li>
+<li><code class="docutils literal notranslate"><span class="pre">K</span></code>: An immediate signed 8-bit integer.</li>
+<li><code class="docutils literal notranslate"><span class="pre">L</span></code>: An immediate integer, 0xff or 0xffff or (in 64-bit mode only)
+0xffffffff.</li>
+<li><code class="docutils literal notranslate"><span class="pre">M</span></code>: An immediate integer between 0 and 3.</li>
+<li><code class="docutils literal notranslate"><span class="pre">N</span></code>: An immediate unsigned 8-bit integer.</li>
+<li><code class="docutils literal notranslate"><span class="pre">O</span></code>: An immediate integer between 0 and 127.</li>
+<li><code class="docutils literal notranslate"><span class="pre">e</span></code>: An immediate 32-bit signed integer.</li>
+<li><code class="docutils literal notranslate"><span class="pre">Z</span></code>: An immediate 32-bit unsigned integer.</li>
+<li><code class="docutils literal notranslate"><span class="pre">o</span></code>, <code class="docutils literal notranslate"><span class="pre">v</span></code>: Treated the same as <code class="docutils literal notranslate"><span class="pre">m</span></code>, at the moment.</li>
+<li><code class="docutils literal notranslate"><span class="pre">q</span></code>: An 8, 16, 32, or 64-bit register which can be accessed as an 8-bit
+<code class="docutils literal notranslate"><span class="pre">l</span></code> integer register. On X86-32, this is the <code class="docutils literal notranslate"><span class="pre">a</span></code>, <code class="docutils literal notranslate"><span class="pre">b</span></code>, <code class="docutils literal notranslate"><span class="pre">c</span></code>, and <code class="docutils literal notranslate"><span class="pre">d</span></code>
+registers, and on X86-64, it is all of the integer registers.</li>
+<li><code class="docutils literal notranslate"><span class="pre">Q</span></code>: An 8, 16, 32, or 64-bit register which can be accessed as an 8-bit
+<code class="docutils literal notranslate"><span class="pre">h</span></code> integer register. This is the <code class="docutils literal notranslate"><span class="pre">a</span></code>, <code class="docutils literal notranslate"><span class="pre">b</span></code>, <code class="docutils literal notranslate"><span class="pre">c</span></code>, and <code class="docutils literal notranslate"><span class="pre">d</span></code> registers.</li>
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code> or <code class="docutils literal notranslate"><span class="pre">l</span></code>: An 8, 16, 32, or 64-bit integer register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">R</span></code>: An 8, 16, 32, or 64-bit âlegacyâ integer register â one which has
+existed since i386, and can be accessed without the REX prefix.</li>
+<li><code class="docutils literal notranslate"><span class="pre">f</span></code>: A 32, 64, or 80-bit â387 FPU stack pseudo-register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">y</span></code>: A 64-bit MMX register, if MMX is enabled.</li>
+<li><code class="docutils literal notranslate"><span class="pre">x</span></code>: If SSE is enabled: a 32 or 64-bit scalar operand, or 128-bit vector
+operand in a SSE register. If AVX is also enabled, can also be a 256-bit
+vector operand in an AVX register. If AVX-512 is also enabled, can also be a
+512-bit vector operand in an AVX512 register, Otherwise, an error.</li>
+<li><code class="docutils literal notranslate"><span class="pre">Y</span></code>: The same as <code class="docutils literal notranslate"><span class="pre">x</span></code>, if <em>SSE2</em> is enabled, otherwise an error.</li>
+<li><code class="docutils literal notranslate"><span class="pre">A</span></code>: Special case: allocates EAX first, then EDX, for a single operand (in
+32-bit mode, a 64-bit integer operand will get split into two registers). It
+is not recommended to use this constraint, as in 64-bit mode, the 64-bit
+operand will get allocated only to RAX â if two 32-bit operands are needed,
+youâre better off splitting it yourself, before passing it to the asm
+statement.</li>
+</ul>
+<p>XCore:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>: A 32-bit integer register.</li>
+</ul>
+</div>
+</div>
+<div class="section" id="asm-template-argument-modifiers">
+<span id="inline-asm-modifiers"></span><h4><a class="toc-backref" href="#id1024">Asm template argument modifiers</a><a class="headerlink" href="#asm-template-argument-modifiers" title="Permalink to this headline">¶</a></h4>
+<p>In the asm template string, modifiers can be used on the operand reference, like
+â<code class="docutils literal notranslate"><span class="pre">${0:n}</span></code>â.</p>
+<p>The modifiers are, in general, expected to behave the same way they do in
+GCC. LLVMâs support is often implemented on an âas-neededâ basis, to support C
+inline asm code which was supported by GCC. A mismatch in behavior between LLVM
+and GCC likely indicates a bug in LLVM.</p>
+<p>Target-independent:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">c</span></code>: Print an immediate integer constant unadorned, without
+the target-specific immediate punctuation (e.g. no <code class="docutils literal notranslate"><span class="pre">$</span></code> prefix).</li>
+<li><code class="docutils literal notranslate"><span class="pre">n</span></code>: Negate and print immediate integer constant unadorned, without the
+target-specific immediate punctuation (e.g. no <code class="docutils literal notranslate"><span class="pre">$</span></code> prefix).</li>
+<li><code class="docutils literal notranslate"><span class="pre">l</span></code>: Print as an unadorned label, without the target-specific label
+punctuation (e.g. no <code class="docutils literal notranslate"><span class="pre">$</span></code> prefix).</li>
+</ul>
+<p>AArch64:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">w</span></code>: Print a GPR register with a <code class="docutils literal notranslate"><span class="pre">w*</span></code> name instead of <code class="docutils literal notranslate"><span class="pre">x*</span></code> name. E.g.,
+instead of <code class="docutils literal notranslate"><span class="pre">x30</span></code>, print <code class="docutils literal notranslate"><span class="pre">w30</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">x</span></code>: Print a GPR register with a <code class="docutils literal notranslate"><span class="pre">x*</span></code> name. (this is the default, anyhow).</li>
+<li><code class="docutils literal notranslate"><span class="pre">b</span></code>, <code class="docutils literal notranslate"><span class="pre">h</span></code>, <code class="docutils literal notranslate"><span class="pre">s</span></code>, <code class="docutils literal notranslate"><span class="pre">d</span></code>, <code class="docutils literal notranslate"><span class="pre">q</span></code>: Print a floating-point/SIMD register with a
+<code class="docutils literal notranslate"><span class="pre">b*</span></code>, <code class="docutils literal notranslate"><span class="pre">h*</span></code>, <code class="docutils literal notranslate"><span class="pre">s*</span></code>, <code class="docutils literal notranslate"><span class="pre">d*</span></code>, or <code class="docutils literal notranslate"><span class="pre">q*</span></code> name, rather than the default of
+<code class="docutils literal notranslate"><span class="pre">v*</span></code>.</li>
+</ul>
+<p>AMDGPU:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>: No effect.</li>
+</ul>
+<p>ARM:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">a</span></code>: Print an operand as an address (with <code class="docutils literal notranslate"><span class="pre">[</span></code> and <code class="docutils literal notranslate"><span class="pre">]</span></code> surrounding a
+register).</li>
+<li><code class="docutils literal notranslate"><span class="pre">P</span></code>: No effect.</li>
+<li><code class="docutils literal notranslate"><span class="pre">q</span></code>: No effect.</li>
+<li><code class="docutils literal notranslate"><span class="pre">y</span></code>: Print a VFP single-precision register as an indexed double (e.g. print
+as <code class="docutils literal notranslate"><span class="pre">d4[1]</span></code> instead of <code class="docutils literal notranslate"><span class="pre">s9</span></code>)</li>
+<li><code class="docutils literal notranslate"><span class="pre">B</span></code>: Bitwise invert and print an immediate integer constant without <code class="docutils literal notranslate"><span class="pre">#</span></code>
+prefix.</li>
+<li><code class="docutils literal notranslate"><span class="pre">L</span></code>: Print the low 16-bits of an immediate integer constant.</li>
+<li><code class="docutils literal notranslate"><span class="pre">M</span></code>: Print as a register set suitable for ldm/stm. Also prints <em>all</em>
+register operands subsequent to the specified one (!), so use carefully.</li>
+<li><code class="docutils literal notranslate"><span class="pre">Q</span></code>: Print the low-order register of a register-pair, or the low-order
+register of a two-register operand.</li>
+<li><code class="docutils literal notranslate"><span class="pre">R</span></code>: Print the high-order register of a register-pair, or the high-order
+register of a two-register operand.</li>
+<li><code class="docutils literal notranslate"><span class="pre">H</span></code>: Print the second register of a register-pair. (On a big-endian system,
+<code class="docutils literal notranslate"><span class="pre">H</span></code> is equivalent to <code class="docutils literal notranslate"><span class="pre">Q</span></code>, and on little-endian system, <code class="docutils literal notranslate"><span class="pre">H</span></code> is equivalent
+to <code class="docutils literal notranslate"><span class="pre">R</span></code>.)</li>
+<li><code class="docutils literal notranslate"><span class="pre">e</span></code>: Print the low doubleword register of a NEON quad register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">f</span></code>: Print the high doubleword register of a NEON quad register.</li>
+<li><code class="docutils literal notranslate"><span class="pre">m</span></code>: Print the base register of a memory operand without the <code class="docutils literal notranslate"><span class="pre">[</span></code> and <code class="docutils literal notranslate"><span class="pre">]</span></code>
+adornment.</li>
+</ul>
+<p>Hexagon:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">L</span></code>: Print the second register of a two-register operand. Requires that it
+has been allocated consecutively to the first.</li>
+<li><code class="docutils literal notranslate"><span class="pre">I</span></code>: Print the letter âiâ if the operand is an integer constant, otherwise
+nothing. Used to print âaddiâ vs âaddâ instructions.</li>
+</ul>
+<p>MSP430:</p>
+<p>No additional modifiers.</p>
+<p>MIPS:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">X</span></code>: Print an immediate integer as hexadecimal</li>
+<li><code class="docutils literal notranslate"><span class="pre">x</span></code>: Print the low 16 bits of an immediate integer as hexadecimal.</li>
+<li><code class="docutils literal notranslate"><span class="pre">d</span></code>: Print an immediate integer as decimal.</li>
+<li><code class="docutils literal notranslate"><span class="pre">m</span></code>: Subtract one and print an immediate integer as decimal.</li>
+<li><code class="docutils literal notranslate"><span class="pre">z</span></code>: Print $0 if an immediate zero, otherwise print normally.</li>
+<li><code class="docutils literal notranslate"><span class="pre">L</span></code>: Print the low-order register of a two-register operand, or prints the
+address of the low-order word of a double-word memory operand.</li>
+<li><code class="docutils literal notranslate"><span class="pre">M</span></code>: Print the high-order register of a two-register operand, or prints the
+address of the high-order word of a double-word memory operand.</li>
+<li><code class="docutils literal notranslate"><span class="pre">D</span></code>: Print the second register of a two-register operand, or prints the
+second word of a double-word memory operand. (On a big-endian system, <code class="docutils literal notranslate"><span class="pre">D</span></code> is
+equivalent to <code class="docutils literal notranslate"><span class="pre">L</span></code>, and on little-endian system, <code class="docutils literal notranslate"><span class="pre">D</span></code> is equivalent to
+<code class="docutils literal notranslate"><span class="pre">M</span></code>.)</li>
+<li><code class="docutils literal notranslate"><span class="pre">w</span></code>: No effect. Provided for compatibility with GCC which requires this
+modifier in order to print MSA registers (<code class="docutils literal notranslate"><span class="pre">W0-W31</span></code>) with the <code class="docutils literal notranslate"><span class="pre">f</span></code>
+constraint.</li>
+</ul>
+<p>NVPTX:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>: No effect.</li>
+</ul>
+<p>PowerPC:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">L</span></code>: Print the second register of a two-register operand. Requires that it
+has been allocated consecutively to the first.</li>
+<li><code class="docutils literal notranslate"><span class="pre">I</span></code>: Print the letter âiâ if the operand is an integer constant, otherwise
+nothing. Used to print âaddiâ vs âaddâ instructions.</li>
+<li><code class="docutils literal notranslate"><span class="pre">y</span></code>: For a memory operand, prints formatter for a two-register X-form
+instruction. (Currently always prints <code class="docutils literal notranslate"><span class="pre">r0,OPERAND</span></code>).</li>
+<li><code class="docutils literal notranslate"><span class="pre">U</span></code>: Prints âuâ if the memory operand is an update form, and nothing
+otherwise. (NOTE: LLVM does not support update form, so this will currently
+always print nothing)</li>
+<li><code class="docutils literal notranslate"><span class="pre">X</span></code>: Prints âxâ if the memory operand is an indexed form. (NOTE: LLVM does
+not support indexed form, so this will currently always print nothing)</li>
+</ul>
+<p>Sparc:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">r</span></code>: No effect.</li>
+</ul>
+<p>SystemZ:</p>
+<p>SystemZ implements only <code class="docutils literal notranslate"><span class="pre">n</span></code>, and does <em>not</em> support any of the other
+target-independent modifiers.</p>
+<p>X86:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">c</span></code>: Print an unadorned integer or symbol name. (The latter is
+target-specific behavior for this typically target-independent modifier).</li>
+<li><code class="docutils literal notranslate"><span class="pre">A</span></code>: Print a register name with a â<code class="docutils literal notranslate"><span class="pre">*</span></code>â before it.</li>
+<li><code class="docutils literal notranslate"><span class="pre">b</span></code>: Print an 8-bit register name (e.g. <code class="docutils literal notranslate"><span class="pre">al</span></code>); do nothing on a memory
+operand.</li>
+<li><code class="docutils literal notranslate"><span class="pre">h</span></code>: Print the upper 8-bit register name (e.g. <code class="docutils literal notranslate"><span class="pre">ah</span></code>); do nothing on a
+memory operand.</li>
+<li><code class="docutils literal notranslate"><span class="pre">w</span></code>: Print the 16-bit register name (e.g. <code class="docutils literal notranslate"><span class="pre">ax</span></code>); do nothing on a memory
+operand.</li>
+<li><code class="docutils literal notranslate"><span class="pre">k</span></code>: Print the 32-bit register name (e.g. <code class="docutils literal notranslate"><span class="pre">eax</span></code>); do nothing on a memory
+operand.</li>
+<li><code class="docutils literal notranslate"><span class="pre">q</span></code>: Print the 64-bit register name (e.g. <code class="docutils literal notranslate"><span class="pre">rax</span></code>), if 64-bit registers are
+available, otherwise the 32-bit register name; do nothing on a memory operand.</li>
+<li><code class="docutils literal notranslate"><span class="pre">n</span></code>: Negate and print an unadorned integer, or, for operands other than an
+immediate integer (e.g. a relocatable symbol expression), print a â-â before
+the operand. (The behavior for relocatable symbol expressions is a
+target-specific behavior for this typically target-independent modifier)</li>
+<li><code class="docutils literal notranslate"><span class="pre">H</span></code>: Print a memory reference with additional offset +8.</li>
+<li><code class="docutils literal notranslate"><span class="pre">P</span></code>: Print a memory reference or operand for use as the argument of a call
+instruction. (E.g. omit <code class="docutils literal notranslate"><span class="pre">(rip)</span></code>, even though itâs PC-relative.)</li>
+</ul>
+<p>XCore:</p>
+<p>No additional modifiers.</p>
+</div>
+<div class="section" id="inline-asm-metadata">
+<h4><a class="toc-backref" href="#id1025">Inline Asm Metadata</a><a class="headerlink" href="#inline-asm-metadata" title="Permalink to this headline">¶</a></h4>
+<p>The call instructions that wrap inline asm nodes may have a
+â<code class="docutils literal notranslate"><span class="pre">!srcloc</span></code>â MDNode attached to it that contains a list of constant
+integers. If present, the code generator will use the integer as the
+location cookie value when report errors through the <code class="docutils literal notranslate"><span class="pre">LLVMContext</span></code>
+error reporting mechanisms. This allows a front-end to correlate backend
+errors that occur with inline asm back to the source code that produced
+it. For example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">call</span> <span class="kt">void</span> <span class="k">asm</span> <span class="k">sideeffect</span> <span class="s">"something bad"</span><span class="p">,</span> <span class="s">""</span><span class="p">(),</span> <span class="nv">!srcloc</span> <span class="nv nv-Anonymous">!42</span>
+<span class="p">...</span>
+<span class="nv nv-Anonymous">!42</span> <span class="p">=</span> <span class="p">!{</span> <span class="k">i32</span> <span class="m">1234567</span> <span class="p">}</span>
+</pre></div>
+</div>
+<p>It is up to the front-end to make sense of the magic numbers it places
+in the IR. If the MDNode contains multiple constants, the code generator
+will use the one that corresponds to the line of the asm that the error
+occurs on.</p>
+</div>
+</div>
+</div>
+<div class="section" id="metadata">
+<span id="id5"></span><h2><a class="toc-backref" href="#id1026">Metadata</a><a class="headerlink" href="#metadata" title="Permalink to this headline">¶</a></h2>
+<p>LLVM IR allows metadata to be attached to instructions in the program
+that can convey extra information about the code to the optimizers and
+code generator. One example application of metadata is source-level
+debug information. There are two metadata primitives: strings and nodes.</p>
+<p>Metadata does not have a type, and is not a value. If referenced from a
+<code class="docutils literal notranslate"><span class="pre">call</span></code> instruction, it uses the <code class="docutils literal notranslate"><span class="pre">metadata</span></code> type.</p>
+<p>All metadata are identified in syntax by a exclamation point (â<code class="docutils literal notranslate"><span class="pre">!</span></code>â).</p>
+<div class="section" id="metadata-nodes-and-metadata-strings">
+<span id="metadata-string"></span><h3><a class="toc-backref" href="#id1027">Metadata Nodes and Metadata Strings</a><a class="headerlink" href="#metadata-nodes-and-metadata-strings" title="Permalink to this headline">¶</a></h3>
+<p>A metadata string is a string surrounded by double quotes. It can
+contain any character by escaping non-printable characters with
+â<code class="docutils literal notranslate"><span class="pre">\xx</span></code>â where â<code class="docutils literal notranslate"><span class="pre">xx</span></code>â is the two digit hex code. For example:
+â<code class="docutils literal notranslate"><span class="pre">!"test\00"</span></code>â.</p>
+<p>Metadata nodes are represented with notation similar to structure
+constants (a comma separated list of elements, surrounded by braces and
+preceded by an exclamation point). Metadata nodes can have any values as
+their operand. For example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="p">!{</span> <span class="nv">!"test\00"</span><span class="p">,</span> <span class="k">i32</span> <span class="m">10</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>Metadata nodes that arenât uniqued use the <code class="docutils literal notranslate"><span class="pre">distinct</span></code> keyword. For example:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = distinct !{!"test\00", i32 10}
+</pre></div>
+</div>
+<p><code class="docutils literal notranslate"><span class="pre">distinct</span></code> nodes are useful when nodes shouldnât be merged based on their
+content. They can also occur when transformations cause uniquing collisions
+when metadata operands change.</p>
+<p>A <a class="reference internal" href="#namedmetadatastructure"><span class="std std-ref">named metadata</span></a> is a collection of
+metadata nodes, which can be looked up in the module symbol table. For
+example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">!foo</span> <span class="p">=</span> <span class="p">!{</span><span class="nv nv-Anonymous">!4</span><span class="p">,</span> <span class="nv nv-Anonymous">!3</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>Metadata can be used as function arguments. Here the <code class="docutils literal notranslate"><span class="pre">llvm.dbg.value</span></code>
+intrinsic is using three metadata arguments:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">call</span> <span class="kt">void</span> <span class="vg">@llvm.dbg.value</span><span class="p">(</span><span class="kt">metadata</span> <span class="nv nv-Anonymous">!24</span><span class="p">,</span> <span class="kt">metadata</span> <span class="nv nv-Anonymous">!25</span><span class="p">,</span> <span class="kt">metadata</span> <span class="nv nv-Anonymous">!26</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>Metadata can be attached to an instruction. Here metadata <code class="docutils literal notranslate"><span class="pre">!21</span></code> is attached
+to the <code class="docutils literal notranslate"><span class="pre">add</span></code> instruction using the <code class="docutils literal notranslate"><span class="pre">!dbg</span></code> identifier:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%indvar.next</span> <span class="p">=</span> <span class="k">add</span> <span class="k">i64</span> <span class="nv">%indvar</span><span class="p">,</span> <span class="m">1</span><span class="p">,</span> <span class="nv">!dbg</span> <span class="nv nv-Anonymous">!21</span>
+</pre></div>
+</div>
+<p>Metadata can also be attached to a function or a global variable. Here metadata
+<code class="docutils literal notranslate"><span class="pre">!22</span></code> is attached to the <code class="docutils literal notranslate"><span class="pre">f1</span></code> and <code class="docutils literal notranslate"><span class="pre">f2</span> <span class="pre">functions,</span> <span class="pre">and</span> <span class="pre">the</span> <span class="pre">globals</span> <span class="pre">``g1</span></code>
+and <code class="docutils literal notranslate"><span class="pre">g2</span></code> using the <code class="docutils literal notranslate"><span class="pre">!dbg</span></code> identifier:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">declare</span> <span class="nv">!dbg</span> <span class="nv nv-Anonymous">!22</span> <span class="kt">void</span> <span class="vg">@f1</span><span class="p">()</span>
+<span class="k">define</span> <span class="kt">void</span> <span class="vg">@f2</span><span class="p">()</span> <span class="nv">!dbg</span> <span class="nv nv-Anonymous">!22</span> <span class="p">{</span>
+ <span class="k">ret</span> <span class="kt">void</span>
+<span class="p">}</span>
+
+<span class="vg">@g1</span> <span class="p">=</span> <span class="k">global</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="nv">!dbg</span> <span class="nv nv-Anonymous">!22</span>
+<span class="vg">@g2</span> <span class="p">=</span> <span class="k">external</span> <span class="k">global</span> <span class="k">i32</span><span class="p">,</span> <span class="nv">!dbg</span> <span class="nv nv-Anonymous">!22</span>
+</pre></div>
+</div>
+<p>A transformation is required to drop any metadata attachment that it does not
+know or know it canât preserve. Currently there is an exception for metadata
+attachment to globals for <code class="docutils literal notranslate"><span class="pre">!type</span></code> and <code class="docutils literal notranslate"><span class="pre">!absolute_symbol</span></code> which canât be
+unconditionally dropped unless the global is itself deleted.</p>
+<p>Metadata attached to a module using named metadata may not be dropped, with
+the exception of debug metadata (named metadata with the name <code class="docutils literal notranslate"><span class="pre">!llvm.dbg.*</span></code>).</p>
+<p>More information about specific metadata nodes recognized by the
+optimizers and code generator is found below.</p>
+<div class="section" id="specialized-metadata-nodes">
+<span id="specialized-metadata"></span><h4><a class="toc-backref" href="#id1028">Specialized Metadata Nodes</a><a class="headerlink" href="#specialized-metadata-nodes" title="Permalink to this headline">¶</a></h4>
+<p>Specialized metadata nodes are custom data structures in metadata (as opposed
+to generic tuples). Their fields are labelled, and can be specified in any
+order.</p>
+<p>These arenât inherently debug info centric, but currently all the specialized
+metadata nodes are related to debug info.</p>
+<div class="section" id="dicompileunit">
+<span id="id6"></span><h5><a class="toc-backref" href="#id1029">DICompileUnit</a><a class="headerlink" href="#dicompileunit" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DICompileUnit</span></code> nodes represent a compile unit. The <code class="docutils literal notranslate"><span class="pre">enums:</span></code>,
+<code class="docutils literal notranslate"><span class="pre">retainedTypes:</span></code>, <code class="docutils literal notranslate"><span class="pre">globals:</span></code>, <code class="docutils literal notranslate"><span class="pre">imports:</span></code> and <code class="docutils literal notranslate"><span class="pre">macros:</span></code> fields are tuples
+containing the debug info to be emitted along with the compile unit, regardless
+of code optimizations (some nodes are only emitted if there are references to
+them from instructions). The <code class="docutils literal notranslate"><span class="pre">debugInfoForProfiling:</span></code> field is a boolean
+indicating whether or not line-table discriminators are updated to provide
+more-accurate debug info for profiling results.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !DICompileUnit(language: DW_LANG_C99, file: !1, producer: "clang",
+ isOptimized: true, flags: "-O2", runtimeVersion: 2,
+ splitDebugFilename: "abc.debug", emissionKind: FullDebug,
+ enums: !2, retainedTypes: !3, globals: !4, imports: !5,
+ macros: !6, dwoId: 0x0abcd)
+</pre></div>
+</div>
+<p>Compile unit descriptors provide the root scope for objects declared in a
+specific compilation unit. File descriptors are defined using this scope. These
+descriptors are collected by a named metadata node <code class="docutils literal notranslate"><span class="pre">!llvm.dbg.cu</span></code>. They keep
+track of global variables, type information, and imported entities (declarations
+and namespaces).</p>
+</div>
+<div class="section" id="difile">
+<span id="id7"></span><h5><a class="toc-backref" href="#id1030">DIFile</a><a class="headerlink" href="#difile" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DIFile</span></code> nodes represent files. The <code class="docutils literal notranslate"><span class="pre">filename:</span></code> can include slashes.</p>
+<div class="highlight-none notranslate"><div class="highlight"><pre><span></span>!0 = !DIFile(filename: "path/to/file", directory: "/path/to/dir",
+ checksumkind: CSK_MD5,
+ checksum: "000102030405060708090a0b0c0d0e0f")
+</pre></div>
+</div>
+<p>Files are sometimes used in <code class="docutils literal notranslate"><span class="pre">scope:</span></code> fields, and are the only valid target
+for <code class="docutils literal notranslate"><span class="pre">file:</span></code> fields.
+Valid values for <code class="docutils literal notranslate"><span class="pre">checksumkind:</span></code> field are: {CSK_None, CSK_MD5, CSK_SHA1}</p>
+</div>
+<div class="section" id="dibasictype">
+<span id="id8"></span><h5><a class="toc-backref" href="#id1031">DIBasicType</a><a class="headerlink" href="#dibasictype" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DIBasicType</span></code> nodes represent primitive types, such as <code class="docutils literal notranslate"><span class="pre">int</span></code>, <code class="docutils literal notranslate"><span class="pre">bool</span></code> and
+<code class="docutils literal notranslate"><span class="pre">float</span></code>. <code class="docutils literal notranslate"><span class="pre">tag:</span></code> defaults to <code class="docutils literal notranslate"><span class="pre">DW_TAG_base_type</span></code>.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !DIBasicType(name: "unsigned char", size: 8, align: 8,
+ encoding: DW_ATE_unsigned_char)
+!1 = !DIBasicType(tag: DW_TAG_unspecified_type, name: "decltype(nullptr)")
+</pre></div>
+</div>
+<p>The <code class="docutils literal notranslate"><span class="pre">encoding:</span></code> describes the details of the type. Usually itâs one of the
+following:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>DW_ATE_address = 1
+DW_ATE_boolean = 2
+DW_ATE_float = 4
+DW_ATE_signed = 5
+DW_ATE_signed_char = 6
+DW_ATE_unsigned = 7
+DW_ATE_unsigned_char = 8
+</pre></div>
+</div>
+</div>
+<div class="section" id="disubroutinetype">
+<span id="id9"></span><h5><a class="toc-backref" href="#id1032">DISubroutineType</a><a class="headerlink" href="#disubroutinetype" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DISubroutineType</span></code> nodes represent subroutine types. Their <code class="docutils literal notranslate"><span class="pre">types:</span></code> field
+refers to a tuple; the first operand is the return type, while the rest are the
+types of the formal arguments in order. If the first operand is <code class="docutils literal notranslate"><span class="pre">null</span></code>, that
+represents a function with no return value (such as <code class="docutils literal notranslate"><span class="pre">void</span> <span class="pre">foo()</span> <span class="pre">{}</span></code> in C++).</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !BasicType(name: "int", size: 32, align: 32, DW_ATE_signed)
+!1 = !BasicType(name: "char", size: 8, align: 8, DW_ATE_signed_char)
+!2 = !DISubroutineType(types: !{null, !0, !1}) ; void (int, char)
+</pre></div>
+</div>
+</div>
+<div class="section" id="diderivedtype">
+<span id="id10"></span><h5><a class="toc-backref" href="#id1033">DIDerivedType</a><a class="headerlink" href="#diderivedtype" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DIDerivedType</span></code> nodes represent types derived from other types, such as
+qualified types.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !DIBasicType(name: "unsigned char", size: 8, align: 8,
+ encoding: DW_ATE_unsigned_char)
+!1 = !DIDerivedType(tag: DW_TAG_pointer_type, baseType: !0, size: 32,
+ align: 32)
+</pre></div>
+</div>
+<p>The following <code class="docutils literal notranslate"><span class="pre">tag:</span></code> values are valid:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>DW_TAG_member = 13
+DW_TAG_pointer_type = 15
+DW_TAG_reference_type = 16
+DW_TAG_typedef = 22
+DW_TAG_inheritance = 28
+DW_TAG_ptr_to_member_type = 31
+DW_TAG_const_type = 38
+DW_TAG_friend = 42
+DW_TAG_volatile_type = 53
+DW_TAG_restrict_type = 55
+DW_TAG_atomic_type = 71
+</pre></div>
+</div>
+<p id="diderivedtypemember"><code class="docutils literal notranslate"><span class="pre">DW_TAG_member</span></code> is used to define a member of a <a class="reference internal" href="#dicompositetype"><span class="std std-ref">composite type</span></a>. The type of the member is the <code class="docutils literal notranslate"><span class="pre">baseType:</span></code>. The
+<code class="docutils literal notranslate"><span class="pre">offset:</span></code> is the memberâs bit offset. If the composite type has an ODR
+<code class="docutils literal notranslate"><span class="pre">identifier:</span></code> and does not set <code class="docutils literal notranslate"><span class="pre">flags:</span> <span class="pre">DIFwdDecl</span></code>, then the member is
+uniqued based only on its <code class="docutils literal notranslate"><span class="pre">name:</span></code> and <code class="docutils literal notranslate"><span class="pre">scope:</span></code>.</p>
+<p><code class="docutils literal notranslate"><span class="pre">DW_TAG_inheritance</span></code> and <code class="docutils literal notranslate"><span class="pre">DW_TAG_friend</span></code> are used in the <code class="docutils literal notranslate"><span class="pre">elements:</span></code>
+field of <a class="reference internal" href="#dicompositetype"><span class="std std-ref">composite types</span></a> to describe parents and
+friends.</p>
+<p><code class="docutils literal notranslate"><span class="pre">DW_TAG_typedef</span></code> is used to provide a name for the <code class="docutils literal notranslate"><span class="pre">baseType:</span></code>.</p>
+<p><code class="docutils literal notranslate"><span class="pre">DW_TAG_pointer_type</span></code>, <code class="docutils literal notranslate"><span class="pre">DW_TAG_reference_type</span></code>, <code class="docutils literal notranslate"><span class="pre">DW_TAG_const_type</span></code>,
+<code class="docutils literal notranslate"><span class="pre">DW_TAG_volatile_type</span></code>, <code class="docutils literal notranslate"><span class="pre">DW_TAG_restrict_type</span></code> and <code class="docutils literal notranslate"><span class="pre">DW_TAG_atomic_type</span></code>
+are used to qualify the <code class="docutils literal notranslate"><span class="pre">baseType:</span></code>.</p>
+<p>Note that the <code class="docutils literal notranslate"><span class="pre">void</span> <span class="pre">*</span></code> type is expressed as a type derived from NULL.</p>
+</div>
+<div class="section" id="dicompositetype">
+<span id="id11"></span><h5><a class="toc-backref" href="#id1034">DICompositeType</a><a class="headerlink" href="#dicompositetype" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DICompositeType</span></code> nodes represent types composed of other types, like
+structures and unions. <code class="docutils literal notranslate"><span class="pre">elements:</span></code> points to a tuple of the composed types.</p>
+<p>If the source language supports ODR, the <code class="docutils literal notranslate"><span class="pre">identifier:</span></code> field gives the unique
+identifier used for type merging between modules. When specified,
+<a class="reference internal" href="#disubprogramdeclaration"><span class="std std-ref">subprogram declarations</span></a> and <a class="reference internal" href="#diderivedtypemember"><span class="std std-ref">member
+derived types</span></a> that reference the ODR-type in their
+<code class="docutils literal notranslate"><span class="pre">scope:</span></code> change uniquing rules.</p>
+<p>For a given <code class="docutils literal notranslate"><span class="pre">identifier:</span></code>, there should only be a single composite type that
+does not have <code class="docutils literal notranslate"><span class="pre">flags:</span> <span class="pre">DIFlagFwdDecl</span></code> set. LLVM tools that link modules
+together will unique such definitions at parse time via the <code class="docutils literal notranslate"><span class="pre">identifier:</span></code>
+field, even if the nodes are <code class="docutils literal notranslate"><span class="pre">distinct</span></code>.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !DIEnumerator(name: "SixKind", value: 7)
+!1 = !DIEnumerator(name: "SevenKind", value: 7)
+!2 = !DIEnumerator(name: "NegEightKind", value: -8)
+!3 = !DICompositeType(tag: DW_TAG_enumeration_type, name: "Enum", file: !12,
+ line: 2, size: 32, align: 32, identifier: "_M4Enum",
+ elements: !{!0, !1, !2})
+</pre></div>
+</div>
+<p>The following <code class="docutils literal notranslate"><span class="pre">tag:</span></code> values are valid:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>DW_TAG_array_type = 1
+DW_TAG_class_type = 2
+DW_TAG_enumeration_type = 4
+DW_TAG_structure_type = 19
+DW_TAG_union_type = 23
+</pre></div>
+</div>
+<p>For <code class="docutils literal notranslate"><span class="pre">DW_TAG_array_type</span></code>, the <code class="docutils literal notranslate"><span class="pre">elements:</span></code> should be <a class="reference internal" href="#disubrange"><span class="std std-ref">subrange
+descriptors</span></a>, each representing the range of subscripts at that
+level of indexing. The <code class="docutils literal notranslate"><span class="pre">DIFlagVector</span></code> flag to <code class="docutils literal notranslate"><span class="pre">flags:</span></code> indicates that an
+array type is a native packed vector.</p>
+<p>For <code class="docutils literal notranslate"><span class="pre">DW_TAG_enumeration_type</span></code>, the <code class="docutils literal notranslate"><span class="pre">elements:</span></code> should be <a class="reference internal" href="#dienumerator"><span class="std std-ref">enumerator
+descriptors</span></a>, each representing the definition of an enumeration
+value for the set. All enumeration type descriptors are collected in the
+<code class="docutils literal notranslate"><span class="pre">enums:</span></code> field of the <a class="reference internal" href="#dicompileunit"><span class="std std-ref">compile unit</span></a>.</p>
+<p>For <code class="docutils literal notranslate"><span class="pre">DW_TAG_structure_type</span></code>, <code class="docutils literal notranslate"><span class="pre">DW_TAG_class_type</span></code>, and
+<code class="docutils literal notranslate"><span class="pre">DW_TAG_union_type</span></code>, the <code class="docutils literal notranslate"><span class="pre">elements:</span></code> should be <a class="reference internal" href="#diderivedtype"><span class="std std-ref">derived types</span></a> with <code class="docutils literal notranslate"><span class="pre">tag:</span> <span class="pre">DW_TAG_member</span></code>, <code class="docutils literal notranslate"><span class="pre">tag:</span> <span class="pre">DW_TAG_inheritance</span></code>, or
+<code class="docutils literal notranslate"><span class="pre">tag:</span> <span class="pre">DW_TAG_friend</span></code>; or <a class="reference internal" href="#disubprogram"><span class="std std-ref">subprograms</span></a> with
+<code class="docutils literal notranslate"><span class="pre">isDefinition:</span> <span class="pre">false</span></code>.</p>
+</div>
+<div class="section" id="disubrange">
+<span id="id12"></span><h5><a class="toc-backref" href="#id1035">DISubrange</a><a class="headerlink" href="#disubrange" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DISubrange</span></code> nodes are the elements for <code class="docutils literal notranslate"><span class="pre">DW_TAG_array_type</span></code> variants of
+<a class="reference internal" href="#dicompositetype"><span class="std std-ref">DICompositeType</span></a>.</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">count:</span> <span class="pre">-1</span></code> indicates an empty array.</li>
+<li><code class="docutils literal notranslate"><span class="pre">count:</span> <span class="pre">!9</span></code> describes the count with a <a class="reference internal" href="#dilocalvariable"><span class="std std-ref">DILocalVariable</span></a>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">count:</span> <span class="pre">!11</span></code> describes the count with a <a class="reference internal" href="#diglobalvariable"><span class="std std-ref">DIGlobalVariable</span></a>.</li>
+</ul>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !DISubrange(count: 5, lowerBound: 0) ; array counting from 0
+!1 = !DISubrange(count: 5, lowerBound: 1) ; array counting from 1
+!2 = !DISubrange(count: -1) ; empty array.
+
+; Scopes used in rest of example
+!6 = !DIFile(filename: "vla.c", directory: "/path/to/file")
+!7 = distinct !DICompileUnit(language: DW_LANG_C99, file: !6)
+!8 = distinct !DISubprogram(name: "foo", scope: !7, file: !6, line: 5)
+
+; Use of local variable as count value
+!9 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)
+!10 = !DILocalVariable(name: "count", scope: !8, file: !6, line: 42, type: !9)
+!11 = !DISubrange(count: !10, lowerBound: 0)
+
+; Use of global variable as count value
+!12 = !DIGlobalVariable(name: "count", scope: !8, file: !6, line: 22, type: !9)
+!13 = !DISubrange(count: !12, lowerBound: 0)
+</pre></div>
+</div>
+</div>
+<div class="section" id="dienumerator">
+<span id="id13"></span><h5><a class="toc-backref" href="#id1036">DIEnumerator</a><a class="headerlink" href="#dienumerator" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DIEnumerator</span></code> nodes are the elements for <code class="docutils literal notranslate"><span class="pre">DW_TAG_enumeration_type</span></code>
+variants of <a class="reference internal" href="#dicompositetype"><span class="std std-ref">DICompositeType</span></a>.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !DIEnumerator(name: "SixKind", value: 7)
+!1 = !DIEnumerator(name: "SevenKind", value: 7)
+!2 = !DIEnumerator(name: "NegEightKind", value: -8)
+</pre></div>
+</div>
+</div>
+<div class="section" id="ditemplatetypeparameter">
+<h5><a class="toc-backref" href="#id1037">DITemplateTypeParameter</a><a class="headerlink" href="#ditemplatetypeparameter" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DITemplateTypeParameter</span></code> nodes represent type parameters to generic source
+language constructs. They are used (optionally) in <a class="reference internal" href="#dicompositetype"><span class="std std-ref">DICompositeType</span></a> and
+<a class="reference internal" href="#disubprogram"><span class="std std-ref">DISubprogram</span></a> <code class="docutils literal notranslate"><span class="pre">templateParams:</span></code> fields.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !DITemplateTypeParameter(name: "Ty", type: !1)
+</pre></div>
+</div>
+</div>
+<div class="section" id="ditemplatevalueparameter">
+<h5><a class="toc-backref" href="#id1038">DITemplateValueParameter</a><a class="headerlink" href="#ditemplatevalueparameter" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DITemplateValueParameter</span></code> nodes represent value parameters to generic source
+language constructs. <code class="docutils literal notranslate"><span class="pre">tag:</span></code> defaults to <code class="docutils literal notranslate"><span class="pre">DW_TAG_template_value_parameter</span></code>,
+but if specified can also be set to <code class="docutils literal notranslate"><span class="pre">DW_TAG_GNU_template_template_param</span></code> or
+<code class="docutils literal notranslate"><span class="pre">DW_TAG_GNU_template_param_pack</span></code>. They are used (optionally) in
+<a class="reference internal" href="#dicompositetype"><span class="std std-ref">DICompositeType</span></a> and <a class="reference internal" href="#disubprogram"><span class="std std-ref">DISubprogram</span></a> <code class="docutils literal notranslate"><span class="pre">templateParams:</span></code> fields.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !DITemplateValueParameter(name: "Ty", type: !1, value: i32 7)
+</pre></div>
+</div>
+</div>
+<div class="section" id="dinamespace">
+<h5><a class="toc-backref" href="#id1039">DINamespace</a><a class="headerlink" href="#dinamespace" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DINamespace</span></code> nodes represent namespaces in the source language.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !DINamespace(name: "myawesomeproject", scope: !1, file: !2, line: 7)
+</pre></div>
+</div>
+</div>
+<div class="section" id="diglobalvariable">
+<span id="id14"></span><h5><a class="toc-backref" href="#id1040">DIGlobalVariable</a><a class="headerlink" href="#diglobalvariable" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DIGlobalVariable</span></code> nodes represent global variables in the source language.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !DIGlobalVariable(name: "foo", linkageName: "foo", scope: !1,
+ file: !2, line: 7, type: !3, isLocal: true,
+ isDefinition: false, variable: i32* @foo,
+ declaration: !4)
+</pre></div>
+</div>
+<p>All global variables should be referenced by the <cite>globals:</cite> field of a
+<a class="reference internal" href="#dicompileunit"><span class="std std-ref">compile unit</span></a>.</p>
+</div>
+<div class="section" id="disubprogram">
+<span id="id15"></span><h5><a class="toc-backref" href="#id1041">DISubprogram</a><a class="headerlink" href="#disubprogram" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DISubprogram</span></code> nodes represent functions from the source language. A
+<code class="docutils literal notranslate"><span class="pre">DISubprogram</span></code> may be attached to a function definition using <code class="docutils literal notranslate"><span class="pre">!dbg</span></code>
+metadata. The <code class="docutils literal notranslate"><span class="pre">variables:</span></code> field points at <a class="reference internal" href="#dilocalvariable"><span class="std std-ref">variables</span></a>
+that must be retained, even if their IR counterparts are optimized out of
+the IR. The <code class="docutils literal notranslate"><span class="pre">type:</span></code> field must point at an <a class="reference internal" href="#disubroutinetype"><span class="std std-ref">DISubroutineType</span></a>.</p>
+<p id="disubprogramdeclaration">When <code class="docutils literal notranslate"><span class="pre">isDefinition:</span> <span class="pre">false</span></code>, subprograms describe a declaration in the type
+tree as opposed to a definition of a function. If the scope is a composite
+type with an ODR <code class="docutils literal notranslate"><span class="pre">identifier:</span></code> and that does not set <code class="docutils literal notranslate"><span class="pre">flags:</span> <span class="pre">DIFwdDecl</span></code>,
+then the subprogram declaration is uniqued based only on its <code class="docutils literal notranslate"><span class="pre">linkageName:</span></code>
+and <code class="docutils literal notranslate"><span class="pre">scope:</span></code>.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>define void @_Z3foov() !dbg !0 {
+ ...
+}
+
+!0 = distinct !DISubprogram(name: "foo", linkageName: "_Zfoov", scope: !1,
+ file: !2, line: 7, type: !3, isLocal: true,
+ isDefinition: true, scopeLine: 8,
+ containingType: !4,
+ virtuality: DW_VIRTUALITY_pure_virtual,
+ virtualIndex: 10, flags: DIFlagPrototyped,
+ isOptimized: true, unit: !5, templateParams: !6,
+ declaration: !7, variables: !8, thrownTypes: !9)
+</pre></div>
+</div>
+</div>
+<div class="section" id="dilexicalblock">
+<span id="id16"></span><h5><a class="toc-backref" href="#id1042">DILexicalBlock</a><a class="headerlink" href="#dilexicalblock" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DILexicalBlock</span></code> nodes describe nested blocks within a <a class="reference internal" href="#disubprogram"><span class="std std-ref">subprogram</span></a>. The line number and column numbers are used to distinguish
+two lexical blocks at same depth. They are valid targets for <code class="docutils literal notranslate"><span class="pre">scope:</span></code>
+fields.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = distinct !DILexicalBlock(scope: !1, file: !2, line: 7, column: 35)
+</pre></div>
+</div>
+<p>Usually lexical blocks are <code class="docutils literal notranslate"><span class="pre">distinct</span></code> to prevent node merging based on
+operands.</p>
+</div>
+<div class="section" id="dilexicalblockfile">
+<span id="id17"></span><h5><a class="toc-backref" href="#id1043">DILexicalBlockFile</a><a class="headerlink" href="#dilexicalblockfile" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DILexicalBlockFile</span></code> nodes are used to discriminate between sections of a
+<a class="reference internal" href="#dilexicalblock"><span class="std std-ref">lexical block</span></a>. The <code class="docutils literal notranslate"><span class="pre">file:</span></code> field can be changed to
+indicate textual inclusion, or the <code class="docutils literal notranslate"><span class="pre">discriminator:</span></code> field can be used to
+discriminate between control flow within a single block in the source language.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !DILexicalBlock(scope: !3, file: !4, line: 7, column: 35)
+!1 = !DILexicalBlockFile(scope: !0, file: !4, discriminator: 0)
+!2 = !DILexicalBlockFile(scope: !0, file: !4, discriminator: 1)
+</pre></div>
+</div>
+</div>
+<div class="section" id="dilocation">
+<span id="id18"></span><h5><a class="toc-backref" href="#id1044">DILocation</a><a class="headerlink" href="#dilocation" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DILocation</span></code> nodes represent source debug locations. The <code class="docutils literal notranslate"><span class="pre">scope:</span></code> field is
+mandatory, and points at an <a class="reference internal" href="#dilexicalblockfile"><span class="std std-ref">DILexicalBlockFile</span></a>, an
+<a class="reference internal" href="#dilexicalblock"><span class="std std-ref">DILexicalBlock</span></a>, or an <a class="reference internal" href="#disubprogram"><span class="std std-ref">DISubprogram</span></a>.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !DILocation(line: 2900, column: 42, scope: !1, inlinedAt: !2)
+</pre></div>
+</div>
+</div>
+<div class="section" id="dilocalvariable">
+<span id="id19"></span><h5><a class="toc-backref" href="#id1045">DILocalVariable</a><a class="headerlink" href="#dilocalvariable" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DILocalVariable</span></code> nodes represent local variables in the source language. If
+the <code class="docutils literal notranslate"><span class="pre">arg:</span></code> field is set to non-zero, then this variable is a subprogram
+parameter, and it will be included in the <code class="docutils literal notranslate"><span class="pre">variables:</span></code> field of its
+<a class="reference internal" href="#disubprogram"><span class="std std-ref">DISubprogram</span></a>.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !DILocalVariable(name: "this", arg: 1, scope: !3, file: !2, line: 7,
+ type: !3, flags: DIFlagArtificial)
+!1 = !DILocalVariable(name: "x", arg: 2, scope: !4, file: !2, line: 7,
+ type: !3)
+!2 = !DILocalVariable(name: "y", scope: !5, file: !2, line: 7, type: !3)
+</pre></div>
+</div>
+</div>
+<div class="section" id="diexpression">
+<h5><a class="toc-backref" href="#id1046">DIExpression</a><a class="headerlink" href="#diexpression" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DIExpression</span></code> nodes represent expressions that are inspired by the DWARF
+expression language. They are used in <a class="reference internal" href="#dbg-intrinsics"><span class="std std-ref">debug intrinsics</span></a>
+(such as <code class="docutils literal notranslate"><span class="pre">llvm.dbg.declare</span></code> and <code class="docutils literal notranslate"><span class="pre">llvm.dbg.value</span></code>) to describe how the
+referenced LLVM variable relates to the source language variable. Debug
+intrinsics are interpreted left-to-right: start by pushing the value/address
+operand of the intrinsic onto a stack, then repeatedly push and evaluate
+opcodes from the DIExpression until the final variable description is produced.</p>
+<p>The current supported opcode vocabulary is limited:</p>
+<ul class="simple">
+<li><code class="docutils literal notranslate"><span class="pre">DW_OP_deref</span></code> dereferences the top of the expression stack.</li>
+<li><code class="docutils literal notranslate"><span class="pre">DW_OP_plus</span></code> pops the last two entries from the expression stack, adds
+them together and appends the result to the expression stack.</li>
+<li><code class="docutils literal notranslate"><span class="pre">DW_OP_minus</span></code> pops the last two entries from the expression stack, subtracts
+the last entry from the second last entry and appends the result to the
+expression stack.</li>
+<li><code class="docutils literal notranslate"><span class="pre">DW_OP_plus_uconst,</span> <span class="pre">93</span></code> adds <code class="docutils literal notranslate"><span class="pre">93</span></code> to the working expression.</li>
+<li><code class="docutils literal notranslate"><span class="pre">DW_OP_LLVM_fragment,</span> <span class="pre">16,</span> <span class="pre">8</span></code> specifies the offset and size (<code class="docutils literal notranslate"><span class="pre">16</span></code> and <code class="docutils literal notranslate"><span class="pre">8</span></code>
+here, respectively) of the variable fragment from the working expression. Note
+that contrary to DW_OP_bit_piece, the offset is describing the location
+within the described source variable.</li>
+<li><code class="docutils literal notranslate"><span class="pre">DW_OP_swap</span></code> swaps top two stack entries.</li>
+<li><code class="docutils literal notranslate"><span class="pre">DW_OP_xderef</span></code> provides extended dereference mechanism. The entry at the top
+of the stack is treated as an address. The second stack entry is treated as an
+address space identifier.</li>
+<li><code class="docutils literal notranslate"><span class="pre">DW_OP_stack_value</span></code> marks a constant value.</li>
+</ul>
+<p>DWARF specifies three kinds of simple location descriptions: Register, memory,
+and implicit location descriptions. Note that a location description is
+defined over certain ranges of a program, i.e the location of a variable may
+change over the course of the program. Register and memory location
+descriptions describe the <em>concrete location</em> of a source variable (in the
+sense that a debugger might modify its value), whereas <em>implicit locations</em>
+describe merely the actual <em>value</em> of a source variable which might not exist
+in registers or in memory (see <code class="docutils literal notranslate"><span class="pre">DW_OP_stack_value</span></code>).</p>
+<p>A <code class="docutils literal notranslate"><span class="pre">llvm.dbg.addr</span></code> or <code class="docutils literal notranslate"><span class="pre">llvm.dbg.declare</span></code> intrinsic describes an indirect
+value (the address) of a source variable. The first operand of the intrinsic
+must be an address of some kind. A DIExpression attached to the intrinsic
+refines this address to produce a concrete location for the source variable.</p>
+<p>A <code class="docutils literal notranslate"><span class="pre">llvm.dbg.value</span></code> intrinsic describes the direct value of a source variable.
+The first operand of the intrinsic may be a direct or indirect value. A
+DIExpresion attached to the intrinsic refines the first operand to produce a
+direct value. For example, if the first operand is an indirect value, it may be
+necessary to insert <code class="docutils literal notranslate"><span class="pre">DW_OP_deref</span></code> into the DIExpresion in order to produce a
+valid debug intrinsic.</p>
+<div class="admonition note">
+<p class="first admonition-title">Note</p>
+<p class="last">A DIExpression is interpreted in the same way regardless of which kind of
+debug intrinsic itâs attached to.</p>
+</div>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!0 = !DIExpression(DW_OP_deref)
+!1 = !DIExpression(DW_OP_plus_uconst, 3)
+!1 = !DIExpression(DW_OP_constu, 3, DW_OP_plus)
+!2 = !DIExpression(DW_OP_bit_piece, 3, 7)
+!3 = !DIExpression(DW_OP_deref, DW_OP_constu, 3, DW_OP_plus, DW_OP_LLVM_fragment, 3, 7)
+!4 = !DIExpression(DW_OP_constu, 2, DW_OP_swap, DW_OP_xderef)
+!5 = !DIExpression(DW_OP_constu, 42, DW_OP_stack_value)
+</pre></div>
+</div>
+</div>
+<div class="section" id="diobjcproperty">
+<h5><a class="toc-backref" href="#id1047">DIObjCProperty</a><a class="headerlink" href="#diobjcproperty" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DIObjCProperty</span></code> nodes represent Objective-C property nodes.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!3 = !DIObjCProperty(name: "foo", file: !1, line: 7, setter: "setFoo",
+ getter: "getFoo", attributes: 7, type: !2)
+</pre></div>
+</div>
+</div>
+<div class="section" id="diimportedentity">
+<h5><a class="toc-backref" href="#id1048">DIImportedEntity</a><a class="headerlink" href="#diimportedentity" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DIImportedEntity</span></code> nodes represent entities (such as modules) imported into a
+compile unit.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!2 = !DIImportedEntity(tag: DW_TAG_imported_module, name: "foo", scope: !0,
+ entity: !1, line: 7)
+</pre></div>
+</div>
+</div>
+<div class="section" id="dimacro">
+<h5><a class="toc-backref" href="#id1049">DIMacro</a><a class="headerlink" href="#dimacro" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DIMacro</span></code> nodes represent definition or undefinition of a macro identifiers.
+The <code class="docutils literal notranslate"><span class="pre">name:</span></code> field is the macro identifier, followed by macro parameters when
+defining a function-like macro, and the <code class="docutils literal notranslate"><span class="pre">value</span></code> field is the token-string
+used to expand the macro identifier.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!2 = !DIMacro(macinfo: DW_MACINFO_define, line: 7, name: "foo(x)",
+ value: "((x) + 1)")
+!3 = !DIMacro(macinfo: DW_MACINFO_undef, line: 30, name: "foo")
+</pre></div>
+</div>
+</div>
+<div class="section" id="dimacrofile">
+<h5><a class="toc-backref" href="#id1050">DIMacroFile</a><a class="headerlink" href="#dimacrofile" title="Permalink to this headline">¶</a></h5>
+<p><code class="docutils literal notranslate"><span class="pre">DIMacroFile</span></code> nodes represent inclusion of source files.
+The <code class="docutils literal notranslate"><span class="pre">nodes:</span></code> field is a list of <code class="docutils literal notranslate"><span class="pre">DIMacro</span></code> and <code class="docutils literal notranslate"><span class="pre">DIMacroFile</span></code> nodes that
+appear in the included source file.</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>!2 = !DIMacroFile(macinfo: DW_MACINFO_start_file, line: 7, file: !2,
+ nodes: !3)
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="tbaa-metadata">
+<h4><a class="toc-backref" href="#id1051">â<code class="docutils literal notranslate"><span class="pre">tbaa</span></code>â Metadata</a><a class="headerlink" href="#tbaa-metadata" title="Permalink to this headline">¶</a></h4>
+<p>In LLVM IR, memory does not have types, so LLVMâs own type system is not
+suitable for doing type based alias analysis (TBAA). Instead, metadata is
+added to the IR to describe a type system of a higher level language. This
+can be used to implement C/C++ strict type aliasing rules, but it can also
+be used to implement custom alias analysis behavior for other languages.</p>
+<p>This description of LLVMâs TBAA system is broken into two parts:
+<a class="reference internal" href="#tbaa-node-semantics"><span class="std std-ref">Semantics</span></a> talks about high level issues, and
+<a class="reference internal" href="#tbaa-node-representation"><span class="std std-ref">Representation</span></a> talks about the metadata
+encoding of various entities.</p>
+<p>It is always possible to trace any TBAA node to a ârootâ TBAA node (details
+in the <a class="reference internal" href="#tbaa-node-representation"><span class="std std-ref">Representation</span></a> section). TBAA
+nodes with different roots have an unknown aliasing relationship, and LLVM
+conservatively infers <code class="docutils literal notranslate"><span class="pre">MayAlias</span></code> between them. The rules mentioned in
+this section only pertain to TBAA nodes living under the same root.</p>
+<div class="section" id="semantics">
+<span id="tbaa-node-semantics"></span><h5><a class="toc-backref" href="#id1052">Semantics</a><a class="headerlink" href="#semantics" title="Permalink to this headline">¶</a></h5>
+<p>The TBAA metadata system, referred to as âstruct path TBAAâ (not to be
+confused with <code class="docutils literal notranslate"><span class="pre">tbaa.struct</span></code>), consists of the following high level
+concepts: <em>Type Descriptors</em>, further subdivided into scalar type
+descriptors and struct type descriptors; and <em>Access Tags</em>.</p>
+<p><strong>Type descriptors</strong> describe the type system of the higher level language
+being compiled. <strong>Scalar type descriptors</strong> describe types that do not
+contain other types. Each scalar type has a parent type, which must also
+be a scalar type or the TBAA root. Via this parent relation, scalar types
+within a TBAA root form a tree. <strong>Struct type descriptors</strong> denote types
+that contain a sequence of other type descriptors, at known offsets. These
+contained type descriptors can either be struct type descriptors themselves
+or scalar type descriptors.</p>
+<p><strong>Access tags</strong> are metadata nodes attached to load and store instructions.
+Access tags use type descriptors to describe the <em>location</em> being accessed
+in terms of the type system of the higher level language. Access tags are
+tuples consisting of a base type, an access type and an offset. The base
+type is a scalar type descriptor or a struct type descriptor, the access
+type is a scalar type descriptor, and the offset is a constant integer.</p>
+<p>The access tag <code class="docutils literal notranslate"><span class="pre">(BaseTy,</span> <span class="pre">AccessTy,</span> <span class="pre">Offset)</span></code> can describe one of two
+things:</p>
+<blockquote>
+<div><ul class="simple">
+<li>If <code class="docutils literal notranslate"><span class="pre">BaseTy</span></code> is a struct type, the tag describes a memory access (load
+or store) of a value of type <code class="docutils literal notranslate"><span class="pre">AccessTy</span></code> contained in the struct type
+<code class="docutils literal notranslate"><span class="pre">BaseTy</span></code> at offset <code class="docutils literal notranslate"><span class="pre">Offset</span></code>.</li>
+<li>If <code class="docutils literal notranslate"><span class="pre">BaseTy</span></code> is a scalar type, <code class="docutils literal notranslate"><span class="pre">Offset</span></code> must be 0 and <code class="docutils literal notranslate"><span class="pre">BaseTy</span></code> and
+<code class="docutils literal notranslate"><span class="pre">AccessTy</span></code> must be the same; and the access tag describes a scalar
+access with scalar type <code class="docutils literal notranslate"><span class="pre">AccessTy</span></code>.</li>
+</ul>
+</div></blockquote>
+<p>We first define an <code class="docutils literal notranslate"><span class="pre">ImmediateParent</span></code> relation on <code class="docutils literal notranslate"><span class="pre">(BaseTy,</span> <span class="pre">Offset)</span></code>
+tuples this way:</p>
+<blockquote>
+<div><ul class="simple">
+<li>If <code class="docutils literal notranslate"><span class="pre">BaseTy</span></code> is a scalar type then <code class="docutils literal notranslate"><span class="pre">ImmediateParent(BaseTy,</span> <span class="pre">0)</span></code> is
+<code class="docutils literal notranslate"><span class="pre">(ParentTy,</span> <span class="pre">0)</span></code> where <code class="docutils literal notranslate"><span class="pre">ParentTy</span></code> is the parent of the scalar type as
+described in the TBAA metadata. <code class="docutils literal notranslate"><span class="pre">ImmediateParent(BaseTy,</span> <span class="pre">Offset)</span></code> is
+undefined if <code class="docutils literal notranslate"><span class="pre">Offset</span></code> is non-zero.</li>
+<li>If <code class="docutils literal notranslate"><span class="pre">BaseTy</span></code> is a struct type then <code class="docutils literal notranslate"><span class="pre">ImmediateParent(BaseTy,</span> <span class="pre">Offset)</span></code>
+is <code class="docutils literal notranslate"><span class="pre">(NewTy,</span> <span class="pre">NewOffset)</span></code> where <code class="docutils literal notranslate"><span class="pre">NewTy</span></code> is the type contained in
+<code class="docutils literal notranslate"><span class="pre">BaseTy</span></code> at offset <code class="docutils literal notranslate"><span class="pre">Offset</span></code> and <code class="docutils literal notranslate"><span class="pre">NewOffset</span></code> is <code class="docutils literal notranslate"><span class="pre">Offset</span></code> adjusted
+to be relative within that inner type.</li>
+</ul>
+</div></blockquote>
+<p>A memory access with an access tag <code class="docutils literal notranslate"><span class="pre">(BaseTy1,</span> <span class="pre">AccessTy1,</span> <span class="pre">Offset1)</span></code>
+aliases a memory access with an access tag <code class="docutils literal notranslate"><span class="pre">(BaseTy2,</span> <span class="pre">AccessTy2,</span>
+<span class="pre">Offset2)</span></code> if either <code class="docutils literal notranslate"><span class="pre">(BaseTy1,</span> <span class="pre">Offset1)</span></code> is reachable from <code class="docutils literal notranslate"><span class="pre">(Base2,</span>
+<span class="pre">Offset2)</span></code> via the <code class="docutils literal notranslate"><span class="pre">Parent</span></code> relation or vice versa.</p>
+<p>As a concrete example, the type descriptor graph for the following program</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="k">struct</span> <span class="n">Inner</span> <span class="p">{</span>
+ <span class="kt">int</span> <span class="n">i</span><span class="p">;</span> <span class="c1">// offset 0</span>
+ <span class="kt">float</span> <span class="n">f</span><span class="p">;</span> <span class="c1">// offset 4</span>
+<span class="p">};</span>
+
+<span class="k">struct</span> <span class="n">Outer</span> <span class="p">{</span>
+ <span class="kt">float</span> <span class="n">f</span><span class="p">;</span> <span class="c1">// offset 0</span>
+ <span class="kt">double</span> <span class="n">d</span><span class="p">;</span> <span class="c1">// offset 4</span>
+ <span class="k">struct</span> <span class="n">Inner</span> <span class="n">inner_a</span><span class="p">;</span> <span class="c1">// offset 12</span>
+<span class="p">};</span>
+
+<span class="kt">void</span> <span class="nf">f</span><span class="p">(</span><span class="k">struct</span> <span class="n">Outer</span><span class="o">*</span> <span class="n">outer</span><span class="p">,</span> <span class="k">struct</span> <span class="n">Inner</span><span class="o">*</span> <span class="n">inner</span><span class="p">,</span> <span class="kt">float</span><span class="o">*</span> <span class="n">f</span><span class="p">,</span> <span class="kt">int</span><span class="o">*</span> <span class="n">i</span><span class="p">,</span> <span class="kt">char</span><span class="o">*</span> <span class="n">c</span><span class="p">)</span> <span class="p">{</span>
+ <span class="n">outer</span><span class="o">-></span><span class="n">f</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span> <span class="c1">// tag0: (OuterStructTy, FloatScalarTy, 0)</span>
+ <span class="n">outer</span><span class="o">-></span><span class="n">inner_a</span><span class="p">.</span><span class="n">i</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span> <span class="c1">// tag1: (OuterStructTy, IntScalarTy, 12)</span>
+ <span class="n">outer</span><span class="o">-></span><span class="n">inner_a</span><span class="p">.</span><span class="n">f</span> <span class="o">=</span> <span class="mf">0.0</span><span class="p">;</span> <span class="c1">// tag2: (OuterStructTy, FloatScalarTy, 16)</span>
+ <span class="o">*</span><span class="n">f</span> <span class="o">=</span> <span class="mf">0.0</span><span class="p">;</span> <span class="c1">// tag3: (FloatScalarTy, FloatScalarTy, 0)</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+<p>is (note that in C and C++, <code class="docutils literal notranslate"><span class="pre">char</span></code> can be used to access any arbitrary
+type):</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>Root = "TBAA Root"
+CharScalarTy = ("char", Root, 0)
+FloatScalarTy = ("float", CharScalarTy, 0)
+DoubleScalarTy = ("double", CharScalarTy, 0)
+IntScalarTy = ("int", CharScalarTy, 0)
+InnerStructTy = {"Inner" (IntScalarTy, 0), (FloatScalarTy, 4)}
+OuterStructTy = {"Outer", (FloatScalarTy, 0), (DoubleScalarTy, 4),
+ (InnerStructTy, 12)}
+</pre></div>
+</div>
+<p>with (e.g.) <code class="docutils literal notranslate"><span class="pre">ImmediateParent(OuterStructTy,</span> <span class="pre">12)</span></code> = <code class="docutils literal notranslate"><span class="pre">(InnerStructTy,</span>
+<span class="pre">0)</span></code>, <code class="docutils literal notranslate"><span class="pre">ImmediateParent(InnerStructTy,</span> <span class="pre">0)</span></code> = <code class="docutils literal notranslate"><span class="pre">(IntScalarTy,</span> <span class="pre">0)</span></code>, and
+<code class="docutils literal notranslate"><span class="pre">ImmediateParent(IntScalarTy,</span> <span class="pre">0)</span></code> = <code class="docutils literal notranslate"><span class="pre">(CharScalarTy,</span> <span class="pre">0)</span></code>.</p>
+</div>
+<div class="section" id="representation">
+<span id="tbaa-node-representation"></span><h5><a class="toc-backref" href="#id1053">Representation</a><a class="headerlink" href="#representation" title="Permalink to this headline">¶</a></h5>
+<p>The root node of a TBAA type hierarchy is an <code class="docutils literal notranslate"><span class="pre">MDNode</span></code> with 0 operands or
+with exactly one <code class="docutils literal notranslate"><span class="pre">MDString</span></code> operand.</p>
+<p>Scalar type descriptors are represented as an <code class="docutils literal notranslate"><span class="pre">MDNode</span></code> s with two
+operands. The first operand is an <code class="docutils literal notranslate"><span class="pre">MDString</span></code> denoting the name of the
+struct type. LLVM does not assign meaning to the value of this operand, it
+only cares about it being an <code class="docutils literal notranslate"><span class="pre">MDString</span></code>. The second operand is an
+<code class="docutils literal notranslate"><span class="pre">MDNode</span></code> which points to the parent for said scalar type descriptor,
+which is either another scalar type descriptor or the TBAA root. Scalar
+type descriptors can have an optional third argument, but that must be the
+constant integer zero.</p>
+<p>Struct type descriptors are represented as <code class="docutils literal notranslate"><span class="pre">MDNode</span></code> s with an odd number
+of operands greater than 1. The first operand is an <code class="docutils literal notranslate"><span class="pre">MDString</span></code> denoting
+the name of the struct type. Like in scalar type descriptors the actual
+value of this name operand is irrelevant to LLVM. After the name operand,
+the struct type descriptors have a sequence of alternating <code class="docutils literal notranslate"><span class="pre">MDNode</span></code> and
+<code class="docutils literal notranslate"><span class="pre">ConstantInt</span></code> operands. With N starting from 1, the 2N - 1 th operand,
+an <code class="docutils literal notranslate"><span class="pre">MDNode</span></code>, denotes a contained field, and the 2N th operand, a
+<code class="docutils literal notranslate"><span class="pre">ConstantInt</span></code>, is the offset of the said contained field. The offsets
+must be in non-decreasing order.</p>
+<p>Access tags are represented as <code class="docutils literal notranslate"><span class="pre">MDNode</span></code> s with either 3 or 4 operands.
+The first operand is an <code class="docutils literal notranslate"><span class="pre">MDNode</span></code> pointing to the node representing the
+base type. The second operand is an <code class="docutils literal notranslate"><span class="pre">MDNode</span></code> pointing to the node
+representing the access type. The third operand is a <code class="docutils literal notranslate"><span class="pre">ConstantInt</span></code> that
+states the offset of the access. If a fourth field is present, it must be
+a <code class="docutils literal notranslate"><span class="pre">ConstantInt</span></code> valued at 0 or 1. If it is 1 then the access tag states
+that the location being accessed is âconstantâ (meaning
+<code class="docutils literal notranslate"><span class="pre">pointsToConstantMemory</span></code> should return true; see <a class="reference external" href="AliasAnalysis.html#OtherItfs">other useful
+AliasAnalysis methods</a>). The TBAA root of
+the access type and the base type of an access tag must be the same, and
+that is the TBAA root of the access tag.</p>
+</div>
+</div>
+<div class="section" id="tbaa-struct-metadata">
+<h4><a class="toc-backref" href="#id1054">â<code class="docutils literal notranslate"><span class="pre">tbaa.struct</span></code>â Metadata</a><a class="headerlink" href="#tbaa-struct-metadata" title="Permalink to this headline">¶</a></h4>
+<p>The <a class="reference internal" href="#int-memcpy"><span class="std std-ref">llvm.memcpy</span></a> is often used to implement
+aggregate assignment operations in C and similar languages, however it
+is defined to copy a contiguous region of memory, which is more than
+strictly necessary for aggregate types which contain holes due to
+padding. Also, it doesnât contain any TBAA information about the fields
+of the aggregate.</p>
+<p><code class="docutils literal notranslate"><span class="pre">!tbaa.struct</span></code> metadata can describe which memory subregions in a
+memcpy are padding and what the TBAA tags of the struct are.</p>
+<p>The current metadata format is very simple. <code class="docutils literal notranslate"><span class="pre">!tbaa.struct</span></code> metadata
+nodes are a list of operands which are in conceptual groups of three.
+For each group of three, the first operand gives the byte offset of a
+field in bytes, the second gives its size in bytes, and the third gives
+its tbaa tag. e.g.:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!4</span> <span class="p">=</span> <span class="p">!{</span> <span class="k">i64</span> <span class="m">0</span><span class="p">,</span> <span class="k">i64</span> <span class="m">4</span><span class="p">,</span> <span class="nv nv-Anonymous">!1</span><span class="p">,</span> <span class="k">i64</span> <span class="m">8</span><span class="p">,</span> <span class="k">i64</span> <span class="m">4</span><span class="p">,</span> <span class="nv nv-Anonymous">!2</span> <span class="p">}</span>
+</pre></div>
+</div>
+<p>This describes a struct with two fields. The first is at offset 0 bytes
+with size 4 bytes, and has tbaa tag !1. The second is at offset 8 bytes
+and has size 4 bytes and has tbaa tag !2.</p>
+<p>Note that the fields need not be contiguous. In this example, there is a
+4 byte gap between the two fields. This gap represents padding which
+does not carry useful data and need not be preserved.</p>
+</div>
+<div class="section" id="noalias-and-alias-scope-metadata">
+<h4><a class="toc-backref" href="#id1055">â<code class="docutils literal notranslate"><span class="pre">noalias</span></code>â and â<code class="docutils literal notranslate"><span class="pre">alias.scope</span></code>â Metadata</a><a class="headerlink" href="#noalias-and-alias-scope-metadata" title="Permalink to this headline">¶</a></h4>
+<p><code class="docutils literal notranslate"><span class="pre">noalias</span></code> and <code class="docutils literal notranslate"><span class="pre">alias.scope</span></code> metadata provide the ability to specify generic
+noalias memory-access sets. This means that some collection of memory access
+instructions (loads, stores, memory-accessing calls, etc.) that carry
+<code class="docutils literal notranslate"><span class="pre">noalias</span></code> metadata can specifically be specified not to alias with some other
+collection of memory access instructions that carry <code class="docutils literal notranslate"><span class="pre">alias.scope</span></code> metadata.
+Each type of metadata specifies a list of scopes where each scope has an id and
+a domain.</p>
+<p>When evaluating an aliasing query, if for some domain, the set
+of scopes with that domain in one instructionâs <code class="docutils literal notranslate"><span class="pre">alias.scope</span></code> list is a
+subset of (or equal to) the set of scopes for that domain in another
+instructionâs <code class="docutils literal notranslate"><span class="pre">noalias</span></code> list, then the two memory accesses are assumed not to
+alias.</p>
+<p>Because scopes in one domain donât affect scopes in other domains, separate
+domains can be used to compose multiple independent noalias sets. This is
+used for example during inlining. As the noalias function parameters are
+turned into noalias scope metadata, a new domain is used every time the
+function is inlined.</p>
+<p>The metadata identifying each domain is itself a list containing one or two
+entries. The first entry is the name of the domain. Note that if the name is a
+string then it can be combined across functions and translation units. A
+self-reference can be used to create globally unique domain names. A
+descriptive string may optionally be provided as a second list entry.</p>
+<p>The metadata identifying each scope is also itself a list containing two or
+three entries. The first entry is the name of the scope. Note that if the name
+is a string then it can be combined across functions and translation units. A
+self-reference can be used to create globally unique scope names. A metadata
+reference to the scopeâs domain is the second entry. A descriptive string may
+optionally be provided as a third list entry.</p>
+<p>For example,</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="c">; Two scope domains:</span>
+<span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv nv-Anonymous">!0</span><span class="p">}</span>
+<span class="nv nv-Anonymous">!1</span> <span class="p">=</span> <span class="p">!{</span><span class="nv nv-Anonymous">!1</span><span class="p">}</span>
+
+<span class="c">; Some scopes in these domains:</span>
+<span class="nv nv-Anonymous">!2</span> <span class="p">=</span> <span class="p">!{</span><span class="nv nv-Anonymous">!2</span><span class="p">,</span> <span class="nv nv-Anonymous">!0</span><span class="p">}</span>
+<span class="nv nv-Anonymous">!3</span> <span class="p">=</span> <span class="p">!{</span><span class="nv nv-Anonymous">!3</span><span class="p">,</span> <span class="nv nv-Anonymous">!0</span><span class="p">}</span>
+<span class="nv nv-Anonymous">!4</span> <span class="p">=</span> <span class="p">!{</span><span class="nv nv-Anonymous">!4</span><span class="p">,</span> <span class="nv nv-Anonymous">!1</span><span class="p">}</span>
+
+<span class="c">; Some scope lists:</span>
+<span class="nv nv-Anonymous">!5</span> <span class="p">=</span> <span class="p">!{</span><span class="nv nv-Anonymous">!4</span><span class="p">}</span> <span class="c">; A list containing only scope !4</span>
+<span class="nv nv-Anonymous">!6</span> <span class="p">=</span> <span class="p">!{</span><span class="nv nv-Anonymous">!4</span><span class="p">,</span> <span class="nv nv-Anonymous">!3</span><span class="p">,</span> <span class="nv nv-Anonymous">!2</span><span class="p">}</span>
+<span class="nv nv-Anonymous">!7</span> <span class="p">=</span> <span class="p">!{</span><span class="nv nv-Anonymous">!3</span><span class="p">}</span>
+
+<span class="c">; These two instructions don't alias:</span>
+<span class="nv nv-Anonymous">%0</span> <span class="p">=</span> <span class="k">load</span> <span class="kt">float</span><span class="p">,</span> <span class="kt">float</span><span class="p">*</span> <span class="nv">%c</span><span class="p">,</span> <span class="k">align</span> <span class="m">4</span><span class="p">,</span> <span class="nv">!alias.scope</span> <span class="nv nv-Anonymous">!5</span>
+<span class="k">store</span> <span class="kt">float</span> <span class="nv nv-Anonymous">%0</span><span class="p">,</span> <span class="kt">float</span><span class="p">*</span> <span class="nv">%arrayidx.i</span><span class="p">,</span> <span class="k">align</span> <span class="m">4</span><span class="p">,</span> <span class="nv">!noalias</span> <span class="nv nv-Anonymous">!5</span>
+
+<span class="c">; These two instructions also don't alias (for domain !1, the set of scopes</span>
+<span class="c">; in the !alias.scope equals that in the !noalias list):</span>
+<span class="nv nv-Anonymous">%2</span> <span class="p">=</span> <span class="k">load</span> <span class="kt">float</span><span class="p">,</span> <span class="kt">float</span><span class="p">*</span> <span class="nv">%c</span><span class="p">,</span> <span class="k">align</span> <span class="m">4</span><span class="p">,</span> <span class="nv">!alias.scope</span> <span class="nv nv-Anonymous">!5</span>
+<span class="k">store</span> <span class="kt">float</span> <span class="nv nv-Anonymous">%2</span><span class="p">,</span> <span class="kt">float</span><span class="p">*</span> <span class="nv">%arrayidx.i2</span><span class="p">,</span> <span class="k">align</span> <span class="m">4</span><span class="p">,</span> <span class="nv">!noalias</span> <span class="nv nv-Anonymous">!6</span>
+
+<span class="c">; These two instructions may alias (for domain !0, the set of scopes in</span>
+<span class="c">; the !noalias list is not a superset of, or equal to, the scopes in the</span>
+<span class="c">; !alias.scope list):</span>
+<span class="nv nv-Anonymous">%2</span> <span class="p">=</span> <span class="k">load</span> <span class="kt">float</span><span class="p">,</span> <span class="kt">float</span><span class="p">*</span> <span class="nv">%c</span><span class="p">,</span> <span class="k">align</span> <span class="m">4</span><span class="p">,</span> <span class="nv">!alias.scope</span> <span class="nv nv-Anonymous">!6</span>
+<span class="k">store</span> <span class="kt">float</span> <span class="nv nv-Anonymous">%0</span><span class="p">,</span> <span class="kt">float</span><span class="p">*</span> <span class="nv">%arrayidx.i</span><span class="p">,</span> <span class="k">align</span> <span class="m">4</span><span class="p">,</span> <span class="nv">!noalias</span> <span class="nv nv-Anonymous">!7</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="fpmath-metadata">
+<h4><a class="toc-backref" href="#id1056">â<code class="docutils literal notranslate"><span class="pre">fpmath</span></code>â Metadata</a><a class="headerlink" href="#fpmath-metadata" title="Permalink to this headline">¶</a></h4>
+<p><code class="docutils literal notranslate"><span class="pre">fpmath</span></code> metadata may be attached to any instruction of floating-point
+type. It can be used to express the maximum acceptable error in the
+result of that instruction, in ULPs, thus potentially allowing the
+compiler to use a more efficient but less accurate method of computing
+it. ULP is defined as follows:</p>
+<blockquote>
+<div>If <code class="docutils literal notranslate"><span class="pre">x</span></code> is a real number that lies between two finite consecutive
+floating-point numbers <code class="docutils literal notranslate"><span class="pre">a</span></code> and <code class="docutils literal notranslate"><span class="pre">b</span></code>, without being equal to one
+of them, then <code class="docutils literal notranslate"><span class="pre">ulp(x)</span> <span class="pre">=</span> <span class="pre">|b</span> <span class="pre">-</span> <span class="pre">a|</span></code>, otherwise <code class="docutils literal notranslate"><span class="pre">ulp(x)</span></code> is the
+distance between the two non-equal finite floating-point numbers
+nearest <code class="docutils literal notranslate"><span class="pre">x</span></code>. Moreover, <code class="docutils literal notranslate"><span class="pre">ulp(NaN)</span></code> is <code class="docutils literal notranslate"><span class="pre">NaN</span></code>.</div></blockquote>
+<p>The metadata node shall consist of a single positive float type number
+representing the maximum relative error, for example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span> <span class="kt">float</span> <span class="m">2.5</span> <span class="p">}</span> <span class="c">; maximum acceptable inaccuracy is 2.5 ULPs</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="range-metadata">
+<span id="id20"></span><h4><a class="toc-backref" href="#id1057">â<code class="docutils literal notranslate"><span class="pre">range</span></code>â Metadata</a><a class="headerlink" href="#range-metadata" title="Permalink to this headline">¶</a></h4>
+<p><code class="docutils literal notranslate"><span class="pre">range</span></code> metadata may be attached only to <code class="docutils literal notranslate"><span class="pre">load</span></code>, <code class="docutils literal notranslate"><span class="pre">call</span></code> and <code class="docutils literal notranslate"><span class="pre">invoke</span></code> of
+integer types. It expresses the possible ranges the loaded value or the value
+returned by the called function at this call site is in. If the loaded or
+returned value is not in the specified range, the behavior is undefined. The
+ranges are represented with a flattened list of integers. The loaded value or
+the value returned is known to be in the union of the ranges defined by each
+consecutive pair. Each pair has the following properties:</p>
+<ul class="simple">
+<li>The type must match the type loaded by the instruction.</li>
+<li>The pair <code class="docutils literal notranslate"><span class="pre">a,b</span></code> represents the range <code class="docutils literal notranslate"><span class="pre">[a,b)</span></code>.</li>
+<li>Both <code class="docutils literal notranslate"><span class="pre">a</span></code> and <code class="docutils literal notranslate"><span class="pre">b</span></code> are constants.</li>
+<li>The range is allowed to wrap.</li>
+<li>The range should not represent the full or empty set. That is,
+<code class="docutils literal notranslate"><span class="pre">a!=b</span></code>.</li>
+</ul>
+<p>In addition, the pairs must be in signed order of the lower bound and
+they must be non-contiguous.</p>
+<p>Examples:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span> <span class="nv">%a</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i8</span><span class="p">,</span> <span class="k">i8</span><span class="p">*</span> <span class="nv">%x</span><span class="p">,</span> <span class="k">align</span> <span class="m">1</span><span class="p">,</span> <span class="nv">!range</span> <span class="nv nv-Anonymous">!0</span> <span class="c">; Can only be 0 or 1</span>
+ <span class="nv">%b</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i8</span><span class="p">,</span> <span class="k">i8</span><span class="p">*</span> <span class="nv">%y</span><span class="p">,</span> <span class="k">align</span> <span class="m">1</span><span class="p">,</span> <span class="nv">!range</span> <span class="nv nv-Anonymous">!1</span> <span class="c">; Can only be 255 (-1), 0 or 1</span>
+ <span class="nv">%c</span> <span class="p">=</span> <span class="k">call</span> <span class="k">i8</span> <span class="vg">@foo</span><span class="p">(),</span> <span class="nv">!range</span> <span class="nv nv-Anonymous">!2</span> <span class="c">; Can only be 0, 1, 3, 4 or 5</span>
+ <span class="nv">%d</span> <span class="p">=</span> <span class="k">invoke</span> <span class="k">i8</span> <span class="vg">@bar</span><span class="p">()</span> <span class="k">to</span> <span class="kt">label</span> <span class="nv">%cont</span>
+ <span class="k">unwind</span> <span class="kt">label</span> <span class="nv">%lpad</span><span class="p">,</span> <span class="nv">!range</span> <span class="nv nv-Anonymous">!3</span> <span class="c">; Can only be -2, -1, 3, 4 or 5</span>
+<span class="p">...</span>
+<span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span> <span class="k">i8</span> <span class="m">0</span><span class="p">,</span> <span class="k">i8</span> <span class="m">2</span> <span class="p">}</span>
+<span class="nv nv-Anonymous">!1</span> <span class="p">=</span> <span class="p">!{</span> <span class="k">i8</span> <span class="m">255</span><span class="p">,</span> <span class="k">i8</span> <span class="m">2</span> <span class="p">}</span>
+<span class="nv nv-Anonymous">!2</span> <span class="p">=</span> <span class="p">!{</span> <span class="k">i8</span> <span class="m">0</span><span class="p">,</span> <span class="k">i8</span> <span class="m">2</span><span class="p">,</span> <span class="k">i8</span> <span class="m">3</span><span class="p">,</span> <span class="k">i8</span> <span class="m">6</span> <span class="p">}</span>
+<span class="nv nv-Anonymous">!3</span> <span class="p">=</span> <span class="p">!{</span> <span class="k">i8</span> <span class="m">-2</span><span class="p">,</span> <span class="k">i8</span> <span class="m">0</span><span class="p">,</span> <span class="k">i8</span> <span class="m">3</span><span class="p">,</span> <span class="k">i8</span> <span class="m">6</span> <span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="absolute-symbol-metadata">
+<h4><a class="toc-backref" href="#id1058">â<code class="docutils literal notranslate"><span class="pre">absolute_symbol</span></code>â Metadata</a><a class="headerlink" href="#absolute-symbol-metadata" title="Permalink to this headline">¶</a></h4>
+<p><code class="docutils literal notranslate"><span class="pre">absolute_symbol</span></code> metadata may be attached to a global variable
+declaration. It marks the declaration as a reference to an absolute symbol,
+which causes the backend to use absolute relocations for the symbol even
+in position independent code, and expresses the possible ranges that the
+global variableâs <em>address</em> (not its value) is in, in the same format as
+<code class="docutils literal notranslate"><span class="pre">range</span></code> metadata, with the extension that the pair <code class="docutils literal notranslate"><span class="pre">all-ones,all-ones</span></code>
+may be used to represent the full set.</p>
+<p>Example (assuming 64-bit pointers):</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span> <span class="vg">@a</span> <span class="p">=</span> <span class="k">external</span> <span class="k">global</span> <span class="k">i8</span><span class="p">,</span> <span class="nv">!absolute_symbol</span> <span class="nv nv-Anonymous">!0</span> <span class="c">; Absolute symbol in range [0,256)</span>
+ <span class="vg">@b</span> <span class="p">=</span> <span class="k">external</span> <span class="k">global</span> <span class="k">i8</span><span class="p">,</span> <span class="nv">!absolute_symbol</span> <span class="nv nv-Anonymous">!1</span> <span class="c">; Absolute symbol in range [0,2^64)</span>
+
+<span class="p">...</span>
+<span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span> <span class="k">i64</span> <span class="m">0</span><span class="p">,</span> <span class="k">i64</span> <span class="m">256</span> <span class="p">}</span>
+<span class="nv nv-Anonymous">!1</span> <span class="p">=</span> <span class="p">!{</span> <span class="k">i64</span> <span class="m">-1</span><span class="p">,</span> <span class="k">i64</span> <span class="m">-1</span> <span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="callees-metadata">
+<h4><a class="toc-backref" href="#id1059">â<code class="docutils literal notranslate"><span class="pre">callees</span></code>â Metadata</a><a class="headerlink" href="#callees-metadata" title="Permalink to this headline">¶</a></h4>
+<p><code class="docutils literal notranslate"><span class="pre">callees</span></code> metadata may be attached to indirect call sites. If <code class="docutils literal notranslate"><span class="pre">callees</span></code>
+metadata is attached to a call site, and any callee is not among the set of
+functions provided by the metadata, the behavior is undefined. The intent of
+this metadata is to facilitate optimizations such as indirect-call promotion.
+For example, in the code below, the call instruction may only target the
+<code class="docutils literal notranslate"><span class="pre">add</span></code> or <code class="docutils literal notranslate"><span class="pre">sub</span></code> functions:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%result</span> <span class="p">=</span> <span class="k">call</span> <span class="k">i64</span> <span class="nv">%binop</span><span class="p">(</span><span class="k">i64</span> <span class="nv">%x</span><span class="p">,</span> <span class="k">i64</span> <span class="nv">%y</span><span class="p">),</span> <span class="nv">!callees</span> <span class="nv nv-Anonymous">!0</span>
+
+<span class="p">...</span>
+<span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="k">i64</span> <span class="p">(</span><span class="k">i64</span><span class="p">,</span> <span class="k">i64</span><span class="p">)*</span> <span class="vg">@add</span><span class="p">,</span> <span class="k">i64</span> <span class="p">(</span><span class="k">i64</span><span class="p">,</span> <span class="k">i64</span><span class="p">)*</span> <span class="vg">@sub</span><span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="unpredictable-metadata">
+<h4><a class="toc-backref" href="#id1060">â<code class="docutils literal notranslate"><span class="pre">unpredictable</span></code>â Metadata</a><a class="headerlink" href="#unpredictable-metadata" title="Permalink to this headline">¶</a></h4>
+<p><code class="docutils literal notranslate"><span class="pre">unpredictable</span></code> metadata may be attached to any branch or switch
+instruction. It can be used to express the unpredictability of control
+flow. Similar to the llvm.expect intrinsic, it may be used to alter
+optimizations related to compare and branch instructions. The metadata
+is treated as a boolean value; if it exists, it signals that the branch
+or switch that it is attached to is completely unpredictable.</p>
+</div>
+<div class="section" id="llvm-loop">
+<span id="id21"></span><h4><a class="toc-backref" href="#id1061">â<code class="docutils literal notranslate"><span class="pre">llvm.loop</span></code>â</a><a class="headerlink" href="#llvm-loop" title="Permalink to this headline">¶</a></h4>
+<p>It is sometimes useful to attach information to loop constructs. Currently,
+loop metadata is implemented as metadata attached to the branch instruction
+in the loop latch block. This type of metadata refer to a metadata node that is
+guaranteed to be separate for each loop. The loop identifier metadata is
+specified with the name <code class="docutils literal notranslate"><span class="pre">llvm.loop</span></code>.</p>
+<p>The loop identifier metadata is implemented using a metadata that refers to
+itself to avoid merging it with any other identifier metadata, e.g.,
+during module linkage or function inlining. That is, each loop should refer
+to their own identification metadata even if they reside in separate functions.
+The following example contains loop identifier metadata for two separate loop
+constructs:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv nv-Anonymous">!0</span><span class="p">}</span>
+<span class="nv nv-Anonymous">!1</span> <span class="p">=</span> <span class="p">!{</span><span class="nv nv-Anonymous">!1</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>The loop identifier metadata can be used to specify additional
+per-loop metadata. Any operands after the first operand can be treated
+as user-defined metadata. For example the <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.count</span></code>
+suggests an unroll factor to the loop unroller:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span> <span class="k">br</span> <span class="k">i1</span> <span class="nv">%exitcond</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%._crit_edge</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%.lr.ph</span><span class="p">,</span> <span class="nv">!llvm.loop</span> <span class="nv nv-Anonymous">!0</span>
+<span class="p">...</span>
+<span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv nv-Anonymous">!0</span><span class="p">,</span> <span class="nv nv-Anonymous">!1</span><span class="p">}</span>
+<span class="nv nv-Anonymous">!1</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.unroll.count"</span><span class="p">,</span> <span class="k">i32</span> <span class="m">4</span><span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="llvm-loop-disable-nonforced">
+<h4><a class="toc-backref" href="#id1062">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.disable_nonforced</span></code>â</a><a class="headerlink" href="#llvm-loop-disable-nonforced" title="Permalink to this headline">¶</a></h4>
+<p>This metadata disables all optional loop transformations unless
+explicitly instructed using other transformation metdata such as
+<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.enable</span></code>. That is, no heuristic will try to determine
+whether a transformation is profitable. The purpose is to avoid that the
+loop is transformed to a different loop before an explicitly requested
+(forced) transformation is applied. For instance, loop fusion can make
+other transformations impossible. Mandatory loop canonicalizations such
+as loop rotation are still applied.</p>
+<p>It is recommended to use this metadata in addition to any llvm.loop.*
+transformation directive. Also, any loop should have at most one
+directive applied to it (and a sequence of transformations built using
+followup-attributes). Otherwise, which transformation will be applied
+depends on implementation details such as the pass pipeline order.</p>
+<p>See <a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Code Transformation Metadata</span></a> for details.</p>
+</div>
+<div class="section" id="llvm-loop-vectorize-and-llvm-loop-interleave">
+<h4><a class="toc-backref" href="#id1063">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize</span></code>â and â<code class="docutils literal notranslate"><span class="pre">llvm.loop.interleave</span></code>â</a><a class="headerlink" href="#llvm-loop-vectorize-and-llvm-loop-interleave" title="Permalink to this headline">¶</a></h4>
+<p>Metadata prefixed with <code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize</span></code> or <code class="docutils literal notranslate"><span class="pre">llvm.loop.interleave</span></code> are
+used to control per-loop vectorization and interleaving parameters such as
+vectorization width and interleave count. These metadata should be used in
+conjunction with <code class="docutils literal notranslate"><span class="pre">llvm.loop</span></code> loop identification metadata. The
+<code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize</span></code> and <code class="docutils literal notranslate"><span class="pre">llvm.loop.interleave</span></code> metadata are only
+optimization hints and the optimizer will only interleave and vectorize loops if
+it believes it is safe to do so. The <code class="docutils literal notranslate"><span class="pre">llvm.loop.parallel_accesses</span></code> metadata
+which contains information about loop-carried memory dependencies can be helpful
+in determining the safety of these transformations.</p>
+</div>
+<div class="section" id="llvm-loop-interleave-count-metadata">
+<h4><a class="toc-backref" href="#id1064">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.interleave.count</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-interleave-count-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata suggests an interleave count to the loop interleaver.
+The first operand is the string <code class="docutils literal notranslate"><span class="pre">llvm.loop.interleave.count</span></code> and the
+second operand is an integer specifying the interleave count. For
+example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.interleave.count"</span><span class="p">,</span> <span class="k">i32</span> <span class="m">4</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>Note that setting <code class="docutils literal notranslate"><span class="pre">llvm.loop.interleave.count</span></code> to 1 disables interleaving
+multiple iterations of the loop. If <code class="docutils literal notranslate"><span class="pre">llvm.loop.interleave.count</span></code> is set to 0
+then the interleave count will be determined automatically.</p>
+</div>
+<div class="section" id="llvm-loop-vectorize-enable-metadata">
+<h4><a class="toc-backref" href="#id1065">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize.enable</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-vectorize-enable-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata selectively enables or disables vectorization for the loop. The
+first operand is the string <code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize.enable</span></code> and the second operand
+is a bit. If the bit operand value is 1 vectorization is enabled. A value of
+0 disables vectorization:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.vectorize.enable"</span><span class="p">,</span> <span class="k">i1</span> <span class="m">0</span><span class="p">}</span>
+<span class="nv nv-Anonymous">!1</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.vectorize.enable"</span><span class="p">,</span> <span class="k">i1</span> <span class="m">1</span><span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="llvm-loop-vectorize-width-metadata">
+<h4><a class="toc-backref" href="#id1066">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize.width</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-vectorize-width-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata sets the target width of the vectorizer. The first
+operand is the string <code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize.width</span></code> and the second
+operand is an integer specifying the width. For example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.vectorize.width"</span><span class="p">,</span> <span class="k">i32</span> <span class="m">4</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>Note that setting <code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize.width</span></code> to 1 disables
+vectorization of the loop. If <code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize.width</span></code> is set to
+0 or if the loop does not have this metadata the width will be
+determined automatically.</p>
+</div>
+<div class="section" id="llvm-loop-vectorize-followup-vectorized-metadata">
+<h4><a class="toc-backref" href="#id1067">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize.followup_vectorized</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-vectorize-followup-vectorized-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata defines which loop attributes the vectorized loop will
+have. See <a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Code Transformation Metadata</span></a> for details.</p>
+</div>
+<div class="section" id="llvm-loop-vectorize-followup-epilogue-metadata">
+<h4><a class="toc-backref" href="#id1068">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize.followup_epilogue</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-vectorize-followup-epilogue-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata defines which loop attributes the epilogue will have. The
+epilogue is not vectorized and is executed when either the vectorized
+loop is not known to preserve semantics (because e.g., it processes two
+arrays that are found to alias by a runtime check) or for the last
+iterations that do not fill a complete set of vector lanes. See
+<a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Transformation Metadata</span></a> for details.</p>
+</div>
+<div class="section" id="llvm-loop-vectorize-followup-all-metadata">
+<h4><a class="toc-backref" href="#id1069">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.vectorize.followup_all</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-vectorize-followup-all-metadata" title="Permalink to this headline">¶</a></h4>
+<p>Attributes in the metadata will be added to both the vectorized and
+epilogue loop.
+See <a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Transformation Metadata</span></a> for details.</p>
+</div>
+<div class="section" id="llvm-loop-unroll">
+<h4><a class="toc-backref" href="#id1070">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll</span></code>â</a><a class="headerlink" href="#llvm-loop-unroll" title="Permalink to this headline">¶</a></h4>
+<p>Metadata prefixed with <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll</span></code> are loop unrolling
+optimization hints such as the unroll factor. <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll</span></code>
+metadata should be used in conjunction with <code class="docutils literal notranslate"><span class="pre">llvm.loop</span></code> loop
+identification metadata. The <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll</span></code> metadata are only
+optimization hints and the unrolling will only be performed if the
+optimizer believes it is safe to do so.</p>
+</div>
+<div class="section" id="llvm-loop-unroll-count-metadata">
+<h4><a class="toc-backref" href="#id1071">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.count</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-count-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata suggests an unroll factor to the loop unroller. The
+first operand is the string <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.count</span></code> and the second
+operand is a positive integer specifying the unroll factor. For
+example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.unroll.count"</span><span class="p">,</span> <span class="k">i32</span> <span class="m">4</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>If the trip count of the loop is less than the unroll count the loop
+will be partially unrolled.</p>
+</div>
+<div class="section" id="llvm-loop-unroll-disable-metadata">
+<h4><a class="toc-backref" href="#id1072">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.disable</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-disable-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata disables loop unrolling. The metadata has a single operand
+which is the string <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.disable</span></code>. For example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.unroll.disable"</span><span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="llvm-loop-unroll-runtime-disable-metadata">
+<h4><a class="toc-backref" href="#id1073">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.runtime.disable</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-runtime-disable-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata disables runtime loop unrolling. The metadata has a single
+operand which is the string <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.runtime.disable</span></code>. For example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.unroll.runtime.disable"</span><span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="llvm-loop-unroll-enable-metadata">
+<h4><a class="toc-backref" href="#id1074">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.enable</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-enable-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata suggests that the loop should be fully unrolled if the trip count
+is known at compile time and partially unrolled if the trip count is not known
+at compile time. The metadata has a single operand which is the string
+<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.enable</span></code>. For example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.unroll.enable"</span><span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="llvm-loop-unroll-full-metadata">
+<h4><a class="toc-backref" href="#id1075">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.full</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-full-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata suggests that the loop should be unrolled fully. The
+metadata has a single operand which is the string <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.full</span></code>.
+For example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.unroll.full"</span><span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="llvm-loop-unroll-followup-metadata">
+<h4><a class="toc-backref" href="#id1076">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.followup</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-followup-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata defines which loop attributes the unrolled loop will have.
+See <a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Transformation Metadata</span></a> for details.</p>
+</div>
+<div class="section" id="llvm-loop-unroll-followup-remainder-metadata">
+<h4><a class="toc-backref" href="#id1077">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.followup_remainder</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-followup-remainder-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata defines which loop attributes the remainder loop after
+partial/runtime unrolling will have. See
+<a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Transformation Metadata</span></a> for details.</p>
+</div>
+<div class="section" id="llvm-loop-unroll-and-jam">
+<h4><a class="toc-backref" href="#id1078">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam</span></code>â</a><a class="headerlink" href="#llvm-loop-unroll-and-jam" title="Permalink to this headline">¶</a></h4>
+<p>This metadata is treated very similarly to the <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll</span></code> metadata
+above, but affect the unroll and jam pass. In addition any loop with
+<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll</span></code> metadata but no <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam</span></code> metadata will
+disable unroll and jam (so <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll</span></code> metadata will be left to the
+unroller, plus <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.disable</span></code> metadata will disable unroll and jam
+too.)</p>
+<p>The metadata for unroll and jam otherwise is the same as for <code class="docutils literal notranslate"><span class="pre">unroll</span></code>.
+<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.enable</span></code>, <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.disable</span></code> and
+<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.count</span></code> do the same as for unroll.
+<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.full</span></code> is not supported. Again these are only hints
+and the normal safety checks will still be performed.</p>
+</div>
+<div class="section" id="llvm-loop-unroll-and-jam-count-metadata">
+<h4><a class="toc-backref" href="#id1079">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.count</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-and-jam-count-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata suggests an unroll and jam factor to use, similarly to
+<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll.count</span></code>. The first operand is the string
+<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.count</span></code> and the second operand is a positive integer
+specifying the unroll factor. For example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.unroll_and_jam.count"</span><span class="p">,</span> <span class="k">i32</span> <span class="m">4</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>If the trip count of the loop is less than the unroll count the loop
+will be partially unroll and jammed.</p>
+</div>
+<div class="section" id="llvm-loop-unroll-and-jam-disable-metadata">
+<h4><a class="toc-backref" href="#id1080">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.disable</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-and-jam-disable-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata disables loop unroll and jamming. The metadata has a single
+operand which is the string <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.disable</span></code>. For example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.unroll_and_jam.disable"</span><span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="llvm-loop-unroll-and-jam-enable-metadata">
+<h4><a class="toc-backref" href="#id1081">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.enable</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-and-jam-enable-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata suggests that the loop should be fully unroll and jammed if the
+trip count is known at compile time and partially unrolled if the trip count is
+not known at compile time. The metadata has a single operand which is the
+string <code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.enable</span></code>. For example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.unroll_and_jam.enable"</span><span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="llvm-loop-unroll-and-jam-followup-outer-metadata">
+<h4><a class="toc-backref" href="#id1082">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.followup_outer</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-and-jam-followup-outer-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata defines which loop attributes the outer unrolled loop will
+have. See <a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Transformation Metadata</span></a> for
+details.</p>
+</div>
+<div class="section" id="llvm-loop-unroll-and-jam-followup-inner-metadata">
+<h4><a class="toc-backref" href="#id1083">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.followup_inner</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-and-jam-followup-inner-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata defines which loop attributes the inner jammed loop will
+have. See <a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Transformation Metadata</span></a> for
+details.</p>
+</div>
+<div class="section" id="llvm-loop-unroll-and-jam-followup-remainder-outer-metadata">
+<h4><a class="toc-backref" href="#id1084">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.followup_remainder_outer</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-and-jam-followup-remainder-outer-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata defines which attributes the epilogue of the outer loop
+will have. This loop is usually unrolled, meaning there is no such
+loop. This attribute will be ignored in this case. See
+<a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Transformation Metadata</span></a> for details.</p>
+</div>
+<div class="section" id="llvm-loop-unroll-and-jam-followup-remainder-inner-metadata">
+<h4><a class="toc-backref" href="#id1085">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.followup_remainder_inner</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-and-jam-followup-remainder-inner-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata defines which attributes the inner loop of the epilogue
+will have. The outer epilogue will usually be unrolled, meaning there
+can be multiple inner remainder loops. See
+<a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Transformation Metadata</span></a> for details.</p>
+</div>
+<div class="section" id="llvm-loop-unroll-and-jam-followup-all-metadata">
+<h4><a class="toc-backref" href="#id1086">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.followup_all</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-unroll-and-jam-followup-all-metadata" title="Permalink to this headline">¶</a></h4>
+<p>Attributes specified in the metadata is added to all
+<code class="docutils literal notranslate"><span class="pre">llvm.loop.unroll_and_jam.*</span></code> loops. See
+<a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Transformation Metadata</span></a> for details.</p>
+</div>
+<div class="section" id="llvm-loop-licm-versioning-disable-metadata">
+<h4><a class="toc-backref" href="#id1087">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.licm_versioning.disable</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-licm-versioning-disable-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata indicates that the loop should not be versioned for the purpose
+of enabling loop-invariant code motion (LICM). The metadata has a single operand
+which is the string <code class="docutils literal notranslate"><span class="pre">llvm.loop.licm_versioning.disable</span></code>. For example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.licm_versioning.disable"</span><span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="llvm-loop-distribute-enable-metadata">
+<h4><a class="toc-backref" href="#id1088">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.distribute.enable</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-distribute-enable-metadata" title="Permalink to this headline">¶</a></h4>
+<p>Loop distribution allows splitting a loop into multiple loops. Currently,
+this is only performed if the entire loop cannot be vectorized due to unsafe
+memory dependencies. The transformation will attempt to isolate the unsafe
+dependencies into their own loop.</p>
+<p>This metadata can be used to selectively enable or disable distribution of the
+loop. The first operand is the string <code class="docutils literal notranslate"><span class="pre">llvm.loop.distribute.enable</span></code> and the
+second operand is a bit. If the bit operand value is 1 distribution is
+enabled. A value of 0 disables distribution:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.distribute.enable"</span><span class="p">,</span> <span class="k">i1</span> <span class="m">0</span><span class="p">}</span>
+<span class="nv nv-Anonymous">!1</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"llvm.loop.distribute.enable"</span><span class="p">,</span> <span class="k">i1</span> <span class="m">1</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>This metadata should be used in conjunction with <code class="docutils literal notranslate"><span class="pre">llvm.loop</span></code> loop
+identification metadata.</p>
+</div>
+<div class="section" id="llvm-loop-distribute-followup-coincident-metadata">
+<h4><a class="toc-backref" href="#id1089">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.distribute.followup_coincident</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-distribute-followup-coincident-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata defines which attributes extracted loops with no cyclic
+dependencies will have (i.e. can be vectorized). See
+<a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Transformation Metadata</span></a> for details.</p>
+</div>
+<div class="section" id="llvm-loop-distribute-followup-sequential-metadata">
+<h4><a class="toc-backref" href="#id1090">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.distribute.followup_sequential</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-distribute-followup-sequential-metadata" title="Permalink to this headline">¶</a></h4>
+<p>This metadata defines which attributes the isolated loops with unsafe
+memory dependencies will have. See
+<a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Transformation Metadata</span></a> for details.</p>
+</div>
+<div class="section" id="llvm-loop-distribute-followup-fallback-metadata">
+<h4><a class="toc-backref" href="#id1091">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.distribute.followup_fallback</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-distribute-followup-fallback-metadata" title="Permalink to this headline">¶</a></h4>
+<p>If loop versioning is necessary, this metadata defined the attributes
+the non-distributed fallback version will have. See
+<a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Transformation Metadata</span></a> for details.</p>
+</div>
+<div class="section" id="llvm-loop-distribute-followup-all-metadata">
+<h4><a class="toc-backref" href="#id1092">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.distribute.followup_all</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-distribute-followup-all-metadata" title="Permalink to this headline">¶</a></h4>
+<p>Thes attributes in this metdata is added to all followup loops of the
+loop distribution pass. See
+<a class="reference internal" href="TransformMetadata.html#transformation-metadata"><span class="std std-ref">Transformation Metadata</span></a> for details.</p>
+</div>
+<div class="section" id="llvm-access-group-metadata">
+<h4><a class="toc-backref" href="#id1093">â<code class="docutils literal notranslate"><span class="pre">llvm.access.group</span></code>â Metadata</a><a class="headerlink" href="#llvm-access-group-metadata" title="Permalink to this headline">¶</a></h4>
+<p><code class="docutils literal notranslate"><span class="pre">llvm.access.group</span></code> metadata can be attached to any instruction that
+potentially accesses memory. It can point to a single distinct metadata
+node, which we call access group. This node represents all memory access
+instructions referring to it via <code class="docutils literal notranslate"><span class="pre">llvm.access.group</span></code>. When an
+instruction belongs to multiple access groups, it can also point to a
+list of accesses groups, illustrated by the following example.</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%val</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%arrayidx</span><span class="p">,</span> <span class="nv">!llvm.access.group</span> <span class="nv nv-Anonymous">!0</span>
+<span class="p">...</span>
+<span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="nv nv-Anonymous">!1</span><span class="p">,</span> <span class="nv nv-Anonymous">!2</span><span class="p">}</span>
+<span class="nv nv-Anonymous">!1</span> <span class="p">=</span> <span class="k">distinct</span> <span class="p">!{}</span>
+<span class="nv nv-Anonymous">!2</span> <span class="p">=</span> <span class="k">distinct</span> <span class="p">!{}</span>
+</pre></div>
+</div>
+<p>It is illegal for the list node to be empty since it might be confused
+with an access group.</p>
+<p>The access group metadata node must be âdistinctâ to avoid collapsing
+multiple access groups by content. A access group metadata node must
+always be empty which can be used to distinguish an access group
+metadata node from a list of access groups. Being empty avoids the
+situation that the content must be updated which, because metadata is
+immutable by design, would required finding and updating all references
+to the access group node.</p>
+<p>The access group can be used to refer to a memory access instruction
+without pointing to it directly (which is not possible in global
+metadata). Currently, the only metadata making use of it is
+<code class="docutils literal notranslate"><span class="pre">llvm.loop.parallel_accesses</span></code>.</p>
+</div>
+<div class="section" id="llvm-loop-parallel-accesses-metadata">
+<h4><a class="toc-backref" href="#id1094">â<code class="docutils literal notranslate"><span class="pre">llvm.loop.parallel_accesses</span></code>â Metadata</a><a class="headerlink" href="#llvm-loop-parallel-accesses-metadata" title="Permalink to this headline">¶</a></h4>
+<p>The <code class="docutils literal notranslate"><span class="pre">llvm.loop.parallel_accesses</span></code> metadata refers to one or more
+access group metadata nodes (see <code class="docutils literal notranslate"><span class="pre">llvm.access.group</span></code>). It denotes that
+no loop-carried memory dependence exist between it and other instructions
+in the loop with this metadata.</p>
+<p>Let <code class="docutils literal notranslate"><span class="pre">m1</span></code> and <code class="docutils literal notranslate"><span class="pre">m2</span></code> be two instructions that both have the
+<code class="docutils literal notranslate"><span class="pre">llvm.access.group</span></code> metadata to the access group <code class="docutils literal notranslate"><span class="pre">g1</span></code>, respectively
+<code class="docutils literal notranslate"><span class="pre">g2</span></code> (which might be identical). If a loop contains both access groups
+in its <code class="docutils literal notranslate"><span class="pre">llvm.loop.parallel_accesses</span></code> metadata, then the compiler can
+assume that there is no dependency between <code class="docutils literal notranslate"><span class="pre">m1</span></code> and <code class="docutils literal notranslate"><span class="pre">m2</span></code> carried by
+this loop. Instructions that belong to multiple access groups are
+considered having this property if at least one of the access groups
+matches the <code class="docutils literal notranslate"><span class="pre">llvm.loop.parallel_accesses</span></code> list.</p>
+<p>If all memory-accessing instructions in a loop have
+<code class="docutils literal notranslate"><span class="pre">llvm.loop.parallel_accesses</span></code> metadata that refers to that loop, then the
+loop has no loop carried memory dependences and is considered to be a
+parallel loop.</p>
+<p>Note that if not all memory access instructions belong to an access
+group referred to by <code class="docutils literal notranslate"><span class="pre">llvm.loop.parallel_accesses</span></code>, then the loop must
+not be considered trivially parallel. Additional
+memory dependence analysis is required to make that determination. As a fail
+safe mechanism, this causes loops that were originally parallel to be considered
+sequential (if optimization passes that are unaware of the parallel semantics
+insert new memory instructions into the loop body).</p>
+<p>Example of a loop that is considered parallel due to its correct use of
+both <code class="docutils literal notranslate"><span class="pre">llvm.access.group</span></code> and <code class="docutils literal notranslate"><span class="pre">llvm.loop.parallel_accesses</span></code>
+metadata types.</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nl">for.body:</span>
+ <span class="p">...</span>
+ <span class="nv">%val0</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%arrayidx</span><span class="p">,</span> <span class="nv">!llvm.access.group</span> <span class="nv nv-Anonymous">!1</span>
+ <span class="p">...</span>
+ <span class="k">store</span> <span class="k">i32</span> <span class="nv">%val0</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%arrayidx1</span><span class="p">,</span> <span class="nv">!llvm.access.group</span> <span class="nv nv-Anonymous">!1</span>
+ <span class="p">...</span>
+ <span class="k">br</span> <span class="k">i1</span> <span class="nv">%exitcond</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%for.end</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%for.body</span><span class="p">,</span> <span class="nv">!llvm.loop</span> <span class="nv nv-Anonymous">!0</span>
+
+<span class="nl">for.end:</span>
+<span class="p">...</span>
+<span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="k">distinct</span> <span class="p">!{</span><span class="nv nv-Anonymous">!0</span><span class="p">,</span> <span class="p">!{</span><span class="nv">!"llvm.loop.parallel_accesses"</span><span class="p">,</span> <span class="nv nv-Anonymous">!1</span><span class="p">}}</span>
+<span class="nv nv-Anonymous">!1</span> <span class="p">=</span> <span class="k">distinct</span> <span class="p">!{}</span>
+</pre></div>
+</div>
+<p>It is also possible to have nested parallel loops:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nl">outer.for.body:</span>
+ <span class="p">...</span>
+ <span class="nv">%val1</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%arrayidx3</span><span class="p">,</span> <span class="nv">!llvm.access.group</span> <span class="nv nv-Anonymous">!4</span>
+ <span class="p">...</span>
+ <span class="k">br</span> <span class="kt">label</span> <span class="nv">%inner.for.body</span>
+
+<span class="nl">inner.for.body:</span>
+ <span class="p">...</span>
+ <span class="nv">%val0</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%arrayidx1</span><span class="p">,</span> <span class="nv">!llvm.access.group</span> <span class="nv nv-Anonymous">!3</span>
+ <span class="p">...</span>
+ <span class="k">store</span> <span class="k">i32</span> <span class="nv">%val0</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%arrayidx2</span><span class="p">,</span> <span class="nv">!llvm.access.group</span> <span class="nv nv-Anonymous">!3</span>
+ <span class="p">...</span>
+ <span class="k">br</span> <span class="k">i1</span> <span class="nv">%exitcond</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%inner.for.end</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%inner.for.body</span><span class="p">,</span> <span class="nv">!llvm.loop</span> <span class="nv nv-Anonymous">!1</span>
+
+<span class="nl">inner.for.end:</span>
+ <span class="p">...</span>
+ <span class="k">store</span> <span class="k">i32</span> <span class="nv">%val1</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%arrayidx4</span><span class="p">,</span> <span class="nv">!llvm.access.group</span> <span class="nv nv-Anonymous">!4</span>
+ <span class="p">...</span>
+ <span class="k">br</span> <span class="k">i1</span> <span class="nv">%exitcond</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%outer.for.end</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%outer.for.body</span><span class="p">,</span> <span class="nv">!llvm.loop</span> <span class="nv nv-Anonymous">!2</span>
+
+<span class="nl">outer.for.end:</span> <span class="c">; preds = %for.body</span>
+<span class="p">...</span>
+<span class="nv nv-Anonymous">!1</span> <span class="p">=</span> <span class="k">distinct</span> <span class="p">!{</span><span class="nv nv-Anonymous">!1</span><span class="p">,</span> <span class="p">!{</span><span class="nv">!"llvm.loop.parallel_accesses"</span><span class="p">,</span> <span class="nv nv-Anonymous">!3</span><span class="p">}}</span> <span class="c">; metadata for the inner loop</span>
+<span class="nv nv-Anonymous">!2</span> <span class="p">=</span> <span class="k">distinct</span> <span class="p">!{</span><span class="nv nv-Anonymous">!2</span><span class="p">,</span> <span class="p">!{</span><span class="nv">!"llvm.loop.parallel_accesses"</span><span class="p">,</span> <span class="nv nv-Anonymous">!3</span><span class="p">,</span> <span class="nv nv-Anonymous">!4</span><span class="p">}}</span> <span class="c">; metadata for the outer loop</span>
+<span class="nv nv-Anonymous">!3</span> <span class="p">=</span> <span class="k">distinct</span> <span class="p">!{}</span> <span class="c">; access group for instructions in the inner loop (which are implicitly contained in outer loop as well)</span>
+<span class="nv nv-Anonymous">!4</span> <span class="p">=</span> <span class="k">distinct</span> <span class="p">!{}</span> <span class="c">; access group for instructions in the outer, but not the inner loop</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="irr-loop-metadata">
+<h4><a class="toc-backref" href="#id1095">â<code class="docutils literal notranslate"><span class="pre">irr_loop</span></code>â Metadata</a><a class="headerlink" href="#irr-loop-metadata" title="Permalink to this headline">¶</a></h4>
+<p><code class="docutils literal notranslate"><span class="pre">irr_loop</span></code> metadata may be attached to the terminator instruction of a basic
+block thatâs an irreducible loop header (note that an irreducible loop has more
+than once header basic blocks.) If <code class="docutils literal notranslate"><span class="pre">irr_loop</span></code> metadata is attached to the
+terminator instruction of a basic block that is not really an irreducible loop
+header, the behavior is undefined. The intent of this metadata is to improve the
+accuracy of the block frequency propagation. For example, in the code below, the
+block <code class="docutils literal notranslate"><span class="pre">header0</span></code> may have a loop header weight (relative to the other headers of
+the irreducible loop) of 100:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nl">header0:</span>
+<span class="p">...</span>
+<span class="k">br</span> <span class="k">i1</span> <span class="nv">%cmp</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%t1</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%t2</span><span class="p">,</span> <span class="nv">!irr_loop</span> <span class="nv nv-Anonymous">!0</span>
+
+<span class="p">...</span>
+<span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span><span class="s">"loop_header_weight"</span><span class="p">,</span> <span class="k">i64</span> <span class="m">100</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>Irreducible loop header weights are typically based on profile data.</p>
+</div>
+<div class="section" id="invariant-group-metadata">
+<h4><a class="toc-backref" href="#id1096">â<code class="docutils literal notranslate"><span class="pre">invariant.group</span></code>â Metadata</a><a class="headerlink" href="#invariant-group-metadata" title="Permalink to this headline">¶</a></h4>
+<p>The experimental <code class="docutils literal notranslate"><span class="pre">invariant.group</span></code> metadata may be attached to
+<code class="docutils literal notranslate"><span class="pre">load</span></code>/<code class="docutils literal notranslate"><span class="pre">store</span></code> instructions referencing a single metadata with no entries.
+The existence of the <code class="docutils literal notranslate"><span class="pre">invariant.group</span></code> metadata on the instruction tells
+the optimizer that every <code class="docutils literal notranslate"><span class="pre">load</span></code> and <code class="docutils literal notranslate"><span class="pre">store</span></code> to the same pointer operand
+can be assumed to load or store the same
+value (but see the <code class="docutils literal notranslate"><span class="pre">llvm.launder.invariant.group</span></code> intrinsic which affects
+when two pointers are considered the same). Pointers returned by bitcast or
+getelementptr with only zero indices are considered the same.</p>
+<p>Examples:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="vg">@unknownPtr</span> <span class="p">=</span> <span class="k">external</span> <span class="k">global</span> <span class="k">i8</span>
+<span class="p">...</span>
+<span class="nv">%ptr</span> <span class="p">=</span> <span class="k">alloca</span> <span class="k">i8</span>
+<span class="k">store</span> <span class="k">i8</span> <span class="m">42</span><span class="p">,</span> <span class="k">i8</span><span class="p">*</span> <span class="nv">%ptr</span><span class="p">,</span> <span class="nv">!invariant.group</span> <span class="nv nv-Anonymous">!0</span>
+<span class="k">call</span> <span class="kt">void</span> <span class="vg">@foo</span><span class="p">(</span><span class="k">i8</span><span class="p">*</span> <span class="nv">%ptr</span><span class="p">)</span>
+
+<span class="nv">%a</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i8</span><span class="p">,</span> <span class="k">i8</span><span class="p">*</span> <span class="nv">%ptr</span><span class="p">,</span> <span class="nv">!invariant.group</span> <span class="nv nv-Anonymous">!0</span> <span class="c">; Can assume that value under %ptr didn't change</span>
+<span class="k">call</span> <span class="kt">void</span> <span class="vg">@foo</span><span class="p">(</span><span class="k">i8</span><span class="p">*</span> <span class="nv">%ptr</span><span class="p">)</span>
+
+<span class="nv">%newPtr</span> <span class="p">=</span> <span class="k">call</span> <span class="k">i8</span><span class="p">*</span> <span class="vg">@getPointer</span><span class="p">(</span><span class="k">i8</span><span class="p">*</span> <span class="nv">%ptr</span><span class="p">)</span>
+<span class="nv">%c</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i8</span><span class="p">,</span> <span class="k">i8</span><span class="p">*</span> <span class="nv">%newPtr</span><span class="p">,</span> <span class="nv">!invariant.group</span> <span class="nv nv-Anonymous">!0</span> <span class="c">; Can't assume anything, because we only have information about %ptr</span>
+
+<span class="nv">%unknownValue</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i8</span><span class="p">,</span> <span class="k">i8</span><span class="p">*</span> <span class="vg">@unknownPtr</span>
+<span class="k">store</span> <span class="k">i8</span> <span class="nv">%unknownValue</span><span class="p">,</span> <span class="k">i8</span><span class="p">*</span> <span class="nv">%ptr</span><span class="p">,</span> <span class="nv">!invariant.group</span> <span class="nv nv-Anonymous">!0</span> <span class="c">; Can assume that %unknownValue == 42</span>
+
+<span class="k">call</span> <span class="kt">void</span> <span class="vg">@foo</span><span class="p">(</span><span class="k">i8</span><span class="p">*</span> <span class="nv">%ptr</span><span class="p">)</span>
+<span class="nv">%newPtr2</span> <span class="p">=</span> <span class="k">call</span> <span class="k">i8</span><span class="p">*</span> <span class="vg">@llvm.launder.invariant.group</span><span class="p">(</span><span class="k">i8</span><span class="p">*</span> <span class="nv">%ptr</span><span class="p">)</span>
+<span class="nv">%d</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i8</span><span class="p">,</span> <span class="k">i8</span><span class="p">*</span> <span class="nv">%newPtr2</span><span class="p">,</span> <span class="nv">!invariant.group</span> <span class="nv nv-Anonymous">!0</span> <span class="c">; Can't step through launder.invariant.group to get value of %ptr</span>
+
+<span class="p">...</span>
+<span class="k">declare</span> <span class="kt">void</span> <span class="vg">@foo</span><span class="p">(</span><span class="k">i8</span><span class="p">*)</span>
+<span class="k">declare</span> <span class="k">i8</span><span class="p">*</span> <span class="vg">@getPointer</span><span class="p">(</span><span class="k">i8</span><span class="p">*)</span>
+<span class="k">declare</span> <span class="k">i8</span><span class="p">*</span> <span class="vg">@llvm.launder.invariant.group</span><span class="p">(</span><span class="k">i8</span><span class="p">*)</span>
+
+<span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{}</span>
+</pre></div>
+</div>
+<p>The invariant.group metadata must be dropped when replacing one pointer by
+another based on aliasing information. This is because invariant.group is tied
+to the SSA value of the pointer operand.</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%v</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i8</span><span class="p">,</span> <span class="k">i8</span><span class="p">*</span> <span class="nv">%x</span><span class="p">,</span> <span class="nv">!invariant.group</span> <span class="nv nv-Anonymous">!0</span>
+<span class="c">; if %x mustalias %y then we can replace the above instruction with</span>
+<span class="nv">%v</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i8</span><span class="p">,</span> <span class="k">i8</span><span class="p">*</span> <span class="nv">%y</span>
+</pre></div>
+</div>
+<p>Note that this is an experimental feature, which means that its semantics might
+change in the future.</p>
+</div>
+<div class="section" id="type-metadata">
+<h4><a class="toc-backref" href="#id1097">â<code class="docutils literal notranslate"><span class="pre">type</span></code>â Metadata</a><a class="headerlink" href="#type-metadata" title="Permalink to this headline">¶</a></h4>
+<p>See <a class="reference internal" href="TypeMetadata.html"><span class="doc">Type Metadata</span></a>.</p>
+</div>
+<div class="section" id="associated-metadata">
+<h4><a class="toc-backref" href="#id1098">â<code class="docutils literal notranslate"><span class="pre">associated</span></code>â Metadata</a><a class="headerlink" href="#associated-metadata" title="Permalink to this headline">¶</a></h4>
+<p>The <code class="docutils literal notranslate"><span class="pre">associated</span></code> metadata may be attached to a global object
+declaration with a single argument that references another global object.</p>
+<p>This metadata prevents discarding of the global object in linker GC
+unless the referenced object is also discarded. The linker support for
+this feature is spotty. For best compatibility, globals carrying this
+metadata may also:</p>
+<ul class="simple">
+<li>Be in a comdat with the referenced global.</li>
+<li>Be in @llvm.compiler.used.</li>
+<li>Have an explicit section with a name which is a valid C identifier.</li>
+</ul>
+<p>It does not have any effect on non-ELF targets.</p>
+<p>Example:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>$a = comdat any
+ at a = global i32 1, comdat $a
+ at b = internal global i32 2, comdat $a, section "abc", !associated !0
+!0 = !{i32* @a}
+</pre></div>
+</div>
+</div>
+<div class="section" id="prof-metadata">
+<h4><a class="toc-backref" href="#id1099">â<code class="docutils literal notranslate"><span class="pre">prof</span></code>â Metadata</a><a class="headerlink" href="#prof-metadata" title="Permalink to this headline">¶</a></h4>
+<p>The <code class="docutils literal notranslate"><span class="pre">prof</span></code> metadata is used to record profile data in the IR.
+The first operand of the metadata node indicates the profile metadata
+type. There are currently 3 types:
+<a class="reference internal" href="#prof-node-branch-weights"><span class="std std-ref">branch_weights</span></a>,
+<a class="reference internal" href="#prof-node-function-entry-count"><span class="std std-ref">function_entry_count</span></a>, and
+<a class="reference internal" href="#prof-node-vp"><span class="std std-ref">VP</span></a>.</p>
+<div class="section" id="branch-weights">
+<span id="prof-node-branch-weights"></span><h5><a class="toc-backref" href="#id1100">branch_weights</a><a class="headerlink" href="#branch-weights" title="Permalink to this headline">¶</a></h5>
+<p>Branch weight metadata attached to a branch, select, switch or call instruction
+represents the likeliness of the associated branch being taken.
+For more information, see <a class="reference internal" href="BranchWeightMetadata.html"><span class="doc">LLVM Branch Weight Metadata</span></a>.</p>
+</div>
+<div class="section" id="function-entry-count">
+<span id="prof-node-function-entry-count"></span><h5><a class="toc-backref" href="#id1101">function_entry_count</a><a class="headerlink" href="#function-entry-count" title="Permalink to this headline">¶</a></h5>
+<p>Function entry count metadata can be attached to function definitions
+to record the number of times the function is called. Used with BFI
+information, it is also used to derive the basic block profile count.
+For more information, see <a class="reference internal" href="BranchWeightMetadata.html"><span class="doc">LLVM Branch Weight Metadata</span></a>.</p>
+</div>
+<div class="section" id="vp">
+<span id="prof-node-vp"></span><h5><a class="toc-backref" href="#id1102">VP</a><a class="headerlink" href="#vp" title="Permalink to this headline">¶</a></h5>
+<p>VP (value profile) metadata can be attached to instructions that have
+value profile information. Currently this is indirect calls (where it
+records the hottest callees) and calls to memory intrinsics such as memcpy,
+memmove, and memset (where it records the hottest byte lengths).</p>
+<p>Each VP metadata node contains âVPâ string, then a uint32_t value for the value
+profiling kind, a uint64_t value for the total number of times the instruction
+is executed, followed by uint64_t value and execution count pairs.
+The value profiling kind is 0 for indirect call targets and 1 for memory
+operations. For indirect call targets, each profile value is a hash
+of the callee function name, and for memory operations each value is the
+byte length.</p>
+<p>Note that the value counts do not need to add up to the total count
+listed in the third operand (in practice only the top hottest values
+are tracked and reported).</p>
+<p>Indirect call example:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">call</span> <span class="kt">void</span> <span class="nv">%f</span><span class="p">(),</span> <span class="nv">!prof</span> <span class="nv nv-Anonymous">!1</span>
+<span class="nv nv-Anonymous">!1</span> <span class="p">=</span> <span class="p">!{</span><span class="nv">!"VP"</span><span class="p">,</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="k">i64</span> <span class="m">1600</span><span class="p">,</span> <span class="k">i64</span> <span class="m">7651369219802541373</span><span class="p">,</span> <span class="k">i64</span> <span class="m">1030</span><span class="p">,</span> <span class="k">i64</span> <span class="m">-4377547752858689819</span><span class="p">,</span> <span class="k">i64</span> <span class="m">410</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>Note that the VP type is 0 (the second operand), which indicates this is
+an indirect call value profile data. The third operand indicates that the
+indirect call executed 1600 times. The 4th and 6th operands give the
+hashes of the 2 hottest target functionsâ names (this is the same hash used
+to represent function names in the profile database), and the 5th and 7th
+operands give the execution count that each of the respective prior target
+functions was called.</p>
+</div>
+</div>
+</div>
+</div>
+<div class="section" id="module-flags-metadata">
+<h2><a class="toc-backref" href="#id1103">Module Flags Metadata</a><a class="headerlink" href="#module-flags-metadata" title="Permalink to this headline">¶</a></h2>
+<p>Information about the module as a whole is difficult to convey to LLVMâs
+subsystems. The LLVM IR isnât sufficient to transmit this information.
+The <code class="docutils literal notranslate"><span class="pre">llvm.module.flags</span></code> named metadata exists in order to facilitate
+this. These flags are in the form of key / value pairs â much like a
+dictionary â making it easy for any subsystem who cares about a flag to
+look it up.</p>
+<p>The <code class="docutils literal notranslate"><span class="pre">llvm.module.flags</span></code> metadata contains a list of metadata triplets.
+Each triplet has the following form:</p>
+<ul class="simple">
+<li>The first element is a <em>behavior</em> flag, which specifies the behavior
+when two (or more) modules are merged together, and it encounters two
+(or more) metadata with the same ID. The supported behaviors are
+described below.</li>
+<li>The second element is a metadata string that is a unique ID for the
+metadata. Each module may only have one flag entry for each unique ID (not
+including entries with the <strong>Require</strong> behavior).</li>
+<li>The third element is the value of the flag.</li>
+</ul>
+<p>When two (or more) modules are merged together, the resulting
+<code class="docutils literal notranslate"><span class="pre">llvm.module.flags</span></code> metadata is the union of the modulesâ flags. That is, for
+each unique metadata ID string, there will be exactly one entry in the merged
+modules <code class="docutils literal notranslate"><span class="pre">llvm.module.flags</span></code> metadata table, and the value for that entry will
+be determined by the merge behavior flag, as described below. The only exception
+is that entries with the <em>Require</em> behavior are always preserved.</p>
+<p>The following behaviors are supported:</p>
+<table border="1" class="colwidths-given docutils">
+<colgroup>
+<col width="10%" />
+<col width="90%" />
+</colgroup>
+<thead valign="bottom">
+<tr class="row-odd"><th class="head">Value</th>
+<th class="head">Behavior</th>
+</tr>
+</thead>
+<tbody valign="top">
+<tr class="row-even"><td>1</td>
+<td><dl class="first last docutils">
+<dt><strong>Error</strong></dt>
+<dd>Emits an error if two values disagree, otherwise the resulting value
+is that of the operands.</dd>
+</dl>
+</td>
+</tr>
+<tr class="row-odd"><td>2</td>
+<td><dl class="first last docutils">
+<dt><strong>Warning</strong></dt>
+<dd>Emits a warning if two values disagree. The result value will be the
+operand for the flag from the first module being linked.</dd>
+</dl>
+</td>
+</tr>
+<tr class="row-even"><td>3</td>
+<td><dl class="first last docutils">
+<dt><strong>Require</strong></dt>
+<dd>Adds a requirement that another module flag be present and have a
+specified value after linking is performed. The value must be a
+metadata pair, where the first element of the pair is the ID of the
+module flag to be restricted, and the second element of the pair is
+the value the module flag should be restricted to. This behavior can
+be used to restrict the allowable results (via triggering of an
+error) of linking IDs with the <strong>Override</strong> behavior.</dd>
+</dl>
+</td>
+</tr>
+<tr class="row-odd"><td>4</td>
+<td><dl class="first last docutils">
+<dt><strong>Override</strong></dt>
+<dd>Uses the specified value, regardless of the behavior or value of the
+other module. If both modules specify <strong>Override</strong>, but the values
+differ, an error will be emitted.</dd>
+</dl>
+</td>
+</tr>
+<tr class="row-even"><td>5</td>
+<td><dl class="first last docutils">
+<dt><strong>Append</strong></dt>
+<dd>Appends the two values, which are required to be metadata nodes.</dd>
+</dl>
+</td>
+</tr>
+<tr class="row-odd"><td>6</td>
+<td><dl class="first last docutils">
+<dt><strong>AppendUnique</strong></dt>
+<dd>Appends the two values, which are required to be metadata
+nodes. However, duplicate entries in the second list are dropped
+during the append operation.</dd>
+</dl>
+</td>
+</tr>
+<tr class="row-even"><td>7</td>
+<td><dl class="first last docutils">
+<dt><strong>Max</strong></dt>
+<dd>Takes the max of the two values, which are required to be integers.</dd>
+</dl>
+</td>
+</tr>
+</tbody>
+</table>
+<p>It is an error for a particular unique flag ID to have multiple behaviors,
+except in the case of <strong>Require</strong> (which adds restrictions on another metadata
+value) or <strong>Override</strong>.</p>
+<p>An example of module flags:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">!0</span> <span class="p">=</span> <span class="p">!{</span> <span class="k">i32</span> <span class="m">1</span><span class="p">,</span> <span class="nv">!"foo"</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span> <span class="p">}</span>
+<span class="nv nv-Anonymous">!1</span> <span class="p">=</span> <span class="p">!{</span> <span class="k">i32</span> <span class="m">4</span><span class="p">,</span> <span class="nv">!"bar"</span><span class="p">,</span> <span class="k">i32</span> <span class="m">37</span> <span class="p">}</span>
+<span class="nv nv-Anonymous">!2</span> <span class="p">=</span> <span class="p">!{</span> <span class="k">i32</span> <span class="m">2</span><span class="p">,</span> <span class="nv">!"qux"</span><span class="p">,</span> <span class="k">i32</span> <span class="m">42</span> <span class="p">}</span>
+<span class="nv nv-Anonymous">!3</span> <span class="p">=</span> <span class="p">!{</span> <span class="k">i32</span> <span class="m">3</span><span class="p">,</span> <span class="nv">!"qux"</span><span class="p">,</span>
+ <span class="p">!{</span>
+ <span class="nv">!"foo"</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span>
+ <span class="p">}</span>
+<span class="p">}</span>
+<span class="nv">!llvm.module.flags</span> <span class="p">=</span> <span class="p">!{</span> <span class="nv nv-Anonymous">!0</span><span class="p">,</span> <span class="nv nv-Anonymous">!1</span><span class="p">,</span> <span class="nv nv-Anonymous">!2</span><span class="p">,</span> <span class="nv nv-Anonymous">!3</span> <span class="p">}</span>
+</pre></div>
+</div>
+<ul>
+<li><p class="first">Metadata <code class="docutils literal notranslate"><span class="pre">!0</span></code> has the ID <code class="docutils literal notranslate"><span class="pre">!"foo"</span></code> and the value â1â. The behavior
+if two or more <code class="docutils literal notranslate"><span class="pre">!"foo"</span></code> flags are seen is to emit an error if their
+values are not equal.</p>
+</li>
+<li><p class="first">Metadata <code class="docutils literal notranslate"><span class="pre">!1</span></code> has the ID <code class="docutils literal notranslate"><span class="pre">!"bar"</span></code> and the value â37â. The
+behavior if two or more <code class="docutils literal notranslate"><span class="pre">!"bar"</span></code> flags are seen is to use the value
+â37â.</p>
+</li>
+<li><p class="first">Metadata <code class="docutils literal notranslate"><span class="pre">!2</span></code> has the ID <code class="docutils literal notranslate"><span class="pre">!"qux"</span></code> and the value â42â. The
+behavior if two or more <code class="docutils literal notranslate"><span class="pre">!"qux"</span></code> flags are seen is to emit a
+warning if their values are not equal.</p>
+</li>
+<li><p class="first">Metadata <code class="docutils literal notranslate"><span class="pre">!3</span></code> has the ID <code class="docutils literal notranslate"><span class="pre">!"qux"</span></code> and the value:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span>!{ !"foo", i32 1 }
+</pre></div>
+</div>
+<p>The behavior is to emit an error if the <code class="docutils literal notranslate"><span class="pre">llvm.module.flags</span></code> does not
+contain a flag with the ID <code class="docutils literal notranslate"><span class="pre">!"foo"</span></code> that has the value â1â after linking is
+performed.</p>
+</li>
+</ul>
+<div class="section" id="objective-c-garbage-collection-module-flags-metadata">
+<h3><a class="toc-backref" href="#id1104">Objective-C Garbage Collection Module Flags Metadata</a><a class="headerlink" href="#objective-c-garbage-collection-module-flags-metadata" title="Permalink to this headline">¶</a></h3>
+<p>On the Mach-O platform, Objective-C stores metadata about garbage
+collection in a special section called âimage infoâ. The metadata
+consists of a version number and a bitmask specifying what types of
+garbage collection are supported (if any) by the file. If two or more
+modules are linked together their garbage collection metadata needs to
+be merged rather than appended together.</p>
+<p>The Objective-C garbage collection module flags metadata consists of the
+following key-value pairs:</p>
+<table border="1" class="colwidths-given docutils">
+<colgroup>
+<col width="30%" />
+<col width="70%" />
+</colgroup>
+<thead valign="bottom">
+<tr class="row-odd"><th class="head">Key</th>
+<th class="head">Value</th>
+</tr>
+</thead>
+<tbody valign="top">
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre">Objective-C</span> <span class="pre">Version</span></code></td>
+<td><strong>[Required]</strong> â The Objective-C ABI version. Valid values are 1 and 2.</td>
+</tr>
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">Objective-C</span> <span class="pre">Image</span> <span class="pre">Info</span> <span class="pre">Version</span></code></td>
+<td><strong>[Required]</strong> â The version of the image info section. Currently
+always 0.</td>
+</tr>
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre">Objective-C</span> <span class="pre">Image</span> <span class="pre">Info</span> <span class="pre">Section</span></code></td>
+<td><strong>[Required]</strong> â The section to place the metadata. Valid values are
+<code class="docutils literal notranslate"><span class="pre">"__OBJC,</span> <span class="pre">__image_info,</span> <span class="pre">regular"</span></code> for Objective-C ABI version 1, and
+<code class="docutils literal notranslate"><span class="pre">"__DATA,__objc_imageinfo,</span> <span class="pre">regular,</span> <span class="pre">no_dead_strip"</span></code> for
+Objective-C ABI version 2.</td>
+</tr>
+<tr class="row-odd"><td><code class="docutils literal notranslate"><span class="pre">Objective-C</span> <span class="pre">Garbage</span> <span class="pre">Collection</span></code></td>
+<td><strong>[Required]</strong> â Specifies whether garbage collection is supported or
+not. Valid values are 0, for no garbage collection, and 2, for garbage
+collection supported.</td>
+</tr>
+<tr class="row-even"><td><code class="docutils literal notranslate"><span class="pre">Objective-C</span> <span class="pre">GC</span> <span class="pre">Only</span></code></td>
+<td><strong>[Optional]</strong> â Specifies that only garbage collection is supported.
+If present, its value must be 6. This flag requires that the
+<code class="docutils literal notranslate"><span class="pre">Objective-C</span> <span class="pre">Garbage</span> <span class="pre">Collection</span></code> flag have the value 2.</td>
+</tr>
+</tbody>
+</table>
+<p>Some important flag interactions:</p>
+<ul class="simple">
+<li>If a module with <code class="docutils literal notranslate"><span class="pre">Objective-C</span> <span class="pre">Garbage</span> <span class="pre">Collection</span></code> set to 0 is
+merged with a module with <code class="docutils literal notranslate"><span class="pre">Objective-C</span> <span class="pre">Garbage</span> <span class="pre">Collection</span></code> set to
+2, then the resulting module has the
+<code class="docutils literal notranslate"><span class="pre">Objective-C</span> <span class="pre">Garbage</span> <span class="pre">Collection</span></code> flag set to 0.</li>
+<li>A module with <code class="docutils literal notranslate"><span class="pre">Objective-C</span> <span class="pre">Garbage</span> <span class="pre">Collection</span></code> set to 0 cannot be
+merged with a module with <code class="docutils literal notranslate"><span class="pre">Objective-C</span> <span class="pre">GC</span> <span class="pre">Only</span></code> set to 6.</li>
+</ul>
+</div>
+<div class="section" id="c-type-width-module-flags-metadata">
+<h3><a class="toc-backref" href="#id1105">C type width Module Flags Metadata</a><a class="headerlink" href="#c-type-width-module-flags-metadata" title="Permalink to this headline">¶</a></h3>
+<p>The ARM backend emits a section into each generated object file describing the
+options that it was compiled with (in a compiler-independent way) to prevent
+linking incompatible objects, and to allow automatic library selection. Some
+of these options are not visible at the IR level, namely wchar_t width and enum
+width.</p>
+<p>To pass this information to the backend, these options are encoded in module
+flags metadata, using the following key-value pairs:</p>
+<table border="1" class="colwidths-given docutils">
+<colgroup>
+<col width="30%" />
+<col width="70%" />
+</colgroup>
+<thead valign="bottom">
+<tr class="row-odd"><th class="head">Key</th>
+<th class="head">Value</th>
+</tr>
+</thead>
+<tbody valign="top">
+<tr class="row-even"><td>short_wchar</td>
+<td><ul class="first last simple">
+<li>0 â sizeof(wchar_t) == 4</li>
+<li>1 â sizeof(wchar_t) == 2</li>
+</ul>
+</td>
+</tr>
+<tr class="row-odd"><td>short_enum</td>
+<td><ul class="first last simple">
+<li>0 â Enums are at least as large as an <code class="docutils literal notranslate"><span class="pre">int</span></code>.</li>
+<li>1 â Enums are stored in the smallest integer type which can
+represent all of its values.</li>
+</ul>
+</td>
+</tr>
+</tbody>
+</table>
+<p>For example, the following metadata section specifies that the module was
+compiled with a <code class="docutils literal notranslate"><span class="pre">wchar_t</span></code> width of 4 bytes, and the underlying type of an
+enum is the smallest type which can represent all of its values:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span>!llvm.module.flags = !{!0, !1}
+!0 = !{i32 1, !"short_wchar", i32 1}
+!1 = !{i32 1, !"short_enum", i32 0}
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="automatic-linker-flags-named-metadata">
+<h2><a class="toc-backref" href="#id1106">Automatic Linker Flags Named Metadata</a><a class="headerlink" href="#automatic-linker-flags-named-metadata" title="Permalink to this headline">¶</a></h2>
+<p>Some targets support embedding flags to the linker inside individual object
+files. Typically this is used in conjunction with language extensions which
+allow source files to explicitly declare the libraries they depend on, and have
+these automatically be transmitted to the linker via object files.</p>
+<p>These flags are encoded in the IR using named metadata with the name
+<code class="docutils literal notranslate"><span class="pre">!llvm.linker.options</span></code>. Each operand is expected to be a metadata node
+which should be a list of other metadata nodes, each of which should be a
+list of metadata strings defining linker options.</p>
+<p>For example, the following metadata section specifies two separate sets of
+linker options, presumably to link against <code class="docutils literal notranslate"><span class="pre">libz</span></code> and the <code class="docutils literal notranslate"><span class="pre">Cocoa</span></code>
+framework:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span>!0 = !{ !"-lz" },
+!1 = !{ !"-framework", !"Cocoa" } } }
+!llvm.linker.options = !{ !0, !1 }
+</pre></div>
+</div>
+<p>The metadata encoding as lists of lists of options, as opposed to a collapsed
+list of options, is chosen so that the IR encoding can use multiple option
+strings to specify e.g., a single library, while still having that specifier be
+preserved as an atomic element that can be recognized by a target specific
+assembly writer or object file emitter.</p>
+<p>Each individual option is required to be either a valid option for the targetâs
+linker, or an option that is reserved by the target specific assembly writer or
+object file emitter. No other aspect of these options is defined by the IR.</p>
+</div>
+<div class="section" id="thinlto-summary">
+<span id="summary"></span><h2><a class="toc-backref" href="#id1107">ThinLTO Summary</a><a class="headerlink" href="#thinlto-summary" title="Permalink to this headline">¶</a></h2>
+<p>Compiling with <a class="reference external" href="https://clang.llvm.org/docs/ThinLTO.html">ThinLTO</a>
+causes the building of a compact summary of the module that is emitted into
+the bitcode. The summary is emitted into the LLVM assembly and identified
+in syntax by a caret (â<code class="docutils literal notranslate"><span class="pre">^</span></code>â).</p>
+<p>The summary is parsed into a bitcode output, along with the Module
+IR, via the â<code class="docutils literal notranslate"><span class="pre">llvm-as</span></code>â tool. Tools that parse the Module IR for the purposes
+of optimization (e.g. â<code class="docutils literal notranslate"><span class="pre">clang</span> <span class="pre">-x</span> <span class="pre">ir</span></code>â and â<code class="docutils literal notranslate"><span class="pre">opt</span></code>â), will ignore the
+summary entries (just as they currently ignore summary entries in a bitcode
+input file).</p>
+<p>Eventually, the summary will be parsed into a ModuleSummaryIndex object under
+the same conditions where summary index is currently built from bitcode.
+Specifically, tools that test the Thin Link portion of a ThinLTO compile
+(i.e. llvm-lto and llvm-lto2), or when parsing a combined index
+for a distributed ThinLTO backend via clangâs â<code class="docutils literal notranslate"><span class="pre">-fthinlto-index=<></span></code>â flag
+(this part is not yet implemented, use llvm-as to create a bitcode object
+before feeding into thin link tools for now).</p>
+<p>There are currently 3 types of summary entries in the LLVM assembly:
+<a class="reference internal" href="#module-path-summary"><span class="std std-ref">module paths</span></a>,
+<a class="reference internal" href="#gv-summary"><span class="std std-ref">global values</span></a>, and
+<a class="reference internal" href="#typeid-summary"><span class="std std-ref">type identifiers</span></a>.</p>
+<div class="section" id="module-path-summary-entry">
+<span id="module-path-summary"></span><h3><a class="toc-backref" href="#id1108">Module Path Summary Entry</a><a class="headerlink" href="#module-path-summary-entry" title="Permalink to this headline">¶</a></h3>
+<p>Each module path summary entry lists a module containing global values included
+in the summary. For a single IR module there will be one such entry, but
+in a combined summary index produced during the thin link, there will be
+one module path entry per linked module with summary.</p>
+<p>Example:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>^0 = module: (path: "/path/to/file.o", hash: (2468601609, 1329373163, 1565878005, 638838075, 3148790418))
+</pre></div>
+</div>
+<p>The <code class="docutils literal notranslate"><span class="pre">path</span></code> field is a string path to the bitcode file, and the <code class="docutils literal notranslate"><span class="pre">hash</span></code>
+field is the 160-bit SHA-1 hash of the IR bitcode contents, used for
+incremental builds and caching.</p>
+</div>
+<div class="section" id="global-value-summary-entry">
+<span id="gv-summary"></span><h3><a class="toc-backref" href="#id1109">Global Value Summary Entry</a><a class="headerlink" href="#global-value-summary-entry" title="Permalink to this headline">¶</a></h3>
+<p>Each global value summary entry corresponds to a global value defined or
+referenced by a summarized module.</p>
+<p>Example:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>^4 = gv: (name: "f"[, summaries: (Summary)[, (Summary)]*]?) ; guid = 14740650423002898831
+</pre></div>
+</div>
+<p>For declarations, there will not be a summary list. For definitions, a
+global value will contain a list of summaries, one per module containing
+a definition. There can be multiple entries in a combined summary index
+for symbols with weak linkage.</p>
+<p>Each <code class="docutils literal notranslate"><span class="pre">Summary</span></code> format will depend on whether the global value is a
+<a class="reference internal" href="#function-summary"><span class="std std-ref">function</span></a>, <a class="reference internal" href="#variable-summary"><span class="std std-ref">variable</span></a>, or
+<a class="reference internal" href="#alias-summary"><span class="std std-ref">alias</span></a>.</p>
+<div class="section" id="function-summary">
+<span id="id22"></span><h4><a class="toc-backref" href="#id1110">Function Summary</a><a class="headerlink" href="#function-summary" title="Permalink to this headline">¶</a></h4>
+<p>If the global value is a function, the <code class="docutils literal notranslate"><span class="pre">Summary</span></code> entry will look like:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>function: (module: ^0, flags: (linkage: external, notEligibleToImport: 0, live: 0, dsoLocal: 0), insts: 2[, FuncFlags]?[, Calls]?[, TypeIdInfo]?[, Refs]?
+</pre></div>
+</div>
+<p>The <code class="docutils literal notranslate"><span class="pre">module</span></code> field includes the summary entry id for the module containing
+this definition, and the <code class="docutils literal notranslate"><span class="pre">flags</span></code> field contains information such as
+the linkage type, a flag indicating whether it is legal to import the
+definition, whether it is globally live and whether the linker resolved it
+to a local definition (the latter two are populated during the thin link).
+The <code class="docutils literal notranslate"><span class="pre">insts</span></code> field contains the number of IR instructions in the function.
+Finally, there are several optional fields: <a class="reference internal" href="#funcflags-summary"><span class="std std-ref">FuncFlags</span></a>,
+<a class="reference internal" href="#calls-summary"><span class="std std-ref">Calls</span></a>, <a class="reference internal" href="#typeidinfo-summary"><span class="std std-ref">TypeIdInfo</span></a>,
+<a class="reference internal" href="#refs-summary"><span class="std std-ref">Refs</span></a>.</p>
+</div>
+<div class="section" id="global-variable-summary">
+<span id="variable-summary"></span><h4><a class="toc-backref" href="#id1111">Global Variable Summary</a><a class="headerlink" href="#global-variable-summary" title="Permalink to this headline">¶</a></h4>
+<p>If the global value is a variable, the <code class="docutils literal notranslate"><span class="pre">Summary</span></code> entry will look like:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>variable: (module: ^0, flags: (linkage: external, notEligibleToImport: 0, live: 0, dsoLocal: 0)[, Refs]?
+</pre></div>
+</div>
+<p>The variable entry contains a subset of the fields in a
+<a class="reference internal" href="#function-summary"><span class="std std-ref">function summary</span></a>, see the descriptions there.</p>
+</div>
+<div class="section" id="alias-summary">
+<span id="id23"></span><h4><a class="toc-backref" href="#id1112">Alias Summary</a><a class="headerlink" href="#alias-summary" title="Permalink to this headline">¶</a></h4>
+<p>If the global value is an alias, the <code class="docutils literal notranslate"><span class="pre">Summary</span></code> entry will look like:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>alias: (module: ^0, flags: (linkage: external, notEligibleToImport: 0, live: 0, dsoLocal: 0), aliasee: ^2)
+</pre></div>
+</div>
+<p>The <code class="docutils literal notranslate"><span class="pre">module</span></code> and <code class="docutils literal notranslate"><span class="pre">flags</span></code> fields are as described for a
+<a class="reference internal" href="#function-summary"><span class="std std-ref">function summary</span></a>. The <code class="docutils literal notranslate"><span class="pre">aliasee</span></code> field
+contains a reference to the global value summary entry of the aliasee.</p>
+</div>
+<div class="section" id="function-flags">
+<span id="funcflags-summary"></span><h4><a class="toc-backref" href="#id1113">Function Flags</a><a class="headerlink" href="#function-flags" title="Permalink to this headline">¶</a></h4>
+<p>The optional <code class="docutils literal notranslate"><span class="pre">FuncFlags</span></code> field looks like:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>funcFlags: (readNone: 0, readOnly: 0, noRecurse: 0, returnDoesNotAlias: 0)
+</pre></div>
+</div>
+<p>If unspecified, flags are assumed to hold the conservative <code class="docutils literal notranslate"><span class="pre">false</span></code> value of
+<code class="docutils literal notranslate"><span class="pre">0</span></code>.</p>
+</div>
+<div class="section" id="calls">
+<span id="calls-summary"></span><h4><a class="toc-backref" href="#id1114">Calls</a><a class="headerlink" href="#calls" title="Permalink to this headline">¶</a></h4>
+<p>The optional <code class="docutils literal notranslate"><span class="pre">Calls</span></code> field looks like:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>calls: ((Callee)[, (Callee)]*)
+</pre></div>
+</div>
+<p>where each <code class="docutils literal notranslate"><span class="pre">Callee</span></code> looks like:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>callee: ^1[, hotness: None]?[, relbf: 0]?
+</pre></div>
+</div>
+<p>The <code class="docutils literal notranslate"><span class="pre">callee</span></code> refers to the summary entry id of the callee. At most one
+of <code class="docutils literal notranslate"><span class="pre">hotness</span></code> (which can take the values <code class="docutils literal notranslate"><span class="pre">Unknown</span></code>, <code class="docutils literal notranslate"><span class="pre">Cold</span></code>, <code class="docutils literal notranslate"><span class="pre">None</span></code>,
+<code class="docutils literal notranslate"><span class="pre">Hot</span></code>, and <code class="docutils literal notranslate"><span class="pre">Critical</span></code>), and <code class="docutils literal notranslate"><span class="pre">relbf</span></code> (which holds the integer
+branch frequency relative to the entry frequency, scaled down by 2^8)
+may be specified. The defaults are <code class="docutils literal notranslate"><span class="pre">Unknown</span></code> and <code class="docutils literal notranslate"><span class="pre">0</span></code>, respectively.</p>
+</div>
+<div class="section" id="refs">
+<span id="refs-summary"></span><h4><a class="toc-backref" href="#id1115">Refs</a><a class="headerlink" href="#refs" title="Permalink to this headline">¶</a></h4>
+<p>The optional <code class="docutils literal notranslate"><span class="pre">Refs</span></code> field looks like:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>refs: ((Ref)[, (Ref)]*)
+</pre></div>
+</div>
+<p>where each <code class="docutils literal notranslate"><span class="pre">Ref</span></code> contains a reference to the summary id of the referenced
+value (e.g. <code class="docutils literal notranslate"><span class="pre">^1</span></code>).</p>
+</div>
+<div class="section" id="typeidinfo">
+<span id="typeidinfo-summary"></span><h4><a class="toc-backref" href="#id1116">TypeIdInfo</a><a class="headerlink" href="#typeidinfo" title="Permalink to this headline">¶</a></h4>
+<p>The optional <code class="docutils literal notranslate"><span class="pre">TypeIdInfo</span></code> field, used for
+<a class="reference external" href="http://clang.llvm.org/docs/ControlFlowIntegrity.html">Control Flow Integrity</a>,
+looks like:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>typeIdInfo: [(TypeTests)]?[, (TypeTestAssumeVCalls)]?[, (TypeCheckedLoadVCalls)]?[, (TypeTestAssumeConstVCalls)]?[, (TypeCheckedLoadConstVCalls)]?
+</pre></div>
+</div>
+<p>These optional fields have the following forms:</p>
+<div class="section" id="typetests">
+<h5><a class="toc-backref" href="#id1117">TypeTests</a><a class="headerlink" href="#typetests" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>typeTests: (TypeIdRef[, TypeIdRef]*)
+</pre></div>
+</div>
+<p>Where each <code class="docutils literal notranslate"><span class="pre">TypeIdRef</span></code> refers to a <a class="reference internal" href="#typeid-summary"><span class="std std-ref">type id</span></a>
+by summary id or <code class="docutils literal notranslate"><span class="pre">GUID</span></code>.</p>
+</div>
+<div class="section" id="typetestassumevcalls">
+<h5><a class="toc-backref" href="#id1118">TypeTestAssumeVCalls</a><a class="headerlink" href="#typetestassumevcalls" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>typeTestAssumeVCalls: (VFuncId[, VFuncId]*)
+</pre></div>
+</div>
+<p>Where each VFuncId has the format:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>vFuncId: (TypeIdRef, offset: 16)
+</pre></div>
+</div>
+<p>Where each <code class="docutils literal notranslate"><span class="pre">TypeIdRef</span></code> refers to a <a class="reference internal" href="#typeid-summary"><span class="std std-ref">type id</span></a>
+by summary id or <code class="docutils literal notranslate"><span class="pre">GUID</span></code> preceeded by a <code class="docutils literal notranslate"><span class="pre">guid:</span></code> tag.</p>
+</div>
+<div class="section" id="typecheckedloadvcalls">
+<h5><a class="toc-backref" href="#id1119">TypeCheckedLoadVCalls</a><a class="headerlink" href="#typecheckedloadvcalls" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>typeCheckedLoadVCalls: (VFuncId[, VFuncId]*)
+</pre></div>
+</div>
+<p>Where each VFuncId has the format described for <code class="docutils literal notranslate"><span class="pre">TypeTestAssumeVCalls</span></code>.</p>
+</div>
+<div class="section" id="typetestassumeconstvcalls">
+<h5><a class="toc-backref" href="#id1120">TypeTestAssumeConstVCalls</a><a class="headerlink" href="#typetestassumeconstvcalls" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>typeTestAssumeConstVCalls: (ConstVCall[, ConstVCall]*)
+</pre></div>
+</div>
+<p>Where each ConstVCall has the format:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>(VFuncId, args: (Arg[, Arg]*))
+</pre></div>
+</div>
+<p>and where each VFuncId has the format described for <code class="docutils literal notranslate"><span class="pre">TypeTestAssumeVCalls</span></code>,
+and each Arg is an integer argument number.</p>
+</div>
+<div class="section" id="typecheckedloadconstvcalls">
+<h5><a class="toc-backref" href="#id1121">TypeCheckedLoadConstVCalls</a><a class="headerlink" href="#typecheckedloadconstvcalls" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>typeCheckedLoadConstVCalls: (ConstVCall[, ConstVCall]*)
+</pre></div>
+</div>
+<p>Where each ConstVCall has the format described for
+<code class="docutils literal notranslate"><span class="pre">TypeTestAssumeConstVCalls</span></code>.</p>
+</div>
+</div>
+</div>
+<div class="section" id="type-id-summary-entry">
+<span id="typeid-summary"></span><h3><a class="toc-backref" href="#id1122">Type ID Summary Entry</a><a class="headerlink" href="#type-id-summary-entry" title="Permalink to this headline">¶</a></h3>
+<p>Each type id summary entry corresponds to a type identifier resolution
+which is generated during the LTO link portion of the compile when building
+with <a class="reference external" href="http://clang.llvm.org/docs/ControlFlowIntegrity.html">Control Flow Integrity</a>,
+so these are only present in a combined summary index.</p>
+<p>Example:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>^4 = typeid: (name: "_ZTS1A", summary: (typeTestRes: (kind: allOnes, sizeM1BitWidth: 7[, alignLog2: 0]?[, sizeM1: 0]?[, bitMask: 0]?[, inlineBits: 0]?)[, WpdResolutions]?)) ; guid = 7004155349499253778
+</pre></div>
+</div>
+<p>The <code class="docutils literal notranslate"><span class="pre">typeTestRes</span></code> gives the type test resolution <code class="docutils literal notranslate"><span class="pre">kind</span></code> (which may
+be <code class="docutils literal notranslate"><span class="pre">unsat</span></code>, <code class="docutils literal notranslate"><span class="pre">byteArray</span></code>, <code class="docutils literal notranslate"><span class="pre">inline</span></code>, <code class="docutils literal notranslate"><span class="pre">single</span></code>, or <code class="docutils literal notranslate"><span class="pre">allOnes</span></code>), and
+the <code class="docutils literal notranslate"><span class="pre">size-1</span></code> bit width. It is followed by optional flags, which default to 0,
+and an optional WpdResolutions (whole program devirtualization resolution)
+field that looks like:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>wpdResolutions: ((offset: 0, WpdRes)[, (offset: 1, WpdRes)]*
+</pre></div>
+</div>
+<p>where each entry is a mapping from the given byte offset to the whole-program
+devirtualization resolution WpdRes, that has one of the following formats:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>wpdRes: (kind: branchFunnel)
+wpdRes: (kind: singleImpl, singleImplName: "_ZN1A1nEi")
+wpdRes: (kind: indir)
+</pre></div>
+</div>
+<p>Additionally, each wpdRes has an optional <code class="docutils literal notranslate"><span class="pre">resByArg</span></code> field, which
+describes the resolutions for calls with all constant integer arguments:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>resByArg: (ResByArg[, ResByArg]*)
+</pre></div>
+</div>
+<p>where ResByArg is:</p>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>args: (Arg[, Arg]*), byArg: (kind: UniformRetVal[, info: 0][, byte: 0][, bit: 0])
+</pre></div>
+</div>
+<p>Where the <code class="docutils literal notranslate"><span class="pre">kind</span></code> can be <code class="docutils literal notranslate"><span class="pre">Indir</span></code>, <code class="docutils literal notranslate"><span class="pre">UniformRetVal</span></code>, <code class="docutils literal notranslate"><span class="pre">UniqueRetVal</span></code>
+or <code class="docutils literal notranslate"><span class="pre">VirtualConstProp</span></code>. The <code class="docutils literal notranslate"><span class="pre">info</span></code> field is only used if the kind
+is <code class="docutils literal notranslate"><span class="pre">UniformRetVal</span></code> (indicates the uniform return value), or
+<code class="docutils literal notranslate"><span class="pre">UniqueRetVal</span></code> (holds the return value associated with the unique vtable
+(0 or 1)). The <code class="docutils literal notranslate"><span class="pre">byte</span></code> and <code class="docutils literal notranslate"><span class="pre">bit</span></code> fields are only used if the target does
+not support the use of absolute symbols to store constants.</p>
+</div>
+</div>
+<div class="section" id="intrinsic-global-variables">
+<span id="intrinsicglobalvariables"></span><h2><a class="toc-backref" href="#id1123">Intrinsic Global Variables</a><a class="headerlink" href="#intrinsic-global-variables" title="Permalink to this headline">¶</a></h2>
+<p>LLVM has a number of âmagicâ global variables that contain data that
+affect code generation or other IR semantics. These are documented here.
+All globals of this sort should have a section specified as
+â<code class="docutils literal notranslate"><span class="pre">llvm.metadata</span></code>â. This section and all globals that start with
+â<code class="docutils literal notranslate"><span class="pre">llvm.</span></code>â are reserved for use by LLVM.</p>
+<div class="section" id="the-llvm-used-global-variable">
+<span id="gv-llvmused"></span><h3><a class="toc-backref" href="#id1124">The â<code class="docutils literal notranslate"><span class="pre">llvm.used</span></code>â Global Variable</a><a class="headerlink" href="#the-llvm-used-global-variable" title="Permalink to this headline">¶</a></h3>
+<p>The <code class="docutils literal notranslate"><span class="pre">@llvm.used</span></code> global is an array which has
+<a class="reference internal" href="#linkage-appending"><span class="std std-ref">appending linkage</span></a>. This array contains a list of
+pointers to named global variables, functions and aliases which may optionally
+have a pointer cast formed of bitcast or getelementptr. For example, a legal
+use of it is:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="vg">@X</span> <span class="p">=</span> <span class="k">global</span> <span class="k">i8</span> <span class="m">4</span>
+<span class="vg">@Y</span> <span class="p">=</span> <span class="k">global</span> <span class="k">i32</span> <span class="m">123</span>
+
+<span class="vg">@llvm.used</span> <span class="p">=</span> <span class="k">appending</span> <span class="k">global</span> <span class="p">[</span><span class="m">2</span> <span class="k">x</span> <span class="k">i8</span><span class="p">*]</span> <span class="p">[</span>
+ <span class="k">i8</span><span class="p">*</span> <span class="vg">@X</span><span class="p">,</span>
+ <span class="k">i8</span><span class="p">*</span> <span class="k">bitcast</span> <span class="p">(</span><span class="k">i32</span><span class="p">*</span> <span class="vg">@Y</span> <span class="k">to</span> <span class="k">i8</span><span class="p">*)</span>
+<span class="p">],</span> <span class="k">section</span> <span class="s">"llvm.metadata"</span>
+</pre></div>
+</div>
+<p>If a symbol appears in the <code class="docutils literal notranslate"><span class="pre">@llvm.used</span></code> list, then the compiler, assembler,
+and linker are required to treat the symbol as if there is a reference to the
+symbol that it cannot see (which is why they have to be named). For example, if
+a variable has internal linkage and no references other than that from the
+<code class="docutils literal notranslate"><span class="pre">@llvm.used</span></code> list, it cannot be deleted. This is commonly used to represent
+references from inline asms and other things the compiler cannot âseeâ, and
+corresponds to â<code class="docutils literal notranslate"><span class="pre">attribute((used))</span></code>â in GNU C.</p>
+<p>On some targets, the code generator must emit a directive to the
+assembler or object file to prevent the assembler and linker from
+molesting the symbol.</p>
+</div>
+<div class="section" id="the-llvm-compiler-used-global-variable">
+<span id="gv-llvmcompilerused"></span><h3><a class="toc-backref" href="#id1125">The â<code class="docutils literal notranslate"><span class="pre">llvm.compiler.used</span></code>â Global Variable</a><a class="headerlink" href="#the-llvm-compiler-used-global-variable" title="Permalink to this headline">¶</a></h3>
+<p>The <code class="docutils literal notranslate"><span class="pre">@llvm.compiler.used</span></code> directive is the same as the <code class="docutils literal notranslate"><span class="pre">@llvm.used</span></code>
+directive, except that it only prevents the compiler from touching the
+symbol. On targets that support it, this allows an intelligent linker to
+optimize references to the symbol without being impeded as it would be
+by <code class="docutils literal notranslate"><span class="pre">@llvm.used</span></code>.</p>
+<p>This is a rare construct that should only be used in rare circumstances,
+and should not be exposed to source languages.</p>
+</div>
+<div class="section" id="the-llvm-global-ctors-global-variable">
+<span id="gv-llvmglobalctors"></span><h3><a class="toc-backref" href="#id1126">The â<code class="docutils literal notranslate"><span class="pre">llvm.global_ctors</span></code>â Global Variable</a><a class="headerlink" href="#the-llvm-global-ctors-global-variable" title="Permalink to this headline">¶</a></h3>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">%0</span> <span class="p">=</span> <span class="k">type</span> <span class="p">{</span> <span class="k">i32</span><span class="p">,</span> <span class="kt">void</span> <span class="p">()*,</span> <span class="k">i8</span><span class="p">*</span> <span class="p">}</span>
+<span class="vg">@llvm.global_ctors</span> <span class="p">=</span> <span class="k">appending</span> <span class="k">global</span> <span class="p">[</span><span class="m">1</span> <span class="k">x</span> <span class="nv nv-Anonymous">%0</span><span class="p">]</span> <span class="p">[</span><span class="nv nv-Anonymous">%0</span> <span class="p">{</span> <span class="k">i32</span> <span class="m">65535</span><span class="p">,</span> <span class="kt">void</span> <span class="p">()*</span> <span class="vg">@ctor</span><span class="p">,</span> <span class="k">i8</span><span class="p">*</span> <span class="vg">@data</span> <span class="p">}]</span>
+</pre></div>
+</div>
+<p>The <code class="docutils literal notranslate"><span class="pre">@llvm.global_ctors</span></code> array contains a list of constructor
+functions, priorities, and an optional associated global or function.
+The functions referenced by this array will be called in ascending order
+of priority (i.e. lowest first) when the module is loaded. The order of
+functions with the same priority is not defined.</p>
+<p>If the third field is present, non-null, and points to a global variable
+or function, the initializer function will only run if the associated
+data from the current module is not discarded.</p>
+</div>
+<div class="section" id="the-llvm-global-dtors-global-variable">
+<span id="llvmglobaldtors"></span><h3><a class="toc-backref" href="#id1127">The â<code class="docutils literal notranslate"><span class="pre">llvm.global_dtors</span></code>â Global Variable</a><a class="headerlink" href="#the-llvm-global-dtors-global-variable" title="Permalink to this headline">¶</a></h3>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv nv-Anonymous">%0</span> <span class="p">=</span> <span class="k">type</span> <span class="p">{</span> <span class="k">i32</span><span class="p">,</span> <span class="kt">void</span> <span class="p">()*,</span> <span class="k">i8</span><span class="p">*</span> <span class="p">}</span>
+<span class="vg">@llvm.global_dtors</span> <span class="p">=</span> <span class="k">appending</span> <span class="k">global</span> <span class="p">[</span><span class="m">1</span> <span class="k">x</span> <span class="nv nv-Anonymous">%0</span><span class="p">]</span> <span class="p">[</span><span class="nv nv-Anonymous">%0</span> <span class="p">{</span> <span class="k">i32</span> <span class="m">65535</span><span class="p">,</span> <span class="kt">void</span> <span class="p">()*</span> <span class="vg">@dtor</span><span class="p">,</span> <span class="k">i8</span><span class="p">*</span> <span class="vg">@data</span> <span class="p">}]</span>
+</pre></div>
+</div>
+<p>The <code class="docutils literal notranslate"><span class="pre">@llvm.global_dtors</span></code> array contains a list of destructor
+functions, priorities, and an optional associated global or function.
+The functions referenced by this array will be called in descending
+order of priority (i.e. highest first) when the module is unloaded. The
+order of functions with the same priority is not defined.</p>
+<p>If the third field is present, non-null, and points to a global variable
+or function, the destructor function will only run if the associated
+data from the current module is not discarded.</p>
+</div>
+</div>
+<div class="section" id="instruction-reference">
+<h2><a class="toc-backref" href="#id1128">Instruction Reference</a><a class="headerlink" href="#instruction-reference" title="Permalink to this headline">¶</a></h2>
+<p>The LLVM instruction set consists of several different classifications
+of instructions: <a class="reference internal" href="#terminators"><span class="std std-ref">terminator instructions</span></a>, <a class="reference internal" href="#binaryops"><span class="std std-ref">binary
+instructions</span></a>, <a class="reference internal" href="#bitwiseops"><span class="std std-ref">bitwise binary
+instructions</span></a>, <a class="reference internal" href="#memoryops"><span class="std std-ref">memory instructions</span></a>, and
+<a class="reference internal" href="#otherops"><span class="std std-ref">other instructions</span></a>.</p>
+<div class="section" id="terminator-instructions">
+<span id="terminators"></span><h3><a class="toc-backref" href="#id1129">Terminator Instructions</a><a class="headerlink" href="#terminator-instructions" title="Permalink to this headline">¶</a></h3>
+<p>As mentioned <a class="reference internal" href="#functionstructure"><span class="std std-ref">previously</span></a>, every basic block in a
+program ends with a âTerminatorâ instruction, which indicates which
+block should be executed after the current block is finished. These
+terminator instructions typically yield a â<code class="docutils literal notranslate"><span class="pre">void</span></code>â value: they produce
+control flow, not values (the one exception being the
+â<a class="reference internal" href="#i-invoke"><span class="std std-ref">invoke</span></a>â instruction).</p>
+<p>The terminator instructions are: â<a class="reference internal" href="#i-ret"><span class="std std-ref">ret</span></a>â,
+â<a class="reference internal" href="#i-br"><span class="std std-ref">br</span></a>â, â<a class="reference internal" href="#i-switch"><span class="std std-ref">switch</span></a>â,
+â<a class="reference internal" href="#i-indirectbr"><span class="std std-ref">indirectbr</span></a>â, â<a class="reference internal" href="#i-invoke"><span class="std std-ref">invoke</span></a>â,
+â<a class="reference internal" href="#i-resume"><span class="std std-ref">resume</span></a>â, â<a class="reference internal" href="#i-catchswitch"><span class="std std-ref">catchswitch</span></a>â,
+â<a class="reference internal" href="#i-catchret"><span class="std std-ref">catchret</span></a>â,
+â<a class="reference internal" href="#i-cleanupret"><span class="std std-ref">cleanupret</span></a>â,
+and â<a class="reference internal" href="#i-unreachable"><span class="std std-ref">unreachable</span></a>â.</p>
+<div class="section" id="ret-instruction">
+<span id="i-ret"></span><h4><a class="toc-backref" href="#id1130">â<code class="docutils literal notranslate"><span class="pre">ret</span></code>â Instruction</a><a class="headerlink" href="#ret-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="syntax">
+<h5><a class="toc-backref" href="#id1131">Syntax:</a><a class="headerlink" href="#syntax" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">ret</span> <span class="o"><</span><span class="nb">type</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="p">;</span> <span class="n">Return</span> <span class="n">a</span> <span class="n">value</span> <span class="kn">from</span> <span class="nn">a</span> <span class="n">non</span><span class="o">-</span><span class="n">void</span> <span class="n">function</span>
+<span class="n">ret</span> <span class="n">void</span> <span class="p">;</span> <span class="n">Return</span> <span class="kn">from</span> <span class="nn">void</span> <span class="n">function</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="overview">
+<h5><a class="toc-backref" href="#id1132">Overview:</a><a class="headerlink" href="#overview" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">ret</span></code>â instruction is used to return control flow (and optionally
+a value) from a function back to the caller.</p>
+<p>There are two forms of the â<code class="docutils literal notranslate"><span class="pre">ret</span></code>â instruction: one that returns a
+value and then causes control flow, and one that just causes control
+flow to occur.</p>
+</div>
+<div class="section" id="arguments">
+<h5><a class="toc-backref" href="#id1133">Arguments:</a><a class="headerlink" href="#arguments" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">ret</span></code>â instruction optionally accepts a single argument, the
+return value. The type of the return value must be a â<a class="reference internal" href="#t-firstclass"><span class="std std-ref">first
+class</span></a>â type.</p>
+<p>A function is not <a class="reference internal" href="#wellformed"><span class="std std-ref">well formed</span></a> if it it has a non-void
+return type and contains a â<code class="docutils literal notranslate"><span class="pre">ret</span></code>â instruction with no return value or
+a return value with a type that does not match its type, or if it has a
+void return type and contains a â<code class="docutils literal notranslate"><span class="pre">ret</span></code>â instruction with a return
+value.</p>
+</div>
+<div class="section" id="id25">
+<h5><a class="toc-backref" href="#id1134">Semantics:</a><a class="headerlink" href="#id25" title="Permalink to this headline">¶</a></h5>
+<p>When the â<code class="docutils literal notranslate"><span class="pre">ret</span></code>â instruction is executed, control flow returns back to
+the calling functionâs context. If the caller is a
+â<a class="reference internal" href="#i-call"><span class="std std-ref">call</span></a>â instruction, execution continues at the
+instruction after the call. If the caller was an
+â<a class="reference internal" href="#i-invoke"><span class="std std-ref">invoke</span></a>â instruction, execution continues at the
+beginning of the ânormalâ destination block. If the instruction returns
+a value, that value shall set the call or invoke instructionâs return
+value.</p>
+</div>
+<div class="section" id="example">
+<h5><a class="toc-backref" href="#id1135">Example:</a><a class="headerlink" href="#example" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">ret</span> <span class="k">i32</span> <span class="m">5</span> <span class="c">; Return an integer value of 5</span>
+<span class="k">ret</span> <span class="kt">void</span> <span class="c">; Return from a void function</span>
+<span class="k">ret</span> <span class="p">{</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i8</span> <span class="p">}</span> <span class="p">{</span> <span class="k">i32</span> <span class="m">4</span><span class="p">,</span> <span class="k">i8</span> <span class="m">2</span> <span class="p">}</span> <span class="c">; Return a struct of values 4 and 2</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="br-instruction">
+<span id="i-br"></span><h4><a class="toc-backref" href="#id1136">â<code class="docutils literal notranslate"><span class="pre">br</span></code>â Instruction</a><a class="headerlink" href="#br-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id26">
+<h5><a class="toc-backref" href="#id1137">Syntax:</a><a class="headerlink" href="#id26" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">br</span> <span class="n">i1</span> <span class="o"><</span><span class="n">cond</span><span class="o">></span><span class="p">,</span> <span class="n">label</span> <span class="o"><</span><span class="n">iftrue</span><span class="o">></span><span class="p">,</span> <span class="n">label</span> <span class="o"><</span><span class="n">iffalse</span><span class="o">></span>
+<span class="n">br</span> <span class="n">label</span> <span class="o"><</span><span class="n">dest</span><span class="o">></span> <span class="p">;</span> <span class="n">Unconditional</span> <span class="n">branch</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id27">
+<h5><a class="toc-backref" href="#id1138">Overview:</a><a class="headerlink" href="#id27" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">br</span></code>â instruction is used to cause control flow to transfer to a
+different basic block in the current function. There are two forms of
+this instruction, corresponding to a conditional branch and an
+unconditional branch.</p>
+</div>
+<div class="section" id="id28">
+<h5><a class="toc-backref" href="#id1139">Arguments:</a><a class="headerlink" href="#id28" title="Permalink to this headline">¶</a></h5>
+<p>The conditional branch form of the â<code class="docutils literal notranslate"><span class="pre">br</span></code>â instruction takes a single
+â<code class="docutils literal notranslate"><span class="pre">i1</span></code>â value and two â<code class="docutils literal notranslate"><span class="pre">label</span></code>â values. The unconditional form of the
+â<code class="docutils literal notranslate"><span class="pre">br</span></code>â instruction takes a single â<code class="docutils literal notranslate"><span class="pre">label</span></code>â value as a target.</p>
+</div>
+<div class="section" id="id29">
+<h5><a class="toc-backref" href="#id1140">Semantics:</a><a class="headerlink" href="#id29" title="Permalink to this headline">¶</a></h5>
+<p>Upon execution of a conditional â<code class="docutils literal notranslate"><span class="pre">br</span></code>â instruction, the â<code class="docutils literal notranslate"><span class="pre">i1</span></code>â
+argument is evaluated. If the value is <code class="docutils literal notranslate"><span class="pre">true</span></code>, control flows to the
+â<code class="docutils literal notranslate"><span class="pre">iftrue</span></code>â <code class="docutils literal notranslate"><span class="pre">label</span></code> argument. If âcondâ is <code class="docutils literal notranslate"><span class="pre">false</span></code>, control flows
+to the â<code class="docutils literal notranslate"><span class="pre">iffalse</span></code>â <code class="docutils literal notranslate"><span class="pre">label</span></code> argument.</p>
+</div>
+<div class="section" id="id30">
+<h5><a class="toc-backref" href="#id1141">Example:</a><a class="headerlink" href="#id30" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nl">Test:</span>
+ <span class="nv">%cond</span> <span class="p">=</span> <span class="k">icmp</span> <span class="k">eq</span> <span class="k">i32</span> <span class="nv">%a</span><span class="p">,</span> <span class="nv">%b</span>
+ <span class="k">br</span> <span class="k">i1</span> <span class="nv">%cond</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%IfEqual</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%IfUnequal</span>
+<span class="nl">IfEqual:</span>
+ <span class="k">ret</span> <span class="k">i32</span> <span class="m">1</span>
+<span class="nl">IfUnequal:</span>
+ <span class="k">ret</span> <span class="k">i32</span> <span class="m">0</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="switch-instruction">
+<span id="i-switch"></span><h4><a class="toc-backref" href="#id1142">â<code class="docutils literal notranslate"><span class="pre">switch</span></code>â Instruction</a><a class="headerlink" href="#switch-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id31">
+<h5><a class="toc-backref" href="#id1143">Syntax:</a><a class="headerlink" href="#id31" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">switch</span> <span class="o"><</span><span class="n">intty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span><span class="p">,</span> <span class="n">label</span> <span class="o"><</span><span class="n">defaultdest</span><span class="o">></span> <span class="p">[</span> <span class="o"><</span><span class="n">intty</span><span class="o">></span> <span class="o"><</span><span class="n">val</span><span class="o">></span><span class="p">,</span> <span class="n">label</span> <span class="o"><</span><span class="n">dest</span><span class="o">></span> <span class="o">...</span> <span class="p">]</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id32">
+<h5><a class="toc-backref" href="#id1144">Overview:</a><a class="headerlink" href="#id32" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">switch</span></code>â instruction is used to transfer control flow to one of
+several different places. It is a generalization of the â<code class="docutils literal notranslate"><span class="pre">br</span></code>â
+instruction, allowing a branch to occur to one of many possible
+destinations.</p>
+</div>
+<div class="section" id="id33">
+<h5><a class="toc-backref" href="#id1145">Arguments:</a><a class="headerlink" href="#id33" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">switch</span></code>â instruction uses three parameters: an integer
+comparison value â<code class="docutils literal notranslate"><span class="pre">value</span></code>â, a default â<code class="docutils literal notranslate"><span class="pre">label</span></code>â destination, and an
+array of pairs of comparison value constants and â<code class="docutils literal notranslate"><span class="pre">label</span></code>âs. The table
+is not allowed to contain duplicate constant entries.</p>
+</div>
+<div class="section" id="id34">
+<h5><a class="toc-backref" href="#id1146">Semantics:</a><a class="headerlink" href="#id34" title="Permalink to this headline">¶</a></h5>
+<p>The <code class="docutils literal notranslate"><span class="pre">switch</span></code> instruction specifies a table of values and destinations.
+When the â<code class="docutils literal notranslate"><span class="pre">switch</span></code>â instruction is executed, this table is searched
+for the given value. If the value is found, control flow is transferred
+to the corresponding destination; otherwise, control flow is transferred
+to the default destination.</p>
+</div>
+<div class="section" id="implementation">
+<h5><a class="toc-backref" href="#id1147">Implementation:</a><a class="headerlink" href="#implementation" title="Permalink to this headline">¶</a></h5>
+<p>Depending on properties of the target machine and the particular
+<code class="docutils literal notranslate"><span class="pre">switch</span></code> instruction, this instruction may be code generated in
+different ways. For example, it could be generated as a series of
+chained conditional branches or with a lookup table.</p>
+</div>
+<div class="section" id="id35">
+<h5><a class="toc-backref" href="#id1148">Example:</a><a class="headerlink" href="#id35" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="c">; Emulate a conditional br instruction</span>
+<span class="nv">%Val</span> <span class="p">=</span> <span class="k">zext</span> <span class="k">i1</span> <span class="nv">%value</span> <span class="k">to</span> <span class="k">i32</span>
+<span class="k">switch</span> <span class="k">i32</span> <span class="nv">%Val</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%truedest</span> <span class="p">[</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%falsedest</span> <span class="p">]</span>
+
+<span class="c">; Emulate an unconditional br instruction</span>
+<span class="k">switch</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%dest</span> <span class="p">[</span> <span class="p">]</span>
+
+<span class="c">; Implement a jump table:</span>
+<span class="k">switch</span> <span class="k">i32</span> <span class="nv">%val</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%otherwise</span> <span class="p">[</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%onzero</span>
+ <span class="k">i32</span> <span class="m">1</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%onone</span>
+ <span class="k">i32</span> <span class="m">2</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%ontwo</span> <span class="p">]</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="indirectbr-instruction">
+<span id="i-indirectbr"></span><h4><a class="toc-backref" href="#id1149">â<code class="docutils literal notranslate"><span class="pre">indirectbr</span></code>â Instruction</a><a class="headerlink" href="#indirectbr-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id36">
+<h5><a class="toc-backref" href="#id1150">Syntax:</a><a class="headerlink" href="#id36" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">indirectbr</span> <span class="o"><</span><span class="n">somety</span><span class="o">>*</span> <span class="o"><</span><span class="n">address</span><span class="o">></span><span class="p">,</span> <span class="p">[</span> <span class="n">label</span> <span class="o"><</span><span class="n">dest1</span><span class="o">></span><span class="p">,</span> <span class="n">label</span> <span class="o"><</span><span class="n">dest2</span><span class="o">></span><span class="p">,</span> <span class="o">...</span> <span class="p">]</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id37">
+<h5><a class="toc-backref" href="#id1151">Overview:</a><a class="headerlink" href="#id37" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">indirectbr</span></code>â instruction implements an indirect branch to a
+label within the current function, whose address is specified by
+â<code class="docutils literal notranslate"><span class="pre">address</span></code>â. Address must be derived from a
+<a class="reference internal" href="#blockaddress"><span class="std std-ref">blockaddress</span></a> constant.</p>
+</div>
+<div class="section" id="id38">
+<h5><a class="toc-backref" href="#id1152">Arguments:</a><a class="headerlink" href="#id38" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">address</span></code>â argument is the address of the label to jump to. The
+rest of the arguments indicate the full set of possible destinations
+that the address may point to. Blocks are allowed to occur multiple
+times in the destination list, though this isnât particularly useful.</p>
+<p>This destination list is required so that dataflow analysis has an
+accurate understanding of the CFG.</p>
+</div>
+<div class="section" id="id39">
+<h5><a class="toc-backref" href="#id1153">Semantics:</a><a class="headerlink" href="#id39" title="Permalink to this headline">¶</a></h5>
+<p>Control transfers to the block specified in the address argument. All
+possible destination blocks must be listed in the label list, otherwise
+this instruction has undefined behavior. This implies that jumps to
+labels defined in other functions have undefined behavior as well.</p>
+</div>
+<div class="section" id="id40">
+<h5><a class="toc-backref" href="#id1154">Implementation:</a><a class="headerlink" href="#id40" title="Permalink to this headline">¶</a></h5>
+<p>This is typically implemented with a jump through a register.</p>
+</div>
+<div class="section" id="id41">
+<h5><a class="toc-backref" href="#id1155">Example:</a><a class="headerlink" href="#id41" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">indirectbr</span> <span class="k">i8</span><span class="p">*</span> <span class="nv">%Addr</span><span class="p">,</span> <span class="p">[</span> <span class="kt">label</span> <span class="nv">%bb1</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%bb2</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%bb3</span> <span class="p">]</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="invoke-instruction">
+<span id="i-invoke"></span><h4><a class="toc-backref" href="#id1156">â<code class="docutils literal notranslate"><span class="pre">invoke</span></code>â Instruction</a><a class="headerlink" href="#invoke-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id42">
+<h5><a class="toc-backref" href="#id1157">Syntax:</a><a class="headerlink" href="#id42" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">invoke</span> <span class="p">[</span><span class="n">cconv</span><span class="p">]</span> <span class="p">[</span><span class="n">ret</span> <span class="n">attrs</span><span class="p">]</span> <span class="p">[</span><span class="n">addrspace</span><span class="p">(</span><span class="o"><</span><span class="n">num</span><span class="o">></span><span class="p">)]</span> <span class="p">[</span><span class="o"><</span><span class="n">ty</span><span class="o">>|<</span><span class="n">fnty</span><span class="o">></span> <span class="o"><</span><span class="n">fnptrval</span><span class="o">></span><span class="p">(</span><span class="o"><</span><span class="n">function</span> <span class="n">args</span><span class="o">></span><span class="p">)</span> <span class="p">[</span><span class="n">fn</span> <span class="n">attrs</span><span class="p">]</span>
+ <span class="p">[</span><span class="n">operand</span> <span class="n">bundles</span><span class="p">]</span> <span class="n">to</span> <span class="n">label</span> <span class="o"><</span><span class="n">normal</span> <span class="n">label</span><span class="o">></span> <span class="n">unwind</span> <span class="n">label</span> <span class="o"><</span><span class="n">exception</span> <span class="n">label</span><span class="o">></span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id43">
+<h5><a class="toc-backref" href="#id1158">Overview:</a><a class="headerlink" href="#id43" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">invoke</span></code>â instruction causes control to transfer to a specified
+function, with the possibility of control flow transfer to either the
+â<code class="docutils literal notranslate"><span class="pre">normal</span></code>â label or the â<code class="docutils literal notranslate"><span class="pre">exception</span></code>â label. If the callee function
+returns with the â<code class="docutils literal notranslate"><span class="pre">ret</span></code>â instruction, control flow will return to the
+ânormalâ label. If the callee (or any indirect callees) returns via the
+â<a class="reference internal" href="#i-resume"><span class="std std-ref">resume</span></a>â instruction or other exception handling
+mechanism, control is interrupted and continued at the dynamically
+nearest âexceptionâ label.</p>
+<p>The â<code class="docutils literal notranslate"><span class="pre">exception</span></code>â label is a <a class="reference external" href="ExceptionHandling.html#overview">landing
+pad</a> for the exception. As such,
+â<code class="docutils literal notranslate"><span class="pre">exception</span></code>â label is required to have the
+â<a class="reference internal" href="#i-landingpad"><span class="std std-ref">landingpad</span></a>â instruction, which contains the
+information about the behavior of the program after unwinding happens,
+as its first non-PHI instruction. The restrictions on the
+â<code class="docutils literal notranslate"><span class="pre">landingpad</span></code>â instructionâs tightly couples it to the â<code class="docutils literal notranslate"><span class="pre">invoke</span></code>â
+instruction, so that the important information contained within the
+â<code class="docutils literal notranslate"><span class="pre">landingpad</span></code>â instruction canât be lost through normal code motion.</p>
+</div>
+<div class="section" id="id44">
+<h5><a class="toc-backref" href="#id1159">Arguments:</a><a class="headerlink" href="#id44" title="Permalink to this headline">¶</a></h5>
+<p>This instruction requires several arguments:</p>
+<ol class="arabic simple">
+<li>The optional âcconvâ marker indicates which <a class="reference internal" href="#callingconv"><span class="std std-ref">calling
+convention</span></a> the call should use. If none is
+specified, the call defaults to using C calling conventions.</li>
+<li>The optional <a class="reference internal" href="#paramattrs"><span class="std std-ref">Parameter Attributes</span></a> list for return
+values. Only â<code class="docutils literal notranslate"><span class="pre">zeroext</span></code>â, â<code class="docutils literal notranslate"><span class="pre">signext</span></code>â, and â<code class="docutils literal notranslate"><span class="pre">inreg</span></code>â attributes
+are valid here.</li>
+<li>The optional addrspace attribute can be used to indicate the address space
+of the called function. If it is not specified, the program address space
+from the <a class="reference internal" href="#langref-datalayout"><span class="std std-ref">datalayout string</span></a> will be used.</li>
+<li>â<code class="docutils literal notranslate"><span class="pre">ty</span></code>â: the type of the call instruction itself which is also the
+type of the return value. Functions that return no value are marked
+<code class="docutils literal notranslate"><span class="pre">void</span></code>.</li>
+<li>â<code class="docutils literal notranslate"><span class="pre">fnty</span></code>â: shall be the signature of the function being invoked. The
+argument types must match the types implied by this signature. This
+type can be omitted if the function is not varargs.</li>
+<li>â<code class="docutils literal notranslate"><span class="pre">fnptrval</span></code>â: An LLVM value containing a pointer to a function to
+be invoked. In most cases, this is a direct function invocation, but
+indirect <code class="docutils literal notranslate"><span class="pre">invoke</span></code>âs are just as possible, calling an arbitrary pointer
+to function value.</li>
+<li>â<code class="docutils literal notranslate"><span class="pre">function</span> <span class="pre">args</span></code>â: argument list whose types match the function
+signature argument types and parameter attributes. All arguments must
+be of <a class="reference internal" href="#t-firstclass"><span class="std std-ref">first class</span></a> type. If the function signature
+indicates the function accepts a variable number of arguments, the
+extra arguments can be specified.</li>
+<li>â<code class="docutils literal notranslate"><span class="pre">normal</span> <span class="pre">label</span></code>â: the label reached when the called function
+executes a â<code class="docutils literal notranslate"><span class="pre">ret</span></code>â instruction.</li>
+<li>â<code class="docutils literal notranslate"><span class="pre">exception</span> <span class="pre">label</span></code>â: the label reached when a callee returns via
+the <a class="reference internal" href="#i-resume"><span class="std std-ref">resume</span></a> instruction or other exception handling
+mechanism.</li>
+<li>The optional <a class="reference internal" href="#fnattrs"><span class="std std-ref">function attributes</span></a> list.</li>
+<li>The optional <a class="reference internal" href="#opbundles"><span class="std std-ref">operand bundles</span></a> list.</li>
+</ol>
+</div>
+<div class="section" id="id45">
+<h5><a class="toc-backref" href="#id1160">Semantics:</a><a class="headerlink" href="#id45" title="Permalink to this headline">¶</a></h5>
+<p>This instruction is designed to operate as a standard â<code class="docutils literal notranslate"><span class="pre">call</span></code>â
+instruction in most regards. The primary difference is that it
+establishes an association with a label, which is used by the runtime
+library to unwind the stack.</p>
+<p>This instruction is used in languages with destructors to ensure that
+proper cleanup is performed in the case of either a <code class="docutils literal notranslate"><span class="pre">longjmp</span></code> or a
+thrown exception. Additionally, this is important for implementation of
+â<code class="docutils literal notranslate"><span class="pre">catch</span></code>â clauses in high-level languages that support them.</p>
+<p>For the purposes of the SSA form, the definition of the value returned
+by the â<code class="docutils literal notranslate"><span class="pre">invoke</span></code>â instruction is deemed to occur on the edge from the
+current block to the ânormalâ label. If the callee unwinds then no
+return value is available.</p>
+</div>
+<div class="section" id="id46">
+<h5><a class="toc-backref" href="#id1161">Example:</a><a class="headerlink" href="#id46" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%retval</span> <span class="p">=</span> <span class="k">invoke</span> <span class="k">i32</span> <span class="vg">@Test</span><span class="p">(</span><span class="k">i32</span> <span class="m">15</span><span class="p">)</span> <span class="k">to</span> <span class="kt">label</span> <span class="nv">%Continue</span>
+ <span class="k">unwind</span> <span class="kt">label</span> <span class="nv">%TestCleanup</span> <span class="c">; i32:retval set</span>
+<span class="nv">%retval</span> <span class="p">=</span> <span class="k">invoke</span> <span class="k">coldcc</span> <span class="k">i32</span> <span class="nv">%Testfnptr</span><span class="p">(</span><span class="k">i32</span> <span class="m">15</span><span class="p">)</span> <span class="k">to</span> <span class="kt">label</span> <span class="nv">%Continue</span>
+ <span class="k">unwind</span> <span class="kt">label</span> <span class="nv">%TestCleanup</span> <span class="c">; i32:retval set</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="resume-instruction">
+<span id="i-resume"></span><h4><a class="toc-backref" href="#id1162">â<code class="docutils literal notranslate"><span class="pre">resume</span></code>â Instruction</a><a class="headerlink" href="#resume-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id47">
+<h5><a class="toc-backref" href="#id1163">Syntax:</a><a class="headerlink" href="#id47" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">resume</span> <span class="o"><</span><span class="nb">type</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id48">
+<h5><a class="toc-backref" href="#id1164">Overview:</a><a class="headerlink" href="#id48" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">resume</span></code>â instruction is a terminator instruction that has no
+successors.</p>
+</div>
+<div class="section" id="id49">
+<h5><a class="toc-backref" href="#id1165">Arguments:</a><a class="headerlink" href="#id49" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">resume</span></code>â instruction requires one argument, which must have the
+same type as the result of any â<code class="docutils literal notranslate"><span class="pre">landingpad</span></code>â instruction in the same
+function.</p>
+</div>
+<div class="section" id="id50">
+<h5><a class="toc-backref" href="#id1166">Semantics:</a><a class="headerlink" href="#id50" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">resume</span></code>â instruction resumes propagation of an existing
+(in-flight) exception whose unwinding was interrupted with a
+<a class="reference internal" href="#i-landingpad"><span class="std std-ref">landingpad</span></a> instruction.</p>
+</div>
+<div class="section" id="id51">
+<h5><a class="toc-backref" href="#id1167">Example:</a><a class="headerlink" href="#id51" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">resume</span> <span class="p">{</span> <span class="k">i8</span><span class="p">*,</span> <span class="k">i32</span> <span class="p">}</span> <span class="nv">%exn</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="catchswitch-instruction">
+<span id="i-catchswitch"></span><h4><a class="toc-backref" href="#id1168">â<code class="docutils literal notranslate"><span class="pre">catchswitch</span></code>â Instruction</a><a class="headerlink" href="#catchswitch-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id52">
+<h5><a class="toc-backref" href="#id1169">Syntax:</a><a class="headerlink" href="#id52" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">resultval</span><span class="o">></span> <span class="o">=</span> <span class="n">catchswitch</span> <span class="n">within</span> <span class="o"><</span><span class="n">parent</span><span class="o">></span> <span class="p">[</span> <span class="n">label</span> <span class="o"><</span><span class="n">handler1</span><span class="o">></span><span class="p">,</span> <span class="n">label</span> <span class="o"><</span><span class="n">handler2</span><span class="o">></span><span class="p">,</span> <span class="o">...</span> <span class="p">]</span> <span class="n">unwind</span> <span class="n">to</span> <span class="n">caller</span>
+<span class="o"><</span><span class="n">resultval</span><span class="o">></span> <span class="o">=</span> <span class="n">catchswitch</span> <span class="n">within</span> <span class="o"><</span><span class="n">parent</span><span class="o">></span> <span class="p">[</span> <span class="n">label</span> <span class="o"><</span><span class="n">handler1</span><span class="o">></span><span class="p">,</span> <span class="n">label</span> <span class="o"><</span><span class="n">handler2</span><span class="o">></span><span class="p">,</span> <span class="o">...</span> <span class="p">]</span> <span class="n">unwind</span> <span class="n">label</span> <span class="o"><</span><span class="n">default</span><span class="o">></span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id53">
+<h5><a class="toc-backref" href="#id1170">Overview:</a><a class="headerlink" href="#id53" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">catchswitch</span></code>â instruction is used by <a class="reference external" href="ExceptionHandling.html#overview">LLVMâs exception handling system</a> to describe the set of possible catch handlers
+that may be executed by the <a class="reference internal" href="#personalityfn"><span class="std std-ref">EH personality routine</span></a>.</p>
+</div>
+<div class="section" id="id54">
+<h5><a class="toc-backref" href="#id1171">Arguments:</a><a class="headerlink" href="#id54" title="Permalink to this headline">¶</a></h5>
+<p>The <code class="docutils literal notranslate"><span class="pre">parent</span></code> argument is the token of the funclet that contains the
+<code class="docutils literal notranslate"><span class="pre">catchswitch</span></code> instruction. If the <code class="docutils literal notranslate"><span class="pre">catchswitch</span></code> is not inside a funclet,
+this operand may be the token <code class="docutils literal notranslate"><span class="pre">none</span></code>.</p>
+<p>The <code class="docutils literal notranslate"><span class="pre">default</span></code> argument is the label of another basic block beginning with
+either a <code class="docutils literal notranslate"><span class="pre">cleanuppad</span></code> or <code class="docutils literal notranslate"><span class="pre">catchswitch</span></code> instruction. This unwind destination
+must be a legal target with respect to the <code class="docutils literal notranslate"><span class="pre">parent</span></code> links, as described in
+the <a class="reference external" href="ExceptionHandling.html#wineh-constraints">exception handling documentation</a>.</p>
+<p>The <code class="docutils literal notranslate"><span class="pre">handlers</span></code> are a nonempty list of successor blocks that each begin with a
+<a class="reference internal" href="#i-catchpad"><span class="std std-ref">catchpad</span></a> instruction.</p>
+</div>
+<div class="section" id="id55">
+<h5><a class="toc-backref" href="#id1172">Semantics:</a><a class="headerlink" href="#id55" title="Permalink to this headline">¶</a></h5>
+<p>Executing this instruction transfers control to one of the successors in
+<code class="docutils literal notranslate"><span class="pre">handlers</span></code>, if appropriate, or continues to unwind via the unwind label if
+present.</p>
+<p>The <code class="docutils literal notranslate"><span class="pre">catchswitch</span></code> is both a terminator and a âpadâ instruction, meaning that
+it must be both the first non-phi instruction and last instruction in the basic
+block. Therefore, it must be the only non-phi instruction in the block.</p>
+</div>
+<div class="section" id="id56">
+<h5><a class="toc-backref" href="#id1173">Example:</a><a class="headerlink" href="#id56" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>dispatch1:
+ %cs1 = catchswitch within none [label %handler0, label %handler1] unwind to caller
+dispatch2:
+ %cs2 = catchswitch within %parenthandler [label %handler0] unwind label %cleanup
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="catchret-instruction">
+<span id="i-catchret"></span><h4><a class="toc-backref" href="#id1174">â<code class="docutils literal notranslate"><span class="pre">catchret</span></code>â Instruction</a><a class="headerlink" href="#catchret-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id57">
+<h5><a class="toc-backref" href="#id1175">Syntax:</a><a class="headerlink" href="#id57" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">catchret</span> <span class="kn">from</span> <span class="o"><</span><span class="n">token</span><span class="o">></span> <span class="n">to</span> <span class="n">label</span> <span class="o"><</span><span class="n">normal</span><span class="o">></span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id58">
+<h5><a class="toc-backref" href="#id1176">Overview:</a><a class="headerlink" href="#id58" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">catchret</span></code>â instruction is a terminator instruction that has a
+single successor.</p>
+</div>
+<div class="section" id="id59">
+<h5><a class="toc-backref" href="#id1177">Arguments:</a><a class="headerlink" href="#id59" title="Permalink to this headline">¶</a></h5>
+<p>The first argument to a â<code class="docutils literal notranslate"><span class="pre">catchret</span></code>â indicates which <code class="docutils literal notranslate"><span class="pre">catchpad</span></code> it
+exits. It must be a <a class="reference internal" href="#i-catchpad"><span class="std std-ref">catchpad</span></a>.
+The second argument to a â<code class="docutils literal notranslate"><span class="pre">catchret</span></code>â specifies where control will
+transfer to next.</p>
+</div>
+<div class="section" id="id60">
+<h5><a class="toc-backref" href="#id1178">Semantics:</a><a class="headerlink" href="#id60" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">catchret</span></code>â instruction ends an existing (in-flight) exception whose
+unwinding was interrupted with a <a class="reference internal" href="#i-catchpad"><span class="std std-ref">catchpad</span></a> instruction. The
+<a class="reference internal" href="#personalityfn"><span class="std std-ref">personality function</span></a> gets a chance to execute arbitrary
+code to, for example, destroy the active exception. Control then transfers to
+<code class="docutils literal notranslate"><span class="pre">normal</span></code>.</p>
+<p>The <code class="docutils literal notranslate"><span class="pre">token</span></code> argument must be a token produced by a <code class="docutils literal notranslate"><span class="pre">catchpad</span></code> instruction.
+If the specified <code class="docutils literal notranslate"><span class="pre">catchpad</span></code> is not the most-recently-entered not-yet-exited
+funclet pad (as described in the <a class="reference external" href="ExceptionHandling.html#wineh-constraints">EH documentation</a>),
+the <code class="docutils literal notranslate"><span class="pre">catchret</span></code>âs behavior is undefined.</p>
+</div>
+<div class="section" id="id61">
+<h5><a class="toc-backref" href="#id1179">Example:</a><a class="headerlink" href="#id61" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>catchret from %catch label %continue
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="cleanupret-instruction">
+<span id="i-cleanupret"></span><h4><a class="toc-backref" href="#id1180">â<code class="docutils literal notranslate"><span class="pre">cleanupret</span></code>â Instruction</a><a class="headerlink" href="#cleanupret-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id62">
+<h5><a class="toc-backref" href="#id1181">Syntax:</a><a class="headerlink" href="#id62" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">cleanupret</span> <span class="kn">from</span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="n">unwind</span> <span class="n">label</span> <span class="o"><</span><span class="k">continue</span><span class="o">></span>
+<span class="n">cleanupret</span> <span class="kn">from</span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="n">unwind</span> <span class="n">to</span> <span class="n">caller</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id63">
+<h5><a class="toc-backref" href="#id1182">Overview:</a><a class="headerlink" href="#id63" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">cleanupret</span></code>â instruction is a terminator instruction that has
+an optional successor.</p>
+</div>
+<div class="section" id="id64">
+<h5><a class="toc-backref" href="#id1183">Arguments:</a><a class="headerlink" href="#id64" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">cleanupret</span></code>â instruction requires one argument, which indicates
+which <code class="docutils literal notranslate"><span class="pre">cleanuppad</span></code> it exits, and must be a <a class="reference internal" href="#i-cleanuppad"><span class="std std-ref">cleanuppad</span></a>.
+If the specified <code class="docutils literal notranslate"><span class="pre">cleanuppad</span></code> is not the most-recently-entered not-yet-exited
+funclet pad (as described in the <a class="reference external" href="ExceptionHandling.html#wineh-constraints">EH documentation</a>),
+the <code class="docutils literal notranslate"><span class="pre">cleanupret</span></code>âs behavior is undefined.</p>
+<p>The â<code class="docutils literal notranslate"><span class="pre">cleanupret</span></code>â instruction also has an optional successor, <code class="docutils literal notranslate"><span class="pre">continue</span></code>,
+which must be the label of another basic block beginning with either a
+<code class="docutils literal notranslate"><span class="pre">cleanuppad</span></code> or <code class="docutils literal notranslate"><span class="pre">catchswitch</span></code> instruction. This unwind destination must
+be a legal target with respect to the <code class="docutils literal notranslate"><span class="pre">parent</span></code> links, as described in the
+<a class="reference external" href="ExceptionHandling.html#wineh-constraints">exception handling documentation</a>.</p>
+</div>
+<div class="section" id="id67">
+<h5><a class="toc-backref" href="#id1184">Semantics:</a><a class="headerlink" href="#id67" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">cleanupret</span></code>â instruction indicates to the
+<a class="reference internal" href="#personalityfn"><span class="std std-ref">personality function</span></a> that one
+<a class="reference internal" href="#i-cleanuppad"><span class="std std-ref">cleanuppad</span></a> it transferred control to has ended.
+It transfers control to <code class="docutils literal notranslate"><span class="pre">continue</span></code> or unwinds out of the function.</p>
+</div>
+<div class="section" id="id68">
+<h5><a class="toc-backref" href="#id1185">Example:</a><a class="headerlink" href="#id68" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>cleanupret from %cleanup unwind to caller
+cleanupret from %cleanup unwind label %continue
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="unreachable-instruction">
+<span id="i-unreachable"></span><h4><a class="toc-backref" href="#id1186">â<code class="docutils literal notranslate"><span class="pre">unreachable</span></code>â Instruction</a><a class="headerlink" href="#unreachable-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id69">
+<h5><a class="toc-backref" href="#id1187">Syntax:</a><a class="headerlink" href="#id69" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">unreachable</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id70">
+<h5><a class="toc-backref" href="#id1188">Overview:</a><a class="headerlink" href="#id70" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">unreachable</span></code>â instruction has no defined semantics. This
+instruction is used to inform the optimizer that a particular portion of
+the code is not reachable. This can be used to indicate that the code
+after a no-return function cannot be reached, and other facts.</p>
+</div>
+<div class="section" id="id71">
+<h5><a class="toc-backref" href="#id1189">Semantics:</a><a class="headerlink" href="#id71" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">unreachable</span></code>â instruction has no defined semantics.</p>
+</div>
+</div>
+</div>
+<div class="section" id="unary-operations">
+<span id="unaryops"></span><h3><a class="toc-backref" href="#id1190">Unary Operations</a><a class="headerlink" href="#unary-operations" title="Permalink to this headline">¶</a></h3>
+<p>Unary operators require a single operand, execute an operation on
+it, and produce a single value. The operand might represent multiple
+data, as is the case with the <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> data type. The
+result value has the same type as its operand.</p>
+<div class="section" id="fneg-instruction">
+<span id="i-fneg"></span><h4><a class="toc-backref" href="#id1191">â<code class="docutils literal notranslate"><span class="pre">fneg</span></code>â Instruction</a><a class="headerlink" href="#fneg-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id72">
+<h5><a class="toc-backref" href="#id1192">Syntax:</a><a class="headerlink" href="#id72" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">fneg</span> <span class="p">[</span><span class="n">fast</span><span class="o">-</span><span class="n">math</span> <span class="n">flags</span><span class="p">]</span><span class="o">*</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id73">
+<h5><a class="toc-backref" href="#id1193">Overview:</a><a class="headerlink" href="#id73" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fneg</span></code>â instruction returns the negation of its operand.</p>
+</div>
+<div class="section" id="id74">
+<h5><a class="toc-backref" href="#id1194">Arguments:</a><a class="headerlink" href="#id74" title="Permalink to this headline">¶</a></h5>
+<p>The argument to the â<code class="docutils literal notranslate"><span class="pre">fneg</span></code>â instruction must be a
+<a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of
+floating-point values.</p>
+</div>
+<div class="section" id="id75">
+<h5><a class="toc-backref" href="#id1195">Semantics:</a><a class="headerlink" href="#id75" title="Permalink to this headline">¶</a></h5>
+<p>The value produced is a copy of the operand with its sign bit flipped.
+This instruction can also take any number of <a class="reference internal" href="#fastmath"><span class="std std-ref">fast-math
+flags</span></a>, which are optimization hints to enable otherwise
+unsafe floating-point optimizations:</p>
+</div>
+<div class="section" id="id76">
+<h5><a class="toc-backref" href="#id1196">Example:</a><a class="headerlink" href="#id76" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = fneg float %val ; yields float:result = -%var
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+<div class="section" id="binary-operations">
+<span id="binaryops"></span><h3><a class="toc-backref" href="#id1197">Binary Operations</a><a class="headerlink" href="#binary-operations" title="Permalink to this headline">¶</a></h3>
+<p>Binary operators are used to do most of the computation in a program.
+They require two operands of the same type, execute an operation on
+them, and produce a single value. The operands might represent multiple
+data, as is the case with the <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> data type. The
+result value has the same type as its operands.</p>
+<p>There are several different binary operators:</p>
+<div class="section" id="add-instruction">
+<span id="i-add"></span><h4><a class="toc-backref" href="#id1198">â<code class="docutils literal notranslate"><span class="pre">add</span></code>â Instruction</a><a class="headerlink" href="#add-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id77">
+<h5><a class="toc-backref" href="#id1199">Syntax:</a><a class="headerlink" href="#id77" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">add</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">add</span> <span class="n">nuw</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">add</span> <span class="n">nsw</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">add</span> <span class="n">nuw</span> <span class="n">nsw</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id78">
+<h5><a class="toc-backref" href="#id1200">Overview:</a><a class="headerlink" href="#id78" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">add</span></code>â instruction returns the sum of its two operands.</p>
+</div>
+<div class="section" id="id79">
+<h5><a class="toc-backref" href="#id1201">Arguments:</a><a class="headerlink" href="#id79" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">add</span></code>â instruction must be
+<a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of integer values. Both
+arguments must have identical types.</p>
+</div>
+<div class="section" id="id80">
+<h5><a class="toc-backref" href="#id1202">Semantics:</a><a class="headerlink" href="#id80" title="Permalink to this headline">¶</a></h5>
+<p>The value produced is the integer sum of the two operands.</p>
+<p>If the sum has unsigned overflow, the result returned is the
+mathematical result modulo 2<sup>n</sup>, where n is the bit width of
+the result.</p>
+<p>Because LLVM integers use a twoâs complement representation, this
+instruction is appropriate for both signed and unsigned integers.</p>
+<p><code class="docutils literal notranslate"><span class="pre">nuw</span></code> and <code class="docutils literal notranslate"><span class="pre">nsw</span></code> stand for âNo Unsigned Wrapâ and âNo Signed Wrapâ,
+respectively. If the <code class="docutils literal notranslate"><span class="pre">nuw</span></code> and/or <code class="docutils literal notranslate"><span class="pre">nsw</span></code> keywords are present, the
+result value of the <code class="docutils literal notranslate"><span class="pre">add</span></code> is a <a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a> if
+unsigned and/or signed overflow, respectively, occurs.</p>
+</div>
+<div class="section" id="id81">
+<h5><a class="toc-backref" href="#id1203">Example:</a><a class="headerlink" href="#id81" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = add i32 4, %var ; yields i32:result = 4 + %var
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="fadd-instruction">
+<span id="i-fadd"></span><h4><a class="toc-backref" href="#id1204">â<code class="docutils literal notranslate"><span class="pre">fadd</span></code>â Instruction</a><a class="headerlink" href="#fadd-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id82">
+<h5><a class="toc-backref" href="#id1205">Syntax:</a><a class="headerlink" href="#id82" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">fadd</span> <span class="p">[</span><span class="n">fast</span><span class="o">-</span><span class="n">math</span> <span class="n">flags</span><span class="p">]</span><span class="o">*</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id83">
+<h5><a class="toc-backref" href="#id1206">Overview:</a><a class="headerlink" href="#id83" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fadd</span></code>â instruction returns the sum of its two operands.</p>
+</div>
+<div class="section" id="id84">
+<h5><a class="toc-backref" href="#id1207">Arguments:</a><a class="headerlink" href="#id84" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">fadd</span></code>â instruction must be
+<a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of
+floating-point values. Both arguments must have identical types.</p>
+</div>
+<div class="section" id="id85">
+<h5><a class="toc-backref" href="#id1208">Semantics:</a><a class="headerlink" href="#id85" title="Permalink to this headline">¶</a></h5>
+<p>The value produced is the floating-point sum of the two operands.
+This instruction is assumed to execute in the default <a class="reference internal" href="#floatenv"><span class="std std-ref">floating-point
+environment</span></a>.
+This instruction can also take any number of <a class="reference internal" href="#fastmath"><span class="std std-ref">fast-math
+flags</span></a>, which are optimization hints to enable otherwise
+unsafe floating-point optimizations:</p>
+</div>
+<div class="section" id="id86">
+<h5><a class="toc-backref" href="#id1209">Example:</a><a class="headerlink" href="#id86" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = fadd float 4.0, %var ; yields float:result = 4.0 + %var
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="sub-instruction">
+<h4><a class="toc-backref" href="#id1210">â<code class="docutils literal notranslate"><span class="pre">sub</span></code>â Instruction</a><a class="headerlink" href="#sub-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id87">
+<h5><a class="toc-backref" href="#id1211">Syntax:</a><a class="headerlink" href="#id87" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">sub</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">sub</span> <span class="n">nuw</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">sub</span> <span class="n">nsw</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">sub</span> <span class="n">nuw</span> <span class="n">nsw</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id88">
+<h5><a class="toc-backref" href="#id1212">Overview:</a><a class="headerlink" href="#id88" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">sub</span></code>â instruction returns the difference of its two operands.</p>
+<p>Note that the â<code class="docutils literal notranslate"><span class="pre">sub</span></code>â instruction is used to represent the â<code class="docutils literal notranslate"><span class="pre">neg</span></code>â
+instruction present in most other intermediate representations.</p>
+</div>
+<div class="section" id="id89">
+<h5><a class="toc-backref" href="#id1213">Arguments:</a><a class="headerlink" href="#id89" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">sub</span></code>â instruction must be
+<a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of integer values. Both
+arguments must have identical types.</p>
+</div>
+<div class="section" id="id90">
+<h5><a class="toc-backref" href="#id1214">Semantics:</a><a class="headerlink" href="#id90" title="Permalink to this headline">¶</a></h5>
+<p>The value produced is the integer difference of the two operands.</p>
+<p>If the difference has unsigned overflow, the result returned is the
+mathematical result modulo 2<sup>n</sup>, where n is the bit width of
+the result.</p>
+<p>Because LLVM integers use a twoâs complement representation, this
+instruction is appropriate for both signed and unsigned integers.</p>
+<p><code class="docutils literal notranslate"><span class="pre">nuw</span></code> and <code class="docutils literal notranslate"><span class="pre">nsw</span></code> stand for âNo Unsigned Wrapâ and âNo Signed Wrapâ,
+respectively. If the <code class="docutils literal notranslate"><span class="pre">nuw</span></code> and/or <code class="docutils literal notranslate"><span class="pre">nsw</span></code> keywords are present, the
+result value of the <code class="docutils literal notranslate"><span class="pre">sub</span></code> is a <a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a> if
+unsigned and/or signed overflow, respectively, occurs.</p>
+</div>
+<div class="section" id="id91">
+<h5><a class="toc-backref" href="#id1215">Example:</a><a class="headerlink" href="#id91" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = sub i32 4, %var ; yields i32:result = 4 - %var
+<result> = sub i32 0, %val ; yields i32:result = -%var
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="fsub-instruction">
+<span id="i-fsub"></span><h4><a class="toc-backref" href="#id1216">â<code class="docutils literal notranslate"><span class="pre">fsub</span></code>â Instruction</a><a class="headerlink" href="#fsub-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id92">
+<h5><a class="toc-backref" href="#id1217">Syntax:</a><a class="headerlink" href="#id92" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">fsub</span> <span class="p">[</span><span class="n">fast</span><span class="o">-</span><span class="n">math</span> <span class="n">flags</span><span class="p">]</span><span class="o">*</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id93">
+<h5><a class="toc-backref" href="#id1218">Overview:</a><a class="headerlink" href="#id93" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fsub</span></code>â instruction returns the difference of its two operands.</p>
+</div>
+<div class="section" id="id94">
+<h5><a class="toc-backref" href="#id1219">Arguments:</a><a class="headerlink" href="#id94" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">fsub</span></code>â instruction must be
+<a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of
+floating-point values. Both arguments must have identical types.</p>
+</div>
+<div class="section" id="id95">
+<h5><a class="toc-backref" href="#id1220">Semantics:</a><a class="headerlink" href="#id95" title="Permalink to this headline">¶</a></h5>
+<p>The value produced is the floating-point difference of the two operands.
+This instruction is assumed to execute in the default <a class="reference internal" href="#floatenv"><span class="std std-ref">floating-point
+environment</span></a>.
+This instruction can also take any number of <a class="reference internal" href="#fastmath"><span class="std std-ref">fast-math
+flags</span></a>, which are optimization hints to enable otherwise
+unsafe floating-point optimizations:</p>
+</div>
+<div class="section" id="id96">
+<h5><a class="toc-backref" href="#id1221">Example:</a><a class="headerlink" href="#id96" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = fsub float 4.0, %var ; yields float:result = 4.0 - %var
+<result> = fsub float -0.0, %val ; yields float:result = -%var
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="mul-instruction">
+<h4><a class="toc-backref" href="#id1222">â<code class="docutils literal notranslate"><span class="pre">mul</span></code>â Instruction</a><a class="headerlink" href="#mul-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id97">
+<h5><a class="toc-backref" href="#id1223">Syntax:</a><a class="headerlink" href="#id97" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">mul</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">mul</span> <span class="n">nuw</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">mul</span> <span class="n">nsw</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">mul</span> <span class="n">nuw</span> <span class="n">nsw</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id98">
+<h5><a class="toc-backref" href="#id1224">Overview:</a><a class="headerlink" href="#id98" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">mul</span></code>â instruction returns the product of its two operands.</p>
+</div>
+<div class="section" id="id99">
+<h5><a class="toc-backref" href="#id1225">Arguments:</a><a class="headerlink" href="#id99" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">mul</span></code>â instruction must be
+<a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of integer values. Both
+arguments must have identical types.</p>
+</div>
+<div class="section" id="id100">
+<h5><a class="toc-backref" href="#id1226">Semantics:</a><a class="headerlink" href="#id100" title="Permalink to this headline">¶</a></h5>
+<p>The value produced is the integer product of the two operands.</p>
+<p>If the result of the multiplication has unsigned overflow, the result
+returned is the mathematical result modulo 2<sup>n</sup>, where n is the
+bit width of the result.</p>
+<p>Because LLVM integers use a twoâs complement representation, and the
+result is the same width as the operands, this instruction returns the
+correct result for both signed and unsigned integers. If a full product
+(e.g. <code class="docutils literal notranslate"><span class="pre">i32</span></code> * <code class="docutils literal notranslate"><span class="pre">i32</span></code> -> <code class="docutils literal notranslate"><span class="pre">i64</span></code>) is needed, the operands should be
+sign-extended or zero-extended as appropriate to the width of the full
+product.</p>
+<p><code class="docutils literal notranslate"><span class="pre">nuw</span></code> and <code class="docutils literal notranslate"><span class="pre">nsw</span></code> stand for âNo Unsigned Wrapâ and âNo Signed Wrapâ,
+respectively. If the <code class="docutils literal notranslate"><span class="pre">nuw</span></code> and/or <code class="docutils literal notranslate"><span class="pre">nsw</span></code> keywords are present, the
+result value of the <code class="docutils literal notranslate"><span class="pre">mul</span></code> is a <a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a> if
+unsigned and/or signed overflow, respectively, occurs.</p>
+</div>
+<div class="section" id="id101">
+<h5><a class="toc-backref" href="#id1227">Example:</a><a class="headerlink" href="#id101" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = mul i32 4, %var ; yields i32:result = 4 * %var
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="fmul-instruction">
+<span id="i-fmul"></span><h4><a class="toc-backref" href="#id1228">â<code class="docutils literal notranslate"><span class="pre">fmul</span></code>â Instruction</a><a class="headerlink" href="#fmul-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id102">
+<h5><a class="toc-backref" href="#id1229">Syntax:</a><a class="headerlink" href="#id102" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">fmul</span> <span class="p">[</span><span class="n">fast</span><span class="o">-</span><span class="n">math</span> <span class="n">flags</span><span class="p">]</span><span class="o">*</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id103">
+<h5><a class="toc-backref" href="#id1230">Overview:</a><a class="headerlink" href="#id103" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fmul</span></code>â instruction returns the product of its two operands.</p>
+</div>
+<div class="section" id="id104">
+<h5><a class="toc-backref" href="#id1231">Arguments:</a><a class="headerlink" href="#id104" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">fmul</span></code>â instruction must be
+<a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of
+floating-point values. Both arguments must have identical types.</p>
+</div>
+<div class="section" id="id105">
+<h5><a class="toc-backref" href="#id1232">Semantics:</a><a class="headerlink" href="#id105" title="Permalink to this headline">¶</a></h5>
+<p>The value produced is the floating-point product of the two operands.
+This instruction is assumed to execute in the default <a class="reference internal" href="#floatenv"><span class="std std-ref">floating-point
+environment</span></a>.
+This instruction can also take any number of <a class="reference internal" href="#fastmath"><span class="std std-ref">fast-math
+flags</span></a>, which are optimization hints to enable otherwise
+unsafe floating-point optimizations:</p>
+</div>
+<div class="section" id="id106">
+<h5><a class="toc-backref" href="#id1233">Example:</a><a class="headerlink" href="#id106" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = fmul float 4.0, %var ; yields float:result = 4.0 * %var
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="udiv-instruction">
+<h4><a class="toc-backref" href="#id1234">â<code class="docutils literal notranslate"><span class="pre">udiv</span></code>â Instruction</a><a class="headerlink" href="#udiv-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id107">
+<h5><a class="toc-backref" href="#id1235">Syntax:</a><a class="headerlink" href="#id107" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">udiv</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">udiv</span> <span class="n">exact</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id108">
+<h5><a class="toc-backref" href="#id1236">Overview:</a><a class="headerlink" href="#id108" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">udiv</span></code>â instruction returns the quotient of its two operands.</p>
+</div>
+<div class="section" id="id109">
+<h5><a class="toc-backref" href="#id1237">Arguments:</a><a class="headerlink" href="#id109" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">udiv</span></code>â instruction must be
+<a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of integer values. Both
+arguments must have identical types.</p>
+</div>
+<div class="section" id="id110">
+<h5><a class="toc-backref" href="#id1238">Semantics:</a><a class="headerlink" href="#id110" title="Permalink to this headline">¶</a></h5>
+<p>The value produced is the unsigned integer quotient of the two operands.</p>
+<p>Note that unsigned integer division and signed integer division are
+distinct operations; for signed integer division, use â<code class="docutils literal notranslate"><span class="pre">sdiv</span></code>â.</p>
+<p>Division by zero is undefined behavior. For vectors, if any element
+of the divisor is zero, the operation has undefined behavior.</p>
+<p>If the <code class="docutils literal notranslate"><span class="pre">exact</span></code> keyword is present, the result value of the <code class="docutils literal notranslate"><span class="pre">udiv</span></code> is
+a <a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a> if %op1 is not a multiple of %op2 (as
+such, â((a udiv exact b) mul b) == aâ).</p>
+</div>
+<div class="section" id="id111">
+<h5><a class="toc-backref" href="#id1239">Example:</a><a class="headerlink" href="#id111" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = udiv i32 4, %var ; yields i32:result = 4 / %var
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="sdiv-instruction">
+<h4><a class="toc-backref" href="#id1240">â<code class="docutils literal notranslate"><span class="pre">sdiv</span></code>â Instruction</a><a class="headerlink" href="#sdiv-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id112">
+<h5><a class="toc-backref" href="#id1241">Syntax:</a><a class="headerlink" href="#id112" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">sdiv</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">sdiv</span> <span class="n">exact</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id113">
+<h5><a class="toc-backref" href="#id1242">Overview:</a><a class="headerlink" href="#id113" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">sdiv</span></code>â instruction returns the quotient of its two operands.</p>
+</div>
+<div class="section" id="id114">
+<h5><a class="toc-backref" href="#id1243">Arguments:</a><a class="headerlink" href="#id114" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">sdiv</span></code>â instruction must be
+<a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of integer values. Both
+arguments must have identical types.</p>
+</div>
+<div class="section" id="id115">
+<h5><a class="toc-backref" href="#id1244">Semantics:</a><a class="headerlink" href="#id115" title="Permalink to this headline">¶</a></h5>
+<p>The value produced is the signed integer quotient of the two operands
+rounded towards zero.</p>
+<p>Note that signed integer division and unsigned integer division are
+distinct operations; for unsigned integer division, use â<code class="docutils literal notranslate"><span class="pre">udiv</span></code>â.</p>
+<p>Division by zero is undefined behavior. For vectors, if any element
+of the divisor is zero, the operation has undefined behavior.
+Overflow also leads to undefined behavior; this is a rare case, but can
+occur, for example, by doing a 32-bit division of -2147483648 by -1.</p>
+<p>If the <code class="docutils literal notranslate"><span class="pre">exact</span></code> keyword is present, the result value of the <code class="docutils literal notranslate"><span class="pre">sdiv</span></code> is
+a <a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a> if the result would be rounded.</p>
+</div>
+<div class="section" id="id116">
+<h5><a class="toc-backref" href="#id1245">Example:</a><a class="headerlink" href="#id116" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = sdiv i32 4, %var ; yields i32:result = 4 / %var
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="fdiv-instruction">
+<span id="i-fdiv"></span><h4><a class="toc-backref" href="#id1246">â<code class="docutils literal notranslate"><span class="pre">fdiv</span></code>â Instruction</a><a class="headerlink" href="#fdiv-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id117">
+<h5><a class="toc-backref" href="#id1247">Syntax:</a><a class="headerlink" href="#id117" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">fdiv</span> <span class="p">[</span><span class="n">fast</span><span class="o">-</span><span class="n">math</span> <span class="n">flags</span><span class="p">]</span><span class="o">*</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id118">
+<h5><a class="toc-backref" href="#id1248">Overview:</a><a class="headerlink" href="#id118" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fdiv</span></code>â instruction returns the quotient of its two operands.</p>
+</div>
+<div class="section" id="id119">
+<h5><a class="toc-backref" href="#id1249">Arguments:</a><a class="headerlink" href="#id119" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">fdiv</span></code>â instruction must be
+<a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of
+floating-point values. Both arguments must have identical types.</p>
+</div>
+<div class="section" id="id120">
+<h5><a class="toc-backref" href="#id1250">Semantics:</a><a class="headerlink" href="#id120" title="Permalink to this headline">¶</a></h5>
+<p>The value produced is the floating-point quotient of the two operands.
+This instruction is assumed to execute in the default <a class="reference internal" href="#floatenv"><span class="std std-ref">floating-point
+environment</span></a>.
+This instruction can also take any number of <a class="reference internal" href="#fastmath"><span class="std std-ref">fast-math
+flags</span></a>, which are optimization hints to enable otherwise
+unsafe floating-point optimizations:</p>
+</div>
+<div class="section" id="id121">
+<h5><a class="toc-backref" href="#id1251">Example:</a><a class="headerlink" href="#id121" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = fdiv float 4.0, %var ; yields float:result = 4.0 / %var
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="urem-instruction">
+<h4><a class="toc-backref" href="#id1252">â<code class="docutils literal notranslate"><span class="pre">urem</span></code>â Instruction</a><a class="headerlink" href="#urem-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id122">
+<h5><a class="toc-backref" href="#id1253">Syntax:</a><a class="headerlink" href="#id122" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">urem</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id123">
+<h5><a class="toc-backref" href="#id1254">Overview:</a><a class="headerlink" href="#id123" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">urem</span></code>â instruction returns the remainder from the unsigned
+division of its two arguments.</p>
+</div>
+<div class="section" id="id124">
+<h5><a class="toc-backref" href="#id1255">Arguments:</a><a class="headerlink" href="#id124" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">urem</span></code>â instruction must be
+<a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of integer values. Both
+arguments must have identical types.</p>
+</div>
+<div class="section" id="id125">
+<h5><a class="toc-backref" href="#id1256">Semantics:</a><a class="headerlink" href="#id125" title="Permalink to this headline">¶</a></h5>
+<p>This instruction returns the unsigned integer <em>remainder</em> of a division.
+This instruction always performs an unsigned division to get the
+remainder.</p>
+<p>Note that unsigned integer remainder and signed integer remainder are
+distinct operations; for signed integer remainder, use â<code class="docutils literal notranslate"><span class="pre">srem</span></code>â.</p>
+<p>Taking the remainder of a division by zero is undefined behavior.
+For vectors, if any element of the divisor is zero, the operation has
+undefined behavior.</p>
+</div>
+<div class="section" id="id126">
+<h5><a class="toc-backref" href="#id1257">Example:</a><a class="headerlink" href="#id126" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = urem i32 4, %var ; yields i32:result = 4 % %var
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="srem-instruction">
+<h4><a class="toc-backref" href="#id1258">â<code class="docutils literal notranslate"><span class="pre">srem</span></code>â Instruction</a><a class="headerlink" href="#srem-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id127">
+<h5><a class="toc-backref" href="#id1259">Syntax:</a><a class="headerlink" href="#id127" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">srem</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id128">
+<h5><a class="toc-backref" href="#id1260">Overview:</a><a class="headerlink" href="#id128" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">srem</span></code>â instruction returns the remainder from the signed
+division of its two operands. This instruction can also take
+<a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> versions of the values in which case the elements
+must be integers.</p>
+</div>
+<div class="section" id="id129">
+<h5><a class="toc-backref" href="#id1261">Arguments:</a><a class="headerlink" href="#id129" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">srem</span></code>â instruction must be
+<a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of integer values. Both
+arguments must have identical types.</p>
+</div>
+<div class="section" id="id130">
+<h5><a class="toc-backref" href="#id1262">Semantics:</a><a class="headerlink" href="#id130" title="Permalink to this headline">¶</a></h5>
+<p>This instruction returns the <em>remainder</em> of a division (where the result
+is either zero or has the same sign as the dividend, <code class="docutils literal notranslate"><span class="pre">op1</span></code>), not the
+<em>modulo</em> operator (where the result is either zero or has the same sign
+as the divisor, <code class="docutils literal notranslate"><span class="pre">op2</span></code>) of a value. For more information about the
+difference, see <a class="reference external" href="http://mathforum.org/dr.math/problems/anne.4.28.99.html">The Math
+Forum</a>. For a
+table of how this is implemented in various languages, please see
+<a class="reference external" href="http://en.wikipedia.org/wiki/Modulo_operation">Wikipedia: modulo
+operation</a>.</p>
+<p>Note that signed integer remainder and unsigned integer remainder are
+distinct operations; for unsigned integer remainder, use â<code class="docutils literal notranslate"><span class="pre">urem</span></code>â.</p>
+<p>Taking the remainder of a division by zero is undefined behavior.
+For vectors, if any element of the divisor is zero, the operation has
+undefined behavior.
+Overflow also leads to undefined behavior; this is a rare case, but can
+occur, for example, by taking the remainder of a 32-bit division of
+-2147483648 by -1. (The remainder doesnât actually overflow, but this
+rule lets srem be implemented using instructions that return both the
+result of the division and the remainder.)</p>
+</div>
+<div class="section" id="id131">
+<h5><a class="toc-backref" href="#id1263">Example:</a><a class="headerlink" href="#id131" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = srem i32 4, %var ; yields i32:result = 4 % %var
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="frem-instruction">
+<span id="i-frem"></span><h4><a class="toc-backref" href="#id1264">â<code class="docutils literal notranslate"><span class="pre">frem</span></code>â Instruction</a><a class="headerlink" href="#frem-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id132">
+<h5><a class="toc-backref" href="#id1265">Syntax:</a><a class="headerlink" href="#id132" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">frem</span> <span class="p">[</span><span class="n">fast</span><span class="o">-</span><span class="n">math</span> <span class="n">flags</span><span class="p">]</span><span class="o">*</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id133">
+<h5><a class="toc-backref" href="#id1266">Overview:</a><a class="headerlink" href="#id133" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">frem</span></code>â instruction returns the remainder from the division of
+its two operands.</p>
+</div>
+<div class="section" id="id134">
+<h5><a class="toc-backref" href="#id1267">Arguments:</a><a class="headerlink" href="#id134" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">frem</span></code>â instruction must be
+<a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of
+floating-point values. Both arguments must have identical types.</p>
+</div>
+<div class="section" id="id135">
+<h5><a class="toc-backref" href="#id1268">Semantics:</a><a class="headerlink" href="#id135" title="Permalink to this headline">¶</a></h5>
+<p>The value produced is the floating-point remainder of the two operands.
+This is the same output as a libm â<code class="docutils literal notranslate"><span class="pre">fmod</span></code>â function, but without any
+possibility of setting <code class="docutils literal notranslate"><span class="pre">errno</span></code>. The remainder has the same sign as the
+dividend.
+This instruction is assumed to execute in the default <a class="reference internal" href="#floatenv"><span class="std std-ref">floating-point
+environment</span></a>.
+This instruction can also take any number of <a class="reference internal" href="#fastmath"><span class="std std-ref">fast-math
+flags</span></a>, which are optimization hints to enable otherwise
+unsafe floating-point optimizations:</p>
+</div>
+<div class="section" id="id136">
+<h5><a class="toc-backref" href="#id1269">Example:</a><a class="headerlink" href="#id136" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = frem float 4.0, %var ; yields float:result = 4.0 % %var
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+<div class="section" id="bitwise-binary-operations">
+<span id="bitwiseops"></span><h3><a class="toc-backref" href="#id1270">Bitwise Binary Operations</a><a class="headerlink" href="#bitwise-binary-operations" title="Permalink to this headline">¶</a></h3>
+<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 of the same type, execute an operation on them, and produce a
+single value. The resulting value is the same type as its operands.</p>
+<div class="section" id="shl-instruction">
+<h4><a class="toc-backref" href="#id1271">â<code class="docutils literal notranslate"><span class="pre">shl</span></code>â Instruction</a><a class="headerlink" href="#shl-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id137">
+<h5><a class="toc-backref" href="#id1272">Syntax:</a><a class="headerlink" href="#id137" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">shl</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">shl</span> <span class="n">nuw</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">shl</span> <span class="n">nsw</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">shl</span> <span class="n">nuw</span> <span class="n">nsw</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id138">
+<h5><a class="toc-backref" href="#id1273">Overview:</a><a class="headerlink" href="#id138" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">shl</span></code>â instruction returns the first operand shifted to the left
+a specified number of bits.</p>
+</div>
+<div class="section" id="id139">
+<h5><a class="toc-backref" href="#id1274">Arguments:</a><a class="headerlink" href="#id139" title="Permalink to this headline">¶</a></h5>
+<p>Both arguments to the â<code class="docutils literal notranslate"><span class="pre">shl</span></code>â instruction must be the same
+<a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of integer type.
+â<code class="docutils literal notranslate"><span class="pre">op2</span></code>â is treated as an unsigned value.</p>
+</div>
+<div class="section" id="id140">
+<h5><a class="toc-backref" href="#id1275">Semantics:</a><a class="headerlink" href="#id140" title="Permalink to this headline">¶</a></h5>
+<p>The value produced is <code class="docutils literal notranslate"><span class="pre">op1</span></code> * 2<sup>op2</sup> mod 2<sup>n</sup>,
+where <code class="docutils literal notranslate"><span class="pre">n</span></code> is the width of the result. If <code class="docutils literal notranslate"><span class="pre">op2</span></code> is (statically or
+dynamically) equal to or larger than the number of bits in
+<code class="docutils literal notranslate"><span class="pre">op1</span></code>, this instruction returns a <a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a>.
+If the arguments are vectors, each vector element of <code class="docutils literal notranslate"><span class="pre">op1</span></code> is shifted
+by the corresponding shift amount in <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</p>
+<p>If the <code class="docutils literal notranslate"><span class="pre">nuw</span></code> keyword is present, then the shift produces a poison
+value if it shifts out any non-zero bits.
+If the <code class="docutils literal notranslate"><span class="pre">nsw</span></code> keyword is present, then the shift produces a poison
+value if it shifts out any bits that disagree with the resultant sign bit.</p>
+</div>
+<div class="section" id="id141">
+<h5><a class="toc-backref" href="#id1276">Example:</a><a class="headerlink" href="#id141" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = shl i32 4, %var ; yields i32: 4 << %var
+<result> = shl i32 4, 2 ; yields i32: 16
+<result> = shl i32 1, 10 ; yields i32: 1024
+<result> = shl i32 1, 32 ; undefined
+<result> = shl <2 x i32> < i32 1, i32 1>, < i32 1, i32 2> ; yields: result=<2 x i32> < i32 2, i32 4>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="lshr-instruction">
+<h4><a class="toc-backref" href="#id1277">â<code class="docutils literal notranslate"><span class="pre">lshr</span></code>â Instruction</a><a class="headerlink" href="#lshr-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id142">
+<h5><a class="toc-backref" href="#id1278">Syntax:</a><a class="headerlink" href="#id142" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">lshr</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">lshr</span> <span class="n">exact</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id143">
+<h5><a class="toc-backref" href="#id1279">Overview:</a><a class="headerlink" href="#id143" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">lshr</span></code>â instruction (logical shift right) returns the first
+operand shifted to the right a specified number of bits with zero fill.</p>
+</div>
+<div class="section" id="id144">
+<h5><a class="toc-backref" href="#id1280">Arguments:</a><a class="headerlink" href="#id144" title="Permalink to this headline">¶</a></h5>
+<p>Both arguments to the â<code class="docutils literal notranslate"><span class="pre">lshr</span></code>â instruction must be the same
+<a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of integer type.
+â<code class="docutils literal notranslate"><span class="pre">op2</span></code>â is treated as an unsigned value.</p>
+</div>
+<div class="section" id="id145">
+<h5><a class="toc-backref" href="#id1281">Semantics:</a><a class="headerlink" href="#id145" title="Permalink to this headline">¶</a></h5>
+<p>This instruction always performs a logical shift right operation. The
+most significant bits of the result will be filled with zero bits after
+the shift. If <code class="docutils literal notranslate"><span class="pre">op2</span></code> is (statically or dynamically) equal to or larger
+than the number of bits in <code class="docutils literal notranslate"><span class="pre">op1</span></code>, this instruction returns a <a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison
+value</span></a>. If the arguments are vectors, each vector element
+of <code class="docutils literal notranslate"><span class="pre">op1</span></code> is shifted by the corresponding shift amount in <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</p>
+<p>If the <code class="docutils literal notranslate"><span class="pre">exact</span></code> keyword is present, the result value of the <code class="docutils literal notranslate"><span class="pre">lshr</span></code> is
+a poison value if any of the bits shifted out are non-zero.</p>
+</div>
+<div class="section" id="id146">
+<h5><a class="toc-backref" href="#id1282">Example:</a><a class="headerlink" href="#id146" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = lshr i32 4, 1 ; yields i32:result = 2
+<result> = lshr i32 4, 2 ; yields i32:result = 1
+<result> = lshr i8 4, 3 ; yields i8:result = 0
+<result> = lshr i8 -2, 1 ; yields i8:result = 0x7F
+<result> = lshr i32 1, 32 ; undefined
+<result> = lshr <2 x i32> < i32 -2, i32 4>, < i32 1, i32 2> ; yields: result=<2 x i32> < i32 0x7FFFFFFF, i32 1>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="ashr-instruction">
+<h4><a class="toc-backref" href="#id1283">â<code class="docutils literal notranslate"><span class="pre">ashr</span></code>â Instruction</a><a class="headerlink" href="#ashr-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id147">
+<h5><a class="toc-backref" href="#id1284">Syntax:</a><a class="headerlink" href="#id147" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">ashr</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">ashr</span> <span class="n">exact</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id148">
+<h5><a class="toc-backref" href="#id1285">Overview:</a><a class="headerlink" href="#id148" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">ashr</span></code>â instruction (arithmetic shift right) returns the first
+operand shifted to the right a specified number of bits with sign
+extension.</p>
+</div>
+<div class="section" id="id149">
+<h5><a class="toc-backref" href="#id1286">Arguments:</a><a class="headerlink" href="#id149" title="Permalink to this headline">¶</a></h5>
+<p>Both arguments to the â<code class="docutils literal notranslate"><span class="pre">ashr</span></code>â instruction must be the same
+<a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of integer type.
+â<code class="docutils literal notranslate"><span class="pre">op2</span></code>â is treated as an unsigned value.</p>
+</div>
+<div class="section" id="id150">
+<h5><a class="toc-backref" href="#id1287">Semantics:</a><a class="headerlink" href="#id150" title="Permalink to this headline">¶</a></h5>
+<p>This instruction always performs an arithmetic shift right operation,
+The most significant bits of the result will be filled with the sign bit
+of <code class="docutils literal notranslate"><span class="pre">op1</span></code>. If <code class="docutils literal notranslate"><span class="pre">op2</span></code> is (statically or dynamically) equal to or larger
+than the number of bits in <code class="docutils literal notranslate"><span class="pre">op1</span></code>, this instruction returns a <a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison
+value</span></a>. If the arguments are vectors, each vector element
+of <code class="docutils literal notranslate"><span class="pre">op1</span></code> is shifted by the corresponding shift amount in <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</p>
+<p>If the <code class="docutils literal notranslate"><span class="pre">exact</span></code> keyword is present, the result value of the <code class="docutils literal notranslate"><span class="pre">ashr</span></code> is
+a poison value if any of the bits shifted out are non-zero.</p>
+</div>
+<div class="section" id="id151">
+<h5><a class="toc-backref" href="#id1288">Example:</a><a class="headerlink" href="#id151" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = ashr i32 4, 1 ; yields i32:result = 2
+<result> = ashr i32 4, 2 ; yields i32:result = 1
+<result> = ashr i8 4, 3 ; yields i8:result = 0
+<result> = ashr i8 -2, 1 ; yields i8:result = -1
+<result> = ashr i32 1, 32 ; undefined
+<result> = ashr <2 x i32> < i32 -2, i32 4>, < i32 1, i32 3> ; yields: result=<2 x i32> < i32 -1, i32 0>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="and-instruction">
+<h4><a class="toc-backref" href="#id1289">â<code class="docutils literal notranslate"><span class="pre">and</span></code>â Instruction</a><a class="headerlink" href="#and-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id152">
+<h5><a class="toc-backref" href="#id1290">Syntax:</a><a class="headerlink" href="#id152" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="ow">and</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id153">
+<h5><a class="toc-backref" href="#id1291">Overview:</a><a class="headerlink" href="#id153" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">and</span></code>â instruction returns the bitwise logical and of its two
+operands.</p>
+</div>
+<div class="section" id="id154">
+<h5><a class="toc-backref" href="#id1292">Arguments:</a><a class="headerlink" href="#id154" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">and</span></code>â instruction must be
+<a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of integer values. Both
+arguments must have identical types.</p>
+</div>
+<div class="section" id="id155">
+<h5><a class="toc-backref" href="#id1293">Semantics:</a><a class="headerlink" href="#id155" title="Permalink to this headline">¶</a></h5>
+<p>The truth table used for the â<code class="docutils literal notranslate"><span class="pre">and</span></code>â instruction is:</p>
+<table border="1" class="docutils">
+<colgroup>
+<col width="33%" />
+<col width="33%" />
+<col width="33%" />
+</colgroup>
+<tbody valign="top">
+<tr class="row-odd"><td>In0</td>
+<td>In1</td>
+<td>Out</td>
+</tr>
+<tr class="row-even"><td>0</td>
+<td>0</td>
+<td>0</td>
+</tr>
+<tr class="row-odd"><td>0</td>
+<td>1</td>
+<td>0</td>
+</tr>
+<tr class="row-even"><td>1</td>
+<td>0</td>
+<td>0</td>
+</tr>
+<tr class="row-odd"><td>1</td>
+<td>1</td>
+<td>1</td>
+</tr>
+</tbody>
+</table>
+</div>
+<div class="section" id="id156">
+<h5><a class="toc-backref" href="#id1294">Example:</a><a class="headerlink" href="#id156" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = and i32 4, %var ; yields i32:result = 4 & %var
+<result> = and i32 15, 40 ; yields i32:result = 8
+<result> = and i32 4, 8 ; yields i32:result = 0
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="or-instruction">
+<h4><a class="toc-backref" href="#id1295">â<code class="docutils literal notranslate"><span class="pre">or</span></code>â Instruction</a><a class="headerlink" href="#or-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id157">
+<h5><a class="toc-backref" href="#id1296">Syntax:</a><a class="headerlink" href="#id157" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="ow">or</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id158">
+<h5><a class="toc-backref" href="#id1297">Overview:</a><a class="headerlink" href="#id158" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">or</span></code>â instruction returns the bitwise logical inclusive or of its
+two operands.</p>
+</div>
+<div class="section" id="id159">
+<h5><a class="toc-backref" href="#id1298">Arguments:</a><a class="headerlink" href="#id159" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">or</span></code>â instruction must be
+<a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of integer values. Both
+arguments must have identical types.</p>
+</div>
+<div class="section" id="id160">
+<h5><a class="toc-backref" href="#id1299">Semantics:</a><a class="headerlink" href="#id160" title="Permalink to this headline">¶</a></h5>
+<p>The truth table used for the â<code class="docutils literal notranslate"><span class="pre">or</span></code>â instruction is:</p>
+<table border="1" class="docutils">
+<colgroup>
+<col width="33%" />
+<col width="33%" />
+<col width="33%" />
+</colgroup>
+<tbody valign="top">
+<tr class="row-odd"><td>In0</td>
+<td>In1</td>
+<td>Out</td>
+</tr>
+<tr class="row-even"><td>0</td>
+<td>0</td>
+<td>0</td>
+</tr>
+<tr class="row-odd"><td>0</td>
+<td>1</td>
+<td>1</td>
+</tr>
+<tr class="row-even"><td>1</td>
+<td>0</td>
+<td>1</td>
+</tr>
+<tr class="row-odd"><td>1</td>
+<td>1</td>
+<td>1</td>
+</tr>
+</tbody>
+</table>
+</div>
+<div class="section" id="id161">
+<h5><a class="toc-backref" href="#id1300">Example:</a><a class="headerlink" href="#id161" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="ow">or</span> <span class="n">i32</span> <span class="mi">4</span><span class="p">,</span> <span class="o">%</span><span class="n">var</span> <span class="p">;</span> <span class="n">yields</span> <span class="n">i32</span><span class="p">:</span><span class="n">result</span> <span class="o">=</span> <span class="mi">4</span> <span class="o">|</span> <span class="o">%</span><span class="n">var</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="ow">or</span> <span class="n">i32</span> <span class="mi">15</span><span class="p">,</span> <span class="mi">40</span> <span class="p">;</span> <span class="n">yields</span> <span class="n">i32</span><span class="p">:</span><span class="n">result</span> <span class="o">=</span> <span class="mi">47</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="ow">or</span> <span class="n">i32</span> <span class="mi">4</span><span class="p">,</span> <span class="mi">8</span> <span class="p">;</span> <span class="n">yields</span> <span class="n">i32</span><span class="p">:</span><span class="n">result</span> <span class="o">=</span> <span class="mi">12</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="xor-instruction">
+<h4><a class="toc-backref" href="#id1301">â<code class="docutils literal notranslate"><span class="pre">xor</span></code>â Instruction</a><a class="headerlink" href="#xor-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id162">
+<h5><a class="toc-backref" href="#id1302">Syntax:</a><a class="headerlink" href="#id162" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">xor</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id163">
+<h5><a class="toc-backref" href="#id1303">Overview:</a><a class="headerlink" href="#id163" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">xor</span></code>â instruction returns the bitwise logical exclusive or of
+its two operands. The <code class="docutils literal notranslate"><span class="pre">xor</span></code> is used to implement the âoneâs
+complementâ operation, which is the â~â operator in C.</p>
+</div>
+<div class="section" id="id164">
+<h5><a class="toc-backref" href="#id1304">Arguments:</a><a class="headerlink" href="#id164" title="Permalink to this headline">¶</a></h5>
+<p>The two arguments to the â<code class="docutils literal notranslate"><span class="pre">xor</span></code>â instruction must be
+<a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of integer values. Both
+arguments must have identical types.</p>
+</div>
+<div class="section" id="id165">
+<h5><a class="toc-backref" href="#id1305">Semantics:</a><a class="headerlink" href="#id165" title="Permalink to this headline">¶</a></h5>
+<p>The truth table used for the â<code class="docutils literal notranslate"><span class="pre">xor</span></code>â instruction is:</p>
+<table border="1" class="docutils">
+<colgroup>
+<col width="33%" />
+<col width="33%" />
+<col width="33%" />
+</colgroup>
+<tbody valign="top">
+<tr class="row-odd"><td>In0</td>
+<td>In1</td>
+<td>Out</td>
+</tr>
+<tr class="row-even"><td>0</td>
+<td>0</td>
+<td>0</td>
+</tr>
+<tr class="row-odd"><td>0</td>
+<td>1</td>
+<td>1</td>
+</tr>
+<tr class="row-even"><td>1</td>
+<td>0</td>
+<td>1</td>
+</tr>
+<tr class="row-odd"><td>1</td>
+<td>1</td>
+<td>0</td>
+</tr>
+</tbody>
+</table>
+</div>
+<div class="section" id="id166">
+<h5><a class="toc-backref" href="#id1306">Example:</a><a class="headerlink" href="#id166" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = xor i32 4, %var ; yields i32:result = 4 ^ %var
+<result> = xor i32 15, 40 ; yields i32:result = 39
+<result> = xor i32 4, 8 ; yields i32:result = 12
+<result> = xor i32 %V, -1 ; yields i32:result = ~%V
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+<div class="section" id="vector-operations">
+<h3><a class="toc-backref" href="#id1307">Vector Operations</a><a class="headerlink" href="#vector-operations" title="Permalink to this headline">¶</a></h3>
+<p>LLVM supports several instructions to represent vector operations in a
+target-independent manner. These instructions cover the element-access
+and vector-specific operations needed to process vectors effectively.
+While LLVM does directly support these vector operations, many
+sophisticated algorithms will want to use target-specific intrinsics to
+take full advantage of a specific target.</p>
+<div class="section" id="extractelement-instruction">
+<span id="i-extractelement"></span><h4><a class="toc-backref" href="#id1308">â<code class="docutils literal notranslate"><span class="pre">extractelement</span></code>â Instruction</a><a class="headerlink" href="#extractelement-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id167">
+<h5><a class="toc-backref" href="#id1309">Syntax:</a><a class="headerlink" href="#id167" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">extractelement</span> <span class="o"><</span><span class="n">n</span> <span class="n">x</span> <span class="o"><</span><span class="n">ty</span><span class="o">>></span> <span class="o"><</span><span class="n">val</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">ty2</span><span class="o">></span> <span class="o"><</span><span class="n">idx</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id168">
+<h5><a class="toc-backref" href="#id1310">Overview:</a><a class="headerlink" href="#id168" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">extractelement</span></code>â instruction extracts a single scalar element
+from a vector at a specified index.</p>
+</div>
+<div class="section" id="id169">
+<h5><a class="toc-backref" href="#id1311">Arguments:</a><a class="headerlink" href="#id169" title="Permalink to this headline">¶</a></h5>
+<p>The first operand of an â<code class="docutils literal notranslate"><span class="pre">extractelement</span></code>â instruction is a value of
+<a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> type. The second operand is an index indicating
+the position from which to extract the element. The index may be a
+variable of any integer type.</p>
+</div>
+<div class="section" id="id170">
+<h5><a class="toc-backref" href="#id1312">Semantics:</a><a class="headerlink" href="#id170" title="Permalink to this headline">¶</a></h5>
+<p>The result is a scalar of the same type as the element type of <code class="docutils literal notranslate"><span class="pre">val</span></code>.
+Its value is the value at position <code class="docutils literal notranslate"><span class="pre">idx</span></code> of <code class="docutils literal notranslate"><span class="pre">val</span></code>. If <code class="docutils literal notranslate"><span class="pre">idx</span></code>
+exceeds the length of <code class="docutils literal notranslate"><span class="pre">val</span></code>, the result is a
+<a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a>.</p>
+</div>
+<div class="section" id="id171">
+<h5><a class="toc-backref" href="#id1313">Example:</a><a class="headerlink" href="#id171" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = extractelement <4 x i32> %vec, i32 0 ; yields i32
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="insertelement-instruction">
+<span id="i-insertelement"></span><h4><a class="toc-backref" href="#id1314">â<code class="docutils literal notranslate"><span class="pre">insertelement</span></code>â Instruction</a><a class="headerlink" href="#insertelement-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id172">
+<h5><a class="toc-backref" href="#id1315">Syntax:</a><a class="headerlink" href="#id172" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">insertelement</span> <span class="o"><</span><span class="n">n</span> <span class="n">x</span> <span class="o"><</span><span class="n">ty</span><span class="o">>></span> <span class="o"><</span><span class="n">val</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">elt</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">ty2</span><span class="o">></span> <span class="o"><</span><span class="n">idx</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="o"><</span><span class="n">n</span> <span class="n">x</span> <span class="o"><</span><span class="n">ty</span><span class="o">>></span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id173">
+<h5><a class="toc-backref" href="#id1316">Overview:</a><a class="headerlink" href="#id173" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">insertelement</span></code>â instruction inserts a scalar element into a
+vector at a specified index.</p>
+</div>
+<div class="section" id="id174">
+<h5><a class="toc-backref" href="#id1317">Arguments:</a><a class="headerlink" href="#id174" title="Permalink to this headline">¶</a></h5>
+<p>The first operand of an â<code class="docutils literal notranslate"><span class="pre">insertelement</span></code>â instruction is a value of
+<a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> type. The second operand is a scalar value whose
+type must equal the element type of the first operand. The third operand
+is an index indicating the position at which to insert the value. The
+index may be a variable of any integer type.</p>
+</div>
+<div class="section" id="id175">
+<h5><a class="toc-backref" href="#id1318">Semantics:</a><a class="headerlink" href="#id175" title="Permalink to this headline">¶</a></h5>
+<p>The result is a vector of the same type as <code class="docutils literal notranslate"><span class="pre">val</span></code>. Its element values
+are those of <code class="docutils literal notranslate"><span class="pre">val</span></code> except at position <code class="docutils literal notranslate"><span class="pre">idx</span></code>, where it gets the value
+<code class="docutils literal notranslate"><span class="pre">elt</span></code>. If <code class="docutils literal notranslate"><span class="pre">idx</span></code> exceeds the length of <code class="docutils literal notranslate"><span class="pre">val</span></code>, the result
+is a <a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a>.</p>
+</div>
+<div class="section" id="id176">
+<h5><a class="toc-backref" href="#id1319">Example:</a><a class="headerlink" href="#id176" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = insertelement <4 x i32> %vec, i32 1, i32 0 ; yields <4 x i32>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="shufflevector-instruction">
+<span id="i-shufflevector"></span><h4><a class="toc-backref" href="#id1320">â<code class="docutils literal notranslate"><span class="pre">shufflevector</span></code>â Instruction</a><a class="headerlink" href="#shufflevector-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id177">
+<h5><a class="toc-backref" href="#id1321">Syntax:</a><a class="headerlink" href="#id177" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">shufflevector</span> <span class="o"><</span><span class="n">n</span> <span class="n">x</span> <span class="o"><</span><span class="n">ty</span><span class="o">>></span> <span class="o"><</span><span class="n">v1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">n</span> <span class="n">x</span> <span class="o"><</span><span class="n">ty</span><span class="o">>></span> <span class="o"><</span><span class="n">v2</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">m</span> <span class="n">x</span> <span class="n">i32</span><span class="o">></span> <span class="o"><</span><span class="n">mask</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="o"><</span><span class="n">m</span> <span class="n">x</span> <span class="o"><</span><span class="n">ty</span><span class="o">>></span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id178">
+<h5><a class="toc-backref" href="#id1322">Overview:</a><a class="headerlink" href="#id178" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">shufflevector</span></code>â instruction constructs a permutation of elements
+from two input vectors, returning a vector with the same element type as
+the input and length that is the same as the shuffle mask.</p>
+</div>
+<div class="section" id="id179">
+<h5><a class="toc-backref" href="#id1323">Arguments:</a><a class="headerlink" href="#id179" title="Permalink to this headline">¶</a></h5>
+<p>The first two operands of a â<code class="docutils literal notranslate"><span class="pre">shufflevector</span></code>â instruction are vectors
+with the same type. The third argument is a shuffle mask whose element
+type is always âi32â. The result of the instruction is a vector whose
+length is the same as the shuffle mask and whose element type is the
+same as the element type of the first two operands.</p>
+<p>The shuffle mask operand is required to be a constant vector with either
+constant integer or undef values.</p>
+</div>
+<div class="section" id="id180">
+<h5><a class="toc-backref" href="#id1324">Semantics:</a><a class="headerlink" href="#id180" title="Permalink to this headline">¶</a></h5>
+<p>The elements of the two input vectors are numbered from left to right
+across both of the vectors. The shuffle mask operand specifies, for each
+element of the result vector, which element of the two input vectors the
+result element gets. If the shuffle mask is undef, the result vector is
+undef. If any element of the mask operand is undef, that element of the
+result is undef. If the shuffle mask selects an undef element from one
+of the input vectors, the resulting element is undef.</p>
+</div>
+<div class="section" id="id181">
+<h5><a class="toc-backref" href="#id1325">Example:</a><a class="headerlink" href="#id181" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = shufflevector <4 x i32> %v1, <4 x i32> %v2,
+ <4 x i32> <i32 0, i32 4, i32 1, i32 5> ; yields <4 x i32>
+<result> = shufflevector <4 x i32> %v1, <4 x i32> undef,
+ <4 x i32> <i32 0, i32 1, i32 2, i32 3> ; yields <4 x i32> - Identity shuffle.
+<result> = shufflevector <8 x i32> %v1, <8 x i32> undef,
+ <4 x i32> <i32 0, i32 1, i32 2, i32 3> ; yields <4 x i32>
+<result> = shufflevector <4 x i32> %v1, <4 x i32> %v2,
+ <8 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7 > ; yields <8 x i32>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+<div class="section" id="aggregate-operations">
+<h3><a class="toc-backref" href="#id1326">Aggregate Operations</a><a class="headerlink" href="#aggregate-operations" title="Permalink to this headline">¶</a></h3>
+<p>LLVM supports several instructions for working with
+<a class="reference internal" href="#t-aggregate"><span class="std std-ref">aggregate</span></a> values.</p>
+<div class="section" id="extractvalue-instruction">
+<span id="i-extractvalue"></span><h4><a class="toc-backref" href="#id1327">â<code class="docutils literal notranslate"><span class="pre">extractvalue</span></code>â Instruction</a><a class="headerlink" href="#extractvalue-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id182">
+<h5><a class="toc-backref" href="#id1328">Syntax:</a><a class="headerlink" href="#id182" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">extractvalue</span> <span class="o"><</span><span class="n">aggregate</span> <span class="nb">type</span><span class="o">></span> <span class="o"><</span><span class="n">val</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">idx</span><span class="o">></span><span class="p">{,</span> <span class="o"><</span><span class="n">idx</span><span class="o">></span><span class="p">}</span><span class="o">*</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id183">
+<h5><a class="toc-backref" href="#id1329">Overview:</a><a class="headerlink" href="#id183" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">extractvalue</span></code>â instruction extracts the value of a member field
+from an <a class="reference internal" href="#t-aggregate"><span class="std std-ref">aggregate</span></a> value.</p>
+</div>
+<div class="section" id="id184">
+<h5><a class="toc-backref" href="#id1330">Arguments:</a><a class="headerlink" href="#id184" title="Permalink to this headline">¶</a></h5>
+<p>The first operand of an â<code class="docutils literal notranslate"><span class="pre">extractvalue</span></code>â instruction is a value of
+<a class="reference internal" href="#t-struct"><span class="std std-ref">struct</span></a> or <a class="reference internal" href="#t-array"><span class="std std-ref">array</span></a> type. The other operands are
+constant indices to specify which value to extract in a similar manner
+as indices in a â<code class="docutils literal notranslate"><span class="pre">getelementptr</span></code>â instruction.</p>
+<p>The major differences to <code class="docutils literal notranslate"><span class="pre">getelementptr</span></code> indexing are:</p>
+<ul class="simple">
+<li>Since the value being indexed is not a pointer, the first index is
+omitted and assumed to be zero.</li>
+<li>At least one index must be specified.</li>
+<li>Not only struct indices but also array indices must be in bounds.</li>
+</ul>
+</div>
+<div class="section" id="id185">
+<h5><a class="toc-backref" href="#id1331">Semantics:</a><a class="headerlink" href="#id185" title="Permalink to this headline">¶</a></h5>
+<p>The result is the value at the position in the aggregate specified by
+the index operands.</p>
+</div>
+<div class="section" id="id186">
+<h5><a class="toc-backref" href="#id1332">Example:</a><a class="headerlink" href="#id186" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = extractvalue {i32, float} %agg, 0 ; yields i32
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="insertvalue-instruction">
+<span id="i-insertvalue"></span><h4><a class="toc-backref" href="#id1333">â<code class="docutils literal notranslate"><span class="pre">insertvalue</span></code>â Instruction</a><a class="headerlink" href="#insertvalue-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id187">
+<h5><a class="toc-backref" href="#id1334">Syntax:</a><a class="headerlink" href="#id187" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">insertvalue</span> <span class="o"><</span><span class="n">aggregate</span> <span class="nb">type</span><span class="o">></span> <span class="o"><</span><span class="n">val</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">elt</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">idx</span><span class="o">></span><span class="p">{,</span> <span class="o"><</span><span class="n">idx</span><span class="o">></span><span class="p">}</span><span class="o">*</span> <span class="p">;</span> <span class="n">yields</span> <span class="o"><</span><span class="n">aggregate</span> <span class="nb">type</span><span class="o">></span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id188">
+<h5><a class="toc-backref" href="#id1335">Overview:</a><a class="headerlink" href="#id188" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">insertvalue</span></code>â instruction inserts a value into a member field in
+an <a class="reference internal" href="#t-aggregate"><span class="std std-ref">aggregate</span></a> value.</p>
+</div>
+<div class="section" id="id189">
+<h5><a class="toc-backref" href="#id1336">Arguments:</a><a class="headerlink" href="#id189" title="Permalink to this headline">¶</a></h5>
+<p>The first operand of an â<code class="docutils literal notranslate"><span class="pre">insertvalue</span></code>â instruction is a value of
+<a class="reference internal" href="#t-struct"><span class="std std-ref">struct</span></a> or <a class="reference internal" href="#t-array"><span class="std std-ref">array</span></a> type. The second operand is
+a first-class value to insert. The following operands are constant
+indices indicating the position at which to insert the value in a
+similar manner as indices in a â<code class="docutils literal notranslate"><span class="pre">extractvalue</span></code>â instruction. The value
+to insert must have the same type as the value identified by the
+indices.</p>
+</div>
+<div class="section" id="id190">
+<h5><a class="toc-backref" href="#id1337">Semantics:</a><a class="headerlink" href="#id190" title="Permalink to this headline">¶</a></h5>
+<p>The result is an aggregate of the same type as <code class="docutils literal notranslate"><span class="pre">val</span></code>. Its value is
+that of <code class="docutils literal notranslate"><span class="pre">val</span></code> except that the value at the position specified by the
+indices is that of <code class="docutils literal notranslate"><span class="pre">elt</span></code>.</p>
+</div>
+<div class="section" id="id191">
+<h5><a class="toc-backref" href="#id1338">Example:</a><a class="headerlink" href="#id191" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%agg1</span> <span class="p">=</span> <span class="k">insertvalue</span> <span class="p">{</span><span class="k">i32</span><span class="p">,</span> <span class="kt">float</span><span class="p">}</span> <span class="k">undef</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span><span class="p">,</span> <span class="m">0</span> <span class="c">; yields {i32 1, float undef}</span>
+<span class="nv">%agg2</span> <span class="p">=</span> <span class="k">insertvalue</span> <span class="p">{</span><span class="k">i32</span><span class="p">,</span> <span class="kt">float</span><span class="p">}</span> <span class="nv">%agg1</span><span class="p">,</span> <span class="kt">float</span> <span class="nv">%val</span><span class="p">,</span> <span class="m">1</span> <span class="c">; yields {i32 1, float %val}</span>
+<span class="nv">%agg3</span> <span class="p">=</span> <span class="k">insertvalue</span> <span class="p">{</span><span class="k">i32</span><span class="p">,</span> <span class="p">{</span><span class="kt">float</span><span class="p">}}</span> <span class="k">undef</span><span class="p">,</span> <span class="kt">float</span> <span class="nv">%val</span><span class="p">,</span> <span class="m">1</span><span class="p">,</span> <span class="m">0</span> <span class="c">; yields {i32 undef, {float %val}}</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+<div class="section" id="memory-access-and-addressing-operations">
+<span id="memoryops"></span><h3><a class="toc-backref" href="#id1339">Memory Access and Addressing Operations</a><a class="headerlink" href="#memory-access-and-addressing-operations" title="Permalink to this headline">¶</a></h3>
+<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, and allocate
+memory in LLVM.</p>
+<div class="section" id="alloca-instruction">
+<span id="i-alloca"></span><h4><a class="toc-backref" href="#id1340">â<code class="docutils literal notranslate"><span class="pre">alloca</span></code>â Instruction</a><a class="headerlink" href="#alloca-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id192">
+<h5><a class="toc-backref" href="#id1341">Syntax:</a><a class="headerlink" href="#id192" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">alloca</span> <span class="p">[</span><span class="n">inalloca</span><span class="p">]</span> <span class="o"><</span><span class="nb">type</span><span class="o">></span> <span class="p">[,</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">NumElements</span><span class="o">></span><span class="p">]</span> <span class="p">[,</span> <span class="n">align</span> <span class="o"><</span><span class="n">alignment</span><span class="o">></span><span class="p">]</span> <span class="p">[,</span> <span class="n">addrspace</span><span class="p">(</span><span class="o"><</span><span class="n">num</span><span class="o">></span><span class="p">)]</span> <span class="p">;</span> <span class="n">yields</span> <span class="nb">type</span> <span class="n">addrspace</span><span class="p">(</span><span class="n">num</span><span class="p">)</span><span class="o">*</span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id193">
+<h5><a class="toc-backref" href="#id1342">Overview:</a><a class="headerlink" href="#id193" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">alloca</span></code>â instruction allocates memory on the stack frame of the
+currently executing function, to be automatically released when this
+function returns to its caller. The object is always allocated in the
+address space for allocas indicated in the datalayout.</p>
+</div>
+<div class="section" id="id194">
+<h5><a class="toc-backref" href="#id1343">Arguments:</a><a class="headerlink" href="#id194" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">alloca</span></code>â instruction allocates <code class="docutils literal notranslate"><span class="pre">sizeof(<type>)*NumElements</span></code>
+bytes of memory on the runtime stack, returning a pointer of the
+appropriate type to the program. If âNumElementsâ is specified, it is
+the number of elements allocated, otherwise âNumElementsâ is defaulted
+to be one. If a constant alignment is specified, the value result of the
+allocation is guaranteed to be aligned to at least that boundary. The
+alignment may not be greater than <code class="docutils literal notranslate"><span class="pre">1</span> <span class="pre"><<</span> <span class="pre">29</span></code>. If not specified, or if
+zero, the target can choose to align the allocation on any convenient
+boundary compatible with the type.</p>
+<p>â<code class="docutils literal notranslate"><span class="pre">type</span></code>â may be any sized type.</p>
+</div>
+<div class="section" id="id195">
+<h5><a class="toc-backref" href="#id1344">Semantics:</a><a class="headerlink" href="#id195" title="Permalink to this headline">¶</a></h5>
+<p>Memory is allocated; a pointer is returned. The operation is undefined
+if there is insufficient stack space for the allocation. â<code class="docutils literal notranslate"><span class="pre">alloca</span></code>âd
+memory is automatically released when the function returns. The
+â<code class="docutils literal notranslate"><span class="pre">alloca</span></code>â instruction is commonly used to represent automatic
+variables that must have an address available. When the function returns
+(either with the <code class="docutils literal notranslate"><span class="pre">ret</span></code> or <code class="docutils literal notranslate"><span class="pre">resume</span></code> instructions), the memory is
+reclaimed. Allocating zero bytes is legal, but the returned pointer may not
+be unique. The order in which memory is allocated (ie., which way the stack
+grows) is not specified.</p>
+</div>
+<div class="section" id="id196">
+<h5><a class="toc-backref" href="#id1345">Example:</a><a class="headerlink" href="#id196" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%ptr</span> <span class="p">=</span> <span class="k">alloca</span> <span class="k">i32</span> <span class="c">; yields i32*:ptr</span>
+<span class="nv">%ptr</span> <span class="p">=</span> <span class="k">alloca</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i32</span> <span class="m">4</span> <span class="c">; yields i32*:ptr</span>
+<span class="nv">%ptr</span> <span class="p">=</span> <span class="k">alloca</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i32</span> <span class="m">4</span><span class="p">,</span> <span class="k">align</span> <span class="m">1024</span> <span class="c">; yields i32*:ptr</span>
+<span class="nv">%ptr</span> <span class="p">=</span> <span class="k">alloca</span> <span class="k">i32</span><span class="p">,</span> <span class="k">align</span> <span class="m">1024</span> <span class="c">; yields i32*:ptr</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="load-instruction">
+<span id="i-load"></span><h4><a class="toc-backref" href="#id1346">â<code class="docutils literal notranslate"><span class="pre">load</span></code>â Instruction</a><a class="headerlink" href="#load-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id197">
+<h5><a class="toc-backref" href="#id1347">Syntax:</a><a class="headerlink" href="#id197" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><result> = load [volatile] <ty>, <ty>* <pointer>[, align <alignment>][, !nontemporal !<index>][, !invariant.load !<index>][, !invariant.group !<index>][, !nonnull !<index>][, !dereferenceable !<deref_bytes_node>][, !dereferenceable_or_null !<deref_bytes_node>][, !align !<align_node>]
+<result> = load atomic [volatile] <ty>, <ty>* <pointer> [syncscope("<target-scope>")] <ordering>, align <alignment> [, !invariant.group !<index>]
+!<index> = !{ i32 1 }
+!<deref_bytes_node> = !{i64 <dereferenceable_bytes>}
+!<align_node> = !{ i64 <value_alignment> }
+</pre></div>
+</div>
+</div>
+<div class="section" id="id198">
+<h5><a class="toc-backref" href="#id1348">Overview:</a><a class="headerlink" href="#id198" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">load</span></code>â instruction is used to read from memory.</p>
+</div>
+<div class="section" id="id199">
+<h5><a class="toc-backref" href="#id1349">Arguments:</a><a class="headerlink" href="#id199" title="Permalink to this headline">¶</a></h5>
+<p>The argument to the <code class="docutils literal notranslate"><span class="pre">load</span></code> instruction specifies the memory address from which
+to load. The type specified must be a <a class="reference internal" href="#t-firstclass"><span class="std std-ref">first class</span></a> type of
+known size (i.e. not containing an <a class="reference internal" href="#t-opaque"><span class="std std-ref">opaque structural type</span></a>). If
+the <code class="docutils literal notranslate"><span class="pre">load</span></code> is marked as <code class="docutils literal notranslate"><span class="pre">volatile</span></code>, then the optimizer is not allowed to
+modify the number or order of execution of this <code class="docutils literal notranslate"><span class="pre">load</span></code> with other
+<a class="reference internal" href="#volatile"><span class="std std-ref">volatile operations</span></a>.</p>
+<p>If the <code class="docutils literal notranslate"><span class="pre">load</span></code> is marked as <code class="docutils literal notranslate"><span class="pre">atomic</span></code>, it takes an extra <a class="reference internal" href="#ordering"><span class="std std-ref">ordering</span></a> and optional <code class="docutils literal notranslate"><span class="pre">syncscope("<target-scope>")</span></code> argument. The
+<code class="docutils literal notranslate"><span class="pre">release</span></code> and <code class="docutils literal notranslate"><span class="pre">acq_rel</span></code> orderings are not valid on <code class="docutils literal notranslate"><span class="pre">load</span></code> instructions.
+Atomic loads produce <a class="reference internal" href="#memmodel"><span class="std std-ref">defined</span></a> results when they may see
+multiple atomic stores. The type of the pointee must be an integer, pointer, or
+floating-point type whose bit width is a power of two greater than or equal to
+eight and less than or equal to a target-specific size limit. <code class="docutils literal notranslate"><span class="pre">align</span></code> must be
+explicitly specified on atomic loads, and the load has undefined behavior if the
+alignment is not set to a value which is at least the size in bytes of the
+pointee. <code class="docutils literal notranslate"><span class="pre">!nontemporal</span></code> does not have any defined semantics for atomic loads.</p>
+<p>The optional constant <code class="docutils literal notranslate"><span class="pre">align</span></code> argument specifies the alignment of the
+operation (that is, the alignment of the memory address). A value of 0
+or an omitted <code class="docutils literal notranslate"><span class="pre">align</span></code> argument means that the operation has the ABI
+alignment for the target. It is the responsibility of the code emitter
+to ensure that the alignment information is correct. Overestimating the
+alignment results in undefined behavior. Underestimating the alignment
+may produce less efficient code. An alignment of 1 is always safe. The
+maximum possible alignment is <code class="docutils literal notranslate"><span class="pre">1</span> <span class="pre"><<</span> <span class="pre">29</span></code>. An alignment value higher
+than the size of the loaded type implies memory up to the alignment
+value bytes can be safely loaded without trapping in the default
+address space. Access of the high bytes can interfere with debugging
+tools, so should not be accessed if the function has the
+<code class="docutils literal notranslate"><span class="pre">sanitize_thread</span></code> or <code class="docutils literal notranslate"><span class="pre">sanitize_address</span></code> attributes.</p>
+<p>The optional <code class="docutils literal notranslate"><span class="pre">!nontemporal</span></code> metadata must reference a single
+metadata name <code class="docutils literal notranslate"><span class="pre"><index></span></code> corresponding to a metadata node with one
+<code class="docutils literal notranslate"><span class="pre">i32</span></code> entry of value 1. The existence of the <code class="docutils literal notranslate"><span class="pre">!nontemporal</span></code>
+metadata on the instruction tells the optimizer and code generator
+that this load is not expected to be reused in the cache. The code
+generator may select special instructions to save cache bandwidth, such
+as the <code class="docutils literal notranslate"><span class="pre">MOVNT</span></code> instruction on x86.</p>
+<p>The optional <code class="docutils literal notranslate"><span class="pre">!invariant.load</span></code> metadata must reference a single
+metadata name <code class="docutils literal notranslate"><span class="pre"><index></span></code> corresponding to a metadata node with no
+entries. If a load instruction tagged with the <code class="docutils literal notranslate"><span class="pre">!invariant.load</span></code>
+metadata is executed, the optimizer may assume the memory location
+referenced by the load contains the same value at all points in the
+program where the memory location is known to be dereferenceable;
+otherwise, the behavior is undefined.</p>
+<dl class="docutils">
+<dt>The optional <code class="docutils literal notranslate"><span class="pre">!invariant.group</span></code> metadata must reference a single metadata name</dt>
+<dd><code class="docutils literal notranslate"><span class="pre"><index></span></code> corresponding to a metadata node with no entries.
+See <code class="docutils literal notranslate"><span class="pre">invariant.group</span></code> metadata.</dd>
+</dl>
+<p>The optional <code class="docutils literal notranslate"><span class="pre">!nonnull</span></code> metadata must reference a single
+metadata name <code class="docutils literal notranslate"><span class="pre"><index></span></code> corresponding to a metadata node with no
+entries. The existence of the <code class="docutils literal notranslate"><span class="pre">!nonnull</span></code> metadata on the
+instruction tells the optimizer that the value loaded is known to
+never be null. If the value is null at runtime, the behavior is undefined.
+This is analogous to the <code class="docutils literal notranslate"><span class="pre">nonnull</span></code> attribute on parameters and return
+values. This metadata can only be applied to loads of a pointer type.</p>
+<p>The optional <code class="docutils literal notranslate"><span class="pre">!dereferenceable</span></code> metadata must reference a single metadata
+name <code class="docutils literal notranslate"><span class="pre"><deref_bytes_node></span></code> corresponding to a metadata node with one <code class="docutils literal notranslate"><span class="pre">i64</span></code>
+entry. The existence of the <code class="docutils literal notranslate"><span class="pre">!dereferenceable</span></code> metadata on the instruction
+tells the optimizer that the value loaded is known to be dereferenceable.
+The number of bytes known to be dereferenceable is specified by the integer
+value in the metadata node. This is analogous to the ââdereferenceableââ
+attribute on parameters and return values. This metadata can only be applied
+to loads of a pointer type.</p>
+<p>The optional <code class="docutils literal notranslate"><span class="pre">!dereferenceable_or_null</span></code> metadata must reference a single
+metadata name <code class="docutils literal notranslate"><span class="pre"><deref_bytes_node></span></code> corresponding to a metadata node with one
+<code class="docutils literal notranslate"><span class="pre">i64</span></code> entry. The existence of the <code class="docutils literal notranslate"><span class="pre">!dereferenceable_or_null</span></code> metadata on the
+instruction tells the optimizer that the value loaded is known to be either
+dereferenceable or null.
+The number of bytes known to be dereferenceable is specified by the integer
+value in the metadata node. This is analogous to the ââdereferenceable_or_nullââ
+attribute on parameters and return values. This metadata can only be applied
+to loads of a pointer type.</p>
+<p>The optional <code class="docutils literal notranslate"><span class="pre">!align</span></code> metadata must reference a single metadata name
+<code class="docutils literal notranslate"><span class="pre"><align_node></span></code> corresponding to a metadata node with one <code class="docutils literal notranslate"><span class="pre">i64</span></code> entry.
+The existence of the <code class="docutils literal notranslate"><span class="pre">!align</span></code> metadata on the instruction tells the
+optimizer that the value loaded is known to be aligned to a boundary specified
+by the integer value in the metadata node. The alignment must be a power of 2.
+This is analogous to the ââalignââ attribute on parameters and return values.
+This metadata can only be applied to loads of a pointer type. If the returned
+value is not appropriately aligned at runtime, the behavior is undefined.</p>
+</div>
+<div class="section" id="id200">
+<h5><a class="toc-backref" href="#id1350">Semantics:</a><a class="headerlink" href="#id200" title="Permalink to this headline">¶</a></h5>
+<p>The location of memory pointed to is loaded. If the value being loaded
+is of scalar type then the number of bytes read does not exceed the
+minimum number of bytes needed to hold all bits of the type. For
+example, loading an <code class="docutils literal notranslate"><span class="pre">i24</span></code> reads at most three bytes. When loading a
+value of a type like <code class="docutils literal notranslate"><span class="pre">i20</span></code> with a size that is not an integral number
+of bytes, the result is undefined if the value was not originally
+written using a store of the same type.</p>
+</div>
+<div class="section" id="id201">
+<h5><a class="toc-backref" href="#id1351">Examples:</a><a class="headerlink" href="#id201" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%ptr</span> <span class="p">=</span> <span class="k">alloca</span> <span class="k">i32</span> <span class="c">; yields i32*:ptr</span>
+<span class="k">store</span> <span class="k">i32</span> <span class="m">3</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%ptr</span> <span class="c">; yields void</span>
+<span class="nv">%val</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%ptr</span> <span class="c">; yields i32:val = i32 3</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="store-instruction">
+<span id="i-store"></span><h4><a class="toc-backref" href="#id1352">â<code class="docutils literal notranslate"><span class="pre">store</span></code>â Instruction</a><a class="headerlink" href="#store-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id202">
+<h5><a class="toc-backref" href="#id1353">Syntax:</a><a class="headerlink" href="#id202" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span>store [volatile] <ty> <value>, <ty>* <pointer>[, align <alignment>][, !nontemporal !<index>][, !invariant.group !<index>] ; yields void
+store atomic [volatile] <ty> <value>, <ty>* <pointer> [syncscope("<target-scope>")] <ordering>, align <alignment> [, !invariant.group !<index>] ; yields void
+</pre></div>
+</div>
+</div>
+<div class="section" id="id203">
+<h5><a class="toc-backref" href="#id1354">Overview:</a><a class="headerlink" href="#id203" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">store</span></code>â instruction is used to write to memory.</p>
+</div>
+<div class="section" id="id204">
+<h5><a class="toc-backref" href="#id1355">Arguments:</a><a class="headerlink" href="#id204" title="Permalink to this headline">¶</a></h5>
+<p>There are two arguments to the <code class="docutils literal notranslate"><span class="pre">store</span></code> instruction: a value to store and an
+address at which to store it. The type of the <code class="docutils literal notranslate"><span class="pre"><pointer></span></code> operand must be a
+pointer to the <a class="reference internal" href="#t-firstclass"><span class="std std-ref">first class</span></a> type of the <code class="docutils literal notranslate"><span class="pre"><value></span></code>
+operand. If the <code class="docutils literal notranslate"><span class="pre">store</span></code> is marked as <code class="docutils literal notranslate"><span class="pre">volatile</span></code>, then the optimizer is not
+allowed to modify the number or order of execution of this <code class="docutils literal notranslate"><span class="pre">store</span></code> with other
+<a class="reference internal" href="#volatile"><span class="std std-ref">volatile operations</span></a>. Only values of <a class="reference internal" href="#t-firstclass"><span class="std std-ref">first class</span></a> types of known size (i.e. not containing an <a class="reference internal" href="#t-opaque"><span class="std std-ref">opaque
+structural type</span></a>) can be stored.</p>
+<p>If the <code class="docutils literal notranslate"><span class="pre">store</span></code> is marked as <code class="docutils literal notranslate"><span class="pre">atomic</span></code>, it takes an extra <a class="reference internal" href="#ordering"><span class="std std-ref">ordering</span></a> and optional <code class="docutils literal notranslate"><span class="pre">syncscope("<target-scope>")</span></code> argument. The
+<code class="docutils literal notranslate"><span class="pre">acquire</span></code> and <code class="docutils literal notranslate"><span class="pre">acq_rel</span></code> orderings arenât valid on <code class="docutils literal notranslate"><span class="pre">store</span></code> instructions.
+Atomic loads produce <a class="reference internal" href="#memmodel"><span class="std std-ref">defined</span></a> results when they may see
+multiple atomic stores. The type of the pointee must be an integer, pointer, or
+floating-point type whose bit width is a power of two greater than or equal to
+eight and less than or equal to a target-specific size limit. <code class="docutils literal notranslate"><span class="pre">align</span></code> must be
+explicitly specified on atomic stores, and the store has undefined behavior if
+the alignment is not set to a value which is at least the size in bytes of the
+pointee. <code class="docutils literal notranslate"><span class="pre">!nontemporal</span></code> does not have any defined semantics for atomic stores.</p>
+<p>The optional constant <code class="docutils literal notranslate"><span class="pre">align</span></code> argument specifies the alignment of the
+operation (that is, the alignment of the memory address). A value of 0
+or an omitted <code class="docutils literal notranslate"><span class="pre">align</span></code> argument means that the operation has the ABI
+alignment for the target. It is the responsibility of the code emitter
+to ensure that the alignment information is correct. Overestimating the
+alignment results in undefined behavior. Underestimating the
+alignment may produce less efficient code. An alignment of 1 is always
+safe. The maximum possible alignment is <code class="docutils literal notranslate"><span class="pre">1</span> <span class="pre"><<</span> <span class="pre">29</span></code>. An alignment
+value higher than the size of the stored type implies memory up to the
+alignment value bytes can be stored to without trapping in the default
+address space. Storing to the higher bytes however may result in data
+races if another thread can access the same address. Introducing a
+data race is not allowed. Storing to the extra bytes is not allowed
+even in situations where a data race is known to not exist if the
+function has the <code class="docutils literal notranslate"><span class="pre">sanitize_address</span></code> attribute.</p>
+<p>The optional <code class="docutils literal notranslate"><span class="pre">!nontemporal</span></code> metadata must reference a single metadata
+name <code class="docutils literal notranslate"><span class="pre"><index></span></code> corresponding to a metadata node with one <code class="docutils literal notranslate"><span class="pre">i32</span></code> entry of
+value 1. The existence of the <code class="docutils literal notranslate"><span class="pre">!nontemporal</span></code> metadata on the instruction
+tells the optimizer and code generator that this load is not expected to
+be reused in the cache. The code generator may select special
+instructions to save cache bandwidth, such as the <code class="docutils literal notranslate"><span class="pre">MOVNT</span></code> instruction on
+x86.</p>
+<p>The optional <code class="docutils literal notranslate"><span class="pre">!invariant.group</span></code> metadata must reference a
+single metadata name <code class="docutils literal notranslate"><span class="pre"><index></span></code>. See <code class="docutils literal notranslate"><span class="pre">invariant.group</span></code> metadata.</p>
+</div>
+<div class="section" id="id205">
+<h5><a class="toc-backref" href="#id1356">Semantics:</a><a class="headerlink" href="#id205" title="Permalink to this headline">¶</a></h5>
+<p>The contents of memory are updated to contain <code class="docutils literal notranslate"><span class="pre"><value></span></code> at the
+location specified by the <code class="docutils literal notranslate"><span class="pre"><pointer></span></code> operand. If <code class="docutils literal notranslate"><span class="pre"><value></span></code> is
+of scalar type then the number of bytes written does not exceed the
+minimum number of bytes needed to hold all bits of the type. For
+example, storing an <code class="docutils literal notranslate"><span class="pre">i24</span></code> writes at most three bytes. When writing a
+value of a type like <code class="docutils literal notranslate"><span class="pre">i20</span></code> with a size that is not an integral number
+of bytes, it is unspecified what happens to the extra bits that do not
+belong to the type, but they will typically be overwritten.</p>
+</div>
+<div class="section" id="id206">
+<h5><a class="toc-backref" href="#id1357">Example:</a><a class="headerlink" href="#id206" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%ptr</span> <span class="p">=</span> <span class="k">alloca</span> <span class="k">i32</span> <span class="c">; yields i32*:ptr</span>
+<span class="k">store</span> <span class="k">i32</span> <span class="m">3</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%ptr</span> <span class="c">; yields void</span>
+<span class="nv">%val</span> <span class="p">=</span> <span class="k">load</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%ptr</span> <span class="c">; yields i32:val = i32 3</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="fence-instruction">
+<span id="i-fence"></span><h4><a class="toc-backref" href="#id1358">â<code class="docutils literal notranslate"><span class="pre">fence</span></code>â Instruction</a><a class="headerlink" href="#fence-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id207">
+<h5><a class="toc-backref" href="#id1359">Syntax:</a><a class="headerlink" href="#id207" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">fence</span> <span class="p">[</span><span class="n">syncscope</span><span class="p">(</span><span class="s2">"<target-scope>"</span><span class="p">)]</span> <span class="o"><</span><span class="n">ordering</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">void</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id208">
+<h5><a class="toc-backref" href="#id1360">Overview:</a><a class="headerlink" href="#id208" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fence</span></code>â instruction is used to introduce happens-before edges
+between operations.</p>
+</div>
+<div class="section" id="id209">
+<h5><a class="toc-backref" href="#id1361">Arguments:</a><a class="headerlink" href="#id209" title="Permalink to this headline">¶</a></h5>
+<p>â<code class="docutils literal notranslate"><span class="pre">fence</span></code>â instructions take an <a class="reference internal" href="#ordering"><span class="std std-ref">ordering</span></a> argument which
+defines what <em>synchronizes-with</em> edges they add. They can only be given
+<code class="docutils literal notranslate"><span class="pre">acquire</span></code>, <code class="docutils literal notranslate"><span class="pre">release</span></code>, <code class="docutils literal notranslate"><span class="pre">acq_rel</span></code>, and <code class="docutils literal notranslate"><span class="pre">seq_cst</span></code> orderings.</p>
+</div>
+<div class="section" id="id210">
+<h5><a class="toc-backref" href="#id1362">Semantics:</a><a class="headerlink" href="#id210" title="Permalink to this headline">¶</a></h5>
+<p>A fence A which has (at least) <code class="docutils literal notranslate"><span class="pre">release</span></code> ordering semantics
+<em>synchronizes with</em> a fence B with (at least) <code class="docutils literal notranslate"><span class="pre">acquire</span></code> ordering
+semantics if and only if there exist atomic operations X and Y, both
+operating on some atomic object M, such that A is sequenced before X, X
+modifies M (either directly or through some side effect of a sequence
+headed by X), Y is sequenced before B, and Y observes M. This provides a
+<em>happens-before</em> dependency between A and B. Rather than an explicit
+<code class="docutils literal notranslate"><span class="pre">fence</span></code>, one (but not both) of the atomic operations X or Y might
+provide a <code class="docutils literal notranslate"><span class="pre">release</span></code> or <code class="docutils literal notranslate"><span class="pre">acquire</span></code> (resp.) ordering constraint and
+still <em>synchronize-with</em> the explicit <code class="docutils literal notranslate"><span class="pre">fence</span></code> and establish the
+<em>happens-before</em> edge.</p>
+<p>A <code class="docutils literal notranslate"><span class="pre">fence</span></code> which has <code class="docutils literal notranslate"><span class="pre">seq_cst</span></code> ordering, in addition to having both
+<code class="docutils literal notranslate"><span class="pre">acquire</span></code> and <code class="docutils literal notranslate"><span class="pre">release</span></code> semantics specified above, participates in
+the global program order of other <code class="docutils literal notranslate"><span class="pre">seq_cst</span></code> operations and/or fences.</p>
+<p>A <code class="docutils literal notranslate"><span class="pre">fence</span></code> instruction can also take an optional
+â<a class="reference internal" href="#syncscope"><span class="std std-ref">syncscope</span></a>â argument.</p>
+</div>
+<div class="section" id="id211">
+<h5><a class="toc-backref" href="#id1363">Example:</a><a class="headerlink" href="#id211" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>fence acquire ; yields void
+fence syncscope("singlethread") seq_cst ; yields void
+fence syncscope("agent") seq_cst ; yields void
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="cmpxchg-instruction">
+<span id="i-cmpxchg"></span><h4><a class="toc-backref" href="#id1364">â<code class="docutils literal notranslate"><span class="pre">cmpxchg</span></code>â Instruction</a><a class="headerlink" href="#cmpxchg-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id212">
+<h5><a class="toc-backref" href="#id1365">Syntax:</a><a class="headerlink" href="#id212" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">cmpxchg</span> <span class="p">[</span><span class="n">weak</span><span class="p">]</span> <span class="p">[</span><span class="n">volatile</span><span class="p">]</span> <span class="o"><</span><span class="n">ty</span><span class="o">>*</span> <span class="o"><</span><span class="n">pointer</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="nb">cmp</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">new</span><span class="o">></span> <span class="p">[</span><span class="n">syncscope</span><span class="p">(</span><span class="s2">"<target-scope>"</span><span class="p">)]</span> <span class="o"><</span><span class="n">success</span> <span class="n">ordering</span><span class="o">></span> <span class="o"><</span><span class="n">failure</span> <span class="n">ordering</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="p">{</span> <span class="n">ty</span><span class="p">,</span> <span class="n">i1</span> <span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id213">
+<h5><a class="toc-backref" href="#id1366">Overview:</a><a class="headerlink" href="#id213" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">cmpxchg</span></code>â instruction is used to atomically modify memory. It
+loads a value in memory and compares it to a given value. If they are
+equal, it tries to store a new value into the memory.</p>
+</div>
+<div class="section" id="id214">
+<h5><a class="toc-backref" href="#id1367">Arguments:</a><a class="headerlink" href="#id214" title="Permalink to this headline">¶</a></h5>
+<p>There are three arguments to the â<code class="docutils literal notranslate"><span class="pre">cmpxchg</span></code>â instruction: an address
+to operate on, a value to compare to the value currently be at that
+address, and a new value to place at that address if the compared values
+are equal. The type of â<cmp>â must be an integer or pointer type whose
+bit width is a power of two greater than or equal to eight and less
+than or equal to a target-specific size limit. â<cmp>â and â<new>â must
+have the same type, and the type of â<pointer>â must be a pointer to
+that type. If the <code class="docutils literal notranslate"><span class="pre">cmpxchg</span></code> is marked as <code class="docutils literal notranslate"><span class="pre">volatile</span></code>, then the
+optimizer is not allowed to modify the number or order of execution of
+this <code class="docutils literal notranslate"><span class="pre">cmpxchg</span></code> with other <a class="reference internal" href="#volatile"><span class="std std-ref">volatile operations</span></a>.</p>
+<p>The success and failure <a class="reference internal" href="#ordering"><span class="std std-ref">ordering</span></a> arguments specify how this
+<code class="docutils literal notranslate"><span class="pre">cmpxchg</span></code> synchronizes with other atomic operations. Both ordering parameters
+must be at least <code class="docutils literal notranslate"><span class="pre">monotonic</span></code>, the ordering constraint on failure must be no
+stronger than that on success, and the failure ordering cannot be either
+<code class="docutils literal notranslate"><span class="pre">release</span></code> or <code class="docutils literal notranslate"><span class="pre">acq_rel</span></code>.</p>
+<p>A <code class="docutils literal notranslate"><span class="pre">cmpxchg</span></code> instruction can also take an optional
+â<a class="reference internal" href="#syncscope"><span class="std std-ref">syncscope</span></a>â argument.</p>
+<p>The pointer passed into cmpxchg must have alignment greater than or
+equal to the size in memory of the operand.</p>
+</div>
+<div class="section" id="id215">
+<h5><a class="toc-backref" href="#id1368">Semantics:</a><a class="headerlink" href="#id215" title="Permalink to this headline">¶</a></h5>
+<p>The contents of memory at the location specified by the â<code class="docutils literal notranslate"><span class="pre"><pointer></span></code>â operand
+is read and compared to â<code class="docutils literal notranslate"><span class="pre"><cmp></span></code>â; if the values are equal, â<code class="docutils literal notranslate"><span class="pre"><new></span></code>â is
+written to the location. The original value at the location is returned,
+together with a flag indicating success (true) or failure (false).</p>
+<p>If the cmpxchg operation is marked as <code class="docutils literal notranslate"><span class="pre">weak</span></code> then a spurious failure is
+permitted: the operation may not write <code class="docutils literal notranslate"><span class="pre"><new></span></code> even if the comparison
+matched.</p>
+<p>If the cmpxchg operation is strong (the default), the i1 value is 1 if and only
+if the value loaded equals <code class="docutils literal notranslate"><span class="pre">cmp</span></code>.</p>
+<p>A successful <code class="docutils literal notranslate"><span class="pre">cmpxchg</span></code> is a read-modify-write instruction for the purpose of
+identifying release sequences. A failed <code class="docutils literal notranslate"><span class="pre">cmpxchg</span></code> is equivalent to an atomic
+load with an ordering parameter determined the second ordering parameter.</p>
+</div>
+<div class="section" id="id216">
+<h5><a class="toc-backref" href="#id1369">Example:</a><a class="headerlink" href="#id216" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nl">entry:</span>
+ <span class="nv">%orig</span> <span class="p">=</span> <span class="k">load</span> <span class="k">atomic</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%ptr</span> <span class="k">unordered</span><span class="p">,</span> <span class="k">align</span> <span class="m">4</span> <span class="c">; yields i32</span>
+ <span class="k">br</span> <span class="kt">label</span> <span class="nv">%loop</span>
+
+<span class="nl">loop:</span>
+ <span class="nv">%cmp</span> <span class="p">=</span> <span class="k">phi</span> <span class="k">i32</span> <span class="p">[</span> <span class="nv">%orig</span><span class="p">,</span> <span class="nv">%entry</span> <span class="p">],</span> <span class="p">[</span><span class="nv">%value_loaded</span><span class="p">,</span> <span class="nv">%loop</span><span class="p">]</span>
+ <span class="nv">%squared</span> <span class="p">=</span> <span class="k">mul</span> <span class="k">i32</span> <span class="nv">%cmp</span><span class="p">,</span> <span class="nv">%cmp</span>
+ <span class="nv">%val_success</span> <span class="p">=</span> <span class="k">cmpxchg</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%ptr</span><span class="p">,</span> <span class="k">i32</span> <span class="nv">%cmp</span><span class="p">,</span> <span class="k">i32</span> <span class="nv">%squared</span> <span class="k">acq_rel</span> <span class="k">monotonic</span> <span class="c">; yields { i32, i1 }</span>
+ <span class="nv">%value_loaded</span> <span class="p">=</span> <span class="k">extractvalue</span> <span class="p">{</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i1</span> <span class="p">}</span> <span class="nv">%val_success</span><span class="p">,</span> <span class="m">0</span>
+ <span class="nv">%success</span> <span class="p">=</span> <span class="k">extractvalue</span> <span class="p">{</span> <span class="k">i32</span><span class="p">,</span> <span class="k">i1</span> <span class="p">}</span> <span class="nv">%val_success</span><span class="p">,</span> <span class="m">1</span>
+ <span class="k">br</span> <span class="k">i1</span> <span class="nv">%success</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%done</span><span class="p">,</span> <span class="kt">label</span> <span class="nv">%loop</span>
+
+<span class="nl">done:</span>
+ <span class="p">...</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="atomicrmw-instruction">
+<span id="i-atomicrmw"></span><h4><a class="toc-backref" href="#id1370">â<code class="docutils literal notranslate"><span class="pre">atomicrmw</span></code>â Instruction</a><a class="headerlink" href="#atomicrmw-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id217">
+<h5><a class="toc-backref" href="#id1371">Syntax:</a><a class="headerlink" href="#id217" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">atomicrmw</span> <span class="p">[</span><span class="n">volatile</span><span class="p">]</span> <span class="o"><</span><span class="n">operation</span><span class="o">></span> <span class="o"><</span><span class="n">ty</span><span class="o">>*</span> <span class="o"><</span><span class="n">pointer</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="p">[</span><span class="n">syncscope</span><span class="p">(</span><span class="s2">"<target-scope>"</span><span class="p">)]</span> <span class="o"><</span><span class="n">ordering</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id218">
+<h5><a class="toc-backref" href="#id1372">Overview:</a><a class="headerlink" href="#id218" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">atomicrmw</span></code>â instruction is used to atomically modify memory.</p>
+</div>
+<div class="section" id="id219">
+<h5><a class="toc-backref" href="#id1373">Arguments:</a><a class="headerlink" href="#id219" title="Permalink to this headline">¶</a></h5>
+<p>There are three arguments to the â<code class="docutils literal notranslate"><span class="pre">atomicrmw</span></code>â instruction: an
+operation to apply, an address whose value to modify, an argument to the
+operation. The operation must be one of the following keywords:</p>
+<ul class="simple">
+<li>xchg</li>
+<li>add</li>
+<li>sub</li>
+<li>and</li>
+<li>nand</li>
+<li>or</li>
+<li>xor</li>
+<li>max</li>
+<li>min</li>
+<li>umax</li>
+<li>umin</li>
+</ul>
+<p>The type of â<value>â must be an integer type whose bit width is a power
+of two greater than or equal to eight and less than or equal to a
+target-specific size limit. The type of the â<code class="docutils literal notranslate"><span class="pre"><pointer></span></code>â operand must
+be a pointer to that type. If the <code class="docutils literal notranslate"><span class="pre">atomicrmw</span></code> is marked as
+<code class="docutils literal notranslate"><span class="pre">volatile</span></code>, then the optimizer is not allowed to modify the number or
+order of execution of this <code class="docutils literal notranslate"><span class="pre">atomicrmw</span></code> with other <a class="reference internal" href="#volatile"><span class="std std-ref">volatile
+operations</span></a>.</p>
+<p>A <code class="docutils literal notranslate"><span class="pre">atomicrmw</span></code> instruction can also take an optional
+â<a class="reference internal" href="#syncscope"><span class="std std-ref">syncscope</span></a>â argument.</p>
+</div>
+<div class="section" id="id220">
+<h5><a class="toc-backref" href="#id1374">Semantics:</a><a class="headerlink" href="#id220" title="Permalink to this headline">¶</a></h5>
+<p>The contents of memory at the location specified by the â<code class="docutils literal notranslate"><span class="pre"><pointer></span></code>â
+operand are atomically read, modified, and written back. The original
+value at the location is returned. The modification is specified by the
+operation argument:</p>
+<ul class="simple">
+<li>xchg: <code class="docutils literal notranslate"><span class="pre">*ptr</span> <span class="pre">=</span> <span class="pre">val</span></code></li>
+<li>add: <code class="docutils literal notranslate"><span class="pre">*ptr</span> <span class="pre">=</span> <span class="pre">*ptr</span> <span class="pre">+</span> <span class="pre">val</span></code></li>
+<li>sub: <code class="docutils literal notranslate"><span class="pre">*ptr</span> <span class="pre">=</span> <span class="pre">*ptr</span> <span class="pre">-</span> <span class="pre">val</span></code></li>
+<li>and: <code class="docutils literal notranslate"><span class="pre">*ptr</span> <span class="pre">=</span> <span class="pre">*ptr</span> <span class="pre">&</span> <span class="pre">val</span></code></li>
+<li>nand: <code class="docutils literal notranslate"><span class="pre">*ptr</span> <span class="pre">=</span> <span class="pre">~(*ptr</span> <span class="pre">&</span> <span class="pre">val)</span></code></li>
+<li>or: <code class="docutils literal notranslate"><span class="pre">*ptr</span> <span class="pre">=</span> <span class="pre">*ptr</span> <span class="pre">|</span> <span class="pre">val</span></code></li>
+<li>xor: <code class="docutils literal notranslate"><span class="pre">*ptr</span> <span class="pre">=</span> <span class="pre">*ptr</span> <span class="pre">^</span> <span class="pre">val</span></code></li>
+<li>max: <code class="docutils literal notranslate"><span class="pre">*ptr</span> <span class="pre">=</span> <span class="pre">*ptr</span> <span class="pre">></span> <span class="pre">val</span> <span class="pre">?</span> <span class="pre">*ptr</span> <span class="pre">:</span> <span class="pre">val</span></code> (using a signed comparison)</li>
+<li>min: <code class="docutils literal notranslate"><span class="pre">*ptr</span> <span class="pre">=</span> <span class="pre">*ptr</span> <span class="pre"><</span> <span class="pre">val</span> <span class="pre">?</span> <span class="pre">*ptr</span> <span class="pre">:</span> <span class="pre">val</span></code> (using a signed comparison)</li>
+<li>umax: <code class="docutils literal notranslate"><span class="pre">*ptr</span> <span class="pre">=</span> <span class="pre">*ptr</span> <span class="pre">></span> <span class="pre">val</span> <span class="pre">?</span> <span class="pre">*ptr</span> <span class="pre">:</span> <span class="pre">val</span></code> (using an unsigned
+comparison)</li>
+<li>umin: <code class="docutils literal notranslate"><span class="pre">*ptr</span> <span class="pre">=</span> <span class="pre">*ptr</span> <span class="pre"><</span> <span class="pre">val</span> <span class="pre">?</span> <span class="pre">*ptr</span> <span class="pre">:</span> <span class="pre">val</span></code> (using an unsigned
+comparison)</li>
+</ul>
+</div>
+<div class="section" id="id221">
+<h5><a class="toc-backref" href="#id1375">Example:</a><a class="headerlink" href="#id221" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%old</span> <span class="p">=</span> <span class="k">atomicrmw</span> <span class="k">add</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%ptr</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span> <span class="k">acquire</span> <span class="c">; yields i32</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="getelementptr-instruction">
+<span id="i-getelementptr"></span><h4><a class="toc-backref" href="#id1376">â<code class="docutils literal notranslate"><span class="pre">getelementptr</span></code>â Instruction</a><a class="headerlink" href="#getelementptr-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id222">
+<h5><a class="toc-backref" href="#id1377">Syntax:</a><a class="headerlink" href="#id222" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">getelementptr</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">ty</span><span class="o">>*</span> <span class="o"><</span><span class="n">ptrval</span><span class="o">></span><span class="p">{,</span> <span class="p">[</span><span class="n">inrange</span><span class="p">]</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">idx</span><span class="o">></span><span class="p">}</span><span class="o">*</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">getelementptr</span> <span class="n">inbounds</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">ty</span><span class="o">>*</span> <span class="o"><</span><span class="n">ptrval</span><span class="o">></span><span class="p">{,</span> <span class="p">[</span><span class="n">inrange</span><span class="p">]</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">idx</span><span class="o">></span><span class="p">}</span><span class="o">*</span>
+<span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">getelementptr</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">ptr</span> <span class="n">vector</span><span class="o">></span> <span class="o"><</span><span class="n">ptrval</span><span class="o">></span><span class="p">,</span> <span class="p">[</span><span class="n">inrange</span><span class="p">]</span> <span class="o"><</span><span class="n">vector</span> <span class="n">index</span> <span class="nb">type</span><span class="o">></span> <span class="o"><</span><span class="n">idx</span><span class="o">></span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id223">
+<h5><a class="toc-backref" href="#id1378">Overview:</a><a class="headerlink" href="#id223" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">getelementptr</span></code>â instruction is used to get the address of a
+subelement of an <a class="reference internal" href="#t-aggregate"><span class="std std-ref">aggregate</span></a> data structure. It performs
+address calculation only and does not access memory. The instruction can also
+be used to calculate a vector of such addresses.</p>
+</div>
+<div class="section" id="id224">
+<h5><a class="toc-backref" href="#id1379">Arguments:</a><a class="headerlink" href="#id224" title="Permalink to this headline">¶</a></h5>
+<p>The first argument is always a type used as the basis for the calculations.
+The second argument is always a pointer or a vector of pointers, and is the
+base address to start from. The remaining arguments are indices
+that indicate which of the elements of the aggregate object are indexed.
+The interpretation of each index is dependent on the type being indexed
+into. The first index always indexes the pointer value given as the
+second argument, the second index indexes a value of the type pointed to
+(not necessarily the value directly pointed to, since the first index
+can be non-zero), etc. The first type indexed into must be a pointer
+value, subsequent types can be arrays, vectors, and structs. Note that
+subsequent types being indexed into can never be pointers, since that
+would require loading the pointer before continuing calculation.</p>
+<p>The type of each index argument depends on the type it is indexing into.
+When indexing into a (optionally packed) structure, only <code class="docutils literal notranslate"><span class="pre">i32</span></code> integer
+<strong>constants</strong> are allowed (when using a vector of indices they must all
+be the <strong>same</strong> <code class="docutils literal notranslate"><span class="pre">i32</span></code> integer constant). When indexing into an array,
+pointer or vector, integers of any width are allowed, and they are not
+required to be constant. These integers are treated as signed values
+where relevant.</p>
+<p>For example, letâs consider a C code fragment and how it gets compiled
+to LLVM:</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="k">struct</span> <span class="n">RT</span> <span class="p">{</span>
+ <span class="kt">char</span> <span class="n">A</span><span class="p">;</span>
+ <span class="kt">int</span> <span class="n">B</span><span class="p">[</span><span class="mi">10</span><span class="p">][</span><span class="mi">20</span><span class="p">];</span>
+ <span class="kt">char</span> <span class="n">C</span><span class="p">;</span>
+<span class="p">};</span>
+<span class="k">struct</span> <span class="n">ST</span> <span class="p">{</span>
+ <span class="kt">int</span> <span class="n">X</span><span class="p">;</span>
+ <span class="kt">double</span> <span class="n">Y</span><span class="p">;</span>
+ <span class="k">struct</span> <span class="n">RT</span> <span class="n">Z</span><span class="p">;</span>
+<span class="p">};</span>
+
+<span class="kt">int</span> <span class="o">*</span><span class="nf">foo</span><span class="p">(</span><span class="k">struct</span> <span class="n">ST</span> <span class="o">*</span><span class="n">s</span><span class="p">)</span> <span class="p">{</span>
+ <span class="k">return</span> <span class="o">&</span><span class="n">s</span><span class="p">[</span><span class="mi">1</span><span class="p">].</span><span class="n">Z</span><span class="p">.</span><span class="n">B</span><span class="p">[</span><span class="mi">5</span><span class="p">][</span><span class="mi">13</span><span class="p">];</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+<p>The LLVM code generated by Clang is:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%struct.RT</span> <span class="p">=</span> <span class="k">type</span> <span class="p">{</span> <span class="k">i8</span><span class="p">,</span> <span class="p">[</span><span class="m">10</span> <span class="k">x</span> <span class="p">[</span><span class="m">20</span> <span class="k">x</span> <span class="k">i32</span><span class="p">]],</span> <span class="k">i8</span> <span class="p">}</span>
+<span class="nv">%struct.ST</span> <span class="p">=</span> <span class="k">type</span> <span class="p">{</span> <span class="k">i32</span><span class="p">,</span> <span class="kt">double</span><span class="p">,</span> <span class="nv">%struct.RT</span> <span class="p">}</span>
+
+<span class="k">define</span> <span class="k">i32</span><span class="p">*</span> <span class="vg">@foo</span><span class="p">(</span><span class="nv">%struct.ST</span><span class="p">*</span> <span class="nv">%s</span><span class="p">)</span> <span class="k">nounwind</span> <span class="k">uwtable</span> <span class="k">readnone</span> <span class="k">optsize</span> <span class="k">ssp</span> <span class="p">{</span>
+<span class="nl">entry:</span>
+ <span class="nv">%arrayidx</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="k">inbounds</span> <span class="nv">%struct.ST</span><span class="p">,</span> <span class="nv">%struct.ST</span><span class="p">*</span> <span class="nv">%s</span><span class="p">,</span> <span class="k">i64</span> <span class="m">1</span><span class="p">,</span> <span class="k">i32</span> <span class="m">2</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span><span class="p">,</span> <span class="k">i64</span> <span class="m">5</span><span class="p">,</span> <span class="k">i64</span> <span class="m">13</span>
+ <span class="k">ret</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%arrayidx</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id225">
+<h5><a class="toc-backref" href="#id1380">Semantics:</a><a class="headerlink" href="#id225" title="Permalink to this headline">¶</a></h5>
+<p>In the example above, the first index is indexing into the
+â<code class="docutils literal notranslate"><span class="pre">%struct.ST*</span></code>â type, which is a pointer, yielding a â<code class="docutils literal notranslate"><span class="pre">%struct.ST</span></code>â
+= â<code class="docutils literal notranslate"><span class="pre">{</span> <span class="pre">i32,</span> <span class="pre">double,</span> <span class="pre">%struct.RT</span> <span class="pre">}</span></code>â type, a structure. The second index
+indexes into the third element of the structure, yielding a
+â<code class="docutils literal notranslate"><span class="pre">%struct.RT</span></code>â = â<code class="docutils literal notranslate"><span class="pre">{</span> <span class="pre">i8</span> <span class="pre">,</span> <span class="pre">[10</span> <span class="pre">x</span> <span class="pre">[20</span> <span class="pre">x</span> <span class="pre">i32]],</span> <span class="pre">i8</span> <span class="pre">}</span></code>â type, another
+structure. The third index indexes into the second element of the
+structure, yielding a â<code class="docutils literal notranslate"><span class="pre">[10</span> <span class="pre">x</span> <span class="pre">[20</span> <span class="pre">x</span> <span class="pre">i32]]</span></code>â type, an array. The two
+dimensions of the array are subscripted into, yielding an â<code class="docutils literal notranslate"><span class="pre">i32</span></code>â
+type. The â<code class="docutils literal notranslate"><span class="pre">getelementptr</span></code>â instruction returns a pointer to this
+element, thus computing a value of â<code class="docutils literal notranslate"><span class="pre">i32*</span></code>â 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>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">define</span> <span class="k">i32</span><span class="p">*</span> <span class="vg">@foo</span><span class="p">(</span><span class="nv">%struct.ST</span><span class="p">*</span> <span class="nv">%s</span><span class="p">)</span> <span class="p">{</span>
+ <span class="nv">%t1</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="nv">%struct.ST</span><span class="p">,</span> <span class="nv">%struct.ST</span><span class="p">*</span> <span class="nv">%s</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span> <span class="c">; yields %struct.ST*:%t1</span>
+ <span class="nv">%t2</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="nv">%struct.ST</span><span class="p">,</span> <span class="nv">%struct.ST</span><span class="p">*</span> <span class="nv">%t1</span><span class="p">,</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="k">i32</span> <span class="m">2</span> <span class="c">; yields %struct.RT*:%t2</span>
+ <span class="nv">%t3</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="nv">%struct.RT</span><span class="p">,</span> <span class="nv">%struct.RT</span><span class="p">*</span> <span class="nv">%t2</span><span class="p">,</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span> <span class="c">; yields [10 x [20 x i32]]*:%t3</span>
+ <span class="nv">%t4</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="p">[</span><span class="m">10</span> <span class="k">x</span> <span class="p">[</span><span class="m">20</span> <span class="k">x</span> <span class="k">i32</span><span class="p">]],</span> <span class="p">[</span><span class="m">10</span> <span class="k">x</span> <span class="p">[</span><span class="m">20</span> <span class="k">x</span> <span class="k">i32</span><span class="p">]]*</span> <span class="nv">%t3</span><span class="p">,</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="k">i32</span> <span class="m">5</span> <span class="c">; yields [20 x i32]*:%t4</span>
+ <span class="nv">%t5</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="p">[</span><span class="m">20</span> <span class="k">x</span> <span class="k">i32</span><span class="p">],</span> <span class="p">[</span><span class="m">20</span> <span class="k">x</span> <span class="k">i32</span><span class="p">]*</span> <span class="nv">%t4</span><span class="p">,</span> <span class="k">i32</span> <span class="m">0</span><span class="p">,</span> <span class="k">i32</span> <span class="m">13</span> <span class="c">; yields i32*:%t5</span>
+ <span class="k">ret</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%t5</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+<p>If the <code class="docutils literal notranslate"><span class="pre">inbounds</span></code> keyword is present, the result value of the
+<code class="docutils literal notranslate"><span class="pre">getelementptr</span></code> is a <a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a> if the base
+pointer is not an <em>in bounds</em> address of an allocated object, or if any
+of the addresses that would be formed by successive addition of the
+offsets implied by the indices to the base address with infinitely
+precise signed arithmetic are not an <em>in bounds</em> address of that
+allocated object. The <em>in bounds</em> addresses for an allocated object are
+all the addresses that point into the object, plus the address one byte
+past the end. The only <em>in bounds</em> address for a null pointer in the
+default address-space is the null pointer itself. In cases where the
+base is a vector of pointers the <code class="docutils literal notranslate"><span class="pre">inbounds</span></code> keyword applies to each
+of the computations element-wise.</p>
+<p>If the <code class="docutils literal notranslate"><span class="pre">inbounds</span></code> keyword is not present, the offsets are added to the
+base address with silently-wrapping twoâs complement arithmetic. If the
+offsets have a different width from the pointer, they are sign-extended
+or truncated to the width of the pointer. The result value of the
+<code class="docutils literal notranslate"><span class="pre">getelementptr</span></code> may be outside the object pointed to by the base
+pointer. The result value may not necessarily be used to access memory
+though, even if it happens to point into allocated storage. See the
+<a class="reference internal" href="#pointeraliasing"><span class="std std-ref">Pointer Aliasing Rules</span></a> section for more
+information.</p>
+<p>If the <code class="docutils literal notranslate"><span class="pre">inrange</span></code> keyword is present before any index, loading from or
+storing to any pointer derived from the <code class="docutils literal notranslate"><span class="pre">getelementptr</span></code> has undefined
+behavior if the load or store would access memory outside of the bounds of
+the element selected by the index marked as <code class="docutils literal notranslate"><span class="pre">inrange</span></code>. The result of a
+pointer comparison or <code class="docutils literal notranslate"><span class="pre">ptrtoint</span></code> (including <code class="docutils literal notranslate"><span class="pre">ptrtoint</span></code>-like operations
+involving memory) involving a pointer derived from a <code class="docutils literal notranslate"><span class="pre">getelementptr</span></code> with
+the <code class="docutils literal notranslate"><span class="pre">inrange</span></code> keyword is undefined, with the exception of comparisons
+in the case where both operands are in the range of the element selected
+by the <code class="docutils literal notranslate"><span class="pre">inrange</span></code> keyword, inclusive of the address one past the end of
+that element. Note that the <code class="docutils literal notranslate"><span class="pre">inrange</span></code> keyword is currently only allowed
+in constant <code class="docutils literal notranslate"><span class="pre">getelementptr</span></code> expressions.</p>
+<p>The getelementptr instruction is often confusing. For some more insight
+into how it works, see <a class="reference internal" href="GetElementPtr.html"><span class="doc">the getelementptr FAQ</span></a>.</p>
+</div>
+<div class="section" id="id226">
+<h5><a class="toc-backref" href="#id1381">Example:</a><a class="headerlink" href="#id226" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="c">; yields [12 x i8]*:aptr</span>
+<span class="nv">%aptr</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="p">{</span><span class="k">i32</span><span class="p">,</span> <span class="p">[</span><span class="m">12</span> <span class="k">x</span> <span class="k">i8</span><span class="p">]},</span> <span class="p">{</span><span class="k">i32</span><span class="p">,</span> <span class="p">[</span><span class="m">12</span> <span class="k">x</span> <span class="k">i8</span><span class="p">]}*</span> <span class="nv">%saptr</span><span class="p">,</span> <span class="k">i64</span> <span class="m">0</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span>
+<span class="c">; yields i8*:vptr</span>
+<span class="nv">%vptr</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="p">{</span><span class="k">i32</span><span class="p">,</span> <span class="p"><</span><span class="m">2</span> <span class="k">x</span> <span class="k">i8</span><span class="p">>},</span> <span class="p">{</span><span class="k">i32</span><span class="p">,</span> <span class="p"><</span><span class="m">2</span> <span class="k">x</span> <span class="k">i8</span><span class="p">>}*</span> <span class="nv">%svptr</span><span class="p">,</span> <span class="k">i64</span> <span class="m">0</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span>
+<span class="c">; yields i8*:eptr</span>
+<span class="nv">%eptr</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="p">[</span><span class="m">12</span> <span class="k">x</span> <span class="k">i8</span><span class="p">],</span> <span class="p">[</span><span class="m">12</span> <span class="k">x</span> <span class="k">i8</span><span class="p">]*</span> <span class="nv">%aptr</span><span class="p">,</span> <span class="k">i64</span> <span class="m">0</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span>
+<span class="c">; yields i32*:iptr</span>
+<span class="nv">%iptr</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="p">[</span><span class="m">10</span> <span class="k">x</span> <span class="k">i32</span><span class="p">],</span> <span class="p">[</span><span class="m">10</span> <span class="k">x</span> <span class="k">i32</span><span class="p">]*</span> <span class="vg">@arr</span><span class="p">,</span> <span class="k">i16</span> <span class="m">0</span><span class="p">,</span> <span class="k">i16</span> <span class="m">0</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="vector-of-pointers">
+<h5><a class="toc-backref" href="#id1382">Vector of pointers:</a><a class="headerlink" href="#vector-of-pointers" title="Permalink to this headline">¶</a></h5>
+<p>The <code class="docutils literal notranslate"><span class="pre">getelementptr</span></code> returns a vector of pointers, instead of a single address,
+when one or more of its arguments is a vector. In such cases, all vector
+arguments should have the same number of elements, and every scalar argument
+will be effectively broadcast into a vector during address calculation.</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="c">; All arguments are vectors:</span>
+<span class="c">; A[i] = ptrs[i] + offsets[i]*sizeof(i8)</span>
+<span class="nv">%A</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="k">i8</span><span class="p">,</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i8</span><span class="p">*></span> <span class="nv">%ptrs</span><span class="p">,</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i64</span><span class="p">></span> <span class="nv">%offsets</span>
+
+<span class="c">; Add the same scalar offset to each pointer of a vector:</span>
+<span class="c">; A[i] = ptrs[i] + offset*sizeof(i8)</span>
+<span class="nv">%A</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="k">i8</span><span class="p">,</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i8</span><span class="p">*></span> <span class="nv">%ptrs</span><span class="p">,</span> <span class="k">i64</span> <span class="nv">%offset</span>
+
+<span class="c">; Add distinct offsets to the same pointer:</span>
+<span class="c">; A[i] = ptr + offsets[i]*sizeof(i8)</span>
+<span class="nv">%A</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="k">i8</span><span class="p">,</span> <span class="k">i8</span><span class="p">*</span> <span class="nv">%ptr</span><span class="p">,</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i64</span><span class="p">></span> <span class="nv">%offsets</span>
+
+<span class="c">; In all cases described above the type of the result is <4 x i8*></span>
+</pre></div>
+</div>
+<p>The two following instructions are equivalent:</p>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="k">getelementptr</span> <span class="nv">%struct.ST</span><span class="p">,</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="nv">%struct.ST</span><span class="p">*></span> <span class="nv">%s</span><span class="p">,</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i64</span><span class="p">></span> <span class="nv">%ind1</span><span class="p">,</span>
+ <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i32</span><span class="p">></span> <span class="p"><</span><span class="k">i32</span> <span class="m">2</span><span class="p">,</span> <span class="k">i32</span> <span class="m">2</span><span class="p">,</span> <span class="k">i32</span> <span class="m">2</span><span class="p">,</span> <span class="k">i32</span> <span class="m">2</span><span class="p">>,</span>
+ <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i32</span><span class="p">></span> <span class="p"><</span><span class="k">i32</span> <span class="m">1</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span><span class="p">>,</span>
+ <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i32</span><span class="p">></span> <span class="nv">%ind4</span><span class="p">,</span>
+ <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i64</span><span class="p">></span> <span class="p"><</span><span class="k">i64</span> <span class="m">13</span><span class="p">,</span> <span class="k">i64</span> <span class="m">13</span><span class="p">,</span> <span class="k">i64</span> <span class="m">13</span><span class="p">,</span> <span class="k">i64</span> <span class="m">13</span><span class="p">></span>
+
+<span class="k">getelementptr</span> <span class="nv">%struct.ST</span><span class="p">,</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="nv">%struct.ST</span><span class="p">*></span> <span class="nv">%s</span><span class="p">,</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i64</span><span class="p">></span> <span class="nv">%ind1</span><span class="p">,</span>
+ <span class="k">i32</span> <span class="m">2</span><span class="p">,</span> <span class="k">i32</span> <span class="m">1</span><span class="p">,</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i32</span><span class="p">></span> <span class="nv">%ind4</span><span class="p">,</span> <span class="k">i64</span> <span class="m">13</span>
+</pre></div>
+</div>
+<p>Letâs look at the C code, where the vector version of <code class="docutils literal notranslate"><span class="pre">getelementptr</span></code>
+makes sense:</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="c1">// Let's assume that we vectorize the following loop:</span>
+<span class="kt">double</span> <span class="o">*</span><span class="n">A</span><span class="p">,</span> <span class="o">*</span><span class="n">B</span><span class="p">;</span> <span class="kt">int</span> <span class="o">*</span><span class="n">C</span><span class="p">;</span>
+<span class="k">for</span> <span class="p">(</span><span class="kt">int</span> <span class="n">i</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span> <span class="n">i</span> <span class="o"><</span> <span class="n">size</span><span class="p">;</span> <span class="o">++</span><span class="n">i</span><span class="p">)</span> <span class="p">{</span>
+ <span class="n">A</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="n">B</span><span class="p">[</span><span class="n">C</span><span class="p">[</span><span class="n">i</span><span class="p">]];</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="c">; get pointers for 8 elements from array B</span>
+<span class="nv">%ptrs</span> <span class="p">=</span> <span class="k">getelementptr</span> <span class="kt">double</span><span class="p">,</span> <span class="kt">double</span><span class="p">*</span> <span class="nv">%B</span><span class="p">,</span> <span class="p"><</span><span class="m">8</span> <span class="k">x</span> <span class="k">i32</span><span class="p">></span> <span class="nv">%C</span>
+<span class="c">; load 8 elements from array B into A</span>
+<span class="nv">%A</span> <span class="p">=</span> <span class="k">call</span> <span class="p"><</span><span class="m">8</span> <span class="k">x</span> <span class="kt">double</span><span class="p">></span> <span class="vg">@llvm.masked.gather.v8f64.v8p0f64</span><span class="p">(<</span><span class="m">8</span> <span class="k">x</span> <span class="kt">double</span><span class="p">*></span> <span class="nv">%ptrs</span><span class="p">,</span>
+ <span class="k">i32</span> <span class="m">8</span><span class="p">,</span> <span class="p"><</span><span class="m">8</span> <span class="k">x</span> <span class="k">i1</span><span class="p">></span> <span class="nv">%mask</span><span class="p">,</span> <span class="p"><</span><span class="m">8</span> <span class="k">x</span> <span class="kt">double</span><span class="p">></span> <span class="nv">%passthru</span><span class="p">)</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+<div class="section" id="conversion-operations">
+<h3><a class="toc-backref" href="#id1383">Conversion Operations</a><a class="headerlink" href="#conversion-operations" title="Permalink to this headline">¶</a></h3>
+<p>The instructions in this category are the conversion instructions
+(casting) which all take a single operand and a type. They perform
+various bit conversions on the operand.</p>
+<div class="section" id="trunc-to-instruction">
+<span id="i-trunc"></span><h4><a class="toc-backref" href="#id1384">â<code class="docutils literal notranslate"><span class="pre">trunc</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><a class="headerlink" href="#trunc-to-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id227">
+<h5><a class="toc-backref" href="#id1385">Syntax:</a><a class="headerlink" href="#id227" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">trunc</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="n">to</span> <span class="o"><</span><span class="n">ty2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty2</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id228">
+<h5><a class="toc-backref" href="#id1386">Overview:</a><a class="headerlink" href="#id228" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">trunc</span></code>â instruction truncates its operand to the type <code class="docutils literal notranslate"><span class="pre">ty2</span></code>.</p>
+</div>
+<div class="section" id="id229">
+<h5><a class="toc-backref" href="#id1387">Arguments:</a><a class="headerlink" href="#id229" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">trunc</span></code>â instruction takes a value to trunc, and a type to trunc
+it to. Both types must be of <a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> types, or vectors
+of the same number of integers. The bit size of the <code class="docutils literal notranslate"><span class="pre">value</span></code> must be
+larger than the bit size of the destination type, <code class="docutils literal notranslate"><span class="pre">ty2</span></code>. Equal sized
+types are not allowed.</p>
+</div>
+<div class="section" id="id230">
+<h5><a class="toc-backref" href="#id1388">Semantics:</a><a class="headerlink" href="#id230" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">trunc</span></code>â instruction truncates the high order bits in <code class="docutils literal notranslate"><span class="pre">value</span></code>
+and converts the remaining bits to <code class="docutils literal notranslate"><span class="pre">ty2</span></code>. Since the source size must
+be larger than the destination size, <code class="docutils literal notranslate"><span class="pre">trunc</span></code> cannot be a <em>no-op cast</em>.
+It will always truncate bits.</p>
+</div>
+<div class="section" id="id231">
+<h5><a class="toc-backref" href="#id1389">Example:</a><a class="headerlink" href="#id231" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%X</span> <span class="p">=</span> <span class="k">trunc</span> <span class="k">i32</span> <span class="m">257</span> <span class="k">to</span> <span class="k">i8</span> <span class="c">; yields i8:1</span>
+<span class="nv">%Y</span> <span class="p">=</span> <span class="k">trunc</span> <span class="k">i32</span> <span class="m">123</span> <span class="k">to</span> <span class="k">i1</span> <span class="c">; yields i1:true</span>
+<span class="nv">%Z</span> <span class="p">=</span> <span class="k">trunc</span> <span class="k">i32</span> <span class="m">122</span> <span class="k">to</span> <span class="k">i1</span> <span class="c">; yields i1:false</span>
+<span class="nv">%W</span> <span class="p">=</span> <span class="k">trunc</span> <span class="p"><</span><span class="m">2</span> <span class="k">x</span> <span class="k">i16</span><span class="p">></span> <span class="p"><</span><span class="k">i16</span> <span class="m">8</span><span class="p">,</span> <span class="k">i16</span> <span class="m">7</span><span class="p">></span> <span class="k">to</span> <span class="p"><</span><span class="m">2</span> <span class="k">x</span> <span class="k">i8</span><span class="p">></span> <span class="c">; yields <i8 8, i8 7></span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="zext-to-instruction">
+<span id="i-zext"></span><h4><a class="toc-backref" href="#id1390">â<code class="docutils literal notranslate"><span class="pre">zext</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><a class="headerlink" href="#zext-to-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id232">
+<h5><a class="toc-backref" href="#id1391">Syntax:</a><a class="headerlink" href="#id232" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">zext</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="n">to</span> <span class="o"><</span><span class="n">ty2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty2</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id233">
+<h5><a class="toc-backref" href="#id1392">Overview:</a><a class="headerlink" href="#id233" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">zext</span></code>â instruction zero extends its operand to type <code class="docutils literal notranslate"><span class="pre">ty2</span></code>.</p>
+</div>
+<div class="section" id="id234">
+<h5><a class="toc-backref" href="#id1393">Arguments:</a><a class="headerlink" href="#id234" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">zext</span></code>â instruction takes a value to cast, and a type to cast it
+to. Both types must be of <a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> types, or vectors of
+the same number of integers. The bit size of the <code class="docutils literal notranslate"><span class="pre">value</span></code> must be
+smaller than the bit size of the destination type, <code class="docutils literal notranslate"><span class="pre">ty2</span></code>.</p>
+</div>
+<div class="section" id="id235">
+<h5><a class="toc-backref" href="#id1394">Semantics:</a><a class="headerlink" href="#id235" title="Permalink to this headline">¶</a></h5>
+<p>The <code class="docutils literal notranslate"><span class="pre">zext</span></code> fills the high order bits of the <code class="docutils literal notranslate"><span class="pre">value</span></code> with zero bits
+until it reaches the size of the destination type, <code class="docutils literal notranslate"><span class="pre">ty2</span></code>.</p>
+<p>When zero extending from i1, the result will always be either 0 or 1.</p>
+</div>
+<div class="section" id="id236">
+<h5><a class="toc-backref" href="#id1395">Example:</a><a class="headerlink" href="#id236" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%X</span> <span class="p">=</span> <span class="k">zext</span> <span class="k">i32</span> <span class="m">257</span> <span class="k">to</span> <span class="k">i64</span> <span class="c">; yields i64:257</span>
+<span class="nv">%Y</span> <span class="p">=</span> <span class="k">zext</span> <span class="k">i1</span> <span class="k">true</span> <span class="k">to</span> <span class="k">i32</span> <span class="c">; yields i32:1</span>
+<span class="nv">%Z</span> <span class="p">=</span> <span class="k">zext</span> <span class="p"><</span><span class="m">2</span> <span class="k">x</span> <span class="k">i16</span><span class="p">></span> <span class="p"><</span><span class="k">i16</span> <span class="m">8</span><span class="p">,</span> <span class="k">i16</span> <span class="m">7</span><span class="p">></span> <span class="k">to</span> <span class="p"><</span><span class="m">2</span> <span class="k">x</span> <span class="k">i32</span><span class="p">></span> <span class="c">; yields <i32 8, i32 7></span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="sext-to-instruction">
+<span id="i-sext"></span><h4><a class="toc-backref" href="#id1396">â<code class="docutils literal notranslate"><span class="pre">sext</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><a class="headerlink" href="#sext-to-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id237">
+<h5><a class="toc-backref" href="#id1397">Syntax:</a><a class="headerlink" href="#id237" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">sext</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="n">to</span> <span class="o"><</span><span class="n">ty2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty2</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id238">
+<h5><a class="toc-backref" href="#id1398">Overview:</a><a class="headerlink" href="#id238" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">sext</span></code>â sign extends <code class="docutils literal notranslate"><span class="pre">value</span></code> to the type <code class="docutils literal notranslate"><span class="pre">ty2</span></code>.</p>
+</div>
+<div class="section" id="id239">
+<h5><a class="toc-backref" href="#id1399">Arguments:</a><a class="headerlink" href="#id239" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">sext</span></code>â instruction takes a value to cast, and a type to cast it
+to. Both types must be of <a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> types, or vectors of
+the same number of integers. The bit size of the <code class="docutils literal notranslate"><span class="pre">value</span></code> must be
+smaller than the bit size of the destination type, <code class="docutils literal notranslate"><span class="pre">ty2</span></code>.</p>
+</div>
+<div class="section" id="id240">
+<h5><a class="toc-backref" href="#id1400">Semantics:</a><a class="headerlink" href="#id240" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">sext</span></code>â instruction performs a sign extension by copying the sign
+bit (highest order bit) of the <code class="docutils literal notranslate"><span class="pre">value</span></code> until it reaches the bit size
+of the type <code class="docutils literal notranslate"><span class="pre">ty2</span></code>.</p>
+<p>When sign extending from i1, the extension always results in -1 or 0.</p>
+</div>
+<div class="section" id="id241">
+<h5><a class="toc-backref" href="#id1401">Example:</a><a class="headerlink" href="#id241" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%X</span> <span class="p">=</span> <span class="k">sext</span> <span class="k">i8</span> <span class="m">-1</span> <span class="k">to</span> <span class="k">i16</span> <span class="c">; yields i16 :65535</span>
+<span class="nv">%Y</span> <span class="p">=</span> <span class="k">sext</span> <span class="k">i1</span> <span class="k">true</span> <span class="k">to</span> <span class="k">i32</span> <span class="c">; yields i32:-1</span>
+<span class="nv">%Z</span> <span class="p">=</span> <span class="k">sext</span> <span class="p"><</span><span class="m">2</span> <span class="k">x</span> <span class="k">i16</span><span class="p">></span> <span class="p"><</span><span class="k">i16</span> <span class="m">8</span><span class="p">,</span> <span class="k">i16</span> <span class="m">7</span><span class="p">></span> <span class="k">to</span> <span class="p"><</span><span class="m">2</span> <span class="k">x</span> <span class="k">i32</span><span class="p">></span> <span class="c">; yields <i32 8, i32 7></span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="fptrunc-to-instruction">
+<h4><a class="toc-backref" href="#id1402">â<code class="docutils literal notranslate"><span class="pre">fptrunc</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><a class="headerlink" href="#fptrunc-to-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id242">
+<h5><a class="toc-backref" href="#id1403">Syntax:</a><a class="headerlink" href="#id242" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">fptrunc</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="n">to</span> <span class="o"><</span><span class="n">ty2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty2</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id243">
+<h5><a class="toc-backref" href="#id1404">Overview:</a><a class="headerlink" href="#id243" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fptrunc</span></code>â instruction truncates <code class="docutils literal notranslate"><span class="pre">value</span></code> to type <code class="docutils literal notranslate"><span class="pre">ty2</span></code>.</p>
+</div>
+<div class="section" id="id244">
+<h5><a class="toc-backref" href="#id1405">Arguments:</a><a class="headerlink" href="#id244" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fptrunc</span></code>â instruction takes a <a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a>
+value to cast and a <a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> type to cast it to.
+The size of <code class="docutils literal notranslate"><span class="pre">value</span></code> must be larger than the size of <code class="docutils literal notranslate"><span class="pre">ty2</span></code>. This
+implies that <code class="docutils literal notranslate"><span class="pre">fptrunc</span></code> cannot be used to make a <em>no-op cast</em>.</p>
+</div>
+<div class="section" id="id245">
+<h5><a class="toc-backref" href="#id1406">Semantics:</a><a class="headerlink" href="#id245" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fptrunc</span></code>â instruction casts a <code class="docutils literal notranslate"><span class="pre">value</span></code> from a larger
+<a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> type to a smaller <a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> type.
+This instruction is assumed to execute in the default <a class="reference internal" href="#floatenv"><span class="std std-ref">floating-point
+environment</span></a>.</p>
+</div>
+<div class="section" id="id246">
+<h5><a class="toc-backref" href="#id1407">Example:</a><a class="headerlink" href="#id246" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%X</span> <span class="p">=</span> <span class="k">fptrunc</span> <span class="kt">double</span> <span class="m">16777217.0</span> <span class="k">to</span> <span class="kt">float</span> <span class="c">; yields float:16777216.0</span>
+<span class="nv">%Y</span> <span class="p">=</span> <span class="k">fptrunc</span> <span class="kt">double</span> <span class="m">1.0E+300</span> <span class="k">to</span> <span class="kt">half</span> <span class="c">; yields half:+infinity</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="fpext-to-instruction">
+<h4><a class="toc-backref" href="#id1408">â<code class="docutils literal notranslate"><span class="pre">fpext</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><a class="headerlink" href="#fpext-to-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id247">
+<h5><a class="toc-backref" href="#id1409">Syntax:</a><a class="headerlink" href="#id247" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">fpext</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="n">to</span> <span class="o"><</span><span class="n">ty2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty2</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id248">
+<h5><a class="toc-backref" href="#id1410">Overview:</a><a class="headerlink" href="#id248" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fpext</span></code>â extends a floating-point <code class="docutils literal notranslate"><span class="pre">value</span></code> to a larger floating-point
+value.</p>
+</div>
+<div class="section" id="id249">
+<h5><a class="toc-backref" href="#id1411">Arguments:</a><a class="headerlink" href="#id249" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fpext</span></code>â instruction takes a <a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a>
+<code class="docutils literal notranslate"><span class="pre">value</span></code> to cast, and a <a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> type to cast it
+to. The source type must be smaller than the destination type.</p>
+</div>
+<div class="section" id="id250">
+<h5><a class="toc-backref" href="#id1412">Semantics:</a><a class="headerlink" href="#id250" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fpext</span></code>â instruction extends the <code class="docutils literal notranslate"><span class="pre">value</span></code> from a smaller
+<a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> type to a larger <a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> type. The <code class="docutils literal notranslate"><span class="pre">fpext</span></code> cannot be used to make a
+<em>no-op cast</em> because it always changes bits. Use <code class="docutils literal notranslate"><span class="pre">bitcast</span></code> to make a
+<em>no-op cast</em> for a floating-point cast.</p>
+</div>
+<div class="section" id="id251">
+<h5><a class="toc-backref" href="#id1413">Example:</a><a class="headerlink" href="#id251" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%X</span> <span class="p">=</span> <span class="k">fpext</span> <span class="kt">float</span> <span class="m">3.125</span> <span class="k">to</span> <span class="kt">double</span> <span class="c">; yields double:3.125000e+00</span>
+<span class="nv">%Y</span> <span class="p">=</span> <span class="k">fpext</span> <span class="kt">double</span> <span class="nv">%X</span> <span class="k">to</span> <span class="kt">fp128</span> <span class="c">; yields fp128:0xL00000000000000004000900000000000</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="fptoui-to-instruction">
+<h4><a class="toc-backref" href="#id1414">â<code class="docutils literal notranslate"><span class="pre">fptoui</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><a class="headerlink" href="#fptoui-to-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id252">
+<h5><a class="toc-backref" href="#id1415">Syntax:</a><a class="headerlink" href="#id252" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">fptoui</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="n">to</span> <span class="o"><</span><span class="n">ty2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty2</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id253">
+<h5><a class="toc-backref" href="#id1416">Overview:</a><a class="headerlink" href="#id253" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fptoui</span></code>â converts a floating-point <code class="docutils literal notranslate"><span class="pre">value</span></code> to its unsigned
+integer equivalent of type <code class="docutils literal notranslate"><span class="pre">ty2</span></code>.</p>
+</div>
+<div class="section" id="id254">
+<h5><a class="toc-backref" href="#id1417">Arguments:</a><a class="headerlink" href="#id254" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fptoui</span></code>â instruction takes a value to cast, which must be a
+scalar or vector <a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> value, and a type to
+cast it to <code class="docutils literal notranslate"><span class="pre">ty2</span></code>, which must be an <a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> type. If
+<code class="docutils literal notranslate"><span class="pre">ty</span></code> is a vector floating-point type, <code class="docutils literal notranslate"><span class="pre">ty2</span></code> must be a vector integer
+type with the same number of elements as <code class="docutils literal notranslate"><span class="pre">ty</span></code></p>
+</div>
+<div class="section" id="id255">
+<h5><a class="toc-backref" href="#id1418">Semantics:</a><a class="headerlink" href="#id255" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fptoui</span></code>â instruction converts its <a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> operand into the nearest (rounding towards zero)
+unsigned integer value. If the value cannot fit in <code class="docutils literal notranslate"><span class="pre">ty2</span></code>, the result
+is a <a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a>.</p>
+</div>
+<div class="section" id="id256">
+<h5><a class="toc-backref" href="#id1419">Example:</a><a class="headerlink" href="#id256" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%X</span> <span class="p">=</span> <span class="k">fptoui</span> <span class="kt">double</span> <span class="m">123.0</span> <span class="k">to</span> <span class="k">i32</span> <span class="c">; yields i32:123</span>
+<span class="nv">%Y</span> <span class="p">=</span> <span class="k">fptoui</span> <span class="kt">float</span> <span class="m">1.0E+300</span> <span class="k">to</span> <span class="k">i1</span> <span class="c">; yields undefined:1</span>
+<span class="nv">%Z</span> <span class="p">=</span> <span class="k">fptoui</span> <span class="kt">float</span> <span class="m">1.04E+17</span> <span class="k">to</span> <span class="k">i8</span> <span class="c">; yields undefined:1</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="fptosi-to-instruction">
+<h4><a class="toc-backref" href="#id1420">â<code class="docutils literal notranslate"><span class="pre">fptosi</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><a class="headerlink" href="#fptosi-to-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id257">
+<h5><a class="toc-backref" href="#id1421">Syntax:</a><a class="headerlink" href="#id257" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">fptosi</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="n">to</span> <span class="o"><</span><span class="n">ty2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty2</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id258">
+<h5><a class="toc-backref" href="#id1422">Overview:</a><a class="headerlink" href="#id258" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fptosi</span></code>â instruction converts <a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a>
+<code class="docutils literal notranslate"><span class="pre">value</span></code> to type <code class="docutils literal notranslate"><span class="pre">ty2</span></code>.</p>
+</div>
+<div class="section" id="id259">
+<h5><a class="toc-backref" href="#id1423">Arguments:</a><a class="headerlink" href="#id259" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fptosi</span></code>â instruction takes a value to cast, which must be a
+scalar or vector <a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> value, and a type to
+cast it to <code class="docutils literal notranslate"><span class="pre">ty2</span></code>, which must be an <a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> type. If
+<code class="docutils literal notranslate"><span class="pre">ty</span></code> is a vector floating-point type, <code class="docutils literal notranslate"><span class="pre">ty2</span></code> must be a vector integer
+type with the same number of elements as <code class="docutils literal notranslate"><span class="pre">ty</span></code></p>
+</div>
+<div class="section" id="id260">
+<h5><a class="toc-backref" href="#id1424">Semantics:</a><a class="headerlink" href="#id260" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fptosi</span></code>â instruction converts its <a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> operand into the nearest (rounding towards zero)
+signed integer value. If the value cannot fit in <code class="docutils literal notranslate"><span class="pre">ty2</span></code>, the result
+is a <a class="reference internal" href="#poisonvalues"><span class="std std-ref">poison value</span></a>.</p>
+</div>
+<div class="section" id="id261">
+<h5><a class="toc-backref" href="#id1425">Example:</a><a class="headerlink" href="#id261" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%X</span> <span class="p">=</span> <span class="k">fptosi</span> <span class="kt">double</span> <span class="m">-123.0</span> <span class="k">to</span> <span class="k">i32</span> <span class="c">; yields i32:-123</span>
+<span class="nv">%Y</span> <span class="p">=</span> <span class="k">fptosi</span> <span class="kt">float</span> <span class="m">1.0E-247</span> <span class="k">to</span> <span class="k">i1</span> <span class="c">; yields undefined:1</span>
+<span class="nv">%Z</span> <span class="p">=</span> <span class="k">fptosi</span> <span class="kt">float</span> <span class="m">1.04E+17</span> <span class="k">to</span> <span class="k">i8</span> <span class="c">; yields undefined:1</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="uitofp-to-instruction">
+<h4><a class="toc-backref" href="#id1426">â<code class="docutils literal notranslate"><span class="pre">uitofp</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><a class="headerlink" href="#uitofp-to-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id262">
+<h5><a class="toc-backref" href="#id1427">Syntax:</a><a class="headerlink" href="#id262" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">uitofp</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="n">to</span> <span class="o"><</span><span class="n">ty2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty2</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id263">
+<h5><a class="toc-backref" href="#id1428">Overview:</a><a class="headerlink" href="#id263" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">uitofp</span></code>â instruction regards <code class="docutils literal notranslate"><span class="pre">value</span></code> as an unsigned integer
+and converts that value to the <code class="docutils literal notranslate"><span class="pre">ty2</span></code> type.</p>
+</div>
+<div class="section" id="id264">
+<h5><a class="toc-backref" href="#id1429">Arguments:</a><a class="headerlink" href="#id264" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">uitofp</span></code>â instruction takes a value to cast, which must be a
+scalar or vector <a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> value, and a type to cast it to
+<code class="docutils literal notranslate"><span class="pre">ty2</span></code>, which must be an <a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> type. If
+<code class="docutils literal notranslate"><span class="pre">ty</span></code> is a vector integer type, <code class="docutils literal notranslate"><span class="pre">ty2</span></code> must be a vector floating-point
+type with the same number of elements as <code class="docutils literal notranslate"><span class="pre">ty</span></code></p>
+</div>
+<div class="section" id="id265">
+<h5><a class="toc-backref" href="#id1430">Semantics:</a><a class="headerlink" href="#id265" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">uitofp</span></code>â instruction interprets its operand as an unsigned
+integer quantity and converts it to the corresponding floating-point
+value. If the value cannot be exactly represented, it is rounded using
+the default rounding mode.</p>
+</div>
+<div class="section" id="id266">
+<h5><a class="toc-backref" href="#id1431">Example:</a><a class="headerlink" href="#id266" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%X</span> <span class="p">=</span> <span class="k">uitofp</span> <span class="k">i32</span> <span class="m">257</span> <span class="k">to</span> <span class="kt">float</span> <span class="c">; yields float:257.0</span>
+<span class="nv">%Y</span> <span class="p">=</span> <span class="k">uitofp</span> <span class="k">i8</span> <span class="m">-1</span> <span class="k">to</span> <span class="kt">double</span> <span class="c">; yields double:255.0</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="sitofp-to-instruction">
+<h4><a class="toc-backref" href="#id1432">â<code class="docutils literal notranslate"><span class="pre">sitofp</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><a class="headerlink" href="#sitofp-to-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id267">
+<h5><a class="toc-backref" href="#id1433">Syntax:</a><a class="headerlink" href="#id267" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">sitofp</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="n">to</span> <span class="o"><</span><span class="n">ty2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty2</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id268">
+<h5><a class="toc-backref" href="#id1434">Overview:</a><a class="headerlink" href="#id268" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">sitofp</span></code>â instruction regards <code class="docutils literal notranslate"><span class="pre">value</span></code> as a signed integer and
+converts that value to the <code class="docutils literal notranslate"><span class="pre">ty2</span></code> type.</p>
+</div>
+<div class="section" id="id269">
+<h5><a class="toc-backref" href="#id1435">Arguments:</a><a class="headerlink" href="#id269" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">sitofp</span></code>â instruction takes a value to cast, which must be a
+scalar or vector <a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> value, and a type to cast it to
+<code class="docutils literal notranslate"><span class="pre">ty2</span></code>, which must be an <a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> type. If
+<code class="docutils literal notranslate"><span class="pre">ty</span></code> is a vector integer type, <code class="docutils literal notranslate"><span class="pre">ty2</span></code> must be a vector floating-point
+type with the same number of elements as <code class="docutils literal notranslate"><span class="pre">ty</span></code></p>
+</div>
+<div class="section" id="id270">
+<h5><a class="toc-backref" href="#id1436">Semantics:</a><a class="headerlink" href="#id270" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">sitofp</span></code>â instruction interprets its operand as a signed integer
+quantity and converts it to the corresponding floating-point value. If the
+value cannot be exactly represented, it is rounded using the default rounding
+mode.</p>
+</div>
+<div class="section" id="id271">
+<h5><a class="toc-backref" href="#id1437">Example:</a><a class="headerlink" href="#id271" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%X</span> <span class="p">=</span> <span class="k">sitofp</span> <span class="k">i32</span> <span class="m">257</span> <span class="k">to</span> <span class="kt">float</span> <span class="c">; yields float:257.0</span>
+<span class="nv">%Y</span> <span class="p">=</span> <span class="k">sitofp</span> <span class="k">i8</span> <span class="m">-1</span> <span class="k">to</span> <span class="kt">double</span> <span class="c">; yields double:-1.0</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="ptrtoint-to-instruction">
+<span id="i-ptrtoint"></span><h4><a class="toc-backref" href="#id1438">â<code class="docutils literal notranslate"><span class="pre">ptrtoint</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><a class="headerlink" href="#ptrtoint-to-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id272">
+<h5><a class="toc-backref" href="#id1439">Syntax:</a><a class="headerlink" href="#id272" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">ptrtoint</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="n">to</span> <span class="o"><</span><span class="n">ty2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty2</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id273">
+<h5><a class="toc-backref" href="#id1440">Overview:</a><a class="headerlink" href="#id273" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">ptrtoint</span></code>â instruction converts the pointer or a vector of
+pointers <code class="docutils literal notranslate"><span class="pre">value</span></code> to the integer (or vector of integers) type <code class="docutils literal notranslate"><span class="pre">ty2</span></code>.</p>
+</div>
+<div class="section" id="id274">
+<h5><a class="toc-backref" href="#id1441">Arguments:</a><a class="headerlink" href="#id274" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">ptrtoint</span></code>â instruction takes a <code class="docutils literal notranslate"><span class="pre">value</span></code> to cast, which must be
+a value of type <a class="reference internal" href="#t-pointer"><span class="std std-ref">pointer</span></a> or a vector of pointers, and a
+type to cast it to <code class="docutils literal notranslate"><span class="pre">ty2</span></code>, which must be an <a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or
+a vector of integers type.</p>
+</div>
+<div class="section" id="id275">
+<h5><a class="toc-backref" href="#id1442">Semantics:</a><a class="headerlink" href="#id275" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">ptrtoint</span></code>â instruction converts <code class="docutils literal notranslate"><span class="pre">value</span></code> to integer type
+<code class="docutils literal notranslate"><span class="pre">ty2</span></code> by interpreting the pointer value as an integer and either
+truncating or zero extending that value to the size of the integer type.
+If <code class="docutils literal notranslate"><span class="pre">value</span></code> is smaller than <code class="docutils literal notranslate"><span class="pre">ty2</span></code> then a zero extension is done. If
+<code class="docutils literal notranslate"><span class="pre">value</span></code> is larger than <code class="docutils literal notranslate"><span class="pre">ty2</span></code> then a truncation is done. If they are
+the same size, then nothing is done (<em>no-op cast</em>) other than a type
+change.</p>
+</div>
+<div class="section" id="id276">
+<h5><a class="toc-backref" href="#id1443">Example:</a><a class="headerlink" href="#id276" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%X</span> <span class="p">=</span> <span class="k">ptrtoint</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%P</span> <span class="k">to</span> <span class="k">i8</span> <span class="c">; yields truncation on 32-bit architecture</span>
+<span class="nv">%Y</span> <span class="p">=</span> <span class="k">ptrtoint</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%P</span> <span class="k">to</span> <span class="k">i64</span> <span class="c">; yields zero extension on 32-bit architecture</span>
+<span class="nv">%Z</span> <span class="p">=</span> <span class="k">ptrtoint</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i32</span><span class="p">*></span> <span class="nv">%P</span> <span class="k">to</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i64</span><span class="p">></span><span class="c">; yields vector zero extension for a vector of addresses on 32-bit architecture</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="inttoptr-to-instruction">
+<span id="i-inttoptr"></span><h4><a class="toc-backref" href="#id1444">â<code class="docutils literal notranslate"><span class="pre">inttoptr</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><a class="headerlink" href="#inttoptr-to-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id277">
+<h5><a class="toc-backref" href="#id1445">Syntax:</a><a class="headerlink" href="#id277" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">inttoptr</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="n">to</span> <span class="o"><</span><span class="n">ty2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty2</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id278">
+<h5><a class="toc-backref" href="#id1446">Overview:</a><a class="headerlink" href="#id278" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">inttoptr</span></code>â instruction converts an integer <code class="docutils literal notranslate"><span class="pre">value</span></code> to a
+pointer type, <code class="docutils literal notranslate"><span class="pre">ty2</span></code>.</p>
+</div>
+<div class="section" id="id279">
+<h5><a class="toc-backref" href="#id1447">Arguments:</a><a class="headerlink" href="#id279" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">inttoptr</span></code>â instruction takes an <a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> value to
+cast, and a type to cast it to, which must be a <a class="reference internal" href="#t-pointer"><span class="std std-ref">pointer</span></a>
+type.</p>
+</div>
+<div class="section" id="id280">
+<h5><a class="toc-backref" href="#id1448">Semantics:</a><a class="headerlink" href="#id280" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">inttoptr</span></code>â instruction converts <code class="docutils literal notranslate"><span class="pre">value</span></code> to type <code class="docutils literal notranslate"><span class="pre">ty2</span></code> by
+applying either a zero extension or a truncation depending on the size
+of the integer <code class="docutils literal notranslate"><span class="pre">value</span></code>. If <code class="docutils literal notranslate"><span class="pre">value</span></code> is larger than the size of a
+pointer then a truncation is done. If <code class="docutils literal notranslate"><span class="pre">value</span></code> is smaller than the size
+of a pointer then a zero extension is done. If they are the same size,
+nothing is done (<em>no-op cast</em>).</p>
+</div>
+<div class="section" id="id281">
+<h5><a class="toc-backref" href="#id1449">Example:</a><a class="headerlink" href="#id281" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%X</span> <span class="p">=</span> <span class="k">inttoptr</span> <span class="k">i32</span> <span class="m">255</span> <span class="k">to</span> <span class="k">i32</span><span class="p">*</span> <span class="c">; yields zero extension on 64-bit architecture</span>
+<span class="nv">%Y</span> <span class="p">=</span> <span class="k">inttoptr</span> <span class="k">i32</span> <span class="m">255</span> <span class="k">to</span> <span class="k">i32</span><span class="p">*</span> <span class="c">; yields no-op on 32-bit architecture</span>
+<span class="nv">%Z</span> <span class="p">=</span> <span class="k">inttoptr</span> <span class="k">i64</span> <span class="m">0</span> <span class="k">to</span> <span class="k">i32</span><span class="p">*</span> <span class="c">; yields truncation on 32-bit architecture</span>
+<span class="nv">%Z</span> <span class="p">=</span> <span class="k">inttoptr</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i32</span><span class="p">></span> <span class="nv">%G</span> <span class="k">to</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i8</span><span class="p">*></span><span class="c">; yields truncation of vector G to four pointers</span>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="bitcast-to-instruction">
+<span id="i-bitcast"></span><h4><a class="toc-backref" href="#id1450">â<code class="docutils literal notranslate"><span class="pre">bitcast</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><a class="headerlink" href="#bitcast-to-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id282">
+<h5><a class="toc-backref" href="#id1451">Syntax:</a><a class="headerlink" href="#id282" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">bitcast</span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">value</span><span class="o">></span> <span class="n">to</span> <span class="o"><</span><span class="n">ty2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">ty2</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id283">
+<h5><a class="toc-backref" href="#id1452">Overview:</a><a class="headerlink" href="#id283" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">bitcast</span></code>â instruction converts <code class="docutils literal notranslate"><span class="pre">value</span></code> to type <code class="docutils literal notranslate"><span class="pre">ty2</span></code> without
+changing any bits.</p>
+</div>
+<div class="section" id="id284">
+<h5><a class="toc-backref" href="#id1453">Arguments:</a><a class="headerlink" href="#id284" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">bitcast</span></code>â instruction takes a value to cast, which must be a
+non-aggregate first class value, and a type to cast it to, which must
+also be a non-aggregate <a class="reference internal" href="#t-firstclass"><span class="std std-ref">first class</span></a> type. The
+bit sizes of <code class="docutils literal notranslate"><span class="pre">value</span></code> and the destination type, <code class="docutils literal notranslate"><span class="pre">ty2</span></code>, must be
+identical. If the source type is a pointer, the destination type must
+also be a pointer of the same size. This instruction supports bitwise
+conversion of vectors to integers and to vectors of other types (as
+long as they have the same size).</p>
+</div>
+<div class="section" id="id285">
+<h5><a class="toc-backref" href="#id1454">Semantics:</a><a class="headerlink" href="#id285" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">bitcast</span></code>â instruction converts <code class="docutils literal notranslate"><span class="pre">value</span></code> to type <code class="docutils literal notranslate"><span class="pre">ty2</span></code>. It
+is always a <em>no-op cast</em> because no bits change with this
+conversion. The conversion is done as if the <code class="docutils literal notranslate"><span class="pre">value</span></code> had been stored
+to memory and read back as type <code class="docutils literal notranslate"><span class="pre">ty2</span></code>. Pointer (or vector of
+pointers) types may only be converted to other pointer (or vector of
+pointers) types with the same address space through this instruction.
+To convert pointers to other types, use the <a class="reference internal" href="#i-inttoptr"><span class="std std-ref">inttoptr</span></a>
+or <a class="reference internal" href="#i-ptrtoint"><span class="std std-ref">ptrtoint</span></a> instructions first.</p>
+</div>
+<div class="section" id="id286">
+<h5><a class="toc-backref" href="#id1455">Example:</a><a class="headerlink" href="#id286" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span>%X = bitcast i8 255 to i8 ; yields i8 :-1
+%Y = bitcast i32* %x to sint* ; yields sint*:%x
+%Z = bitcast <2 x int> %V to i64; ; yields i64: %V
+%Z = bitcast <2 x i32*> %V to <2 x i64*> ; yields <2 x i64*>
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="addrspacecast-to-instruction">
+<span id="i-addrspacecast"></span><h4><a class="toc-backref" href="#id1456">â<code class="docutils literal notranslate"><span class="pre">addrspacecast</span> <span class="pre">..</span> <span class="pre">to</span></code>â Instruction</a><a class="headerlink" href="#addrspacecast-to-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id287">
+<h5><a class="toc-backref" href="#id1457">Syntax:</a><a class="headerlink" href="#id287" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">addrspacecast</span> <span class="o"><</span><span class="n">pty</span><span class="o">></span> <span class="o"><</span><span class="n">ptrval</span><span class="o">></span> <span class="n">to</span> <span class="o"><</span><span class="n">pty2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">pty2</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id288">
+<h5><a class="toc-backref" href="#id1458">Overview:</a><a class="headerlink" href="#id288" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">addrspacecast</span></code>â instruction converts <code class="docutils literal notranslate"><span class="pre">ptrval</span></code> from <code class="docutils literal notranslate"><span class="pre">pty</span></code> in
+address space <code class="docutils literal notranslate"><span class="pre">n</span></code> to type <code class="docutils literal notranslate"><span class="pre">pty2</span></code> in address space <code class="docutils literal notranslate"><span class="pre">m</span></code>.</p>
+</div>
+<div class="section" id="id289">
+<h5><a class="toc-backref" href="#id1459">Arguments:</a><a class="headerlink" href="#id289" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">addrspacecast</span></code>â instruction takes a pointer or vector of pointer value
+to cast and a pointer type to cast it to, which must have a different
+address space.</p>
+</div>
+<div class="section" id="id290">
+<h5><a class="toc-backref" href="#id1460">Semantics:</a><a class="headerlink" href="#id290" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">addrspacecast</span></code>â instruction converts the pointer value
+<code class="docutils literal notranslate"><span class="pre">ptrval</span></code> to type <code class="docutils literal notranslate"><span class="pre">pty2</span></code>. It can be a <em>no-op cast</em> or a complex
+value modification, depending on the target and the address space
+pair. Pointer conversions within the same address space must be
+performed with the <code class="docutils literal notranslate"><span class="pre">bitcast</span></code> instruction. Note that if the address space
+conversion is legal then both result and operand refer to the same memory
+location.</p>
+</div>
+<div class="section" id="id291">
+<h5><a class="toc-backref" href="#id1461">Example:</a><a class="headerlink" href="#id291" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-llvm notranslate"><div class="highlight"><pre><span></span><span class="nv">%X</span> <span class="p">=</span> <span class="k">addrspacecast</span> <span class="k">i32</span><span class="p">*</span> <span class="nv">%x</span> <span class="k">to</span> <span class="k">i32</span> <span class="k">addrspace</span><span class="p">(</span><span class="m">1</span><span class="p">)*</span> <span class="c">; yields i32 addrspace(1)*:%x</span>
+<span class="nv">%Y</span> <span class="p">=</span> <span class="k">addrspacecast</span> <span class="k">i32</span> <span class="k">addrspace</span><span class="p">(</span><span class="m">1</span><span class="p">)*</span> <span class="nv">%y</span> <span class="k">to</span> <span class="k">i64</span> <span class="k">addrspace</span><span class="p">(</span><span class="m">2</span><span class="p">)*</span> <span class="c">; yields i64 addrspace(2)*:%y</span>
+<span class="nv">%Z</span> <span class="p">=</span> <span class="k">addrspacecast</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="k">i32</span><span class="p">*></span> <span class="nv">%z</span> <span class="k">to</span> <span class="p"><</span><span class="m">4</span> <span class="k">x</span> <span class="kt">float</span> <span class="k">addrspace</span><span class="p">(</span><span class="m">3</span><span class="p">)*></span> <span class="c">; yields <4 x float addrspace(3)*>:%z</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+<div class="section" id="other-operations">
+<span id="otherops"></span><h3><a class="toc-backref" href="#id1462">Other Operations</a><a class="headerlink" href="#other-operations" title="Permalink to this headline">¶</a></h3>
+<p>The instructions in this category are the âmiscellaneousâ instructions,
+which defy better classification.</p>
+<div class="section" id="icmp-instruction">
+<span id="i-icmp"></span><h4><a class="toc-backref" href="#id1463">â<code class="docutils literal notranslate"><span class="pre">icmp</span></code>â Instruction</a><a class="headerlink" href="#icmp-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id292">
+<h5><a class="toc-backref" href="#id1464">Syntax:</a><a class="headerlink" href="#id292" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">icmp</span> <span class="o"><</span><span class="n">cond</span><span class="o">></span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">i1</span> <span class="ow">or</span> <span class="o"><</span><span class="n">N</span> <span class="n">x</span> <span class="n">i1</span><span class="o">></span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id293">
+<h5><a class="toc-backref" href="#id1465">Overview:</a><a class="headerlink" href="#id293" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">icmp</span></code>â instruction returns a boolean value or a vector of
+boolean values based on comparison of its two integer, integer vector,
+pointer, or pointer vector operands.</p>
+</div>
+<div class="section" id="id294">
+<h5><a class="toc-backref" href="#id1466">Arguments:</a><a class="headerlink" href="#id294" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">icmp</span></code>â instruction takes three operands. The first operand is
+the condition code indicating the kind of comparison to perform. It is
+not a value, just a keyword. The possible condition codes are:</p>
+<ol class="arabic simple">
+<li><code class="docutils literal notranslate"><span class="pre">eq</span></code>: equal</li>
+<li><code class="docutils literal notranslate"><span class="pre">ne</span></code>: not equal</li>
+<li><code class="docutils literal notranslate"><span class="pre">ugt</span></code>: unsigned greater than</li>
+<li><code class="docutils literal notranslate"><span class="pre">uge</span></code>: unsigned greater or equal</li>
+<li><code class="docutils literal notranslate"><span class="pre">ult</span></code>: unsigned less than</li>
+<li><code class="docutils literal notranslate"><span class="pre">ule</span></code>: unsigned less or equal</li>
+<li><code class="docutils literal notranslate"><span class="pre">sgt</span></code>: signed greater than</li>
+<li><code class="docutils literal notranslate"><span class="pre">sge</span></code>: signed greater or equal</li>
+<li><code class="docutils literal notranslate"><span class="pre">slt</span></code>: signed less than</li>
+<li><code class="docutils literal notranslate"><span class="pre">sle</span></code>: signed less or equal</li>
+</ol>
+<p>The remaining two arguments must be <a class="reference internal" href="#t-integer"><span class="std std-ref">integer</span></a> or
+<a class="reference internal" href="#t-pointer"><span class="std std-ref">pointer</span></a> or integer <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> typed. They
+must also be identical types.</p>
+</div>
+<div class="section" id="id295">
+<h5><a class="toc-backref" href="#id1467">Semantics:</a><a class="headerlink" href="#id295" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">icmp</span></code>â compares <code class="docutils literal notranslate"><span class="pre">op1</span></code> and <code class="docutils literal notranslate"><span class="pre">op2</span></code> according to the condition
+code given as <code class="docutils literal notranslate"><span class="pre">cond</span></code>. The comparison performed always yields either an
+<a class="reference internal" href="#t-integer"><span class="std std-ref">i1</span></a> or vector of <code class="docutils literal notranslate"><span class="pre">i1</span></code> result, as follows:</p>
+<ol class="arabic simple">
+<li><code class="docutils literal notranslate"><span class="pre">eq</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if the operands are equal, <code class="docutils literal notranslate"><span class="pre">false</span></code>
+otherwise. No sign interpretation is necessary or performed.</li>
+<li><code class="docutils literal notranslate"><span class="pre">ne</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if the operands are unequal, <code class="docutils literal notranslate"><span class="pre">false</span></code>
+otherwise. No sign interpretation is necessary or performed.</li>
+<li><code class="docutils literal notranslate"><span class="pre">ugt</span></code>: interprets the operands as unsigned values and yields
+<code class="docutils literal notranslate"><span class="pre">true</span></code> if <code class="docutils literal notranslate"><span class="pre">op1</span></code> is greater than <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">uge</span></code>: interprets the operands as unsigned values and yields
+<code class="docutils literal notranslate"><span class="pre">true</span></code> if <code class="docutils literal notranslate"><span class="pre">op1</span></code> is greater than or equal to <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">ult</span></code>: interprets the operands as unsigned values and yields
+<code class="docutils literal notranslate"><span class="pre">true</span></code> if <code class="docutils literal notranslate"><span class="pre">op1</span></code> is less than <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">ule</span></code>: interprets the operands as unsigned values and yields
+<code class="docutils literal notranslate"><span class="pre">true</span></code> if <code class="docutils literal notranslate"><span class="pre">op1</span></code> is less than or equal to <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">sgt</span></code>: interprets the operands as signed values and yields <code class="docutils literal notranslate"><span class="pre">true</span></code>
+if <code class="docutils literal notranslate"><span class="pre">op1</span></code> is greater than <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">sge</span></code>: interprets the operands as signed values and yields <code class="docutils literal notranslate"><span class="pre">true</span></code>
+if <code class="docutils literal notranslate"><span class="pre">op1</span></code> is greater than or equal to <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">slt</span></code>: interprets the operands as signed values and yields <code class="docutils literal notranslate"><span class="pre">true</span></code>
+if <code class="docutils literal notranslate"><span class="pre">op1</span></code> is less than <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">sle</span></code>: interprets the operands as signed values and yields <code class="docutils literal notranslate"><span class="pre">true</span></code>
+if <code class="docutils literal notranslate"><span class="pre">op1</span></code> is less than or equal to <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+</ol>
+<p>If the operands are <a class="reference internal" href="#t-pointer"><span class="std std-ref">pointer</span></a> typed, the pointer values
+are compared as if they were integers.</p>
+<p>If the operands are integer vectors, then they are compared element by
+element. The result is an <code class="docutils literal notranslate"><span class="pre">i1</span></code> vector with the same number of elements
+as the values being compared. Otherwise, the result is an <code class="docutils literal notranslate"><span class="pre">i1</span></code>.</p>
+</div>
+<div class="section" id="id296">
+<h5><a class="toc-backref" href="#id1468">Example:</a><a class="headerlink" href="#id296" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = icmp eq i32 4, 5 ; yields: result=false
+<result> = icmp ne float* %X, %X ; yields: result=false
+<result> = icmp ult i16 4, 5 ; yields: result=true
+<result> = icmp sgt i16 4, 5 ; yields: result=false
+<result> = icmp ule i16 -4, 5 ; yields: result=false
+<result> = icmp sge i16 4, 5 ; yields: result=false
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="fcmp-instruction">
+<span id="i-fcmp"></span><h4><a class="toc-backref" href="#id1469">â<code class="docutils literal notranslate"><span class="pre">fcmp</span></code>â Instruction</a><a class="headerlink" href="#fcmp-instruction" title="Permalink to this headline">¶</a></h4>
+<div class="section" id="id297">
+<h5><a class="toc-backref" href="#id1470">Syntax:</a><a class="headerlink" href="#id297" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o"><</span><span class="n">result</span><span class="o">></span> <span class="o">=</span> <span class="n">fcmp</span> <span class="p">[</span><span class="n">fast</span><span class="o">-</span><span class="n">math</span> <span class="n">flags</span><span class="p">]</span><span class="o">*</span> <span class="o"><</span><span class="n">cond</span><span class="o">></span> <span class="o"><</span><span class="n">ty</span><span class="o">></span> <span class="o"><</span><span class="n">op1</span><span class="o">></span><span class="p">,</span> <span class="o"><</span><span class="n">op2</span><span class="o">></span> <span class="p">;</span> <span class="n">yields</span> <span class="n">i1</span> <span class="ow">or</span> <span class="o"><</span><span class="n">N</span> <span class="n">x</span> <span class="n">i1</span><span class="o">></span><span class="p">:</span><span class="n">result</span>
+</pre></div>
+</div>
+</div>
+<div class="section" id="id298">
+<h5><a class="toc-backref" href="#id1471">Overview:</a><a class="headerlink" href="#id298" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fcmp</span></code>â instruction returns a boolean value or vector of boolean
+values based on comparison of its operands.</p>
+<p>If the operands are floating-point scalars, then the result type is a
+boolean (<a class="reference internal" href="#t-integer"><span class="std std-ref">i1</span></a>).</p>
+<p>If the operands are floating-point vectors, then the result type is a
+vector of boolean with the same number of elements as the operands being
+compared.</p>
+</div>
+<div class="section" id="id299">
+<h5><a class="toc-backref" href="#id1472">Arguments:</a><a class="headerlink" href="#id299" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fcmp</span></code>â instruction takes three operands. The first operand is
+the condition code indicating the kind of comparison to perform. It is
+not a value, just a keyword. The possible condition codes are:</p>
+<ol class="arabic simple">
+<li><code class="docutils literal notranslate"><span class="pre">false</span></code>: no comparison, always returns false</li>
+<li><code class="docutils literal notranslate"><span class="pre">oeq</span></code>: ordered and equal</li>
+<li><code class="docutils literal notranslate"><span class="pre">ogt</span></code>: ordered and greater than</li>
+<li><code class="docutils literal notranslate"><span class="pre">oge</span></code>: ordered and greater than or equal</li>
+<li><code class="docutils literal notranslate"><span class="pre">olt</span></code>: ordered and less than</li>
+<li><code class="docutils literal notranslate"><span class="pre">ole</span></code>: ordered and less than or equal</li>
+<li><code class="docutils literal notranslate"><span class="pre">one</span></code>: ordered and not equal</li>
+<li><code class="docutils literal notranslate"><span class="pre">ord</span></code>: ordered (no nans)</li>
+<li><code class="docutils literal notranslate"><span class="pre">ueq</span></code>: unordered or equal</li>
+<li><code class="docutils literal notranslate"><span class="pre">ugt</span></code>: unordered or greater than</li>
+<li><code class="docutils literal notranslate"><span class="pre">uge</span></code>: unordered or greater than or equal</li>
+<li><code class="docutils literal notranslate"><span class="pre">ult</span></code>: unordered or less than</li>
+<li><code class="docutils literal notranslate"><span class="pre">ule</span></code>: unordered or less than or equal</li>
+<li><code class="docutils literal notranslate"><span class="pre">une</span></code>: unordered or not equal</li>
+<li><code class="docutils literal notranslate"><span class="pre">uno</span></code>: unordered (either nans)</li>
+<li><code class="docutils literal notranslate"><span class="pre">true</span></code>: no comparison, always returns true</li>
+</ol>
+<p><em>Ordered</em> means that neither operand is a QNAN while <em>unordered</em> means
+that either operand may be a QNAN.</p>
+<p>Each of <code class="docutils literal notranslate"><span class="pre">val1</span></code> and <code class="docutils literal notranslate"><span class="pre">val2</span></code> arguments must be either a <a class="reference internal" href="#t-floating"><span class="std std-ref">floating-point</span></a> type or a <a class="reference internal" href="#t-vector"><span class="std std-ref">vector</span></a> of floating-point type.
+They must have identical types.</p>
+</div>
+<div class="section" id="id300">
+<h5><a class="toc-backref" href="#id1473">Semantics:</a><a class="headerlink" href="#id300" title="Permalink to this headline">¶</a></h5>
+<p>The â<code class="docutils literal notranslate"><span class="pre">fcmp</span></code>â instruction compares <code class="docutils literal notranslate"><span class="pre">op1</span></code> and <code class="docutils literal notranslate"><span class="pre">op2</span></code> according to the
+condition code given as <code class="docutils literal notranslate"><span class="pre">cond</span></code>. If the operands are vectors, then the
+vectors are compared element by element. Each comparison performed
+always yields an <a class="reference internal" href="#t-integer"><span class="std std-ref">i1</span></a> result, as follows:</p>
+<ol class="arabic simple">
+<li><code class="docutils literal notranslate"><span class="pre">false</span></code>: always yields <code class="docutils literal notranslate"><span class="pre">false</span></code>, regardless of operands.</li>
+<li><code class="docutils literal notranslate"><span class="pre">oeq</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if both operands are not a QNAN and <code class="docutils literal notranslate"><span class="pre">op1</span></code>
+is equal to <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">ogt</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if both operands are not a QNAN and <code class="docutils literal notranslate"><span class="pre">op1</span></code>
+is greater than <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">oge</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if both operands are not a QNAN and <code class="docutils literal notranslate"><span class="pre">op1</span></code>
+is greater than or equal to <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">olt</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if both operands are not a QNAN and <code class="docutils literal notranslate"><span class="pre">op1</span></code>
+is less than <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">ole</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if both operands are not a QNAN and <code class="docutils literal notranslate"><span class="pre">op1</span></code>
+is less than or equal to <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">one</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if both operands are not a QNAN and <code class="docutils literal notranslate"><span class="pre">op1</span></code>
+is not equal to <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">ord</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if both operands are not a QNAN.</li>
+<li><code class="docutils literal notranslate"><span class="pre">ueq</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if either operand is a QNAN or <code class="docutils literal notranslate"><span class="pre">op1</span></code> is
+equal to <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">ugt</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if either operand is a QNAN or <code class="docutils literal notranslate"><span class="pre">op1</span></code> is
+greater than <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">uge</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if either operand is a QNAN or <code class="docutils literal notranslate"><span class="pre">op1</span></code> is
+greater than or equal to <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">ult</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if either operand is a QNAN or <code class="docutils literal notranslate"><span class="pre">op1</span></code> is
+less than <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">ule</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if either operand is a QNAN or <code class="docutils literal notranslate"><span class="pre">op1</span></code> is
+less than or equal to <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">une</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if either operand is a QNAN or <code class="docutils literal notranslate"><span class="pre">op1</span></code> is
+not equal to <code class="docutils literal notranslate"><span class="pre">op2</span></code>.</li>
+<li><code class="docutils literal notranslate"><span class="pre">uno</span></code>: yields <code class="docutils literal notranslate"><span class="pre">true</span></code> if either operand is a QNAN.</li>
+<li><code class="docutils literal notranslate"><span class="pre">true</span></code>: always yields <code class="docutils literal notranslate"><span class="pre">true</span></code>, regardless of operands.</li>
+</ol>
+<p>The <code class="docutils literal notranslate"><span class="pre">fcmp</span></code> instruction can also optionally take any number of
+<a class="reference internal" href="#fastmath"><span class="std std-ref">fast-math flags</span></a>, which are optimization hints to enable
+otherwise unsafe floating-point optimizations.</p>
+<p>Any set of fast-math flags are legal on an <code class="docutils literal notranslate"><span class="pre">fcmp</span></code> instruction, but the
+only flags that have any effect on its semantics are those that allow
+assumptions to be made about the values of input arguments; namely
+<code class="docutils literal notranslate"><span class="pre">nnan</span></code>, <code class="docutils literal notranslate"><span class="pre">ninf</span></code>, and <code class="docutils literal notranslate"><span class="pre">reassoc</span></code>. See <a class="reference internal" href="#fastmath"><span class="std std-ref">Fast-Math Flags</span></a> for more information.</p>
+</div>
+<div class="section" id="id301">
+<h5><a class="toc-backref" href="#id1474">Example:</a><a class="headerlink" href="#id301" title="Permalink to this headline">¶</a></h5>
+<div class="highlight-text notranslate"><div class="highlight"><pre><span></span><result> = fcmp oeq float 4.0, 5.0 ; yields: result=false
+<result> = fcmp one float 4.0, 5.0 ; yields: result=true
+<result> = fcmp olt float 4.0, 5.0 ; yields: result=true
+<result> = fcmp ueq double 1.0, 2.0 ; yields: result=false
+</pre></div>
+</div>
+</div>
+</div>
+<div class="section" id="phi-instruction">
[... 5943 lines stripped ...]
More information about the llvm-commits
mailing list