[LLVMdev] ARM opcode format
James Molloy
James.Molloy at arm.com
Mon Feb 20 03:55:17 PST 2012
Hi Guillermo,
I’m unable to reproduce the error you’re seeing with your bitcode input. “llc –mtriple armv7a-unknown-linux-gnueabi –O3” succeeds.
What are you using to reproduce, and what version?
Cheers,
James
From: Guillermo Perez [mailto:gaperez64 at gmail.com]
Sent: 20 February 2012 11:32
To: James Molloy; llvmdev at cs.uiuc.edu
Subject: Re: [LLVMdev] ARM opcode format
Hi,
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.
The triple I'm using is "armv7-unknown-linux-gnueabi" and the bitcode I'm dealing with is:
; ModuleID = 'CRYO jit'
target triple = "armv7a-unknown-linux-gnueabi"
define i32 @execute(i8* %JNIEnv, i8* %v8) {
entry:
%litTemp = alloca i32
%v0_INTEGER = alloca i32
%v4_INTEGER = alloca i32
%v5_INTEGER = alloca i32
%v2_INTEGER = alloca i32
%v6_INTEGER = alloca i32
%v5_POINTER = alloca i8*
%v1_INTEGER = alloca i32
%v3_INTEGER = alloca i32
%v7_INTEGER = alloca i32
store i32 1, i32* %v7_INTEGER
store i32 1, i32* %v3_INTEGER
store i32 0, i32* %v1_INTEGER
%0 = getelementptr i8* %v8, i32 8
%1 = bitcast i8* %0 to i8**
%2 = load i8** %1
store i8* %2, i8** %v5_POINTER
store i32 0, i32* %v6_INTEGER
%3 = load i8** %v5_POINTER
%4 = getelementptr i8* %3, i32 12
%5 = bitcast i8* %4 to i32*
%6 = load i32* %v6_INTEGER
%7 = getelementptr i32* %5, i32 %6
%8 = load i32* %v7_INTEGER
store i32 %8, i32* %7
%9 = getelementptr i8* %v8, i32 8
%10 = bitcast i8* %9 to i8**
%11 = load i8** %10
store i8* %11, i8** %v5_POINTER
store i32 2, i32* %v6_INTEGER
%12 = load i8** %v5_POINTER
%13 = getelementptr i8* %12, i32 12
%14 = bitcast i8* %13 to i32*
%15 = load i32* %v7_INTEGER
%16 = getelementptr i32* %14, i32 %15
%17 = load i32* %v6_INTEGER
store i32 %17, i32* %16
store i32 2, i32* %v3_INTEGER
store i32 3, i32* %v2_INTEGER
br label %label000f
label000f: ; preds = %merge0024, %entry
%18 = getelementptr i8* %v8, i32 12
%19 = bitcast i8* %18 to i32*
%20 = load i32* %19
store i32 %20, i32* %v5_INTEGER
%21 = load i32* %v2_INTEGER
%22 = load i32* %v5_INTEGER
%23 = icmp slt i32 %21, %22
br i1 %23, label %merge0014, label %else
else: ; preds = %label000f
%24 = load i32* %v3_INTEGER
ret i32 %24
merge0014: ; preds = %label000f
store i32 1, i32* %v4_INTEGER
store i32 1, i32* %v0_INTEGER
br label %label0016
label0016: ; preds = %merge003e, %merge0014
%25 = load i32* %v4_INTEGER
%26 = load i32* %v3_INTEGER
%27 = icmp sge i32 %25, %26
br i1 %27, label %merge001a, label %else1
else1: ; preds = %label0016
%28 = load i32* %v0_INTEGER
%29 = icmp ne i32 %28, 0
br i1 %29, label %merge0027, label %else2
else2: ; preds = %else1
br label %merge001a
merge001a: ; preds = %else2, %label0016
%30 = load i32* %v0_INTEGER
%31 = icmp eq i32 %30, 0
br i1 %31, label %merge0024, label %else3
else3: ; preds = %merge001a
%32 = load i32* %v3_INTEGER
store i32 1, i32* %litTemp
%33 = load i32* %litTemp
%34 = add i32 %32, %33
store i32 %34, i32* %v3_INTEGER
%35 = getelementptr i8* %v8, i32 8
%36 = bitcast i8* %35 to i8**
%37 = load i8** %36
store i8* %37, i8** %v5_POINTER
%38 = load i32* %v3_INTEGER
%39 = load i32* %v7_INTEGER
%40 = sub i32 %38, %39
store i32 %40, i32* %v6_INTEGER
%41 = load i8** %v5_POINTER
%42 = getelementptr i8* %41, i32 12
%43 = bitcast i8* %42 to i32*
%44 = load i32* %v6_INTEGER
%45 = getelementptr i32* %43, i32 %44
%46 = load i32* %v2_INTEGER
store i32 %46, i32* %45
br label %merge0024
merge0024: ; preds = %else3, %merge001a
%47 = load i32* %v2_INTEGER
store i32 1, i32* %litTemp
%48 = load i32* %litTemp
%49 = add i32 %47, %48
store i32 %49, i32* %v2_INTEGER
br label %label000f
merge0027: ; preds = %else1
%50 = getelementptr i8* %v8, i32 8
%51 = bitcast i8* %50 to i8**
%52 = load i8** %51
store i8* %52, i8** %v5_POINTER
%53 = load i8** %v5_POINTER
%54 = getelementptr i8* %53, i32 12
%55 = bitcast i8* %54 to i32*
%56 = load i32* %v4_INTEGER
%57 = getelementptr i32* %55, i32 %56
%58 = load i32* %57
store i32 %58, i32* %v5_INTEGER
%59 = load i32* %v5_INTEGER
%60 = icmp sle i32 %59, 0
br i1 %60, label %merge003e, label %else4
else4: ; preds = %merge0027
%61 = getelementptr i8* %v8, i32 8
%62 = bitcast i8* %61 to i8**
%63 = load i8** %62
store i8* %63, i8** %v5_POINTER
%64 = load i8** %v5_POINTER
%65 = getelementptr i8* %64, i32 12
%66 = bitcast i8* %65 to i32*
%67 = load i32* %v4_INTEGER
%68 = getelementptr i32* %66, i32 %67
%69 = load i32* %68
store i32 %69, i32* %v5_INTEGER
%70 = load i32* %v2_INTEGER
store i32 2, i32* %litTemp
%71 = load i32* %litTemp
%72 = udiv i32 %70, %71
store i32 %72, i32* %v6_INTEGER
%73 = load i32* %v5_INTEGER
%74 = load i32* %v6_INTEGER
%75 = icmp sgt i32 %73, %74
br i1 %75, label %merge003e, label %else5
else5: ; preds = %else4
%76 = getelementptr i8* %v8, i32 8
%77 = bitcast i8* %76 to i8**
%78 = load i8** %77
store i8* %78, i8** %v5_POINTER
%79 = load i8** %v5_POINTER
%80 = getelementptr i8* %79, i32 12
%81 = bitcast i8* %80 to i32*
%82 = load i32* %v4_INTEGER
%83 = getelementptr i32* %81, i32 %82
%84 = load i32* %83
store i32 %84, i32* %v5_INTEGER
%85 = load i32* %v2_INTEGER
%86 = load i32* %v5_INTEGER
%87 = urem i32 %85, %86
store i32 %87, i32* %v5_INTEGER
%88 = load i32* %v5_INTEGER
%89 = icmp ne i32 %88, 0
br i1 %89, label %merge003e, label %else6
else6: ; preds = %else5
store i32 0, i32* %v0_INTEGER
br label %merge003e
merge003e: ; preds = %else6, %else5, %else4, %merge0027
%90 = load i32* %v4_INTEGER
store i32 1, i32* %litTemp
%91 = load i32* %litTemp
%92 = add i32 %90, %91
store i32 %92, i32* %v4_INTEGER
br label %label0016
}
Thanks for your help,
On Mon, Feb 20, 2012 at 7:10 PM, James Molloy <james.molloy at arm.com<mailto:james.molloy at arm.com>> wrote:
Hi Guillermo,
It’s difficult to do anything without a testcase – do you have a (reduced) testcase available?
Cheers,
James
From: llvmdev-bounces at cs.uiuc.edu<mailto:llvmdev-bounces at cs.uiuc.edu> [mailto:llvmdev-bounces at cs.uiuc.edu<mailto:llvmdev-bounces at cs.uiuc.edu>] On Behalf Of Guillermo Perez
Sent: 20 February 2012 07:48
To: llvmdev at cs.uiuc.edu<mailto:llvmdev at cs.uiuc.edu>
Subject: [LLVMdev] ARM opcode format
I'm doing some tests running llvm on Android. I'm getting an error message saying:
Unhandled instruction encoding format!
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
Any suggestions are welcome
--
Guillermo A. Pérez (吉耶莫)
--
Guillermo A. Pérez (吉耶莫)
-- 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.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20120220/4932f1d3/attachment.html>
More information about the llvm-dev
mailing list