diff options
author | Pirama Arumuga Nainar <pirama@google.com> | 2015-04-08 08:55:49 -0700 |
---|---|---|
committer | Pirama Arumuga Nainar <pirama@google.com> | 2015-04-09 15:04:38 -0700 |
commit | 4c5e43da7792f75567b693105cc53e3f1992ad98 (patch) | |
tree | 1b2c9792582e12f5af0b1512e3094425f0dc0df9 /test/CodeGen/Thumb | |
parent | c75239e6119d0f9a74c57099d91cbc9bde56bf33 (diff) | |
download | external_llvm-4c5e43da7792f75567b693105cc53e3f1992ad98.zip external_llvm-4c5e43da7792f75567b693105cc53e3f1992ad98.tar.gz external_llvm-4c5e43da7792f75567b693105cc53e3f1992ad98.tar.bz2 |
Update aosp/master llvm for rebase to r233350
Change-Id: I07d935f8793ee8ec6b7da003f6483046594bca49
Diffstat (limited to 'test/CodeGen/Thumb')
28 files changed, 569 insertions, 516 deletions
diff --git a/test/CodeGen/Thumb/2007-01-31-RegInfoAssert.ll b/test/CodeGen/Thumb/2007-01-31-RegInfoAssert.ll index 1e61b23..37bcc36 100644 --- a/test/CodeGen/Thumb/2007-01-31-RegInfoAssert.ll +++ b/test/CodeGen/Thumb/2007-01-31-RegInfoAssert.ll @@ -6,7 +6,7 @@ define void @f1() { %D = alloca %struct.rtx_def, align 1 %tmp1 = bitcast %struct.rtx_def* %D to i32* - %tmp7 = load i32* %tmp1 + %tmp7 = load i32, i32* %tmp1 %tmp14 = lshr i32 %tmp7, 1 %tmp1415 = and i32 %tmp14, 1 call void (i32, ...)* @printf( i32 undef, i32 0, i32 %tmp1415 ) diff --git a/test/CodeGen/Thumb/2007-05-05-InvalidPushPop.ll b/test/CodeGen/Thumb/2007-05-05-InvalidPushPop.ll index 929c472..71fb005 100644 --- a/test/CodeGen/Thumb/2007-05-05-InvalidPushPop.ll +++ b/test/CodeGen/Thumb/2007-05-05-InvalidPushPop.ll @@ -9,7 +9,7 @@ target triple = "thumb-unknown-linux-gnueabi" define i8* @f(i8* %a) { entry: - %tmp1 = load i32* @i.1882 ; <i32> [#uses=1] + %tmp1 = load i32, i32* @i.1882 ; <i32> [#uses=1] %tmp2 = add i32 %tmp1, 1 ; <i32> [#uses=2] store i32 %tmp2, i32* @i.1882 %tmp34 = inttoptr i32 %tmp2 to i8* ; <i8*> [#uses=1] @@ -21,16 +21,16 @@ entry: %t = alloca i32, align 4 ; <i32*> [#uses=4] %ret = alloca i32, align 4 ; <i32*> [#uses=3] %tmp1 = call i32 @pthread_create( i32* %t, %struct.pthread_attr_t* null, i8* (i8*)* @f, i8* null ) ; <i32> [#uses=0] - %tmp2 = load i32* %t ; <i32> [#uses=1] + %tmp2 = load i32, i32* %t ; <i32> [#uses=1] %ret3 = bitcast i32* %ret to i8** ; <i8**> [#uses=2] %tmp4 = call i32 @pthread_join( i32 %tmp2, i8** %ret3 ) ; <i32> [#uses=0] - %tmp5 = load i32* %ret ; <i32> [#uses=1] - %tmp7 = call i32 (i8*, ...)* @printf( i8* getelementptr ([14 x i8]* @.str, i32 0, i32 0), i32 %tmp5 ) ; <i32> [#uses=0] + %tmp5 = load i32, i32* %ret ; <i32> [#uses=1] + %tmp7 = call i32 (i8*, ...)* @printf( i8* getelementptr ([14 x i8], [14 x i8]* @.str, i32 0, i32 0), i32 %tmp5 ) ; <i32> [#uses=0] %tmp8 = call i32 @pthread_create( i32* %t, %struct.pthread_attr_t* null, i8* (i8*)* @f, i8* null ) ; <i32> [#uses=0] - %tmp9 = load i32* %t ; <i32> [#uses=1] + %tmp9 = load i32, i32* %t ; <i32> [#uses=1] %tmp11 = call i32 @pthread_join( i32 %tmp9, i8** %ret3 ) ; <i32> [#uses=0] - %tmp12 = load i32* %ret ; <i32> [#uses=1] - %tmp14 = call i32 (i8*, ...)* @printf( i8* getelementptr ([14 x i8]* @.str1, i32 0, i32 0), i32 %tmp12 ) ; <i32> [#uses=0] + %tmp12 = load i32, i32* %ret ; <i32> [#uses=1] + %tmp14 = call i32 (i8*, ...)* @printf( i8* getelementptr ([14 x i8], [14 x i8]* @.str1, i32 0, i32 0), i32 %tmp12 ) ; <i32> [#uses=0] ret i32 0 } diff --git a/test/CodeGen/Thumb/2009-07-20-TwoAddrBug.ll b/test/CodeGen/Thumb/2009-07-20-TwoAddrBug.ll index d4651a1..fd30032 100644 --- a/test/CodeGen/Thumb/2009-07-20-TwoAddrBug.ll +++ b/test/CodeGen/Thumb/2009-07-20-TwoAddrBug.ll @@ -4,7 +4,7 @@ define i64 @millisecs() nounwind { entry: - %0 = load i64* @Time.2535, align 4 ; <i64> [#uses=2] + %0 = load i64, i64* @Time.2535, align 4 ; <i64> [#uses=2] %1 = add i64 %0, 1 ; <i64> [#uses=1] store i64 %1, i64* @Time.2535, align 4 ret i64 %0 diff --git a/test/CodeGen/Thumb/2009-08-12-ConstIslandAssert.ll b/test/CodeGen/Thumb/2009-08-12-ConstIslandAssert.ll index 5b420fc..7036dd1 100644 --- a/test/CodeGen/Thumb/2009-08-12-ConstIslandAssert.ll +++ b/test/CodeGen/Thumb/2009-08-12-ConstIslandAssert.ll @@ -4,697 +4,697 @@ define void @BF_encrypt(i32* nocapture %data, %struct.BF_KEY* nocapture %key, i32 %encrypt) nounwind { entry: - %0 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 0; <i32*> [#uses=2] - %1 = load i32* %data, align 4 ; <i32> [#uses=2] - %2 = load i32* undef, align 4 ; <i32> [#uses=2] + %0 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 0; <i32*> [#uses=2] + %1 = load i32, i32* %data, align 4 ; <i32> [#uses=2] + %2 = load i32, i32* undef, align 4 ; <i32> [#uses=2] br i1 undef, label %bb1, label %bb bb: ; preds = %entry - %3 = load i32* %0, align 4 ; <i32> [#uses=1] + %3 = load i32, i32* %0, align 4 ; <i32> [#uses=1] %4 = xor i32 %3, %1 ; <i32> [#uses=4] - %5 = load i32* null, align 4 ; <i32> [#uses=1] + %5 = load i32, i32* null, align 4 ; <i32> [#uses=1] %6 = lshr i32 %4, 24 ; <i32> [#uses=1] - %7 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %6; <i32*> [#uses=1] - %8 = load i32* %7, align 4 ; <i32> [#uses=1] + %7 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %6; <i32*> [#uses=1] + %8 = load i32, i32* %7, align 4 ; <i32> [#uses=1] %9 = lshr i32 %4, 16 ; <i32> [#uses=1] %10 = or i32 %9, 256 ; <i32> [#uses=1] %11 = and i32 %10, 511 ; <i32> [#uses=1] - %12 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %11; <i32*> [#uses=1] - %13 = load i32* %12, align 4 ; <i32> [#uses=1] + %12 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %11; <i32*> [#uses=1] + %13 = load i32, i32* %12, align 4 ; <i32> [#uses=1] %14 = add i32 %13, %8 ; <i32> [#uses=1] - %15 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 undef; <i32*> [#uses=1] - %16 = load i32* %15, align 4 ; <i32> [#uses=1] + %15 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 undef; <i32*> [#uses=1] + %16 = load i32, i32* %15, align 4 ; <i32> [#uses=1] %17 = xor i32 %14, %16 ; <i32> [#uses=1] %18 = or i32 %4, 768 ; <i32> [#uses=1] %19 = and i32 %18, 1023 ; <i32> [#uses=1] - %20 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %19; <i32*> [#uses=1] - %21 = load i32* %20, align 4 ; <i32> [#uses=1] + %20 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %19; <i32*> [#uses=1] + %21 = load i32, i32* %20, align 4 ; <i32> [#uses=1] %22 = add i32 %17, %21 ; <i32> [#uses=1] %23 = xor i32 %5, %2 ; <i32> [#uses=1] %24 = xor i32 %23, %22 ; <i32> [#uses=5] - %25 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 2; <i32*> [#uses=1] - %26 = load i32* %25, align 4 ; <i32> [#uses=1] + %25 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 2; <i32*> [#uses=1] + %26 = load i32, i32* %25, align 4 ; <i32> [#uses=1] %27 = lshr i32 %24, 24 ; <i32> [#uses=1] - %28 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %27; <i32*> [#uses=1] - %29 = load i32* %28, align 4 ; <i32> [#uses=1] + %28 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %27; <i32*> [#uses=1] + %29 = load i32, i32* %28, align 4 ; <i32> [#uses=1] %30 = lshr i32 %24, 16 ; <i32> [#uses=1] %31 = or i32 %30, 256 ; <i32> [#uses=1] %32 = and i32 %31, 511 ; <i32> [#uses=1] - %33 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %32; <i32*> [#uses=1] - %34 = load i32* %33, align 4 ; <i32> [#uses=1] + %33 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %32; <i32*> [#uses=1] + %34 = load i32, i32* %33, align 4 ; <i32> [#uses=1] %35 = add i32 %34, %29 ; <i32> [#uses=1] %36 = lshr i32 %24, 8 ; <i32> [#uses=1] %37 = or i32 %36, 512 ; <i32> [#uses=1] %38 = and i32 %37, 767 ; <i32> [#uses=1] - %39 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %38; <i32*> [#uses=1] - %40 = load i32* %39, align 4 ; <i32> [#uses=1] + %39 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %38; <i32*> [#uses=1] + %40 = load i32, i32* %39, align 4 ; <i32> [#uses=1] %41 = xor i32 %35, %40 ; <i32> [#uses=1] %42 = or i32 %24, 768 ; <i32> [#uses=1] %43 = and i32 %42, 1023 ; <i32> [#uses=1] - %44 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %43; <i32*> [#uses=1] - %45 = load i32* %44, align 4 ; <i32> [#uses=1] + %44 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %43; <i32*> [#uses=1] + %45 = load i32, i32* %44, align 4 ; <i32> [#uses=1] %46 = add i32 %41, %45 ; <i32> [#uses=1] %47 = xor i32 %26, %4 ; <i32> [#uses=1] %48 = xor i32 %47, %46 ; <i32> [#uses=5] - %49 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 3; <i32*> [#uses=1] - %50 = load i32* %49, align 4 ; <i32> [#uses=1] + %49 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 3; <i32*> [#uses=1] + %50 = load i32, i32* %49, align 4 ; <i32> [#uses=1] %51 = lshr i32 %48, 24 ; <i32> [#uses=1] - %52 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %51; <i32*> [#uses=1] - %53 = load i32* %52, align 4 ; <i32> [#uses=1] + %52 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %51; <i32*> [#uses=1] + %53 = load i32, i32* %52, align 4 ; <i32> [#uses=1] %54 = lshr i32 %48, 16 ; <i32> [#uses=1] %55 = or i32 %54, 256 ; <i32> [#uses=1] %56 = and i32 %55, 511 ; <i32> [#uses=1] - %57 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %56; <i32*> [#uses=1] - %58 = load i32* %57, align 4 ; <i32> [#uses=1] + %57 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %56; <i32*> [#uses=1] + %58 = load i32, i32* %57, align 4 ; <i32> [#uses=1] %59 = add i32 %58, %53 ; <i32> [#uses=1] %60 = lshr i32 %48, 8 ; <i32> [#uses=1] %61 = or i32 %60, 512 ; <i32> [#uses=1] %62 = and i32 %61, 767 ; <i32> [#uses=1] - %63 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %62; <i32*> [#uses=1] - %64 = load i32* %63, align 4 ; <i32> [#uses=1] + %63 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %62; <i32*> [#uses=1] + %64 = load i32, i32* %63, align 4 ; <i32> [#uses=1] %65 = xor i32 %59, %64 ; <i32> [#uses=1] %66 = or i32 %48, 768 ; <i32> [#uses=1] %67 = and i32 %66, 1023 ; <i32> [#uses=1] - %68 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %67; <i32*> [#uses=1] - %69 = load i32* %68, align 4 ; <i32> [#uses=1] + %68 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %67; <i32*> [#uses=1] + %69 = load i32, i32* %68, align 4 ; <i32> [#uses=1] %70 = add i32 %65, %69 ; <i32> [#uses=1] %71 = xor i32 %50, %24 ; <i32> [#uses=1] %72 = xor i32 %71, %70 ; <i32> [#uses=5] - %73 = load i32* null, align 4 ; <i32> [#uses=1] + %73 = load i32, i32* null, align 4 ; <i32> [#uses=1] %74 = lshr i32 %72, 24 ; <i32> [#uses=1] - %75 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %74; <i32*> [#uses=1] - %76 = load i32* %75, align 4 ; <i32> [#uses=1] + %75 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %74; <i32*> [#uses=1] + %76 = load i32, i32* %75, align 4 ; <i32> [#uses=1] %77 = lshr i32 %72, 16 ; <i32> [#uses=1] %78 = or i32 %77, 256 ; <i32> [#uses=1] %79 = and i32 %78, 511 ; <i32> [#uses=1] - %80 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %79; <i32*> [#uses=1] - %81 = load i32* %80, align 4 ; <i32> [#uses=1] + %80 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %79; <i32*> [#uses=1] + %81 = load i32, i32* %80, align 4 ; <i32> [#uses=1] %82 = add i32 %81, %76 ; <i32> [#uses=1] %83 = lshr i32 %72, 8 ; <i32> [#uses=1] %84 = or i32 %83, 512 ; <i32> [#uses=1] %85 = and i32 %84, 767 ; <i32> [#uses=1] - %86 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %85; <i32*> [#uses=1] - %87 = load i32* %86, align 4 ; <i32> [#uses=1] + %86 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %85; <i32*> [#uses=1] + %87 = load i32, i32* %86, align 4 ; <i32> [#uses=1] %88 = xor i32 %82, %87 ; <i32> [#uses=1] %89 = or i32 %72, 768 ; <i32> [#uses=1] %90 = and i32 %89, 1023 ; <i32> [#uses=1] - %91 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %90; <i32*> [#uses=1] - %92 = load i32* %91, align 4 ; <i32> [#uses=1] + %91 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %90; <i32*> [#uses=1] + %92 = load i32, i32* %91, align 4 ; <i32> [#uses=1] %93 = add i32 %88, %92 ; <i32> [#uses=1] %94 = xor i32 %73, %48 ; <i32> [#uses=1] %95 = xor i32 %94, %93 ; <i32> [#uses=5] - %96 = load i32* undef, align 4 ; <i32> [#uses=1] + %96 = load i32, i32* undef, align 4 ; <i32> [#uses=1] %97 = lshr i32 %95, 24 ; <i32> [#uses=1] - %98 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %97; <i32*> [#uses=1] - %99 = load i32* %98, align 4 ; <i32> [#uses=1] + %98 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %97; <i32*> [#uses=1] + %99 = load i32, i32* %98, align 4 ; <i32> [#uses=1] %100 = lshr i32 %95, 16 ; <i32> [#uses=1] %101 = or i32 %100, 256 ; <i32> [#uses=1] %102 = and i32 %101, 511 ; <i32> [#uses=1] - %103 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %102; <i32*> [#uses=1] - %104 = load i32* %103, align 4 ; <i32> [#uses=1] + %103 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %102; <i32*> [#uses=1] + %104 = load i32, i32* %103, align 4 ; <i32> [#uses=1] %105 = add i32 %104, %99 ; <i32> [#uses=1] %106 = lshr i32 %95, 8 ; <i32> [#uses=1] %107 = or i32 %106, 512 ; <i32> [#uses=1] %108 = and i32 %107, 767 ; <i32> [#uses=1] - %109 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %108; <i32*> [#uses=1] - %110 = load i32* %109, align 4 ; <i32> [#uses=1] + %109 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %108; <i32*> [#uses=1] + %110 = load i32, i32* %109, align 4 ; <i32> [#uses=1] %111 = xor i32 %105, %110 ; <i32> [#uses=1] %112 = or i32 %95, 768 ; <i32> [#uses=1] %113 = and i32 %112, 1023 ; <i32> [#uses=1] - %114 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %113; <i32*> [#uses=1] - %115 = load i32* %114, align 4 ; <i32> [#uses=1] + %114 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %113; <i32*> [#uses=1] + %115 = load i32, i32* %114, align 4 ; <i32> [#uses=1] %116 = add i32 %111, %115 ; <i32> [#uses=1] %117 = xor i32 %96, %72 ; <i32> [#uses=1] %118 = xor i32 %117, %116 ; <i32> [#uses=5] - %119 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 6; <i32*> [#uses=1] - %120 = load i32* %119, align 4 ; <i32> [#uses=1] + %119 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 6; <i32*> [#uses=1] + %120 = load i32, i32* %119, align 4 ; <i32> [#uses=1] %121 = lshr i32 %118, 24 ; <i32> [#uses=1] - %122 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %121; <i32*> [#uses=1] - %123 = load i32* %122, align 4 ; <i32> [#uses=1] + %122 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %121; <i32*> [#uses=1] + %123 = load i32, i32* %122, align 4 ; <i32> [#uses=1] %124 = lshr i32 %118, 16 ; <i32> [#uses=1] %125 = or i32 %124, 256 ; <i32> [#uses=1] %126 = and i32 %125, 511 ; <i32> [#uses=1] - %127 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %126; <i32*> [#uses=1] - %128 = load i32* %127, align 4 ; <i32> [#uses=1] + %127 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %126; <i32*> [#uses=1] + %128 = load i32, i32* %127, align 4 ; <i32> [#uses=1] %129 = add i32 %128, %123 ; <i32> [#uses=1] %130 = lshr i32 %118, 8 ; <i32> [#uses=1] %131 = or i32 %130, 512 ; <i32> [#uses=1] %132 = and i32 %131, 767 ; <i32> [#uses=1] - %133 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %132; <i32*> [#uses=1] - %134 = load i32* %133, align 4 ; <i32> [#uses=1] + %133 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %132; <i32*> [#uses=1] + %134 = load i32, i32* %133, align 4 ; <i32> [#uses=1] %135 = xor i32 %129, %134 ; <i32> [#uses=1] %136 = or i32 %118, 768 ; <i32> [#uses=1] %137 = and i32 %136, 1023 ; <i32> [#uses=1] - %138 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %137; <i32*> [#uses=1] - %139 = load i32* %138, align 4 ; <i32> [#uses=1] + %138 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %137; <i32*> [#uses=1] + %139 = load i32, i32* %138, align 4 ; <i32> [#uses=1] %140 = add i32 %135, %139 ; <i32> [#uses=1] %141 = xor i32 %120, %95 ; <i32> [#uses=1] %142 = xor i32 %141, %140 ; <i32> [#uses=5] - %143 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 7; <i32*> [#uses=1] - %144 = load i32* %143, align 4 ; <i32> [#uses=1] + %143 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 7; <i32*> [#uses=1] + %144 = load i32, i32* %143, align 4 ; <i32> [#uses=1] %145 = lshr i32 %142, 24 ; <i32> [#uses=1] - %146 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %145; <i32*> [#uses=1] - %147 = load i32* %146, align 4 ; <i32> [#uses=1] + %146 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %145; <i32*> [#uses=1] + %147 = load i32, i32* %146, align 4 ; <i32> [#uses=1] %148 = lshr i32 %142, 16 ; <i32> [#uses=1] %149 = or i32 %148, 256 ; <i32> [#uses=1] %150 = and i32 %149, 511 ; <i32> [#uses=1] - %151 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %150; <i32*> [#uses=1] - %152 = load i32* %151, align 4 ; <i32> [#uses=1] + %151 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %150; <i32*> [#uses=1] + %152 = load i32, i32* %151, align 4 ; <i32> [#uses=1] %153 = add i32 %152, %147 ; <i32> [#uses=1] %154 = lshr i32 %142, 8 ; <i32> [#uses=1] %155 = or i32 %154, 512 ; <i32> [#uses=1] %156 = and i32 %155, 767 ; <i32> [#uses=1] - %157 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %156; <i32*> [#uses=1] - %158 = load i32* %157, align 4 ; <i32> [#uses=1] + %157 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %156; <i32*> [#uses=1] + %158 = load i32, i32* %157, align 4 ; <i32> [#uses=1] %159 = xor i32 %153, %158 ; <i32> [#uses=1] %160 = or i32 %142, 768 ; <i32> [#uses=1] %161 = and i32 %160, 1023 ; <i32> [#uses=1] - %162 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %161; <i32*> [#uses=1] - %163 = load i32* %162, align 4 ; <i32> [#uses=1] + %162 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %161; <i32*> [#uses=1] + %163 = load i32, i32* %162, align 4 ; <i32> [#uses=1] %164 = add i32 %159, %163 ; <i32> [#uses=1] %165 = xor i32 %144, %118 ; <i32> [#uses=1] %166 = xor i32 %165, %164 ; <i32> [#uses=5] - %167 = load i32* undef, align 4 ; <i32> [#uses=1] + %167 = load i32, i32* undef, align 4 ; <i32> [#uses=1] %168 = lshr i32 %166, 24 ; <i32> [#uses=1] - %169 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %168; <i32*> [#uses=1] - %170 = load i32* %169, align 4 ; <i32> [#uses=1] + %169 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %168; <i32*> [#uses=1] + %170 = load i32, i32* %169, align 4 ; <i32> [#uses=1] %171 = lshr i32 %166, 16 ; <i32> [#uses=1] %172 = or i32 %171, 256 ; <i32> [#uses=1] %173 = and i32 %172, 511 ; <i32> [#uses=1] - %174 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %173; <i32*> [#uses=1] - %175 = load i32* %174, align 4 ; <i32> [#uses=1] + %174 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %173; <i32*> [#uses=1] + %175 = load i32, i32* %174, align 4 ; <i32> [#uses=1] %176 = add i32 %175, %170 ; <i32> [#uses=1] %177 = lshr i32 %166, 8 ; <i32> [#uses=1] %178 = or i32 %177, 512 ; <i32> [#uses=1] %179 = and i32 %178, 767 ; <i32> [#uses=1] - %180 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %179; <i32*> [#uses=1] - %181 = load i32* %180, align 4 ; <i32> [#uses=1] + %180 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %179; <i32*> [#uses=1] + %181 = load i32, i32* %180, align 4 ; <i32> [#uses=1] %182 = xor i32 %176, %181 ; <i32> [#uses=1] %183 = or i32 %166, 768 ; <i32> [#uses=1] %184 = and i32 %183, 1023 ; <i32> [#uses=1] - %185 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %184; <i32*> [#uses=1] - %186 = load i32* %185, align 4 ; <i32> [#uses=1] + %185 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %184; <i32*> [#uses=1] + %186 = load i32, i32* %185, align 4 ; <i32> [#uses=1] %187 = add i32 %182, %186 ; <i32> [#uses=1] %188 = xor i32 %167, %142 ; <i32> [#uses=1] %189 = xor i32 %188, %187 ; <i32> [#uses=5] - %190 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 9; <i32*> [#uses=1] - %191 = load i32* %190, align 4 ; <i32> [#uses=1] + %190 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 9; <i32*> [#uses=1] + %191 = load i32, i32* %190, align 4 ; <i32> [#uses=1] %192 = lshr i32 %189, 24 ; <i32> [#uses=1] - %193 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %192; <i32*> [#uses=1] - %194 = load i32* %193, align 4 ; <i32> [#uses=1] + %193 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %192; <i32*> [#uses=1] + %194 = load i32, i32* %193, align 4 ; <i32> [#uses=1] %195 = lshr i32 %189, 16 ; <i32> [#uses=1] %196 = or i32 %195, 256 ; <i32> [#uses=1] %197 = and i32 %196, 511 ; <i32> [#uses=1] - %198 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %197; <i32*> [#uses=1] - %199 = load i32* %198, align 4 ; <i32> [#uses=1] + %198 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %197; <i32*> [#uses=1] + %199 = load i32, i32* %198, align 4 ; <i32> [#uses=1] %200 = add i32 %199, %194 ; <i32> [#uses=1] %201 = lshr i32 %189, 8 ; <i32> [#uses=1] %202 = or i32 %201, 512 ; <i32> [#uses=1] %203 = and i32 %202, 767 ; <i32> [#uses=1] - %204 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %203; <i32*> [#uses=1] - %205 = load i32* %204, align 4 ; <i32> [#uses=1] + %204 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %203; <i32*> [#uses=1] + %205 = load i32, i32* %204, align 4 ; <i32> [#uses=1] %206 = xor i32 %200, %205 ; <i32> [#uses=1] %207 = or i32 %189, 768 ; <i32> [#uses=1] %208 = and i32 %207, 1023 ; <i32> [#uses=1] - %209 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %208; <i32*> [#uses=1] - %210 = load i32* %209, align 4 ; <i32> [#uses=1] + %209 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %208; <i32*> [#uses=1] + %210 = load i32, i32* %209, align 4 ; <i32> [#uses=1] %211 = add i32 %206, %210 ; <i32> [#uses=1] %212 = xor i32 %191, %166 ; <i32> [#uses=1] %213 = xor i32 %212, %211 ; <i32> [#uses=5] - %214 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 10; <i32*> [#uses=1] - %215 = load i32* %214, align 4 ; <i32> [#uses=1] + %214 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 10; <i32*> [#uses=1] + %215 = load i32, i32* %214, align 4 ; <i32> [#uses=1] %216 = lshr i32 %213, 24 ; <i32> [#uses=1] - %217 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %216; <i32*> [#uses=1] - %218 = load i32* %217, align 4 ; <i32> [#uses=1] + %217 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %216; <i32*> [#uses=1] + %218 = load i32, i32* %217, align 4 ; <i32> [#uses=1] %219 = lshr i32 %213, 16 ; <i32> [#uses=1] %220 = or i32 %219, 256 ; <i32> [#uses=1] %221 = and i32 %220, 511 ; <i32> [#uses=1] - %222 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %221; <i32*> [#uses=1] - %223 = load i32* %222, align 4 ; <i32> [#uses=1] + %222 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %221; <i32*> [#uses=1] + %223 = load i32, i32* %222, align 4 ; <i32> [#uses=1] %224 = add i32 %223, %218 ; <i32> [#uses=1] %225 = lshr i32 %213, 8 ; <i32> [#uses=1] %226 = or i32 %225, 512 ; <i32> [#uses=1] %227 = and i32 %226, 767 ; <i32> [#uses=1] - %228 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %227; <i32*> [#uses=1] - %229 = load i32* %228, align 4 ; <i32> [#uses=1] + %228 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %227; <i32*> [#uses=1] + %229 = load i32, i32* %228, align 4 ; <i32> [#uses=1] %230 = xor i32 %224, %229 ; <i32> [#uses=1] %231 = or i32 %213, 768 ; <i32> [#uses=1] %232 = and i32 %231, 1023 ; <i32> [#uses=1] - %233 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %232; <i32*> [#uses=1] - %234 = load i32* %233, align 4 ; <i32> [#uses=1] + %233 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %232; <i32*> [#uses=1] + %234 = load i32, i32* %233, align 4 ; <i32> [#uses=1] %235 = add i32 %230, %234 ; <i32> [#uses=1] %236 = xor i32 %215, %189 ; <i32> [#uses=1] %237 = xor i32 %236, %235 ; <i32> [#uses=5] - %238 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 11; <i32*> [#uses=1] - %239 = load i32* %238, align 4 ; <i32> [#uses=1] + %238 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 11; <i32*> [#uses=1] + %239 = load i32, i32* %238, align 4 ; <i32> [#uses=1] %240 = lshr i32 %237, 24 ; <i32> [#uses=1] - %241 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %240; <i32*> [#uses=1] - %242 = load i32* %241, align 4 ; <i32> [#uses=1] + %241 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %240; <i32*> [#uses=1] + %242 = load i32, i32* %241, align 4 ; <i32> [#uses=1] %243 = lshr i32 %237, 16 ; <i32> [#uses=1] %244 = or i32 %243, 256 ; <i32> [#uses=1] %245 = and i32 %244, 511 ; <i32> [#uses=1] - %246 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %245; <i32*> [#uses=1] - %247 = load i32* %246, align 4 ; <i32> [#uses=1] + %246 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %245; <i32*> [#uses=1] + %247 = load i32, i32* %246, align 4 ; <i32> [#uses=1] %248 = add i32 %247, %242 ; <i32> [#uses=1] %249 = lshr i32 %237, 8 ; <i32> [#uses=1] %250 = or i32 %249, 512 ; <i32> [#uses=1] %251 = and i32 %250, 767 ; <i32> [#uses=1] - %252 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %251; <i32*> [#uses=1] - %253 = load i32* %252, align 4 ; <i32> [#uses=1] + %252 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %251; <i32*> [#uses=1] + %253 = load i32, i32* %252, align 4 ; <i32> [#uses=1] %254 = xor i32 %248, %253 ; <i32> [#uses=1] %255 = or i32 %237, 768 ; <i32> [#uses=1] %256 = and i32 %255, 1023 ; <i32> [#uses=1] - %257 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %256; <i32*> [#uses=1] - %258 = load i32* %257, align 4 ; <i32> [#uses=1] + %257 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %256; <i32*> [#uses=1] + %258 = load i32, i32* %257, align 4 ; <i32> [#uses=1] %259 = add i32 %254, %258 ; <i32> [#uses=1] %260 = xor i32 %239, %213 ; <i32> [#uses=1] %261 = xor i32 %260, %259 ; <i32> [#uses=5] - %262 = load i32* undef, align 4 ; <i32> [#uses=1] + %262 = load i32, i32* undef, align 4 ; <i32> [#uses=1] %263 = lshr i32 %261, 24 ; <i32> [#uses=1] - %264 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %263; <i32*> [#uses=1] - %265 = load i32* %264, align 4 ; <i32> [#uses=1] + %264 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %263; <i32*> [#uses=1] + %265 = load i32, i32* %264, align 4 ; <i32> [#uses=1] %266 = lshr i32 %261, 16 ; <i32> [#uses=1] %267 = or i32 %266, 256 ; <i32> [#uses=1] %268 = and i32 %267, 511 ; <i32> [#uses=1] - %269 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %268; <i32*> [#uses=1] - %270 = load i32* %269, align 4 ; <i32> [#uses=1] + %269 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %268; <i32*> [#uses=1] + %270 = load i32, i32* %269, align 4 ; <i32> [#uses=1] %271 = add i32 %270, %265 ; <i32> [#uses=1] %272 = lshr i32 %261, 8 ; <i32> [#uses=1] %273 = or i32 %272, 512 ; <i32> [#uses=1] %274 = and i32 %273, 767 ; <i32> [#uses=1] - %275 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %274; <i32*> [#uses=1] - %276 = load i32* %275, align 4 ; <i32> [#uses=1] + %275 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %274; <i32*> [#uses=1] + %276 = load i32, i32* %275, align 4 ; <i32> [#uses=1] %277 = xor i32 %271, %276 ; <i32> [#uses=1] %278 = or i32 %261, 768 ; <i32> [#uses=1] %279 = and i32 %278, 1023 ; <i32> [#uses=1] - %280 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %279; <i32*> [#uses=1] - %281 = load i32* %280, align 4 ; <i32> [#uses=1] + %280 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %279; <i32*> [#uses=1] + %281 = load i32, i32* %280, align 4 ; <i32> [#uses=1] %282 = add i32 %277, %281 ; <i32> [#uses=1] %283 = xor i32 %262, %237 ; <i32> [#uses=1] %284 = xor i32 %283, %282 ; <i32> [#uses=4] - %285 = load i32* null, align 4 ; <i32> [#uses=1] + %285 = load i32, i32* null, align 4 ; <i32> [#uses=1] %286 = lshr i32 %284, 24 ; <i32> [#uses=1] - %287 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %286; <i32*> [#uses=1] - %288 = load i32* %287, align 4 ; <i32> [#uses=1] + %287 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %286; <i32*> [#uses=1] + %288 = load i32, i32* %287, align 4 ; <i32> [#uses=1] %289 = lshr i32 %284, 16 ; <i32> [#uses=1] %290 = or i32 %289, 256 ; <i32> [#uses=1] %291 = and i32 %290, 511 ; <i32> [#uses=1] - %292 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %291; <i32*> [#uses=1] - %293 = load i32* %292, align 4 ; <i32> [#uses=1] + %292 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %291; <i32*> [#uses=1] + %293 = load i32, i32* %292, align 4 ; <i32> [#uses=1] %294 = add i32 %293, %288 ; <i32> [#uses=1] %295 = lshr i32 %284, 8 ; <i32> [#uses=1] %296 = or i32 %295, 512 ; <i32> [#uses=1] %297 = and i32 %296, 767 ; <i32> [#uses=1] - %298 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %297; <i32*> [#uses=1] - %299 = load i32* %298, align 4 ; <i32> [#uses=1] + %298 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %297; <i32*> [#uses=1] + %299 = load i32, i32* %298, align 4 ; <i32> [#uses=1] %300 = xor i32 %294, %299 ; <i32> [#uses=1] %301 = or i32 %284, 768 ; <i32> [#uses=1] %302 = and i32 %301, 1023 ; <i32> [#uses=1] - %303 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %302; <i32*> [#uses=1] - %304 = load i32* %303, align 4 ; <i32> [#uses=1] + %303 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %302; <i32*> [#uses=1] + %304 = load i32, i32* %303, align 4 ; <i32> [#uses=1] %305 = add i32 %300, %304 ; <i32> [#uses=1] %306 = xor i32 %285, %261 ; <i32> [#uses=1] %307 = xor i32 %306, %305 ; <i32> [#uses=1] - %308 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 15; <i32*> [#uses=1] - %309 = load i32* %308, align 4 ; <i32> [#uses=1] - %310 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 0; <i32*> [#uses=1] - %311 = load i32* %310, align 4 ; <i32> [#uses=1] + %308 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 15; <i32*> [#uses=1] + %309 = load i32, i32* %308, align 4 ; <i32> [#uses=1] + %310 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 0; <i32*> [#uses=1] + %311 = load i32, i32* %310, align 4 ; <i32> [#uses=1] %312 = or i32 0, 256 ; <i32> [#uses=1] %313 = and i32 %312, 511 ; <i32> [#uses=1] - %314 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %313; <i32*> [#uses=1] - %315 = load i32* %314, align 4 ; <i32> [#uses=1] + %314 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %313; <i32*> [#uses=1] + %315 = load i32, i32* %314, align 4 ; <i32> [#uses=1] %316 = add i32 %315, %311 ; <i32> [#uses=1] %317 = or i32 0, 512 ; <i32> [#uses=1] %318 = and i32 %317, 767 ; <i32> [#uses=1] - %319 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %318; <i32*> [#uses=1] - %320 = load i32* %319, align 4 ; <i32> [#uses=1] + %319 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %318; <i32*> [#uses=1] + %320 = load i32, i32* %319, align 4 ; <i32> [#uses=1] %321 = xor i32 %316, %320 ; <i32> [#uses=1] %322 = or i32 0, 768 ; <i32> [#uses=1] %323 = and i32 %322, 1023 ; <i32> [#uses=1] - %324 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %323; <i32*> [#uses=1] - %325 = load i32* %324, align 4 ; <i32> [#uses=1] + %324 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %323; <i32*> [#uses=1] + %325 = load i32, i32* %324, align 4 ; <i32> [#uses=1] %326 = add i32 %321, %325 ; <i32> [#uses=1] %327 = xor i32 %309, %307 ; <i32> [#uses=1] %328 = xor i32 %327, %326 ; <i32> [#uses=5] - %329 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 17; <i32*> [#uses=1] + %329 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 17; <i32*> [#uses=1] br label %bb2 bb1: ; preds = %entry - %330 = load i32* null, align 4 ; <i32> [#uses=1] + %330 = load i32, i32* null, align 4 ; <i32> [#uses=1] %331 = xor i32 %330, %1 ; <i32> [#uses=4] - %332 = load i32* null, align 4 ; <i32> [#uses=1] + %332 = load i32, i32* null, align 4 ; <i32> [#uses=1] %333 = lshr i32 %331, 24 ; <i32> [#uses=1] - %334 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %333; <i32*> [#uses=1] - %335 = load i32* %334, align 4 ; <i32> [#uses=1] - %336 = load i32* null, align 4 ; <i32> [#uses=1] + %334 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %333; <i32*> [#uses=1] + %335 = load i32, i32* %334, align 4 ; <i32> [#uses=1] + %336 = load i32, i32* null, align 4 ; <i32> [#uses=1] %337 = add i32 %336, %335 ; <i32> [#uses=1] %338 = lshr i32 %331, 8 ; <i32> [#uses=1] %339 = or i32 %338, 512 ; <i32> [#uses=1] %340 = and i32 %339, 767 ; <i32> [#uses=1] - %341 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %340; <i32*> [#uses=1] - %342 = load i32* %341, align 4 ; <i32> [#uses=1] + %341 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %340; <i32*> [#uses=1] + %342 = load i32, i32* %341, align 4 ; <i32> [#uses=1] %343 = xor i32 %337, %342 ; <i32> [#uses=1] %344 = or i32 %331, 768 ; <i32> [#uses=1] %345 = and i32 %344, 1023 ; <i32> [#uses=1] - %346 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %345; <i32*> [#uses=1] - %347 = load i32* %346, align 4 ; <i32> [#uses=1] + %346 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %345; <i32*> [#uses=1] + %347 = load i32, i32* %346, align 4 ; <i32> [#uses=1] %348 = add i32 %343, %347 ; <i32> [#uses=1] %349 = xor i32 %332, %2 ; <i32> [#uses=1] %350 = xor i32 %349, %348 ; <i32> [#uses=5] - %351 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 15; <i32*> [#uses=1] - %352 = load i32* %351, align 4 ; <i32> [#uses=1] + %351 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 15; <i32*> [#uses=1] + %352 = load i32, i32* %351, align 4 ; <i32> [#uses=1] %353 = lshr i32 %350, 24 ; <i32> [#uses=1] - %354 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %353; <i32*> [#uses=1] - %355 = load i32* %354, align 4 ; <i32> [#uses=1] + %354 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %353; <i32*> [#uses=1] + %355 = load i32, i32* %354, align 4 ; <i32> [#uses=1] %356 = lshr i32 %350, 16 ; <i32> [#uses=1] %357 = or i32 %356, 256 ; <i32> [#uses=1] %358 = and i32 %357, 511 ; <i32> [#uses=1] - %359 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %358; <i32*> [#uses=1] - %360 = load i32* %359, align 4 ; <i32> [#uses=1] + %359 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %358; <i32*> [#uses=1] + %360 = load i32, i32* %359, align 4 ; <i32> [#uses=1] %361 = add i32 %360, %355 ; <i32> [#uses=1] %362 = lshr i32 %350, 8 ; <i32> [#uses=1] %363 = or i32 %362, 512 ; <i32> [#uses=1] %364 = and i32 %363, 767 ; <i32> [#uses=1] - %365 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %364; <i32*> [#uses=1] - %366 = load i32* %365, align 4 ; <i32> [#uses=1] + %365 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %364; <i32*> [#uses=1] + %366 = load i32, i32* %365, align 4 ; <i32> [#uses=1] %367 = xor i32 %361, %366 ; <i32> [#uses=1] %368 = or i32 %350, 768 ; <i32> [#uses=1] %369 = and i32 %368, 1023 ; <i32> [#uses=1] - %370 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %369; <i32*> [#uses=1] - %371 = load i32* %370, align 4 ; <i32> [#uses=1] + %370 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %369; <i32*> [#uses=1] + %371 = load i32, i32* %370, align 4 ; <i32> [#uses=1] %372 = add i32 %367, %371 ; <i32> [#uses=1] %373 = xor i32 %352, %331 ; <i32> [#uses=1] %374 = xor i32 %373, %372 ; <i32> [#uses=5] - %375 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 14; <i32*> [#uses=1] - %376 = load i32* %375, align 4 ; <i32> [#uses=1] + %375 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 14; <i32*> [#uses=1] + %376 = load i32, i32* %375, align 4 ; <i32> [#uses=1] %377 = lshr i32 %374, 24 ; <i32> [#uses=1] - %378 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %377; <i32*> [#uses=1] - %379 = load i32* %378, align 4 ; <i32> [#uses=1] + %378 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %377; <i32*> [#uses=1] + %379 = load i32, i32* %378, align 4 ; <i32> [#uses=1] %380 = lshr i32 %374, 16 ; <i32> [#uses=1] %381 = or i32 %380, 256 ; <i32> [#uses=1] %382 = and i32 %381, 511 ; <i32> [#uses=1] - %383 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %382; <i32*> [#uses=1] - %384 = load i32* %383, align 4 ; <i32> [#uses=1] + %383 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %382; <i32*> [#uses=1] + %384 = load i32, i32* %383, align 4 ; <i32> [#uses=1] %385 = add i32 %384, %379 ; <i32> [#uses=1] %386 = lshr i32 %374, 8 ; <i32> [#uses=1] %387 = or i32 %386, 512 ; <i32> [#uses=1] %388 = and i32 %387, 767 ; <i32> [#uses=1] - %389 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %388; <i32*> [#uses=1] - %390 = load i32* %389, align 4 ; <i32> [#uses=1] + %389 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %388; <i32*> [#uses=1] + %390 = load i32, i32* %389, align 4 ; <i32> [#uses=1] %391 = xor i32 %385, %390 ; <i32> [#uses=1] %392 = or i32 %374, 768 ; <i32> [#uses=1] %393 = and i32 %392, 1023 ; <i32> [#uses=1] - %394 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %393; <i32*> [#uses=1] - %395 = load i32* %394, align 4 ; <i32> [#uses=1] + %394 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %393; <i32*> [#uses=1] + %395 = load i32, i32* %394, align 4 ; <i32> [#uses=1] %396 = add i32 %391, %395 ; <i32> [#uses=1] %397 = xor i32 %376, %350 ; <i32> [#uses=1] %398 = xor i32 %397, %396 ; <i32> [#uses=5] - %399 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 13; <i32*> [#uses=1] - %400 = load i32* %399, align 4 ; <i32> [#uses=1] + %399 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 13; <i32*> [#uses=1] + %400 = load i32, i32* %399, align 4 ; <i32> [#uses=1] %401 = lshr i32 %398, 24 ; <i32> [#uses=1] - %402 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %401; <i32*> [#uses=1] - %403 = load i32* %402, align 4 ; <i32> [#uses=1] + %402 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %401; <i32*> [#uses=1] + %403 = load i32, i32* %402, align 4 ; <i32> [#uses=1] %404 = lshr i32 %398, 16 ; <i32> [#uses=1] %405 = or i32 %404, 256 ; <i32> [#uses=1] %406 = and i32 %405, 511 ; <i32> [#uses=1] - %407 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %406; <i32*> [#uses=1] - %408 = load i32* %407, align 4 ; <i32> [#uses=1] + %407 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %406; <i32*> [#uses=1] + %408 = load i32, i32* %407, align 4 ; <i32> [#uses=1] %409 = add i32 %408, %403 ; <i32> [#uses=1] %410 = lshr i32 %398, 8 ; <i32> [#uses=1] %411 = or i32 %410, 512 ; <i32> [#uses=1] %412 = and i32 %411, 767 ; <i32> [#uses=1] - %413 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %412; <i32*> [#uses=1] - %414 = load i32* %413, align 4 ; <i32> [#uses=1] + %413 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %412; <i32*> [#uses=1] + %414 = load i32, i32* %413, align 4 ; <i32> [#uses=1] %415 = xor i32 %409, %414 ; <i32> [#uses=1] %416 = or i32 %398, 768 ; <i32> [#uses=1] %417 = and i32 %416, 1023 ; <i32> [#uses=1] - %418 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %417; <i32*> [#uses=1] - %419 = load i32* %418, align 4 ; <i32> [#uses=1] + %418 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %417; <i32*> [#uses=1] + %419 = load i32, i32* %418, align 4 ; <i32> [#uses=1] %420 = add i32 %415, %419 ; <i32> [#uses=1] %421 = xor i32 %400, %374 ; <i32> [#uses=1] %422 = xor i32 %421, %420 ; <i32> [#uses=5] - %423 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 12; <i32*> [#uses=1] - %424 = load i32* %423, align 4 ; <i32> [#uses=1] + %423 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 12; <i32*> [#uses=1] + %424 = load i32, i32* %423, align 4 ; <i32> [#uses=1] %425 = lshr i32 %422, 24 ; <i32> [#uses=1] - %426 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %425; <i32*> [#uses=1] - %427 = load i32* %426, align 4 ; <i32> [#uses=1] + %426 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %425; <i32*> [#uses=1] + %427 = load i32, i32* %426, align 4 ; <i32> [#uses=1] %428 = lshr i32 %422, 16 ; <i32> [#uses=1] %429 = or i32 %428, 256 ; <i32> [#uses=1] %430 = and i32 %429, 511 ; <i32> [#uses=1] - %431 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %430; <i32*> [#uses=1] - %432 = load i32* %431, align 4 ; <i32> [#uses=1] + %431 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %430; <i32*> [#uses=1] + %432 = load i32, i32* %431, align 4 ; <i32> [#uses=1] %433 = add i32 %432, %427 ; <i32> [#uses=1] %434 = lshr i32 %422, 8 ; <i32> [#uses=1] %435 = or i32 %434, 512 ; <i32> [#uses=1] %436 = and i32 %435, 767 ; <i32> [#uses=1] - %437 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %436; <i32*> [#uses=1] - %438 = load i32* %437, align 4 ; <i32> [#uses=1] + %437 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %436; <i32*> [#uses=1] + %438 = load i32, i32* %437, align 4 ; <i32> [#uses=1] %439 = xor i32 %433, %438 ; <i32> [#uses=1] %440 = or i32 %422, 768 ; <i32> [#uses=1] %441 = and i32 %440, 1023 ; <i32> [#uses=1] - %442 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %441; <i32*> [#uses=1] - %443 = load i32* %442, align 4 ; <i32> [#uses=1] + %442 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %441; <i32*> [#uses=1] + %443 = load i32, i32* %442, align 4 ; <i32> [#uses=1] %444 = add i32 %439, %443 ; <i32> [#uses=1] %445 = xor i32 %424, %398 ; <i32> [#uses=1] %446 = xor i32 %445, %444 ; <i32> [#uses=5] - %447 = load i32* undef, align 4 ; <i32> [#uses=1] + %447 = load i32, i32* undef, align 4 ; <i32> [#uses=1] %448 = lshr i32 %446, 24 ; <i32> [#uses=1] - %449 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %448; <i32*> [#uses=1] - %450 = load i32* %449, align 4 ; <i32> [#uses=1] + %449 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %448; <i32*> [#uses=1] + %450 = load i32, i32* %449, align 4 ; <i32> [#uses=1] %451 = lshr i32 %446, 16 ; <i32> [#uses=1] %452 = or i32 %451, 256 ; <i32> [#uses=1] %453 = and i32 %452, 511 ; <i32> [#uses=1] - %454 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %453; <i32*> [#uses=1] - %455 = load i32* %454, align 4 ; <i32> [#uses=1] + %454 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %453; <i32*> [#uses=1] + %455 = load i32, i32* %454, align 4 ; <i32> [#uses=1] %456 = add i32 %455, %450 ; <i32> [#uses=1] %457 = lshr i32 %446, 8 ; <i32> [#uses=1] %458 = or i32 %457, 512 ; <i32> [#uses=1] %459 = and i32 %458, 767 ; <i32> [#uses=1] - %460 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %459; <i32*> [#uses=1] - %461 = load i32* %460, align 4 ; <i32> [#uses=1] + %460 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %459; <i32*> [#uses=1] + %461 = load i32, i32* %460, align 4 ; <i32> [#uses=1] %462 = xor i32 %456, %461 ; <i32> [#uses=1] %463 = or i32 %446, 768 ; <i32> [#uses=1] %464 = and i32 %463, 1023 ; <i32> [#uses=1] - %465 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %464; <i32*> [#uses=1] - %466 = load i32* %465, align 4 ; <i32> [#uses=1] + %465 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %464; <i32*> [#uses=1] + %466 = load i32, i32* %465, align 4 ; <i32> [#uses=1] %467 = add i32 %462, %466 ; <i32> [#uses=1] %468 = xor i32 %447, %422 ; <i32> [#uses=1] %469 = xor i32 %468, %467 ; <i32> [#uses=5] - %470 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 10; <i32*> [#uses=1] - %471 = load i32* %470, align 4 ; <i32> [#uses=1] + %470 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 10; <i32*> [#uses=1] + %471 = load i32, i32* %470, align 4 ; <i32> [#uses=1] %472 = lshr i32 %469, 24 ; <i32> [#uses=1] - %473 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %472; <i32*> [#uses=1] - %474 = load i32* %473, align 4 ; <i32> [#uses=1] + %473 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %472; <i32*> [#uses=1] + %474 = load i32, i32* %473, align 4 ; <i32> [#uses=1] %475 = lshr i32 %469, 16 ; <i32> [#uses=1] %476 = or i32 %475, 256 ; <i32> [#uses=1] %477 = and i32 %476, 511 ; <i32> [#uses=1] - %478 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %477; <i32*> [#uses=1] - %479 = load i32* %478, align 4 ; <i32> [#uses=1] + %478 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %477; <i32*> [#uses=1] + %479 = load i32, i32* %478, align 4 ; <i32> [#uses=1] %480 = add i32 %479, %474 ; <i32> [#uses=1] %481 = lshr i32 %469, 8 ; <i32> [#uses=1] %482 = or i32 %481, 512 ; <i32> [#uses=1] %483 = and i32 %482, 767 ; <i32> [#uses=1] - %484 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %483; <i32*> [#uses=1] - %485 = load i32* %484, align 4 ; <i32> [#uses=1] + %484 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %483; <i32*> [#uses=1] + %485 = load i32, i32* %484, align 4 ; <i32> [#uses=1] %486 = xor i32 %480, %485 ; <i32> [#uses=1] %487 = or i32 %469, 768 ; <i32> [#uses=1] %488 = and i32 %487, 1023 ; <i32> [#uses=1] - %489 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %488; <i32*> [#uses=1] - %490 = load i32* %489, align 4 ; <i32> [#uses=1] + %489 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %488; <i32*> [#uses=1] + %490 = load i32, i32* %489, align 4 ; <i32> [#uses=1] %491 = add i32 %486, %490 ; <i32> [#uses=1] %492 = xor i32 %471, %446 ; <i32> [#uses=1] %493 = xor i32 %492, %491 ; <i32> [#uses=5] - %494 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 9; <i32*> [#uses=1] - %495 = load i32* %494, align 4 ; <i32> [#uses=1] + %494 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 9; <i32*> [#uses=1] + %495 = load i32, i32* %494, align 4 ; <i32> [#uses=1] %496 = lshr i32 %493, 24 ; <i32> [#uses=1] - %497 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %496; <i32*> [#uses=1] - %498 = load i32* %497, align 4 ; <i32> [#uses=1] + %497 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %496; <i32*> [#uses=1] + %498 = load i32, i32* %497, align 4 ; <i32> [#uses=1] %499 = lshr i32 %493, 16 ; <i32> [#uses=1] %500 = or i32 %499, 256 ; <i32> [#uses=1] %501 = and i32 %500, 511 ; <i32> [#uses=1] - %502 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %501; <i32*> [#uses=1] - %503 = load i32* %502, align 4 ; <i32> [#uses=1] + %502 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %501; <i32*> [#uses=1] + %503 = load i32, i32* %502, align 4 ; <i32> [#uses=1] %504 = add i32 %503, %498 ; <i32> [#uses=1] %505 = lshr i32 %493, 8 ; <i32> [#uses=1] %506 = or i32 %505, 512 ; <i32> [#uses=1] %507 = and i32 %506, 767 ; <i32> [#uses=1] - %508 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %507; <i32*> [#uses=1] - %509 = load i32* %508, align 4 ; <i32> [#uses=1] + %508 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %507; <i32*> [#uses=1] + %509 = load i32, i32* %508, align 4 ; <i32> [#uses=1] %510 = xor i32 %504, %509 ; <i32> [#uses=1] %511 = or i32 %493, 768 ; <i32> [#uses=1] %512 = and i32 %511, 1023 ; <i32> [#uses=1] - %513 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %512; <i32*> [#uses=1] - %514 = load i32* %513, align 4 ; <i32> [#uses=1] + %513 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %512; <i32*> [#uses=1] + %514 = load i32, i32* %513, align 4 ; <i32> [#uses=1] %515 = add i32 %510, %514 ; <i32> [#uses=1] %516 = xor i32 %495, %469 ; <i32> [#uses=1] %517 = xor i32 %516, %515 ; <i32> [#uses=5] - %518 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 8; <i32*> [#uses=1] - %519 = load i32* %518, align 4 ; <i32> [#uses=1] + %518 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 8; <i32*> [#uses=1] + %519 = load i32, i32* %518, align 4 ; <i32> [#uses=1] %520 = lshr i32 %517, 24 ; <i32> [#uses=1] - %521 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %520; <i32*> [#uses=1] - %522 = load i32* %521, align 4 ; <i32> [#uses=1] + %521 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %520; <i32*> [#uses=1] + %522 = load i32, i32* %521, align 4 ; <i32> [#uses=1] %523 = lshr i32 %517, 16 ; <i32> [#uses=1] %524 = or i32 %523, 256 ; <i32> [#uses=1] %525 = and i32 %524, 511 ; <i32> [#uses=1] - %526 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %525; <i32*> [#uses=1] - %527 = load i32* %526, align 4 ; <i32> [#uses=1] + %526 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %525; <i32*> [#uses=1] + %527 = load i32, i32* %526, align 4 ; <i32> [#uses=1] %528 = add i32 %527, %522 ; <i32> [#uses=1] %529 = lshr i32 %517, 8 ; <i32> [#uses=1] %530 = or i32 %529, 512 ; <i32> [#uses=1] %531 = and i32 %530, 767 ; <i32> [#uses=1] - %532 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %531; <i32*> [#uses=1] - %533 = load i32* %532, align 4 ; <i32> [#uses=1] + %532 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %531; <i32*> [#uses=1] + %533 = load i32, i32* %532, align 4 ; <i32> [#uses=1] %534 = xor i32 %528, %533 ; <i32> [#uses=1] %535 = or i32 %517, 768 ; <i32> [#uses=1] %536 = and i32 %535, 1023 ; <i32> [#uses=1] - %537 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %536; <i32*> [#uses=1] - %538 = load i32* %537, align 4 ; <i32> [#uses=1] + %537 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %536; <i32*> [#uses=1] + %538 = load i32, i32* %537, align 4 ; <i32> [#uses=1] %539 = add i32 %534, %538 ; <i32> [#uses=1] %540 = xor i32 %519, %493 ; <i32> [#uses=1] %541 = xor i32 %540, %539 ; <i32> [#uses=5] - %542 = load i32* undef, align 4 ; <i32> [#uses=1] + %542 = load i32, i32* undef, align 4 ; <i32> [#uses=1] %543 = lshr i32 %541, 24 ; <i32> [#uses=1] - %544 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %543; <i32*> [#uses=1] - %545 = load i32* %544, align 4 ; <i32> [#uses=1] + %544 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %543; <i32*> [#uses=1] + %545 = load i32, i32* %544, align 4 ; <i32> [#uses=1] %546 = lshr i32 %541, 16 ; <i32> [#uses=1] %547 = or i32 %546, 256 ; <i32> [#uses=1] %548 = and i32 %547, 511 ; <i32> [#uses=1] - %549 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %548; <i32*> [#uses=1] - %550 = load i32* %549, align 4 ; <i32> [#uses=1] + %549 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %548; <i32*> [#uses=1] + %550 = load i32, i32* %549, align 4 ; <i32> [#uses=1] %551 = add i32 %550, %545 ; <i32> [#uses=1] %552 = lshr i32 %541, 8 ; <i32> [#uses=1] %553 = or i32 %552, 512 ; <i32> [#uses=1] %554 = and i32 %553, 767 ; <i32> [#uses=1] - %555 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %554; <i32*> [#uses=1] - %556 = load i32* %555, align 4 ; <i32> [#uses=1] + %555 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %554; <i32*> [#uses=1] + %556 = load i32, i32* %555, align 4 ; <i32> [#uses=1] %557 = xor i32 %551, %556 ; <i32> [#uses=1] %558 = or i32 %541, 768 ; <i32> [#uses=1] %559 = and i32 %558, 1023 ; <i32> [#uses=1] - %560 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %559; <i32*> [#uses=1] - %561 = load i32* %560, align 4 ; <i32> [#uses=1] + %560 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %559; <i32*> [#uses=1] + %561 = load i32, i32* %560, align 4 ; <i32> [#uses=1] %562 = add i32 %557, %561 ; <i32> [#uses=1] %563 = xor i32 %542, %517 ; <i32> [#uses=1] %564 = xor i32 %563, %562 ; <i32> [#uses=5] - %565 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 6; <i32*> [#uses=1] - %566 = load i32* %565, align 4 ; <i32> [#uses=1] + %565 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 6; <i32*> [#uses=1] + %566 = load i32, i32* %565, align 4 ; <i32> [#uses=1] %567 = lshr i32 %564, 24 ; <i32> [#uses=1] - %568 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %567; <i32*> [#uses=1] - %569 = load i32* %568, align 4 ; <i32> [#uses=1] + %568 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %567; <i32*> [#uses=1] + %569 = load i32, i32* %568, align 4 ; <i32> [#uses=1] %570 = lshr i32 %564, 16 ; <i32> [#uses=1] %571 = or i32 %570, 256 ; <i32> [#uses=1] %572 = and i32 %571, 511 ; <i32> [#uses=1] - %573 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %572; <i32*> [#uses=1] - %574 = load i32* %573, align 4 ; <i32> [#uses=1] + %573 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %572; <i32*> [#uses=1] + %574 = load i32, i32* %573, align 4 ; <i32> [#uses=1] %575 = add i32 %574, %569 ; <i32> [#uses=1] %576 = lshr i32 %564, 8 ; <i32> [#uses=1] %577 = or i32 %576, 512 ; <i32> [#uses=1] %578 = and i32 %577, 767 ; <i32> [#uses=1] - %579 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %578; <i32*> [#uses=1] - %580 = load i32* %579, align 4 ; <i32> [#uses=1] + %579 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %578; <i32*> [#uses=1] + %580 = load i32, i32* %579, align 4 ; <i32> [#uses=1] %581 = xor i32 %575, %580 ; <i32> [#uses=1] %582 = or i32 %564, 768 ; <i32> [#uses=1] %583 = and i32 %582, 1023 ; <i32> [#uses=1] - %584 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %583; <i32*> [#uses=1] - %585 = load i32* %584, align 4 ; <i32> [#uses=1] + %584 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %583; <i32*> [#uses=1] + %585 = load i32, i32* %584, align 4 ; <i32> [#uses=1] %586 = add i32 %581, %585 ; <i32> [#uses=1] %587 = xor i32 %566, %541 ; <i32> [#uses=1] %588 = xor i32 %587, %586 ; <i32> [#uses=5] - %589 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 5; <i32*> [#uses=1] - %590 = load i32* %589, align 4 ; <i32> [#uses=1] + %589 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 5; <i32*> [#uses=1] + %590 = load i32, i32* %589, align 4 ; <i32> [#uses=1] %591 = lshr i32 %588, 24 ; <i32> [#uses=1] - %592 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %591; <i32*> [#uses=1] - %593 = load i32* %592, align 4 ; <i32> [#uses=1] + %592 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %591; <i32*> [#uses=1] + %593 = load i32, i32* %592, align 4 ; <i32> [#uses=1] %594 = lshr i32 %588, 16 ; <i32> [#uses=1] %595 = or i32 %594, 256 ; <i32> [#uses=1] %596 = and i32 %595, 511 ; <i32> [#uses=1] - %597 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %596; <i32*> [#uses=1] - %598 = load i32* %597, align 4 ; <i32> [#uses=1] + %597 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %596; <i32*> [#uses=1] + %598 = load i32, i32* %597, align 4 ; <i32> [#uses=1] %599 = add i32 %598, %593 ; <i32> [#uses=1] %600 = lshr i32 %588, 8 ; <i32> [#uses=1] %601 = or i32 %600, 512 ; <i32> [#uses=1] %602 = and i32 %601, 767 ; <i32> [#uses=1] - %603 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %602; <i32*> [#uses=1] - %604 = load i32* %603, align 4 ; <i32> [#uses=1] + %603 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %602; <i32*> [#uses=1] + %604 = load i32, i32* %603, align 4 ; <i32> [#uses=1] %605 = xor i32 %599, %604 ; <i32> [#uses=1] %606 = or i32 %588, 768 ; <i32> [#uses=1] %607 = and i32 %606, 1023 ; <i32> [#uses=1] - %608 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %607; <i32*> [#uses=1] - %609 = load i32* %608, align 4 ; <i32> [#uses=1] + %608 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %607; <i32*> [#uses=1] + %609 = load i32, i32* %608, align 4 ; <i32> [#uses=1] %610 = add i32 %605, %609 ; <i32> [#uses=1] %611 = xor i32 %590, %564 ; <i32> [#uses=1] %612 = xor i32 %611, %610 ; <i32> [#uses=5] - %613 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 4; <i32*> [#uses=1] - %614 = load i32* %613, align 4 ; <i32> [#uses=1] + %613 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 4; <i32*> [#uses=1] + %614 = load i32, i32* %613, align 4 ; <i32> [#uses=1] %615 = lshr i32 %612, 24 ; <i32> [#uses=1] - %616 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %615; <i32*> [#uses=1] - %617 = load i32* %616, align 4 ; <i32> [#uses=1] + %616 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %615; <i32*> [#uses=1] + %617 = load i32, i32* %616, align 4 ; <i32> [#uses=1] %618 = lshr i32 %612, 16 ; <i32> [#uses=1] %619 = or i32 %618, 256 ; <i32> [#uses=1] %620 = and i32 %619, 511 ; <i32> [#uses=1] - %621 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %620; <i32*> [#uses=1] - %622 = load i32* %621, align 4 ; <i32> [#uses=1] + %621 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %620; <i32*> [#uses=1] + %622 = load i32, i32* %621, align 4 ; <i32> [#uses=1] %623 = add i32 %622, %617 ; <i32> [#uses=1] %624 = lshr i32 %612, 8 ; <i32> [#uses=1] %625 = or i32 %624, 512 ; <i32> [#uses=1] %626 = and i32 %625, 767 ; <i32> [#uses=1] - %627 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %626; <i32*> [#uses=1] - %628 = load i32* %627, align 4 ; <i32> [#uses=1] + %627 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %626; <i32*> [#uses=1] + %628 = load i32, i32* %627, align 4 ; <i32> [#uses=1] %629 = xor i32 %623, %628 ; <i32> [#uses=1] %630 = or i32 %612, 768 ; <i32> [#uses=1] %631 = and i32 %630, 1023 ; <i32> [#uses=1] - %632 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %631; <i32*> [#uses=1] - %633 = load i32* %632, align 4 ; <i32> [#uses=1] + %632 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %631; <i32*> [#uses=1] + %633 = load i32, i32* %632, align 4 ; <i32> [#uses=1] %634 = add i32 %629, %633 ; <i32> [#uses=1] %635 = xor i32 %614, %588 ; <i32> [#uses=1] %636 = xor i32 %635, %634 ; <i32> [#uses=5] - %637 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 3; <i32*> [#uses=1] - %638 = load i32* %637, align 4 ; <i32> [#uses=1] + %637 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 3; <i32*> [#uses=1] + %638 = load i32, i32* %637, align 4 ; <i32> [#uses=1] %639 = lshr i32 %636, 24 ; <i32> [#uses=1] - %640 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %639; <i32*> [#uses=1] - %641 = load i32* %640, align 4 ; <i32> [#uses=1] + %640 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %639; <i32*> [#uses=1] + %641 = load i32, i32* %640, align 4 ; <i32> [#uses=1] %642 = lshr i32 %636, 16 ; <i32> [#uses=1] %643 = or i32 %642, 256 ; <i32> [#uses=1] %644 = and i32 %643, 511 ; <i32> [#uses=1] - %645 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %644; <i32*> [#uses=1] - %646 = load i32* %645, align 4 ; <i32> [#uses=1] + %645 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %644; <i32*> [#uses=1] + %646 = load i32, i32* %645, align 4 ; <i32> [#uses=1] %647 = add i32 %646, %641 ; <i32> [#uses=1] %648 = lshr i32 %636, 8 ; <i32> [#uses=1] %649 = or i32 %648, 512 ; <i32> [#uses=1] %650 = and i32 %649, 767 ; <i32> [#uses=1] - %651 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %650; <i32*> [#uses=1] - %652 = load i32* %651, align 4 ; <i32> [#uses=1] + %651 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %650; <i32*> [#uses=1] + %652 = load i32, i32* %651, align 4 ; <i32> [#uses=1] %653 = xor i32 %647, %652 ; <i32> [#uses=1] %654 = or i32 %636, 768 ; <i32> [#uses=1] %655 = and i32 %654, 1023 ; <i32> [#uses=1] - %656 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %655; <i32*> [#uses=1] - %657 = load i32* %656, align 4 ; <i32> [#uses=1] + %656 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %655; <i32*> [#uses=1] + %657 = load i32, i32* %656, align 4 ; <i32> [#uses=1] %658 = add i32 %653, %657 ; <i32> [#uses=1] %659 = xor i32 %638, %612 ; <i32> [#uses=1] %660 = xor i32 %659, %658 ; <i32> [#uses=5] - %661 = load i32* undef, align 4 ; <i32> [#uses=1] + %661 = load i32, i32* undef, align 4 ; <i32> [#uses=1] %662 = lshr i32 %660, 24 ; <i32> [#uses=1] - %663 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %662; <i32*> [#uses=1] - %664 = load i32* %663, align 4 ; <i32> [#uses=1] + %663 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %662; <i32*> [#uses=1] + %664 = load i32, i32* %663, align 4 ; <i32> [#uses=1] %665 = lshr i32 %660, 16 ; <i32> [#uses=1] %666 = or i32 %665, 256 ; <i32> [#uses=1] %667 = and i32 %666, 511 ; <i32> [#uses=1] - %668 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %667; <i32*> [#uses=1] - %669 = load i32* %668, align 4 ; <i32> [#uses=1] + %668 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %667; <i32*> [#uses=1] + %669 = load i32, i32* %668, align 4 ; <i32> [#uses=1] %670 = add i32 %669, %664 ; <i32> [#uses=1] %671 = lshr i32 %660, 8 ; <i32> [#uses=1] %672 = or i32 %671, 512 ; <i32> [#uses=1] %673 = and i32 %672, 767 ; <i32> [#uses=1] - %674 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %673; <i32*> [#uses=1] - %675 = load i32* %674, align 4 ; <i32> [#uses=1] + %674 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %673; <i32*> [#uses=1] + %675 = load i32, i32* %674, align 4 ; <i32> [#uses=1] %676 = xor i32 %670, %675 ; <i32> [#uses=1] %677 = or i32 %660, 768 ; <i32> [#uses=1] %678 = and i32 %677, 1023 ; <i32> [#uses=1] - %679 = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %678; <i32*> [#uses=1] - %680 = load i32* %679, align 4 ; <i32> [#uses=1] + %679 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %678; <i32*> [#uses=1] + %680 = load i32, i32* %679, align 4 ; <i32> [#uses=1] %681 = add i32 %676, %680 ; <i32> [#uses=1] %682 = xor i32 %661, %636 ; <i32> [#uses=1] %683 = xor i32 %682, %681 ; <i32> [#uses=5] - %684 = getelementptr %struct.BF_KEY* %key, i32 0, i32 0, i32 1; <i32*> [#uses=1] + %684 = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 0, i32 1; <i32*> [#uses=1] br label %bb2 bb2: ; preds = %bb1, %bb @@ -712,21 +712,21 @@ bb2: ; preds = %bb1, %bb %.pn15 = lshr i32 %.pn15.in, 24 ; <i32> [#uses=1] %.pn14 = and i32 %.pn14.in, 511 ; <i32> [#uses=1] %.pn13.in = or i32 %.pn13.in.in, 512 ; <i32> [#uses=1] - %.pn11.in = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %.pn15; <i32*> [#uses=1] - %.pn12.in = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %.pn14; <i32*> [#uses=1] + %.pn11.in = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %.pn15; <i32*> [#uses=1] + %.pn12.in = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %.pn14; <i32*> [#uses=1] %.pn13 = and i32 %.pn13.in, 767 ; <i32> [#uses=1] %.pn10.in = or i32 %.pn10.in.in, 768 ; <i32> [#uses=1] - %.pn11 = load i32* %.pn11.in ; <i32> [#uses=1] - %.pn12 = load i32* %.pn12.in ; <i32> [#uses=1] - %.pn9.in = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %.pn13; <i32*> [#uses=1] + %.pn11 = load i32, i32* %.pn11.in ; <i32> [#uses=1] + %.pn12 = load i32, i32* %.pn12.in ; <i32> [#uses=1] + %.pn9.in = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %.pn13; <i32*> [#uses=1] %.pn10 = and i32 %.pn10.in, 1023 ; <i32> [#uses=1] %.pn8 = add i32 %.pn12, %.pn11 ; <i32> [#uses=1] - %.pn9 = load i32* %.pn9.in ; <i32> [#uses=1] - %.pn7.in = getelementptr %struct.BF_KEY* %key, i32 0, i32 1, i32 %.pn10; <i32*> [#uses=1] + %.pn9 = load i32, i32* %.pn9.in ; <i32> [#uses=1] + %.pn7.in = getelementptr %struct.BF_KEY, %struct.BF_KEY* %key, i32 0, i32 1, i32 %.pn10; <i32*> [#uses=1] %.pn6 = xor i32 %.pn8, %.pn9 ; <i32> [#uses=1] - %.pn7 = load i32* %.pn7.in ; <i32> [#uses=1] - %.pn4 = load i32* %.pn4.in ; <i32> [#uses=1] - %.pn2 = load i32* %.pn2.in ; <i32> [#uses=1] + %.pn7 = load i32, i32* %.pn7.in ; <i32> [#uses=1] + %.pn4 = load i32, i32* %.pn4.in ; <i32> [#uses=1] + %.pn2 = load i32, i32* %.pn2.in ; <i32> [#uses=1] %.pn = add i32 %.pn6, %.pn7 ; <i32> [#uses=1] %r.0 = xor i32 %.pn2, %.pn3 ; <i32> [#uses=1] %.pn1 = xor i32 %.pn, %.pn5 ; <i32> [#uses=1] diff --git a/test/CodeGen/Thumb/2009-08-12-RegInfoAssert.ll b/test/CodeGen/Thumb/2009-08-12-RegInfoAssert.ll index 041306d..983e0f5 100644 --- a/test/CodeGen/Thumb/2009-08-12-RegInfoAssert.ll +++ b/test/CodeGen/Thumb/2009-08-12-RegInfoAssert.ll @@ -11,19 +11,19 @@ define i8* @vorbis_comment_query(%struct.vorbis_comment* nocapture %vc, i8* %tag entry: %0 = alloca i8, i32 undef, align 4 ; <i8*> [#uses=2] %1 = call i8* @__strcpy_chk(i8* %0, i8* %tag, i32 -1) nounwind; <i8*> [#uses=0] - %2 = call i8* @__strcat_chk(i8* %0, i8* getelementptr ([2 x i8]* @.str16, i32 0, i32 0), i32 -1) nounwind; <i8*> [#uses=0] - %3 = getelementptr %struct.vorbis_comment* %vc, i32 0, i32 0; <i8***> [#uses=1] + %2 = call i8* @__strcat_chk(i8* %0, i8* getelementptr ([2 x i8], [2 x i8]* @.str16, i32 0, i32 0), i32 -1) nounwind; <i8*> [#uses=0] + %3 = getelementptr %struct.vorbis_comment, %struct.vorbis_comment* %vc, i32 0, i32 0; <i8***> [#uses=1] br label %bb11 bb6: ; preds = %bb11 - %4 = load i8*** %3, align 4 ; <i8**> [#uses=1] - %scevgep = getelementptr i8** %4, i32 %8 ; <i8**> [#uses=1] - %5 = load i8** %scevgep, align 4 ; <i8*> [#uses=1] + %4 = load i8**, i8*** %3, align 4 ; <i8**> [#uses=1] + %scevgep = getelementptr i8*, i8** %4, i32 %8 ; <i8**> [#uses=1] + %5 = load i8*, i8** %scevgep, align 4 ; <i8*> [#uses=1] br label %bb3.i bb3.i: ; preds = %bb3.i, %bb6 - %scevgep7.i = getelementptr i8* %5, i32 0 ; <i8*> [#uses=1] - %6 = load i8* %scevgep7.i, align 1 ; <i8> [#uses=0] + %scevgep7.i = getelementptr i8, i8* %5, i32 0 ; <i8*> [#uses=1] + %6 = load i8, i8* %scevgep7.i, align 1 ; <i8> [#uses=0] br i1 undef, label %bb3.i, label %bb10 bb10: ; preds = %bb3.i diff --git a/test/CodeGen/Thumb/2009-08-20-ISelBug.ll b/test/CodeGen/Thumb/2009-08-20-ISelBug.ll index 414b76d..86d7023 100644 --- a/test/CodeGen/Thumb/2009-08-20-ISelBug.ll +++ b/test/CodeGen/Thumb/2009-08-20-ISelBug.ll @@ -18,15 +18,15 @@ entry: br i1 %0, label %bb13, label %bb1 bb1: ; preds = %entry - %1 = getelementptr inbounds %struct.asl_file_t* %s, i32 0, i32 11 ; <%struct.FILE**> [#uses=2] - %2 = load %struct.FILE** %1, align 4 ; <%struct.FILE*> [#uses=2] + %1 = getelementptr inbounds %struct.asl_file_t, %struct.asl_file_t* %s, i32 0, i32 11 ; <%struct.FILE**> [#uses=2] + %2 = load %struct.FILE*, %struct.FILE** %1, align 4 ; <%struct.FILE*> [#uses=2] %3 = icmp eq %struct.FILE* %2, null ; <i1> [#uses=1] br i1 %3, label %bb13, label %bb3 bb3: ; preds = %bb1 %4 = add nsw i64 %off, 8 ; <i64> [#uses=1] - %5 = getelementptr inbounds %struct.asl_file_t* %s, i32 0, i32 10 ; <i32*> [#uses=1] - %6 = load i32* %5, align 4 ; <i32> [#uses=1] + %5 = getelementptr inbounds %struct.asl_file_t, %struct.asl_file_t* %s, i32 0, i32 10 ; <i32*> [#uses=1] + %6 = load i32, i32* %5, align 4 ; <i32> [#uses=1] %7 = zext i32 %6 to i64 ; <i64> [#uses=1] %8 = icmp sgt i64 %4, %7 ; <i1> [#uses=1] br i1 %8, label %bb13, label %bb5 @@ -38,7 +38,7 @@ bb5: ; preds = %bb3 bb7: ; preds = %bb5 store i64 0, i64* %val, align 4 - %11 = load %struct.FILE** %1, align 4 ; <%struct.FILE*> [#uses=1] + %11 = load %struct.FILE*, %struct.FILE** %1, align 4 ; <%struct.FILE*> [#uses=1] %val8 = bitcast i64* %val to i8* ; <i8*> [#uses=1] %12 = call i32 @fread(i8* noalias %val8, i32 8, i32 1, %struct.FILE* noalias %11) nounwind ; <i32> [#uses=1] %13 = icmp eq i32 %12, 1 ; <i1> [#uses=1] @@ -49,7 +49,7 @@ bb10: ; preds = %bb7 br i1 %14, label %bb13, label %bb11 bb11: ; preds = %bb10 - %15 = load i64* %val, align 4 ; <i64> [#uses=1] + %15 = load i64, i64* %val, align 4 ; <i64> [#uses=1] %16 = call i64 @asl_core_ntohq(i64 %15) nounwind ; <i64> [#uses=1] store i64 %16, i64* %out, align 4 ret i32 0 diff --git a/test/CodeGen/Thumb/2009-12-17-pre-regalloc-taildup.ll b/test/CodeGen/Thumb/2009-12-17-pre-regalloc-taildup.ll index 132d9ac..e768417 100644 --- a/test/CodeGen/Thumb/2009-12-17-pre-regalloc-taildup.ll +++ b/test/CodeGen/Thumb/2009-12-17-pre-regalloc-taildup.ll @@ -12,17 +12,17 @@ target triple = "thumbv7-apple-darwin10" define i32 @interpret_threaded(i8* nocapture %opcodes) nounwind readonly optsize { entry: - %0 = load i8* %opcodes, align 1 ; <i8> [#uses=1] + %0 = load i8, i8* %opcodes, align 1 ; <i8> [#uses=1] %1 = zext i8 %0 to i32 ; <i32> [#uses=1] - %2 = getelementptr inbounds [5 x i8*]* @codetable.2928, i32 0, i32 %1 ; <i8**> [#uses=1] + %2 = getelementptr inbounds [5 x i8*], [5 x i8*]* @codetable.2928, i32 0, i32 %1 ; <i8**> [#uses=1] br label %bb bb: ; preds = %bb.backedge, %entry %indvar = phi i32 [ %phitmp, %bb.backedge ], [ 1, %entry ] ; <i32> [#uses=2] %gotovar.22.0.in = phi i8** [ %gotovar.22.0.in.be, %bb.backedge ], [ %2, %entry ] ; <i8**> [#uses=1] %result.0 = phi i32 [ %result.0.be, %bb.backedge ], [ 0, %entry ] ; <i32> [#uses=6] - %opcodes_addr.0 = getelementptr i8* %opcodes, i32 %indvar ; <i8*> [#uses=4] - %gotovar.22.0 = load i8** %gotovar.22.0.in, align 4 ; <i8*> [#uses=1] + %opcodes_addr.0 = getelementptr i8, i8* %opcodes, i32 %indvar ; <i8*> [#uses=4] + %gotovar.22.0 = load i8*, i8** %gotovar.22.0.in, align 4 ; <i8*> [#uses=1] indirectbr i8* %gotovar.22.0, [label %RETURN, label %INCREMENT, label %DECREMENT, label %DOUBLE, label %SWAPWORD] RETURN: ; preds = %bb @@ -30,9 +30,9 @@ RETURN: ; preds = %bb INCREMENT: ; preds = %bb %3 = add nsw i32 %result.0, 1 ; <i32> [#uses=1] - %4 = load i8* %opcodes_addr.0, align 1 ; <i8> [#uses=1] + %4 = load i8, i8* %opcodes_addr.0, align 1 ; <i8> [#uses=1] %5 = zext i8 %4 to i32 ; <i32> [#uses=1] - %6 = getelementptr inbounds [5 x i8*]* @codetable.2928, i32 0, i32 %5 ; <i8**> [#uses=1] + %6 = getelementptr inbounds [5 x i8*], [5 x i8*]* @codetable.2928, i32 0, i32 %5 ; <i8**> [#uses=1] br label %bb.backedge bb.backedge: ; preds = %SWAPWORD, %DOUBLE, %DECREMENT, %INCREMENT @@ -43,24 +43,24 @@ bb.backedge: ; preds = %SWAPWORD, %DOUBLE, DECREMENT: ; preds = %bb %7 = add i32 %result.0, -1 ; <i32> [#uses=1] - %8 = load i8* %opcodes_addr.0, align 1 ; <i8> [#uses=1] + %8 = load i8, i8* %opcodes_addr.0, align 1 ; <i8> [#uses=1] %9 = zext i8 %8 to i32 ; <i32> [#uses=1] - %10 = getelementptr inbounds [5 x i8*]* @codetable.2928, i32 0, i32 %9 ; <i8**> [#uses=1] + %10 = getelementptr inbounds [5 x i8*], [5 x i8*]* @codetable.2928, i32 0, i32 %9 ; <i8**> [#uses=1] br label %bb.backedge DOUBLE: ; preds = %bb %11 = shl i32 %result.0, 1 ; <i32> [#uses=1] - %12 = load i8* %opcodes_addr.0, align 1 ; <i8> [#uses=1] + %12 = load i8, i8* %opcodes_addr.0, align 1 ; <i8> [#uses=1] %13 = zext i8 %12 to i32 ; <i32> [#uses=1] - %14 = getelementptr inbounds [5 x i8*]* @codetable.2928, i32 0, i32 %13 ; <i8**> [#uses=1] + %14 = getelementptr inbounds [5 x i8*], [5 x i8*]* @codetable.2928, i32 0, i32 %13 ; <i8**> [#uses=1] br label %bb.backedge SWAPWORD: ; preds = %bb %15 = shl i32 %result.0, 16 ; <i32> [#uses=1] %16 = ashr i32 %result.0, 16 ; <i32> [#uses=1] %17 = or i32 %15, %16 ; <i32> [#uses=1] - %18 = load i8* %opcodes_addr.0, align 1 ; <i8> [#uses=1] + %18 = load i8, i8* %opcodes_addr.0, align 1 ; <i8> [#uses=1] %19 = zext i8 %18 to i32 ; <i32> [#uses=1] - %20 = getelementptr inbounds [5 x i8*]* @codetable.2928, i32 0, i32 %19 ; <i8**> [#uses=1] + %20 = getelementptr inbounds [5 x i8*], [5 x i8*]* @codetable.2928, i32 0, i32 %19 ; <i8**> [#uses=1] br label %bb.backedge } diff --git a/test/CodeGen/Thumb/2010-07-15-debugOrdering.ll b/test/CodeGen/Thumb/2010-07-15-debugOrdering.ll index 622f55d..58b15c8 100644 --- a/test/CodeGen/Thumb/2010-07-15-debugOrdering.ll +++ b/test/CodeGen/Thumb/2010-07-15-debugOrdering.ll @@ -25,11 +25,11 @@ define void @_Z19getClosestDiagonal3ii(%0* noalias sret, i32, i32) nounwind { %storemerge = phi double [ -1.000000e+00, %4 ], [ 1.000000e+00, %3 ], [ 1.000000e+00, %3 ] ; <double> [#uses=1] %v_6 = icmp slt i32 %1, 2 ; <i1> [#uses=1] %storemerge1 = select i1 %v_6, double 1.000000e+00, double -1.000000e+00 ; <double> [#uses=3] - call void @llvm.dbg.value(metadata double %storemerge, i64 0, metadata !91, metadata !{!"0x102"}), !dbg !0 + call void @llvm.dbg.value(metadata double %storemerge, i64 0, metadata !91, metadata !MDExpression()), !dbg !0 %v_7 = icmp eq i32 %2, 1, !dbg !92 ; <i1> [#uses=1] %storemerge2 = select i1 %v_7, double 1.000000e+00, double -1.000000e+00 ; <double> [#uses=3] - %v_8 = getelementptr inbounds %0* %0, i32 0, i32 0, i32 0 ; <double*> [#uses=1] - %v_10 = getelementptr inbounds %0* %0, i32 0, i32 0, i32 2 ; <double*> [#uses=1] + %v_8 = getelementptr inbounds %0, %0* %0, i32 0, i32 0, i32 0 ; <double*> [#uses=1] + %v_10 = getelementptr inbounds %0, %0* %0, i32 0, i32 0, i32 2 ; <double*> [#uses=1] %v_11 = fmul double %storemerge1, %storemerge1, !dbg !93 ; <double> [#uses=1] %v_15 = tail call double @sqrt(double %v_11) nounwind readonly, !dbg !93 ; <double> [#uses=1] %v_16 = fdiv double 1.000000e+00, %v_15, !dbg !93 ; <double> [#uses=3] @@ -49,107 +49,107 @@ declare void @llvm.dbg.value(metadata, i64, metadata, metadata) nounwind readnon !llvm.dbg.cu = !{!5} !llvm.module.flags = !{!104} !0 = !MDLocation(line: 46, scope: !1) -!1 = !{!"0xb\0044\000\000", !101, !2} ; [ DW_TAG_lexical_block ] -!2 = !{!"0xb\0044\000\000", !101, !3} ; [ DW_TAG_lexical_block ] -!3 = !{!"0x2e\00getClosestDiagonal3\00getClosestDiagonal3\00_Z19getClosestDiagonal3ii\0044\000\001\000\006\000\000\000", !101, null, !6, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!4 = !{!"0x29", !101} ; [ DW_TAG_file_type ] -!5 = !{!"0x11\004\004.2.1 (Based on Apple Inc. build 5658) (LLVM build 00)\001\00\000\00\000", !101, !102, !102, !103, null, null} ; [ DW_TAG_compile_unit ] -!6 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !7, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!1 = distinct !MDLexicalBlock(line: 44, column: 0, file: !101, scope: !2) +!2 = distinct !MDLexicalBlock(line: 44, column: 0, file: !101, scope: !3) +!3 = !MDSubprogram(name: "getClosestDiagonal3", linkageName: "_Z19getClosestDiagonal3ii", line: 44, isLocal: false, isDefinition: true, virtualIndex: 6, isOptimized: false, file: !101, scope: null, type: !6) +!4 = !MDFile(filename: "ggEdgeDiscrepancy.cc", directory: "/Volumes/Home/grosbaj/sources/llvm-externals/speccpu2000/benchspec/CINT2000/252.eon/src") +!5 = !MDCompileUnit(language: DW_LANG_C_plus_plus, producer: "4.2.1 (Based on Apple Inc. build 5658) (LLVM build 00)", isOptimized: true, emissionKind: 0, file: !101, enums: !102, retainedTypes: !102, subprograms: !103) +!6 = !MDSubroutineType(types: !7) !7 = !{!8, !22, !22} -!8 = !{!"0x13\00ggVector3\0066\00192\0032\000\000\000", !99, null, null, !10, null, null, null} ; [ DW_TAG_structure_type ] [ggVector3] [line 66, size 192, align 32, offset 0] [def] [from ] -!9 = !{!"0x29", !"ggVector3.h", !"/Volumes/Home/grosbaj/sources/llvm-externals/speccpu2000/benchspec/CINT2000/252.eon/src", !5} ; [ DW_TAG_file_type ] -!99 = !{!"ggVector3.h", !"/Volumes/Home/grosbaj/sources/llvm-externals/speccpu2000/benchspec/CINT2000/252.eon/src"} +!8 = !MDCompositeType(tag: DW_TAG_structure_type, name: "ggVector3", line: 66, size: 192, align: 32, file: !99, elements: !10) +!9 = !MDFile(filename: "ggVector3.h", directory: "/Volumes/Home/grosbaj/sources/llvm-externals/speccpu2000/benchspec/CINT2000/252.eon/src") +!99 = !MDFile(filename: "ggVector3.h", directory: "/Volumes/Home/grosbaj/sources/llvm-externals/speccpu2000/benchspec/CINT2000/252.eon/src") !10 = !{!11, !16, !23, !26, !29, !30, !35, !36, !37, !41, !42, !43, !46, !47, !48, !52, !53, !54, !57, !60, !63, !66, !70, !71, !74, !75, !76, !77, !78, !81, !82, !83, !84, !85, !88, !89, !90} -!11 = !{!"0xd\00e\00160\00192\0032\000\000", !99, !8, !12} ; [ DW_TAG_member ] -!12 = !{!"0x1\00\000\00192\0032\000\000", !101, !4, !13, !14, i32 0, null, null, null} ; [ DW_TAG_array_type ] [line 0, size 192, align 32, offset 0] [from double] -!13 = !{!"0x24\00double\000\0064\0032\000\000\004", !101, !4} ; [ DW_TAG_base_type ] +!11 = !MDDerivedType(tag: DW_TAG_member, name: "e", line: 160, size: 192, align: 32, file: !99, scope: !8, baseType: !12) +!12 = !MDCompositeType(tag: DW_TAG_array_type, size: 192, align: 32, file: !101, scope: !4, baseType: !13, elements: !14) +!13 = !MDBasicType(tag: DW_TAG_base_type, name: "double", size: 64, align: 32, encoding: DW_ATE_float) !14 = !{!15} -!15 = !{!"0x21\000\003"} ; [ DW_TAG_subrange_type ] -!16 = !{!"0x2e\00ggVector3\00ggVector3\00\0072\000\000\000\006\000\000\000", !9, !8, !17, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!17 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !18, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!15 = !MDSubrange(count: 3) +!16 = !MDSubprogram(name: "ggVector3", line: 72, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !17) +!17 = !MDSubroutineType(types: !18) !18 = !{null, !19, !20} -!19 = !{!"0xf\00\000\0032\0032\000\0064", !101, !4, !8} ; [ DW_TAG_pointer_type ] -!20 = !{!"0x16\00ggBoolean\00478\000\000\000\000", !100, null, !22} ; [ DW_TAG_typedef ] -!21 = !{!"0x29", !"math.h", !"/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS4.2.Internal.sdk/usr/include/architecture/arm", !5} ; [ DW_TAG_file_type ] -!100 = !{!"math.h", !"/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS4.2.Internal.sdk/usr/include/architecture/arm"} -!22 = !{!"0x24\00int\000\0032\0032\000\000\005", !101, !4} ; [ DW_TAG_base_type ] -!23 = !{!"0x2e\00ggVector3\00ggVector3\00\0073\000\000\000\006\000\000\000", !9, !8, !24, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!24 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !25, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!19 = !MDDerivedType(tag: DW_TAG_pointer_type, size: 32, align: 32, flags: DIFlagArtificial, file: !101, scope: !4, baseType: !8) +!20 = !MDDerivedType(tag: DW_TAG_typedef, name: "ggBoolean", line: 478, file: !100, baseType: !22) +!21 = !MDFile(filename: "math.h", directory: "/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS4.2.Internal.sdk/usr/include/architecture/arm") +!100 = !MDFile(filename: "math.h", directory: "/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS4.2.Internal.sdk/usr/include/architecture/arm") +!22 = !MDBasicType(tag: DW_TAG_base_type, name: "int", size: 32, align: 32, encoding: DW_ATE_signed) +!23 = !MDSubprogram(name: "ggVector3", line: 73, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !24) +!24 = !MDSubroutineType(types: !25) !25 = !{null, !19} -!26 = !{!"0x2e\00ggVector3\00ggVector3\00\0074\000\000\000\006\000\000\000", !9, !8, !27, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!27 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !28, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!26 = !MDSubprogram(name: "ggVector3", line: 74, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !27) +!27 = !MDSubroutineType(types: !28) !28 = !{null, !19, !13, !13, !13} -!29 = !{!"0x2e\00Set\00Set\00_ZN9ggVector33SetEddd\0081\000\000\000\006\000\000\000", !9, !8, !27, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!30 = !{!"0x2e\00x\00x\00_ZNK9ggVector31xEv\0082\000\000\000\006\000\000\000", !9, !8, !31, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!31 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !32, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!29 = !MDSubprogram(name: "Set", linkageName: "_ZN9ggVector33SetEddd", line: 81, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !27) +!30 = !MDSubprogram(name: "x", linkageName: "_ZNK9ggVector31xEv", line: 82, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !31) +!31 = !MDSubroutineType(types: !32) !32 = !{!13, !33} -!33 = !{!"0xf\00\000\0032\0032\000\0064", !101, !4, !34} ; [ DW_TAG_pointer_type ] -!34 = !{!"0x26\00\000\00192\0032\000\000", !101, !4, !8} ; [ DW_TAG_const_type ] -!35 = !{!"0x2e\00y\00y\00_ZNK9ggVector31yEv\0083\000\000\000\006\000\000\000", !9, !8, !31, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!36 = !{!"0x2e\00z\00z\00_ZNK9ggVector31zEv\0084\000\000\000\006\000\000\000", !9, !8, !31, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!37 = !{!"0x2e\00x\00x\00_ZN9ggVector31xEv\0085\000\001\000\006\000\000\000", !9, !8, !38, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!38 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !39, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!33 = !MDDerivedType(tag: DW_TAG_pointer_type, size: 32, align: 32, flags: DIFlagArtificial, file: !101, scope: !4, baseType: !34) +!34 = !MDDerivedType(tag: DW_TAG_const_type, size: 192, align: 32, file: !101, scope: !4, baseType: !8) +!35 = !MDSubprogram(name: "y", linkageName: "_ZNK9ggVector31yEv", line: 83, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !31) +!36 = !MDSubprogram(name: "z", linkageName: "_ZNK9ggVector31zEv", line: 84, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !31) +!37 = !MDSubprogram(name: "x", linkageName: "_ZN9ggVector31xEv", line: 85, isLocal: false, isDefinition: true, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !38) +!38 = !MDSubroutineType(types: !39) !39 = !{!40, !19} -!40 = !{!"0x10\00double\000\0032\0032\000\000", !101, !4, !13} ; [ DW_TAG_reference_type ] -!41 = !{!"0x2e\00y\00y\00_ZN9ggVector31yEv\0086\000\001\000\006\000\000\000", !9, !8, !38, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!42 = !{!"0x2e\00z\00z\00_ZN9ggVector31zEv\0087\000\001\000\006\000\000\000", !9, !8, !38, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!43 = !{!"0x2e\00SetX\00SetX\00_ZN9ggVector34SetXEd\0088\000\000\000\006\000\000\000", !9, !8, !44, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!44 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !45, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!40 = !MDDerivedType(tag: DW_TAG_reference_type, name: "double", size: 32, align: 32, file: !101, scope: !4, baseType: !13) +!41 = !MDSubprogram(name: "y", linkageName: "_ZN9ggVector31yEv", line: 86, isLocal: false, isDefinition: true, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !38) +!42 = !MDSubprogram(name: "z", linkageName: "_ZN9ggVector31zEv", line: 87, isLocal: false, isDefinition: true, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !38) +!43 = !MDSubprogram(name: "SetX", linkageName: "_ZN9ggVector34SetXEd", line: 88, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !44) +!44 = !MDSubroutineType(types: !45) !45 = !{null, !19, !13} -!46 = !{!"0x2e\00SetY\00SetY\00_ZN9ggVector34SetYEd\0089\000\000\000\006\000\000\000", !9, !8, !44, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!47 = !{!"0x2e\00SetZ\00SetZ\00_ZN9ggVector34SetZEd\0090\000\000\000\006\000\000\000", !9, !8, !44, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!48 = !{!"0x2e\00ggVector3\00ggVector3\00\0092\000\000\000\006\000\000\000", !9, !8, !49, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!49 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !50, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!46 = !MDSubprogram(name: "SetY", linkageName: "_ZN9ggVector34SetYEd", line: 89, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !44) +!47 = !MDSubprogram(name: "SetZ", linkageName: "_ZN9ggVector34SetZEd", line: 90, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !44) +!48 = !MDSubprogram(name: "ggVector3", line: 92, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !49) +!49 = !MDSubroutineType(types: !50) !50 = !{null, !19, !51} -!51 = !{!"0x10\00\000\0032\0032\000\000", !101, !4, !34} ; [ DW_TAG_reference_type ] -!52 = !{!"0x2e\00tolerance\00tolerance\00_ZNK9ggVector39toleranceEv\00100\000\000\000\006\000\000\000", !9, !8, !31, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!53 = !{!"0x2e\00tolerance\00tolerance\00_ZN9ggVector39toleranceEv\00101\000\000\000\006\000\000\000", !9, !8, !38, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!54 = !{!"0x2e\00operator+\00operator+\00_ZNK9ggVector3psEv\00107\000\000\000\006\000\000\000", !9, !8, !55, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!55 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !56, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!51 = !MDDerivedType(tag: DW_TAG_reference_type, size: 32, align: 32, file: !101, scope: !4, baseType: !34) +!52 = !MDSubprogram(name: "tolerance", linkageName: "_ZNK9ggVector39toleranceEv", line: 100, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !31) +!53 = !MDSubprogram(name: "tolerance", linkageName: "_ZN9ggVector39toleranceEv", line: 101, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !38) +!54 = !MDSubprogram(name: "operator+", linkageName: "_ZNK9ggVector3psEv", line: 107, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !55) +!55 = !MDSubroutineType(types: !56) !56 = !{!51, !33} -!57 = !{!"0x2e\00operator-\00operator-\00_ZNK9ggVector3ngEv\00108\000\000\000\006\000\000\000", !9, !8, !58, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!58 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !59, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!57 = !MDSubprogram(name: "operator-", linkageName: "_ZNK9ggVector3ngEv", line: 108, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !58) +!58 = !MDSubroutineType(types: !59) !59 = !{!8, !33} -!60 = !{!"0x2e\00operator[]\00operator[]\00_ZNK9ggVector3ixEi\00290\000\000\000\006\000\000\000", !9, !8, !61, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!61 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !62, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!60 = !MDSubprogram(name: "operator[]", linkageName: "_ZNK9ggVector3ixEi", line: 290, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !61) +!61 = !MDSubroutineType(types: !62) !62 = !{!13, !33, !22} -!63 = !{!"0x2e\00operator[]\00operator[]\00_ZN9ggVector3ixEi\00278\000\000\000\006\000\000\000", !9, !8, !64, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!64 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !65, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!63 = !MDSubprogram(name: "operator[]", linkageName: "_ZN9ggVector3ixEi", line: 278, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !64) +!64 = !MDSubroutineType(types: !65) !65 = !{!40, !19, !22} -!66 = !{!"0x2e\00operator+=\00operator+=\00_ZN9ggVector3pLERKS_\00303\000\000\000\006\000\000\000", !9, !8, !67, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!67 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !68, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!66 = !MDSubprogram(name: "operator+=", linkageName: "_ZN9ggVector3pLERKS_", line: 303, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !67) +!67 = !MDSubroutineType(types: !68) !68 = !{!69, !19, !51} -!69 = !{!"0x10\00ggVector3\000\0032\0032\000\000", !101, !4, !8} ; [ DW_TAG_reference_type ] -!70 = !{!"0x2e\00operator-=\00operator-=\00_ZN9ggVector3mIERKS_\00310\000\000\000\006\000\000\000", !9, !8, !67, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!71 = !{!"0x2e\00operator*=\00operator*=\00_ZN9ggVector3mLEd\00317\000\000\000\006\000\000\000", !9, !8, !72, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!72 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !73, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!69 = !MDDerivedType(tag: DW_TAG_reference_type, name: "ggVector3", size: 32, align: 32, file: !101, scope: !4, baseType: !8) +!70 = !MDSubprogram(name: "operator-=", linkageName: "_ZN9ggVector3mIERKS_", line: 310, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !67) +!71 = !MDSubprogram(name: "operator*=", linkageName: "_ZN9ggVector3mLEd", line: 317, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !72) +!72 = !MDSubroutineType(types: !73) !73 = !{!69, !19, !13} -!74 = !{!"0x2e\00operator/=\00operator/=\00_ZN9ggVector3dVEd\00324\000\000\000\006\000\000\000", !9, !8, !72, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!75 = !{!"0x2e\00length\00length\00_ZNK9ggVector36lengthEv\00121\000\000\000\006\000\000\000", !9, !8, !31, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!76 = !{!"0x2e\00squaredLength\00squaredLength\00_ZNK9ggVector313squaredLengthEv\00122\000\000\000\006\000\000\000", !9, !8, !31, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!77 = !{!"0x2e\00MakeUnitVector\00MakeUnitVector\00_ZN9ggVector314MakeUnitVectorEv\00217\000\001\000\006\000\000\000", !9, !8, !24, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!78 = !{!"0x2e\00Perturb\00Perturb\00_ZNK9ggVector37PerturbEdd\00126\000\000\000\006\000\000\000", !9, !8, !79, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!79 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !80, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!74 = !MDSubprogram(name: "operator/=", linkageName: "_ZN9ggVector3dVEd", line: 324, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !72) +!75 = !MDSubprogram(name: "length", linkageName: "_ZNK9ggVector36lengthEv", line: 121, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !31) +!76 = !MDSubprogram(name: "squaredLength", linkageName: "_ZNK9ggVector313squaredLengthEv", line: 122, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !31) +!77 = !MDSubprogram(name: "MakeUnitVector", linkageName: "_ZN9ggVector314MakeUnitVectorEv", line: 217, isLocal: false, isDefinition: true, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !24) +!78 = !MDSubprogram(name: "Perturb", linkageName: "_ZNK9ggVector37PerturbEdd", line: 126, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !79) +!79 = !MDSubroutineType(types: !80) !80 = !{!8, !33, !13, !13} -!81 = !{!"0x2e\00maxComponent\00maxComponent\00_ZNK9ggVector312maxComponentEv\00128\000\000\000\006\000\000\000", !9, !8, !31, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!82 = !{!"0x2e\00minComponent\00minComponent\00_ZNK9ggVector312minComponentEv\00129\000\000\000\006\000\000\000", !9, !8, !31, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!83 = !{!"0x2e\00maxAbsComponent\00maxAbsComponent\00_ZNK9ggVector315maxAbsComponentEv\00131\000\000\000\006\000\000\000", !9, !8, !31, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!84 = !{!"0x2e\00minAbsComponent\00minAbsComponent\00_ZNK9ggVector315minAbsComponentEv\00132\000\000\000\006\000\000\000", !9, !8, !31, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!85 = !{!"0x2e\00indexOfMinComponent\00indexOfMinComponent\00_ZNK9ggVector319indexOfMinComponentEv\00133\000\000\000\006\000\000\000", !9, !8, !86, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!86 = !{!"0x15\00\000\000\000\000\000\000", !101, !4, null, !87, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!81 = !MDSubprogram(name: "maxComponent", linkageName: "_ZNK9ggVector312maxComponentEv", line: 128, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !31) +!82 = !MDSubprogram(name: "minComponent", linkageName: "_ZNK9ggVector312minComponentEv", line: 129, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !31) +!83 = !MDSubprogram(name: "maxAbsComponent", linkageName: "_ZNK9ggVector315maxAbsComponentEv", line: 131, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !31) +!84 = !MDSubprogram(name: "minAbsComponent", linkageName: "_ZNK9ggVector315minAbsComponentEv", line: 132, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !31) +!85 = !MDSubprogram(name: "indexOfMinComponent", linkageName: "_ZNK9ggVector319indexOfMinComponentEv", line: 133, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !86) +!86 = !MDSubroutineType(types: !87) !87 = !{!22, !33} -!88 = !{!"0x2e\00indexOfMinAbsComponent\00indexOfMinAbsComponent\00_ZNK9ggVector322indexOfMinAbsComponentEv\00137\000\000\000\006\000\000\000", !9, !8, !86, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!89 = !{!"0x2e\00indexOfMaxComponent\00indexOfMaxComponent\00_ZNK9ggVector319indexOfMaxComponentEv\00146\000\000\000\006\000\000\000", !9, !8, !86, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!90 = !{!"0x2e\00indexOfMaxAbsComponent\00indexOfMaxAbsComponent\00_ZNK9ggVector322indexOfMaxAbsComponentEv\00150\000\000\000\006\000\000\000", !9, !8, !86, null, null, null, null, null} ; [ DW_TAG_subprogram ] -!91 = !{!"0x100\00vx\0046\000", !1, !4, !13} ; [ DW_TAG_auto_variable ] +!88 = !MDSubprogram(name: "indexOfMinAbsComponent", linkageName: "_ZNK9ggVector322indexOfMinAbsComponentEv", line: 137, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !86) +!89 = !MDSubprogram(name: "indexOfMaxComponent", linkageName: "_ZNK9ggVector319indexOfMaxComponentEv", line: 146, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !86) +!90 = !MDSubprogram(name: "indexOfMaxAbsComponent", linkageName: "_ZNK9ggVector322indexOfMaxAbsComponentEv", line: 150, isLocal: false, isDefinition: false, virtualIndex: 6, isOptimized: false, file: !9, scope: !8, type: !86) +!91 = !MDLocalVariable(tag: DW_TAG_auto_variable, name: "vx", line: 46, scope: !1, file: !4, type: !13) !92 = !MDLocation(line: 48, scope: !1) !93 = !MDLocation(line: 218, scope: !94, inlinedAt: !96) -!94 = !{!"0xb\00217\000\000", !101, !95} ; [ DW_TAG_lexical_block ] -!95 = !{!"0xb\00217\000\000", !101, !77} ; [ DW_TAG_lexical_block ] +!94 = distinct !MDLexicalBlock(line: 217, column: 0, file: !101, scope: !95) +!95 = distinct !MDLexicalBlock(line: 217, column: 0, file: !101, scope: !77) !96 = !MDLocation(line: 51, scope: !1) !97 = !MDLocation(line: 227, scope: !94, inlinedAt: !96) !98 = !MDLocation(line: 52, scope: !1) -!101 = !{!"ggEdgeDiscrepancy.cc", !"/Volumes/Home/grosbaj/sources/llvm-externals/speccpu2000/benchspec/CINT2000/252.eon/src"} +!101 = !MDFile(filename: "ggEdgeDiscrepancy.cc", directory: "/Volumes/Home/grosbaj/sources/llvm-externals/speccpu2000/benchspec/CINT2000/252.eon/src") !102 = !{i32 0} !103 = !{!3, !77} -!104 = !{i32 1, !"Debug Info Version", i32 2} +!104 = !{i32 1, !"Debug Info Version", i32 3} diff --git a/test/CodeGen/Thumb/2011-05-11-DAGLegalizer.ll b/test/CodeGen/Thumb/2011-05-11-DAGLegalizer.ll index ed55bb5..ff574c2 100644 --- a/test/CodeGen/Thumb/2011-05-11-DAGLegalizer.ll +++ b/test/CodeGen/Thumb/2011-05-11-DAGLegalizer.ll @@ -23,32 +23,32 @@ entry: br label %do.body do.body: ; preds = %entry - %tmp = load i8** @kkkkkk, align 4 - %tmp1 = load %struct.MMMMMMMMMMMM** %aidData.addr - %eph = getelementptr inbounds %struct.MMMMMMMMMMMM* %tmp1, i32 0, i32 0 - %arrayidx = getelementptr inbounds [4 x %struct.RRRRRRRR]* %eph, i32 0, i32 0 + %tmp = load i8*, i8** @kkkkkk, align 4 + %tmp1 = load %struct.MMMMMMMMMMMM*, %struct.MMMMMMMMMMMM** %aidData.addr + %eph = getelementptr inbounds %struct.MMMMMMMMMMMM, %struct.MMMMMMMMMMMM* %tmp1, i32 0, i32 0 + %arrayidx = getelementptr inbounds [4 x %struct.RRRRRRRR], [4 x %struct.RRRRRRRR]* %eph, i32 0, i32 0 %tmp2 = bitcast %struct.RRRRRRRR* %agg.tmp to i8* %tmp3 = bitcast %struct.RRRRRRRR* %arrayidx to i8* call void @llvm.memcpy.p0i8.p0i8.i32(i8* %tmp2, i8* %tmp3, i32 312, i32 4, i1 false) - %tmp5 = load %struct.MMMMMMMMMMMM** %aidData.addr - %eph6 = getelementptr inbounds %struct.MMMMMMMMMMMM* %tmp5, i32 0, i32 0 - %arrayidx7 = getelementptr inbounds [4 x %struct.RRRRRRRR]* %eph6, i32 0, i32 1 + %tmp5 = load %struct.MMMMMMMMMMMM*, %struct.MMMMMMMMMMMM** %aidData.addr + %eph6 = getelementptr inbounds %struct.MMMMMMMMMMMM, %struct.MMMMMMMMMMMM* %tmp5, i32 0, i32 0 + %arrayidx7 = getelementptr inbounds [4 x %struct.RRRRRRRR], [4 x %struct.RRRRRRRR]* %eph6, i32 0, i32 1 %tmp8 = bitcast %struct.RRRRRRRR* %agg.tmp4 to i8* %tmp9 = bitcast %struct.RRRRRRRR* %arrayidx7 to i8* call void @llvm.memcpy.p0i8.p0i8.i32(i8* %tmp8, i8* %tmp9, i32 312, i32 4, i1 false) - %tmp11 = load %struct.MMMMMMMMMMMM** %aidData.addr - %eph12 = getelementptr inbounds %struct.MMMMMMMMMMMM* %tmp11, i32 0, i32 0 - %arrayidx13 = getelementptr inbounds [4 x %struct.RRRRRRRR]* %eph12, i32 0, i32 2 + %tmp11 = load %struct.MMMMMMMMMMMM*, %struct.MMMMMMMMMMMM** %aidData.addr + %eph12 = getelementptr inbounds %struct.MMMMMMMMMMMM, %struct.MMMMMMMMMMMM* %tmp11, i32 0, i32 0 + %arrayidx13 = getelementptr inbounds [4 x %struct.RRRRRRRR], [4 x %struct.RRRRRRRR]* %eph12, i32 0, i32 2 %tmp14 = bitcast %struct.RRRRRRRR* %agg.tmp10 to i8* %tmp15 = bitcast %struct.RRRRRRRR* %arrayidx13 to i8* call void @llvm.memcpy.p0i8.p0i8.i32(i8* %tmp14, i8* %tmp15, i32 312, i32 4, i1 false) - %tmp17 = load %struct.MMMMMMMMMMMM** %aidData.addr - %eph18 = getelementptr inbounds %struct.MMMMMMMMMMMM* %tmp17, i32 0, i32 0 - %arrayidx19 = getelementptr inbounds [4 x %struct.RRRRRRRR]* %eph18, i32 0, i32 3 + %tmp17 = load %struct.MMMMMMMMMMMM*, %struct.MMMMMMMMMMMM** %aidData.addr + %eph18 = getelementptr inbounds %struct.MMMMMMMMMMMM, %struct.MMMMMMMMMMMM* %tmp17, i32 0, i32 0 + %arrayidx19 = getelementptr inbounds [4 x %struct.RRRRRRRR], [4 x %struct.RRRRRRRR]* %eph18, i32 0, i32 3 %tmp20 = bitcast %struct.RRRRRRRR* %agg.tmp16 to i8* %tmp21 = bitcast %struct.RRRRRRRR* %arrayidx19 to i8* call void @llvm.memcpy.p0i8.p0i8.i32(i8* %tmp20, i8* %tmp21, i32 312, i32 4, i1 false) - call void (i8*, i32, i8*, i8*, ...)* @CLLoggingLog(i8* %tmp, i32 2, i8* getelementptr inbounds ([62 x i8]* @__PRETTY_FUNCTION__._ZN12CLGll, i32 0, i32 0), i8* getelementptr inbounds ([75 x i8]* @.str, i32 0, i32 0), %struct.RRRRRRRR* byval %agg.tmp, %struct.RRRRRRRR* byval %agg.tmp4, %struct.RRRRRRRR* byval %agg.tmp10, %struct.RRRRRRRR* byval %agg.tmp16) + call void (i8*, i32, i8*, i8*, ...)* @CLLoggingLog(i8* %tmp, i32 2, i8* getelementptr inbounds ([62 x i8], [62 x i8]* @__PRETTY_FUNCTION__._ZN12CLGll, i32 0, i32 0), i8* getelementptr inbounds ([75 x i8], [75 x i8]* @.str, i32 0, i32 0), %struct.RRRRRRRR* byval %agg.tmp, %struct.RRRRRRRR* byval %agg.tmp4, %struct.RRRRRRRR* byval %agg.tmp10, %struct.RRRRRRRR* byval %agg.tmp16) br label %do.end do.end: ; preds = %do.body diff --git a/test/CodeGen/Thumb/2011-EpilogueBug.ll b/test/CodeGen/Thumb/2011-EpilogueBug.ll index 16789e6..9657dc7 100644 --- a/test/CodeGen/Thumb/2011-EpilogueBug.ll +++ b/test/CodeGen/Thumb/2011-EpilogueBug.ll @@ -6,7 +6,7 @@ define void @t1(%struct.state* %v) { ; CHECK: push {r4 - %tmp6 = load i32* null + %tmp6 = load i32, i32* null %tmp8 = alloca float, i32 %tmp6 store i32 1, i32* null br label %return diff --git a/test/CodeGen/Thumb/2014-06-10-thumb1-ldst-opt-bug.ll b/test/CodeGen/Thumb/2014-06-10-thumb1-ldst-opt-bug.ll index cfa1159..d5c8db7 100644 --- a/test/CodeGen/Thumb/2014-06-10-thumb1-ldst-opt-bug.ll +++ b/test/CodeGen/Thumb/2014-06-10-thumb1-ldst-opt-bug.ll @@ -7,9 +7,9 @@ entry: ; CHECK: ldm ; CHECK-NEXT: subs ; CHECK-NEXT: bl - %0 = load i32* %A, align 4 - %arrayidx1 = getelementptr inbounds i32* %A, i32 1 - %1 = load i32* %arrayidx1, align 4 + %0 = load i32, i32* %A, align 4 + %arrayidx1 = getelementptr inbounds i32, i32* %A, i32 1 + %1 = load i32, i32* %arrayidx1, align 4 tail call void @bar(i32* %A, i32 %0, i32 %1) #2 ret void } diff --git a/test/CodeGen/Thumb/PR17309.ll b/test/CodeGen/Thumb/PR17309.ll index b7b08e9..f1033e7 100644 --- a/test/CodeGen/Thumb/PR17309.ll +++ b/test/CodeGen/Thumb/PR17309.ll @@ -10,7 +10,7 @@ define void @pass_C() #0 { entry: %c = alloca %struct.C, align 1 - %0 = getelementptr inbounds %struct.C* %c, i32 0, i32 0, i32 0 + %0 = getelementptr inbounds %struct.C, %struct.C* %c, i32 0, i32 0, i32 0 call void @llvm.lifetime.start(i64 1000, i8* %0) #1 call void @use_C(%struct.C* byval %c) #3 call void @llvm.lifetime.end(i64 1000, i8* %0) #1 diff --git a/test/CodeGen/Thumb/asmprinter-bug.ll b/test/CodeGen/Thumb/asmprinter-bug.ll index 18e11ba..0024d08 100644 --- a/test/CodeGen/Thumb/asmprinter-bug.ll +++ b/test/CodeGen/Thumb/asmprinter-bug.ll @@ -15,14 +15,14 @@ define void @adpcm_coder(i16* nocapture %indata, i8* nocapture %outdata, i32 %len, %struct.adpcm_state* nocapture %state) nounwind { entry: - %0 = getelementptr %struct.adpcm_state* %state, i32 0, i32 0 ; <i16*> [#uses=2] - %1 = load i16* %0, align 2 ; <i16> [#uses=1] + %0 = getelementptr %struct.adpcm_state, %struct.adpcm_state* %state, i32 0, i32 0 ; <i16*> [#uses=2] + %1 = load i16, i16* %0, align 2 ; <i16> [#uses=1] %2 = sext i16 %1 to i32 ; <i32> [#uses=2] - %3 = getelementptr %struct.adpcm_state* %state, i32 0, i32 1 ; <i8*> [#uses=2] - %4 = load i8* %3, align 2 ; <i8> [#uses=1] + %3 = getelementptr %struct.adpcm_state, %struct.adpcm_state* %state, i32 0, i32 1 ; <i8*> [#uses=2] + %4 = load i8, i8* %3, align 2 ; <i8> [#uses=1] %5 = sext i8 %4 to i32 ; <i32> [#uses=3] - %6 = getelementptr [89 x i32]* @stepsizeTable, i32 0, i32 %5 ; <i32*> [#uses=1] - %7 = load i32* %6, align 4 ; <i32> [#uses=1] + %6 = getelementptr [89 x i32], [89 x i32]* @stepsizeTable, i32 0, i32 %5 ; <i32*> [#uses=1] + %7 = load i32, i32* %6, align 4 ; <i32> [#uses=1] %8 = icmp sgt i32 %len, 0 ; <i1> [#uses=1] br i1 %8, label %bb, label %bb27 @@ -34,8 +34,8 @@ bb: ; preds = %bb25, %entry %index.033 = phi i32 [ %5, %entry ], [ %index.2, %bb25 ] ; <i32> [#uses=1] %valpred.132 = phi i32 [ %2, %entry ], [ %valpred.2, %bb25 ] ; <i32> [#uses=2] %step.031 = phi i32 [ %7, %entry ], [ %36, %bb25 ] ; <i32> [#uses=5] - %inp.038 = getelementptr i16* %indata, i32 %indvar ; <i16*> [#uses=1] - %9 = load i16* %inp.038, align 2 ; <i16> [#uses=1] + %inp.038 = getelementptr i16, i16* %indata, i32 %indvar ; <i16*> [#uses=1] + %9 = load i16, i16* %inp.038, align 2 ; <i16> [#uses=1] %10 = sext i16 %9 to i32 ; <i32> [#uses=1] %11 = sub i32 %10, %valpred.132 ; <i32> [#uses=3] %12 = icmp slt i32 %11, 0 ; <i1> [#uses=1] @@ -79,15 +79,15 @@ bb18: ; preds = %bb17, %bb16, %bb %delta.1 = or i32 %21, %iftmp.1.0 ; <i32> [#uses=1] %delta.2 = or i32 %delta.1, %25 ; <i32> [#uses=1] %29 = xor i32 %delta.2, 1 ; <i32> [#uses=3] - %30 = getelementptr [16 x i32]* @indexTable, i32 0, i32 %29 ; <i32*> [#uses=1] - %31 = load i32* %30, align 4 ; <i32> [#uses=1] + %30 = getelementptr [16 x i32], [16 x i32]* @indexTable, i32 0, i32 %29 ; <i32*> [#uses=1] + %31 = load i32, i32* %30, align 4 ; <i32> [#uses=1] %32 = add i32 %31, %index.033 ; <i32> [#uses=2] %33 = icmp slt i32 %32, 0 ; <i1> [#uses=1] %index.1 = select i1 %33, i32 0, i32 %32 ; <i32> [#uses=2] %34 = icmp sgt i32 %index.1, 88 ; <i1> [#uses=1] %index.2 = select i1 %34, i32 88, i32 %index.1 ; <i32> [#uses=3] - %35 = getelementptr [89 x i32]* @stepsizeTable, i32 0, i32 %index.2 ; <i32*> [#uses=1] - %36 = load i32* %35, align 4 ; <i32> [#uses=1] + %35 = getelementptr [89 x i32], [89 x i32]* @stepsizeTable, i32 0, i32 %index.2 ; <i32*> [#uses=1] + %36 = load i32, i32* %35, align 4 ; <i32> [#uses=1] %37 = icmp eq i32 %bufferstep.035, 0 ; <i1> [#uses=1] br i1 %37, label %bb24, label %bb23 @@ -102,7 +102,7 @@ bb24: ; preds = %bb18 %42 = trunc i32 %outputbuffer.134 to i8 ; <i8> [#uses=1] %43 = or i8 %41, %42 ; <i8> [#uses=1] store i8 %43, i8* %outp.136, align 1 - %44 = getelementptr i8* %outp.136, i32 1 ; <i8*> [#uses=1] + %44 = getelementptr i8, i8* %outp.136, i32 1 ; <i8*> [#uses=1] br label %bb25 bb25: ; preds = %bb24, %bb23 @@ -140,14 +140,14 @@ bb29: ; preds = %bb28, %bb27 define void @adpcm_decoder(i8* nocapture %indata, i16* nocapture %outdata, i32 %len, %struct.adpcm_state* nocapture %state) nounwind { entry: - %0 = getelementptr %struct.adpcm_state* %state, i32 0, i32 0 ; <i16*> [#uses=2] - %1 = load i16* %0, align 2 ; <i16> [#uses=1] + %0 = getelementptr %struct.adpcm_state, %struct.adpcm_state* %state, i32 0, i32 0 ; <i16*> [#uses=2] + %1 = load i16, i16* %0, align 2 ; <i16> [#uses=1] %2 = sext i16 %1 to i32 ; <i32> [#uses=2] - %3 = getelementptr %struct.adpcm_state* %state, i32 0, i32 1 ; <i8*> [#uses=2] - %4 = load i8* %3, align 2 ; <i8> [#uses=1] + %3 = getelementptr %struct.adpcm_state, %struct.adpcm_state* %state, i32 0, i32 1 ; <i8*> [#uses=2] + %4 = load i8, i8* %3, align 2 ; <i8> [#uses=1] %5 = sext i8 %4 to i32 ; <i32> [#uses=3] - %6 = getelementptr [89 x i32]* @stepsizeTable, i32 0, i32 %5 ; <i32*> [#uses=1] - %7 = load i32* %6, align 4 ; <i32> [#uses=1] + %6 = getelementptr [89 x i32], [89 x i32]* @stepsizeTable, i32 0, i32 %5 ; <i32*> [#uses=1] + %7 = load i32, i32* %6, align 4 ; <i32> [#uses=1] %8 = icmp sgt i32 %len, 0 ; <i1> [#uses=1] br i1 %8, label %bb, label %bb22 @@ -159,14 +159,14 @@ bb: ; preds = %bb20, %entry %index.026 = phi i32 [ %5, %entry ], [ %index.2, %bb20 ] ; <i32> [#uses=1] %valpred.125 = phi i32 [ %2, %entry ], [ %valpred.2, %bb20 ] ; <i32> [#uses=1] %step.024 = phi i32 [ %7, %entry ], [ %35, %bb20 ] ; <i32> [#uses=4] - %outp.030 = getelementptr i16* %outdata, i32 %indvar ; <i16*> [#uses=1] + %outp.030 = getelementptr i16, i16* %outdata, i32 %indvar ; <i16*> [#uses=1] %9 = icmp eq i32 %bufferstep.028, 0 ; <i1> [#uses=1] br i1 %9, label %bb2, label %bb3 bb2: ; preds = %bb - %10 = load i8* %inp.131, align 1 ; <i8> [#uses=1] + %10 = load i8, i8* %inp.131, align 1 ; <i8> [#uses=1] %11 = sext i8 %10 to i32 ; <i32> [#uses=2] - %12 = getelementptr i8* %inp.131, i32 1 ; <i8*> [#uses=1] + %12 = getelementptr i8, i8* %inp.131, i32 1 ; <i8*> [#uses=1] %13 = ashr i32 %11, 4 ; <i32> [#uses=1] br label %bb3 @@ -176,8 +176,8 @@ bb3: ; preds = %bb2, %bb %inp.0 = phi i8* [ %12, %bb2 ], [ %inp.131, %bb ] ; <i8*> [#uses=1] %delta.0 = and i32 %delta.0.in, 15 ; <i32> [#uses=1] %tmp = xor i32 %bufferstep.028, 1 ; <i32> [#uses=1] - %14 = getelementptr [16 x i32]* @indexTable, i32 0, i32 %delta.0 ; <i32*> [#uses=1] - %15 = load i32* %14, align 4 ; <i32> [#uses=1] + %14 = getelementptr [16 x i32], [16 x i32]* @indexTable, i32 0, i32 %delta.0 ; <i32*> [#uses=1] + %15 = load i32, i32* %14, align 4 ; <i32> [#uses=1] %16 = add i32 %15, %index.026 ; <i32> [#uses=2] %17 = icmp slt i32 %16, 0 ; <i1> [#uses=1] %index.1 = select i1 %17, i32 0, i32 %16 ; <i32> [#uses=2] @@ -227,8 +227,8 @@ bb19: ; preds = %bb18 bb20: ; preds = %bb19, %bb18, %bb13 %valpred.2 = phi i32 [ -32768, %bb19 ], [ 32767, %bb13 ], [ %valpred.0, %bb18 ] ; <i32> [#uses=3] - %34 = getelementptr [89 x i32]* @stepsizeTable, i32 0, i32 %index.2 ; <i32*> [#uses=1] - %35 = load i32* %34, align 4 ; <i32> [#uses=1] + %34 = getelementptr [89 x i32], [89 x i32]* @stepsizeTable, i32 0, i32 %index.2 ; <i32*> [#uses=1] + %35 = load i32, i32* %34, align 4 ; <i32> [#uses=1] %36 = trunc i32 %valpred.2 to i16 ; <i16> [#uses=1] store i16 %36, i16* %outp.030, align 2 %indvar.next = add i32 %indvar, 1 ; <i32> [#uses=2] @@ -250,12 +250,12 @@ entry: br label %bb bb: ; preds = %bb3, %entry - %0 = tail call i32 (...)* @read(i32 0, i8* getelementptr ([500 x i8]* @abuf, i32 0, i32 0), i32 500) nounwind ; <i32> [#uses=4] + %0 = tail call i32 (...)* @read(i32 0, i8* getelementptr ([500 x i8], [500 x i8]* @abuf, i32 0, i32 0), i32 500) nounwind ; <i32> [#uses=4] %1 = icmp slt i32 %0, 0 ; <i1> [#uses=1] br i1 %1, label %bb1, label %bb2 bb1: ; preds = %bb - tail call void @perror(i8* getelementptr ([11 x i8]* @.str, i32 0, i32 0)) nounwind + tail call void @perror(i8* getelementptr ([11 x i8], [11 x i8]* @.str, i32 0, i32 0)) nounwind ret i32 1 bb2: ; preds = %bb @@ -264,18 +264,18 @@ bb2: ; preds = %bb bb3: ; preds = %bb2 %3 = shl i32 %0, 1 ; <i32> [#uses=1] - tail call void @adpcm_decoder(i8* getelementptr ([500 x i8]* @abuf, i32 0, i32 0), i16* getelementptr ([1000 x i16]* @sbuf, i32 0, i32 0), i32 %3, %struct.adpcm_state* @state) nounwind + tail call void @adpcm_decoder(i8* getelementptr ([500 x i8], [500 x i8]* @abuf, i32 0, i32 0), i16* getelementptr ([1000 x i16], [1000 x i16]* @sbuf, i32 0, i32 0), i32 %3, %struct.adpcm_state* @state) nounwind %4 = shl i32 %0, 2 ; <i32> [#uses=1] - %5 = tail call i32 (...)* @write(i32 1, i16* getelementptr ([1000 x i16]* @sbuf, i32 0, i32 0), i32 %4) nounwind ; <i32> [#uses=0] + %5 = tail call i32 (...)* @write(i32 1, i16* getelementptr ([1000 x i16], [1000 x i16]* @sbuf, i32 0, i32 0), i32 %4) nounwind ; <i32> [#uses=0] br label %bb bb4: ; preds = %bb2 - %6 = load %struct.FILE** @__stderrp, align 4 ; <%struct.FILE*> [#uses=1] - %7 = load i16* getelementptr (%struct.adpcm_state* @state, i32 0, i32 0), align 4 ; <i16> [#uses=1] + %6 = load %struct.FILE*, %struct.FILE** @__stderrp, align 4 ; <%struct.FILE*> [#uses=1] + %7 = load i16, i16* getelementptr (%struct.adpcm_state, %struct.adpcm_state* @state, i32 0, i32 0), align 4 ; <i16> [#uses=1] %8 = sext i16 %7 to i32 ; <i32> [#uses=1] - %9 = load i8* getelementptr (%struct.adpcm_state* @state, i32 0, i32 1), align 2 ; <i8> [#uses=1] + %9 = load i8, i8* getelementptr (%struct.adpcm_state, %struct.adpcm_state* @state, i32 0, i32 1), align 2 ; <i8> [#uses=1] %10 = sext i8 %9 to i32 ; <i32> [#uses=1] - %11 = tail call i32 (%struct.FILE*, i8*, ...)* @fprintf(%struct.FILE* %6, i8* getelementptr ([28 x i8]* @.str1, i32 0, i32 0), i32 %8, i32 %10) nounwind ; <i32> [#uses=0] + %11 = tail call i32 (%struct.FILE*, i8*, ...)* @fprintf(%struct.FILE* %6, i8* getelementptr ([28 x i8], [28 x i8]* @.str1, i32 0, i32 0), i32 %8, i32 %10) nounwind ; <i32> [#uses=0] ret i32 0 } diff --git a/test/CodeGen/Thumb/cortex-m0-unaligned-access.ll b/test/CodeGen/Thumb/cortex-m0-unaligned-access.ll index c4403fe..cba1ca6 100644 --- a/test/CodeGen/Thumb/cortex-m0-unaligned-access.ll +++ b/test/CodeGen/Thumb/cortex-m0-unaligned-access.ll @@ -8,6 +8,6 @@ define i32 @split_load(i32* %p) nounwind { ; V7M-LABEL: split_load ; V7M-NOT: ldrh ; V7M: bx lr - %val = load i32* %p, align 2 + %val = load i32, i32* %p, align 2 ret i32 %val } diff --git a/test/CodeGen/Thumb/dyn-stackalloc.ll b/test/CodeGen/Thumb/dyn-stackalloc.ll index 309d802..c94c904 100644 --- a/test/CodeGen/Thumb/dyn-stackalloc.ll +++ b/test/CodeGen/Thumb/dyn-stackalloc.ll @@ -12,7 +12,7 @@ define void @t1(%struct.state* %v) { ; CHECK: mov r[[R1:[0-9]+]], sp ; CHECK: subs r[[R2:[0-9]+]], r[[R1]], r[[R0]] ; CHECK: mov sp, r[[R2]] - %tmp6 = load i32* null + %tmp6 = load i32, i32* null %tmp8 = alloca float, i32 %tmp6 store i32 1, i32* null br i1 false, label %bb123.preheader, label %return @@ -22,8 +22,8 @@ bb123.preheader: bb43: call fastcc void @f1( float* %tmp8, float* null, i32 0 ) - %tmp70 = load i32* null - %tmp85 = getelementptr float* %tmp8, i32 0 + %tmp70 = load i32, i32* null + %tmp85 = getelementptr float, float* %tmp8, i32 0 call fastcc void @f2( float* null, float* null, float* %tmp85, i32 %tmp70 ) ret void @@ -60,8 +60,8 @@ define void @t2(%struct.comment* %vc, i8* %tag, i8* %contents) { %tmp6 = alloca i8, i32 %tmp5 %tmp9 = call i8* @strcpy( i8* %tmp6, i8* %tag ) %tmp6.len = call i32 @strlen( i8* %tmp6 ) - %tmp6.indexed = getelementptr i8* %tmp6, i32 %tmp6.len - call void @llvm.memcpy.p0i8.p0i8.i32(i8* %tmp6.indexed, i8* getelementptr inbounds ([2 x i8]* @str215, i32 0, i32 0), i32 2, i32 1, i1 false) + %tmp6.indexed = getelementptr i8, i8* %tmp6, i32 %tmp6.len + call void @llvm.memcpy.p0i8.p0i8.i32(i8* %tmp6.indexed, i8* getelementptr inbounds ([2 x i8], [2 x i8]* @str215, i32 0, i32 0), i32 2, i32 1, i1 false) %tmp15 = call i8* @strcat( i8* %tmp6, i8* %contents ) call fastcc void @comment_add( %struct.comment* %vc, i8* %tmp6 ) ret void diff --git a/test/CodeGen/Thumb/large-stack.ll b/test/CodeGen/Thumb/large-stack.ll index 269bdd9..0d53458 100644 --- a/test/CodeGen/Thumb/large-stack.ll +++ b/test/CodeGen/Thumb/large-stack.ll @@ -56,7 +56,7 @@ define i32 @test3() { %tmp = alloca i32, align 4 %a = alloca [805306369 x i8], align 16 store i32 0, i32* %tmp - %tmp1 = load i32* %tmp + %tmp1 = load i32, i32* %tmp ret i32 %tmp1 } diff --git a/test/CodeGen/Thumb/ldm-merge-call.ll b/test/CodeGen/Thumb/ldm-merge-call.ll index febc96b..eb78529 100644 --- a/test/CodeGen/Thumb/ldm-merge-call.ll +++ b/test/CodeGen/Thumb/ldm-merge-call.ll @@ -8,9 +8,9 @@ entry: ; CHECK-LABEL: foo: ; CHECK: ldm r[[BASE:[0-9]]]!, ; CHECK-NEXT: mov r[[BASE]], - %0 = load i32* %A, align 4 - %arrayidx1 = getelementptr inbounds i32* %A, i32 1 - %1 = load i32* %arrayidx1, align 4 + %0 = load i32, i32* %A, align 4 + %arrayidx1 = getelementptr inbounds i32, i32* %A, i32 1 + %1 = load i32, i32* %arrayidx1, align 4 %call = tail call i32 @bar(i32 %0, i32 %1, i32 %0, i32 %1) #2 %call2 = tail call i32 @bar(i32 %0, i32 %1, i32 %0, i32 %1) #2 ret void diff --git a/test/CodeGen/Thumb/ldm-merge-struct.ll b/test/CodeGen/Thumb/ldm-merge-struct.ll index 2f732e0..9815a9e 100644 --- a/test/CodeGen/Thumb/ldm-merge-struct.ll +++ b/test/CodeGen/Thumb/ldm-merge-struct.ll @@ -11,8 +11,8 @@ entry: ; CHECK-LABEL: f: ; CHECK: ldm r[[BASE:[0-9]]], ; CHECK-NEXT-NOT: subs r[[BASE]] - %0 = load i32* getelementptr inbounds (%struct.S* @s, i32 0, i32 0), align 4 - %1 = load i32* getelementptr inbounds (%struct.S* @s, i32 0, i32 1), align 4 + %0 = load i32, i32* getelementptr inbounds (%struct.S, %struct.S* @s, i32 0, i32 0), align 4 + %1 = load i32, i32* getelementptr inbounds (%struct.S, %struct.S* @s, i32 0, i32 1), align 4 %cmp = icmp sgt i32 %0, %1 %2 = sub i32 0, %1 %cond.p = select i1 %cmp, i32 %1, i32 %2 diff --git a/test/CodeGen/Thumb/ldm-stm-base-materialization.ll b/test/CodeGen/Thumb/ldm-stm-base-materialization.ll index 6382c25..916e5ea 100644 --- a/test/CodeGen/Thumb/ldm-stm-base-materialization.ll +++ b/test/CodeGen/Thumb/ldm-stm-base-materialization.ll @@ -15,11 +15,11 @@ entry: ; CHECK-NEXT: ldm r[[NLB]], ; CHECK: adds r[[NSB:[0-9]]], r[[SB]], #4 ; CHECK-NEXT: stm r[[NSB]] - %0 = load i32** @a, align 4 - %arrayidx = getelementptr inbounds i32* %0, i32 1 + %0 = load i32*, i32** @a, align 4 + %arrayidx = getelementptr inbounds i32, i32* %0, i32 1 %1 = bitcast i32* %arrayidx to i8* - %2 = load i32** @b, align 4 - %arrayidx1 = getelementptr inbounds i32* %2, i32 1 + %2 = load i32*, i32** @b, align 4 + %arrayidx1 = getelementptr inbounds i32, i32* %2, i32 1 %3 = bitcast i32* %arrayidx1 to i8* tail call void @llvm.memcpy.p0i8.p0i8.i32(i8* %1, i8* %3, i32 24, i32 4, i1 false) ret void diff --git a/test/CodeGen/Thumb/ldr_ext.ll b/test/CodeGen/Thumb/ldr_ext.ll index 2d25af3..90194ae 100644 --- a/test/CodeGen/Thumb/ldr_ext.ll +++ b/test/CodeGen/Thumb/ldr_ext.ll @@ -7,7 +7,7 @@ define i32 @test1(i8* %t1) nounwind { ; V5: ldrb ; V6: ldrb - %tmp.u = load i8* %t1 + %tmp.u = load i8, i8* %t1 %tmp1.s = zext i8 %tmp.u to i32 ret i32 %tmp1.s } @@ -16,7 +16,7 @@ define i32 @test2(i16* %t1) nounwind { ; V5: ldrh ; V6: ldrh - %tmp.u = load i16* %t1 + %tmp.u = load i16, i16* %t1 %tmp1.s = zext i16 %tmp.u to i32 ret i32 %tmp1.s } @@ -28,7 +28,7 @@ define i32 @test3(i8* %t0) nounwind { ; V6: ldrb ; V6: sxtb - %tmp.s = load i8* %t0 + %tmp.s = load i8, i8* %t0 %tmp1.s = sext i8 %tmp.s to i32 ret i32 %tmp1.s } @@ -40,7 +40,7 @@ define i32 @test4(i16* %t0) nounwind { ; V6: ldrh ; V6: sxth - %tmp.s = load i16* %t0 + %tmp.s = load i16, i16* %t0 %tmp1.s = sext i16 %tmp.s to i32 ret i32 %tmp1.s } @@ -51,7 +51,7 @@ define i32 @test5() nounwind { ; V6: movs r0, #0 ; V6: ldrsh - %tmp.s = load i16* null + %tmp.s = load i16, i16* null %tmp1.s = sext i16 %tmp.s to i32 ret i32 %tmp1.s } diff --git a/test/CodeGen/Thumb/ldr_frame.ll b/test/CodeGen/Thumb/ldr_frame.ll index 0e879d7..fdcf3b7 100644 --- a/test/CodeGen/Thumb/ldr_frame.ll +++ b/test/CodeGen/Thumb/ldr_frame.ll @@ -4,8 +4,8 @@ define i32 @f1() { ; CHECK-LABEL: f1: ; CHECK: ldr r0 %buf = alloca [32 x i32], align 4 - %tmp = getelementptr [32 x i32]* %buf, i32 0, i32 0 - %tmp1 = load i32* %tmp + %tmp = getelementptr [32 x i32], [32 x i32]* %buf, i32 0, i32 0 + %tmp1 = load i32, i32* %tmp ret i32 %tmp1 } @@ -14,8 +14,8 @@ define i32 @f2() { ; CHECK: mov r0 ; CHECK: ldrb %buf = alloca [32 x i8], align 4 - %tmp = getelementptr [32 x i8]* %buf, i32 0, i32 0 - %tmp1 = load i8* %tmp + %tmp = getelementptr [32 x i8], [32 x i8]* %buf, i32 0, i32 0 + %tmp1 = load i8, i8* %tmp %tmp2 = zext i8 %tmp1 to i32 ret i32 %tmp2 } @@ -24,8 +24,8 @@ define i32 @f3() { ; CHECK-LABEL: f3: ; CHECK: ldr r0 %buf = alloca [32 x i32], align 4 - %tmp = getelementptr [32 x i32]* %buf, i32 0, i32 32 - %tmp1 = load i32* %tmp + %tmp = getelementptr [32 x i32], [32 x i32]* %buf, i32 0, i32 32 + %tmp1 = load i32, i32* %tmp ret i32 %tmp1 } @@ -34,8 +34,8 @@ define i32 @f4() { ; CHECK: mov r0 ; CHECK: ldrb %buf = alloca [32 x i8], align 4 - %tmp = getelementptr [32 x i8]* %buf, i32 0, i32 2 - %tmp1 = load i8* %tmp + %tmp = getelementptr [32 x i8], [32 x i8]* %buf, i32 0, i32 2 + %tmp1 = load i8, i8* %tmp %tmp2 = zext i8 %tmp1 to i32 ret i32 %tmp2 } diff --git a/test/CodeGen/Thumb/long.ll b/test/CodeGen/Thumb/long.ll index 2449e5a..33f6389 100644 --- a/test/CodeGen/Thumb/long.ll +++ b/test/CodeGen/Thumb/long.ll @@ -65,7 +65,7 @@ entry: define i64 @f10() { entry: %a = alloca i64, align 8 ; <i64*> [#uses=1] - %retval = load i64* %a ; <i64> [#uses=1] + %retval = load i64, i64* %a ; <i64> [#uses=1] ret i64 %retval } diff --git a/test/CodeGen/Thumb/segmented-stacks.ll b/test/CodeGen/Thumb/segmented-stacks.ll index d6e25c7..09f5db8 100644 --- a/test/CodeGen/Thumb/segmented-stacks.ll +++ b/test/CodeGen/Thumb/segmented-stacks.ll @@ -55,7 +55,7 @@ define void @test_basic() #0 { } define i32 @test_nested(i32 * nest %closure, i32 %other) #0 { - %addend = load i32 * %closure + %addend = load i32 , i32 * %closure %result = add i32 %other, %addend %mem = alloca i32, i32 10 call void @dummy_use (i32* %mem, i32 10) diff --git a/test/CodeGen/Thumb/stack-access.ll b/test/CodeGen/Thumb/stack-access.ll index bcffda2..fded410 100644 --- a/test/CodeGen/Thumb/stack-access.ll +++ b/test/CodeGen/Thumb/stack-access.ll @@ -36,9 +36,9 @@ define i32 @test3() #0 { %x = alloca i8, align 1 %y = alloca i8, align 1 ; CHECK: ldr r0, [sp] - %1 = load i8* %x, align 1 + %1 = load i8, i8* %x, align 1 ; CHECK: ldr r1, [sp, #4] - %2 = load i8* %y, align 1 + %2 = load i8, i8* %y, align 1 %3 = add nsw i8 %1, %2 %4 = zext i8 %3 to i32 ret i32 %4 @@ -48,9 +48,9 @@ define i32 @test4() #0 { %x = alloca i16, align 2 %y = alloca i16, align 2 ; CHECK: ldr r0, [sp] - %1 = load i16* %x, align 2 + %1 = load i16, i16* %x, align 2 ; CHECK: ldr r1, [sp, #4] - %2 = load i16* %y, align 2 + %2 = load i16, i16* %y, align 2 %3 = add nsw i16 %1, %2 %4 = zext i16 %3 to i32 ret i32 %4 @@ -61,7 +61,7 @@ define zeroext i8 @test5() { %x = alloca i8, align 1 ; CHECK: mov r0, sp ; CHECK: ldrb r0, [r0] - %1 = load i8* %x, align 1 + %1 = load i8, i8* %x, align 1 ret i8 %1 } @@ -69,6 +69,59 @@ define zeroext i16 @test6() { %x = alloca i16, align 2 ; CHECK: mov r0, sp ; CHECK: ldrh r0, [r0] - %1 = load i16* %x, align 2 + %1 = load i16, i16* %x, align 2 ret i16 %1 } + +; Accessing the bottom of a large array shouldn't require materializing a base +define void @test7() { + %arr = alloca [200 x i32], align 4 + + ; CHECK: movs [[REG:r[0-9]+]], #1 + ; CHECK: str [[REG]], [sp, #4] + %arrayidx = getelementptr inbounds [200 x i32], [200 x i32]* %arr, i32 0, i32 1 + store i32 1, i32* %arrayidx, align 4 + + ; CHECK: str [[REG]], [sp, #16] + %arrayidx1 = getelementptr inbounds [200 x i32], [200 x i32]* %arr, i32 0, i32 4 + store i32 1, i32* %arrayidx1, align 4 + + ret void +} + +; Check that loads/stores with out-of-range offsets are handled correctly +define void @test8() { + %arr3 = alloca [224 x i32], align 4 + %arr2 = alloca [224 x i32], align 4 + %arr1 = alloca [224 x i32], align 4 + +; CHECK: movs [[REG:r[0-9]+]], #1 +; CHECK: str [[REG]], [sp] + %arr1idx1 = getelementptr inbounds [224 x i32], [224 x i32]* %arr1, i32 0, i32 0 + store i32 1, i32* %arr1idx1, align 4 + +; Offset in range for sp-based store, but not for non-sp-based store +; CHECK: str [[REG]], [sp, #128] + %arr1idx2 = getelementptr inbounds [224 x i32], [224 x i32]* %arr1, i32 0, i32 32 + store i32 1, i32* %arr1idx2, align 4 + +; CHECK: str [[REG]], [sp, #896] + %arr2idx1 = getelementptr inbounds [224 x i32], [224 x i32]* %arr2, i32 0, i32 0 + store i32 1, i32* %arr2idx1, align 4 + +; %arr2 is in range, but this element of it is not +; CHECK: str [[REG]], [{{r[0-9]+}}] + %arr2idx2 = getelementptr inbounds [224 x i32], [224 x i32]* %arr2, i32 0, i32 32 + store i32 1, i32* %arr2idx2, align 4 + +; %arr3 is not in range +; CHECK: str [[REG]], [{{r[0-9]+}}] + %arr3idx1 = getelementptr inbounds [224 x i32], [224 x i32]* %arr3, i32 0, i32 0 + store i32 1, i32* %arr3idx1, align 4 + +; CHECK: str [[REG]], [{{r[0-9]+}}] + %arr3idx2 = getelementptr inbounds [224 x i32], [224 x i32]* %arr3, i32 0, i32 32 + store i32 1, i32* %arr3idx2, align 4 + + ret void +} diff --git a/test/CodeGen/Thumb/stack_guard_remat.ll b/test/CodeGen/Thumb/stack_guard_remat.ll index e949cc1..41edef5 100644 --- a/test/CodeGen/Thumb/stack_guard_remat.ll +++ b/test/CodeGen/Thumb/stack_guard_remat.ll @@ -28,7 +28,7 @@ define i32 @test_stack_guard_remat() #0 { %a1 = alloca [256 x i32], align 4 %1 = bitcast [256 x i32]* %a1 to i8* call void @llvm.lifetime.start(i64 1024, i8* %1) - %2 = getelementptr inbounds [256 x i32]* %a1, i32 0, i32 0 + %2 = getelementptr inbounds [256 x i32], [256 x i32]* %a1, i32 0, i32 0 call void @foo3(i32* %2) #3 call void asm sideeffect "foo2", "~{r0},~{r1},~{r2},~{r3},~{r4},~{r5},~{r6},~{r7},~{r8},~{r9},~{r10},~{r11},~{r12},~{sp},~{lr}"() call void @llvm.lifetime.end(i64 1024, i8* %1) diff --git a/test/CodeGen/Thumb/stm-merge.ll b/test/CodeGen/Thumb/stm-merge.ll index d4b4cd2..5492ad8 100644 --- a/test/CodeGen/Thumb/stm-merge.ll +++ b/test/CodeGen/Thumb/stm-merge.ll @@ -18,7 +18,7 @@ entry: store i32 %x, i32* %i, align 4 store i32 %y, i32* %h, align 4 store i32 %z, i32* %g, align 4 - %.pr = load i32* @d, align 4 + %.pr = load i32, i32* @d, align 4 %cmp11 = icmp slt i32 %.pr, 1 br i1 %cmp11, label %for.inc.lr.ph, label %for.body5 diff --git a/test/CodeGen/Thumb/thumb-ldm.ll b/test/CodeGen/Thumb/thumb-ldm.ll index 7e9560e..8c49669 100644 --- a/test/CodeGen/Thumb/thumb-ldm.ll +++ b/test/CodeGen/Thumb/thumb-ldm.ll @@ -7,8 +7,8 @@ define i32 @t1() { ; CHECK: push {r7, lr} ; CHECK: ldm ; CHECK: pop {r7, pc} - %tmp = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 0) ; <i32> [#uses=1] - %tmp3 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 1) ; <i32> [#uses=1] + %tmp = load i32, i32* getelementptr ([0 x i32], [0 x i32]* @X, i32 0, i32 0) ; <i32> [#uses=1] + %tmp3 = load i32, i32* getelementptr ([0 x i32], [0 x i32]* @X, i32 0, i32 1) ; <i32> [#uses=1] %tmp4 = call i32 @f1( i32 %tmp, i32 %tmp3 ) ; <i32> [#uses=1] ret i32 %tmp4 } @@ -18,9 +18,9 @@ define i32 @t2() { ; CHECK: push {r7, lr} ; CHECK: ldm ; CHECK: pop {r7, pc} - %tmp = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 2) ; <i32> [#uses=1] - %tmp3 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 3) ; <i32> [#uses=1] - %tmp5 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 4) ; <i32> [#uses=1] + %tmp = load i32, i32* getelementptr ([0 x i32], [0 x i32]* @X, i32 0, i32 2) ; <i32> [#uses=1] + %tmp3 = load i32, i32* getelementptr ([0 x i32], [0 x i32]* @X, i32 0, i32 3) ; <i32> [#uses=1] + %tmp5 = load i32, i32* getelementptr ([0 x i32], [0 x i32]* @X, i32 0, i32 4) ; <i32> [#uses=1] %tmp6 = call i32 @f2( i32 %tmp, i32 %tmp3, i32 %tmp5 ) ; <i32> [#uses=1] ret i32 %tmp6 } @@ -30,9 +30,9 @@ define i32 @t3() { ; CHECK: push {r7, lr} ; CHECK: ldm ; CHECK: pop {r7, pc} - %tmp = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 1) ; <i32> [#uses=1] - %tmp3 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 2) ; <i32> [#uses=1] - %tmp5 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 3) ; <i32> [#uses=1] + %tmp = load i32, i32* getelementptr ([0 x i32], [0 x i32]* @X, i32 0, i32 1) ; <i32> [#uses=1] + %tmp3 = load i32, i32* getelementptr ([0 x i32], [0 x i32]* @X, i32 0, i32 2) ; <i32> [#uses=1] + %tmp5 = load i32, i32* getelementptr ([0 x i32], [0 x i32]* @X, i32 0, i32 3) ; <i32> [#uses=1] %tmp6 = call i32 @f2( i32 %tmp, i32 %tmp3, i32 %tmp5 ) ; <i32> [#uses=1] ret i32 %tmp6 } diff --git a/test/CodeGen/Thumb/vargs.ll b/test/CodeGen/Thumb/vargs.ll index 71e8afa..7137429 100644 --- a/test/CodeGen/Thumb/vargs.ll +++ b/test/CodeGen/Thumb/vargs.ll @@ -17,8 +17,8 @@ entry: bb: ; preds = %bb, %entry %a_addr.0 = phi i32 [ %a, %entry ], [ %tmp5, %bb ] ; <i32> [#uses=2] - %tmp = load volatile i8** %va ; <i8*> [#uses=2] - %tmp2 = getelementptr i8* %tmp, i32 4 ; <i8*> [#uses=1] + %tmp = load volatile i8*, i8** %va ; <i8*> [#uses=2] + %tmp2 = getelementptr i8, i8* %tmp, i32 4 ; <i8*> [#uses=1] store volatile i8* %tmp2, i8** %va %tmp5 = add i32 %a_addr.0, -1 ; <i32> [#uses=1] %tmp.upgrd.2 = icmp eq i32 %a_addr.0, 1 ; <i1> [#uses=1] @@ -26,8 +26,8 @@ bb: ; preds = %bb, %entry bb7: ; preds = %bb %tmp3 = bitcast i8* %tmp to i32* ; <i32*> [#uses=1] - %tmp.upgrd.3 = load i32* %tmp3 ; <i32> [#uses=1] - %tmp10 = call i32 (i8*, ...)* @printf( i8* getelementptr ([4 x i8]* @str, i32 0, i64 0), i32 %tmp.upgrd.3 ) ; <i32> [#uses=0] + %tmp.upgrd.3 = load i32, i32* %tmp3 ; <i32> [#uses=1] + %tmp10 = call i32 (i8*, ...)* @printf( i8* getelementptr ([4 x i8], [4 x i8]* @str, i32 0, i64 0), i32 %tmp.upgrd.3 ) ; <i32> [#uses=0] %va.upgrd.4 = bitcast i8** %va to i8* ; <i8*> [#uses=1] call void @llvm.va_end( i8* %va.upgrd.4 ) ret void |