<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
p.msonormal0, li.msonormal0, div.msonormal0
        {mso-style-name:msonormal;
        mso-margin-top-alt:auto;
        margin-right:0in;
        mso-margin-bottom-alt:auto;
        margin-left:0in;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
span.EmailStyle18
        {mso-style-type:personal-reply;
        font-family:"Calibri",sans-serif;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style>
</head>
<body lang="EN-US" link="blue" vlink="purple">
<div class="WordSection1">
<p class="MsoNormal">See the revert instructions in <a href="http://llvm.org/docs/GettingStarted.html#for-developers-to-work-with-git-svn">
http://llvm.org/docs/GettingStarted.html#for-developers-to-work-with-git-svn</a> for how to get an SVN revision number instead of a git commit hash in your revert messages, and it's also helpful to include an explanation of why you're reverting (e.g. buildbots
 broke).<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal" style="margin-left:.5in"><b><span style="font-size:12.0pt;color:black">From:
</span></b><span style="font-size:12.0pt;color:black">llvm-commits <llvm-commits-bounces@lists.llvm.org> on behalf of Mandeep Singh Grang via llvm-commits <llvm-commits@lists.llvm.org><br>
<b>Reply-To: </b>Mandeep Singh Grang <mgrang@codeaurora.org><br>
<b>Date: </b>Thursday, November 1, 2018 at 10:56 AM<br>
<b>To: </b>"llvm-commits@lists.llvm.org" <llvm-commits@lists.llvm.org><br>
<b>Subject: </b>[llvm] r345863 - Revert "[COFF, ARM64] Implement Intrinsic.sponentry for AArch64"<o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Author: mgrang<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Date: Thu Nov  1 10:53:57 2018<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">New Revision: 345863<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject-3Frev-3D345863-26view-3Drev&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=IumkpJMoTpQLCve3oLoiix4u11sk6H14Yzo6dxWEis8&e=">
https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject-3Frev-3D345863-26view-3Drev&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=IumkpJMoTpQLCve3oLoiix4u11sk6H14Yzo6dxWEis8&e=</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Log:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Revert "[COFF, ARM64] Implement Intrinsic.sponentry for AArch64"<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">This reverts commit 585b6667b4712e3c7f32401e929855b3313b4ff2.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Removed:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">    llvm/trunk/test/CodeGen/AArch64/sponentry.ll<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Modified:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">    llvm/trunk/docs/LangRef.rst<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">    llvm/trunk/include/llvm/CodeGen/ISDOpcodes.h<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">    llvm/trunk/include/llvm/IR/Intrinsics.td<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">    llvm/trunk/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">    llvm/trunk/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">    llvm/trunk/lib/CodeGen/SelectionDAG/SelectionDAGDumper.cpp<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">    llvm/trunk/lib/Target/AArch64/AArch64FastISel.cpp<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">    llvm/trunk/lib/Target/AArch64/AArch64ISelLowering.cpp<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">    llvm/trunk/lib/Target/AArch64/AArch64ISelLowering.h<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Modified: llvm/trunk/docs/LangRef.rst<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_docs_LangRef.rst-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=_ejsa2bF-q_7SxayDMqBJkwKAcNCH4x-OD30SLRpKvA&e=">
https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_docs_LangRef.rst-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=_ejsa2bF-q_7SxayDMqBJkwKAcNCH4x-OD30SLRpKvA&e=</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">==============================================================================<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">--- llvm/trunk/docs/LangRef.rst (original)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+++ llvm/trunk/docs/LangRef.rst Thu Nov  1 10:53:57 2018<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -2926,7 +2926,7 @@ Simple Constants<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     hexadecimal notation (see below). The assembler requires the exact<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     decimal value of a floating-point constant. For example, the<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     assembler accepts 1.25 but rejects 1.3 because 1.3 is a repeating<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-    decimal in binary. Floating-point constants must have a<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+    decimal in binary. Floating-point constants must have a
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     :ref:`floating-point <t_floating>` type.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">**Null pointer constants**<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     The identifier '``null``' is recognized as a null pointer constant<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -3331,7 +3331,7 @@ The following is the syntax for constant<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     value won't fit in the integer type, the result is a<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     :ref:`poison value <poisonvalues>`.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">``uitofp (CST to TYPE)``<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-    Convert an unsigned integer constant to the corresponding<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+    Convert an unsigned integer constant to the corresponding
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     floating-point constant. TYPE must be a scalar or vector floating-point<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     type.  CST must be of scalar or vector integer type. Both CST and TYPE must<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     be scalars, or vectors of the same number of elements.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -5434,7 +5434,7 @@ Irreducible loop header weights are typi<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">'``invariant.group``' Metadata<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-The experimental ``invariant.group`` metadata may be attached to<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+The experimental ``invariant.group`` metadata may be attached to
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">``load``/``store`` instructions referencing a single metadata with no entries.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The existence of the ``invariant.group`` metadata on the instruction tells<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">the optimizer that every ``load`` and ``store`` to the same pointer operand<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -6875,7 +6875,7 @@ Arguments:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">""""""""""<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The two arguments to the '``fadd``' instruction must be<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-:ref:`floating-point <t_floating>` or :ref:`vector <t_vector>` of<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+:ref:`floating-point <t_floating>` or :ref:`vector <t_vector>` of
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">floating-point values. Both arguments must have identical types.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Semantics:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -6883,7 +6883,7 @@ Semantics:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The value produced is the floating-point sum of the two operands.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">This instruction is assumed to execute in the default :ref:`floating-point<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-environment <floatenv>`.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+environment <floatenv>`. <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">This instruction can also take any number of :ref:`fast-math<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">flags <fastmath>`, which are optimization hints to enable otherwise<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">unsafe floating-point optimizations:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -6972,7 +6972,7 @@ Arguments:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">""""""""""<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The two arguments to the '``fsub``' instruction must be<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-:ref:`floating-point <t_floating>` or :ref:`vector <t_vector>` of<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+:ref:`floating-point <t_floating>` or :ref:`vector <t_vector>` of
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">floating-point values. Both arguments must have identical types.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Semantics:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -6980,7 +6980,7 @@ Semantics:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The value produced is the floating-point difference of the two operands.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">This instruction is assumed to execute in the default :ref:`floating-point<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-environment <floatenv>`.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+environment <floatenv>`. <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">This instruction can also take any number of :ref:`fast-math<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">flags <fastmath>`, which are optimization hints to enable otherwise<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">unsafe floating-point optimizations:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -7067,7 +7067,7 @@ Arguments:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">""""""""""<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The two arguments to the '``fmul``' instruction must be<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-:ref:`floating-point <t_floating>` or :ref:`vector <t_vector>` of<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+:ref:`floating-point <t_floating>` or :ref:`vector <t_vector>` of
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">floating-point values. Both arguments must have identical types.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Semantics:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -7075,7 +7075,7 @@ Semantics:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The value produced is the floating-point product of the two operands.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">This instruction is assumed to execute in the default :ref:`floating-point<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-environment <floatenv>`.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+environment <floatenv>`. <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">This instruction can also take any number of :ref:`fast-math<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">flags <fastmath>`, which are optimization hints to enable otherwise<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">unsafe floating-point optimizations:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -7201,7 +7201,7 @@ Arguments:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">""""""""""<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The two arguments to the '``fdiv``' instruction must be<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-:ref:`floating-point <t_floating>` or :ref:`vector <t_vector>` of<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+:ref:`floating-point <t_floating>` or :ref:`vector <t_vector>` of
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">floating-point values. Both arguments must have identical types.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Semantics:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -7209,7 +7209,7 @@ Semantics:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The value produced is the floating-point quotient of the two operands.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">This instruction is assumed to execute in the default :ref:`floating-point<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-environment <floatenv>`.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+environment <floatenv>`. <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">This instruction can also take any number of :ref:`fast-math<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">flags <fastmath>`, which are optimization hints to enable otherwise<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">unsafe floating-point optimizations:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -7344,7 +7344,7 @@ Arguments:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">""""""""""<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The two arguments to the '``frem``' instruction must be<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-:ref:`floating-point <t_floating>` or :ref:`vector <t_vector>` of<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+:ref:`floating-point <t_floating>` or :ref:`vector <t_vector>` of
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">floating-point values. Both arguments must have identical types.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Semantics:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -7352,10 +7352,10 @@ Semantics:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The value produced is the floating-point remainder of the two operands.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">This is the same output as a libm '``fmod``' function, but without any<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-possibility of setting ``errno``. The remainder has the same sign as the<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+possibility of setting ``errno``. The remainder has the same sign as the
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">dividend.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">This instruction is assumed to execute in the default :ref:`floating-point<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-environment <floatenv>`.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+environment <floatenv>`. <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">This instruction can also take any number of :ref:`fast-math<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">flags <fastmath>`, which are optimization hints to enable otherwise<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">unsafe floating-point optimizations:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -8809,7 +8809,7 @@ Semantics:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The '``fptrunc``' instruction casts a ``value`` from a larger<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">:ref:`floating-point <t_floating>` type to a smaller :ref:`floating-point<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<t_floating>` type.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+<t_floating>` type.  <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">This instruction is assumed to execute in the default :ref:`floating-point<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">environment <floatenv>`.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -10330,27 +10330,6 @@ of the obvious source-language caller.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">This intrinsic is only implemented for x86.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-'``llvm.sponentry``' Intrinsic<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-Syntax:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-"""""""<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-::<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-      declare i8* @llvm.sponentry()<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-Overview:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-"""""""""<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-The '``llvm.sponentry``' intrinsic returns the stack pointer value at<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-the entry of the current function calling this intrinsic.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-Semantics:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-""""""""""<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-Note this intrinsic is only verified on AArch64.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">'``llvm.frameaddress``' Intrinsic<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -12136,11 +12115,11 @@ Overview:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The '``llvm.fshl``' family of intrinsic functions performs a funnel shift left:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">the first two values are concatenated as { %a : %b } (%a is the most significant<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-bits of the wide value), the combined value is shifted left, and the most<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-significant bits are extracted to produce a result that is the same size as the<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-original arguments. If the first 2 arguments are identical, this is equivalent<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-to a rotate left operation. For vector types, the operation occurs for each<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-element of the vector. The shift argument is treated as an unsigned amount<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+bits of the wide value), the combined value is shifted left, and the most
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+significant bits are extracted to produce a result that is the same size as the
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+original arguments. If the first 2 arguments are identical, this is equivalent
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+to a rotate left operation. For vector types, the operation occurs for each
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+element of the vector. The shift argument is treated as an unsigned amount
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">modulo the element size of the arguments.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Arguments:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -12182,11 +12161,11 @@ Overview:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The '``llvm.fshr``' family of intrinsic functions performs a funnel shift right:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">the first two values are concatenated as { %a : %b } (%a is the most significant<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-bits of the wide value), the combined value is shifted right, and the least<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-significant bits are extracted to produce a result that is the same size as the<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-original arguments. If the first 2 arguments are identical, this is equivalent<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-to a rotate right operation. For vector types, the operation occurs for each<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-element of the vector. The shift argument is treated as an unsigned amount<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+bits of the wide value), the combined value is shifted right, and the least
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+significant bits are extracted to produce a result that is the same size as the
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+original arguments. If the first 2 arguments are identical, this is equivalent
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+to a rotate right operation. For vector types, the operation occurs for each
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+element of the vector. The shift argument is treated as an unsigned amount
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">modulo the element size of the arguments.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Arguments:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -13467,7 +13446,7 @@ The '``llvm.masked.expandload``' intrins<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     %Tmp = call <8 x double> @llvm.masked.expandload.v8f64(double* %Bptr, <8 x i1> %Mask, <8 x double> undef)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     ; Store the result in A<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     call void @llvm.masked.store.v8f64.p0v8f64(<8 x double> %Tmp, <8 x double>* %Aptr, i32 8, <8 x i1> %Mask)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+    <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     ; %Bptr should be increased on each iteration according to the number of '1' elements in the Mask.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     %MaskI = bitcast <8 x i1> %Mask to i8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     %MaskIPopcnt = call i8 @llvm.ctpop.i8(i8 %MaskI)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -13524,7 +13503,7 @@ The '``llvm.masked.compressstore``' intr<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     %Tmp = call <8 x double> @llvm.masked.load.v8f64.p0v8f64(<8 x double>* %Aptr, i32 8, <8 x i1> %Mask, <8 x double> undef)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     ; Store all selected elements consecutively in array B<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     call <void> @llvm.masked.compressstore.v8f64(<8 x double> %Tmp, double* %Bptr, <8 x i1> %Mask)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+    <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     ; %Bptr should be increased on each iteration according to the number of '1' elements in the Mask.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     %MaskI = bitcast <8 x i1> %Mask to i8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     %MaskIPopcnt = call i8 @llvm.ctpop.i8(i8 %MaskI)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -14157,7 +14136,7 @@ Overview:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The '``llvm.experimental.constrained.powi``' intrinsic returns the first operand<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">raised to the (positive or negative) power specified by the second operand. The<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-order of evaluation of multiplications is not defined. When a vector of<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+order of evaluation of multiplications is not defined. When a vector of
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">floating-point type is used, the second argument remains a scalar integer value.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -14483,7 +14462,7 @@ Overview:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">"""""""""<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">The '``llvm.experimental.constrained.nearbyint``' intrinsic returns the first<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-operand rounded to the nearest integer. It will not raise an inexact<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+operand rounded to the nearest integer. It will not raise an inexact
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">floating-point exception if the operand is not an integer.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Modified: llvm/trunk/include/llvm/CodeGen/ISDOpcodes.h<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_include_llvm_CodeGen_ISDOpcodes.h-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=nP1YiFUbW5S_Ybsw-uB3PACFXirSbVQUUHSW9mOWbis&e=">
https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_include_llvm_CodeGen_ISDOpcodes.h-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=nP1YiFUbW5S_Ybsw-uB3PACFXirSbVQUUHSW9mOWbis&e=</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">==============================================================================<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">--- llvm/trunk/include/llvm/CodeGen/ISDOpcodes.h (original)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+++ llvm/trunk/include/llvm/CodeGen/ISDOpcodes.h Thu Nov  1 10:53:57 2018<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -70,7 +70,7 @@ namespace ISD {<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     /// of the frame or return address to return.  An index of zero corresponds<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     /// to the current function's frame or return address, an index of one to<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     /// the parent's frame or return address, and so on.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-    FRAMEADDR, RETURNADDR, ADDROFRETURNADDR, SPONENTRY,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+    FRAMEADDR, RETURNADDR, ADDROFRETURNADDR,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     /// LOCAL_RECOVER - Represents the llvm.localrecover intrinsic.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     /// Materializes the offset from the local object pointer of another<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Modified: llvm/trunk/include/llvm/IR/Intrinsics.td<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_include_llvm_IR_Intrinsics.td-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=FJ8FgON4ymog-LWO2B8lhPdbUrzrOWb1Xfn69jOQd_w&e=">
https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_include_llvm_IR_Intrinsics.td-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=FJ8FgON4ymog-LWO2B8lhPdbUrzrOWb1Xfn69jOQd_w&e=</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">==============================================================================<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">--- llvm/trunk/include/llvm/IR/Intrinsics.td (original)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+++ llvm/trunk/include/llvm/IR/Intrinsics.td Thu Nov  1 10:53:57 2018<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -320,7 +320,6 @@ def int_gcwrite : Intrinsic<[],<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">def int_returnaddress : Intrinsic<[llvm_ptr_ty], [llvm_i32_ty], [IntrNoMem]>;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">def int_addressofreturnaddress : Intrinsic<[llvm_ptr_ty], [], [IntrNoMem]>;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">def int_frameaddress  : Intrinsic<[llvm_ptr_ty], [llvm_i32_ty], [IntrNoMem]>;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-def int_sponentry  : Intrinsic<[llvm_ptr_ty], [], [IntrNoMem]>;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">def int_read_register  : Intrinsic<[llvm_anyint_ty], [llvm_metadata_ty],<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">                                    [IntrReadMem], "llvm.read_register">;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">def int_write_register : Intrinsic<[], [llvm_metadata_ty, llvm_anyint_ty],<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Modified: llvm/trunk/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_lib_CodeGen_SelectionDAG_LegalizeDAG.cpp-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=LWvsdaXCgFsQkgXqBMmeUcaZLKwh8WSbxt8YZhzooOE&e=">
https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_lib_CodeGen_SelectionDAG_LegalizeDAG.cpp-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=LWvsdaXCgFsQkgXqBMmeUcaZLKwh8WSbxt8YZhzooOE&e=</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">==============================================================================<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">--- llvm/trunk/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp (original)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+++ llvm/trunk/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp Thu Nov  1 10:53:57 2018<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -1059,7 +1059,6 @@ void SelectionDAGLegalize::LegalizeOp(SD<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case ISD::FRAMEADDR:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case ISD::RETURNADDR:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case ISD::ADDROFRETURNADDR:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  case ISD::SPONENTRY:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     // These operations lie about being legal: when they claim to be legal,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     // they should actually be custom-lowered.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     Action = TLI.getOperationAction(Node->getOpcode(), Node->getValueType(0));<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Modified: llvm/trunk/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_lib_CodeGen_SelectionDAG_SelectionDAGBuilder.cpp-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=5hrVgU0q8w5Ma2jXgBliuhGsH1Ja4qo_7puFzTO8I-I&e=">
https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_lib_CodeGen_SelectionDAG_SelectionDAGBuilder.cpp-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=5hrVgU0q8w5Ma2jXgBliuhGsH1Ja4qo_7puFzTO8I-I&e=</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">==============================================================================<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">--- llvm/trunk/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp (original)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+++ llvm/trunk/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp Thu Nov  1 10:53:57 2018<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -5050,10 +5050,6 @@ SelectionDAGBuilder::visitIntrinsicCall(<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     setValue(&I, DAG.getNode(ISD::ADDROFRETURNADDR, sdl,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">                              TLI.getPointerTy(DAG.getDataLayout())));<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     return nullptr;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  case Intrinsic::sponentry:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-    setValue(&I, DAG.getNode(ISD::SPONENTRY, sdl,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-                             TLI.getPointerTy(DAG.getDataLayout())));<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-    return nullptr;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case Intrinsic::frameaddress:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     setValue(&I, DAG.getNode(ISD::FRAMEADDR, sdl,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">                              TLI.getPointerTy(DAG.getDataLayout()),<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Modified: llvm/trunk/lib/CodeGen/SelectionDAG/SelectionDAGDumper.cpp<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_lib_CodeGen_SelectionDAG_SelectionDAGDumper.cpp-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=wSONm46woB_kC3wtKPSG_tLhvVXjnhGkvRGqNrMkCNI&e=">
https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_lib_CodeGen_SelectionDAG_SelectionDAGDumper.cpp-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=wSONm46woB_kC3wtKPSG_tLhvVXjnhGkvRGqNrMkCNI&e=</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">==============================================================================<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">--- llvm/trunk/lib/CodeGen/SelectionDAG/SelectionDAGDumper.cpp (original)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+++ llvm/trunk/lib/CodeGen/SelectionDAG/SelectionDAGDumper.cpp Thu Nov  1 10:53:57 2018<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -124,7 +124,6 @@ std::string SDNode::getOperationName(con<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case ISD::RETURNADDR:                 return "RETURNADDR";<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case ISD::ADDROFRETURNADDR:           return "ADDROFRETURNADDR";<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case ISD::FRAMEADDR:                  return "FRAMEADDR";<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  case ISD::SPONENTRY:                  return "SPONENTRY";<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case ISD::LOCAL_RECOVER:              return "LOCAL_RECOVER";<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case ISD::READ_REGISTER:              return "READ_REGISTER";<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case ISD::WRITE_REGISTER:             return "WRITE_REGISTER";<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Modified: llvm/trunk/lib/Target/AArch64/AArch64FastISel.cpp<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_lib_Target_AArch64_AArch64FastISel.cpp-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=qe2ofDTLCVCxZ4I76Fokgvz-dC08hOoAf26V-5kbvcY&e=">
https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_lib_Target_AArch64_AArch64FastISel.cpp-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=qe2ofDTLCVCxZ4I76Fokgvz-dC08hOoAf26V-5kbvcY&e=</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">==============================================================================<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">--- llvm/trunk/lib/Target/AArch64/AArch64FastISel.cpp (original)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+++ llvm/trunk/lib/Target/AArch64/AArch64FastISel.cpp Thu Nov  1 10:53:57 2018<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -3450,22 +3450,6 @@ bool AArch64FastISel::fastLowerIntrinsic<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     updateValueMap(II, SrcReg);<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     return true;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   }<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  case Intrinsic::sponentry: {<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-    MachineFrameInfo &MFI = FuncInfo.MF->getFrameInfo();<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-    // SP = FP + Fixed Object + 16<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-    MVT VT = TLI.getPointerTy(DL);<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-    int FI = MFI.CreateFixedObject(4, 0, false);<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-    unsigned ResultReg = createResultReg(TLI.getRegClassFor(VT));<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-    BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt, DbgLoc,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-            TII.get(AArch64::ADDXri), ResultReg)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-            .addFrameIndex(FI)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-            .addImm(0)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-            .addImm(0);<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-    updateValueMap(II, ResultReg);<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-    return true;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  }<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case Intrinsic::memcpy:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case Intrinsic::memmove: {<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     const auto *MTI = cast<MemTransferInst>(II);<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Modified: llvm/trunk/lib/Target/AArch64/AArch64ISelLowering.cpp<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_lib_Target_AArch64_AArch64ISelLowering.cpp-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=PVm4hmJ5sbJf4my4zTdAkkroAKp52U9omNuorgh9Ibw&e=">
https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_lib_Target_AArch64_AArch64ISelLowering.cpp-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=PVm4hmJ5sbJf4my4zTdAkkroAKp52U9omNuorgh9Ibw&e=</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">==============================================================================<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">--- llvm/trunk/lib/Target/AArch64/AArch64ISelLowering.cpp (original)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+++ llvm/trunk/lib/Target/AArch64/AArch64ISelLowering.cpp Thu Nov  1 10:53:57 2018<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -2863,8 +2863,6 @@ SDValue AArch64TargetLowering::LowerOper<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     return LowerFP_EXTEND(Op, DAG);<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case ISD::FRAMEADDR:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     return LowerFRAMEADDR(Op, DAG);<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  case ISD::SPONENTRY:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-    return LowerSPONENTRY(Op, DAG);<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case ISD::RETURNADDR:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">     return LowerRETURNADDR(Op, DAG);<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   case ISD::INSERT_VECTOR_ELT:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -5173,16 +5171,6 @@ SDValue AArch64TargetLowering::LowerFRAM<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   return FrameAddr;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">}<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-SDValue AArch64TargetLowering::LowerSPONENTRY(SDValue Op,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-                                              SelectionDAG &DAG) const {<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  MachineFrameInfo &MFI = DAG.getMachineFunction().getFrameInfo();<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  EVT VT = getPointerTy(DAG.getDataLayout());<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  SDLoc DL(Op);<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  int FI = MFI.CreateFixedObject(4, 0, false);<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  return DAG.getFrameIndex(FI, VT);<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-}<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">// FIXME? Maybe this could be a TableGen attribute on some registers and<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">// this table could be generated automatically from RegInfo.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">unsigned AArch64TargetLowering::getRegisterByName(const char* RegName, EVT VT,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Modified: llvm/trunk/lib/Target/AArch64/AArch64ISelLowering.h<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_lib_Target_AArch64_AArch64ISelLowering.h-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=xImxv8Wi34U88k_7Drcz0RuZWzZeW7E6-XiNvNJxpIQ&e=">
https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_lib_Target_AArch64_AArch64ISelLowering.h-3Frev-3D345863-26r1-3D345862-26r2-3D345863-26view-3Ddiff&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=xImxv8Wi34U88k_7Drcz0RuZWzZeW7E6-XiNvNJxpIQ&e=</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">==============================================================================<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">--- llvm/trunk/lib/Target/AArch64/AArch64ISelLowering.h (original)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+++ llvm/trunk/lib/Target/AArch64/AArch64ISelLowering.h Thu Nov  1 10:53:57 2018<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -617,7 +617,6 @@ private:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   SDValue LowerVACOPY(SDValue Op, SelectionDAG &DAG) const;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   SDValue LowerVAARG(SDValue Op, SelectionDAG &DAG) const;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   SDValue LowerFRAMEADDR(SDValue Op, SelectionDAG &DAG) const;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  SDValue LowerSPONENTRY(SDValue Op, SelectionDAG &DAG) const;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   SDValue LowerRETURNADDR(SDValue Op, SelectionDAG &DAG) const;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   SDValue LowerFLT_ROUNDS_(SDValue Op, SelectionDAG &DAG) const;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">   SDValue LowerINSERT_VECTOR_ELT(SDValue Op, SelectionDAG &DAG) const;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">Removed: llvm/trunk/test/CodeGen/AArch64/sponentry.ll<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_test_CodeGen_AArch64_sponentry.ll-3Frev-3D345862-26view-3Dauto&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=vame1Y9HrZg_5GhjJ2EeRmAsYgmsmopjO6ygqnpX1Yg&e=">
https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_llvm_trunk_test_CodeGen_AArch64_sponentry.ll-3Frev-3D345862-26view-3Dauto&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=vame1Y9HrZg_5GhjJ2EeRmAsYgmsmopjO6ygqnpX1Yg&e=</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">==============================================================================<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">--- llvm/trunk/test/CodeGen/AArch64/sponentry.ll (original)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">+++ llvm/trunk/test/CodeGen/AArch64/sponentry.ll (removed)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">@@ -1,104 +0,0 @@<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; RUN: llc -mtriple=aarch64-windows-msvc -disable-fp-elim %s -o - | FileCheck %s<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; RUN: llc -mtriple=aarch64-windows-msvc -fast-isel -disable-fp-elim %s -o - | FileCheck %s<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; RUN: llc -mtriple=aarch64-windows-msvc %s -o - | FileCheck %s --check-prefix=NOFP<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; RUN: llc -mtriple=aarch64-windows-msvc -fast-isel %s -o - | FileCheck %s --check-prefix=NOFP<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-@env2 = common dso_local global [24 x i64]* null, align 8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-define dso_local void @bar() {<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %1 = call i8* @llvm.sponentry()<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %2 = load [24 x i64]*, [24 x i64]** @env2, align 8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %3 = getelementptr inbounds [24 x i64], [24 x i64]* %2, i32 0, i32 0<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %4 = bitcast i64* %3 to i8*<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %5 = call i32 @_setjmpex(i8* %4, i8* %1) #2<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  ret void<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-}<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CHECK: bar:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CHECK: mov     x29, sp<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CHECK: add     x1, x29, #16<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CEHCK: bl      _setjmpex<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; NOFP: str     x30, [sp, #-16]!<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; NOFP: add     x1, sp, #16<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-define dso_local void @foo([24 x i64]*) {<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %2 = alloca [24 x i64]*, align 8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %3 = alloca i32, align 4<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %4 = alloca [100 x i32], align 4<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  store [24 x i64]* %0, [24 x i64]** %2, align 8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %5 = call i8* @llvm.sponentry()<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %6 = load [24 x i64]*, [24 x i64]** %2, align 8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %7 = getelementptr inbounds [24 x i64], [24 x i64]* %6, i32 0, i32 0<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %8 = bitcast i64* %7 to i8*<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %9 = call i32 @_setjmpex(i8* %8, i8* %5)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  store i32 %9, i32* %3, align 4<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  ret void<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-}<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CHECK: foo:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CHECK: sub     sp, sp, #448<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CHECK: add     x29, sp, #432<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CHECK: add     x1, x29, #16<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CEHCK: bl      _setjmpex<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; NOFP: sub     sp, sp, #432<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; NOFP: add     x1, sp, #432<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-define dso_local void @var_args(i8*, ...) {<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %2 = alloca i8*, align 8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %3 = alloca i8*, align 8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  store i8* %0, i8** %2, align 8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %4 = bitcast i8** %3 to i8*<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  call void @llvm.va_start(i8* %4)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %5 = load i8*, i8** %3, align 8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %6 = getelementptr inbounds i8, i8* %5, i64 8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  store i8* %6, i8** %3, align 8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %7 = bitcast i8* %5 to i32*<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %8 = load i32, i32* %7, align 8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %9 = bitcast i8** %3 to i8*<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  call void @llvm.va_end(i8* %9)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %10 = call i8* @llvm.sponentry()<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %11 = load [24 x i64]*, [24 x i64]** @env2, align 8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %12 = getelementptr inbounds [24 x i64], [24 x i64]* %11, i32 0, i32 0<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %13 = bitcast i64* %12 to i8*<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %14 = call i32 @_setjmpex(i8* %13, i8* %10) #3<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  ret void<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-}<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CHECK: var_args:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CHECK: sub     sp, sp, #96<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CHECK: add     x29, sp, #16<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CHECK: add     x1, x29, #80<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CEHCK: bl      _setjmpex<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; NOFP: sub     sp, sp, #96<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; NOFP: add     x1, sp, #96<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-define dso_local void @manyargs(i64 %x1, i64 %x2, i64 %x3, i64 %x4, i64 %x5, i64 %x6, i64 %x7, i64 %x8, i64 %x9, i64 %x10) {<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %1 = call i8* @llvm.sponentry()<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %2 = load [24 x i64]*, [24 x i64]** @env2, align 8<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %3 = getelementptr inbounds [24 x i64], [24 x i64]* %2, i32 0, i32 0<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %4 = bitcast i64* %3 to i8*<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  %5 = call i32 @_setjmpex(i8* %4, i8* %1) #2<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-  ret void<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-}<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CHECK: manyargs:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CHECK: stp     x29, x30, [sp, #-16]!<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; CHECK: add     x1, x29, #16<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; NOFP: str     x30, [sp, #-16]!<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; NOFP: add     x1, sp, #16<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; Function Attrs: nounwind readnone<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-declare i8* @llvm.sponentry()<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; Function Attrs: returns_twice<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-declare dso_local i32 @_setjmpex(i8*, i8*)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; Function Attrs: nounwind<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-declare void @llvm.va_start(i8*) #1<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-; Function Attrs: nounwind<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">-declare void @llvm.va_end(i8*) #1<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">_______________________________________________<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in">llvm-commits mailing list<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><a href="mailto:llvm-commits@lists.llvm.org">llvm-commits@lists.llvm.org</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__lists.llvm.org_cgi-2Dbin_mailman_listinfo_llvm-2Dcommits&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=f3h57w5V12RDlVwwwgJJzI9BMUm6Cedfyr0StJSQ7_k&e=">https://urldefense.proofpoint.com/v2/url?u=http-3A__lists.llvm.org_cgi-2Dbin_mailman_listinfo_llvm-2Dcommits&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=YNR5WhPZqnT6ljbLybHN4yQiyIHKQct_g4Ab6SLUlb8&s=f3h57w5V12RDlVwwwgJJzI9BMUm6Cedfyr0StJSQ7_k&e=</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><o:p> </o:p></p>
</div>
</div>
</body>
</html>