xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/2009-04-scale.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=x86 -mtriple=i386-unknown-linux-gnu
2*9880d681SAndroid Build Coastguard Worker; PR3995
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Worker        %struct.vtable = type { i32 (...)** }
5*9880d681SAndroid Build Coastguard Worker	%struct.array = type { %struct.impl, [256 x %struct.pair], [256 x %struct.pair], [256 x %struct.pair], [256 x %struct.pair], [256 x %struct.pair], [256 x %struct.pair] }
6*9880d681SAndroid Build Coastguard Worker	%struct.impl = type { %struct.vtable, i8, %struct.impl*, i32, i32, i64, i64 }
7*9880d681SAndroid Build Coastguard Worker	%struct.pair = type { i64, i64 }
8*9880d681SAndroid Build Coastguard Worker
9*9880d681SAndroid Build Coastguard Workerdefine void @test() {
10*9880d681SAndroid Build Coastguard Workerentry:
11*9880d681SAndroid Build Coastguard Worker	%0 = load i32, i32* null, align 4		; <i32> [#uses=1]
12*9880d681SAndroid Build Coastguard Worker	%1 = lshr i32 %0, 8		; <i32> [#uses=1]
13*9880d681SAndroid Build Coastguard Worker	%2 = and i32 %1, 255		; <i32> [#uses=1]
14*9880d681SAndroid Build Coastguard Worker	%3 = getelementptr %struct.array, %struct.array* null, i32 0, i32 3		; <[256 x %struct.pair]*> [#uses=1]
15*9880d681SAndroid Build Coastguard Worker	%4 = getelementptr [256 x %struct.pair], [256 x %struct.pair]* %3, i32 0, i32 %2		; <%struct.pair*> [#uses=1]
16*9880d681SAndroid Build Coastguard Worker	%5 = getelementptr %struct.pair, %struct.pair* %4, i32 0, i32 1		; <i64*> [#uses=1]
17*9880d681SAndroid Build Coastguard Worker	%6 = load i64, i64* %5, align 4		; <i64> [#uses=1]
18*9880d681SAndroid Build Coastguard Worker	%7 = xor i64 0, %6		; <i64> [#uses=1]
19*9880d681SAndroid Build Coastguard Worker	%8 = xor i64 %7, 0		; <i64> [#uses=1]
20*9880d681SAndroid Build Coastguard Worker	%9 = xor i64 %8, 0		; <i64> [#uses=1]
21*9880d681SAndroid Build Coastguard Worker	store i64 %9, i64* null, align 8
22*9880d681SAndroid Build Coastguard Worker	unreachable
23*9880d681SAndroid Build Coastguard Worker}
24