<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns:p="urn:schemas-microsoft-com:office:powerpoint" xmlns:a="urn:schemas-microsoft-com:office:access" xmlns:dt="uuid:C2F41010-65B3-11d1-A29F-00AA00C14882" xmlns:s="uuid:BDC6E3F0-6DA3-11d1-A2A3-00AA00C14882" xmlns:rs="urn:schemas-microsoft-com:rowset" xmlns:z="#RowsetSchema" xmlns:b="urn:schemas-microsoft-com:office:publisher" xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet" xmlns:c="urn:schemas-microsoft-com:office:component:spreadsheet" xmlns:odc="urn:schemas-microsoft-com:office:odc" xmlns:oa="urn:schemas-microsoft-com:office:activation" xmlns:html="http://www.w3.org/TR/REC-html40" xmlns:q="http://schemas.xmlsoap.org/soap/envelope/" xmlns:rtc="http://microsoft.com/officenet/conferencing" xmlns:D="DAV:" xmlns:Repl="http://schemas.microsoft.com/repl/" xmlns:mt="http://schemas.microsoft.com/sharepoint/soap/meetings/" xmlns:x2="http://schemas.microsoft.com/office/excel/2003/xml" xmlns:ppda="http://www.passport.com/NameSpace.xsd" xmlns:ois="http://schemas.microsoft.com/sharepoint/soap/ois/" xmlns:dir="http://schemas.microsoft.com/sharepoint/soap/directory/" xmlns:ds="http://www.w3.org/2000/09/xmldsig#" xmlns:dsp="http://schemas.microsoft.com/sharepoint/dsp" xmlns:udc="http://schemas.microsoft.com/data/udc" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:sub="http://schemas.microsoft.com/sharepoint/soap/2002/1/alerts/" xmlns:ec="http://www.w3.org/2001/04/xmlenc#" xmlns:sp="http://schemas.microsoft.com/sharepoint/" xmlns:sps="http://schemas.microsoft.com/sharepoint/soap/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:udcs="http://schemas.microsoft.com/data/udc/soap" xmlns:udcxf="http://schemas.microsoft.com/data/udc/xmlfile" xmlns:udcp2p="http://schemas.microsoft.com/data/udc/parttopart" xmlns:wf="http://schemas.microsoft.com/sharepoint/soap/workflow/" xmlns:dsss="http://schemas.microsoft.com/office/2006/digsig-setup" xmlns:dssi="http://schemas.microsoft.com/office/2006/digsig" xmlns:mdssi="http://schemas.openxmlformats.org/package/2006/digital-signature" xmlns:mver="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns:mrels="http://schemas.openxmlformats.org/package/2006/relationships" xmlns:spwp="http://microsoft.com/sharepoint/webpartpages" xmlns:ex12t="http://schemas.microsoft.com/exchange/services/2006/types" xmlns:ex12m="http://schemas.microsoft.com/exchange/services/2006/messages" xmlns:pptsl="http://schemas.microsoft.com/sharepoint/soap/SlideLibrary/" xmlns:spsl="http://microsoft.com/webservices/SharePointPortalServer/PublishedLinksService" xmlns:Z="urn:schemas-microsoft-com:" xmlns:st="" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Generator" content="Microsoft Word 12 (filtered medium)">
<style>
<!--
/* Font Definitions */
@font-face
{font-family:"MS Mincho";
panose-1:2 2 6 9 4 2 5 8 3 4;}
@font-face
{font-family:"MS Mincho";
panose-1:2 2 6 9 4 2 5 8 3 4;}
@font-face
{font-family:Calibri;
panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
{font-family:Tahoma;
panose-1:2 11 6 4 3 5 4 4 2 4;}
@font-face
{font-family:"\@MS Mincho";
panose-1:2 2 6 9 4 2 5 8 3 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0cm;
margin-bottom:.0001pt;
font-size:12.0pt;
font-family:"Times New Roman","serif";}
a:link, span.MsoHyperlink
{mso-style-priority:99;
color:blue;
text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
{mso-style-priority:99;
color:purple;
text-decoration:underline;}
span.EmailStyle17
{mso-style-type:personal-reply;
font-family:"Calibri","sans-serif";
color:#1F497D;}
.MsoChpDefault
{mso-style-type:export-only;}
@page Section1
{size:612.0pt 792.0pt;
margin:72.0pt 72.0pt 72.0pt 72.0pt;}
div.Section1
{page:Section1;}
-->
</style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-GB" link="blue" vlink="purple">
<div class="Section1">
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";
color:#1F497D">Hi Guillermo,<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";
color:#1F497D"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";
color:#1F497D">I’m unable to reproduce the error you’re seeing with your bitcode input. “llc –mtriple armv7a-unknown-linux-gnueabi –O3” succeeds.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";
color:#1F497D"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";
color:#1F497D">What are you using to reproduce, and what version?<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";
color:#1F497D"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";
color:#1F497D">Cheers,<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";
color:#1F497D"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";
color:#1F497D">James<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";
color:#1F497D"><o:p> </o:p></span></p>
<div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0cm 0cm 0cm">
<p class="MsoNormal"><b><span lang="EN-US" style="font-size:10.0pt;font-family:
"Tahoma","sans-serif"">From:</span></b><span lang="EN-US" style="font-size:10.0pt;
font-family:"Tahoma","sans-serif""> Guillermo Perez [mailto:gaperez64@gmail.com]
<br>
<b>Sent:</b> 20 February 2012 11:32<br>
<b>To:</b> James Molloy; llvmdev@cs.uiuc.edu<br>
<b>Subject:</b> Re: [LLVMdev] ARM opcode format<o:p></o:p></span></p>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Hi,<o:p></o:p></p>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">I haven't been able to reproduce this problem on a smaller test and the original source code is from another virtual machine's IR. What I found out was that 42 << 7 is actually DPSoRegImmFrm, defined in ARMInstrFormats.td. This format is
not dealt with in the ARMCodeEmitter.cpp and that's the problem I'm facing.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">The triple I'm using is "armv7-unknown-linux-gnueabi" and the bitcode I'm dealing with is:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<div>
<p class="MsoNormal"><span style="color:#006600"> ; ModuleID = 'CRYO jit'</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> target triple = "armv7a-unknown-linux-gnueabi"</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> define i32 @execute(i8* %JNIEnv, i8* %v8) {</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> entry:</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %litTemp = alloca i32</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %v0_INTEGER = alloca i32</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %v4_INTEGER = alloca i32</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %v5_INTEGER = alloca i32</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %v2_INTEGER = alloca i32</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %v6_INTEGER = alloca i32</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %v5_POINTER = alloca i8*</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %v1_INTEGER = alloca i32</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %v3_INTEGER = alloca i32</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %v7_INTEGER = alloca i32</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 1, i32* %v7_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 1, i32* %v3_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 0, i32* %v1_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %0 = getelementptr i8* %v8, i32 8</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %1 = bitcast i8* %0 to i8**</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %2 = load i8** %1</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i8* %2, i8** %v5_POINTER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 0, i32* %v6_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %3 = load i8** %v5_POINTER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %4 = getelementptr i8* %3, i32 12</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %5 = bitcast i8* %4 to i32*</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %6 = load i32* %v6_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %7 = getelementptr i32* %5, i32 %6</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %8 = load i32* %v7_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 %8, i32* %7</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %9 = getelementptr i8* %v8, i32 8</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %10 = bitcast i8* %9 to i8**</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %11 = load i8** %10</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i8* %11, i8** %v5_POINTER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 2, i32* %v6_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %12 = load i8** %v5_POINTER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %13 = getelementptr i8* %12, i32 12</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %14 = bitcast i8* %13 to i32*</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %15 = load i32* %v7_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %16 = getelementptr i32* %14, i32 %15</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %17 = load i32* %v6_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 %17, i32* %16</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 2, i32* %v3_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 3, i32* %v2_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> br label %label000f</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> label000f: ; preds = %merge0024, %entry</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %18 = getelementptr i8* %v8, i32 12</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %19 = bitcast i8* %18 to i32*</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %20 = load i32* %19</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 %20, i32* %v5_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %21 = load i32* %v2_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %22 = load i32* %v5_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %23 = icmp slt i32 %21, %22</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> br i1 %23, label %merge0014, label %else</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> else: ; preds = %label000f</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %24 = load i32* %v3_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> ret i32 %24</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> merge0014: ; preds = %label000f</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 1, i32* %v4_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 1, i32* %v0_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> br label %label0016</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> label0016: ; preds = %merge003e, %merge0014</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %25 = load i32* %v4_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %26 = load i32* %v3_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %27 = icmp sge i32 %25, %26</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> br i1 %27, label %merge001a, label %else1</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> else1: ; preds = %label0016</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %28 = load i32* %v0_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %29 = icmp ne i32 %28, 0</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> br i1 %29, label %merge0027, label %else2</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> else2: ; preds = %else1</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> br label %merge001a</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> merge001a: ; preds = %else2, %label0016</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %30 = load i32* %v0_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %31 = icmp eq i32 %30, 0</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> br i1 %31, label %merge0024, label %else3</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> else3: ; preds = %merge001a</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %32 = load i32* %v3_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 1, i32* %litTemp</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %33 = load i32* %litTemp</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %34 = add i32 %32, %33</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 %34, i32* %v3_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %35 = getelementptr i8* %v8, i32 8</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %36 = bitcast i8* %35 to i8**</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %37 = load i8** %36</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i8* %37, i8** %v5_POINTER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %38 = load i32* %v3_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %39 = load i32* %v7_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %40 = sub i32 %38, %39</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 %40, i32* %v6_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %41 = load i8** %v5_POINTER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %42 = getelementptr i8* %41, i32 12</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %43 = bitcast i8* %42 to i32*</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %44 = load i32* %v6_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %45 = getelementptr i32* %43, i32 %44</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %46 = load i32* %v2_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 %46, i32* %45</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> br label %merge0024</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> merge0024: ; preds = %else3, %merge001a</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %47 = load i32* %v2_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 1, i32* %litTemp</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %48 = load i32* %litTemp</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %49 = add i32 %47, %48</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 %49, i32* %v2_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> br label %label000f</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> merge0027: ; preds = %else1</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %50 = getelementptr i8* %v8, i32 8</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %51 = bitcast i8* %50 to i8**</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %52 = load i8** %51</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i8* %52, i8** %v5_POINTER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %53 = load i8** %v5_POINTER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %54 = getelementptr i8* %53, i32 12</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %55 = bitcast i8* %54 to i32*</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %56 = load i32* %v4_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %57 = getelementptr i32* %55, i32 %56</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %58 = load i32* %57</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 %58, i32* %v5_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %59 = load i32* %v5_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %60 = icmp sle i32 %59, 0</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> br i1 %60, label %merge003e, label %else4</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> else4: ; preds = %merge0027</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %61 = getelementptr i8* %v8, i32 8</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %62 = bitcast i8* %61 to i8**</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %63 = load i8** %62</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i8* %63, i8** %v5_POINTER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %64 = load i8** %v5_POINTER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %65 = getelementptr i8* %64, i32 12</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %66 = bitcast i8* %65 to i32*</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %67 = load i32* %v4_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %68 = getelementptr i32* %66, i32 %67</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %69 = load i32* %68</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 %69, i32* %v5_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %70 = load i32* %v2_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 2, i32* %litTemp</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %71 = load i32* %litTemp</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %72 = udiv i32 %70, %71</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 %72, i32* %v6_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %73 = load i32* %v5_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %74 = load i32* %v6_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %75 = icmp sgt i32 %73, %74</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> br i1 %75, label %merge003e, label %else5</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> else5: ; preds = %else4</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %76 = getelementptr i8* %v8, i32 8</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %77 = bitcast i8* %76 to i8**</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %78 = load i8** %77</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i8* %78, i8** %v5_POINTER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %79 = load i8** %v5_POINTER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %80 = getelementptr i8* %79, i32 12</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %81 = bitcast i8* %80 to i32*</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %82 = load i32* %v4_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %83 = getelementptr i32* %81, i32 %82</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %84 = load i32* %83</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 %84, i32* %v5_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %85 = load i32* %v2_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %86 = load i32* %v5_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %87 = urem i32 %85, %86</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 %87, i32* %v5_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %88 = load i32* %v5_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %89 = icmp ne i32 %88, 0</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> br i1 %89, label %merge003e, label %else6</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> else6: ; preds = %else5</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 0, i32* %v0_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> br label %merge003e</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> merge003e: ; preds = %else6, %else5, %else4, %merge0027</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %90 = load i32* %v4_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 1, i32* %litTemp</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %91 = load i32* %litTemp</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> %92 = add i32 %90, %91</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> store i32 %92, i32* %v4_INTEGER</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> br label %label0016</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#006600"> }</span><o:p></o:p></p>
</div>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">Thanks for your help,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal">On Mon, Feb 20, 2012 at 7:10 PM, James Molloy <<a href="mailto:james.molloy@arm.com">james.molloy@arm.com</a>> wrote:<o:p></o:p></p>
<div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D">Hi Guillermo,</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D"> </span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D">It’s difficult to do anything without a testcase – do you have a (reduced) testcase available?</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D"> </span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D">Cheers,</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D"> </span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D">James</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D"> </span><o:p></o:p></p>
<div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0cm 0cm 0cm">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><b><span lang="EN-US" style="font-size:10.0pt;font-family:"Tahoma","sans-serif"">From:</span></b><span lang="EN-US" style="font-size:10.0pt;font-family:"Tahoma","sans-serif"">
<a href="mailto:llvmdev-bounces@cs.uiuc.edu" target="_blank">llvmdev-bounces@cs.uiuc.edu</a> [mailto:<a href="mailto:llvmdev-bounces@cs.uiuc.edu" target="_blank">llvmdev-bounces@cs.uiuc.edu</a>]
<b>On Behalf Of </b>Guillermo Perez<br>
<b>Sent:</b> 20 February 2012 07:48<br>
<b>To:</b> <a href="mailto:llvmdev@cs.uiuc.edu" target="_blank">llvmdev@cs.uiuc.edu</a><br>
<b>Subject:</b> [LLVMdev] ARM opcode format</span><o:p></o:p></p>
</div>
<div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">I'm doing some tests running llvm on Android. I'm getting an error message saying:<o:p></o:p></p>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">Unhandled instruction encoding format!<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">I checked which instruction was causing this and it is ADDrsi, it appears to have format 42 << 7, which is definitely not available in ARMBaseInfo.h<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">Any suggestions are welcome<br clear="all">
<o:p></o:p></p>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">--
<br>
Guillermo A. Pérez (<span style="font-family:"MS Mincho"">吉耶莫</span>)<o:p></o:p></p>
</div>
</div>
</div>
</div>
</div>
</div>
<p class="MsoNormal"><br>
<br clear="all">
<o:p></o:p></p>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<p class="MsoNormal">-- <br>
Guillermo A. Pérez (<span style="font-family:"MS Mincho"">吉耶莫</span>)<o:p></o:p></p>
</div>
</div>
<br>
<font face="Arial" color="Black" size="2">-- IMPORTANT NOTICE: The contents of this email and any attachments are confidential and may also be privileged. If you are not the intended recipient, please notify the sender immediately and do not disclose the contents
to any other person, use it for any purpose, or store or copy the information in any medium. Thank you.<br>
</font>
</body>
</html>