Sophie

Sophie

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

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/SPARC/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'>SPARC</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>
<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 "HsVersions.h"</span>
<a name="line-24"></a><span class='hs-cpp'>#include "nativeGen/NCG.h"</span>
<a name="line-25"></a>
<a name="line-26"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>SPARC</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'>SPARC</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'>SPARC</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'>SPARC</span><span class='hs-varop'>.</span><span class='hs-conid'>Imm</span>
<a name="line-30"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>SPARC</span><span class='hs-varop'>.</span><span class='hs-conid'>AddrMode</span>
<a name="line-31"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>SPARC</span><span class='hs-varop'>.</span><span class='hs-conid'>Base</span>
<a name="line-32"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Instruction</span>
<a name="line-33"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Reg</span>
<a name="line-34"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Size</span>
<a name="line-35"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>PprBase</span>
<a name="line-36"></a>
<a name="line-37"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>BlockId</span>
<a name="line-38"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Cmm</span>
<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-keyword'>qualified</span> <span class='hs-conid'>Outputable</span>
<a name="line-43"></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-44"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Pretty</span>
<a name="line-45"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>FastString</span>
<a name="line-46"></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-47"></a>
<a name="line-48"></a><span class='hs-comment'>-- -----------------------------------------------------------------------------</span>
<a name="line-49"></a><span class='hs-comment'>-- Printing this stuff out</span>
<a name="line-50"></a>
<a name="line-51"></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-52"></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-53"></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-54"></a>
<a name="line-55"></a> <span class='hs-comment'>-- special case for split markers:</span>
<a name="line-56"></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-57"></a>
<a name="line-58"></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-59"></a>  <span class='hs-varid'>pprSectionHeader</span> <span class='hs-conid'>Text</span> <span class='hs-varop'>$$</span>
<a name="line-60"></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-61"></a>       <span class='hs-varid'>pprLabel</span> <span class='hs-varid'>lbl</span>
<a name="line-62"></a>   <span class='hs-keyword'>else</span>
<a name="line-63"></a><span class='hs-cpp'>#if HAVE_SUBSECTIONS_VIA_SYMBOLS</span>
<a name="line-64"></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-65"></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-66"></a><span class='hs-cpp'>#endif</span>
<a name="line-67"></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-68"></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-69"></a>  <span class='hs-layout'>)</span> <span class='hs-varop'>$$</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'>pprBasicBlock</span> <span class='hs-varid'>blocks</span><span class='hs-layout'>)</span>
<a name="line-71"></a>     <span class='hs-comment'>-- above: Even the first block gets a label, because with branch-chain</span>
<a name="line-72"></a>     <span class='hs-comment'>-- elimination, it might be the target of a goto.</span>
<a name="line-73"></a><span class='hs-cpp'>#if HAVE_SUBSECTIONS_VIA_SYMBOLS</span>
<a name="line-74"></a>        <span class='hs-comment'>-- If we are using the .subsections_via_symbols directive</span>
<a name="line-75"></a>        <span class='hs-comment'>-- (available on recent versions of Darwin),</span>
<a name="line-76"></a>        <span class='hs-comment'>-- we have to make sure that there is some kind of reference</span>
<a name="line-77"></a>        <span class='hs-comment'>-- from the entry code to a label on the _top_ of of the info table,</span>
<a name="line-78"></a>        <span class='hs-comment'>-- so that the linker will not think it is unreferenced and dead-strip</span>
<a name="line-79"></a>        <span class='hs-comment'>-- it. That's why the label is called a DeadStripPreventer (_dsp).</span>
<a name="line-80"></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-81"></a>		    <span class='hs-keyword'>then</span> <span class='hs-varid'>text</span> <span class='hs-str'>"\t.long "</span>
<a name="line-82"></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-83"></a>		      <span class='hs-varop'>&lt;+&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'-'</span>
<a name="line-84"></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-85"></a>		    <span class='hs-keyword'>else</span> <span class='hs-varid'>empty</span>
<a name="line-86"></a><span class='hs-cpp'>#endif</span>
<a name="line-87"></a>
<a name="line-88"></a>
<a name="line-89"></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-90"></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-91"></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-92"></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-93"></a>
<a name="line-94"></a>
<a name="line-95"></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-96"></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-97"></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-98"></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-99"></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-100"></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-101"></a>
<a name="line-102"></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-103"></a><span class='hs-definition'>pprGloblDecl</span> <span class='hs-varid'>lbl</span>
<a name="line-104"></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-105"></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-106"></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-107"></a>		<span class='hs-varid'>pprCLabel_asm</span> <span class='hs-varid'>lbl</span>
<a name="line-108"></a>
<a name="line-109"></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-110"></a><span class='hs-cpp'>#if linux_TARGET_OS</span>
<a name="line-111"></a><span class='hs-definition'>pprTypeAndSizeDecl</span> <span class='hs-varid'>lbl</span>
<a name="line-112"></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-113"></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-114"></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-115"></a><span class='hs-cpp'>#else</span>
<a name="line-116"></a><span class='hs-definition'>pprTypeAndSizeDecl</span> <span class='hs-keyword'>_</span>
<a name="line-117"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>empty</span>
<a name="line-118"></a><span class='hs-cpp'>#endif</span>
<a name="line-119"></a>
<a name="line-120"></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-121"></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-122"></a>
<a name="line-123"></a>
<a name="line-124"></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-125"></a><span class='hs-definition'>pprASCII</span> <span class='hs-varid'>str</span>
<a name="line-126"></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-127"></a>    <span class='hs-keyword'>where</span>
<a name="line-128"></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-129"></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-130"></a>
<a name="line-131"></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-132"></a><span class='hs-definition'>pprAlign</span> <span class='hs-varid'>bytes</span> <span class='hs-keyglyph'>=</span>
<a name="line-133"></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'>bytes</span>
<a name="line-134"></a>
<a name="line-135"></a>
<a name="line-136"></a><span class='hs-comment'>-- -----------------------------------------------------------------------------</span>
<a name="line-137"></a><span class='hs-comment'>-- pprInstr: print an 'Instr'</span>
<a name="line-138"></a>
<a name="line-139"></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-140"></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-141"></a>
<a name="line-142"></a>
<a name="line-143"></a><a name="pprUserReg"></a><span class='hs-comment'>-- | Pretty print a register.</span>
<a name="line-144"></a><span class='hs-comment'>--	This is an alias of pprReg for legacy reasons, should remove it.</span>
<a name="line-145"></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-146"></a><span class='hs-definition'>pprUserReg</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprReg</span>
<a name="line-147"></a>
<a name="line-148"></a>
<a name="line-149"></a><a name="pprReg"></a><span class='hs-comment'>-- | Pretty print a register.</span>
<a name="line-150"></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-151"></a><span class='hs-definition'>pprReg</span> <span class='hs-varid'>reg</span>
<a name="line-152"></a> <span class='hs-keyglyph'>=</span> <span class='hs-keyword'>case</span> <span class='hs-varid'>reg</span> <span class='hs-keyword'>of</span>
<a name="line-153"></a> 	<span class='hs-conid'>RegVirtual</span> <span class='hs-varid'>vr</span>
<a name="line-154"></a>	 <span class='hs-keyglyph'>-&gt;</span> <span class='hs-keyword'>case</span> <span class='hs-varid'>vr</span> <span class='hs-keyword'>of</span>
<a name="line-155"></a>		<span class='hs-conid'>VirtualRegI</span>  <span class='hs-varid'>u</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-156"></a>		<span class='hs-conid'>VirtualRegHi</span> <span class='hs-varid'>u</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-157"></a>		<span class='hs-conid'>VirtualRegF</span>  <span class='hs-varid'>u</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-158"></a>		<span class='hs-conid'>VirtualRegD</span>  <span class='hs-varid'>u</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-159"></a>
<a name="line-160"></a>	<span class='hs-conid'>RegReal</span> <span class='hs-varid'>rr</span>
<a name="line-161"></a>	 <span class='hs-keyglyph'>-&gt;</span> <span class='hs-keyword'>case</span> <span class='hs-varid'>rr</span> <span class='hs-keyword'>of</span>
<a name="line-162"></a>		<span class='hs-conid'>RealRegSingle</span> <span class='hs-varid'>r1</span>
<a name="line-163"></a>		 <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>pprReg_ofRegNo</span> <span class='hs-varid'>r1</span>
<a name="line-164"></a>
<a name="line-165"></a>		<span class='hs-conid'>RealRegPair</span>   <span class='hs-varid'>r1</span> <span class='hs-varid'>r2</span>	
<a name="line-166"></a>		 <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>text</span> <span class='hs-str'>"("</span> 	<span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>pprReg_ofRegNo</span> <span class='hs-varid'>r1</span> 
<a name="line-167"></a>		 <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>text</span> <span class='hs-str'>"|"</span> 	<span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>pprReg_ofRegNo</span> <span class='hs-varid'>r2</span>
<a name="line-168"></a>		 <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>text</span> <span class='hs-str'>")"</span>
<a name="line-169"></a>	
<a name="line-170"></a>
<a name="line-171"></a>
<a name="line-172"></a><a name="pprReg_ofRegNo"></a><span class='hs-comment'>-- | Pretty print a register name, based on this register number.</span>
<a name="line-173"></a><span class='hs-comment'>--	The definition has been unfolded so we get a jump-table in the</span>
<a name="line-174"></a><span class='hs-comment'>--	object code. This function is called quite a lot when emitting the asm file..</span>
<a name="line-175"></a><span class='hs-comment'>--</span>
<a name="line-176"></a><span class='hs-definition'>pprReg_ofRegNo</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-definition'>pprReg_ofRegNo</span> <span class='hs-varid'>i</span>
<a name="line-178"></a> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span>
<a name="line-179"></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-180"></a>	 <span class='hs-num'>0</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%g0"</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'>"%g1"</span><span class='hs-layout'>;</span>
<a name="line-181"></a>	 <span class='hs-num'>2</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%g2"</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'>"%g3"</span><span class='hs-layout'>;</span>
<a name="line-182"></a>	 <span class='hs-num'>4</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%g4"</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'>"%g5"</span><span class='hs-layout'>;</span>
<a name="line-183"></a>	 <span class='hs-num'>6</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%g6"</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'>"%g7"</span><span class='hs-layout'>;</span>
<a name="line-184"></a>	 <span class='hs-num'>8</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%o0"</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'>"%o1"</span><span class='hs-layout'>;</span>
<a name="line-185"></a>	<span class='hs-num'>10</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%o2"</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'>"%o3"</span><span class='hs-layout'>;</span>
<a name="line-186"></a>	<span class='hs-num'>12</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%o4"</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'>"%o5"</span><span class='hs-layout'>;</span>
<a name="line-187"></a>	<span class='hs-num'>14</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%o6"</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'>"%o7"</span><span class='hs-layout'>;</span>
<a name="line-188"></a>	<span class='hs-num'>16</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%l0"</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'>"%l1"</span><span class='hs-layout'>;</span>
<a name="line-189"></a>	<span class='hs-num'>18</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%l2"</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'>"%l3"</span><span class='hs-layout'>;</span>
<a name="line-190"></a>	<span class='hs-num'>20</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%l4"</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'>"%l5"</span><span class='hs-layout'>;</span>
<a name="line-191"></a>	<span class='hs-num'>22</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%l6"</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'>"%l7"</span><span class='hs-layout'>;</span>
<a name="line-192"></a>	<span class='hs-num'>24</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%i0"</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'>"%i1"</span><span class='hs-layout'>;</span>
<a name="line-193"></a>	<span class='hs-num'>26</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%i2"</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'>"%i3"</span><span class='hs-layout'>;</span>
<a name="line-194"></a>	<span class='hs-num'>28</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%i4"</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'>"%i5"</span><span class='hs-layout'>;</span>
<a name="line-195"></a>	<span class='hs-num'>30</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"%i6"</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'>"%i7"</span><span class='hs-layout'>;</span>
<a name="line-196"></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-197"></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-198"></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-199"></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-200"></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-201"></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-202"></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-203"></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-204"></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-205"></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-206"></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-207"></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-208"></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-209"></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-210"></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-211"></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-212"></a>	<span class='hs-keyword'>_</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"very naughty sparc register"</span> <span class='hs-layout'>}</span><span class='hs-layout'>)</span>
<a name="line-213"></a>
<a name="line-214"></a>
<a name="line-215"></a><a name="pprSize"></a><span class='hs-comment'>-- | Pretty print a size for an instruction suffix.</span>
<a name="line-216"></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-217"></a><span class='hs-definition'>pprSize</span> <span class='hs-varid'>x</span> 
<a name="line-218"></a> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span> 
<a name="line-219"></a>    <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-220"></a>	<span class='hs-conid'>II8</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"ub"</span>
<a name="line-221"></a>	<span class='hs-conid'>II16</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"uh"</span>
<a name="line-222"></a>	<span class='hs-conid'>II32</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>""</span>
<a name="line-223"></a>	<span class='hs-conid'>II64</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"d"</span>
<a name="line-224"></a>	<span class='hs-conid'>FF32</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>""</span>
<a name="line-225"></a>	<span class='hs-conid'>FF64</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"d"</span>
<a name="line-226"></a>	<span class='hs-keyword'>_</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"SPARC.Ppr.pprSize: no match"</span><span class='hs-layout'>)</span>
<a name="line-227"></a>
<a name="line-228"></a>
<a name="line-229"></a><a name="pprStSize"></a><span class='hs-comment'>-- | Pretty print a size for an instruction suffix.</span>
<a name="line-230"></a><span class='hs-comment'>--	eg LD is 32bit on sparc, but LDD is 64 bit.</span>
<a name="line-231"></a><span class='hs-definition'>pprStSize</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-232"></a><span class='hs-definition'>pprStSize</span> <span class='hs-varid'>x</span> 
<a name="line-233"></a> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span> 
<a name="line-234"></a>    <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-235"></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-236"></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-237"></a>	<span class='hs-conid'>II32</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>""</span>
<a name="line-238"></a>	<span class='hs-conid'>II64</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"x"</span>
<a name="line-239"></a>	<span class='hs-conid'>FF32</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>""</span>
<a name="line-240"></a>	<span class='hs-conid'>FF64</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"d"</span>
<a name="line-241"></a>	<span class='hs-keyword'>_</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"SPARC.Ppr.pprSize: no match"</span><span class='hs-layout'>)</span>
<a name="line-242"></a>
<a name="line-243"></a>		
<a name="line-244"></a><a name="pprCond"></a><span class='hs-comment'>-- | Pretty print a condition code.</span>
<a name="line-245"></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-246"></a><span class='hs-definition'>pprCond</span> <span class='hs-varid'>c</span> 
<a name="line-247"></a> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>ptext</span> 
<a name="line-248"></a>    <span class='hs-layout'>(</span><span class='hs-keyword'>case</span> <span class='hs-varid'>c</span> <span class='hs-keyword'>of</span> 
<a name="line-249"></a>	<span class='hs-conid'>ALWAYS</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>""</span>
<a name="line-250"></a>	<span class='hs-conid'>NEVER</span> 	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"n"</span>
<a name="line-251"></a>	<span class='hs-conid'>GEU</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"geu"</span>
<a name="line-252"></a>	<span class='hs-conid'>LU</span>    	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"lu"</span>
<a name="line-253"></a>	<span class='hs-conid'>EQQ</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"e"</span>
<a name="line-254"></a>	<span class='hs-conid'>GTT</span>   	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"g"</span>
<a name="line-255"></a>	<span class='hs-conid'>GE</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"ge"</span>
<a name="line-256"></a>	<span class='hs-conid'>GU</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"gu"</span>
<a name="line-257"></a>	<span class='hs-conid'>LTT</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"l"</span>
<a name="line-258"></a>	<span class='hs-conid'>LE</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"le"</span>
<a name="line-259"></a>	<span class='hs-conid'>LEU</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"leu"</span>
<a name="line-260"></a>	<span class='hs-conid'>NE</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"ne"</span>
<a name="line-261"></a>	<span class='hs-conid'>NEG</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"neg"</span>
<a name="line-262"></a>	<span class='hs-conid'>POS</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"pos"</span>
<a name="line-263"></a>	<span class='hs-conid'>VC</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"vc"</span>
<a name="line-264"></a>	<span class='hs-conid'>VS</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"vs"</span><span class='hs-layout'>)</span>
<a name="line-265"></a>
<a name="line-266"></a>
<a name="line-267"></a><a name="pprAddr"></a><span class='hs-comment'>-- | Pretty print an address mode.</span>
<a name="line-268"></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-269"></a><span class='hs-definition'>pprAddr</span> <span class='hs-varid'>am</span>
<a name="line-270"></a> <span class='hs-keyglyph'>=</span> <span class='hs-keyword'>case</span> <span class='hs-varid'>am</span> <span class='hs-keyword'>of</span>
<a name="line-271"></a> 	<span class='hs-conid'>AddrRegReg</span> <span class='hs-varid'>r1</span> <span class='hs-layout'>(</span><span class='hs-conid'>RegReal</span> <span class='hs-layout'>(</span><span class='hs-conid'>RealRegSingle</span> <span class='hs-num'>0</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span>
<a name="line-272"></a>	 <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>r1</span>
<a name="line-273"></a>
<a name="line-274"></a>	<span class='hs-conid'>AddrRegReg</span> <span class='hs-varid'>r1</span> <span class='hs-varid'>r2</span>
<a name="line-275"></a>	 <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</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-layout'>,</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>r2</span> <span class='hs-keyglyph'>]</span>
<a name="line-276"></a>
<a name="line-277"></a>	<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>
<a name="line-278"></a>	 <span class='hs-keyglyph'>|</span> <span class='hs-varid'>i</span> <span class='hs-varop'>==</span> <span class='hs-num'>0</span> 		<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>r1</span>
<a name="line-279"></a>	 <span class='hs-keyglyph'>|</span> <span class='hs-varid'>not</span> <span class='hs-layout'>(</span><span class='hs-varid'>fits13Bits</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span> 	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>largeOffsetError</span> <span class='hs-varid'>i</span>
<a name="line-280"></a>	 <span class='hs-keyglyph'>|</span> <span class='hs-varid'>otherwise</span> 		<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>r1</span><span class='hs-layout'>,</span> <span class='hs-varid'>pp_sign</span><span class='hs-layout'>,</span> <span class='hs-varid'>int</span> <span class='hs-varid'>i</span> <span class='hs-keyglyph'>]</span>
<a name="line-281"></a>	 <span class='hs-keyword'>where</span>	
<a name="line-282"></a>	 	<span class='hs-varid'>pp_sign</span> <span class='hs-keyglyph'>=</span> <span class='hs-keyword'>if</span> <span class='hs-varid'>i</span> <span class='hs-varop'>&gt;</span> <span class='hs-num'>0</span> <span class='hs-keyword'>then</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'+'</span> <span class='hs-keyword'>else</span> <span class='hs-varid'>empty</span>
<a name="line-283"></a>
<a name="line-284"></a>	<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>
<a name="line-285"></a>	 <span class='hs-keyglyph'>|</span> <span class='hs-varid'>i</span> <span class='hs-varop'>==</span> <span class='hs-num'>0</span> 		<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>r1</span>
<a name="line-286"></a>	 <span class='hs-keyglyph'>|</span> <span class='hs-varid'>not</span> <span class='hs-layout'>(</span><span class='hs-varid'>fits13Bits</span> <span class='hs-varid'>i</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>largeOffsetError</span> <span class='hs-varid'>i</span>
<a name="line-287"></a>	 <span class='hs-keyglyph'>|</span> <span class='hs-varid'>otherwise</span>		<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>r1</span><span class='hs-layout'>,</span> <span class='hs-varid'>pp_sign</span><span class='hs-layout'>,</span> <span class='hs-varid'>integer</span> <span class='hs-varid'>i</span> <span class='hs-keyglyph'>]</span>
<a name="line-288"></a>	 <span class='hs-keyword'>where</span>
<a name="line-289"></a>		<span class='hs-varid'>pp_sign</span> <span class='hs-keyglyph'>=</span> <span class='hs-keyword'>if</span> <span class='hs-varid'>i</span> <span class='hs-varop'>&gt;</span> <span class='hs-num'>0</span> <span class='hs-keyword'>then</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'+'</span> <span class='hs-keyword'>else</span> <span class='hs-varid'>empty</span>
<a name="line-290"></a>
<a name="line-291"></a>	<span class='hs-conid'>AddrRegImm</span> <span class='hs-varid'>r1</span> <span class='hs-varid'>imm</span>
<a name="line-292"></a>	 <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</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-layout'>,</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>imm</span> <span class='hs-keyglyph'>]</span>
<a name="line-293"></a>
<a name="line-294"></a>
<a name="line-295"></a><a name="pprImm"></a><span class='hs-comment'>-- | Pretty print an immediate value.</span>
<a name="line-296"></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-297"></a><span class='hs-definition'>pprImm</span> <span class='hs-varid'>imm</span>
<a name="line-298"></a> <span class='hs-keyglyph'>=</span> <span class='hs-keyword'>case</span> <span class='hs-varid'>imm</span> <span class='hs-keyword'>of</span>
<a name="line-299"></a> 	<span class='hs-conid'>ImmInt</span> <span class='hs-varid'>i</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>int</span> <span class='hs-varid'>i</span>
<a name="line-300"></a>	<span class='hs-conid'>ImmInteger</span> <span class='hs-varid'>i</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>integer</span> <span class='hs-varid'>i</span>
<a name="line-301"></a>	<span class='hs-conid'>ImmCLbl</span> <span class='hs-varid'>l</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>pprCLabel_asm</span> <span class='hs-varid'>l</span>
<a name="line-302"></a>	<span class='hs-conid'>ImmIndex</span> <span class='hs-varid'>l</span> <span class='hs-varid'>i</span>	<span class='hs-keyglyph'>-&gt;</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-303"></a>	<span class='hs-conid'>ImmLit</span> <span class='hs-varid'>s</span>	<span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>s</span>
<a name="line-304"></a>
<a name="line-305"></a>	<span class='hs-conid'>ImmConstantSum</span> <span class='hs-varid'>a</span> <span class='hs-varid'>b</span>	
<a name="line-306"></a>	 <span class='hs-keyglyph'>-&gt;</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-307"></a>
<a name="line-308"></a>	<span class='hs-conid'>ImmConstantDiff</span> <span class='hs-varid'>a</span> <span class='hs-varid'>b</span>	
<a name="line-309"></a>	 <span class='hs-keyglyph'>-&gt;</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'>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-310"></a>
<a name="line-311"></a>	<span class='hs-conid'>LO</span> <span class='hs-varid'>i</span>
<a name="line-312"></a>	 <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-varid'>text</span> <span class='hs-str'>"%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-313"></a>	
<a name="line-314"></a>	<span class='hs-conid'>HI</span> <span class='hs-varid'>i</span>
<a name="line-315"></a>	 <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span> <span class='hs-varid'>text</span> <span class='hs-str'>"%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-316"></a>
<a name="line-317"></a>	<span class='hs-comment'>-- these should have been converted to bytes and placed</span>
<a name="line-318"></a>	<span class='hs-comment'>--	in the data section.</span>
<a name="line-319"></a>	<span class='hs-conid'>ImmFloat</span> <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'>"naughty float immediate"</span><span class='hs-layout'>)</span>
<a name="line-320"></a>	<span class='hs-conid'>ImmDouble</span> <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'>"naughty double immediate"</span><span class='hs-layout'>)</span>
<a name="line-321"></a>
<a name="line-322"></a>
<a name="line-323"></a><a name="pprSectionHeader"></a><span class='hs-comment'>-- | Pretty print a section \/ segment header.</span>
<a name="line-324"></a><span class='hs-comment'>--	On SPARC all the data sections must be at least 8 byte aligned</span>
<a name="line-325"></a><span class='hs-comment'>--	incase we store doubles in them.</span>
<a name="line-326"></a><span class='hs-comment'>--</span>
<a name="line-327"></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-328"></a><span class='hs-definition'>pprSectionHeader</span> <span class='hs-varid'>seg</span>
<a name="line-329"></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-330"></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\t.align 4"</span><span class='hs-layout'>)</span>
<a name="line-331"></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\t.align 8"</span><span class='hs-layout'>)</span>
<a name="line-332"></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'>".text\n\t.align 8"</span><span class='hs-layout'>)</span>
<a name="line-333"></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'>".text\n\t.align 8"</span><span class='hs-layout'>)</span>
<a name="line-334"></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'>".bss\n\t.align 8"</span><span class='hs-layout'>)</span>
<a name="line-335"></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'>".data\n\t.align 16"</span><span class='hs-layout'>)</span>
<a name="line-336"></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-337"></a>
<a name="line-338"></a>
<a name="line-339"></a><a name="pprDataItem"></a><span class='hs-comment'>-- | Pretty print a data item.</span>
<a name="line-340"></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-341"></a><span class='hs-definition'>pprDataItem</span> <span class='hs-varid'>lit</span>
<a name="line-342"></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-343"></a>    <span class='hs-keyword'>where</span>
<a name="line-344"></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-345"></a>
<a name="line-346"></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-347"></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-348"></a>
<a name="line-349"></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-350"></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-351"></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-352"></a>
<a name="line-353"></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-354"></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-355"></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-356"></a>
<a name="line-357"></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-358"></a>	<span class='hs-varid'>ppr_item</span> <span class='hs-conid'>II64</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.quad\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-359"></a>	<span class='hs-varid'>ppr_item</span> <span class='hs-keyword'>_</span> <span class='hs-keyword'>_</span>		<span class='hs-keyglyph'>=</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"SPARC.Ppr.pprDataItem: no match"</span>
<a name="line-360"></a>
<a name="line-361"></a>
<a name="line-362"></a><a name="pprInstr"></a><span class='hs-comment'>-- | Pretty print an instruction.</span>
<a name="line-363"></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-364"></a>
<a name="line-365"></a><span class='hs-comment'>-- nuke comments.</span>
<a name="line-366"></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> 
<a name="line-367"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>empty</span> 
<a name="line-368"></a>
<a name="line-369"></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-370"></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-371"></a>
<a name="line-372"></a><span class='hs-comment'>-- Newblocks and LData should have been slurped out before producing the .s file.</span>
<a name="line-373"></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-374"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"X86.Ppr.pprInstr: NEWBLOCK"</span>
<a name="line-375"></a>
<a name="line-376"></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-377"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"PprMach.pprInstr: LDATA"</span>
<a name="line-378"></a>
<a name="line-379"></a><span class='hs-comment'>-- 64 bit FP loads are expanded into individual instructions in CodeGen.Expand</span>
<a name="line-380"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>LD</span> <span class='hs-conid'>FF64</span> <span class='hs-keyword'>_</span> <span class='hs-varid'>reg</span><span class='hs-layout'>)</span>
<a name="line-381"></a>	<span class='hs-keyglyph'>|</span> <span class='hs-conid'>RegReal</span> <span class='hs-layout'>(</span><span class='hs-conid'>RealRegSingle</span><span class='hs-layout'>{</span><span class='hs-layout'>}</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>&lt;-</span> <span class='hs-varid'>reg</span>
<a name="line-382"></a> 	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"SPARC.Ppr: not emitting potentially misaligned LD FF64 instr"</span>
<a name="line-383"></a>
<a name="line-384"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>LD</span> <span class='hs-varid'>size</span> <span class='hs-varid'>addr</span> <span class='hs-varid'>reg</span><span class='hs-layout'>)</span>
<a name="line-385"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-386"></a>	       <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\tld"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-387"></a>	       <span class='hs-varid'>pprSize</span> <span class='hs-varid'>size</span><span class='hs-layout'>,</span>
<a name="line-388"></a>	       <span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-389"></a>	       <span class='hs-varid'>lbrack</span><span class='hs-layout'>,</span>
<a name="line-390"></a>	       <span class='hs-varid'>pprAddr</span> <span class='hs-varid'>addr</span><span class='hs-layout'>,</span>
<a name="line-391"></a>	       <span class='hs-varid'>pp_rbracket_comma</span><span class='hs-layout'>,</span>
<a name="line-392"></a>	       <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span>
<a name="line-393"></a>	    <span class='hs-keyglyph'>]</span>
<a name="line-394"></a>
<a name="line-395"></a><span class='hs-comment'>-- 64 bit FP storees are expanded into individual instructions in CodeGen.Expand</span>
<a name="line-396"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>ST</span> <span class='hs-conid'>FF64</span> <span class='hs-varid'>reg</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span>
<a name="line-397"></a>	<span class='hs-keyglyph'>|</span> <span class='hs-conid'>RegReal</span> <span class='hs-layout'>(</span><span class='hs-conid'>RealRegSingle</span><span class='hs-layout'>{</span><span class='hs-layout'>}</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>&lt;-</span> <span class='hs-varid'>reg</span>
<a name="line-398"></a> 	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"SPARC.Ppr: not emitting potentially misaligned ST FF64 instr"</span>
<a name="line-399"></a>
<a name="line-400"></a><span class='hs-comment'>-- no distinction is made between signed and unsigned bytes on stores for the</span>
<a name="line-401"></a><span class='hs-comment'>-- Sparc opcodes (at least I cannot see any, and gas is nagging me --SOF),</span>
<a name="line-402"></a><span class='hs-comment'>-- so we call a special-purpose pprSize for ST..</span>
<a name="line-403"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>ST</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg</span> <span class='hs-varid'>addr</span><span class='hs-layout'>)</span>
<a name="line-404"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-405"></a>	       <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\tst"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-406"></a>	       <span class='hs-varid'>pprStSize</span> <span class='hs-varid'>size</span><span class='hs-layout'>,</span>
<a name="line-407"></a>	       <span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-408"></a>	       <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span><span class='hs-layout'>,</span>
<a name="line-409"></a>	       <span class='hs-varid'>pp_comma_lbracket</span><span class='hs-layout'>,</span>
<a name="line-410"></a>	       <span class='hs-varid'>pprAddr</span> <span class='hs-varid'>addr</span><span class='hs-layout'>,</span>
<a name="line-411"></a>	       <span class='hs-varid'>rbrack</span>
<a name="line-412"></a>	    <span class='hs-keyglyph'>]</span>
<a name="line-413"></a>
<a name="line-414"></a>
<a name="line-415"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>ADD</span> <span class='hs-varid'>x</span> <span class='hs-varid'>cc</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>
<a name="line-416"></a>	<span class='hs-keyglyph'>|</span> <span class='hs-varid'>not</span> <span class='hs-varid'>x</span> <span class='hs-varop'>&amp;&amp;</span> <span class='hs-varid'>not</span> <span class='hs-varid'>cc</span> <span class='hs-varop'>&amp;&amp;</span> <span class='hs-varid'>riZero</span> <span class='hs-varid'>ri</span>
<a name="line-417"></a>	<span class='hs-keyglyph'>=</span> <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'>"\tmov\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'>comma</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span> <span class='hs-keyglyph'>]</span>
<a name="line-418"></a>
<a name="line-419"></a>	<span class='hs-keyglyph'>|</span> <span class='hs-varid'>otherwise</span>
<a name="line-420"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</span> <span class='hs-layout'>(</span><span class='hs-keyword'>if</span> <span class='hs-varid'>x</span> <span class='hs-keyword'>then</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"addx"</span> <span class='hs-keyword'>else</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"add"</span><span class='hs-layout'>)</span> <span class='hs-varid'>cc</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-421"></a>
<a name="line-422"></a>
<a name="line-423"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>SUB</span> <span class='hs-varid'>x</span> <span class='hs-varid'>cc</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>
<a name="line-424"></a>	<span class='hs-keyglyph'>|</span> <span class='hs-varid'>not</span> <span class='hs-varid'>x</span> <span class='hs-varop'>&amp;&amp;</span> <span class='hs-varid'>cc</span> <span class='hs-varop'>&amp;&amp;</span> <span class='hs-varid'>reg2</span> <span class='hs-varop'>==</span> <span class='hs-varid'>g0</span>
<a name="line-425"></a>	<span class='hs-keyglyph'>=</span> <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'>"\tcmp\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'>comma</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprRI</span> <span class='hs-varid'>ri</span> <span class='hs-keyglyph'>]</span>
<a name="line-426"></a>
<a name="line-427"></a>	<span class='hs-keyglyph'>|</span> <span class='hs-varid'>not</span> <span class='hs-varid'>x</span> <span class='hs-varop'>&amp;&amp;</span> <span class='hs-varid'>not</span> <span class='hs-varid'>cc</span> <span class='hs-varop'>&amp;&amp;</span> <span class='hs-varid'>riZero</span> <span class='hs-varid'>ri</span>
<a name="line-428"></a>	<span class='hs-keyglyph'>=</span> <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'>"\tmov\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'>comma</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span> <span class='hs-keyglyph'>]</span>
<a name="line-429"></a>	
<a name="line-430"></a>	<span class='hs-keyglyph'>|</span> <span class='hs-varid'>otherwise</span>
<a name="line-431"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</span> <span class='hs-layout'>(</span><span class='hs-keyword'>if</span> <span class='hs-varid'>x</span> <span class='hs-keyword'>then</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"subx"</span> <span class='hs-keyword'>else</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"sub"</span><span class='hs-layout'>)</span> <span class='hs-varid'>cc</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-432"></a>
<a name="line-433"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>AND</span>  <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</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'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-434"></a>
<a name="line-435"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>ANDN</span> <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"andn"</span><span class='hs-layout'>)</span> <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-436"></a>
<a name="line-437"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>OR</span> <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>
<a name="line-438"></a>	<span class='hs-keyglyph'>|</span> <span class='hs-varid'>not</span> <span class='hs-varid'>b</span> <span class='hs-varop'>&amp;&amp;</span> <span class='hs-varid'>reg1</span> <span class='hs-varop'>==</span> <span class='hs-varid'>g0</span>
<a name="line-439"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-keyword'>let</span> <span class='hs-varid'>doit</span> <span class='hs-keyglyph'>=</span> <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'>"\tmov\t"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprRI</span> <span class='hs-varid'>ri</span><span class='hs-layout'>,</span> <span class='hs-varid'>comma</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span> <span class='hs-keyglyph'>]</span>
<a name="line-440"></a>	  <span class='hs-keyword'>in</span>  <span class='hs-keyword'>case</span> <span class='hs-varid'>ri</span> <span class='hs-keyword'>of</span>
<a name="line-441"></a>	           <span class='hs-conid'>RIReg</span> <span class='hs-varid'>rrr</span> <span class='hs-keyglyph'>|</span> <span class='hs-varid'>rrr</span> <span class='hs-varop'>==</span> <span class='hs-varid'>reg2</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>empty</span>
<a name="line-442"></a>	           <span class='hs-keyword'>_</span>                       <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>doit</span>
<a name="line-443"></a>
<a name="line-444"></a>	<span class='hs-keyglyph'>|</span> <span class='hs-varid'>otherwise</span>
<a name="line-445"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</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'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-446"></a>
<a name="line-447"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>ORN</span> <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"orn"</span><span class='hs-layout'>)</span> <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-448"></a>
<a name="line-449"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>XOR</span>  <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</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'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-450"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>XNOR</span> <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"xnor"</span><span class='hs-layout'>)</span> <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-451"></a>
<a name="line-452"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>SLL</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"sll"</span><span class='hs-layout'>)</span> <span class='hs-conid'>False</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-453"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>SRL</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"srl"</span><span class='hs-layout'>)</span> <span class='hs-conid'>False</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-454"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>SRA</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"sra"</span><span class='hs-layout'>)</span> <span class='hs-conid'>False</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-455"></a>
<a name="line-456"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>RDY</span> <span class='hs-varid'>rd</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'>"\trd\t%y,"</span><span class='hs-layout'>)</span> <span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>rd</span>
<a name="line-457"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>WRY</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span> 	
<a name="line-458"></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'>"\twr\t"</span><span class='hs-layout'>)</span> 
<a name="line-459"></a>		<span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span> 
<a name="line-460"></a>		<span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>','</span>
<a name="line-461"></a>		<span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span>
<a name="line-462"></a>		<span class='hs-varop'>&lt;&gt;</span> <span class='hs-varid'>char</span> <span class='hs-chr'>','</span>
<a name="line-463"></a>		<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'>"%y"</span><span class='hs-layout'>)</span> 
<a name="line-464"></a>
<a name="line-465"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>SMUL</span> <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"smul"</span><span class='hs-layout'>)</span>  <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-466"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>UMUL</span> <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"umul"</span><span class='hs-layout'>)</span>  <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-467"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>SDIV</span> <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"sdiv"</span><span class='hs-layout'>)</span>  <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-468"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>UDIV</span> <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprRegRIReg</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"udiv"</span><span class='hs-layout'>)</span>  <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-469"></a>
<a name="line-470"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>SETHI</span> <span class='hs-varid'>imm</span> <span class='hs-varid'>reg</span><span class='hs-layout'>)</span>
<a name="line-471"></a>  <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'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\tsethi\t"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-473"></a>	<span class='hs-varid'>pprImm</span> <span class='hs-varid'>imm</span><span class='hs-layout'>,</span>
<a name="line-474"></a>	<span class='hs-varid'>comma</span><span class='hs-layout'>,</span>
<a name="line-475"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg</span>
<a name="line-476"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-477"></a>
<a name="line-478"></a><span class='hs-definition'>pprInstr</span> <span class='hs-conid'>NOP</span> 
<a name="line-479"></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'>"\tnop"</span><span class='hs-layout'>)</span>
<a name="line-480"></a>
<a name="line-481"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FABS</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>	
<a name="line-482"></a> 	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprSizeRegReg</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"fabs"</span><span class='hs-layout'>)</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span>
<a name="line-483"></a>
<a name="line-484"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FADD</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span>	
<a name="line-485"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprSizeRegRegReg</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'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span>
<a name="line-486"></a>
<a name="line-487"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FCMP</span> <span class='hs-varid'>e</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>
<a name="line-488"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprSizeRegReg</span> <span class='hs-layout'>(</span><span class='hs-keyword'>if</span> <span class='hs-varid'>e</span> <span class='hs-keyword'>then</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"fcmpe"</span> <span class='hs-keyword'>else</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"fcmp"</span><span class='hs-layout'>)</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span>
<a name="line-489"></a>
<a name="line-490"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FDIV</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span>
<a name="line-491"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprSizeRegRegReg</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'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span>
<a name="line-492"></a>
<a name="line-493"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FMOV</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>	
<a name="line-494"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprSizeRegReg</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"fmov"</span><span class='hs-layout'>)</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span>
<a name="line-495"></a>
<a name="line-496"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FMUL</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span>
<a name="line-497"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprSizeRegRegReg</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'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span>
<a name="line-498"></a>
<a name="line-499"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FNEG</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span> 
<a name="line-500"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprSizeRegReg</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'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span>
<a name="line-501"></a>
<a name="line-502"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FSQRT</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>     
<a name="line-503"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprSizeRegReg</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"fsqrt"</span><span class='hs-layout'>)</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span>
<a name="line-504"></a>
<a name="line-505"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FSUB</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span><span class='hs-layout'>)</span> 
<a name="line-506"></a>	<span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprSizeRegRegReg</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'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span>
<a name="line-507"></a>
<a name="line-508"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>FxTOy</span> <span class='hs-varid'>size1</span> <span class='hs-varid'>size2</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>)</span>
<a name="line-509"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-510"></a>    	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\tf"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-511"></a>	<span class='hs-varid'>ptext</span>
<a name="line-512"></a>    	<span class='hs-layout'>(</span><span class='hs-keyword'>case</span> <span class='hs-varid'>size1</span> <span class='hs-keyword'>of</span>
<a name="line-513"></a>    	    <span class='hs-conid'>II32</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"ito"</span>
<a name="line-514"></a>    	    <span class='hs-conid'>FF32</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"sto"</span>
<a name="line-515"></a>    	    <span class='hs-conid'>FF64</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"dto"</span>
<a name="line-516"></a>	    <span class='hs-keyword'>_</span>	  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"SPARC.Ppr.pprInstr.FxToY: no match"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-517"></a>	<span class='hs-varid'>ptext</span>
<a name="line-518"></a>    	<span class='hs-layout'>(</span><span class='hs-keyword'>case</span> <span class='hs-varid'>size2</span> <span class='hs-keyword'>of</span>
<a name="line-519"></a>    	    <span class='hs-conid'>II32</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"i\t"</span>
<a name="line-520"></a>	    <span class='hs-conid'>II64</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"x\t"</span>
<a name="line-521"></a>    	    <span class='hs-conid'>FF32</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"s\t"</span>
<a name="line-522"></a>    	    <span class='hs-conid'>FF64</span>  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>sLit</span> <span class='hs-str'>"d\t"</span>
<a name="line-523"></a>	    <span class='hs-keyword'>_</span>	  <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"SPARC.Ppr.pprInstr.FxToY: no match"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-524"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span> <span class='hs-varid'>comma</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span>
<a name="line-525"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-526"></a>
<a name="line-527"></a>
<a name="line-528"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>BI</span> <span class='hs-varid'>cond</span> <span class='hs-varid'>b</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>
<a name="line-529"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-530"></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> <span class='hs-varid'>pprCond</span> <span class='hs-varid'>cond</span><span class='hs-layout'>,</span>
<a name="line-531"></a>	<span class='hs-keyword'>if</span> <span class='hs-varid'>b</span> <span class='hs-keyword'>then</span> <span class='hs-varid'>pp_comma_a</span> <span class='hs-keyword'>else</span> <span class='hs-varid'>empty</span><span class='hs-layout'>,</span>
<a name="line-532"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-533"></a>	<span class='hs-varid'>pprCLabel_asm</span> <span class='hs-layout'>(</span><span class='hs-varid'>mkAsmTempLabel</span> <span class='hs-varid'>id</span><span class='hs-layout'>)</span>
<a name="line-534"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-535"></a>
<a name="line-536"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>BF</span> <span class='hs-varid'>cond</span> <span class='hs-varid'>b</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>
<a name="line-537"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-538"></a>	<span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"\tfb"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprCond</span> <span class='hs-varid'>cond</span><span class='hs-layout'>,</span>
<a name="line-539"></a>	<span class='hs-keyword'>if</span> <span class='hs-varid'>b</span> <span class='hs-keyword'>then</span> <span class='hs-varid'>pp_comma_a</span> <span class='hs-keyword'>else</span> <span class='hs-varid'>empty</span><span class='hs-layout'>,</span>
<a name="line-540"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-541"></a>	<span class='hs-varid'>pprCLabel_asm</span> <span class='hs-layout'>(</span><span class='hs-varid'>mkAsmTempLabel</span> <span class='hs-varid'>id</span><span class='hs-layout'>)</span>
<a name="line-542"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-543"></a>
<a name="line-544"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>JMP</span> <span class='hs-varid'>addr</span><span class='hs-layout'>)</span> <span class='hs-keyglyph'>=</span> <span class='hs-layout'>(</span><span class='hs-varop'>&lt;&gt;</span><span class='hs-layout'>)</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'>"\tjmp\t"</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span> <span class='hs-layout'>(</span><span class='hs-varid'>pprAddr</span> <span class='hs-varid'>addr</span><span class='hs-layout'>)</span>
<a name="line-545"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>JMP_TBL</span> <span class='hs-varid'>op</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>JMP</span> <span class='hs-varid'>op</span><span class='hs-layout'>)</span>
<a name="line-546"></a>
<a name="line-547"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>CALL</span> <span class='hs-layout'>(</span><span class='hs-conid'>Left</span> <span class='hs-varid'>imm</span><span class='hs-layout'>)</span> <span class='hs-varid'>n</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span>
<a name="line-548"></a>  <span class='hs-keyglyph'>=</span> <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'>"\tcall\t"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span> <span class='hs-varid'>pprImm</span> <span class='hs-varid'>imm</span><span class='hs-layout'>,</span> <span class='hs-varid'>comma</span><span class='hs-layout'>,</span> <span class='hs-varid'>int</span> <span class='hs-varid'>n</span> <span class='hs-keyglyph'>]</span>
<a name="line-549"></a>
<a name="line-550"></a><span class='hs-definition'>pprInstr</span> <span class='hs-layout'>(</span><span class='hs-conid'>CALL</span> <span class='hs-layout'>(</span><span class='hs-conid'>Right</span> <span class='hs-varid'>reg</span><span class='hs-layout'>)</span> <span class='hs-varid'>n</span> <span class='hs-keyword'>_</span><span class='hs-layout'>)</span>
<a name="line-551"></a>  <span class='hs-keyglyph'>=</span> <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'>"\tcall\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-layout'>,</span> <span class='hs-varid'>comma</span><span class='hs-layout'>,</span> <span class='hs-varid'>int</span> <span class='hs-varid'>n</span> <span class='hs-keyglyph'>]</span>
<a name="line-552"></a>
<a name="line-553"></a>
<a name="line-554"></a><a name="pprRI"></a><span class='hs-comment'>-- | Pretty print a RI</span>
<a name="line-555"></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-556"></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-557"></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-558"></a>
<a name="line-559"></a>
<a name="line-560"></a><a name="pprSizeRegReg"></a><span class='hs-comment'>-- | Pretty print a two reg instruction.</span>
<a name="line-561"></a><span class='hs-definition'>pprSizeRegReg</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'>Doc</span>
<a name="line-562"></a><span class='hs-definition'>pprSizeRegReg</span> <span class='hs-varid'>name</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span>
<a name="line-563"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</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'>ptext</span> <span class='hs-varid'>name</span><span class='hs-layout'>,</span>
<a name="line-566"></a>    	<span class='hs-layout'>(</span><span class='hs-keyword'>case</span> <span class='hs-varid'>size</span> <span class='hs-keyword'>of</span>
<a name="line-567"></a>    	    <span class='hs-conid'>FF32</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'>"s\t"</span><span class='hs-layout'>)</span>
<a name="line-568"></a>    	    <span class='hs-conid'>FF64</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'>"d\t"</span><span class='hs-layout'>)</span>
<a name="line-569"></a>	    <span class='hs-keyword'>_</span>    <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"SPARC.Ppr.pprSizeRegReg: no match"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-570"></a>
<a name="line-571"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span>
<a name="line-572"></a>	<span class='hs-varid'>comma</span><span class='hs-layout'>,</span>
<a name="line-573"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span>
<a name="line-574"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-575"></a>
<a name="line-576"></a>
<a name="line-577"></a><a name="pprSizeRegRegReg"></a><span class='hs-comment'>-- | Pretty print a three reg instruction.</span>
<a name="line-578"></a><span class='hs-definition'>pprSizeRegRegReg</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-579"></a><span class='hs-definition'>pprSizeRegRegReg</span> <span class='hs-varid'>name</span> <span class='hs-varid'>size</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>reg2</span> <span class='hs-varid'>reg3</span>
<a name="line-580"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-581"></a>    	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-582"></a>	<span class='hs-varid'>ptext</span> <span class='hs-varid'>name</span><span class='hs-layout'>,</span>
<a name="line-583"></a>    	<span class='hs-layout'>(</span><span class='hs-keyword'>case</span> <span class='hs-varid'>size</span> <span class='hs-keyword'>of</span>
<a name="line-584"></a>    	    <span class='hs-conid'>FF32</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'>"s\t"</span><span class='hs-layout'>)</span>
<a name="line-585"></a>    	    <span class='hs-conid'>FF64</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'>"d\t"</span><span class='hs-layout'>)</span>
<a name="line-586"></a>	    <span class='hs-keyword'>_</span>    <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>panic</span> <span class='hs-str'>"SPARC.Ppr.pprSizeRegReg: no match"</span><span class='hs-layout'>)</span><span class='hs-layout'>,</span>
<a name="line-587"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span>
<a name="line-588"></a>	<span class='hs-varid'>comma</span><span class='hs-layout'>,</span>
<a name="line-589"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span><span class='hs-layout'>,</span>
<a name="line-590"></a>	<span class='hs-varid'>comma</span><span class='hs-layout'>,</span>
<a name="line-591"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg3</span>
<a name="line-592"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-593"></a>
<a name="line-594"></a>
<a name="line-595"></a><a name="pprRegRIReg"></a><span class='hs-comment'>-- | Pretty print an instruction of two regs and a ri.</span>
<a name="line-596"></a><span class='hs-definition'>pprRegRIReg</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>LitString</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Bool</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'>Reg</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-conid'>Doc</span>
<a name="line-597"></a><span class='hs-definition'>pprRegRIReg</span> <span class='hs-varid'>name</span> <span class='hs-varid'>b</span> <span class='hs-varid'>reg1</span> <span class='hs-varid'>ri</span> <span class='hs-varid'>reg2</span>
<a name="line-598"></a>  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>hcat</span> <span class='hs-keyglyph'>[</span>
<a name="line-599"></a>	<span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-600"></a>	<span class='hs-varid'>ptext</span> <span class='hs-varid'>name</span><span class='hs-layout'>,</span>
<a name="line-601"></a>	<span class='hs-keyword'>if</span> <span class='hs-varid'>b</span> <span class='hs-keyword'>then</span> <span class='hs-varid'>ptext</span> <span class='hs-layout'>(</span><span class='hs-varid'>sLit</span> <span class='hs-str'>"cc\t"</span><span class='hs-layout'>)</span> <span class='hs-keyword'>else</span> <span class='hs-varid'>char</span> <span class='hs-chr'>'\t'</span><span class='hs-layout'>,</span>
<a name="line-602"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg1</span><span class='hs-layout'>,</span>
<a name="line-603"></a>	<span class='hs-varid'>comma</span><span class='hs-layout'>,</span>
<a name="line-604"></a>	<span class='hs-varid'>pprRI</span> <span class='hs-varid'>ri</span><span class='hs-layout'>,</span>
<a name="line-605"></a>	<span class='hs-varid'>comma</span><span class='hs-layout'>,</span>
<a name="line-606"></a>	<span class='hs-varid'>pprReg</span> <span class='hs-varid'>reg2</span>
<a name="line-607"></a>    <span class='hs-keyglyph'>]</span>
<a name="line-608"></a>
<a name="line-609"></a><span class='hs-comment'>{-
<a name="line-610"></a>pprRIReg :: LitString -&gt; Bool -&gt; RI -&gt; Reg -&gt; Doc
<a name="line-611"></a>pprRIReg name b ri reg1
<a name="line-612"></a>  = hcat [
<a name="line-613"></a>	char '\t',
<a name="line-614"></a>	ptext name,
<a name="line-615"></a>	if b then ptext (sLit "cc\t") else char '\t',
<a name="line-616"></a>	pprRI ri,
<a name="line-617"></a>	comma,
<a name="line-618"></a>	pprReg reg1
<a name="line-619"></a>    ]
<a name="line-620"></a>-}</span>
<a name="line-621"></a>
<a name="line-622"></a><span class='hs-comment'>{-
<a name="line-623"></a>pp_ld_lbracket :: Doc
<a name="line-624"></a>pp_ld_lbracket    = ptext (sLit "\tld\t[")
<a name="line-625"></a>-}</span>
<a name="line-626"></a>
<a name="line-627"></a><a name="pp_rbracket_comma"></a><span class='hs-definition'>pp_rbracket_comma</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Doc</span>
<a name="line-628"></a><span class='hs-definition'>pp_rbracket_comma</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>text</span> <span class='hs-str'>"],"</span>
<a name="line-629"></a>
<a name="line-630"></a>
<a name="line-631"></a><a name="pp_comma_lbracket"></a><span class='hs-definition'>pp_comma_lbracket</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Doc</span>
<a name="line-632"></a><span class='hs-definition'>pp_comma_lbracket</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>text</span> <span class='hs-str'>",["</span>
<a name="line-633"></a>
<a name="line-634"></a>
<a name="line-635"></a><a name="pp_comma_a"></a><span class='hs-definition'>pp_comma_a</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Doc</span>
<a name="line-636"></a><span class='hs-definition'>pp_comma_a</span>	  <span class='hs-keyglyph'>=</span> <span class='hs-varid'>text</span> <span class='hs-str'>",a"</span>
<a name="line-637"></a>
</pre></body>
</html>