// REQUIRES: hexagon-registered-target // RUN: %clang_cc1 -emit-llvm -O2 -o - -triple hexagon-unknown-elf %s | FileCheck %s // This unit test validates that the store to "dst" variable needs to be eliminated. // CHECK: @brev_store_elimination_test1 // CHECK: llvm.hexagon.L2.loadri.pbr // CHECK-NOT: store int *brev_store_elimination_test1(int *ptr, int mod) { int dst = 100; return __builtin_brev_ldw(ptr, &dst, mod); } // CHECK: @brev_store_elimination_test2 // CHECK: llvm.hexagon.L2.loadri.pbr // CHECK-NOT: store extern int add(int a); int brev_store_elimination_test2(int *ptr, int mod) { int dst = 100; __builtin_brev_ldw(ptr, &dst, mod); return add(dst); } // CHECK: @brev_store_elimination_test3 // CHECK: llvm.hexagon.L2.loadri.pbr // CHECK-NOT: store int brev_store_elimination_test3(int *ptr, int mod, int inc) { int dst = 100; for (int i = 0; i < inc; ++i) { __builtin_brev_ldw(ptr, &dst, mod); dst = add(dst); } return dst; } // brev_store_elimination_test4 validates the fact that we are not deleting the // stores if the value is passed by reference later. // CHECK: @brev_store_elimination_test4 // CHECK: llvm.hexagon.L2.loadri.pbr // CHECK: store extern int sub(int *a); int brev_store_elimination_test4(int *ptr, int mod) { int dst = 100; __builtin_brev_ldw(ptr, &dst, mod); return sub(&dst); } |