[polly] r278100 - [GPGPU] Pass parameters always by using their own type
Tobias Grosser via llvm-commits
llvm-commits at lists.llvm.org
Tue Aug 9 00:22:08 PDT 2016
Author: grosser
Date: Tue Aug 9 02:22:08 2016
New Revision: 278100
URL: http://llvm.org/viewvc/llvm-project?rev=278100&view=rev
Log:
[GPGPU] Pass parameters always by using their own type
Added:
polly/trunk/test/GPGPU/scalar-param-and-value-32-bit.ll
Modified:
polly/trunk/lib/CodeGen/PPCGCodeGeneration.cpp
Modified: polly/trunk/lib/CodeGen/PPCGCodeGeneration.cpp
URL: http://llvm.org/viewvc/llvm-project/polly/trunk/lib/CodeGen/PPCGCodeGeneration.cpp?rev=278100&r1=278099&r2=278100&view=diff
==============================================================================
--- polly/trunk/lib/CodeGen/PPCGCodeGeneration.cpp (original)
+++ polly/trunk/lib/CodeGen/PPCGCodeGeneration.cpp Tue Aug 9 02:22:08 2016
@@ -1161,8 +1161,12 @@ GPUNodeBuilder::createKernelFunctionDecl
int NumVars = isl_space_dim(Kernel->space, isl_dim_param);
- for (long i = 0; i < NumVars; i++)
- Args.push_back(Builder.getInt64Ty());
+ for (long i = 0; i < NumVars; i++) {
+ isl_id *Id = isl_space_get_dim_id(Kernel->space, isl_dim_param, i);
+ Value *Val = IDToValue[Id];
+ isl_id_free(Id);
+ Args.push_back(Val->getType());
+ }
for (auto *V : SubtreeValues)
Args.push_back(V->getType());
Added: polly/trunk/test/GPGPU/scalar-param-and-value-32-bit.ll
URL: http://llvm.org/viewvc/llvm-project/polly/trunk/test/GPGPU/scalar-param-and-value-32-bit.ll?rev=278100&view=auto
==============================================================================
--- polly/trunk/test/GPGPU/scalar-param-and-value-32-bit.ll (added)
+++ polly/trunk/test/GPGPU/scalar-param-and-value-32-bit.ll Tue Aug 9 02:22:08 2016
@@ -0,0 +1,41 @@
+; RUN: opt %loadPolly -polly-codegen-ppcg -polly-acc-dump-kernel-ir \
+; RUN: -disable-output < %s | \
+; RUN: FileCheck %s
+
+; REQUIRES: pollyacc
+;
+; void foo(float A[], int n) {
+; for (long j = 0; j < n; j++)
+; A[j + n] += 42;
+; }
+
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+
+; CHECK: define ptx_kernel void @kernel_0(i8* %MemRef_A, i32 %n)
+
+define void @foo(float* %A, i32 %n) {
+bb:
+ br label %bb1
+
+bb1: ; preds = %bb9, %bb
+ %j.0 = phi i64 [ 0, %bb ], [ %tmp10, %bb9 ]
+ %tmp = sext i32 %n to i64
+ %tmp2 = icmp slt i64 %j.0, %tmp
+ br i1 %tmp2, label %bb3, label %bb11
+
+bb3: ; preds = %bb1
+ %tmp4 = sext i32 %n to i64
+ %tmp5 = add nsw i64 %j.0, %tmp4
+ %tmp6 = getelementptr inbounds float, float* %A, i64 %tmp5
+ %tmp7 = load float, float* %tmp6, align 4
+ %tmp8 = fadd float %tmp7, 4.200000e+01
+ store float %tmp8, float* %tmp6, align 4
+ br label %bb9
+
+bb9: ; preds = %bb3
+ %tmp10 = add nuw nsw i64 %j.0, 1
+ br label %bb1
+
+bb11: ; preds = %bb1
+ ret void
+}
More information about the llvm-commits
mailing list