mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-27 15:28:53 -04:00

This avoids generating two gep's for common array operations. Before we would generate something like: %tmp = load i32* %X.addr ; <i32> [#uses=1] %arraydecay = getelementptr inbounds [100 x i32]* %A, i32 0, i32 0 ; <i32*> [#uses=1] %arrayidx = getelementptr inbounds i32* %arraydecay, i32 %tmp ; <i32*> [#uses=1] %tmp1 = load i32* %arrayidx ; <i32> [#uses=1] Now we generate: %tmp = load i32* %X.addr ; <i32> [#uses=1] %arrayidx = getelementptr inbounds [100 x i32]* %A, i32 0, i32 %tmp ; <i32*> [#uses=1] %tmp1 = load i32* %arrayidx ; <i32> [#uses=1] Less IR is better at -O0. llvm-svn: 106966
56 lines
1.3 KiB
C
56 lines
1.3 KiB
C
// RUN: %clang_cc1 -emit-llvm %s -o - | FileCheck %s
|
|
// CHECK: addrspace(2)
|
|
// CHECK: addrspace(3)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(3)
|
|
// CHECK: addrspace(3)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(1)
|
|
// CHECK: addrspace(2)
|
|
// CHECK: addrspace(2)
|
|
|
|
// Check the load and store are using the correct address space to access
|
|
// the variables.
|
|
|
|
#define __addr1 __attribute__((address_space(1)))
|
|
#define __addr2 __attribute__((address_space(2)))
|
|
#define __addr3 __attribute__((address_space(3)))
|
|
|
|
typedef struct Pair {
|
|
__addr2 int* a;
|
|
__addr3 int* b;
|
|
} Pair;
|
|
|
|
typedef struct S {
|
|
Pair arr[ 3 ];
|
|
} S;
|
|
|
|
void test_addrspace(__addr1 S* p1, __addr1 S* p2) {
|
|
*p1->arr[0].a = *p2->arr[1].b;
|
|
}
|