Sophie

Sophie

distrib > Fedora > 14 > x86_64 > by-pkgid > 8d1ef08c9e0d44c69764afc615a03d0d > files > 1797

ghc-ghc-devel-6.12.3-5.fc14.i686.rpm

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
<!-- Generated by HsColour, http://www.cs.york.ac.uk/fp/darcs/hscolour/ -->
<title>nativeGen/PPC/Ppr.hs</title>
<link type='text/css' rel='stylesheet' href='hscolour.css' />
</head>
<body>
<pre><a name="line-1"></a><span class='hs-comment'>-----------------------------------------------------------------------------</span>
<a name="line-2"></a><span class='hs-comment'>--</span>
<a name="line-3"></a><span class='hs-comment'>-- Pretty-printing assembly language</span>
<a name="line-4"></a><span class='hs-comment'>--</span>
<a name="line-5"></a><span class='hs-comment'>-- (c) The University of Glasgow 1993-2005</span>
<a name="line-6"></a><span class='hs-comment'>--</span>
<a name="line-7"></a><span class='hs-comment'>-----------------------------------------------------------------------------</span>
<a name="line-8"></a>
<a name="line-9"></a><span class='hs-keyword'>module</span> <span class='hs-conid'>PPC</span><span class='hs-varop'>.</span><span class='hs-conid'>Ppr</span> <span class='hs-layout'>(</span>
<a name="line-10"></a>	<span class='hs-varid'>pprNatCmmTop</span><span class='hs-layout'>,</span>
<a name="line-11"></a>	<span class='hs-varid'>pprBasicBlock</span><span class='hs-layout'>,</span>
<a name="line-12"></a>	<span class='hs-varid'>pprSectionHeader</span><span class='hs-layout'>,</span>
<a name="line-13"></a>	<span class='hs-varid'>pprData</span><span class='hs-layout'>,</span>
<a name="line-14"></a>	<span class='hs-varid'>pprInstr</span><span class='hs-layout'>,</span>
<a name="line-15"></a>	<span class='hs-varid'>pprUserReg</span><span class='hs-layout'>,</span>
<a name="line-16"></a>	<span class='hs-varid'>pprSize</span><span class='hs-layout'>,</span>
<a name="line-17"></a>	<span class='hs-varid'>pprImm</span><span class='hs-layout'>,</span>
<a name="line-18"></a>	<span class='hs-varid'>pprDataItem</span><span class='hs-layout'>,</span>
<a name="line-19"></a><span class='hs-layout'>)</span>
<a name="line-20"></a>
<a name="line-21"></a><span class='hs-keyword'>where</span>
<a name="line-22"></a>
<a name="line-23"></a><span class='hs-cpp'>#include "nativeGen/NCG.h"</span>
<a name="line-24"></a><span class='hs-cpp'>#include "HsVersions.h"</span>
<a name="line-25"></a>
<a name="line-26"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>PPC</span><span class='hs-varop'>.</span><span class='hs-conid'>Regs</span>
<a name="line-27"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>PPC</span><span class='hs-varop'>.</span><span class='hs-conid'>Instr</span>
<a name="line-28"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>PPC</span><span class='hs-varop'>.</span><span class='hs-conid'>Cond</span>
<a name="line-29"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>PprBase</span>
<a name="line-30"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Instruction</span>
<a name="line-31"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Size</span>
<a name="line-32"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Reg</span>
<a name="line-33"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>RegClass</span>
<a name="line-34"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>TargetReg</span>
<a name="line-35"></a>
<a name="line-36"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>BlockId</span>
<a name="line-37"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Cmm</span>
<a name="line-38"></a>
<a name="line-39"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>CLabel</span>
<a name="line-40"></a>
<a name="line-41"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Unique</span>		<span class='hs-layout'>(</span> <span class='hs-varid'>pprUnique</span> <span class='hs-layout'>)</span>
<a name="line-42"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Pretty</span>
<a name="line-43"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>FastString</span>
<a name="line-44"></a><span class='hs-keyword'>import</span> <span class='hs-keyword'>qualified</span> <span class='hs-conid'>Outputable</span>
<a name="line-45"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Outputable</span>	<span class='hs-layout'>(</span> <span class='hs-conid'>Outputable</span><span class='hs-layout'>,</span> <span class='hs-varid'>panic</span> <span class='hs-layout'>)</span>
<a name="line-46"></a>
<a name="line-47"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Data</span><span class='hs-varop'>.</span><span class='hs-conid'>Word</span>
<a name="line-48"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Data</span><span class='hs-varop'>.</span><span class='hs-conid'>Bits</span>
<a name="line-49"></a>
<a name="line-50"></a>
<a name="line-51"></a><span class='hs-comment'>-- -----------------------------------------------------------------------------</span>
<a name="line-52"></a><span class='hs-comment'>-- Printing this stuff out</span>
<a name="line-53"></a>
<a name="line-54"></a><a name="pprNatCmmTop"></a><span class='hs-definition'>pprNatCmmTop</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>NatCmmTop</span> <span class='hs-conid'>Instr</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-55"></a><span class='hs-definition'>pprNatCmmTop</span> <span class='hs-layout'>(</span><span class='hs-conid'>CmmData</span> <span class='hs-varid'>section</span> <span class='hs-varid'>dats</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> 
<a name="line-56"></a>  <span class='hs-varid'>pprSectionHeader</span> <span class='hs-varid'>section</span> <span class='hs-varop'>$$</span> <span class='hs-varid'>vcat</span> <span class='hs-layout'>(</span><span class='hs-varid'>map</span> <span class='hs-varid'>pprData</span> <span class='hs-varid'>dats</span><span class='hs-layout'>)</span>
<a name="line-57"></a>
<a name="line-58"></a> <span class='hs-comment'>-- special case for split markers:</span>
<a name="line-59"></a><span class='hs-definition'>pprNatCmmTop</span> <span class='hs-layout'>(</span><span class='hs-conid'>CmmProc</span> <span class='hs-conid'>[]</span> <span class='hs-varid'>lbl</span> <span class='hs-keyword'>_</span> <span class='hs-layout'>(</span><span class='hs-conid'>ListGraph</span> <span class='hs-conid'>[]</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLabel</span> <span class='hs-varid'>lbl</span>
<a name="line-60"></a>
<a name="line-61"></a><span class='hs-definition'>pprNatCmmTop</span> <span class='hs-layout'>(</span><span class='hs-conid'>CmmProc</span> <span class='hs-varid'>info</span> <span class='hs-varid'>lbl</span> <span class='hs-keyword'>_</span> <span class='hs-layout'>(</span><span class='hs-conid'>ListGraph</span> <span class='hs-varid'>blocks</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> 
<a name="line-62"></a>  <span class='hs-varid'>pprSectionHeader</span> <span class='hs-conid'>Text</span> <span class='hs-varop'>$$</span>
<a name="line-63"></a>  <span class='hs-layout'>(</span><span class='hs-keyword'>if</span> <span class='hs-varid'>null</span> <span class='hs-varid'>info</span> <span class='hs-keyword'>then</span> <span class='hs-comment'>-- blocks guaranteed not null, so label needed</span>
<a name="line-64"></a>       <span class='hs-varid'>pprLabel</span> <span class='hs-varid'>lbl</span>
<a name="line-65"></a>   <span class='hs-keyword'>else</span>
<a name="line-66"></a><span class='hs-cpp'>#if HAVE_SUBSECTIONS_VIA_SYMBOLS</span>
<a name="line-67"></a>            <span class='hs-varid'>pprCLabel_asm</span> <span class='hs-layout'>(</span><span class='hs-varid'>mkDeadStripPreventer</span> <span class='hs-varop'>$</span> <span class='hs-varid'>entryLblToInfoLbl</span> <span class='hs-varid'>lbl</span><span class='hs-layout'>)</span>
<a name="line-68"></a>                <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>':'</span> <span class='hs-varop'>$$</span>
<a name="line-69"></a><span class='hs-cpp'>#endif</span>
<a name="line-70"></a>       <span class='hs-varid'>vcat</span> <span class='hs-layout'>(</span><span class='hs-varid'>map</span> <span class='hs-varid'>pprData</span> <span class='hs-varid'>info</span><span class='hs-layout'>)</span> <span class='hs-varop'>$$</span>
<a name="line-71"></a>       <span class='hs-varid'>pprLabel</span> <span class='hs-layout'>(</span><span class='hs-varid'>entryLblToInfoLbl</span> <span class='hs-varid'>lbl</span><span class='hs-layout'>)</span>
<a name="line-72"></a>  <span class='hs-layout'>)</span> <span class='hs-varop'>$$</span>
<a name="line-73"></a>  <span class='hs-varid'>vcat</span> <span class='hs-layout'>(</span><span class='hs-varid'>map</span> <span class='hs-varid'>pprBasicBlock</span> <span class='hs-varid'>blocks</span><span class='hs-layout'>)</span>
<a name="line-74"></a>     <span class='hs-comment'>-- above: Even the first block gets a label, because with branch-chain</span>
<a name="line-75"></a>     <span class='hs-comment'>-- elimination, it might be the target of a goto.</span>
<a name="line-76"></a><span class='hs-cpp'>#if HAVE_SUBSECTIONS_VIA_SYMBOLS</span>
<a name="line-77"></a>        <span class='hs-comment'>-- If we are using the .subsections_via_symbols directive</span>
<a name="line-78"></a>        <span class='hs-comment'>-- (available on recent versions of Darwin),</span>
<a name="line-79"></a>        <span class='hs-comment'>-- we have to make sure that there is some kind of reference</span>
<a name="line-80"></a>        <span class='hs-comment'>-- from the entry code to a label on the _top_ of of the info table,</span>
<a name="line-81"></a>        <span class='hs-comment'>-- so that the linker will not think it is unreferenced and dead-strip</span>
<a name="line-82"></a>        <span class='hs-comment'>-- it. That's why the label is called a DeadStripPreventer (_dsp).</span>
<a name="line-83"></a>  <span class='hs-varop'>$$</span> <span class='hs-keyword'>if</span> <span class='hs-varid'>not</span> <span class='hs-layout'>(</span><span class='hs-varid'>null</span> <span class='hs-varid'>info</span><span class='hs-layout'>)</span>
<a name="line-84"></a>		    <span class='hs-keyword'>then</span> <span class='hs-varid'>text</span> <span class='hs-str'>"\t.long "</span>
<a name="line-85"></a>		      <span class='hs-varop'>&lt;+&gt;</span> <span class='hs-varid'>pprCLabel_asm</span> <span class='hs-layout'>(</span><span class='hs-varid'>entryLblToInfoLbl</span> <span class='hs-varid'>lbl</span><span class='hs-layout'>)</span>
<a name="line-86"></a>		      <span class='hs-varop'>&lt;+&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'-'</span>
<a name="line-87"></a>		      <span class='hs-varop'>&lt;+&gt;</span> <span class='hs-varid'>pprCLabel_asm</span> <span class='hs-layout'>(</span><span class='hs-varid'>mkDeadStripPreventer</span> <span class='hs-varop'>$</span> <span class='hs-varid'>entryLblToInfoLbl</span> <span class='hs-varid'>lbl</span><span class='hs-layout'>)</span>
<a name="line-88"></a>		    <span class='hs-keyword'>else</span> <span class='hs-varid'>empty</span>
<a name="line-89"></a><span class='hs-cpp'>#endif</span>
<a name="line-90"></a>
<a name="line-91"></a>
<a name="line-92"></a><a name="pprBasicBlock"></a><span class='hs-definition'>pprBasicBlock</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>NatBasicBlock</span> <span class='hs-conid'>Instr</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-93"></a><span class='hs-definition'>pprBasicBlock</span> <span class='hs-layout'>(</span><span class='hs-conid'>BasicBlock</span> <span class='hs-layout'>(</span><span class='hs-conid'>BlockId</span> <span class='hs-varid'>id</span><span class='hs-layout'>)</span> <span class='hs-varid'>instrs</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span>
<a name="line-94"></a>  <span class='hs-varid'>pprLabel</span> <span class='hs-layout'>(</span><span class='hs-varid'>mkAsmTempLabel</span> <span class='hs-varid'>id</span><span class='hs-layout'>)</span> <span class='hs-varop'>$$</span>
<a name="line-95"></a>  <span class='hs-varid'>vcat</span> <span class='hs-layout'>(</span><span class='hs-varid'>map</span> <span class='hs-varid'>pprInstr</span> <span class='hs-varid'>instrs</span><span class='hs-layout'>)</span>
<a name="line-96"></a>
<a name="line-97"></a>
<a name="line-98"></a><a name="pprData"></a><span class='hs-definition'>pprData</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>CmmStatic</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-99"></a><span class='hs-definition'>pprData</span> <span class='hs-layout'>(</span><span class='hs-conid'>CmmAlign</span> <span class='hs-varid'>bytes</span><span class='hs-layout'>)</span>         <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprAlign</span> <span class='hs-varid'>bytes</span>
<a name="line-100"></a><span class='hs-definition'>pprData</span> <span class='hs-layout'>(</span><span class='hs-conid'>CmmDataLabel</span> <span class='hs-varid'>lbl</span><span class='hs-layout'>)</span>       <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLabel</span> <span class='hs-varid'>lbl</span>
<a name="line-101"></a><span class='hs-definition'>pprData</span> <span class='hs-layout'>(</span><span class='hs-conid'>CmmString</span> <span class='hs-varid'>str</span><span class='hs-layout'>)</span>          <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprASCII</span> <span class='hs-varid'>str</span>
<a name="line-102"></a>
<a name="line-103"></a><span class='hs-cpp'>#if darwin_TARGET_OS</span>
<a name="line-104"></a><span class='hs-definition'>pprData</span> <span class='hs-layout'>(</span><span class='hs-conid'>CmmUninitialised</span> <span class='hs-varid'>bytes</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".space "</span><span class='hs-layout'>)</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>int</span> <span class='hs-varid'>bytes</span>
<a name="line-105"></a><span class='hs-cpp'>#else</span>
<a name="line-106"></a><span class='hs-definition'>pprData</span> <span class='hs-layout'>(</span><span class='hs-conid'>CmmUninitialised</span> <span class='hs-varid'>bytes</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".skip "</span><span class='hs-layout'>)</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>int</span> <span class='hs-varid'>bytes</span>
<a name="line-107"></a><span class='hs-cpp'>#endif</span>
<a name="line-108"></a>
<a name="line-109"></a><span class='hs-definition'>pprData</span> <span class='hs-layout'>(</span><span class='hs-conid'>CmmStaticLit</span> <span class='hs-varid'>lit</span><span class='hs-layout'>)</span>       <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprDataItem</span> <span class='hs-varid'>lit</span>
<a name="line-110"></a>
<a name="line-111"></a><a name="pprGloblDecl"></a><span class='hs-definition'>pprGloblDecl</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>CLabel</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-112"></a><span class='hs-definition'>pprGloblDecl</span> <span class='hs-varid'>lbl</span>
<a name="line-113"></a>  <span class='hs-keyglyph'>|</span> <span class='hs-varid'>not</span> <span class='hs-layout'>(</span><span class='hs-varid'>externallyVisibleCLabel</span> <span class='hs-varid'>lbl</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>empty</span>
<a name="line-114"></a>  <span class='hs-keyglyph'>|</span> <span class='hs-varid'>otherwise</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span> <span class='hs-conid'>IF_ARCH_sparc</span><span class='hs-layout'>(</span><span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".global "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span> 
<a name="line-115"></a>				    <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".globl "</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span> <span class='hs-varop'>&lt;&gt;</span>
<a name="line-116"></a>		<span class='hs-varid'>pprCLabel_asm</span> <span class='hs-varid'>lbl</span>
<a name="line-117"></a>
<a name="line-118"></a><a name="pprTypeAndSizeDecl"></a><span class='hs-definition'>pprTypeAndSizeDecl</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>CLabel</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-119"></a><span class='hs-cpp'>#if linux_TARGET_OS</span>
<a name="line-120"></a><span class='hs-definition'>pprTypeAndSizeDecl</span> <span class='hs-varid'>lbl</span>
<a name="line-121"></a>  <span class='hs-keyglyph'>|</span> <span class='hs-varid'>not</span> <span class='hs-layout'>(</span><span class='hs-varid'>externallyVisibleCLabel</span> <span class='hs-varid'>lbl</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>empty</span>
<a name="line-122"></a>  <span class='hs-keyglyph'>|</span> <span class='hs-varid'>otherwise</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".type "</span><span class='hs-layout'>)</span> <span class='hs-varop'>&lt;&gt;</span>
<a name="line-123"></a>		<span class='hs-varid'>pprCLabel_asm</span> <span class='hs-varid'>lbl</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", @object"</span><span class='hs-layout'>)</span>
<a name="line-124"></a><span class='hs-cpp'>#else</span>
<a name="line-125"></a><span class='hs-definition'>pprTypeAndSizeDecl</span> <span class='hs-keyword'>_</span>
<a name="line-126"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>empty</span>
<a name="line-127"></a><span class='hs-cpp'>#endif</span>
<a name="line-128"></a>
<a name="line-129"></a><a name="pprLabel"></a><span class='hs-definition'>pprLabel</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>CLabel</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-130"></a><span class='hs-definition'>pprLabel</span> <span class='hs-varid'>lbl</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprGloblDecl</span> <span class='hs-varid'>lbl</span> <span class='hs-varop'>$$</span> <span class='hs-varid'>pprTypeAndSizeDecl</span> <span class='hs-varid'>lbl</span> <span class='hs-varop'>$$</span> <span class='hs-layout'>(</span><span class='hs-varid'>pprCLabel_asm</span> <span class='hs-varid'>lbl</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>':'</span><span class='hs-layout'>)</span>
<a name="line-131"></a>
<a name="line-132"></a>
<a name="line-133"></a><a name="pprASCII"></a><span class='hs-definition'>pprASCII</span> <span class='hs-keyglyph'>::</span> <span class='hs-keyglyph'>[</span><span class='hs-conid'>Word8</span><span class='hs-keyglyph'>]</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-134"></a><span class='hs-definition'>pprASCII</span> <span class='hs-varid'>str</span>
<a name="line-135"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>vcat</span> <span class='hs-layout'>(</span><span class='hs-varid'>map</span> <span class='hs-varid'>do1</span> <span class='hs-varid'>str</span><span class='hs-layout'>)</span> <span class='hs-varop'>$$</span> <span class='hs-varid'>do1</span> <span class='hs-num'>0</span>
<a name="line-136"></a>    <span class='hs-keyword'>where</span>
<a name="line-137"></a>       <span class='hs-varid'>do1</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Word8</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-138"></a>       <span class='hs-varid'>do1</span> <span class='hs-varid'>w</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\t.byte\t"</span><span class='hs-layout'>)</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>int</span> <span class='hs-layout'>(</span><span class='hs-varid'>fromIntegral</span> <span class='hs-varid'>w</span><span class='hs-layout'>)</span>
<a name="line-139"></a>
<a name="line-140"></a><a name="pprAlign"></a><span class='hs-definition'>pprAlign</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Int</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-141"></a><span class='hs-definition'>pprAlign</span> <span class='hs-varid'>bytes</span> <span class='hs-keyglyph'>=</span>
<a name="line-142"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".align "</span><span class='hs-layout'>)</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>int</span> <span class='hs-varid'>pow2</span>
<a name="line-143"></a>  <span class='hs-keyword'>where</span>
<a name="line-144"></a>	<span class='hs-varid'>pow2</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>log2</span> <span class='hs-varid'>bytes</span>
<a name="line-145"></a>	
<a name="line-146"></a>	<span class='hs-varid'>log2</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Int</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Int</span>  <span class='hs-comment'>-- cache the common ones</span>
<a name="line-147"></a>	<span class='hs-varid'>log2</span> <span class='hs-num'>1</span> <span class='hs-keyglyph'>=</span> <span class='hs-num'>0</span> 
<a name="line-148"></a>	<span class='hs-varid'>log2</span> <span class='hs-num'>2</span> <span class='hs-keyglyph'>=</span> <span class='hs-num'>1</span>
<a name="line-149"></a>	<span class='hs-varid'>log2</span> <span class='hs-num'>4</span> <span class='hs-keyglyph'>=</span> <span class='hs-num'>2</span>
<a name="line-150"></a>	<span class='hs-varid'>log2</span> <span class='hs-num'>8</span> <span class='hs-keyglyph'>=</span> <span class='hs-num'>3</span>
<a name="line-151"></a>	<span class='hs-varid'>log2</span> <span class='hs-varid'>n</span> <span class='hs-keyglyph'>=</span> <span class='hs-num'>1</span> <span class='hs-varop'>+</span> <span class='hs-varid'>log2</span> <span class='hs-layout'>(</span><span class='hs-varid'>n</span> <span class='hs-varop'>`quot`</span> <span class='hs-num'>2</span><span class='hs-layout'>)</span>
<a name="line-152"></a>
<a name="line-153"></a>
<a name="line-154"></a><span class='hs-comment'>-- -----------------------------------------------------------------------------</span>
<a name="line-155"></a><span class='hs-comment'>-- pprInstr: print an 'Instr'</span>
<a name="line-156"></a>
<a name="line-157"></a><span class='hs-keyword'>instance</span> <span class='hs-conid'>Outputable</span> <span class='hs-conid'>Instr</span> <span class='hs-keyword'>where</span>
<a name="line-158"></a>    <span class='hs-varid'>ppr</span>	 <span class='hs-varid'>instr</span>	<span class='hs-keyglyph'>=</span> <span class='hs-conid'>Outputable</span><span class='hs-varop'>.</span><span class='hs-varid'>docToSDoc</span> <span class='hs-varop'>$</span> <span class='hs-varid'>pprInstr</span> <span class='hs-varid'>instr</span>
<a name="line-159"></a>
<a name="line-160"></a>
<a name="line-161"></a><a name="pprUserReg"></a><span class='hs-definition'>pprUserReg</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Reg</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-162"></a><span class='hs-definition'>pprUserReg</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprReg</span>
<a name="line-163"></a>
<a name="line-164"></a><a name="pprReg"></a><span class='hs-definition'>pprReg</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Reg</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-165"></a>
<a name="line-166"></a><span class='hs-definition'>pprReg</span> <span class='hs-varid'>r</span>
<a name="line-167"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-keyword'>case</span> <span class='hs-varid'>r</span> <span class='hs-keyword'>of</span>
<a name="line-168"></a>      <span class='hs-conid'>RegReal</span>    <span class='hs-layout'>(</span><span class='hs-conid'>RealRegSingle</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ppr_reg_no</span> <span class='hs-varid'>i</span>
<a name="line-169"></a>      <span class='hs-conid'>RegReal</span>    <span class='hs-layout'>(</span><span class='hs-conid'>RealRegPair</span><span class='hs-layout'>{</span><span class='hs-layout'>}</span><span class='hs-layout'>)</span>   <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"PPC.pprReg: no reg pairs on this arch"</span>
<a name="line-170"></a>      <span class='hs-conid'>RegVirtual</span> <span class='hs-layout'>(</span><span class='hs-conid'>VirtualRegI</span>  <span class='hs-varid'>u</span><span class='hs-layout'>)</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>text</span> <span class='hs-str'>"%vI_"</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>asmSDoc</span> <span class='hs-layout'>(</span><span class='hs-varid'>pprUnique</span> <span class='hs-varid'>u</span><span class='hs-layout'>)</span>
<a name="line-171"></a>      <span class='hs-conid'>RegVirtual</span> <span class='hs-layout'>(</span><span class='hs-conid'>VirtualRegHi</span> <span class='hs-varid'>u</span><span class='hs-layout'>)</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>text</span> <span class='hs-str'>"%vHi_"</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>asmSDoc</span> <span class='hs-layout'>(</span><span class='hs-varid'>pprUnique</span> <span class='hs-varid'>u</span><span class='hs-layout'>)</span>
<a name="line-172"></a>      <span class='hs-conid'>RegVirtual</span> <span class='hs-layout'>(</span><span class='hs-conid'>VirtualRegF</span>  <span class='hs-varid'>u</span><span class='hs-layout'>)</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>text</span> <span class='hs-str'>"%vF_"</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>asmSDoc</span> <span class='hs-layout'>(</span><span class='hs-varid'>pprUnique</span> <span class='hs-varid'>u</span><span class='hs-layout'>)</span>
<a name="line-173"></a>      <span class='hs-conid'>RegVirtual</span> <span class='hs-layout'>(</span><span class='hs-conid'>VirtualRegD</span>  <span class='hs-varid'>u</span><span class='hs-layout'>)</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>text</span> <span class='hs-str'>"%vD_"</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>asmSDoc</span> <span class='hs-layout'>(</span><span class='hs-varid'>pprUnique</span> <span class='hs-varid'>u</span><span class='hs-layout'>)</span>
<a name="line-174"></a>  <span class='hs-keyword'>where</span>
<a name="line-175"></a><span class='hs-cpp'>#if darwin_TARGET_OS</span>
<a name="line-176"></a>    <span class='hs-varid'>ppr_reg_no</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Int</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-177"></a>    <span class='hs-varid'>ppr_reg_no</span> <span class='hs-varid'>i</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span>
<a name="line-178"></a>      <span class='hs-layout'>(</span><span class='hs-keyword'>case</span> <span class='hs-varid'>i</span> <span class='hs-keyword'>of</span> <span class='hs-layout'>{</span>
<a name="line-179"></a>	 <span class='hs-num'>0</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r0"</span><span class='hs-layout'>;</span>   <span class='hs-num'>1</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r1"</span><span class='hs-layout'>;</span>
<a name="line-180"></a>	 <span class='hs-num'>2</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r2"</span><span class='hs-layout'>;</span>   <span class='hs-num'>3</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r3"</span><span class='hs-layout'>;</span>
<a name="line-181"></a>	 <span class='hs-num'>4</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r4"</span><span class='hs-layout'>;</span>   <span class='hs-num'>5</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r5"</span><span class='hs-layout'>;</span>
<a name="line-182"></a>	 <span class='hs-num'>6</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r6"</span><span class='hs-layout'>;</span>   <span class='hs-num'>7</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r7"</span><span class='hs-layout'>;</span>
<a name="line-183"></a>	 <span class='hs-num'>8</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r8"</span><span class='hs-layout'>;</span>   <span class='hs-num'>9</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r9"</span><span class='hs-layout'>;</span>
<a name="line-184"></a>	<span class='hs-num'>10</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r10"</span><span class='hs-layout'>;</span>  <span class='hs-num'>11</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r11"</span><span class='hs-layout'>;</span>
<a name="line-185"></a>	<span class='hs-num'>12</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r12"</span><span class='hs-layout'>;</span>  <span class='hs-num'>13</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r13"</span><span class='hs-layout'>;</span>
<a name="line-186"></a>	<span class='hs-num'>14</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r14"</span><span class='hs-layout'>;</span>  <span class='hs-num'>15</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r15"</span><span class='hs-layout'>;</span>
<a name="line-187"></a>	<span class='hs-num'>16</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r16"</span><span class='hs-layout'>;</span>  <span class='hs-num'>17</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r17"</span><span class='hs-layout'>;</span>
<a name="line-188"></a>	<span class='hs-num'>18</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r18"</span><span class='hs-layout'>;</span>  <span class='hs-num'>19</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r19"</span><span class='hs-layout'>;</span>
<a name="line-189"></a>	<span class='hs-num'>20</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r20"</span><span class='hs-layout'>;</span>  <span class='hs-num'>21</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r21"</span><span class='hs-layout'>;</span>
<a name="line-190"></a>	<span class='hs-num'>22</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r22"</span><span class='hs-layout'>;</span>  <span class='hs-num'>23</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r23"</span><span class='hs-layout'>;</span>
<a name="line-191"></a>	<span class='hs-num'>24</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r24"</span><span class='hs-layout'>;</span>  <span class='hs-num'>25</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r25"</span><span class='hs-layout'>;</span>
<a name="line-192"></a>	<span class='hs-num'>26</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r26"</span><span class='hs-layout'>;</span>  <span class='hs-num'>27</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r27"</span><span class='hs-layout'>;</span>
<a name="line-193"></a>	<span class='hs-num'>28</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r28"</span><span class='hs-layout'>;</span>  <span class='hs-num'>29</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r29"</span><span class='hs-layout'>;</span>
<a name="line-194"></a>	<span class='hs-num'>30</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r30"</span><span class='hs-layout'>;</span>  <span class='hs-num'>31</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"r31"</span><span class='hs-layout'>;</span>
<a name="line-195"></a>	<span class='hs-num'>32</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f0"</span><span class='hs-layout'>;</span>  <span class='hs-num'>33</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f1"</span><span class='hs-layout'>;</span>
<a name="line-196"></a>	<span class='hs-num'>34</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f2"</span><span class='hs-layout'>;</span>  <span class='hs-num'>35</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f3"</span><span class='hs-layout'>;</span>
<a name="line-197"></a>	<span class='hs-num'>36</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f4"</span><span class='hs-layout'>;</span>  <span class='hs-num'>37</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f5"</span><span class='hs-layout'>;</span>
<a name="line-198"></a>	<span class='hs-num'>38</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f6"</span><span class='hs-layout'>;</span>  <span class='hs-num'>39</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f7"</span><span class='hs-layout'>;</span>
<a name="line-199"></a>	<span class='hs-num'>40</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f8"</span><span class='hs-layout'>;</span>  <span class='hs-num'>41</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f9"</span><span class='hs-layout'>;</span>
<a name="line-200"></a>	<span class='hs-num'>42</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f10"</span><span class='hs-layout'>;</span> <span class='hs-num'>43</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f11"</span><span class='hs-layout'>;</span>
<a name="line-201"></a>	<span class='hs-num'>44</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f12"</span><span class='hs-layout'>;</span> <span class='hs-num'>45</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f13"</span><span class='hs-layout'>;</span>
<a name="line-202"></a>	<span class='hs-num'>46</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f14"</span><span class='hs-layout'>;</span> <span class='hs-num'>47</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f15"</span><span class='hs-layout'>;</span>
<a name="line-203"></a>	<span class='hs-num'>48</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f16"</span><span class='hs-layout'>;</span> <span class='hs-num'>49</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f17"</span><span class='hs-layout'>;</span>
<a name="line-204"></a>	<span class='hs-num'>50</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f18"</span><span class='hs-layout'>;</span> <span class='hs-num'>51</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f19"</span><span class='hs-layout'>;</span>
<a name="line-205"></a>	<span class='hs-num'>52</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f20"</span><span class='hs-layout'>;</span> <span class='hs-num'>53</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f21"</span><span class='hs-layout'>;</span>
<a name="line-206"></a>	<span class='hs-num'>54</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f22"</span><span class='hs-layout'>;</span> <span class='hs-num'>55</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f23"</span><span class='hs-layout'>;</span>
<a name="line-207"></a>	<span class='hs-num'>56</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f24"</span><span class='hs-layout'>;</span> <span class='hs-num'>57</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f25"</span><span class='hs-layout'>;</span>
<a name="line-208"></a>	<span class='hs-num'>58</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f26"</span><span class='hs-layout'>;</span> <span class='hs-num'>59</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f27"</span><span class='hs-layout'>;</span>
<a name="line-209"></a>	<span class='hs-num'>60</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f28"</span><span class='hs-layout'>;</span> <span class='hs-num'>61</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f29"</span><span class='hs-layout'>;</span>
<a name="line-210"></a>	<span class='hs-num'>62</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f30"</span><span class='hs-layout'>;</span> <span class='hs-num'>63</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"f31"</span><span class='hs-layout'>;</span>
<a name="line-211"></a>	<span class='hs-keyword'>_</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"very naughty powerpc register"</span>
<a name="line-212"></a>      <span class='hs-layout'>}</span><span class='hs-layout'>)</span>
<a name="line-213"></a><span class='hs-cpp'>#else</span>
<a name="line-214"></a>    <span class='hs-varid'>ppr_reg_no</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Int</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-215"></a>    <span class='hs-varid'>ppr_reg_no</span> <span class='hs-varid'>i</span> <span class='hs-keyglyph'>|</span> <span class='hs-varid'>i</span> <span class='hs-varop'>&lt;=</span> <span class='hs-num'>31</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>int</span> <span class='hs-varid'>i</span>	<span class='hs-comment'>-- GPRs</span>
<a name="line-216"></a>                 <span class='hs-keyglyph'>|</span> <span class='hs-varid'>i</span> <span class='hs-varop'>&lt;=</span> <span class='hs-num'>63</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>int</span> <span class='hs-layout'>(</span><span class='hs-varid'>i</span><span class='hs-comment'>-</span><span class='hs-num'>32</span><span class='hs-layout'>)</span> <span class='hs-comment'>-- FPRs</span>
<a name="line-217"></a>                 <span class='hs-keyglyph'>|</span> <span class='hs-varid'>otherwise</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"very naughty powerpc register"</span><span class='hs-layout'>)</span>
<a name="line-218"></a><span class='hs-cpp'>#endif</span>
<a name="line-219"></a>
<a name="line-220"></a>
<a name="line-221"></a>
<a name="line-222"></a><a name="pprSize"></a><span class='hs-definition'>pprSize</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Size</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-223"></a><span class='hs-definition'>pprSize</span> <span class='hs-varid'>x</span> 
<a name="line-224"></a> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-keyword'>case</span> <span class='hs-varid'>x</span> <span class='hs-keyword'>of</span>
<a name="line-225"></a>		<span class='hs-conid'>II8</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"b"</span>
<a name="line-226"></a>	        <span class='hs-conid'>II16</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"h"</span>
<a name="line-227"></a>		<span class='hs-conid'>II32</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"w"</span>
<a name="line-228"></a>		<span class='hs-conid'>FF32</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"fs"</span>
<a name="line-229"></a>		<span class='hs-conid'>FF64</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"fd"</span>
<a name="line-230"></a>		<span class='hs-keyword'>_</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"PPC.Ppr.pprSize: no match"</span><span class='hs-layout'>)</span>
<a name="line-231"></a>		
<a name="line-232"></a>		
<a name="line-233"></a><a name="pprCond"></a><span class='hs-definition'>pprCond</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Cond</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-234"></a><span class='hs-definition'>pprCond</span> <span class='hs-varid'>c</span> 
<a name="line-235"></a> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-keyword'>case</span> <span class='hs-varid'>c</span> <span class='hs-keyword'>of</span> <span class='hs-layout'>{</span>
<a name="line-236"></a>		<span class='hs-conid'>ALWAYS</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>""</span><span class='hs-layout'>;</span>
<a name="line-237"></a>		<span class='hs-conid'>EQQ</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"eq"</span><span class='hs-layout'>;</span>	<span class='hs-conid'>NE</span>    <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"ne"</span><span class='hs-layout'>;</span>
<a name="line-238"></a>		<span class='hs-conid'>LTT</span>     <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"lt"</span><span class='hs-layout'>;</span>  <span class='hs-conid'>GE</span>    <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"ge"</span><span class='hs-layout'>;</span>
<a name="line-239"></a>		<span class='hs-conid'>GTT</span>     <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"gt"</span><span class='hs-layout'>;</span>  <span class='hs-conid'>LE</span>    <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"le"</span><span class='hs-layout'>;</span>
<a name="line-240"></a>		<span class='hs-conid'>LU</span>      <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"lt"</span><span class='hs-layout'>;</span>  <span class='hs-conid'>GEU</span>   <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"ge"</span><span class='hs-layout'>;</span>
<a name="line-241"></a>		<span class='hs-conid'>GU</span>      <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"gt"</span><span class='hs-layout'>;</span>  <span class='hs-conid'>LEU</span>   <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"le"</span><span class='hs-layout'>;</span> <span class='hs-layout'>}</span><span class='hs-layout'>)</span>
<a name="line-242"></a>
<a name="line-243"></a>
<a name="line-244"></a><a name="pprImm"></a><span class='hs-definition'>pprImm</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Imm</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-245"></a>
<a name="line-246"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmInt</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span>     <span class='hs-keyglyph'>=</span> <span class='hs-varid'>int</span> <span class='hs-varid'>i</span>
<a name="line-247"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmInteger</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>integer</span> <span class='hs-varid'>i</span>
<a name="line-248"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmCLbl</span> <span class='hs-varid'>l</span><span class='hs-layout'>)</span>    <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprCLabel_asm</span> <span class='hs-varid'>l</span>
<a name="line-249"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmIndex</span> <span class='hs-varid'>l</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprCLabel_asm</span> <span class='hs-varid'>l</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'+'</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>int</span> <span class='hs-varid'>i</span>
<a name="line-250"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmLit</span> <span class='hs-varid'>s</span><span class='hs-layout'>)</span>     <span class='hs-keyglyph'>=</span> <span class='hs-varid'>s</span>
<a name="line-251"></a>
<a name="line-252"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmFloat</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"naughty float immediate"</span><span class='hs-layout'>)</span>
<a name="line-253"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmDouble</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"naughty double immediate"</span><span class='hs-layout'>)</span>
<a name="line-254"></a>
<a name="line-255"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmConstantSum</span> <span class='hs-varid'>a</span> <span class='hs-varid'>b</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>a</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'+'</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>b</span>
<a name="line-256"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmConstantDiff</span> <span class='hs-varid'>a</span> <span class='hs-varid'>b</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>a</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'-'</span>
<a name="line-257"></a>                            <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>lparen</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>b</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>rparen</span>
<a name="line-258"></a>
<a name="line-259"></a><span class='hs-cpp'>#if darwin_TARGET_OS</span>
<a name="line-260"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>LO</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span>
<a name="line-261"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-varid'>pp_lo</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>i</span><span class='hs-layout'>,</span> <span class='hs-varid'>rparen</span> <span class='hs-keyglyph'>]</span>
<a name="line-262"></a>  <span class='hs-keyword'>where</span>
<a name="line-263"></a>    <span class='hs-varid'>pp_lo</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>text</span> <span class='hs-str'>"lo16("</span>
<a name="line-264"></a>
<a name="line-265"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>HI</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span>
<a name="line-266"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-varid'>pp_hi</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>i</span><span class='hs-layout'>,</span> <span class='hs-varid'>rparen</span> <span class='hs-keyglyph'>]</span>
<a name="line-267"></a>  <span class='hs-keyword'>where</span>
<a name="line-268"></a>    <span class='hs-varid'>pp_hi</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>text</span> <span class='hs-str'>"hi16("</span>
<a name="line-269"></a>
<a name="line-270"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>HA</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span>
<a name="line-271"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-varid'>pp_ha</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>i</span><span class='hs-layout'>,</span> <span class='hs-varid'>rparen</span> <span class='hs-keyglyph'>]</span>
<a name="line-272"></a>  <span class='hs-keyword'>where</span>
<a name="line-273"></a>    <span class='hs-varid'>pp_ha</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>text</span> <span class='hs-str'>"ha16("</span>
<a name="line-274"></a>    
<a name="line-275"></a><span class='hs-cpp'>#else</span>
<a name="line-276"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>LO</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span>
<a name="line-277"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>i</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>text</span> <span class='hs-str'>"@l"</span>
<a name="line-278"></a>
<a name="line-279"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>HI</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span>
<a name="line-280"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>i</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>text</span> <span class='hs-str'>"@h"</span>
<a name="line-281"></a>
<a name="line-282"></a><span class='hs-definition'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>HA</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span>
<a name="line-283"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>i</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>text</span> <span class='hs-str'>"@ha"</span>
<a name="line-284"></a><span class='hs-cpp'>#endif</span>
<a name="line-285"></a>
<a name="line-286"></a>
<a name="line-287"></a>
<a name="line-288"></a><a name="pprAddr"></a><span class='hs-definition'>pprAddr</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>AddrMode</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-289"></a><span class='hs-definition'>pprAddr</span> <span class='hs-layout'>(</span><span class='hs-conid'>AddrRegReg</span> <span class='hs-varid'>r1</span> <span class='hs-varid'>r2</span><span class='hs-layout'>)</span>
<a name="line-290"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>r1</span> <span class='hs-varop'>&lt;+&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span> <span class='hs-varop'>&lt;+&gt;</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>r2</span>
<a name="line-291"></a>
<a name="line-292"></a><span class='hs-definition'>pprAddr</span> <span class='hs-layout'>(</span><span class='hs-conid'>AddrRegImm</span> <span class='hs-varid'>r1</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmInt</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-varid'>int</span> <span class='hs-varid'>i</span><span class='hs-layout'>,</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'('</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>r1</span><span class='hs-layout'>,</span> <span class='hs-varid'>char</span> <span class='hs-chr'>')'</span> <span class='hs-keyglyph'>]</span>
<a name="line-293"></a><span class='hs-definition'>pprAddr</span> <span class='hs-layout'>(</span><span class='hs-conid'>AddrRegImm</span> <span class='hs-varid'>r1</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmInteger</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-varid'>integer</span> <span class='hs-varid'>i</span><span class='hs-layout'>,</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'('</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>r1</span><span class='hs-layout'>,</span> <span class='hs-varid'>char</span> <span class='hs-chr'>')'</span> <span class='hs-keyglyph'>]</span>
<a name="line-294"></a><span class='hs-definition'>pprAddr</span> <span class='hs-layout'>(</span><span class='hs-conid'>AddrRegImm</span> <span class='hs-varid'>r1</span> <span class='hs-varid'>imm</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>imm</span><span class='hs-layout'>,</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'('</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>r1</span><span class='hs-layout'>,</span> <span class='hs-varid'>char</span> <span class='hs-chr'>')'</span> <span class='hs-keyglyph'>]</span>
<a name="line-295"></a>
<a name="line-296"></a>
<a name="line-297"></a><a name="pprSectionHeader"></a><span class='hs-definition'>pprSectionHeader</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Section</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-298"></a><span class='hs-cpp'>#if darwin_TARGET_OS </span>
<a name="line-299"></a><span class='hs-definition'>pprSectionHeader</span> <span class='hs-varid'>seg</span>
<a name="line-300"></a> <span class='hs-keyglyph'>=</span> <span class='hs-keyword'>case</span> <span class='hs-varid'>seg</span> <span class='hs-keyword'>of</span>
<a name="line-301"></a> 	<span class='hs-conid'>Text</span>			<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".text\n.align 2"</span><span class='hs-layout'>)</span>
<a name="line-302"></a>	<span class='hs-conid'>Data</span>			<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".data\n.align 2"</span><span class='hs-layout'>)</span>
<a name="line-303"></a>	<span class='hs-conid'>ReadOnlyData</span>		<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".const\n.align 2"</span><span class='hs-layout'>)</span>
<a name="line-304"></a>	<span class='hs-conid'>RelocatableReadOnlyData</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".const_data\n.align 2"</span><span class='hs-layout'>)</span>
<a name="line-305"></a>	<span class='hs-conid'>UninitialisedData</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".const_data\n.align 2"</span><span class='hs-layout'>)</span>
<a name="line-306"></a>	<span class='hs-conid'>ReadOnlyData16</span>		<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".const\n.align 4"</span><span class='hs-layout'>)</span>
<a name="line-307"></a>	<span class='hs-conid'>OtherSection</span> <span class='hs-keyword'>_</span>		<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"PprMach.pprSectionHeader: unknown section"</span>
<a name="line-308"></a>
<a name="line-309"></a><span class='hs-cpp'>#else</span>
<a name="line-310"></a><span class='hs-definition'>pprSectionHeader</span> <span class='hs-varid'>seg</span>
<a name="line-311"></a> <span class='hs-keyglyph'>=</span> <span class='hs-keyword'>case</span> <span class='hs-varid'>seg</span> <span class='hs-keyword'>of</span>
<a name="line-312"></a> 	<span class='hs-conid'>Text</span>			<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".text\n.align 2"</span><span class='hs-layout'>)</span>
<a name="line-313"></a>	<span class='hs-conid'>Data</span>			<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".data\n.align 2"</span><span class='hs-layout'>)</span>
<a name="line-314"></a>	<span class='hs-conid'>ReadOnlyData</span>		<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".section .rodata\n\t.align 2"</span><span class='hs-layout'>)</span>
<a name="line-315"></a>	<span class='hs-conid'>RelocatableReadOnlyData</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".data\n\t.align 2"</span><span class='hs-layout'>)</span>
<a name="line-316"></a>	<span class='hs-conid'>UninitialisedData</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".section .bss\n\t.align 2"</span><span class='hs-layout'>)</span>
<a name="line-317"></a>	<span class='hs-conid'>ReadOnlyData16</span>		<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>".section .rodata\n\t.align 4"</span><span class='hs-layout'>)</span>
<a name="line-318"></a>	<span class='hs-conid'>OtherSection</span> <span class='hs-keyword'>_</span>		<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"PprMach.pprSectionHeader: unknown section"</span>
<a name="line-319"></a>
<a name="line-320"></a><span class='hs-cpp'>#endif</span>
<a name="line-321"></a>
<a name="line-322"></a>
<a name="line-323"></a><a name="pprDataItem"></a><span class='hs-definition'>pprDataItem</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>CmmLit</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-324"></a><span class='hs-definition'>pprDataItem</span> <span class='hs-varid'>lit</span>
<a name="line-325"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>vcat</span> <span class='hs-layout'>(</span><span class='hs-varid'>ppr_item</span> <span class='hs-layout'>(</span><span class='hs-varid'>cmmTypeSize</span> <span class='hs-varop'>$</span> <span class='hs-varid'>cmmLitType</span> <span class='hs-varid'>lit</span><span class='hs-layout'>)</span> <span class='hs-varid'>lit</span><span class='hs-layout'>)</span>
<a name="line-326"></a>    <span class='hs-keyword'>where</span>
<a name="line-327"></a>	<span class='hs-varid'>imm</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>litToImm</span> <span class='hs-varid'>lit</span>
<a name="line-328"></a>
<a name="line-329"></a>	<span class='hs-varid'>ppr_item</span> <span class='hs-conid'>II8</span>   <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>=</span> <span class='hs-keyglyph'>[</span><span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\t.byte\t"</span><span class='hs-layout'>)</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>imm</span><span class='hs-keyglyph'>]</span>
<a name="line-330"></a>
<a name="line-331"></a>	<span class='hs-varid'>ppr_item</span> <span class='hs-conid'>II32</span>  <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>=</span> <span class='hs-keyglyph'>[</span><span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\t.long\t"</span><span class='hs-layout'>)</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>imm</span><span class='hs-keyglyph'>]</span>
<a name="line-332"></a>
<a name="line-333"></a>	<span class='hs-varid'>ppr_item</span> <span class='hs-conid'>FF32</span> <span class='hs-layout'>(</span><span class='hs-conid'>CmmFloat</span> <span class='hs-varid'>r</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span>
<a name="line-334"></a>           <span class='hs-keyglyph'>=</span> <span class='hs-keyword'>let</span> <span class='hs-varid'>bs</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>floatToBytes</span> <span class='hs-layout'>(</span><span class='hs-varid'>fromRational</span> <span class='hs-varid'>r</span><span class='hs-layout'>)</span>
<a name="line-335"></a>             <span class='hs-keyword'>in</span>  <span class='hs-varid'>map</span> <span class='hs-layout'>(</span><span class='hs-keyglyph'>\</span><span class='hs-varid'>b</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\t.byte\t"</span><span class='hs-layout'>)</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmInt</span> <span class='hs-varid'>b</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span> <span class='hs-varid'>bs</span>
<a name="line-336"></a>
<a name="line-337"></a>    	<span class='hs-varid'>ppr_item</span> <span class='hs-conid'>FF64</span> <span class='hs-layout'>(</span><span class='hs-conid'>CmmFloat</span> <span class='hs-varid'>r</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span>
<a name="line-338"></a>           <span class='hs-keyglyph'>=</span> <span class='hs-keyword'>let</span> <span class='hs-varid'>bs</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>doubleToBytes</span> <span class='hs-layout'>(</span><span class='hs-varid'>fromRational</span> <span class='hs-varid'>r</span><span class='hs-layout'>)</span>
<a name="line-339"></a>             <span class='hs-keyword'>in</span>  <span class='hs-varid'>map</span> <span class='hs-layout'>(</span><span class='hs-keyglyph'>\</span><span class='hs-varid'>b</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\t.byte\t"</span><span class='hs-layout'>)</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>pprImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmInt</span> <span class='hs-varid'>b</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span> <span class='hs-varid'>bs</span>
<a name="line-340"></a>
<a name="line-341"></a>	<span class='hs-varid'>ppr_item</span> <span class='hs-conid'>II16</span> <span class='hs-keyword'>_</span>	<span class='hs-keyglyph'>=</span> <span class='hs-keyglyph'>[</span><span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\t.short\t"</span><span class='hs-layout'>)</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>imm</span><span class='hs-keyglyph'>]</span>
<a name="line-342"></a>
<a name="line-343"></a>        <span class='hs-varid'>ppr_item</span> <span class='hs-conid'>II64</span> <span class='hs-layout'>(</span><span class='hs-conid'>CmmInt</span> <span class='hs-varid'>x</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span>  <span class='hs-keyglyph'>=</span>
<a name="line-344"></a>                <span class='hs-keyglyph'>[</span><span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\t.long\t"</span><span class='hs-layout'>)</span>
<a name="line-345"></a>                    <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>int</span> <span class='hs-layout'>(</span><span class='hs-varid'>fromIntegral</span> 
<a name="line-346"></a>                        <span class='hs-layout'>(</span><span class='hs-varid'>fromIntegral</span> <span class='hs-layout'>(</span><span class='hs-varid'>x</span> <span class='hs-varop'>`shiftR`</span> <span class='hs-num'>32</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Word32</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-347"></a>                 <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\t.long\t"</span><span class='hs-layout'>)</span>
<a name="line-348"></a>                    <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>int</span> <span class='hs-layout'>(</span><span class='hs-varid'>fromIntegral</span> <span class='hs-layout'>(</span><span class='hs-varid'>fromIntegral</span> <span class='hs-varid'>x</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Word32</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span><span class='hs-keyglyph'>]</span>
<a name="line-349"></a>
<a name="line-350"></a>	<span class='hs-varid'>ppr_item</span> <span class='hs-keyword'>_</span> <span class='hs-keyword'>_</span>
<a name="line-351"></a>		<span class='hs-keyglyph'>=</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"PPC.Ppr.pprDataItem: no match"</span>
<a name="line-352"></a>
<a name="line-353"></a>
<a name="line-354"></a><a name="pprInstr"></a><span class='hs-definition'>pprInstr</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Instr</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-355"></a>
<a name="line-356"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>COMMENT</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>empty</span> <span class='hs-comment'>-- nuke 'em</span>
<a name="line-357"></a><span class='hs-comment'>{-
<a name="line-358"></a>pprInstr (COMMENT s)
<a name="line-359"></a>   =  IF_ARCH_alpha( ((&lt;&gt;) (ptext (sLit "\t# ")) (ftext s))
<a name="line-360"></a>     ,IF_ARCH_sparc( ((&lt;&gt;) (ptext (sLit "# "))   (ftext s))
<a name="line-361"></a>     ,IF_ARCH_i386( ((&lt;&gt;) (ptext (sLit "# "))   (ftext s))
<a name="line-362"></a>     ,IF_ARCH_x86_64( ((&lt;&gt;) (ptext (sLit "# "))   (ftext s))
<a name="line-363"></a>     ,IF_ARCH_powerpc( IF_OS_linux(
<a name="line-364"></a>        ((&lt;&gt;) (ptext (sLit "# ")) (ftext s)),
<a name="line-365"></a>        ((&lt;&gt;) (ptext (sLit "; ")) (ftext s)))
<a name="line-366"></a>     ,)))))
<a name="line-367"></a>-}</span>
<a name="line-368"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>DELTA</span> <span class='hs-varid'>d</span><span class='hs-layout'>)</span>
<a name="line-369"></a>   <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>COMMENT</span> <span class='hs-layout'>(</span><span class='hs-varid'>mkFastString</span> <span class='hs-layout'>(</span><span class='hs-str'>"\tdelta = "</span> <span class='hs-varop'>++</span> <span class='hs-varid'>show</span> <span class='hs-varid'>d</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span>
<a name="line-370"></a>
<a name="line-371"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>NEWBLOCK</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span>
<a name="line-372"></a>   <span class='hs-keyglyph'>=</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"PprMach.pprInstr: NEWBLOCK"</span>
<a name="line-373"></a>
<a name="line-374"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>LDATA</span> <span class='hs-keyword'>_</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span>
<a name="line-375"></a>   <span class='hs-keyglyph'>=</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"PprMach.pprInstr: LDATA"</span>
<a name="line-376"></a>
<a name="line-377"></a><span class='hs-comment'>{-
<a name="line-378"></a>pprInstr (SPILL reg slot)
<a name="line-379"></a>   = hcat [
<a name="line-380"></a>   	ptext (sLit "\tSPILL"),
<a name="line-381"></a>	char '\t',
<a name="line-382"></a>	pprReg reg,
<a name="line-383"></a>	comma,
<a name="line-384"></a>	ptext (sLit "SLOT") &lt;&gt; parens (int slot)]
<a name="line-385"></a>
<a name="line-386"></a>pprInstr (RELOAD slot reg)
<a name="line-387"></a>   = hcat [
<a name="line-388"></a>   	ptext (sLit "\tRELOAD"),
<a name="line-389"></a>	char '\t',
<a name="line-390"></a>	ptext (sLit "SLOT") &lt;&gt; parens (int slot),
<a name="line-391"></a>	comma,
<a name="line-392"></a>	pprReg reg]
<a name="line-393"></a>-}</span>
<a name="line-394"></a>
<a name="line-395"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>LD</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg</span> <span class='hs-varid'>addr</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-396"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-397"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"l"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-398"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-keyword'>case</span> <span class='hs-varid'>sz</span> <span class='hs-keyword'>of</span>
<a name="line-399"></a>	    <span class='hs-conid'>II8</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"bz"</span>
<a name="line-400"></a>	    <span class='hs-conid'>II16</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"hz"</span>
<a name="line-401"></a>	    <span class='hs-conid'>II32</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"wz"</span>
<a name="line-402"></a>	    <span class='hs-conid'>FF32</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"fs"</span>
<a name="line-403"></a>	    <span class='hs-conid'>FF64</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"fd"</span>
<a name="line-404"></a>	    <span class='hs-keyword'>_</span>	 <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"PPC.Ppr.pprInstr: no match"</span>
<a name="line-405"></a>	    <span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-406"></a>        <span class='hs-keyword'>case</span> <span class='hs-varid'>addr</span> <span class='hs-keyword'>of</span> <span class='hs-conid'>AddrRegImm</span> <span class='hs-keyword'>_</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>empty</span>
<a name="line-407"></a>                     <span class='hs-conid'>AddrRegReg</span> <span class='hs-keyword'>_</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'x'</span><span class='hs-layout'>,</span>
<a name="line-408"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-409"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span><span class='hs-layout'>,</span>
<a name="line-410"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-411"></a>	<span class='hs-varid'>pprAddr</span> <span class='hs-varid'>addr</span>
<a name="line-412"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-413"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>LA</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg</span> <span class='hs-varid'>addr</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-414"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-415"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"l"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-416"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-keyword'>case</span> <span class='hs-varid'>sz</span> <span class='hs-keyword'>of</span>
<a name="line-417"></a>	    <span class='hs-conid'>II8</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"ba"</span>
<a name="line-418"></a>	    <span class='hs-conid'>II16</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"ha"</span>
<a name="line-419"></a>	    <span class='hs-conid'>II32</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"wa"</span>
<a name="line-420"></a>	    <span class='hs-conid'>FF32</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"fs"</span>
<a name="line-421"></a>	    <span class='hs-conid'>FF64</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"fd"</span>
<a name="line-422"></a>	    <span class='hs-keyword'>_</span>	 <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"PPC.Ppr.pprInstr: no match"</span>
<a name="line-423"></a>	    <span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-424"></a>        <span class='hs-keyword'>case</span> <span class='hs-varid'>addr</span> <span class='hs-keyword'>of</span> <span class='hs-conid'>AddrRegImm</span> <span class='hs-keyword'>_</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>empty</span>
<a name="line-425"></a>                     <span class='hs-conid'>AddrRegReg</span> <span class='hs-keyword'>_</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'x'</span><span class='hs-layout'>,</span>
<a name="line-426"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-427"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span><span class='hs-layout'>,</span>
<a name="line-428"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-429"></a>	<span class='hs-varid'>pprAddr</span> <span class='hs-varid'>addr</span>
<a name="line-430"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-431"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>ST</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg</span> <span class='hs-varid'>addr</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-432"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-433"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"st"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-434"></a>	<span class='hs-varid'>pprSize</span> <span class='hs-varid'>sz</span><span class='hs-layout'>,</span>
<a name="line-435"></a>        <span class='hs-keyword'>case</span> <span class='hs-varid'>addr</span> <span class='hs-keyword'>of</span> <span class='hs-conid'>AddrRegImm</span> <span class='hs-keyword'>_</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>empty</span>
<a name="line-436"></a>                     <span class='hs-conid'>AddrRegReg</span> <span class='hs-keyword'>_</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'x'</span><span class='hs-layout'>,</span>
<a name="line-437"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-438"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span><span class='hs-layout'>,</span>
<a name="line-439"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-440"></a>	<span class='hs-varid'>pprAddr</span> <span class='hs-varid'>addr</span>
<a name="line-441"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-442"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>STU</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg</span> <span class='hs-varid'>addr</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-443"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-444"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"st"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-445"></a>	<span class='hs-varid'>pprSize</span> <span class='hs-varid'>sz</span><span class='hs-layout'>,</span>
<a name="line-446"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"u\t"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-447"></a>        <span class='hs-keyword'>case</span> <span class='hs-varid'>addr</span> <span class='hs-keyword'>of</span> <span class='hs-conid'>AddrRegImm</span> <span class='hs-keyword'>_</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>empty</span>
<a name="line-448"></a>                     <span class='hs-conid'>AddrRegReg</span> <span class='hs-keyword'>_</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'x'</span><span class='hs-layout'>,</span>
<a name="line-449"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span><span class='hs-layout'>,</span>
<a name="line-450"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-451"></a>	<span class='hs-varid'>pprAddr</span> <span class='hs-varid'>addr</span>
<a name="line-452"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-453"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>LIS</span> <span class='hs-varid'>reg</span> <span class='hs-varid'>imm</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-454"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-455"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"lis"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-456"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-457"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span><span class='hs-layout'>,</span>
<a name="line-458"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-459"></a>	<span class='hs-varid'>pprImm</span> <span class='hs-varid'>imm</span>
<a name="line-460"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-461"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>LI</span> <span class='hs-varid'>reg</span> <span class='hs-varid'>imm</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-462"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-463"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"li"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-464"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-465"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span><span class='hs-layout'>,</span>
<a name="line-466"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-467"></a>	<span class='hs-varid'>pprImm</span> <span class='hs-varid'>imm</span>
<a name="line-468"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-469"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>MR</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span> 
<a name="line-470"></a>    <span class='hs-keyglyph'>|</span> <span class='hs-varid'>reg1</span> <span class='hs-varop'>==</span> <span class='hs-varid'>reg2</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>empty</span>
<a name="line-471"></a>    <span class='hs-keyglyph'>|</span> <span class='hs-varid'>otherwise</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-472"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-473"></a>	<span class='hs-keyword'>case</span> <span class='hs-varid'>targetClassOfReg</span> <span class='hs-varid'>reg1</span> <span class='hs-keyword'>of</span>
<a name="line-474"></a>	    <span class='hs-conid'>RcInteger</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"mr"</span><span class='hs-layout'>)</span>
<a name="line-475"></a>	    <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"fmr"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-476"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-477"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span>
<a name="line-478"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-479"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span>
<a name="line-480"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-481"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>CMP</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg</span> <span class='hs-varid'>ri</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-482"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-483"></a>	<span class='hs-varid'>op</span><span class='hs-layout'>,</span>
<a name="line-484"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-485"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span><span class='hs-layout'>,</span>
<a name="line-486"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-487"></a>	<span class='hs-varid'>pprRI</span> <span class='hs-varid'>ri</span>
<a name="line-488"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-489"></a>    <span class='hs-keyword'>where</span>
<a name="line-490"></a>	<span class='hs-varid'>op</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-491"></a>		<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"cmp"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-492"></a>		<span class='hs-varid'>pprSize</span> <span class='hs-varid'>sz</span><span class='hs-layout'>,</span>
<a name="line-493"></a>		<span class='hs-keyword'>case</span> <span class='hs-varid'>ri</span> <span class='hs-keyword'>of</span>
<a name="line-494"></a>		    <span class='hs-conid'>RIReg</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>empty</span>
<a name="line-495"></a>		    <span class='hs-conid'>RIImm</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'i'</span>
<a name="line-496"></a>	    <span class='hs-keyglyph'>]</span>
<a name="line-497"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>CMPL</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg</span> <span class='hs-varid'>ri</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-498"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-499"></a>	<span class='hs-varid'>op</span><span class='hs-layout'>,</span>
<a name="line-500"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-501"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span><span class='hs-layout'>,</span>
<a name="line-502"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-503"></a>	<span class='hs-varid'>pprRI</span> <span class='hs-varid'>ri</span>
<a name="line-504"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-505"></a>    <span class='hs-keyword'>where</span>
<a name="line-506"></a>	<span class='hs-varid'>op</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-507"></a>		<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"cmpl"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-508"></a>		<span class='hs-varid'>pprSize</span> <span class='hs-varid'>sz</span><span class='hs-layout'>,</span>
<a name="line-509"></a>		<span class='hs-keyword'>case</span> <span class='hs-varid'>ri</span> <span class='hs-keyword'>of</span>
<a name="line-510"></a>		    <span class='hs-conid'>RIReg</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>empty</span>
<a name="line-511"></a>		    <span class='hs-conid'>RIImm</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'i'</span>
<a name="line-512"></a>	    <span class='hs-keyglyph'>]</span>
<a name="line-513"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>BCC</span> <span class='hs-varid'>cond</span> <span class='hs-layout'>(</span><span class='hs-conid'>BlockId</span> <span class='hs-varid'>id</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-514"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-515"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"b"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-516"></a>	<span class='hs-varid'>pprCond</span> <span class='hs-varid'>cond</span><span class='hs-layout'>,</span>
<a name="line-517"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-518"></a>	<span class='hs-varid'>pprCLabel_asm</span> <span class='hs-varid'>lbl</span>
<a name="line-519"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-520"></a>    <span class='hs-keyword'>where</span> <span class='hs-varid'>lbl</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>mkAsmTempLabel</span> <span class='hs-varid'>id</span>
<a name="line-521"></a>
<a name="line-522"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>BCCFAR</span> <span class='hs-varid'>cond</span> <span class='hs-layout'>(</span><span class='hs-conid'>BlockId</span> <span class='hs-varid'>id</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>vcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-523"></a>        <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-524"></a>            <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\tb"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-525"></a>            <span class='hs-varid'>pprCond</span> <span class='hs-layout'>(</span><span class='hs-varid'>condNegate</span> <span class='hs-varid'>cond</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-526"></a>            <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\t$+8"</span><span class='hs-layout'>)</span>
<a name="line-527"></a>        <span class='hs-keyglyph'>]</span><span class='hs-layout'>,</span>
<a name="line-528"></a>        <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-529"></a>            <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\tb\t"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-530"></a>            <span class='hs-varid'>pprCLabel_asm</span> <span class='hs-varid'>lbl</span>
<a name="line-531"></a>        <span class='hs-keyglyph'>]</span>
<a name="line-532"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-533"></a>    <span class='hs-keyword'>where</span> <span class='hs-varid'>lbl</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>mkAsmTempLabel</span> <span class='hs-varid'>id</span>
<a name="line-534"></a>
<a name="line-535"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>JMP</span> <span class='hs-varid'>lbl</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-comment'>-- an alias for b that takes a CLabel</span>
<a name="line-536"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-537"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"b"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-538"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-539"></a>	<span class='hs-varid'>pprCLabel_asm</span> <span class='hs-varid'>lbl</span>
<a name="line-540"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-541"></a>
<a name="line-542"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>MTCTR</span> <span class='hs-varid'>reg</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-543"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-544"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"mtctr"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-545"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-546"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span>
<a name="line-547"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-548"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>BCTR</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-549"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-550"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"bctr"</span><span class='hs-layout'>)</span>
<a name="line-551"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-552"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>BL</span> <span class='hs-varid'>lbl</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-553"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\tbl\t"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-554"></a>        <span class='hs-varid'>pprCLabel_asm</span> <span class='hs-varid'>lbl</span>
<a name="line-555"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-556"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>BCTRL</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-557"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-558"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"bctrl"</span><span class='hs-layout'>)</span>
<a name="line-559"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-560"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>ADD</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLogic</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"add"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span>
<a name="line-561"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>ADDIS</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>imm</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-562"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-563"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"addis"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-564"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-565"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span>
<a name="line-566"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-567"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>,</span>
<a name="line-568"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-569"></a>	<span class='hs-varid'>pprImm</span> <span class='hs-varid'>imm</span>
<a name="line-570"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-571"></a>
<a name="line-572"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>ADDC</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLogic</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"addc"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-layout'>(</span><span class='hs-conid'>RIReg</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span>
<a name="line-573"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>ADDE</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLogic</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"adde"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-layout'>(</span><span class='hs-conid'>RIReg</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span>
<a name="line-574"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>SUBF</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLogic</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"subf"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-layout'>(</span><span class='hs-conid'>RIReg</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span>
<a name="line-575"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>MULLW</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span><span class='hs-keyglyph'>@</span><span class='hs-layout'>(</span><span class='hs-conid'>RIReg</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLogic</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"mullw"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span>
<a name="line-576"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>MULLW</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span><span class='hs-keyglyph'>@</span><span class='hs-layout'>(</span><span class='hs-conid'>RIImm</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLogic</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"mull"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span>
<a name="line-577"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>DIVW</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLogic</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"divw"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-layout'>(</span><span class='hs-conid'>RIReg</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span>
<a name="line-578"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>DIVWU</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLogic</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"divwu"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-layout'>(</span><span class='hs-conid'>RIReg</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span>
<a name="line-579"></a>
<a name="line-580"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>MULLW_MayOflo</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>vcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-581"></a>         <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\tmullwo\t"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-582"></a>                                          <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>,</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-583"></a>                                          <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg3</span> <span class='hs-keyglyph'>]</span><span class='hs-layout'>,</span>
<a name="line-584"></a>         <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\tmfxer\t"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>  <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span> <span class='hs-keyglyph'>]</span><span class='hs-layout'>,</span>
<a name="line-585"></a>         <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\trlwinm\t"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-586"></a>                                          <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-587"></a>                                          <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"2, 31, 31"</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>]</span>
<a name="line-588"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-589"></a>
<a name="line-590"></a>    	<span class='hs-comment'>-- for some reason, "andi" doesn't exist.</span>
<a name="line-591"></a>	<span class='hs-comment'>-- we'll use "andi." instead.</span>
<a name="line-592"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>AND</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-layout'>(</span><span class='hs-conid'>RIImm</span> <span class='hs-varid'>imm</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-593"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-594"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"andi."</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-595"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-596"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span>
<a name="line-597"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-598"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>,</span>
<a name="line-599"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-600"></a>	<span class='hs-varid'>pprImm</span> <span class='hs-varid'>imm</span>
<a name="line-601"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-602"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>AND</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLogic</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"and"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span>
<a name="line-603"></a>
<a name="line-604"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>OR</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLogic</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"or"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span>
<a name="line-605"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>XOR</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLogic</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"xor"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span>
<a name="line-606"></a>
<a name="line-607"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>XORIS</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>imm</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-608"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-609"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"xoris"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-610"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-611"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span>
<a name="line-612"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-613"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>,</span>
<a name="line-614"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-615"></a>	<span class='hs-varid'>pprImm</span> <span class='hs-varid'>imm</span>
<a name="line-616"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-617"></a>
<a name="line-618"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>EXTS</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-619"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-620"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"exts"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-621"></a>	<span class='hs-varid'>pprSize</span> <span class='hs-varid'>sz</span><span class='hs-layout'>,</span>
<a name="line-622"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-623"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span>
<a name="line-624"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-625"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span>
<a name="line-626"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-627"></a>
<a name="line-628"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>NEG</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprUnary</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"neg"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span>
<a name="line-629"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>NOT</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprUnary</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"not"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span>
<a name="line-630"></a>
<a name="line-631"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>SLW</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLogic</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"slw"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-layout'>(</span><span class='hs-varid'>limitShiftRI</span> <span class='hs-varid'>ri</span><span class='hs-layout'>)</span>
<a name="line-632"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>SRW</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLogic</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"srw"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-layout'>(</span><span class='hs-varid'>limitShiftRI</span> <span class='hs-varid'>ri</span><span class='hs-layout'>)</span>
<a name="line-633"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>SRAW</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprLogic</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"sraw"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-layout'>(</span><span class='hs-varid'>limitShiftRI</span> <span class='hs-varid'>ri</span><span class='hs-layout'>)</span>
<a name="line-634"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>RLWINM</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>sh</span> <span class='hs-varid'>mb</span> <span class='hs-varid'>me</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-635"></a>        <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\trlwinm\t"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-636"></a>        <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span>
<a name="line-637"></a>        <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-638"></a>        <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>,</span>
<a name="line-639"></a>        <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-640"></a>        <span class='hs-varid'>int</span> <span class='hs-varid'>sh</span><span class='hs-layout'>,</span>
<a name="line-641"></a>        <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-642"></a>        <span class='hs-varid'>int</span> <span class='hs-varid'>mb</span><span class='hs-layout'>,</span>
<a name="line-643"></a>        <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-644"></a>        <span class='hs-varid'>int</span> <span class='hs-varid'>me</span>
<a name="line-645"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-646"></a>    
<a name="line-647"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FADD</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprBinaryF</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"fadd"</span><span class='hs-layout'>)</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span>
<a name="line-648"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FSUB</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprBinaryF</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"fsub"</span><span class='hs-layout'>)</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span>
<a name="line-649"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FMUL</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprBinaryF</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"fmul"</span><span class='hs-layout'>)</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span>
<a name="line-650"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FDIV</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprBinaryF</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"fdiv"</span><span class='hs-layout'>)</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span>
<a name="line-651"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FNEG</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprUnary</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"fneg"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span>
<a name="line-652"></a>
<a name="line-653"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FCMP</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-654"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-655"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"fcmpu\tcr0, "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-656"></a>	    <span class='hs-comment'>-- Note: we're using fcmpu, not fcmpo</span>
<a name="line-657"></a>	    <span class='hs-comment'>-- The difference is with fcmpo, compare with NaN is an invalid operation.</span>
<a name="line-658"></a>	    <span class='hs-comment'>-- We don't handle invalid fp ops, so we don't care</span>
<a name="line-659"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span>
<a name="line-660"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-661"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span>
<a name="line-662"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-663"></a>
<a name="line-664"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FCTIWZ</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprUnary</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"fctiwz"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span>
<a name="line-665"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FRSP</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprUnary</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"frsp"</span><span class='hs-layout'>)</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span>
<a name="line-666"></a>
<a name="line-667"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>CRNOR</span> <span class='hs-varid'>dst</span> <span class='hs-varid'>src1</span> <span class='hs-varid'>src2</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-668"></a>        <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\tcrnor\t"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-669"></a>        <span class='hs-varid'>int</span> <span class='hs-varid'>dst</span><span class='hs-layout'>,</span>
<a name="line-670"></a>        <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-671"></a>        <span class='hs-varid'>int</span> <span class='hs-varid'>src1</span><span class='hs-layout'>,</span>
<a name="line-672"></a>        <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-673"></a>        <span class='hs-varid'>int</span> <span class='hs-varid'>src2</span>
<a name="line-674"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-675"></a>
<a name="line-676"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>MFCR</span> <span class='hs-varid'>reg</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-677"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-678"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"mfcr"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-679"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-680"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span>
<a name="line-681"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-682"></a>
<a name="line-683"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>MFLR</span> <span class='hs-varid'>reg</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-684"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-685"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"mflr"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-686"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-687"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span>
<a name="line-688"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-689"></a>
<a name="line-690"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FETCHPC</span> <span class='hs-varid'>reg</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>vcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-691"></a>        <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\tbcl\t20,31,1f"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-692"></a>        <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"1:\tmflr\t"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span> <span class='hs-keyglyph'>]</span>
<a name="line-693"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-694"></a>
<a name="line-695"></a><span class='hs-definition'>pprInstr</span> <span class='hs-conid'>LWSYNC</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\tlwsync"</span><span class='hs-layout'>)</span>
<a name="line-696"></a>
<a name="line-697"></a><span class='hs-comment'>-- pprInstr _ = panic "pprInstr (ppc)"</span>
<a name="line-698"></a>
<a name="line-699"></a>
<a name="line-700"></a><a name="pprLogic"></a><span class='hs-definition'>pprLogic</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>LitString</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Reg</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Reg</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>RI</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-701"></a><span class='hs-definition'>pprLogic</span> <span class='hs-varid'>op</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>ri</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-702"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-703"></a>	<span class='hs-varid'>ptext</span> <span class='hs-varid'>op</span><span class='hs-layout'>,</span>
<a name="line-704"></a>	<span class='hs-keyword'>case</span> <span class='hs-varid'>ri</span> <span class='hs-keyword'>of</span>
<a name="line-705"></a>	    <span class='hs-conid'>RIReg</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>empty</span>
<a name="line-706"></a>	    <span class='hs-conid'>RIImm</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'i'</span><span class='hs-layout'>,</span>
<a name="line-707"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-708"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span>
<a name="line-709"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-710"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>,</span>
<a name="line-711"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-712"></a>	<span class='hs-varid'>pprRI</span> <span class='hs-varid'>ri</span>
<a name="line-713"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-714"></a>
<a name="line-715"></a>
<a name="line-716"></a><a name="pprUnary"></a><span class='hs-definition'>pprUnary</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>LitString</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Reg</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Reg</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>    
<a name="line-717"></a><span class='hs-definition'>pprUnary</span> <span class='hs-varid'>op</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-718"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-719"></a>	<span class='hs-varid'>ptext</span> <span class='hs-varid'>op</span><span class='hs-layout'>,</span>
<a name="line-720"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-721"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span>
<a name="line-722"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-723"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span>
<a name="line-724"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-725"></a>    
<a name="line-726"></a>    
<a name="line-727"></a><a name="pprBinaryF"></a><span class='hs-definition'>pprBinaryF</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>LitString</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Size</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Reg</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Reg</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Reg</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-728"></a><span class='hs-definition'>pprBinaryF</span> <span class='hs-varid'>op</span> <span class='hs-varid'>sz</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-729"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-730"></a>	<span class='hs-varid'>ptext</span> <span class='hs-varid'>op</span><span class='hs-layout'>,</span>
<a name="line-731"></a>	<span class='hs-varid'>pprFSize</span> <span class='hs-varid'>sz</span><span class='hs-layout'>,</span>
<a name="line-732"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-733"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span>
<a name="line-734"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-735"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>,</span>
<a name="line-736"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>", "</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-737"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg3</span>
<a name="line-738"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-739"></a>    
<a name="line-740"></a><a name="pprRI"></a><span class='hs-definition'>pprRI</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>RI</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-741"></a><span class='hs-definition'>pprRI</span> <span class='hs-layout'>(</span><span class='hs-conid'>RIReg</span> <span class='hs-varid'>r</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>r</span>
<a name="line-742"></a><span class='hs-definition'>pprRI</span> <span class='hs-layout'>(</span><span class='hs-conid'>RIImm</span> <span class='hs-varid'>r</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>r</span>
<a name="line-743"></a>
<a name="line-744"></a>
<a name="line-745"></a><a name="pprFSize"></a><span class='hs-definition'>pprFSize</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Size</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-746"></a><span class='hs-definition'>pprFSize</span> <span class='hs-conid'>FF64</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>empty</span>
<a name="line-747"></a><span class='hs-definition'>pprFSize</span> <span class='hs-conid'>FF32</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'s'</span>
<a name="line-748"></a><span class='hs-definition'>pprFSize</span> <span class='hs-keyword'>_</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"PPC.Ppr.pprFSize: no match"</span>
<a name="line-749"></a>
<a name="line-750"></a>    <span class='hs-comment'>-- limit immediate argument for shift instruction to range 0..32</span>
<a name="line-751"></a>    <span class='hs-comment'>-- (yes, the maximum is really 32, not 31)</span>
<a name="line-752"></a><a name="limitShiftRI"></a><span class='hs-definition'>limitShiftRI</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>RI</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>RI</span>
<a name="line-753"></a><span class='hs-definition'>limitShiftRI</span> <span class='hs-layout'>(</span><span class='hs-conid'>RIImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmInt</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>|</span> <span class='hs-varid'>i</span> <span class='hs-varop'>&gt;</span> <span class='hs-num'>32</span> <span class='hs-varop'>||</span> <span class='hs-varid'>i</span> <span class='hs-varop'>&lt;</span> <span class='hs-num'>0</span> <span class='hs-keyglyph'>=</span> <span class='hs-conid'>RIImm</span> <span class='hs-layout'>(</span><span class='hs-conid'>ImmInt</span> <span class='hs-num'>32</span><span class='hs-layout'>)</span>
<a name="line-754"></a><span class='hs-definition'>limitShiftRI</span> <span class='hs-varid'>x</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>x</span>
<a name="line-755"></a>
</pre></body>
</html>